@carbon/charts 1.11.2 → 1.11.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +26 -0
- package/dist/{_baseEach-477c04db.js → _baseEach-326db134.js} +2 -2
- package/dist/{_baseEach-477c04db.js.map → _baseEach-326db134.js.map} +1 -1
- package/dist/{_baseEach-05847c57.mjs → _baseEach-9b6a12fa.mjs} +2 -2
- package/dist/{_baseEach-05847c57.mjs.map → _baseEach-9b6a12fa.mjs.map} +1 -1
- package/dist/angle-utils-264ed176.mjs +840 -0
- package/dist/angle-utils-264ed176.mjs.map +1 -0
- package/dist/angle-utils-ccc0d890.js +3 -0
- package/dist/angle-utils-ccc0d890.js.map +1 -0
- package/dist/chart.d.ts +1 -1
- package/dist/{choropleth-9a359c3b.mjs → choropleth-141685a0.mjs} +280 -277
- package/dist/choropleth-141685a0.mjs.map +1 -0
- package/dist/{choropleth-2f8ec4a1.js → choropleth-b1a3729f.js} +9 -9
- package/dist/choropleth-b1a3729f.js.map +1 -0
- package/dist/color-scale-utils-2cd523be.js +2 -0
- package/dist/color-scale-utils-2cd523be.js.map +1 -0
- package/dist/color-scale-utils-b9604b2c.mjs +3335 -0
- package/dist/color-scale-utils-b9604b2c.mjs.map +1 -0
- package/dist/components/index.js +1 -1
- package/dist/components/index.mjs +4 -4
- package/dist/demo/charts/index.d.ts +9 -6
- package/dist/demo/index.js +197 -193
- package/dist/demo/index.js.map +1 -1
- package/dist/demo/index.mjs +2119 -1592
- package/dist/demo/index.mjs.map +1 -1
- package/dist/demo/utils/index.d.ts +1 -1
- package/dist/demo/utils/package-versions.d.ts +20 -0
- package/dist/demo/utils/stackblitz/angular.d.ts +3 -0
- package/dist/demo/utils/stackblitz/index.d.ts +5 -0
- package/dist/demo/utils/stackblitz/react.d.ts +3 -0
- package/dist/demo/utils/stackblitz/svelte.d.ts +3 -0
- package/dist/demo/utils/stackblitz/vanilla-js.d.ts +3 -0
- package/dist/demo/utils/stackblitz/vue.d.ts +3 -0
- package/dist/{index-e425a7b5.mjs → index-4b5d1e49.mjs} +3 -3
- package/dist/{index-e425a7b5.mjs.map → index-4b5d1e49.mjs.map} +1 -1
- package/dist/{index-4203ca23.js → index-eace9da9.js} +2 -2
- package/dist/{index-4203ca23.js.map → index-eace9da9.js.map} +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +126 -125
- package/dist/index.mjs.map +1 -1
- package/dist/model/index.js +1 -1
- package/dist/model/index.js.map +1 -1
- package/dist/model/index.mjs +34 -34
- package/dist/model/index.mjs.map +1 -1
- package/dist/services/index.js +1 -1
- package/dist/services/index.mjs +10 -10
- package/package.json +5 -5
- package/dist/angle-utils-512bc5cd.js +0 -2
- package/dist/angle-utils-512bc5cd.js.map +0 -1
- package/dist/angle-utils-7255d1d9.mjs +0 -387
- package/dist/angle-utils-7255d1d9.mjs.map +0 -1
- package/dist/choropleth-2f8ec4a1.js.map +0 -1
- package/dist/choropleth-9a359c3b.mjs.map +0 -1
- package/dist/color-scale-utils-222feda6.mjs +0 -3815
- package/dist/color-scale-utils-222feda6.mjs.map +0 -1
- package/dist/color-scale-utils-79786095.js +0 -3
- package/dist/color-scale-utils-79786095.js.map +0 -1
- package/dist/demo/utils/sandbox.d.ts +0 -36
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@carbon/charts",
|
|
3
|
-
"version": "1.11.
|
|
3
|
+
"version": "1.11.4",
|
|
4
4
|
"description": "Carbon Charts component library",
|
|
5
5
|
"module": "./dist/index.mjs",
|
|
6
6
|
"main": "./dist/index.js",
|
|
@@ -90,7 +90,7 @@
|
|
|
90
90
|
"d3-cloud": "^1.2.5",
|
|
91
91
|
"d3-sankey": "^0.12.3",
|
|
92
92
|
"date-fns": "^2.30.0",
|
|
93
|
-
"
|
|
93
|
+
"html-to-image": "^1.11.11",
|
|
94
94
|
"lodash-es": "^4.17.21",
|
|
95
95
|
"topojson-client": "^3.1.0",
|
|
96
96
|
"tslib": "^2.6.0"
|
|
@@ -134,7 +134,7 @@
|
|
|
134
134
|
"@typescript-eslint/parser": "^5.60.1",
|
|
135
135
|
"concurrently": "^8.2.0",
|
|
136
136
|
"downlevel-dts": "^0.11.0",
|
|
137
|
-
"eslint": "^8.
|
|
137
|
+
"eslint": "^8.44.0",
|
|
138
138
|
"eslint-config-prettier": "^8.8.0",
|
|
139
139
|
"eslint-plugin-storybook": "^0.6.12",
|
|
140
140
|
"jsdom": "^22.1.0",
|
|
@@ -145,7 +145,7 @@
|
|
|
145
145
|
"sass": "^1.63.6",
|
|
146
146
|
"storybook": "^7.0.24",
|
|
147
147
|
"typedoc": "^0.24.8",
|
|
148
|
-
"typescript": "^5.1.
|
|
148
|
+
"typescript": "^5.1.6",
|
|
149
149
|
"vite": "^4.3.9",
|
|
150
150
|
"vite-plugin-dts": "^2.3.0",
|
|
151
151
|
"vitest": "^0.32.2"
|
|
@@ -192,5 +192,5 @@
|
|
|
192
192
|
"url": "https://github.com/theiliad"
|
|
193
193
|
}
|
|
194
194
|
],
|
|
195
|
-
"gitHead": "
|
|
195
|
+
"gitHead": "cb00c7db04f1add0754b99336bfd98ad1967a84f"
|
|
196
196
|
}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";const h=require("d3"),f=require("./color-scale-utils-79786095.js"),a=require("./enums-aa2efd99.js");var z=/\s/;function P(s){for(var e=s.length;e--&&z.test(s.charAt(e)););return e}var k=/^\s+/;function V(s){return s&&s.slice(0,P(s)+1).replace(k,"")}var H=0/0,$=/^[-+]0x[0-9a-f]+$/i,q=/^0b[01]+$/i,W=/^0o[0-7]+$/i,U=parseInt;function w(s){if(typeof s=="number")return s;if(f.isSymbol(s))return H;if(f.isObject(s)){var e=typeof s.valueOf=="function"?s.valueOf():s;s=f.isObject(e)?e+"":e}if(typeof s!="string")return s===0?s:+s;s=V(s);var t=q.test(s);return t||W.test(s)?U(s.slice(2),t?2:8):$.test(s)?H:+s}var _=function(){return f.root.Date.now()};const v=_;var j="Expected a function",J=Math.max,X=Math.min;function L(s,e,t){var n,i,o,r,c,u,g=0,y=!1,m=!1,d=!0;if(typeof s!="function")throw new TypeError(j);e=w(e)||0,f.isObject(t)&&(y=!!t.leading,m="maxWait"in t,o=m?J(w(t.maxWait)||0,e):o,d="trailing"in t?!!t.trailing:d);function p(l){var x=n,b=i;return n=i=void 0,g=l,r=s.apply(b,x),r}function S(l){return g=l,c=setTimeout(C,e),y?p(l):r}function T(l){var x=l-u,b=l-g,F=e-x;return m?X(F,o-b):F}function M(l){var x=l-u,b=l-g;return u===void 0||x>=e||x<0||m&&b>=o}function C(){var l=v();if(M(l))return R(l);c=setTimeout(C,T(l))}function R(l){return c=void 0,d&&n?p(l):(n=i=void 0,r)}function O(){c!==void 0&&clearTimeout(c),g=0,n=u=i=c=void 0}function G(){return c===void 0?r:R(v())}function I(){var l=v(),x=M(l);if(n=arguments,i=this,u=l,x){if(c===void 0)return S(u);if(m)return clearTimeout(c),c=setTimeout(C,e),p(u)}return c===void 0&&(c=setTimeout(C,e)),r}return I.cancel=O,I.flush=G,I}class A{constructor(e,t){this.model=e,this.services=t,this.init()}init(){}update(){}setModel(e){this.model=e}setServices(e){this.services=e}}const Y="DONT_STYLE_ME_css_styles_verifier";class D extends A{constructor(e,t){super(e,t),this.chartID=""}static getHTMLElementSize(e){return{width:e.clientWidth,height:e.clientHeight}}static getSVGElementSize(e,t={useAttrs:!1,useClientDimensions:!1,useBBox:!1,useBoundingRect:!1}){e.attr||(e=h.select(e));const n={width:0,height:0},i=d=>{d&&Object.keys(n).forEach(p=>{if(d[p]){const S=d[p],T=parseFloat(S);S&&T>n[p]&&(""+S).indexOf("%")===-1&&(n[p]=T)}})},o={width:e.attr("width"),height:e.attr("height")},r=e.node();let c,u,g,y;try{typeof r.getBBox=="function"&&(c=r.getBBox(),u={width:c.width,height:c.height})}catch(d){console.error(d)}try{typeof(r==null?void 0:r.getBoundingClientRect)=="function"&&(g=r.getBoundingClientRect(),y={width:g.width,height:g.height})}catch(d){console.error(d)}let m;if(r instanceof SVGSVGElement&&(m={width:r.clientWidth,height:r.clientHeight}),t){if(t.useAttrs&&(i(o),n.width>0&&n.height>0))return n;if(t.useClientDimensions&&(i(m),n.width>0&&n.height>0))return m;if(t.useBBox&&(i(u),n.width>0&&n.height>0))return u;if(t.useBoundingRect&&(i(y),n.width>0&&n.height>0))return y}try{const d={width:f.getProperty(e.node(),"width","baseVal","value"),height:f.getProperty(e.node(),"height","baseVal","value")};i(d)}catch{i(m),i(u),i(o)}return n}static appendOrSelect(e,t){const n=e.select(`${t}`);if(n.empty()){let i=t.split("#"),o,r;return i.length===2?(o=i[0],i=i[1].split("."),r=i[0]):(i=t.split("."),o=i[0]),e.append(o).attr("id",r).attr("class",i.slice(1).join(" "))}return n}init(){this.styleHolderElement(),this.initializeID(),this.addMainContainer(),this.model.getOptions().resizable&&this.addResizeListener(),this.addHolderListeners(),this.handleFullscreenChange()}getChartID(){return this.chartID}generateElementIDString(e){return`chart-${this.chartID}-${e}`}initializeID(){this.chartID=Math.floor((1+Math.random())*281474976710656).toString(16)}addMainContainer(){const e=this.model.getOptions(),t=f.getProperty(e,"style","prefix"),n=h.select(this.getHolder()).append("div").classed(`${f.carbonPrefix}--${t}--chart-wrapper`,!0).attr("id",`chart-${this.getChartID()}`).style("height","100%").style("width","100%");n.append("g").attr("class",Y),this.mainContainer=n.node()}update(){this.styleHolderElement()}styleHolderElement(){const e=this.getHolder(),{width:t,height:n,theme:i}=this.model.getOptions();t!==this.width&&(e.style.width=t,this.width=t),n!==this.height&&(e.style.height=n,this.height=n),h.select(this.getHolder()).classed(`${f.carbonPrefix}--chart-holder`,!0).attr("data-carbon-theme",i)}getHolder(){return this.model.get("holder")}exportToJPG(){const e=this,t=this.getHolder(),n=h.select(t);n.classed("filled",!0),f.domToImage.toJpeg(this.getMainContainer(),{bgcolor:typeof window<"u"?window.getComputedStyle(t).getPropertyValue("background-color"):void 0,quality:1,filter:i=>!(i.classList&&i.classList.contains("cds--cc--toolbar"))}).then(function(i){var o;(o=e.services.files)==null||o.downloadImage(i,"myChart.jpg"),n.classed("filled",!1)})}exportToPNG(){const e=this,t=this.getHolder(),n=h.select(t);n.classed("filled",!0),f.domToImage.toPng(this.getMainContainer(),{bgcolor:typeof window<"u"?window.getComputedStyle(t).getPropertyValue("background-color"):void 0,quality:1,filter:i=>!(i.classList&&i.classList.contains("cds--cc--toolbar"))}).then(function(i){var o;(o=e.services.files)==null||o.downloadImage(i,"myChart.png"),n.classed("filled",!1)}).catch(function(i){console.error("oops, something went wrong!",i)})}toggleFullscreen(){const e=this.getHolder();h.select(e).classed("fullscreen")&&(document.fullscreenElement||document.webkitFullscreenElement||document.mozFullScreenElement||document.msFullscreenElement)?document.exitFullscreen?document.exitFullscreen():document.webkitExitFullscreen?document.webkitExitFullscreen():document.mozCancelFullScreen?document.mozCancelFullScreen():document.msExitFullscreen&&document.msExitFullscreen():e.requestFullscreen?e.requestFullscreen():e.webkitRequestFullscreen?e.webkitRequestFullscreen():e.mozRequestFullScreen?e.mozRequestFullScreen():e.msRequestFullscreen&&e.msRequestFullscreen()}handleFullscreenChange(){document.addEventListener("fullscreenchange",()=>{const e=h.select(this.getHolder()),t=e.classed("fullscreen");e.classed("fullscreen",!t)})}setSVGMaxHeight(){if(!this.model.getOptions().height){const{height:e}=D.getSVGElementSize(h.select(this.mainContainer),{useBBox:!0}),t=h.select(this.mainContainer).attr("class"),n=h.select(this.mainContainer).selectAll(`.${t} > svg`);let i=0;n.nodes().forEach(function(o){i+=Number(D.getSVGElementSize(h.select(o),{useBBox:!0}).height)}),i<=e?h.select(this.mainContainer).attr("height",i):h.select(this.mainContainer).attr("height","100%")}}getMainContainer(){return this.mainContainer}addHolderListeners(){const e=this.getHolder();e&&h.select(e).on("mouseover",()=>{var t;(t=this.services.events)==null||t.dispatchEvent(a.Events.Chart.MOUSEOVER)}).on("mouseout",()=>{var t;(t=this.services.events)==null||t.dispatchEvent(a.Events.Chart.MOUSEOUT)})}addResizeListener(){const e=this.getHolder();if(!e)return;let t=e.clientWidth,n=e.clientHeight;const i=L(()=>{var r;e&&(Math.abs(t-e.clientWidth)>1||Math.abs(n-e.clientHeight)>1)&&(t=e.clientWidth,n=e.clientHeight,(r=this.services.events)==null||r.dispatchEvent(a.Events.Chart.RESIZE))},12.5);new ResizeObserver(i).observe(e)}}class B extends A{static appendOrUpdateLinearGradient(e){let t=e.svg.select(`defs linearGradient#${e.id}`);t.empty()&&(t=e.svg.append("defs").append("linearGradient").attr("id",e.id).attr("x1",e.x1).attr("x2",e.x2).attr("y1",e.y1).attr("y2",e.y2)),t.selectAll("stop").remove(),t.selectAll("stop").data(e.stops).enter().append("stop").attr("offset",n=>n.offset).style("stop-color",n=>n.color).style("stop-opacity",n=>n.opacity)}static getOffsetRatio(e){return(Math.abs(e[1])*100/Math.abs(e[0]-e[1])).toFixed(2)+"%"}static getStops(e,t){const n=e[0]<0&&e[1]>0;let i=[{offset:"0%",color:t,opacity:"0.6"},{offset:"80%",color:t,opacity:"0"}];return n&&(i=[{offset:"0%",color:t,opacity:"0.6"},{offset:B.getOffsetRatio(e),color:t,opacity:"0"},{offset:"100%",color:t,opacity:"0.6"}]),i}}function Z(s){const e=Q(N(s),360);return E(e,[0,10])||E(e,[350,0])?{textAnchor:a.TextAnchor.START,dominantBaseline:a.DominantBaseline.MIDDLE}:E(e,[10,80])?{textAnchor:a.TextAnchor.START,dominantBaseline:a.DominantBaseline.HANGING}:E(e,[80,100])?{textAnchor:a.TextAnchor.MIDDLE,dominantBaseline:a.DominantBaseline.HANGING}:E(e,[100,170])?{textAnchor:a.TextAnchor.END,dominantBaseline:a.DominantBaseline.HANGING}:E(e,[170,190])?{textAnchor:a.TextAnchor.END,dominantBaseline:a.DominantBaseline.MIDDLE}:E(e,[190,260])?{textAnchor:a.TextAnchor.END,dominantBaseline:a.DominantBaseline.BASELINE}:E(e,[260,280])?{textAnchor:a.TextAnchor.MIDDLE,dominantBaseline:a.DominantBaseline.BASELINE}:{textAnchor:a.TextAnchor.START,dominantBaseline:a.DominantBaseline.BASELINE}}function Q(s,e){return(s%e+e)%e}function E(s,[e,t]){return s>=e&&s<=t}function N(s){return s*(180/Math.PI)}function K(s){return s*(Math.PI/180)}function ee(s,e,t={x:0,y:0}){const n=e*Math.cos(s)+t.x,i=e*Math.sin(s)+t.y;return{x:isNaN(n)?0:n,y:isNaN(i)?0:i}}function te(s,e){return e*Math.sin(s-Math.PI/2)}exports.DOMUtils=D;exports.GradientUtils=B;exports.Service=A;exports.debounce=L;exports.degToRad=K;exports.distanceBetweenPointOnCircAndVerticalDiameter=te;exports.polarToCartesianCoords=ee;exports.radToDeg=N;exports.radialLabelPlacement=Z;exports.toNumber=w;
|
|
2
|
-
//# sourceMappingURL=angle-utils-512bc5cd.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"angle-utils-512bc5cd.js","sources":["../node_modules/lodash-es/_trimmedEndIndex.js","../node_modules/lodash-es/_baseTrim.js","../node_modules/lodash-es/toNumber.js","../node_modules/lodash-es/now.js","../node_modules/lodash-es/debounce.js","../src/services/service.ts","../src/services/essentials/dom-utils.ts","../src/services/essentials/gradient-utils.ts","../src/services/angle-utils.ts"],"sourcesContent":["/** Used to match a single whitespace character. */\nvar reWhitespace = /\\s/;\n\n/**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last non-whitespace\n * character of `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the index of the last non-whitespace character.\n */\nfunction trimmedEndIndex(string) {\n var index = string.length;\n\n while (index-- && reWhitespace.test(string.charAt(index))) {}\n return index;\n}\n\nexport default trimmedEndIndex;\n","import trimmedEndIndex from './_trimmedEndIndex.js';\n\n/** Used to match leading whitespace. */\nvar reTrimStart = /^\\s+/;\n\n/**\n * The base implementation of `_.trim`.\n *\n * @private\n * @param {string} string The string to trim.\n * @returns {string} Returns the trimmed string.\n */\nfunction baseTrim(string) {\n return string\n ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, '')\n : string;\n}\n\nexport default baseTrim;\n","import baseTrim from './_baseTrim.js';\nimport isObject from './isObject.js';\nimport isSymbol from './isSymbol.js';\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = baseTrim(value);\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nexport default toNumber;\n","import root from './_root.js';\n\n/**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n * console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\nvar now = function() {\n return root.Date.now();\n};\n\nexport default now;\n","import isObject from './isObject.js';\nimport now from './now.js';\nimport toNumber from './toNumber.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n nativeMin = Math.min;\n\n/**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked. The debounced function comes with a `cancel` method to cancel\n * delayed `func` invocations and a `flush` method to immediately invoke them.\n * Provide `options` to indicate whether `func` should be invoked on the\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\n * with the last arguments provided to the debounced function. Subsequent\n * calls to the debounced function return the result of the last `func`\n * invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the debounced function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.debounce` and `_.throttle`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to debounce.\n * @param {number} [wait=0] The number of milliseconds to delay.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=false]\n * Specify invoking on the leading edge of the timeout.\n * @param {number} [options.maxWait]\n * The maximum time `func` is allowed to be delayed before it's invoked.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new debounced function.\n * @example\n *\n * // Avoid costly calculations while the window size is in flux.\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\n *\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\n * 'leading': true,\n * 'trailing': false\n * }));\n *\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\n * var source = new EventSource('/stream');\n * jQuery(source).on('message', debounced);\n *\n * // Cancel the trailing debounced invocation.\n * jQuery(window).on('popstate', debounced.cancel);\n */\nfunction debounce(func, wait, options) {\n var lastArgs,\n lastThis,\n maxWait,\n result,\n timerId,\n lastCallTime,\n lastInvokeTime = 0,\n leading = false,\n maxing = false,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n wait = toNumber(wait) || 0;\n if (isObject(options)) {\n leading = !!options.leading;\n maxing = 'maxWait' in options;\n maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n\n function invokeFunc(time) {\n var args = lastArgs,\n thisArg = lastThis;\n\n lastArgs = lastThis = undefined;\n lastInvokeTime = time;\n result = func.apply(thisArg, args);\n return result;\n }\n\n function leadingEdge(time) {\n // Reset any `maxWait` timer.\n lastInvokeTime = time;\n // Start the timer for the trailing edge.\n timerId = setTimeout(timerExpired, wait);\n // Invoke the leading edge.\n return leading ? invokeFunc(time) : result;\n }\n\n function remainingWait(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime,\n timeWaiting = wait - timeSinceLastCall;\n\n return maxing\n ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke)\n : timeWaiting;\n }\n\n function shouldInvoke(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime;\n\n // Either this is the first call, activity has stopped and we're at the\n // trailing edge, the system time has gone backwards and we're treating\n // it as the trailing edge, or we've hit the `maxWait` limit.\n return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\n (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\n }\n\n function timerExpired() {\n var time = now();\n if (shouldInvoke(time)) {\n return trailingEdge(time);\n }\n // Restart the timer.\n timerId = setTimeout(timerExpired, remainingWait(time));\n }\n\n function trailingEdge(time) {\n timerId = undefined;\n\n // Only invoke if we have `lastArgs` which means `func` has been\n // debounced at least once.\n if (trailing && lastArgs) {\n return invokeFunc(time);\n }\n lastArgs = lastThis = undefined;\n return result;\n }\n\n function cancel() {\n if (timerId !== undefined) {\n clearTimeout(timerId);\n }\n lastInvokeTime = 0;\n lastArgs = lastCallTime = lastThis = timerId = undefined;\n }\n\n function flush() {\n return timerId === undefined ? result : trailingEdge(now());\n }\n\n function debounced() {\n var time = now(),\n isInvoking = shouldInvoke(time);\n\n lastArgs = arguments;\n lastThis = this;\n lastCallTime = time;\n\n if (isInvoking) {\n if (timerId === undefined) {\n return leadingEdge(lastCallTime);\n }\n if (maxing) {\n // Handle invocations in a tight loop.\n clearTimeout(timerId);\n timerId = setTimeout(timerExpired, wait);\n return invokeFunc(lastCallTime);\n }\n }\n if (timerId === undefined) {\n timerId = setTimeout(timerExpired, wait);\n }\n return result;\n }\n debounced.cancel = cancel;\n debounced.flush = flush;\n return debounced;\n}\n\nexport default debounce;\n","import type { ChartModel } from '@/model/model'\nimport type { Services } from '@/interfaces/services'\n\nexport class Service {\n\tprotected model: ChartModel\n\tprotected services: Services\n\n\tconstructor(model: ChartModel, services: Services) {\n\t\tthis.model = model\n\t\tthis.services = services\n\n\t\tthis.init()\n\t}\n\n\tinit() {\n\t\t// do nothing.\n\t}\n\n\tupdate() {\n\t\t// do nothing.\n\t}\n\n\t// Used to pass down information to the components\n\tsetModel(newObj: ChartModel) {\n\t\tthis.model = newObj\n\t}\n\n\t// Used to pass down services to the components\n\tsetServices(newObj: Services) {\n\t\tthis.services = newObj\n\t}\n}\n","import { select, type Selection } from 'd3'\nimport domToImage from 'dom-to-image-more'\nimport { debounce, getProperty } from '@/tools'\nimport { carbonPrefix } from '@/configuration-non-customizable' // CSS prefix\nimport type { ChartModel } from '@/model/model'\nimport { Service } from '@/services/service'\nimport { Events } from '@/interfaces/enums'\n\nconst CSS_VERIFIER_ELEMENT_CLASSNAME = 'DONT_STYLE_ME_css_styles_verifier'\n\n// Functions like validateAndSetDimensions() may return strings or numbers\nexport interface Dimensions {\n height: number\n width: number\n}\n\nexport interface getSVGElementSizeOptions {\n\tuseAttrs?: boolean\n\tuseClientDimensions?: boolean\n\tuseBBox?: boolean\n\tuseBoundingRect?: boolean\n}\n\nexport class DOMUtils extends Service {\n\tprivate chartID = '' // initialized in initializeID() called by init()\n\n\tconstructor(model: ChartModel, services: any) {\n\t\tsuper(model, services)\n\t}\n\n\tstatic getHTMLElementSize(element: HTMLElement) {\n\t\treturn {\n\t\t\twidth: element.clientWidth,\n\t\t\theight: element.clientHeight\n\t\t}\n\t}\n\n\tstatic getSVGElementSize(\n\t\tsvgSelector: Selection<SVGGraphicsElement, any, Element, any>,\n\t\toptions: getSVGElementSizeOptions = {\n\t\t\tuseAttrs: false,\n\t\t\tuseClientDimensions: false,\n\t\t\tuseBBox: false,\n\t\t\tuseBoundingRect: false\n\t\t}\n\t) {\n\t\tif (!svgSelector.attr) {\n\t\t\tsvgSelector = select<SVGGraphicsElement, any>(svgSelector as any) // issue with @types/d3 - select can handle Selection parameters just fine\n\t\t}\n\n\t\tconst finalDimensions = {\n\t\t\twidth: 0,\n\t\t\theight: 0\n\t\t}\n\n\t\t// Dimensions can be width and height as numbers or strings\n\t\tconst validateAndSetDimensions = (dimensions: any) => {\n\t\t\tif (dimensions) {\n\t\t\t\tObject.keys(finalDimensions).forEach((dimensionKey: 'width' | 'height') => {\n\t\t\t\t\tif (dimensions[dimensionKey]) {\n\t\t\t\t\t\tconst dimension = dimensions[dimensionKey]\n\t\t\t\t\t\tconst dimensionNumber = parseFloat(dimension)\n\t\t\t\t\t\tif (\n\t\t\t\t\t\t\tdimension &&\n\t\t\t\t\t\t\tdimensionNumber > finalDimensions[dimensionKey] &&\n\t\t\t\t\t\t\t('' + dimension).indexOf('%') === -1\n\t\t\t\t\t\t) {\n\t\t\t\t\t\t\tfinalDimensions[dimensionKey] = dimensionNumber\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\n\t\tconst attrDimensions = {\n\t\t\twidth: svgSelector.attr('width'),\n\t\t\theight: svgSelector.attr('height')\n\t\t}\n\n\t\tconst svgElement = svgSelector.node()\n\n\t\tlet bbox: DOMRect,\n\t\t\tbboxDimensions: Dimensions,\n\t\t\tboundingRect: DOMRect,\n\t\t\tboundingRectDimensions: Dimensions\n\n\t\ttry {\n\t\t\t// Not all SVG graphics elements have bounding boxes (eg <defs>, <title>, <styles>)\n\t\t\tif (typeof svgElement.getBBox === 'function') {\n\t\t\t\tbbox = svgElement.getBBox()\n\t\t\t\tbboxDimensions = {\n\t\t\t\t\twidth: bbox.width,\n\t\t\t\t\theight: bbox.height\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (e) {\n\t\t\tconsole.error(e)\n\t\t}\n\n\t\ttry {\n\t\t\t// Not all SVG graphics elements have...\n\t\t\tif (typeof svgElement?.getBoundingClientRect === 'function') {\n\t\t\t\tboundingRect = svgElement.getBoundingClientRect()\n\t\t\t\tboundingRectDimensions = {\n\t\t\t\t\twidth: boundingRect.width,\n\t\t\t\t\theight: boundingRect.height\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (e) {\n\t\t\tconsole.error(e)\n\t\t}\n\n\t\t// Not all SVG graphics elements have...\n\t\tlet clientDimensions: Dimensions\n\t\tif (svgElement instanceof SVGSVGElement) {\n\t\t\tclientDimensions = {\n\t\t\t\twidth: svgElement.clientWidth,\n\t\t\t\theight: svgElement.clientHeight\n\t\t\t}\n\t\t}\n\n\t\t// If both attribute values are numbers\n\t\t// And not percentages or NaN\n\t\tif (options) {\n\t\t\tif (options.useAttrs) {\n\t\t\t\tvalidateAndSetDimensions(attrDimensions)\n\n\t\t\t\tif (finalDimensions.width > 0 && finalDimensions.height > 0) {\n\t\t\t\t\treturn finalDimensions\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (options.useClientDimensions) {\n\t\t\t\tvalidateAndSetDimensions(clientDimensions)\n\n\t\t\t\tif (finalDimensions.width > 0 && finalDimensions.height > 0) {\n\t\t\t\t\treturn clientDimensions\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (options.useBBox) {\n\t\t\t\tvalidateAndSetDimensions(bboxDimensions)\n\n\t\t\t\tif (finalDimensions.width > 0 && finalDimensions.height > 0) {\n\t\t\t\t\treturn bboxDimensions\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (options.useBoundingRect) {\n\t\t\t\tvalidateAndSetDimensions(boundingRectDimensions)\n\n\t\t\t\tif (finalDimensions.width > 0 && finalDimensions.height > 0) {\n\t\t\t\t\treturn boundingRectDimensions\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\ttry {\n\t\t\tconst nativeDimensions = {\n\t\t\t\twidth: getProperty(svgSelector.node(), 'width', 'baseVal', 'value'),\n\t\t\t\theight: getProperty(svgSelector.node(), 'height', 'baseVal', 'value')\n\t\t\t}\n\n\t\t\tvalidateAndSetDimensions(nativeDimensions)\n\t\t} catch (e) {\n\t\t\tvalidateAndSetDimensions(clientDimensions)\n\t\t\tvalidateAndSetDimensions(bboxDimensions)\n\t\t\tvalidateAndSetDimensions(attrDimensions)\n\t\t}\n\t\treturn finalDimensions\n\t}\n\n\tstatic appendOrSelect(parent: Selection<SVGElement | HTMLDivElement, any, Element, any>, query: string) {\n\t\tconst selection = parent.select(`${query}`)\n\n\t\tif (selection.empty()) {\n\t\t\t// see if there is an id\n\t\t\tlet querySections = query.split('#')\n\t\t\tlet elementToAppend: any\n\t\t\tlet id: string\n\t\t\t// if there is an id\n\t\t\tif (querySections.length === 2) {\n\t\t\t\t// take out the element to append\n\t\t\t\telementToAppend = querySections[0]\n\t\t\t\t// split it by classes\n\t\t\t\tquerySections = querySections[1].split('.')\n\t\t\t\t// the first string is the id\n\t\t\t\tid = querySections[0]\n\t\t\t} else {\n\t\t\t\tquerySections = query.split('.')\n\t\t\t\telementToAppend = querySections[0]\n\t\t\t}\n\n\t\t\treturn parent\n\t\t\t\t.append(elementToAppend)\n\t\t\t\t.attr('id', id)\n\t\t\t\t.attr('class', querySections.slice(1).join(' '))\n\t\t}\n\n\t\treturn selection\n\t}\n\n\tprotected mainContainer: HTMLDivElement\n\tprotected width: string\n\tprotected height: string\n\n\tinit() {\n\t\t// Add width & height to the chart holder if necessary, and add a classname\n\t\tthis.styleHolderElement()\n\n\t\t// Initialize chart ID\n\t\tthis.initializeID()\n\n\t\tthis.addMainContainer()\n\n\t\tif (this.model.getOptions().resizable) {\n\t\t\tthis.addResizeListener()\n\t\t}\n\n\t\tthis.addHolderListeners()\n\n\t\tthis.handleFullscreenChange()\n\t}\n\n\tgetChartID() {\n\t\treturn this.chartID\n\t}\n\n\tgenerateElementIDString(originalID: string | number) {\n\t\treturn `chart-${this.chartID}-${originalID}`\n\t}\n\n\tprivate initializeID() {\n\t\tthis.chartID = Math.floor((1 + Math.random()) * 0x1000000000000).toString(16)\n\t}\n\n\taddMainContainer() {\n\t\tconst options = this.model.getOptions()\n\t\tconst chartsprefix = getProperty(options, 'style', 'prefix')\n\n\t\tconst mainContainer = select(this.getHolder())\n\t\t\t.append('div')\n\t\t\t.classed(`${carbonPrefix}--${chartsprefix}--chart-wrapper`, true)\n\t\t\t.attr('id', `chart-${this.getChartID()}`)\n\t\t\t.style('height', '100%')\n\t\t\t.style('width', '100%')\n\n\t\tmainContainer.append('g').attr('class', CSS_VERIFIER_ELEMENT_CLASSNAME)\n\n\t\tthis.mainContainer = mainContainer.node()\n\t}\n\n\tupdate() {\n\t\tthis.styleHolderElement()\n\t}\n\n\tstyleHolderElement() {\n\t\tconst holderElement = this.getHolder() as HTMLElement\n\n\t\t// In order for resize events to not clash with these updates\n\t\t// We'll check if the width & height values passed in options\n\t\t// Have changed, before setting them to the holder\n\t\tconst { width, height, theme } = this.model.getOptions()\n\t\tif (width !== this.width) {\n\t\t\t// Apply formatted width attribute to chart\n\t\t\tholderElement.style.width = width\n\n\t\t\tthis.width = width\n\t\t}\n\n\t\tif (height !== this.height) {\n\t\t\t// Apply formatted width attribute to chart\n\t\t\tholderElement.style.height = height\n\n\t\t\tthis.height = height\n\t\t}\n\n\t\t// Add class to chart holder\n\t\tselect(this.getHolder())\n\t\t\t.classed(`${carbonPrefix}--chart-holder`, true)\n\t\t\t.attr('data-carbon-theme', theme)\n\t}\n\n\tgetHolder() {\n\t\treturn this.model.get('holder')\n\t}\n\n\texportToJPG() {\n\t\tconst self = this\n\n\t\tconst holder = this.getHolder()\n\t\tconst holderSelection = select(holder)\n\t\tholderSelection.classed('filled', true)\n\n\t\tdomToImage\n\t\t\t.toJpeg(this.getMainContainer(), {\n\t\t\t\tbgcolor:\n\t\t\t\t\ttypeof window !== 'undefined'\n\t\t\t\t\t\t? window.getComputedStyle(holder).getPropertyValue('background-color')\n\t\t\t\t\t\t: undefined,\n\t\t\t\tquality: 1,\n\t\t\t\t// Remove the toolbar\n\t\t\t\tfilter: (node: any) => {\n\t\t\t\t\tif (node.classList && node.classList.contains('cds--cc--toolbar')) {\n\t\t\t\t\t\treturn false\n\t\t\t\t\t}\n\n\t\t\t\t\treturn true\n\t\t\t\t}\n\t\t\t})\n\t\t\t.then(function (dataUrl: string) {\n\t\t\t\tself.services.files?.downloadImage(dataUrl, 'myChart.jpg')\n\t\t\t\tholderSelection.classed('filled', false)\n\t\t\t})\n\t}\n\n\texportToPNG() {\n\t\tconst self = this\n\n\t\tconst holder = this.getHolder()\n\t\tconst holderSelection = select(holder)\n\t\tholderSelection.classed('filled', true)\n\n\t\tdomToImage\n\t\t\t.toPng(this.getMainContainer(), {\n\t\t\t\tbgcolor:\n\t\t\t\t\ttypeof window !== 'undefined'\n\t\t\t\t\t\t? window.getComputedStyle(holder).getPropertyValue('background-color')\n\t\t\t\t\t\t: undefined,\n\t\t\t\tquality: 1,\n\t\t\t\t// Remove the toolbar\n\t\t\t\tfilter: (node: HTMLElement) => {\n\t\t\t\t\tif (node.classList && node.classList.contains('cds--cc--toolbar')) {\n\t\t\t\t\t\treturn false\n\t\t\t\t\t}\n\n\t\t\t\t\treturn true\n\t\t\t\t}\n\t\t\t})\n\t\t\t.then(function (dataUrl: string) {\n\t\t\t\tself.services.files?.downloadImage(dataUrl, 'myChart.png')\n\t\t\t\tholderSelection.classed('filled', false)\n\t\t\t})\n\t\t\t.catch(function (error: Error) {\n\t\t\t\tconsole.error('oops, something went wrong!', error)\n\t\t\t})\n\t}\n\n\ttoggleFullscreen() {\n\t\tconst holder = this.getHolder()\n\t\tconst holderSelection = select(holder)\n\n\t\tconst isFullScreen = holderSelection.classed('fullscreen')\n\n\t\tif (\n\t\t\tisFullScreen &&\n\t\t\t(document.fullscreenElement ||\n\t\t\t\tdocument['webkitFullscreenElement'] ||\n\t\t\t\tdocument['mozFullScreenElement'] ||\n\t\t\t\tdocument['msFullscreenElement'])\n\t\t) {\n\t\t\t// Call the correct function depending on the browser\n\t\t\tif (document.exitFullscreen) {\n\t\t\t\tdocument.exitFullscreen()\n\t\t\t} else if (document['webkitExitFullscreen']) {\n\t\t\t\tdocument['webkitExitFullscreen']()\n\t\t\t} else if (document['mozCancelFullScreen']) {\n\t\t\t\tdocument['mozCancelFullScreen']()\n\t\t\t} else if (document['msExitFullscreen']) {\n\t\t\t\tdocument['msExitFullscreen']()\n\t\t\t}\n\t\t} else {\n\t\t\t// Call the correct function depending on the browser\n\t\t\tif (holder.requestFullscreen) {\n\t\t\t\tholder.requestFullscreen()\n\t\t\t} else if (holder.webkitRequestFullscreen) {\n\t\t\t\tholder.webkitRequestFullscreen()\n\t\t\t} else if (holder.mozRequestFullScreen) {\n\t\t\t\tholder.mozRequestFullScreen()\n\t\t\t} else if (holder.msRequestFullscreen) {\n\t\t\t\tholder.msRequestFullscreen()\n\t\t\t}\n\t\t}\n\t}\n\n\thandleFullscreenChange() {\n\t\tdocument.addEventListener('fullscreenchange', () => {\n\t\t\tconst holderSelection = select(this.getHolder())\n\t\t\tconst isFullScreen = holderSelection.classed('fullscreen')\n\n\t\t\t// Toggle the `fullscreen` classname\n\t\t\tholderSelection.classed('fullscreen', !isFullScreen)\n\t\t})\n\t}\n\n\tsetSVGMaxHeight() {\n\t\t// if there is a set height on the holder, leave the chart svg height at 100%\n\t\tif (!this.model.getOptions().height) {\n\t\t\tconst { height: chartHeight } = DOMUtils.getSVGElementSize(\n\t\t\t\tselect(this.mainContainer) as any,\n\t\t\t\t{\n\t\t\t\t\tuseBBox: true\n\t\t\t\t}\n\t\t\t)\n\t\t\tconst chartSVGSelector = select(this.mainContainer).attr('class')\n\t\t\tconst children = select(this.mainContainer).selectAll(`.${chartSVGSelector} > svg`)\n\n\t\t\t// get the height of the children SVGs (spacers, titles, etc)\n\t\t\tlet childrenHeight = 0\n\t\t\tchildren.nodes().forEach(function (childSVG) {\n\t\t\t\tchildrenHeight += Number(\n\t\t\t\t\tDOMUtils.getSVGElementSize(select<SVGGraphicsElement, any>(childSVG as any), {\n\t\t\t\t\t\tuseBBox: true\n\t\t\t\t\t}).height\n\t\t\t\t)\n\t\t\t})\n\n\t\t\t// set the chart svg height to the children height\n\t\t\t// forcing the chart not to take up any more space than it requires\n\t\t\tchildrenHeight <= chartHeight\n\t\t\t\t? select(this.mainContainer).attr('height', childrenHeight)\n\t\t\t\t: select(this.mainContainer).attr('height', '100%')\n\t\t}\n\t}\n\n\tgetMainContainer() {\n\t\treturn this.mainContainer\n\t}\n\n\taddHolderListeners() {\n\t\tconst holder = this.getHolder()\n\n\t\tif (!holder) {\n\t\t\treturn\n\t\t}\n\n\t\tselect(holder)\n\t\t\t.on('mouseover', () => {\n\t\t\t\t// Dispatch event\n\t\t\t\tthis.services.events?.dispatchEvent(Events.Chart.MOUSEOVER)\n\t\t\t})\n\t\t\t.on('mouseout', () => {\n\t\t\t\t// Dispatch event\n\t\t\t\tthis.services.events?.dispatchEvent(Events.Chart.MOUSEOUT)\n\t\t\t})\n\t}\n\n\taddResizeListener() {\n\t\tconst holder = this.getHolder()\n\n\t\tif (!holder) {\n\t\t\treturn\n\t\t}\n\n\t\t// Grab current dimensions of the chart holder\n\t\tlet containerWidth = holder.clientWidth\n\t\tlet containerHeight = holder.clientHeight\n\n\t\t// The resize callback function\n\t\tconst resizeCallback = debounce(() => {\n\t\t\tif (!holder) {\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\tif (\n\t\t\t\tMath.abs(containerWidth - holder.clientWidth) > 1 ||\n\t\t\t\tMath.abs(containerHeight - holder.clientHeight) > 1\n\t\t\t) {\n\t\t\t\tcontainerWidth = holder.clientWidth\n\t\t\t\tcontainerHeight = holder.clientHeight\n\n\t\t\t\tthis.services.events?.dispatchEvent(Events.Chart.RESIZE)\n\t\t\t}\n\t\t}, 12.5)\n\n\t\t// Observe the behaviour of resizing on the holder\n\t\tconst resizeObserver = new ResizeObserver(resizeCallback)\n\t\tresizeObserver.observe(holder)\n\t}\n}\n","import { Service } from '@/services/service'\n\nexport class GradientUtils extends Service {\n\tstatic appendOrUpdateLinearGradient(configs: any) {\n\t\tlet lg = configs.svg.select(`defs linearGradient#${configs.id}`)\n\t\tif (lg.empty()) {\n\t\t\tlg = configs.svg\n\t\t\t\t.append('defs')\n\t\t\t\t.append('linearGradient')\n\t\t\t\t.attr('id', configs.id)\n\t\t\t\t.attr('x1', configs.x1)\n\t\t\t\t.attr('x2', configs.x2)\n\t\t\t\t.attr('y1', configs.y1)\n\t\t\t\t.attr('y2', configs.y2)\n\t\t}\n\n\t\tlg.selectAll('stop').remove()\n\t\tlg.selectAll('stop')\n\t\t\t.data(configs.stops)\n\t\t\t.enter()\n\t\t\t.append('stop')\n\t\t\t.attr('offset', (d: any) => d.offset)\n\t\t\t.style('stop-color', (d: any) => d.color)\n\t\t\t.style('stop-opacity', (d: any) => d.opacity)\n\t}\n\n\tstatic getOffsetRatio(domain: any) {\n\t\tconst offsetRatio =\n\t\t\t((Math.abs(domain[1]) * 100) / Math.abs(domain[0] - domain[1])).toFixed(2) + '%'\n\t\treturn offsetRatio\n\t}\n\n\tstatic getStops(domain: any, color: string) {\n\t\tconst need3Stops = domain[0] < 0 && domain[1] > 0\n\t\tlet stops: object[] = [\n\t\t\t{\n\t\t\t\toffset: '0%',\n\t\t\t\tcolor: color,\n\t\t\t\topacity: '0.6'\n\t\t\t},\n\t\t\t{\n\t\t\t\toffset: '80%',\n\t\t\t\tcolor: color,\n\t\t\t\topacity: '0'\n\t\t\t}\n\t\t]\n\n\t\tif (need3Stops) {\n\t\t\tstops = [\n\t\t\t\t{\n\t\t\t\t\toffset: '0%',\n\t\t\t\t\tcolor: color,\n\t\t\t\t\topacity: '0.6'\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\toffset: GradientUtils.getOffsetRatio(domain),\n\t\t\t\t\tcolor: color,\n\t\t\t\t\topacity: '0'\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\toffset: '100%',\n\t\t\t\t\tcolor: color,\n\t\t\t\t\topacity: '0.6'\n\t\t\t\t}\n\t\t\t]\n\t\t}\n\t\treturn stops\n\t}\n}\n","import { TextAnchor, DominantBaseline } from '@/interfaces/enums'\n\nexport interface Point {\n\tx: number\n\ty: number\n}\n\nexport type Angle = number\n\nexport interface LabelAlignment {\n\ttextAnchor: TextAnchor\n\tdominantBaseline: DominantBaseline\n}\n\nexport function radialLabelPlacement(angleRadians: Angle): LabelAlignment {\n\tconst angle = mod(radToDeg(angleRadians), 360)\n\n\tif (isInRange(angle, [0, 10]) || isInRange(angle, [350, 0])) {\n\t\treturn {\n\t\t\ttextAnchor: TextAnchor.START,\n\t\t\tdominantBaseline: DominantBaseline.MIDDLE\n\t\t}\n\t} else if (isInRange(angle, [10, 80])) {\n\t\treturn {\n\t\t\ttextAnchor: TextAnchor.START,\n\t\t\tdominantBaseline: DominantBaseline.HANGING\n\t\t}\n\t} else if (isInRange(angle, [80, 100])) {\n\t\treturn {\n\t\t\ttextAnchor: TextAnchor.MIDDLE,\n\t\t\tdominantBaseline: DominantBaseline.HANGING\n\t\t}\n\t} else if (isInRange(angle, [100, 170])) {\n\t\treturn {\n\t\t\ttextAnchor: TextAnchor.END,\n\t\t\tdominantBaseline: DominantBaseline.HANGING\n\t\t}\n\t} else if (isInRange(angle, [170, 190])) {\n\t\treturn {\n\t\t\ttextAnchor: TextAnchor.END,\n\t\t\tdominantBaseline: DominantBaseline.MIDDLE\n\t\t}\n\t} else if (isInRange(angle, [190, 260])) {\n\t\treturn {\n\t\t\ttextAnchor: TextAnchor.END,\n\t\t\tdominantBaseline: DominantBaseline.BASELINE\n\t\t}\n\t} else if (isInRange(angle, [260, 280])) {\n\t\treturn {\n\t\t\ttextAnchor: TextAnchor.MIDDLE,\n\t\t\tdominantBaseline: DominantBaseline.BASELINE\n\t\t}\n\t} else {\n\t\t// 280 - 350\n\t\treturn {\n\t\t\ttextAnchor: TextAnchor.START,\n\t\t\tdominantBaseline: DominantBaseline.BASELINE\n\t\t}\n\t}\n}\n\nfunction mod(n: number, m: number) {\n\treturn ((n % m) + m) % m\n}\n\nfunction isInRange(x: number, [min, max]: [number, number]) {\n\treturn x >= min && x <= max\n}\n\nexport function radToDeg(rad: Angle): Angle {\n\treturn rad * (180 / Math.PI)\n}\n\nexport function degToRad(deg: Angle): Angle {\n\treturn deg * (Math.PI / 180)\n}\n\nexport function polarToCartesianCoords(a: Angle, r: number, t: Point = { x: 0, y: 0 }): Point {\n\tconst x = r * Math.cos(a) + t.x\n\tconst y = r * Math.sin(a) + t.y\n\n\t// NaN is rendered at coordinate 0 in browsers\n\t// By setting it to 0, further operations can be performed\n\treturn { x: isNaN(x) ? 0 : x, y: isNaN(y) ? 0 : y }\n}\n\n// Return the distance between a point (described with polar coordinates)\n// on a circumference and the vertical diameter.\n// If the point is on the left if the diameter, its distance is positive,\n// if it is on the right of the diameter, its distance is negative.\nexport function distanceBetweenPointOnCircAndVerticalDiameter(a: Angle, r: number) {\n\treturn r * Math.sin(a - Math.PI / 2)\n}\n"],"names":["reWhitespace","trimmedEndIndex","string","index","reTrimStart","baseTrim","NAN","reIsBadHex","reIsBinary","reIsOctal","freeParseInt","toNumber","value","isSymbol","isObject","other","isBinary","now","root","now$1","FUNC_ERROR_TEXT","nativeMax","nativeMin","debounce","func","wait","options","lastArgs","lastThis","maxWait","result","timerId","lastCallTime","lastInvokeTime","leading","maxing","trailing","invokeFunc","time","args","thisArg","leadingEdge","timerExpired","remainingWait","timeSinceLastCall","timeSinceLastInvoke","timeWaiting","shouldInvoke","trailingEdge","cancel","flush","debounced","isInvoking","Service","model","services","newObj","CSS_VERIFIER_ELEMENT_CLASSNAME","DOMUtils","element","svgSelector","select","finalDimensions","validateAndSetDimensions","dimensions","dimensionKey","dimension","dimensionNumber","attrDimensions","svgElement","bbox","bboxDimensions","boundingRect","boundingRectDimensions","e","clientDimensions","nativeDimensions","getProperty","parent","query","selection","querySections","elementToAppend","id","originalID","chartsprefix","mainContainer","carbonPrefix","holderElement","width","height","theme","self","holder","holderSelection","domToImage","node","dataUrl","_a","error","isFullScreen","chartHeight","chartSVGSelector","children","childrenHeight","childSVG","Events","containerWidth","containerHeight","resizeCallback","GradientUtils","configs","lg","d","domain","color","need3Stops","stops","radialLabelPlacement","angleRadians","angle","mod","radToDeg","isInRange","TextAnchor","DominantBaseline","n","m","x","min","max","rad","degToRad","deg","polarToCartesianCoords","a","r","y","distanceBetweenPointOnCircAndVerticalDiameter"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4]}
|
|
@@ -1,387 +0,0 @@
|
|
|
1
|
-
import { select as d } from "d3";
|
|
2
|
-
import { a as P, c as A, r as $, g as v, d as H, e as L } from "./color-scale-utils-222feda6.mjs";
|
|
3
|
-
import { _ as D, T as p, o as E } from "./enums-a96ef472.mjs";
|
|
4
|
-
var W = /\s/;
|
|
5
|
-
function q(s) {
|
|
6
|
-
for (var e = s.length; e-- && W.test(s.charAt(e)); )
|
|
7
|
-
;
|
|
8
|
-
return e;
|
|
9
|
-
}
|
|
10
|
-
var _ = /^\s+/;
|
|
11
|
-
function j(s) {
|
|
12
|
-
return s && s.slice(0, q(s) + 1).replace(_, "");
|
|
13
|
-
}
|
|
14
|
-
var N = 0 / 0, U = /^[-+]0x[0-9a-f]+$/i, J = /^0b[01]+$/i, X = /^0o[0-7]+$/i, Y = parseInt;
|
|
15
|
-
function O(s) {
|
|
16
|
-
if (typeof s == "number")
|
|
17
|
-
return s;
|
|
18
|
-
if (P(s))
|
|
19
|
-
return N;
|
|
20
|
-
if (A(s)) {
|
|
21
|
-
var e = typeof s.valueOf == "function" ? s.valueOf() : s;
|
|
22
|
-
s = A(e) ? e + "" : e;
|
|
23
|
-
}
|
|
24
|
-
if (typeof s != "string")
|
|
25
|
-
return s === 0 ? s : +s;
|
|
26
|
-
s = j(s);
|
|
27
|
-
var t = J.test(s);
|
|
28
|
-
return t || X.test(s) ? Y(s.slice(2), t ? 2 : 8) : U.test(s) ? N : +s;
|
|
29
|
-
}
|
|
30
|
-
var Z = function() {
|
|
31
|
-
return $.Date.now();
|
|
32
|
-
};
|
|
33
|
-
const T = Z;
|
|
34
|
-
var Q = "Expected a function", K = Math.max, ee = Math.min;
|
|
35
|
-
function te(s, e, t) {
|
|
36
|
-
var n, i, a, r, l, h, f = 0, y = !1, u = !1, c = !0;
|
|
37
|
-
if (typeof s != "function")
|
|
38
|
-
throw new TypeError(Q);
|
|
39
|
-
e = O(e) || 0, A(t) && (y = !!t.leading, u = "maxWait" in t, a = u ? K(O(t.maxWait) || 0, e) : a, c = "trailing" in t ? !!t.trailing : c);
|
|
40
|
-
function m(o) {
|
|
41
|
-
var g = n, b = i;
|
|
42
|
-
return n = i = void 0, f = o, r = s.apply(b, g), r;
|
|
43
|
-
}
|
|
44
|
-
function S(o) {
|
|
45
|
-
return f = o, l = setTimeout(C, e), y ? m(o) : r;
|
|
46
|
-
}
|
|
47
|
-
function I(o) {
|
|
48
|
-
var g = o - h, b = o - f, F = e - g;
|
|
49
|
-
return u ? ee(F, a - b) : F;
|
|
50
|
-
}
|
|
51
|
-
function M(o) {
|
|
52
|
-
var g = o - h, b = o - f;
|
|
53
|
-
return h === void 0 || g >= e || g < 0 || u && b >= a;
|
|
54
|
-
}
|
|
55
|
-
function C() {
|
|
56
|
-
var o = T();
|
|
57
|
-
if (M(o))
|
|
58
|
-
return R(o);
|
|
59
|
-
l = setTimeout(C, I(o));
|
|
60
|
-
}
|
|
61
|
-
function R(o) {
|
|
62
|
-
return l = void 0, c && n ? m(o) : (n = i = void 0, r);
|
|
63
|
-
}
|
|
64
|
-
function k() {
|
|
65
|
-
l !== void 0 && clearTimeout(l), f = 0, n = h = i = l = void 0;
|
|
66
|
-
}
|
|
67
|
-
function V() {
|
|
68
|
-
return l === void 0 ? r : R(T());
|
|
69
|
-
}
|
|
70
|
-
function w() {
|
|
71
|
-
var o = T(), g = M(o);
|
|
72
|
-
if (n = arguments, i = this, h = o, g) {
|
|
73
|
-
if (l === void 0)
|
|
74
|
-
return S(h);
|
|
75
|
-
if (u)
|
|
76
|
-
return clearTimeout(l), l = setTimeout(C, e), m(h);
|
|
77
|
-
}
|
|
78
|
-
return l === void 0 && (l = setTimeout(C, e)), r;
|
|
79
|
-
}
|
|
80
|
-
return w.cancel = k, w.flush = V, w;
|
|
81
|
-
}
|
|
82
|
-
class G {
|
|
83
|
-
constructor(e, t) {
|
|
84
|
-
this.model = e, this.services = t, this.init();
|
|
85
|
-
}
|
|
86
|
-
init() {
|
|
87
|
-
}
|
|
88
|
-
update() {
|
|
89
|
-
}
|
|
90
|
-
// Used to pass down information to the components
|
|
91
|
-
setModel(e) {
|
|
92
|
-
this.model = e;
|
|
93
|
-
}
|
|
94
|
-
// Used to pass down services to the components
|
|
95
|
-
setServices(e) {
|
|
96
|
-
this.services = e;
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
const ne = "DONT_STYLE_ME_css_styles_verifier";
|
|
100
|
-
class B extends G {
|
|
101
|
-
// initialized in initializeID() called by init()
|
|
102
|
-
constructor(e, t) {
|
|
103
|
-
super(e, t), this.chartID = "";
|
|
104
|
-
}
|
|
105
|
-
static getHTMLElementSize(e) {
|
|
106
|
-
return {
|
|
107
|
-
width: e.clientWidth,
|
|
108
|
-
height: e.clientHeight
|
|
109
|
-
};
|
|
110
|
-
}
|
|
111
|
-
static getSVGElementSize(e, t = {
|
|
112
|
-
useAttrs: !1,
|
|
113
|
-
useClientDimensions: !1,
|
|
114
|
-
useBBox: !1,
|
|
115
|
-
useBoundingRect: !1
|
|
116
|
-
}) {
|
|
117
|
-
e.attr || (e = d(e));
|
|
118
|
-
const n = {
|
|
119
|
-
width: 0,
|
|
120
|
-
height: 0
|
|
121
|
-
}, i = (c) => {
|
|
122
|
-
c && Object.keys(n).forEach((m) => {
|
|
123
|
-
if (c[m]) {
|
|
124
|
-
const S = c[m], I = parseFloat(S);
|
|
125
|
-
S && I > n[m] && ("" + S).indexOf("%") === -1 && (n[m] = I);
|
|
126
|
-
}
|
|
127
|
-
});
|
|
128
|
-
}, a = {
|
|
129
|
-
width: e.attr("width"),
|
|
130
|
-
height: e.attr("height")
|
|
131
|
-
}, r = e.node();
|
|
132
|
-
let l, h, f, y;
|
|
133
|
-
try {
|
|
134
|
-
typeof r.getBBox == "function" && (l = r.getBBox(), h = {
|
|
135
|
-
width: l.width,
|
|
136
|
-
height: l.height
|
|
137
|
-
});
|
|
138
|
-
} catch (c) {
|
|
139
|
-
console.error(c);
|
|
140
|
-
}
|
|
141
|
-
try {
|
|
142
|
-
typeof (r == null ? void 0 : r.getBoundingClientRect) == "function" && (f = r.getBoundingClientRect(), y = {
|
|
143
|
-
width: f.width,
|
|
144
|
-
height: f.height
|
|
145
|
-
});
|
|
146
|
-
} catch (c) {
|
|
147
|
-
console.error(c);
|
|
148
|
-
}
|
|
149
|
-
let u;
|
|
150
|
-
if (r instanceof SVGSVGElement && (u = {
|
|
151
|
-
width: r.clientWidth,
|
|
152
|
-
height: r.clientHeight
|
|
153
|
-
}), t) {
|
|
154
|
-
if (t.useAttrs && (i(a), n.width > 0 && n.height > 0))
|
|
155
|
-
return n;
|
|
156
|
-
if (t.useClientDimensions && (i(u), n.width > 0 && n.height > 0))
|
|
157
|
-
return u;
|
|
158
|
-
if (t.useBBox && (i(h), n.width > 0 && n.height > 0))
|
|
159
|
-
return h;
|
|
160
|
-
if (t.useBoundingRect && (i(y), n.width > 0 && n.height > 0))
|
|
161
|
-
return y;
|
|
162
|
-
}
|
|
163
|
-
try {
|
|
164
|
-
const c = {
|
|
165
|
-
width: v(e.node(), "width", "baseVal", "value"),
|
|
166
|
-
height: v(e.node(), "height", "baseVal", "value")
|
|
167
|
-
};
|
|
168
|
-
i(c);
|
|
169
|
-
} catch {
|
|
170
|
-
i(u), i(h), i(a);
|
|
171
|
-
}
|
|
172
|
-
return n;
|
|
173
|
-
}
|
|
174
|
-
static appendOrSelect(e, t) {
|
|
175
|
-
const n = e.select(`${t}`);
|
|
176
|
-
if (n.empty()) {
|
|
177
|
-
let i = t.split("#"), a, r;
|
|
178
|
-
return i.length === 2 ? (a = i[0], i = i[1].split("."), r = i[0]) : (i = t.split("."), a = i[0]), e.append(a).attr("id", r).attr("class", i.slice(1).join(" "));
|
|
179
|
-
}
|
|
180
|
-
return n;
|
|
181
|
-
}
|
|
182
|
-
init() {
|
|
183
|
-
this.styleHolderElement(), this.initializeID(), this.addMainContainer(), this.model.getOptions().resizable && this.addResizeListener(), this.addHolderListeners(), this.handleFullscreenChange();
|
|
184
|
-
}
|
|
185
|
-
getChartID() {
|
|
186
|
-
return this.chartID;
|
|
187
|
-
}
|
|
188
|
-
generateElementIDString(e) {
|
|
189
|
-
return `chart-${this.chartID}-${e}`;
|
|
190
|
-
}
|
|
191
|
-
initializeID() {
|
|
192
|
-
this.chartID = Math.floor((1 + Math.random()) * 281474976710656).toString(16);
|
|
193
|
-
}
|
|
194
|
-
addMainContainer() {
|
|
195
|
-
const e = this.model.getOptions(), t = v(e, "style", "prefix"), n = d(this.getHolder()).append("div").classed(`${H}--${t}--chart-wrapper`, !0).attr("id", `chart-${this.getChartID()}`).style("height", "100%").style("width", "100%");
|
|
196
|
-
n.append("g").attr("class", ne), this.mainContainer = n.node();
|
|
197
|
-
}
|
|
198
|
-
update() {
|
|
199
|
-
this.styleHolderElement();
|
|
200
|
-
}
|
|
201
|
-
styleHolderElement() {
|
|
202
|
-
const e = this.getHolder(), { width: t, height: n, theme: i } = this.model.getOptions();
|
|
203
|
-
t !== this.width && (e.style.width = t, this.width = t), n !== this.height && (e.style.height = n, this.height = n), d(this.getHolder()).classed(`${H}--chart-holder`, !0).attr("data-carbon-theme", i);
|
|
204
|
-
}
|
|
205
|
-
getHolder() {
|
|
206
|
-
return this.model.get("holder");
|
|
207
|
-
}
|
|
208
|
-
exportToJPG() {
|
|
209
|
-
const e = this, t = this.getHolder(), n = d(t);
|
|
210
|
-
n.classed("filled", !0), L.toJpeg(this.getMainContainer(), {
|
|
211
|
-
bgcolor: typeof window < "u" ? window.getComputedStyle(t).getPropertyValue("background-color") : void 0,
|
|
212
|
-
quality: 1,
|
|
213
|
-
// Remove the toolbar
|
|
214
|
-
filter: (i) => !(i.classList && i.classList.contains("cds--cc--toolbar"))
|
|
215
|
-
}).then(function(i) {
|
|
216
|
-
var a;
|
|
217
|
-
(a = e.services.files) == null || a.downloadImage(i, "myChart.jpg"), n.classed("filled", !1);
|
|
218
|
-
});
|
|
219
|
-
}
|
|
220
|
-
exportToPNG() {
|
|
221
|
-
const e = this, t = this.getHolder(), n = d(t);
|
|
222
|
-
n.classed("filled", !0), L.toPng(this.getMainContainer(), {
|
|
223
|
-
bgcolor: typeof window < "u" ? window.getComputedStyle(t).getPropertyValue("background-color") : void 0,
|
|
224
|
-
quality: 1,
|
|
225
|
-
// Remove the toolbar
|
|
226
|
-
filter: (i) => !(i.classList && i.classList.contains("cds--cc--toolbar"))
|
|
227
|
-
}).then(function(i) {
|
|
228
|
-
var a;
|
|
229
|
-
(a = e.services.files) == null || a.downloadImage(i, "myChart.png"), n.classed("filled", !1);
|
|
230
|
-
}).catch(function(i) {
|
|
231
|
-
console.error("oops, something went wrong!", i);
|
|
232
|
-
});
|
|
233
|
-
}
|
|
234
|
-
toggleFullscreen() {
|
|
235
|
-
const e = this.getHolder();
|
|
236
|
-
d(e).classed("fullscreen") && (document.fullscreenElement || document.webkitFullscreenElement || document.mozFullScreenElement || document.msFullscreenElement) ? document.exitFullscreen ? document.exitFullscreen() : document.webkitExitFullscreen ? document.webkitExitFullscreen() : document.mozCancelFullScreen ? document.mozCancelFullScreen() : document.msExitFullscreen && document.msExitFullscreen() : e.requestFullscreen ? e.requestFullscreen() : e.webkitRequestFullscreen ? e.webkitRequestFullscreen() : e.mozRequestFullScreen ? e.mozRequestFullScreen() : e.msRequestFullscreen && e.msRequestFullscreen();
|
|
237
|
-
}
|
|
238
|
-
handleFullscreenChange() {
|
|
239
|
-
document.addEventListener("fullscreenchange", () => {
|
|
240
|
-
const e = d(this.getHolder()), t = e.classed("fullscreen");
|
|
241
|
-
e.classed("fullscreen", !t);
|
|
242
|
-
});
|
|
243
|
-
}
|
|
244
|
-
setSVGMaxHeight() {
|
|
245
|
-
if (!this.model.getOptions().height) {
|
|
246
|
-
const { height: e } = B.getSVGElementSize(
|
|
247
|
-
d(this.mainContainer),
|
|
248
|
-
{
|
|
249
|
-
useBBox: !0
|
|
250
|
-
}
|
|
251
|
-
), t = d(this.mainContainer).attr("class"), n = d(this.mainContainer).selectAll(`.${t} > svg`);
|
|
252
|
-
let i = 0;
|
|
253
|
-
n.nodes().forEach(function(a) {
|
|
254
|
-
i += Number(
|
|
255
|
-
B.getSVGElementSize(d(a), {
|
|
256
|
-
useBBox: !0
|
|
257
|
-
}).height
|
|
258
|
-
);
|
|
259
|
-
}), i <= e ? d(this.mainContainer).attr("height", i) : d(this.mainContainer).attr("height", "100%");
|
|
260
|
-
}
|
|
261
|
-
}
|
|
262
|
-
getMainContainer() {
|
|
263
|
-
return this.mainContainer;
|
|
264
|
-
}
|
|
265
|
-
addHolderListeners() {
|
|
266
|
-
const e = this.getHolder();
|
|
267
|
-
e && d(e).on("mouseover", () => {
|
|
268
|
-
var t;
|
|
269
|
-
(t = this.services.events) == null || t.dispatchEvent(D.Chart.MOUSEOVER);
|
|
270
|
-
}).on("mouseout", () => {
|
|
271
|
-
var t;
|
|
272
|
-
(t = this.services.events) == null || t.dispatchEvent(D.Chart.MOUSEOUT);
|
|
273
|
-
});
|
|
274
|
-
}
|
|
275
|
-
addResizeListener() {
|
|
276
|
-
const e = this.getHolder();
|
|
277
|
-
if (!e)
|
|
278
|
-
return;
|
|
279
|
-
let t = e.clientWidth, n = e.clientHeight;
|
|
280
|
-
const i = te(() => {
|
|
281
|
-
var r;
|
|
282
|
-
e && (Math.abs(t - e.clientWidth) > 1 || Math.abs(n - e.clientHeight) > 1) && (t = e.clientWidth, n = e.clientHeight, (r = this.services.events) == null || r.dispatchEvent(D.Chart.RESIZE));
|
|
283
|
-
}, 12.5);
|
|
284
|
-
new ResizeObserver(i).observe(e);
|
|
285
|
-
}
|
|
286
|
-
}
|
|
287
|
-
class z extends G {
|
|
288
|
-
static appendOrUpdateLinearGradient(e) {
|
|
289
|
-
let t = e.svg.select(`defs linearGradient#${e.id}`);
|
|
290
|
-
t.empty() && (t = e.svg.append("defs").append("linearGradient").attr("id", e.id).attr("x1", e.x1).attr("x2", e.x2).attr("y1", e.y1).attr("y2", e.y2)), t.selectAll("stop").remove(), t.selectAll("stop").data(e.stops).enter().append("stop").attr("offset", (n) => n.offset).style("stop-color", (n) => n.color).style("stop-opacity", (n) => n.opacity);
|
|
291
|
-
}
|
|
292
|
-
static getOffsetRatio(e) {
|
|
293
|
-
return (Math.abs(e[1]) * 100 / Math.abs(e[0] - e[1])).toFixed(2) + "%";
|
|
294
|
-
}
|
|
295
|
-
static getStops(e, t) {
|
|
296
|
-
const n = e[0] < 0 && e[1] > 0;
|
|
297
|
-
let i = [
|
|
298
|
-
{
|
|
299
|
-
offset: "0%",
|
|
300
|
-
color: t,
|
|
301
|
-
opacity: "0.6"
|
|
302
|
-
},
|
|
303
|
-
{
|
|
304
|
-
offset: "80%",
|
|
305
|
-
color: t,
|
|
306
|
-
opacity: "0"
|
|
307
|
-
}
|
|
308
|
-
];
|
|
309
|
-
return n && (i = [
|
|
310
|
-
{
|
|
311
|
-
offset: "0%",
|
|
312
|
-
color: t,
|
|
313
|
-
opacity: "0.6"
|
|
314
|
-
},
|
|
315
|
-
{
|
|
316
|
-
offset: z.getOffsetRatio(e),
|
|
317
|
-
color: t,
|
|
318
|
-
opacity: "0"
|
|
319
|
-
},
|
|
320
|
-
{
|
|
321
|
-
offset: "100%",
|
|
322
|
-
color: t,
|
|
323
|
-
opacity: "0.6"
|
|
324
|
-
}
|
|
325
|
-
]), i;
|
|
326
|
-
}
|
|
327
|
-
}
|
|
328
|
-
function le(s) {
|
|
329
|
-
const e = ie(se(s), 360);
|
|
330
|
-
return x(e, [0, 10]) || x(e, [350, 0]) ? {
|
|
331
|
-
textAnchor: p.START,
|
|
332
|
-
dominantBaseline: E.MIDDLE
|
|
333
|
-
} : x(e, [10, 80]) ? {
|
|
334
|
-
textAnchor: p.START,
|
|
335
|
-
dominantBaseline: E.HANGING
|
|
336
|
-
} : x(e, [80, 100]) ? {
|
|
337
|
-
textAnchor: p.MIDDLE,
|
|
338
|
-
dominantBaseline: E.HANGING
|
|
339
|
-
} : x(e, [100, 170]) ? {
|
|
340
|
-
textAnchor: p.END,
|
|
341
|
-
dominantBaseline: E.HANGING
|
|
342
|
-
} : x(e, [170, 190]) ? {
|
|
343
|
-
textAnchor: p.END,
|
|
344
|
-
dominantBaseline: E.MIDDLE
|
|
345
|
-
} : x(e, [190, 260]) ? {
|
|
346
|
-
textAnchor: p.END,
|
|
347
|
-
dominantBaseline: E.BASELINE
|
|
348
|
-
} : x(e, [260, 280]) ? {
|
|
349
|
-
textAnchor: p.MIDDLE,
|
|
350
|
-
dominantBaseline: E.BASELINE
|
|
351
|
-
} : {
|
|
352
|
-
textAnchor: p.START,
|
|
353
|
-
dominantBaseline: E.BASELINE
|
|
354
|
-
};
|
|
355
|
-
}
|
|
356
|
-
function ie(s, e) {
|
|
357
|
-
return (s % e + e) % e;
|
|
358
|
-
}
|
|
359
|
-
function x(s, [e, t]) {
|
|
360
|
-
return s >= e && s <= t;
|
|
361
|
-
}
|
|
362
|
-
function se(s) {
|
|
363
|
-
return s * (180 / Math.PI);
|
|
364
|
-
}
|
|
365
|
-
function ce(s) {
|
|
366
|
-
return s * (Math.PI / 180);
|
|
367
|
-
}
|
|
368
|
-
function de(s, e, t = { x: 0, y: 0 }) {
|
|
369
|
-
const n = e * Math.cos(s) + t.x, i = e * Math.sin(s) + t.y;
|
|
370
|
-
return { x: isNaN(n) ? 0 : n, y: isNaN(i) ? 0 : i };
|
|
371
|
-
}
|
|
372
|
-
function he(s, e) {
|
|
373
|
-
return e * Math.sin(s - Math.PI / 2);
|
|
374
|
-
}
|
|
375
|
-
export {
|
|
376
|
-
B as D,
|
|
377
|
-
z as G,
|
|
378
|
-
G as S,
|
|
379
|
-
he as a,
|
|
380
|
-
se as b,
|
|
381
|
-
te as c,
|
|
382
|
-
ce as d,
|
|
383
|
-
de as p,
|
|
384
|
-
le as r,
|
|
385
|
-
O as t
|
|
386
|
-
};
|
|
387
|
-
//# sourceMappingURL=angle-utils-7255d1d9.mjs.map
|