{"version":3,"file":"static/js/main.f97e031f.js","mappings":"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qB,GAAW,mCACT,gNACA,oBACA,4BACE,8GACA,2IACA,qKACA,uOACA,2CAAgB,+CAAyB,4GAK7C,mCACI,mDACA,oBACA,uCACA,6BACE,oIACA,oLACA,uGAEF,yDACA,6BACE,iGACCA,GACD,mBACCd,GAAYG,QAIvB,yLC7Ce,SAASgB,GAAcn8N,GACpC,IAAoD,KAAhBqvK,EAAAA,EAAAA,UAASusD,IAAO,GAA7CT,EAAU,KAAEC,EAAa,KAUhC,OATAv7N,EAAAA,EAAAA,YAAU,WACc,GAAlBG,EAAMy6N,SACNW,EAAcQ,IAGdR,EAAcO,GAGpB,GAAG,CAAC37N,EAAMy6N,YAER,mCACI,iDACA,oBACA,uCACA,6BACE,gPACA,wNAEF,oBACA,6DACA,6BACE,4BACE,4EACA,8EACA,iGACA,gKACA,yFACA,uFAEF,mBACCO,GAAYG,OAEf,oBACA,wDACA,6BACE,oBACA,gIACA,yJACA,oBACA,0CACA,iBAAKx8L,IAAK4oL,MACV,yNACA,sJACA,oBACA,uHACA,uFACA,4BACE,wIACA,wFAEF,iLACA,oBACA,gDACA,wGACA,iHACA,yFACA,oBACA,mCACA,8IACA,oGACA,2CACA,mJACA,0CACA,sMACA,wCACA,uPACA,uFACA,kCACA,gLACA,oBACA,qCACA,yLACA,uQACA,oBACA,gGACA,2BAAG,mCAAa,+CAChB,2BAAG,mCAAa,wFAChB,2BAAG,mCAAa,oGAI1B,iHCrFe,SAAS6U,GAAUp8N,GAChC,IAAoD,KAAhBqvK,EAAAA,EAAAA,UAASusD,IAAO,GAA7CT,EAAU,KAAEC,EAAa,KAUhC,OATAv7N,EAAAA,EAAAA,YAAU,WACc,GAAlBG,EAAMy6N,SACNW,EAAcQ,IAGdR,EAAcO,GAGpB,GAAG,CAAC37N,EAAMy6N,YAER,mCACI,sDACA,oBACA,uCACA,6BACE,wTACA,+OACA,4KAEF,oBACA,0DACA,6BACE,4BACE,4GACA,0KACA,6EAEF,iGACCO,GAAYG,QAIvB,wMCjCe,SAASkB,KACtB,OACE,mCACI,kDACA,oBACA,6BACI,+HACA,oBACA,iBAAKnxN,MAAO,CAACkxF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","sources":["api/common.js","../node_modules/form-data/lib/browser.js","../../../../webpack/universalModuleDefinition","../../../../webpack/bootstrap 866101db6e6d9c90b880","../../../../highcharts-react.min.js","../../../../src/HighchartsReact.js","../../../../external {\"root\":\"React\",\"commonjs\":\"react\",\"commonjs2\":\"react\",\"amd\":\"react\"}","../node_modules/highcharts/highcharts.src.js","../node_modules/highcharts/highstock.src.js","../node_modules/moment/moment.js","../node_modules/prop-types/factoryWithThrowingShims.js","../node_modules/prop-types/index.js","../node_modules/prop-types/lib/ReactPropTypesSecret.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-numeric-input/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/scheduler/cjs/scheduler.production.min.js","../node_modules/scheduler/index.js","../webpack/bootstrap","../webpack/runtime/compat get default export","../webpack/runtime/create fake namespace object","../webpack/runtime/define property getters","../webpack/runtime/hasOwnProperty shorthand","../webpack/runtime/make namespace object","../webpack/runtime/node module decorator","../webpack/runtime/publicPath","../node_modules/@remix-run/router/history.ts","../node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js","../node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js","../node_modules/@babel/runtime/helpers/esm/slicedToArray.js","../node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js","../node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js","../node_modules/@babel/runtime/helpers/esm/nonIterableRest.js","../node_modules/@babel/runtime/helpers/esm/toConsumableArray.js","../node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js","../node_modules/@babel/runtime/helpers/esm/iterableToArray.js","../node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js","../node_modules/@babel/runtime/helpers/esm/classCallCheck.js","../node_modules/@babel/runtime/helpers/esm/createClass.js","../node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js","../node_modules/@babel/runtime/helpers/esm/inherits.js","../node_modules/@babel/runtime/helpers/esm/getPrototypeOf.js","../node_modules/@babel/runtime/helpers/esm/isNativeReflectConstruct.js","../node_modules/@babel/runtime/helpers/esm/typeof.js","../node_modules/@babel/runtime/helpers/esm/possibleConstructorReturn.js","../node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","../node_modules/@babel/runtime/helpers/esm/createSuper.js","../node_modules/@babel/runtime/helpers/esm/construct.js","../node_modules/@babel/runtime/helpers/esm/wrapNativeSuper.js","../node_modules/@babel/runtime/helpers/esm/isNativeFunction.js","../node_modules/@remix-run/router/utils.ts","../node_modules/@remix-run/router/router.ts","../node_modules/react-router/lib/use-sync-external-store-shim/useSyncExternalStoreShimClient.ts","../node_modules/react-router/lib/use-sync-external-store-shim/index.ts","../node_modules/react-router/lib/context.ts","../node_modules/react-router/lib/hooks.tsx","../node_modules/react-router/lib/components.tsx","../node_modules/react-router-dom/index.tsx","../node_modules/react-router-dom/dom.ts","../node_modules/@babel/runtime/helpers/esm/regeneratorRuntime.js","../node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js","../node_modules/@babel/runtime/helpers/esm/defineProperty.js","../node_modules/@babel/runtime/helpers/esm/objectSpread2.js","../node_modules/axios/lib/helpers/bind.js","../node_modules/axios/lib/utils.js","../node_modules/axios/lib/core/AxiosError.js","../node_modules/axios/lib/env/classes/FormData.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/classes/URLSearchParams.js","../node_modules/axios/lib/platform/browser/classes/FormData.js","../node_modules/axios/lib/platform/browser/index.js","../node_modules/axios/lib/helpers/formDataToJSON.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/helpers/isURLSameOrigin.js","../node_modules/axios/lib/cancel/CanceledError.js","../node_modules/axios/lib/helpers/parseHeaders.js","../node_modules/axios/lib/core/AxiosHeaders.js","../node_modules/axios/lib/helpers/speedometer.js","../node_modules/axios/lib/adapters/xhr.js","../node_modules/axios/lib/core/settle.js","../node_modules/axios/lib/helpers/parseProtocol.js","../node_modules/axios/lib/adapters/index.js","../node_modules/axios/lib/defaults/index.js","../node_modules/axios/lib/helpers/toURLEncodedForm.js","../node_modules/axios/lib/core/transformData.js","../node_modules/axios/lib/cancel/isCancel.js","../node_modules/axios/lib/core/dispatchRequest.js","../node_modules/axios/lib/core/mergeConfig.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/axios.js","../node_modules/axios/lib/helpers/spread.js","../node_modules/axios/lib/helpers/isAxiosError.js","../node_modules/axios/index.js","api/authServer.js","api/dataServer.js","utils/processor.js","context/UserContext.js","api/custServer.js","context/DataContext.js","context/StorageContext.js","hooks/useContextCommunicator.js","components/DrawerComponent.js","components/Drawer.js","sections/NavBar.js","components/Button.js","components/LoadingBar.js","layouts/Login.js","components/Dialog.js","hooks/useInstrument.js","dialogs/AstroDialog.js","components/Spinner.js","dialogs/QSpectrum.js","dialogs/IxDialog.js","hooks/useErrorHandler.js","../node_modules/react-icons/lib/esm/iconContext.js","../node_modules/react-icons/lib/esm/iconBase.js","../node_modules/react-icons/ai/index.esm.js","layouts/Instrument.js","../node_modules/date-fns/esm/_lib/toInteger/index.js","../node_modules/date-fns/esm/_lib/requiredArgs/index.js","../node_modules/date-fns/esm/toDate/index.js","../node_modules/react-icons/tb/index.esm.js","layouts/Scanner.js","../node_modules/date-fns/esm/addDays/index.js","../node_modules/react-icons/bs/index.esm.js","components/SearchResults.js","layouts/Search.js","layouts/User.js","layouts/Admin.js","components/Help/Overview.js","utils/video.js","components/Help/AddingInstruments.js","components/Help/ScannerHelp.js","components/Help/IntermarketHelp.js","components/Help/QSpectrumHelp.js","components/Help/AstroHelp.js","components/Help/InstrumentHelp.js","layouts/Help.js","App.js","index.js"],"sourcesContent":["let status = \"prod\"\r\n\r\nif (status === \"dev\") {\r\n module.exports = {\r\n nodeUrl: \"http://localhost:5000\"\r\n }\r\n} else if (status === \"prod\") {\r\n module.exports = {\r\n nodeUrl: ''\r\n }\r\n}","/* eslint-env browser */\nmodule.exports = typeof self == 'object' ? self.FormData : window.FormData;\n","(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"react\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"react\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"HighchartsReact\"] = factory(require(\"react\"));\n\telse\n\t\troot[\"HighchartsReact\"] = factory(root[\"React\"]);\n})(typeof self !== 'undefined' ? self : this, function(__WEBPACK_EXTERNAL_MODULE_1__) {\nreturn \n\n\n// WEBPACK FOOTER //\n// webpack/universalModuleDefinition"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 866101db6e6d9c90b880","(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"react\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"react\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"HighchartsReact\"] = factory(require(\"react\"));\n\telse\n\t\troot[\"HighchartsReact\"] = factory(root[\"React\"]);\n})(typeof self !== 'undefined' ? self : this, function(__WEBPACK_EXTERNAL_MODULE_1__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, {\n/******/ \t\t\t\tconfigurable: false,\n/******/ \t\t\t\tenumerable: true,\n/******/ \t\t\t\tget: getter\n/******/ \t\t\t});\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 0);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\nObject.defineProperty(__webpack_exports__, \"__esModule\", { value: true });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_react__);\nfunction _extends() { _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; }; return _extends.apply(this, arguments); }\n\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\n\nfunction _nonIterableSpread() { 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 _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); }\n\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter); }\n\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\n\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; }\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n // 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\n// `Highcharts` ref is available in the layout phase. This makes it available\n// in a parent component's `componentDidMount`.\n\nvar useIsomorphicLayoutEffect = typeof window !== 'undefined' ? __WEBPACK_IMPORTED_MODULE_0_react__[\"useLayoutEffect\"] : __WEBPACK_IMPORTED_MODULE_0_react__[\"useEffect\"];\nvar HighchartsReact = /*#__PURE__*/Object(__WEBPACK_IMPORTED_MODULE_0_react__[\"forwardRef\"])(function HighchartsReact(props, ref) {\n var containerRef = Object(__WEBPACK_IMPORTED_MODULE_0_react__[\"useRef\"])();\n var chartRef = Object(__WEBPACK_IMPORTED_MODULE_0_react__[\"useRef\"])();\n useIsomorphicLayoutEffect(function () {\n function createChart() {\n var H = props.highcharts || (typeof window === \"undefined\" ? \"undefined\" : _typeof(window)) === 'object' && window.Highcharts;\n var constructorType = props.constructorType || 'chart';\n\n if (!H) {\n console.warn('The \"highcharts\" property was not passed.');\n } else if (!H[constructorType]) {\n console.warn('The \"constructorType\" property is incorrect or some ' + 'required module is not imported.');\n } else if (!props.options) {\n console.warn('The \"options\" property was not passed.');\n } else {\n // Create a chart\n chartRef.current = H[constructorType](containerRef.current, props.options, props.callback ? props.callback : undefined);\n }\n }\n\n if (!chartRef.current) {\n createChart();\n } else {\n if (props.allowChartUpdate !== false) {\n if (!props.immutable && chartRef.current) {\n var _chartRef$current;\n\n (_chartRef$current = chartRef.current).update.apply(_chartRef$current, [props.options].concat(_toConsumableArray(props.updateArgs || [true, true])));\n } else {\n createChart();\n }\n }\n }\n });\n useIsomorphicLayoutEffect(function () {\n return function () {\n // Destroy chart only if unmounting.\n if (chartRef.current) {\n chartRef.current.destroy();\n chartRef.current = null;\n }\n };\n }, []);\n Object(__WEBPACK_IMPORTED_MODULE_0_react__[\"useImperativeHandle\"])(ref, function () {\n return {\n get chart() {\n return chartRef.current;\n },\n\n container: containerRef\n };\n }, []); // Create container for the chart\n\n return /*#__PURE__*/__WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\"div\", _extends({}, props.containerProps, {\n ref: containerRef\n }));\n});\n/* harmony default export */ __webpack_exports__[\"default\"] = (Object(__WEBPACK_IMPORTED_MODULE_0_react__[\"memo\"])(HighchartsReact));\n\n/***/ }),\n/* 1 */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_1__;\n\n/***/ })\n/******/ ]);\n});\n\n\n// WEBPACK FOOTER //\n// highcharts-react.min.js","import React, {\n forwardRef,\n memo,\n useEffect,\n useImperativeHandle,\n useLayoutEffect,\n useRef\n} from 'react';\n\n// 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\n// `Highcharts` ref is available in the layout phase. This makes it available\n// in a parent component's `componentDidMount`.\nconst useIsomorphicLayoutEffect =\n typeof window !== 'undefined' ? useLayoutEffect : useEffect;\n\nconst HighchartsReact = forwardRef(\n function HighchartsReact(props, ref) {\n const containerRef = useRef();\n const chartRef = useRef();\n\n useIsomorphicLayoutEffect(() => {\n function createChart() {\n const H = props.highcharts || (\n typeof window === 'object' && window.Highcharts\n );\n const constructorType = props.constructorType || 'chart';\n\n if (!H) {\n console.warn('The \"highcharts\" property was not passed.');\n\n } else if (!H[constructorType]) {\n console.warn(\n 'The \"constructorType\" property is incorrect or some ' +\n 'required module is not imported.'\n );\n } else if (!props.options) {\n console.warn('The \"options\" property was not passed.');\n\n } else {\n // Create a chart\n chartRef.current = H[constructorType](\n containerRef.current,\n props.options,\n props.callback ? props.callback : undefined\n );\n }\n }\n\n if (!chartRef.current) {\n createChart();\n } else {\n if (props.allowChartUpdate !== false) {\n if (!props.immutable && chartRef.current) {\n chartRef.current.update(\n props.options,\n ...(props.updateArgs || [true, true])\n );\n } else {\n createChart();\n }\n }\n }\n });\n\n useIsomorphicLayoutEffect(() => {\n return () => {\n // Destroy chart only if unmounting.\n if (chartRef.current) {\n chartRef.current.destroy();\n chartRef.current = null;\n }\n };\n }, []);\n\n useImperativeHandle(\n ref,\n () => ({\n get chart() {\n return chartRef.current;\n },\n container: containerRef\n }),\n []\n );\n\n // Create container for the chart\n return
;\n }\n);\n\nexport default memo(HighchartsReact);\n\n\n\n// WEBPACK FOOTER //\n// ./src/HighchartsReact.js","module.exports = __WEBPACK_EXTERNAL_MODULE_1__;\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"root\":\"React\",\"commonjs\":\"react\",\"commonjs2\":\"react\",\"amd\":\"react\"}\n// module id = 1\n// module chunks = 0 1","/**\n * @license Highcharts JS v10.3.1 (2022-10-31)\n *\n * (c) 2009-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n */\n(function (root, factory) {\n if (typeof module === 'object' && module.exports) {\n factory['default'] = factory;\n module.exports = root.document ?\n factory(root) :\n factory;\n } else if (typeof define === 'function' && define.amd) {\n define('highcharts/highcharts', function () {\n return factory(root);\n });\n } else {\n if (root.Highcharts) {\n root.Highcharts.error(16, true);\n }\n root.Highcharts = factory(root);\n }\n}(typeof window !== 'undefined' ? window : this, function (window) {\n 'use strict';\n var _modules = {};\n function _registerModule(obj, path, args, fn) {\n if (!obj.hasOwnProperty(path)) {\n obj[path] = fn.apply(null, args);\n\n if (typeof CustomEvent === 'function') {\n window.dispatchEvent(\n new CustomEvent(\n 'HighchartsModuleLoaded',\n { detail: { path: path, module: obj[path] }\n })\n );\n }\n }\n }\n _registerModule(_modules, 'Core/Globals.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Namespace\n *\n * */\n /**\n * Shared Highcharts properties.\n * @private\n */\n var Globals;\n (function (Globals) {\n /* *\n *\n * Constants\n *\n * */\n Globals.SVG_NS = 'http://www.w3.org/2000/svg', Globals.product = 'Highcharts', Globals.version = '10.3.1', Globals.win = (typeof window !== 'undefined' ?\n window :\n {}), // eslint-disable-line node/no-unsupported-features/es-builtins\n Globals.doc = Globals.win.document, Globals.svg = (Globals.doc &&\n Globals.doc.createElementNS &&\n !!Globals.doc.createElementNS(Globals.SVG_NS, 'svg').createSVGRect), Globals.userAgent = (Globals.win.navigator && Globals.win.navigator.userAgent) || '', Globals.isChrome = Globals.userAgent.indexOf('Chrome') !== -1, Globals.isFirefox = Globals.userAgent.indexOf('Firefox') !== -1, Globals.isMS = /(edge|msie|trident)/i.test(Globals.userAgent) && !Globals.win.opera, Globals.isSafari = !Globals.isChrome && Globals.userAgent.indexOf('Safari') !== -1, Globals.isTouchDevice = /(Mobile|Android|Windows Phone)/.test(Globals.userAgent), Globals.isWebKit = Globals.userAgent.indexOf('AppleWebKit') !== -1, Globals.deg2rad = Math.PI * 2 / 360, Globals.hasBidiBug = (Globals.isFirefox &&\n parseInt(Globals.userAgent.split('Firefox/')[1], 10) < 4 // issue #38\n ), Globals.hasTouch = !!Globals.win.TouchEvent, Globals.marginNames = [\n 'plotTop',\n 'marginRight',\n 'marginBottom',\n 'plotLeft'\n ], Globals.noop = function () { }, Globals.supportsPassiveEvents = (function () {\n // Checks whether the browser supports passive events, (#11353).\n var supportsPassive = false;\n // Object.defineProperty doesn't work on IE as well as passive\n // events - instead of using polyfill, we can exclude IE totally.\n if (!Globals.isMS) {\n var opts = Object.defineProperty({}, 'passive', {\n get: function () {\n supportsPassive = true;\n }\n });\n if (Globals.win.addEventListener && Globals.win.removeEventListener) {\n Globals.win.addEventListener('testPassive', Globals.noop, opts);\n Globals.win.removeEventListener('testPassive', Globals.noop, opts);\n }\n }\n return supportsPassive;\n }());\n /**\n * An array containing the current chart objects in the page. A chart's\n * position in the array is preserved throughout the page's lifetime. When\n * a chart is destroyed, the array item becomes `undefined`.\n *\n * @name Highcharts.charts\n * @type {Array}\n */\n Globals.charts = [];\n /**\n * A hook for defining additional date format specifiers. New\n * specifiers are defined as key-value pairs by using the\n * specifier as key, and a function which takes the timestamp as\n * value. This function returns the formatted portion of the\n * date.\n *\n * @sample highcharts/global/dateformats/\n * Adding support for week number\n *\n * @name Highcharts.dateFormats\n * @type {Record}\n */\n Globals.dateFormats = {};\n /**\n * @private\n * @deprecated\n * @todo Use only `Core/Series/SeriesRegistry.seriesTypes`\n */\n Globals.seriesTypes = {};\n /**\n * @private\n */\n Globals.symbolSizes = {};\n /* *\n *\n * Properties\n *\n * */\n // eslint-disable-next-line prefer-const\n Globals.chartCount = 0;\n })(Globals || (Globals = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Theme options that should get applied to the chart. In module mode it\n * might not be possible to change this property because of read-only\n * restrictions, instead use {@link Highcharts.setOptions}.\n *\n * @deprecated\n * @name Highcharts.theme\n * @type {Highcharts.Options}\n */\n (''); // keeps doclets above in JS file\n\n return Globals;\n });\n _registerModule(_modules, 'Core/Utilities.js', [_modules['Core/Globals.js']], function (H) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var charts = H.charts,\n doc = H.doc,\n win = H.win;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Provide error messages for debugging, with links to online explanation. This\n * function can be overridden to provide custom error handling.\n *\n * @sample highcharts/chart/highcharts-error/\n * Custom error handler\n *\n * @function Highcharts.error\n *\n * @param {number|string} code\n * The error code. See\n * [errors.xml](https://github.com/highcharts/highcharts/blob/master/errors/errors.xml)\n * for available codes. If it is a string, the error message is printed\n * directly in the console.\n *\n * @param {boolean} [stop=false]\n * Whether to throw an error or just log a warning in the console.\n *\n * @param {Highcharts.Chart} [chart]\n * Reference to the chart that causes the error. Used in 'debugger'\n * module to display errors directly on the chart.\n * Important note: This argument is undefined for errors that lack\n * access to the Chart instance. In such case, the error will be\n * displayed on the last created chart.\n *\n * @param {Highcharts.Dictionary} [params]\n * Additional parameters for the generated message.\n *\n * @return {void}\n */\n function error(code, stop, chart, params) {\n var severity = stop ? 'Highcharts error' : 'Highcharts warning';\n if (code === 32) {\n code = \"\" + severity + \": Deprecated member\";\n }\n var isCode = isNumber(code);\n var message = isCode ?\n \"\" + severity + \" #\" + code + \": www.highcharts.com/errors/\" + code + \"/\" :\n code.toString();\n var defaultHandler = function () {\n if (stop) {\n throw new Error(message);\n }\n // else ...\n if (win.console &&\n error.messages.indexOf(message) === -1 // prevent console flooting\n ) {\n console.warn(message); // eslint-disable-line no-console\n }\n };\n if (typeof params !== 'undefined') {\n var additionalMessages_1 = '';\n if (isCode) {\n message += '?';\n }\n objectEach(params, function (value, key) {\n additionalMessages_1 += \"\\n - \".concat(key, \": \").concat(value);\n if (isCode) {\n message += encodeURI(key) + '=' + encodeURI(value);\n }\n });\n message += additionalMessages_1;\n }\n fireEvent(H, 'displayError', { chart: chart, code: code, message: message, params: params }, defaultHandler);\n error.messages.push(message);\n }\n (function (error) {\n error.messages = [];\n })(error || (error = {}));\n /* eslint-disable valid-jsdoc */\n /**\n * Utility function to deep merge two or more objects and return a third object.\n * If the first argument is true, the contents of the second object is copied\n * into the first object. The merge function can also be used with a single\n * object argument to create a deep copy of an object.\n *\n * @function Highcharts.merge\n *\n * @param {boolean} extend\n * Whether to extend the left-side object (a) or return a whole new\n * object.\n *\n * @param {T|undefined} a\n * The first object to extend. When only this is given, the function\n * returns a deep copy.\n *\n * @param {...Array} [n]\n * An object to merge into the previous one.\n *\n * @return {T}\n * The merged object. If the first argument is true, the return is the\n * same as the second argument.\n */ /**\n * Utility function to deep merge two or more objects and return a third object.\n * The merge function can also be used with a single object argument to create a\n * deep copy of an object.\n *\n * @function Highcharts.merge\n *\n * @param {T|undefined} a\n * The first object to extend. When only this is given, the function\n * returns a deep copy.\n *\n * @param {...Array} [n]\n * An object to merge into the previous one.\n *\n * @return {T}\n * The merged object. If the first argument is true, the return is the\n * same as the second argument.\n */\n function merge() {\n /* eslint-enable valid-jsdoc */\n var i,\n args = arguments,\n ret = {};\n var doCopy = function (copy,\n original) {\n // An object is replacing a primitive\n if (typeof copy !== 'object') {\n copy = {};\n }\n objectEach(original, function (value, key) {\n // Prototype pollution (#14883)\n if (key === '__proto__' || key === 'constructor') {\n return;\n }\n // Copy the contents of objects, but not arrays or DOM nodes\n if (isObject(value, true) &&\n !isClass(value) &&\n !isDOMElement(value)) {\n copy[key] = doCopy(copy[key] || {}, value);\n // Primitives and arrays are copied over directly\n }\n else {\n copy[key] = original[key];\n }\n });\n return copy;\n };\n // If first argument is true, copy into the existing object. Used in\n // setOptions.\n if (args[0] === true) {\n ret = args[1];\n args = Array.prototype.slice.call(args, 2);\n }\n // For each argument, extend the return\n var len = args.length;\n for (i = 0; i < len; i++) {\n ret = doCopy(ret, args[i]);\n }\n return ret;\n }\n /**\n * Constrain a value to within a lower and upper threshold.\n *\n * @private\n * @param {number} value The initial value\n * @param {number} min The lower threshold\n * @param {number} max The upper threshold\n * @return {number} Returns a number value within min and max.\n */\n function clamp(value, min, max) {\n return value > min ? value < max ? value : max : min;\n }\n // eslint-disable-next-line valid-jsdoc\n /**\n * Remove settings that have not changed, to avoid unnecessary rendering or\n * computing (#9197).\n * @private\n */\n function cleanRecursively(newer, older) {\n var result = {};\n objectEach(newer, function (_val, key) {\n var ob;\n // Dive into objects (except DOM nodes)\n if (isObject(newer[key], true) &&\n !newer.nodeType && // #10044\n older[key]) {\n ob = cleanRecursively(newer[key], older[key]);\n if (Object.keys(ob).length) {\n result[key] = ob;\n }\n // Arrays, primitives and DOM nodes are copied directly\n }\n else if (isObject(newer[key]) ||\n newer[key] !== older[key] ||\n // If the newer key is explicitly undefined, keep it (#10525)\n (key in newer && !(key in older))) {\n result[key] = newer[key];\n }\n });\n return result;\n }\n /**\n * Shortcut for parseInt\n *\n * @private\n * @function Highcharts.pInt\n *\n * @param {*} s\n * any\n *\n * @param {number} [mag]\n * Magnitude\n *\n * @return {number}\n * number\n */\n function pInt(s, mag) {\n return parseInt(s, mag || 10);\n }\n /**\n * Utility function to check for string type.\n *\n * @function Highcharts.isString\n *\n * @param {*} s\n * The item to check.\n *\n * @return {boolean}\n * True if the argument is a string.\n */\n function isString(s) {\n return typeof s === 'string';\n }\n /**\n * Utility function to check if an item is an array.\n *\n * @function Highcharts.isArray\n *\n * @param {*} obj\n * The item to check.\n *\n * @return {boolean}\n * True if the argument is an array.\n */\n function isArray(obj) {\n var str = Object.prototype.toString.call(obj);\n return str === '[object Array]' || str === '[object Array Iterator]';\n }\n /**\n * Utility function to check if an item is of type object.\n *\n * @function Highcharts.isObject\n *\n * @param {*} obj\n * The item to check.\n *\n * @param {boolean} [strict=false]\n * Also checks that the object is not an array.\n *\n * @return {boolean}\n * True if the argument is an object.\n */\n function isObject(obj, strict) {\n return (!!obj &&\n typeof obj === 'object' &&\n (!strict || !isArray(obj))); // eslint-disable-line @typescript-eslint/no-explicit-any\n }\n /**\n * Utility function to check if an Object is a HTML Element.\n *\n * @function Highcharts.isDOMElement\n *\n * @param {*} obj\n * The item to check.\n *\n * @return {boolean}\n * True if the argument is a HTML Element.\n */\n function isDOMElement(obj) {\n return isObject(obj) && typeof obj.nodeType === 'number';\n }\n /**\n * Utility function to check if an Object is a class.\n *\n * @function Highcharts.isClass\n *\n * @param {object|undefined} obj\n * The item to check.\n *\n * @return {boolean}\n * True if the argument is a class.\n */\n function isClass(obj) {\n var c = obj && obj.constructor;\n return !!(isObject(obj, true) &&\n !isDOMElement(obj) &&\n (c && c.name && c.name !== 'Object'));\n }\n /**\n * Utility function to check if an item is a number and it is finite (not NaN,\n * Infinity or -Infinity).\n *\n * @function Highcharts.isNumber\n *\n * @param {*} n\n * The item to check.\n *\n * @return {boolean}\n * True if the item is a finite number\n */\n function isNumber(n) {\n return typeof n === 'number' && !isNaN(n) && n < Infinity && n > -Infinity;\n }\n /**\n * Remove the last occurence of an item from an array.\n *\n * @function Highcharts.erase\n *\n * @param {Array<*>} arr\n * The array.\n *\n * @param {*} item\n * The item to remove.\n *\n * @return {void}\n */\n function erase(arr, item) {\n var i = arr.length;\n while (i--) {\n if (arr[i] === item) {\n arr.splice(i, 1);\n break;\n }\n }\n }\n /**\n * Check if an object is null or undefined.\n *\n * @function Highcharts.defined\n *\n * @param {*} obj\n * The object to check.\n *\n * @return {boolean}\n * False if the object is null or undefined, otherwise true.\n */\n function defined(obj) {\n return typeof obj !== 'undefined' && obj !== null;\n }\n /**\n * Set or get an attribute or an object of attributes.\n *\n * To use as a setter, pass a key and a value, or let the second argument be a\n * collection of keys and values. When using a collection, passing a value of\n * `null` or `undefined` will remove the attribute.\n *\n * To use as a getter, pass only a string as the second argument.\n *\n * @function Highcharts.attr\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGDOMElement} elem\n * The DOM element to receive the attribute(s).\n *\n * @param {string|Highcharts.HTMLAttributes|Highcharts.SVGAttributes} [keyOrAttribs]\n * The property or an object of key-value pairs.\n *\n * @param {number|string} [value]\n * The value if a single property is set.\n *\n * @return {string|null|undefined}\n * When used as a getter, return the value.\n */\n function attr(elem, keyOrAttribs, value) {\n var isGetter = isString(keyOrAttribs) && !defined(value);\n var ret;\n var attrSingle = function (value,\n key) {\n // Set the value\n if (defined(value)) {\n elem.setAttribute(key,\n value);\n // Get the value\n }\n else if (isGetter) {\n ret = elem.getAttribute(key);\n // IE7 and below cannot get class through getAttribute (#7850)\n if (!ret && key === 'class') {\n ret = elem.getAttribute(key + 'Name');\n }\n // Remove the value\n }\n else {\n elem.removeAttribute(key);\n }\n };\n // If keyOrAttribs is a string\n if (isString(keyOrAttribs)) {\n attrSingle(value, keyOrAttribs);\n // Else if keyOrAttribs is defined, it is a hash of key/value pairs\n }\n else {\n objectEach(keyOrAttribs, attrSingle);\n }\n return ret;\n }\n /**\n * Check if an element is an array, and if not, make it into an array.\n *\n * @function Highcharts.splat\n *\n * @param {*} obj\n * The object to splat.\n *\n * @return {Array}\n * The produced or original array.\n */\n function splat(obj) {\n return isArray(obj) ? obj : [obj];\n }\n /**\n * Set a timeout if the delay is given, otherwise perform the function\n * synchronously.\n *\n * @function Highcharts.syncTimeout\n *\n * @param {Function} fn\n * The function callback.\n *\n * @param {number} delay\n * Delay in milliseconds.\n *\n * @param {*} [context]\n * An optional context to send to the function callback.\n *\n * @return {number}\n * An identifier for the timeout that can later be cleared with\n * Highcharts.clearTimeout. Returns -1 if there is no timeout.\n */\n function syncTimeout(fn, delay, context) {\n if (delay > 0) {\n return setTimeout(fn, delay, context);\n }\n fn.call(0, context);\n return -1;\n }\n /**\n * Internal clear timeout. The function checks that the `id` was not removed\n * (e.g. by `chart.destroy()`). For the details see\n * [issue #7901](https://github.com/highcharts/highcharts/issues/7901).\n *\n * @function Highcharts.clearTimeout\n *\n * @param {number|undefined} id\n * Id of a timeout.\n */\n function internalClearTimeout(id) {\n if (defined(id)) {\n clearTimeout(id);\n }\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Utility function to extend an object with the members of another.\n *\n * @function Highcharts.extend\n *\n * @param {T|undefined} a\n * The object to be extended.\n *\n * @param {Partial} b\n * The object to add to the first one.\n *\n * @return {T}\n * Object a, the original object.\n */\n function extend(a, b) {\n /* eslint-enable valid-jsdoc */\n var n;\n if (!a) {\n a = {};\n }\n for (n in b) { // eslint-disable-line guard-for-in\n a[n] = b[n];\n }\n return a;\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Return the first value that is not null or undefined.\n *\n * @function Highcharts.pick\n *\n * @param {...Array} items\n * Variable number of arguments to inspect.\n *\n * @return {T}\n * The value of the first argument that is not null or undefined.\n */\n function pick() {\n var args = arguments;\n var length = args.length;\n for (var i = 0; i < length; i++) {\n var arg = args[i];\n if (typeof arg !== 'undefined' && arg !== null) {\n return arg;\n }\n }\n }\n /**\n * Set CSS on a given element.\n *\n * @function Highcharts.css\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGDOMElement} el\n * An HTML DOM element.\n *\n * @param {Highcharts.CSSObject} styles\n * Style object with camel case property names.\n *\n * @return {void}\n */\n function css(el, styles) {\n if (H.isMS && !H.svg) { // #2686\n if (styles && defined(styles.opacity)) {\n styles.filter = \"alpha(opacity=\".concat(styles.opacity * 100, \")\");\n }\n }\n extend(el.style, styles);\n }\n /**\n * Utility function to create an HTML element with attributes and styles.\n *\n * @function Highcharts.createElement\n *\n * @param {string} tag\n * The HTML tag.\n *\n * @param {Highcharts.HTMLAttributes} [attribs]\n * Attributes as an object of key-value pairs.\n *\n * @param {Highcharts.CSSObject} [styles]\n * Styles as an object of key-value pairs.\n *\n * @param {Highcharts.HTMLDOMElement} [parent]\n * The parent HTML object.\n *\n * @param {boolean} [nopad=false]\n * If true, remove all padding, border and margin.\n *\n * @return {Highcharts.HTMLDOMElement}\n * The created DOM element.\n */\n function createElement(tag, attribs, styles, parent, nopad) {\n var el = doc.createElement(tag);\n if (attribs) {\n extend(el, attribs);\n }\n if (nopad) {\n css(el, { padding: '0', border: 'none', margin: '0' });\n }\n if (styles) {\n css(el, styles);\n }\n if (parent) {\n parent.appendChild(el);\n }\n return el;\n }\n // eslint-disable-next-line valid-jsdoc\n /**\n * Extend a prototyped class by new members.\n *\n * @function Highcharts.extendClass\n *\n * @param {Highcharts.Class} parent\n * The parent prototype to inherit.\n *\n * @param {Highcharts.Dictionary<*>} members\n * A collection of prototype members to add or override compared to the\n * parent prototype.\n *\n * @return {Highcharts.Class}\n * A new prototype.\n */\n function extendClass(parent, members) {\n var obj = (function () { });\n obj.prototype = new parent(); // eslint-disable-line new-cap\n extend(obj.prototype, members);\n return obj;\n }\n /**\n * Left-pad a string to a given length by adding a character repetitively.\n *\n * @function Highcharts.pad\n *\n * @param {number} number\n * The input string or number.\n *\n * @param {number} [length]\n * The desired string length.\n *\n * @param {string} [padder=0]\n * The character to pad with.\n *\n * @return {string}\n * The padded string.\n */\n function pad(number, length, padder) {\n return new Array((length || 2) +\n 1 -\n String(number)\n .replace('-', '')\n .length).join(padder || '0') + number;\n }\n /**\n * Return a length based on either the integer value, or a percentage of a base.\n *\n * @function Highcharts.relativeLength\n *\n * @param {Highcharts.RelativeSize} value\n * A percentage string or a number.\n *\n * @param {number} base\n * The full length that represents 100%.\n *\n * @param {number} [offset=0]\n * A pixel offset to apply for percentage values. Used internally in\n * axis positioning.\n *\n * @return {number}\n * The computed length.\n */\n function relativeLength(value, base, offset) {\n return (/%$/).test(value) ?\n (base * parseFloat(value) / 100) + (offset || 0) :\n parseFloat(value);\n }\n /**\n * Wrap a method with extended functionality, preserving the original function.\n *\n * @function Highcharts.wrap\n *\n * @param {*} obj\n * The context object that the method belongs to. In real cases, this is\n * often a prototype.\n *\n * @param {string} method\n * The name of the method to extend.\n *\n * @param {Highcharts.WrapProceedFunction} func\n * A wrapper function callback. This function is called with the same\n * arguments as the original function, except that the original function\n * is unshifted and passed as the first argument.\n */\n function wrap(obj, method, func) {\n var proceed = obj[method];\n obj[method] = function () {\n var outerArgs = arguments,\n scope = this;\n return func.apply(this, [\n function () {\n return proceed.apply(scope, arguments.length ? arguments : outerArgs);\n }\n ].concat([].slice.call(arguments)));\n };\n }\n /**\n * Get the magnitude of a number.\n *\n * @function Highcharts.getMagnitude\n *\n * @param {number} num\n * The number.\n *\n * @return {number}\n * The magnitude, where 1-9 are magnitude 1, 10-99 magnitude 2 etc.\n */\n function getMagnitude(num) {\n return Math.pow(10, Math.floor(Math.log(num) / Math.LN10));\n }\n /**\n * Take an interval and normalize it to multiples of round numbers.\n *\n * @deprecated\n * @function Highcharts.normalizeTickInterval\n *\n * @param {number} interval\n * The raw, un-rounded interval.\n *\n * @param {Array<*>} [multiples]\n * Allowed multiples.\n *\n * @param {number} [magnitude]\n * The magnitude of the number.\n *\n * @param {boolean} [allowDecimals]\n * Whether to allow decimals.\n *\n * @param {boolean} [hasTickAmount]\n * If it has tickAmount, avoid landing on tick intervals lower than\n * original.\n *\n * @return {number}\n * The normalized interval.\n *\n * @todo\n * Move this function to the Axis prototype. It is here only for historical\n * reasons.\n */\n function normalizeTickInterval(interval, multiples, magnitude, allowDecimals, hasTickAmount) {\n var i,\n retInterval = interval;\n // round to a tenfold of 1, 2, 2.5 or 5\n magnitude = pick(magnitude, getMagnitude(interval));\n var normalized = interval / magnitude;\n // multiples for a linear scale\n if (!multiples) {\n multiples = hasTickAmount ?\n // Finer grained ticks when the tick amount is hard set, including\n // when alignTicks is true on multiple axes (#4580).\n [1, 1.2, 1.5, 2, 2.5, 3, 4, 5, 6, 8, 10] :\n // Else, let ticks fall on rounder numbers\n [1, 2, 2.5, 5, 10];\n // the allowDecimals option\n if (allowDecimals === false) {\n if (magnitude === 1) {\n multiples = multiples.filter(function (num) {\n return num % 1 === 0;\n });\n }\n else if (magnitude <= 0.1) {\n multiples = [1 / magnitude];\n }\n }\n }\n // normalize the interval to the nearest multiple\n for (i = 0; i < multiples.length; i++) {\n retInterval = multiples[i];\n // only allow tick amounts smaller than natural\n if ((hasTickAmount &&\n retInterval * magnitude >= interval) ||\n (!hasTickAmount &&\n (normalized <=\n (multiples[i] +\n (multiples[i + 1] || multiples[i])) / 2))) {\n break;\n }\n }\n // Multiply back to the correct magnitude. Correct floats to appropriate\n // precision (#6085).\n retInterval = correctFloat(retInterval * magnitude, -Math.round(Math.log(0.001) / Math.LN10));\n return retInterval;\n }\n /**\n * Sort an object array and keep the order of equal items. The ECMAScript\n * standard does not specify the behaviour when items are equal.\n *\n * @function Highcharts.stableSort\n *\n * @param {Array<*>} arr\n * The array to sort.\n *\n * @param {Function} sortFunction\n * The function to sort it with, like with regular Array.prototype.sort.\n */\n function stableSort(arr, sortFunction) {\n // @todo It seems like Chrome since v70 sorts in a stable way internally,\n // plus all other browsers do it, so over time we may be able to remove this\n // function\n var length = arr.length;\n var sortValue,\n i;\n // Add index to each item\n for (i = 0; i < length; i++) {\n arr[i].safeI = i; // stable sort index\n }\n arr.sort(function (a, b) {\n sortValue = sortFunction(a, b);\n return sortValue === 0 ? a.safeI - b.safeI : sortValue;\n });\n // Remove index from items\n for (i = 0; i < length; i++) {\n delete arr[i].safeI; // stable sort index\n }\n }\n /**\n * Non-recursive method to find the lowest member of an array. `Math.min` raises\n * a maximum call stack size exceeded error in Chrome when trying to apply more\n * than 150.000 points. This method is slightly slower, but safe.\n *\n * @function Highcharts.arrayMin\n *\n * @param {Array<*>} data\n * An array of numbers.\n *\n * @return {number}\n * The lowest number.\n */\n function arrayMin(data) {\n var i = data.length,\n min = data[0];\n while (i--) {\n if (data[i] < min) {\n min = data[i];\n }\n }\n return min;\n }\n /**\n * Non-recursive method to find the lowest member of an array. `Math.max` raises\n * a maximum call stack size exceeded error in Chrome when trying to apply more\n * than 150.000 points. This method is slightly slower, but safe.\n *\n * @function Highcharts.arrayMax\n *\n * @param {Array<*>} data\n * An array of numbers.\n *\n * @return {number}\n * The highest number.\n */\n function arrayMax(data) {\n var i = data.length,\n max = data[0];\n while (i--) {\n if (data[i] > max) {\n max = data[i];\n }\n }\n return max;\n }\n /**\n * Utility method that destroys any SVGElement instances that are properties on\n * the given object. It loops all properties and invokes destroy if there is a\n * destroy method. The property is then delete.\n *\n * @function Highcharts.destroyObjectProperties\n *\n * @param {*} obj\n * The object to destroy properties on.\n *\n * @param {*} [except]\n * Exception, do not destroy this property, only delete it.\n */\n function destroyObjectProperties(obj, except) {\n objectEach(obj, function (val, n) {\n // If the object is non-null and destroy is defined\n if (val && val !== except && val.destroy) {\n // Invoke the destroy\n val.destroy();\n }\n // Delete the property from the object.\n delete obj[n];\n });\n }\n /**\n * Discard a HTML element\n *\n * @function Highcharts.discardElement\n *\n * @param {Highcharts.HTMLDOMElement} element\n * The HTML node to discard.\n */\n function discardElement(element) {\n if (element && element.parentElement) {\n element.parentElement.removeChild(element);\n }\n }\n /**\n * Fix JS round off float errors.\n *\n * @function Highcharts.correctFloat\n *\n * @param {number} num\n * A float number to fix.\n *\n * @param {number} [prec=14]\n * The precision.\n *\n * @return {number}\n * The corrected float number.\n */\n function correctFloat(num, prec) {\n // When the number is higher than 1e14 use the number (#16275)\n return num > 1e14 ? num : parseFloat(num.toPrecision(prec || 14));\n }\n /**\n * The time unit lookup\n *\n * @ignore\n */\n var timeUnits = {\n millisecond: 1,\n second: 1000,\n minute: 60000,\n hour: 3600000,\n day: 24 * 3600000,\n week: 7 * 24 * 3600000,\n month: 28 * 24 * 3600000,\n year: 364 * 24 * 3600000\n };\n /**\n * Easing definition\n *\n * @private\n * @function Math.easeInOutSine\n *\n * @param {number} pos\n * Current position, ranging from 0 to 1.\n *\n * @return {number}\n * Ease result\n */\n Math.easeInOutSine = function (pos) {\n return -0.5 * (Math.cos(Math.PI * pos) - 1);\n };\n /**\n * Returns the value of a property path on a given object.\n *\n * @private\n * @function getNestedProperty\n *\n * @param {string} path\n * Path to the property, for example `custom.myValue`.\n *\n * @param {unknown} obj\n * Instance containing the property on the specific path.\n *\n * @return {unknown}\n * The unknown property value.\n */\n function getNestedProperty(path, parent) {\n var pathElements = path.split('.');\n while (pathElements.length && defined(parent)) {\n var pathElement = pathElements.shift();\n // Filter on the key\n if (typeof pathElement === 'undefined' ||\n pathElement === '__proto__') {\n return; // undefined\n }\n var child = parent[pathElement];\n // Filter on the child\n if (!defined(child) ||\n typeof child === 'function' ||\n typeof child.nodeType === 'number' ||\n child === win) {\n return; // undefined\n }\n // Else, proceed\n parent = child;\n }\n return parent;\n }\n /**\n * Get the computed CSS value for given element and property, only for numerical\n * properties. For width and height, the dimension of the inner box (excluding\n * padding) is returned. Used for fitting the chart within the container.\n *\n * @function Highcharts.getStyle\n *\n * @param {Highcharts.HTMLDOMElement} el\n * An HTML element.\n *\n * @param {string} prop\n * The property name.\n *\n * @param {boolean} [toInt=true]\n * Parse to integer.\n *\n * @return {number|string|undefined}\n * The style value.\n */\n function getStyle(el, prop, toInt) {\n var customGetStyle = (H.getStyle || // oldie getStyle\n getStyle);\n var style;\n // For width and height, return the actual inner pixel size (#4913)\n if (prop === 'width') {\n var offsetWidth = Math.min(el.offsetWidth,\n el.scrollWidth);\n // In flex boxes, we need to use getBoundingClientRect and floor it,\n // because scrollWidth doesn't support subpixel precision (#6427) ...\n var boundingClientRectWidth = el.getBoundingClientRect &&\n el.getBoundingClientRect().width;\n // ...unless if the containing div or its parents are transform-scaled\n // down, in which case the boundingClientRect can't be used as it is\n // also scaled down (#9871, #10498).\n if (boundingClientRectWidth < offsetWidth &&\n boundingClientRectWidth >= offsetWidth - 1) {\n offsetWidth = Math.floor(boundingClientRectWidth);\n }\n return Math.max(0, // #8377\n (offsetWidth -\n (customGetStyle(el, 'padding-left', true) || 0) -\n (customGetStyle(el, 'padding-right', true) || 0)));\n }\n if (prop === 'height') {\n return Math.max(0, // #8377\n (Math.min(el.offsetHeight, el.scrollHeight) -\n (customGetStyle(el, 'padding-top', true) || 0) -\n (customGetStyle(el, 'padding-bottom', true) || 0)));\n }\n if (!win.getComputedStyle) {\n // SVG not supported, forgot to load oldie.js?\n error(27, true);\n }\n // Otherwise, get the computed style\n var css = win.getComputedStyle(el,\n void 0); // eslint-disable-line no-undefined\n if (css) {\n style = css.getPropertyValue(prop);\n if (pick(toInt, prop !== 'opacity')) {\n style = pInt(style);\n }\n }\n return style;\n }\n /**\n * Search for an item in an array.\n *\n * @function Highcharts.inArray\n *\n * @deprecated\n *\n * @param {*} item\n * The item to search for.\n *\n * @param {Array<*>} arr\n * The array or node collection to search in.\n *\n * @param {number} [fromIndex=0]\n * The index to start searching from.\n *\n * @return {number}\n * The index within the array, or -1 if not found.\n */\n function inArray(item, arr, fromIndex) {\n error(32, false, void 0, { 'Highcharts.inArray': 'use Array.indexOf' });\n return arr.indexOf(item, fromIndex);\n }\n /**\n * Return the value of the first element in the array that satisfies the\n * provided testing function.\n *\n * @function Highcharts.find\n *\n * @param {Array} arr\n * The array to test.\n *\n * @param {Function} callback\n * The callback function. The function receives the item as the first\n * argument. Return `true` if this item satisfies the condition.\n *\n * @return {T|undefined}\n * The value of the element.\n */\n var find = Array.prototype.find ?\n function (arr,\n callback) {\n return arr.find(callback);\n } :\n // Legacy implementation. PhantomJS, IE <= 11 etc. #7223.\n function (arr, callback) {\n var i;\n var length = arr.length;\n for (i = 0; i < length; i++) {\n if (callback(arr[i], i)) { // eslint-disable-line node/callback-return\n return arr[i];\n }\n }\n };\n /**\n * Returns an array of a given object's own properties.\n *\n * @function Highcharts.keys\n * @deprecated\n *\n * @param {*} obj\n * The object of which the properties are to be returned.\n *\n * @return {Array}\n * An array of strings that represents all the properties.\n */\n function keys(obj) {\n error(32, false, void 0, { 'Highcharts.keys': 'use Object.keys' });\n return Object.keys(obj);\n }\n /**\n * Get the element's offset position, corrected for `overflow: auto`.\n *\n * @function Highcharts.offset\n *\n * @param {global.Element} el\n * The DOM element.\n *\n * @return {Highcharts.OffsetObject}\n * An object containing `left` and `top` properties for the position in\n * the page.\n */\n function offset(el) {\n var docElem = doc.documentElement,\n box = (el.parentElement || el.parentNode) ?\n el.getBoundingClientRect() :\n { top: 0,\n left: 0,\n width: 0,\n height: 0 };\n return {\n top: box.top + (win.pageYOffset || docElem.scrollTop) -\n (docElem.clientTop || 0),\n left: box.left + (win.pageXOffset || docElem.scrollLeft) -\n (docElem.clientLeft || 0),\n width: box.width,\n height: box.height\n };\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Iterate over object key pairs in an object.\n *\n * @function Highcharts.objectEach\n *\n * @param {*} obj\n * The object to iterate over.\n *\n * @param {Highcharts.ObjectEachCallbackFunction} fn\n * The iterator callback. It passes three arguments:\n * * value - The property value.\n * * key - The property key.\n * * obj - The object that objectEach is being applied to.\n *\n * @param {T} [ctx]\n * The context.\n */\n function objectEach(obj, fn, ctx) {\n /* eslint-enable valid-jsdoc */\n for (var key in obj) {\n if (Object.hasOwnProperty.call(obj, key)) {\n fn.call(ctx || obj[key], obj[key], key, obj);\n }\n }\n }\n /**\n * Iterate over an array.\n *\n * @deprecated\n * @function Highcharts.each\n *\n * @param {Array<*>} arr\n * The array to iterate over.\n *\n * @param {Function} fn\n * The iterator callback. It passes three arguments:\n * - `item`: The array item.\n * - `index`: The item's index in the array.\n * - `arr`: The array that each is being applied to.\n *\n * @param {*} [ctx]\n * The context.\n *\n * @return {void}\n */\n /**\n * Filter an array by a callback.\n *\n * @deprecated\n * @function Highcharts.grep\n *\n * @param {Array<*>} arr\n * The array to filter.\n *\n * @param {Function} callback\n * The callback function. The function receives the item as the first\n * argument. Return `true` if the item is to be preserved.\n *\n * @return {Array<*>}\n * A new, filtered array.\n */\n /**\n * Map an array by a callback.\n *\n * @deprecated\n * @function Highcharts.map\n *\n * @param {Array<*>} arr\n * The array to map.\n *\n * @param {Function} fn\n * The callback function. Return the new value for the new array.\n *\n * @return {Array<*>}\n * A new array item with modified items.\n */\n /**\n * Reduce an array to a single value.\n *\n * @deprecated\n * @function Highcharts.reduce\n *\n * @param {Array<*>} arr\n * The array to reduce.\n *\n * @param {Function} fn\n * The callback function. Return the reduced value. Receives 4\n * arguments: Accumulated/reduced value, current value, current array\n * index, and the array.\n *\n * @param {*} initialValue\n * The initial value of the accumulator.\n *\n * @return {*}\n * The reduced value.\n */\n /**\n * Test whether at least one element in the array passes the test implemented by\n * the provided function.\n *\n * @deprecated\n * @function Highcharts.some\n *\n * @param {Array<*>} arr\n * The array to test\n *\n * @param {Function} fn\n * The function to run on each item. Return truty to pass the test.\n * Receives arguments `currentValue`, `index` and `array`.\n *\n * @param {*} ctx\n * The context.\n *\n * @return {boolean}\n */\n objectEach({\n map: 'map',\n each: 'forEach',\n grep: 'filter',\n reduce: 'reduce',\n some: 'some'\n }, function (val, key) {\n H[key] = function (arr) {\n var _a;\n error(32, false, void 0, (_a = {}, _a[\"Highcharts.\".concat(key)] = \"use Array.\".concat(val), _a));\n return Array.prototype[val].apply(arr, [].slice.call(arguments, 1));\n };\n });\n /* eslint-disable valid-jsdoc */\n /**\n * Add an event listener.\n *\n * @function Highcharts.addEvent\n *\n * @param {Highcharts.Class|T} el\n * The element or object to add a listener to. It can be a\n * {@link HTMLDOMElement}, an {@link SVGElement} or any other object.\n *\n * @param {string} type\n * The event type.\n *\n * @param {Highcharts.EventCallbackFunction|Function} fn\n * The function callback to execute when the event is fired.\n *\n * @param {Highcharts.EventOptionsObject} [options]\n * Options for adding the event.\n *\n * @return {Function}\n * A callback function to remove the added event.\n */\n function addEvent(el, type, fn, options) {\n /* eslint-enable valid-jsdoc */\n if (options === void 0) { options = {}; }\n // Add hcEvents to either the prototype (in case we're running addEvent on a\n // class) or the instance. If hasOwnProperty('hcEvents') is false, it is\n // inherited down the prototype chain, in which case we need to set the\n // property on this instance (which may itself be a prototype).\n var owner = typeof el === 'function' && el.prototype || el;\n if (!Object.hasOwnProperty.call(owner, 'hcEvents')) {\n owner.hcEvents = {};\n }\n var events = owner.hcEvents;\n // Allow click events added to points, otherwise they will be prevented by\n // the TouchPointer.pinch function after a pinch zoom operation (#7091).\n if (H.Point && // without H a dependency loop occurs\n el instanceof H.Point &&\n el.series &&\n el.series.chart) {\n el.series.chart.runTrackerClick = true;\n }\n // Handle DOM events\n // If the browser supports passive events, add it to improve performance\n // on touch events (#11353).\n var addEventListener = (el.addEventListener || H.addEventListenerPolyfill);\n if (addEventListener) {\n addEventListener.call(el, type, fn, H.supportsPassiveEvents ? {\n passive: options.passive === void 0 ?\n type.indexOf('touch') !== -1 : options.passive,\n capture: false\n } : false);\n }\n if (!events[type]) {\n events[type] = [];\n }\n var eventObject = {\n fn: fn,\n order: typeof options.order === 'number' ? options.order : Infinity\n };\n events[type].push(eventObject);\n // Order the calls\n events[type].sort(function (a, b) { return a.order - b.order; });\n // Return a function that can be called to remove this event.\n return function () {\n removeEvent(el, type, fn);\n };\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Remove an event that was added with {@link Highcharts#addEvent}.\n *\n * @function Highcharts.removeEvent\n *\n * @param {Highcharts.Class|T} el\n * The element to remove events on.\n *\n * @param {string} [type]\n * The type of events to remove. If undefined, all events are removed\n * from the element.\n *\n * @param {Highcharts.EventCallbackFunction} [fn]\n * The specific callback to remove. If undefined, all events that match\n * the element and optionally the type are removed.\n *\n * @return {void}\n */\n function removeEvent(el, type, fn) {\n /* eslint-enable valid-jsdoc */\n /**\n * @private\n */\n function removeOneEvent(type, fn) {\n var removeEventListener = (el.removeEventListener || H.removeEventListenerPolyfill);\n if (removeEventListener) {\n removeEventListener.call(el, type, fn, false);\n }\n }\n /**\n * @private\n */\n function removeAllEvents(eventCollection) {\n var types,\n len;\n if (!el.nodeName) {\n return; // break on non-DOM events\n }\n if (type) {\n types = {};\n types[type] = true;\n }\n else {\n types = eventCollection;\n }\n objectEach(types, function (_val, n) {\n if (eventCollection[n]) {\n len = eventCollection[n].length;\n while (len--) {\n removeOneEvent(n, eventCollection[n][len].fn);\n }\n }\n });\n }\n var owner = typeof el === 'function' && el.prototype || el;\n if (Object.hasOwnProperty.call(owner, 'hcEvents')) {\n var events = owner.hcEvents;\n if (type) {\n var typeEvents = (events[type] || []);\n if (fn) {\n events[type] = typeEvents.filter(function (obj) {\n return fn !== obj.fn;\n });\n removeOneEvent(type, fn);\n }\n else {\n removeAllEvents(events);\n events[type] = [];\n }\n }\n else {\n removeAllEvents(events);\n delete owner.hcEvents;\n }\n }\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Fire an event that was registered with {@link Highcharts#addEvent}.\n *\n * @function Highcharts.fireEvent\n *\n * @param {T} el\n * The object to fire the event on. It can be a {@link HTMLDOMElement},\n * an {@link SVGElement} or any other object.\n *\n * @param {string} type\n * The type of event.\n *\n * @param {Highcharts.Dictionary<*>|Event} [eventArguments]\n * Custom event arguments that are passed on as an argument to the event\n * handler.\n *\n * @param {Highcharts.EventCallbackFunction|Function} [defaultFunction]\n * The default function to execute if the other listeners haven't\n * returned false.\n *\n * @return {void}\n */\n function fireEvent(el, type, eventArguments, defaultFunction) {\n /* eslint-enable valid-jsdoc */\n var e,\n i;\n eventArguments = eventArguments || {};\n if (doc.createEvent &&\n (el.dispatchEvent ||\n (el.fireEvent &&\n // Enable firing events on Highcharts instance.\n el !== H))) {\n e = doc.createEvent('Events');\n e.initEvent(type, true, true);\n eventArguments = extend(e, eventArguments);\n if (el.dispatchEvent) {\n el.dispatchEvent(eventArguments);\n }\n else {\n el.fireEvent(type, eventArguments);\n }\n }\n else if (el.hcEvents) {\n if (!eventArguments.target) {\n // We're running a custom event\n extend(eventArguments, {\n // Attach a simple preventDefault function to skip\n // default handler if called. The built-in\n // defaultPrevented property is not overwritable (#5112)\n preventDefault: function () {\n eventArguments.defaultPrevented = true;\n },\n // Setting target to native events fails with clicking\n // the zoom-out button in Chrome.\n target: el,\n // If the type is not set, we're running a custom event\n // (#2297). If it is set, we're running a browser event,\n // and setting it will cause en error in IE8 (#2465).\n type: type\n });\n }\n var events = [];\n var object = el;\n var multilevel = false;\n // Recurse up the inheritance chain and collect hcEvents set as own\n // objects on the prototypes.\n while (object.hcEvents) {\n if (Object.hasOwnProperty.call(object, 'hcEvents') &&\n object.hcEvents[type]) {\n if (events.length) {\n multilevel = true;\n }\n events.unshift.apply(events, object.hcEvents[type]);\n }\n object = Object.getPrototypeOf(object);\n }\n // For performance reasons, only sort the event handlers in case we are\n // dealing with multiple levels in the prototype chain. Otherwise, the\n // events are already sorted in the addEvent function.\n if (multilevel) {\n // Order the calls\n events.sort(function (a, b) { return a.order - b.order; });\n }\n // Call the collected event handlers\n events.forEach(function (obj) {\n // If the event handler returns false, prevent the default handler\n // from executing\n if (obj.fn.call(el, eventArguments) === false) {\n eventArguments.preventDefault();\n }\n });\n }\n // Run the default if not prevented\n if (defaultFunction && !eventArguments.defaultPrevented) {\n defaultFunction.call(el, eventArguments);\n }\n }\n var serialMode;\n /**\n * Get a unique key for using in internal element id's and pointers. The key is\n * composed of a random hash specific to this Highcharts instance, and a\n * counter.\n *\n * @example\n * let id = uniqueKey(); // => 'highcharts-x45f6hp-0'\n *\n * @function Highcharts.uniqueKey\n *\n * @return {string}\n * A unique key.\n */\n var uniqueKey = (function () {\n var hash = Math.random().toString(36).substring(2, 9) + '-';\n var id = 0;\n return function () {\n return 'highcharts-' + (serialMode ? '' : hash) + id++;\n };\n }());\n /**\n * Activates a serial mode for element IDs provided by\n * {@link Highcharts.uniqueKey}. This mode can be used in automated tests, where\n * a simple comparison of two rendered SVG graphics is needed.\n *\n * **Note:** This is only for testing purposes and will break functionality in\n * webpages with multiple charts.\n *\n * @example\n * if (\n * process &&\n * process.env.NODE_ENV === 'development'\n * ) {\n * Highcharts.useSerialIds(true);\n * }\n *\n * @function Highcharts.useSerialIds\n *\n * @param {boolean} [mode]\n * Changes the state of serial mode.\n *\n * @return {boolean|undefined}\n * State of the serial mode.\n */\n function useSerialIds(mode) {\n return (serialMode = pick(mode, serialMode));\n }\n function isFunction(obj) {\n return typeof obj === 'function';\n }\n // Register Highcharts as a plugin in jQuery\n if (win.jQuery) {\n /**\n * Highcharts-extended JQuery.\n *\n * @external JQuery\n */\n /**\n * Helper function to return the chart of the current JQuery selector\n * element.\n *\n * @function external:JQuery#highcharts\n *\n * @return {Highcharts.Chart}\n * The chart that is linked to the JQuery selector element.\n */ /**\n * Factory function to create a chart in the current JQuery selector\n * element.\n *\n * @function external:JQuery#highcharts\n *\n * @param {'Chart'|'Map'|'StockChart'|string} [className]\n * Name of the factory class in the Highcharts namespace.\n *\n * @param {Highcharts.Options} [options]\n * The chart options structure.\n *\n * @param {Highcharts.ChartCallbackFunction} [callback]\n * Function to run when the chart has loaded and and all external\n * images are loaded. Defining a\n * [chart.events.load](https://api.highcharts.com/highcharts/chart.events.load)\n * handler is equivalent.\n *\n * @return {JQuery}\n * The current JQuery selector.\n */\n win.jQuery.fn.highcharts = function () {\n var args = [].slice.call(arguments);\n if (this[0]) { // this[0] is the renderTo div\n // Create the chart\n if (args[0]) {\n new H[ // eslint-disable-line computed-property-spacing, no-new\n // Constructor defaults to Chart\n isString(args[0]) ? args.shift() : 'Chart'](this[0], args[0], args[1]);\n return this;\n }\n // When called without parameters or with the return argument,\n // return an existing chart\n return charts[attr(this[0], 'data-highcharts-chart')];\n }\n };\n }\n /* *\n *\n * Default Export\n *\n * */\n // TODO use named exports when supported.\n var Utilities = {\n addEvent: addEvent,\n arrayMax: arrayMax,\n arrayMin: arrayMin,\n attr: attr,\n clamp: clamp,\n cleanRecursively: cleanRecursively,\n clearTimeout: internalClearTimeout,\n correctFloat: correctFloat,\n createElement: createElement,\n css: css,\n defined: defined,\n destroyObjectProperties: destroyObjectProperties,\n discardElement: discardElement,\n erase: erase,\n error: error,\n extend: extend,\n extendClass: extendClass,\n find: find,\n fireEvent: fireEvent,\n getMagnitude: getMagnitude,\n getNestedProperty: getNestedProperty,\n getStyle: getStyle,\n inArray: inArray,\n isArray: isArray,\n isClass: isClass,\n isDOMElement: isDOMElement,\n isFunction: isFunction,\n isNumber: isNumber,\n isObject: isObject,\n isString: isString,\n keys: keys,\n merge: merge,\n normalizeTickInterval: normalizeTickInterval,\n objectEach: objectEach,\n offset: offset,\n pad: pad,\n pick: pick,\n pInt: pInt,\n relativeLength: relativeLength,\n removeEvent: removeEvent,\n splat: splat,\n stableSort: stableSort,\n syncTimeout: syncTimeout,\n timeUnits: timeUnits,\n uniqueKey: uniqueKey,\n useSerialIds: useSerialIds,\n wrap: wrap\n };\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * An animation configuration. Animation configurations can also be defined as\n * booleans, where `false` turns off animation and `true` defaults to a duration\n * of 500ms and defer of 0ms.\n *\n * @interface Highcharts.AnimationOptionsObject\n */ /**\n * A callback function to exectute when the animation finishes.\n * @name Highcharts.AnimationOptionsObject#complete\n * @type {Function|undefined}\n */ /**\n * The animation defer in milliseconds.\n * @name Highcharts.AnimationOptionsObject#defer\n * @type {number|undefined}\n */ /**\n * The animation duration in milliseconds.\n * @name Highcharts.AnimationOptionsObject#duration\n * @type {number|undefined}\n */ /**\n * The name of an easing function as defined on the `Math` object.\n * @name Highcharts.AnimationOptionsObject#easing\n * @type {string|Function|undefined}\n */ /**\n * A callback function to execute on each step of each attribute or CSS property\n * that's being animated. The first argument contains information about the\n * animation and progress.\n * @name Highcharts.AnimationOptionsObject#step\n * @type {Function|undefined}\n */\n /**\n * Creates a frame for the animated SVG element.\n *\n * @callback Highcharts.AnimationStepCallbackFunction\n *\n * @param {Highcharts.SVGElement} this\n * The SVG element to animate.\n *\n * @return {void}\n */\n /**\n * Interface description for a class.\n *\n * @interface Highcharts.Class\n * @extends Function\n */ /**\n * Class costructor.\n * @function Highcharts.Class#new\n * @param {...Array<*>} args\n * Constructor arguments.\n * @return {T}\n * Class instance.\n */\n /**\n * A style object with camel case property names to define visual appearance of\n * a SVG element or HTML element. The properties can be whatever styles are\n * supported on the given SVG or HTML element.\n *\n * @example\n * {\n * fontFamily: 'monospace',\n * fontSize: '1.2em'\n * }\n *\n * @interface Highcharts.CSSObject\n */ /**\n * @name Highcharts.CSSObject#[key:string]\n * @type {boolean|number|string|undefined}\n */ /**\n * Background style for the element.\n * @name Highcharts.CSSObject#background\n * @type {string|undefined}\n */ /**\n * Background color of the element.\n * @name Highcharts.CSSObject#backgroundColor\n * @type {Highcharts.ColorString|undefined}\n */ /**\n * Border style for the element.\n * @name Highcharts.CSSObject#border\n * @type {string|undefined}\n */ /**\n * Radius of the element border.\n * @name Highcharts.CSSObject#borderRadius\n * @type {number|undefined}\n */ /**\n * Color used in the element. The 'contrast' option is a Highcharts custom\n * property that results in black or white, depending on the background of the\n * element.\n * @name Highcharts.CSSObject#color\n * @type {'contrast'|Highcharts.ColorString|undefined}\n */ /**\n * Style of the mouse cursor when resting over the element.\n * @name Highcharts.CSSObject#cursor\n * @type {Highcharts.CursorValue|undefined}\n */ /**\n * Font family of the element text. Multiple values have to be in decreasing\n * preference order and separated by comma.\n * @name Highcharts.CSSObject#fontFamily\n * @type {string|undefined}\n */ /**\n * Font size of the element text.\n * @name Highcharts.CSSObject#fontSize\n * @type {string|undefined}\n */ /**\n * Font weight of the element text.\n * @name Highcharts.CSSObject#fontWeight\n * @type {string|undefined}\n */ /**\n * Height of the element.\n * @name Highcharts.CSSObject#height\n * @type {number|undefined}\n */ /**\n * Width of the element border.\n * @name Highcharts.CSSObject#lineWidth\n * @type {number|undefined}\n */ /**\n * Opacity of the element.\n * @name Highcharts.CSSObject#opacity\n * @type {number|undefined}\n */ /**\n * Space around the element content.\n * @name Highcharts.CSSObject#padding\n * @type {string|undefined}\n */ /**\n * Behaviour of the element when the mouse cursor rests over it.\n * @name Highcharts.CSSObject#pointerEvents\n * @type {string|undefined}\n */ /**\n * Positioning of the element.\n * @name Highcharts.CSSObject#position\n * @type {string|undefined}\n */ /**\n * Alignment of the element text.\n * @name Highcharts.CSSObject#textAlign\n * @type {string|undefined}\n */ /**\n * Additional decoration of the element text.\n * @name Highcharts.CSSObject#textDecoration\n * @type {string|undefined}\n */ /**\n * Outline style of the element text.\n * @name Highcharts.CSSObject#textOutline\n * @type {string|undefined}\n */ /**\n * Line break style of the element text. Highcharts SVG elements support\n * `ellipsis` when a `width` is set.\n * @name Highcharts.CSSObject#textOverflow\n * @type {string|undefined}\n */ /**\n * Top spacing of the element relative to the parent element.\n * @name Highcharts.CSSObject#top\n * @type {string|undefined}\n */ /**\n * Animated transition of selected element properties.\n * @name Highcharts.CSSObject#transition\n * @type {string|undefined}\n */ /**\n * Line break style of the element text.\n * @name Highcharts.CSSObject#whiteSpace\n * @type {string|undefined}\n */ /**\n * Width of the element.\n * @name Highcharts.CSSObject#width\n * @type {number|undefined}\n */\n /**\n * All possible cursor styles.\n *\n * @typedef {'alias'|'all-scroll'|'auto'|'cell'|'col-resize'|'context-menu'|'copy'|'crosshair'|'default'|'e-resize'|'ew-resize'|'grab'|'grabbing'|'help'|'move'|'n-resize'|'ne-resize'|'nesw-resize'|'no-drop'|'none'|'not-allowed'|'ns-resize'|'nw-resize'|'nwse-resize'|'pointer'|'progress'|'row-resize'|'s-resize'|'se-resize'|'sw-resize'|'text'|'vertical-text'|'w-resize'|'wait'|'zoom-in'|'zoom-out'} Highcharts.CursorValue\n */\n /**\n * All possible dash styles.\n *\n * @typedef {'Dash'|'DashDot'|'Dot'|'LongDash'|'LongDashDot'|'LongDashDotDot'|'ShortDash'|'ShortDashDot'|'ShortDashDotDot'|'ShortDot'|'Solid'} Highcharts.DashStyleValue\n */\n /**\n * Generic dictionary in TypeScript notation.\n * Use the native `AnyRecord` instead.\n *\n * @deprecated\n * @interface Highcharts.Dictionary\n */ /**\n * @name Highcharts.Dictionary#[key:string]\n * @type {T}\n */\n /**\n * The function callback to execute when the event is fired. The `this` context\n * contains the instance, that fired the event.\n *\n * @callback Highcharts.EventCallbackFunction\n *\n * @param {T} this\n *\n * @param {Highcharts.Dictionary<*>|Event} [eventArguments]\n * Event arguments.\n *\n * @return {boolean|void}\n */\n /**\n * The event options for adding function callback.\n *\n * @interface Highcharts.EventOptionsObject\n */ /**\n * The order the event handler should be called. This opens for having one\n * handler be called before another, independent of in which order they were\n * added.\n * @name Highcharts.EventOptionsObject#order\n * @type {number}\n */ /**\n * Whether an event should be passive or not.\n * When set to `true`, the function specified by listener will never call\n * `preventDefault()`.\n * @name Highcharts.EventOptionsObject#passive\n * @type boolean\n */\n /**\n * Formats data as a string. Usually the data is accessible throught the `this`\n * keyword.\n *\n * @callback Highcharts.FormatterCallbackFunction\n *\n * @param {T} this\n * Context to format\n *\n * @return {string}\n * Formatted text\n */\n /**\n * An object of key-value pairs for HTML attributes.\n *\n * @typedef {Highcharts.Dictionary} Highcharts.HTMLAttributes\n */\n /**\n * An HTML DOM element. The type is a reference to the regular HTMLElement in\n * the global scope.\n *\n * @typedef {global.HTMLElement} Highcharts.HTMLDOMElement\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement\n */\n /**\n * The iterator callback.\n *\n * @callback Highcharts.ObjectEachCallbackFunction\n *\n * @param {T} this\n * The context.\n *\n * @param {*} value\n * The property value.\n *\n * @param {string} key\n * The property key.\n *\n * @param {*} obj\n * The object that objectEach is being applied to.\n */\n /**\n * An object containing `left` and `top` properties for the position in the\n * page.\n *\n * @interface Highcharts.OffsetObject\n */ /**\n * Left distance to the page border.\n * @name Highcharts.OffsetObject#left\n * @type {number}\n */ /**\n * Top distance to the page border.\n * @name Highcharts.OffsetObject#top\n * @type {number}\n */\n /**\n * Describes a range.\n *\n * @interface Highcharts.RangeObject\n */ /**\n * Maximum number of the range.\n * @name Highcharts.RangeObject#max\n * @type {number}\n */ /**\n * Minimum number of the range.\n * @name Highcharts.RangeObject#min\n * @type {number}\n */\n /**\n * If a number is given, it defines the pixel length. If a percentage string is\n * given, like for example `'50%'`, the setting defines a length relative to a\n * base size, for example the size of a container.\n *\n * @typedef {number|string} Highcharts.RelativeSize\n */\n /**\n * Proceed function to call original (wrapped) function.\n *\n * @callback Highcharts.WrapProceedFunction\n *\n * @param {*} [arg1]\n * Optional argument. Without any arguments defaults to first argument of\n * the wrapping function.\n *\n * @param {*} [arg2]\n * Optional argument. Without any arguments defaults to second argument\n * of the wrapping function.\n *\n * @param {*} [arg3]\n * Optional argument. Without any arguments defaults to third argument of\n * the wrapping function.\n *\n * @return {*}\n * Return value of the original function.\n */\n /**\n * The Highcharts object is the placeholder for all other members, and various\n * utility functions. The most important member of the namespace would be the\n * chart constructor.\n *\n * @example\n * let chart = Highcharts.chart('container', { ... });\n *\n * @namespace Highcharts\n */\n ''; // detach doclets above\n\n return Utilities;\n });\n _registerModule(_modules, 'Core/Chart/ChartDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * General options for the chart.\n *\n * @optionparent chart\n */\n var ChartDefaults = {\n /**\n * Default `mapData` for all series,\n in terms of a GeoJSON or TopoJSON\n * object. If set to a string,\n it functions as an index into the\n * `Highcharts.maps` array.\n *\n * For picking out individual shapes and geometries to use for each series\n * of the map,\n see [series.mapData](#series.map.mapData).\n *\n * @sample maps/demo/geojson\n * Loading GeoJSON data\n * @sample maps/chart/topojson\n * Loading TopoJSON data\n *\n * @type {string|Array<*>|Highcharts.GeoJSON|Highcharts.TopoJSON}\n * @since 5.0.0\n * @product highmaps\n * @apioption chart.map\n */\n /**\n * Set lat/lon transformation definitions for the chart. If not defined,\n * these are extracted from the map data.\n *\n * @type {*}\n * @since 5.0.0\n * @product highmaps\n * @apioption chart.mapTransforms\n */\n /**\n * When using multiple axes,\n the ticks of two or more opposite axes\n * will automatically be aligned by adding ticks to the axis or axes\n * with the least ticks,\n as if `tickAmount` were specified.\n *\n * This can be prevented by setting `alignTicks` to false. If the grid\n * lines look messy,\n it's a good idea to hide them for the secondary\n * axis by setting `gridLineWidth` to 0.\n *\n * If `startOnTick` or `endOnTick` in the axis options are set to false,\n * then the `alignTicks ` will be disabled for the axis.\n *\n * Disabled for logarithmic axes.\n *\n * @sample {highcharts} highcharts/chart/alignticks-true/\n * True by default\n * @sample {highcharts} highcharts/chart/alignticks-false/\n * False\n * @sample {highstock} stock/chart/alignticks-true/\n * True by default\n * @sample {highstock} stock/chart/alignticks-false/\n * False\n *\n * @type {boolean}\n * @default true\n * @product highcharts highstock gantt\n * @apioption chart.alignTicks\n */\n /**\n * When using multiple axes,\n align the thresholds. When this is true,\n other\n * ticks will also be aligned.\n *\n * Note that for line series and some other series types,\n the `threshold`\n * option is set to `null` by default. This will in turn cause their y-axis\n * to not have a threshold. In order to avoid that,\n set the series\n * `threshold` to 0 or another number.\n *\n * If `startOnTick` or `endOnTick` in the axis options are set to false,\n or\n * if the axis is logarithmic,\n the threshold will not be aligned.\n *\n * @sample {highcharts} highcharts/chart/alignthresholds/ Set to true\n *\n * @since 10.0.0\n * @product highcharts highstock gantt\n * @apioption chart.alignThresholds\n */\n alignThresholds: false,\n /**\n * Set the overall animation for all chart updating. Animation can be\n * disabled throughout the chart by setting it to false here. It can\n * be overridden for each individual API method as a function parameter.\n * The only animation not affected by this option is the initial series\n * animation,\n see [plotOptions.series.animation](\n * #plotOptions.series.animation).\n *\n * The animation can either be set as a boolean or a configuration\n * object. If `true`,\n it will use the 'swing' jQuery easing and a\n * duration of 500 ms. If used as a configuration object,\n the following\n * properties are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * - `duration`: The duration of the animation in milliseconds.\n *\n * - `easing`: A string reference to an easing function set on the\n * `Math` object. See\n * [the easing demo](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-animation-easing/).\n *\n * When zooming on a series with less than 100 points,\n the chart redraw\n * will be done with animation,\n but in case of more data points,\n it is\n * necessary to set this option to ensure animation on zoom.\n *\n * @sample {highcharts} highcharts/chart/animation-none/\n * Updating with no animation\n * @sample {highcharts} highcharts/chart/animation-duration/\n * With a longer duration\n * @sample {highcharts} highcharts/chart/animation-easing/\n * With a jQuery UI easing\n * @sample {highmaps} maps/chart/animation-none/\n * Updating with no animation\n * @sample {highmaps} maps/chart/animation-duration/\n * With a longer duration\n *\n * @type {boolean|Partial}\n * @default undefined\n * @apioption chart.animation\n */\n /**\n * A CSS class name to apply to the charts container `div`,\n allowing\n * unique CSS styling for each chart.\n *\n * @type {string}\n * @apioption chart.className\n */\n /**\n * Event listeners for the chart.\n *\n * @apioption chart.events\n */\n /**\n * Fires when a series is added to the chart after load time,\n using the\n * `addSeries` method. One parameter,\n `event`,\n is passed to the\n * function,\n containing common event information. Through\n * `event.options` you can access the series options that were passed to\n * the `addSeries` method. Returning false prevents the series from\n * being added.\n *\n * @sample {highcharts} highcharts/chart/events-addseries/\n * Alert on add series\n * @sample {highstock} stock/chart/events-addseries/\n * Alert on add series\n *\n * @type {Highcharts.ChartAddSeriesCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Chart\n * @apioption chart.events.addSeries\n */\n /**\n * Fires when clicking on the plot background. One parameter,\n `event`,\n * is passed to the function,\n containing common event information.\n *\n * Information on the clicked spot can be found through `event.xAxis`\n * and `event.yAxis`,\n which are arrays containing the axes of each\n * dimension and each axis' value at the clicked spot. The primary axes\n * are `event.xAxis[0]` and `event.yAxis[0]`. Remember the unit of a\n * datetime axis is milliseconds since 1970-01-01 00:00:00.\n *\n * ```js\n * click: function(e) {\n * console.log(\n * Highcharts.dateFormat('%Y-%m-%d %H:%M:%S',\n e.xAxis[0].value),\n * e.yAxis[0].value\n * )\n * }\n * ```\n *\n * @sample {highcharts} highcharts/chart/events-click/\n * Alert coordinates on click\n * @sample {highcharts} highcharts/chart/events-container/\n * Alternatively,\n attach event to container\n * @sample {highstock} stock/chart/events-click/\n * Alert coordinates on click\n * @sample {highstock} highcharts/chart/events-container/\n * Alternatively,\n attach event to container\n * @sample {highmaps} maps/chart/events-click/\n * Record coordinates on click\n * @sample {highmaps} highcharts/chart/events-container/\n * Alternatively,\n attach event to container\n *\n * @type {Highcharts.ChartClickCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Chart\n * @apioption chart.events.click\n */\n /**\n * Fires when the chart is finished loading. Since v4.2.2,\n it also waits\n * for images to be loaded,\n for example from point markers. One\n * parameter,\n `event`,\n is passed to the function,\n containing common\n * event information.\n *\n * There is also a second parameter to the chart constructor where a\n * callback function can be passed to be executed on chart.load.\n *\n * @sample {highcharts} highcharts/chart/events-load/\n * Alert on chart load\n * @sample {highstock} stock/chart/events-load/\n * Alert on chart load\n * @sample {highmaps} maps/chart/events-load/\n * Add series on chart load\n *\n * @type {Highcharts.ChartLoadCallbackFunction}\n * @context Highcharts.Chart\n * @apioption chart.events.load\n */\n /**\n * Fires when the chart is redrawn,\n either after a call to\n * `chart.redraw()` or after an axis,\n series or point is modified with\n * the `redraw` option set to `true`. One parameter,\n `event`,\n is passed\n * to the function,\n containing common event information.\n *\n * @sample {highcharts} highcharts/chart/events-redraw/\n * Alert on chart redraw\n * @sample {highstock} stock/chart/events-redraw/\n * Alert on chart redraw when adding a series or moving the\n * zoomed range\n * @sample {highmaps} maps/chart/events-redraw/\n * Set subtitle on chart redraw\n *\n * @type {Highcharts.ChartRedrawCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Chart\n * @apioption chart.events.redraw\n */\n /**\n * Fires after initial load of the chart (directly after the `load`\n * event),\n and after each redraw (directly after the `redraw` event).\n *\n * @type {Highcharts.ChartRenderCallbackFunction}\n * @since 5.0.7\n * @context Highcharts.Chart\n * @apioption chart.events.render\n */\n /**\n * Fires when an area of the chart has been selected. Selection is\n * enabled by setting the chart's zoomType. One parameter,\n `event`,\n is\n * passed to the function,\n containing common event information. The\n * default action for the selection event is to zoom the chart to the\n * selected area. It can be prevented by calling\n * `event.preventDefault()` or return false.\n *\n * Information on the selected area can be found through `event.xAxis`\n * and `event.yAxis`,\n which are arrays containing the axes of each\n * dimension and each axis' min and max values. The primary axes are\n * `event.xAxis[0]` and `event.yAxis[0]`. Remember the unit of a\n * datetime axis is milliseconds since 1970-01-01 00:00:00.\n *\n * ```js\n * selection: function(event) {\n * // log the min and max of the primary, datetime x-axis\n * console.log(\n * Highcharts.dateFormat(\n * '%Y-%m-%d %H:%M:%S',\n * event.xAxis[0].min\n * ),\n * Highcharts.dateFormat(\n * '%Y-%m-%d %H:%M:%S',\n * event.xAxis[0].max\n * )\n * );\n * // log the min and max of the y axis\n * console.log(event.yAxis[0].min, event.yAxis[0].max);\n * }\n * ```\n *\n * @sample {highcharts} highcharts/chart/events-selection/\n * Report on selection and reset\n * @sample {highcharts} highcharts/chart/events-selection-points/\n * Select a range of points through a drag selection\n * @sample {highstock} stock/chart/events-selection/\n * Report on selection and reset\n * @sample {highstock} highcharts/chart/events-selection-points/\n * Select a range of points through a drag selection\n * (Highcharts)\n *\n * @type {Highcharts.ChartSelectionCallbackFunction}\n * @apioption chart.events.selection\n */\n /**\n * The margin between the outer edge of the chart and the plot area.\n * The numbers in the array designate top, right, bottom and left\n * respectively. Use the options `marginTop`, `marginRight`,\n * `marginBottom` and `marginLeft` for shorthand setting of one option.\n *\n * By default there is no margin. The actual space is dynamically\n * calculated from the offset of axis labels, axis title, title,\n * subtitle and legend in addition to the `spacingTop`, `spacingRight`,\n * `spacingBottom` and `spacingLeft` options.\n *\n * @sample {highcharts} highcharts/chart/margins-zero/\n * Zero margins\n * @sample {highstock} stock/chart/margin-zero/\n * Zero margins\n *\n * @type {number|Array}\n * @apioption chart.margin\n */\n /**\n * The margin between the bottom outer edge of the chart and the plot\n * area. Use this to set a fixed pixel value for the margin as opposed\n * to the default dynamic margin. See also `spacingBottom`.\n *\n * @sample {highcharts} highcharts/chart/marginbottom/\n * 100px bottom margin\n * @sample {highstock} stock/chart/marginbottom/\n * 100px bottom margin\n * @sample {highmaps} maps/chart/margin/\n * 100px margins\n *\n * @type {number}\n * @since 2.0\n * @apioption chart.marginBottom\n */\n /**\n * The margin between the left outer edge of the chart and the plot\n * area. Use this to set a fixed pixel value for the margin as opposed\n * to the default dynamic margin. See also `spacingLeft`.\n *\n * @sample {highcharts} highcharts/chart/marginleft/\n * 150px left margin\n * @sample {highstock} stock/chart/marginleft/\n * 150px left margin\n * @sample {highmaps} maps/chart/margin/\n * 100px margins\n *\n * @type {number}\n * @since 2.0\n * @apioption chart.marginLeft\n */\n /**\n * The margin between the right outer edge of the chart and the plot\n * area. Use this to set a fixed pixel value for the margin as opposed\n * to the default dynamic margin. See also `spacingRight`.\n *\n * @sample {highcharts} highcharts/chart/marginright/\n * 100px right margin\n * @sample {highstock} stock/chart/marginright/\n * 100px right margin\n * @sample {highmaps} maps/chart/margin/\n * 100px margins\n *\n * @type {number}\n * @since 2.0\n * @apioption chart.marginRight\n */\n /**\n * The margin between the top outer edge of the chart and the plot area.\n * Use this to set a fixed pixel value for the margin as opposed to\n * the default dynamic margin. See also `spacingTop`.\n *\n * @sample {highcharts} highcharts/chart/margintop/ 100px top margin\n * @sample {highstock} stock/chart/margintop/\n * 100px top margin\n * @sample {highmaps} maps/chart/margin/\n * 100px margins\n *\n * @type {number}\n * @since 2.0\n * @apioption chart.marginTop\n */\n /**\n * Callback function to override the default function that formats all\n * the numbers in the chart. Returns a string with the formatted number.\n *\n * @sample highcharts/members/highcharts-numberformat\n * Arabic digits in Highcharts\n * @type {Highcharts.NumberFormatterCallbackFunction}\n * @since 8.0.0\n * @apioption chart.numberFormatter\n */\n /**\n * Allows setting a key to switch between zooming and panning. Can be\n * one of `alt`, `ctrl`, `meta` (the command key on Mac and Windows\n * key on Windows) or `shift`. The keys are mapped directly to the key\n * properties of the click event argument (`event.altKey`,\n * `event.ctrlKey`, `event.metaKey` and `event.shiftKey`).\n *\n * @type {string}\n * @since 4.0.3\n * @product highcharts gantt\n * @validvalue [\"alt\", \"ctrl\", \"meta\", \"shift\"]\n * @apioption chart.panKey\n */\n /**\n * Allow panning in a chart. Best used with [panKey](#chart.panKey)\n * to combine zooming and panning.\n *\n * On touch devices, when the [tooltip.followTouchMove](\n * #tooltip.followTouchMove) option is `true` (default), panning\n * requires two fingers. To allow panning with one finger, set\n * `followTouchMove` to `false`.\n *\n * @sample {highcharts} highcharts/chart/pankey/ Zooming and panning\n * @sample {highstock} stock/chart/panning/ Zooming and xy panning\n */\n panning: {\n /**\n * Enable or disable chart panning.\n *\n * @type {boolean}\n * @default {highcharts} false\n * @default {highstock|highmaps} true\n */\n enabled: false,\n /**\n * Decides in what dimensions the user can pan the chart. Can be\n * one of `x`, `y`, or `xy`.\n *\n * @sample {highcharts} highcharts/chart/panning-type\n * Zooming and xy panning\n *\n * @declare Highcharts.OptionsChartPanningTypeValue\n * @type {string}\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @default {highcharts|highstock} x\n * @default {highmaps} xy\n */\n type: 'x'\n },\n /**\n * Equivalent to [zoomType](#chart.zoomType), but for multitouch\n * gestures only. By default, the `pinchType` is the same as the\n * `zoomType` setting. However, pinching can be enabled separately in\n * some cases, for example in stock charts where a mouse drag pans the\n * chart, while pinching is enabled. When [tooltip.followTouchMove](\n * #tooltip.followTouchMove) is true, pinchType only applies to\n * two-finger touches.\n *\n * @type {string}\n * @default {highcharts} undefined\n * @default {highstock} x\n * @since 3.0\n * @product highcharts highstock gantt\n * @deprecated\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @apioption chart.pinchType\n */\n /**\n * Whether to apply styled mode. When in styled mode, no presentational\n * attributes or CSS are applied to the chart SVG. Instead, CSS rules\n * are required to style the chart. The default style sheet is\n * available from `https://code.highcharts.com/css/highcharts.css`.\n *\n * @type {boolean}\n * @default false\n * @since 7.0\n * @apioption chart.styledMode\n */\n styledMode: false,\n /**\n * The corner radius of the outer chart border.\n *\n * @sample {highcharts} highcharts/chart/borderradius/\n * 20px radius\n * @sample {highstock} stock/chart/border/\n * 10px radius\n * @sample {highmaps} maps/chart/border/\n * Border options\n *\n */\n borderRadius: 0,\n /**\n * In styled mode, this sets how many colors the class names\n * should rotate between. With ten colors, series (or points) are\n * given class names like `highcharts-color-0`, `highcharts-color-0`\n * [...] `highcharts-color-9`. The equivalent in non-styled mode\n * is to set colors using the [colors](#colors) setting.\n *\n * @since 5.0.0\n */\n colorCount: 10,\n /**\n * By default, (because of memory and performance reasons) the chart does\n * not copy the data but keeps it as a reference. In some cases, this might\n * result in mutating the original data source. In order to prevent that,\n * set that property to false. Please note that changing that might decrease\n * performance, especially with bigger sets of data.\n *\n * @type {boolean}\n * @since 10.1.0\n */\n allowMutatingData: true,\n /**\n * Alias of `type`.\n *\n * @sample {highcharts} highcharts/chart/defaultseriestype/\n * Bar\n *\n * @deprecated\n *\n * @product highcharts\n */\n defaultSeriesType: 'line',\n /**\n * If true, the axes will scale to the remaining visible series once\n * one series is hidden. If false, hiding and showing a series will\n * not affect the axes or the other series. For stacks, once one series\n * within the stack is hidden, the rest of the stack will close in\n * around it even if the axis is not affected.\n *\n * @sample {highcharts} highcharts/chart/ignorehiddenseries-true/\n * True by default\n * @sample {highcharts} highcharts/chart/ignorehiddenseries-false/\n * False\n * @sample {highcharts} highcharts/chart/ignorehiddenseries-true-stacked/\n * True with stack\n * @sample {highstock} stock/chart/ignorehiddenseries-true/\n * True by default\n * @sample {highstock} stock/chart/ignorehiddenseries-false/\n * False\n *\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n ignoreHiddenSeries: true,\n /**\n * Whether to invert the axes so that the x axis is vertical and y axis\n * is horizontal. When `true`, the x axis is [reversed](#xAxis.reversed)\n * by default.\n *\n * @productdesc {highcharts}\n * If a bar series is present in the chart, it will be inverted\n * automatically. Inverting the chart doesn't have an effect if there\n * are no cartesian series in the chart, or if the chart is\n * [polar](#chart.polar).\n *\n * @sample {highcharts} highcharts/chart/inverted/\n * Inverted line\n * @sample {highstock} stock/navigator/inverted/\n * Inverted stock chart\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock gantt\n * @apioption chart.inverted\n */\n /**\n * The distance between the outer edge of the chart and the content,\n * like title or legend, or axis title and labels if present. The\n * numbers in the array designate top, right, bottom and left\n * respectively. Use the options spacingTop, spacingRight, spacingBottom\n * and spacingLeft options for shorthand setting of one option.\n *\n * @type {Array}\n * @see [chart.margin](#chart.margin)\n * @default [10, 10, 15, 10]\n * @since 3.0.6\n */\n spacing: [10, 10, 15, 10],\n /**\n * The button that appears after a selection zoom, allowing the user\n * to reset zoom.\n *\n * @since 2.2\n * @deprecated 10.2.1\n */\n resetZoomButton: {\n /**\n * What frame the button placement should be related to. Can be\n * either `plotBox` or `spacingBox`.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-relativeto/\n * Relative to the chart\n * @sample {highstock} highcharts/chart/resetzoombutton-relativeto/\n * Relative to the chart\n *\n * @type {Highcharts.ButtonRelativeToValue}\n * @default plot\n * @apioption chart.resetZoomButton.relativeTo\n */\n /**\n * A collection of attributes for the button. The object takes SVG\n * attributes like `fill`, `stroke`, `stroke-width` or `r`, the\n * border radius. The theme also supports `style`, a collection of\n * CSS properties for the text. Equivalent attributes for the hover\n * state are given in `theme.states.hover`.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-theme/\n * Theming the button\n * @sample {highstock} highcharts/chart/resetzoombutton-theme/\n * Theming the button\n *\n * @type {Highcharts.SVGAttributes}\n */\n theme: {\n /**\n * @internal\n */\n zIndex: 6\n },\n /**\n * The position of the button.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n * @sample {highstock} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n * @sample {highmaps} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n *\n * @type {Highcharts.AlignObject}\n */\n position: {\n /**\n * The horizontal alignment of the button.\n */\n align: 'right',\n /**\n * The horizontal offset of the button.\n */\n x: -10,\n /**\n * The vertical alignment of the button.\n *\n * @type {Highcharts.VerticalAlignValue}\n * @default top\n * @apioption chart.resetZoomButton.position.verticalAlign\n */\n /**\n * The vertical offset of the button.\n */\n y: 10\n }\n },\n /**\n * The pixel width of the plot area border.\n *\n * @sample {highcharts} highcharts/chart/plotborderwidth/\n * 1px border\n * @sample {highstock} stock/chart/plotborder/\n * 2px border\n * @sample {highmaps} maps/chart/plotborder/\n * Plot border options\n *\n * @type {number}\n * @default 0\n * @apioption chart.plotBorderWidth\n */\n /**\n * Whether to apply a drop shadow to the plot area. Requires that\n * plotBackgroundColor be set. The shadow can be an object configuration\n * containing `color`, `offsetX`, `offsetY`, `opacity` and `width`.\n *\n * @sample {highcharts} highcharts/chart/plotshadow/\n * Plot shadow\n * @sample {highstock} stock/chart/plotshadow/\n * Plot shadow\n * @sample {highmaps} maps/chart/plotborder/\n * Plot border options\n *\n * @type {boolean|Highcharts.CSSObject}\n * @default false\n * @apioption chart.plotShadow\n */\n /**\n * When true, cartesian charts like line, spline, area and column are\n * transformed into the polar coordinate system. This produces _polar\n * charts_, also known as _radar charts_.\n *\n * @sample {highcharts} highcharts/demo/polar/\n * Polar chart\n * @sample {highcharts} highcharts/demo/polar-wind-rose/\n * Wind rose, stacked polar column chart\n * @sample {highcharts} highcharts/demo/polar-spider/\n * Spider web chart\n * @sample {highcharts} highcharts/parallel-coordinates/polar/\n * Star plot, multivariate data in a polar chart\n *\n * @type {boolean}\n * @default false\n * @since 2.3.0\n * @product highcharts\n * @requires highcharts-more\n * @apioption chart.polar\n */\n /**\n * Whether to reflow the chart to fit the width of the container div\n * on resizing the window.\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * True by default\n * @sample {highcharts} highcharts/chart/reflow-false/\n * False\n * @sample {highstock} stock/chart/reflow-true/\n * True by default\n * @sample {highstock} stock/chart/reflow-false/\n * False\n * @sample {highmaps} maps/chart/reflow-true/\n * True by default\n * @sample {highmaps} maps/chart/reflow-false/\n * False\n *\n * @type {boolean}\n * @default true\n * @since 2.1\n * @apioption chart.reflow\n */\n /**\n * The HTML element where the chart will be rendered. If it is a string,\n * the element by that id is used. The HTML element can also be passed\n * by direct reference, or as the first argument of the chart\n * constructor, in which case the option is not needed.\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * String\n * @sample {highcharts} highcharts/chart/renderto-object/\n * Object reference\n * @sample {highstock} stock/chart/renderto-string/\n * String\n * @sample {highstock} stock/chart/renderto-object/\n * Object reference\n *\n * @type {string|Highcharts.HTMLDOMElement}\n * @apioption chart.renderTo\n */\n /**\n * The background color of the marker square when selecting (zooming\n * in on) an area of the chart.\n *\n * @see In styled mode, the selection marker fill is set with the\n * `.highcharts-selection-marker` class.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default rgba(51,92,173,0.25)\n * @since 2.1.7\n * @apioption chart.selectionMarkerFill\n */\n /**\n * Whether to apply a drop shadow to the outer chart area. Requires\n * that backgroundColor be set. The shadow can be an object\n * configuration containing `color`, `offsetX`, `offsetY`, `opacity` and\n * `width`.\n *\n * @sample {highcharts} highcharts/chart/shadow/\n * Shadow\n * @sample {highstock} stock/chart/shadow/\n * Shadow\n * @sample {highmaps} maps/chart/border/\n * Chart border and shadow\n *\n * @type {boolean|Highcharts.CSSObject}\n * @default false\n * @apioption chart.shadow\n */\n /**\n * Whether to show the axes initially. This only applies to empty charts\n * where series are added dynamically, as axes are automatically added\n * to cartesian series.\n *\n * @sample {highcharts} highcharts/chart/showaxes-false/\n * False by default\n * @sample {highcharts} highcharts/chart/showaxes-true/\n * True\n *\n * @type {boolean}\n * @since 1.2.5\n * @product highcharts gantt\n * @apioption chart.showAxes\n */\n /**\n * The space between the bottom edge of the chart and the content (plot\n * area, axis title and labels, title, subtitle or legend in top\n * position).\n *\n * @sample {highcharts} highcharts/chart/spacingbottom/\n * Spacing bottom set to 100\n * @sample {highstock} stock/chart/spacingbottom/\n * Spacing bottom set to 100\n * @sample {highmaps} maps/chart/spacing/\n * Spacing 100 all around\n *\n * @type {number}\n * @default 15\n * @since 2.1\n * @apioption chart.spacingBottom\n */\n /**\n * The space between the left edge of the chart and the content (plot\n * area, axis title and labels, title, subtitle or legend in top\n * position).\n *\n * @sample {highcharts} highcharts/chart/spacingleft/\n * Spacing left set to 100\n * @sample {highstock} stock/chart/spacingleft/\n * Spacing left set to 100\n * @sample {highmaps} maps/chart/spacing/\n * Spacing 100 all around\n *\n * @type {number}\n * @default 10\n * @since 2.1\n * @apioption chart.spacingLeft\n */\n /**\n * The space between the right edge of the chart and the content (plot\n * area, axis title and labels, title, subtitle or legend in top\n * position).\n *\n * @sample {highcharts} highcharts/chart/spacingright-100/\n * Spacing set to 100\n * @sample {highcharts} highcharts/chart/spacingright-legend/\n * Legend in right position with default spacing\n * @sample {highstock} stock/chart/spacingright/\n * Spacing set to 100\n * @sample {highmaps} maps/chart/spacing/\n * Spacing 100 all around\n *\n * @type {number}\n * @default 10\n * @since 2.1\n * @apioption chart.spacingRight\n */\n /**\n * The space between the top edge of the chart and the content (plot\n * area, axis title and labels, title, subtitle or legend in top\n * position).\n *\n * @sample {highcharts} highcharts/chart/spacingtop-100/\n * A top spacing of 100\n * @sample {highcharts} highcharts/chart/spacingtop-10/\n * Floating chart title makes the plot area align to the default\n * spacingTop of 10.\n * @sample {highstock} stock/chart/spacingtop/\n * A top spacing of 100\n * @sample {highmaps} maps/chart/spacing/\n * Spacing 100 all around\n *\n * @type {number}\n * @default 10\n * @since 2.1\n * @apioption chart.spacingTop\n */\n /**\n * Additional CSS styles to apply inline to the container `div`. Note\n * that since the default font styles are applied in the renderer, it\n * is ignorant of the individual chart options and must be set globally.\n *\n * @see In styled mode, general chart styles can be set with the\n * `.highcharts-root` class.\n * @sample {highcharts} highcharts/chart/style-serif-font/\n * Using a serif type font\n * @sample {highcharts} highcharts/css/em/\n * Styled mode with relative font sizes\n * @sample {highstock} stock/chart/style/\n * Using a serif type font\n * @sample {highmaps} maps/chart/style-serif-font/\n * Using a serif type font\n *\n * @type {Highcharts.CSSObject}\n * @default {\"fontFamily\": \"\\\"Lucida Grande\\\", \\\"Lucida Sans Unicode\\\", Verdana, Arial, Helvetica, sans-serif\",\"fontSize\":\"12px\"}\n * @apioption chart.style\n */\n /**\n * The default series type for the chart. Can be any of the chart types\n * listed under [plotOptions](#plotOptions) and [series](#series) or can\n * be a series provided by an additional module.\n *\n * In TypeScript this option has no effect in sense of typing and\n * instead the `type` option must always be set in the series.\n *\n * @sample {highcharts} highcharts/chart/type-bar/\n * Bar\n * @sample {highstock} stock/chart/type/\n * Areaspline\n * @sample {highmaps} maps/chart/type-mapline/\n * Mapline\n *\n * @type {string}\n * @default {highcharts} line\n * @default {highstock} line\n * @default {highmaps} map\n * @since 2.1.0\n * @apioption chart.type\n */\n /**\n * Decides in what dimensions the user can zoom by dragging the mouse.\n * Can be one of `x`, `y` or `xy`.\n *\n * @see [panKey](#chart.panKey)\n *\n * @sample {highcharts} highcharts/chart/zoomtype-none/\n * None by default\n * @sample {highcharts} highcharts/chart/zoomtype-x/\n * X\n * @sample {highcharts} highcharts/chart/zoomtype-y/\n * Y\n * @sample {highcharts} highcharts/chart/zoomtype-xy/\n * Xy\n * @sample {highcharts} highcharts/chart/zoomtype-polar/\n * Zoom on polar chart\n * @sample {highstock} stock/demo/basic-line/\n * None by default\n * @sample {highstock} stock/chart/zoomtype-x/\n * X\n * @sample {highstock} stock/chart/zoomtype-y/\n * Y\n * @sample {highstock} stock/chart/zoomtype-xy/\n * Xy\n * @sample {highmaps} maps/chart/zoomtype-xy/\n * Map with selection zoom\n *\n * @type {string}\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @deprecated\n * @apioption chart.zoomType\n */\n /**\n * Enables zooming by a single touch, in combination with\n * [chart.zoomType](#chart.zoomType). When enabled, two-finger pinch\n * will still work as set up by [chart.pinchType](#chart.pinchType).\n * However, `zoomBySingleTouch` will interfere with touch-dragging the\n * chart to read the tooltip. And especially when vertical zooming is\n * enabled, it will make it hard to scroll vertically on the page.\n * @since 9.0.0\n * @sample highcharts/chart/zoombysingletouch\n * Zoom by single touch enabled, with buttons to toggle\n * @product highcharts highstock gantt\n * @deprecated\n */\n zoomBySingleTouch: false,\n /**\n * Chart zooming options.\n * @since 10.2.1\n */\n zooming: {\n /**\n * Equivalent to [type](#chart.zooming.type), but for multitouch\n * gestures only. By default, the `pinchType` is the same as the\n * `type` setting. However, pinching can be enabled separately in\n * some cases, for example in stock charts where a mouse drag pans the\n * chart, while pinching is enabled. When [tooltip.followTouchMove](\n * #tooltip.followTouchMove) is true, pinchType only applies to\n * two-finger touches.\n *\n * @type {string}\n * @default {highcharts} undefined\n * @default {highstock} x\n * @product highcharts highstock gantt\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @apioption chart.zooming.pinchType\n */\n /**\n * Decides in what dimensions the user can zoom by dragging the mouse.\n * Can be one of `x`, `y` or `xy`.\n *\n * @declare Highcharts.OptionsChartZoomingTypeValue\n * @type {string}\n * @default {highcharts} undefined\n * @product highcharts highstock gantt\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @apioption chart.zooming.type\n */\n /**\n * Set a key to hold when dragging to zoom the chart. This is useful to\n * avoid zooming while moving points. Should be set different than\n * [chart.panKey](#chart.panKey).\n *\n * @type {string}\n * @default {highcharts} undefined\n * @validvalue [\"alt\", \"ctrl\", \"meta\", \"shift\"]\n * @requires modules/draggable-points\n * @apioption chart.zooming.key\n */\n /**\n * Enables zooming by a single touch, in combination with\n * [chart.zooming.type](#chart.zooming.type). When enabled, two-finger\n * pinch will still work as set up by [chart.zooming.pinchType]\n * (#chart.zooming.pinchType). However, `singleTouch` will interfere\n * with touch-dragging the chart to read the tooltip. And especially\n * when vertical zooming is enabled, it will make it hard to scroll\n * vertically on the page.\n *\n * @sample highcharts/chart/zoombysingletouch\n * Zoom by single touch enabled, with buttons to toggle\n *\n * @product highcharts highstock gantt\n */\n singleTouch: false,\n /**\n * The button that appears after a selection zoom, allowing the user\n * to reset zoom.\n */\n resetButton: {\n /**\n * What frame the button placement should be related to. Can be\n * either `plotBox` or `spacingBox`.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-relativeto/\n * Relative to the chart\n * @sample {highstock} highcharts/chart/resetzoombutton-relativeto/\n * Relative to the chart\n *\n * @type {Highcharts.ButtonRelativeToValue}\n * @default plot\n * @apioption chart.zooming.resetButton.relativeTo\n */\n /**\n * A collection of attributes for the button. The object takes SVG\n * attributes like `fill`, `stroke`, `stroke-width` or `r`, the\n * border radius. The theme also supports `style`, a collection of\n * CSS properties for the text. Equivalent attributes for the hover\n * state are given in `theme.states.hover`.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-theme/\n * Theming the button\n * @sample {highstock} highcharts/chart/resetzoombutton-theme/\n * Theming the button\n *\n * @type {Highcharts.SVGAttributes}\n * @since 10.2.1\n */\n theme: {\n /** @internal */\n zIndex: 6\n },\n /**\n * The position of the button.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n * @sample {highstock} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n * @sample {highmaps} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n *\n * @type {Highcharts.AlignObject}\n * @since 10.2.1\n */\n position: {\n /**\n * The horizontal alignment of the button.\n */\n align: 'right',\n /**\n * The horizontal offset of the button.\n */\n x: -10,\n /**\n * The vertical alignment of the button.\n *\n * @type {Highcharts.VerticalAlignValue}\n * @default top\n * @apioption chart.zooming.resetButton.position.verticalAlign\n */\n /**\n * The vertical offset of the button.\n */\n y: 10\n }\n }\n },\n /**\n * An explicit width for the chart. By default (when `null`) the width\n * is calculated from the offset width of the containing element.\n *\n * @sample {highcharts} highcharts/chart/width/\n * 800px wide\n * @sample {highstock} stock/chart/width/\n * 800px wide\n * @sample {highmaps} maps/chart/size/\n * Chart with explicit size\n *\n * @type {null|number|string}\n */\n width: null,\n /**\n * An explicit height for the chart. If a _number_, the height is\n * given in pixels. If given a _percentage string_ (for example\n * `'56%'`), the height is given as the percentage of the actual chart\n * width. This allows for preserving the aspect ratio across responsive\n * sizes.\n *\n * By default (when `null`) the height is calculated from the offset\n * height of the containing element, or 400 pixels if the containing\n * element's height is 0.\n *\n * @sample {highcharts} highcharts/chart/height/\n * 500px height\n * @sample {highstock} stock/chart/height/\n * 300px height\n * @sample {highmaps} maps/chart/size/\n * Chart with explicit size\n * @sample highcharts/chart/height-percent/\n * Highcharts with percentage height\n *\n * @type {null|number|string}\n */\n height: null,\n /**\n * The color of the outer chart border.\n *\n * @see In styled mode, the stroke is set with the\n * `.highcharts-background` class.\n *\n * @sample {highcharts} highcharts/chart/bordercolor/\n * Brown border\n * @sample {highstock} stock/chart/border/\n * Brown border\n * @sample {highmaps} maps/chart/border/\n * Border options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n borderColor: \"#335cad\" /* Palette.highlightColor80 */,\n /**\n * The pixel width of the outer chart border.\n *\n * @see In styled mode, the stroke is set with the\n * `.highcharts-background` class.\n *\n * @sample {highcharts} highcharts/chart/borderwidth/\n * 5px border\n * @sample {highstock} stock/chart/border/\n * 2px border\n * @sample {highmaps} maps/chart/border/\n * Border options\n *\n * @type {number}\n * @default 0\n * @apioption chart.borderWidth\n */\n /**\n * The background color or gradient for the outer chart area.\n *\n * @see In styled mode, the background is set with the\n * `.highcharts-background` class.\n *\n * @sample {highcharts} highcharts/chart/backgroundcolor-color/\n * Color\n * @sample {highcharts} highcharts/chart/backgroundcolor-gradient/\n * Gradient\n * @sample {highstock} stock/chart/backgroundcolor-color/\n * Color\n * @sample {highstock} stock/chart/backgroundcolor-gradient/\n * Gradient\n * @sample {highmaps} maps/chart/backgroundcolor-color/\n * Color\n * @sample {highmaps} maps/chart/backgroundcolor-gradient/\n * Gradient\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n backgroundColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The background color or gradient for the plot area.\n *\n * @see In styled mode, the plot background is set with the\n * `.highcharts-plot-background` class.\n *\n * @sample {highcharts} highcharts/chart/plotbackgroundcolor-color/\n * Color\n * @sample {highcharts} highcharts/chart/plotbackgroundcolor-gradient/\n * Gradient\n * @sample {highstock} stock/chart/plotbackgroundcolor-color/\n * Color\n * @sample {highstock} stock/chart/plotbackgroundcolor-gradient/\n * Gradient\n * @sample {highmaps} maps/chart/plotbackgroundcolor-color/\n * Color\n * @sample {highmaps} maps/chart/plotbackgroundcolor-gradient/\n * Gradient\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption chart.plotBackgroundColor\n */\n /**\n * The URL for an image to use as the plot background. To set an image\n * as the background for the entire chart, set a CSS background image\n * to the container element. Note that for the image to be applied to\n * exported charts, its URL needs to be accessible by the export server.\n *\n * @see In styled mode, a plot background image can be set with the\n * `.highcharts-plot-background` class and a [custom pattern](\n * https://www.highcharts.com/docs/chart-design-and-style/\n * gradients-shadows-and-patterns).\n *\n * @sample {highcharts} highcharts/chart/plotbackgroundimage/\n * Skies\n * @sample {highstock} stock/chart/plotbackgroundimage/\n * Skies\n *\n * @type {string}\n * @apioption chart.plotBackgroundImage\n */\n /**\n * The color of the inner chart or plot area border.\n *\n * @see In styled mode, a plot border stroke can be set with the\n * `.highcharts-plot-border` class.\n *\n * @sample {highcharts} highcharts/chart/plotbordercolor/\n * Blue border\n * @sample {highstock} stock/chart/plotborder/\n * Blue border\n * @sample {highmaps} maps/chart/plotborder/\n * Plot border options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n plotBorderColor: \"#cccccc\" /* Palette.neutralColor20 */\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return ChartDefaults;\n });\n _registerModule(_modules, 'Core/Color/Color.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var isNumber = U.isNumber,\n merge = U.merge,\n pInt = U.pInt;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Handle color operations. Some object methods are chainable.\n *\n * @class\n * @name Highcharts.Color\n *\n * @param {Highcharts.ColorType} input\n * The input color in either rbga or hex format\n */\n var Color = /** @class */ (function () {\n /* *\n *\n * Constructor\n *\n * */\n function Color(input) {\n this.rgba = [NaN, NaN, NaN, NaN];\n this.input = input;\n var GlobalColor = H.Color;\n // Backwards compatibility, allow class overwrite\n if (GlobalColor && GlobalColor !== Color) {\n return new GlobalColor(input);\n }\n // Backwards compatibility, allow instanciation without new (#13053)\n if (!(this instanceof Color)) {\n return new Color(input);\n }\n this.init(input);\n }\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Creates a color instance out of a color string or object.\n *\n * @function Highcharts.Color.parse\n *\n * @param {Highcharts.ColorType} [input]\n * The input color in either rbga or hex format.\n *\n * @return {Highcharts.Color}\n * Color instance.\n */\n Color.parse = function (input) {\n return input ? new Color(input) : Color.None;\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Parse the input color to rgba array\n *\n * @private\n * @function Highcharts.Color#init\n *\n * @param {Highcharts.ColorType} input\n * The input color in either rbga or hex format\n */\n Color.prototype.init = function (input) {\n var result,\n rgba,\n i,\n parser;\n // Gradients\n if (typeof input === 'object' &&\n typeof input.stops !== 'undefined') {\n this.stops = input.stops.map(function (stop) { return new Color(stop[1]); });\n // Solid colors\n }\n else if (typeof input === 'string') {\n this.input = input = (Color.names[input.toLowerCase()] || input);\n // Bitmasking as input[0] is not working for legacy IE.\n if (input.charAt(0) === '#') {\n var len = input.length,\n col = parseInt(input.substr(1), 16);\n // Handle long-form, e.g. #AABBCC\n if (len === 7) {\n rgba = [\n (col & 0xFF0000) >> 16,\n (col & 0xFF00) >> 8,\n (col & 0xFF),\n 1\n ];\n // Handle short-form, e.g. #ABC\n // In short form, the value is assumed to be the same\n // for both nibbles for each component. e.g. #ABC = #AABBCC\n }\n else if (len === 4) {\n rgba = [\n (((col & 0xF00) >> 4) |\n (col & 0xF00) >> 8),\n (((col & 0xF0) >> 4) |\n (col & 0xF0)),\n ((col & 0xF) << 4) | (col & 0xF),\n 1\n ];\n }\n }\n // Otherwise, check regex parsers\n if (!rgba) {\n i = Color.parsers.length;\n while (i-- && !rgba) {\n parser = Color.parsers[i];\n result = parser.regex.exec(input);\n if (result) {\n rgba = parser.parse(result);\n }\n }\n }\n }\n if (rgba) {\n this.rgba = rgba;\n }\n };\n /**\n * Return the color or gradient stops in the specified format\n *\n * @function Highcharts.Color#get\n *\n * @param {string} [format]\n * Possible values are 'a', 'rgb', 'rgba' (default).\n *\n * @return {Highcharts.ColorType}\n * This color as a string or gradient stops.\n */\n Color.prototype.get = function (format) {\n var input = this.input,\n rgba = this.rgba;\n if (typeof input === 'object' &&\n typeof this.stops !== 'undefined') {\n var ret_1 = merge(input);\n ret_1.stops = [].slice.call(ret_1.stops);\n this.stops.forEach(function (stop, i) {\n ret_1.stops[i] = [\n ret_1.stops[i][0],\n stop.get(format)\n ];\n });\n return ret_1;\n }\n // it's NaN if gradient colors on a column chart\n if (rgba && isNumber(rgba[0])) {\n if (format === 'rgb' || (!format && rgba[3] === 1)) {\n return 'rgb(' + rgba[0] + ',' + rgba[1] + ',' + rgba[2] + ')';\n }\n if (format === 'a') {\n return \"\".concat(rgba[3]);\n }\n return 'rgba(' + rgba.join(',') + ')';\n }\n return input;\n };\n /**\n * Brighten the color instance.\n *\n * @function Highcharts.Color#brighten\n *\n * @param {number} alpha\n * The alpha value.\n *\n * @return {Highcharts.Color}\n * This color with modifications.\n */\n Color.prototype.brighten = function (alpha) {\n var rgba = this.rgba;\n if (this.stops) {\n this.stops.forEach(function (stop) {\n stop.brighten(alpha);\n });\n }\n else if (isNumber(alpha) && alpha !== 0) {\n for (var i = 0; i < 3; i++) {\n rgba[i] += pInt(alpha * 255);\n if (rgba[i] < 0) {\n rgba[i] = 0;\n }\n if (rgba[i] > 255) {\n rgba[i] = 255;\n }\n }\n }\n return this;\n };\n /**\n * Set the color's opacity to a given alpha value.\n *\n * @function Highcharts.Color#setOpacity\n *\n * @param {number} alpha\n * Opacity between 0 and 1.\n *\n * @return {Highcharts.Color}\n * Color with modifications.\n */\n Color.prototype.setOpacity = function (alpha) {\n this.rgba[3] = alpha;\n return this;\n };\n /**\n * Return an intermediate color between two colors.\n *\n * @function Highcharts.Color#tweenTo\n *\n * @param {Highcharts.Color} to\n * The color object to tween to.\n *\n * @param {number} pos\n * The intermediate position, where 0 is the from color (current color\n * item), and 1 is the `to` color.\n *\n * @return {Highcharts.ColorType}\n * The intermediate color in rgba notation, or unsupported type.\n */\n Color.prototype.tweenTo = function (to, pos) {\n var fromRgba = this.rgba,\n toRgba = to.rgba;\n // Unsupported color, return to-color (#3920, #7034)\n if (!isNumber(fromRgba[0]) || !isNumber(toRgba[0])) {\n return to.input || 'none';\n }\n // Check for has alpha, because rgba colors perform worse due to\n // lack of support in WebKit.\n var hasAlpha = (toRgba[3] !== 1 || fromRgba[3] !== 1);\n return (hasAlpha ? 'rgba(' : 'rgb(') +\n Math.round(toRgba[0] + (fromRgba[0] - toRgba[0]) * (1 - pos)) +\n ',' +\n Math.round(toRgba[1] + (fromRgba[1] - toRgba[1]) * (1 - pos)) +\n ',' +\n Math.round(toRgba[2] + (fromRgba[2] - toRgba[2]) * (1 - pos)) +\n (hasAlpha ?\n (',' +\n (toRgba[3] + (fromRgba[3] - toRgba[3]) * (1 - pos))) :\n '') +\n ')';\n };\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * Collection of named colors. Can be extended from the outside by adding\n * colors to Highcharts.Color.names.\n * @private\n */\n Color.names = {\n white: '#ffffff',\n black: '#000000'\n };\n /**\n * Collection of parsers. This can be extended from the outside by pushing\n * parsers to `Color.parsers`.\n */\n Color.parsers = [{\n // RGBA color\n // eslint-disable-next-line max-len\n regex: /rgba\\(\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*,\\s*([0-9]?(?:\\.[0-9]+)?)\\s*\\)/,\n parse: function (result) {\n return [\n pInt(result[1]),\n pInt(result[2]),\n pInt(result[3]),\n parseFloat(result[4], 10)\n ];\n }\n }, {\n // RGB color\n regex: /rgb\\(\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*\\)/,\n parse: function (result) {\n return [pInt(result[1]), pInt(result[2]), pInt(result[3]), 1];\n }\n }];\n // Must be last static member for init cycle\n Color.None = new Color('');\n return Color;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * A valid color to be parsed and handled by Highcharts. Highcharts internally\n * supports hex colors like `#ffffff`, rgb colors like `rgb(255,255,255)` and\n * rgba colors like `rgba(255,255,255,1)`. Other colors may be supported by the\n * browsers and displayed correctly, but Highcharts is not able to process them\n * and apply concepts like opacity and brightening.\n *\n * @typedef {string} Highcharts.ColorString\n */\n /**\n * A valid color type than can be parsed and handled by Highcharts. It can be a\n * color string, a gradient object, or a pattern object.\n *\n * @typedef {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject} Highcharts.ColorType\n */\n /**\n * Gradient options instead of a solid color.\n *\n * @example\n * // Linear gradient used as a color option\n * color: {\n * linearGradient: { x1: 0, x2: 0, y1: 0, y2: 1 },\n * stops: [\n * [0, '#003399'], // start\n * [0.5, '#ffffff'], // middle\n * [1, '#3366AA'] // end\n * ]\n * }\n *\n * @interface Highcharts.GradientColorObject\n */ /**\n * Holds an object that defines the start position and the end position relative\n * to the shape.\n * @name Highcharts.GradientColorObject#linearGradient\n * @type {Highcharts.LinearGradientColorObject|undefined}\n */ /**\n * Holds an object that defines the center position and the radius.\n * @name Highcharts.GradientColorObject#radialGradient\n * @type {Highcharts.RadialGradientColorObject|undefined}\n */ /**\n * The first item in each tuple is the position in the gradient, where 0 is the\n * start of the gradient and 1 is the end of the gradient. Multiple stops can be\n * applied. The second item is the color for each stop. This color can also be\n * given in the rgba format.\n * @name Highcharts.GradientColorObject#stops\n * @type {Array}\n */\n /**\n * Color stop tuple.\n *\n * @see Highcharts.GradientColorObject\n *\n * @interface Highcharts.GradientColorStopObject\n */ /**\n * @name Highcharts.GradientColorStopObject#0\n * @type {number}\n */ /**\n * @name Highcharts.GradientColorStopObject#1\n * @type {Highcharts.ColorString}\n */ /**\n * @name Highcharts.GradientColorStopObject#color\n * @type {Highcharts.Color|undefined}\n */\n /**\n * Defines the start position and the end position for a gradient relative\n * to the shape. Start position (x1, y1) and end position (x2, y2) are relative\n * to the shape, where 0 means top/left and 1 is bottom/right.\n *\n * @interface Highcharts.LinearGradientColorObject\n */ /**\n * Start horizontal position of the gradient. Float ranges 0-1.\n * @name Highcharts.LinearGradientColorObject#x1\n * @type {number}\n */ /**\n * End horizontal position of the gradient. Float ranges 0-1.\n * @name Highcharts.LinearGradientColorObject#x2\n * @type {number}\n */ /**\n * Start vertical position of the gradient. Float ranges 0-1.\n * @name Highcharts.LinearGradientColorObject#y1\n * @type {number}\n */ /**\n * End vertical position of the gradient. Float ranges 0-1.\n * @name Highcharts.LinearGradientColorObject#y2\n * @type {number}\n */\n /**\n * Defines the center position and the radius for a gradient.\n *\n * @interface Highcharts.RadialGradientColorObject\n */ /**\n * Center horizontal position relative to the shape. Float ranges 0-1.\n * @name Highcharts.RadialGradientColorObject#cx\n * @type {number}\n */ /**\n * Center vertical position relative to the shape. Float ranges 0-1.\n * @name Highcharts.RadialGradientColorObject#cy\n * @type {number}\n */ /**\n * Radius relative to the shape. Float ranges 0-1.\n * @name Highcharts.RadialGradientColorObject#r\n * @type {number}\n */\n /**\n * Creates a color instance out of a color string.\n *\n * @function Highcharts.color\n *\n * @param {Highcharts.ColorType} input\n * The input color in either rbga or hex format\n *\n * @return {Highcharts.Color}\n * Color instance\n */\n (''); // detach doclets above\n\n return Color;\n });\n _registerModule(_modules, 'Core/Color/Palettes.js', [], function () {\n /**\n * Series palettes for Highcharts. Series colors are defined in highcharts.scss.\n * **Do not edit this file!** This file is generated using the 'gulp palette' task.\n */\n var SeriesPalettes = {\n /**\n * Colors for data series and points.\n */\n colors: [\n '#7cb5ec',\n '#434348',\n '#90ed7d',\n '#f7a35c',\n '#8085e9',\n '#f15c80',\n '#e4d354',\n '#2b908f',\n '#f45b5b',\n '#91e8e1'\n ]\n };\n\n return SeriesPalettes;\n });\n _registerModule(_modules, 'Core/Time.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var win = H.win;\n var defined = U.defined,\n error = U.error,\n extend = U.extend,\n isObject = U.isObject,\n merge = U.merge,\n objectEach = U.objectEach,\n pad = U.pad,\n pick = U.pick,\n splat = U.splat,\n timeUnits = U.timeUnits;\n /* *\n *\n * Constants\n *\n * */\n var hasNewSafariBug = H.isSafari &&\n win.Intl &&\n win.Intl.DateTimeFormat.prototype.formatRange;\n // To do: Remove this when we no longer need support for Safari < v14.1\n var hasOldSafariBug = H.isSafari &&\n win.Intl &&\n !win.Intl.DateTimeFormat.prototype.formatRange;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The Time class. Time settings are applied in general for each page using\n * `Highcharts.setOptions`, or individually for each Chart item through the\n * [time](https://api.highcharts.com/highcharts/time) options set.\n *\n * The Time object is available from {@link Highcharts.Chart#time},\n * which refers to `Highcharts.time` if no individual time settings are\n * applied.\n *\n * @example\n * // Apply time settings globally\n * Highcharts.setOptions({\n * time: {\n * timezone: 'Europe/London'\n * }\n * });\n *\n * // Apply time settings by instance\n * let chart = Highcharts.chart('container', {\n * time: {\n * timezone: 'America/New_York'\n * },\n * series: [{\n * data: [1, 4, 3, 5]\n * }]\n * });\n *\n * // Use the Time object\n * console.log(\n * 'Current time in New York',\n * chart.time.dateFormat('%Y-%m-%d %H:%M:%S', Date.now())\n * );\n *\n * @since 6.0.5\n *\n * @class\n * @name Highcharts.Time\n *\n * @param {Highcharts.TimeOptions} [options]\n * Time options as defined in [chart.options.time](/highcharts/time).\n */\n var Time = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Time(options) {\n /* *\n *\n * Properties\n *\n * */\n this.options = {};\n this.useUTC = false;\n this.variableTimezone = false;\n this.Date = win.Date;\n /**\n * Get the time zone offset based on the current timezone information as\n * set in the global options.\n *\n * @function Highcharts.Time#getTimezoneOffset\n *\n * @param {number} timestamp\n * The JavaScript timestamp to inspect.\n *\n * @return {number}\n * The timezone offset in minutes compared to UTC.\n */\n this.getTimezoneOffset = this.timezoneOffsetFunction();\n this.update(options);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Time units used in `Time.get` and `Time.set`\n *\n * @typedef {\"Date\"|\"Day\"|\"FullYear\"|\"Hours\"|\"Milliseconds\"|\"Minutes\"|\"Month\"|\"Seconds\"} Highcharts.TimeUnitValue\n */\n /**\n * Get the value of a date object in given units, and subject to the Time\n * object's current timezone settings. This function corresponds directly to\n * JavaScripts `Date.getXXX / Date.getUTCXXX`, so instead of calling\n * `date.getHours()` or `date.getUTCHours()` we will call\n * `time.get('Hours')`.\n *\n * @function Highcharts.Time#get\n *\n * @param {Highcharts.TimeUnitValue} unit\n * @param {Date} date\n *\n * @return {number}\n * The given time unit\n */\n Time.prototype.get = function (unit, date) {\n if (this.variableTimezone || this.timezoneOffset) {\n var realMs = date.getTime();\n var ms = realMs - this.getTimezoneOffset(date);\n date.setTime(ms); // Temporary adjust to timezone\n var ret = date['getUTC' + unit]();\n date.setTime(realMs); // Reset\n return ret;\n }\n // UTC time with no timezone handling\n if (this.useUTC) {\n return date['getUTC' + unit]();\n }\n // Else, local time\n return date['get' + unit]();\n };\n /**\n * Set the value of a date object in given units, and subject to the Time\n * object's current timezone settings. This function corresponds directly to\n * JavaScripts `Date.setXXX / Date.setUTCXXX`, so instead of calling\n * `date.setHours(0)` or `date.setUTCHours(0)` we will call\n * `time.set('Hours', 0)`.\n *\n * @function Highcharts.Time#set\n *\n * @param {Highcharts.TimeUnitValue} unit\n * @param {Date} date\n * @param {number} value\n *\n * @return {number}\n * The epoch milliseconds of the updated date\n */\n Time.prototype.set = function (unit, date, value) {\n // UTC time with timezone handling\n if (this.variableTimezone || this.timezoneOffset) {\n // For lower order time units, just set it directly using UTC\n // time\n if (unit === 'Milliseconds' ||\n unit === 'Seconds' ||\n (unit === 'Minutes' &&\n this.getTimezoneOffset(date) % 3600000 === 0) // #13961\n ) {\n return date['setUTC' + unit](value);\n }\n // Higher order time units need to take the time zone into\n // account\n // Adjust by timezone\n var offset = this.getTimezoneOffset(date);\n var ms = date.getTime() - offset;\n date.setTime(ms);\n date['setUTC' + unit](value);\n var newOffset = this.getTimezoneOffset(date);\n ms = date.getTime() + newOffset;\n return date.setTime(ms);\n }\n // UTC time with no timezone handling\n if (this.useUTC ||\n // leap calculation in UTC only\n (hasNewSafariBug && unit === 'FullYear')) {\n return date['setUTC' + unit](value);\n }\n // Else, local time\n return date['set' + unit](value);\n };\n /**\n * Update the Time object with current options. It is called internally on\n * initializing Highcharts, after running `Highcharts.setOptions` and on\n * `Chart.update`.\n *\n * @private\n * @function Highcharts.Time#update\n *\n * @param {Highcharts.TimeOptions} [options]\n *\n */\n Time.prototype.update = function (options) {\n if (options === void 0) { options = {}; }\n var useUTC = pick(options.useUTC,\n true);\n this.options = options = merge(true, this.options, options);\n // Allow using a different Date class\n this.Date = options.Date || win.Date || Date;\n this.useUTC = useUTC;\n this.timezoneOffset = (useUTC && options.timezoneOffset) || void 0;\n this.getTimezoneOffset = this.timezoneOffsetFunction();\n /*\n * The time object has options allowing for variable time zones, meaning\n * the axis ticks or series data needs to consider this.\n */\n this.variableTimezone = useUTC && !!(options.getTimezoneOffset ||\n options.timezone);\n };\n /**\n * Make a time and returns milliseconds. Interprets the inputs as UTC time,\n * local time or a specific timezone time depending on the current time\n * settings.\n *\n * @function Highcharts.Time#makeTime\n *\n * @param {number} year\n * The year\n *\n * @param {number} month\n * The month. Zero-based, so January is 0.\n *\n * @param {number} [date=1]\n * The day of the month\n *\n * @param {number} [hours=0]\n * The hour of the day, 0-23.\n *\n * @param {number} [minutes=0]\n * The minutes\n *\n * @param {number} [seconds=0]\n * The seconds\n *\n * @return {number}\n * The time in milliseconds since January 1st 1970.\n */\n Time.prototype.makeTime = function (year, month, date, hours, minutes, seconds) {\n var d,\n offset,\n newOffset;\n if (this.useUTC) {\n d = this.Date.UTC.apply(0, arguments);\n offset = this.getTimezoneOffset(d);\n d += offset;\n newOffset = this.getTimezoneOffset(d);\n if (offset !== newOffset) {\n d += newOffset - offset;\n // A special case for transitioning from summer time to winter time.\n // When the clock is set back, the same time is repeated twice, i.e.\n // 02:30 am is repeated since the clock is set back from 3 am to\n // 2 am. We need to make the same time as local Date does.\n }\n else if (offset - 36e5 === this.getTimezoneOffset(d - 36e5) &&\n !hasOldSafariBug) {\n d -= 36e5;\n }\n }\n else {\n d = new this.Date(year, month, pick(date, 1), pick(hours, 0), pick(minutes, 0), pick(seconds, 0)).getTime();\n }\n return d;\n };\n /**\n * Sets the getTimezoneOffset function. If the `timezone` option is set, a\n * default getTimezoneOffset function with that timezone is returned. If\n * a `getTimezoneOffset` option is defined, it is returned. If neither are\n * specified, the function using the `timezoneOffset` option or 0 offset is\n * returned.\n *\n * @private\n * @function Highcharts.Time#timezoneOffsetFunction\n *\n * @return {Function}\n * A getTimezoneOffset function\n */\n Time.prototype.timezoneOffsetFunction = function () {\n var time = this,\n options = this.options,\n getTimezoneOffset = options.getTimezoneOffset,\n moment = options.moment || win.moment;\n if (!this.useUTC) {\n return function (timestamp) {\n return new Date(timestamp.toString()).getTimezoneOffset() * 60000;\n };\n }\n if (options.timezone) {\n if (!moment) {\n // getTimezoneOffset-function stays undefined because it depends\n // on Moment.js\n error(25);\n }\n else {\n return function (timestamp) {\n return -moment.tz(timestamp, options.timezone).utcOffset() * 60000;\n };\n }\n }\n // If not timezone is set, look for the getTimezoneOffset callback\n if (this.useUTC && getTimezoneOffset) {\n return function (timestamp) {\n return getTimezoneOffset(timestamp.valueOf()) * 60000;\n };\n }\n // Last, use the `timezoneOffset` option if set\n return function () {\n return (time.timezoneOffset || 0) * 60000;\n };\n };\n /**\n * Formats a JavaScript date timestamp (milliseconds since Jan 1st 1970)\n * into a human readable date string. The available format keys are listed\n * below. Additional formats can be given in the\n * {@link Highcharts.dateFormats} hook.\n *\n * Supported format keys:\n * - `%a`: Short weekday, like 'Mon'\n * - `%A`: Long weekday, like 'Monday'\n * - `%d`: Two digit day of the month, 01 to 31\n * - `%e`: Day of the month, 1 through 31\n * - `%w`: Day of the week, 0 through 6\n * - `%b`: Short month, like 'Jan'\n * - `%B`: Long month, like 'January'\n * - `%m`: Two digit month number, 01 through 12\n * - `%y`: Two digits year, like 09 for 2009\n * - `%Y`: Four digits year, like 2009\n * - `%H`: Two digits hours in 24h format, 00 through 23\n * - `%k`: Hours in 24h format, 0 through 23\n * - `%I`: Two digits hours in 12h format, 00 through 11\n * - `%l`: Hours in 12h format, 1 through 12\n * - `%M`: Two digits minutes, 00 through 59\n * - `%p`: Upper case AM or PM\n * - `%P`: Lower case AM or PM\n * - `%S`: Two digits seconds, 00 through 59\n * - `%L`: Milliseconds (naming from Ruby)\n *\n * @example\n * const time = new Highcharts.Time();\n * const s = time.dateFormat('%Y-%m-%d %H:%M:%S', Date.UTC(2020, 0, 1));\n * console.log(s); // => 2020-01-01 00:00:00\n *\n * @function Highcharts.Time#dateFormat\n *\n * @param {string} format\n * The desired format where various time representations are\n * prefixed with %.\n *\n * @param {number} [timestamp]\n * The JavaScript timestamp.\n *\n * @param {boolean} [capitalize=false]\n * Upper case first letter in the return.\n *\n * @return {string}\n * The formatted date.\n */\n Time.prototype.dateFormat = function (format, timestamp, capitalize) {\n if (!defined(timestamp) || isNaN(timestamp)) {\n return (H.defaultOptions.lang &&\n H.defaultOptions.lang.invalidDate ||\n '');\n }\n format = pick(format, '%Y-%m-%d %H:%M:%S');\n var time = this, date = new this.Date(timestamp), \n // get the basic time values\n hours = this.get('Hours', date), day = this.get('Day', date), dayOfMonth = this.get('Date', date), month = this.get('Month', date), fullYear = this.get('FullYear', date), lang = H.defaultOptions.lang, langWeekdays = (lang && lang.weekdays), shortWeekdays = (lang && lang.shortWeekdays), \n // List all format keys. Custom formats can be added from the\n // outside.\n replacements = extend({\n // Day\n // Short weekday, like 'Mon'\n a: shortWeekdays ?\n shortWeekdays[day] :\n langWeekdays[day].substr(0, 3),\n // Long weekday, like 'Monday'\n A: langWeekdays[day],\n // Two digit day of the month, 01 to 31\n d: pad(dayOfMonth),\n // Day of the month, 1 through 31\n e: pad(dayOfMonth, 2, ' '),\n // Day of the week, 0 through 6\n w: day,\n // Week (none implemented)\n // 'W': weekNumber(),\n // Month\n // Short month, like 'Jan'\n b: lang.shortMonths[month],\n // Long month, like 'January'\n B: lang.months[month],\n // Two digit month number, 01 through 12\n m: pad(month + 1),\n // Month number, 1 through 12 (#8150)\n o: month + 1,\n // Year\n // Two digits year, like 09 for 2009\n y: fullYear.toString().substr(2, 2),\n // Four digits year, like 2009\n Y: fullYear,\n // Time\n // Two digits hours in 24h format, 00 through 23\n H: pad(hours),\n // Hours in 24h format, 0 through 23\n k: hours,\n // Two digits hours in 12h format, 00 through 11\n I: pad((hours % 12) || 12),\n // Hours in 12h format, 1 through 12\n l: (hours % 12) || 12,\n // Two digits minutes, 00 through 59\n M: pad(this.get('Minutes', date)),\n // Upper case AM or PM\n p: hours < 12 ? 'AM' : 'PM',\n // Lower case AM or PM\n P: hours < 12 ? 'am' : 'pm',\n // Two digits seconds, 00 through 59\n S: pad(date.getSeconds()),\n // Milliseconds (naming from Ruby)\n L: pad(Math.floor(timestamp % 1000), 3)\n }, H.dateFormats);\n // Do the replaces\n objectEach(replacements, function (val, key) {\n // Regex would do it in one line, but this is faster\n while (format.indexOf('%' + key) !== -1) {\n format = format.replace('%' + key, typeof val === 'function' ? val.call(time, timestamp) : val);\n }\n });\n // Optionally capitalize the string and return\n return capitalize ?\n (format.substr(0, 1).toUpperCase() +\n format.substr(1)) :\n format;\n };\n /**\n * Resolve legacy formats of dateTimeLabelFormats (strings and arrays) into\n * an object.\n * @private\n * @param {string|Array|Highcharts.Dictionary} f\n * General format description\n * @return {Highcharts.Dictionary}\n * The object definition\n */\n Time.prototype.resolveDTLFormat = function (f) {\n if (!isObject(f, true)) { // check for string or array\n f = splat(f);\n return {\n main: f[0],\n from: f[1],\n to: f[2]\n };\n }\n return f;\n };\n /**\n * Return an array with time positions distributed on round time values\n * right and right after min and max. Used in datetime axes as well as for\n * grouping data on a datetime axis.\n *\n * @function Highcharts.Time#getTimeTicks\n *\n * @param {Highcharts.TimeNormalizedObject} normalizedInterval\n * The interval in axis values (ms) and the count\n *\n * @param {number} [min]\n * The minimum in axis values\n *\n * @param {number} [max]\n * The maximum in axis values\n *\n * @param {number} [startOfWeek=1]\n *\n * @return {Highcharts.AxisTickPositionsArray}\n * Time positions\n */\n Time.prototype.getTimeTicks = function (normalizedInterval, min, max, startOfWeek) {\n var time = this,\n Date = time.Date,\n tickPositions = [],\n higherRanks = {}, \n // When crossing DST, use the max. Resolves #6278.\n minDate = new Date(min),\n interval = normalizedInterval.unitRange,\n count = normalizedInterval.count || 1;\n var i,\n minYear, // used in months and years as a basis for Date.UTC()\n variableDayLength,\n minDay;\n startOfWeek = pick(startOfWeek, 1);\n if (defined(min)) { // #1300\n time.set('Milliseconds', minDate, interval >= timeUnits.second ?\n 0 : // #3935\n count * Math.floor(time.get('Milliseconds', minDate) / count)); // #3652, #3654\n if (interval >= timeUnits.second) { // second\n time.set('Seconds', minDate, interval >= timeUnits.minute ?\n 0 : // #3935\n count * Math.floor(time.get('Seconds', minDate) / count));\n }\n if (interval >= timeUnits.minute) { // minute\n time.set('Minutes', minDate, interval >= timeUnits.hour ?\n 0 :\n count * Math.floor(time.get('Minutes', minDate) / count));\n }\n if (interval >= timeUnits.hour) { // hour\n time.set('Hours', minDate, interval >= timeUnits.day ?\n 0 :\n count * Math.floor(time.get('Hours', minDate) / count));\n }\n if (interval >= timeUnits.day) { // day\n time.set('Date', minDate, interval >= timeUnits.month ?\n 1 :\n Math.max(1, count * Math.floor(time.get('Date', minDate) / count)));\n }\n if (interval >= timeUnits.month) { // month\n time.set('Month', minDate, interval >= timeUnits.year ? 0 :\n count * Math.floor(time.get('Month', minDate) / count));\n minYear = time.get('FullYear', minDate);\n }\n if (interval >= timeUnits.year) { // year\n minYear -= minYear % count;\n time.set('FullYear', minDate, minYear);\n }\n // week is a special case that runs outside the hierarchy\n if (interval === timeUnits.week) {\n // get start of current week, independent of count\n minDay = time.get('Day', minDate);\n time.set('Date', minDate, (time.get('Date', minDate) -\n minDay + startOfWeek +\n // We don't want to skip days that are before\n // startOfWeek (#7051)\n (minDay < startOfWeek ? -7 : 0)));\n }\n // Get basics for variable time spans\n minYear = time.get('FullYear', minDate);\n var minMonth = time.get('Month', minDate), minDateDate = time.get('Date', minDate), minHours = time.get('Hours', minDate);\n // Redefine min to the floored/rounded minimum time (#7432)\n min = minDate.getTime();\n // Handle local timezone offset\n if ((time.variableTimezone || !time.useUTC) && defined(max)) {\n // Detect whether we need to take the DST crossover into\n // consideration. If we're crossing over DST, the day length may\n // be 23h or 25h and we need to compute the exact clock time for\n // each tick instead of just adding hours. This comes at a cost,\n // so first we find out if it is needed (#4951).\n variableDayLength = (\n // Long range, assume we're crossing over.\n max - min > 4 * timeUnits.month ||\n // Short range, check if min and max are in different time\n // zones.\n time.getTimezoneOffset(min) !==\n time.getTimezoneOffset(max));\n }\n // Iterate and add tick positions at appropriate values\n var t = minDate.getTime();\n i = 1;\n while (t < max) {\n tickPositions.push(t);\n // if the interval is years, use Date.UTC to increase years\n if (interval === timeUnits.year) {\n t = time.makeTime(minYear + i * count, 0);\n // if the interval is months, use Date.UTC to increase months\n }\n else if (interval === timeUnits.month) {\n t = time.makeTime(minYear, minMonth + i * count);\n // if we're using global time, the interval is not fixed as it\n // jumps one hour at the DST crossover\n }\n else if (variableDayLength &&\n (interval === timeUnits.day || interval === timeUnits.week)) {\n t = time.makeTime(minYear, minMonth, minDateDate +\n i * count * (interval === timeUnits.day ? 1 : 7));\n }\n else if (variableDayLength &&\n interval === timeUnits.hour &&\n count > 1) {\n // make sure higher ranks are preserved across DST (#6797,\n // #7621)\n t = time.makeTime(minYear, minMonth, minDateDate, minHours + i * count);\n // else, the interval is fixed and we use simple addition\n }\n else {\n t += interval * count;\n }\n i++;\n }\n // push the last time\n tickPositions.push(t);\n // Handle higher ranks. Mark new days if the time is on midnight\n // (#950, #1649, #1760, #3349). Use a reasonable dropout threshold\n // to prevent looping over dense data grouping (#6156).\n if (interval <= timeUnits.hour && tickPositions.length < 10000) {\n tickPositions.forEach(function (t) {\n if (\n // Speed optimization, no need to run dateFormat unless\n // we're on a full or half hour\n t % 1800000 === 0 &&\n // Check for local or global midnight\n time.dateFormat('%H%M%S%L', t) === '000000000') {\n higherRanks[t] = 'day';\n }\n });\n }\n }\n // record information on the chosen unit - for dynamic label formatter\n tickPositions.info = extend(normalizedInterval, {\n higherRanks: higherRanks,\n totalRange: interval * count\n });\n return tickPositions;\n };\n /**\n * Get the optimal date format for a point, based on a range.\n *\n * @private\n * @function Highcharts.Time#getDateFormat\n *\n * @param {number} range\n * The time range\n *\n * @param {number} timestamp\n * The timestamp of the date\n *\n * @param {number} startOfWeek\n * An integer representing the first day of the week, where 0 is\n * Sunday.\n *\n * @param {Highcharts.Dictionary} dateTimeLabelFormats\n * A map of time units to formats.\n *\n * @return {string}\n * The optimal date format for a point.\n */\n Time.prototype.getDateFormat = function (range, timestamp, startOfWeek, dateTimeLabelFormats) {\n var dateStr = this.dateFormat('%m-%d %H:%M:%S.%L', timestamp), blank = '01-01 00:00:00.000', strpos = {\n millisecond: 15,\n second: 12,\n minute: 9,\n hour: 6,\n day: 3\n };\n var n = 'millisecond', \n // for sub-millisecond data, #4223\n lastN = n;\n for (n in timeUnits) { // eslint-disable-line guard-for-in\n // If the range is exactly one week and we're looking at a\n // Sunday/Monday, go for the week format\n if (range === timeUnits.week &&\n +this.dateFormat('%w', timestamp) === startOfWeek &&\n dateStr.substr(6) === blank.substr(6)) {\n n = 'week';\n break;\n }\n // The first format that is too great for the range\n if (timeUnits[n] > range) {\n n = lastN;\n break;\n }\n // If the point is placed every day at 23:59, we need to show\n // the minutes as well. #2637.\n if (strpos[n] &&\n dateStr.substr(strpos[n]) !== blank.substr(strpos[n])) {\n break;\n }\n // Weeks are outside the hierarchy, only apply them on\n // Mondays/Sundays like in the first condition\n if (n !== 'week') {\n lastN = n;\n }\n }\n return this.resolveDTLFormat(dateTimeLabelFormats[n]).main;\n };\n return Time;\n }());\n /* *\n *\n * Default export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Normalized interval.\n *\n * @interface Highcharts.TimeNormalizedObject\n */ /**\n * The count.\n *\n * @name Highcharts.TimeNormalizedObject#count\n * @type {number|undefined}\n */ /**\n * The interval in axis values (ms).\n *\n * @name Highcharts.TimeNormalizedObject#unitRange\n * @type {number}\n */\n /**\n * Function of an additional date format specifier.\n *\n * @callback Highcharts.TimeFormatCallbackFunction\n *\n * @param {number} timestamp\n * The time to format.\n *\n * @return {string}\n * The formatted portion of the date.\n */\n /**\n * Time ticks.\n *\n * @interface Highcharts.AxisTickPositionsArray\n * @extends global.Array\n */ /**\n * @name Highcharts.AxisTickPositionsArray#info\n * @type {Highcharts.TimeTicksInfoObject|undefined}\n */\n /**\n * A callback to return the time zone offset for a given datetime. It\n * takes the timestamp in terms of milliseconds since January 1 1970,\n * and returns the timezone offset in minutes. This provides a hook\n * for drawing time based charts in specific time zones using their\n * local DST crossover dates, with the help of external libraries.\n *\n * @callback Highcharts.TimezoneOffsetCallbackFunction\n *\n * @param {number} timestamp\n * Timestamp in terms of milliseconds since January 1 1970.\n *\n * @return {number}\n * Timezone offset in minutes.\n */\n /**\n * Allows to manually load the `moment.js` library from Highcharts options\n * instead of the `window`.\n * In case of loading the library from a `script` tag,\n * this option is not needed, it will be loaded from there by default.\n *\n * @type {Function}\n * @since 8.2.0\n * @apioption time.moment\n */\n ''; // keeps doclets above in JS file\n\n return Time;\n });\n _registerModule(_modules, 'Core/Defaults.js', [_modules['Core/Chart/ChartDefaults.js'], _modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Color/Palettes.js'], _modules['Core/Time.js'], _modules['Core/Utilities.js']], function (ChartDefaults, Color, H, Palettes, Time, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var color = Color.parse;\n var isTouchDevice = H.isTouchDevice,\n svg = H.svg;\n var merge = U.merge;\n /* *\n *\n * API Options\n *\n * */\n /**\n * Global default settings.\n *\n * @name Highcharts.defaultOptions\n * @type {Highcharts.Options}\n */ /**\n * @optionparent\n * @private\n */\n var defaultOptions = {\n /**\n * An array containing the default colors for the chart's series. When\n * all colors are used, new colors are pulled from the start again.\n *\n * Default colors can also be set on a series or series.type basis,\n * see [column.colors](#plotOptions.column.colors),\n * [pie.colors](#plotOptions.pie.colors).\n *\n * In styled mode, the colors option doesn't exist. Instead, colors\n * are defined in CSS and applied either through series or point class\n * names, or through the [chart.colorCount](#chart.colorCount) option.\n *\n *\n * ### Legacy\n *\n * In Highcharts 3.x, the default colors were:\n * ```js\n * colors: ['#2f7ed8', '#0d233a', '#8bbc21', '#910000', '#1aadce',\n * '#492970', '#f28f43', '#77a1e5', '#c42525', '#a6c96a']\n * ```\n *\n * In Highcharts 2.x, the default colors were:\n * ```js\n * colors: ['#4572A7', '#AA4643', '#89A54E', '#80699B', '#3D96AE',\n * '#DB843D', '#92A8CD', '#A47D7C', '#B5CA92']\n * ```\n *\n * @sample {highcharts} highcharts/chart/colors/\n * Assign a global color theme\n *\n * @type {Array<(Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject)>}\n * @default [\"#7cb5ec\", \"#434348\", \"#90ed7d\", \"#f7a35c\", \"#8085e9\",\n * \"#f15c80\", \"#e4d354\", \"#2b908f\", \"#f45b5b\", \"#91e8e1\"]\n */\n colors: Palettes.colors,\n /**\n * Styled mode only. Configuration object for adding SVG definitions for\n * reusable elements. See [gradients, shadows and\n * patterns](https://www.highcharts.com/docs/chart-design-and-style/gradients-shadows-and-patterns)\n * for more information and code examples.\n *\n * @type {*}\n * @since 5.0.0\n * @apioption defs\n */\n /**\n * @ignore-option\n */\n symbols: ['circle', 'diamond', 'square', 'triangle', 'triangle-down'],\n /**\n * The language object is global and it can't be set on each chart\n * initialization. Instead, use `Highcharts.setOptions` to set it before any\n * chart is initialized.\n *\n * ```js\n * Highcharts.setOptions({\n * lang: {\n * months: [\n * 'Janvier', 'Février', 'Mars', 'Avril',\n * 'Mai', 'Juin', 'Juillet', 'Août',\n * 'Septembre', 'Octobre', 'Novembre', 'Décembre'\n * ],\n * weekdays: [\n * 'Dimanche', 'Lundi', 'Mardi', 'Mercredi',\n * 'Jeudi', 'Vendredi', 'Samedi'\n * ]\n * }\n * });\n * ```\n */\n lang: {\n /**\n * The loading text that appears when the chart is set into the loading\n * state following a call to `chart.showLoading`.\n */\n loading: 'Loading...',\n /**\n * An array containing the months names. Corresponds to the `%B` format\n * in `Highcharts.dateFormat()`.\n *\n * @type {Array}\n * @default [\"January\", \"February\", \"March\", \"April\", \"May\", \"June\",\n * \"July\", \"August\", \"September\", \"October\", \"November\",\n * \"December\"]\n */\n months: [\n 'January', 'February', 'March', 'April', 'May', 'June', 'July',\n 'August', 'September', 'October', 'November', 'December'\n ],\n /**\n * An array containing the months names in abbreviated form. Corresponds\n * to the `%b` format in `Highcharts.dateFormat()`.\n *\n * @type {Array}\n * @default [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\",\n * \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"]\n */\n shortMonths: [\n 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul',\n 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'\n ],\n /**\n * An array containing the weekday names.\n *\n * @type {Array}\n * @default [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\",\n * \"Friday\", \"Saturday\"]\n */\n weekdays: [\n 'Sunday', 'Monday', 'Tuesday', 'Wednesday',\n 'Thursday', 'Friday', 'Saturday'\n ],\n /**\n * Short week days, starting Sunday. If not specified, Highcharts uses\n * the first three letters of the `lang.weekdays` option.\n *\n * @sample highcharts/lang/shortweekdays/\n * Finnish two-letter abbreviations\n *\n * @type {Array}\n * @since 4.2.4\n * @apioption lang.shortWeekdays\n */\n /**\n * What to show in a date field for invalid dates. Defaults to an empty\n * string.\n *\n * @type {string}\n * @since 4.1.8\n * @product highcharts highstock\n * @apioption lang.invalidDate\n */\n /**\n * The title appearing on hovering the zoom in button. The text itself\n * defaults to \"+\" and can be changed in the button options.\n *\n * @type {string}\n * @default Zoom in\n * @product highmaps\n * @apioption lang.zoomIn\n */\n /**\n * The title appearing on hovering the zoom out button. The text itself\n * defaults to \"-\" and can be changed in the button options.\n *\n * @type {string}\n * @default Zoom out\n * @product highmaps\n * @apioption lang.zoomOut\n */\n /**\n * The default decimal point used in the `Highcharts.numberFormat`\n * method unless otherwise specified in the function arguments.\n *\n * @since 1.2.2\n */\n decimalPoint: '.',\n /**\n * [Metric prefixes](https://en.wikipedia.org/wiki/Metric_prefix) used\n * to shorten high numbers in axis labels. Replacing any of the\n * positions with `null` causes the full number to be written. Setting\n * `numericSymbols` to `null` disables shortening altogether.\n *\n * @sample {highcharts} highcharts/lang/numericsymbols/\n * Replacing the symbols with text\n * @sample {highstock} highcharts/lang/numericsymbols/\n * Replacing the symbols with text\n *\n * @type {Array}\n * @default [\"k\", \"M\", \"G\", \"T\", \"P\", \"E\"]\n * @since 2.3.0\n */\n numericSymbols: ['k', 'M', 'G', 'T', 'P', 'E'],\n /**\n * The magnitude of [numericSymbols](#lang.numericSymbol) replacements.\n * Use 10000 for Japanese, Korean and various Chinese locales, which\n * use symbols for 10^4, 10^8 and 10^12.\n *\n * @sample highcharts/lang/numericsymbolmagnitude/\n * 10000 magnitude for Japanese\n *\n * @type {number}\n * @default 1000\n * @since 5.0.3\n * @apioption lang.numericSymbolMagnitude\n */\n /**\n * The text for the label appearing when a chart is zoomed.\n *\n * @since 1.2.4\n */\n resetZoom: 'Reset zoom',\n /**\n * The tooltip title for the label appearing when a chart is zoomed.\n *\n * @since 1.2.4\n */\n resetZoomTitle: 'Reset zoom level 1:1',\n /**\n * The default thousands separator used in the `Highcharts.numberFormat`\n * method unless otherwise specified in the function arguments. Defaults\n * to a single space character, which is recommended in\n * [ISO 31-0](https://en.wikipedia.org/wiki/ISO_31-0#Numbers) and works\n * across Anglo-American and continental European languages.\n *\n * @default \\u0020\n * @since 1.2.2\n */\n thousandsSep: ' '\n },\n /**\n * Global options that don't apply to each chart. These options, like\n * the `lang` options, must be set using the `Highcharts.setOptions`\n * method.\n *\n * ```js\n * Highcharts.setOptions({\n * global: {\n * useUTC: false\n * }\n * });\n * ```\n */\n /**\n * _Canvg rendering for Android 2.x is removed as of Highcharts 5.0\\.\n * Use the [libURL](#exporting.libURL) option to configure exporting._\n *\n * The URL to the additional file to lazy load for Android 2.x devices.\n * These devices don't support SVG, so we download a helper file that\n * contains [canvg](https://github.com/canvg/canvg), its dependency\n * rbcolor, and our own CanVG Renderer class. To avoid hotlinking to\n * our site, you can install canvas-tools.js on your own server and\n * change this option accordingly.\n *\n * @deprecated\n *\n * @type {string}\n * @default https://code.highcharts.com/{version}/modules/canvas-tools.js\n * @product highcharts highmaps\n * @apioption global.canvasToolsURL\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.useUTC](#time.useUTC) that supports individual time settings\n * per chart.\n *\n * @deprecated\n *\n * @type {boolean}\n * @apioption global.useUTC\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.Date](#time.Date) that supports individual time settings\n * per chart.\n *\n * @deprecated\n *\n * @type {Function}\n * @product highcharts highstock\n * @apioption global.Date\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.getTimezoneOffset](#time.getTimezoneOffset) that supports\n * individual time settings per chart.\n *\n * @deprecated\n *\n * @type {Function}\n * @product highcharts highstock\n * @apioption global.getTimezoneOffset\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.timezone](#time.timezone) that supports individual time\n * settings per chart.\n *\n * @deprecated\n *\n * @type {string}\n * @product highcharts highstock\n * @apioption global.timezone\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.timezoneOffset](#time.timezoneOffset) that supports individual\n * time settings per chart.\n *\n * @deprecated\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption global.timezoneOffset\n */\n global: {},\n /**\n * Time options that can apply globally or to individual charts. These\n * settings affect how `datetime` axes are laid out, how tooltips are\n * formatted, how series\n * [pointIntervalUnit](#plotOptions.series.pointIntervalUnit) works and how\n * the Highcharts Stock range selector handles time.\n *\n * The common use case is that all charts in the same Highcharts object\n * share the same time settings, in which case the global settings are set\n * using `setOptions`.\n *\n * ```js\n * // Apply time settings globally\n * Highcharts.setOptions({\n * time: {\n * timezone: 'Europe/London'\n * }\n * });\n * // Apply time settings by instance\n * let chart = Highcharts.chart('container', {\n * time: {\n * timezone: 'America/New_York'\n * },\n * series: [{\n * data: [1, 4, 3, 5]\n * }]\n * });\n *\n * // Use the Time object\n * console.log(\n * 'Current time in New York',\n * chart.time.dateFormat('%Y-%m-%d %H:%M:%S', Date.now())\n * );\n * ```\n *\n * Since v6.0.5, the time options were moved from the `global` obect to the\n * `time` object, and time options can be set on each individual chart.\n *\n * @sample {highcharts|highstock}\n * highcharts/time/timezone/\n * Set the timezone globally\n * @sample {highcharts}\n * highcharts/time/individual/\n * Set the timezone per chart instance\n * @sample {highstock}\n * stock/time/individual/\n * Set the timezone per chart instance\n *\n * @since 6.0.5\n * @optionparent time\n */\n time: {\n /**\n * A custom `Date` class for advanced date handling. For example,\n * [JDate](https://github.com/tahajahangir/jdate) can be hooked in to\n * handle Jalali dates.\n *\n * @type {*}\n * @since 4.0.4\n * @product highcharts highstock gantt\n */\n Date: void 0,\n /**\n * A callback to return the time zone offset for a given datetime. It\n * takes the timestamp in terms of milliseconds since January 1 1970,\n * and returns the timezone offset in minutes. This provides a hook\n * for drawing time based charts in specific time zones using their\n * local DST crossover dates, with the help of external libraries.\n *\n * @see [global.timezoneOffset](#global.timezoneOffset)\n *\n * @sample {highcharts|highstock} highcharts/time/gettimezoneoffset/\n * Use moment.js to draw Oslo time regardless of browser locale\n *\n * @type {Highcharts.TimezoneOffsetCallbackFunction}\n * @since 4.1.0\n * @product highcharts highstock gantt\n */\n getTimezoneOffset: void 0,\n /**\n * Requires [moment.js](https://momentjs.com/). If the timezone option\n * is specified, it creates a default\n * [getTimezoneOffset](#time.getTimezoneOffset) function that looks\n * up the specified timezone in moment.js. If moment.js is not included,\n * this throws a Highcharts error in the console, but does not crash the\n * chart.\n *\n * @see [getTimezoneOffset](#time.getTimezoneOffset)\n *\n * @sample {highcharts|highstock} highcharts/time/timezone/\n * Europe/Oslo\n *\n * @type {string}\n * @since 5.0.7\n * @product highcharts highstock gantt\n */\n timezone: void 0,\n /**\n * The timezone offset in minutes. Positive values are west, negative\n * values are east of UTC, as in the ECMAScript\n * [getTimezoneOffset](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/getTimezoneOffset)\n * method. Use this to display UTC based data in a predefined time zone.\n *\n * @see [time.getTimezoneOffset](#time.getTimezoneOffset)\n *\n * @sample {highcharts|highstock} highcharts/time/timezoneoffset/\n * Timezone offset\n *\n * @since 3.0.8\n * @product highcharts highstock gantt\n */\n timezoneOffset: 0,\n /**\n * Whether to use UTC time for axis scaling, tickmark placement and\n * time display in `Highcharts.dateFormat`. Advantages of using UTC\n * is that the time displays equally regardless of the user agent's\n * time zone settings. Local time can be used when the data is loaded\n * in real time or when correct Daylight Saving Time transitions are\n * required.\n *\n * @sample {highcharts} highcharts/time/useutc-true/\n * True by default\n * @sample {highcharts} highcharts/time/useutc-false/\n * False\n */\n useUTC: true\n },\n chart: ChartDefaults,\n /**\n * The chart's main title.\n *\n * @sample {highmaps} maps/title/title/\n * Title options demonstrated\n */\n title: {\n /**\n * When the title is floating, the plot area will not move to make space\n * for it.\n *\n * @sample {highcharts} highcharts/chart/zoomtype-none/\n * False by default\n * @sample {highcharts} highcharts/title/floating/\n * True - title on top of the plot area\n * @sample {highstock} stock/chart/title-floating/\n * True - title on top of the plot area\n *\n * @type {boolean}\n * @default false\n * @since 2.1\n * @apioption title.floating\n */\n /**\n * CSS styles for the title. Use this for font styling, but use `align`,\n * `x` and `y` for text alignment.\n *\n * In styled mode, the title style is given in the `.highcharts-title`\n * class.\n *\n * @sample {highcharts} highcharts/title/style/\n * Custom color and weight\n * @sample {highstock} stock/chart/title-style/\n * Custom color and weight\n * @sample highcharts/css/titles/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n * @default {highcharts|highmaps} { \"color\": \"#333333\", \"fontSize\": \"18px\" }\n * @default {highstock} { \"color\": \"#333333\", \"fontSize\": \"16px\" }\n * @apioption title.style\n */\n /**\n * Whether to\n * [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the text.\n *\n * @type {boolean}\n * @default false\n * @apioption title.useHTML\n */\n /**\n * The vertical alignment of the title. Can be one of `\"top\"`,\n * `\"middle\"` and `\"bottom\"`. When a value is given, the title behaves\n * as if [floating](#title.floating) were `true`.\n *\n * @sample {highcharts} highcharts/title/verticalalign/\n * Chart title in bottom right corner\n * @sample {highstock} stock/chart/title-verticalalign/\n * Chart title in bottom right corner\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 2.1\n * @apioption title.verticalAlign\n */\n /**\n * The x position of the title relative to the alignment within\n * `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @sample {highcharts} highcharts/title/align/\n * Aligned to the plot area (x = 70px = margin left - spacing\n * left)\n * @sample {highstock} stock/chart/title-align/\n * Aligned to the plot area (x = 50px = margin left - spacing\n * left)\n *\n * @type {number}\n * @default 0\n * @since 2.0\n * @apioption title.x\n */\n /**\n * The y position of the title relative to the alignment within\n * [chart.spacingTop](#chart.spacingTop) and [chart.spacingBottom](\n * #chart.spacingBottom). By default it depends on the font size.\n *\n * @sample {highcharts} highcharts/title/y/\n * Title inside the plot area\n * @sample {highstock} stock/chart/title-verticalalign/\n * Chart title in bottom right corner\n *\n * @type {number}\n * @since 2.0\n * @apioption title.y\n */\n /**\n * The title of the chart. To disable the title, set the `text` to\n * `undefined`.\n *\n * @sample {highcharts} highcharts/title/text/\n * Custom title\n * @sample {highstock} stock/chart/title-text/\n * Custom title\n *\n * @default {highcharts|highmaps} Chart title\n * @default {highstock} undefined\n */\n text: 'Chart title',\n /**\n * The horizontal alignment of the title. Can be one of \"left\", \"center\"\n * and \"right\".\n *\n * @sample {highcharts} highcharts/title/align/\n * Aligned to the plot area (x = 70px = margin left - spacing\n * left)\n * @sample {highstock} stock/chart/title-align/\n * Aligned to the plot area (x = 50px = margin left - spacing\n * left)\n *\n * @type {Highcharts.AlignValue}\n * @since 2.0\n */\n align: 'center',\n /**\n * The margin between the title and the plot area, or if a subtitle\n * is present, the margin between the subtitle and the plot area.\n *\n * @sample {highcharts} highcharts/title/margin-50/\n * A chart title margin of 50\n * @sample {highcharts} highcharts/title/margin-subtitle/\n * The same margin applied with a subtitle\n * @sample {highstock} stock/chart/title-margin/\n * A chart title margin of 50\n *\n * @since 2.1\n */\n margin: 15,\n /**\n * Adjustment made to the title width, normally to reserve space for\n * the exporting burger menu.\n *\n * @sample highcharts/title/widthadjust/\n * Wider menu, greater padding\n *\n * @since 4.2.5\n */\n widthAdjust: -44\n },\n /**\n * The chart's subtitle. This can be used both to display a subtitle below\n * the main title, and to display random text anywhere in the chart. The\n * subtitle can be updated after chart initialization through the\n * `Chart.setTitle` method.\n *\n * @sample {highmaps} maps/title/subtitle/\n * Subtitle options demonstrated\n */\n subtitle: {\n /**\n * When the subtitle is floating, the plot area will not move to make\n * space for it.\n *\n * @sample {highcharts} highcharts/subtitle/floating/\n * Floating title and subtitle\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote floating at bottom right of plot area\n *\n * @type {boolean}\n * @default false\n * @since 2.1\n * @apioption subtitle.floating\n */\n /**\n * CSS styles for the title.\n *\n * In styled mode, the subtitle style is given in the\n * `.highcharts-subtitle` class.\n *\n * @sample {highcharts} highcharts/subtitle/style/\n * Custom color and weight\n * @sample {highcharts} highcharts/css/titles/\n * Styled mode\n * @sample {highstock} stock/chart/subtitle-style\n * Custom color and weight\n * @sample {highstock} highcharts/css/titles/\n * Styled mode\n * @sample {highmaps} highcharts/css/titles/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#666666\"}\n * @apioption subtitle.style\n */\n /**\n * Whether to\n * [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the text.\n *\n * @type {boolean}\n * @default false\n * @apioption subtitle.useHTML\n */\n /**\n * The vertical alignment of the title. Can be one of `\"top\"`,\n * `\"middle\"` and `\"bottom\"`. When middle, the subtitle behaves as\n * floating.\n *\n * @sample {highcharts} highcharts/subtitle/verticalalign/\n * Footnote at the bottom right of plot area\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote at the bottom right of plot area\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 2.1\n * @apioption subtitle.verticalAlign\n */\n /**\n * The x position of the subtitle relative to the alignment within\n * `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @sample {highcharts} highcharts/subtitle/align/\n * Footnote at right of plot area\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote at the bottom right of plot area\n *\n * @type {number}\n * @default 0\n * @since 2.0\n * @apioption subtitle.x\n */\n /**\n * The y position of the subtitle relative to the alignment within\n * `chart.spacingTop` and `chart.spacingBottom`. By default the subtitle\n * is laid out below the title unless the title is floating.\n *\n * @sample {highcharts} highcharts/subtitle/verticalalign/\n * Footnote at the bottom right of plot area\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote at the bottom right of plot area\n *\n * @type {number}\n * @since 2.0\n * @apioption subtitle.y\n */\n /**\n * The subtitle of the chart.\n *\n * @sample {highcharts|highstock} highcharts/subtitle/text/\n * Custom subtitle\n * @sample {highcharts|highstock} highcharts/subtitle/text-formatted/\n * Formatted and linked text.\n */\n text: '',\n /**\n * The horizontal alignment of the subtitle. Can be one of \"left\",\n * \"center\" and \"right\".\n *\n * @sample {highcharts} highcharts/subtitle/align/\n * Footnote at right of plot area\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote at bottom right of plot area\n *\n * @type {Highcharts.AlignValue}\n * @since 2.0\n */\n align: 'center',\n /**\n * Adjustment made to the subtitle width, normally to reserve space\n * for the exporting burger menu.\n *\n * @see [title.widthAdjust](#title.widthAdjust)\n *\n * @sample highcharts/title/widthadjust/\n * Wider menu, greater padding\n *\n * @since 4.2.5\n */\n widthAdjust: -44\n },\n /**\n * The chart's caption, which will render below the chart and will be part\n * of exported charts. The caption can be updated after chart initialization\n * through the `Chart.update` or `Chart.caption.update` methods.\n *\n * @sample highcharts/caption/text/\n * A chart with a caption\n * @since 7.2.0\n */\n caption: {\n /**\n * When the caption is floating, the plot area will not move to make\n * space for it.\n *\n * @type {boolean}\n * @default false\n * @apioption caption.floating\n */\n /**\n * The margin between the caption and the plot area.\n */\n margin: 15,\n /**\n * CSS styles for the caption.\n *\n * In styled mode, the caption style is given in the\n * `.highcharts-caption` class.\n *\n * @sample {highcharts} highcharts/css/titles/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#666666\"}\n * @apioption caption.style\n */\n /**\n * Whether to\n * [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the text.\n *\n * @type {boolean}\n * @default false\n * @apioption caption.useHTML\n */\n /**\n * The x position of the caption relative to the alignment within\n * `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @type {number}\n * @default 0\n * @apioption caption.x\n */\n /**\n * The y position of the caption relative to the alignment within\n * `chart.spacingTop` and `chart.spacingBottom`.\n *\n * @type {number}\n * @apioption caption.y\n */\n /**\n * The caption text of the chart.\n *\n * @sample {highcharts} highcharts/caption/text/\n * Custom caption\n */\n text: '',\n /**\n * The horizontal alignment of the caption. Can be one of \"left\",\n * \"center\" and \"right\".\n *\n * @type {Highcharts.AlignValue}\n */\n align: 'left',\n /**\n * The vertical alignment of the caption. Can be one of `\"top\"`,\n * `\"middle\"` and `\"bottom\"`. When middle, the caption behaves as\n * floating.\n *\n * @type {Highcharts.VerticalAlignValue}\n */\n verticalAlign: 'bottom'\n },\n /**\n * The plotOptions is a wrapper object for config objects for each series\n * type. The config objects for each series can also be overridden for\n * each series item as given in the series array.\n *\n * Configuration options for the series are given in three levels. Options\n * for all series in a chart are given in the [plotOptions.series](\n * #plotOptions.series) object. Then options for all series of a specific\n * type are given in the plotOptions of that type, for example\n * `plotOptions.line`. Next, options for one single series are given in\n * [the series array](#series).\n */\n plotOptions: {},\n /**\n * HTML labels that can be positioned anywhere in the chart area.\n *\n * This option is deprecated since v7.1.2. Instead, use\n * [annotations](#annotations) that support labels.\n *\n * @deprecated\n * @product highcharts highstock\n */\n labels: {\n /**\n * An HTML label that can be positioned anywhere in the chart area.\n *\n * @deprecated\n * @type {Array<*>}\n * @apioption labels.items\n */\n /**\n * Inner HTML or text for the label.\n *\n * @deprecated\n * @type {string}\n * @apioption labels.items.html\n */\n /**\n * CSS styles for each label. To position the label, use left and top\n * like this:\n * ```js\n * style: {\n * left: '100px',\n * top: '100px'\n * }\n * ```\n *\n * @deprecated\n * @type {Highcharts.CSSObject}\n * @apioption labels.items.style\n */\n /**\n * Shared CSS styles for all labels.\n *\n * @deprecated\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#333333\", \"position\": \"absolute\"}\n */\n style: {\n /**\n * @ignore-option\n */\n position: 'absolute',\n /**\n * @ignore-option\n */\n color: \"#333333\" /* Palette.neutralColor80 */\n }\n },\n /**\n * The legend is a box containing a symbol and name for each series\n * item or point item in the chart. Each series (or points in case\n * of pie charts) is represented by a symbol and its name in the legend.\n *\n * It is possible to override the symbol creator function and create\n * [custom legend symbols](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/studies/legend-custom-symbol/).\n *\n * @productdesc {highmaps}\n * A Highmaps legend by default contains one legend item per series, but if\n * a `colorAxis` is defined, the axis will be displayed in the legend.\n * Either as a gradient, or as multiple legend items for `dataClasses`.\n */\n legend: {\n /**\n * The background color of the legend.\n *\n * @see In styled mode, the legend background fill can be applied with\n * the `.highcharts-legend-box` class.\n *\n * @sample {highcharts} highcharts/legend/backgroundcolor/\n * Yellowish background\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption legend.backgroundColor\n */\n /**\n * The width of the drawn border around the legend.\n *\n * @see In styled mode, the legend border stroke width can be applied\n * with the `.highcharts-legend-box` class.\n *\n * @sample {highcharts} highcharts/legend/borderwidth/\n * 2px border width\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n *\n * @type {number}\n * @default 0\n * @apioption legend.borderWidth\n */\n /**\n * Enable or disable the legend. There is also a series-specific option,\n * [showInLegend](#plotOptions.series.showInLegend), that can hide the\n * series from the legend. In some series types this is `false` by\n * default, so it must set to `true` in order to show the legend for the\n * series.\n *\n * @sample {highcharts} highcharts/legend/enabled-false/ Legend disabled\n * @sample {highstock} stock/legend/align/ Various legend options\n * @sample {highmaps} maps/legend/enabled-false/ Legend disabled\n *\n * @default {highstock} false\n * @default {highmaps} true\n * @default {gantt} false\n */\n enabled: true,\n /**\n * The horizontal alignment of the legend box within the chart area.\n * Valid values are `left`, `center` and `right`.\n *\n * In the case that the legend is aligned in a corner position, the\n * `layout` option will determine whether to place it above/below\n * or on the side of the plot area.\n *\n * @sample {highcharts} highcharts/legend/align/\n * Legend at the right of the chart\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/alignment/\n * Legend alignment\n *\n * @type {Highcharts.AlignValue}\n * @since 2.0\n */\n align: 'center',\n /**\n * If the [layout](legend.layout) is `horizontal` and the legend items\n * span over two lines or more, whether to align the items into vertical\n * columns. Setting this to `false` makes room for more items, but will\n * look more messy.\n *\n * @since 6.1.0\n */\n alignColumns: true,\n /**\n * A CSS class name to apply to the legend group.\n */\n className: 'highcharts-no-tooltip',\n /**\n * When the legend is floating, the plot area ignores it and is allowed\n * to be placed below it.\n *\n * @sample {highcharts} highcharts/legend/floating-false/\n * False by default\n * @sample {highcharts} highcharts/legend/floating-true/\n * True\n * @sample {highmaps} maps/legend/alignment/\n * Floating legend\n *\n * @type {boolean}\n * @default false\n * @since 2.1\n * @apioption legend.floating\n */\n /**\n * The layout of the legend items. Can be one of `horizontal` or\n * `vertical` or `proximate`. When `proximate`, the legend items will be\n * placed as close as possible to the graphs they're representing,\n * except in inverted charts or when the legend position doesn't allow\n * it.\n *\n * @sample {highcharts} highcharts/legend/layout-horizontal/\n * Horizontal by default\n * @sample {highcharts} highcharts/legend/layout-vertical/\n * Vertical\n * @sample highcharts/legend/layout-proximate\n * Labels proximate to the data\n * @sample {highstock} stock/legend/layout-horizontal/\n * Horizontal by default\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Vertical with data classes\n * @sample {highmaps} maps/legend/layout-vertical/\n * Vertical with color axis gradient\n *\n * @validvalue [\"horizontal\", \"vertical\", \"proximate\"]\n */\n layout: 'horizontal',\n /**\n * In a legend with horizontal layout, the itemDistance defines the\n * pixel distance between each item.\n *\n * @sample {highcharts} highcharts/legend/layout-horizontal/\n * 50px item distance\n * @sample {highstock} highcharts/legend/layout-horizontal/\n * 50px item distance\n *\n * @type {number}\n * @default {highcharts} 20\n * @default {highstock} 20\n * @default {highmaps} 8\n * @since 3.0.3\n * @apioption legend.itemDistance\n */\n /**\n * The pixel bottom margin for each legend item.\n *\n * @sample {highcharts|highstock} highcharts/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n *\n * @type {number}\n * @default 0\n * @since 2.2.0\n * @apioption legend.itemMarginBottom\n */\n /**\n * The pixel top margin for each legend item.\n *\n * @sample {highcharts|highstock} highcharts/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n *\n * @type {number}\n * @default 0\n * @since 2.2.0\n * @apioption legend.itemMarginTop\n */\n /**\n * The width for each legend item. By default the items are laid out\n * successively. In a [horizontal layout](legend.layout), if the items\n * are laid out across two rows or more, they will be vertically aligned\n * depending on the [legend.alignColumns](legend.alignColumns) option.\n *\n * @sample {highcharts} highcharts/legend/itemwidth-default/\n * Undefined by default\n * @sample {highcharts} highcharts/legend/itemwidth-80/\n * 80 for aligned legend items\n *\n * @type {number}\n * @since 2.0\n * @apioption legend.itemWidth\n */\n /**\n * A [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for each legend label. Available variables relates to properties on\n * the series, or the point in case of pies.\n *\n * @type {string}\n * @default {name}\n * @since 1.3\n * @apioption legend.labelFormat\n */\n /* eslint-disable valid-jsdoc */\n /**\n * Callback function to format each of the series' labels. The `this`\n * keyword refers to the series object, or the point object in case of\n * pie charts. By default the series or point name is printed.\n *\n * @productdesc {highmaps}\n * In Highmaps the context can also be a data class in case of a\n * `colorAxis`.\n *\n * @sample {highcharts} highcharts/legend/labelformatter/\n * Add text\n * @sample {highmaps} maps/legend/labelformatter/\n * Data classes with label formatter\n *\n * @type {Highcharts.FormatterCallbackFunction}\n */\n labelFormatter: function () {\n /** eslint-enable valid-jsdoc */\n return this.name;\n },\n /**\n * Line height for the legend items. Deprecated as of 2.1\\. Instead,\n * the line height for each item can be set using\n * `itemStyle.lineHeight`, and the padding between items using\n * `itemMarginTop` and `itemMarginBottom`.\n *\n * @sample {highcharts} highcharts/legend/lineheight/\n * Setting padding\n *\n * @deprecated\n *\n * @type {number}\n * @default 16\n * @since 2.0\n * @product highcharts gantt\n * @apioption legend.lineHeight\n */\n /**\n * If the plot area sized is calculated automatically and the legend is\n * not floating, the legend margin is the space between the legend and\n * the axis labels or plot area.\n *\n * @sample {highcharts} highcharts/legend/margin-default/\n * 12 pixels by default\n * @sample {highcharts} highcharts/legend/margin-30/\n * 30 pixels\n *\n * @type {number}\n * @default 12\n * @since 2.1\n * @apioption legend.margin\n */\n /**\n * Maximum pixel height for the legend. When the maximum height is\n * extended, navigation will show.\n *\n * @type {number}\n * @since 2.3.0\n * @apioption legend.maxHeight\n */\n /**\n * The color of the drawn border around the legend.\n *\n * @see In styled mode, the legend border stroke can be applied with the\n * `.highcharts-legend-box` class.\n *\n * @sample {highcharts} highcharts/legend/bordercolor/\n * Brown border\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n borderColor: \"#999999\" /* Palette.neutralColor40 */,\n /**\n * The border corner radius of the legend.\n *\n * @sample {highcharts} highcharts/legend/borderradius-default/\n * Square by default\n * @sample {highcharts} highcharts/legend/borderradius-round/\n * 5px rounded\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n */\n borderRadius: 0,\n /**\n * Options for the paging or navigation appearing when the legend is\n * overflown. Navigation works well on screen, but not in static\n * exported images. One way of working around that is to\n * [increase the chart height in\n * export](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/legend/navigation-enabled-false/).\n */\n navigation: {\n /**\n * How to animate the pages when navigating up or down. A value of\n * `true` applies the default navigation given in the\n * `chart.animation` option. Additional options can be given as an\n * object containing values for easing and duration.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {boolean|Partial}\n * @default true\n * @since 2.2.4\n * @apioption legend.navigation.animation\n */\n /**\n * The pixel size of the up and down arrows in the legend paging\n * navigation.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {number}\n * @default 12\n * @since 2.2.4\n * @apioption legend.navigation.arrowSize\n */\n /**\n * Whether to enable the legend navigation. In most cases, disabling\n * the navigation results in an unwanted overflow.\n *\n * See also the\n * [adapt chart to legend](https://github.com/highcharts/adapt-chart-to-legend)\n * plugin for a solution to extend the chart height to make room for\n * the legend, optionally in exported charts only.\n *\n * @type {boolean}\n * @default true\n * @since 4.2.4\n * @apioption legend.navigation.enabled\n */\n /**\n * Text styles for the legend page navigation.\n *\n * @see In styled mode, the navigation items are styled with the\n * `.highcharts-legend-navigation` class.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {Highcharts.CSSObject}\n * @since 2.2.4\n * @apioption legend.navigation.style\n */\n /**\n * The color for the active up or down arrow in the legend page\n * navigation.\n *\n * @see In styled mode, the active arrow be styled with the\n * `.highcharts-legend-nav-active` class.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.2.4\n */\n activeColor: \"#003399\" /* Palette.highlightColor100 */,\n /**\n * The color of the inactive up or down arrow in the legend page\n * navigation. .\n *\n * @see In styled mode, the inactive arrow be styled with the\n * `.highcharts-legend-nav-inactive` class.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.2.4\n */\n inactiveColor: \"#cccccc\" /* Palette.neutralColor20 */\n },\n /**\n * The inner padding of the legend box.\n *\n * @sample {highcharts|highstock} highcharts/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n *\n * @type {number}\n * @default 8\n * @since 2.2.0\n * @apioption legend.padding\n */\n /**\n * Whether to reverse the order of the legend items compared to the\n * order of the series or points as defined in the configuration object.\n *\n * @see [yAxis.reversedStacks](#yAxis.reversedStacks),\n * [series.legendIndex](#series.legendIndex)\n *\n * @sample {highcharts} highcharts/legend/reversed/\n * Stacked bar with reversed legend\n *\n * @type {boolean}\n * @default false\n * @since 1.2.5\n * @apioption legend.reversed\n */\n /**\n * Whether to show the symbol on the right side of the text rather than\n * the left side. This is common in Arabic and Hebrew.\n *\n * @sample {highcharts} highcharts/legend/rtl/\n * Symbol to the right\n *\n * @type {boolean}\n * @default false\n * @since 2.2\n * @apioption legend.rtl\n */\n /**\n * CSS styles for the legend area. In the 1.x versions the position\n * of the legend area was determined by CSS. In 2.x, the position is\n * determined by properties like `align`, `verticalAlign`, `x` and `y`,\n * but the styles are still parsed for backwards compatibility.\n *\n * @deprecated\n *\n * @type {Highcharts.CSSObject}\n * @product highcharts highstock\n * @apioption legend.style\n */\n /**\n * CSS styles for each legend item. Only a subset of CSS is supported,\n * notably those options related to text. The default `textOverflow`\n * property makes long texts truncate. Set it to `undefined` to wrap\n * text instead. A `width` property can be added to control the text\n * width.\n *\n * @see In styled mode, the legend items can be styled with the\n * `.highcharts-legend-item` class.\n *\n * @sample {highcharts} highcharts/legend/itemstyle/\n * Bold black text\n * @sample {highmaps} maps/legend/itemstyle/\n * Item text styles\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#333333\", \"cursor\": \"pointer\", \"fontSize\": \"12px\", \"fontWeight\": \"bold\", \"textOverflow\": \"ellipsis\"}\n */\n itemStyle: {\n /**\n * @ignore\n */\n color: \"#333333\" /* Palette.neutralColor80 */,\n /**\n * @ignore\n */\n cursor: 'pointer',\n /**\n * @ignore\n */\n fontSize: '12px',\n /**\n * @ignore\n */\n fontWeight: 'bold',\n /**\n * @ignore\n */\n textOverflow: 'ellipsis'\n },\n /**\n * CSS styles for each legend item in hover mode. Only a subset of\n * CSS is supported, notably those options related to text. Properties\n * are inherited from `style` unless overridden here.\n *\n * @see In styled mode, the hovered legend items can be styled with\n * the `.highcharts-legend-item:hover` pesudo-class.\n *\n * @sample {highcharts} highcharts/legend/itemhoverstyle/\n * Red on hover\n * @sample {highmaps} maps/legend/itemstyle/\n * Item text styles\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#000000\"}\n */\n itemHoverStyle: {\n /**\n * @ignore\n */\n color: \"#000000\" /* Palette.neutralColor100 */\n },\n /**\n * CSS styles for each legend item when the corresponding series or\n * point is hidden. Only a subset of CSS is supported, notably those\n * options related to text. Properties are inherited from `style`\n * unless overridden here.\n *\n * @see In styled mode, the hidden legend items can be styled with\n * the `.highcharts-legend-item-hidden` class.\n *\n * @sample {highcharts} highcharts/legend/itemhiddenstyle/\n * Darker gray color\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#cccccc\"}\n */\n itemHiddenStyle: {\n /**\n * @ignore\n */\n color: \"#cccccc\" /* Palette.neutralColor20 */\n },\n /**\n * Whether to apply a drop shadow to the legend. A `backgroundColor`\n * also needs to be applied for this to take effect. The shadow can be\n * an object configuration containing `color`, `offsetX`, `offsetY`,\n * `opacity` and `width`.\n *\n * @sample {highcharts} highcharts/legend/shadow/\n * White background and drop shadow\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n *\n * @type {boolean|Highcharts.CSSObject}\n */\n shadow: false,\n /**\n * Default styling for the checkbox next to a legend item when\n * `showCheckbox` is true.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"width\": \"13px\", \"height\": \"13px\", \"position\":\"absolute\"}\n */\n itemCheckboxStyle: {\n /**\n * @ignore\n */\n position: 'absolute',\n /**\n * @ignore\n */\n width: '13px',\n /**\n * @ignore\n */\n height: '13px'\n },\n // itemWidth: undefined,\n /**\n * When this is true, the legend symbol width will be the same as\n * the symbol height, which in turn defaults to the font size of the\n * legend items.\n *\n * @since 5.0.0\n */\n squareSymbol: true,\n /**\n * The pixel height of the symbol for series types that use a rectangle\n * in the legend. Defaults to the font size of legend items.\n *\n * @productdesc {highmaps}\n * In Highmaps, when the symbol is the gradient of a vertical color\n * axis, the height defaults to 200.\n *\n * @sample {highmaps} maps/legend/layout-vertical-sized/\n * Sized vertical gradient\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * No distance between data classes\n *\n * @type {number}\n * @since 3.0.8\n * @apioption legend.symbolHeight\n */\n /**\n * The border radius of the symbol for series types that use a rectangle\n * in the legend. Defaults to half the `symbolHeight`.\n *\n * @sample {highcharts} highcharts/legend/symbolradius/\n * Round symbols\n * @sample {highstock} highcharts/legend/symbolradius/\n * Round symbols\n * @sample {highmaps} highcharts/legend/symbolradius/\n * Round symbols\n *\n * @type {number}\n * @since 3.0.8\n * @apioption legend.symbolRadius\n */\n /**\n * The pixel width of the legend item symbol. When the `squareSymbol`\n * option is set, this defaults to the `symbolHeight`, otherwise 16.\n *\n * @productdesc {highmaps}\n * In Highmaps, when the symbol is the gradient of a horizontal color\n * axis, the width defaults to 200.\n *\n * @sample {highcharts} highcharts/legend/symbolwidth/\n * Greater symbol width and padding\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n * @sample {highmaps} maps/legend/layout-vertical-sized/\n * Sized vertical gradient\n *\n * @type {number}\n * @apioption legend.symbolWidth\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the legend item texts.\n *\n * Prior to 4.1.7, when using HTML, [legend.navigation](\n * #legend.navigation) was disabled.\n *\n * @type {boolean}\n * @default false\n * @apioption legend.useHTML\n */\n /**\n * For a color axis with data classes, how many decimals to render in\n * the legend. The default preserves the decimals of the range numbers.\n *\n * @type {number}\n * @default -1\n * @product highcharts highmaps\n * @apioption legend.valueDecimals\n */\n /**\n * For a color axis with data classes, a suffix for the range numbers in\n * the legend.\n *\n * @type {string}\n * @default ''\n * @product highcharts highmaps\n * @apioption legend.valueSuffix\n */\n /**\n * The width of the legend box. If a number is set, it translates to\n * pixels. Since v7.0.2 it allows setting a percent string of the full\n * chart width, for example `40%`.\n *\n * Defaults to the full chart width for legends below or above the\n * chart, half the chart width for legends to the left and right.\n *\n * @sample {highcharts} highcharts/legend/width/\n * Aligned to the plot area\n * @sample {highcharts} highcharts/legend/width-percent/\n * A percent of the chart width\n *\n * @type {number|string}\n * @since 2.0\n * @apioption legend.width\n */\n /**\n * The pixel padding between the legend item symbol and the legend\n * item text.\n *\n * @sample {highcharts} highcharts/legend/symbolpadding/\n * Greater symbol width and padding\n */\n symbolPadding: 5,\n /**\n * The vertical alignment of the legend box. Can be one of `top`,\n * `middle` or `bottom`. Vertical position can be further determined\n * by the `y` option.\n *\n * In the case that the legend is aligned in a corner position, the\n * `layout` option will determine whether to place it above/below\n * or on the side of the plot area.\n *\n * When the [layout](#legend.layout) option is `proximate`, the\n * `verticalAlign` option doesn't apply.\n *\n * @sample {highcharts} highcharts/legend/verticalalign/\n * Legend 100px from the top of the chart\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/alignment/\n * Legend alignment\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 2.0\n */\n verticalAlign: 'bottom',\n // width: undefined,\n /**\n * The x offset of the legend relative to its horizontal alignment\n * `align` within chart.spacingLeft and chart.spacingRight. Negative\n * x moves it to the left, positive x moves it to the right.\n *\n * @sample {highcharts} highcharts/legend/width/\n * Aligned to the plot area\n *\n * @since 2.0\n */\n x: 0,\n /**\n * The vertical offset of the legend relative to it's vertical alignment\n * `verticalAlign` within chart.spacingTop and chart.spacingBottom.\n * Negative y moves it up, positive y moves it down.\n *\n * @sample {highcharts} highcharts/legend/verticalalign/\n * Legend 100px from the top of the chart\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/alignment/\n * Legend alignment\n *\n * @since 2.0\n */\n y: 0,\n /**\n * A title to be added on top of the legend.\n *\n * @sample {highcharts} highcharts/legend/title/\n * Legend title\n * @sample {highmaps} maps/legend/alignment/\n * Legend with title\n *\n * @since 3.0\n */\n title: {\n /**\n * A text or HTML string for the title.\n *\n * @type {string}\n * @since 3.0\n * @apioption legend.title.text\n */\n /**\n * Generic CSS styles for the legend title.\n *\n * @see In styled mode, the legend title is styled with the\n * `.highcharts-legend-title` class.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"fontWeight\": \"bold\"}\n * @since 3.0\n */\n style: {\n /**\n * @ignore\n */\n fontWeight: 'bold'\n }\n }\n },\n /**\n * The loading options control the appearance of the loading screen\n * that covers the plot area on chart operations. This screen only\n * appears after an explicit call to `chart.showLoading()`. It is a\n * utility for developers to communicate to the end user that something\n * is going on, for example while retrieving new data via an XHR connection.\n * The \"Loading...\" text itself is not part of this configuration\n * object, but part of the `lang` object.\n */\n loading: {\n /**\n * The duration in milliseconds of the fade out effect.\n *\n * @sample highcharts/loading/hideduration/\n * Fade in and out over a second\n *\n * @type {number}\n * @default 100\n * @since 1.2.0\n * @apioption loading.hideDuration\n */\n /**\n * The duration in milliseconds of the fade in effect.\n *\n * @sample highcharts/loading/hideduration/\n * Fade in and out over a second\n *\n * @type {number}\n * @default 100\n * @since 1.2.0\n * @apioption loading.showDuration\n */\n /**\n * CSS styles for the loading label `span`.\n *\n * @see In styled mode, the loading label is styled with the\n * `.highcharts-loading-inner` class.\n *\n * @sample {highcharts|highmaps} highcharts/loading/labelstyle/\n * Vertically centered\n * @sample {highstock} stock/loading/general/\n * Label styles\n *\n * @type {Highcharts.CSSObject}\n * @default {\"fontWeight\": \"bold\", \"position\": \"relative\", \"top\": \"45%\"}\n * @since 1.2.0\n */\n labelStyle: {\n /**\n * @ignore\n */\n fontWeight: 'bold',\n /**\n * @ignore\n */\n position: 'relative',\n /**\n * @ignore\n */\n top: '45%'\n },\n /**\n * CSS styles for the loading screen that covers the plot area.\n *\n * In styled mode, the loading label is styled with the\n * `.highcharts-loading` class.\n *\n * @sample {highcharts|highmaps} highcharts/loading/style/\n * Gray plot area, white text\n * @sample {highstock} stock/loading/general/\n * Gray plot area, white text\n *\n * @type {Highcharts.CSSObject}\n * @default {\"position\": \"absolute\", \"backgroundColor\": \"#ffffff\", \"opacity\": 0.5, \"textAlign\": \"center\"}\n * @since 1.2.0\n */\n style: {\n /**\n * @ignore\n */\n position: 'absolute',\n /**\n * @ignore\n */\n backgroundColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * @ignore\n */\n opacity: 0.5,\n /**\n * @ignore\n */\n textAlign: 'center'\n }\n },\n /**\n * Options for the tooltip that appears when the user hovers over a\n * series or point.\n *\n * @declare Highcharts.TooltipOptions\n */\n tooltip: {\n /**\n * The color of the tooltip border. When `undefined`, the border takes\n * the color of the corresponding series or point.\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * Follow series by default\n * @sample {highcharts} highcharts/tooltip/bordercolor-black/\n * Black border\n * @sample {highstock} stock/tooltip/general/\n * Styled tooltip\n * @sample {highmaps} maps/tooltip/background-border/\n * Background and border demo\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption tooltip.borderColor\n */\n /**\n * A CSS class name to apply to the tooltip's container div,\n * allowing unique CSS styling for each chart.\n *\n * @type {string}\n * @apioption tooltip.className\n */\n /**\n * Since 4.1, the crosshair definitions are moved to the Axis object\n * in order for a better separation from the tooltip. See\n * [xAxis.crosshair](#xAxis.crosshair).\n *\n * @sample {highcharts} highcharts/tooltip/crosshairs-x/\n * Enable a crosshair for the x value\n *\n * @deprecated\n *\n * @type {*}\n * @default true\n * @apioption tooltip.crosshairs\n */\n /**\n * Distance from point to tooltip in pixels.\n *\n * @type {number}\n * @default 16\n * @apioption tooltip.distance\n */\n /**\n * Whether the tooltip should follow the mouse as it moves across\n * columns, pie slices and other point types with an extent.\n * By default it behaves this way for pie, polygon, map, sankey\n * and wordcloud series by override in the `plotOptions`\n * for those series types.\n *\n * Does not apply if [split](#tooltip.split) is `true`.\n *\n * For touch moves to behave the same way, [followTouchMove](\n * #tooltip.followTouchMove) must be `true` also.\n *\n * @type {boolean}\n * @default {highcharts} false\n * @default {highstock} false\n * @default {highmaps} true\n * @since 3.0\n * @apioption tooltip.followPointer\n */\n /**\n * Whether the tooltip should update as the finger moves on a touch\n * device. If this is `true` and [chart.panning](#chart.panning) is\n * set,`followTouchMove` will take over one-finger touches, so the user\n * needs to use two fingers for zooming and panning.\n *\n * Note the difference to [followPointer](#tooltip.followPointer) that\n * only defines the _position_ of the tooltip. If `followPointer` is\n * false in for example a column series, the tooltip will show above or\n * below the column, but as `followTouchMove` is true, the tooltip will\n * jump from column to column as the user swipes across the plot area.\n *\n * @type {boolean}\n * @default {highcharts} true\n * @default {highstock} true\n * @default {highmaps} false\n * @since 3.0.1\n * @apioption tooltip.followTouchMove\n */\n /**\n * Callback function to format the text of the tooltip from scratch. In\n * case of single or [shared](#tooltip.shared) tooltips, a string should\n * be returned. In case of [split](#tooltip.split) tooltips, it should\n * return an array where the first item is the header, and subsequent\n * items are mapped to the points. Return `false` to disable tooltip for\n * a specific point on series.\n *\n * A subset of HTML is supported. Unless `useHTML` is true, the HTML of\n * the tooltip is parsed and converted to SVG, therefore this isn't a\n * complete HTML renderer. The following HTML tags are supported: `b`,\n * `br`, `em`, `i`, `span`, `strong`. Spans can be styled with a `style`\n * attribute, but only text-related CSS, that is shared with SVG, is\n * handled.\n *\n * The available data in the formatter differ a bit depending on whether\n * the tooltip is shared or split, or belongs to a single point. In a\n * shared/split tooltip, all properties except `x`, which is common for\n * all points, are kept in an array, `this.points`.\n *\n * Available data are:\n *\n * - **this.percentage (not shared) /**\n * **this.points[i].percentage (shared)**:\n * Stacked series and pies only. The point's percentage of the total.\n *\n * - **this.point (not shared) / this.points[i].point (shared)**:\n * The point object. The point name, if defined, is available through\n * `this.point.name`.\n *\n * - **this.points**:\n * In a shared tooltip, this is an array containing all other\n * properties for each point.\n *\n * - **this.series (not shared) / this.points[i].series (shared)**:\n * The series object. The series name is available through\n * `this.series.name`.\n *\n * - **this.total (not shared) / this.points[i].total (shared)**:\n * Stacked series only. The total value at this point's x value.\n *\n * - **this.x**:\n * The x value. This property is the same regardless of the tooltip\n * being shared or not.\n *\n * - **this.y (not shared) / this.points[i].y (shared)**:\n * The y value.\n *\n * @sample {highcharts} highcharts/tooltip/formatter-simple/\n * Simple string formatting\n * @sample {highcharts} highcharts/tooltip/formatter-shared/\n * Formatting with shared tooltip\n * @sample {highcharts|highstock} highcharts/tooltip/formatter-split/\n * Formatting with split tooltip\n * @sample highcharts/tooltip/formatter-conditional-default/\n * Extending default formatter\n * @sample {highstock} stock/tooltip/formatter/\n * Formatting with shared tooltip\n * @sample {highmaps} maps/tooltip/formatter/\n * String formatting\n *\n * @type {Highcharts.TooltipFormatterCallbackFunction}\n * @apioption tooltip.formatter\n */\n /**\n * Callback function to format the text of the tooltip for\n * visible null points.\n * Works analogously to [formatter](#tooltip.formatter).\n *\n * @sample highcharts/plotoptions/series-nullformat\n * Format data label and tooltip for null point.\n *\n * @type {Highcharts.TooltipFormatterCallbackFunction}\n * @apioption tooltip.nullFormatter\n */\n /**\n * Whether to allow the tooltip to render outside the chart's SVG\n * element box. By default (`false`), the tooltip is rendered within the\n * chart's SVG element, which results in the tooltip being aligned\n * inside the chart area. For small charts, this may result in clipping\n * or overlapping. When `true`, a separate SVG element is created and\n * overlaid on the page, allowing the tooltip to be aligned inside the\n * page itself.\n *\n * Defaults to `true` if `chart.scrollablePlotArea` is activated,\n * otherwise `false`.\n *\n * @sample highcharts/tooltip/outside\n * Small charts with tooltips outside\n *\n * @type {boolean|undefined}\n * @default undefined\n * @since 6.1.1\n * @apioption tooltip.outside\n */\n /**\n * A callback function for formatting the HTML output for a single point\n * in the tooltip. Like the `pointFormat` string, but with more\n * flexibility.\n *\n * @type {Highcharts.FormatterCallbackFunction}\n * @since 4.1.0\n * @context Highcharts.Point\n * @apioption tooltip.pointFormatter\n */\n /**\n * A callback function to place the tooltip in a custom position. The\n * callback receives three parameters: `labelWidth`, `labelHeight` and\n * `point`, where point contains values for `plotX` and `plotY` telling\n * where the reference point is in the plot area. Add `chart.plotLeft`\n * and `chart.plotTop` to get the full coordinates.\n *\n * To find the actual hovered `Point` instance, use\n * `this.chart.hoverPoint`. For shared or split tooltips, all the hover\n * points are available in `this.chart.hoverPoints`.\n *\n * Since v7, when [tooltip.split](#tooltip.split) option is enabled,\n * positioner is called for each of the boxes separately, including\n * xAxis header. xAxis header is not a point, instead `point` argument\n * contains info: `{ plotX: Number, plotY: Number, isHeader: Boolean }`\n *\n * The return should be an object containing x and y values, for example\n * `{ x: 100, y: 100 }`.\n *\n * @sample {highcharts} highcharts/tooltip/positioner/\n * A fixed tooltip position\n * @sample {highstock} stock/tooltip/positioner/\n * A fixed tooltip position on top of the chart\n * @sample {highmaps} maps/tooltip/positioner/\n * A fixed tooltip position\n * @sample {highstock} stock/tooltip/split-positioner/\n * Split tooltip with fixed positions\n * @sample {highstock} stock/tooltip/positioner-scrollable-plotarea/\n * Scrollable plot area combined with tooltip positioner\n *\n * @type {Highcharts.TooltipPositionerCallbackFunction}\n * @since 2.2.4\n * @apioption tooltip.positioner\n */\n /**\n * Split the tooltip into one label per series, with the header close\n * to the axis. This is recommended over [shared](#tooltip.shared)\n * tooltips for charts with multiple line series, generally making them\n * easier to read. This option takes precedence over `tooltip.shared`.\n *\n * @productdesc {highstock} In Highcharts Stock, tooltips are split\n * by default since v6.0.0. Stock charts typically contain\n * multi-dimension points and multiple panes, making split tooltips\n * the preferred layout over\n * the previous `shared` tooltip.\n *\n * @sample highcharts/tooltip/split/\n * Split tooltip\n * @sample {highcharts|highstock} highcharts/tooltip/formatter-split/\n * Split tooltip and custom formatter callback\n *\n * @type {boolean}\n * @default {highcharts} false\n * @default {highstock} true\n * @since 5.0.0\n * @product highcharts highstock\n * @apioption tooltip.split\n */\n /**\n * Prevents the tooltip from switching or closing, when touched or\n * pointed.\n *\n * @sample highcharts/tooltip/stickoncontact/\n * Tooltip sticks on pointer contact\n *\n * @type {boolean}\n * @since 8.0.1\n * @apioption tooltip.stickOnContact\n */\n /**\n * Use HTML to render the contents of the tooltip instead of SVG. Using\n * HTML allows advanced formatting like tables and images in the\n * tooltip. It is also recommended for rtl languages as it works around\n * rtl bugs in early Firefox.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/footerformat/\n * A table for value alignment\n * @sample {highcharts|highstock} highcharts/tooltip/fullhtml/\n * Full HTML tooltip\n * @sample {highmaps} maps/tooltip/usehtml/\n * Pure HTML tooltip\n *\n * @type {boolean}\n * @default false\n * @since 2.2\n * @apioption tooltip.useHTML\n */\n /**\n * How many decimals to show in each series' y value. This is\n * overridable in each series' tooltip options object. The default is to\n * preserve all decimals.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n * @sample {highmaps} maps/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n *\n * @type {number|undefined}\n * @since 2.2\n * @apioption tooltip.valueDecimals\n */\n /**\n * A string to prepend to each series' y value. Overridable in each\n * series' tooltip options object.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n * @sample {highmaps} maps/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n *\n * @type {string}\n * @since 2.2\n * @apioption tooltip.valuePrefix\n */\n /**\n * A string to append to each series' y value. Overridable in each\n * series' tooltip options object.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n * @sample {highmaps} maps/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n *\n * @type {string}\n * @since 2.2\n * @apioption tooltip.valueSuffix\n */\n /**\n * The format for the date in the tooltip header if the X axis is a\n * datetime axis. The default is a best guess based on the smallest\n * distance between points in the chart.\n *\n * @sample {highcharts} highcharts/tooltip/xdateformat/\n * A different format\n *\n * @type {string}\n * @product highcharts highstock gantt\n * @apioption tooltip.xDateFormat\n */\n /**\n * How many decimals to show for the `point.change`\n * or the `point.cumulativeSum` value when the `series.compare`\n * or the `series.cumulative` option is set.\n * This is overridable in each series' tooltip options object.\n *\n * @type {number}\n * @default 2\n * @since 1.0.1\n * @product highstock\n * @apioption tooltip.changeDecimals\n */\n /**\n * Enable or disable the tooltip.\n *\n * @sample {highcharts} highcharts/tooltip/enabled/\n * Disabled\n * @sample {highcharts} highcharts/plotoptions/series-point-events-mouseover/\n * Disable tooltip and show values on chart instead\n */\n enabled: true,\n /**\n * Enable or disable animation of the tooltip.\n *\n * @type {boolean}\n * @default true\n * @since 2.3.0\n */\n animation: svg,\n /**\n * The radius of the rounded border corners.\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * 5px by default\n * @sample {highcharts} highcharts/tooltip/borderradius-0/\n * Square borders\n * @sample {highmaps} maps/tooltip/background-border/\n * Background and border demo\n */\n borderRadius: 3,\n /**\n * For series on datetime axes, the date format in the tooltip's\n * header will by default be guessed based on the closest data points.\n * This member gives the default string representations used for\n * each unit. For an overview of the replacement codes, see\n * [dateFormat](/class-reference/Highcharts.Time#dateFormat).\n *\n * @see [xAxis.dateTimeLabelFormats](#xAxis.dateTimeLabelFormats)\n *\n * @type {Highcharts.Dictionary}\n * @product highcharts highstock gantt\n */\n dateTimeLabelFormats: {\n /** @internal */\n millisecond: '%A, %b %e, %H:%M:%S.%L',\n /** @internal */\n second: '%A, %b %e, %H:%M:%S',\n /** @internal */\n minute: '%A, %b %e, %H:%M',\n /** @internal */\n hour: '%A, %b %e, %H:%M',\n /** @internal */\n day: '%A, %b %e, %Y',\n /** @internal */\n week: 'Week from %A, %b %e, %Y',\n /** @internal */\n month: '%B %Y',\n /** @internal */\n year: '%Y'\n },\n /**\n * A string to append to the tooltip format.\n *\n * @sample {highcharts} highcharts/tooltip/footerformat/\n * A table for value alignment\n * @sample {highmaps} maps/tooltip/format/\n * Format demo\n *\n * @since 2.2\n */\n footerFormat: '',\n /**\n * The name of a symbol to use for the border around the tooltip\n * header. Applies only when [tooltip.split](#tooltip.split) is\n * enabled.\n *\n * Custom callbacks for symbol path generation can also be added to\n * `Highcharts.SVGRenderer.prototype.symbols` the same way as for\n * [series.marker.symbol](plotOptions.line.marker.symbol).\n *\n * @see [tooltip.shape](#tooltip.shape)\n *\n * @sample {highstock} stock/tooltip/split-positioner/\n * Different shapes for header and split boxes\n *\n * @type {Highcharts.TooltipShapeValue}\n * @validvalue [\"callout\", \"square\"]\n * @since 7.0\n */\n headerShape: 'callout',\n /**\n * The number of milliseconds to wait until the tooltip is hidden when\n * mouse out from a point or chart.\n *\n * @since 3.0\n */\n hideDelay: 500,\n /**\n * Padding inside the tooltip, in pixels.\n *\n * @since 5.0.0\n */\n padding: 8,\n /**\n * The name of a symbol to use for the border around the tooltip. Can\n * be one of: `\"callout\"`, `\"circle\"` or `\"rect\"`. When\n * [tooltip.split](#tooltip.split)\n * option is enabled, shape is applied to all boxes except header, which\n * is controlled by\n * [tooltip.headerShape](#tooltip.headerShape).\n *\n * Custom callbacks for symbol path generation can also be added to\n * `Highcharts.SVGRenderer.prototype.symbols` the same way as for\n * [series.marker.symbol](plotOptions.line.marker.symbol).\n *\n * @type {Highcharts.TooltipShapeValue}\n * @since 4.0\n */\n shape: 'callout',\n /**\n * When the tooltip is shared, the entire plot area will capture mouse\n * movement or touch events. Tooltip texts for series types with ordered\n * data (not pie, scatter, flags etc) will be shown in a single bubble.\n * This is recommended for single series charts and for tablet/mobile\n * optimized charts.\n *\n * See also [tooltip.split](#tooltip.split), that is better suited for\n * charts with many series, especially line-type series. The\n * `tooltip.split` option takes precedence over `tooltip.shared`.\n *\n * @sample {highcharts} highcharts/tooltip/shared-false/\n * False by default\n * @sample {highcharts} highcharts/tooltip/shared-true/\n * True\n * @sample {highcharts} highcharts/tooltip/shared-x-crosshair/\n * True with x axis crosshair\n * @sample {highcharts} highcharts/tooltip/shared-true-mixed-types/\n * True with mixed series types\n *\n * @since 2.1\n * @product highcharts highstock\n */\n shared: false,\n /**\n * Proximity snap for graphs or single points. It defaults to 10 for\n * mouse-powered devices and 25 for touch devices.\n *\n * Note that in most cases the whole plot area captures the mouse\n * movement, and in these cases `tooltip.snap` doesn't make sense. This\n * applies when [stickyTracking](#plotOptions.series.stickyTracking)\n * is `true` (default) and when the tooltip is [shared](#tooltip.shared)\n * or [split](#tooltip.split).\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * 10 px by default\n * @sample {highcharts} highcharts/tooltip/snap-50/\n * 50 px on graph\n *\n * @type {number}\n * @default 10/25\n * @since 1.2.0\n * @product highcharts highstock\n */\n snap: isTouchDevice ? 25 : 10,\n /**\n * The HTML of the tooltip header line. Variables are enclosed by\n * curly brackets. Available variables are `point.key`, `series.name`,\n * `series.color` and other members from the `point` and `series`\n * objects. The `point.key` variable contains the category name, x\n * value or datetime string depending on the type of axis. For datetime\n * axes, the `point.key` date format can be set using\n * `tooltip.xDateFormat`.\n *\n * @sample {highcharts} highcharts/tooltip/footerformat/\n * An HTML table in the tooltip\n * @sample {highstock} highcharts/tooltip/footerformat/\n * An HTML table in the tooltip\n * @sample {highmaps} maps/tooltip/format/\n * Format demo\n *\n * @type {string}\n * @apioption tooltip.headerFormat\n */\n headerFormat: '{point.key}
',\n /**\n * The HTML of the null point's line in the tooltip. Works analogously\n * to [pointFormat](#tooltip.pointFormat).\n *\n * @sample {highcharts} highcharts/plotoptions/series-nullformat\n * Format data label and tooltip for null point.\n *\n * @type {string}\n * @apioption tooltip.nullFormat\n */\n /**\n * The HTML of the point's line in the tooltip. Variables are enclosed\n * by curly brackets. Available variables are `point.x`, `point.y`,\n * `series.name` and `series.color` and other properties on the same\n * form. Furthermore, `point.y` can be extended by the\n * `tooltip.valuePrefix` and `tooltip.valueSuffix` variables. This can\n * also be overridden for each series, which makes it a good hook for\n * displaying units.\n *\n * In styled mode, the dot is colored by a class name rather\n * than the point color.\n *\n * @sample {highcharts} highcharts/tooltip/pointformat/\n * A different point format with value suffix\n * @sample {highcharts|highstock} highcharts/tooltip/pointformat-extra-information/\n * Show extra information about points in the tooltip\n * @sample {highmaps} maps/tooltip/format/\n * Format demo\n *\n * @type {string}\n * @since 2.2\n * @apioption tooltip.pointFormat\n */\n pointFormat: '\\u25CF {series.name}: {point.y}
',\n /**\n * The background color or gradient for the tooltip.\n *\n * In styled mode, the stroke width is set in the\n * `.highcharts-tooltip-box` class.\n *\n * @sample {highcharts} highcharts/tooltip/backgroundcolor-solid/\n * Yellowish background\n * @sample {highcharts} highcharts/tooltip/backgroundcolor-gradient/\n * Gradient\n * @sample {highcharts} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n * @sample {highstock} stock/tooltip/general/\n * Custom tooltip\n * @sample {highstock} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n * @sample {highmaps} maps/tooltip/background-border/\n * Background and border demo\n * @sample {highmaps} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n backgroundColor: color(\"#f7f7f7\" /* Palette.neutralColor3 */)\n // @todo: Disallow undefined as input for colors\n .setOpacity(0.85).get(),\n /**\n * The pixel width of the tooltip border.\n *\n * In styled mode, the stroke width is set in the\n * `.highcharts-tooltip-box` class.\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * 2px by default\n * @sample {highcharts} highcharts/tooltip/borderwidth/\n * No border (shadow only)\n * @sample {highcharts} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n * @sample {highstock} stock/tooltip/general/\n * Custom tooltip\n * @sample {highstock} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n * @sample {highmaps} maps/tooltip/background-border/\n * Background and border demo\n * @sample {highmaps} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n */\n borderWidth: 1,\n /**\n * Whether to apply a drop shadow to the tooltip.\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * True by default\n * @sample {highcharts} highcharts/tooltip/shadow/\n * False\n * @sample {highmaps} maps/tooltip/positioner/\n * Fixed tooltip position, border and shadow disabled\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n */\n shadow: true,\n /**\n * Prevents the tooltip from switching or closing when touched or\n * pointed.\n *\n * @sample highcharts/tooltip/stickoncontact/\n * Tooltip sticks on pointer contact\n *\n * @since 8.0.1\n */\n stickOnContact: false,\n /**\n * CSS styles for the tooltip. The tooltip can also be styled through\n * the CSS class `.highcharts-tooltip`.\n *\n * Note that the default `pointerEvents` style makes the tooltip ignore\n * mouse events, so in order to use clickable tooltips, this value must\n * be set to `auto`.\n *\n * @sample {highcharts} highcharts/tooltip/style/\n * Greater padding, bold text\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @internal */\n color: \"#333333\" /* Palette.neutralColor80 */,\n /** @internal */\n cursor: 'default',\n /** @internal */\n fontSize: '12px',\n /** @internal */\n whiteSpace: 'nowrap'\n },\n /**\n * Use HTML to render the contents of the tooltip instead of SVG. Using\n * HTML allows advanced formatting like tables and images in the\n * tooltip. It is also recommended for rtl languages as it works around\n * rtl bugs in early Firefox.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/footerformat/\n * A table for value alignment\n * @sample {highcharts|highstock} highcharts/tooltip/fullhtml/\n * Full HTML tooltip\n * @sample {highmaps} maps/tooltip/usehtml/\n * Pure HTML tooltip\n *\n * @since 2.2\n */\n useHTML: false\n },\n /**\n * Highchart by default puts a credits label in the lower right corner\n * of the chart. This can be changed using these options.\n */\n credits: {\n /**\n * Credits for map source to be concatenated with conventional credit\n * text. By default this is a format string that collects copyright\n * information from the map if available.\n *\n * @see [mapTextFull](#credits.mapTextFull)\n * @see [text](#credits.text)\n *\n * @type {string}\n * @default \\u00a9 {geojson.copyrightShort}\n * @since 4.2.2\n * @product highmaps\n * @apioption credits.mapText\n */\n /**\n * Detailed credits for map source to be displayed on hover of credits\n * text. By default this is a format string that collects copyright\n * information from the map if available.\n *\n * @see [mapText](#credits.mapText)\n * @see [text](#credits.text)\n *\n * @type {string}\n * @default {geojson.copyright}\n * @since 4.2.2\n * @product highmaps\n * @apioption credits.mapTextFull\n */\n /**\n * Whether to show the credits text.\n *\n * @sample {highcharts} highcharts/credits/enabled-false/\n * Credits disabled\n * @sample {highstock} stock/credits/enabled/\n * Credits disabled\n * @sample {highmaps} maps/credits/enabled-false/\n * Credits disabled\n */\n enabled: true,\n /**\n * The URL for the credits label.\n *\n * @sample {highcharts} highcharts/credits/href/\n * Custom URL and text\n * @sample {highmaps} maps/credits/customized/\n * Custom URL and text\n */\n href: 'https://www.highcharts.com?credits',\n /**\n * Position configuration for the credits label.\n *\n * @sample {highcharts} highcharts/credits/position-left/\n * Left aligned\n * @sample {highcharts} highcharts/credits/position-left/\n * Left aligned\n * @sample {highmaps} maps/credits/customized/\n * Left aligned\n * @sample {highmaps} maps/credits/customized/\n * Left aligned\n *\n * @type {Highcharts.AlignObject}\n * @since 2.1\n */\n position: {\n /** @internal */\n align: 'right',\n /** @internal */\n x: -10,\n /** @internal */\n verticalAlign: 'bottom',\n /** @internal */\n y: -5\n },\n /**\n * CSS styles for the credits label.\n *\n * @see In styled mode, credits styles can be set with the\n * `.highcharts-credits` class.\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @internal */\n cursor: 'pointer',\n /** @internal */\n color: \"#999999\" /* Palette.neutralColor40 */,\n /** @internal */\n fontSize: '9px'\n },\n /**\n * The text for the credits label.\n *\n * @productdesc {highmaps}\n * If a map is loaded as GeoJSON, the text defaults to\n * `Highcharts @ {map-credits}`. Otherwise, it defaults to\n * `Highcharts.com`.\n *\n * @sample {highcharts} highcharts/credits/href/\n * Custom URL and text\n * @sample {highmaps} maps/credits/customized/\n * Custom URL and text\n */\n text: 'Highcharts.com'\n }\n };\n /* eslint-disable spaced-comment */\n\n defaultOptions.chart.styledMode = false;\n\n '';\n var defaultTime = new Time(merge(defaultOptions.global,\n defaultOptions.time));\n /**\n * Get the updated default options. Until 3.0.7, merely exposing defaultOptions\n * for outside modules wasn't enough because the setOptions method created a new\n * object.\n *\n * @function Highcharts.getOptions\n *\n * @return {Highcharts.Options}\n * Default options.\n */\n function getOptions() {\n return defaultOptions;\n }\n /**\n * Merge the default options with custom options and return the new options\n * structure. Commonly used for defining reusable templates.\n *\n * @sample highcharts/global/useutc-false Setting a global option\n * @sample highcharts/members/setoptions Applying a global theme\n *\n * @function Highcharts.setOptions\n *\n * @param {Highcharts.Options} options\n * The new custom chart options.\n *\n * @return {Highcharts.Options}\n * Updated options.\n */\n function setOptions(options) {\n // Copy in the default options\n merge(true, defaultOptions, options);\n // Update the time object\n if (options.time || options.global) {\n if (H.time) {\n H.time.update(merge(defaultOptions.global, defaultOptions.time, options.global, options.time));\n }\n else {\n /**\n * Global `Time` object with default options. Since v6.0.5, time\n * settings can be applied individually for each chart. If no\n * individual settings apply, this `Time` object is shared by all\n * instances.\n *\n * @name Highcharts.time\n * @type {Highcharts.Time}\n */\n H.time = defaultTime;\n }\n }\n return defaultOptions;\n }\n /* *\n *\n * Default Export\n *\n * */\n var DefaultOptions = {\n defaultOptions: defaultOptions,\n defaultTime: defaultTime,\n getOptions: getOptions,\n setOptions: setOptions\n };\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @typedef {\"plotBox\"|\"spacingBox\"} Highcharts.ButtonRelativeToValue\n */\n /**\n * Gets fired when a series is added to the chart after load time, using the\n * `addSeries` method. Returning `false` prevents the series from being added.\n *\n * @callback Highcharts.ChartAddSeriesCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {Highcharts.ChartAddSeriesEventObject} event\n * The event that occured.\n */\n /**\n * Contains common event information. Through the `options` property you can\n * access the series options that were passed to the `addSeries` method.\n *\n * @interface Highcharts.ChartAddSeriesEventObject\n */ /**\n * The series options that were passed to the `addSeries` method.\n * @name Highcharts.ChartAddSeriesEventObject#options\n * @type {Highcharts.SeriesOptionsType}\n */ /**\n * Prevents the default behaviour of the event.\n * @name Highcharts.ChartAddSeriesEventObject#preventDefault\n * @type {Function}\n */ /**\n * The event target.\n * @name Highcharts.ChartAddSeriesEventObject#target\n * @type {Highcharts.Chart}\n */ /**\n * The event type.\n * @name Highcharts.ChartAddSeriesEventObject#type\n * @type {\"addSeries\"}\n */\n /**\n * Gets fired when clicking on the plot background.\n *\n * @callback Highcharts.ChartClickCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {Highcharts.PointerEventObject} event\n * The event that occured.\n */\n /**\n * Contains an axes of the clicked spot.\n *\n * @interface Highcharts.ChartClickEventAxisObject\n */ /**\n * Axis at the clicked spot.\n * @name Highcharts.ChartClickEventAxisObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * Axis value at the clicked spot.\n * @name Highcharts.ChartClickEventAxisObject#value\n * @type {number}\n */\n /**\n * Contains information about the clicked spot on the chart. Remember the unit\n * of a datetime axis is milliseconds since 1970-01-01 00:00:00.\n *\n * @interface Highcharts.ChartClickEventObject\n * @extends Highcharts.PointerEventObject\n */ /**\n * Information about the x-axis on the clicked spot.\n * @name Highcharts.ChartClickEventObject#xAxis\n * @type {Array}\n */ /**\n * Information about the y-axis on the clicked spot.\n * @name Highcharts.ChartClickEventObject#yAxis\n * @type {Array}\n */ /**\n * Information about the z-axis on the clicked spot.\n * @name Highcharts.ChartClickEventObject#zAxis\n * @type {Array|undefined}\n */\n /**\n * Gets fired when the chart is finished loading.\n *\n * @callback Highcharts.ChartLoadCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * Fires when the chart is redrawn, either after a call to `chart.redraw()` or\n * after an axis, series or point is modified with the `redraw` option set to\n * `true`.\n *\n * @callback Highcharts.ChartRedrawCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * Gets fired after initial load of the chart (directly after the `load` event),\n * and after each redraw (directly after the `redraw` event).\n *\n * @callback Highcharts.ChartRenderCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * Gets fired when an area of the chart has been selected. The default action\n * for the selection event is to zoom the chart to the selected area. It can be\n * prevented by calling `event.preventDefault()` or return false.\n *\n * @callback Highcharts.ChartSelectionCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {Highcharts.SelectEventObject} event\n * Event informations\n *\n * @return {boolean|undefined}\n * Return false to prevent the default action, usually zoom.\n */\n (''); // detach doclets above\n\n return DefaultOptions;\n });\n _registerModule(_modules, 'Core/Animation/Fx.js', [_modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (Color, H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var color = Color.parse;\n var win = H.win;\n var isNumber = U.isNumber,\n objectEach = U.objectEach;\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /* *\n *\n * Class\n *\n * */\n /**\n * An animator object used internally. One instance applies to one property\n * (attribute or style prop) on one element. Animation is always initiated\n * through {@link SVGElement#animate}.\n *\n * @example\n * let rect = renderer.rect(0, 0, 10, 10).add();\n * rect.animate({ width: 100 });\n *\n * @private\n * @class\n * @name Highcharts.Fx\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGElement} elem\n * The element to animate.\n *\n * @param {Partial} options\n * Animation options.\n *\n * @param {string} prop\n * The single attribute or CSS property to animate.\n */\n var Fx = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Fx(elem, options, prop) {\n this.pos = NaN;\n this.options = options;\n this.elem = elem;\n this.prop = prop;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set the current step of a path definition on SVGElement.\n *\n * @function Highcharts.Fx#dSetter\n *\n */\n Fx.prototype.dSetter = function () {\n var paths = this.paths,\n start = paths && paths[0],\n end = paths && paths[1],\n now = this.now || 0;\n var path = [];\n // Land on the final path without adjustment points appended in the ends\n if (now === 1 || !start || !end) {\n path = this.toD || [];\n }\n else if (start.length === end.length && now < 1) {\n for (var i = 0; i < end.length; i++) {\n // Tween between the start segment and the end segment. Start\n // with a copy of the end segment and tween the appropriate\n // numerics\n var startSeg = start[i];\n var endSeg = end[i];\n var tweenSeg = [];\n for (var j = 0; j < endSeg.length; j++) {\n var startItem = startSeg[j];\n var endItem = endSeg[j];\n // Tween numbers\n if (isNumber(startItem) &&\n isNumber(endItem) &&\n // Arc boolean flags\n !(endSeg[0] === 'A' && (j === 4 || j === 5))) {\n tweenSeg[j] = startItem + now * (endItem - startItem);\n // Strings, take directly from the end segment\n }\n else {\n tweenSeg[j] = endItem;\n }\n }\n path.push(tweenSeg);\n }\n // If animation is finished or length not matching, land on right value\n }\n else {\n path = end;\n }\n this.elem.attr('d', path, void 0, true);\n };\n /**\n * Update the element with the current animation step.\n *\n * @function Highcharts.Fx#update\n *\n */\n Fx.prototype.update = function () {\n var elem = this.elem,\n prop = this.prop, // if destroyed, it is null\n now = this.now,\n step = this.options.step;\n // Animation setter defined from outside\n if (this[prop + 'Setter']) {\n this[prop + 'Setter']();\n // Other animations on SVGElement\n }\n else if (elem.attr) {\n if (elem.element) {\n elem.attr(prop, now, null, true);\n }\n // HTML styles, raw HTML content like container size\n }\n else {\n elem.style[prop] = now + this.unit;\n }\n if (step) {\n step.call(elem, now, this);\n }\n };\n /**\n * Run an animation.\n *\n * @function Highcharts.Fx#run\n *\n * @param {number} from\n * The current value, value to start from.\n *\n * @param {number} to\n * The end value, value to land on.\n *\n * @param {string} unit\n * The property unit, for example `px`.\n *\n */\n Fx.prototype.run = function (from, to, unit) {\n var self = this,\n options = self.options,\n timer = function (gotoEnd) {\n return timer.stopped ? false : self.step(gotoEnd);\n }, requestAnimationFrame = win.requestAnimationFrame ||\n function (step) {\n setTimeout(step, 13);\n }, step = function () {\n for (var i = 0; i < Fx.timers.length; i++) {\n if (!Fx.timers[i]()) {\n Fx.timers.splice(i--, 1);\n }\n }\n if (Fx.timers.length) {\n requestAnimationFrame(step);\n }\n };\n if (from === to && !this.elem['forceAnimate:' + this.prop]) {\n delete options.curAnim[this.prop];\n if (options.complete &&\n Object.keys(options.curAnim).length === 0) {\n options.complete.call(this.elem);\n }\n }\n else { // #7166\n this.startTime = +new Date();\n this.start = from;\n this.end = to;\n this.unit = unit;\n this.now = this.start;\n this.pos = 0;\n timer.elem = this.elem;\n timer.prop = this.prop;\n if (timer() && Fx.timers.push(timer) === 1) {\n requestAnimationFrame(step);\n }\n }\n };\n /**\n * Run a single step in the animation.\n *\n * @function Highcharts.Fx#step\n *\n * @param {boolean} [gotoEnd]\n * Whether to go to the endpoint of the animation after abort.\n *\n * @return {boolean}\n * Returns `true` if animation continues.\n */\n Fx.prototype.step = function (gotoEnd) {\n var t = +new Date(),\n options = this.options,\n elem = this.elem,\n complete = options.complete,\n duration = options.duration,\n curAnim = options.curAnim;\n var ret,\n done;\n if ((elem.attr) && !elem.element) { // #2616, element is destroyed\n ret = false;\n }\n else if (gotoEnd || t >= duration + this.startTime) {\n this.now = this.end;\n this.pos = 1;\n this.update();\n curAnim[this.prop] = true;\n done = true;\n objectEach(curAnim, function (val) {\n if (val !== true) {\n done = false;\n }\n });\n if (done && complete) {\n complete.call(elem);\n }\n ret = false;\n }\n else {\n this.pos = options.easing((t - this.startTime) / duration);\n this.now = this.start + ((this.end -\n this.start) * this.pos);\n this.update();\n ret = true;\n }\n return ret;\n };\n /**\n * Prepare start and end values so that the path can be animated one to one.\n *\n * @function Highcharts.Fx#initPath\n *\n * @param {Highcharts.SVGElement} elem\n * The SVGElement item.\n *\n * @param {Highcharts.SVGPathArray|undefined} fromD\n * Starting path definition.\n *\n * @param {Highcharts.SVGPathArray} toD\n * Ending path definition.\n *\n * @return {Array}\n * An array containing start and end paths in array form so that\n * they can be animated in parallel.\n */\n Fx.prototype.initPath = function (elem, fromD, toD) {\n var startX = elem.startX,\n endX = elem.endX,\n end = toD.slice(), // copy\n isArea = elem.isArea,\n positionFactor = isArea ? 2 : 1;\n var shift,\n fullLength,\n i,\n reverse,\n start = fromD && fromD.slice(); // copy\n if (!start) {\n return [end,\n end];\n }\n /**\n * If shifting points, prepend a dummy point to the end path.\n * @private\n */\n function prepend(arr, other) {\n while (arr.length < fullLength) {\n // Move to, line to or curve to?\n var moveSegment = arr[0],\n otherSegment = other[fullLength - arr.length];\n if (otherSegment && moveSegment[0] === 'M') {\n if (otherSegment[0] === 'C') {\n arr[0] = [\n 'C',\n moveSegment[1],\n moveSegment[2],\n moveSegment[1],\n moveSegment[2],\n moveSegment[1],\n moveSegment[2]\n ];\n }\n else {\n arr[0] = ['L', moveSegment[1], moveSegment[2]];\n }\n }\n // Prepend a copy of the first point\n arr.unshift(moveSegment);\n // For areas, the bottom path goes back again to the left, so we\n // need to append a copy of the last point.\n if (isArea) {\n var z = arr.pop();\n arr.push(arr[arr.length - 1], z); // append point and the Z\n }\n }\n }\n /**\n * Copy and append last point until the length matches the end length.\n * @private\n */\n function append(arr, other) {\n while (arr.length < fullLength) {\n // Pull out the slice that is going to be appended or inserted.\n // In a line graph, the positionFactor is 1, and the last point\n // is sliced out. In an area graph, the positionFactor is 2,\n // causing the middle two points to be sliced out, since an area\n // path starts at left, follows the upper path then turns and\n // follows the bottom back.\n var segmentToAdd = arr[Math.floor(arr.length / positionFactor) - 1].slice();\n // Disable the first control point of curve segments\n if (segmentToAdd[0] === 'C') {\n segmentToAdd[1] = segmentToAdd[5];\n segmentToAdd[2] = segmentToAdd[6];\n }\n if (!isArea) {\n arr.push(segmentToAdd);\n }\n else {\n var lowerSegmentToAdd = arr[Math.floor(arr.length / positionFactor)].slice();\n arr.splice(arr.length / 2, 0, segmentToAdd, lowerSegmentToAdd);\n }\n }\n }\n // For sideways animation, find out how much we need to shift to get the\n // start path Xs to match the end path Xs.\n if (startX && endX && endX.length) {\n for (i = 0; i < startX.length; i++) {\n // Moving left, new points coming in on right\n if (startX[i] === endX[0]) {\n shift = i;\n break;\n // Moving right\n }\n else if (startX[0] ===\n endX[endX.length - startX.length + i]) {\n shift = i;\n reverse = true;\n break;\n // Fixed from the right side, \"scaling\" left\n }\n else if (startX[startX.length - 1] ===\n endX[endX.length - startX.length + i]) {\n shift = startX.length - i;\n break;\n }\n }\n if (typeof shift === 'undefined') {\n start = [];\n }\n }\n if (start.length && isNumber(shift)) {\n // The common target length for the start and end array, where both\n // arrays are padded in opposite ends\n fullLength = end.length + shift * positionFactor;\n if (!reverse) {\n prepend(end, start);\n append(start, end);\n }\n else {\n prepend(start, end);\n append(end, start);\n }\n }\n return [start, end];\n };\n /**\n * Handle animation of the color attributes directly.\n *\n * @function Highcharts.Fx#fillSetter\n *\n */\n Fx.prototype.fillSetter = function () {\n Fx.prototype.strokeSetter.apply(this, arguments);\n };\n /**\n * Handle animation of the color attributes directly.\n *\n * @function Highcharts.Fx#strokeSetter\n *\n */\n Fx.prototype.strokeSetter = function () {\n this.elem.attr(this.prop, color(this.start).tweenTo(color(this.end), this.pos), void 0, true);\n };\n /* *\n *\n * Static Properties\n *\n * */\n Fx.timers = [];\n return Fx;\n }());\n /* *\n *\n * Default Export\n *\n * */\n\n return Fx;\n });\n _registerModule(_modules, 'Core/Animation/AnimationUtilities.js', [_modules['Core/Animation/Fx.js'], _modules['Core/Utilities.js']], function (Fx, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var defined = U.defined,\n getStyle = U.getStyle,\n isArray = U.isArray,\n isNumber = U.isNumber,\n isObject = U.isObject,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set the global animation to either a given value, or fall back to the given\n * chart's animation option.\n *\n * @function Highcharts.setAnimation\n *\n * @param {boolean|Partial|undefined} animation\n * The animation object.\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @todo\n * This function always relates to a chart, and sets a property on the renderer,\n * so it should be moved to the SVGRenderer.\n */\n function setAnimation(animation, chart) {\n chart.renderer.globalAnimation = pick(animation, chart.options.chart.animation, true);\n }\n /**\n * Get the animation in object form, where a disabled animation is always\n * returned as `{ duration: 0 }`.\n *\n * @function Highcharts.animObject\n *\n * @param {boolean|Highcharts.AnimationOptionsObject} [animation=0]\n * An animation setting. Can be an object with duration, complete and\n * easing properties, or a boolean to enable or disable.\n *\n * @return {Highcharts.AnimationOptionsObject}\n * An object with at least a duration property.\n */\n function animObject(animation) {\n return isObject(animation) ?\n merge({ duration: 500, defer: 0 }, animation) :\n { duration: animation ? 500 : 0, defer: 0 };\n }\n /**\n * Get the defer as a number value from series animation options.\n *\n * @function Highcharts.getDeferredAnimation\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {boolean|Highcharts.AnimationOptionsObject} animation\n * An animation setting. Can be an object with duration, complete and\n * easing properties, or a boolean to enable or disable.\n *\n * @param {Highcharts.Series} [series]\n * Series to defer animation.\n *\n * @return {number}\n * The numeric value.\n */\n function getDeferredAnimation(chart, animation, series) {\n var labelAnimation = animObject(animation),\n s = series ? [series] : chart.series;\n var defer = 0,\n duration = 0;\n s.forEach(function (series) {\n var seriesAnim = animObject(series.options.animation);\n defer = animation && defined(animation.defer) ?\n labelAnimation.defer :\n Math.max(defer, seriesAnim.duration + seriesAnim.defer);\n duration = Math.min(labelAnimation.duration, seriesAnim.duration);\n });\n // Disable defer for exporting\n if (chart.renderer.forExport) {\n defer = 0;\n }\n var anim = {\n defer: Math.max(0,\n defer - duration),\n duration: Math.min(defer,\n duration)\n };\n return anim;\n }\n /**\n * The global animate method, which uses Fx to create individual animators.\n *\n * @function Highcharts.animate\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGElement} el\n * The element to animate.\n *\n * @param {Highcharts.CSSObject|Highcharts.SVGAttributes} params\n * An object containing key-value pairs of the properties to animate.\n * Supports numeric as pixel-based CSS properties for HTML objects and\n * attributes for SVGElements.\n *\n * @param {Partial} [opt]\n * Animation options.\n *\n * @return {void}\n */\n function animate(el, params, opt) {\n var start,\n unit = '',\n end,\n fx,\n args;\n if (!isObject(opt)) { // Number or undefined/null\n args = arguments;\n opt = {\n duration: args[2],\n easing: args[3],\n complete: args[4]\n };\n }\n if (!isNumber(opt.duration)) {\n opt.duration = 400;\n }\n opt.easing = typeof opt.easing === 'function' ?\n opt.easing :\n (Math[opt.easing] || Math.easeInOutSine);\n opt.curAnim = merge(params);\n objectEach(params, function (val, prop) {\n // Stop current running animation of this property\n stop(el, prop);\n fx = new Fx(el, opt, prop);\n end = void 0;\n if (prop === 'd' && isArray(params.d)) {\n fx.paths = fx.initPath(el, el.pathArray, params.d);\n fx.toD = params.d;\n start = 0;\n end = 1;\n }\n else if (el.attr) {\n start = el.attr(prop);\n }\n else {\n start = parseFloat(getStyle(el, prop)) || 0;\n if (prop !== 'opacity') {\n unit = 'px';\n }\n }\n if (!end) {\n end = val;\n }\n if (typeof end === 'string' && end.match('px')) {\n end = end.replace(/px/g, ''); // #4351\n }\n fx.run(start, end, unit);\n });\n }\n /**\n * Stop running animation.\n *\n * @function Highcharts.stop\n *\n * @param {Highcharts.SVGElement} el\n * The SVGElement to stop animation on.\n *\n * @param {string} [prop]\n * The property to stop animating. If given, the stop method will stop a\n * single property from animating, while others continue.\n *\n * @return {void}\n *\n * @todo\n * A possible extension to this would be to stop a single property, when\n * we want to continue animating others. Then assign the prop to the timer\n * in the Fx.run method, and check for the prop here. This would be an\n * improvement in all cases where we stop the animation from .attr. Instead of\n * stopping everything, we can just stop the actual attributes we're setting.\n */\n function stop(el, prop) {\n var i = Fx.timers.length;\n // Remove timers related to this element (#4519)\n while (i--) {\n if (Fx.timers[i].elem === el && (!prop || prop === Fx.timers[i].prop)) {\n Fx.timers[i].stopped = true; // #4667\n }\n }\n }\n var animationExports = {\n animate: animate,\n animObject: animObject,\n getDeferredAnimation: getDeferredAnimation,\n setAnimation: setAnimation,\n stop: stop\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return animationExports;\n });\n _registerModule(_modules, 'Core/Renderer/HTML/AST.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * (c) 2010-2020 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var SVG_NS = H.SVG_NS,\n win = H.win;\n var attr = U.attr,\n createElement = U.createElement,\n css = U.css,\n error = U.error,\n isFunction = U.isFunction,\n isString = U.isString,\n objectEach = U.objectEach,\n splat = U.splat;\n var trustedTypes = win.trustedTypes;\n /* *\n *\n * Constants\n *\n * */\n // Create the trusted type policy. This should not be exposed.\n var trustedTypesPolicy = (trustedTypes &&\n isFunction(trustedTypes.createPolicy) &&\n trustedTypes.createPolicy('highcharts', {\n createHTML: function (s) { return s; }\n }));\n var emptyHTML = trustedTypesPolicy ?\n trustedTypesPolicy.createHTML('') :\n '';\n // In IE8, DOMParser is undefined. IE9 and PhantomJS are only able to parse XML.\n var hasValidDOMParser = (function () {\n try {\n return Boolean(new DOMParser().parseFromString(emptyHTML, 'text/html'));\n }\n catch (e) {\n return false;\n }\n }());\n /* *\n *\n * Class\n *\n * */\n /**\n * The AST class represents an abstract syntax tree of HTML or SVG content. It\n * can take HTML as an argument, parse it, optionally transform it to SVG, then\n * perform sanitation before inserting it into the DOM.\n *\n * @class\n * @name Highcharts.AST\n *\n * @param {string|Array} source\n * Either an HTML string or an ASTNode list to populate the tree.\n */\n var AST = /** @class */ (function () {\n /* *\n *\n * Constructor\n *\n * */\n // Construct an AST from HTML markup, or wrap an array of existing AST nodes\n function AST(source) {\n this.nodes = typeof source === 'string' ?\n this.parseMarkup(source) : source;\n }\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Filter an object of SVG or HTML attributes against the allow list.\n *\n * @static\n *\n * @function Highcharts.AST#filterUserAttributes\n *\n * @param {Highcharts.SVGAttributes} attributes The attributes to filter\n *\n * @return {Highcharts.SVGAttributes}\n * The filtered attributes\n */\n AST.filterUserAttributes = function (attributes) {\n objectEach(attributes, function (val, key) {\n var valid = true;\n if (AST.allowedAttributes.indexOf(key) === -1) {\n valid = false;\n }\n if (['background', 'dynsrc', 'href', 'lowsrc', 'src']\n .indexOf(key) !== -1) {\n valid = isString(val) && AST.allowedReferences.some(function (ref) { return val.indexOf(ref) === 0; });\n }\n if (!valid) {\n error(33, false, void 0, {\n 'Invalid attribute in config': \"\".concat(key)\n });\n delete attributes[key];\n }\n });\n return attributes;\n };\n AST.parseStyle = function (style) {\n return style\n .split(';')\n .reduce(function (styles, line) {\n var pair = line.split(':').map(function (s) { return s.trim(); }),\n key = pair.shift();\n if (key && pair.length) {\n styles[key.replace(/-([a-z])/g, function (g) { return g[1].toUpperCase(); })] = pair.join(':'); // #17146\n }\n return styles;\n }, {});\n };\n /**\n * Utility function to set html content for an element by passing in a\n * markup string. The markup is safely parsed by the AST class to avoid\n * XSS vulnerabilities. This function should be used instead of setting\n * `innerHTML` in all cases where the content is not fully trusted.\n *\n * @static\n * @function Highcharts.AST#setElementHTML\n *\n * @param {SVGDOMElement|HTMLDOMElement} el\n * Node to set content of.\n *\n * @param {string} html\n * Markup string\n */\n AST.setElementHTML = function (el, html) {\n el.innerHTML = AST.emptyHTML; // Clear previous\n if (html) {\n var ast = new AST(html);\n ast.addToDOM(el);\n }\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Add the tree defined as a hierarchical JS structure to the DOM\n *\n * @function Highcharts.AST#addToDOM\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGDOMElement} parent\n * The node where it should be added\n *\n * @return {Highcharts.HTMLDOMElement|Highcharts.SVGDOMElement}\n * The inserted node.\n */\n AST.prototype.addToDOM = function (parent) {\n /**\n * @private\n * @param {Highcharts.ASTNode} subtree\n * HTML/SVG definition\n * @param {Element} [subParent]\n * parent node\n * @return {Highcharts.SVGDOMElement|Highcharts.HTMLDOMElement}\n * The inserted node.\n */\n function recurse(subtree, subParent) {\n var ret;\n splat(subtree).forEach(function (item) {\n var tagName = item.tagName;\n var textNode = item.textContent ?\n H.doc.createTextNode(item.textContent) :\n void 0;\n // Whether to ignore the AST filtering totally, #15345\n var bypassHTMLFiltering = AST.bypassHTMLFiltering;\n var node;\n if (tagName) {\n if (tagName === '#text') {\n node = textNode;\n }\n else if (AST.allowedTags.indexOf(tagName) !== -1 ||\n bypassHTMLFiltering) {\n var NS = tagName === 'svg' ?\n SVG_NS :\n (subParent.namespaceURI || SVG_NS);\n var element = H.doc.createElementNS(NS,\n tagName);\n var attributes_1 = item.attributes || {};\n // Apply attributes from root of AST node, legacy from\n // from before TextBuilder\n objectEach(item, function (val, key) {\n if (key !== 'tagName' &&\n key !== 'attributes' &&\n key !== 'children' &&\n key !== 'style' &&\n key !== 'textContent') {\n attributes_1[key] = val;\n }\n });\n attr(element, bypassHTMLFiltering ?\n attributes_1 :\n AST.filterUserAttributes(attributes_1));\n if (item.style) {\n css(element, item.style);\n }\n // Add text content\n if (textNode) {\n element.appendChild(textNode);\n }\n // Recurse\n recurse(item.children || [], element);\n node = element;\n }\n else {\n error(33, false, void 0, {\n 'Invalid tagName in config': tagName\n });\n }\n }\n // Add to the tree\n if (node) {\n subParent.appendChild(node);\n }\n ret = node;\n });\n // Return last node added (on top level it's the only one)\n return ret;\n }\n return recurse(this.nodes, parent);\n };\n /**\n * Parse HTML/SVG markup into AST Node objects. Used internally from the\n * constructor.\n *\n * @private\n *\n * @function Highcharts.AST#getNodesFromMarkup\n *\n * @param {string} markup The markup string.\n *\n * @return {Array} The parsed nodes.\n */\n AST.prototype.parseMarkup = function (markup) {\n var nodes = [];\n markup = markup\n .trim()\n // The style attribute throws a warning when parsing when CSP is\n // enabled (#6884), so use an alias and pick it up below\n // Make all quotation marks parse correctly to DOM (#17627)\n .replace(/ style=([\"'])/g, ' data-style=$1');\n var doc;\n if (hasValidDOMParser) {\n doc = new DOMParser().parseFromString(trustedTypesPolicy ?\n trustedTypesPolicy.createHTML(markup) :\n markup, 'text/html');\n }\n else {\n var body = createElement('div');\n body.innerHTML = markup;\n doc = { body: body };\n }\n var appendChildNodes = function (node,\n addTo) {\n var tagName = node.nodeName.toLowerCase();\n // Add allowed tags\n var astNode = {\n tagName: tagName\n };\n if (tagName === '#text') {\n astNode.textContent = node.textContent || '';\n }\n var parsedAttributes = node.attributes;\n // Add attributes\n if (parsedAttributes) {\n var attributes_2 = {};\n [].forEach.call(parsedAttributes, function (attrib) {\n if (attrib.name === 'data-style') {\n astNode.style = AST.parseStyle(attrib.value);\n }\n else {\n attributes_2[attrib.name] = attrib.value;\n }\n });\n astNode.attributes = attributes_2;\n }\n // Handle children\n if (node.childNodes.length) {\n var children_1 = [];\n [].forEach.call(node.childNodes, function (childNode) {\n appendChildNodes(childNode, children_1);\n });\n if (children_1.length) {\n astNode.children = children_1;\n }\n }\n addTo.push(astNode);\n };\n [].forEach.call(doc.body.childNodes, function (childNode) { return appendChildNodes(childNode, nodes); });\n return nodes;\n };\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * The list of allowed SVG or HTML attributes, used for sanitizing\n * potentially harmful content from the chart configuration before adding to\n * the DOM.\n *\n * @example\n * // Allow a custom, trusted attribute\n * Highcharts.AST.allowedAttributes.push('data-value');\n *\n * @name Highcharts.AST.allowedAttributes\n * @static\n */\n AST.allowedAttributes = [\n 'aria-controls',\n 'aria-describedby',\n 'aria-expanded',\n 'aria-haspopup',\n 'aria-hidden',\n 'aria-label',\n 'aria-labelledby',\n 'aria-live',\n 'aria-pressed',\n 'aria-readonly',\n 'aria-roledescription',\n 'aria-selected',\n 'class',\n 'clip-path',\n 'color',\n 'colspan',\n 'cx',\n 'cy',\n 'd',\n 'dx',\n 'dy',\n 'disabled',\n 'fill',\n 'height',\n 'href',\n 'id',\n 'in',\n 'markerHeight',\n 'markerWidth',\n 'offset',\n 'opacity',\n 'orient',\n 'padding',\n 'paddingLeft',\n 'paddingRight',\n 'patternUnits',\n 'r',\n 'refX',\n 'refY',\n 'role',\n 'scope',\n 'slope',\n 'src',\n 'startOffset',\n 'stdDeviation',\n 'stroke',\n 'stroke-linecap',\n 'stroke-width',\n 'style',\n 'tableValues',\n 'result',\n 'rowspan',\n 'summary',\n 'target',\n 'tabindex',\n 'text-align',\n 'text-anchor',\n 'textAnchor',\n 'textLength',\n 'title',\n 'type',\n 'valign',\n 'width',\n 'x',\n 'x1',\n 'x2',\n 'y',\n 'y1',\n 'y2',\n 'zIndex'\n ];\n /**\n * The list of allowed references for referring attributes like `href` and\n * `src`. Attribute values will only be allowed if they start with one of\n * these strings.\n *\n * @example\n * // Allow tel:\n * Highcharts.AST.allowedReferences.push('tel:');\n *\n * @name Highcharts.AST.allowedReferences\n * @static\n */\n AST.allowedReferences = [\n 'https://',\n 'http://',\n 'mailto:',\n '/',\n '../',\n './',\n '#'\n ];\n /**\n * The list of allowed SVG or HTML tags, used for sanitizing potentially\n * harmful content from the chart configuration before adding to the DOM.\n *\n * @example\n * // Allow a custom, trusted tag\n * Highcharts.AST.allowedTags.push('blink'); // ;)\n *\n * @name Highcharts.AST.allowedTags\n * @static\n */\n AST.allowedTags = [\n 'a',\n 'abbr',\n 'b',\n 'br',\n 'button',\n 'caption',\n 'circle',\n 'clipPath',\n 'code',\n 'dd',\n 'defs',\n 'div',\n 'dl',\n 'dt',\n 'em',\n 'feComponentTransfer',\n 'feFuncA',\n 'feFuncB',\n 'feFuncG',\n 'feFuncR',\n 'feGaussianBlur',\n 'feOffset',\n 'feMerge',\n 'feMergeNode',\n 'filter',\n 'h1',\n 'h2',\n 'h3',\n 'h4',\n 'h5',\n 'h6',\n 'hr',\n 'i',\n 'img',\n 'li',\n 'linearGradient',\n 'marker',\n 'ol',\n 'p',\n 'path',\n 'pattern',\n 'pre',\n 'rect',\n 'small',\n 'span',\n 'stop',\n 'strong',\n 'style',\n 'sub',\n 'sup',\n 'svg',\n 'table',\n 'text',\n 'textPath',\n 'thead',\n 'tbody',\n 'tspan',\n 'td',\n 'th',\n 'tr',\n 'u',\n 'ul',\n '#text'\n ];\n AST.emptyHTML = emptyHTML;\n /**\n * Allow all custom SVG and HTML attributes, references and tags (together\n * with potentially harmful ones) to be added to the DOM from the chart\n * configuration. In other words, disable the the allow-listing which is the\n * primary functionality of the AST.\n *\n * WARNING: Setting this property to `true` while allowing untrusted user\n * data in the chart configuration will expose your application to XSS\n * security risks!\n *\n * Note that in case you want to allow a known set of tags or attributes,\n * you should allow-list them instead of disabling the filtering totally.\n * See [allowedAttributes](Highcharts.AST#.allowedAttributes),\n * [allowedReferences](Highcharts.AST#.allowedReferences) and\n * [allowedTags](Highcharts.AST#.allowedTags). The `bypassHTMLFiltering`\n * setting is intended only for those cases where allow-listing is not\n * practical, and the chart configuration already comes from a secure\n * source.\n *\n * @example\n * // Allow all custom attributes, references and tags (disable DOM XSS\n * // filtering)\n * Highcharts.AST.bypassHTMLFiltering = true;\n *\n * @name Highcharts.AST.bypassHTMLFiltering\n * @static\n */\n AST.bypassHTMLFiltering = false;\n return AST;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Serialized form of an SVG/HTML definition, including children.\n *\n * @interface Highcharts.ASTNode\n */ /**\n * @name Highcharts.ASTNode#attributes\n * @type {Highcharts.SVGAttributes|undefined}\n */ /**\n * @name Highcharts.ASTNode#children\n * @type {Array|undefined}\n */ /**\n * @name Highcharts.ASTNode#tagName\n * @type {string|undefined}\n */ /**\n * @name Highcharts.ASTNode#textContent\n * @type {string|undefined}\n */\n (''); // keeps doclets above in file\n\n return AST;\n });\n _registerModule(_modules, 'Core/FormatUtilities.js', [_modules['Core/Defaults.js'], _modules['Core/Utilities.js']], function (D, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var defaultOptions = D.defaultOptions,\n defaultTime = D.defaultTime;\n var getNestedProperty = U.getNestedProperty,\n isNumber = U.isNumber,\n pick = U.pick,\n pInt = U.pInt;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Formats a JavaScript date timestamp (milliseconds since Jan 1st 1970) into a\n * human readable date string. The format is a subset of the formats for PHP's\n * [strftime](https://www.php.net/manual/en/function.strftime.php) function.\n * Additional formats can be given in the {@link Highcharts.dateFormats} hook.\n *\n * Since v6.0.5, all internal dates are formatted through the\n * {@link Highcharts.Chart#time} instance to respect chart-level time settings.\n * The `Highcharts.dateFormat` function only reflects global time settings set\n * with `setOptions`.\n *\n * Supported format keys:\n * - `%a`: Short weekday, like 'Mon'\n * - `%A`: Long weekday, like 'Monday'\n * - `%d`: Two digit day of the month, 01 to 31\n * - `%e`: Day of the month, 1 through 31\n * - `%w`: Day of the week, 0 through 6\n * - `%b`: Short month, like 'Jan'\n * - `%B`: Long month, like 'January'\n * - `%m`: Two digit month number, 01 through 12\n * - `%y`: Two digits year, like 09 for 2009\n * - `%Y`: Four digits year, like 2009\n * - `%H`: Two digits hours in 24h format, 00 through 23\n * - `%k`: Hours in 24h format, 0 through 23\n * - `%I`: Two digits hours in 12h format, 00 through 11\n * - `%l`: Hours in 12h format, 1 through 12\n * - `%M`: Two digits minutes, 00 through 59\n * - `%p`: Upper case AM or PM\n * - `%P`: Lower case AM or PM\n * - `%S`: Two digits seconds, 00 through 59\n * - `%L`: Milliseconds (naming from Ruby)\n *\n * @function Highcharts.dateFormat\n *\n * @param {string} format\n * The desired format where various time representations are prefixed\n * with `%`.\n *\n * @param {number} timestamp\n * The JavaScript timestamp.\n *\n * @param {boolean} [capitalize=false]\n * Upper case first letter in the return.\n *\n * @return {string}\n * The formatted date.\n */\n function dateFormat(format, timestamp, capitalize) {\n return defaultTime.dateFormat(format, timestamp, capitalize);\n }\n /**\n * Format a string according to a subset of the rules of Python's String.format\n * method.\n *\n * @example\n * let s = Highcharts.format(\n * 'The {color} fox was {len:.2f} feet long',\n * { color: 'red', len: Math.PI }\n * );\n * // => The red fox was 3.14 feet long\n *\n * @function Highcharts.format\n *\n * @param {string} str\n * The string to format.\n *\n * @param {Record} ctx\n * The context, a collection of key-value pairs where each key is\n * replaced by its value.\n *\n * @param {Highcharts.Chart} [chart]\n * A `Chart` instance used to get numberFormatter and time.\n *\n * @return {string}\n * The formatted string.\n */\n function format(str, ctx, chart) {\n var splitter = '{',\n isInside = false,\n segment,\n valueAndFormat,\n val,\n index;\n var floatRegex = /f$/;\n var decRegex = /\\.([0-9])/;\n var lang = defaultOptions.lang;\n var time = chart && chart.time || defaultTime;\n var numberFormatter = chart && chart.numberFormatter || numberFormat;\n var ret = [];\n while (str) {\n index = str.indexOf(splitter);\n if (index === -1) {\n break;\n }\n segment = str.slice(0, index);\n if (isInside) { // we're on the closing bracket looking back\n valueAndFormat = segment.split(':');\n val = getNestedProperty(valueAndFormat.shift() || '', ctx);\n // Format the replacement\n if (valueAndFormat.length && typeof val === 'number') {\n segment = valueAndFormat.join(':');\n if (floatRegex.test(segment)) { // float\n var decimals = parseInt((segment.match(decRegex) || ['', '-1'])[1], 10);\n if (val !== null) {\n val = numberFormatter(val, decimals, lang.decimalPoint, segment.indexOf(',') > -1 ? lang.thousandsSep : '');\n }\n }\n else {\n val = time.dateFormat(segment, val);\n }\n }\n // Push the result and advance the cursor\n ret.push(val);\n }\n else {\n ret.push(segment);\n }\n str = str.slice(index + 1); // the rest\n isInside = !isInside; // toggle\n splitter = isInside ? '}' : '{'; // now look for next matching bracket\n }\n ret.push(str);\n return ret.join('');\n }\n /**\n * Format a number and return a string based on input settings.\n *\n * @sample highcharts/members/highcharts-numberformat/\n * Custom number format\n *\n * @function Highcharts.numberFormat\n *\n * @param {number} number\n * The input number to format.\n *\n * @param {number} decimals\n * The amount of decimals. A value of -1 preserves the amount in the\n * input number.\n *\n * @param {string} [decimalPoint]\n * The decimal point, defaults to the one given in the lang options, or\n * a dot.\n *\n * @param {string} [thousandsSep]\n * The thousands separator, defaults to the one given in the lang\n * options, or a space character.\n *\n * @return {string}\n * The formatted number.\n */\n function numberFormat(number, decimals, decimalPoint, thousandsSep) {\n number = +number || 0;\n decimals = +decimals;\n var ret,\n fractionDigits;\n var lang = defaultOptions.lang, origDec = (number.toString().split('.')[1] || '').split('e')[0].length, exponent = number.toString().split('e'), firstDecimals = decimals;\n if (decimals === -1) {\n // Preserve decimals. Not huge numbers (#3793).\n decimals = Math.min(origDec, 20);\n }\n else if (!isNumber(decimals)) {\n decimals = 2;\n }\n else if (decimals && exponent[1] && exponent[1] < 0) {\n // Expose decimals from exponential notation (#7042)\n fractionDigits = decimals + +exponent[1];\n if (fractionDigits >= 0) {\n // remove too small part of the number while keeping the notation\n exponent[0] = (+exponent[0]).toExponential(fractionDigits)\n .split('e')[0];\n decimals = fractionDigits;\n }\n else {\n // fractionDigits < 0\n exponent[0] = exponent[0].split('.')[0] || 0;\n if (decimals < 20) {\n // use number instead of exponential notation (#7405)\n number = (exponent[0] * Math.pow(10, exponent[1]))\n .toFixed(decimals);\n }\n else {\n // or zero\n number = 0;\n }\n exponent[1] = 0;\n }\n }\n // Add another decimal to avoid rounding errors of float numbers. (#4573)\n // Then use toFixed to handle rounding.\n var roundedNumber = (Math.abs(exponent[1] ? exponent[0] : number) +\n Math.pow(10, -Math.max(decimals,\n origDec) - 1)).toFixed(decimals);\n // A string containing the positive integer component of the number\n var strinteger = String(pInt(roundedNumber));\n // Leftover after grouping into thousands. Can be 0, 1 or 2.\n var thousands = strinteger.length > 3 ? strinteger.length % 3 : 0;\n // Language\n decimalPoint = pick(decimalPoint, lang.decimalPoint);\n thousandsSep = pick(thousandsSep, lang.thousandsSep);\n // Start building the return\n ret = number < 0 ? '-' : '';\n // Add the leftover after grouping into thousands. For example, in the\n // number 42 000 000, this line adds 42.\n ret += thousands ? strinteger.substr(0, thousands) + thousandsSep : '';\n if (+exponent[1] < 0 && !firstDecimals) {\n ret = '0';\n }\n else {\n // Add the remaining thousands groups, joined by the thousands separator\n ret += strinteger\n .substr(thousands)\n .replace(/(\\d{3})(?=\\d)/g, '$1' + thousandsSep);\n }\n // Add the decimal point and the decimal component\n if (decimals) {\n // Get the decimal component\n ret += decimalPoint + roundedNumber.slice(-decimals);\n }\n if (exponent[1] && +ret !== 0) {\n ret += 'e' + exponent[1];\n }\n return ret;\n }\n /* *\n *\n * Default Export\n *\n * */\n var FormatUtilities = {\n dateFormat: dateFormat,\n format: format,\n numberFormat: numberFormat\n };\n\n return FormatUtilities;\n });\n _registerModule(_modules, 'Core/Renderer/RendererUtilities.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Imports\n *\n * */\n var clamp = U.clamp,\n pick = U.pick,\n stableSort = U.stableSort;\n /* *\n *\n * Namespace\n *\n * */\n var RendererUtilities;\n (function (RendererUtilities) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * General distribution algorithm for distributing labels of differing size\n * along a confined length in two dimensions. The algorithm takes an array\n * of objects containing a size, a target and a rank. It will place the\n * labels as close as possible to their targets, skipping the lowest ranked\n * labels if necessary.\n * @private\n */\n function distribute(boxes, len, maxDistance) {\n // Original array will be altered with added .pos\n var origBoxes = boxes,\n reducedLen = origBoxes.reducedLen || len,\n sortByRank = function (a,\n b) {\n return (b.rank || 0) - (a.rank || 0);\n }, sortByTarget = function (a, b) {\n return a.target - b.target;\n };\n var i,\n overlapping = true,\n restBoxes = [], // The outranked overshoot\n box,\n target,\n total = 0;\n // If the total size exceeds the len, remove those boxes with the lowest\n // rank\n i = boxes.length;\n while (i--) {\n total += boxes[i].size;\n }\n // Sort by rank, then slice away overshoot\n if (total > reducedLen) {\n stableSort(boxes, sortByRank);\n i = 0;\n total = 0;\n while (total <= reducedLen) {\n total += boxes[i].size;\n i++;\n }\n restBoxes = boxes.splice(i - 1, boxes.length);\n }\n // Order by target\n stableSort(boxes, sortByTarget);\n // So far we have been mutating the original array. Now\n // create a copy with target arrays\n boxes = boxes.map(function (box) { return ({\n size: box.size,\n targets: [box.target],\n align: pick(box.align, 0.5)\n }); });\n while (overlapping) {\n // Initial positions: target centered in box\n i = boxes.length;\n while (i--) {\n box = boxes[i];\n // Composite box, average of targets\n target = (Math.min.apply(0, box.targets) +\n Math.max.apply(0, box.targets)) / 2;\n box.pos = clamp(target - box.size * box.align, 0, len - box.size);\n }\n // Detect overlap and join boxes\n i = boxes.length;\n overlapping = false;\n while (i--) {\n // Overlap\n if (i > 0 &&\n boxes[i - 1].pos + boxes[i - 1].size >\n boxes[i].pos) {\n // Add this size to the previous box\n boxes[i - 1].size += boxes[i].size;\n boxes[i - 1].targets = boxes[i - 1]\n .targets\n .concat(boxes[i].targets);\n boxes[i - 1].align = 0.5;\n // Overlapping right, push left\n if (boxes[i - 1].pos + boxes[i - 1].size > len) {\n boxes[i - 1].pos = len - boxes[i - 1].size;\n }\n boxes.splice(i, 1); // Remove this item\n overlapping = true;\n }\n }\n }\n // Add the rest (hidden boxes)\n origBoxes.push.apply(origBoxes, restBoxes);\n // Now the composite boxes are placed, we need to put the original boxes\n // within them\n i = 0;\n boxes.some(function (box) {\n var posInCompositeBox = 0;\n // Exceeded maxDistance => abort\n return (box.targets || []).some(function () {\n origBoxes[i].pos = box.pos + posInCompositeBox;\n // If the distance between the position and the target exceeds\n // maxDistance, abort the loop and decrease the length in\n // increments of 10% to recursively reduce the number of\n // visible boxes by rank. Once all boxes are within the\n // maxDistance, we're good.\n if (typeof maxDistance !== 'undefined' &&\n Math.abs(origBoxes[i].pos - origBoxes[i].target) > maxDistance) {\n // Reset the positions that are already set\n origBoxes\n .slice(0, i + 1)\n .forEach(function (box) { return delete box.pos; });\n // Try with a smaller length\n origBoxes.reducedLen =\n (origBoxes.reducedLen || len) - (len * 0.1);\n // Recurse\n if (origBoxes.reducedLen > len * 0.1) {\n distribute(origBoxes, len, maxDistance);\n }\n // Exceeded maxDistance => abort\n return true;\n }\n posInCompositeBox += origBoxes[i].size;\n i++;\n return false;\n });\n });\n // Add the rest (hidden) boxes and sort by target\n stableSort(origBoxes, sortByTarget);\n return origBoxes;\n }\n RendererUtilities.distribute = distribute;\n })(RendererUtilities || (RendererUtilities = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return RendererUtilities;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/SVGElement.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (A, Color, H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var animate = A.animate,\n animObject = A.animObject,\n stop = A.stop;\n var deg2rad = H.deg2rad,\n doc = H.doc,\n noop = H.noop,\n svg = H.svg,\n SVG_NS = H.SVG_NS,\n win = H.win;\n var addEvent = U.addEvent,\n attr = U.attr,\n createElement = U.createElement,\n css = U.css,\n defined = U.defined,\n erase = U.erase,\n extend = U.extend,\n fireEvent = U.fireEvent,\n isArray = U.isArray,\n isFunction = U.isFunction,\n isNumber = U.isNumber,\n isString = U.isString,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick,\n pInt = U.pInt,\n removeEvent = U.removeEvent,\n syncTimeout = U.syncTimeout,\n uniqueKey = U.uniqueKey;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The SVGElement prototype is a JavaScript wrapper for SVG elements used in the\n * rendering layer of Highcharts. Combined with the\n * {@link Highcharts.SVGRenderer}\n * object, these prototypes allow freeform annotation in the charts or even in\n * HTML pages without instanciating a chart. The SVGElement can also wrap HTML\n * labels, when `text` or `label` elements are created with the `useHTML`\n * parameter.\n *\n * The SVGElement instances are created through factory functions on the\n * {@link Highcharts.SVGRenderer}\n * object, like\n * {@link Highcharts.SVGRenderer#rect|rect},\n * {@link Highcharts.SVGRenderer#path|path},\n * {@link Highcharts.SVGRenderer#text|text},\n * {@link Highcharts.SVGRenderer#label|label},\n * {@link Highcharts.SVGRenderer#g|g}\n * and more.\n *\n * @class\n * @name Highcharts.SVGElement\n */\n var SVGElement = /** @class */ (function () {\n function SVGElement() {\n /* *\n *\n * Properties\n *\n * */\n this.element = void 0;\n this.onEvents = {};\n this.opacity = 1; // Default base for animation\n this.renderer = void 0;\n this.SVG_NS = SVG_NS;\n // Custom attributes used for symbols, these should be filtered out when\n // setting SVGElement attributes (#9375).\n this.symbolCustomAttribs = [\n 'x',\n 'y',\n 'width',\n 'height',\n 'r',\n 'start',\n 'end',\n 'innerR',\n 'anchorX',\n 'anchorY',\n 'rounded'\n ];\n }\n // @todo public zIndex?: number;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get the current value of an attribute or pseudo attribute,\n * used mainly for animation. Called internally from\n * the {@link Highcharts.SVGRenderer#attr} function.\n *\n * @private\n * @function Highcharts.SVGElement#_defaultGetter\n *\n * @param {string} key\n * Property key.\n *\n * @return {number|string}\n * Property value.\n */\n SVGElement.prototype._defaultGetter = function (key) {\n var ret = pick(this[key + 'Value'], // align getter\n this[key],\n this.element ? this.element.getAttribute(key) : null, 0);\n if (/^[\\-0-9\\.]+$/.test(ret)) { // is numerical\n ret = parseFloat(ret);\n }\n return ret;\n };\n /**\n * @private\n * @function Highcharts.SVGElement#_defaultSetter\n *\n * @param {string} value\n *\n * @param {string} key\n *\n * @param {Highcharts.SVGDOMElement} element\n *\n */\n SVGElement.prototype._defaultSetter = function (value, key, element) {\n element.setAttribute(key, value);\n };\n /**\n * Add the element to the DOM. All elements must be added this way.\n *\n * @sample highcharts/members/renderer-g\n * Elements added to a group\n *\n * @function Highcharts.SVGElement#add\n *\n * @param {Highcharts.SVGElement} [parent]\n * The parent item to add it to. If undefined, the element is added\n * to the {@link Highcharts.SVGRenderer.box}.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n SVGElement.prototype.add = function (parent) {\n var renderer = this.renderer,\n element = this.element;\n var inserted;\n if (parent) {\n this.parentGroup = parent;\n }\n // Mark as inverted\n this.parentInverted = parent && parent.inverted;\n // Build formatted text\n if (typeof this.textStr !== 'undefined' &&\n this.element.nodeName === 'text' // Not for SVGLabel instances\n ) {\n renderer.buildText(this);\n }\n // Mark as added\n this.added = true;\n // If we're adding to renderer root, or other elements in the group\n // have a z index, we need to handle it\n if (!parent || parent.handleZ || this.zIndex) {\n inserted = this.zIndexSetter();\n }\n // If zIndex is not handled, append at the end\n if (!inserted) {\n (parent ?\n parent.element :\n renderer.box).appendChild(element);\n }\n // fire an event for internal hooks\n if (this.onAdd) {\n this.onAdd();\n }\n return this;\n };\n /**\n * Add a class name to an element.\n *\n * @function Highcharts.SVGElement#addClass\n *\n * @param {string} className\n * The new class name to add.\n *\n * @param {boolean} [replace=false]\n * When true, the existing class name(s) will be overwritten with the new\n * one. When false, the new one is added.\n *\n * @return {Highcharts.SVGElement}\n * Return the SVG element for chainability.\n */\n SVGElement.prototype.addClass = function (className, replace) {\n var currentClassName = replace ? '' : (this.attr('class') || '');\n // Trim the string and remove duplicates\n className = (className || '')\n .split(/ /g)\n .reduce(function (newClassName, name) {\n if (currentClassName.indexOf(name) === -1) {\n newClassName.push(name);\n }\n return newClassName;\n }, (currentClassName ?\n [currentClassName] :\n []))\n .join(' ');\n if (className !== currentClassName) {\n this.attr('class', className);\n }\n return this;\n };\n /**\n * This method is executed in the end of `attr()`, after setting all\n * attributes in the hash. In can be used to efficiently consolidate\n * multiple attributes in one SVG property -- e.g., translate, rotate and\n * scale are merged in one \"transform\" attribute in the SVG node.\n *\n * @private\n * @function Highcharts.SVGElement#afterSetters\n */\n SVGElement.prototype.afterSetters = function () {\n // Update transform. Do this outside the loop to prevent redundant\n // updating for batch setting of attributes.\n if (this.doTransform) {\n this.updateTransform();\n this.doTransform = false;\n }\n };\n /**\n * Align the element relative to the chart or another box.\n *\n * @function Highcharts.SVGElement#align\n *\n * @param {Highcharts.AlignObject} [alignOptions]\n * The alignment options. The function can be called without this\n * parameter in order to re-align an element after the box has been\n * updated.\n *\n * @param {boolean} [alignByTranslate]\n * Align element by translation.\n *\n * @param {string|Highcharts.BBoxObject} [box]\n * The box to align to, needs a width and height. When the box is a\n * string, it refers to an object in the Renderer. For example, when\n * box is `spacingBox`, it refers to `Renderer.spacingBox` which\n * holds `width`, `height`, `x` and `y` properties.\n *\n * @return {Highcharts.SVGElement} Returns the SVGElement for chaining.\n */\n SVGElement.prototype.align = function (alignOptions, alignByTranslate, box) {\n var attribs = {},\n renderer = this.renderer,\n alignedObjects = renderer.alignedObjects;\n var x,\n y,\n alignTo,\n alignFactor,\n vAlignFactor;\n // First call on instanciate\n if (alignOptions) {\n this.alignOptions = alignOptions;\n this.alignByTranslate = alignByTranslate;\n if (!box || isString(box)) {\n this.alignTo = alignTo = box || 'renderer';\n // prevent duplicates, like legendGroup after resize\n erase(alignedObjects, this);\n alignedObjects.push(this);\n box = void 0; // reassign it below\n }\n // When called on resize, no arguments are supplied\n }\n else {\n alignOptions = this.alignOptions;\n alignByTranslate = this.alignByTranslate;\n alignTo = this.alignTo;\n }\n box = pick(box, renderer[alignTo], alignTo === 'scrollablePlotBox' ?\n renderer.plotBox : void 0, renderer);\n // Assign variables\n var align = alignOptions.align,\n vAlign = alignOptions.verticalAlign;\n // default: left align\n x = (box.x || 0) + (alignOptions.x || 0);\n // default: top align\n y = (box.y || 0) + (alignOptions.y || 0);\n // Align\n if (align === 'right') {\n alignFactor = 1;\n }\n else if (align === 'center') {\n alignFactor = 2;\n }\n if (alignFactor) {\n x += (box.width - (alignOptions.width || 0)) /\n alignFactor;\n }\n attribs[alignByTranslate ? 'translateX' : 'x'] = Math.round(x);\n // Vertical align\n if (vAlign === 'bottom') {\n vAlignFactor = 1;\n }\n else if (vAlign === 'middle') {\n vAlignFactor = 2;\n }\n if (vAlignFactor) {\n y += (box.height - (alignOptions.height || 0)) /\n vAlignFactor;\n }\n attribs[alignByTranslate ? 'translateY' : 'y'] = Math.round(y);\n // Animate only if already placed\n this[this.placed ? 'animate' : 'attr'](attribs);\n this.placed = true;\n this.alignAttr = attribs;\n return this;\n };\n /**\n * @private\n * @function Highcharts.SVGElement#alignSetter\n * @param {\"left\"|\"center\"|\"right\"} value\n */\n SVGElement.prototype.alignSetter = function (value) {\n var convert = {\n left: 'start',\n center: 'middle',\n right: 'end'\n };\n if (convert[value]) {\n this.alignValue = value;\n this.element.setAttribute('text-anchor', convert[value]);\n }\n };\n /**\n * Animate to given attributes or CSS properties.\n *\n * @sample highcharts/members/element-on/\n * Setting some attributes by animation\n *\n * @function Highcharts.SVGElement#animate\n *\n * @param {Highcharts.SVGAttributes} params\n * SVG attributes or CSS to animate.\n *\n * @param {boolean|Partial} [options]\n * Animation options.\n *\n * @param {Function} [complete]\n * Function to perform at the end of animation.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n SVGElement.prototype.animate = function (params, options, complete) {\n var _this = this;\n var animOptions = animObject(pick(options,\n this.renderer.globalAnimation,\n true)),\n deferTime = animOptions.defer;\n // When the page is hidden save resources in the background by not\n // running animation at all (#9749).\n if (pick(doc.hidden, doc.msHidden, doc.webkitHidden, false)) {\n animOptions.duration = 0;\n }\n if (animOptions.duration !== 0) {\n // allows using a callback with the global animation without\n // overwriting it\n if (complete) {\n animOptions.complete = complete;\n }\n // If defer option is defined delay the animation #12901\n syncTimeout(function () {\n if (_this.element) {\n animate(_this, params, animOptions);\n }\n }, deferTime);\n }\n else {\n this.attr(params, void 0, complete || animOptions.complete);\n // Call the end step synchronously\n objectEach(params, function (val, prop) {\n if (animOptions.step) {\n animOptions.step.call(this, val, { prop: prop, pos: 1, elem: this });\n }\n }, this);\n }\n return this;\n };\n /**\n * Apply a text outline through a custom CSS property, by copying the text\n * element and apply stroke to the copy. Used internally. Contrast checks at\n * [example](https://jsfiddle.net/highcharts/43soe9m1/2/).\n *\n * @example\n * // Specific color\n * text.css({\n * textOutline: '1px black'\n * });\n * // Automatic contrast\n * text.css({\n * color: '#000000', // black text\n * textOutline: '1px contrast' // => white outline\n * });\n *\n * @private\n * @function Highcharts.SVGElement#applyTextOutline\n *\n * @param {string} textOutline\n * A custom CSS `text-outline` setting, defined by `width color`.\n */\n SVGElement.prototype.applyTextOutline = function (textOutline) {\n var elem = this.element,\n hasContrast = textOutline.indexOf('contrast') !== -1,\n styles = {};\n // When the text shadow is set to contrast, use dark stroke for light\n // text and vice versa.\n if (hasContrast) {\n styles.textOutline = textOutline = textOutline.replace(/contrast/g, this.renderer.getContrast(elem.style.fill));\n }\n // Extract the stroke width and color\n var parts = textOutline.split(' ');\n var color = parts[parts.length - 1];\n var strokeWidth = parts[0];\n if (strokeWidth && strokeWidth !== 'none' && H.svg) {\n this.fakeTS = true; // Fake text shadow\n // Since the stroke is applied on center of the actual outline, we\n // need to double it to get the correct stroke-width outside the\n // glyphs.\n strokeWidth = strokeWidth.replace(/(^[\\d\\.]+)(.*?)$/g, function (match, digit, unit) {\n return (2 * Number(digit)) + unit;\n });\n // Remove shadows from previous runs.\n this.removeTextOutline();\n var outline_1 = doc.createElementNS(SVG_NS, 'tspan');\n attr(outline_1, {\n 'class': 'highcharts-text-outline',\n fill: color,\n stroke: color,\n 'stroke-width': strokeWidth,\n 'stroke-linejoin': 'round'\n });\n // For each of the tspans and text nodes, create a copy in the\n // outline.\n var parentElem = elem.querySelector('textPath') || elem;\n [].forEach.call(parentElem.childNodes, function (childNode) {\n var clone = childNode.cloneNode(true);\n if (clone.removeAttribute) {\n ['fill', 'stroke', 'stroke-width', 'stroke'].forEach(function (prop) { return clone\n .removeAttribute(prop); });\n }\n outline_1.appendChild(clone);\n });\n // Collect the sum of dy from all children, included nested ones\n var totalHeight_1 = 0;\n [].forEach.call(parentElem.querySelectorAll('text tspan'), function (element) {\n totalHeight_1 += Number(element.getAttribute('dy'));\n });\n // Insert an absolutely positioned break before the original text\n // to keep it in place\n var br = doc.createElementNS(SVG_NS, 'tspan');\n br.textContent = '\\u200B';\n // Reset the position for the following text\n attr(br, {\n x: Number(elem.getAttribute('x')),\n dy: -totalHeight_1\n });\n // Insert the outline\n outline_1.appendChild(br);\n parentElem.insertBefore(outline_1, parentElem.firstChild);\n }\n };\n /**\n * @function Highcharts.SVGElement#attr\n * @param {string} key\n * @return {number|string}\n */ /**\n * Apply native and custom attributes to the SVG elements.\n *\n * In order to set the rotation center for rotation, set x and y to 0 and\n * use `translateX` and `translateY` attributes to position the element\n * instead.\n *\n * Attributes frequently used in Highcharts are `fill`, `stroke`,\n * `stroke-width`.\n *\n * @sample highcharts/members/renderer-rect/\n * Setting some attributes\n *\n * @example\n * // Set multiple attributes\n * element.attr({\n * stroke: 'red',\n * fill: 'blue',\n * x: 10,\n * y: 10\n * });\n *\n * // Set a single attribute\n * element.attr('stroke', 'red');\n *\n * // Get an attribute\n * element.attr('stroke'); // => 'red'\n *\n * @function Highcharts.SVGElement#attr\n *\n * @param {string|Highcharts.SVGAttributes} [hash]\n * The native and custom SVG attributes.\n *\n * @param {number|string|Highcharts.SVGPathArray} [val]\n * If the type of the first argument is `string`, the second can be a\n * value, which will serve as a single attribute setter. If the first\n * argument is a string and the second is undefined, the function\n * serves as a getter and the current value of the property is\n * returned.\n *\n * @param {Function} [complete]\n * A callback function to execute after setting the attributes. This\n * makes the function compliant and interchangeable with the\n * {@link SVGElement#animate} function.\n *\n * @param {boolean} [continueAnimation=true]\n * Used internally when `.attr` is called as part of an animation\n * step. Otherwise, calling `.attr` for an attribute will stop\n * animation for that attribute.\n *\n * @return {Highcharts.SVGElement}\n * If used as a setter, it returns the current\n * {@link Highcharts.SVGElement} so the calls can be chained. If\n * used as a getter, the current value of the attribute is returned.\n */\n SVGElement.prototype.attr = function (hash, val, complete, continueAnimation) {\n var element = this.element,\n symbolCustomAttribs = this.symbolCustomAttribs;\n var key,\n hasSetSymbolSize,\n ret = this,\n skipAttr,\n setter;\n // single key-value pair\n if (typeof hash === 'string' && typeof val !== 'undefined') {\n key = hash;\n hash = {};\n hash[key] = val;\n }\n // used as a getter: first argument is a string, second is undefined\n if (typeof hash === 'string') {\n ret = (this[hash + 'Getter'] ||\n this._defaultGetter).call(this, hash, element);\n // setter\n }\n else {\n objectEach(hash, function eachAttribute(val, key) {\n skipAttr = false;\n // Unless .attr is from the animator update, stop current\n // running animation of this property\n if (!continueAnimation) {\n stop(this, key);\n }\n // Special handling of symbol attributes\n if (this.symbolName &&\n symbolCustomAttribs.indexOf(key) !== -1) {\n if (!hasSetSymbolSize) {\n this.symbolAttr(hash);\n hasSetSymbolSize = true;\n }\n skipAttr = true;\n }\n if (this.rotation && (key === 'x' || key === 'y')) {\n this.doTransform = true;\n }\n if (!skipAttr) {\n setter = (this[key + 'Setter'] ||\n this._defaultSetter);\n setter.call(this, val, key, element);\n // Let the shadow follow the main element\n if (!this.styledMode &&\n this.shadows &&\n /^(width|height|visibility|x|y|d|transform|cx|cy|r)$/\n .test(key)) {\n this.updateShadows(key, val, setter);\n }\n }\n }, this);\n this.afterSetters();\n }\n // In accordance with animate, run a complete callback\n if (complete) {\n complete.call(this);\n }\n return ret;\n };\n /**\n * Apply a clipping rectangle to this element.\n *\n * @function Highcharts.SVGElement#clip\n *\n * @param {Highcharts.ClipRectElement} [clipRect]\n * The clipping rectangle. If skipped, the current clip is removed.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVG element to allow chaining.\n */\n SVGElement.prototype.clip = function (clipRect) {\n return this.attr('clip-path', clipRect ?\n 'url(' + this.renderer.url + '#' + clipRect.id + ')' :\n 'none');\n };\n /**\n * Calculate the coordinates needed for drawing a rectangle crisply and\n * return the calculated attributes.\n *\n * @function Highcharts.SVGElement#crisp\n *\n * @param {Highcharts.RectangleObject} rect\n * Rectangle to crisp.\n *\n * @param {number} [strokeWidth]\n * The stroke width to consider when computing crisp positioning. It can\n * also be set directly on the rect parameter.\n *\n * @return {Highcharts.RectangleObject}\n * The modified rectangle arguments.\n */\n SVGElement.prototype.crisp = function (rect, strokeWidth) {\n var wrapper = this;\n strokeWidth = strokeWidth || rect.strokeWidth || 0;\n // Math.round because strokeWidth can sometimes have roundoff errors\n var normalizer = Math.round(strokeWidth) % 2 / 2;\n // normalize for crisp edges\n rect.x = Math.floor(rect.x || wrapper.x || 0) + normalizer;\n rect.y = Math.floor(rect.y || wrapper.y || 0) + normalizer;\n rect.width = Math.floor((rect.width || wrapper.width || 0) - 2 * normalizer);\n rect.height = Math.floor((rect.height || wrapper.height || 0) - 2 * normalizer);\n if (defined(rect.strokeWidth)) {\n rect.strokeWidth = strokeWidth;\n }\n return rect;\n };\n /**\n * Build and apply an SVG gradient out of a common JavaScript configuration\n * object. This function is called from the attribute setters. An event\n * hook is added for supporting other complex color types.\n *\n * @private\n * @function Highcharts.SVGElement#complexColor\n *\n * @param {Highcharts.GradientColorObject|Highcharts.PatternObject} colorOptions\n * The gradient or pattern options structure.\n *\n * @param {string} prop\n * The property to apply, can either be `fill` or `stroke`.\n *\n * @param {Highcharts.SVGDOMElement} elem\n * SVG element to apply the gradient on.\n */\n SVGElement.prototype.complexColor = function (colorOptions, prop, elem) {\n var renderer = this.renderer;\n var colorObject,\n gradName,\n gradAttr,\n radAttr,\n gradients,\n stops,\n stopColor,\n stopOpacity,\n radialReference,\n id,\n key = [],\n value;\n fireEvent(this.renderer, 'complexColor', {\n args: arguments\n }, function () {\n // Apply linear or radial gradients\n if (colorOptions.radialGradient) {\n gradName = 'radialGradient';\n }\n else if (colorOptions.linearGradient) {\n gradName = 'linearGradient';\n }\n if (gradName) {\n gradAttr = colorOptions[gradName];\n gradients = renderer.gradients;\n stops = colorOptions.stops;\n radialReference = elem.radialReference;\n // Keep < 2.2 kompatibility\n if (isArray(gradAttr)) {\n colorOptions[gradName] = gradAttr = {\n x1: gradAttr[0],\n y1: gradAttr[1],\n x2: gradAttr[2],\n y2: gradAttr[3],\n gradientUnits: 'userSpaceOnUse'\n };\n }\n // Correct the radial gradient for the radial reference system\n if (gradName === 'radialGradient' &&\n radialReference &&\n !defined(gradAttr.gradientUnits)) {\n // Save the radial attributes for updating\n radAttr = gradAttr;\n gradAttr = merge(gradAttr, renderer.getRadialAttr(radialReference, radAttr), { gradientUnits: 'userSpaceOnUse' });\n }\n // Build the unique key to detect whether we need to create a\n // new element (#1282)\n objectEach(gradAttr, function (value, n) {\n if (n !== 'id') {\n key.push(n, value);\n }\n });\n objectEach(stops, function (val) {\n key.push(val);\n });\n key = key.join(',');\n // Check if a gradient object with the same config object is\n // created within this renderer\n if (gradients[key]) {\n id = gradients[key].attr('id');\n }\n else {\n // Set the id and create the element\n gradAttr.id = id = uniqueKey();\n var gradientObject_1 = gradients[key] =\n renderer.createElement(gradName)\n .attr(gradAttr)\n .add(renderer.defs);\n gradientObject_1.radAttr = radAttr;\n // The gradient needs to keep a list of stops to be able to\n // destroy them\n gradientObject_1.stops = [];\n stops.forEach(function (stop) {\n if (stop[1].indexOf('rgba') === 0) {\n colorObject = Color.parse(stop[1]);\n stopColor = colorObject.get('rgb');\n stopOpacity = colorObject.get('a');\n }\n else {\n stopColor = stop[1];\n stopOpacity = 1;\n }\n var stopObject = renderer.createElement('stop').attr({\n offset: stop[0],\n 'stop-color': stopColor,\n 'stop-opacity': stopOpacity\n }).add(gradientObject_1);\n // Add the stop element to the gradient\n gradientObject_1.stops.push(stopObject);\n });\n }\n // Set the reference to the gradient object\n value = 'url(' + renderer.url + '#' + id + ')';\n elem.setAttribute(prop, value);\n elem.gradient = key;\n // Allow the color to be concatenated into tooltips formatters\n // etc. (#2995)\n colorOptions.toString = function () {\n return value;\n };\n }\n });\n };\n /**\n * Set styles for the element. In addition to CSS styles supported by\n * native SVG and HTML elements, there are also some custom made for\n * Highcharts, like `width`, `ellipsis` and `textOverflow` for SVG text\n * elements.\n *\n * @sample highcharts/members/renderer-text-on-chart/\n * Styled text\n *\n * @function Highcharts.SVGElement#css\n *\n * @param {Highcharts.CSSObject} styles\n * The new CSS styles.\n *\n * @return {Highcharts.SVGElement}\n * Return the SVG element for chaining.\n */\n SVGElement.prototype.css = function (styles) {\n var oldStyles = this.styles,\n newStyles = {},\n elem = this.element;\n var textWidth,\n hasNew = !oldStyles;\n // convert legacy\n if (styles.color) {\n styles.fill = styles.color;\n }\n // Filter out existing styles to increase performance (#2640)\n if (oldStyles) {\n objectEach(styles, function (value, n) {\n if (oldStyles && oldStyles[n] !== value) {\n newStyles[n] = value;\n hasNew = true;\n }\n });\n }\n if (hasNew) {\n // Merge the new styles with the old ones\n if (oldStyles) {\n styles = extend(oldStyles, newStyles);\n }\n // Get the text width from style\n // Previously set, unset it (#8234)\n if (styles.width === null || styles.width === 'auto') {\n delete this.textWidth;\n // Apply new\n }\n else if (elem.nodeName.toLowerCase() === 'text' &&\n styles.width) {\n textWidth = this.textWidth = pInt(styles.width);\n }\n // store object\n this.styles = styles;\n if (textWidth && (!svg && this.renderer.forExport)) {\n delete styles.width;\n }\n var stylesToApply_1 = merge(styles);\n if (elem.namespaceURI === this.SVG_NS) {\n // These CSS properties are interpreted internally by the SVG\n // renderer, but are not supported by SVG and should not be\n // added to the DOM. In styled mode, no CSS should find its way\n // to the DOM whatsoever (#6173, #6474).\n ['textOutline', 'textOverflow', 'width'].forEach(function (key) { return (stylesToApply_1 &&\n delete stylesToApply_1[key]); });\n }\n css(elem, stylesToApply_1);\n if (this.added) {\n // Rebuild text after added. Cache mechanisms in the buildText\n // will prevent building if there are no significant changes.\n if (this.element.nodeName === 'text') {\n this.renderer.buildText(this);\n }\n // Apply text outline after added\n if (styles.textOutline) {\n this.applyTextOutline(styles.textOutline);\n }\n }\n }\n return this;\n };\n /**\n * @private\n * @function Highcharts.SVGElement#dashstyleSetter\n * @param {string} value\n */\n SVGElement.prototype.dashstyleSetter = function (value) {\n var i,\n strokeWidth = this['stroke-width'];\n // If \"inherit\", like maps in IE, assume 1 (#4981). With HC5 and the new\n // strokeWidth function, we should be able to use that instead.\n if (strokeWidth === 'inherit') {\n strokeWidth = 1;\n }\n value = value && value.toLowerCase();\n if (value) {\n var v = value\n .replace('shortdashdotdot', '3,1,1,1,1,1,')\n .replace('shortdashdot', '3,1,1,1')\n .replace('shortdot', '1,1,')\n .replace('shortdash', '3,1,')\n .replace('longdash', '8,3,')\n .replace(/dot/g, '1,3,')\n .replace('dash', '4,3,')\n .replace(/,$/, '')\n .split(','); // ending comma\n i = v.length;\n while (i--) {\n v[i] = '' + (pInt(v[i]) * pick(strokeWidth, NaN));\n }\n value = v.join(',').replace(/NaN/g, 'none'); // #3226\n this.element.setAttribute('stroke-dasharray', value);\n }\n };\n /**\n * Destroy the element and element wrapper and clear up the DOM and event\n * hooks.\n *\n * @function Highcharts.SVGElement#destroy\n */\n SVGElement.prototype.destroy = function () {\n var wrapper = this,\n element = wrapper.element || {},\n renderer = wrapper.renderer,\n ownerSVGElement = element.ownerSVGElement;\n var parentToClean = (renderer.isSVG &&\n element.nodeName === 'SPAN' &&\n wrapper.parentGroup ||\n void 0),\n grandParent,\n i;\n // remove events\n element.onclick = element.onmouseout = element.onmouseover =\n element.onmousemove = element.point = null;\n stop(wrapper); // stop running animations\n if (wrapper.clipPath && ownerSVGElement) {\n var clipPath_1 = wrapper.clipPath;\n // Look for existing references to this clipPath and remove them\n // before destroying the element (#6196).\n // The upper case version is for Edge\n [].forEach.call(ownerSVGElement.querySelectorAll('[clip-path],[CLIP-PATH]'), function (el) {\n if (el.getAttribute('clip-path').indexOf(clipPath_1.element.id) > -1) {\n el.removeAttribute('clip-path');\n }\n });\n wrapper.clipPath = clipPath_1.destroy();\n }\n // Destroy stops in case this is a gradient object @todo old code?\n if (wrapper.stops) {\n for (i = 0; i < wrapper.stops.length; i++) {\n wrapper.stops[i].destroy();\n }\n wrapper.stops.length = 0;\n wrapper.stops = void 0;\n }\n // remove element\n wrapper.safeRemoveChild(element);\n if (!renderer.styledMode) {\n wrapper.destroyShadows();\n }\n // In case of useHTML, clean up empty containers emulating SVG groups\n // (#1960, #2393, #2697).\n while (parentToClean &&\n parentToClean.div &&\n parentToClean.div.childNodes.length === 0) {\n grandParent = parentToClean.parentGroup;\n wrapper.safeRemoveChild(parentToClean.div);\n delete parentToClean.div;\n parentToClean = grandParent;\n }\n // remove from alignObjects\n if (wrapper.alignTo) {\n erase(renderer.alignedObjects, wrapper);\n }\n objectEach(wrapper, function (val, key) {\n // Destroy child elements of a group\n if (wrapper[key] &&\n wrapper[key].parentGroup === wrapper &&\n wrapper[key].destroy) {\n wrapper[key].destroy();\n }\n // Delete all properties\n delete wrapper[key];\n });\n return;\n };\n /**\n * Destroy shadows on the element.\n *\n * @private\n * @function Highcharts.SVGElement#destroyShadows\n *\n */\n SVGElement.prototype.destroyShadows = function () {\n (this.shadows || []).forEach(function (shadow) {\n this.safeRemoveChild(shadow);\n }, this);\n this.shadows = void 0;\n };\n /**\n * @private\n * @function Highcharts.SVGElement#dSettter\n * @param {number|string|Highcharts.SVGPathArray} value\n * @param {string} key\n * @param {Highcharts.SVGDOMElement} element\n */\n SVGElement.prototype.dSetter = function (value, key, element) {\n if (isArray(value)) {\n // Backwards compatibility, convert one-dimensional array into an\n // array of segments\n if (typeof value[0] === 'string') {\n value = this.renderer.pathToSegments(value);\n }\n this.pathArray = value;\n value = value.reduce(function (acc, seg, i) {\n if (!seg || !seg.join) {\n return (seg || '').toString();\n }\n return (i ? acc + ' ' : '') + seg.join(' ');\n }, '');\n }\n if (/(NaN| {2}|^$)/.test(value)) {\n value = 'M 0 0';\n }\n // Check for cache before resetting. Resetting causes disturbance in the\n // DOM, causing flickering in some cases in Edge/IE (#6747). Also\n // possible performance gain.\n if (this[key] !== value) {\n element.setAttribute(key, value);\n this[key] = value;\n }\n };\n /**\n * Fade out an element by animating its opacity down to 0, and hide it on\n * complete. Used internally for the tooltip.\n *\n * @function Highcharts.SVGElement#fadeOut\n *\n * @param {number} [duration=150]\n * The fade duration in milliseconds.\n */\n SVGElement.prototype.fadeOut = function (duration) {\n var elemWrapper = this;\n elemWrapper.animate({\n opacity: 0\n }, {\n duration: pick(duration, 150),\n complete: function () {\n // #3088, assuming we're only using this for tooltips\n elemWrapper.hide();\n }\n });\n };\n /**\n * @private\n * @function Highcharts.SVGElement#fillSetter\n * @param {Highcharts.ColorType} value\n * @param {string} key\n * @param {Highcharts.SVGDOMElement} element\n */\n SVGElement.prototype.fillSetter = function (value, key, element) {\n if (typeof value === 'string') {\n element.setAttribute(key, value);\n }\n else if (value) {\n this.complexColor(value, key, element);\n }\n };\n /**\n * Get the bounding box (width, height, x and y) for the element. Generally\n * used to get rendered text size. Since this is called a lot in charts,\n * the results are cached based on text properties, in order to save DOM\n * traffic. The returned bounding box includes the rotation, so for example\n * a single text line of rotation 90 will report a greater height, and a\n * width corresponding to the line-height.\n *\n * @sample highcharts/members/renderer-on-chart/\n * Draw a rectangle based on a text's bounding box\n *\n * @function Highcharts.SVGElement#getBBox\n *\n * @param {boolean} [reload]\n * Skip the cache and get the updated DOM bouding box.\n *\n * @param {number} [rot]\n * Override the element's rotation. This is internally used on axis\n * labels with a value of 0 to find out what the bounding box would\n * be have been if it were not rotated.\n *\n * @return {Highcharts.BBoxObject}\n * The bounding box with `x`, `y`, `width` and `height` properties.\n */\n SVGElement.prototype.getBBox = function (reload, rot) {\n var wrapper = this,\n alignValue = wrapper.alignValue,\n element = wrapper.element,\n renderer = wrapper.renderer,\n styles = wrapper.styles,\n textStr = wrapper.textStr,\n cache = renderer.cache,\n cacheKeys = renderer.cacheKeys,\n isSVG = element.namespaceURI === wrapper.SVG_NS,\n rotation = pick(rot,\n wrapper.rotation, 0),\n fontSize = renderer.styledMode ? (element &&\n SVGElement.prototype.getStyle.call(element, 'font-size')) : (styles && styles.fontSize);\n var bBox,\n width,\n height,\n toggleTextShadowShim,\n cacheKey;\n // Avoid undefined and null (#7316)\n if (defined(textStr)) {\n cacheKey = textStr.toString();\n // Since numbers are monospaced, and numerical labels appear a lot\n // in a chart, we assume that a label of n characters has the same\n // bounding box as others of the same length. Unless there is inner\n // HTML in the label. In that case, leave the numbers as is (#5899).\n if (cacheKey.indexOf('<') === -1) {\n cacheKey = cacheKey.replace(/[0-9]/g, '0');\n }\n // Properties that affect bounding box\n cacheKey += [\n '',\n rotation,\n fontSize,\n wrapper.textWidth,\n alignValue,\n styles && styles.textOverflow,\n styles && styles.fontWeight // #12163\n ].join(',');\n }\n if (cacheKey && !reload) {\n bBox = cache[cacheKey];\n }\n // No cache found\n if (!bBox) {\n // SVG elements\n if (isSVG || renderer.forExport) {\n try { // Fails in Firefox if the container has display: none.\n // When the text shadow shim is used, we need to hide the\n // fake shadows to get the correct bounding box (#3872)\n toggleTextShadowShim = this.fakeTS && function (display) {\n var outline = element.querySelector('.highcharts-text-outline');\n if (outline) {\n css(outline, { display: display });\n }\n };\n // Workaround for #3842, Firefox reporting wrong bounding\n // box for shadows\n if (isFunction(toggleTextShadowShim)) {\n toggleTextShadowShim('none');\n }\n bBox = element.getBBox ?\n // SVG: use extend because IE9 is not allowed to change\n // width and height in case of rotation (below)\n extend({}, element.getBBox()) : {\n // HTML elements with `exporting.allowHTML` and\n // legacy IE in export mode\n width: element.offsetWidth,\n height: element.offsetHeight,\n x: 0,\n y: 0\n };\n // #3842\n if (isFunction(toggleTextShadowShim)) {\n toggleTextShadowShim('');\n }\n }\n catch (e) {\n '';\n }\n // If the bBox is not set, the try-catch block above failed. The\n // other condition is for Opera that returns a width of\n // -Infinity on hidden elements.\n if (!bBox || bBox.width < 0) {\n bBox = { x: 0, y: 0, width: 0, height: 0 };\n }\n // VML Renderer or useHTML within SVG\n }\n else {\n bBox = wrapper.htmlGetBBox();\n }\n // True SVG elements as well as HTML elements in modern browsers\n // using the .useHTML option need to compensated for rotation\n if (renderer.isSVG) {\n width = bBox.width;\n height = bBox.height;\n // Workaround for wrong bounding box in IE, Edge and Chrome on\n // Windows. With Highcharts' default font, IE and Edge report\n // a box height of 16.899 and Chrome rounds it to 17. If this\n // stands uncorrected, it results in more padding added below\n // the text than above when adding a label border or background.\n // Also vertical positioning is affected.\n // https://jsfiddle.net/highcharts/em37nvuj/\n // (#1101, #1505, #1669, #2568, #6213).\n if (isSVG) {\n bBox.height = height = ({\n '11px,17': 14,\n '13px,20': 16\n }[\"\" + (fontSize || '') + \",\".concat(Math.round(height))] ||\n height);\n }\n // Adjust for rotated text\n if (rotation) {\n var baseline = Number(element.getAttribute('y') || 0) - bBox.y,\n alignFactor = {\n 'right': 1,\n 'center': 0.5\n }[alignValue || 0] || 0,\n rad = rotation * deg2rad,\n rad90 = (rotation - 90) * deg2rad,\n wCosRad = width * Math.cos(rad),\n wSinRad = width * Math.sin(rad),\n cosRad90 = Math.cos(rad90),\n sinRad90 = Math.sin(rad90), \n // Find the starting point on the left side baseline of\n // the text\n pX = bBox.x + alignFactor * (width - wCosRad),\n pY = bBox.y + baseline - alignFactor * wSinRad, \n // Find all corners\n aX = pX + baseline * cosRad90,\n bX = aX + wCosRad,\n cX = bX - height * cosRad90,\n dX = cX - wCosRad,\n aY = pY + baseline * sinRad90,\n bY = aY + wSinRad,\n cY = bY - height * sinRad90,\n dY = cY - wSinRad;\n // Deduct the bounding box from the corners\n bBox.x = Math.min(aX, bX, cX, dX);\n bBox.y = Math.min(aY, bY, cY, dY);\n bBox.width = Math.max(aX, bX, cX, dX) - bBox.x;\n bBox.height = Math.max(aY, bY, cY, dY) - bBox.y;\n }\n }\n // Cache it. When loading a chart in a hidden iframe in Firefox and\n // IE/Edge, the bounding box height is 0, so don't cache it (#5620).\n if (cacheKey && (textStr === '' || bBox.height > 0)) {\n // Rotate (#4681)\n while (cacheKeys.length > 250) {\n delete cache[cacheKeys.shift()];\n }\n if (!cache[cacheKey]) {\n cacheKeys.push(cacheKey);\n }\n cache[cacheKey] = bBox;\n }\n }\n return bBox;\n };\n /**\n * Get the computed style. Only in styled mode.\n *\n * @example\n * chart.series[0].points[0].graphic.getStyle('stroke-width'); // => '1px'\n *\n * @function Highcharts.SVGElement#getStyle\n *\n * @param {string} prop\n * The property name to check for.\n *\n * @return {string}\n * The current computed value.\n */\n SVGElement.prototype.getStyle = function (prop) {\n return win\n .getComputedStyle(this.element || this, '')\n .getPropertyValue(prop);\n };\n /**\n * Check if an element has the given class name.\n *\n * @function Highcharts.SVGElement#hasClass\n *\n * @param {string} className\n * The class name to check for.\n *\n * @return {boolean}\n * Whether the class name is found.\n */\n SVGElement.prototype.hasClass = function (className) {\n return ('' + this.attr('class'))\n .split(' ')\n .indexOf(className) !== -1;\n };\n /**\n * Hide the element, similar to setting the `visibility` attribute to\n * `hidden`.\n *\n * @function Highcharts.SVGElement#hide\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n SVGElement.prototype.hide = function () {\n return this.attr({ visibility: 'hidden' });\n };\n /**\n * @private\n */\n SVGElement.prototype.htmlGetBBox = function () {\n return { height: 0, width: 0, x: 0, y: 0 };\n };\n /**\n * Initialize the SVG element. This function only exists to make the\n * initialization process overridable. It should not be called directly.\n *\n * @function Highcharts.SVGElement#init\n *\n * @param {Highcharts.SVGRenderer} renderer\n * The SVGRenderer instance to initialize to.\n *\n * @param {string} nodeName\n * The SVG node name.\n */\n SVGElement.prototype.init = function (renderer, nodeName) {\n /**\n * The primary DOM node. Each `SVGElement` instance wraps a main DOM\n * node, but may also represent more nodes.\n *\n * @name Highcharts.SVGElement#element\n * @type {Highcharts.SVGDOMElement|Highcharts.HTMLDOMElement}\n */\n this.element = nodeName === 'span' ?\n createElement(nodeName) :\n doc.createElementNS(this.SVG_NS, nodeName);\n /**\n * The renderer that the SVGElement belongs to.\n *\n * @name Highcharts.SVGElement#renderer\n * @type {Highcharts.SVGRenderer}\n */\n this.renderer = renderer;\n fireEvent(this, 'afterInit');\n };\n /**\n * Invert a group, rotate and flip. This is used internally on inverted\n * charts, where the points and graphs are drawn as if not inverted, then\n * the series group elements are inverted.\n *\n * @function Highcharts.SVGElement#invert\n *\n * @param {boolean} inverted\n * Whether to invert or not. An inverted shape can be un-inverted by\n * setting it to false.\n *\n * @return {Highcharts.SVGElement}\n * Return the SVGElement for chaining.\n */\n SVGElement.prototype.invert = function (inverted) {\n this.inverted = inverted;\n this.updateTransform();\n return this;\n };\n /**\n * Add an event listener. This is a simple setter that replaces the\n * previous event of the same type added by this function, as opposed to\n * the {@link Highcharts#addEvent} function.\n *\n * @sample highcharts/members/element-on/\n * A clickable rectangle\n *\n * @function Highcharts.SVGElement#on\n *\n * @param {string} eventType\n * The event type.\n *\n * @param {Function} handler\n * The handler callback.\n *\n * @return {Highcharts.SVGElement}\n * The SVGElement for chaining.\n */\n SVGElement.prototype.on = function (eventType, handler) {\n var onEvents = this.onEvents;\n if (onEvents[eventType]) {\n // Unbind existing event\n onEvents[eventType]();\n }\n onEvents[eventType] = addEvent(this.element, eventType, handler);\n return this;\n };\n /**\n * @private\n * @function Highcharts.SVGElement#opacitySetter\n * @param {string} value\n * @param {string} key\n * @param {Highcharts.SVGDOMElement} element\n */\n SVGElement.prototype.opacitySetter = function (value, key, element) {\n // Round off to avoid float errors, like tests where opacity lands on\n // 9.86957e-06 instead of 0\n var opacity = Number(Number(value).toFixed(3));\n this.opacity = opacity;\n element.setAttribute(key, opacity);\n };\n /**\n * Remove a class name from the element.\n *\n * @function Highcharts.SVGElement#removeClass\n *\n * @param {string|RegExp} className\n * The class name to remove.\n *\n * @return {Highcharts.SVGElement} Returns the SVG element for chainability.\n */\n SVGElement.prototype.removeClass = function (className) {\n return this.attr('class', ('' + this.attr('class'))\n .replace(isString(className) ?\n new RegExp(\"(^| )\".concat(className, \"( |$)\")) : // #12064, #13590\n className, ' ')\n .replace(/ +/g, ' ')\n .trim());\n };\n /**\n *\n * @private\n */\n SVGElement.prototype.removeTextOutline = function () {\n var outline = this.element\n .querySelector('tspan.highcharts-text-outline');\n if (outline) {\n this.safeRemoveChild(outline);\n }\n };\n /**\n * Removes an element from the DOM.\n *\n * @private\n * @function Highcharts.SVGElement#safeRemoveChild\n *\n * @param {Highcharts.SVGDOMElement|Highcharts.HTMLDOMElement} element\n * The DOM node to remove.\n */\n SVGElement.prototype.safeRemoveChild = function (element) {\n var parentNode = element.parentNode;\n if (parentNode) {\n parentNode.removeChild(element);\n }\n };\n /**\n * Set the coordinates needed to draw a consistent radial gradient across\n * a shape regardless of positioning inside the chart. Used on pie slices\n * to make all the slices have the same radial reference point.\n *\n * @function Highcharts.SVGElement#setRadialReference\n *\n * @param {Array} coordinates\n * The center reference. The format is `[centerX, centerY, diameter]` in\n * pixels.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n SVGElement.prototype.setRadialReference = function (coordinates) {\n var existingGradient = (this.element.gradient &&\n this.renderer.gradients[this.element.gradient]);\n this.element.radialReference = coordinates;\n // On redrawing objects with an existing gradient, the gradient needs\n // to be repositioned (#3801)\n if (existingGradient && existingGradient.radAttr) {\n existingGradient.animate(this.renderer.getRadialAttr(coordinates, existingGradient.radAttr));\n }\n return this;\n };\n /**\n * Set a text path for a `text` or `label` element, allowing the text to\n * flow along a path.\n *\n * In order to unset the path for an existing element, call `setTextPath`\n * with `{ enabled: false }` as the second argument.\n *\n * @sample highcharts/members/renderer-textpath/ Text path demonstrated\n *\n * @function Highcharts.SVGElement#setTextPath\n *\n * @param {Highcharts.SVGElement|undefined} path\n * Path to follow. If undefined, it allows changing options for the\n * existing path.\n *\n * @param {Highcharts.DataLabelsTextPathOptionsObject} textPathOptions\n * Options.\n *\n * @return {Highcharts.SVGElement} Returns the SVGElement for chaining.\n */\n SVGElement.prototype.setTextPath = function (path, textPathOptions) {\n var _this = this;\n // Defaults\n textPathOptions = merge(true, {\n enabled: true,\n attributes: {\n dy: -5,\n startOffset: '50%',\n textAnchor: 'middle'\n }\n }, textPathOptions);\n var url = this.renderer.url,\n textWrapper = this.text || this,\n textPath = textWrapper.textPath,\n attributes = textPathOptions.attributes,\n enabled = textPathOptions.enabled;\n path = path || (textPath && textPath.path);\n // Remove previously added event\n if (textPath) {\n textPath.undo();\n }\n if (path && enabled) {\n var undo = addEvent(textWrapper, 'afterModifyTree',\n function (e) {\n if (path && enabled) {\n // Set ID for the path\n var textPathId = path.attr('id');\n if (!textPathId) {\n path.attr('id', textPathId = uniqueKey());\n }\n // Set attributes for the \n var textAttribs = {\n // dx/dy options must by set on (parent), the\n // rest should be set on \n x: 0,\n y: 0\n };\n if (defined(attributes.dx)) {\n textAttribs.dx = attributes.dx;\n delete attributes.dx;\n }\n if (defined(attributes.dy)) {\n textAttribs.dy = attributes.dy;\n delete attributes.dy;\n }\n textWrapper.attr(textAttribs);\n // Handle label properties\n _this.attr({ transform: '' });\n if (_this.box) {\n _this.box = _this.box.destroy();\n }\n // Wrap the nodes in a textPath\n var children = e.nodes.slice(0);\n e.nodes.length = 0;\n e.nodes[0] = {\n tagName: 'textPath',\n attributes: extend(attributes, {\n 'text-anchor': attributes.textAnchor,\n href: \"\" + url + \"#\".concat(textPathId)\n }),\n children: children\n };\n }\n });\n // Set the reference\n textWrapper.textPath = { path: path, undo: undo };\n }\n else {\n textWrapper.attr({ dx: 0, dy: 0 });\n delete textWrapper.textPath;\n }\n if (this.added) {\n // Rebuild text after added\n textWrapper.textCache = '';\n this.renderer.buildText(textWrapper);\n }\n return this;\n };\n /**\n * Add a shadow to the element. Must be called after the element is added to\n * the DOM. In styled mode, this method is not used, instead use `defs` and\n * filters.\n *\n * @example\n * renderer.rect(10, 100, 100, 100)\n * .attr({ fill: 'red' })\n * .shadow(true);\n *\n * @function Highcharts.SVGElement#shadow\n *\n * @param {boolean|Highcharts.ShadowOptionsObject} [shadowOptions]\n * The shadow options. If `true`, the default options are applied. If\n * `false`, the current shadow will be removed.\n *\n * @param {Highcharts.SVGElement} [group]\n * The SVG group element where the shadows will be applied. The\n * default is to add it to the same parent as the current element.\n * Internally, this is ised for pie slices, where all the shadows are\n * added to an element behind all the slices.\n *\n * @param {boolean} [cutOff]\n * Used internally for column shadows.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n SVGElement.prototype.shadow = function (shadowOptions, group, cutOff) {\n var shadows = [],\n element = this.element,\n oldShadowOptions = this.oldShadowOptions,\n defaultShadowOptions = {\n color: \"#000000\" /* Palette.neutralColor100 */,\n offsetX: this.parentInverted ? -1 : 1,\n offsetY: this.parentInverted ? -1 : 1,\n opacity: 0.15,\n width: 3\n };\n var i,\n shadow,\n strokeWidth,\n shadowElementOpacity,\n update = false, \n // compensate for inverted plot area\n transform,\n options;\n if (shadowOptions === true) {\n options = defaultShadowOptions;\n }\n else if (typeof shadowOptions === 'object') {\n options = extend(defaultShadowOptions, shadowOptions);\n }\n // Update shadow when options change (#12091).\n if (options) {\n // Go over each key to look for change\n if (options && oldShadowOptions) {\n objectEach(options, function (value, key) {\n if (value !== oldShadowOptions[key]) {\n update = true;\n }\n });\n }\n if (update) {\n this.destroyShadows();\n }\n this.oldShadowOptions = options;\n }\n if (!options) {\n this.destroyShadows();\n }\n else if (!this.shadows) {\n shadowElementOpacity = options.opacity / options.width;\n transform = this.parentInverted ?\n \"translate(\".concat(options.offsetY, \", \").concat(options.offsetX, \")\") :\n \"translate(\".concat(options.offsetX, \", \").concat(options.offsetY, \")\");\n for (i = 1; i <= options.width; i++) {\n shadow = element.cloneNode(false);\n strokeWidth = (options.width * 2) + 1 - (2 * i);\n attr(shadow, {\n stroke: (shadowOptions.color ||\n \"#000000\" /* Palette.neutralColor100 */),\n 'stroke-opacity': shadowElementOpacity * i,\n 'stroke-width': strokeWidth,\n transform: transform,\n fill: 'none'\n });\n shadow.setAttribute('class', (shadow.getAttribute('class') || '') + ' highcharts-shadow');\n if (cutOff) {\n attr(shadow, 'height', Math.max(attr(shadow, 'height') - strokeWidth, 0));\n shadow.cutHeight = strokeWidth;\n }\n if (group) {\n group.element.appendChild(shadow);\n }\n else if (element.parentNode) {\n element.parentNode.insertBefore(shadow, element);\n }\n shadows.push(shadow);\n }\n this.shadows = shadows;\n }\n return this;\n };\n /**\n * Show the element after it has been hidden.\n *\n * @function Highcharts.SVGElement#show\n *\n * @param {boolean} [inherit=true]\n * Set the visibility attribute to `inherit` rather than `visible`.\n * The difference is that an element with `visibility=\"visible\"`\n * will be visible even if the parent is hidden.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n SVGElement.prototype.show = function (inherit) {\n if (inherit === void 0) { inherit = true; }\n return this.attr({ visibility: inherit ? 'inherit' : 'visible' });\n };\n /**\n * WebKit and Batik have problems with a stroke-width of zero, so in this\n * case we remove the stroke attribute altogether. #1270, #1369, #3065,\n * #3072.\n *\n * @private\n * @function Highcharts.SVGElement#strokeSetter\n * @param {number|string|ColorType} value\n * @param {string} key\n * @param {Highcharts.SVGDOMElement} element\n */\n SVGElement.prototype.strokeSetter = function (value, key, element) {\n this[key] = value;\n // Only apply the stroke attribute if the stroke width is defined and\n // larger than 0\n if (this.stroke && this['stroke-width']) {\n // Use prototype as instance may be overridden\n SVGElement.prototype.fillSetter.call(this, this.stroke, 'stroke', element);\n element.setAttribute('stroke-width', this['stroke-width']);\n this.hasStroke = true;\n }\n else if (key === 'stroke-width' && value === 0 && this.hasStroke) {\n element.removeAttribute('stroke');\n this.hasStroke = false;\n }\n else if (this.renderer.styledMode && this['stroke-width']) {\n element.setAttribute('stroke-width', this['stroke-width']);\n this.hasStroke = true;\n }\n };\n /**\n * Get the computed stroke width in pixel values. This is used extensively\n * when drawing shapes to ensure the shapes are rendered crisp and\n * positioned correctly relative to each other. Using\n * `shape-rendering: crispEdges` leaves us less control over positioning,\n * for example when we want to stack columns next to each other, or position\n * things pixel-perfectly within the plot box.\n *\n * The common pattern when placing a shape is:\n * - Create the SVGElement and add it to the DOM. In styled mode, it will\n * now receive a stroke width from the style sheet. In classic mode we\n * will add the `stroke-width` attribute.\n * - Read the computed `elem.strokeWidth()`.\n * - Place it based on the stroke width.\n *\n * @function Highcharts.SVGElement#strokeWidth\n *\n * @return {number}\n * The stroke width in pixels. Even if the given stroke widtch (in CSS or by\n * attributes) is based on `em` or other units, the pixel size is returned.\n */\n SVGElement.prototype.strokeWidth = function () {\n // In non-styled mode, read the stroke width as set by .attr\n if (!this.renderer.styledMode) {\n return this['stroke-width'] || 0;\n }\n // In styled mode, read computed stroke width\n var val = this.getStyle('stroke-width');\n var ret = 0,\n dummy;\n // Read pixel values directly\n if (val.indexOf('px') === val.length - 2) {\n ret = pInt(val);\n // Other values like em, pt etc need to be measured\n }\n else if (val !== '') {\n dummy = doc.createElementNS(SVG_NS, 'rect');\n attr(dummy, {\n width: val,\n 'stroke-width': 0\n });\n this.element.parentNode.appendChild(dummy);\n ret = dummy.getBBox().width;\n dummy.parentNode.removeChild(dummy);\n }\n return ret;\n };\n /**\n * If one of the symbol size affecting parameters are changed,\n * check all the others only once for each call to an element's\n * .attr() method\n *\n * @private\n * @function Highcharts.SVGElement#symbolAttr\n *\n * @param {Highcharts.SVGAttributes} hash\n * The attributes to set.\n */\n SVGElement.prototype.symbolAttr = function (hash) {\n var wrapper = this;\n [\n 'x',\n 'y',\n 'r',\n 'start',\n 'end',\n 'width',\n 'height',\n 'innerR',\n 'anchorX',\n 'anchorY',\n 'clockwise'\n ].forEach(function (key) {\n wrapper[key] = pick(hash[key], wrapper[key]);\n });\n wrapper.attr({\n d: wrapper.renderer.symbols[wrapper.symbolName](wrapper.x, wrapper.y, wrapper.width, wrapper.height, wrapper)\n });\n };\n /**\n * @private\n * @function Highcharts.SVGElement#textSetter\n * @param {string} value\n */\n SVGElement.prototype.textSetter = function (value) {\n if (value !== this.textStr) {\n // Delete size caches when the text changes\n // delete this.bBox; // old code in series-label\n delete this.textPxLength;\n this.textStr = value;\n if (this.added) {\n this.renderer.buildText(this);\n }\n }\n };\n /**\n * @private\n * @function Highcharts.SVGElement#titleSetter\n * @param {string} value\n */\n SVGElement.prototype.titleSetter = function (value) {\n var el = this.element;\n var titleNode = el.getElementsByTagName('title')[0] ||\n doc.createElementNS(this.SVG_NS, 'title');\n // Move to first child\n if (el.insertBefore) {\n el.insertBefore(titleNode, el.firstChild);\n }\n else {\n el.appendChild(titleNode);\n }\n // Replace text content and escape markup\n titleNode.textContent =\n // #3276, #3895\n String(pick(value, ''))\n .replace(/<[^>]*>/g, '')\n .replace(/</g, '<')\n .replace(/>/g, '>');\n };\n /**\n * Bring the element to the front. Alternatively, a new zIndex can be set.\n *\n * @sample highcharts/members/element-tofront/\n * Click an element to bring it to front\n *\n * @function Highcharts.SVGElement#toFront\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n SVGElement.prototype.toFront = function () {\n var element = this.element;\n element.parentNode.appendChild(element);\n return this;\n };\n /**\n * Move an object and its children by x and y values.\n *\n * @function Highcharts.SVGElement#translate\n *\n * @param {number} x\n * The x value.\n *\n * @param {number} y\n * The y value.\n *\n * @return {Highcharts.SVGElement}\n * Translated element.\n */\n SVGElement.prototype.translate = function (x, y) {\n return this.attr({\n translateX: x,\n translateY: y\n });\n };\n /**\n * Update the shadow elements with new attributes.\n *\n * @private\n * @function Highcharts.SVGElement#updateShadows\n *\n * @param {string} key\n * The attribute name.\n *\n * @param {number} value\n * The value of the attribute.\n *\n * @param {Function} setter\n * The setter function, inherited from the parent wrapper.\n */\n SVGElement.prototype.updateShadows = function (key, value, setter) {\n var shadows = this.shadows;\n if (shadows) {\n var i = shadows.length;\n while (i--) {\n setter.call(shadows[i], key === 'height' ?\n Math.max(value - (shadows[i].cutHeight || 0), 0) :\n key === 'd' ? this.d : value, key, shadows[i]);\n }\n }\n };\n /**\n * Update the transform attribute based on internal properties. Deals with\n * the custom `translateX`, `translateY`, `rotation`, `scaleX` and `scaleY`\n * attributes and updates the SVG `transform` attribute.\n *\n * @private\n * @function Highcharts.SVGElement#updateTransform\n */\n SVGElement.prototype.updateTransform = function () {\n var wrapper = this,\n scaleX = wrapper.scaleX,\n scaleY = wrapper.scaleY,\n inverted = wrapper.inverted,\n rotation = wrapper.rotation,\n matrix = wrapper.matrix,\n element = wrapper.element;\n var translateX = wrapper.translateX || 0,\n translateY = wrapper.translateY || 0;\n // Flipping affects translate as adjustment for flipping around the\n // group's axis\n if (inverted) {\n translateX += wrapper.width;\n translateY += wrapper.height;\n }\n // Apply translate. Nearly all transformed elements have translation,\n // so instead of checking for translate = 0, do it always (#1767,\n // #1846).\n var transform = ['translate(' + translateX + ',' + translateY + ')'];\n // apply matrix\n if (defined(matrix)) {\n transform.push('matrix(' + matrix.join(',') + ')');\n }\n // apply rotation\n if (inverted) {\n transform.push('rotate(90) scale(-1,1)');\n }\n else if (rotation) { // text rotation\n transform.push('rotate(' + rotation + ' ' +\n pick(this.rotationOriginX, element.getAttribute('x'), 0) +\n ' ' +\n pick(this.rotationOriginY, element.getAttribute('y') || 0) + ')');\n }\n // apply scale\n if (defined(scaleX) || defined(scaleY)) {\n transform.push('scale(' + pick(scaleX, 1) + ' ' + pick(scaleY, 1) + ')');\n }\n if (transform.length && !(wrapper.text || wrapper).textPath) {\n element.setAttribute('transform', transform.join(' '));\n }\n };\n /**\n * @private\n * @function Highcharts.SVGElement#visibilitySetter\n *\n * @param {string} value\n *\n * @param {string} key\n *\n * @param {Highcharts.SVGDOMElement} element\n *\n */\n SVGElement.prototype.visibilitySetter = function (value, key, element) {\n // IE9-11 doesn't handle visibilty:inherit well, so we remove the\n // attribute instead (#2881, #3909)\n if (value === 'inherit') {\n element.removeAttribute(key);\n }\n else if (this[key] !== value) { // #6747\n element.setAttribute(key, value);\n }\n this[key] = value;\n };\n /**\n * @private\n * @function Highcharts.SVGElement#xGetter\n */\n SVGElement.prototype.xGetter = function (key) {\n if (this.element.nodeName === 'circle') {\n if (key === 'x') {\n key = 'cx';\n }\n else if (key === 'y') {\n key = 'cy';\n }\n }\n return this._defaultGetter(key);\n };\n /**\n * @private\n * @function Highcharts.SVGElement#zIndexSetter\n */\n SVGElement.prototype.zIndexSetter = function (value, key) {\n var renderer = this.renderer,\n parentGroup = this.parentGroup,\n parentWrapper = parentGroup || renderer,\n parentNode = parentWrapper.element || renderer.box,\n element = this.element,\n svgParent = parentNode === renderer.box;\n var childNodes,\n otherElement,\n otherZIndex,\n inserted = false,\n undefinedOtherZIndex,\n run = this.added,\n i;\n if (defined(value)) {\n // So we can read it for other elements in the group\n element.setAttribute('data-z-index', value);\n value = +value;\n if (this[key] === value) {\n // Only update when needed (#3865)\n run = false;\n }\n }\n else if (defined(this[key])) {\n element.removeAttribute('data-z-index');\n }\n this[key] = value;\n // Insert according to this and other elements' zIndex. Before .add() is\n // called, nothing is done. Then on add, or by later calls to\n // zIndexSetter, the node is placed on the right place in the DOM.\n if (run) {\n value = this.zIndex;\n if (value && parentGroup) {\n parentGroup.handleZ = true;\n }\n childNodes = parentNode.childNodes;\n for (i = childNodes.length - 1; i >= 0 && !inserted; i--) {\n otherElement = childNodes[i];\n otherZIndex = otherElement.getAttribute('data-z-index');\n undefinedOtherZIndex = !defined(otherZIndex);\n if (otherElement !== element) {\n if (\n // Negative zIndex versus no zIndex:\n // On all levels except the highest. If the parent is\n // , then we don't want to put items before \n // or \n value < 0 &&\n undefinedOtherZIndex &&\n !svgParent &&\n !i) {\n parentNode.insertBefore(element, childNodes[i]);\n inserted = true;\n }\n else if (\n // Insert after the first element with a lower zIndex\n pInt(otherZIndex) <= value ||\n // If negative zIndex, add this before first undefined\n // zIndex element\n (undefinedOtherZIndex &&\n (!defined(value) || value >= 0))) {\n parentNode.insertBefore(element, childNodes[i + 1] || null // null for oldIE export\n );\n inserted = true;\n }\n }\n }\n if (!inserted) {\n parentNode.insertBefore(element, childNodes[svgParent ? 3 : 0] || null // null for oldIE\n );\n inserted = true;\n }\n }\n return inserted;\n };\n return SVGElement;\n }());\n // Some shared setters and getters\n SVGElement.prototype['stroke-widthSetter'] = SVGElement.prototype.strokeSetter;\n SVGElement.prototype.yGetter = SVGElement.prototype.xGetter;\n SVGElement.prototype.matrixSetter =\n SVGElement.prototype.rotationOriginXSetter =\n SVGElement.prototype.rotationOriginYSetter =\n SVGElement.prototype.rotationSetter =\n SVGElement.prototype.scaleXSetter =\n SVGElement.prototype.scaleYSetter =\n SVGElement.prototype.translateXSetter =\n SVGElement.prototype.translateYSetter =\n SVGElement.prototype.verticalAlignSetter = function (value, key) {\n this[key] = value;\n this.doTransform = true;\n };\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Reference to the global SVGElement class as a workaround for a name conflict\n * in the Highcharts namespace.\n *\n * @global\n * @typedef {global.SVGElement} GlobalSVGElement\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/SVGElement\n */\n /**\n * The horizontal alignment of an element.\n *\n * @typedef {\"center\"|\"left\"|\"right\"} Highcharts.AlignValue\n */\n /**\n * Options to align the element relative to the chart or another box.\n *\n * @interface Highcharts.AlignObject\n */ /**\n * Horizontal alignment. Can be one of `left`, `center` and `right`.\n *\n * @name Highcharts.AlignObject#align\n * @type {Highcharts.AlignValue|undefined}\n *\n * @default left\n */ /**\n * Vertical alignment. Can be one of `top`, `middle` and `bottom`.\n *\n * @name Highcharts.AlignObject#verticalAlign\n * @type {Highcharts.VerticalAlignValue|undefined}\n *\n * @default top\n */ /**\n * Horizontal pixel offset from alignment.\n *\n * @name Highcharts.AlignObject#x\n * @type {number|undefined}\n *\n * @default 0\n */ /**\n * Vertical pixel offset from alignment.\n *\n * @name Highcharts.AlignObject#y\n * @type {number|undefined}\n *\n * @default 0\n */ /**\n * Use the `transform` attribute with translateX and translateY custom\n * attributes to align this elements rather than `x` and `y` attributes.\n *\n * @name Highcharts.AlignObject#alignByTranslate\n * @type {boolean|undefined}\n *\n * @default false\n */\n /**\n * Bounding box of an element.\n *\n * @interface Highcharts.BBoxObject\n * @extends Highcharts.PositionObject\n */ /**\n * Height of the bounding box.\n *\n * @name Highcharts.BBoxObject#height\n * @type {number}\n */ /**\n * Width of the bounding box.\n *\n * @name Highcharts.BBoxObject#width\n * @type {number}\n */ /**\n * Horizontal position of the bounding box.\n *\n * @name Highcharts.BBoxObject#x\n * @type {number}\n */ /**\n * Vertical position of the bounding box.\n *\n * @name Highcharts.BBoxObject#y\n * @type {number}\n */\n /**\n * An object of key-value pairs for SVG attributes. Attributes in Highcharts\n * elements for the most parts correspond to SVG, but some are specific to\n * Highcharts, like `zIndex`, `rotation`, `rotationOriginX`,\n * `rotationOriginY`, `translateX`, `translateY`, `scaleX` and `scaleY`. SVG\n * attributes containing a hyphen are _not_ camel-cased, they should be\n * quoted to preserve the hyphen.\n *\n * @example\n * {\n * 'stroke': '#ff0000', // basic\n * 'stroke-width': 2, // hyphenated\n * 'rotation': 45 // custom\n * 'd': ['M', 10, 10, 'L', 30, 30, 'z'] // path definition, note format\n * }\n *\n * @interface Highcharts.SVGAttributes\n */ /**\n * @name Highcharts.SVGAttributes#[key:string]\n * @type {*}\n */ /**\n * @name Highcharts.SVGAttributes#d\n * @type {string|Highcharts.SVGPathArray|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#dx\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#dy\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#fill\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#inverted\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#matrix\n * @type {Array|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#rotation\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#rotationOriginX\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#rotationOriginY\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#scaleX\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#scaleY\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#stroke\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#style\n * @type {string|Highcharts.CSSObject|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#translateX\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#translateY\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#zIndex\n * @type {number|undefined}\n */\n /**\n * An SVG DOM element. The type is a reference to the regular SVGElement in the\n * global scope.\n *\n * @typedef {globals.GlobalSVGElement} Highcharts.SVGDOMElement\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/SVGElement\n */\n /**\n * The vertical alignment of an element.\n *\n * @typedef {\"bottom\"|\"middle\"|\"top\"} Highcharts.VerticalAlignValue\n */\n ''; // keeps doclets above in JS file\n\n return SVGElement;\n });\n _registerModule(_modules, 'Core/Renderer/RendererRegistry.js', [_modules['Core/Globals.js']], function (H) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Namespace\n *\n * */\n var RendererRegistry;\n (function (RendererRegistry) {\n /* *\n *\n * Constants\n *\n * */\n RendererRegistry.rendererTypes = {};\n /* *\n *\n * Variables\n *\n * */\n var defaultRenderer;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Gets a registered renderer class. If no renderer type is provided or the\n * requested renderer was not founded, the default renderer is returned.\n *\n * @param {string} [rendererType]\n * Renderer type or the default renderer.\n *\n * @return {Highcharts.Class}\n * Returns the requested renderer class or the default renderer class.\n */\n function getRendererType(rendererType) {\n if (rendererType === void 0) { rendererType = defaultRenderer; }\n return (RendererRegistry.rendererTypes[rendererType] || RendererRegistry.rendererTypes[defaultRenderer]);\n }\n RendererRegistry.getRendererType = getRendererType;\n /**\n * Register a renderer class.\n *\n * @param {string} rendererType\n * Renderer type to register.\n *\n * @param {Highcharts.Class} rendererClass\n * Returns the requested renderer class or the default renderer class.\n *\n * @param {boolean} setAsDefault\n * Sets the renderer class as the default renderer.\n */\n function registerRendererType(rendererType, rendererClass, setAsDefault) {\n RendererRegistry.rendererTypes[rendererType] = rendererClass;\n if (!defaultRenderer || setAsDefault) {\n defaultRenderer = rendererType;\n H.Renderer = rendererClass; // compatibility\n }\n }\n RendererRegistry.registerRendererType = registerRendererType;\n })(RendererRegistry || (RendererRegistry = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return RendererRegistry;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/SVGLabel.js', [_modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var defined = U.defined,\n extend = U.extend,\n isNumber = U.isNumber,\n merge = U.merge,\n pick = U.pick,\n removeEvent = U.removeEvent;\n /* *\n *\n * Class\n *\n * */\n /**\n * SVG label to render text.\n * @private\n * @class\n * @name Highcharts.SVGLabel\n * @augments Highcharts.SVGElement\n */\n var SVGLabel = /** @class */ (function (_super) {\n __extends(SVGLabel, _super);\n /* *\n *\n * Constructor\n *\n * */\n function SVGLabel(renderer, str, x, y, shape, anchorX, anchorY, useHTML, baseline, className) {\n var _this = _super.call(this) || this;\n _this.paddingLeftSetter = _this.paddingSetter;\n _this.paddingRightSetter = _this.paddingSetter;\n _this.init(renderer, 'g');\n _this.textStr = str;\n _this.x = x;\n _this.y = y;\n _this.anchorX = anchorX;\n _this.anchorY = anchorY;\n _this.baseline = baseline;\n _this.className = className;\n _this.addClass(className === 'button' ?\n 'highcharts-no-tooltip' :\n 'highcharts-label');\n if (className) {\n _this.addClass('highcharts-' + className);\n }\n // Create the text element. An undefined text content prevents redundant\n // box calculation (#16121)\n _this.text = renderer.text(void 0, 0, 0, useHTML).attr({ zIndex: 1 });\n // Validate the shape argument\n var hasBGImage;\n if (typeof shape === 'string') {\n hasBGImage = /^url\\((.*?)\\)$/.test(shape);\n if (hasBGImage || _this.renderer.symbols[shape]) {\n _this.symbolKey = shape;\n }\n }\n _this.bBox = SVGLabel.emptyBBox;\n _this.padding = 3;\n _this.baselineOffset = 0;\n _this.needsBox = renderer.styledMode || hasBGImage;\n _this.deferredAttr = {};\n _this.alignFactor = 0;\n return _this;\n }\n /* *\n *\n * Functions\n *\n * */\n SVGLabel.prototype.alignSetter = function (value) {\n var alignFactor = ({\n left: 0,\n center: 0.5,\n right: 1\n })[value];\n if (alignFactor !== this.alignFactor) {\n this.alignFactor = alignFactor;\n // Bounding box exists, means we're dynamically changing\n if (this.bBox && isNumber(this.xSetting)) {\n this.attr({ x: this.xSetting }); // #5134\n }\n }\n };\n SVGLabel.prototype.anchorXSetter = function (value, key) {\n this.anchorX = value;\n this.boxAttr(key, Math.round(value) - this.getCrispAdjust() - this.xSetting);\n };\n SVGLabel.prototype.anchorYSetter = function (value, key) {\n this.anchorY = value;\n this.boxAttr(key, value - this.ySetting);\n };\n /*\n * Set a box attribute, or defer it if the box is not yet created\n */\n SVGLabel.prototype.boxAttr = function (key, value) {\n if (this.box) {\n this.box.attr(key, value);\n }\n else {\n this.deferredAttr[key] = value;\n }\n };\n /*\n * Pick up some properties and apply them to the text instead of the\n * wrapper.\n */\n SVGLabel.prototype.css = function (styles) {\n if (styles) {\n var textStyles_1 = {};\n // Create a copy to avoid altering the original object\n // (#537)\n styles = merge(styles);\n SVGLabel.textProps.forEach(function (prop) {\n if (typeof styles[prop] !== 'undefined') {\n textStyles_1[prop] = styles[prop];\n delete styles[prop];\n }\n });\n this.text.css(textStyles_1);\n var isWidth = 'width' in textStyles_1, isFontStyle = ('fontSize' in textStyles_1 ||\n 'fontWeight' in textStyles_1);\n // Update existing text, box (#9400, #12163)\n if (isFontStyle) {\n this.updateTextPadding();\n }\n else if (isWidth) {\n this.updateBoxSize();\n }\n }\n return SVGElement.prototype.css.call(this, styles);\n };\n /*\n * Destroy and release memory.\n */\n SVGLabel.prototype.destroy = function () {\n // Added by button implementation\n removeEvent(this.element, 'mouseenter');\n removeEvent(this.element, 'mouseleave');\n if (this.text) {\n this.text.destroy();\n }\n if (this.box) {\n this.box = this.box.destroy();\n }\n // Call base implementation to destroy the rest\n SVGElement.prototype.destroy.call(this);\n return void 0;\n };\n SVGLabel.prototype.fillSetter = function (value, key) {\n if (value) {\n this.needsBox = true;\n }\n // for animation getter (#6776)\n this.fill = value;\n this.boxAttr(key, value);\n };\n /*\n * Return the bounding box of the box, not the group.\n */\n SVGLabel.prototype.getBBox = function () {\n // If we have a text string and the DOM bBox was 0, it typically means\n // that the label was first rendered hidden, so we need to update the\n // bBox (#15246)\n if (this.textStr && this.bBox.width === 0 && this.bBox.height === 0) {\n this.updateBoxSize();\n }\n var padding = this.padding;\n var paddingLeft = pick(this.paddingLeft,\n padding);\n return {\n width: this.width,\n height: this.height,\n x: this.bBox.x - paddingLeft,\n y: this.bBox.y - padding\n };\n };\n SVGLabel.prototype.getCrispAdjust = function () {\n return this.renderer.styledMode && this.box ?\n this.box.strokeWidth() % 2 / 2 :\n (this['stroke-width'] ? parseInt(this['stroke-width'], 10) : 0) % 2 / 2;\n };\n SVGLabel.prototype.heightSetter = function (value) {\n this.heightSetting = value;\n };\n /*\n * After the text element is added, get the desired size of the border\n * box and add it before the text in the DOM.\n */\n SVGLabel.prototype.onAdd = function () {\n var str = this.textStr;\n this.text.add(this);\n this.attr({\n // Alignment is available now (#3295, 0 not rendered if given\n // as a value)\n text: (defined(str) ? str : ''),\n x: this.x,\n y: this.y\n });\n if (this.box && defined(this.anchorX)) {\n this.attr({\n anchorX: this.anchorX,\n anchorY: this.anchorY\n });\n }\n };\n SVGLabel.prototype.paddingSetter = function (value, key) {\n if (!isNumber(value)) {\n this[key] = void 0;\n }\n else if (value !== this[key]) {\n this[key] = value;\n this.updateTextPadding();\n }\n };\n SVGLabel.prototype.rSetter = function (value, key) {\n this.boxAttr(key, value);\n };\n SVGLabel.prototype.shadow = function (b) {\n if (b && !this.renderer.styledMode) {\n this.updateBoxSize();\n if (this.box) {\n this.box.shadow(b);\n }\n }\n return this;\n };\n SVGLabel.prototype.strokeSetter = function (value, key) {\n // for animation getter (#6776)\n this.stroke = value;\n this.boxAttr(key, value);\n };\n SVGLabel.prototype['stroke-widthSetter'] = function (value, key) {\n if (value) {\n this.needsBox = true;\n }\n this['stroke-width'] = value;\n this.boxAttr(key, value);\n };\n SVGLabel.prototype['text-alignSetter'] = function (value) {\n this.textAlign = value;\n };\n SVGLabel.prototype.textSetter = function (text) {\n if (typeof text !== 'undefined') {\n // Must use .attr to ensure transforms are done (#10009)\n this.text.attr({ text: text });\n }\n this.updateTextPadding();\n };\n /*\n * This function runs after the label is added to the DOM (when the bounding\n * box is available), and after the text of the label is updated to detect\n * the new bounding box and reflect it in the border box.\n */\n SVGLabel.prototype.updateBoxSize = function () {\n var text = this.text,\n style = text.element.style,\n attribs = {},\n padding = this.padding, \n // #12165 error when width is null (auto)\n // #12163 when fontweight: bold, recalculate bBox withot cache\n // #3295 && 3514 box failure when string equals 0\n bBox = this.bBox = (((!isNumber(this.widthSetting) ||\n !isNumber(this.heightSetting) ||\n this.textAlign) && defined(text.textStr)) ?\n text.getBBox() :\n SVGLabel.emptyBBox);\n var crispAdjust;\n this.width = this.getPaddedWidth();\n this.height = (this.heightSetting || bBox.height || 0) + 2 * padding;\n var metrics = this.renderer.fontMetrics(style && style.fontSize,\n text);\n // Update the label-scoped y offset. Math.min because of inline\n // style (#9400)\n this.baselineOffset = padding + Math.min(\n // When applicable, use the font size of the first line (#15707)\n (this.text.firstLineMetrics || metrics).b, \n // When the height is 0, there is no bBox, so go with the font\n // metrics. Highmaps CSS demos.\n bBox.height || Infinity);\n // #15491: Vertical centering\n if (this.heightSetting) {\n this.baselineOffset += (this.heightSetting - metrics.h) / 2;\n }\n if (this.needsBox && !text.textPath) {\n // Create the border box if it is not already present\n if (!this.box) {\n // Symbol definition exists (#5324)\n var box = this.box = this.symbolKey ?\n this.renderer.symbol(this.symbolKey) :\n this.renderer.rect();\n box.addClass(// Don't use label className for buttons\n (this.className === 'button' ?\n '' : 'highcharts-label-box') +\n (this.className ?\n ' highcharts-' + this.className + '-box' : ''));\n box.add(this);\n }\n crispAdjust = this.getCrispAdjust();\n attribs.x = crispAdjust;\n attribs.y = ((this.baseline ? -this.baselineOffset : 0) + crispAdjust);\n // Apply the box attributes\n attribs.width = Math.round(this.width);\n attribs.height = Math.round(this.height);\n this.box.attr(extend(attribs, this.deferredAttr));\n this.deferredAttr = {};\n }\n };\n /*\n * This function runs after setting text or padding, but only if padding\n * is changed.\n */\n SVGLabel.prototype.updateTextPadding = function () {\n var text = this.text;\n if (!text.textPath) {\n this.updateBoxSize();\n // Determine y based on the baseline\n var textY = this.baseline ? 0 : this.baselineOffset;\n var textX = pick(this.paddingLeft,\n this.padding);\n // compensate for alignment\n if (defined(this.widthSetting) &&\n this.bBox &&\n (this.textAlign === 'center' || this.textAlign === 'right')) {\n textX += { center: 0.5, right: 1 }[this.textAlign] * (this.widthSetting - this.bBox.width);\n }\n // update if anything changed\n if (textX !== text.x || textY !== text.y) {\n text.attr('x', textX);\n // #8159 - prevent misplaced data labels in treemap\n // (useHTML: true)\n if (text.hasBoxWidthChanged) {\n this.bBox = text.getBBox(true);\n }\n if (typeof textY !== 'undefined') {\n text.attr('y', textY);\n }\n }\n // record current values\n text.x = textX;\n text.y = textY;\n }\n };\n SVGLabel.prototype.widthSetter = function (value) {\n // width:auto => null\n this.widthSetting = isNumber(value) ? value : void 0;\n };\n SVGLabel.prototype.getPaddedWidth = function () {\n var padding = this.padding;\n var paddingLeft = pick(this.paddingLeft,\n padding);\n var paddingRight = pick(this.paddingRight,\n padding);\n return ((this.widthSetting || this.bBox.width || 0) +\n paddingLeft +\n paddingRight);\n };\n SVGLabel.prototype.xSetter = function (value) {\n this.x = value; // for animation getter\n if (this.alignFactor) {\n value -= this.alignFactor * this.getPaddedWidth();\n // Force animation even when setting to the same value (#7898)\n this['forceAnimate:x'] = true;\n }\n this.xSetting = Math.round(value);\n this.attr('translateX', this.xSetting);\n };\n SVGLabel.prototype.ySetter = function (value) {\n this.ySetting = this.y = Math.round(value);\n this.attr('translateY', this.ySetting);\n };\n /* *\n *\n * Static Properties\n *\n * */\n SVGLabel.emptyBBox = {\n width: 0,\n height: 0,\n x: 0,\n y: 0\n };\n /**\n * For labels, these CSS properties are applied to the `text` node directly.\n *\n * @private\n * @name Highcharts.SVGLabel#textProps\n * @type {Array}\n */\n SVGLabel.textProps = [\n 'color', 'direction', 'fontFamily', 'fontSize', 'fontStyle',\n 'fontWeight', 'lineHeight', 'textAlign', 'textDecoration',\n 'textOutline', 'textOverflow', 'width'\n ];\n return SVGLabel;\n }(SVGElement));\n /* *\n *\n * Default Export\n *\n * */\n\n return SVGLabel;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/Symbols.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var defined = U.defined,\n isNumber = U.isNumber,\n pick = U.pick;\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable require-jsdoc, valid-jsdoc */\n function arc(x, y, w, h, options) {\n var arc = [];\n if (options) {\n var start = options.start || 0,\n rx = pick(options.r,\n w),\n ry = pick(options.r,\n h || w),\n proximity = 0.001,\n fullCircle = (Math.abs((options.end || 0) - start - 2 * Math.PI) <\n proximity), \n // Substract a small number to prevent cos and sin of start\n // and end from becoming equal on 360 arcs (related: #1561)\n end = (options.end || 0) - proximity,\n innerRadius = options.innerR,\n open_1 = pick(options.open,\n fullCircle),\n cosStart = Math.cos(start),\n sinStart = Math.sin(start),\n cosEnd = Math.cos(end),\n sinEnd = Math.sin(end), \n // Proximity takes care of rounding errors around PI (#6971)\n longArc = pick(options.longArc,\n end - start - Math.PI < proximity ? 0 : 1);\n arc.push([\n 'M',\n x + rx * cosStart,\n y + ry * sinStart\n ], [\n 'A',\n rx,\n ry,\n 0,\n longArc,\n pick(options.clockwise, 1),\n x + rx * cosEnd,\n y + ry * sinEnd\n ]);\n if (defined(innerRadius)) {\n arc.push(open_1 ?\n [\n 'M',\n x + innerRadius * cosEnd,\n y + innerRadius * sinEnd\n ] : [\n 'L',\n x + innerRadius * cosEnd,\n y + innerRadius * sinEnd\n ], [\n 'A',\n innerRadius,\n innerRadius,\n 0,\n longArc,\n // Clockwise - opposite to the outer arc clockwise\n defined(options.clockwise) ? 1 - options.clockwise : 0,\n x + innerRadius * cosStart,\n y + innerRadius * sinStart\n ]);\n }\n if (!open_1) {\n arc.push(['Z']);\n }\n }\n return arc;\n }\n /**\n * Callout shape used for default tooltips, also used for rounded\n * rectangles in VML\n */\n function callout(x, y, w, h, options) {\n var arrowLength = 6,\n halfDistance = 6,\n r = Math.min((options && options.r) || 0,\n w,\n h),\n safeDistance = r + halfDistance,\n anchorX = options && options.anchorX,\n anchorY = options && options.anchorY || 0;\n var path = roundedRect(x,\n y,\n w,\n h, { r: r });\n if (!isNumber(anchorX)) {\n return path;\n }\n // Anchor on right side\n if (x + anchorX >= w) {\n // Chevron\n if (anchorY > y + safeDistance &&\n anchorY < y + h - safeDistance) {\n path.splice(3, 1, ['L', x + w, anchorY - halfDistance], ['L', x + w + arrowLength, anchorY], ['L', x + w, anchorY + halfDistance], ['L', x + w, y + h - r]);\n // Simple connector\n }\n else {\n path.splice(3, 1, ['L', x + w, h / 2], ['L', anchorX, anchorY], ['L', x + w, h / 2], ['L', x + w, y + h - r]);\n }\n // Anchor on left side\n }\n else if (x + anchorX <= 0) {\n // Chevron\n if (anchorY > y + safeDistance &&\n anchorY < y + h - safeDistance) {\n path.splice(7, 1, ['L', x, anchorY + halfDistance], ['L', x - arrowLength, anchorY], ['L', x, anchorY - halfDistance], ['L', x, y + r]);\n // Simple connector\n }\n else {\n path.splice(7, 1, ['L', x, h / 2], ['L', anchorX, anchorY], ['L', x, h / 2], ['L', x, y + r]);\n }\n }\n else if ( // replace bottom\n anchorY &&\n anchorY > h &&\n anchorX > x + safeDistance &&\n anchorX < x + w - safeDistance) {\n path.splice(5, 1, ['L', anchorX + halfDistance, y + h], ['L', anchorX, y + h + arrowLength], ['L', anchorX - halfDistance, y + h], ['L', x + r, y + h]);\n }\n else if ( // replace top\n anchorY &&\n anchorY < 0 &&\n anchorX > x + safeDistance &&\n anchorX < x + w - safeDistance) {\n path.splice(1, 1, ['L', anchorX - halfDistance, y], ['L', anchorX, y - arrowLength], ['L', anchorX + halfDistance, y], ['L', w - r, y]);\n }\n return path;\n }\n function circle(x, y, w, h) {\n // Return a full arc\n return arc(x + w / 2, y + h / 2, w / 2, h / 2, {\n start: Math.PI * 0.5,\n end: Math.PI * 2.5,\n open: false\n });\n }\n function diamond(x, y, w, h) {\n return [\n ['M', x + w / 2, y],\n ['L', x + w, y + h / 2],\n ['L', x + w / 2, y + h],\n ['L', x, y + h / 2],\n ['Z']\n ];\n }\n // #15291\n function rect(x, y, w, h, options) {\n if (options && options.r) {\n return roundedRect(x, y, w, h, options);\n }\n return [\n ['M', x, y],\n ['L', x + w, y],\n ['L', x + w, y + h],\n ['L', x, y + h],\n ['Z']\n ];\n }\n function roundedRect(x, y, w, h, options) {\n var r = (options && options.r) || 0;\n return [\n ['M', x + r, y],\n ['L', x + w - r, y],\n ['C', x + w, y, x + w, y, x + w, y + r],\n ['L', x + w, y + h - r],\n ['C', x + w, y + h, x + w, y + h, x + w - r, y + h],\n ['L', x + r, y + h],\n ['C', x, y + h, x, y + h, x, y + h - r],\n ['L', x, y + r],\n ['C', x, y, x, y, x + r, y] // top-left corner\n ];\n }\n function triangle(x, y, w, h) {\n return [\n ['M', x + w / 2, y],\n ['L', x + w, y + h],\n ['L', x, y + h],\n ['Z']\n ];\n }\n function triangleDown(x, y, w, h) {\n return [\n ['M', x, y],\n ['L', x + w, y],\n ['L', x + w / 2, y + h],\n ['Z']\n ];\n }\n var Symbols = {\n arc: arc,\n callout: callout,\n circle: circle,\n diamond: diamond,\n rect: rect,\n roundedRect: roundedRect,\n square: rect,\n triangle: triangle,\n 'triangle-down': triangleDown\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return Symbols;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/TextBuilder.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (AST, H, U) {\n /* *\n *\n * (c) 2010-2020 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var doc = H.doc,\n SVG_NS = H.SVG_NS,\n win = H.win;\n var attr = U.attr,\n extend = U.extend,\n fireEvent = U.fireEvent,\n isString = U.isString,\n objectEach = U.objectEach,\n pick = U.pick;\n /* *\n *\n * Class\n *\n * */\n /**\n * SVG Text Builder\n * @private\n * @class\n * @name Highcharts.TextBuilder\n */\n var TextBuilder = /** @class */ (function () {\n function TextBuilder(svgElement) {\n var textStyles = svgElement.styles;\n this.renderer = svgElement.renderer;\n this.svgElement = svgElement;\n this.width = svgElement.textWidth;\n this.textLineHeight = textStyles && textStyles.lineHeight;\n this.textOutline = textStyles && textStyles.textOutline;\n this.ellipsis = Boolean(textStyles && textStyles.textOverflow === 'ellipsis');\n this.noWrap = Boolean(textStyles && textStyles.whiteSpace === 'nowrap');\n this.fontSize = textStyles && textStyles.fontSize;\n }\n /**\n * Build an SVG representation of the pseudo HTML given in the object's\n * svgElement.\n *\n * @private\n *\n * @return {void}.\n */\n TextBuilder.prototype.buildSVG = function () {\n var wrapper = this.svgElement, textNode = wrapper.element, renderer = wrapper.renderer, textStr = pick(wrapper.textStr, '').toString(), hasMarkup = textStr.indexOf('<') !== -1, childNodes = textNode.childNodes, tempParent = this.width && !wrapper.added && renderer.box, regexMatchBreaks = //g, \n // The buildText code is quite heavy, so if we're not changing\n // something that affects the text, skip it (#6113).\n textCache = [\n textStr,\n this.ellipsis,\n this.noWrap,\n this.textLineHeight,\n this.textOutline,\n this.fontSize,\n this.width\n ].join(',');\n if (textCache === wrapper.textCache) {\n return;\n }\n wrapper.textCache = textCache;\n delete wrapper.actualWidth;\n // Remove old text\n for (var i = childNodes.length; i--;) {\n textNode.removeChild(childNodes[i]);\n }\n // Simple strings, add text directly and return\n if (!hasMarkup &&\n !this.ellipsis &&\n !this.width &&\n !wrapper.textPath &&\n (textStr.indexOf(' ') === -1 ||\n (this.noWrap && !regexMatchBreaks.test(textStr)))) {\n textNode.appendChild(doc.createTextNode(this.unescapeEntities(textStr)));\n // Complex strings, add more logic\n }\n else if (textStr !== '') {\n if (tempParent) {\n // attach it to the DOM to read offset width\n tempParent.appendChild(textNode);\n }\n // Step 1. Parse the markup safely and directly into a tree\n // structure.\n var ast = new AST(textStr);\n // Step 2. Do as many as we can of the modifications to the tree\n // structure before it is added to the DOM\n this.modifyTree(ast.nodes);\n ast.addToDOM(textNode);\n // Step 3. Some modifications can't be done until the structure is\n // in the DOM, because we need to read computed metrics.\n this.modifyDOM();\n // Add title if an ellipsis was added\n if (this.ellipsis &&\n (textNode.textContent || '').indexOf('\\u2026') !== -1) {\n wrapper.attr('title', this.unescapeEntities(wrapper.textStr || '', ['<', '>']) // #7179\n );\n }\n if (tempParent) {\n tempParent.removeChild(textNode);\n }\n }\n // Apply the text outline\n if (isString(this.textOutline) && wrapper.applyTextOutline) {\n wrapper.applyTextOutline(this.textOutline);\n }\n };\n /**\n * Modify the DOM of the generated SVG structure. This function only does\n * operations that cannot be done until the elements are attached to the\n * DOM, like doing layout based on rendered metrics of the added elements.\n *\n * @private\n *\n */\n TextBuilder.prototype.modifyDOM = function () {\n var _this = this;\n var wrapper = this.svgElement;\n var x = attr(wrapper.element, 'x');\n wrapper.firstLineMetrics = void 0;\n // Remove empty tspans (including breaks) from the beginning because\n // SVG's getBBox doesn't count empty lines. The use case is tooltip\n // where the header is empty. By doing this in the DOM rather than in\n // the AST, we can inspect the textContent directly and don't have to\n // recurse down to look for valid content.\n var firstChild;\n while ((firstChild = wrapper.element.firstChild)) {\n if (/^[\\s\\u200B]*$/.test(firstChild.textContent || ' ')) {\n wrapper.element.removeChild(firstChild);\n }\n else {\n break;\n }\n }\n // Modify hard line breaks by applying the rendered line height\n [].forEach.call(wrapper.element.querySelectorAll('tspan.highcharts-br'), function (br, i) {\n if (br.nextSibling && br.previousSibling) { // #5261\n if (i === 0 && br.previousSibling.nodeType === 1) {\n wrapper.firstLineMetrics = wrapper.renderer\n .fontMetrics(void 0, br.previousSibling);\n }\n attr(br, {\n // Since the break is inserted in front of the next\n // line, we need to use the next sibling for the line\n // height\n dy: _this.getLineHeight(br.nextSibling),\n x: x\n });\n }\n });\n // Constrain the line width, either by ellipsis or wrapping\n var width = this.width || 0;\n if (!width) {\n return;\n }\n // Insert soft line breaks into each text node\n var modifyTextNode = function (textNode,\n parentElement) {\n var text = textNode.textContent || '';\n var words = text\n .replace(/([^\\^])-/g, '$1- ') // Split on hyphens\n // .trim()\n .split(' '); // #1273\n var hasWhiteSpace = !_this.noWrap && (words.length > 1 || wrapper.element.childNodes.length > 1);\n var dy = _this.getLineHeight(parentElement);\n var lineNo = 0;\n var startAt = wrapper.actualWidth;\n if (_this.ellipsis) {\n if (text) {\n _this.truncate(textNode, text, void 0, 0, \n // Target width\n Math.max(0, \n // Substract the font face to make room for the\n // ellipsis itself\n width - parseInt(_this.fontSize || 12, 10)), \n // Build the text to test for\n function (text, currentIndex) {\n return text.substring(0, currentIndex) + '\\u2026';\n });\n }\n }\n else if (hasWhiteSpace) {\n var lines = [];\n // Remove preceding siblings in order to make the text length\n // calculation correct in the truncate function\n var precedingSiblings = [];\n while (parentElement.firstChild &&\n parentElement.firstChild !== textNode) {\n precedingSiblings.push(parentElement.firstChild);\n parentElement.removeChild(parentElement.firstChild);\n }\n while (words.length) {\n // Apply the previous line\n if (words.length && !_this.noWrap && lineNo > 0) {\n lines.push(textNode.textContent || '');\n textNode.textContent = words.join(' ')\n .replace(/- /g, '-');\n }\n // For each line, truncate the remaining\n // words into the line length.\n _this.truncate(textNode, void 0, words, lineNo === 0 ? (startAt || 0) : 0, width, \n // Build the text to test for\n function (t, currentIndex) {\n return words\n .slice(0, currentIndex)\n .join(' ')\n .replace(/- /g, '-');\n });\n startAt = wrapper.actualWidth;\n lineNo++;\n }\n // Reinsert the preceding child nodes\n precedingSiblings.forEach(function (childNode) {\n parentElement.insertBefore(childNode, textNode);\n });\n // Insert the previous lines before the original text node\n lines.forEach(function (line) {\n // Insert the line\n parentElement.insertBefore(doc.createTextNode(line), textNode);\n // Insert a break\n var br = doc.createElementNS(SVG_NS, 'tspan');\n br.textContent = '\\u200B'; // zero-width space\n attr(br, { dy: dy, x: x });\n parentElement.insertBefore(br, textNode);\n });\n }\n };\n // Recurse down the DOM tree and handle line breaks for each text node\n var modifyChildren = (function (node) {\n var childNodes = [].slice.call(node.childNodes);\n childNodes.forEach(function (childNode) {\n if (childNode.nodeType === win.Node.TEXT_NODE) {\n modifyTextNode(childNode, node);\n }\n else {\n // Reset word-wrap width readings after hard breaks\n if (childNode.className.baseVal\n .indexOf('highcharts-br') !== -1) {\n wrapper.actualWidth = 0;\n }\n // Recurse down to child node\n modifyChildren(childNode);\n }\n });\n });\n modifyChildren(wrapper.element);\n };\n /**\n * Get the rendered line height of a , or pure text node.\n *\n * @param {DOMElementType|Text} node The node to check for\n *\n * @return {number} The rendered line height\n */\n TextBuilder.prototype.getLineHeight = function (node) {\n var fontSizeStyle;\n // If the node is a text node, use its parent\n var element = (node.nodeType === win.Node.TEXT_NODE) ?\n node.parentElement :\n node;\n if (!this.renderer.styledMode) {\n fontSizeStyle =\n element && /(px|em)$/.test(element.style.fontSize) ?\n element.style.fontSize :\n (this.fontSize || this.renderer.style.fontSize || 12);\n }\n return this.textLineHeight ?\n parseInt(this.textLineHeight.toString(), 10) :\n this.renderer.fontMetrics(fontSizeStyle, element || this.svgElement.element).h;\n };\n /**\n * Transform a pseudo HTML AST node tree into an SVG structure. We do as\n * much heavy lifting as we can here, before doing the final processing in\n * the modifyDOM function. The original data is mutated.\n *\n * @private\n *\n * @param {ASTNode[]} nodes The AST nodes\n *\n */\n TextBuilder.prototype.modifyTree = function (nodes) {\n var _this = this;\n var modifyChild = function (node,\n i) {\n var _a = node.attributes,\n attributes = _a === void 0 ? {} : _a,\n children = node.children,\n _b = node.style,\n style = _b === void 0 ? {} : _b,\n tagName = node.tagName,\n styledMode = _this.renderer.styledMode;\n // Apply styling to text tags\n if (tagName === 'b' || tagName === 'strong') {\n if (styledMode) {\n // eslint-disable-next-line dot-notation\n attributes['class'] = 'highcharts-strong';\n }\n else {\n style.fontWeight = 'bold';\n }\n }\n else if (tagName === 'i' || tagName === 'em') {\n if (styledMode) {\n // eslint-disable-next-line dot-notation\n attributes['class'] = 'highcharts-emphasized';\n }\n else {\n style.fontStyle = 'italic';\n }\n }\n // Modify styling\n if (style && style.color) {\n style.fill = style.color;\n }\n // Handle breaks\n if (tagName === 'br') {\n attributes['class'] = 'highcharts-br'; // eslint-disable-line dot-notation\n node.textContent = '\\u200B'; // zero-width space\n // Trim whitespace off the beginning of new lines\n var nextNode = nodes[i + 1];\n if (nextNode && nextNode.textContent) {\n nextNode.textContent =\n nextNode.textContent.replace(/^ +/gm, '');\n }\n // If an anchor has direct text node children, the text is unable to\n // wrap because there is no `getSubStringLength` function on the\n // element. Therefore we need to wrap the child text node or nodes\n // in a tspan. #16173.\n }\n else if (tagName === 'a' &&\n children &&\n children.some(function (child) { return child.tagName === '#text'; })) {\n node.children = [{ children: children, tagName: 'tspan' }];\n }\n if (tagName !== '#text' && tagName !== 'a') {\n node.tagName = 'tspan';\n }\n extend(node, { attributes: attributes, style: style });\n // Recurse\n if (children) {\n children\n .filter(function (c) { return c.tagName !== '#text'; })\n .forEach(modifyChild);\n }\n };\n nodes.forEach(modifyChild);\n fireEvent(this.svgElement, 'afterModifyTree', { nodes: nodes });\n };\n /*\n * Truncate the text node contents to a given length. Used when the css\n * width is set. If the `textOverflow` is `ellipsis`, the text is truncated\n * character by character to the given length. If not, the text is\n * word-wrapped line by line.\n */\n TextBuilder.prototype.truncate = function (textNode, text, words, startAt, width, getString) {\n var svgElement = this.svgElement;\n var renderer = svgElement.renderer,\n rotation = svgElement.rotation;\n // Cache the lengths to avoid checking the same twice\n var lengths = [];\n // Word wrap cannot be truncated to shorter than one word, ellipsis\n // text can be completely blank.\n var minIndex = words ? 1 : 0;\n var maxIndex = (text || words || '').length;\n var currentIndex = maxIndex;\n var str;\n var actualWidth;\n var getSubStringLength = function (charEnd,\n concatenatedEnd) {\n // charEnd is used when finding the character-by-character\n // break for ellipsis, concatenatedEnd is used for word-by-word\n // break for word wrapping.\n var end = concatenatedEnd || charEnd;\n var parentNode = textNode.parentNode;\n if (parentNode && typeof lengths[end] === 'undefined') {\n // Modern browsers\n if (parentNode.getSubStringLength) {\n // Fails with DOM exception on unit-tests/legend/members\n // of unknown reason. Desired width is 0, text content\n // is \"5\" and end is 1.\n try {\n lengths[end] = startAt +\n parentNode.getSubStringLength(0, words ? end + 1 : end);\n }\n catch (e) {\n '';\n }\n // Legacy\n }\n else if (renderer.getSpanWidth) { // #9058 jsdom\n textNode.textContent = getString(text || words, charEnd);\n lengths[end] = startAt +\n renderer.getSpanWidth(svgElement, textNode);\n }\n }\n return lengths[end];\n };\n svgElement.rotation = 0; // discard rotation when computing box\n actualWidth = getSubStringLength(textNode.textContent.length);\n if (startAt + actualWidth > width) {\n // Do a binary search for the index where to truncate the text\n while (minIndex <= maxIndex) {\n currentIndex = Math.ceil((minIndex + maxIndex) / 2);\n // When checking words for word-wrap, we need to build the\n // string and measure the subStringLength at the concatenated\n // word length.\n if (words) {\n str = getString(words, currentIndex);\n }\n actualWidth = getSubStringLength(currentIndex, str && str.length - 1);\n if (minIndex === maxIndex) {\n // Complete\n minIndex = maxIndex + 1;\n }\n else if (actualWidth > width) {\n // Too large. Set max index to current.\n maxIndex = currentIndex - 1;\n }\n else {\n // Within width. Set min index to current.\n minIndex = currentIndex;\n }\n }\n // If max index was 0 it means the shortest possible text was also\n // too large. For ellipsis that means only the ellipsis, while for\n // word wrap it means the whole first word.\n if (maxIndex === 0) {\n // Remove ellipsis\n textNode.textContent = '';\n // If the new text length is one less than the original, we don't\n // need the ellipsis\n }\n else if (!(text && maxIndex === text.length - 1)) {\n textNode.textContent = str || getString(text || words, currentIndex);\n }\n }\n // When doing line wrapping, prepare for the next line by removing the\n // items from this line.\n if (words) {\n words.splice(0, currentIndex);\n }\n svgElement.actualWidth = actualWidth;\n svgElement.rotation = rotation; // Apply rotation again.\n };\n /*\n * Un-escape HTML entities based on the public `renderer.escapes` list\n *\n * @private\n *\n * @param {string} inputStr The string to unescape\n * @param {Array} [except] Exceptions\n *\n * @return {string} The processed string\n */\n TextBuilder.prototype.unescapeEntities = function (inputStr, except) {\n objectEach(this.renderer.escapes, function (value, key) {\n if (!except || except.indexOf(value) === -1) {\n inputStr = inputStr.toString().replace(new RegExp(value, 'g'), key);\n }\n });\n return inputStr;\n };\n return TextBuilder;\n }());\n\n return TextBuilder;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/SVGRenderer.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Renderer/SVG/SVGLabel.js'], _modules['Core/Renderer/SVG/Symbols.js'], _modules['Core/Renderer/SVG/TextBuilder.js'], _modules['Core/Utilities.js']], function (AST, Color, H, RendererRegistry, SVGElement, SVGLabel, Symbols, TextBuilder, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var charts = H.charts,\n deg2rad = H.deg2rad,\n doc = H.doc,\n isFirefox = H.isFirefox,\n isMS = H.isMS,\n isWebKit = H.isWebKit,\n noop = H.noop,\n SVG_NS = H.SVG_NS,\n symbolSizes = H.symbolSizes,\n win = H.win;\n var addEvent = U.addEvent,\n attr = U.attr,\n createElement = U.createElement,\n css = U.css,\n defined = U.defined,\n destroyObjectProperties = U.destroyObjectProperties,\n extend = U.extend,\n isArray = U.isArray,\n isNumber = U.isNumber,\n isObject = U.isObject,\n isString = U.isString,\n merge = U.merge,\n pick = U.pick,\n pInt = U.pInt,\n uniqueKey = U.uniqueKey;\n /* *\n *\n * Variables\n *\n * */\n var hasInternalReferenceBug;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Allows direct access to the Highcharts rendering layer in order to draw\n * primitive shapes like circles, rectangles, paths or text directly on a chart,\n * or independent from any chart. The SVGRenderer represents a wrapper object\n * for SVG in modern browsers. Through the VMLRenderer, part of the `oldie.js`\n * module, it also brings vector graphics to IE <= 8.\n *\n * An existing chart's renderer can be accessed through {@link Chart.renderer}.\n * The renderer can also be used completely decoupled from a chart.\n *\n * @sample highcharts/members/renderer-on-chart\n * Annotating a chart programmatically.\n * @sample highcharts/members/renderer-basic\n * Independent SVG drawing.\n *\n * @example\n * // Use directly without a chart object.\n * let renderer = new Highcharts.Renderer(parentNode, 600, 400);\n *\n * @class\n * @name Highcharts.SVGRenderer\n *\n * @param {Highcharts.HTMLDOMElement} container\n * Where to put the SVG in the web page.\n *\n * @param {number} width\n * The width of the SVG.\n *\n * @param {number} height\n * The height of the SVG.\n *\n * @param {Highcharts.CSSObject} [style]\n * The box style, if not in styleMode\n *\n * @param {boolean} [forExport=false]\n * Whether the rendered content is intended for export.\n *\n * @param {boolean} [allowHTML=true]\n * Whether the renderer is allowed to include HTML text, which will be\n * projected on top of the SVG.\n *\n * @param {boolean} [styledMode=false]\n * Whether the renderer belongs to a chart that is in styled mode.\n * If it does, it will avoid setting presentational attributes in\n * some cases, but not when set explicitly through `.attr` and `.css`\n * etc.\n */\n var SVGRenderer = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function SVGRenderer(container, width, height, style, forExport, allowHTML, styledMode) {\n /* *\n *\n * Properties\n *\n * */\n this.alignedObjects = void 0;\n /**\n * The root `svg` node of the renderer.\n *\n * @name Highcharts.SVGRenderer#box\n * @type {Highcharts.SVGDOMElement}\n */\n this.box = void 0;\n /**\n * The wrapper for the root `svg` node of the renderer.\n *\n * @name Highcharts.SVGRenderer#boxWrapper\n * @type {Highcharts.SVGElement}\n */\n this.boxWrapper = void 0;\n this.cache = void 0;\n this.cacheKeys = void 0;\n this.chartIndex = void 0;\n /**\n * A pointer to the `defs` node of the root SVG.\n *\n * @name Highcharts.SVGRenderer#defs\n * @type {Highcharts.SVGElement}\n */\n this.defs = void 0;\n this.globalAnimation = void 0;\n this.gradients = void 0;\n this.height = void 0;\n this.imgCount = void 0;\n this.isSVG = void 0;\n this.style = void 0;\n /**\n * Page url used for internal references.\n *\n * @private\n * @name Highcharts.SVGRenderer#url\n * @type {string}\n */\n this.url = void 0;\n this.width = void 0;\n this.init(container, width, height, style, forExport, allowHTML, styledMode);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Initialize the SVGRenderer. Overridable initializer function that takes\n * the same parameters as the constructor.\n *\n * @function Highcharts.SVGRenderer#init\n *\n * @param {Highcharts.HTMLDOMElement} container\n * Where to put the SVG in the web page.\n *\n * @param {number} width\n * The width of the SVG.\n *\n * @param {number} height\n * The height of the SVG.\n *\n * @param {Highcharts.CSSObject} [style]\n * The box style, if not in styleMode\n *\n * @param {boolean} [forExport=false]\n * Whether the rendered content is intended for export.\n *\n * @param {boolean} [allowHTML=true]\n * Whether the renderer is allowed to include HTML text, which will be\n * projected on top of the SVG.\n *\n * @param {boolean} [styledMode=false]\n * Whether the renderer belongs to a chart that is in styled mode. If it\n * does, it will avoid setting presentational attributes in some cases, but\n * not when set explicitly through `.attr` and `.css` etc.\n */\n SVGRenderer.prototype.init = function (container, width, height, style, forExport, allowHTML, styledMode) {\n var renderer = this,\n boxWrapper = renderer\n .createElement('svg')\n .attr({\n version: '1.1',\n 'class': 'highcharts-root'\n }),\n element = boxWrapper.element;\n if (!styledMode) {\n boxWrapper.css(this.getStyle(style));\n }\n container.appendChild(element);\n // Always use ltr on the container, otherwise text-anchor will be\n // flipped and text appear outside labels, buttons, tooltip etc (#3482)\n attr(container, 'dir', 'ltr');\n // For browsers other than IE, add the namespace attribute (#1978)\n if (container.innerHTML.indexOf('xmlns') === -1) {\n attr(element, 'xmlns', this.SVG_NS);\n }\n // object properties\n renderer.isSVG = true;\n this.box = element;\n this.boxWrapper = boxWrapper;\n renderer.alignedObjects = [];\n this.url = this.getReferenceURL();\n // Add description\n var desc = this.createElement('desc').add();\n desc.element.appendChild(doc.createTextNode('Created with Highcharts 10.3.1'));\n renderer.defs = this.createElement('defs').add();\n renderer.allowHTML = allowHTML;\n renderer.forExport = forExport;\n renderer.styledMode = styledMode;\n renderer.gradients = {}; // Object where gradient SvgElements are stored\n renderer.cache = {}; // Cache for numerical bounding boxes\n renderer.cacheKeys = [];\n renderer.imgCount = 0;\n renderer.setSize(width, height, false);\n // Issue 110 workaround:\n // In Firefox, if a div is positioned by percentage, its pixel position\n // may land between pixels. The container itself doesn't display this,\n // but an SVG element inside this container will be drawn at subpixel\n // precision. In order to draw sharp lines, this must be compensated\n // for. This doesn't seem to work inside iframes though (like in\n // jsFiddle).\n var subPixelFix,\n rect;\n if (isFirefox && container.getBoundingClientRect) {\n subPixelFix = function () {\n css(container, { left: 0, top: 0 });\n rect = container.getBoundingClientRect();\n css(container, {\n left: (Math.ceil(rect.left) - rect.left) + 'px',\n top: (Math.ceil(rect.top) - rect.top) + 'px'\n });\n };\n // run the fix now\n subPixelFix();\n // run it on resize\n renderer.unSubPixelFix = addEvent(win, 'resize', subPixelFix);\n }\n };\n /**\n * General method for adding a definition to the SVG `defs` tag. Can be used\n * for gradients, fills, filters etc. Styled mode only. A hook for adding\n * general definitions to the SVG's defs tag. Definitions can be referenced\n * from the CSS by its `id`. Read more in\n * [gradients, shadows and patterns](https://www.highcharts.com/docs/chart-design-and-style/gradients-shadows-and-patterns).\n * Styled mode only.\n *\n * @function Highcharts.SVGRenderer#definition\n *\n * @param {Highcharts.ASTNode} def\n * A serialized form of an SVG definition, including children.\n *\n * @return {Highcharts.SVGElement}\n * The inserted node.\n */\n SVGRenderer.prototype.definition = function (def) {\n var ast = new AST([def]);\n return ast.addToDOM(this.defs.element);\n };\n /**\n * Get the prefix needed for internal URL references to work in certain\n * cases. Some older browser versions had a bug where internal url\n * references in SVG attributes, on the form `url(#some-id)`, would fail if\n * a base tag was present in the page. There were also issues with\n * `history.pushState` related to this prefix.\n *\n * Related issues: #24, #672, #1070, #5244.\n *\n * The affected browsers are:\n * - Chrome <= 53 (May 2018)\n * - Firefox <= 51 (January 2017)\n * - Safari/Mac <= 12.1 (2018 or 2019)\n * - Safari/iOS <= 13\n *\n * @todo Remove this hack when time has passed. All the affected browsers\n * are evergreens, so it is increasingly unlikely that users are affected by\n * the bug.\n *\n * @return {string}\n * The prefix to use. An empty string for modern browsers.\n */\n SVGRenderer.prototype.getReferenceURL = function () {\n if ((isFirefox || isWebKit) &&\n doc.getElementsByTagName('base').length) {\n // Detect if a clip path is taking effect by performing a hit test\n // outside the clipped area. If the hit element is the rectangle\n // that was supposed to be clipped, the bug is present. This only\n // has to be performed once per page load, so we store the result\n // locally in the module.\n if (!defined(hasInternalReferenceBug)) {\n var id = uniqueKey();\n var ast = new AST([{\n tagName: 'svg',\n attributes: {\n width: 8,\n height: 8\n },\n children: [{\n tagName: 'defs',\n children: [{\n tagName: 'clipPath',\n attributes: {\n id: id\n },\n children: [{\n tagName: 'rect',\n attributes: {\n width: 4,\n height: 4\n }\n }]\n }]\n }, {\n tagName: 'rect',\n attributes: {\n id: 'hitme',\n width: 8,\n height: 8,\n 'clip-path': \"url(#\".concat(id, \")\"),\n fill: 'rgba(0,0,0,0.001)'\n }\n }]\n }]);\n var svg = ast.addToDOM(doc.body);\n css(svg, {\n position: 'fixed',\n top: 0,\n left: 0,\n zIndex: 9e5\n });\n var hitElement = doc.elementFromPoint(6, 6);\n hasInternalReferenceBug = (hitElement && hitElement.id) === 'hitme';\n doc.body.removeChild(svg);\n }\n if (hasInternalReferenceBug) {\n return win.location.href\n .split('#')[0] // remove the hash\n .replace(/<[^>]*>/g, '') // wing cut HTML\n // escape parantheses and quotes\n .replace(/([\\('\\)])/g, '\\\\$1')\n // replace spaces (needed for Safari only)\n .replace(/ /g, '%20');\n }\n }\n return '';\n };\n /**\n * Get the global style setting for the renderer.\n *\n * @private\n * @function Highcharts.SVGRenderer#getStyle\n *\n * @param {Highcharts.CSSObject} style\n * Style settings.\n *\n * @return {Highcharts.CSSObject}\n * The style settings mixed with defaults.\n */\n SVGRenderer.prototype.getStyle = function (style) {\n this.style = extend({\n fontFamily: '\"Lucida Grande\", \"Lucida Sans Unicode\", ' +\n 'Arial, Helvetica, sans-serif',\n fontSize: '12px'\n }, style);\n return this.style;\n };\n /**\n * Apply the global style on the renderer, mixed with the default styles.\n *\n * @function Highcharts.SVGRenderer#setStyle\n *\n * @param {Highcharts.CSSObject} style\n * CSS to apply.\n */\n SVGRenderer.prototype.setStyle = function (style) {\n this.boxWrapper.css(this.getStyle(style));\n };\n /**\n * Detect whether the renderer is hidden. This happens when one of the\n * parent elements has `display: none`. Used internally to detect when we\n * needto render preliminarily in another div to get the text bounding boxes\n * right.\n *\n * @function Highcharts.SVGRenderer#isHidden\n *\n * @return {boolean}\n * True if it is hidden.\n */\n SVGRenderer.prototype.isHidden = function () {\n return !this.boxWrapper.getBBox().width;\n };\n /**\n * Destroys the renderer and its allocated members.\n *\n * @function Highcharts.SVGRenderer#destroy\n *\n * @return {null}\n * Pass through value.\n */\n SVGRenderer.prototype.destroy = function () {\n var renderer = this,\n rendererDefs = renderer.defs;\n renderer.box = null;\n renderer.boxWrapper = renderer.boxWrapper.destroy();\n // Call destroy on all gradient elements\n destroyObjectProperties(renderer.gradients || {});\n renderer.gradients = null;\n // Defs are null in VMLRenderer\n // Otherwise, destroy them here.\n if (rendererDefs) {\n renderer.defs = rendererDefs.destroy();\n }\n // Remove sub pixel fix handler (#982)\n if (renderer.unSubPixelFix) {\n renderer.unSubPixelFix();\n }\n renderer.alignedObjects = null;\n return null;\n };\n /**\n * Create a wrapper for an SVG element. Serves as a factory for\n * {@link SVGElement}, but this function is itself mostly called from\n * primitive factories like {@link SVGRenderer#path}, {@link\n * SVGRenderer#rect} or {@link SVGRenderer#text}.\n *\n * @function Highcharts.SVGRenderer#createElement\n *\n * @param {string} nodeName\n * The node name, for example `rect`, `g` etc.\n *\n * @return {Highcharts.SVGElement}\n * The generated SVGElement.\n */\n SVGRenderer.prototype.createElement = function (nodeName) {\n var wrapper = new this.Element();\n wrapper.init(this, nodeName);\n return wrapper;\n };\n /**\n * Get converted radial gradient attributes according to the radial\n * reference. Used internally from the {@link SVGElement#colorGradient}\n * function.\n *\n * @private\n * @function Highcharts.SVGRenderer#getRadialAttr\n */\n SVGRenderer.prototype.getRadialAttr = function (radialReference, gradAttr) {\n return {\n cx: (radialReference[0] - radialReference[2] / 2) +\n (gradAttr.cx || 0) * radialReference[2],\n cy: (radialReference[1] - radialReference[2] / 2) +\n (gradAttr.cy || 0) * radialReference[2],\n r: (gradAttr.r || 0) * radialReference[2]\n };\n };\n /**\n * Parse a simple HTML string into SVG tspans. Called internally when text\n * is set on an SVGElement. The function supports a subset of HTML tags, CSS\n * text features like `width`, `text-overflow`, `white-space`, and also\n * attributes like `href` and `style`.\n *\n * @private\n * @function Highcharts.SVGRenderer#buildText\n *\n * @param {Highcharts.SVGElement} wrapper\n * The parent SVGElement.\n */\n SVGRenderer.prototype.buildText = function (wrapper) {\n new TextBuilder(wrapper).buildSVG();\n };\n /**\n * Returns white for dark colors and black for bright colors, based on W3C's\n * definition of [Relative luminance](\n * https://www.w3.org/WAI/GL/wiki/Relative_luminance).\n *\n * @function Highcharts.SVGRenderer#getContrast\n *\n * @param {Highcharts.ColorString} color\n * The color to get the contrast for.\n *\n * @return {Highcharts.ColorString}\n * The contrast color, either `#000000` or `#FFFFFF`.\n */\n SVGRenderer.prototype.getContrast = function (color) {\n // #6216, #17273\n var rgba = Color.parse(color).rgba\n .map(function (b8) {\n var c = b8 / 255;\n return c <= 0.03928 ?\n c / 12.92 :\n Math.pow((c + 0.055) / 1.055, 2.4);\n });\n // Relative luminance\n var l = 0.2126 * rgba[0] + 0.7152 * rgba[1] + 0.0722 * rgba[2];\n // Use white or black based on which provides more contrast\n return 1.05 / (l + 0.05) > (l + 0.05) / 0.05 ? '#FFFFFF' : '#000000';\n };\n /**\n * Create a button with preset states.\n *\n * @function Highcharts.SVGRenderer#button\n *\n * @param {string} text\n * The text or HTML to draw.\n *\n * @param {number} x\n * The x position of the button's left side.\n *\n * @param {number} y\n * The y position of the button's top side.\n *\n * @param {Highcharts.EventCallbackFunction} callback\n * The function to execute on button click or touch.\n *\n * @param {Highcharts.SVGAttributes} [theme]\n * SVG attributes for the normal state.\n *\n * @param {Highcharts.SVGAttributes} [hoverState]\n * SVG attributes for the hover state.\n *\n * @param {Highcharts.SVGAttributes} [selectState]\n * SVG attributes for the pressed state.\n *\n * @param {Highcharts.SVGAttributes} [disabledState]\n * SVG attributes for the disabled state.\n *\n * @param {Highcharts.SymbolKeyValue} [shape=rect]\n * The shape type.\n *\n * @param {boolean} [useHTML=false]\n * Whether to use HTML to render the label.\n *\n * @return {Highcharts.SVGElement}\n * The button element.\n */\n SVGRenderer.prototype.button = function (text, x, y, callback, theme, hoverState, selectState, disabledState, shape, useHTML) {\n if (theme === void 0) { theme = {}; }\n var label = this.label(text,\n x,\n y,\n shape,\n void 0,\n void 0,\n useHTML,\n void 0, 'button'),\n styledMode = this.styledMode,\n states = theme.states || {};\n var curState = 0;\n theme = merge(theme);\n delete theme.states;\n var normalStyle = merge({\n color: \"#333333\" /* Palette.neutralColor80 */,\n cursor: 'pointer',\n fontWeight: 'normal'\n },\n theme.style);\n delete theme.style;\n // Remove stylable attributes. Pass in the ButtonThemeObject and get the\n // SVGAttributes subset back.\n var normalState = AST.filterUserAttributes(theme);\n // Default, non-stylable attributes\n label.attr(merge({ padding: 8, r: 2 }, normalState));\n // Presentational. The string type is a mistake, it is just for\n // compliance with SVGAttribute and is not used in button theme.\n var hoverStyle,\n selectStyle,\n disabledStyle;\n if (!styledMode) {\n // Normal state - prepare the attributes\n normalState = merge({\n fill: \"#f7f7f7\" /* Palette.neutralColor3 */,\n stroke: \"#cccccc\" /* Palette.neutralColor20 */,\n 'stroke-width': 1\n }, normalState);\n // Hover state\n hoverState = merge(normalState, {\n fill: \"#e6e6e6\" /* Palette.neutralColor10 */\n }, AST.filterUserAttributes(hoverState || states.hover || {}));\n hoverStyle = hoverState.style;\n delete hoverState.style;\n // Pressed state\n selectState = merge(normalState, {\n fill: \"#e6ebf5\" /* Palette.highlightColor10 */,\n style: {\n color: \"#000000\" /* Palette.neutralColor100 */,\n fontWeight: 'bold'\n }\n }, AST.filterUserAttributes(selectState || states.select || {}));\n selectStyle = selectState.style;\n delete selectState.style;\n // Disabled state\n disabledState = merge(normalState, {\n style: {\n color: \"#cccccc\" /* Palette.neutralColor20 */\n }\n }, AST.filterUserAttributes(disabledState || states.disabled || {}));\n disabledStyle = disabledState.style;\n delete disabledState.style;\n }\n // Add the events. IE9 and IE10 need mouseover and mouseout to function\n // (#667).\n addEvent(label.element, isMS ? 'mouseover' : 'mouseenter', function () {\n if (curState !== 3) {\n label.setState(1);\n }\n });\n addEvent(label.element, isMS ? 'mouseout' : 'mouseleave', function () {\n if (curState !== 3) {\n label.setState(curState);\n }\n });\n label.setState = function (state) {\n // Hover state is temporary, don't record it\n if (state !== 1) {\n label.state = curState = state;\n }\n // Update visuals\n label\n .removeClass(/highcharts-button-(normal|hover|pressed|disabled)/)\n .addClass('highcharts-button-' +\n ['normal', 'hover', 'pressed', 'disabled'][state || 0]);\n if (!styledMode) {\n label\n .attr([\n normalState,\n hoverState,\n selectState,\n disabledState\n ][state || 0]);\n var css_1 = [\n normalStyle,\n hoverStyle,\n selectStyle,\n disabledStyle\n ][state || 0];\n if (isObject(css_1)) {\n label.css(css_1);\n }\n }\n };\n // Presentational attributes\n if (!styledMode) {\n label\n .attr(normalState)\n .css(extend({ cursor: 'default' }, normalStyle));\n // HTML labels don't need to handle pointer events because click and\n // mouseenter/mouseleave is bound to the underlying element.\n // Should this be reconsidered, we need more complex logic to share\n // events between the and its
counterpart, and avoid\n // triggering mouseenter/mouseleave when hovering from one to the\n // other (#17440).\n if (useHTML) {\n label.text.css({ pointerEvents: 'none' });\n }\n }\n return label\n .on('touchstart', function (e) { return e.stopPropagation(); })\n .on('click', function (e) {\n if (curState !== 3) {\n callback.call(label, e);\n }\n });\n };\n /**\n * Make a straight line crisper by not spilling out to neighbour pixels.\n *\n * @function Highcharts.SVGRenderer#crispLine\n *\n * @param {Highcharts.SVGPathArray} points\n * The original points on the format `[['M', 0, 0], ['L', 100, 0]]`.\n *\n * @param {number} width\n * The width of the line.\n *\n * @param {string} [roundingFunction=round]\n * The rounding function name on the `Math` object, can be one of\n * `round`, `floor` or `ceil`.\n *\n * @return {Highcharts.SVGPathArray}\n * The original points array, but modified to render crisply.\n */\n SVGRenderer.prototype.crispLine = function (points, width, roundingFunction) {\n if (roundingFunction === void 0) { roundingFunction = 'round'; }\n var start = points[0];\n var end = points[1];\n // Normalize to a crisp line\n if (defined(start[1]) && start[1] === end[1]) {\n // Substract due to #1129. Now bottom and left axis gridlines behave\n // the same.\n start[1] = end[1] =\n Math[roundingFunction](start[1]) - (width % 2 / 2);\n }\n if (defined(start[2]) && start[2] === end[2]) {\n start[2] = end[2] =\n Math[roundingFunction](start[2]) + (width % 2 / 2);\n }\n return points;\n };\n /**\n * Draw a path, wraps the SVG `path` element.\n *\n * @sample highcharts/members/renderer-path-on-chart/\n * Draw a path in a chart\n * @sample highcharts/members/renderer-path/\n * Draw a path independent from a chart\n *\n * @example\n * let path = renderer.path(['M', 10, 10, 'L', 30, 30, 'z'])\n * .attr({ stroke: '#ff00ff' })\n * .add();\n *\n * @function Highcharts.SVGRenderer#path\n *\n * @param {Highcharts.SVGPathArray} [path]\n * An SVG path definition in array form.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n *\n */ /**\n * Draw a path, wraps the SVG `path` element.\n *\n * @function Highcharts.SVGRenderer#path\n *\n * @param {Highcharts.SVGAttributes} [attribs]\n * The initial attributes.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n SVGRenderer.prototype.path = function (path) {\n var attribs = (this.styledMode ? {} : {\n fill: 'none'\n });\n if (isArray(path)) {\n attribs.d = path;\n }\n else if (isObject(path)) { // attributes\n extend(attribs, path);\n }\n return this.createElement('path').attr(attribs);\n };\n /**\n * Draw a circle, wraps the SVG `circle` element.\n *\n * @sample highcharts/members/renderer-circle/\n * Drawing a circle\n *\n * @function Highcharts.SVGRenderer#circle\n *\n * @param {number} [x]\n * The center x position.\n *\n * @param {number} [y]\n * The center y position.\n *\n * @param {number} [r]\n * The radius.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */ /**\n * Draw a circle, wraps the SVG `circle` element.\n *\n * @function Highcharts.SVGRenderer#circle\n *\n * @param {Highcharts.SVGAttributes} [attribs]\n * The initial attributes.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n SVGRenderer.prototype.circle = function (x, y, r) {\n var attribs = (isObject(x) ?\n x :\n typeof x === 'undefined' ? {} : { x: x, y: y, r: r }), wrapper = this.createElement('circle');\n // Setting x or y translates to cx and cy\n wrapper.xSetter = wrapper.ySetter = function (value, key, element) {\n element.setAttribute('c' + key, value);\n };\n return wrapper.attr(attribs);\n };\n /**\n * Draw and return an arc.\n *\n * @sample highcharts/members/renderer-arc/\n * Drawing an arc\n *\n * @function Highcharts.SVGRenderer#arc\n *\n * @param {number} [x=0]\n * Center X position.\n *\n * @param {number} [y=0]\n * Center Y position.\n *\n * @param {number} [r=0]\n * The outer radius' of the arc.\n *\n * @param {number} [innerR=0]\n * Inner radius like used in donut charts.\n *\n * @param {number} [start=0]\n * The starting angle of the arc in radians, where 0 is to the right and\n * `-Math.PI/2` is up.\n *\n * @param {number} [end=0]\n * The ending angle of the arc in radians, where 0 is to the right and\n * `-Math.PI/2` is up.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */ /**\n * Draw and return an arc. Overloaded function that takes arguments object.\n *\n * @function Highcharts.SVGRenderer#arc\n *\n * @param {Highcharts.SVGAttributes} attribs\n * Initial SVG attributes.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n SVGRenderer.prototype.arc = function (x, y, r, innerR, start, end) {\n var options;\n if (isObject(x)) {\n options = x;\n y = options.y;\n r = options.r;\n innerR = options.innerR;\n start = options.start;\n end = options.end;\n x = options.x;\n }\n else {\n options = { innerR: innerR, start: start, end: end };\n }\n // Arcs are defined as symbols for the ability to set\n // attributes in attr and animate\n var arc = this.symbol('arc',\n x,\n y,\n r,\n r,\n options);\n arc.r = r; // #959\n return arc;\n };\n /**\n * Draw and return a rectangle.\n *\n * @function Highcharts.SVGRenderer#rect\n *\n * @param {number} [x]\n * Left position.\n *\n * @param {number} [y]\n * Top position.\n *\n * @param {number} [width]\n * Width of the rectangle.\n *\n * @param {number} [height]\n * Height of the rectangle.\n *\n * @param {number} [r]\n * Border corner radius.\n *\n * @param {number} [strokeWidth]\n * A stroke width can be supplied to allow crisp drawing.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */ /**\n * Draw and return a rectangle.\n *\n * @sample highcharts/members/renderer-rect-on-chart/\n * Draw a rectangle in a chart\n * @sample highcharts/members/renderer-rect/\n * Draw a rectangle independent from a chart\n *\n * @function Highcharts.SVGRenderer#rect\n *\n * @param {Highcharts.SVGAttributes} [attributes]\n * General SVG attributes for the rectangle.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n SVGRenderer.prototype.rect = function (x, y, width, height, r, strokeWidth) {\n r = isObject(x) ? x.r : r;\n var wrapper = this.createElement('rect');\n var attribs = (isObject(x) ?\n x :\n typeof x === 'undefined' ?\n {} :\n {\n x: x,\n y: y,\n width: Math.max(width, 0),\n height: Math.max(height, 0)\n });\n if (!this.styledMode) {\n if (typeof strokeWidth !== 'undefined') {\n attribs['stroke-width'] = strokeWidth;\n attribs = wrapper.crisp(attribs);\n }\n attribs.fill = 'none';\n }\n if (r) {\n attribs.r = r;\n }\n wrapper.rSetter = function (value, _key, element) {\n wrapper.r = value;\n attr(element, {\n rx: value,\n ry: value\n });\n };\n wrapper.rGetter = function () {\n return wrapper.r || 0;\n };\n return wrapper.attr(attribs);\n };\n /**\n * Resize the {@link SVGRenderer#box} and re-align all aligned child\n * elements.\n *\n * @sample highcharts/members/renderer-g/\n * Show and hide grouped objects\n *\n * @function Highcharts.SVGRenderer#setSize\n *\n * @param {number} width\n * The new pixel width.\n *\n * @param {number} height\n * The new pixel height.\n *\n * @param {boolean|Partial} [animate=true]\n * Whether and how to animate.\n */\n SVGRenderer.prototype.setSize = function (width, height, animate) {\n var renderer = this;\n renderer.width = width;\n renderer.height = height;\n renderer.boxWrapper.animate({\n width: width,\n height: height\n }, {\n step: function () {\n this.attr({\n viewBox: '0 0 ' + this.attr('width') + ' ' +\n this.attr('height')\n });\n },\n duration: pick(animate, true) ? void 0 : 0\n });\n renderer.alignElements();\n };\n /**\n * Create and return an svg group element. Child\n * {@link Highcharts.SVGElement} objects are added to the group by using the\n * group as the first parameter in {@link Highcharts.SVGElement#add|add()}.\n *\n * @function Highcharts.SVGRenderer#g\n *\n * @param {string} [name]\n * The group will be given a class name of `highcharts-{name}`. This\n * can be used for styling and scripting.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n SVGRenderer.prototype.g = function (name) {\n var elem = this.createElement('g');\n return name ?\n elem.attr({ 'class': 'highcharts-' + name }) :\n elem;\n };\n /**\n * Display an image.\n *\n * @sample highcharts/members/renderer-image-on-chart/\n * Add an image in a chart\n * @sample highcharts/members/renderer-image/\n * Add an image independent of a chart\n *\n * @function Highcharts.SVGRenderer#image\n *\n * @param {string} src\n * The image source.\n *\n * @param {number} [x]\n * The X position.\n *\n * @param {number} [y]\n * The Y position.\n *\n * @param {number} [width]\n * The image width. If omitted, it defaults to the image file width.\n *\n * @param {number} [height]\n * The image height. If omitted it defaults to the image file\n * height.\n *\n * @param {Function} [onload]\n * Event handler for image load.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n SVGRenderer.prototype.image = function (src, x, y, width, height, onload) {\n var attribs = { preserveAspectRatio: 'none' }, setSVGImageSource = function (el, src) {\n // Set the href in the xlink namespace\n if (el.setAttributeNS) {\n el.setAttributeNS('http://www.w3.org/1999/xlink', 'href', src);\n }\n else {\n // could be exporting in IE\n // using href throws \"not supported\" in ie7 and under,\n // requries regex shim to fix later\n el.setAttribute('hc-svg-href', src);\n }\n };\n // Optional properties (#11756)\n if (isNumber(x)) {\n attribs.x = x;\n }\n if (isNumber(y)) {\n attribs.y = y;\n }\n if (isNumber(width)) {\n attribs.width = width;\n }\n if (isNumber(height)) {\n attribs.height = height;\n }\n var elemWrapper = this.createElement('image').attr(attribs),\n onDummyLoad = function (e) {\n setSVGImageSource(elemWrapper.element,\n src);\n onload.call(elemWrapper, e);\n };\n // Add load event if supplied\n if (onload) {\n // We have to use a dummy HTML image since IE support for SVG image\n // load events is very buggy. First set a transparent src, wait for\n // dummy to load, and then add the real src to the SVG image.\n setSVGImageSource(elemWrapper.element, 'data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==' /* eslint-disable-line */);\n var dummy = new win.Image();\n addEvent(dummy, 'load', onDummyLoad);\n dummy.src = src;\n if (dummy.complete) {\n onDummyLoad({});\n }\n }\n else {\n setSVGImageSource(elemWrapper.element, src);\n }\n return elemWrapper;\n };\n /**\n * Draw a symbol out of pre-defined shape paths from\n * {@link SVGRenderer#symbols}.\n * It is used in Highcharts for point makers, which cake a `symbol` option,\n * and label and button backgrounds like in the tooltip and stock flags.\n *\n * @function Highcharts.SVGRenderer#symbol\n *\n * @param {string} symbol\n * The symbol name.\n *\n * @param {number} [x]\n * The X coordinate for the top left position.\n *\n * @param {number} [y]\n * The Y coordinate for the top left position.\n *\n * @param {number} [width]\n * The pixel width.\n *\n * @param {number} [height]\n * The pixel height.\n *\n * @param {Highcharts.SymbolOptionsObject} [options]\n * Additional options, depending on the actual symbol drawn.\n *\n * @return {Highcharts.SVGElement}\n * SVG symbol.\n */\n SVGRenderer.prototype.symbol = function (symbol, x, y, width, height, options) {\n var ren = this,\n imageRegex = /^url\\((.*?)\\)$/,\n isImage = imageRegex.test(symbol),\n sym = (!isImage && (this.symbols[symbol] ? symbol : 'circle')), \n // get the symbol definition function\n symbolFn = (sym && this.symbols[sym]);\n var obj,\n path,\n imageSrc,\n centerImage;\n if (symbolFn) {\n // Check if there's a path defined for this symbol\n if (typeof x === 'number') {\n path = symbolFn.call(this.symbols, Math.round(x || 0), Math.round(y || 0), width || 0, height || 0, options);\n }\n obj = this.path(path);\n if (!ren.styledMode) {\n obj.attr('fill', 'none');\n }\n // expando properties for use in animate and attr\n extend(obj, {\n symbolName: (sym || void 0),\n x: x,\n y: y,\n width: width,\n height: height\n });\n if (options) {\n extend(obj, options);\n }\n // Image symbols\n }\n else if (isImage) {\n imageSrc = symbol.match(imageRegex)[1];\n // Create the image synchronously, add attribs async\n var img_1 = obj = this.image(imageSrc);\n // The image width is not always the same as the symbol width. The\n // image may be centered within the symbol, as is the case when\n // image shapes are used as label backgrounds, for example in flags.\n img_1.imgwidth = pick(symbolSizes[imageSrc] && symbolSizes[imageSrc].width, options && options.width);\n img_1.imgheight = pick(symbolSizes[imageSrc] && symbolSizes[imageSrc].height, options && options.height);\n /**\n * Set the size and position\n */\n centerImage = function (obj) { return obj.attr({\n width: obj.width,\n height: obj.height\n }); };\n /**\n * Width and height setters that take both the image's physical size\n * and the label size into consideration, and translates the image\n * to center within the label.\n */\n ['width', 'height'].forEach(function (key) {\n img_1[key + 'Setter'] = function (value, key) {\n this[key] = value;\n var _a = this,\n alignByTranslate = _a.alignByTranslate,\n element = _a.element,\n width = _a.width,\n height = _a.height,\n imgwidth = _a.imgwidth,\n imgheight = _a.imgheight;\n var imgSize = this['img' + key];\n if (defined(imgSize)) {\n var scale = 1;\n // Scale and center the image within its container.\n // The name `backgroundSize` is taken from the CSS spec,\n // but the value `within` is made up. Other possible\n // values in the spec, `cover` and `contain`, can be\n // implemented if needed.\n if (options &&\n options.backgroundSize === 'within' &&\n width &&\n height) {\n scale = Math.min(width / imgwidth, height / imgheight);\n imgSize = Math.round(imgSize * scale);\n // Update both width and height to keep the ratio\n // correct (#17315)\n attr(element, {\n width: Math.round(imgwidth * scale),\n height: Math.round(imgheight * scale)\n });\n }\n else if (element) {\n element.setAttribute(key, imgSize);\n }\n if (!alignByTranslate) {\n this.translate(((width || 0) - (imgSize * scale)) / 2, ((height || 0) - (imgSize * scale)) / 2);\n }\n }\n };\n });\n if (defined(x)) {\n img_1.attr({\n x: x,\n y: y\n });\n }\n img_1.isImg = true;\n if (defined(img_1.imgwidth) && defined(img_1.imgheight)) {\n centerImage(img_1);\n }\n else {\n // Initialize image to be 0 size so export will still function\n // if there's no cached sizes.\n img_1.attr({ width: 0, height: 0 });\n // Create a dummy JavaScript image to get the width and height.\n createElement('img', {\n onload: function () {\n var chart = charts[ren.chartIndex];\n // Special case for SVGs on IE11, the width is not\n // accessible until the image is part of the DOM\n // (#2854).\n if (this.width === 0) {\n css(this, {\n position: 'absolute',\n top: '-999em'\n });\n doc.body.appendChild(this);\n }\n // Center the image\n symbolSizes[imageSrc] = {\n width: this.width,\n height: this.height\n };\n img_1.imgwidth = this.width;\n img_1.imgheight = this.height;\n if (img_1.element) {\n centerImage(img_1);\n }\n // Clean up after #2854 workaround.\n if (this.parentNode) {\n this.parentNode.removeChild(this);\n }\n // Fire the load event when all external images are\n // loaded\n ren.imgCount--;\n if (!ren.imgCount && chart && !chart.hasLoaded) {\n chart.onload();\n }\n },\n src: imageSrc\n });\n this.imgCount++;\n }\n }\n return obj;\n };\n /**\n * Define a clipping rectangle. The clipping rectangle is later applied\n * to {@link SVGElement} objects through the {@link SVGElement#clip}\n * function.\n *\n * @example\n * let circle = renderer.circle(100, 100, 100)\n * .attr({ fill: 'red' })\n * .add();\n * let clipRect = renderer.clipRect(100, 100, 100, 100);\n *\n * // Leave only the lower right quarter visible\n * circle.clip(clipRect);\n *\n * @function Highcharts.SVGRenderer#clipRect\n *\n * @param {number} [x]\n *\n * @param {number} [y]\n *\n * @param {number} [width]\n *\n * @param {number} [height]\n *\n * @return {Highcharts.ClipRectElement}\n * A clipping rectangle.\n */\n SVGRenderer.prototype.clipRect = function (x, y, width, height) {\n var \n // Add a hyphen at the end to avoid confusion in testing indexes\n // -1 and -10, -11 etc (#6550)\n id = uniqueKey() + '-', clipPath = this.createElement('clipPath').attr({\n id: id\n }).add(this.defs), wrapper = this.rect(x, y, width, height, 0).add(clipPath);\n wrapper.id = id;\n wrapper.clipPath = clipPath;\n wrapper.count = 0;\n return wrapper;\n };\n /**\n * Draw text. The text can contain a subset of HTML, like spans and anchors\n * and some basic text styling of these. For more advanced features like\n * border and background, use {@link Highcharts.SVGRenderer#label} instead.\n * To update the text after render, run `text.attr({ text: 'New text' })`.\n *\n * @sample highcharts/members/renderer-text-on-chart/\n * Annotate the chart freely\n * @sample highcharts/members/renderer-on-chart/\n * Annotate with a border and in response to the data\n * @sample highcharts/members/renderer-text/\n * Formatted text\n *\n * @function Highcharts.SVGRenderer#text\n *\n * @param {string} [str]\n * The text of (subset) HTML to draw.\n *\n * @param {number} [x]\n * The x position of the text's lower left corner.\n *\n * @param {number} [y]\n * The y position of the text's lower left corner.\n *\n * @param {boolean} [useHTML=false]\n * Use HTML to render the text.\n *\n * @return {Highcharts.SVGElement}\n * The text object.\n */\n SVGRenderer.prototype.text = function (str, x, y, useHTML) {\n var renderer = this,\n attribs = {};\n if (useHTML && (renderer.allowHTML || !renderer.forExport)) {\n return renderer.html(str, x, y);\n }\n attribs.x = Math.round(x || 0); // X always needed for line-wrap logic\n if (y) {\n attribs.y = Math.round(y);\n }\n if (defined(str)) {\n attribs.text = str;\n }\n var wrapper = renderer.createElement('text').attr(attribs);\n if (!useHTML || (renderer.forExport && !renderer.allowHTML)) {\n wrapper.xSetter = function (value, key, element) {\n var tspans = element.getElementsByTagName('tspan'),\n parentVal = element.getAttribute(key);\n for (var i = 0, tspan = void 0; i < tspans.length; i++) {\n tspan = tspans[i];\n // If the x values are equal, the tspan represents a line\n // break\n if (tspan.getAttribute(key) === parentVal) {\n tspan.setAttribute(key, value);\n }\n }\n element.setAttribute(key, value);\n };\n }\n return wrapper;\n };\n /**\n * Utility to return the baseline offset and total line height from the font\n * size.\n *\n * @function Highcharts.SVGRenderer#fontMetrics\n *\n * @param {number|string} [fontSize]\n * The current font size to inspect. If not given, the font size\n * will be found from the DOM element.\n *\n * @param {Highcharts.SVGElement|Highcharts.SVGDOMElement} [elem]\n * The element to inspect for a current font size.\n *\n * @return {Highcharts.FontMetricsObject}\n * The font metrics.\n */\n SVGRenderer.prototype.fontMetrics = function (fontSize, elem) {\n if ((this.styledMode || !/px/.test(fontSize)) &&\n (win.getComputedStyle) // old IE doesn't support it\n ) {\n fontSize = elem && SVGElement.prototype.getStyle.call(elem, 'font-size');\n }\n else {\n fontSize = fontSize ||\n // When the elem is a DOM element (#5932)\n (elem && elem.style && elem.style.fontSize) ||\n // Fall back on the renderer style default\n (this.style && this.style.fontSize);\n }\n // Handle different units\n if (/px/.test(fontSize)) {\n fontSize = pInt(fontSize);\n }\n else {\n fontSize = 12;\n }\n // Empirical values found by comparing font size and bounding box\n // height. Applies to the default font family.\n // https://jsfiddle.net/highcharts/7xvn7/\n var lineHeight = (fontSize < 24 ?\n fontSize + 3 :\n Math.round(fontSize * 1.2)),\n baseline = Math.round(lineHeight * 0.8);\n return {\n h: lineHeight,\n b: baseline,\n f: fontSize\n };\n };\n /**\n * Correct X and Y positioning of a label for rotation (#1764).\n *\n * @private\n * @function Highcharts.SVGRenderer#rotCorr\n */\n SVGRenderer.prototype.rotCorr = function (baseline, rotation, alterY) {\n var y = baseline;\n if (rotation && alterY) {\n y = Math.max(y * Math.cos(rotation * deg2rad), 4);\n }\n return {\n x: (-baseline / 3) * Math.sin(rotation * deg2rad),\n y: y\n };\n };\n /**\n * Compatibility function to convert the legacy one-dimensional path array\n * into an array of segments.\n *\n * It is used in maps to parse the `path` option, and in SVGRenderer.dSetter\n * to support legacy paths from demos.\n *\n * @private\n * @function Highcharts.SVGRenderer#pathToSegments\n */\n SVGRenderer.prototype.pathToSegments = function (path) {\n var ret = [];\n var segment = [];\n var commandLength = {\n A: 8,\n C: 7,\n H: 2,\n L: 3,\n M: 3,\n Q: 5,\n S: 5,\n T: 3,\n V: 2\n };\n // Short, non-typesafe parsing of the one-dimensional array. It splits\n // the path on any string. This is not type checked against the tuple\n // types, but is shorter, and doesn't require specific checks for any\n // command type in SVG.\n for (var i = 0; i < path.length; i++) {\n // Command skipped, repeat previous or insert L/l for M/m\n if (isString(segment[0]) &&\n isNumber(path[i]) &&\n segment.length === commandLength[(segment[0].toUpperCase())]) {\n path.splice(i, 0, segment[0].replace('M', 'L').replace('m', 'l'));\n }\n // Split on string\n if (typeof path[i] === 'string') {\n if (segment.length) {\n ret.push(segment.slice(0));\n }\n segment.length = 0;\n }\n segment.push(path[i]);\n }\n ret.push(segment.slice(0));\n return ret;\n /*\n // Fully type-safe version where each tuple type is checked. The\n // downside is filesize and a lack of flexibility for unsupported\n // commands\n const ret: SVGPath = [],\n commands = {\n A: 7,\n C: 6,\n H: 1,\n L: 2,\n M: 2,\n Q: 4,\n S: 4,\n T: 2,\n V: 1,\n Z: 0\n };\n\n let i = 0,\n lastI = 0,\n lastCommand;\n\n while (i < path.length) {\n const item = path[i];\n\n let command;\n\n if (typeof item === 'string') {\n command = item;\n i += 1;\n } else {\n command = lastCommand || 'M';\n }\n\n // Upper case\n const commandUC = command.toUpperCase();\n\n if (commandUC in commands) {\n\n // No numeric parameters\n if (command === 'Z' || command === 'z') {\n ret.push([command]);\n\n // One numeric parameter\n } else {\n const val0 = path[i];\n if (typeof val0 === 'number') {\n\n // Horizontal line to\n if (command === 'H' || command === 'h') {\n ret.push([command, val0]);\n i += 1;\n\n // Vertical line to\n } else if (command === 'V' || command === 'v') {\n ret.push([command, val0]);\n i += 1;\n\n // Two numeric parameters\n } else {\n const val1 = path[i + 1];\n if (typeof val1 === 'number') {\n // lineTo\n if (command === 'L' || command === 'l') {\n ret.push([command, val0, val1]);\n i += 2;\n\n // moveTo\n } else if (command === 'M' || command === 'm') {\n ret.push([command, val0, val1]);\n i += 2;\n\n // Smooth quadratic bezier\n } else if (command === 'T' || command === 't') {\n ret.push([command, val0, val1]);\n i += 2;\n\n // Four numeric parameters\n } else {\n const val2 = path[i + 2],\n val3 = path[i + 3];\n if (\n typeof val2 === 'number' &&\n typeof val3 === 'number'\n ) {\n // Quadratic bezier to\n if (\n command === 'Q' ||\n command === 'q'\n ) {\n ret.push([\n command,\n val0,\n val1,\n val2,\n val3\n ]);\n i += 4;\n\n // Smooth cubic bezier to\n } else if (\n command === 'S' ||\n command === 's'\n ) {\n ret.push([\n command,\n val0,\n val1,\n val2,\n val3\n ]);\n i += 4;\n\n // Six numeric parameters\n } else {\n const val4 = path[i + 4],\n val5 = path[i + 5];\n\n if (\n typeof val4 === 'number' &&\n typeof val5 === 'number'\n ) {\n // Curve to\n if (\n command === 'C' ||\n command === 'c'\n ) {\n ret.push([\n command,\n val0,\n val1,\n val2,\n val3,\n val4,\n val5\n ]);\n i += 6;\n\n // Seven numeric parameters\n } else {\n const val6 = path[i + 6];\n\n // Arc to\n if (\n typeof val6 ===\n 'number' &&\n (\n command === 'A' ||\n command === 'a'\n )\n ) {\n ret.push([\n command,\n val0,\n val1,\n val2,\n val3,\n val4,\n val5,\n val6\n ]);\n i += 7;\n\n }\n\n }\n }\n }\n }\n }\n }\n\n }\n }\n }\n }\n\n // An unmarked command following a moveTo is a lineTo\n lastCommand = command === 'M' ? 'L' : command;\n\n if (i === lastI) {\n break;\n }\n lastI = i;\n }\n return ret;\n */\n };\n /**\n * Draw a label, which is an extended text element with support for border\n * and background. Highcharts creates a `g` element with a text and a `path`\n * or `rect` inside, to make it behave somewhat like a HTML div. Border and\n * background are set through `stroke`, `stroke-width` and `fill` attributes\n * using the {@link Highcharts.SVGElement#attr|attr} method. To update the\n * text after render, run `label.attr({ text: 'New text' })`.\n *\n * @sample highcharts/members/renderer-label-on-chart/\n * A label on the chart\n *\n * @function Highcharts.SVGRenderer#label\n *\n * @param {string} str\n * The initial text string or (subset) HTML to render.\n *\n * @param {number} x\n * The x position of the label's left side.\n *\n * @param {number} [y]\n * The y position of the label's top side or baseline, depending on\n * the `baseline` parameter.\n *\n * @param {string} [shape='rect']\n * The shape of the label's border/background, if any. Defaults to\n * `rect`. Other possible values are `callout` or other shapes\n * defined in {@link Highcharts.SVGRenderer#symbols}.\n *\n * @param {number} [anchorX]\n * In case the `shape` has a pointer, like a flag, this is the\n * coordinates it should be pinned to.\n *\n * @param {number} [anchorY]\n * In case the `shape` has a pointer, like a flag, this is the\n * coordinates it should be pinned to.\n *\n * @param {boolean} [useHTML=false]\n * Whether to use HTML to render the label.\n *\n * @param {boolean} [baseline=false]\n * Whether to position the label relative to the text baseline,\n * like {@link Highcharts.SVGRenderer#text|renderer.text}, or to the\n * upper border of the rectangle.\n *\n * @param {string} [className]\n * Class name for the group.\n *\n * @return {Highcharts.SVGElement}\n * The generated label.\n */\n SVGRenderer.prototype.label = function (str, x, y, shape, anchorX, anchorY, useHTML, baseline, className) {\n return new SVGLabel(this, str, x, y, shape, anchorX, anchorY, useHTML, baseline, className);\n };\n /**\n * Re-align all aligned elements.\n *\n * @private\n * @function Highcharts.SVGRenderer#alignElements\n */\n SVGRenderer.prototype.alignElements = function () {\n this.alignedObjects.forEach(function (el) { return el.align(); });\n };\n return SVGRenderer;\n }());\n extend(SVGRenderer.prototype, {\n /**\n * A pointer to the renderer's associated Element class. The VMLRenderer\n * will have a pointer to VMLElement here.\n *\n * @name Highcharts.SVGRenderer#Element\n * @type {Highcharts.SVGElement}\n */\n Element: SVGElement,\n SVG_NS: SVG_NS,\n /**\n * A collection of characters mapped to HTML entities. When `useHTML` on an\n * element is true, these entities will be rendered correctly by HTML. In\n * the SVG pseudo-HTML, they need to be unescaped back to simple characters,\n * so for example `<` will render as `<`.\n *\n * @example\n * // Add support for unescaping quotes\n * Highcharts.SVGRenderer.prototype.escapes['\"'] = '"';\n *\n * @name Highcharts.SVGRenderer#escapes\n * @type {Highcharts.Dictionary}\n */\n escapes: {\n '&': '&',\n '<': '<',\n '>': '>',\n \"'\": ''',\n '\"': '"'\n },\n /**\n * An extendable collection of functions for defining symbol paths.\n *\n * @name Highcharts.SVGRenderer#symbols\n * @type {Highcharts.SymbolDictionary}\n */\n symbols: Symbols,\n /**\n * Dummy function for plugins, called every time the renderer is updated.\n * Prior to Highcharts 5, this was used for the canvg renderer.\n *\n * @deprecated\n * @function Highcharts.SVGRenderer#draw\n */\n draw: noop\n });\n /* *\n *\n * Registry\n *\n * */\n RendererRegistry.registerRendererType('svg', SVGRenderer, true);\n /* *\n *\n * Export Default\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * A clipping rectangle that can be applied to one or more {@link SVGElement}\n * instances. It is instanciated with the {@link SVGRenderer#clipRect} function\n * and applied with the {@link SVGElement#clip} function.\n *\n * @example\n * let circle = renderer.circle(100, 100, 100)\n * .attr({ fill: 'red' })\n * .add();\n * let clipRect = renderer.clipRect(100, 100, 100, 100);\n *\n * // Leave only the lower right quarter visible\n * circle.clip(clipRect);\n *\n * @typedef {Highcharts.SVGElement} Highcharts.ClipRectElement\n */\n /**\n * The font metrics.\n *\n * @interface Highcharts.FontMetricsObject\n */ /**\n * The baseline relative to the top of the box.\n *\n * @name Highcharts.FontMetricsObject#b\n * @type {number}\n */ /**\n * The font size.\n *\n * @name Highcharts.FontMetricsObject#f\n * @type {number}\n */ /**\n * The line height.\n *\n * @name Highcharts.FontMetricsObject#h\n * @type {number}\n */\n /**\n * An object containing `x` and `y` properties for the position of an element.\n *\n * @interface Highcharts.PositionObject\n */ /**\n * X position of the element.\n * @name Highcharts.PositionObject#x\n * @type {number}\n */ /**\n * Y position of the element.\n * @name Highcharts.PositionObject#y\n * @type {number}\n */\n /**\n * A rectangle.\n *\n * @interface Highcharts.RectangleObject\n */ /**\n * Height of the rectangle.\n * @name Highcharts.RectangleObject#height\n * @type {number}\n */ /**\n * Width of the rectangle.\n * @name Highcharts.RectangleObject#width\n * @type {number}\n */ /**\n * Horizontal position of the rectangle.\n * @name Highcharts.RectangleObject#x\n * @type {number}\n */ /**\n * Vertical position of the rectangle.\n * @name Highcharts.RectangleObject#y\n * @type {number}\n */\n /**\n * The shadow options.\n *\n * @interface Highcharts.ShadowOptionsObject\n */ /**\n * The shadow color.\n * @name Highcharts.ShadowOptionsObject#color\n * @type {Highcharts.ColorString|undefined}\n * @default #000000\n */ /**\n * The horizontal offset from the element.\n *\n * @name Highcharts.ShadowOptionsObject#offsetX\n * @type {number|undefined}\n * @default 1\n */ /**\n * The vertical offset from the element.\n * @name Highcharts.ShadowOptionsObject#offsetY\n * @type {number|undefined}\n * @default 1\n */ /**\n * The shadow opacity.\n *\n * @name Highcharts.ShadowOptionsObject#opacity\n * @type {number|undefined}\n * @default 0.15\n */ /**\n * The shadow width or distance from the element.\n * @name Highcharts.ShadowOptionsObject#width\n * @type {number|undefined}\n * @default 3\n */\n /**\n * @interface Highcharts.SizeObject\n */ /**\n * @name Highcharts.SizeObject#height\n * @type {number}\n */ /**\n * @name Highcharts.SizeObject#width\n * @type {number}\n */\n /**\n * Array of path commands, that will go into the `d` attribute of an SVG\n * element.\n *\n * @typedef {Array<(Array|Array|Array|Array|Array|Array)>} Highcharts.SVGPathArray\n */\n /**\n * Possible path commands in an SVG path array. Valid values are `A`, `C`, `H`,\n * `L`, `M`, `Q`, `S`, `T`, `V`, `Z`.\n *\n * @typedef {string} Highcharts.SVGPathCommand\n * @validvalue [\"a\",\"c\",\"h\",\"l\",\"m\",\"q\",\"s\",\"t\",\"v\",\"z\",\"A\",\"C\",\"H\",\"L\",\"M\",\"Q\",\"S\",\"T\",\"V\",\"Z\"]\n */\n /**\n * An extendable collection of functions for defining symbol paths. Symbols are\n * used internally for point markers, button and label borders and backgrounds,\n * or custom shapes. Extendable by adding to {@link SVGRenderer#symbols}.\n *\n * @interface Highcharts.SymbolDictionary\n */ /**\n * @name Highcharts.SymbolDictionary#[key:string]\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#arc\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#callout\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#circle\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#diamond\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#square\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#triangle\n * @type {Function|undefined}\n */\n /**\n * Can be one of `arc`, `callout`, `circle`, `diamond`, `square`, `triangle`,\n * and `triangle-down`. Symbols are used internally for point markers, button\n * and label borders and backgrounds, or custom shapes. Extendable by adding to\n * {@link SVGRenderer#symbols}.\n *\n * @typedef {\"arc\"|\"callout\"|\"circle\"|\"diamond\"|\"square\"|\"triangle\"|\"triangle-down\"} Highcharts.SymbolKeyValue\n */\n /**\n * Additional options, depending on the actual symbol drawn.\n *\n * @interface Highcharts.SymbolOptionsObject\n */ /**\n * The anchor X position for the `callout` symbol. This is where the chevron\n * points to.\n *\n * @name Highcharts.SymbolOptionsObject#anchorX\n * @type {number|undefined}\n */ /**\n * The anchor Y position for the `callout` symbol. This is where the chevron\n * points to.\n *\n * @name Highcharts.SymbolOptionsObject#anchorY\n * @type {number|undefined}\n */ /**\n * The end angle of an `arc` symbol.\n *\n * @name Highcharts.SymbolOptionsObject#end\n * @type {number|undefined}\n */ /**\n * Whether to draw `arc` symbol open or closed.\n *\n * @name Highcharts.SymbolOptionsObject#open\n * @type {boolean|undefined}\n */ /**\n * The radius of an `arc` symbol, or the border radius for the `callout` symbol.\n *\n * @name Highcharts.SymbolOptionsObject#r\n * @type {number|undefined}\n */ /**\n * The start angle of an `arc` symbol.\n *\n * @name Highcharts.SymbolOptionsObject#start\n * @type {number|undefined}\n */\n (''); // keeps doclets above in transpiled file\n\n return SVGRenderer;\n });\n _registerModule(_modules, 'Core/Renderer/HTML/HTMLElement.js', [_modules['Core/Globals.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (H, SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var isFirefox = H.isFirefox,\n isMS = H.isMS,\n isWebKit = H.isWebKit,\n win = H.win;\n var css = U.css,\n defined = U.defined,\n extend = U.extend,\n pick = U.pick,\n pInt = U.pInt;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable valid-jsdoc */\n var HTMLElement = /** @class */ (function (_super) {\n __extends(HTMLElement, _super);\n function HTMLElement() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Modifies SVGElement to support HTML elements.\n * @private\n */\n HTMLElement.compose = function (SVGElementClass) {\n if (HTMLElement.composedClasses.indexOf(SVGElementClass) === -1) {\n HTMLElement.composedClasses.push(SVGElementClass);\n var htmlElementProto = HTMLElement.prototype,\n svgElementProto = SVGElementClass.prototype;\n svgElementProto.getSpanCorrection = htmlElementProto\n .getSpanCorrection;\n svgElementProto.htmlCss = htmlElementProto.htmlCss;\n svgElementProto.htmlGetBBox = htmlElementProto.htmlGetBBox;\n svgElementProto.htmlUpdateTransform = htmlElementProto\n .htmlUpdateTransform;\n svgElementProto.setSpanRotation = htmlElementProto.setSpanRotation;\n }\n return SVGElementClass;\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get the correction in X and Y positioning as the element is rotated.\n * @private\n */\n HTMLElement.prototype.getSpanCorrection = function (width, baseline, alignCorrection) {\n this.xCorr = -width * alignCorrection;\n this.yCorr = -baseline;\n };\n /**\n * Apply CSS to HTML elements. This is used in text within SVG rendering and\n * by the VML renderer\n * @private\n */\n HTMLElement.prototype.htmlCss = function (styles) {\n var wrapper = this,\n element = wrapper.element, \n // When setting or unsetting the width style, we need to update\n // transform (#8809)\n isSettingWidth = (element.tagName === 'SPAN' &&\n styles &&\n 'width' in styles),\n textWidth = pick(isSettingWidth && styles.width,\n void 0);\n var doTransform;\n if (isSettingWidth) {\n delete styles.width;\n wrapper.textWidth = textWidth;\n doTransform = true;\n }\n if (styles && styles.textOverflow === 'ellipsis') {\n styles.whiteSpace = 'nowrap';\n styles.overflow = 'hidden';\n }\n wrapper.styles = extend(wrapper.styles, styles);\n css(wrapper.element, styles);\n // Now that all styles are applied, to the transform\n if (doTransform) {\n wrapper.htmlUpdateTransform();\n }\n return wrapper;\n };\n /**\n * VML and useHTML method for calculating the bounding box based on offsets.\n */\n HTMLElement.prototype.htmlGetBBox = function () {\n var wrapper = this,\n element = wrapper.element;\n return {\n x: element.offsetLeft,\n y: element.offsetTop,\n width: element.offsetWidth,\n height: element.offsetHeight\n };\n };\n /**\n * VML override private method to update elements based on internal\n * properties based on SVG transform.\n * @private\n */\n HTMLElement.prototype.htmlUpdateTransform = function () {\n // aligning non added elements is expensive\n if (!this.added) {\n this.alignOnAdd = true;\n return;\n }\n var wrapper = this,\n renderer = wrapper.renderer,\n elem = wrapper.element,\n translateX = wrapper.translateX || 0,\n translateY = wrapper.translateY || 0,\n x = wrapper.x || 0,\n y = wrapper.y || 0,\n align = wrapper.textAlign || 'left',\n alignCorrection = {\n left: 0,\n center: 0.5,\n right: 1\n }[align],\n styles = wrapper.styles,\n whiteSpace = styles && styles.whiteSpace;\n /** @private */\n function getTextPxLength() {\n if (wrapper.textPxLength) {\n return wrapper.textPxLength;\n }\n // Reset multiline/ellipsis in order to read width (#4928,\n // #5417)\n css(elem, {\n width: '',\n whiteSpace: whiteSpace || 'nowrap'\n });\n return elem.offsetWidth;\n }\n // apply translate\n css(elem, {\n marginLeft: translateX,\n marginTop: translateY\n });\n if (!renderer.styledMode && wrapper.shadows) { // used in labels/tooltip\n wrapper.shadows.forEach(function (shadow) {\n css(shadow, {\n marginLeft: translateX + 1,\n marginTop: translateY + 1\n });\n });\n }\n // apply inversion\n if (wrapper.inverted) { // wrapper is a group\n [].forEach.call(elem.childNodes, function (child) {\n renderer.invertChild(child, elem);\n });\n }\n if (elem.tagName === 'SPAN') {\n var rotation = wrapper.rotation, textWidth = wrapper.textWidth && pInt(wrapper.textWidth), currentTextTransform = [\n rotation,\n align,\n elem.innerHTML,\n wrapper.textWidth,\n wrapper.textAlign\n ].join(',');\n var baseline = void 0,\n hasBoxWidthChanged = false;\n // Update textWidth. Use the memoized textPxLength if possible, to\n // avoid the getTextPxLength function using elem.offsetWidth.\n // Calling offsetWidth affects rendering time as it forces layout\n // (#7656).\n if (textWidth !== wrapper.oldTextWidth) { // #983, #1254\n var textPxLength = getTextPxLength();\n if (((textWidth > wrapper.oldTextWidth) ||\n textPxLength > textWidth) && (\n // Only set the width if the text is able to word-wrap,\n // or text-overflow is ellipsis (#9537)\n /[ \\-]/.test(elem.textContent || elem.innerText) ||\n elem.style.textOverflow === 'ellipsis')) {\n css(elem, {\n width: (textPxLength > textWidth) || rotation ?\n textWidth + 'px' :\n 'auto',\n display: 'block',\n whiteSpace: whiteSpace || 'normal' // #3331\n });\n wrapper.oldTextWidth = textWidth;\n hasBoxWidthChanged = true; // #8159\n }\n }\n wrapper.hasBoxWidthChanged = hasBoxWidthChanged; // #8159\n // Do the calculations and DOM access only if properties changed\n if (currentTextTransform !== wrapper.cTT) {\n baseline = renderer.fontMetrics(elem.style.fontSize, elem).b;\n // Renderer specific handling of span rotation, but only if we\n // have something to update.\n if (defined(rotation) &&\n ((rotation !== (wrapper.oldRotation || 0)) ||\n (align !== wrapper.oldAlign))) {\n wrapper.setSpanRotation(rotation, alignCorrection, baseline);\n }\n wrapper.getSpanCorrection(\n // Avoid elem.offsetWidth if we can, it affects rendering\n // time heavily (#7656)\n ((!defined(rotation) && wrapper.textPxLength) || // #7920\n elem.offsetWidth), baseline, alignCorrection, rotation, align);\n }\n // apply position with correction\n css(elem, {\n left: (x + (wrapper.xCorr || 0)) + 'px',\n top: (y + (wrapper.yCorr || 0)) + 'px'\n });\n // record current text transform\n wrapper.cTT = currentTextTransform;\n wrapper.oldRotation = rotation;\n wrapper.oldAlign = align;\n }\n };\n /**\n * Set the rotation of an individual HTML span.\n * @private\n */\n HTMLElement.prototype.setSpanRotation = function (rotation, alignCorrection, baseline) {\n var getTransformKey = function () { return (isMS &&\n !/Edge/.test(win.navigator.userAgent) ?\n '-ms-transform' :\n isWebKit ?\n '-webkit-transform' :\n isFirefox ?\n 'MozTransform' :\n win.opera ?\n '-o-transform' :\n void 0); };\n var rotationStyle = {},\n cssTransformKey = getTransformKey();\n if (cssTransformKey) {\n rotationStyle[cssTransformKey] = rotationStyle.transform =\n 'rotate(' + rotation + 'deg)';\n rotationStyle[cssTransformKey + (isFirefox ? 'Origin' : '-origin')] = rotationStyle.transformOrigin =\n (alignCorrection * 100) + '% ' + baseline + 'px';\n css(this.element, rotationStyle);\n }\n };\n /* *\n *\n * Static Properties\n *\n * */\n HTMLElement.composedClasses = [];\n return HTMLElement;\n }(SVGElement));\n /* *\n *\n * Default Export\n *\n * */\n\n return HTMLElement;\n });\n _registerModule(_modules, 'Core/Renderer/HTML/HTMLRenderer.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Utilities.js']], function (AST, SVGElement, SVGRenderer, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var attr = U.attr,\n createElement = U.createElement,\n extend = U.extend,\n pick = U.pick;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable valid-jsdoc */\n // Extend SvgRenderer for useHTML option.\n var HTMLRenderer = /** @class */ (function (_super) {\n __extends(HTMLRenderer, _super);\n function HTMLRenderer() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n /* *\n *\n * Static Functions\n *\n * */\n /** @private */\n HTMLRenderer.compose = function (SVGRendererClass) {\n if (HTMLRenderer.composedClasses.indexOf(SVGRendererClass) === -1) {\n HTMLRenderer.composedClasses.push(SVGRendererClass);\n var htmlRendererProto = HTMLRenderer.prototype,\n svgRendererProto = SVGRendererClass.prototype;\n svgRendererProto.html = htmlRendererProto.html;\n }\n return SVGRendererClass;\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Create HTML text node. This is used by the VML renderer as well as the\n * SVG renderer through the useHTML option.\n *\n * @private\n * @function Highcharts.SVGRenderer#html\n *\n * @param {string} str\n * The text of (subset) HTML to draw.\n *\n * @param {number} x\n * The x position of the text's lower left corner.\n *\n * @param {number} y\n * The y position of the text's lower left corner.\n *\n * @return {Highcharts.HTMLDOMElement}\n * HTML element.\n */\n HTMLRenderer.prototype.html = function (str, x, y) {\n var wrapper = this.createElement('span'), element = wrapper.element, renderer = wrapper.renderer, isSVG = renderer.isSVG, addSetters = function (gWrapper, style) {\n // These properties are set as attributes on the SVG group, and\n // as identical CSS properties on the div. (#3542)\n ['opacity', 'visibility'].forEach(function (prop) {\n gWrapper[prop + 'Setter'] = function (value, key, elem) {\n var styleObject = gWrapper.div ?\n gWrapper.div.style :\n style;\n SVGElement.prototype[prop + 'Setter']\n .call(this, value, key, elem);\n if (styleObject) {\n styleObject[key] = value;\n }\n };\n });\n gWrapper.addedSetters = true;\n };\n // Text setter\n wrapper.textSetter = function (value) {\n if (value !== this.textStr) {\n delete this.bBox;\n delete this.oldTextWidth;\n AST.setElementHTML(this.element, pick(value, ''));\n this.textStr = value;\n wrapper.doTransform = true;\n }\n };\n // Add setters for the element itself (#4938)\n if (isSVG) { // #4938, only for HTML within SVG\n addSetters(wrapper, wrapper.element.style);\n }\n // Various setters which rely on update transform\n wrapper.xSetter =\n wrapper.ySetter =\n wrapper.alignSetter =\n wrapper.rotationSetter =\n function (value, key) {\n if (key === 'align') {\n // Do not overwrite the SVGElement.align method. Same as VML.\n wrapper.alignValue = wrapper.textAlign = value;\n }\n else {\n wrapper[key] = value;\n }\n wrapper.doTransform = true;\n };\n // Runs at the end of .attr()\n wrapper.afterSetters = function () {\n // Update transform. Do this outside the loop to prevent redundant\n // updating for batch setting of attributes.\n if (this.doTransform) {\n this.htmlUpdateTransform();\n this.doTransform = false;\n }\n };\n // Set the default attributes\n wrapper\n .attr({\n text: str,\n x: Math.round(x),\n y: Math.round(y)\n })\n .css({\n position: 'absolute'\n });\n if (!renderer.styledMode) {\n wrapper.css({\n fontFamily: this.style.fontFamily,\n fontSize: this.style.fontSize\n });\n }\n // Keep the whiteSpace style outside the wrapper.styles collection\n element.style.whiteSpace = 'nowrap';\n // Use the HTML specific .css method\n wrapper.css = wrapper.htmlCss;\n // This is specific for HTML within SVG\n if (isSVG) {\n wrapper.add = function (svgGroupWrapper) {\n var container = renderer.box.parentNode,\n parents = [];\n var htmlGroup,\n parentGroup;\n this.parentGroup = svgGroupWrapper;\n // Create a mock group to hold the HTML elements\n if (svgGroupWrapper) {\n htmlGroup = svgGroupWrapper.div;\n if (!htmlGroup) {\n // Read the parent chain into an array and read from top\n // down\n parentGroup = svgGroupWrapper;\n while (parentGroup) {\n parents.push(parentGroup);\n // Move up to the next parent group\n parentGroup = parentGroup.parentGroup;\n }\n // Ensure dynamically updating position when any parent\n // is translated\n parents.reverse().forEach(function (parentGroup) {\n var cls = attr(parentGroup.element, 'class');\n /**\n * Common translate setter for X and Y on the HTML\n * group. Reverted the fix for #6957 du to\n * positioning problems and offline export (#7254,\n * #7280, #7529)\n * @private\n * @param {*} value\n * @param {string} key\n */\n function translateSetter(value, key) {\n parentGroup[key] = value;\n if (key === 'translateX') {\n htmlGroupStyle.left = value + 'px';\n }\n else {\n htmlGroupStyle.top = value + 'px';\n }\n parentGroup.doTransform = true;\n }\n // Create a HTML div and append it to the parent div\n // to emulate the SVG group structure\n var parentGroupStyles = parentGroup.styles || {};\n htmlGroup =\n parentGroup.div =\n parentGroup.div || createElement('div', cls ? { className: cls } : void 0, {\n position: 'absolute',\n left: (parentGroup.translateX || 0) + 'px',\n top: (parentGroup.translateY || 0) + 'px',\n display: parentGroup.display,\n opacity: parentGroup.opacity,\n cursor: parentGroupStyles.cursor,\n pointerEvents: (\n // #5595\n parentGroupStyles.pointerEvents),\n visibility: parentGroup.visibility\n // the top group is appended to container\n }, htmlGroup || container);\n // Shortcut\n var htmlGroupStyle = htmlGroup.style;\n // Set listeners to update the HTML div's position\n // whenever the SVG group position is changed.\n extend(parentGroup, {\n // (#7287) Pass htmlGroup to use\n // the related group\n classSetter: (function (htmlGroup) {\n return function (value) {\n this.element.setAttribute('class', value);\n htmlGroup.className = value;\n };\n }(htmlGroup)),\n on: function () {\n if (parents[0].div) { // #6418\n wrapper.on.apply({\n element: parents[0].div,\n onEvents: parentGroup.onEvents\n }, arguments);\n }\n return parentGroup;\n },\n translateXSetter: translateSetter,\n translateYSetter: translateSetter\n });\n if (!parentGroup.addedSetters) {\n addSetters(parentGroup);\n }\n });\n }\n }\n else {\n htmlGroup = container;\n }\n htmlGroup.appendChild(element);\n // Shared with VML:\n wrapper.added = true;\n if (wrapper.alignOnAdd) {\n wrapper.htmlUpdateTransform();\n }\n return wrapper;\n };\n }\n return wrapper;\n };\n /* *\n *\n * Static Properties\n *\n * */\n HTMLRenderer.composedClasses = [];\n return HTMLRenderer;\n }(SVGRenderer));\n /* *\n *\n * Default Export\n *\n * */\n\n return HTMLRenderer;\n });\n _registerModule(_modules, 'Core/Axis/AxisDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Namespace\n *\n * */\n var AxisDefaults;\n (function (AxisDefaults) {\n /* *\n *\n * Constants\n *\n * */\n /**\n * The X axis or category axis. Normally this is the horizontal axis,\n * though if the chart is inverted this is the vertical axis. In case of\n * multiple axes, the xAxis node is an array of configuration objects.\n *\n * See the [Axis class](/class-reference/Highcharts.Axis) for programmatic\n * access to the axis.\n *\n * @productdesc {highmaps}\n * In Highmaps, the axis is hidden, but it is used behind the scenes to\n * control features like zooming and panning. Zooming is in effect the same\n * as setting the extremes of one of the exes.\n *\n * @type {*|Array<*>}\n * @optionparent xAxis\n */\n AxisDefaults.defaultXAxisOptions = {\n /**\n * When using multiple axis, the ticks of two or more opposite axes\n * will automatically be aligned by adding ticks to the axis or axes\n * with the least ticks, as if `tickAmount` were specified.\n *\n * This can be prevented by setting `alignTicks` to false. If the grid\n * lines look messy, it's a good idea to hide them for the secondary\n * axis by setting `gridLineWidth` to 0.\n *\n * If `startOnTick` or `endOnTick` in an Axis options are set to false,\n * then the `alignTicks ` will be disabled for the Axis.\n *\n * Disabled for logarithmic axes.\n *\n * @product highcharts highstock gantt\n */\n alignTicks: true,\n /**\n * Whether to allow decimals in this axis' ticks. When counting\n * integers, like persons or hits on a web page, decimals should\n * be avoided in the labels. By default, decimals are allowed on small\n * scale axes.\n *\n * @see [minTickInterval](#xAxis.minTickInterval)\n *\n * @sample {highcharts|highstock} highcharts/yaxis/allowdecimals-true/\n * True by default\n * @sample {highcharts|highstock} highcharts/yaxis/allowdecimals-false/\n * False\n *\n * @type {boolean|undefined}\n * @default undefined\n * @since 2.0\n */\n allowDecimals: void 0,\n /**\n * When using an alternate grid color, a band is painted across the\n * plot area between every other grid line.\n *\n * @sample {highcharts} highcharts/yaxis/alternategridcolor/\n * Alternate grid color on the Y axis\n * @sample {highstock} stock/xaxis/alternategridcolor/\n * Alternate grid color on the Y axis\n *\n * @type {Highcharts.ColorType}\n * @apioption xAxis.alternateGridColor\n */\n /**\n * An array defining breaks in the axis, the sections defined will be\n * left out and all the points shifted closer to each other.\n *\n * @productdesc {highcharts}\n * Requires that the broken-axis.js module is loaded.\n *\n * @sample {highcharts} highcharts/axisbreak/break-simple/\n * Simple break\n * @sample {highcharts|highstock} highcharts/axisbreak/break-visualized/\n * Advanced with callback\n * @sample {highstock} stock/demo/intraday-breaks/\n * Break on nights and weekends\n *\n * @type {Array<*>}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks\n */\n /**\n * A number indicating how much space should be left between the start\n * and the end of the break. The break size is given in axis units,\n * so for instance on a `datetime` axis, a break size of 3600000 would\n * indicate the equivalent of an hour.\n *\n * @type {number}\n * @default 0\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks.breakSize\n */\n /**\n * The point where the break starts.\n *\n * @type {number}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks.from\n */\n /**\n * Defines an interval after which the break appears again. By default\n * the breaks do not repeat.\n *\n * @type {number}\n * @default 0\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks.repeat\n */\n /**\n * The point where the break ends.\n *\n * @type {number}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks.to\n */\n /**\n * If categories are present for the xAxis, names are used instead of\n * numbers for that axis.\n *\n * Since Highcharts 3.0, categories can also\n * be extracted by giving each point a [name](#series.data) and setting\n * axis [type](#xAxis.type) to `category`. However, if you have multiple\n * series, best practice remains defining the `categories` array.\n *\n * Example: `categories: ['Apples', 'Bananas', 'Oranges']`\n *\n * @sample {highcharts} highcharts/demo/line-labels/\n * With\n * @sample {highcharts} highcharts/xaxis/categories/\n * Without\n *\n * @type {Array}\n * @product highcharts gantt\n * @apioption xAxis.categories\n */\n /**\n * The highest allowed value for automatically computed axis extremes.\n *\n * @see [floor](#xAxis.floor)\n *\n * @sample {highcharts|highstock} highcharts/yaxis/floor-ceiling/\n * Floor and ceiling\n *\n * @type {number}\n * @since 4.0\n * @product highcharts highstock gantt\n * @apioption xAxis.ceiling\n */\n /**\n * A class name that opens for styling the axis by CSS, especially in\n * Highcharts styled mode. The class name is applied to group elements\n * for the grid, axis elements and labels.\n *\n * @sample {highcharts|highstock|highmaps} highcharts/css/axis/\n * Multiple axes with separate styling\n *\n * @type {string}\n * @since 5.0.0\n * @apioption xAxis.className\n */\n /**\n * Configure a crosshair that follows either the mouse pointer or the\n * hovered point.\n *\n * In styled mode, the crosshairs are styled in the\n * `.highcharts-crosshair`, `.highcharts-crosshair-thin` or\n * `.highcharts-xaxis-category` classes.\n *\n * @productdesc {highstock}\n * In Highcharts stock, by default, the crosshair is enabled on the\n * X axis and disabled on the Y axis.\n *\n * @sample {highcharts} highcharts/xaxis/crosshair-both/\n * Crosshair on both axes\n * @sample {highstock} stock/xaxis/crosshairs-xy/\n * Crosshair on both axes, with y axis label\n * @sample {highmaps} highcharts/xaxis/crosshair-both/\n * Crosshair on both axes\n *\n * @declare Highcharts.AxisCrosshairOptions\n * @type {boolean|*}\n * @default false\n * @since 4.1\n * @apioption xAxis.crosshair\n */\n /**\n * A class name for the crosshair, especially as a hook for styling.\n *\n * @type {string}\n * @since 5.0.0\n * @apioption xAxis.crosshair.className\n */\n /**\n * The color of the crosshair. Defaults to `#cccccc` for numeric and\n * datetime axes, and `rgba(204,214,235,0.25)` for category axes, where\n * the crosshair by default highlights the whole category.\n *\n * @sample {highcharts|highstock|highmaps} highcharts/xaxis/crosshair-customized/\n * Customized crosshairs\n *\n * @type {Highcharts.ColorType}\n * @default #cccccc\n * @since 4.1\n * @apioption xAxis.crosshair.color\n */\n /**\n * The dash style for the crosshair. See\n * [plotOptions.series.dashStyle](#plotOptions.series.dashStyle)\n * for possible values.\n *\n * @sample {highcharts|highmaps} highcharts/xaxis/crosshair-dotted/\n * Dotted crosshair\n * @sample {highstock} stock/xaxis/crosshair-dashed/\n * Dashed X axis crosshair\n *\n * @type {Highcharts.DashStyleValue}\n * @default Solid\n * @since 4.1\n * @apioption xAxis.crosshair.dashStyle\n */\n /**\n * A label on the axis next to the crosshair.\n *\n * In styled mode, the label is styled with the\n * `.highcharts-crosshair-label` class.\n *\n * @sample {highstock} stock/xaxis/crosshair-label/\n * Crosshair labels\n * @sample {highstock} highcharts/css/crosshair-label/\n * Style mode\n *\n * @declare Highcharts.AxisCrosshairLabelOptions\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label\n */\n /**\n * Alignment of the label compared to the axis. Defaults to `\"left\"` for\n * right-side axes, `\"right\"` for left-side axes and `\"center\"` for\n * horizontal axes.\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.align\n */\n /**\n * The background color for the label. Defaults to the related series\n * color, or `#666666` if that is not available.\n *\n * @type {Highcharts.ColorType}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.backgroundColor\n */\n /**\n * The border color for the crosshair label\n *\n * @type {Highcharts.ColorType}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.borderColor\n */\n /**\n * The border corner radius of the crosshair label.\n *\n * @type {number}\n * @default 3\n * @since 2.1.10\n * @product highstock\n * @apioption xAxis.crosshair.label.borderRadius\n */\n /**\n * The border width for the crosshair label.\n *\n * @type {number}\n * @default 0\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.borderWidth\n */\n /**\n * Flag to enable crosshair's label.\n *\n * @sample {highstock} stock/xaxis/crosshairs-xy/\n * Enabled label for yAxis' crosshair\n *\n * @type {boolean}\n * @default false\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.enabled\n */\n /**\n * A format string for the crosshair label. Defaults to `{value}` for\n * numeric axes and `{value:%b %d, %Y}` for datetime axes.\n *\n * @type {string}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.format\n */\n /**\n * Formatter function for the label text.\n *\n * @type {Highcharts.XAxisCrosshairLabelFormatterCallbackFunction}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.formatter\n */\n /**\n * Padding inside the crosshair label.\n *\n * @type {number}\n * @default 8\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.padding\n */\n /**\n * The shape to use for the label box.\n *\n * @type {string}\n * @default callout\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.shape\n */\n /**\n * Text styles for the crosshair label.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"white\", \"fontWeight\": \"normal\", \"fontSize\": \"11px\", \"textAlign\": \"center\"}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.style\n */\n /**\n * Whether the crosshair should snap to the point or follow the pointer\n * independent of points.\n *\n * @sample {highcharts|highstock} highcharts/xaxis/crosshair-snap-false/\n * True by default\n * @sample {highmaps} maps/demo/latlon-advanced/\n * Snap is false\n *\n * @type {boolean}\n * @default true\n * @since 4.1\n * @apioption xAxis.crosshair.snap\n */\n /**\n * The pixel width of the crosshair. Defaults to 1 for numeric or\n * datetime axes, and for one category width for category axes.\n *\n * @sample {highcharts} highcharts/xaxis/crosshair-customized/\n * Customized crosshairs\n * @sample {highstock} highcharts/xaxis/crosshair-customized/\n * Customized crosshairs\n * @sample {highmaps} highcharts/xaxis/crosshair-customized/\n * Customized crosshairs\n *\n * @type {number}\n * @default 1\n * @since 4.1\n * @apioption xAxis.crosshair.width\n */\n /**\n * The Z index of the crosshair. Higher Z indices allow drawing the\n * crosshair on top of the series or behind the grid lines.\n *\n * @type {number}\n * @default 2\n * @since 4.1\n * @apioption xAxis.crosshair.zIndex\n */\n /**\n * Whether to pan axis. If `chart.panning` is enabled, the option\n * allows to disable panning on an individual axis.\n */\n panningEnabled: true,\n /**\n * The Z index for the axis group.\n */\n zIndex: 2,\n /**\n * Whether to zoom axis. If `chart.zoomType` is set, the option allows\n * to disable zooming on an individual axis.\n *\n * @sample {highcharts} highcharts/xaxis/zoomenabled/\n * Zoom enabled is false\n */\n zoomEnabled: true,\n /**\n * For a datetime axis, the scale will automatically adjust to the\n * appropriate unit. This member gives the default string\n * representations used for each unit. For intermediate values,\n * different units may be used, for example the `day` unit can be used\n * on midnight and `hour` unit be used for intermediate values on the\n * same axis.\n *\n * For an overview of the replacement codes, see\n * [dateFormat](/class-reference/Highcharts.Time#dateFormat).\n *\n * Defaults to:\n * ```js\n * {\n * millisecond: '%H:%M:%S.%L',\n * second: '%H:%M:%S',\n * minute: '%H:%M',\n * hour: '%H:%M',\n * day: '%e. %b',\n * week: '%e. %b',\n * month: '%b \\'%y',\n * year: '%Y'\n * }\n * ```\n *\n * @sample {highcharts} highcharts/xaxis/datetimelabelformats/\n * Different day format on X axis\n * @sample {highstock} stock/xaxis/datetimelabelformats/\n * More information in x axis labels\n *\n * @declare Highcharts.AxisDateTimeLabelFormatsOptions\n * @product highcharts highstock gantt\n */\n dateTimeLabelFormats: {\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n millisecond: {\n main: '%H:%M:%S.%L',\n range: false\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n second: {\n main: '%H:%M:%S',\n range: false\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n minute: {\n main: '%H:%M',\n range: false\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n hour: {\n main: '%H:%M',\n range: false\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n day: {\n main: '%e. %b'\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n week: {\n main: '%e. %b'\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n month: {\n main: '%b \\'%y'\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n year: {\n main: '%Y'\n }\n },\n /**\n * Whether to force the axis to end on a tick. Use this option with\n * the `maxPadding` option to control the axis end.\n *\n * @productdesc {highstock}\n * In Highcharts Stock, `endOnTick` is always `false` when the navigator\n * is enabled, to prevent jumpy scrolling.\n *\n * @sample {highcharts} highcharts/yaxis/endontick/\n * True by default\n * @sample {highcharts} highcharts/yaxis/endontick-false/\n * False\n * @sample {highstock} stock/demo/basic-line/\n * True by default\n * @sample {highstock} stock/xaxis/endontick/\n * False\n *\n * @since 1.2.0\n */\n endOnTick: false,\n /**\n * Event handlers for the axis.\n *\n * @type {*}\n * @apioption xAxis.events\n */\n /**\n * An event fired after the breaks have rendered.\n *\n * @see [breaks](#xAxis.breaks)\n *\n * @sample {highcharts} highcharts/axisbreak/break-event/\n * AfterBreak Event\n *\n * @type {Highcharts.AxisEventCallbackFunction}\n * @since 4.1.0\n * @product highcharts gantt\n * @apioption xAxis.events.afterBreaks\n */\n /**\n * As opposed to the `setExtremes` event, this event fires after the\n * final min and max values are computed and corrected for `minRange`.\n *\n * Fires when the minimum and maximum is set for the axis, either by\n * calling the `.setExtremes()` method or by selecting an area in the\n * chart. One parameter, `event`, is passed to the function, containing\n * common event information.\n *\n * The new user set minimum and maximum values can be found by\n * `event.min` and `event.max`. These reflect the axis minimum and\n * maximum in axis values. The actual data extremes are found in\n * `event.dataMin` and `event.dataMax`.\n *\n * @type {Highcharts.AxisSetExtremesEventCallbackFunction}\n * @since 2.3\n * @context Highcharts.Axis\n * @apioption xAxis.events.afterSetExtremes\n */\n /**\n * An event fired when a break from this axis occurs on a point.\n *\n * @see [breaks](#xAxis.breaks)\n *\n * @sample {highcharts} highcharts/axisbreak/break-visualized/\n * Visualization of a Break\n *\n * @type {Highcharts.AxisPointBreakEventCallbackFunction}\n * @since 4.1.0\n * @product highcharts gantt\n * @context Highcharts.Axis\n * @apioption xAxis.events.pointBreak\n */\n /**\n * An event fired when a point falls inside a break from this axis.\n *\n * @type {Highcharts.AxisPointBreakEventCallbackFunction}\n * @product highcharts highstock gantt\n * @context Highcharts.Axis\n * @apioption xAxis.events.pointInBreak\n */\n /**\n * Fires when the minimum and maximum is set for the axis, either by\n * calling the `.setExtremes()` method or by selecting an area in the\n * chart. One parameter, `event`, is passed to the function,\n * containing common event information.\n *\n * The new user set minimum and maximum values can be found by\n * `event.min` and `event.max`. These reflect the axis minimum and\n * maximum in data values. When an axis is zoomed all the way out from\n * the \"Reset zoom\" button, `event.min` and `event.max` are null, and\n * the new extremes are set based on `this.dataMin` and `this.dataMax`.\n *\n * @sample {highstock} stock/xaxis/events-setextremes/\n * Log new extremes on x axis\n *\n * @type {Highcharts.AxisSetExtremesEventCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Axis\n * @apioption xAxis.events.setExtremes\n */\n /**\n * The lowest allowed value for automatically computed axis extremes.\n *\n * @see [ceiling](#yAxis.ceiling)\n *\n * @sample {highcharts} highcharts/yaxis/floor-ceiling/\n * Floor and ceiling\n * @sample {highstock} stock/demo/lazy-loading/\n * Prevent negative stock price on Y axis\n *\n * @type {number}\n * @since 4.0\n * @product highcharts highstock gantt\n * @apioption xAxis.floor\n */\n /**\n * The dash or dot style of the grid lines. For possible values, see\n * [this demonstration](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-dashstyle-all/).\n *\n * @sample {highcharts} highcharts/yaxis/gridlinedashstyle/\n * Long dashes\n * @sample {highstock} stock/xaxis/gridlinedashstyle/\n * Long dashes\n *\n * @type {Highcharts.DashStyleValue}\n * @since 1.2\n */\n gridLineDashStyle: 'Solid',\n /**\n * The Z index of the grid lines.\n *\n * @sample {highcharts|highstock} highcharts/xaxis/gridzindex/\n * A Z index of 4 renders the grid above the graph\n *\n * @product highcharts highstock gantt\n */\n gridZIndex: 1,\n /**\n * An id for the axis. This can be used after render time to get\n * a pointer to the axis object through `chart.get()`.\n *\n * @sample {highcharts} highcharts/xaxis/id/\n * Get the object\n * @sample {highstock} stock/xaxis/id/\n * Get the object\n *\n * @type {string}\n * @since 1.2.0\n * @apioption xAxis.id\n */\n /**\n * The axis labels show the number or category for each tick.\n *\n * Since v8.0.0: Labels are animated in categorized x-axis with\n * updating data if `tickInterval` and `step` is set to 1.\n *\n * @productdesc {highmaps}\n * X and Y axis labels are by default disabled in Highmaps, but the\n * functionality is inherited from Highcharts and used on `colorAxis`,\n * and can be enabled on X and Y axes too.\n */\n labels: {\n /**\n * What part of the string the given position is anchored to.\n * If `left`, the left side of the string is at the axis position.\n * Can be one of `\"left\"`, `\"center\"` or `\"right\"`. Defaults to\n * an intelligent guess based on which side of the chart the axis\n * is on and the rotation of the label.\n *\n * @see [reserveSpace](#xAxis.labels.reserveSpace)\n *\n * @sample {highcharts} highcharts/xaxis/labels-align-left/\n * Left\n * @sample {highcharts} highcharts/xaxis/labels-align-right/\n * Right\n * @sample {highcharts} highcharts/xaxis/labels-reservespace-true/\n * Left-aligned labels on a vertical category axis\n *\n * @type {Highcharts.AlignValue}\n * @apioption xAxis.labels.align\n */\n /**\n * Whether to allow the axis labels to overlap.\n * When false, overlapping labels are hidden.\n *\n * @sample {highcharts} highcharts/xaxis/labels-allowoverlap-true/\n * X axis labels overlap enabled\n *\n * @type {boolean}\n * @default false\n * @apioption xAxis.labels.allowOverlap\n *\n */\n /**\n * For horizontal axes, the allowed degrees of label rotation\n * to prevent overlapping labels. If there is enough space,\n * labels are not rotated. As the chart gets narrower, it\n * will start rotating the labels -45 degrees, then remove\n * every second label and try again with rotations 0 and -45 etc.\n * Set it to `undefined` to disable rotation, which will\n * cause the labels to word-wrap if possible. Defaults to `[-45]``\n * on bottom and top axes, `undefined` on left and right axes.\n *\n * @sample {highcharts|highstock} highcharts/xaxis/labels-autorotation-default/\n * Default auto rotation of 0 or -45\n * @sample {highcharts|highstock} highcharts/xaxis/labels-autorotation-0-90/\n * Custom graded auto rotation\n *\n * @type {Array}\n * @default undefined\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.labels.autoRotation\n */\n autoRotation: void 0,\n /**\n * When each category width is more than this many pixels, we don't\n * apply auto rotation. Instead, we lay out the axis label with word\n * wrap. A lower limit makes sense when the label contains multiple\n * short words that don't extend the available horizontal space for\n * each label.\n *\n * @sample {highcharts} highcharts/xaxis/labels-autorotationlimit/\n * Lower limit\n *\n * @since 4.1.5\n * @product highcharts gantt\n */\n autoRotationLimit: 80,\n /**\n * Polar charts only. The label's pixel distance from the perimeter\n * of the plot area.\n *\n * @type {number}\n * @default undefined\n * @product highcharts gantt\n */\n distance: void 0,\n /**\n * Enable or disable the axis labels.\n *\n * @sample {highcharts} highcharts/xaxis/labels-enabled/\n * X axis labels disabled\n * @sample {highstock} stock/xaxis/labels-enabled/\n * X axis labels disabled\n *\n * @default {highcharts|highstock|gantt} true\n * @default {highmaps} false\n */\n enabled: true,\n /**\n * A format string for the axis label. The context is available as\n * format string variables. For example, you can use `{text}` to\n * insert the default formatted text. The recommended way of adding\n * units for the label is using `text`, for example `{text} km`.\n *\n * To add custom numeric or datetime formatting, use `{value}` with\n * formatting, for example `{value:.1f}` or `{value:%Y-%m-%d}`.\n *\n * See\n * [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for more examples of formatting.\n *\n * The default value is not specified due to the dynamic\n * nature of the default implementation.\n *\n * @sample {highcharts|highstock} highcharts/yaxis/labels-format/\n * Add units to Y axis label\n * @sample {highcharts} highcharts/xaxis/labels-format-linked/\n * Linked category names\n * @sample {highcharts} highcharts/xaxis/labels-format-custom/\n * Custom number format\n *\n * @type {string}\n * @since 3.0\n * @apioption xAxis.labels.format\n */\n /**\n * Callback JavaScript function to format the label. The value\n * is given by `this.value`. Additional properties for `this` are\n * `axis`, `chart`, `isFirst`, `isLast` and `text` which holds the\n * value of the default formatter.\n *\n * Defaults to a built in function returning a formatted string\n * depending on whether the axis is `category`, `datetime`,\n * `numeric` or other.\n *\n * @sample {highcharts} highcharts/xaxis/labels-formatter-linked/\n * Linked category names\n * @sample {highcharts} highcharts/xaxis/labels-formatter-extended/\n * Modified numeric labels\n * @sample {highstock} stock/xaxis/labels-formatter/\n * Added units on Y axis\n *\n * @type {Highcharts.AxisLabelsFormatterCallbackFunction}\n * @apioption xAxis.labels.formatter\n */\n /**\n * The number of pixels to indent the labels per level in a treegrid\n * axis.\n *\n * @sample gantt/treegrid-axis/demo\n * Indentation 10px by default.\n * @sample gantt/treegrid-axis/indentation-0px\n * Indentation set to 0px.\n *\n * @product gantt\n */\n indentation: 10,\n /**\n * Horizontal axis only. When `staggerLines` is not set,\n * `maxStaggerLines` defines how many lines the axis is allowed to\n * add to automatically avoid overlapping X labels. Set to `1` to\n * disable overlap detection.\n *\n * @deprecated\n * @type {number}\n * @default 5\n * @since 1.3.3\n * @apioption xAxis.labels.maxStaggerLines\n */\n /**\n * How to handle overflowing labels on horizontal axis. If set to\n * `\"allow\"`, it will not be aligned at all. By default it\n * `\"justify\"` labels inside the chart area. If there is room to\n * move it, it will be aligned to the edge, else it will be removed.\n *\n * @since 2.2.5\n * @validvalue [\"allow\", \"justify\"]\n */\n overflow: 'justify',\n /**\n * The pixel padding for axis labels, to ensure white space between\n * them.\n *\n * @product highcharts gantt\n */\n padding: 5,\n /**\n * Whether to reserve space for the labels. By default, space is\n * reserved for the labels in these cases:\n *\n * * On all horizontal axes.\n * * On vertical axes if `label.align` is `right` on a left-side\n * axis or `left` on a right-side axis.\n * * On vertical axes if `label.align` is `center`.\n *\n * This can be turned off when for example the labels are rendered\n * inside the plot area instead of outside.\n *\n * @see [labels.align](#xAxis.labels.align)\n *\n * @sample {highcharts} highcharts/xaxis/labels-reservespace/\n * No reserved space, labels inside plot\n * @sample {highcharts} highcharts/xaxis/labels-reservespace-true/\n * Left-aligned labels on a vertical category axis\n *\n * @type {boolean}\n * @since 4.1.10\n * @product highcharts gantt\n * @apioption xAxis.labels.reserveSpace\n */\n reserveSpace: void 0,\n /**\n * Rotation of the labels in degrees. When `undefined`, the\n * `autoRotation` option takes precedence.\n *\n * @sample {highcharts} highcharts/xaxis/labels-rotation/\n * X axis labels rotated 90°\n *\n * @type {number}\n * @default 0\n * @apioption xAxis.labels.rotation\n */\n rotation: void 0,\n /**\n * Horizontal axes only. The number of lines to spread the labels\n * over to make room or tighter labels. 0 disables staggering.\n *\n * @sample {highcharts} highcharts/xaxis/labels-staggerlines/\n * Show labels over two lines\n * @sample {highstock} stock/xaxis/labels-staggerlines/\n * Show labels over two lines\n *\n * @since 2.1\n */\n staggerLines: 0,\n /**\n * To show only every _n_'th label on the axis, set the step to _n_.\n * Setting the step to 2 shows every other label.\n *\n * By default, when 0, the step is calculated automatically to avoid\n * overlap. To prevent this, set it to 1\\. This usually only\n * happens on a category axis, and is often a sign that you have\n * chosen the wrong axis type.\n *\n * Read more at\n * [Axis docs](https://www.highcharts.com/docs/chart-concepts/axes)\n * => What axis should I use?\n *\n * @sample {highcharts} highcharts/xaxis/labels-step/\n * Showing only every other axis label on a categorized\n * x-axis\n * @sample {highcharts} highcharts/xaxis/labels-step-auto/\n * Auto steps on a category axis\n *\n * @since 2.1\n */\n step: 0,\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n */\n useHTML: false,\n /**\n * The x position offset of all labels relative to the tick\n * positions on the axis.\n *\n * @sample {highcharts} highcharts/xaxis/labels-x/\n * Y axis labels placed on grid lines\n */\n x: 0,\n /**\n * The y position offset of all labels relative to the tick\n * positions on the axis. The default makes it adapt to the font\n * size of the bottom axis.\n *\n * @sample {highcharts} highcharts/xaxis/labels-x/\n * Y axis labels placed on grid lines\n *\n * @type {number}\n * @apioption xAxis.labels.y\n */\n /**\n * The Z index for the axis labels.\n */\n zIndex: 7,\n /**\n * CSS styles for the label. Use `whiteSpace: 'nowrap'` to prevent\n * wrapping of category labels. Use `textOverflow: 'none'` to\n * prevent ellipsis (dots).\n *\n * In styled mode, the labels are styled with the\n * `.highcharts-axis-labels` class.\n *\n * @sample {highcharts} highcharts/xaxis/labels-style/\n * Red X axis labels\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @internal */\n color: \"#666666\" /* Palette.neutralColor60 */,\n /** @internal */\n cursor: 'default',\n /** @internal */\n fontSize: '11px'\n }\n },\n /**\n * The left position as the horizontal axis. If it's a number, it is\n * interpreted as pixel position relative to the chart.\n *\n * Since Highcharts v5.0.13: If it's a percentage string, it is\n * interpreted as percentages of the plot width, offset from plot area\n * left.\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption xAxis.left\n */\n /**\n * The top position as the vertical axis. If it's a number, it is\n * interpreted as pixel position relative to the chart.\n *\n * Since Highcharts 2: If it's a percentage string, it is interpreted\n * as percentages of the plot height, offset from plot area top.\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption xAxis.top\n */\n /**\n * Index of another axis that this axis is linked to. When an axis is\n * linked to a master axis, it will take the same extremes as\n * the master, but as assigned by min or max or by setExtremes.\n * It can be used to show additional info, or to ease reading the\n * chart by duplicating the scales.\n *\n * @sample {highcharts} highcharts/xaxis/linkedto/\n * Different string formats of the same date\n * @sample {highcharts} highcharts/yaxis/linkedto/\n * Y values on both sides\n *\n * @type {number}\n * @since 2.0.2\n * @product highcharts highstock gantt\n * @apioption xAxis.linkedTo\n */\n /**\n * The maximum value of the axis. If `null`, the max value is\n * automatically calculated.\n *\n * If the [endOnTick](#yAxis.endOnTick) option is true, the `max` value\n * might be rounded up.\n *\n * If a [tickAmount](#yAxis.tickAmount) is set, the axis may be extended\n * beyond the set max in order to reach the given number of ticks. The\n * same may happen in a chart with multiple axes, determined by [chart.\n * alignTicks](#chart), where a `tickAmount` is applied internally.\n *\n * @sample {highcharts} highcharts/yaxis/max-200/\n * Y axis max of 200\n * @sample {highcharts} highcharts/yaxis/max-logarithmic/\n * Y axis max on logarithmic axis\n * @sample {highstock} stock/xaxis/min-max/\n * Fixed min and max on X axis\n *\n * @type {number|null}\n * @apioption xAxis.max\n */\n /**\n * Padding of the max value relative to the length of the axis. A\n * padding of 0.05 will make a 100px axis 5px longer. This is useful\n * when you don't want the highest data value to appear on the edge\n * of the plot area. When the axis' `max` option is set or a max extreme\n * is set using `axis.setExtremes()`, the maxPadding will be ignored.\n *\n * @productdesc {highstock}\n * For an [ordinal](#xAxis.ordinal) axis, `minPadding` and `maxPadding`\n * are ignored. Use [overscroll](#xAxis.overscroll) instead.\n *\n * @sample {highcharts} highcharts/yaxis/maxpadding/\n * Max padding of 0.25 on y axis\n * @sample {highstock} stock/xaxis/minpadding-maxpadding/\n * Greater min- and maxPadding\n * @sample {highmaps} maps/chart/plotbackgroundcolor-gradient/\n * Add some padding\n *\n * @default {highcharts} 0.01\n * @default {highstock|highmaps} 0\n * @since 1.2.0\n */\n maxPadding: 0.01,\n /**\n * Deprecated. Use `minRange` instead.\n *\n * @deprecated\n * @type {number}\n * @product highcharts highstock\n * @apioption xAxis.maxZoom\n */\n /**\n * The minimum value of the axis. If `null` the min value is\n * automatically calculated.\n *\n * If the [startOnTick](#yAxis.startOnTick) option is true (default),\n * the `min` value might be rounded down.\n *\n * The automatically calculated minimum value is also affected by\n * [floor](#yAxis.floor), [softMin](#yAxis.softMin),\n * [minPadding](#yAxis.minPadding), [minRange](#yAxis.minRange)\n * as well as [series.threshold](#plotOptions.series.threshold)\n * and [series.softThreshold](#plotOptions.series.softThreshold).\n *\n * @sample {highcharts} highcharts/yaxis/min-startontick-false/\n * -50 with startOnTick to false\n * @sample {highcharts} highcharts/yaxis/min-startontick-true/\n * -50 with startOnTick true by default\n * @sample {highstock} stock/xaxis/min-max/\n * Set min and max on X axis\n *\n * @type {number|null}\n * @apioption xAxis.min\n */\n /**\n * The dash or dot style of the minor grid lines. For possible values,\n * see [this demonstration](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-dashstyle-all/).\n *\n * @sample {highcharts} highcharts/yaxis/minorgridlinedashstyle/\n * Long dashes on minor grid lines\n * @sample {highstock} stock/xaxis/minorgridlinedashstyle/\n * Long dashes on minor grid lines\n *\n * @type {Highcharts.DashStyleValue}\n * @since 1.2\n */\n minorGridLineDashStyle: 'Solid',\n /**\n * Specific tick interval in axis units for the minor ticks. On a linear\n * axis, if `\"auto\"`, the minor tick interval is calculated as a fifth\n * of the tickInterval. If `null` or `undefined`, minor ticks are not\n * shown.\n *\n * On logarithmic axes, the unit is the power of the value. For example,\n * setting the minorTickInterval to 1 puts one tick on each of 0.1, 1,\n * 10, 100 etc. Setting the minorTickInterval to 0.1 produces 9 ticks\n * between 1 and 10, 10 and 100 etc.\n *\n * If user settings dictate minor ticks to become too dense, they don't\n * make sense, and will be ignored to prevent performance problems.\n *\n * @sample {highcharts} highcharts/yaxis/minortickinterval-null/\n * Null by default\n * @sample {highcharts} highcharts/yaxis/minortickinterval-5/\n * 5 units\n * @sample {highcharts} highcharts/yaxis/minortickinterval-log-auto/\n * \"auto\"\n * @sample {highcharts} highcharts/yaxis/minortickinterval-log/\n * 0.1\n * @sample {highstock} stock/demo/basic-line/\n * Null by default\n * @sample {highstock} stock/xaxis/minortickinterval-auto/\n * \"auto\"\n *\n * @type {number|string|null}\n * @apioption xAxis.minorTickInterval\n */\n /**\n * The pixel length of the minor tick marks.\n *\n * @sample {highcharts} highcharts/yaxis/minorticklength/\n * 10px on Y axis\n * @sample {highstock} stock/xaxis/minorticks/\n * 10px on Y axis\n */\n minorTickLength: 2,\n /**\n * The position of the minor tick marks relative to the axis line.\n * Can be one of `inside` and `outside`.\n *\n * @sample {highcharts} highcharts/yaxis/minortickposition-outside/\n * Outside by default\n * @sample {highcharts} highcharts/yaxis/minortickposition-inside/\n * Inside\n * @sample {highstock} stock/xaxis/minorticks/\n * Inside\n *\n * @validvalue [\"inside\", \"outside\"]\n */\n minorTickPosition: 'outside',\n /**\n * Enable or disable minor ticks. Unless\n * [minorTickInterval](#xAxis.minorTickInterval) is set, the tick\n * interval is calculated as a fifth of the `tickInterval`.\n *\n * On a logarithmic axis, minor ticks are laid out based on a best\n * guess, attempting to enter approximately 5 minor ticks between\n * each major tick.\n *\n * Prior to v6.0.0, ticks were unabled in auto layout by setting\n * `minorTickInterval` to `\"auto\"`.\n *\n * @productdesc {highcharts}\n * On axes using [categories](#xAxis.categories), minor ticks are not\n * supported.\n *\n * @sample {highcharts} highcharts/yaxis/minorticks-true/\n * Enabled on linear Y axis\n *\n * @type {boolean}\n * @default false\n * @since 6.0.0\n * @apioption xAxis.minorTicks\n */\n /**\n * The pixel width of the minor tick mark.\n *\n * @sample {highcharts} highcharts/yaxis/minortickwidth/\n * 3px width\n * @sample {highstock} stock/xaxis/minorticks/\n * 1px width\n *\n * @type {number}\n * @default 0\n * @apioption xAxis.minorTickWidth\n */\n /**\n * Padding of the min value relative to the length of the axis. A\n * padding of 0.05 will make a 100px axis 5px longer. This is useful\n * when you don't want the lowest data value to appear on the edge\n * of the plot area. When the axis' `min` option is set or a min extreme\n * is set using `axis.setExtremes()`, the minPadding will be ignored.\n *\n * @productdesc {highstock}\n * For an [ordinal](#xAxis.ordinal) axis, `minPadding` and `maxPadding`\n * are ignored. Use [overscroll](#xAxis.overscroll) instead.\n *\n * @sample {highcharts} highcharts/yaxis/minpadding/\n * Min padding of 0.2\n * @sample {highstock} stock/xaxis/minpadding-maxpadding/\n * Greater min- and maxPadding\n * @sample {highmaps} maps/chart/plotbackgroundcolor-gradient/\n * Add some padding\n *\n * @default {highcharts} 0.01\n * @default {highstock|highmaps} 0\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n minPadding: 0.01,\n /**\n * The minimum range to display on this axis. The entire axis will not\n * be allowed to span over a smaller interval than this. For example,\n * for a datetime axis the main unit is milliseconds. If minRange is\n * set to 3600000, you can't zoom in more than to one hour.\n *\n * The default minRange for the x axis is five times the smallest\n * interval between any of the data points.\n *\n * On a logarithmic axis, the unit for the minimum range is the power.\n * So a minRange of 1 means that the axis can be zoomed to 10-100,\n * 100-1000, 1000-10000 etc.\n *\n * **Note**: The `minPadding`, `maxPadding`, `startOnTick` and\n * `endOnTick` settings also affect how the extremes of the axis\n * are computed.\n *\n * @sample {highcharts} highcharts/xaxis/minrange/\n * Minimum range of 5\n * @sample {highstock} stock/xaxis/minrange/\n * Max zoom of 6 months overrides user selections\n *\n * @type {number}\n * @apioption xAxis.minRange\n */\n /**\n * The minimum tick interval allowed in axis values. For example on\n * zooming in on an axis with daily data, this can be used to prevent\n * the axis from showing hours. Defaults to the closest distance between\n * two points on the axis.\n *\n * @type {number}\n * @since 2.3.0\n * @apioption xAxis.minTickInterval\n */\n /**\n * The distance in pixels from the plot area to the axis line.\n * A positive offset moves the axis with it's line, labels and ticks\n * away from the plot area. This is typically used when two or more\n * axes are displayed on the same side of the plot. With multiple\n * axes the offset is dynamically adjusted to avoid collision, this\n * can be overridden by setting offset explicitly.\n *\n * @sample {highcharts} highcharts/yaxis/offset/\n * Y axis offset of 70\n * @sample {highcharts} highcharts/yaxis/offset-centered/\n * Axes positioned in the center of the plot\n * @sample {highstock} stock/xaxis/offset/\n * Y axis offset by 70 px\n *\n * @type {number}\n */\n offset: void 0,\n /**\n * Whether to display the axis on the opposite side of the normal. The\n * normal is on the left side for vertical axes and bottom for\n * horizontal, so the opposite sides will be right and top respectively.\n * This is typically used with dual or multiple axes.\n *\n * @sample {highcharts} highcharts/yaxis/opposite/\n * Secondary Y axis opposite\n * @sample {highstock} stock/xaxis/opposite/\n * Y axis on left side\n *\n * @default {highcharts|highstock|highmaps} false\n * @default {gantt} true\n */\n opposite: false,\n /**\n * In an ordinal axis, the points are equally spaced in the chart\n * regardless of the actual time or x distance between them. This means\n * that missing data periods (e.g. nights or weekends for a stock chart)\n * will not take up space in the chart.\n * Having `ordinal: false` will show any gaps created by the `gapSize`\n * setting proportionate to their duration.\n *\n * In stock charts the X axis is ordinal by default, unless\n * the boost module is used and at least one of the series' data length\n * exceeds the [boostThreshold](#series.line.boostThreshold).\n *\n * For an ordinal axis, `minPadding` and `maxPadding` are ignored. Use\n * [overscroll](#xAxis.overscroll) instead.\n *\n * @sample {highstock} stock/xaxis/ordinal-true/\n * True by default\n * @sample {highstock} stock/xaxis/ordinal-false/\n * False\n *\n * @see [overscroll](#xAxis.overscroll)\n *\n * @type {boolean}\n * @default true\n * @since 1.1\n * @product highstock\n * @apioption xAxis.ordinal\n */\n /**\n * Additional range on the right side of the xAxis. Works similar to\n * `xAxis.maxPadding`, but value is set in milliseconds. Can be set for\n * both main `xAxis` and the navigator's `xAxis`.\n *\n * @sample {highstock} stock/xaxis/overscroll/\n * One minute overscroll with live data\n *\n * @type {number}\n * @default 0\n * @since 6.0.0\n * @product highstock\n * @apioption xAxis.overscroll\n */\n /**\n * Refers to the index in the [panes](#panes) array. Used for circular\n * gauges and polar charts. When the option is not set then first pane\n * will be used.\n *\n * @sample highcharts/demo/gauge-vu-meter\n * Two gauges with different center\n *\n * @type {number}\n * @product highcharts\n * @apioption xAxis.pane\n */\n /**\n * The zoomed range to display when only defining one or none of `min`\n * or `max`. For example, to show the latest month, a range of one month\n * can be set.\n *\n * @sample {highstock} stock/xaxis/range/\n * Setting a zoomed range when the rangeSelector is disabled\n *\n * @type {number}\n * @product highstock\n * @apioption xAxis.range\n */\n /**\n * Whether to reverse the axis so that the highest number is closest\n * to the origin. If the chart is inverted, the x axis is reversed by\n * default.\n *\n * @sample {highcharts} highcharts/yaxis/reversed/\n * Reversed Y axis\n * @sample {highstock} stock/xaxis/reversed/\n * Reversed Y axis\n *\n * @type {boolean}\n * @default undefined\n * @apioption xAxis.reversed\n */\n reversed: void 0,\n /**\n * This option determines how stacks should be ordered within a group.\n * For example reversed xAxis also reverses stacks, so first series\n * comes last in a group. To keep order like for non-reversed xAxis\n * enable this option.\n *\n * @sample {highcharts} highcharts/xaxis/reversedstacks/\n * Reversed stacks comparison\n * @sample {highstock} highcharts/xaxis/reversedstacks/\n * Reversed stacks comparison\n *\n * @since 6.1.1\n * @product highcharts highstock\n */\n reversedStacks: false,\n /**\n * An optional scrollbar to display on the X axis in response to\n * limiting the minimum and maximum of the axis values.\n *\n * In styled mode, all the presentational options for the scrollbar are\n * replaced by the classes `.highcharts-scrollbar-thumb`,\n * `.highcharts-scrollbar-arrow`, `.highcharts-scrollbar-button`,\n * `.highcharts-scrollbar-rifles` and `.highcharts-scrollbar-track`.\n *\n * @sample {highstock} stock/yaxis/heatmap-scrollbars/\n * Heatmap with both scrollbars\n *\n * @extends scrollbar\n * @since 4.2.6\n * @product highstock\n * @apioption xAxis.scrollbar\n */\n /**\n * Whether to show the axis line and title when the axis has no data.\n *\n * @sample {highcharts} highcharts/yaxis/showempty/\n * When clicking the legend to hide series, one axis preserves\n * line and title, the other doesn't\n * @sample {highstock} highcharts/yaxis/showempty/\n * When clicking the legend to hide series, one axis preserves\n * line and title, the other doesn't\n *\n * @since 1.1\n */\n showEmpty: true,\n /**\n * Whether to show the first tick label.\n *\n * @sample {highcharts} highcharts/xaxis/showfirstlabel-false/\n * Set to false on X axis\n * @sample {highstock} stock/xaxis/showfirstlabel/\n * Labels below plot lines on Y axis\n */\n showFirstLabel: true,\n /**\n * Whether to show the last tick label. Defaults to `true` on cartesian\n * charts, and `false` on polar charts.\n *\n * @sample {highcharts} highcharts/xaxis/showlastlabel-true/\n * Set to true on X axis\n * @sample {highstock} stock/xaxis/showfirstlabel/\n * Labels below plot lines on Y axis\n *\n * @type {boolean}\n * @default undefined\n * @product highcharts highstock gantt\n */\n showLastLabel: true,\n /**\n * A soft maximum for the axis. If the series data maximum is less than\n * this, the axis will stay at this maximum, but if the series data\n * maximum is higher, the axis will flex to show all data.\n *\n * @sample highcharts/yaxis/softmin-softmax/\n * Soft min and max\n *\n * @type {number}\n * @since 5.0.1\n * @product highcharts highstock gantt\n * @apioption xAxis.softMax\n */\n /**\n * A soft minimum for the axis. If the series data minimum is greater\n * than this, the axis will stay at this minimum, but if the series\n * data minimum is lower, the axis will flex to show all data.\n *\n * @sample highcharts/yaxis/softmin-softmax/\n * Soft min and max\n *\n * @type {number}\n * @since 5.0.1\n * @product highcharts highstock gantt\n * @apioption xAxis.softMin\n */\n /**\n * For datetime axes, this decides where to put the tick between weeks.\n * 0 = Sunday, 1 = Monday.\n *\n * @sample {highcharts} highcharts/xaxis/startofweek-monday/\n * Monday by default\n * @sample {highcharts} highcharts/xaxis/startofweek-sunday/\n * Sunday\n * @sample {highstock} stock/xaxis/startofweek-1\n * Monday by default\n * @sample {highstock} stock/xaxis/startofweek-0\n * Sunday\n *\n * @product highcharts highstock gantt\n */\n startOfWeek: 1,\n /**\n * Whether to force the axis to start on a tick. Use this option with\n * the `minPadding` option to control the axis start.\n *\n * @productdesc {highstock}\n * In Highcharts Stock, `startOnTick` is always `false` when\n * the navigator is enabled, to prevent jumpy scrolling.\n *\n * @sample {highcharts} highcharts/xaxis/startontick-false/\n * False by default\n * @sample {highcharts} highcharts/xaxis/startontick-true/\n * True\n *\n * @since 1.2.0\n */\n startOnTick: false,\n /**\n * The amount of ticks to draw on the axis. This opens up for aligning\n * the ticks of multiple charts or panes within a chart. This option\n * overrides the `tickPixelInterval` option.\n *\n * This option only has an effect on linear axes. Datetime, logarithmic\n * or category axes are not affected.\n *\n * @sample {highcharts} highcharts/yaxis/tickamount/\n * 8 ticks on Y axis\n * @sample {highstock} highcharts/yaxis/tickamount/\n * 8 ticks on Y axis\n *\n * @type {number}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.tickAmount\n */\n /**\n * The interval of the tick marks in axis units. When `undefined`, the\n * tick interval is computed to approximately follow the\n * [tickPixelInterval](#xAxis.tickPixelInterval) on linear and datetime\n * axes. On categorized axes, a `undefined` tickInterval will default to\n * 1, one category. Note that datetime axes are based on milliseconds,\n * so for example an interval of one day is expressed as\n * `24 * 3600 * 1000`.\n *\n * On logarithmic axes, the tickInterval is based on powers, so a\n * tickInterval of 1 means one tick on each of 0.1, 1, 10, 100 etc. A\n * tickInterval of 2 means a tick of 0.1, 10, 1000 etc. A tickInterval\n * of 0.2 puts a tick on 0.1, 0.2, 0.4, 0.6, 0.8, 1, 2, 4, 6, 8, 10, 20,\n * 40 etc.\n *\n *\n * If the tickInterval is too dense for labels to be drawn, Highcharts\n * may remove ticks.\n *\n * If the chart has multiple axes, the [alignTicks](#chart.alignTicks)\n * option may interfere with the `tickInterval` setting.\n *\n * @see [tickPixelInterval](#xAxis.tickPixelInterval)\n * @see [tickPositions](#xAxis.tickPositions)\n * @see [tickPositioner](#xAxis.tickPositioner)\n *\n * @sample {highcharts} highcharts/xaxis/tickinterval-5/\n * Tick interval of 5 on a linear axis\n * @sample {highstock} stock/xaxis/tickinterval/\n * Tick interval of 0.01 on Y axis\n *\n * @type {number}\n * @apioption xAxis.tickInterval\n */\n /**\n * The pixel length of the main tick marks.\n *\n * @sample {highcharts} highcharts/xaxis/ticklength/\n * 20 px tick length on the X axis\n * @sample {highstock} stock/xaxis/ticks/\n * Formatted ticks on X axis\n */\n tickLength: 10,\n /**\n * If tickInterval is `null` this option sets the approximate pixel\n * interval of the tick marks. Not applicable to categorized axis.\n *\n * The tick interval is also influenced by the [minTickInterval](\n * #xAxis.minTickInterval) option, that, by default prevents ticks from\n * being denser than the data points.\n *\n * @see [tickInterval](#xAxis.tickInterval)\n * @see [tickPositioner](#xAxis.tickPositioner)\n * @see [tickPositions](#xAxis.tickPositions)\n *\n * @sample {highcharts} highcharts/xaxis/tickpixelinterval-50/\n * 50 px on X axis\n * @sample {highstock} stock/xaxis/tickpixelinterval/\n * 200 px on X axis\n */\n tickPixelInterval: 100,\n /**\n * For categorized axes only. If `on` the tick mark is placed in the\n * center of the category, if `between` the tick mark is placed between\n * categories. The default is `between` if the `tickInterval` is 1, else\n * `on`.\n *\n * @sample {highcharts} highcharts/xaxis/tickmarkplacement-between/\n * \"between\" by default\n * @sample {highcharts} highcharts/xaxis/tickmarkplacement-on/\n * \"on\"\n *\n * @product highcharts gantt\n * @validvalue [\"on\", \"between\"]\n */\n tickmarkPlacement: 'between',\n /**\n * The position of the major tick marks relative to the axis line.\n * Can be one of `inside` and `outside`.\n *\n * @sample {highcharts} highcharts/xaxis/tickposition-outside/\n * \"outside\" by default\n * @sample {highcharts} highcharts/xaxis/tickposition-inside/\n * \"inside\"\n * @sample {highstock} stock/xaxis/ticks/\n * Formatted ticks on X axis\n *\n * @validvalue [\"inside\", \"outside\"]\n */\n tickPosition: 'outside',\n /**\n * A callback function returning array defining where the ticks are\n * laid out on the axis. This overrides the default behaviour of\n * [tickPixelInterval](#xAxis.tickPixelInterval) and [tickInterval](\n * #xAxis.tickInterval). The automatic tick positions are accessible\n * through `this.tickPositions` and can be modified by the callback.\n *\n * @see [tickPositions](#xAxis.tickPositions)\n *\n * @sample {highcharts} highcharts/xaxis/tickpositions-tickpositioner/\n * Demo of tickPositions and tickPositioner\n * @sample {highstock} highcharts/xaxis/tickpositions-tickpositioner/\n * Demo of tickPositions and tickPositioner\n *\n * @type {Highcharts.AxisTickPositionerCallbackFunction}\n * @apioption xAxis.tickPositioner\n */\n /**\n * An array defining where the ticks are laid out on the axis. This\n * overrides the default behaviour of [tickPixelInterval](\n * #xAxis.tickPixelInterval) and [tickInterval](#xAxis.tickInterval).\n *\n * @see [tickPositioner](#xAxis.tickPositioner)\n *\n * @sample {highcharts} highcharts/xaxis/tickpositions-tickpositioner/\n * Demo of tickPositions and tickPositioner\n * @sample {highstock} highcharts/xaxis/tickpositions-tickpositioner/\n * Demo of tickPositions and tickPositioner\n *\n * @type {Array}\n * @apioption xAxis.tickPositions\n */\n /**\n * The pixel width of the major tick marks. Defaults to 0 on category\n * axes, otherwise 1.\n *\n * In styled mode, the stroke width is given in the `.highcharts-tick`\n * class, but in order for the element to be generated on category axes,\n * the option must be explicitly set to 1.\n *\n * @sample {highcharts} highcharts/xaxis/tickwidth/\n * 10 px width\n * @sample {highcharts} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/ticks/\n * Formatted ticks on X axis\n * @sample {highstock} highcharts/css/axis-grid/\n * Styled mode\n *\n * @type {undefined|number}\n * @default {highstock} 1\n * @default {highmaps} 0\n * @apioption xAxis.tickWidth\n */\n /**\n * The axis title, showing next to the axis line.\n *\n * @productdesc {highmaps}\n * In Highmaps, the axis is hidden by default, but adding an axis title\n * is still possible. X axis and Y axis titles will appear at the bottom\n * and left by default.\n */\n title: {\n /**\n * Alignment of the title relative to the axis values. Possible\n * values are \"low\", \"middle\" or \"high\".\n *\n * @sample {highcharts} highcharts/xaxis/title-align-low/\n * \"low\"\n * @sample {highcharts} highcharts/xaxis/title-align-center/\n * \"middle\" by default\n * @sample {highcharts} highcharts/xaxis/title-align-high/\n * \"high\"\n * @sample {highcharts} highcharts/yaxis/title-offset/\n * Place the Y axis title on top of the axis\n * @sample {highstock} stock/xaxis/title-align/\n * Aligned to \"high\" value\n *\n * @type {Highcharts.AxisTitleAlignValue}\n */\n align: 'middle',\n /**\n * Deprecated. Set the `text` to `undefined` to disable the title.\n *\n * @deprecated\n * @type {boolean}\n * @product highcharts\n * @apioption xAxis.title.enabled\n */\n /**\n * The pixel distance between the axis labels or line and the title.\n * Defaults to 0 for horizontal axes, 10 for vertical\n *\n * @sample {highcharts} highcharts/xaxis/title-margin/\n * Y axis title margin of 60\n *\n * @type {number}\n * @apioption xAxis.title.margin\n */\n /**\n * The distance of the axis title from the axis line. By default,\n * this distance is computed from the offset width of the labels,\n * the labels' distance from the axis and the title's margin.\n * However when the offset option is set, it overrides all this.\n *\n * @sample {highcharts} highcharts/yaxis/title-offset/\n * Place the axis title on top of the axis\n * @sample {highstock} highcharts/yaxis/title-offset/\n * Place the axis title on top of the Y axis\n *\n * @type {number}\n * @since 2.2.0\n * @apioption xAxis.title.offset\n */\n /**\n * Whether to reserve space for the title when laying out the axis.\n *\n * @type {boolean}\n * @default true\n * @since 5.0.11\n * @product highcharts highstock gantt\n * @apioption xAxis.title.reserveSpace\n */\n /**\n * The rotation of the text in degrees. 0 is horizontal, 270 is\n * vertical reading from bottom to top.\n *\n * @sample {highcharts} highcharts/yaxis/title-offset/\n * Horizontal\n */\n rotation: 0,\n /**\n * The actual text of the axis title. It can contain basic HTML tags\n * like `b`, `i` and `span` with style.\n *\n * @sample {highcharts} highcharts/xaxis/title-text/\n * Custom HTML\n * @sample {highstock} stock/xaxis/title-text/\n * Titles for both axes\n *\n * @type {string|null}\n * @apioption xAxis.title.text\n */\n /**\n * Alignment of the text, can be `\"left\"`, `\"right\"` or `\"center\"`.\n * Default alignment depends on the\n * [title.align](xAxis.title.align):\n *\n * Horizontal axes:\n * - for `align` = `\"low\"`, `textAlign` is set to `left`\n * - for `align` = `\"middle\"`, `textAlign` is set to `center`\n * - for `align` = `\"high\"`, `textAlign` is set to `right`\n *\n * Vertical axes:\n * - for `align` = `\"low\"` and `opposite` = `true`, `textAlign` is\n * set to `right`\n * - for `align` = `\"low\"` and `opposite` = `false`, `textAlign` is\n * set to `left`\n * - for `align` = `\"middle\"`, `textAlign` is set to `center`\n * - for `align` = `\"high\"` and `opposite` = `true` `textAlign` is\n * set to `left`\n * - for `align` = `\"high\"` and `opposite` = `false` `textAlign` is\n * set to `right`\n *\n * @type {Highcharts.AlignValue}\n * @apioption xAxis.title.textAlign\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the axis title.\n *\n * @product highcharts highstock gantt\n */\n useHTML: false,\n /**\n * Horizontal pixel offset of the title position.\n *\n * @since 4.1.6\n * @product highcharts highstock gantt\n */\n x: 0,\n /**\n * Vertical pixel offset of the title position.\n *\n * @product highcharts highstock gantt\n */\n y: 0,\n /**\n * CSS styles for the title. If the title text is longer than the\n * axis length, it will wrap to multiple lines by default. This can\n * be customized by setting `textOverflow: 'ellipsis'`, by\n * setting a specific `width` or by setting `whiteSpace: 'nowrap'`.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-axis-title` class.\n *\n * @sample {highcharts} highcharts/xaxis/title-style/\n * Red\n * @sample {highcharts} highcharts/css/axis/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @internal */\n color: \"#666666\" /* Palette.neutralColor60 */\n }\n },\n /**\n * The type of axis. Can be one of `linear`, `logarithmic`, `datetime`\n * or `category`. In a datetime axis, the numbers are given in\n * milliseconds, and tick marks are placed on appropriate values like\n * full hours or days. In a category axis, the\n * [point names](#series.line.data.name) of the chart's series are used\n * for categories, if not a [categories](#xAxis.categories) array is\n * defined.\n *\n * @sample {highcharts} highcharts/xaxis/type-linear/\n * Linear\n * @sample {highcharts} highcharts/yaxis/type-log/\n * Logarithmic\n * @sample {highcharts} highcharts/yaxis/type-log-minorgrid/\n * Logarithmic with minor grid lines\n * @sample {highcharts} highcharts/xaxis/type-log-both/\n * Logarithmic on two axes\n * @sample {highcharts} highcharts/yaxis/type-log-negative/\n * Logarithmic with extension to emulate negative values\n *\n * @type {Highcharts.AxisTypeValue}\n * @product highcharts gantt\n */\n type: 'linear',\n /**\n * If there are multiple axes on the same side of the chart, the pixel\n * margin between the axes. Defaults to 0 on vertical axes, 15 on\n * horizontal axes.\n *\n * @type {number}\n * @since 7.0.3\n * @apioption xAxis.margin\n */\n /**\n * Applies only when the axis `type` is `category`. When `uniqueNames`\n * is true, points are placed on the X axis according to their names.\n * If the same point name is repeated in the same or another series,\n * the point is placed on the same X position as other points of the\n * same name. When `uniqueNames` is false, the points are laid out in\n * increasing X positions regardless of their names, and the X axis\n * category will take the name of the last point in each position.\n *\n * @sample {highcharts} highcharts/xaxis/uniquenames-true/\n * True by default\n * @sample {highcharts} highcharts/xaxis/uniquenames-false/\n * False\n *\n * @since 4.2.7\n * @product highcharts gantt\n */\n uniqueNames: true,\n /**\n * Datetime axis only. An array determining what time intervals the\n * ticks are allowed to fall on. Each array item is an array where the\n * first value is the time unit and the second value another array of\n * allowed multiples.\n *\n * Defaults to:\n * ```js\n * units: [[\n * 'millisecond', // unit name\n * [1, 2, 5, 10, 20, 25, 50, 100, 200, 500] // allowed multiples\n * ], [\n * 'second',\n * [1, 2, 5, 10, 15, 30]\n * ], [\n * 'minute',\n * [1, 2, 5, 10, 15, 30]\n * ], [\n * 'hour',\n * [1, 2, 3, 4, 6, 8, 12]\n * ], [\n * 'day',\n * [1, 2]\n * ], [\n * 'week',\n * [1, 2]\n * ], [\n * 'month',\n * [1, 2, 3, 4, 6]\n * ], [\n * 'year',\n * null\n * ]]\n * ```\n *\n * @type {Array|null)>>}\n * @product highcharts highstock gantt\n * @apioption xAxis.units\n */\n /**\n * Whether axis, including axis title, line, ticks and labels, should\n * be visible.\n *\n * @since 4.1.9\n * @product highcharts highstock gantt\n */\n visible: true,\n /**\n * Color of the minor, secondary grid lines.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-minor-grid-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/minorgridlinecolor/\n * Bright grey lines from Y axis\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/minorgridlinecolor/\n * Bright grey lines from Y axis\n *\n * @type {Highcharts.ColorType}\n * @default #f2f2f2\n */\n minorGridLineColor: \"#f2f2f2\" /* Palette.neutralColor5 */,\n /**\n * Width of the minor, secondary grid lines.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-grid-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/minorgridlinewidth/\n * 2px lines from Y axis\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/minorgridlinewidth/\n * 2px lines from Y axis\n */\n minorGridLineWidth: 1,\n /**\n * Color for the minor tick marks.\n *\n * @sample {highcharts} highcharts/yaxis/minortickcolor/\n * Black tick marks on Y axis\n * @sample {highstock} stock/xaxis/minorticks/\n * Black tick marks on Y axis\n *\n * @type {Highcharts.ColorType}\n * @default #999999\n */\n minorTickColor: \"#999999\" /* Palette.neutralColor40 */,\n /**\n * The color of the line marking the axis itself.\n *\n * In styled mode, the line stroke is given in the\n * `.highcharts-axis-line` or `.highcharts-xaxis-line` class.\n *\n * @productdesc {highmaps}\n * In Highmaps, the axis line is hidden by default, because the axis is\n * not visible by default.\n *\n * @sample {highcharts} highcharts/yaxis/linecolor/\n * A red line on Y axis\n * @sample {highcharts|highstock} highcharts/css/axis/\n * Axes in styled mode\n * @sample {highstock} stock/xaxis/linecolor/\n * A red line on X axis\n *\n * @type {Highcharts.ColorType}\n * @default #ccd6eb\n */\n lineColor: \"#ccd6eb\" /* Palette.highlightColor20 */,\n /**\n * The width of the line marking the axis itself.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-axis-line` or `.highcharts-xaxis-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/linecolor/\n * A 1px line on Y axis\n * @sample {highcharts|highstock} highcharts/css/axis/\n * Axes in styled mode\n * @sample {highstock} stock/xaxis/linewidth/\n * A 2px line on X axis\n *\n * @default {highcharts|highstock} 1\n * @default {highmaps} 0\n */\n lineWidth: 1,\n /**\n * Color of the grid lines extending the ticks across the plot area.\n *\n * In styled mode, the stroke is given in the `.highcharts-grid-line`\n * class.\n *\n * @productdesc {highmaps}\n * In Highmaps, the grid lines are hidden by default.\n *\n * @sample {highcharts} highcharts/yaxis/gridlinecolor/\n * Green lines\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/gridlinecolor/\n * Green lines\n *\n * @type {Highcharts.ColorType}\n * @default #e6e6e6\n */\n gridLineColor: \"#e6e6e6\" /* Palette.neutralColor10 */,\n /**\n * The width of the grid lines extending the ticks across the plot area.\n * Defaults to 1 on the Y axis and 0 on the X axis, except for 3d\n * charts.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-grid-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/gridlinewidth/\n * 2px lines\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/gridlinewidth/\n * 2px lines\n *\n * @type {number}\n * @apioption xAxis.gridLineWidth\n */\n gridLineWidth: void 0,\n /**\n * The height as the vertical axis. If it's a number, it is\n * interpreted as pixels.\n *\n * Since Highcharts 2: If it's a percentage string, it is interpreted\n * as percentages of the total plot height.\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption xAxis.height\n */\n /**\n * The width as the horizontal axis. If it's a number, it is interpreted\n * as pixels.\n *\n * Since Highcharts v5.0.13: If it's a percentage string, it is\n * interpreted as percentages of the total plot width.\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption xAxis.width\n */\n /**\n * Color for the main tick marks.\n *\n * In styled mode, the stroke is given in the `.highcharts-tick`\n * class.\n *\n * @sample {highcharts} highcharts/xaxis/tickcolor/\n * Red ticks on X axis\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/ticks/\n * Formatted ticks on X axis\n *\n * @type {Highcharts.ColorType}\n * @default #ccd6eb\n */\n tickColor: \"#ccd6eb\" /* Palette.highlightColor20 */\n // tickWidth: 1\n };\n /**\n * The Y axis or value axis. Normally this is the vertical axis,\n * though if the chart is inverted this is the horizontal axis.\n * In case of multiple axes, the yAxis node is an array of\n * configuration objects.\n *\n * See [the Axis object](/class-reference/Highcharts.Axis) for programmatic\n * access to the axis.\n *\n * @type {*|Array<*>}\n * @extends xAxis\n * @excluding currentDateIndicator,ordinal,overscroll\n * @optionparent yAxis\n */\n AxisDefaults.defaultYAxisOptions = {\n /**\n * The type of axis. Can be one of `linear`, `logarithmic`, `datetime`,\n * `category` or `treegrid`. Defaults to `treegrid` for Gantt charts,\n * `linear` for other chart types.\n *\n * In a datetime axis, the numbers are given in milliseconds, and tick\n * marks are placed on appropriate values, like full hours or days. In a\n * category or treegrid axis, the [point names](#series.line.data.name)\n * of the chart's series are used for categories, if a\n * [categories](#xAxis.categories) array is not defined.\n *\n * @sample {highcharts} highcharts/yaxis/type-log-minorgrid/\n * Logarithmic with minor grid lines\n * @sample {highcharts} highcharts/yaxis/type-log-negative/\n * Logarithmic with extension to emulate negative values\n * @sample {gantt} gantt/treegrid-axis/demo\n * Treegrid axis\n *\n * @type {Highcharts.AxisTypeValue}\n * @default {highcharts} linear\n * @default {gantt} treegrid\n * @product highcharts gantt\n * @apioption yAxis.type\n */\n /**\n * The height of the Y axis. If it's a number, it is interpreted as\n * pixels.\n *\n * Since Highcharts 2: If it's a percentage string, it is interpreted as\n * percentages of the total plot height.\n *\n * @see [yAxis.top](#yAxis.top)\n *\n * @sample {highstock} stock/demo/candlestick-and-volume/\n * Percentage height panes\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption yAxis.height\n */\n /**\n * Solid gauge only. Unless [stops](#yAxis.stops) are set, the color\n * to represent the maximum value of the Y axis.\n *\n * @sample {highcharts} highcharts/yaxis/mincolor-maxcolor/\n * Min and max colors\n *\n * @type {Highcharts.ColorType}\n * @default #003399\n * @since 4.0\n * @product highcharts\n * @apioption yAxis.maxColor\n */\n /**\n * Solid gauge only. Unless [stops](#yAxis.stops) are set, the color\n * to represent the minimum value of the Y axis.\n *\n * @sample {highcharts} highcharts/yaxis/mincolor-maxcolor/\n * Min and max color\n *\n * @type {Highcharts.ColorType}\n * @default #e6ebf5\n * @since 4.0\n * @product highcharts\n * @apioption yAxis.minColor\n */\n /**\n * Whether to reverse the axis so that the highest number is closest\n * to the origin.\n *\n * @sample {highcharts} highcharts/yaxis/reversed/\n * Reversed Y axis\n * @sample {highstock} stock/xaxis/reversed/\n * Reversed Y axis\n *\n * @type {boolean}\n * @default {highcharts} false\n * @default {highstock} false\n * @default {highmaps} true\n * @default {gantt} true\n * @apioption yAxis.reversed\n */\n /**\n * If `true`, the first series in a stack will be drawn on top in a\n * positive, non-reversed Y axis. If `false`, the first series is in\n * the base of the stack.\n *\n * @sample {highcharts} highcharts/yaxis/reversedstacks-false/\n * Non-reversed stacks\n * @sample {highstock} highcharts/yaxis/reversedstacks-false/\n * Non-reversed stacks\n *\n * @type {boolean}\n * @default true\n * @since 3.0.10\n * @product highcharts highstock\n * @apioption yAxis.reversedStacks\n */\n reversedStacks: true,\n /**\n * Solid gauge series only. Color stops for the solid gauge. Use this\n * in cases where a linear gradient between a `minColor` and `maxColor`\n * is not sufficient. The stops is an array of tuples, where the first\n * item is a float between 0 and 1 assigning the relative position in\n * the gradient, and the second item is the color.\n *\n * For solid gauges, the Y axis also inherits the concept of\n * [data classes](https://api.highcharts.com/highmaps#colorAxis.dataClasses)\n * from the Highmaps color axis.\n *\n * @sample {highcharts} highcharts/demo/gauge-solid/\n * Gauge with stops\n *\n * @see [minColor](#yAxis.minColor)\n * @see [maxColor](#yAxis.maxColor)\n *\n * @type {Array>}\n * @since 4.0\n * @product highcharts\n * @apioption yAxis.stops\n */\n /**\n * The pixel width of the major tick marks.\n *\n * @sample {highcharts} highcharts/xaxis/tickwidth/ 10 px width\n * @sample {highstock} stock/xaxis/ticks/ Formatted ticks on X axis\n *\n * @type {number}\n * @default 0\n * @product highcharts highstock gantt\n * @apioption yAxis.tickWidth\n */\n /**\n * Whether to force the axis to end on a tick. Use this option with\n * the `maxPadding` option to control the axis end.\n *\n * This option is always disabled, when panning type is\n * either `y` or `xy`.\n *\n * @see [type](#chart.panning.type)\n *\n *\n * @sample {highcharts} highcharts/yaxis/endontick/\n * True by default\n * @sample {highcharts} highcharts/yaxis/endontick-false/\n * False\n * @sample {highstock} stock/demo/basic-line/\n * True by default\n * @sample {highstock} stock/xaxis/endontick/\n * False for Y axis\n *\n * @since 1.2.0\n */\n endOnTick: true,\n /**\n * Padding of the max value relative to the length of the axis. A\n * padding of 0.05 will make a 100px axis 5px longer. This is useful\n * when you don't want the highest data value to appear on the edge\n * of the plot area. When the axis' `max` option is set or a max extreme\n * is set using `axis.setExtremes()`, the maxPadding will be ignored.\n *\n * Also the `softThreshold` option takes precedence over `maxPadding`,\n * so if the data is tangent to the threshold, `maxPadding` may not\n * apply unless `softThreshold` is set to false.\n *\n * @sample {highcharts} highcharts/yaxis/maxpadding-02/\n * Max padding of 0.2\n * @sample {highstock} stock/xaxis/minpadding-maxpadding/\n * Greater min- and maxPadding\n *\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n maxPadding: 0.05,\n /**\n * Padding of the min value relative to the length of the axis. A\n * padding of 0.05 will make a 100px axis 5px longer. This is useful\n * when you don't want the lowest data value to appear on the edge\n * of the plot area. When the axis' `min` option is set or a max extreme\n * is set using `axis.setExtremes()`, the maxPadding will be ignored.\n *\n * Also the `softThreshold` option takes precedence over `minPadding`,\n * so if the data is tangent to the threshold, `minPadding` may not\n * apply unless `softThreshold` is set to false.\n *\n * @sample {highcharts} highcharts/yaxis/minpadding/\n * Min padding of 0.2\n * @sample {highstock} stock/xaxis/minpadding-maxpadding/\n * Greater min- and maxPadding\n *\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n minPadding: 0.05,\n /**\n * @productdesc {highstock}\n * In Highcharts Stock 1.x, the Y axis was placed\n * on the left side by default.\n *\n * @sample {highcharts} highcharts/yaxis/opposite/\n * Secondary Y axis opposite\n * @sample {highstock} stock/xaxis/opposite/\n * Y axis on left side\n *\n * @type {boolean}\n * @default {highstock} true\n * @default {highcharts} false\n * @product highstock highcharts gantt\n * @apioption yAxis.opposite\n */\n /**\n * @see [tickInterval](#xAxis.tickInterval)\n * @see [tickPositioner](#xAxis.tickPositioner)\n * @see [tickPositions](#xAxis.tickPositions)\n */\n tickPixelInterval: 72,\n /**\n * Whether to show the last tick label.\n *\n * @productdesc {highcharts|gantt}\n * Defaults to `true` on cartesian charts, and `false` on polar charts.\n *\n * @productdesc {highstock}\n * Defaults to `true` for categorized yAxis and `false` for other types\n * of yAxis.\n *\n * @default undefined\n */\n showLastLabel: true,\n /**\n * @extends xAxis.labels\n */\n labels: {\n /**\n * Angular gauges and solid gauges only.\n * The label's pixel distance from the perimeter of the plot area.\n *\n * Since v7.1.2: If it's a percentage string, it is interpreted the\n * same as [series.radius](#plotOptions.gauge.radius), so label can be\n * aligned under the gauge's shape.\n *\n * @sample {highcharts} highcharts/yaxis/labels-distance/\n * Labels centered under the arc\n *\n * @type {number|string}\n * @default -25\n * @product highcharts\n * @apioption yAxis.labels.distance\n */\n /**\n * The y position offset of all labels relative to the tick\n * positions on the axis. For polar and radial axis consider the use\n * of the [distance](#yAxis.labels.distance) option.\n *\n * @sample {highcharts} highcharts/xaxis/labels-x/\n * Y axis labels placed on grid lines\n *\n * @type {number}\n * @default {highcharts} 3\n * @default {highstock} -2\n * @default {highmaps} 3\n * @apioption yAxis.labels.y\n */\n /**\n * What part of the string the given position is anchored to. Can\n * be one of `\"left\"`, `\"center\"` or `\"right\"`. The exact position\n * also depends on the `labels.x` setting.\n *\n * Angular gauges and solid gauges defaults to `\"center\"`.\n * Solid gauges with two labels have additional option `\"auto\"`\n * for automatic horizontal and vertical alignment.\n *\n * @see [yAxis.labels.distance](#yAxis.labels.distance)\n *\n * @sample {highcharts} highcharts/yaxis/labels-align-left/\n * Left\n * @sample {highcharts} highcharts/series-solidgauge/labels-auto-aligned/\n * Solid gauge labels auto aligned\n *\n * @type {Highcharts.AlignValue}\n * @default {highstock} right\n * @apioption yAxis.labels.align\n */\n /**\n * The x position offset of all labels relative to the tick\n * positions on the axis. Defaults to -15 for left axis, 15 for\n * right axis.\n *\n * @sample {highcharts} highcharts/xaxis/labels-x/\n * Y axis labels placed on grid lines\n */\n x: -8\n },\n /**\n * @productdesc {highmaps}\n * In Highmaps, the axis line is hidden by default, because the axis is\n * not visible by default.\n *\n * @type {Highcharts.ColorType}\n * @apioption yAxis.lineColor\n */\n /**\n * @sample {highcharts} highcharts/yaxis/max-200/\n * Y axis max of 200\n * @sample {highcharts} highcharts/yaxis/max-logarithmic/\n * Y axis max on logarithmic axis\n * @sample {highstock} stock/yaxis/min-max/\n * Fixed min and max on Y axis\n *\n * @apioption yAxis.max\n */\n /**\n * @sample {highcharts} highcharts/yaxis/min-startontick-false/\n * -50 with startOnTick to false\n * @sample {highcharts} highcharts/yaxis/min-startontick-true/\n * -50 with startOnTick true by default\n * @sample {highstock} stock/yaxis/min-max/\n * Fixed min and max on Y axis\n *\n * @apioption yAxis.min\n */\n /**\n * An optional scrollbar to display on the Y axis in response to\n * limiting the minimum an maximum of the axis values.\n *\n * In styled mode, all the presentational options for the scrollbar\n * are replaced by the classes `.highcharts-scrollbar-thumb`,\n * `.highcharts-scrollbar-arrow`, `.highcharts-scrollbar-button`,\n * `.highcharts-scrollbar-rifles` and `.highcharts-scrollbar-track`.\n *\n * @sample {highstock} stock/yaxis/scrollbar/\n * Scrollbar on the Y axis\n *\n * @extends scrollbar\n * @since 4.2.6\n * @product highstock\n * @excluding height\n * @apioption yAxis.scrollbar\n */\n /**\n * Enable the scrollbar on the Y axis.\n *\n * @sample {highstock} stock/yaxis/scrollbar/\n * Enabled on Y axis\n *\n * @type {boolean}\n * @default false\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.enabled\n */\n /**\n * Pixel margin between the scrollbar and the axis elements.\n *\n * @type {number}\n * @default 10\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.margin\n */\n /* eslint-disable highcharts/doclet-apioption-last */\n /**\n * Defines the position of the scrollbar. By default, it is positioned\n * on the opposite of the main axis (right side of the chart).\n * However, in the case of RTL languages could be set to `false`\n * which positions the scrollbar on the left.\n *\n * Works only for vertical axes.\n * This means yAxis in a non-inverted chart and xAxis in the inverted.\n *\n * @sample stock/yaxis/scrollbar-opposite/\n * A scrollbar not on the opposite side\n *\n * @type {boolean}\n * @default true\n * @since 9.3.0\n *\n * @apioption yAxis.scrollbar.opposite\n * @apioption xAxis.scrollbar.opposite\n *\n */\n /* eslint-enable highcharts/doclet-apioption-last */\n /**\n * Whether to show the scrollbar when it is fully zoomed out at max\n * range. Setting it to `false` on the Y axis makes the scrollbar stay\n * hidden until the user zooms in, like common in browsers.\n *\n * @type {boolean}\n * @default true\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.showFull\n */\n /**\n * The width of a vertical scrollbar or height of a horizontal\n * scrollbar. Defaults to 20 on touch devices.\n *\n * @type {number}\n * @default 14\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.size\n */\n /**\n * Z index of the scrollbar elements.\n *\n * @type {number}\n * @default 3\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.zIndex\n */\n /**\n * A soft maximum for the axis. If the series data maximum is less\n * than this, the axis will stay at this maximum, but if the series\n * data maximum is higher, the axis will flex to show all data.\n *\n * **Note**: The [series.softThreshold](\n * #plotOptions.series.softThreshold) option takes precedence over this\n * option.\n *\n * @sample highcharts/yaxis/softmin-softmax/\n * Soft min and max\n *\n * @type {number}\n * @since 5.0.1\n * @product highcharts highstock gantt\n * @apioption yAxis.softMax\n */\n /**\n * A soft minimum for the axis. If the series data minimum is greater\n * than this, the axis will stay at this minimum, but if the series\n * data minimum is lower, the axis will flex to show all data.\n *\n * **Note**: The [series.softThreshold](\n * #plotOptions.series.softThreshold) option takes precedence over this\n * option.\n *\n * @sample highcharts/yaxis/softmin-softmax/\n * Soft min and max\n *\n * @type {number}\n * @since 5.0.1\n * @product highcharts highstock gantt\n * @apioption yAxis.softMin\n */\n /**\n * Defines the horizontal alignment of the stack total label. Can be one\n * of `\"left\"`, `\"center\"` or `\"right\"`. The default value is calculated\n * at runtime and depends on orientation and whether the stack is\n * positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-align-left/\n * Aligned to the left\n * @sample {highcharts} highcharts/yaxis/stacklabels-align-center/\n * Aligned in center\n * @sample {highcharts} highcharts/yaxis/stacklabels-align-right/\n * Aligned to the right\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.align\n */\n /**\n * A format string for the data label. Available variables are the same\n * as for `formatter`.\n *\n * @type {string}\n * @default {total}\n * @since 3.0.2\n * @product highcharts highstock\n * @apioption yAxis.stackLabels.format\n */\n /**\n * Rotation of the labels in degrees.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-rotation/\n * Labels rotated 45°\n *\n * @type {number}\n * @default 0\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.rotation\n */\n /**\n * The text alignment for the label. While `align` determines where the\n * texts anchor point is placed with regards to the stack, `textAlign`\n * determines how the text is aligned against its anchor point. Possible\n * values are `\"left\"`, `\"center\"` and `\"right\"`. The default value is\n * calculated at runtime and depends on orientation and whether the\n * stack is positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-textalign-left/\n * Label in center position but text-aligned left\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.textAlign\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n *\n * @type {boolean}\n * @default false\n * @since 3.0\n * @product highcharts highstock\n * @apioption yAxis.stackLabels.useHTML\n */\n /**\n * Defines the vertical alignment of the stack total label. Can be one\n * of `\"top\"`, `\"middle\"` or `\"bottom\"`. The default value is calculated\n * at runtime and depends on orientation and whether the stack is\n * positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-verticalalign-top/\n * Vertically aligned top\n * @sample {highcharts} highcharts/yaxis/stacklabels-verticalalign-middle/\n * Vertically aligned middle\n * @sample {highcharts} highcharts/yaxis/stacklabels-verticalalign-bottom/\n * Vertically aligned bottom\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.verticalAlign\n */\n /**\n * The x position offset of the label relative to the left of the\n * stacked bar. The default value is calculated at runtime and depends\n * on orientation and whether the stack is positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-x/\n * Stack total labels with x offset\n *\n * @type {number}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.x\n */\n /**\n * The y position offset of the label relative to the tick position\n * on the axis. The default value is calculated at runtime and depends\n * on orientation and whether the stack is positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-y/\n * Stack total labels with y offset\n *\n * @type {number}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.y\n */\n /**\n * Whether to force the axis to start on a tick. Use this option with\n * the `maxPadding` option to control the axis start.\n *\n * This option is always disabled, when panning type is\n * either `y` or `xy`.\n *\n * @see [type](#chart.panning.type)\n *\n * @sample {highcharts} highcharts/xaxis/startontick-false/\n * False by default\n * @sample {highcharts} highcharts/xaxis/startontick-true/\n * True\n * @sample {highstock} stock/xaxis/endontick/\n * False for Y axis\n *\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n startOnTick: true,\n title: {\n /**\n * The pixel distance between the axis labels and the title.\n * Positive values are outside the axis line, negative are inside.\n *\n * @sample {highcharts} highcharts/xaxis/title-margin/\n * Y axis title margin of 60\n *\n * @type {number}\n * @default 40\n * @apioption yAxis.title.margin\n */\n /**\n * The rotation of the text in degrees. 0 is horizontal, 270 is\n * vertical reading from bottom to top.\n *\n * @sample {highcharts} highcharts/yaxis/title-offset/\n * Horizontal\n */\n rotation: 270,\n /**\n * The actual text of the axis title. Horizontal texts can contain\n * HTML, but rotated texts are painted using vector techniques and\n * must be clean text. The Y axis title is disabled by setting the\n * `text` option to `undefined`.\n *\n * @sample {highcharts} highcharts/xaxis/title-text/\n * Custom HTML\n *\n * @type {string|null}\n * @default {highcharts} Values\n * @default {highstock} undefined\n * @product highcharts highstock gantt\n */\n text: 'Values'\n },\n /**\n * The top position of the Y axis. If it's a number, it is interpreted\n * as pixel position relative to the chart.\n *\n * Since Highcharts 2: If it's a percentage string, it is interpreted as\n * percentages of the plot height, offset from plot area top.\n *\n * @see [yAxis.height](#yAxis.height)\n *\n * @sample {highstock} stock/demo/candlestick-and-volume/\n * Percentage height panes\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption yAxis.top\n */\n /**\n * The stack labels show the total value for each bar in a stacked\n * column or bar chart. The label will be placed on top of positive\n * columns and below negative columns. In case of an inverted column\n * chart or a bar chart the label is placed to the right of positive\n * bars and to the left of negative bars.\n *\n * @product highcharts\n */\n stackLabels: {\n /**\n * Enable or disable the initial animation when a series is\n * displayed for the `stackLabels`. The animation can also be set as\n * a configuration object. Please note that this option only\n * applies to the initial animation.\n * For other animations, see [chart.animation](#chart.animation)\n * and the animation parameter under the API methods.\n * The following properties are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * @sample {highcharts} highcharts/plotoptions/animation-defer/\n * Animation defer settings\n * @type {boolean|Partial}\n * @since 8.2.0\n * @apioption yAxis.stackLabels.animation\n */\n animation: {},\n /**\n * The animation delay time in milliseconds.\n * Set to `0` renders stackLabel immediately.\n * As `undefined` inherits defer time from the [series.animation.defer](#plotOptions.series.animation.defer).\n *\n * @type {number}\n * @since 8.2.0\n * @apioption yAxis.stackLabels.animation.defer\n */\n /**\n * Allow the stack labels to overlap.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-allowoverlap-false/\n * Default false\n *\n * @since 5.0.13\n * @product highcharts\n */\n allowOverlap: false,\n /**\n * The background color or gradient for the stack label.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-box/\n * Stack labels box options\n * @type {Highcharts.ColorType}\n * @since 8.1.0\n * @apioption yAxis.stackLabels.backgroundColor\n */\n /**\n * The border color for the stack label. Defaults to `undefined`.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-box/\n * Stack labels box options\n * @type {Highcharts.ColorType}\n * @since 8.1.0\n * @apioption yAxis.stackLabels.borderColor\n */\n /**\n * The border radius in pixels for the stack label.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-box/\n * Stack labels box options\n * @type {number}\n * @default 0\n * @since 8.1.0\n * @apioption yAxis.stackLabels.borderRadius\n */\n /**\n * The border width in pixels for the stack label.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-box/\n * Stack labels box options\n * @type {number}\n * @default 0\n * @since 8.1.0\n * @apioption yAxis.stackLabels.borderWidth\n */\n /**\n * Enable or disable the stack total labels.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-enabled/\n * Enabled stack total labels\n * @sample {highcharts} highcharts/yaxis/stacklabels-enabled-waterfall/\n * Enabled stack labels in waterfall chart\n *\n * @since 2.1.5\n * @product highcharts\n */\n enabled: false,\n /**\n * Whether to hide stack labels that are outside the plot area.\n * By default, the stack label is moved\n * inside the plot area according to the\n * [overflow](/highcharts/#yAxis/stackLabels/overflow)\n * option.\n *\n * @type {boolean}\n * @since 7.1.3\n */\n crop: true,\n /**\n * How to handle stack total labels that flow outside the plot area.\n * The default is set to `\"justify\"`,\n * which aligns them inside the plot area.\n * For columns and bars, this means it will be moved inside the bar.\n * To display stack labels outside the plot area,\n * set `crop` to `false` and `overflow` to `\"allow\"`.\n *\n * @sample highcharts/yaxis/stacklabels-overflow/\n * Stack labels flows outside the plot area.\n *\n * @type {Highcharts.DataLabelsOverflowValue}\n * @since 7.1.3\n */\n overflow: 'justify',\n /* eslint-disable valid-jsdoc */\n /**\n * Callback JavaScript function to format the label. The value is\n * given by `this.total`.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-formatter/\n * Added units to stack total value\n *\n * @type {Highcharts.FormatterCallbackFunction}\n * @since 2.1.5\n * @product highcharts\n */\n formatter: function () {\n var numberFormatter = this.axis.chart.numberFormatter;\n /* eslint-enable valid-jsdoc */\n return numberFormatter(this.total || 0, -1);\n },\n /**\n * CSS styles for the label.\n *\n * In styled mode, the styles are set in the\n * `.highcharts-stack-label` class.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-style/\n * Red stack total labels\n *\n * @type {Highcharts.CSSObject}\n * @since 2.1.5\n * @product highcharts\n */\n style: {\n /** @internal */\n color: \"#000000\" /* Palette.neutralColor100 */,\n /** @internal */\n fontSize: '11px',\n /** @internal */\n fontWeight: 'bold',\n /** @internal */\n textOutline: '1px contrast'\n }\n },\n gridLineWidth: 1,\n lineWidth: 0\n // tickWidth: 0\n };\n /**\n * The Z axis or depth axis for 3D plots.\n *\n * See the [Axis class](/class-reference/Highcharts.Axis) for programmatic\n * access to the axis.\n *\n * @sample {highcharts} highcharts/3d/scatter-zaxis-categories/\n * Z-Axis with Categories\n * @sample {highcharts} highcharts/3d/scatter-zaxis-grid/\n * Z-Axis with styling\n *\n * @type {*|Array<*>}\n * @extends xAxis\n * @since 5.0.0\n * @product highcharts\n * @excluding breaks, crosshair, height, left, lineColor, lineWidth,\n * nameToX, showEmpty, top, width\n * @apioption zAxis\n */\n // This variable extends the defaultOptions for left axes.\n AxisDefaults.defaultLeftAxisOptions = {\n labels: {\n x: -15\n },\n title: {\n rotation: 270\n }\n };\n // This variable extends the defaultOptions for right axes.\n AxisDefaults.defaultRightAxisOptions = {\n labels: {\n x: 15\n },\n title: {\n rotation: 90\n }\n };\n // This variable extends the defaultOptions for bottom axes.\n AxisDefaults.defaultBottomAxisOptions = {\n labels: {\n autoRotation: [-45],\n x: 0\n // overflow: undefined,\n // staggerLines: null\n },\n margin: 15,\n title: {\n rotation: 0\n }\n };\n // This variable extends the defaultOptions for top axes.\n AxisDefaults.defaultTopAxisOptions = {\n labels: {\n autoRotation: [-45],\n x: 0\n // overflow: undefined\n // staggerLines: null\n },\n margin: 15,\n title: {\n rotation: 0\n }\n };\n })(AxisDefaults || (AxisDefaults = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return AxisDefaults;\n });\n _registerModule(_modules, 'Core/Foundation.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var addEvent = U.addEvent,\n isFunction = U.isFunction,\n objectEach = U.objectEach,\n removeEvent = U.removeEvent;\n /* *\n *\n * Class Namespace\n *\n * */\n var Foundation;\n (function (Foundation) {\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Register event options. If an event handler is set on the options, it\n * should be subject to Chart.update, Axis.update and Series.update. This is\n * contrary to general handlers that are set directly using addEvent either\n * on the class or on the instance. #6538, #6943, #10861.\n * @private\n */\n function registerEventOptions(component, options) {\n // A lookup over those events that are added by _options_ (not\n // programmatically). These are updated through .update()\n component.eventOptions = component.eventOptions || {};\n // Register event listeners\n objectEach(options.events, function (event, eventType) {\n // If event does not exist, or is changed by the .update()\n // function\n if (component.eventOptions[eventType] !== event) {\n // Remove existing if set by option\n if (component.eventOptions[eventType]) {\n removeEvent(component, eventType, component.eventOptions[eventType]);\n delete component.eventOptions[eventType];\n }\n if (isFunction(event)) {\n component.eventOptions[eventType] = event;\n addEvent(component, eventType, event);\n }\n }\n });\n }\n Foundation.registerEventOptions = registerEventOptions;\n })(Foundation || (Foundation = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return Foundation;\n });\n _registerModule(_modules, 'Core/Axis/Tick.js', [_modules['Core/FormatUtilities.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (F, H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var deg2rad = H.deg2rad;\n var clamp = U.clamp,\n correctFloat = U.correctFloat,\n defined = U.defined,\n destroyObjectProperties = U.destroyObjectProperties,\n extend = U.extend,\n fireEvent = U.fireEvent,\n isNumber = U.isNumber,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The Tick class.\n *\n * @class\n * @name Highcharts.Tick\n *\n * @param {Highcharts.Axis} axis\n * The axis of the tick.\n *\n * @param {number} pos\n * The position of the tick on the axis in terms of axis values.\n *\n * @param {string} [type]\n * The type of tick, either 'minor' or an empty string\n *\n * @param {boolean} [noLabel=false]\n * Whether to disable the label or not. Defaults to false.\n *\n * @param {Object} [parameters]\n * Optional parameters for the tick.\n */\n var Tick = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Tick(axis, pos, type, noLabel, parameters) {\n this.isNew = true;\n this.isNewLabel = true;\n /**\n * The related axis of the tick.\n * @name Highcharts.Tick#axis\n * @type {Highcharts.Axis}\n */\n this.axis = axis;\n /**\n * The logical position of the tick on the axis in terms of axis values.\n * @name Highcharts.Tick#pos\n * @type {number}\n */\n this.pos = pos;\n /**\n * The tick type, which can be `\"minor\"`, or an empty string.\n * @name Highcharts.Tick#type\n * @type {string}\n */\n this.type = type || '';\n this.parameters = parameters || {};\n /**\n * The mark offset of the tick on the axis. Usually `undefined`, numeric\n * for grid axes.\n * @name Highcharts.Tick#tickmarkOffset\n * @type {number|undefined}\n */\n this.tickmarkOffset = this.parameters.tickmarkOffset;\n this.options = this.parameters.options;\n fireEvent(this, 'init');\n if (!type && !noLabel) {\n this.addLabel();\n }\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Write the tick label.\n *\n * @private\n * @function Highcharts.Tick#addLabel\n */\n Tick.prototype.addLabel = function () {\n var tick = this,\n axis = tick.axis,\n options = axis.options,\n chart = axis.chart,\n categories = axis.categories,\n log = axis.logarithmic,\n names = axis.names,\n pos = tick.pos,\n labelOptions = pick(tick.options && tick.options.labels,\n options.labels),\n tickPositions = axis.tickPositions,\n isFirst = pos === tickPositions[0],\n isLast = pos === tickPositions[tickPositions.length - 1],\n animateLabels = (!labelOptions.step || labelOptions.step === 1) &&\n axis.tickInterval === 1,\n tickPositionInfo = tickPositions.info;\n var label = tick.label,\n dateTimeLabelFormat,\n dateTimeLabelFormats,\n i;\n // The context value\n var value = this.parameters.category || (categories ?\n pick(categories[pos],\n names[pos],\n pos) :\n pos);\n if (log && isNumber(value)) {\n value = correctFloat(log.lin2log(value));\n }\n // Set the datetime label format. If a higher rank is set for this\n // position, use that. If not, use the general format.\n if (axis.dateTime) {\n if (tickPositionInfo) {\n dateTimeLabelFormats = chart.time.resolveDTLFormat(options.dateTimeLabelFormats[(!options.grid &&\n tickPositionInfo.higherRanks[pos]) ||\n tickPositionInfo.unitName]);\n dateTimeLabelFormat = dateTimeLabelFormats.main;\n }\n else if (isNumber(value)) { // #1441\n dateTimeLabelFormat = axis.dateTime.getXDateFormat(value, options.dateTimeLabelFormats ||\n {});\n }\n }\n // set properties for access in render method\n /**\n * True if the tick is the first one on the axis.\n * @name Highcharts.Tick#isFirst\n * @readonly\n * @type {boolean|undefined}\n */\n tick.isFirst = isFirst;\n /**\n * True if the tick is the last one on the axis.\n * @name Highcharts.Tick#isLast\n * @readonly\n * @type {boolean|undefined}\n */\n tick.isLast = isLast;\n // Get the string\n var ctx = {\n axis: axis,\n chart: chart,\n dateTimeLabelFormat: dateTimeLabelFormat,\n isFirst: isFirst,\n isLast: isLast,\n pos: pos,\n tick: tick,\n tickPositionInfo: tickPositionInfo,\n value: value\n };\n // Fire an event that allows modifying the context for use in\n // `labels.format` and `labels.formatter`.\n fireEvent(this, 'labelFormat', ctx);\n // Label formatting. When `labels.format` is given, we first run the\n // defaultFormatter and append the result to the context as `text`.\n // Handy for adding prefix or suffix while keeping default number\n // formatting.\n var labelFormatter = function (ctx) {\n if (labelOptions.formatter) {\n return labelOptions.formatter.call(ctx,\n ctx);\n }\n if (labelOptions.format) {\n ctx.text = axis.defaultLabelFormatter.call(ctx, ctx);\n return F.format(labelOptions.format, ctx, chart);\n }\n return axis.defaultLabelFormatter.call(ctx, ctx);\n };\n var str = labelFormatter.call(ctx,\n ctx);\n // Set up conditional formatting based on the format list if existing.\n var list = dateTimeLabelFormats && dateTimeLabelFormats.list;\n if (list) {\n tick.shortenLabel = function () {\n for (i = 0; i < list.length; i++) {\n extend(ctx, { dateTimeLabelFormat: list[i] });\n label.attr({\n text: labelFormatter.call(ctx, ctx)\n });\n if (label.getBBox().width <\n axis.getSlotWidth(tick) - 2 *\n labelOptions.padding) {\n return;\n }\n }\n label.attr({\n text: ''\n });\n };\n }\n else {\n // #15692\n tick.shortenLabel = void 0;\n }\n // Call only after first render\n if (animateLabels && axis._addedPlotLB) {\n tick.moveLabel(str, labelOptions);\n }\n // First call\n if (!defined(label) && !tick.movedLabel) {\n /**\n * The rendered text label of the tick.\n * @name Highcharts.Tick#label\n * @type {Highcharts.SVGElement|undefined}\n */\n tick.label = label = tick.createLabel({ x: 0, y: 0 }, str, labelOptions);\n // Base value to detect change for new calls to getBBox\n tick.rotation = 0;\n // update\n }\n else if (label && label.textStr !== str && !animateLabels) {\n // When resetting text, also reset the width if dynamically set\n // (#8809)\n if (label.textWidth &&\n !labelOptions.style.width &&\n !label.styles.width) {\n label.css({ width: null });\n }\n label.attr({ text: str });\n label.textPxLength = label.getBBox().width;\n }\n };\n /**\n * Render and return the label of the tick.\n *\n * @private\n * @function Highcharts.Tick#createLabel\n */\n Tick.prototype.createLabel = function (xy, str, labelOptions) {\n var axis = this.axis,\n chart = axis.chart,\n label = defined(str) && labelOptions.enabled ?\n chart.renderer\n .text(str,\n xy.x,\n xy.y,\n labelOptions.useHTML)\n .add(axis.labelGroup) :\n null;\n // Un-rotated length\n if (label) {\n // Without position absolute, IE export sometimes is wrong\n if (!chart.styledMode) {\n label.css(merge(labelOptions.style));\n }\n label.textPxLength = label.getBBox().width;\n }\n return label;\n };\n /**\n * Destructor for the tick prototype\n *\n * @private\n * @function Highcharts.Tick#destroy\n */\n Tick.prototype.destroy = function () {\n destroyObjectProperties(this, this.axis);\n };\n /**\n * Gets the x and y positions for ticks in terms of pixels.\n *\n * @private\n * @function Highcharts.Tick#getPosition\n *\n * @param {boolean} horiz\n * Whether the tick is on an horizontal axis or not.\n *\n * @param {number} tickPos\n * Position of the tick.\n *\n * @param {number} tickmarkOffset\n * Tickmark offset for all ticks.\n *\n * @param {boolean} [old]\n * Whether the axis has changed or not.\n *\n * @return {Highcharts.PositionObject}\n * The tick position.\n *\n * @emits Highcharts.Tick#event:afterGetPosition\n */\n Tick.prototype.getPosition = function (horiz, tickPos, tickmarkOffset, old) {\n var axis = this.axis,\n chart = axis.chart,\n cHeight = (old && chart.oldChartHeight) || chart.chartHeight,\n pos = {\n x: horiz ?\n correctFloat(axis.translate(tickPos + tickmarkOffset,\n void 0,\n void 0,\n old) +\n axis.transB) :\n (axis.left +\n axis.offset +\n (axis.opposite ?\n (((old && chart.oldChartWidth) ||\n chart.chartWidth) -\n axis.right -\n axis.left) :\n 0)),\n y: horiz ?\n (cHeight -\n axis.bottom +\n axis.offset -\n (axis.opposite ? axis.height : 0)) :\n correctFloat(cHeight -\n axis.translate(tickPos + tickmarkOffset,\n void 0,\n void 0,\n old) -\n axis.transB)\n };\n // Chrome workaround for #10516\n pos.y = clamp(pos.y, -1e5, 1e5);\n fireEvent(this, 'afterGetPosition', { pos: pos });\n return pos;\n };\n /**\n * Get the x, y position of the tick label\n * @private\n */\n Tick.prototype.getLabelPosition = function (x, y, label, horiz, labelOptions, tickmarkOffset, index, step) {\n var axis = this.axis,\n transA = axis.transA,\n reversed = ( // #7911\n axis.isLinked && axis.linkedParent ?\n axis.linkedParent.reversed :\n axis.reversed),\n staggerLines = axis.staggerLines,\n rotCorr = axis.tickRotCorr || { x: 0,\n y: 0 }, \n // Adjust for label alignment if we use reserveSpace: true (#5286)\n labelOffsetCorrection = (!horiz && !axis.reserveSpaceDefault ?\n -axis.labelOffset * (axis.labelAlign === 'center' ? 0.5 : 1) :\n 0),\n pos = {};\n var yOffset,\n line;\n if (axis.side === 0) {\n yOffset = label.rotation ? -8 : -label.getBBox().height;\n }\n else if (axis.side === 2) {\n yOffset = rotCorr.y + 8;\n }\n else {\n // #3140, #3140\n yOffset = Math.cos(label.rotation * deg2rad) *\n (rotCorr.y - label.getBBox(false, 0).height / 2);\n }\n if (defined(labelOptions.y)) {\n yOffset = axis.side === 0 && axis.horiz ?\n labelOptions.y + yOffset :\n labelOptions.y;\n }\n x = x +\n labelOptions.x +\n labelOffsetCorrection +\n rotCorr.x -\n (tickmarkOffset && horiz ?\n tickmarkOffset * transA * (reversed ? -1 : 1) :\n 0);\n y = y + yOffset - (tickmarkOffset && !horiz ?\n tickmarkOffset * transA * (reversed ? 1 : -1) : 0);\n // Correct for staggered labels\n if (staggerLines) {\n line = (index / (step || 1) % staggerLines);\n if (axis.opposite) {\n line = staggerLines - line - 1;\n }\n y += line * (axis.labelOffset / staggerLines);\n }\n pos.x = x;\n pos.y = Math.round(y);\n fireEvent(this, 'afterGetLabelPosition', { pos: pos, tickmarkOffset: tickmarkOffset, index: index });\n return pos;\n };\n /**\n * Get the offset height or width of the label\n *\n * @private\n * @function Highcharts.Tick#getLabelSize\n */\n Tick.prototype.getLabelSize = function () {\n return this.label ?\n this.label.getBBox()[this.axis.horiz ? 'height' : 'width'] :\n 0;\n };\n /**\n * Extendible method to return the path of the marker\n * @private\n */\n Tick.prototype.getMarkPath = function (x, y, tickLength, tickWidth, horiz, renderer) {\n return renderer.crispLine([[\n 'M',\n x,\n y\n ], [\n 'L',\n x + (horiz ? 0 : -tickLength),\n y + (horiz ? tickLength : 0)\n ]], tickWidth);\n };\n /**\n * Handle the label overflow by adjusting the labels to the left and right\n * edge, or hide them if they collide into the neighbour label.\n *\n * @private\n * @function Highcharts.Tick#handleOverflow\n */\n Tick.prototype.handleOverflow = function (xy) {\n var tick = this,\n axis = this.axis,\n labelOptions = axis.options.labels,\n pxPos = xy.x,\n chartWidth = axis.chart.chartWidth,\n spacing = axis.chart.spacing,\n leftBound = pick(axis.labelLeft,\n Math.min(axis.pos,\n spacing[3])),\n rightBound = pick(axis.labelRight,\n Math.max(!axis.isRadial ? axis.pos + axis.len : 0,\n chartWidth - spacing[1])),\n label = this.label,\n rotation = this.rotation,\n factor = {\n left: 0,\n center: 0.5,\n right: 1\n }[axis.labelAlign || label.attr('align')],\n labelWidth = label.getBBox().width,\n slotWidth = axis.getSlotWidth(tick),\n xCorrection = factor,\n css = {};\n var modifiedSlotWidth = slotWidth,\n goRight = 1,\n leftPos,\n rightPos,\n textWidth;\n // Check if the label overshoots the chart spacing box. If it does, move\n // it. If it now overshoots the slotWidth, add ellipsis.\n if (!rotation && labelOptions.overflow === 'justify') {\n leftPos = pxPos - factor * labelWidth;\n rightPos = pxPos + (1 - factor) * labelWidth;\n if (leftPos < leftBound) {\n modifiedSlotWidth =\n xy.x + modifiedSlotWidth * (1 - factor) - leftBound;\n }\n else if (rightPos > rightBound) {\n modifiedSlotWidth =\n rightBound - xy.x + modifiedSlotWidth * factor;\n goRight = -1;\n }\n modifiedSlotWidth = Math.min(slotWidth, modifiedSlotWidth); // #4177\n if (modifiedSlotWidth < slotWidth && axis.labelAlign === 'center') {\n xy.x += (goRight *\n (slotWidth -\n modifiedSlotWidth -\n xCorrection * (slotWidth - Math.min(labelWidth, modifiedSlotWidth))));\n }\n // If the label width exceeds the available space, set a text width\n // to be picked up below. Also, if a width has been set before, we\n // need to set a new one because the reported labelWidth will be\n // limited by the box (#3938).\n if (labelWidth > modifiedSlotWidth ||\n (axis.autoRotation && (label.styles || {}).width)) {\n textWidth = modifiedSlotWidth;\n }\n // Add ellipsis to prevent rotated labels to be clipped against the edge\n // of the chart\n }\n else if (rotation < 0 &&\n pxPos - factor * labelWidth < leftBound) {\n textWidth = Math.round(pxPos / Math.cos(rotation * deg2rad) - leftBound);\n }\n else if (rotation > 0 &&\n pxPos + factor * labelWidth > rightBound) {\n textWidth = Math.round((chartWidth - pxPos) /\n Math.cos(rotation * deg2rad));\n }\n if (textWidth) {\n if (tick.shortenLabel) {\n tick.shortenLabel();\n }\n else {\n css.width = Math.floor(textWidth) + 'px';\n if (!(labelOptions.style || {}).textOverflow) {\n css.textOverflow = 'ellipsis';\n }\n label.css(css);\n }\n }\n };\n /**\n * Try to replace the label if the same one already exists.\n *\n * @private\n * @function Highcharts.Tick#moveLabel\n */\n Tick.prototype.moveLabel = function (str, labelOptions) {\n var tick = this,\n label = tick.label,\n axis = tick.axis,\n reversed = axis.reversed;\n var moved = false,\n labelPos,\n xPos,\n yPos;\n if (label && label.textStr === str) {\n tick.movedLabel = label;\n moved = true;\n delete tick.label;\n }\n else { // Find a label with the same string\n objectEach(axis.ticks, function (currentTick) {\n if (!moved &&\n !currentTick.isNew &&\n currentTick !== tick &&\n currentTick.label &&\n currentTick.label.textStr === str) {\n tick.movedLabel = currentTick.label;\n moved = true;\n currentTick.labelPos = tick.movedLabel.xy;\n delete currentTick.label;\n }\n });\n }\n // Create new label if the actual one is moved\n if (!moved && (tick.labelPos || label)) {\n labelPos = tick.labelPos || label.xy;\n xPos = axis.horiz ?\n (reversed ? 0 : axis.width + axis.left) : labelPos.x;\n yPos = axis.horiz ?\n labelPos.y : (reversed ? (axis.width + axis.left) : 0);\n tick.movedLabel = tick.createLabel({ x: xPos, y: yPos }, str, labelOptions);\n if (tick.movedLabel) {\n tick.movedLabel.attr({ opacity: 0 });\n }\n }\n };\n /**\n * Put everything in place\n *\n * @private\n * @param {number} index\n *\n * @param {boolean} [old]\n * Use old coordinates to prepare an animation into new position\n *\n * @param {number} [opacity]\n */\n Tick.prototype.render = function (index, old, opacity) {\n var tick = this,\n axis = tick.axis,\n horiz = axis.horiz,\n pos = tick.pos,\n tickmarkOffset = pick(tick.tickmarkOffset,\n axis.tickmarkOffset),\n xy = tick.getPosition(horiz,\n pos,\n tickmarkOffset,\n old),\n x = xy.x,\n y = xy.y,\n reverseCrisp = ((horiz && x === axis.pos + axis.len) ||\n (!horiz && y === axis.pos)) ? -1 : 1; // #1480, #1687\n var labelOpacity = pick(opacity,\n tick.label && tick.label.newOpacity, // #15528\n 1);\n opacity = pick(opacity, 1);\n this.isActive = true;\n // Create the grid line\n this.renderGridLine(old, opacity, reverseCrisp);\n // create the tick mark\n this.renderMark(xy, opacity, reverseCrisp);\n // the label is created on init - now move it into place\n this.renderLabel(xy, old, labelOpacity, index);\n tick.isNew = false;\n fireEvent(this, 'afterRender');\n };\n /**\n * Renders the gridLine.\n *\n * @private\n * @function Highcharts.Tick#renderGridLine\n * @param {boolean} old Whether or not the tick is old\n * @param {number} opacity The opacity of the grid line\n * @param {number} reverseCrisp Modifier for avoiding overlapping 1 or -1\n */\n Tick.prototype.renderGridLine = function (old, opacity, reverseCrisp) {\n var tick = this,\n axis = tick.axis,\n options = axis.options,\n attribs = {},\n pos = tick.pos,\n type = tick.type,\n tickmarkOffset = pick(tick.tickmarkOffset,\n axis.tickmarkOffset),\n renderer = axis.chart.renderer;\n var gridLine = tick.gridLine,\n gridLinePath,\n gridLineWidth = options.gridLineWidth,\n gridLineColor = options.gridLineColor,\n dashStyle = options.gridLineDashStyle;\n if (tick.type === 'minor') {\n gridLineWidth = options.minorGridLineWidth;\n gridLineColor = options.minorGridLineColor;\n dashStyle = options.minorGridLineDashStyle;\n }\n if (!gridLine) {\n if (!axis.chart.styledMode) {\n attribs.stroke = gridLineColor;\n attribs['stroke-width'] = gridLineWidth || 0;\n attribs.dashstyle = dashStyle;\n }\n if (!type) {\n attribs.zIndex = 1;\n }\n if (old) {\n opacity = 0;\n }\n /**\n * The rendered grid line of the tick.\n * @name Highcharts.Tick#gridLine\n * @type {Highcharts.SVGElement|undefined}\n */\n tick.gridLine = gridLine = renderer.path()\n .attr(attribs)\n .addClass('highcharts-' + (type ? type + '-' : '') + 'grid-line')\n .add(axis.gridGroup);\n }\n if (gridLine) {\n gridLinePath = axis.getPlotLinePath({\n value: pos + tickmarkOffset,\n lineWidth: gridLine.strokeWidth() * reverseCrisp,\n force: 'pass',\n old: old\n });\n // If the parameter 'old' is set, the current call will be followed\n // by another call, therefore do not do any animations this time\n if (gridLinePath) {\n gridLine[old || tick.isNew ? 'attr' : 'animate']({\n d: gridLinePath,\n opacity: opacity\n });\n }\n }\n };\n /**\n * Renders the tick mark.\n *\n * @private\n * @function Highcharts.Tick#renderMark\n * @param {Highcharts.PositionObject} xy The position vector of the mark\n * @param {number} opacity The opacity of the mark\n * @param {number} reverseCrisp Modifier for avoiding overlapping 1 or -1\n */\n Tick.prototype.renderMark = function (xy, opacity, reverseCrisp) {\n var tick = this, axis = tick.axis, options = axis.options, renderer = axis.chart.renderer, type = tick.type, tickSize = axis.tickSize(type ? type + 'Tick' : 'tick'), x = xy.x, y = xy.y, tickWidth = pick(options[type !== 'minor' ? 'tickWidth' : 'minorTickWidth'], !type && axis.isXAxis ? 1 : 0), // X axis defaults to 1\n tickColor = options[type !== 'minor' ? 'tickColor' : 'minorTickColor'];\n var mark = tick.mark;\n var isNewMark = !mark;\n if (tickSize) {\n // negate the length\n if (axis.opposite) {\n tickSize[0] = -tickSize[0];\n }\n // First time, create it\n if (!mark) {\n /**\n * The rendered mark of the tick.\n * @name Highcharts.Tick#mark\n * @type {Highcharts.SVGElement|undefined}\n */\n tick.mark = mark = renderer.path()\n .addClass('highcharts-' + (type ? type + '-' : '') + 'tick')\n .add(axis.axisGroup);\n if (!axis.chart.styledMode) {\n mark.attr({\n stroke: tickColor,\n 'stroke-width': tickWidth\n });\n }\n }\n mark[isNewMark ? 'attr' : 'animate']({\n d: tick.getMarkPath(x, y, tickSize[0], mark.strokeWidth() * reverseCrisp, axis.horiz, renderer),\n opacity: opacity\n });\n }\n };\n /**\n * Renders the tick label.\n * Note: The label should already be created in init(), so it should only\n * have to be moved into place.\n *\n * @private\n * @function Highcharts.Tick#renderLabel\n * @param {Highcharts.PositionObject} xy The position vector of the label\n * @param {boolean} old Whether or not the tick is old\n * @param {number} opacity The opacity of the label\n * @param {number} index The index of the tick\n */\n Tick.prototype.renderLabel = function (xy, old, opacity, index) {\n var tick = this,\n axis = tick.axis,\n horiz = axis.horiz,\n options = axis.options,\n label = tick.label,\n labelOptions = options.labels,\n step = labelOptions.step,\n tickmarkOffset = pick(tick.tickmarkOffset,\n axis.tickmarkOffset),\n x = xy.x,\n y = xy.y;\n var show = true;\n if (label && isNumber(x)) {\n label.xy = xy = tick.getLabelPosition(x, y, label, horiz, labelOptions, tickmarkOffset, index, step);\n // Apply show first and show last. If the tick is both first and\n // last, it is a single centered tick, in which case we show the\n // label anyway (#2100).\n if ((tick.isFirst &&\n !tick.isLast &&\n !options.showFirstLabel) ||\n (tick.isLast &&\n !tick.isFirst &&\n !options.showLastLabel)) {\n show = false;\n // Handle label overflow and show or hide accordingly\n }\n else if (horiz &&\n !labelOptions.step &&\n !labelOptions.rotation &&\n !old &&\n opacity !== 0) {\n tick.handleOverflow(xy);\n }\n // apply step\n if (step && index % step) {\n // show those indices dividable by step\n show = false;\n }\n // Set the new position, and show or hide\n if (show && isNumber(xy.y)) {\n xy.opacity = opacity;\n label[tick.isNewLabel ? 'attr' : 'animate'](xy).show(true);\n tick.isNewLabel = false;\n }\n else {\n label.hide(); // #1338, #15863\n tick.isNewLabel = true;\n }\n }\n };\n /**\n * Replace labels with the moved ones to perform animation. Additionally\n * destroy unused labels.\n *\n * @private\n * @function Highcharts.Tick#replaceMovedLabel\n */\n Tick.prototype.replaceMovedLabel = function () {\n var tick = this,\n label = tick.label,\n axis = tick.axis,\n reversed = axis.reversed;\n var x,\n y;\n // Animate and destroy\n if (label && !tick.isNew) {\n x = axis.horiz ? (reversed ? axis.left : axis.width + axis.left) : label.xy.x;\n y = axis.horiz ?\n label.xy.y :\n (reversed ? axis.width + axis.top : axis.top);\n label.animate({ x: x, y: y, opacity: 0 }, void 0, label.destroy);\n delete tick.label;\n }\n axis.isDirty = true;\n tick.label = tick.movedLabel;\n delete tick.movedLabel;\n };\n return Tick;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Optional parameters for the tick.\n * @private\n * @interface Highcharts.TickParametersObject\n */ /**\n * Set category for the tick.\n * @name Highcharts.TickParametersObject#category\n * @type {string|undefined}\n */ /**\n * @name Highcharts.TickParametersObject#options\n * @type {Highcharts.Dictionary|undefined}\n */ /**\n * Set tickmarkOffset for the tick.\n * @name Highcharts.TickParametersObject#tickmarkOffset\n * @type {number|undefined}\n */\n /**\n * Additonal time tick information.\n *\n * @interface Highcharts.TimeTicksInfoObject\n * @extends Highcharts.TimeNormalizedObject\n */ /**\n * @name Highcharts.TimeTicksInfoObject#higherRanks\n * @type {Array}\n */ /**\n * @name Highcharts.TimeTicksInfoObject#totalRange\n * @type {number}\n */\n (''); // keeps doclets above in JS file\n\n return Tick;\n });\n _registerModule(_modules, 'Core/Axis/Axis.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Axis/AxisDefaults.js'], _modules['Core/Color/Color.js'], _modules['Core/Defaults.js'], _modules['Core/Foundation.js'], _modules['Core/Globals.js'], _modules['Core/Axis/Tick.js'], _modules['Core/Utilities.js']], function (A, AxisDefaults, Color, D, F, H, Tick, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var animObject = A.animObject;\n var defaultOptions = D.defaultOptions;\n var registerEventOptions = F.registerEventOptions;\n var deg2rad = H.deg2rad;\n var arrayMax = U.arrayMax,\n arrayMin = U.arrayMin,\n clamp = U.clamp,\n correctFloat = U.correctFloat,\n defined = U.defined,\n destroyObjectProperties = U.destroyObjectProperties,\n erase = U.erase,\n error = U.error,\n extend = U.extend,\n fireEvent = U.fireEvent,\n isArray = U.isArray,\n isNumber = U.isNumber,\n isString = U.isString,\n merge = U.merge,\n normalizeTickInterval = U.normalizeTickInterval,\n objectEach = U.objectEach,\n pick = U.pick,\n relativeLength = U.relativeLength,\n removeEvent = U.removeEvent,\n splat = U.splat,\n syncTimeout = U.syncTimeout;\n var getNormalizedTickInterval = function (axis,\n tickInterval) { return normalizeTickInterval(tickInterval,\n void 0,\n void 0,\n pick(axis.options.allowDecimals, \n // If the tick interval is greather than 0.5, avoid decimals, as\n // linear axes are often used to render discrete values (#3363). If\n // a tick amount is set, allow decimals by default, as it increases\n // the chances for a good fit.\n tickInterval < 0.5 || axis.tickAmount !== void 0), !!axis.tickAmount); };\n /* *\n *\n * Class\n *\n * */\n /**\n * Create a new axis object. Called internally when instanciating a new chart or\n * adding axes by {@link Highcharts.Chart#addAxis}.\n *\n * A chart can have from 0 axes (pie chart) to multiples. In a normal, single\n * series cartesian chart, there is one X axis and one Y axis.\n *\n * The X axis or axes are referenced by {@link Highcharts.Chart.xAxis}, which is\n * an array of Axis objects. If there is only one axis, it can be referenced\n * through `chart.xAxis[0]`, and multiple axes have increasing indices. The same\n * pattern goes for Y axes.\n *\n * If you need to get the axes from a series object, use the `series.xAxis` and\n * `series.yAxis` properties. These are not arrays, as one series can only be\n * associated to one X and one Y axis.\n *\n * A third way to reference the axis programmatically is by `id`. Add an `id` in\n * the axis configuration options, and get the axis by\n * {@link Highcharts.Chart#get}.\n *\n * Configuration options for the axes are given in options.xAxis and\n * options.yAxis.\n *\n * @class\n * @name Highcharts.Axis\n *\n * @param {Highcharts.Chart} chart\n * The Chart instance to apply the axis on.\n *\n * @param {Highcharts.AxisOptions} userOptions\n * Axis options.\n */\n var Axis = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Axis(chart, userOptions) {\n this.alternateBands = void 0;\n this.bottom = void 0;\n this.chart = void 0;\n this.closestPointRange = void 0;\n this.coll = void 0;\n this.eventOptions = void 0;\n this.hasNames = void 0;\n this.hasVisibleSeries = void 0;\n this.height = void 0;\n this.isLinked = void 0;\n this.labelEdge = void 0; // @todo\n this.labelFormatter = void 0;\n this.left = void 0;\n this.len = void 0;\n this.max = void 0;\n this.maxLabelLength = void 0;\n this.min = void 0;\n this.minorTickInterval = void 0;\n this.minorTicks = void 0;\n this.minPixelPadding = void 0;\n this.names = void 0;\n this.offset = void 0;\n this.options = void 0;\n this.overlap = void 0;\n this.paddedTicks = void 0;\n this.plotLinesAndBands = void 0;\n this.plotLinesAndBandsGroups = void 0;\n this.pointRange = void 0;\n this.pointRangePadding = void 0;\n this.pos = void 0;\n this.positiveValuesOnly = void 0;\n this.right = void 0;\n this.series = void 0;\n this.side = void 0;\n this.tickAmount = void 0;\n this.tickInterval = void 0;\n this.tickmarkOffset = void 0;\n this.tickPositions = void 0;\n this.tickRotCorr = void 0;\n this.ticks = void 0;\n this.top = void 0;\n this.transA = void 0;\n this.transB = void 0;\n this.translationSlope = void 0;\n this.userOptions = void 0;\n this.visible = void 0;\n this.width = void 0;\n this.zoomEnabled = void 0;\n this.init(chart, userOptions);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Overrideable function to initialize the axis.\n *\n * @see {@link Axis}\n *\n * @function Highcharts.Axis#init\n *\n * @param {Highcharts.Chart} chart\n * The Chart instance to apply the axis on.\n *\n * @param {AxisOptions} userOptions\n * Axis options.\n *\n * @emits Highcharts.Axis#event:afterInit\n * @emits Highcharts.Axis#event:init\n */\n Axis.prototype.init = function (chart, userOptions) {\n var isXAxis = userOptions.isX,\n axis = this;\n /**\n * The Chart that the axis belongs to.\n *\n * @name Highcharts.Axis#chart\n * @type {Highcharts.Chart}\n */\n axis.chart = chart;\n /**\n * Whether the axis is horizontal.\n *\n * @name Highcharts.Axis#horiz\n * @type {boolean|undefined}\n */\n axis.horiz = chart.inverted && !axis.isZAxis ? !isXAxis : isXAxis;\n /**\n * Whether the axis is the x-axis.\n *\n * @name Highcharts.Axis#isXAxis\n * @type {boolean|undefined}\n */\n axis.isXAxis = isXAxis;\n /**\n * The collection where the axis belongs, for example `xAxis`, `yAxis`\n * or `colorAxis`. Corresponds to properties on Chart, for example\n * {@link Chart.xAxis}.\n *\n * @name Highcharts.Axis#coll\n * @type {string}\n */\n axis.coll = axis.coll || (isXAxis ? 'xAxis' : 'yAxis');\n fireEvent(this, 'init', { userOptions: userOptions });\n // Needed in setOptions\n axis.opposite = pick(userOptions.opposite, axis.opposite);\n /**\n * The side on which the axis is rendered. 0 is top, 1 is right, 2\n * is bottom and 3 is left.\n *\n * @name Highcharts.Axis#side\n * @type {number}\n */\n axis.side = pick(userOptions.side, axis.side, (axis.horiz ?\n (axis.opposite ? 0 : 2) : // top : bottom\n (axis.opposite ? 1 : 3)) // right : left\n );\n /**\n * Current options for the axis after merge of defaults and user's\n * options.\n *\n * @name Highcharts.Axis#options\n * @type {Highcharts.AxisOptions}\n */\n axis.setOptions(userOptions);\n var options = this.options,\n labelsOptions = options.labels,\n type = options.type;\n /**\n * User's options for this axis without defaults.\n *\n * @name Highcharts.Axis#userOptions\n * @type {Highcharts.AxisOptions}\n */\n axis.userOptions = userOptions;\n axis.minPixelPadding = 0;\n /**\n * Whether the axis is reversed. Based on the `axis.reversed`,\n * option, but inverted charts have reversed xAxis by default.\n *\n * @name Highcharts.Axis#reversed\n * @type {boolean}\n */\n axis.reversed = pick(options.reversed, axis.reversed);\n axis.visible = options.visible;\n axis.zoomEnabled = options.zoomEnabled;\n // Initial categories\n axis.hasNames =\n type === 'category' || options.categories === true;\n /**\n * If categories are present for the axis, names are used instead of\n * numbers for that axis.\n *\n * Since Highcharts 3.0, categories can also be extracted by giving each\n * point a name and setting axis type to `category`. However, if you\n * have multiple series, best practice remains defining the `categories`\n * array.\n *\n * @see [xAxis.categories](/highcharts/xAxis.categories)\n *\n * @name Highcharts.Axis#categories\n * @type {Array}\n * @readonly\n */\n axis.categories = options.categories || (axis.hasNames ? [] : void 0);\n if (!axis.names) { // Preserve on update (#3830)\n axis.names = [];\n axis.names.keys = {};\n }\n // Placeholder for plotlines and plotbands groups\n axis.plotLinesAndBandsGroups = {};\n // Shorthand types\n axis.positiveValuesOnly = !!axis.logarithmic;\n // Flag, if axis is linked to another axis\n axis.isLinked = defined(options.linkedTo);\n /**\n * List of major ticks mapped by postition on axis.\n *\n * @see {@link Highcharts.Tick}\n *\n * @name Highcharts.Axis#ticks\n * @type {Highcharts.Dictionary}\n */\n axis.ticks = {};\n axis.labelEdge = [];\n /**\n * List of minor ticks mapped by position on the axis.\n *\n * @see {@link Highcharts.Tick}\n *\n * @name Highcharts.Axis#minorTicks\n * @type {Highcharts.Dictionary}\n */\n axis.minorTicks = {};\n // List of plotLines/Bands\n axis.plotLinesAndBands = [];\n // Alternate bands\n axis.alternateBands = {};\n // Axis metrics\n axis.len = 0;\n axis.minRange = axis.userMinRange = options.minRange || options.maxZoom;\n axis.range = options.range;\n axis.offset = options.offset || 0;\n /**\n * The maximum value of the axis. In a logarithmic axis, this is the\n * logarithm of the real value, and the real value can be obtained from\n * {@link Axis#getExtremes}.\n *\n * @name Highcharts.Axis#max\n * @type {number|null}\n */\n axis.max = null;\n /**\n * The minimum value of the axis. In a logarithmic axis, this is the\n * logarithm of the real value, and the real value can be obtained from\n * {@link Axis#getExtremes}.\n *\n * @name Highcharts.Axis#min\n * @type {number|null}\n */\n axis.min = null;\n /**\n * The processed crosshair options.\n *\n * @name Highcharts.Axis#crosshair\n * @type {boolean|Highcharts.AxisCrosshairOptions}\n */\n var crosshair = pick(options.crosshair,\n splat(chart.options.tooltip.crosshairs)[isXAxis ? 0 : 1]);\n axis.crosshair = crosshair === true ? {} : crosshair;\n // Register. Don't add it again on Axis.update().\n if (chart.axes.indexOf(axis) === -1) { //\n if (isXAxis) { // #2713\n chart.axes.splice(chart.xAxis.length, 0, axis);\n }\n else {\n chart.axes.push(axis);\n }\n chart[axis.coll].push(axis);\n }\n /**\n * All series associated to the axis.\n *\n * @name Highcharts.Axis#series\n * @type {Array}\n */\n axis.series = axis.series || []; // populated by Series\n // Reversed axis\n if (chart.inverted &&\n !axis.isZAxis &&\n isXAxis &&\n typeof axis.reversed === 'undefined') {\n axis.reversed = true;\n }\n axis.labelRotation = isNumber(labelsOptions.rotation) ?\n labelsOptions.rotation :\n void 0;\n // Register event listeners\n registerEventOptions(axis, options);\n fireEvent(this, 'afterInit');\n };\n /**\n * Merge and set options.\n *\n * @private\n * @function Highcharts.Axis#setOptions\n *\n * @param {Highcharts.AxisOptions} userOptions\n * Axis options.\n *\n * @emits Highcharts.Axis#event:afterSetOptions\n */\n Axis.prototype.setOptions = function (userOptions) {\n this.options = merge(AxisDefaults.defaultXAxisOptions, (this.coll === 'yAxis') && AxisDefaults.defaultYAxisOptions, [\n AxisDefaults.defaultTopAxisOptions,\n AxisDefaults.defaultRightAxisOptions,\n AxisDefaults.defaultBottomAxisOptions,\n AxisDefaults.defaultLeftAxisOptions\n ][this.side], merge(\n // if set in setOptions (#1053):\n defaultOptions[this.coll], userOptions));\n fireEvent(this, 'afterSetOptions', { userOptions: userOptions });\n };\n /**\n * The default label formatter. The context is a special config object for\n * the label. In apps, use the\n * [labels.formatter](https://api.highcharts.com/highcharts/xAxis.labels.formatter)\n * instead, except when a modification is needed.\n *\n * @function Highcharts.Axis#defaultLabelFormatter\n *\n * @param {Highcharts.AxisLabelsFormatterContextObject} this\n * Formatter context of axis label.\n *\n * @param {Highcharts.AxisLabelsFormatterContextObject} [ctx]\n * Formatter context of axis label.\n *\n * @return {string}\n * The formatted label content.\n */\n Axis.prototype.defaultLabelFormatter = function (ctx) {\n var axis = this.axis,\n chart = this.chart,\n numberFormatter = chart.numberFormatter,\n value = isNumber(this.value) ? this.value : NaN,\n time = axis.chart.time,\n categories = axis.categories,\n dateTimeLabelFormat = this.dateTimeLabelFormat,\n lang = defaultOptions.lang,\n numericSymbols = lang.numericSymbols,\n numSymMagnitude = lang.numericSymbolMagnitude || 1000, \n // make sure the same symbol is added for all labels on a linear\n // axis\n numericSymbolDetector = axis.logarithmic ?\n Math.abs(value) :\n axis.tickInterval;\n var i = numericSymbols && numericSymbols.length,\n multi,\n ret;\n if (categories) {\n ret = \"\".concat(this.value);\n }\n else if (dateTimeLabelFormat) { // datetime axis\n ret = time.dateFormat(dateTimeLabelFormat, value);\n }\n else if (i && numericSymbolDetector >= 1000) {\n // Decide whether we should add a numeric symbol like k (thousands)\n // or M (millions). If we are to enable this in tooltip or other\n // places as well, we can move this logic to the numberFormatter and\n // enable it by a parameter.\n while (i-- && typeof ret === 'undefined') {\n multi = Math.pow(numSymMagnitude, i + 1);\n if (\n // Only accept a numeric symbol when the distance is more\n // than a full unit. So for example if the symbol is k, we\n // don't accept numbers like 0.5k.\n numericSymbolDetector >= multi &&\n // Accept one decimal before the symbol. Accepts 0.5k but\n // not 0.25k. How does this work with the previous?\n (value * 10) % multi === 0 &&\n numericSymbols[i] !== null &&\n value !== 0) { // #5480\n ret = numberFormatter(value / multi, -1) + numericSymbols[i];\n }\n }\n }\n if (typeof ret === 'undefined') {\n if (Math.abs(value) >= 10000) { // add thousands separators\n ret = numberFormatter(value, -1);\n }\n else { // small numbers\n ret = numberFormatter(value, -1, void 0, ''); // #2466\n }\n }\n return ret;\n };\n /**\n * Get the minimum and maximum for the series of each axis. The function\n * analyzes the axis series and updates `this.dataMin` and `this.dataMax`.\n *\n * @private\n * @function Highcharts.Axis#getSeriesExtremes\n *\n * @emits Highcharts.Axis#event:afterGetSeriesExtremes\n * @emits Highcharts.Axis#event:getSeriesExtremes\n */\n Axis.prototype.getSeriesExtremes = function () {\n var axis = this,\n chart = axis.chart;\n var xExtremes;\n fireEvent(this, 'getSeriesExtremes', null, function () {\n axis.hasVisibleSeries = false;\n // Reset properties in case we're redrawing (#3353)\n axis.dataMin = axis.dataMax = axis.threshold = null;\n axis.softThreshold = !axis.isXAxis;\n if (axis.stacking) {\n axis.stacking.buildStacks();\n }\n // loop through this axis' series\n axis.series.forEach(function (series) {\n if (series.visible ||\n !chart.options.chart.ignoreHiddenSeries) {\n var seriesOptions = series.options;\n var xData = void 0,\n threshold = seriesOptions.threshold,\n seriesDataMin = void 0,\n seriesDataMax = void 0;\n axis.hasVisibleSeries = true;\n // Validate threshold in logarithmic axes\n if (axis.positiveValuesOnly && threshold <= 0) {\n threshold = null;\n }\n // Get dataMin and dataMax for X axes\n if (axis.isXAxis) {\n xData = series.xData;\n if (xData.length) {\n xData = axis.logarithmic ?\n xData.filter(axis.validatePositiveValue) :\n xData;\n xExtremes = series.getXExtremes(xData);\n // If xData contains values which is not numbers,\n // then filter them out. To prevent performance hit,\n // we only do this after we have already found\n // seriesDataMin because in most cases all data is\n // valid. #5234.\n seriesDataMin = xExtremes.min;\n seriesDataMax = xExtremes.max;\n if (!isNumber(seriesDataMin) &&\n // #5010:\n !(seriesDataMin instanceof Date)) {\n xData = xData.filter(isNumber);\n xExtremes = series.getXExtremes(xData);\n // Do it again with valid data\n seriesDataMin = xExtremes.min;\n seriesDataMax = xExtremes.max;\n }\n if (xData.length) {\n axis.dataMin = Math.min(pick(axis.dataMin, seriesDataMin), seriesDataMin);\n axis.dataMax = Math.max(pick(axis.dataMax, seriesDataMax), seriesDataMax);\n }\n }\n // Get dataMin and dataMax for Y axes, as well as handle\n // stacking and processed data\n }\n else {\n // Get this particular series extremes\n var dataExtremes = series.applyExtremes();\n // Get the dataMin and dataMax so far. If percentage is\n // used, the min and max are always 0 and 100. If\n // seriesDataMin and seriesDataMax is null, then series\n // doesn't have active y data, we continue with nulls\n if (isNumber(dataExtremes.dataMin)) {\n seriesDataMin = dataExtremes.dataMin;\n axis.dataMin = Math.min(pick(axis.dataMin, seriesDataMin), seriesDataMin);\n }\n if (isNumber(dataExtremes.dataMax)) {\n seriesDataMax = dataExtremes.dataMax;\n axis.dataMax = Math.max(pick(axis.dataMax, seriesDataMax), seriesDataMax);\n }\n // Adjust to threshold\n if (defined(threshold)) {\n axis.threshold = threshold;\n }\n // If any series has a hard threshold, it takes\n // precedence\n if (!seriesOptions.softThreshold ||\n axis.positiveValuesOnly) {\n axis.softThreshold = false;\n }\n }\n }\n });\n });\n fireEvent(this, 'afterGetSeriesExtremes');\n };\n /**\n * Translate from axis value to pixel position on the chart, or back. Use\n * the `toPixels` and `toValue` functions in applications.\n *\n * @private\n * @function Highcharts.Axis#translate\n */\n Axis.prototype.translate = function (val, backwards, cvsCoord, old, handleLog, pointPlacement) {\n var axis = (this.linkedParent || this), // #1417\n localMin = (old && axis.old ? axis.old.min : axis.min);\n if (!isNumber(localMin)) {\n return NaN;\n }\n var minPixelPadding = axis.minPixelPadding,\n doPostTranslate = (axis.isOrdinal ||\n axis.brokenAxis && axis.brokenAxis.hasBreaks ||\n (axis.logarithmic && handleLog)) && axis.lin2val;\n var sign = 1,\n cvsOffset = 0,\n localA = old && axis.old ? axis.old.transA : axis.transA,\n returnValue = 0;\n if (!localA) {\n localA = axis.transA;\n }\n // In vertical axes, the canvas coordinates start from 0 at the top like\n // in SVG.\n if (cvsCoord) {\n sign *= -1; // canvas coordinates inverts the value\n cvsOffset = axis.len;\n }\n // Handle reversed axis\n if (axis.reversed) {\n sign *= -1;\n cvsOffset -= sign * (axis.sector || axis.len);\n }\n // From pixels to value\n if (backwards) { // reverse translation\n val = val * sign + cvsOffset;\n val -= minPixelPadding;\n // from chart pixel to value:\n returnValue = val / localA + localMin;\n if (doPostTranslate) { // log, ordinal and broken axis\n returnValue = axis.lin2val(returnValue);\n }\n // From value to pixels\n }\n else {\n if (doPostTranslate) { // log, ordinal and broken axis\n val = axis.val2lin(val);\n }\n var value = sign * (val - localMin) * localA;\n returnValue = (!axis.isRadial ? correctFloat(value) : value) +\n cvsOffset +\n (sign * minPixelPadding) +\n (isNumber(pointPlacement) ? localA * pointPlacement : 0);\n }\n return returnValue;\n };\n /**\n * Translate a value in terms of axis units into pixels within the chart.\n *\n * @function Highcharts.Axis#toPixels\n *\n * @param {number} value\n * A value in terms of axis units.\n *\n * @param {boolean} paneCoordinates\n * Whether to return the pixel coordinate relative to the chart or just the\n * axis/pane itself.\n *\n * @return {number}\n * Pixel position of the value on the chart or axis.\n */\n Axis.prototype.toPixels = function (value, paneCoordinates) {\n return this.translate(value, false, !this.horiz, void 0, true) +\n (paneCoordinates ? 0 : this.pos);\n };\n /**\n * Translate a pixel position along the axis to a value in terms of axis\n * units.\n *\n * @function Highcharts.Axis#toValue\n *\n * @param {number} pixel\n * The pixel value coordinate.\n *\n * @param {boolean} [paneCoordinates=false]\n * Whether the input pixel is relative to the chart or just the axis/pane\n * itself.\n *\n * @return {number}\n * The axis value.\n */\n Axis.prototype.toValue = function (pixel, paneCoordinates) {\n return this.translate(pixel - (paneCoordinates ? 0 : this.pos), true, !this.horiz, void 0, true);\n };\n /**\n * Create the path for a plot line that goes from the given value on\n * this axis, across the plot to the opposite side. Also used internally for\n * grid lines and crosshairs.\n *\n * @function Highcharts.Axis#getPlotLinePath\n *\n * @param {Highcharts.AxisPlotLinePathOptionsObject} options\n * Options for the path.\n *\n * @return {Highcharts.SVGPathArray|null}\n * The SVG path definition for the plot line.\n */\n Axis.prototype.getPlotLinePath = function (options) {\n var axis = this,\n chart = axis.chart,\n axisLeft = axis.left,\n axisTop = axis.top,\n old = options.old,\n value = options.value,\n lineWidth = options.lineWidth,\n cHeight = (old && chart.oldChartHeight) || chart.chartHeight,\n cWidth = (old && chart.oldChartWidth) || chart.chartWidth,\n transB = axis.transB;\n var translatedValue = options.translatedValue,\n force = options.force,\n x1,\n y1,\n x2,\n y2,\n skip;\n // eslint-disable-next-line valid-jsdoc\n /**\n * Check if x is between a and b. If not, either move to a/b\n * or skip, depending on the force parameter.\n * @private\n */\n function between(x, a, b) {\n if (force !== 'pass' && x < a || x > b) {\n if (force) {\n x = clamp(x, a, b);\n }\n else {\n skip = true;\n }\n }\n return x;\n }\n var evt = {\n value: value,\n lineWidth: lineWidth,\n old: old,\n force: force,\n acrossPanes: options.acrossPanes,\n translatedValue: translatedValue\n };\n fireEvent(this, 'getPlotLinePath', evt, function (e) {\n translatedValue = pick(translatedValue, axis.translate(value, void 0, void 0, old));\n // Keep the translated value within sane bounds, and avoid Infinity\n // to fail the isNumber test (#7709).\n translatedValue = clamp(translatedValue, -1e5, 1e5);\n x1 = x2 = Math.round(translatedValue + transB);\n y1 = y2 = Math.round(cHeight - translatedValue - transB);\n if (!isNumber(translatedValue)) { // no min or max\n skip = true;\n force = false; // #7175, don't force it when path is invalid\n }\n else if (axis.horiz) {\n y1 = axisTop;\n y2 = cHeight - axis.bottom;\n x1 = x2 = between(x1, axisLeft, axisLeft + axis.width);\n }\n else {\n x1 = axisLeft;\n x2 = cWidth - axis.right;\n y1 = y2 = between(y1, axisTop, axisTop + axis.height);\n }\n e.path = skip && !force ?\n null :\n chart.renderer.crispLine([['M', x1, y1], ['L', x2, y2]], lineWidth || 1);\n });\n return evt.path;\n };\n /**\n * Internal function to get the tick positions of a linear axis to round\n * values like whole tens or every five.\n *\n * @function Highcharts.Axis#getLinearTickPositions\n *\n * @param {number} tickInterval\n * The normalized tick interval.\n *\n * @param {number} min\n * Axis minimum.\n *\n * @param {number} max\n * Axis maximum.\n *\n * @return {Array}\n * An array of axis values where ticks should be placed.\n */\n Axis.prototype.getLinearTickPositions = function (tickInterval, min, max) {\n var roundedMin = correctFloat(Math.floor(min / tickInterval) * tickInterval),\n roundedMax = correctFloat(Math.ceil(max / tickInterval) * tickInterval),\n tickPositions = [];\n var pos,\n lastPos,\n precision;\n // When the precision is higher than what we filter out in\n // correctFloat, skip it (#6183).\n if (correctFloat(roundedMin + tickInterval) === roundedMin) {\n precision = 20;\n }\n // For single points, add a tick regardless of the relative position\n // (#2662, #6274)\n if (this.single) {\n return [min];\n }\n // Populate the intermediate values\n pos = roundedMin;\n while (pos <= roundedMax) {\n // Place the tick on the rounded value\n tickPositions.push(pos);\n // Always add the raw tickInterval, not the corrected one.\n pos = correctFloat(pos + tickInterval, precision);\n // If the interval is not big enough in the current min - max range\n // to actually increase the loop variable, we need to break out to\n // prevent endless loop. Issue #619\n if (pos === lastPos) {\n break;\n }\n // Record the last value\n lastPos = pos;\n }\n return tickPositions;\n };\n /**\n * Resolve the new minorTicks/minorTickInterval options into the legacy\n * loosely typed minorTickInterval option.\n *\n * @function Highcharts.Axis#getMinorTickInterval\n *\n * @return {number|\"auto\"|null}\n * Legacy option\n */\n Axis.prototype.getMinorTickInterval = function () {\n var options = this.options;\n if (options.minorTicks === true) {\n return pick(options.minorTickInterval, 'auto');\n }\n if (options.minorTicks === false) {\n return null;\n }\n return options.minorTickInterval;\n };\n /**\n * Internal function to return the minor tick positions. For logarithmic\n * axes, the same logic as for major ticks is reused.\n *\n * @function Highcharts.Axis#getMinorTickPositions\n *\n * @return {Array}\n * An array of axis values where ticks should be placed.\n */\n Axis.prototype.getMinorTickPositions = function () {\n var axis = this,\n options = axis.options,\n tickPositions = axis.tickPositions,\n minorTickInterval = axis.minorTickInterval,\n pointRangePadding = axis.pointRangePadding || 0,\n min = axis.min - pointRangePadding, // #1498\n max = axis.max + pointRangePadding, // #1498\n range = max - min;\n var minorTickPositions = [],\n pos;\n // If minor ticks get too dense, they are hard to read, and may cause\n // long running script. So we don't draw them.\n if (range && range / minorTickInterval < axis.len / 3) { // #3875\n var logarithmic_1 = axis.logarithmic;\n if (logarithmic_1) {\n // For each interval in the major ticks, compute the minor ticks\n // separately.\n this.paddedTicks.forEach(function (_pos, i, paddedTicks) {\n if (i) {\n minorTickPositions.push.apply(minorTickPositions, logarithmic_1.getLogTickPositions(minorTickInterval, paddedTicks[i - 1], paddedTicks[i], true));\n }\n });\n }\n else if (axis.dateTime &&\n this.getMinorTickInterval() === 'auto') { // #1314\n minorTickPositions = minorTickPositions.concat(axis.getTimeTicks(axis.dateTime.normalizeTimeTickInterval(minorTickInterval), min, max, options.startOfWeek));\n }\n else {\n for (pos = min + (tickPositions[0] - min) % minorTickInterval; pos <= max; pos += minorTickInterval) {\n // Very, very, tight grid lines (#5771)\n if (pos === minorTickPositions[0]) {\n break;\n }\n minorTickPositions.push(pos);\n }\n }\n }\n if (minorTickPositions.length !== 0) {\n axis.trimTicks(minorTickPositions); // #3652 #3743 #1498 #6330\n }\n return minorTickPositions;\n };\n /**\n * Adjust the min and max for the minimum range. Keep in mind that the\n * series data is not yet processed, so we don't have information on data\n * cropping and grouping, or updated `axis.pointRange` or\n * `series.pointRange`. The data can't be processed until we have finally\n * established min and max.\n *\n * @private\n * @function Highcharts.Axis#adjustForMinRange\n */\n Axis.prototype.adjustForMinRange = function () {\n var axis = this,\n options = axis.options,\n log = axis.logarithmic;\n var min = axis.min,\n max = axis.max,\n zoomOffset,\n spaceAvailable,\n closestDataRange = 0,\n i,\n distance,\n xData,\n loopLength,\n minArgs,\n maxArgs,\n minRange;\n // Set the automatic minimum range based on the closest point distance\n if (axis.isXAxis &&\n typeof axis.minRange === 'undefined' &&\n !log) {\n if (defined(options.min) ||\n defined(options.max) ||\n defined(options.floor) ||\n defined(options.ceiling)) {\n axis.minRange = null; // don't do this again\n }\n else {\n // Find the closest distance between raw data points, as opposed\n // to closestPointRange that applies to processed points\n // (cropped and grouped)\n axis.series.forEach(function (series) {\n xData = series.xData;\n loopLength = series.xIncrement ? 1 : xData.length - 1;\n if (xData.length > 1) {\n for (i = loopLength; i > 0; i--) {\n distance = xData[i] - xData[i - 1];\n if (!closestDataRange ||\n distance < closestDataRange) {\n closestDataRange = distance;\n }\n }\n }\n });\n axis.minRange = Math.min(closestDataRange * 5, axis.dataMax - axis.dataMin);\n }\n }\n // if minRange is exceeded, adjust\n if (max - min < axis.minRange) {\n spaceAvailable =\n axis.dataMax - axis.dataMin >=\n axis.minRange;\n minRange = axis.minRange;\n zoomOffset = (minRange - max + min) / 2;\n // if min and max options have been set, don't go beyond it\n minArgs = [\n min - zoomOffset,\n pick(options.min, min - zoomOffset)\n ];\n // If space is available, stay within the data range\n if (spaceAvailable) {\n minArgs[2] = axis.logarithmic ?\n axis.logarithmic.log2lin(axis.dataMin) :\n axis.dataMin;\n }\n min = arrayMax(minArgs);\n maxArgs = [\n min + minRange,\n pick(options.max, min + minRange)\n ];\n // If space is availabe, stay within the data range\n if (spaceAvailable) {\n maxArgs[2] = log ?\n log.log2lin(axis.dataMax) :\n axis.dataMax;\n }\n max = arrayMin(maxArgs);\n // now if the max is adjusted, adjust the min back\n if (max - min < minRange) {\n minArgs[0] = max - minRange;\n minArgs[1] = pick(options.min, max - minRange);\n min = arrayMax(minArgs);\n }\n }\n // Record modified extremes\n axis.min = min;\n axis.max = max;\n };\n /**\n * Find the closestPointRange across all series.\n *\n * @private\n * @function Highcharts.Axis#getClosest\n */\n Axis.prototype.getClosest = function () {\n var ret;\n if (this.categories) {\n ret = 1;\n }\n else {\n this.series.forEach(function (series) {\n var seriesClosest = series.closestPointRange,\n visible = series.visible ||\n !series.chart.options.chart.ignoreHiddenSeries;\n if (!series.noSharedTooltip &&\n defined(seriesClosest) &&\n visible) {\n ret = defined(ret) ?\n Math.min(ret, seriesClosest) :\n seriesClosest;\n }\n });\n }\n return ret;\n };\n /**\n * When a point name is given and no x, search for the name in the existing\n * categories, or if categories aren't provided, search names or create a\n * new category (#2522).\n *\n * @private\n * @function Highcharts.Axis#nameToX\n *\n * @param {Highcharts.Point} point\n * The point to inspect.\n *\n * @return {number}\n * The X value that the point is given.\n */\n Axis.prototype.nameToX = function (point) {\n var explicitCategories = isArray(this.options.categories),\n names = explicitCategories ? this.categories : this.names;\n var nameX = point.options.x,\n x;\n point.series.requireSorting = false;\n if (!defined(nameX)) {\n nameX = this.options.uniqueNames && names ?\n (explicitCategories ?\n names.indexOf(point.name) :\n pick(names.keys[point.name], -1)) :\n point.series.autoIncrement();\n }\n if (nameX === -1) { // Not found in currenct categories\n if (!explicitCategories && names) {\n x = names.length;\n }\n }\n else {\n x = nameX;\n }\n // Write the last point's name to the names array\n if (typeof x !== 'undefined') {\n this.names[x] = point.name;\n // Backwards mapping is much faster than array searching (#7725)\n this.names.keys[point.name] = x;\n }\n else if (point.x) {\n x = point.x; // #17438\n }\n return x;\n };\n /**\n * When changes have been done to series data, update the axis.names.\n *\n * @private\n * @function Highcharts.Axis#updateNames\n */\n Axis.prototype.updateNames = function () {\n var axis = this,\n names = this.names,\n i = names.length;\n if (i > 0) {\n Object.keys(names.keys).forEach(function (key) {\n delete (names.keys)[key];\n });\n names.length = 0;\n this.minRange = this.userMinRange; // Reset\n (this.series || []).forEach(function (series) {\n // Reset incrementer (#5928)\n series.xIncrement = null;\n // When adding a series, points are not yet generated\n if (!series.points || series.isDirtyData) {\n // When we're updating the series with data that is longer\n // than it was, and cropThreshold is passed, we need to make\n // sure that the axis.max is increased _before_ running the\n // premature processData. Otherwise this early iteration of\n // processData will crop the points to axis.max, and the\n // names array will be too short (#5857).\n axis.max = Math.max(axis.max, series.xData.length - 1);\n series.processData();\n series.generatePoints();\n }\n series.data.forEach(function (point, i) {\n var x;\n if (point &&\n point.options &&\n typeof point.name !== 'undefined' // #9562\n ) {\n x = axis.nameToX(point);\n if (typeof x !== 'undefined' && x !== point.x) {\n point.x = x;\n series.xData[i] = x;\n }\n }\n });\n });\n }\n };\n /**\n * Update translation information.\n *\n * @private\n * @function Highcharts.Axis#setAxisTranslation\n *\n * @emits Highcharts.Axis#event:afterSetAxisTranslation\n */\n Axis.prototype.setAxisTranslation = function () {\n var axis = this,\n range = axis.max - axis.min,\n linkedParent = axis.linkedParent,\n hasCategories = !!axis.categories,\n isXAxis = axis.isXAxis;\n var pointRange = axis.axisPointRange || 0,\n closestPointRange,\n minPointOffset = 0,\n pointRangePadding = 0,\n ordinalCorrection,\n transA = axis.transA;\n // Adjust translation for padding. Y axis with categories need to go\n // through the same (#1784).\n if (isXAxis || hasCategories || pointRange) {\n // Get the closest points\n closestPointRange = axis.getClosest();\n if (linkedParent) {\n minPointOffset = linkedParent.minPointOffset;\n pointRangePadding = linkedParent.pointRangePadding;\n }\n else {\n axis.series.forEach(function (series) {\n var seriesPointRange = hasCategories ?\n 1 :\n (isXAxis ?\n pick(series.options.pointRange,\n closestPointRange, 0) :\n (axis.axisPointRange || 0)), // #2806\n pointPlacement = series.options.pointPlacement;\n pointRange = Math.max(pointRange, seriesPointRange);\n if (!axis.single || hasCategories) {\n // TODO: series should internally set x- and y-\n // pointPlacement to simplify this logic.\n var isPointPlacementAxis = series.is('xrange') ?\n !isXAxis :\n isXAxis;\n // minPointOffset is the value padding to the left of\n // the axis in order to make room for points with a\n // pointRange, typically columns. When the\n // pointPlacement option is 'between' or 'on', this\n // padding does not apply.\n minPointOffset = Math.max(minPointOffset, isPointPlacementAxis && isString(pointPlacement) ?\n 0 :\n seriesPointRange / 2);\n // Determine the total padding needed to the length of\n // the axis to make room for the pointRange. If the\n // series' pointPlacement is 'on', no padding is added.\n pointRangePadding = Math.max(pointRangePadding, isPointPlacementAxis && pointPlacement === 'on' ?\n 0 :\n seriesPointRange);\n }\n });\n }\n // Record minPointOffset and pointRangePadding\n ordinalCorrection = (axis.ordinal && axis.ordinal.slope && closestPointRange) ?\n axis.ordinal.slope / closestPointRange :\n 1; // #988, #1853\n axis.minPointOffset = minPointOffset =\n minPointOffset * ordinalCorrection;\n axis.pointRangePadding =\n pointRangePadding = pointRangePadding * ordinalCorrection;\n // pointRange means the width reserved for each point, like in a\n // column chart\n axis.pointRange = Math.min(pointRange, axis.single && hasCategories ? 1 : range);\n // closestPointRange means the closest distance between points. In\n // columns it is mostly equal to pointRange, but in lines pointRange\n // is 0 while closestPointRange is some other value\n if (isXAxis) {\n axis.closestPointRange = closestPointRange;\n }\n }\n // Secondary values\n axis.translationSlope = axis.transA = transA =\n axis.staticScale ||\n axis.len / ((range + pointRangePadding) || 1);\n // Translation addend\n axis.transB = axis.horiz ? axis.left : axis.bottom;\n axis.minPixelPadding = transA * minPointOffset;\n fireEvent(this, 'afterSetAxisTranslation');\n };\n /**\n * @private\n * @function Highcharts.Axis#minFromRange\n */\n Axis.prototype.minFromRange = function () {\n var axis = this;\n return axis.max - axis.range;\n };\n /**\n * Set the tick positions to round values and optionally extend the extremes\n * to the nearest tick.\n *\n * @private\n * @function Highcharts.Axis#setTickInterval\n *\n * @param {boolean} secondPass\n * TO-DO: parameter description\n *\n * @emits Highcharts.Axis#event:foundExtremes\n */\n Axis.prototype.setTickInterval = function (secondPass) {\n var axis = this,\n chart = axis.chart,\n log = axis.logarithmic,\n options = axis.options,\n isXAxis = axis.isXAxis,\n isLinked = axis.isLinked,\n tickPixelIntervalOption = options.tickPixelInterval,\n categories = axis.categories,\n softThreshold = axis.softThreshold;\n var maxPadding = options.maxPadding,\n minPadding = options.minPadding,\n length,\n linkedParentExtremes, \n // Only non-negative tickInterval is valid, #12961\n tickIntervalOption = isNumber(options.tickInterval) && options.tickInterval >= 0 ?\n options.tickInterval : void 0,\n threshold = isNumber(axis.threshold) ? axis.threshold : null,\n thresholdMin,\n thresholdMax,\n hardMin,\n hardMax;\n if (!axis.dateTime && !categories && !isLinked) {\n this.getTickAmount();\n }\n // Min or max set either by zooming/setExtremes or initial options\n hardMin = pick(axis.userMin, options.min);\n hardMax = pick(axis.userMax, options.max);\n // Linked axis gets the extremes from the parent axis\n if (isLinked) {\n axis.linkedParent = chart[axis.coll][options.linkedTo];\n linkedParentExtremes = axis.linkedParent.getExtremes();\n axis.min = pick(linkedParentExtremes.min, linkedParentExtremes.dataMin);\n axis.max = pick(linkedParentExtremes.max, linkedParentExtremes.dataMax);\n if (options.type !== axis.linkedParent.options.type) {\n // Can't link axes of different type\n error(11, 1, chart);\n }\n // Initial min and max from the extreme data values\n }\n else {\n // Adjust to hard threshold\n if (softThreshold && defined(threshold)) {\n if (axis.dataMin >= threshold) {\n thresholdMin = threshold;\n minPadding = 0;\n }\n else if (axis.dataMax <= threshold) {\n thresholdMax = threshold;\n maxPadding = 0;\n }\n }\n axis.min = pick(hardMin, thresholdMin, axis.dataMin);\n axis.max = pick(hardMax, thresholdMax, axis.dataMax);\n }\n if (log) {\n if (axis.positiveValuesOnly &&\n !secondPass &&\n Math.min(axis.min, pick(axis.dataMin, axis.min)) <= 0) { // #978\n // Can't plot negative values on log axis\n error(10, 1, chart);\n }\n // The correctFloat cures #934, float errors on full tens. But it\n // was too aggressive for #4360 because of conversion back to lin,\n // therefore use precision 15.\n axis.min = correctFloat(log.log2lin(axis.min), 16);\n axis.max = correctFloat(log.log2lin(axis.max), 16);\n }\n // handle zoomed range\n if (axis.range && defined(axis.max)) {\n // #618, #6773:\n axis.userMin = axis.min = hardMin =\n Math.max(axis.dataMin, axis.minFromRange());\n axis.userMax = hardMax = axis.max;\n axis.range = null; // don't use it when running setExtremes\n }\n // Hook for Highcharts Stock Scroller.\n // Consider combining with beforePadding.\n fireEvent(axis, 'foundExtremes');\n // Hook for adjusting this.min and this.max. Used by bubble series.\n if (axis.beforePadding) {\n axis.beforePadding();\n }\n // adjust min and max for the minimum range\n axis.adjustForMinRange();\n // Pad the values to get clear of the chart's edges. To avoid\n // tickInterval taking the padding into account, we do this after\n // computing tick interval (#1337).\n if (!categories &&\n !axis.axisPointRange &&\n !(axis.stacking && axis.stacking.usePercentage) &&\n !isLinked &&\n defined(axis.min) &&\n defined(axis.max)) {\n length = axis.max - axis.min;\n if (length) {\n if (!defined(hardMin) && minPadding) {\n axis.min -= length * minPadding;\n }\n if (!defined(hardMax) && maxPadding) {\n axis.max += length * maxPadding;\n }\n }\n }\n // Handle options for floor, ceiling, softMin and softMax (#6359)\n if (!isNumber(axis.userMin)) {\n if (isNumber(options.softMin) && options.softMin < axis.min) {\n axis.min = hardMin = options.softMin; // #6894\n }\n if (isNumber(options.floor)) {\n axis.min = Math.max(axis.min, options.floor);\n }\n }\n if (!isNumber(axis.userMax)) {\n if (isNumber(options.softMax) && options.softMax > axis.max) {\n axis.max = hardMax = options.softMax; // #6894\n }\n if (isNumber(options.ceiling)) {\n axis.max = Math.min(axis.max, options.ceiling);\n }\n }\n // When the threshold is soft, adjust the extreme value only if the data\n // extreme and the padded extreme land on either side of the threshold.\n // For example, a series of [0, 1, 2, 3] would make the yAxis add a tick\n // for -1 because of the default minPadding and startOnTick options.\n // This is prevented by the softThreshold option.\n if (softThreshold && defined(axis.dataMin)) {\n threshold = threshold || 0;\n if (!defined(hardMin) &&\n axis.min < threshold &&\n axis.dataMin >= threshold) {\n axis.min = axis.options.minRange ?\n Math.min(threshold, axis.max -\n axis.minRange) :\n threshold;\n }\n else if (!defined(hardMax) &&\n axis.max > threshold &&\n axis.dataMax <= threshold) {\n axis.max = axis.options.minRange ?\n Math.max(threshold, axis.min +\n axis.minRange) :\n threshold;\n }\n }\n // If min is bigger than highest, or if max less than lowest value, the\n // chart should not render points. (#14417)\n if (isNumber(axis.min) &&\n isNumber(axis.max) &&\n !this.chart.polar &&\n (axis.min > axis.max)) {\n if (defined(axis.options.min)) {\n axis.max = axis.min;\n }\n else if (defined(axis.options.max)) {\n axis.min = axis.max;\n }\n }\n // get tickInterval\n if (axis.min === axis.max ||\n typeof axis.min === 'undefined' ||\n typeof axis.max === 'undefined') {\n axis.tickInterval = 1;\n }\n else if (isLinked &&\n axis.linkedParent &&\n !tickIntervalOption &&\n tickPixelIntervalOption ===\n axis.linkedParent.options.tickPixelInterval) {\n axis.tickInterval = tickIntervalOption =\n axis.linkedParent.tickInterval;\n }\n else {\n axis.tickInterval = pick(tickIntervalOption, this.tickAmount ?\n ((axis.max - axis.min) /\n Math.max(this.tickAmount - 1, 1)) :\n void 0, \n // For categoried axis, 1 is default, for linear axis use\n // tickPix\n categories ?\n 1 :\n // don't let it be more than the data range\n (axis.max - axis.min) *\n tickPixelIntervalOption /\n Math.max(axis.len, tickPixelIntervalOption));\n }\n // Now we're finished detecting min and max, crop and group series data.\n // This is in turn needed in order to find tick positions in ordinal\n // axes.\n if (isXAxis && !secondPass) {\n var hasExtremesChanged_1 = axis.min !==\n (axis.old && axis.old.min) ||\n axis.max !== (axis.old && axis.old.max);\n // First process all series assigned to that axis.\n axis.series.forEach(function (series) {\n // Allows filtering out points outside the plot area.\n series.forceCrop = (series.forceCropping &&\n series.forceCropping());\n series.processData(hasExtremesChanged_1);\n });\n // Then apply grouping if needed. The hasExtremesChanged helps to\n // decide if the data grouping should be skipped in the further\n // calculations #16319.\n fireEvent(this, 'postProcessData', { hasExtremesChanged: hasExtremesChanged_1 });\n }\n // set the translation factor used in translate function\n axis.setAxisTranslation();\n // hook for ordinal axes and radial axes\n fireEvent(this, 'initialAxisTranslation');\n // In column-like charts, don't cramp in more ticks than there are\n // points (#1943, #4184)\n if (axis.pointRange && !tickIntervalOption) {\n axis.tickInterval = Math.max(axis.pointRange, axis.tickInterval);\n }\n // Before normalizing the tick interval, handle minimum tick interval.\n // This applies only if tickInterval is not defined.\n var minTickInterval = pick(options.minTickInterval, \n // In datetime axes, don't go below the data interval, except when\n // there are scatter-like series involved (#13369).\n axis.dateTime &&\n !axis.series.some(function (s) { return s.noSharedTooltip; }) ?\n axis.closestPointRange : 0);\n if (!tickIntervalOption && axis.tickInterval < minTickInterval) {\n axis.tickInterval = minTickInterval;\n }\n // For linear axes, normalize the interval\n if (!axis.dateTime && !axis.logarithmic && !tickIntervalOption) {\n axis.tickInterval = getNormalizedTickInterval(axis, axis.tickInterval);\n }\n // Prevent ticks from getting so close that we can't draw the labels\n if (!this.tickAmount) {\n axis.tickInterval = axis.unsquish();\n }\n this.setTickPositions();\n };\n /**\n * Now we have computed the normalized tickInterval, get the tick positions.\n *\n * @private\n * @function Highcharts.Axis#setTickPositions\n *\n * @emits Highcharts.Axis#event:afterSetTickPositions\n */\n Axis.prototype.setTickPositions = function () {\n var axis = this,\n options = this.options,\n tickPositionsOption = options.tickPositions,\n tickPositioner = options.tickPositioner,\n minorTickIntervalOption = this.getMinorTickInterval(),\n hasVerticalPanning = this.hasVerticalPanning(),\n isColorAxis = this.coll === 'colorAxis',\n startOnTick = ((isColorAxis || !hasVerticalPanning) && options.startOnTick),\n endOnTick = ((isColorAxis || !hasVerticalPanning) && options.endOnTick);\n var tickPositions = [],\n tickPositionerResult;\n // Set the tickmarkOffset\n this.tickmarkOffset = (this.categories &&\n options.tickmarkPlacement === 'between' &&\n this.tickInterval === 1) ? 0.5 : 0; // #3202\n // get minorTickInterval\n this.minorTickInterval =\n minorTickIntervalOption === 'auto' &&\n this.tickInterval ?\n this.tickInterval / 5 :\n minorTickIntervalOption;\n // When there is only one point, or all points have the same value on\n // this axis, then min and max are equal and tickPositions.length is 0\n // or 1. In this case, add some padding in order to center the point,\n // but leave it with one tick. #1337.\n this.single =\n this.min === this.max &&\n defined(this.min) &&\n !this.tickAmount &&\n (\n // Data is on integer (#6563)\n parseInt(this.min, 10) === this.min ||\n // Between integers and decimals are not allowed (#6274)\n options.allowDecimals !== false);\n /**\n * Contains the current positions that are laid out on the axis. The\n * positions are numbers in terms of axis values. In a category axis\n * they are integers, in a datetime axis they are also integers, but\n * designating milliseconds.\n *\n * This property is read only - for modifying the tick positions, use\n * the `tickPositioner` callback or [axis.tickPositions(\n * https://api.highcharts.com/highcharts/xAxis.tickPositions) option\n * instead.\n *\n * @name Highcharts.Axis#tickPositions\n * @type {Highcharts.AxisTickPositionsArray|undefined}\n */\n if (tickPositionsOption) {\n // Find the tick positions. Work on a copy (#1565)\n tickPositions = tickPositionsOption.slice();\n }\n else if (isNumber(this.min) && isNumber(this.max)) {\n // Too many ticks (#6405). Create a friendly warning and provide two\n // ticks so at least we can show the data series.\n if ((!axis.ordinal || !axis.ordinal.positions) &&\n ((this.max - this.min) /\n this.tickInterval >\n Math.max(2 * this.len, 200))) {\n tickPositions = [this.min, this.max];\n error(19, false, this.chart);\n }\n else if (axis.dateTime) {\n tickPositions = axis.getTimeTicks(axis.dateTime.normalizeTimeTickInterval(this.tickInterval, options.units), this.min, this.max, options.startOfWeek, axis.ordinal && axis.ordinal.positions, this.closestPointRange, true);\n }\n else if (axis.logarithmic) {\n tickPositions = axis.logarithmic.getLogTickPositions(this.tickInterval, this.min, this.max);\n }\n else {\n var startingTickInterval = this.tickInterval;\n var adjustedTickInterval = startingTickInterval;\n while (adjustedTickInterval <= startingTickInterval * 2) {\n tickPositions = this.getLinearTickPositions(this.tickInterval, this.min, this.max);\n // If there are more tick positions than the set tickAmount,\n // increase the tickInterval and continue until it fits.\n // (#17100)\n if (this.tickAmount &&\n tickPositions.length > this.tickAmount) {\n this.tickInterval = getNormalizedTickInterval(this, adjustedTickInterval *= 1.1);\n }\n else {\n break;\n }\n }\n }\n // Too dense ticks, keep only the first and last (#4477)\n if (tickPositions.length > this.len) {\n tickPositions = [\n tickPositions[0],\n tickPositions[tickPositions.length - 1]\n ];\n // Reduce doubled value (#7339)\n if (tickPositions[0] === tickPositions[1]) {\n tickPositions.length = 1;\n }\n }\n // Run the tick positioner callback, that allows modifying auto tick\n // positions.\n if (tickPositioner) {\n // Make it available to the positioner\n this.tickPositions = tickPositions;\n tickPositionerResult = tickPositioner.apply(axis, [this.min, this.max]);\n if (tickPositionerResult) {\n tickPositions = tickPositionerResult;\n }\n }\n }\n this.tickPositions = tickPositions;\n // Reset min/max or remove extremes based on start/end on tick\n this.paddedTicks = tickPositions.slice(0); // Used for logarithmic minor\n this.trimTicks(tickPositions, startOnTick, endOnTick);\n if (!this.isLinked && isNumber(this.min) && isNumber(this.max)) {\n // Substract half a unit (#2619, #2846, #2515, #3390), but not in\n // case of multiple ticks (#6897)\n if (this.single &&\n tickPositions.length < 2 &&\n !this.categories &&\n !this.series.some(function (s) {\n return (s.is('heatmap') && s.options.pointPlacement === 'between');\n })) {\n this.min -= 0.5;\n this.max += 0.5;\n }\n if (!tickPositionsOption && !tickPositionerResult) {\n this.adjustTickAmount();\n }\n }\n fireEvent(this, 'afterSetTickPositions');\n };\n /**\n * Handle startOnTick and endOnTick by either adapting to padding min/max or\n * rounded min/max. Also handle single data points.\n *\n * @private\n * @function Highcharts.Axis#trimTicks\n *\n * @param {Array} tickPositions\n * TO-DO: parameter description\n *\n * @param {boolean} [startOnTick]\n * TO-DO: parameter description\n *\n * @param {boolean} [endOnTick]\n * TO-DO: parameter description\n */\n Axis.prototype.trimTicks = function (tickPositions, startOnTick, endOnTick) {\n var roundedMin = tickPositions[0],\n roundedMax = tickPositions[tickPositions.length - 1],\n minPointOffset = (!this.isOrdinal && this.minPointOffset) || 0; // (#12716)\n fireEvent(this, 'trimTicks');\n if (!this.isLinked) {\n if (startOnTick && roundedMin !== -Infinity) { // #6502\n this.min = roundedMin;\n }\n else {\n while (this.min - minPointOffset > tickPositions[0]) {\n tickPositions.shift();\n }\n }\n if (endOnTick) {\n this.max = roundedMax;\n }\n else {\n while (this.max + minPointOffset <\n tickPositions[tickPositions.length - 1]) {\n tickPositions.pop();\n }\n }\n // If no tick are left, set one tick in the middle (#3195)\n if (tickPositions.length === 0 &&\n defined(roundedMin) &&\n !this.options.tickPositions) {\n tickPositions.push((roundedMax + roundedMin) / 2);\n }\n }\n };\n /**\n * Check if there are multiple axes in the same pane.\n *\n * @private\n * @function Highcharts.Axis#alignToOthers\n *\n * @return {boolean|undefined}\n * True if there are other axes.\n */\n Axis.prototype.alignToOthers = function () {\n var axis = this,\n alignedAxes = [this],\n options = axis.options,\n alignThresholds = (this.coll === 'yAxis' &&\n this.chart.options.chart.alignThresholds),\n thresholdAlignments = [];\n var hasOther;\n axis.thresholdAlignment = void 0;\n if ((\n // Only if alignTicks or alignThresholds is true\n (this.chart.options.chart.alignTicks !== false &&\n options.alignTicks) || (alignThresholds)) &&\n // Disabled when startOnTick or endOnTick are false (#7604)\n options.startOnTick !== false &&\n options.endOnTick !== false &&\n // Don't try to align ticks on a log axis, they are not evenly\n // spaced (#6021)\n !axis.logarithmic) {\n // Get a key identifying which pane the axis belongs to\n var getKey_1 = function (axis) {\n var horiz = axis.horiz,\n options = axis.options;\n return [\n horiz ? options.left : options.top,\n options.width,\n options.height,\n options.pane\n ].join(',');\n };\n var thisKey_1 = getKey_1(this);\n this.chart[this.coll].forEach(function (otherAxis) {\n var series = otherAxis.series;\n if (\n // #4442\n series.length &&\n series.some(function (s) { return s.visible; }) &&\n otherAxis !== axis &&\n getKey_1(otherAxis) === thisKey_1) {\n hasOther = true; // #4201\n alignedAxes.push(otherAxis);\n }\n });\n }\n if (hasOther && alignThresholds) {\n // Handle alignThresholds. The `thresholdAlignments` array keeps\n // records of where each axis in the group wants its threshold, from\n // 0 which is on `axis.min`, to 1 which is on `axis.max`.\n alignedAxes.forEach(function (otherAxis) {\n var threshAlign = otherAxis.getThresholdAlignment(axis);\n if (isNumber(threshAlign)) {\n thresholdAlignments.push(threshAlign);\n }\n });\n // For each of the axes in the group, record the average\n // `thresholdAlignment`.\n var thresholdAlignment_1 = thresholdAlignments.length > 1 ?\n thresholdAlignments.reduce(function (sum,\n n) { return (sum += n); }, 0) / thresholdAlignments.length :\n void 0;\n alignedAxes.forEach(function (axis) {\n axis.thresholdAlignment = thresholdAlignment_1;\n });\n }\n return hasOther;\n };\n /**\n * Where the axis wants its threshold, from 0 which is on `axis.min`, to 1 which\n * is on `axis.max`.\n *\n * @private\n * @function Highcharts.Axis#getThresholdAlignment\n */\n Axis.prototype.getThresholdAlignment = function (callerAxis) {\n if (!isNumber(this.dataMin) ||\n (this !== callerAxis &&\n this.series.some(function (s) { return (s.isDirty || s.isDirtyData); }))) {\n this.getSeriesExtremes();\n }\n if (isNumber(this.threshold)) {\n var thresholdAlignment = clamp(((this.threshold - (this.dataMin || 0)) /\n ((this.dataMax || 0) - (this.dataMin || 0))), 0, 1);\n if (this.options.reversed) {\n thresholdAlignment = 1 - thresholdAlignment;\n }\n return thresholdAlignment;\n }\n };\n /**\n * Find the max ticks of either the x and y axis collection, and record it\n * in `this.tickAmount`.\n *\n * @private\n * @function Highcharts.Axis#getTickAmount\n */\n Axis.prototype.getTickAmount = function () {\n var axis = this,\n options = this.options,\n tickPixelInterval = options.tickPixelInterval;\n var tickAmount = options.tickAmount;\n if (!defined(options.tickInterval) &&\n !tickAmount &&\n this.len < tickPixelInterval &&\n !this.isRadial &&\n !axis.logarithmic &&\n options.startOnTick &&\n options.endOnTick) {\n tickAmount = 2;\n }\n if (!tickAmount && this.alignToOthers()) {\n // Add 1 because 4 tick intervals require 5 ticks (including first\n // and last)\n tickAmount = Math.ceil(this.len / tickPixelInterval) + 1;\n }\n // For tick amounts of 2 and 3, compute five ticks and remove the\n // intermediate ones. This prevents the axis from adding ticks that are\n // too far away from the data extremes.\n if (tickAmount < 4) {\n this.finalTickAmt = tickAmount;\n tickAmount = 5;\n }\n this.tickAmount = tickAmount;\n };\n /**\n * When using multiple axes, adjust the number of ticks to match the highest\n * number of ticks in that group.\n *\n * @private\n * @function Highcharts.Axis#adjustTickAmount\n */\n Axis.prototype.adjustTickAmount = function () {\n var axis = this,\n finalTickAmt = axis.finalTickAmt,\n max = axis.max,\n min = axis.min,\n options = axis.options,\n tickPositions = axis.tickPositions,\n tickAmount = axis.tickAmount,\n thresholdAlignment = axis.thresholdAlignment,\n currentTickAmount = tickPositions && tickPositions.length,\n threshold = pick(axis.threshold,\n axis.softThreshold ? 0 : null);\n var len,\n i,\n tickInterval = axis.tickInterval,\n thresholdTickIndex;\n var \n // Extend the tickPositions by appending a position\n append = function () { return tickPositions.push(correctFloat(tickPositions[tickPositions.length - 1] +\n tickInterval)); }, \n // Extend the tickPositions by prepending a position\n prepend = function () { return tickPositions.unshift(correctFloat(tickPositions[0] - tickInterval)); };\n // If `thresholdAlignment` is a number, it means the `alignThresholds`\n // option is true. The `thresholdAlignment` is a scalar value between 0\n // and 1 for where the threshold should be relative to `axis.min` and\n // `axis.max`. Now that we know the tick amount, convert this to the\n // tick index. Unless `thresholdAlignment` is exactly 0 or 1, avoid the\n // first or last tick because that would lead to series being clipped.\n if (isNumber(thresholdAlignment)) {\n thresholdTickIndex = thresholdAlignment < 0.5 ?\n Math.ceil(thresholdAlignment * (tickAmount - 1)) :\n Math.floor(thresholdAlignment * (tickAmount - 1));\n if (options.reversed) {\n thresholdTickIndex = tickAmount - 1 - thresholdTickIndex;\n }\n }\n if (axis.hasData() && isNumber(min) && isNumber(max)) { // #14769\n // Adjust extremes and translation to the modified tick positions\n var adjustExtremes = function () {\n axis.transA *= (currentTickAmount - 1) / (tickAmount - 1);\n // Do not crop when ticks are not extremes (#9841)\n axis.min = options.startOnTick ?\n tickPositions[0] :\n Math.min(min, tickPositions[0]);\n axis.max = options.endOnTick ?\n tickPositions[tickPositions.length - 1] :\n Math.max(max, tickPositions[tickPositions.length - 1]);\n };\n // When the axis is subject to the alignThresholds option. Use\n // axis.threshold because the local threshold includes the\n // `softThreshold`.\n if (isNumber(thresholdTickIndex) && isNumber(axis.threshold)) {\n // Throw away the previously computed tickPositions and start\n // from scratch with only the threshold itself, then add ticks\n // below the threshold first, then fill up above the threshold.\n // If we are not able to fill up to axis.max, double the\n // tickInterval and run again.\n while (tickPositions[thresholdTickIndex] !== threshold ||\n tickPositions.length !== tickAmount ||\n tickPositions[0] > min ||\n tickPositions[tickPositions.length - 1] < max) {\n tickPositions.length = 0;\n tickPositions.push(axis.threshold);\n while (tickPositions.length < tickAmount) {\n if (\n // Start by prepending positions until the threshold\n // is at the required index...\n tickPositions[thresholdTickIndex] === void 0 ||\n tickPositions[thresholdTickIndex] > axis.threshold) {\n prepend();\n }\n else {\n // ... then append positions until we have the\n // required length\n append();\n }\n }\n // Safety vent\n if (tickInterval > axis.tickInterval * 8) {\n break;\n }\n tickInterval *= 2;\n }\n adjustExtremes();\n }\n else if (currentTickAmount < tickAmount) {\n while (tickPositions.length < tickAmount) {\n // Extend evenly for both sides unless we're on the\n // threshold (#3965)\n if (tickPositions.length % 2 || min === threshold) {\n append();\n }\n else {\n prepend();\n }\n }\n adjustExtremes();\n }\n // The finalTickAmt property is set in getTickAmount\n if (defined(finalTickAmt)) {\n i = len = tickPositions.length;\n while (i--) {\n if (\n // Remove every other tick\n (finalTickAmt === 3 && i % 2 === 1) ||\n // Remove all but first and last\n (finalTickAmt <= 2 && i > 0 && i < len - 1)) {\n tickPositions.splice(i, 1);\n }\n }\n axis.finalTickAmt = void 0;\n }\n }\n };\n /**\n * Set the scale based on data min and max, user set min and max or options.\n *\n * @private\n * @function Highcharts.Axis#setScale\n *\n * @emits Highcharts.Axis#event:afterSetScale\n */\n Axis.prototype.setScale = function () {\n var axis = this;\n var isDirtyData = false,\n isXAxisDirty = false;\n axis.series.forEach(function (series) {\n isDirtyData = isDirtyData || series.isDirtyData || series.isDirty;\n // When x axis is dirty, we need new data extremes for y as\n // well:\n isXAxisDirty = (isXAxisDirty ||\n (series.xAxis && series.xAxis.isDirty) ||\n false);\n });\n // set the new axisLength\n axis.setAxisSize();\n var isDirtyAxisLength = axis.len !== (axis.old && axis.old.len);\n // do we really need to go through all this?\n if (isDirtyAxisLength ||\n isDirtyData ||\n isXAxisDirty ||\n axis.isLinked ||\n axis.forceRedraw ||\n axis.userMin !== (axis.old && axis.old.userMin) ||\n axis.userMax !== (axis.old && axis.old.userMax) ||\n axis.alignToOthers()) {\n if (axis.stacking) {\n axis.stacking.resetStacks();\n }\n axis.forceRedraw = false;\n // get data extremes if needed\n axis.getSeriesExtremes();\n // get fixed positions based on tickInterval\n axis.setTickInterval();\n // Mark as dirty if it is not already set to dirty and extremes have\n // changed. #595.\n if (!axis.isDirty) {\n axis.isDirty =\n isDirtyAxisLength ||\n axis.min !== (axis.old && axis.old.min) ||\n axis.max !== (axis.old && axis.old.max);\n }\n }\n else if (axis.stacking) {\n axis.stacking.cleanStacks();\n }\n // Recalculate panning state object, when the data\n // has changed. It is required when vertical panning is enabled.\n if (isDirtyData && axis.panningState) {\n axis.panningState.isDirty = true;\n }\n fireEvent(this, 'afterSetScale');\n };\n /**\n * Set the minimum and maximum of the axes after render time. If the\n * `startOnTick` and `endOnTick` options are true, the minimum and maximum\n * values are rounded off to the nearest tick. To prevent this, these\n * options can be set to false before calling setExtremes. Also, setExtremes\n * will not allow a range lower than the `minRange` option, which by default\n * is the range of five points.\n *\n * @sample highcharts/members/axis-setextremes/\n * Set extremes from a button\n * @sample highcharts/members/axis-setextremes-datetime/\n * Set extremes on a datetime axis\n * @sample highcharts/members/axis-setextremes-off-ticks/\n * Set extremes off ticks\n * @sample stock/members/axis-setextremes/\n * Set extremes in Highcharts Stock\n *\n * @function Highcharts.Axis#setExtremes\n *\n * @param {number} [newMin]\n * The new minimum value.\n *\n * @param {number} [newMax]\n * The new maximum value.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or wait for an explicit call to\n * {@link Highcharts.Chart#redraw}\n *\n * @param {boolean|Partial} [animation=true]\n * Enable or modify animations.\n *\n * @param {*} [eventArguments]\n * Arguments to be accessed in event handler.\n *\n * @emits Highcharts.Axis#event:setExtremes\n */\n Axis.prototype.setExtremes = function (newMin, newMax, redraw, animation, eventArguments) {\n var axis = this,\n chart = axis.chart;\n redraw = pick(redraw, true); // defaults to true\n axis.series.forEach(function (serie) {\n delete serie.kdTree;\n });\n // Extend the arguments with min and max\n eventArguments = extend(eventArguments, {\n min: newMin,\n max: newMax\n });\n // Fire the event\n fireEvent(axis, 'setExtremes', eventArguments, function () {\n axis.userMin = newMin;\n axis.userMax = newMax;\n axis.eventArgs = eventArguments;\n if (redraw) {\n chart.redraw(animation);\n }\n });\n };\n /**\n * Overridable method for zooming chart. Pulled out in a separate method to\n * allow overriding in stock charts.\n *\n * @private\n * @function Highcharts.Axis#zoom\n */\n Axis.prototype.zoom = function (newMin, newMax) {\n var axis = this,\n dataMin = this.dataMin,\n dataMax = this.dataMax,\n options = this.options,\n min = Math.min(dataMin,\n pick(options.min,\n dataMin)),\n max = Math.max(dataMax,\n pick(options.max,\n dataMax)),\n evt = {\n newMin: newMin,\n newMax: newMax\n };\n fireEvent(this, 'zoom', evt, function (e) {\n // Use e.newMin and e.newMax - event handlers may have altered them\n var newMin = e.newMin,\n newMax = e.newMax;\n if (newMin !== axis.min || newMax !== axis.max) { // #5790\n // Prevent pinch zooming out of range. Check for defined is for\n // #1946. #1734.\n if (!axis.allowZoomOutside) {\n // #6014, sometimes newMax will be smaller than min (or\n // newMin will be larger than max).\n if (defined(dataMin)) {\n if (newMin < min) {\n newMin = min;\n }\n if (newMin > max) {\n newMin = max;\n }\n }\n if (defined(dataMax)) {\n if (newMax < min) {\n newMax = min;\n }\n if (newMax > max) {\n newMax = max;\n }\n }\n }\n // In full view, displaying the reset zoom button is not\n // required\n axis.displayBtn = (typeof newMin !== 'undefined' ||\n typeof newMax !== 'undefined');\n // Do it\n axis.setExtremes(newMin, newMax, false, void 0, { trigger: 'zoom' });\n }\n e.zoomed = true;\n });\n return evt.zoomed;\n };\n /**\n * Update the axis metrics.\n *\n * @private\n * @function Highcharts.Axis#setAxisSize\n */\n Axis.prototype.setAxisSize = function () {\n var chart = this.chart,\n options = this.options, \n // [top, right, bottom, left]\n offsets = options.offsets || [0, 0, 0, 0],\n horiz = this.horiz, \n // Check for percentage based input values. Rounding fixes problems\n // with column overflow and plot line filtering (#4898, #4899)\n width = this.width = Math.round(relativeLength(pick(options.width,\n chart.plotWidth - offsets[3] + offsets[1]),\n chart.plotWidth)),\n height = this.height = Math.round(relativeLength(pick(options.height,\n chart.plotHeight - offsets[0] + offsets[2]),\n chart.plotHeight)),\n top = this.top = Math.round(relativeLength(pick(options.top,\n chart.plotTop + offsets[0]),\n chart.plotHeight,\n chart.plotTop)),\n left = this.left = Math.round(relativeLength(pick(options.left,\n chart.plotLeft + offsets[3]),\n chart.plotWidth,\n chart.plotLeft));\n // Expose basic values to use in Series object and navigator\n this.bottom = chart.chartHeight - height - top;\n this.right = chart.chartWidth - width - left;\n // Direction agnostic properties\n this.len = Math.max(horiz ? width : height, 0); // Math.max fixes #905\n this.pos = horiz ? left : top; // distance from SVG origin\n };\n /**\n * Get the current extremes for the axis.\n *\n * @sample highcharts/members/axis-getextremes/\n * Report extremes by click on a button\n *\n * @function Highcharts.Axis#getExtremes\n *\n * @return {Highcharts.ExtremesObject}\n * An object containing extremes information.\n */\n Axis.prototype.getExtremes = function () {\n var axis = this,\n log = axis.logarithmic;\n return {\n min: log ?\n correctFloat(log.lin2log(axis.min)) :\n axis.min,\n max: log ?\n correctFloat(log.lin2log(axis.max)) :\n axis.max,\n dataMin: axis.dataMin,\n dataMax: axis.dataMax,\n userMin: axis.userMin,\n userMax: axis.userMax\n };\n };\n /**\n * Get the zero plane either based on zero or on the min or max value.\n * Used in bar and area plots.\n *\n * @function Highcharts.Axis#getThreshold\n *\n * @param {number} threshold\n * The threshold in axis values.\n *\n * @return {number}\n * The translated threshold position in terms of pixels, and corrected to\n * stay within the axis bounds.\n */\n Axis.prototype.getThreshold = function (threshold) {\n var axis = this,\n log = axis.logarithmic,\n realMin = log ? log.lin2log(axis.min) : axis.min,\n realMax = log ? log.lin2log(axis.max) : axis.max;\n if (threshold === null || threshold === -Infinity) {\n threshold = realMin;\n }\n else if (threshold === Infinity) {\n threshold = realMax;\n }\n else if (realMin > threshold) {\n threshold = realMin;\n }\n else if (realMax < threshold) {\n threshold = realMax;\n }\n return axis.translate(threshold, 0, 1, 0, 1);\n };\n /**\n * Compute auto alignment for the axis label based on which side the axis is\n * on and the given rotation for the label.\n *\n * @private\n * @function Highcharts.Axis#autoLabelAlign\n *\n * @param {number} rotation\n * The rotation in degrees as set by either the `rotation` or `autoRotation`\n * options.\n *\n * @return {Highcharts.AlignValue}\n * Can be `\"center\"`, `\"left\"` or `\"right\"`.\n */\n Axis.prototype.autoLabelAlign = function (rotation) {\n var angle = (pick(rotation, 0) - (this.side * 90) + 720) % 360,\n evt = { align: 'center' };\n fireEvent(this, 'autoLabelAlign', evt, function (e) {\n if (angle > 15 && angle < 165) {\n e.align = 'right';\n }\n else if (angle > 195 && angle < 345) {\n e.align = 'left';\n }\n });\n return evt.align;\n };\n /**\n * Get the tick length and width for the axis based on axis options.\n *\n * @private\n * @function Highcharts.Axis#tickSize\n *\n * @param {string} [prefix]\n * 'tick' or 'minorTick'\n *\n * @return {Array|undefined}\n * An array of tickLength and tickWidth\n */\n Axis.prototype.tickSize = function (prefix) {\n var options = this.options,\n tickWidth = pick(options[prefix === 'tick' ? 'tickWidth' : 'minorTickWidth'], \n // Default to 1 on linear and datetime X axes\n prefix === 'tick' && this.isXAxis && !this.categories ? 1 : 0);\n var tickLength = options[prefix === 'tick' ? 'tickLength' : 'minorTickLength'],\n tickSize;\n if (tickWidth && tickLength) {\n // Negate the length\n if (options[prefix + 'Position'] === 'inside') {\n tickLength = -tickLength;\n }\n tickSize = [tickLength, tickWidth];\n }\n var e = { tickSize: tickSize };\n fireEvent(this, 'afterTickSize', e);\n return e.tickSize;\n };\n /**\n * Return the size of the labels.\n *\n * @private\n * @function Highcharts.Axis#labelMetrics\n */\n Axis.prototype.labelMetrics = function () {\n var index = this.tickPositions && this.tickPositions[0] || 0;\n return this.chart.renderer.fontMetrics(this.options.labels.style.fontSize, this.ticks[index] && this.ticks[index].label);\n };\n /**\n * Prevent the ticks from getting so close we can't draw the labels. On a\n * horizontal axis, this is handled by rotating the labels, removing ticks\n * and adding ellipsis. On a vertical axis remove ticks and add ellipsis.\n *\n * @private\n * @function Highcharts.Axis#unsquish\n */\n Axis.prototype.unsquish = function () {\n var labelOptions = this.options.labels,\n horiz = this.horiz,\n tickInterval = this.tickInterval,\n slotSize = this.len / (((this.categories ? 1 : 0) +\n this.max -\n this.min) /\n tickInterval),\n rotationOption = labelOptions.rotation,\n labelMetrics = this.labelMetrics(),\n range = Math.max(this.max - this.min, 0), \n // Return the multiple of tickInterval that is needed to avoid\n // collision\n getStep = function (spaceNeeded) {\n var step = spaceNeeded / (slotSize || 1);\n step = step > 1 ? Math.ceil(step) : 1;\n // Guard for very small or negative angles (#9835)\n if (step * tickInterval > range &&\n spaceNeeded !== Infinity &&\n slotSize !== Infinity &&\n range) {\n step = Math.ceil(range / tickInterval);\n }\n return correctFloat(step * tickInterval);\n };\n var newTickInterval = tickInterval,\n rotation,\n bestScore = Number.MAX_VALUE,\n autoRotation;\n if (horiz) {\n if (!labelOptions.staggerLines) {\n if (isNumber(rotationOption)) {\n autoRotation = [rotationOption];\n }\n else if (slotSize < labelOptions.autoRotationLimit) {\n autoRotation = labelOptions.autoRotation;\n }\n }\n if (autoRotation) {\n var step = void 0,\n score = void 0;\n // Loop over the given autoRotation options, and determine which\n // gives the best score. The best score is that with the lowest\n // number of steps and a rotation closest to horizontal.\n for (var _i = 0, autoRotation_1 = autoRotation; _i < autoRotation_1.length; _i++) {\n var rot = autoRotation_1[_i];\n if (rot === rotationOption ||\n (rot && rot >= -90 && rot <= 90)) { // #3891\n step = getStep(Math.abs(labelMetrics.h / Math.sin(deg2rad * rot)));\n score = step + Math.abs(rot / 360);\n if (score < bestScore) {\n bestScore = score;\n rotation = rot;\n newTickInterval = step;\n }\n }\n }\n }\n }\n else { // #4411\n newTickInterval = getStep(labelMetrics.h);\n }\n this.autoRotation = autoRotation;\n this.labelRotation = pick(rotation, isNumber(rotationOption) ? rotationOption : 0);\n return labelOptions.step ? tickInterval : newTickInterval;\n };\n /**\n * Get the general slot width for labels/categories on this axis. This may\n * change between the pre-render (from Axis.getOffset) and the final tick\n * rendering and placement.\n *\n * @private\n * @function Highcharts.Axis#getSlotWidth\n *\n * @param {Highcharts.Tick} [tick] Optionally, calculate the slot width\n * basing on tick label. It is used in highcharts-3d module, where the slots\n * has different widths depending on perspective angles.\n *\n * @return {number}\n * The pixel width allocated to each axis label.\n */\n Axis.prototype.getSlotWidth = function (tick) {\n // #5086, #1580, #1931\n var chart = this.chart,\n horiz = this.horiz,\n labelOptions = this.options.labels,\n slotCount = Math.max(this.tickPositions.length - (this.categories ? 0 : 1), 1),\n marginLeft = chart.margin[3];\n // Used by grid axis\n if (tick && isNumber(tick.slotWidth)) { // #13221, can be 0\n return tick.slotWidth;\n }\n if (horiz && labelOptions.step < 2) {\n if (labelOptions.rotation) { // #4415\n return 0;\n }\n return ((this.staggerLines || 1) * this.len) / slotCount;\n }\n if (!horiz) {\n // #7028\n var cssWidth = labelOptions.style.width;\n if (cssWidth !== void 0) {\n return parseInt(String(cssWidth), 10);\n }\n if (marginLeft) {\n return marginLeft - chart.spacing[3];\n }\n }\n // Last resort, a fraction of the available size\n return chart.chartWidth * 0.33;\n };\n /**\n * Render the axis labels and determine whether ellipsis or rotation need to\n * be applied.\n *\n * @private\n * @function Highcharts.Axis#renderUnsquish\n */\n Axis.prototype.renderUnsquish = function () {\n var chart = this.chart,\n renderer = chart.renderer,\n tickPositions = this.tickPositions,\n ticks = this.ticks,\n labelOptions = this.options.labels,\n labelStyleOptions = labelOptions.style,\n horiz = this.horiz,\n slotWidth = this.getSlotWidth(),\n innerWidth = Math.max(1,\n Math.round(slotWidth - 2 * labelOptions.padding)),\n attr = {},\n labelMetrics = this.labelMetrics(),\n textOverflowOption = labelStyleOptions.textOverflow;\n var commonWidth,\n commonTextOverflow,\n maxLabelLength = 0,\n label,\n i,\n pos;\n // Set rotation option unless it is \"auto\", like in gauges\n if (!isString(labelOptions.rotation)) {\n // #4443\n attr.rotation = labelOptions.rotation || 0;\n }\n // Get the longest label length\n tickPositions.forEach(function (tickPosition) {\n var tick = ticks[tickPosition];\n // Replace label - sorting animation\n if (tick.movedLabel) {\n tick.replaceMovedLabel();\n }\n if (tick &&\n tick.label &&\n tick.label.textPxLength > maxLabelLength) {\n maxLabelLength = tick.label.textPxLength;\n }\n });\n this.maxLabelLength = maxLabelLength;\n // Handle auto rotation on horizontal axis\n if (this.autoRotation) {\n // Apply rotation only if the label is too wide for the slot, and\n // the label is wider than its height.\n if (maxLabelLength > innerWidth &&\n maxLabelLength > labelMetrics.h) {\n attr.rotation = this.labelRotation;\n }\n else {\n this.labelRotation = 0;\n }\n // Handle word-wrap or ellipsis on vertical axis\n }\n else if (slotWidth) {\n // For word-wrap or ellipsis\n commonWidth = innerWidth;\n if (!textOverflowOption) {\n commonTextOverflow = 'clip';\n // On vertical axis, only allow word wrap if there is room\n // for more lines.\n i = tickPositions.length;\n while (!horiz && i--) {\n pos = tickPositions[i];\n label = ticks[pos].label;\n if (label) {\n // Reset ellipsis in order to get the correct\n // bounding box (#4070)\n if (label.styles &&\n label.styles.textOverflow === 'ellipsis') {\n label.css({ textOverflow: 'clip' });\n // Set the correct width in order to read\n // the bounding box height (#4678, #5034)\n }\n else if (label.textPxLength > slotWidth) {\n label.css({ width: slotWidth + 'px' });\n }\n if (label.getBBox().height > (this.len / tickPositions.length -\n (labelMetrics.h - labelMetrics.f))) {\n label.specificTextOverflow = 'ellipsis';\n }\n }\n }\n }\n }\n // Add ellipsis if the label length is significantly longer than ideal\n if (attr.rotation) {\n commonWidth = (maxLabelLength > chart.chartHeight * 0.5 ?\n chart.chartHeight * 0.33 :\n maxLabelLength);\n if (!textOverflowOption) {\n commonTextOverflow = 'ellipsis';\n }\n }\n // Set the explicit or automatic label alignment\n this.labelAlign = labelOptions.align ||\n this.autoLabelAlign(this.labelRotation);\n if (this.labelAlign) {\n attr.align = this.labelAlign;\n }\n // Apply general and specific CSS\n tickPositions.forEach(function (pos) {\n var tick = ticks[pos],\n label = tick && tick.label,\n widthOption = labelStyleOptions.width,\n css = {};\n if (label) {\n // This needs to go before the CSS in old IE (#4502)\n label.attr(attr);\n if (tick.shortenLabel) {\n tick.shortenLabel();\n }\n else if (commonWidth &&\n !widthOption &&\n // Setting width in this case messes with the bounding box\n // (#7975)\n labelStyleOptions.whiteSpace !== 'nowrap' &&\n (\n // Speed optimizing, #7656\n commonWidth < label.textPxLength ||\n // Resetting CSS, #4928\n label.element.tagName === 'SPAN')) {\n css.width = commonWidth + 'px';\n if (!textOverflowOption) {\n css.textOverflow = (label.specificTextOverflow ||\n commonTextOverflow);\n }\n label.css(css);\n // Reset previously shortened label (#8210)\n }\n else if (label.styles &&\n label.styles.width &&\n !css.width &&\n !widthOption) {\n label.css({ width: null });\n }\n delete label.specificTextOverflow;\n tick.rotation = attr.rotation;\n }\n }, this);\n // Note: Why is this not part of getLabelPosition?\n this.tickRotCorr = renderer.rotCorr(labelMetrics.b, this.labelRotation || 0, this.side !== 0);\n };\n /**\n * Return true if the axis has associated data.\n *\n * @function Highcharts.Axis#hasData\n *\n * @return {boolean}\n * True if the axis has associated visible series and those series have\n * either valid data points or explicit `min` and `max` settings.\n */\n Axis.prototype.hasData = function () {\n return this.series.some(function (s) {\n return s.hasData();\n }) ||\n (this.options.showEmpty &&\n defined(this.min) &&\n defined(this.max));\n };\n /**\n * Adds the title defined in axis.options.title.\n *\n * @function Highcharts.Axis#addTitle\n *\n * @param {boolean} [display]\n * Whether or not to display the title.\n */\n Axis.prototype.addTitle = function (display) {\n var axis = this,\n renderer = axis.chart.renderer,\n horiz = axis.horiz,\n opposite = axis.opposite,\n options = axis.options,\n axisTitleOptions = options.title,\n styledMode = axis.chart.styledMode;\n var textAlign;\n if (!axis.axisTitle) {\n textAlign = axisTitleOptions.textAlign;\n if (!textAlign) {\n textAlign = (horiz ? {\n low: 'left',\n middle: 'center',\n high: 'right'\n } : {\n low: opposite ? 'right' : 'left',\n middle: 'center',\n high: opposite ? 'left' : 'right'\n })[axisTitleOptions.align];\n }\n axis.axisTitle = renderer\n .text(axisTitleOptions.text || '', 0, 0, axisTitleOptions.useHTML)\n .attr({\n zIndex: 7,\n rotation: axisTitleOptions.rotation,\n align: textAlign\n })\n .addClass('highcharts-axis-title');\n // #7814, don't mutate style option\n if (!styledMode) {\n axis.axisTitle.css(merge(axisTitleOptions.style));\n }\n axis.axisTitle.add(axis.axisGroup);\n axis.axisTitle.isNew = true;\n }\n // Max width defaults to the length of the axis\n if (!styledMode &&\n !axisTitleOptions.style.width &&\n !axis.isRadial) {\n axis.axisTitle.css({\n width: axis.len + 'px'\n });\n }\n // hide or show the title depending on whether showEmpty is set\n axis.axisTitle[display ? 'show' : 'hide'](display);\n };\n /**\n * Generates a tick for initial positioning.\n *\n * @private\n * @function Highcharts.Axis#generateTick\n *\n * @param {number} pos\n * The tick position in axis values.\n *\n * @param {number} [i]\n * The index of the tick in {@link Axis.tickPositions}.\n */\n Axis.prototype.generateTick = function (pos) {\n var axis = this,\n ticks = axis.ticks;\n if (!ticks[pos]) {\n ticks[pos] = new Tick(axis, pos);\n }\n else {\n ticks[pos].addLabel(); // update labels depending on tick interval\n }\n };\n /**\n * Render the tick labels to a preliminary position to get their sizes\n *\n * @private\n * @function Highcharts.Axis#getOffset\n *\n * @emits Highcharts.Axis#event:afterGetOffset\n */\n Axis.prototype.getOffset = function () {\n var _this = this;\n var axis = this,\n chart = axis.chart,\n horiz = axis.horiz,\n options = axis.options,\n side = axis.side,\n ticks = axis.ticks,\n tickPositions = axis.tickPositions,\n coll = axis.coll,\n axisParent = axis.axisParent // Used in color axis\n ,\n renderer = chart.renderer,\n invertedSide = (chart.inverted && !axis.isZAxis ?\n [1, 0, 3, 2][side] :\n side),\n hasData = axis.hasData(),\n axisTitleOptions = options.title,\n labelOptions = options.labels,\n axisOffset = chart.axisOffset,\n clipOffset = chart.clipOffset,\n directionFactor = [-1, 1, 1, -1][side],\n className = options.className;\n var showAxis,\n titleOffset = 0,\n titleOffsetOption,\n titleMargin = 0,\n labelOffset = 0, // reset\n labelOffsetPadded,\n lineHeightCorrection;\n // For reuse in Axis.render\n axis.showAxis = showAxis = hasData || options.showEmpty;\n // Set/reset staggerLines\n axis.staggerLines = (axis.horiz && labelOptions.staggerLines) || void 0;\n // Create the axisGroup and gridGroup elements on first iteration\n if (!axis.axisGroup) {\n var createGroup = function (name, suffix, zIndex) { return renderer.g(name)\n .attr({ zIndex: zIndex })\n .addClass(\"highcharts-\".concat(coll.toLowerCase()).concat(suffix, \" \") +\n (_this.isRadial ? \"highcharts-radial-axis\".concat(suffix, \" \") : '') +\n (className || ''))\n .add(axisParent); };\n axis.gridGroup = createGroup('grid', '-grid', options.gridZIndex);\n axis.axisGroup = createGroup('axis', '', options.zIndex);\n axis.labelGroup = createGroup('axis-labels', '-labels', labelOptions.zIndex);\n }\n if (hasData || axis.isLinked) {\n // Generate ticks\n tickPositions.forEach(function (pos) {\n // i is not used here, but may be used in overrides\n axis.generateTick(pos);\n });\n axis.renderUnsquish();\n // Left side must be align: right and right side must\n // have align: left for labels\n axis.reserveSpaceDefault = (side === 0 ||\n side === 2 ||\n { 1: 'left', 3: 'right' }[side] === axis.labelAlign);\n if (pick(labelOptions.reserveSpace, axis.labelAlign === 'center' ? true : null, axis.reserveSpaceDefault)) {\n tickPositions.forEach(function (pos) {\n // get the highest offset\n labelOffset = Math.max(ticks[pos].getLabelSize(), labelOffset);\n });\n }\n if (axis.staggerLines) {\n labelOffset *= axis.staggerLines;\n }\n axis.labelOffset = labelOffset * (axis.opposite ? -1 : 1);\n }\n else { // doesn't have data\n objectEach(ticks, function (tick, n) {\n tick.destroy();\n delete ticks[n];\n });\n }\n if (axisTitleOptions &&\n axisTitleOptions.text &&\n axisTitleOptions.enabled !== false) {\n axis.addTitle(showAxis);\n if (showAxis && axisTitleOptions.reserveSpace !== false) {\n axis.titleOffset = titleOffset =\n axis.axisTitle.getBBox()[horiz ? 'height' : 'width'];\n titleOffsetOption = axisTitleOptions.offset;\n titleMargin = defined(titleOffsetOption) ?\n 0 :\n pick(axisTitleOptions.margin, horiz ? 5 : 10);\n }\n }\n // Render the axis line\n axis.renderLine();\n // handle automatic or user set offset\n axis.offset = directionFactor * pick(options.offset, axisOffset[side] ? axisOffset[side] + (options.margin || 0) : 0);\n axis.tickRotCorr = axis.tickRotCorr || { x: 0, y: 0 }; // polar\n if (side === 0) {\n lineHeightCorrection = -axis.labelMetrics().h;\n }\n else if (side === 2) {\n lineHeightCorrection = axis.tickRotCorr.y;\n }\n else {\n lineHeightCorrection = 0;\n }\n // Find the padded label offset\n labelOffsetPadded = Math.abs(labelOffset) + titleMargin;\n if (labelOffset) {\n labelOffsetPadded -= lineHeightCorrection;\n labelOffsetPadded += directionFactor * (horiz ?\n pick(labelOptions.y, axis.tickRotCorr.y + directionFactor * 8) :\n labelOptions.x);\n }\n axis.axisTitleMargin = pick(titleOffsetOption, labelOffsetPadded);\n if (axis.getMaxLabelDimensions) {\n axis.maxLabelDimensions = axis.getMaxLabelDimensions(ticks, tickPositions);\n }\n // Due to GridAxis.tickSize, tickSize should be calculated after ticks\n // has rendered.\n if (coll !== 'colorAxis') {\n var tickSize = this.tickSize('tick');\n axisOffset[side] = Math.max(axisOffset[side], (axis.axisTitleMargin || 0) + titleOffset +\n directionFactor * axis.offset, labelOffsetPadded, // #3027\n tickPositions && tickPositions.length && tickSize ?\n tickSize[0] + directionFactor * axis.offset :\n 0 // #4866\n );\n // Decide the clipping needed to keep the graph inside\n // the plot area and axis lines\n var clip = !axis.axisLine || options.offset ?\n 0 :\n // #4308, #4371:\n Math.floor(axis.axisLine.strokeWidth() / 2) * 2;\n clipOffset[invertedSide] =\n Math.max(clipOffset[invertedSide], clip);\n }\n fireEvent(this, 'afterGetOffset');\n };\n /**\n * Internal function to get the path for the axis line. Extended for polar\n * charts.\n *\n * @function Highcharts.Axis#getLinePath\n *\n * @param {number} lineWidth\n * The line width in pixels.\n *\n * @return {Highcharts.SVGPathArray}\n * The SVG path definition in array form.\n */\n Axis.prototype.getLinePath = function (lineWidth) {\n var chart = this.chart,\n opposite = this.opposite,\n offset = this.offset,\n horiz = this.horiz,\n lineLeft = this.left + (opposite ? this.width : 0) + offset,\n lineTop = chart.chartHeight - this.bottom -\n (opposite ? this.height : 0) + offset;\n if (opposite) {\n lineWidth *= -1; // crispify the other way - #1480, #1687\n }\n return chart.renderer\n .crispLine([\n [\n 'M',\n horiz ?\n this.left :\n lineLeft,\n horiz ?\n lineTop :\n this.top\n ],\n [\n 'L',\n horiz ?\n chart.chartWidth - this.right :\n lineLeft,\n horiz ?\n lineTop :\n chart.chartHeight - this.bottom\n ]\n ], lineWidth);\n };\n /**\n * Render the axis line. Called internally when rendering and redrawing the\n * axis.\n *\n * @function Highcharts.Axis#renderLine\n */\n Axis.prototype.renderLine = function () {\n if (!this.axisLine) {\n this.axisLine = this.chart.renderer.path()\n .addClass('highcharts-axis-line')\n .add(this.axisGroup);\n if (!this.chart.styledMode) {\n this.axisLine.attr({\n stroke: this.options.lineColor,\n 'stroke-width': this.options.lineWidth,\n zIndex: 7\n });\n }\n }\n };\n /**\n * Position the axis title.\n *\n * @private\n * @function Highcharts.Axis#getTitlePosition\n *\n * @return {Highcharts.PositionObject}\n * X and Y positions for the title.\n */\n Axis.prototype.getTitlePosition = function () {\n // compute anchor points for each of the title align options\n var horiz = this.horiz,\n axisLeft = this.left,\n axisTop = this.top,\n axisLength = this.len,\n axisTitleOptions = this.options.title,\n margin = horiz ? axisLeft : axisTop,\n opposite = this.opposite,\n offset = this.offset,\n xOption = axisTitleOptions.x,\n yOption = axisTitleOptions.y,\n axisTitle = this.axisTitle,\n fontMetrics = this.chart.renderer.fontMetrics(axisTitleOptions.style.fontSize,\n axisTitle), \n // The part of a multiline text that is below the baseline of the\n // first line. Subtract 1 to preserve pixel-perfectness from the\n // old behaviour (v5.0.12), where only one line was allowed.\n textHeightOvershoot = axisTitle ? Math.max(axisTitle.getBBox(false, 0).height - fontMetrics.h - 1, 0) : 0, \n // the position in the length direction of the axis\n alongAxis = ({\n low: margin + (horiz ? 0 : axisLength),\n middle: margin + axisLength / 2,\n high: margin + (horiz ? axisLength : 0)\n })[axisTitleOptions.align], \n // the position in the perpendicular direction of the axis\n offAxis = (horiz ? axisTop + this.height : axisLeft) +\n (horiz ? 1 : -1) * // horizontal axis reverses the margin\n (opposite ? -1 : 1) * // so does opposite axes\n (this.axisTitleMargin || 0) +\n [\n -textHeightOvershoot,\n textHeightOvershoot,\n fontMetrics.f,\n -textHeightOvershoot // left\n ][this.side],\n titlePosition = {\n x: horiz ?\n alongAxis + xOption :\n offAxis + (opposite ? this.width : 0) + offset + xOption,\n y: horiz ?\n offAxis + yOption - (opposite ? this.height : 0) + offset :\n alongAxis + yOption\n };\n fireEvent(this, 'afterGetTitlePosition', { titlePosition: titlePosition });\n return titlePosition;\n };\n /**\n * Render a minor tick into the given position. If a minor tick already\n * exists in this position, move it.\n *\n * @function Highcharts.Axis#renderMinorTick\n *\n * @param {number} pos\n * The position in axis values.\n *\n * @param {boolean} slideIn\n * Whether the tick should animate in from last computed position\n */\n Axis.prototype.renderMinorTick = function (pos, slideIn) {\n var axis = this;\n var minorTicks = axis.minorTicks;\n if (!minorTicks[pos]) {\n minorTicks[pos] = new Tick(axis, pos, 'minor');\n }\n // Render new ticks in old position\n if (slideIn && minorTicks[pos].isNew) {\n minorTicks[pos].render(null, true);\n }\n minorTicks[pos].render(null, false, 1);\n };\n /**\n * Render a major tick into the given position. If a tick already exists\n * in this position, move it.\n *\n * @function Highcharts.Axis#renderTick\n *\n * @param {number} pos\n * The position in axis values.\n *\n * @param {number} i\n * The tick index.\n *\n * @param {boolean} slideIn\n * Whether the tick should animate in from last computed position\n */\n Axis.prototype.renderTick = function (pos, i, slideIn) {\n var axis = this,\n isLinked = axis.isLinked,\n ticks = axis.ticks;\n // Linked axes need an extra check to find out if\n if (!isLinked ||\n (pos >= axis.min && pos <= axis.max) ||\n (axis.grid && axis.grid.isColumn)) {\n if (!ticks[pos]) {\n ticks[pos] = new Tick(axis, pos);\n }\n // NOTE this seems like overkill. Could be handled in tick.render by\n // setting old position in attr, then set new position in animate.\n // render new ticks in old position\n if (slideIn && ticks[pos].isNew) {\n // Start with negative opacity so that it is visible from\n // halfway into the animation\n ticks[pos].render(i, true, -1);\n }\n ticks[pos].render(i);\n }\n };\n /**\n * Render the axis.\n *\n * @private\n * @function Highcharts.Axis#render\n *\n * @emits Highcharts.Axis#event:afterRender\n */\n Axis.prototype.render = function () {\n var axis = this,\n chart = axis.chart,\n log = axis.logarithmic,\n renderer = chart.renderer,\n options = axis.options,\n isLinked = axis.isLinked,\n tickPositions = axis.tickPositions,\n axisTitle = axis.axisTitle,\n ticks = axis.ticks,\n minorTicks = axis.minorTicks,\n alternateBands = axis.alternateBands,\n stackLabelOptions = options.stackLabels,\n alternateGridColor = options.alternateGridColor,\n tickmarkOffset = axis.tickmarkOffset,\n axisLine = axis.axisLine,\n showAxis = axis.showAxis,\n animation = animObject(renderer.globalAnimation);\n var from,\n to;\n // Reset\n axis.labelEdge.length = 0;\n axis.overlap = false;\n // Mark all elements inActive before we go over and mark the active ones\n [ticks, minorTicks, alternateBands].forEach(function (coll) {\n objectEach(coll, function (tick) {\n tick.isActive = false;\n });\n });\n // If the series has data draw the ticks. Else only the line and title\n if (axis.hasData() || isLinked) {\n var slideInTicks_1 = axis.chart.hasRendered &&\n axis.old && isNumber(axis.old.min);\n // minor ticks\n if (axis.minorTickInterval && !axis.categories) {\n axis.getMinorTickPositions().forEach(function (pos) {\n axis.renderMinorTick(pos, slideInTicks_1);\n });\n }\n // Major ticks. Pull out the first item and render it last so that\n // we can get the position of the neighbour label. #808.\n if (tickPositions.length) { // #1300\n tickPositions.forEach(function (pos, i) {\n axis.renderTick(pos, i, slideInTicks_1);\n });\n // In a categorized axis, the tick marks are displayed\n // between labels. So we need to add a tick mark and\n // grid line at the left edge of the X axis.\n if (tickmarkOffset && (axis.min === 0 || axis.single)) {\n if (!ticks[-1]) {\n ticks[-1] = new Tick(axis, -1, null, true);\n }\n ticks[-1].render(-1);\n }\n }\n // alternate grid color\n if (alternateGridColor) {\n tickPositions.forEach(function (pos, i) {\n to = typeof tickPositions[i + 1] !== 'undefined' ?\n tickPositions[i + 1] + tickmarkOffset :\n axis.max - tickmarkOffset;\n if (i % 2 === 0 &&\n pos < axis.max &&\n to <= axis.max + (chart.polar ?\n -tickmarkOffset :\n tickmarkOffset)) { // #2248, #4660\n if (!alternateBands[pos]) {\n // Should be imported from PlotLineOrBand.js, but\n // the dependency cycle with axis is a problem\n alternateBands[pos] = new H.PlotLineOrBand(axis);\n }\n from = pos + tickmarkOffset; // #949\n alternateBands[pos].options = {\n from: log ? log.lin2log(from) : from,\n to: log ? log.lin2log(to) : to,\n color: alternateGridColor,\n className: 'highcharts-alternate-grid'\n };\n alternateBands[pos].render();\n alternateBands[pos].isActive = true;\n }\n });\n }\n // custom plot lines and bands\n if (!axis._addedPlotLB) { // only first time\n axis._addedPlotLB = true;\n (options.plotLines || [])\n .concat(options.plotBands || [])\n .forEach(function (plotLineOptions) {\n axis\n .addPlotBandOrLine(plotLineOptions);\n });\n }\n } // end if hasData\n // Remove inactive ticks\n [ticks, minorTicks, alternateBands].forEach(function (coll) {\n var forDestruction = [],\n delay = animation.duration,\n destroyInactiveItems = function () {\n var i = forDestruction.length;\n while (i--) {\n // When resizing rapidly, the same items\n // may be destroyed in different timeouts,\n // or the may be reactivated\n if (coll[forDestruction[i]] &&\n !coll[forDestruction[i]].isActive) {\n coll[forDestruction[i]].destroy();\n delete coll[forDestruction[i]];\n }\n }\n };\n objectEach(coll, function (tick, pos) {\n if (!tick.isActive) {\n // Render to zero opacity\n tick.render(pos, false, 0);\n tick.isActive = false;\n forDestruction.push(pos);\n }\n });\n // When the objects are finished fading out, destroy them\n syncTimeout(destroyInactiveItems, coll === alternateBands ||\n !chart.hasRendered ||\n !delay ?\n 0 :\n delay);\n });\n // Set the axis line path\n if (axisLine) {\n axisLine[axisLine.isPlaced ? 'animate' : 'attr']({\n d: this.getLinePath(axisLine.strokeWidth())\n });\n axisLine.isPlaced = true;\n // Show or hide the line depending on options.showEmpty\n axisLine[showAxis ? 'show' : 'hide'](showAxis);\n }\n if (axisTitle && showAxis) {\n var titleXy = axis.getTitlePosition();\n axisTitle[axisTitle.isNew ? 'attr' : 'animate'](titleXy);\n axisTitle.isNew = false;\n }\n // Stacked totals:\n if (stackLabelOptions && stackLabelOptions.enabled && axis.stacking) {\n axis.stacking.renderStackTotals();\n }\n // End stacked totals\n // Record old scaling for updating/animation\n axis.old = {\n len: axis.len,\n max: axis.max,\n min: axis.min,\n transA: axis.transA,\n userMax: axis.userMax,\n userMin: axis.userMin\n };\n axis.isDirty = false;\n fireEvent(this, 'afterRender');\n };\n /**\n * Redraw the axis to reflect changes in the data or axis extremes. Called\n * internally from Highcharts.Chart#redraw.\n *\n * @private\n * @function Highcharts.Axis#redraw\n */\n Axis.prototype.redraw = function () {\n if (this.visible) {\n // render the axis\n this.render();\n // move plot lines and bands\n this.plotLinesAndBands.forEach(function (plotLine) {\n plotLine.render();\n });\n }\n // mark associated series as dirty and ready for redraw\n this.series.forEach(function (series) {\n series.isDirty = true;\n });\n };\n /**\n * Returns an array of axis properties, that should be untouched during\n * reinitialization.\n *\n * @private\n * @function Highcharts.Axis#getKeepProps\n */\n Axis.prototype.getKeepProps = function () {\n return (this.keepProps || Axis.keepProps);\n };\n /**\n * Destroys an Axis instance. See {@link Axis#remove} for the API endpoint\n * to fully remove the axis.\n *\n * @private\n * @function Highcharts.Axis#destroy\n *\n * @param {boolean} [keepEvents]\n * Whether to preserve events, used internally in Axis.update.\n */\n Axis.prototype.destroy = function (keepEvents) {\n var axis = this,\n plotLinesAndBands = axis.plotLinesAndBands,\n eventOptions = this.eventOptions;\n fireEvent(this, 'destroy', { keepEvents: keepEvents });\n // Remove the events\n if (!keepEvents) {\n removeEvent(axis);\n }\n // Destroy collections\n [axis.ticks, axis.minorTicks, axis.alternateBands].forEach(function (coll) {\n destroyObjectProperties(coll);\n });\n if (plotLinesAndBands) {\n var i = plotLinesAndBands.length;\n while (i--) { // #1975\n plotLinesAndBands[i].destroy();\n }\n }\n // Destroy elements\n ['axisLine', 'axisTitle', 'axisGroup',\n 'gridGroup', 'labelGroup', 'cross', 'scrollbar'].forEach(function (prop) {\n if (axis[prop]) {\n axis[prop] = axis[prop].destroy();\n }\n });\n // Destroy each generated group for plotlines and plotbands\n for (var plotGroup in axis.plotLinesAndBandsGroups) { // eslint-disable-line guard-for-in\n axis.plotLinesAndBandsGroups[plotGroup] =\n axis.plotLinesAndBandsGroups[plotGroup].destroy();\n }\n // Delete all properties and fall back to the prototype.\n objectEach(axis, function (val, key) {\n if (axis.getKeepProps().indexOf(key) === -1) {\n delete axis[key];\n }\n });\n this.eventOptions = eventOptions;\n };\n /**\n * Internal function to draw a crosshair.\n *\n * @function Highcharts.Axis#drawCrosshair\n *\n * @param {Highcharts.PointerEventObject} [e]\n * The event arguments from the modified pointer event, extended with\n * `chartX` and `chartY`\n *\n * @param {Highcharts.Point} [point]\n * The Point object if the crosshair snaps to points.\n *\n * @emits Highcharts.Axis#event:afterDrawCrosshair\n * @emits Highcharts.Axis#event:drawCrosshair\n */\n Axis.prototype.drawCrosshair = function (e, point) {\n var options = this.crosshair,\n snap = pick(options && options.snap,\n true),\n chart = this.chart;\n var path,\n pos,\n categorized,\n graphic = this.cross,\n crossOptions;\n fireEvent(this, 'drawCrosshair', { e: e, point: point });\n // Use last available event when updating non-snapped crosshairs without\n // mouse interaction (#5287)\n if (!e) {\n e = this.cross && this.cross.e;\n }\n if (\n // Disabled in options\n !options ||\n // Snap\n ((defined(point) || !snap) === false)) {\n this.hideCrosshair();\n }\n else {\n // Get the path\n if (!snap) {\n pos = e &&\n (this.horiz ?\n e.chartX - this.pos :\n this.len - e.chartY + this.pos);\n }\n else if (defined(point)) {\n // #3834\n pos = pick(this.coll !== 'colorAxis' ?\n point.crosshairPos : // 3D axis extension\n null, this.isXAxis ?\n point.plotX :\n this.len - point.plotY);\n }\n if (defined(pos)) {\n crossOptions = {\n // value, only used on radial\n value: point && (this.isXAxis ?\n point.x :\n pick(point.stackY, point.y)),\n translatedValue: pos\n };\n if (chart.polar) {\n // Additional information required for crosshairs in\n // polar chart\n extend(crossOptions, {\n isCrosshair: true,\n chartX: e && e.chartX,\n chartY: e && e.chartY,\n point: point\n });\n }\n path = this.getPlotLinePath(crossOptions) ||\n null; // #3189\n }\n if (!defined(path)) {\n this.hideCrosshair();\n return;\n }\n categorized = this.categories && !this.isRadial;\n // Draw the cross\n if (!graphic) {\n this.cross = graphic = chart.renderer\n .path()\n .addClass('highcharts-crosshair highcharts-crosshair-' +\n (categorized ? 'category ' : 'thin ') +\n (options.className || ''))\n .attr({\n zIndex: pick(options.zIndex, 2)\n })\n .add();\n // Presentational attributes\n if (!chart.styledMode) {\n graphic.attr({\n stroke: options.color ||\n (categorized ?\n Color\n .parse(\"#ccd6eb\" /* Palette.highlightColor20 */)\n .setOpacity(0.25)\n .get() :\n \"#cccccc\" /* Palette.neutralColor20 */),\n 'stroke-width': pick(options.width, 1)\n }).css({\n 'pointer-events': 'none'\n });\n if (options.dashStyle) {\n graphic.attr({\n dashstyle: options.dashStyle\n });\n }\n }\n }\n graphic.show().attr({\n d: path\n });\n if (categorized && !options.width) {\n graphic.attr({\n 'stroke-width': this.transA\n });\n }\n this.cross.e = e;\n }\n fireEvent(this, 'afterDrawCrosshair', { e: e, point: point });\n };\n /**\n * Hide the crosshair if visible.\n *\n * @function Highcharts.Axis#hideCrosshair\n */\n Axis.prototype.hideCrosshair = function () {\n if (this.cross) {\n this.cross.hide();\n }\n fireEvent(this, 'afterHideCrosshair');\n };\n /**\n * Check whether the chart has vertical panning ('y' or 'xy' type).\n *\n * @private\n * @function Highcharts.Axis#hasVerticalPanning\n */\n Axis.prototype.hasVerticalPanning = function () {\n var panningOptions = this.chart.options.chart.panning;\n return Boolean(panningOptions &&\n panningOptions.enabled && // #14624\n /y/.test(panningOptions.type));\n };\n /**\n * Check whether the given value is a positive valid axis value.\n *\n * @private\n * @function Highcharts.Axis#validatePositiveValue\n *\n * @param {unknown} value\n * The axis value\n */\n Axis.prototype.validatePositiveValue = function (value) {\n return isNumber(value) && value > 0;\n };\n /**\n * Update an axis object with a new set of options. The options are merged\n * with the existing options, so only new or altered options need to be\n * specified.\n *\n * @sample highcharts/members/axis-update/\n * Axis update demo\n *\n * @function Highcharts.Axis#update\n *\n * @param {Highcharts.AxisOptions} options\n * The new options that will be merged in with existing options on the axis.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the axis is altered. If doing more\n * operations on the chart, it is a good idea to set redraw to false and\n * call {@link Chart#redraw} after.\n */\n Axis.prototype.update = function (options, redraw) {\n var chart = this.chart;\n options = merge(this.userOptions, options);\n this.destroy(true);\n this.init(chart, options);\n chart.isDirtyBox = true;\n if (pick(redraw, true)) {\n chart.redraw();\n }\n };\n /**\n * Remove the axis from the chart.\n *\n * @sample highcharts/members/chart-addaxis/\n * Add and remove axes\n *\n * @function Highcharts.Axis#remove\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart following the remove.\n */\n Axis.prototype.remove = function (redraw) {\n var chart = this.chart,\n key = this.coll, // xAxis or yAxis\n axisSeries = this.series;\n var i = axisSeries.length;\n // Remove associated series (#2687)\n while (i--) {\n if (axisSeries[i]) {\n axisSeries[i].remove(false);\n }\n }\n // Remove the axis\n erase(chart.axes, this);\n erase(chart[key], this);\n chart[key].forEach(function (axis, i) {\n // Re-index, #1706, #8075\n axis.options.index = axis.userOptions.index = i;\n });\n this.destroy();\n chart.isDirtyBox = true;\n if (pick(redraw, true)) {\n chart.redraw();\n }\n };\n /**\n * Update the axis title by options after render time.\n *\n * @sample highcharts/members/axis-settitle/\n * Set a new Y axis title\n *\n * @function Highcharts.Axis#setTitle\n *\n * @param {Highcharts.AxisTitleOptions} titleOptions\n * The additional title options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after setting the title.\n */\n Axis.prototype.setTitle = function (titleOptions, redraw) {\n this.update({ title: titleOptions }, redraw);\n };\n /**\n * Set new axis categories and optionally redraw.\n *\n * @sample highcharts/members/axis-setcategories/\n * Set categories by click on a button\n *\n * @function Highcharts.Axis#setCategories\n *\n * @param {Array} categories\n * The new categories.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart.\n */\n Axis.prototype.setCategories = function (categories, redraw) {\n this.update({ categories: categories }, redraw);\n };\n /* *\n *\n * Static Properties\n *\n * */\n Axis.defaultOptions = AxisDefaults.defaultXAxisOptions;\n // Properties to survive after destroy, needed for Axis.update (#4317,\n // #5773, #5881).\n Axis.keepProps = [\n 'extKey',\n 'hcEvents',\n 'names',\n 'series',\n 'userMax',\n 'userMin'\n ];\n return Axis;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Options for the path on the Axis to be calculated.\n * @interface Highcharts.AxisPlotLinePathOptionsObject\n */ /**\n * Axis value.\n * @name Highcharts.AxisPlotLinePathOptionsObject#value\n * @type {number|undefined}\n */ /**\n * Line width used for calculation crisp line coordinates. Defaults to 1.\n * @name Highcharts.AxisPlotLinePathOptionsObject#lineWidth\n * @type {number|undefined}\n */ /**\n * If `false`, the function will return null when it falls outside the axis\n * bounds. If `true`, the function will return a path aligned to the plot area\n * sides if it falls outside. If `pass`, it will return a path outside.\n * @name Highcharts.AxisPlotLinePathOptionsObject#force\n * @type {string|boolean|undefined}\n */ /**\n * Used in Highcharts Stock. When `true`, plot paths\n * (crosshair, plotLines, gridLines)\n * will be rendered on all axes when defined on the first axis.\n * @name Highcharts.AxisPlotLinePathOptionsObject#acrossPanes\n * @type {boolean|undefined}\n */ /**\n * Use old coordinates (for resizing and rescaling).\n * If not set, defaults to `false`.\n * @name Highcharts.AxisPlotLinePathOptionsObject#old\n * @type {boolean|undefined}\n */ /**\n * If given, return the plot line path of a pixel position on the axis.\n * @name Highcharts.AxisPlotLinePathOptionsObject#translatedValue\n * @type {number|undefined}\n */ /**\n * Used in Polar axes. Reverse the positions for concatenation of polygonal\n * plot bands\n * @name Highcharts.AxisPlotLinePathOptionsObject#reverse\n * @type {boolean|undefined}\n */\n /**\n * Options for crosshairs on axes.\n *\n * @product highstock\n *\n * @typedef {Highcharts.XAxisCrosshairOptions|Highcharts.YAxisCrosshairOptions} Highcharts.AxisCrosshairOptions\n */\n /**\n * @typedef {\"navigator\"|\"pan\"|\"rangeSelectorButton\"|\"rangeSelectorInput\"|\"scrollbar\"|\"traverseUpButton\"|\"zoom\"} Highcharts.AxisExtremesTriggerValue\n */\n /**\n * @callback Highcharts.AxisEventCallbackFunction\n *\n * @param {Highcharts.Axis} this\n */\n /**\n * @callback Highcharts.AxisLabelsFormatterCallbackFunction\n *\n * @param {Highcharts.AxisLabelsFormatterContextObject} this\n *\n * @param {Highcharts.AxisLabelsFormatterContextObject} ctx\n *\n * @return {string}\n */\n /**\n * @interface Highcharts.AxisLabelsFormatterContextObject\n */ /**\n * The axis item of the label\n * @name Highcharts.AxisLabelsFormatterContextObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * The chart instance.\n * @name Highcharts.AxisLabelsFormatterContextObject#chart\n * @type {Highcharts.Chart}\n */ /**\n * Default formatting of date/time labels.\n * @name Highcharts.AxisLabelsFormatterContextObject#dateTimeLabelFormat\n * @type {string|undefined}\n */ /**\n * Whether the label belongs to the first tick on the axis.\n * @name Highcharts.AxisLabelsFormatterContextObject#isFirst\n * @type {boolean}\n */ /**\n * Whether the label belongs to the last tick on the axis.\n * @name Highcharts.AxisLabelsFormatterContextObject#isLast\n * @type {boolean}\n */ /**\n * The position on the axis in terms of axis values. For category axes, a\n * zero-based index. For datetime axes, the JavaScript time in milliseconds\n * since 1970.\n * @name Highcharts.AxisLabelsFormatterContextObject#pos\n * @type {number}\n */ /**\n * The preformatted text as the result of the default formatting. For example\n * dates will be formatted as strings, and numbers with language-specific comma\n * separators, thousands separators and numeric symbols like `k` or `M`.\n * @name Highcharts.AxisLabelsFormatterContextObject#text\n * @type {string|undefined}\n */ /**\n * The Tick instance.\n * @name Highcharts.AxisLabelsFormatterContextObject#tick\n * @type {Highcharts.Tick}\n */ /**\n * This can be either a numeric value or a category string.\n * @name Highcharts.AxisLabelsFormatterContextObject#value\n * @type {number|string}\n */\n /**\n * Options for axes.\n *\n * @typedef {Highcharts.XAxisOptions|Highcharts.YAxisOptions|Highcharts.ZAxisOptions} Highcharts.AxisOptions\n */\n /**\n * @callback Highcharts.AxisPointBreakEventCallbackFunction\n *\n * @param {Highcharts.Axis} this\n *\n * @param {Highcharts.AxisPointBreakEventObject} evt\n */\n /**\n * @interface Highcharts.AxisPointBreakEventObject\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#brk\n * @type {Highcharts.Dictionary}\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#point\n * @type {Highcharts.Point}\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#preventDefault\n * @type {Function}\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#target\n * @type {Highcharts.SVGElement}\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#type\n * @type {\"pointBreak\"|\"pointInBreak\"}\n */\n /**\n * @callback Highcharts.AxisSetExtremesEventCallbackFunction\n *\n * @param {Highcharts.Axis} this\n *\n * @param {Highcharts.AxisSetExtremesEventObject} evt\n */\n /**\n * @interface Highcharts.AxisSetExtremesEventObject\n * @extends Highcharts.ExtremesObject\n */ /**\n * @name Highcharts.AxisSetExtremesEventObject#preventDefault\n * @type {Function}\n */ /**\n * @name Highcharts.AxisSetExtremesEventObject#target\n * @type {Highcharts.SVGElement}\n */ /**\n * @name Highcharts.AxisSetExtremesEventObject#trigger\n * @type {Highcharts.AxisExtremesTriggerValue|string}\n */ /**\n * @name Highcharts.AxisSetExtremesEventObject#type\n * @type {\"setExtremes\"}\n */\n /**\n * @callback Highcharts.AxisTickPositionerCallbackFunction\n *\n * @param {Highcharts.Axis} this\n *\n * @return {Highcharts.AxisTickPositionsArray}\n */\n /**\n * @interface Highcharts.AxisTickPositionsArray\n * @augments Array\n */\n /**\n * @typedef {\"high\"|\"low\"|\"middle\"} Highcharts.AxisTitleAlignValue\n */\n /**\n * @typedef {Highcharts.XAxisTitleOptions|Highcharts.YAxisTitleOptions|Highcharts.ZAxisTitleOptions} Highcharts.AxisTitleOptions\n */\n /**\n * @typedef {\"linear\"|\"logarithmic\"|\"datetime\"|\"category\"|\"treegrid\"} Highcharts.AxisTypeValue\n */\n /**\n * The returned object literal from the {@link Highcharts.Axis#getExtremes}\n * function.\n *\n * @interface Highcharts.ExtremesObject\n */ /**\n * The maximum value of the axis' associated series.\n * @name Highcharts.ExtremesObject#dataMax\n * @type {number}\n */ /**\n * The minimum value of the axis' associated series.\n * @name Highcharts.ExtremesObject#dataMin\n * @type {number}\n */ /**\n * The maximum axis value, either automatic or set manually. If the `max` option\n * is not set, `maxPadding` is 0 and `endOnTick` is false, this value will be\n * the same as `dataMax`.\n * @name Highcharts.ExtremesObject#max\n * @type {number}\n */ /**\n * The minimum axis value, either automatic or set manually. If the `min` option\n * is not set, `minPadding` is 0 and `startOnTick` is false, this value will be\n * the same as `dataMin`.\n * @name Highcharts.ExtremesObject#min\n * @type {number}\n */ /**\n * The user defined maximum, either from the `max` option or from a zoom or\n * `setExtremes` action.\n * @name Highcharts.ExtremesObject#userMax\n * @type {number}\n */ /**\n * The user defined minimum, either from the `min` option or from a zoom or\n * `setExtremes` action.\n * @name Highcharts.ExtremesObject#userMin\n * @type {number}\n */\n /**\n * Formatter function for the text of a crosshair label.\n *\n * @callback Highcharts.XAxisCrosshairLabelFormatterCallbackFunction\n *\n * @param {Highcharts.Axis} this\n * Axis context\n *\n * @param {number} value\n * Y value of the data point\n *\n * @return {string}\n */\n ''; // keeps doclets above in JS file\n\n return Axis;\n });\n _registerModule(_modules, 'Core/Axis/DateTimeAxis.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var addEvent = U.addEvent,\n getMagnitude = U.getMagnitude,\n normalizeTickInterval = U.normalizeTickInterval,\n timeUnits = U.timeUnits;\n /* *\n *\n * Composition\n *\n * */\n /* eslint-disable valid-jsdoc */\n var DateTimeAxis;\n (function (DateTimeAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extends axis class with date and time support.\n * @private\n */\n function compose(AxisClass) {\n if (composedClasses.indexOf(AxisClass) === -1) {\n composedClasses.push(AxisClass);\n AxisClass.keepProps.push('dateTime');\n var axisProto = AxisClass.prototype;\n axisProto.getTimeTicks = getTimeTicks;\n addEvent(AxisClass, 'init', onInit);\n }\n return AxisClass;\n }\n DateTimeAxis.compose = compose;\n /**\n * Set the tick positions to a time unit that makes sense, for example\n * on the first of each month or on every Monday. Return an array with\n * the time positions. Used in datetime axes as well as for grouping\n * data on a datetime axis.\n *\n * @private\n * @function Highcharts.Axis#getTimeTicks\n * @param {Highcharts.TimeNormalizeObject} normalizedInterval\n * The interval in axis values (ms) and thecount.\n * @param {number} min\n * The minimum in axis values.\n * @param {number} max\n * The maximum in axis values.\n */\n function getTimeTicks() {\n return this.chart.time.getTimeTicks.apply(this.chart.time, arguments);\n }\n /**\n * @private\n */\n function onInit(e) {\n var axis = this;\n var options = e.userOptions;\n if (options.type !== 'datetime') {\n axis.dateTime = void 0;\n return;\n }\n if (!axis.dateTime) {\n axis.dateTime = new Additions(axis);\n }\n }\n /* *\n *\n * Classes\n *\n * */\n var Additions = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Additions(axis) {\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get a normalized tick interval for dates. Returns a configuration\n * object with unit range (interval), count and name. Used to prepare\n * data for `getTimeTicks`. Previously this logic was part of\n * getTimeTicks, but as `getTimeTicks` now runs of segments in stock\n * charts, the normalizing logic was extracted in order to prevent it\n * for running over again for each segment having the same interval.\n * #662, #697.\n * @private\n */\n Additions.prototype.normalizeTimeTickInterval = function (tickInterval, unitsOption) {\n var units = (unitsOption || [[\n // unit name\n 'millisecond',\n // allowed multiples\n [1, 2, 5, 10, 20, 25, 50, 100, 200, 500]\n ],\n [\n 'second',\n [1, 2, 5, 10, 15, 30]\n ],\n [\n 'minute',\n [1, 2, 5, 10, 15, 30]\n ],\n [\n 'hour',\n [1, 2, 3, 4, 6, 8, 12]\n ],\n [\n 'day',\n [1, 2]\n ],\n [\n 'week',\n [1, 2]\n ],\n [\n 'month',\n [1, 2, 3, 4, 6]\n ],\n [\n 'year',\n null\n ]]);\n var unit = units[units.length - 1], // default unit is years\n interval = timeUnits[unit[0]],\n multiples = unit[1],\n i;\n // loop through the units to find the one that best fits the\n // tickInterval\n for (i = 0; i < units.length; i++) {\n unit = units[i];\n interval = timeUnits[unit[0]];\n multiples = unit[1];\n if (units[i + 1]) {\n // lessThan is in the middle between the highest multiple\n // and the next unit.\n var lessThan = (interval *\n multiples[multiples.length - 1] +\n timeUnits[units[i + 1][0]]) / 2;\n // break and keep the current unit\n if (tickInterval <= lessThan) {\n break;\n }\n }\n }\n // prevent 2.5 years intervals, though 25, 250 etc. are allowed\n if (interval === timeUnits.year && tickInterval < 5 * interval) {\n multiples = [1, 2, 5];\n }\n // get the count\n var count = normalizeTickInterval(tickInterval / interval,\n multiples,\n unit[0] === 'year' ? // #1913, #2360\n Math.max(getMagnitude(tickInterval / interval), 1) :\n 1);\n return {\n unitRange: interval,\n count: count,\n unitName: unit[0]\n };\n };\n /**\n * Get the best date format for a specific X value based on the closest\n * point range on the axis.\n *\n * @private\n */\n Additions.prototype.getXDateFormat = function (x, dateTimeLabelFormats) {\n var axis = this.axis,\n time = axis.chart.time;\n return axis.closestPointRange ?\n time.getDateFormat(axis.closestPointRange, x, axis.options.startOfWeek, dateTimeLabelFormats) ||\n // #2546, 2581\n time.resolveDTLFormat(dateTimeLabelFormats.year).main :\n time.resolveDTLFormat(dateTimeLabelFormats.day).main;\n };\n return Additions;\n }());\n DateTimeAxis.Additions = Additions;\n })(DateTimeAxis || (DateTimeAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return DateTimeAxis;\n });\n _registerModule(_modules, 'Core/Axis/LogarithmicAxis.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var addEvent = U.addEvent,\n getMagnitude = U.getMagnitude,\n normalizeTickInterval = U.normalizeTickInterval,\n pick = U.pick;\n /* *\n *\n * Class\n *\n * */\n /**\n * @private\n */\n var LogarithmicAxis;\n (function (LogarithmicAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Provides logarithmic support for axes.\n * @private\n */\n function compose(AxisClass) {\n if (composedClasses.indexOf(AxisClass) === -1) {\n composedClasses.push(AxisClass);\n AxisClass.keepProps.push('logarithmic');\n addEvent(AxisClass, 'init', onInit);\n addEvent(AxisClass, 'afterInit', onAfterInit);\n }\n return AxisClass;\n }\n LogarithmicAxis.compose = compose;\n /**\n * @private\n */\n function onInit(e) {\n var axis = this;\n var options = e.userOptions;\n var logarithmic = axis.logarithmic;\n if (options.type !== 'logarithmic') {\n axis.logarithmic = void 0;\n }\n else {\n if (!logarithmic) {\n logarithmic = axis.logarithmic = new Additions(axis);\n }\n }\n }\n /**\n * @private\n */\n function onAfterInit() {\n var axis = this;\n var log = axis.logarithmic;\n // extend logarithmic axis\n if (log) {\n axis.lin2val = function (num) {\n return log.lin2log(num);\n };\n axis.val2lin = function (num) {\n return log.log2lin(num);\n };\n }\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * Provides logarithmic support for axes.\n * @private\n * @class\n */\n var Additions = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Additions(axis) {\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set the tick positions of a logarithmic axis.\n */\n Additions.prototype.getLogTickPositions = function (interval, min, max, minor) {\n var log = this;\n var axis = log.axis;\n var axisLength = axis.len;\n var options = axis.options;\n // Since we use this method for both major and minor ticks,\n // use a local variable and return the result\n var positions = [];\n // Reset\n if (!minor) {\n log.minorAutoInterval = void 0;\n }\n // First case: All ticks fall on whole logarithms: 1, 10, 100 etc.\n if (interval >= 0.5) {\n interval = Math.round(interval);\n positions = axis.getLinearTickPositions(interval, min, max);\n // Second case: We need intermediary ticks. For example\n // 1, 2, 4, 6, 8, 10, 20, 40 etc.\n }\n else if (interval >= 0.08) {\n var roundedMin = Math.floor(min);\n var intermediate = void 0,\n i = void 0,\n j = void 0,\n len = void 0,\n pos = void 0,\n lastPos = void 0,\n break2 = void 0;\n if (interval > 0.3) {\n intermediate = [1, 2, 4];\n // 0.2 equals five minor ticks per 1, 10, 100 etc\n }\n else if (interval > 0.15) {\n intermediate = [1, 2, 4, 6, 8];\n }\n else { // 0.1 equals ten minor ticks per 1, 10, 100 etc\n intermediate = [1, 2, 3, 4, 5, 6, 7, 8, 9];\n }\n for (i = roundedMin; i < max + 1 && !break2; i++) {\n len = intermediate.length;\n for (j = 0; j < len && !break2; j++) {\n pos = log.log2lin(log.lin2log(i) * intermediate[j]);\n // #1670, lastPos is #3113\n if (pos > min &&\n (!minor || lastPos <= max) &&\n typeof lastPos !== 'undefined') {\n positions.push(lastPos);\n }\n if (lastPos > max) {\n break2 = true;\n }\n lastPos = pos;\n }\n }\n // Third case: We are so deep in between whole logarithmic values,\n // that we might as well handle the tick positions like a linear\n // axis. For example 1.01, 1.02, 1.03, 1.04.\n }\n else {\n var realMin = log.lin2log(min),\n realMax = log.lin2log(max),\n tickIntervalOption = minor ?\n axis.getMinorTickInterval() :\n options.tickInterval,\n filteredTickIntervalOption = tickIntervalOption === 'auto' ?\n null :\n tickIntervalOption,\n tickPixelIntervalOption = options.tickPixelInterval / (minor ? 5 : 1),\n totalPixelLength = minor ?\n axisLength / axis.tickPositions.length :\n axisLength;\n interval = pick(filteredTickIntervalOption, log.minorAutoInterval, (realMax - realMin) *\n tickPixelIntervalOption / (totalPixelLength || 1));\n interval = normalizeTickInterval(interval);\n positions = axis.getLinearTickPositions(interval, realMin, realMax).map(log.log2lin);\n if (!minor) {\n log.minorAutoInterval = interval / 5;\n }\n }\n // Set the axis-level tickInterval variable\n if (!minor) {\n axis.tickInterval = interval;\n }\n return positions;\n };\n Additions.prototype.lin2log = function (num) {\n return Math.pow(10, num);\n };\n Additions.prototype.log2lin = function (num) {\n return Math.log(num) / Math.LN10;\n };\n return Additions;\n }());\n LogarithmicAxis.Additions = Additions;\n })(LogarithmicAxis || (LogarithmicAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return LogarithmicAxis;\n });\n _registerModule(_modules, 'Core/Axis/PlotLineOrBand/PlotLineOrBandAxis.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var erase = U.erase,\n extend = U.extend,\n isNumber = U.isNumber;\n /* *\n *\n * Composition\n *\n * */\n var PlotLineOrBandAxis;\n (function (PlotLineOrBandAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Variables\n *\n * */\n var PlotLineOrBandClass;\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * @private\n */\n function compose(PlotLineOrBandType, AxisClass) {\n if (!PlotLineOrBandClass) {\n PlotLineOrBandClass = PlotLineOrBandType;\n }\n if (composedClasses.indexOf(AxisClass) === -1) {\n composedClasses.push(AxisClass);\n extend(AxisClass.prototype, Additions.prototype);\n }\n return AxisClass;\n }\n PlotLineOrBandAxis.compose = compose;\n /* *\n *\n * Classes\n *\n * */\n /**\n * Object with members for extending the Axis prototype.\n * @private\n */\n var Additions = /** @class */ (function () {\n function Additions() {\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Internal function to create the SVG path definition for a plot band.\n *\n * @function Highcharts.Axis#getPlotBandPath\n *\n * @param {number} from\n * The axis value to start from.\n *\n * @param {number} to\n * The axis value to end on.\n *\n * @param {Highcharts.AxisPlotBandsOptions|Highcharts.AxisPlotLinesOptions} options\n * The plotBand or plotLine configuration object.\n *\n * @return {Highcharts.SVGPathArray}\n * The SVG path definition in array form.\n */\n Additions.prototype.getPlotBandPath = function (from, to, options) {\n if (options === void 0) { options = this.options; }\n var toPath = this.getPlotLinePath({\n value: to,\n force: true,\n acrossPanes: options.acrossPanes\n }), result = [], horiz = this.horiz, outside = !isNumber(this.min) ||\n !isNumber(this.max) ||\n (from < this.min && to < this.min) ||\n (from > this.max && to > this.max);\n var path = this.getPlotLinePath({\n value: from,\n force: true,\n acrossPanes: options.acrossPanes\n }),\n i, \n // #4964 check if chart is inverted or plotband is on yAxis\n plus = 1,\n isFlat;\n if (path && toPath) {\n // Flat paths don't need labels (#3836)\n if (outside) {\n isFlat = path.toString() === toPath.toString();\n plus = 0;\n }\n // Go over each subpath - for panes in Highcharts Stock\n for (i = 0; i < path.length; i += 2) {\n var pathStart = path[i],\n pathEnd = path[i + 1],\n toPathStart = toPath[i],\n toPathEnd = toPath[i + 1];\n // Type checking all affected path segments. Consider\n // something smarter.\n if ((pathStart[0] === 'M' || pathStart[0] === 'L') &&\n (pathEnd[0] === 'M' || pathEnd[0] === 'L') &&\n (toPathStart[0] === 'M' || toPathStart[0] === 'L') &&\n (toPathEnd[0] === 'M' || toPathEnd[0] === 'L')) {\n // Add 1 pixel when coordinates are the same\n if (horiz && toPathStart[1] === pathStart[1]) {\n toPathStart[1] += plus;\n toPathEnd[1] += plus;\n }\n else if (!horiz && toPathStart[2] === pathStart[2]) {\n toPathStart[2] += plus;\n toPathEnd[2] += plus;\n }\n result.push(['M', pathStart[1], pathStart[2]], ['L', pathEnd[1], pathEnd[2]], ['L', toPathEnd[1], toPathEnd[2]], ['L', toPathStart[1], toPathStart[2]], ['Z']);\n }\n result.isFlat = isFlat;\n }\n }\n else { // outside the axis area\n path = null;\n }\n return result;\n };\n /**\n * Add a plot band after render time.\n *\n * @sample highcharts/members/axis-addplotband/\n * Toggle the plot band from a button\n *\n * @function Highcharts.Axis#addPlotBand\n *\n * @param {Highcharts.AxisPlotBandsOptions} options\n * A configuration object for the plot band, as defined in\n * [xAxis.plotBands](https://api.highcharts.com/highcharts/xAxis.plotBands).\n *\n * @return {Highcharts.PlotLineOrBand|undefined}\n * The added plot band.\n */\n Additions.prototype.addPlotBand = function (options) {\n return this.addPlotBandOrLine(options, 'plotBands');\n };\n /**\n * Add a plot line after render time.\n *\n * @sample highcharts/members/axis-addplotline/\n * Toggle the plot line from a button\n *\n * @function Highcharts.Axis#addPlotLine\n *\n * @param {Highcharts.AxisPlotLinesOptions} options\n * A configuration object for the plot line, as defined in\n * [xAxis.plotLines](https://api.highcharts.com/highcharts/xAxis.plotLines).\n *\n * @return {Highcharts.PlotLineOrBand|undefined}\n * The added plot line.\n */\n Additions.prototype.addPlotLine = function (options) {\n return this.addPlotBandOrLine(options, 'plotLines');\n };\n /**\n * Add a plot band or plot line after render time. Called from\n * addPlotBand and addPlotLine internally.\n *\n * @private\n * @function Highcharts.Axis#addPlotBandOrLine\n * @param {Highcharts.AxisPlotBandsOptions|Highcharts.AxisPlotLinesOptions} options\n * The plotBand or plotLine configuration object.\n */\n Additions.prototype.addPlotBandOrLine = function (options, coll) {\n var _this = this;\n var userOptions = this.userOptions;\n var obj = new PlotLineOrBandClass(this,\n options);\n if (this.visible) {\n obj = obj.render();\n }\n if (obj) { // #2189\n if (!this._addedPlotLB) {\n this._addedPlotLB = true;\n (userOptions.plotLines || [])\n .concat(userOptions.plotBands || [])\n .forEach(function (plotLineOptions) {\n _this.addPlotBandOrLine(plotLineOptions);\n });\n }\n // Add it to the user options for exporting and Axis.update\n if (coll) {\n // Workaround Microsoft/TypeScript issue #32693\n var updatedOptions = (userOptions[coll] || []);\n updatedOptions.push(options);\n userOptions[coll] = updatedOptions;\n }\n this.plotLinesAndBands.push(obj);\n }\n return obj;\n };\n /**\n * Remove a plot band or plot line from the chart by id. Called\n * internally from `removePlotBand` and `removePlotLine`.\n * @private\n * @function Highcharts.Axis#removePlotBandOrLine\n */\n Additions.prototype.removePlotBandOrLine = function (id) {\n var plotLinesAndBands = this.plotLinesAndBands,\n options = this.options,\n userOptions = this.userOptions;\n if (plotLinesAndBands) { // #15639\n var i_1 = plotLinesAndBands.length;\n while (i_1--) {\n if (plotLinesAndBands[i_1].id === id) {\n plotLinesAndBands[i_1].destroy();\n }\n }\n ([\n options.plotLines || [],\n userOptions.plotLines || [],\n options.plotBands || [],\n userOptions.plotBands || []\n ]).forEach(function (arr) {\n i_1 = arr.length;\n while (i_1--) {\n if ((arr[i_1] || {}).id === id) {\n erase(arr, arr[i_1]);\n }\n }\n });\n }\n };\n /**\n * Remove a plot band by its id.\n *\n * @sample highcharts/members/axis-removeplotband/\n * Remove plot band by id\n * @sample highcharts/members/axis-addplotband/\n * Toggle the plot band from a button\n *\n * @function Highcharts.Axis#removePlotBand\n *\n * @param {string} id\n * The plot band's `id` as given in the original configuration\n * object or in the `addPlotBand` option.\n */\n Additions.prototype.removePlotBand = function (id) {\n this.removePlotBandOrLine(id);\n };\n /**\n * Remove a plot line by its id.\n *\n * @sample highcharts/xaxis/plotlines-id/\n * Remove plot line by id\n * @sample highcharts/members/axis-addplotline/\n * Toggle the plot line from a button\n *\n * @function Highcharts.Axis#removePlotLine\n *\n * @param {string} id\n * The plot line's `id` as given in the original configuration\n * object or in the `addPlotLine` option.\n */\n Additions.prototype.removePlotLine = function (id) {\n this.removePlotBandOrLine(id);\n };\n return Additions;\n }());\n })(PlotLineOrBandAxis || (PlotLineOrBandAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return PlotLineOrBandAxis;\n });\n _registerModule(_modules, 'Core/Axis/PlotLineOrBand/PlotLineOrBand.js', [_modules['Core/Axis/PlotLineOrBand/PlotLineOrBandAxis.js'], _modules['Core/Utilities.js']], function (PlotLineOrBandAxis, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var arrayMax = U.arrayMax,\n arrayMin = U.arrayMin,\n defined = U.defined,\n destroyObjectProperties = U.destroyObjectProperties,\n erase = U.erase,\n fireEvent = U.fireEvent,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick;\n /* *\n *\n * Class\n *\n * */\n /**\n * The object wrapper for plot lines and plot bands\n *\n * @class\n * @name Highcharts.PlotLineOrBand\n *\n * @param {Highcharts.Axis} axis\n * Related axis.\n *\n * @param {Highcharts.AxisPlotLinesOptions|Highcharts.AxisPlotBandsOptions} [options]\n * Options to use.\n */\n var PlotLineOrBand = /** @class */ (function () {\n /* *\n *\n * Constructor\n *\n * */\n function PlotLineOrBand(axis, options) {\n this.axis = axis;\n if (options) {\n this.options = options;\n this.id = options.id;\n }\n }\n /* *\n *\n * Static Functions\n *\n * */\n PlotLineOrBand.compose = function (AxisClass) {\n return PlotLineOrBandAxis.compose(PlotLineOrBand, AxisClass);\n };\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Render the plot line or plot band. If it is already existing,\n * move it.\n * @private\n * @function Highcharts.PlotLineOrBand#render\n */\n PlotLineOrBand.prototype.render = function () {\n fireEvent(this, 'render');\n var plotLine = this,\n axis = plotLine.axis,\n horiz = axis.horiz,\n log = axis.logarithmic,\n options = plotLine.options,\n color = options.color,\n zIndex = pick(options.zIndex, 0),\n events = options.events,\n groupAttribs = {},\n renderer = axis.chart.renderer;\n var optionsLabel = options.label,\n label = plotLine.label,\n to = options.to,\n from = options.from,\n value = options.value,\n svgElem = plotLine.svgElem,\n path = [],\n group;\n var isBand = defined(from) && defined(to),\n isLine = defined(value),\n isNew = !svgElem,\n attribs = {\n 'class': 'highcharts-plot-' + (isBand ? 'band ' : 'line ') +\n (options.className || '')\n };\n var groupName = isBand ? 'bands' : 'lines';\n // logarithmic conversion\n if (log) {\n from = log.log2lin(from);\n to = log.log2lin(to);\n value = log.log2lin(value);\n }\n // Set the presentational attributes\n if (!axis.chart.styledMode) {\n if (isLine) {\n attribs.stroke = color || \"#999999\" /* Palette.neutralColor40 */;\n attribs['stroke-width'] = pick(options.width, 1);\n if (options.dashStyle) {\n attribs.dashstyle =\n options.dashStyle;\n }\n }\n else if (isBand) { // plot band\n attribs.fill = color || \"#e6ebf5\" /* Palette.highlightColor10 */;\n if (options.borderWidth) {\n attribs.stroke = options.borderColor;\n attribs['stroke-width'] = options.borderWidth;\n }\n }\n }\n // Grouping and zIndex\n groupAttribs.zIndex = zIndex;\n groupName += '-' + zIndex;\n group = axis.plotLinesAndBandsGroups[groupName];\n if (!group) {\n axis.plotLinesAndBandsGroups[groupName] = group =\n renderer.g('plot-' + groupName)\n .attr(groupAttribs).add();\n }\n // Create the path\n if (isNew) {\n /**\n * SVG element of the plot line or band.\n *\n * @name Highcharts.PlotLineOrBand#svgElem\n * @type {Highcharts.SVGElement}\n */\n plotLine.svgElem = svgElem = renderer\n .path()\n .attr(attribs)\n .add(group);\n }\n // Set the path or return\n if (isLine) {\n path = axis.getPlotLinePath({\n value: value,\n lineWidth: svgElem.strokeWidth(),\n acrossPanes: options.acrossPanes\n });\n }\n else if (isBand) { // plot band\n path = axis.getPlotBandPath(from, to, options);\n }\n else {\n return;\n }\n // common for lines and bands\n // Add events only if they were not added before.\n if (!plotLine.eventsAdded && events) {\n objectEach(events, function (event, eventType) {\n svgElem.on(eventType, function (e) {\n events[eventType].apply(plotLine, [e]);\n });\n });\n plotLine.eventsAdded = true;\n }\n if ((isNew || !svgElem.d) && path && path.length) {\n svgElem.attr({ d: path });\n }\n else if (svgElem) {\n if (path) {\n svgElem.show();\n svgElem.animate({ d: path });\n }\n else if (svgElem.d) {\n svgElem.hide();\n if (label) {\n plotLine.label = label = label.destroy();\n }\n }\n }\n // the plot band/line label\n if (optionsLabel &&\n (defined(optionsLabel.text) || defined(optionsLabel.formatter)) &&\n path &&\n path.length &&\n axis.width > 0 &&\n axis.height > 0 &&\n !path.isFlat) {\n // apply defaults\n optionsLabel = merge({\n align: horiz && isBand && 'center',\n x: horiz ? !isBand && 4 : 10,\n verticalAlign: !horiz && isBand && 'middle',\n y: horiz ? isBand ? 16 : 10 : isBand ? 6 : -4,\n rotation: horiz && !isBand && 90\n }, optionsLabel);\n this.renderLabel(optionsLabel, path, isBand, zIndex);\n }\n else if (label) { // move out of sight\n label.hide();\n }\n // chainable\n return plotLine;\n };\n /**\n * Render and align label for plot line or band.\n * @private\n * @function Highcharts.PlotLineOrBand#renderLabel\n */\n PlotLineOrBand.prototype.renderLabel = function (optionsLabel, path, isBand, zIndex) {\n var plotLine = this,\n axis = plotLine.axis,\n renderer = axis.chart.renderer;\n var label = plotLine.label;\n // add the SVG element\n if (!label) {\n /**\n * SVG element of the label.\n *\n * @name Highcharts.PlotLineOrBand#label\n * @type {Highcharts.SVGElement}\n */\n plotLine.label = label = renderer\n .text(this.getLabelText(optionsLabel), 0, 0, optionsLabel.useHTML)\n .attr({\n align: optionsLabel.textAlign || optionsLabel.align,\n rotation: optionsLabel.rotation,\n 'class': 'highcharts-plot-' + (isBand ? 'band' : 'line') +\n '-label ' + (optionsLabel.className || ''),\n zIndex: zIndex\n })\n .add();\n if (!axis.chart.styledMode) {\n label.css(merge({\n textOverflow: 'ellipsis'\n }, optionsLabel.style));\n }\n }\n // get the bounding box and align the label\n // #3000 changed to better handle choice between plotband or plotline\n var xBounds = path.xBounds ||\n [path[0][1],\n path[1][1], (isBand ? path[2][1] : path[0][1])];\n var yBounds = path.yBounds ||\n [path[0][2],\n path[1][2], (isBand ? path[2][2] : path[0][2])];\n var x = arrayMin(xBounds);\n var y = arrayMin(yBounds);\n label.align(optionsLabel, false, {\n x: x,\n y: y,\n width: arrayMax(xBounds) - x,\n height: arrayMax(yBounds) - y\n });\n if (!label.alignValue || label.alignValue === 'left') {\n label.css({\n width: (label.rotation === 90 ?\n axis.height - (label.alignAttr.y - axis.top) :\n axis.width - (label.alignAttr.x - axis.left)) + 'px'\n });\n }\n label.show(true);\n };\n /**\n * Get label's text content.\n * @private\n * @function Highcharts.PlotLineOrBand#getLabelText\n */\n PlotLineOrBand.prototype.getLabelText = function (optionsLabel) {\n return defined(optionsLabel.formatter) ?\n optionsLabel.formatter\n .call(this) :\n optionsLabel.text;\n };\n /**\n * Remove the plot line or band.\n *\n * @function Highcharts.PlotLineOrBand#destroy\n */\n PlotLineOrBand.prototype.destroy = function () {\n // remove it from the lookup\n erase(this.axis.plotLinesAndBands, this);\n delete this.axis;\n destroyObjectProperties(this);\n };\n return PlotLineOrBand;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Options for plot bands on axes.\n *\n * @typedef {Highcharts.XAxisPlotBandsOptions|Highcharts.YAxisPlotBandsOptions|Highcharts.ZAxisPlotBandsOptions} Highcharts.AxisPlotBandsOptions\n */\n /**\n * Options for plot band labels on axes.\n *\n * @typedef {Highcharts.XAxisPlotBandsLabelOptions|Highcharts.YAxisPlotBandsLabelOptions|Highcharts.ZAxisPlotBandsLabelOptions} Highcharts.AxisPlotBandsLabelOptions\n */\n /**\n * Options for plot lines on axes.\n *\n * @typedef {Highcharts.XAxisPlotLinesOptions|Highcharts.YAxisPlotLinesOptions|Highcharts.ZAxisPlotLinesOptions} Highcharts.AxisPlotLinesOptions\n */\n /**\n * Options for plot line labels on axes.\n *\n * @typedef {Highcharts.XAxisPlotLinesLabelOptions|Highcharts.YAxisPlotLinesLabelOptions|Highcharts.ZAxisPlotLinesLabelOptions} Highcharts.AxisPlotLinesLabelOptions\n */\n ('');\n /* *\n *\n * API Options\n *\n * */\n /**\n * An array of colored bands stretching across the plot area marking an\n * interval on the axis.\n *\n * In styled mode, the plot bands are styled by the `.highcharts-plot-band`\n * class in addition to the `className` option.\n *\n * @productdesc {highcharts}\n * In a gauge, a plot band on the Y axis (value axis) will stretch along the\n * perimeter of the gauge.\n *\n * @type {Array<*>}\n * @product highcharts highstock gantt\n * @apioption xAxis.plotBands\n */\n /**\n * Flag to decide if plotBand should be rendered across all panes.\n *\n * @since 7.1.2\n * @product highstock\n * @type {boolean}\n * @default true\n * @apioption xAxis.plotBands.acrossPanes\n */\n /**\n * Border color for the plot band. Also requires `borderWidth` to be set.\n *\n * @type {Highcharts.ColorString}\n * @apioption xAxis.plotBands.borderColor\n */\n /**\n * Border width for the plot band. Also requires `borderColor` to be set.\n *\n * @type {number}\n * @default 0\n * @apioption xAxis.plotBands.borderWidth\n */\n /**\n * A custom class name, in addition to the default `highcharts-plot-band`,\n * to apply to each individual band.\n *\n * @type {string}\n * @since 5.0.0\n * @apioption xAxis.plotBands.className\n */\n /**\n * The color of the plot band.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-color/\n * Color band\n * @sample {highstock} stock/xaxis/plotbands/\n * Plot band on Y axis\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #e6ebf5\n * @apioption xAxis.plotBands.color\n */\n /**\n * An object defining mouse events for the plot band. Supported properties\n * are `click`, `mouseover`, `mouseout`, `mousemove`.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-events/\n * Mouse events demonstrated\n *\n * @since 1.2\n * @apioption xAxis.plotBands.events\n */\n /**\n * Click event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotBands.events.click\n */\n /**\n * Mouse move event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotBands.events.mousemove\n */\n /**\n * Mouse out event on the corner of a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotBands.events.mouseout\n */\n /**\n * Mouse over event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotBands.events.mouseover\n */\n /**\n * The start position of the plot band in axis units.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-color/\n * Datetime axis\n * @sample {highcharts} highcharts/xaxis/plotbands-from/\n * Categorized axis\n * @sample {highstock} stock/xaxis/plotbands/\n * Plot band on Y axis\n *\n * @type {number}\n * @apioption xAxis.plotBands.from\n */\n /**\n * An id used for identifying the plot band in Axis.removePlotBand.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-id/\n * Remove plot band by id\n * @sample {highstock} highcharts/xaxis/plotbands-id/\n * Remove plot band by id\n *\n * @type {string}\n * @apioption xAxis.plotBands.id\n */\n /**\n * The end position of the plot band in axis units.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-color/\n * Datetime axis\n * @sample {highcharts} highcharts/xaxis/plotbands-from/\n * Categorized axis\n * @sample {highstock} stock/xaxis/plotbands/\n * Plot band on Y axis\n *\n * @type {number}\n * @apioption xAxis.plotBands.to\n */\n /**\n * The z index of the plot band within the chart, relative to other\n * elements. Using the same z index as another element may give\n * unpredictable results, as the last rendered element will be on top.\n * Values from 0 to 20 make sense.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-color/\n * Behind plot lines by default\n * @sample {highcharts} highcharts/xaxis/plotbands-zindex/\n * Above plot lines\n * @sample {highcharts} highcharts/xaxis/plotbands-zindex-above-series/\n * Above plot lines and series\n *\n * @type {number}\n * @since 1.2\n * @apioption xAxis.plotBands.zIndex\n */\n /**\n * Text labels for the plot bands\n *\n * @product highcharts highstock gantt\n * @apioption xAxis.plotBands.label\n */\n /**\n * Horizontal alignment of the label. Can be one of \"left\", \"center\" or\n * \"right\".\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-align/\n * Aligned to the right\n * @sample {highstock} stock/xaxis/plotbands-label/\n * Plot band with labels\n *\n * @type {Highcharts.AlignValue}\n * @default center\n * @since 2.1\n * @apioption xAxis.plotBands.label.align\n */\n /**\n * Rotation of the text label in degrees .\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-rotation/\n * Vertical text\n *\n * @type {number}\n * @default 0\n * @since 2.1\n * @apioption xAxis.plotBands.label.rotation\n */\n /**\n * CSS styles for the text label.\n *\n * In styled mode, the labels are styled by the\n * `.highcharts-plot-band-label` class.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-style/\n * Blue and bold label\n *\n * @type {Highcharts.CSSObject}\n * @since 2.1\n * @apioption xAxis.plotBands.label.style\n */\n /**\n * The string text itself. A subset of HTML is supported.\n *\n * @type {string}\n * @since 2.1\n * @apioption xAxis.plotBands.label.text\n */\n /**\n * The text alignment for the label. While `align` determines where the\n * texts anchor point is placed within the plot band, `textAlign` determines\n * how the text is aligned against its anchor point. Possible values are\n * \"left\", \"center\" and \"right\". Defaults to the same as the `align` option.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-rotation/\n * Vertical text in center position but text-aligned left\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1\n * @apioption xAxis.plotBands.label.textAlign\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n *\n * @type {boolean}\n * @default false\n * @since 3.0.3\n * @apioption xAxis.plotBands.label.useHTML\n */\n /**\n * Vertical alignment of the label relative to the plot band. Can be one of\n * \"top\", \"middle\" or \"bottom\".\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-verticalalign/\n * Vertically centered label\n * @sample {highstock} stock/xaxis/plotbands-label/\n * Plot band with labels\n *\n * @type {Highcharts.VerticalAlignValue}\n * @default top\n * @since 2.1\n * @apioption xAxis.plotBands.label.verticalAlign\n */\n /**\n * Horizontal position relative the alignment. Default varies by\n * orientation.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-align/\n * Aligned 10px from the right edge\n * @sample {highstock} stock/xaxis/plotbands-label/\n * Plot band with labels\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotBands.label.x\n */\n /**\n * Vertical position of the text baseline relative to the alignment. Default\n * varies by orientation.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-y/\n * Label on x axis\n * @sample {highstock} stock/xaxis/plotbands-label/\n * Plot band with labels\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotBands.label.y\n */\n /**\n * An array of lines stretching across the plot area, marking a specific\n * value on one of the axes.\n *\n * In styled mode, the plot lines are styled by the\n * `.highcharts-plot-line` class in addition to the `className` option.\n *\n * @type {Array<*>}\n * @product highcharts highstock gantt\n * @sample {highcharts} highcharts/xaxis/plotlines-color/\n * Basic plot line\n * @sample {highcharts} highcharts/series-solidgauge/labels-auto-aligned/\n * Solid gauge plot line\n * @apioption xAxis.plotLines\n */\n /**\n * Flag to decide if plotLine should be rendered across all panes.\n *\n * @sample {highstock} stock/xaxis/plotlines-acrosspanes/\n * Plot lines on different panes\n *\n * @since 7.1.2\n * @product highstock\n * @type {boolean}\n * @default true\n * @apioption xAxis.plotLines.acrossPanes\n */\n /**\n * A custom class name, in addition to the default `highcharts-plot-line`,\n * to apply to each individual line.\n *\n * @type {string}\n * @since 5.0.0\n * @apioption xAxis.plotLines.className\n */\n /**\n * The color of the line.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-color/\n * A red line from X axis\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {Highcharts.ColorString}\n * @default #999999\n * @apioption xAxis.plotLines.color\n */\n /**\n * The dashing or dot style for the plot line. For possible values see\n * [this overview](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-dashstyle-all/).\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-dashstyle/\n * Dash and dot pattern\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {Highcharts.DashStyleValue}\n * @default Solid\n * @since 1.2\n * @apioption xAxis.plotLines.dashStyle\n */\n /**\n * An object defining mouse events for the plot line. Supported\n * properties are `click`, `mouseover`, `mouseout`, `mousemove`.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-events/\n * Mouse events demonstrated\n *\n * @since 1.2\n * @apioption xAxis.plotLines.events\n */\n /**\n * Click event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotLines.events.click\n */\n /**\n * Mouse move event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotLines.events.mousemove\n */\n /**\n * Mouse out event on the corner of a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotLines.events.mouseout\n */\n /**\n * Mouse over event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotLines.events.mouseover\n */\n /**\n * An id used for identifying the plot line in Axis.removePlotLine.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-id/\n * Remove plot line by id\n *\n * @type {string}\n * @apioption xAxis.plotLines.id\n */\n /**\n * The position of the line in axis units.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-color/\n * Between two categories on X axis\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {number}\n * @apioption xAxis.plotLines.value\n */\n /**\n * The width or thickness of the plot line.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-color/\n * 2px wide line from X axis\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {number}\n * @default 2\n * @apioption xAxis.plotLines.width\n */\n /**\n * The z index of the plot line within the chart.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-zindex-behind/\n * Behind plot lines by default\n * @sample {highcharts} highcharts/xaxis/plotlines-zindex-above/\n * Above plot lines\n * @sample {highcharts} highcharts/xaxis/plotlines-zindex-above-all/\n * Above plot lines and series\n *\n * @type {number}\n * @since 1.2\n * @apioption xAxis.plotLines.zIndex\n */\n /**\n * Text labels for the plot bands\n *\n * @apioption xAxis.plotLines.label\n */\n /**\n * Horizontal alignment of the label. Can be one of \"left\", \"center\" or\n * \"right\".\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-align-right/\n * Aligned to the right\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {Highcharts.AlignValue}\n * @default left\n * @since 2.1\n * @apioption xAxis.plotLines.label.align\n */\n /**\n * Callback JavaScript function to format the label. Useful properties like\n * the value of plot line or the range of plot band (`from` & `to`\n * properties) can be found in `this.options` object.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-plotbands-label-formatter\n * Label formatters for plot line and plot band.\n * @type {Highcharts.FormatterCallbackFunction}\n * @apioption xAxis.plotLines.label.formatter\n */\n /**\n * Rotation of the text label in degrees. Defaults to 0 for horizontal plot\n * lines and 90 for vertical lines.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-verticalalign-middle/\n * Slanted text\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotLines.label.rotation\n */\n /**\n * CSS styles for the text label.\n *\n * In styled mode, the labels are styled by the\n * `.highcharts-plot-line-label` class.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-style/\n * Blue and bold label\n *\n * @type {Highcharts.CSSObject}\n * @since 2.1\n * @apioption xAxis.plotLines.label.style\n */\n /**\n * The text itself. A subset of HTML is supported.\n *\n * @type {string}\n * @since 2.1\n * @apioption xAxis.plotLines.label.text\n */\n /**\n * The text alignment for the label. While `align` determines where the\n * texts anchor point is placed within the plot band, `textAlign` determines\n * how the text is aligned against its anchor point. Possible values are\n * \"left\", \"center\" and \"right\". Defaults to the same as the `align` option.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-textalign/\n * Text label in bottom position\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1\n * @apioption xAxis.plotLines.label.textAlign\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n *\n * @type {boolean}\n * @default false\n * @since 3.0.3\n * @apioption xAxis.plotLines.label.useHTML\n */\n /**\n * Vertical alignment of the label relative to the plot line. Can be\n * one of \"top\", \"middle\" or \"bottom\".\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-verticalalign-middle/\n * Vertically centered label\n *\n * @type {Highcharts.VerticalAlignValue}\n * @default {highcharts} top\n * @default {highstock} top\n * @since 2.1\n * @apioption xAxis.plotLines.label.verticalAlign\n */\n /**\n * Horizontal position relative the alignment. Default varies by\n * orientation.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-align-right/\n * Aligned 10px from the right edge\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotLines.label.x\n */\n /**\n * Vertical position of the text baseline relative to the alignment. Default\n * varies by orientation.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-y/\n * Label below the plot line\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotLines.label.y\n */\n /**\n * @type {Array<*>}\n * @extends xAxis.plotBands\n * @apioption yAxis.plotBands\n */\n /**\n * In a gauge chart, this option determines the inner radius of the\n * plot band that stretches along the perimeter. It can be given as\n * a percentage string, like `\"100%\"`, or as a pixel number, like `100`.\n * By default, the inner radius is controlled by the [thickness](\n * #yAxis.plotBands.thickness) option.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-gauge\n * Gauge plot band\n *\n * @type {number|string}\n * @since 2.3\n * @product highcharts\n * @apioption yAxis.plotBands.innerRadius\n */\n /**\n * In a gauge chart, this option determines the outer radius of the\n * plot band that stretches along the perimeter. It can be given as\n * a percentage string, like `\"100%\"`, or as a pixel number, like `100`.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-gauge\n * Gauge plot band\n *\n * @type {number|string}\n * @default 100%\n * @since 2.3\n * @product highcharts\n * @apioption yAxis.plotBands.outerRadius\n */\n /**\n * In a gauge chart, this option sets the width of the plot band\n * stretching along the perimeter. It can be given as a percentage\n * string, like `\"10%\"`, or as a pixel number, like `10`. The default\n * value 10 is the same as the default [tickLength](#yAxis.tickLength),\n * thus making the plot band act as a background for the tick markers.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-gauge\n * Gauge plot band\n *\n * @type {number|string}\n * @default 10\n * @since 2.3\n * @product highcharts\n * @apioption yAxis.plotBands.thickness\n */\n /**\n * @type {Array<*>}\n * @extends xAxis.plotLines\n * @apioption yAxis.plotLines\n */\n (''); // keeps doclets above in JS file\n\n return PlotLineOrBand;\n });\n _registerModule(_modules, 'Core/Tooltip.js', [_modules['Core/FormatUtilities.js'], _modules['Core/Globals.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Utilities.js']], function (F, H, R, RendererRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var format = F.format;\n var doc = H.doc;\n var distribute = R.distribute;\n var addEvent = U.addEvent,\n clamp = U.clamp,\n css = U.css,\n defined = U.defined,\n discardElement = U.discardElement,\n extend = U.extend,\n fireEvent = U.fireEvent,\n isArray = U.isArray,\n isNumber = U.isNumber,\n isString = U.isString,\n merge = U.merge,\n pick = U.pick,\n splat = U.splat,\n syncTimeout = U.syncTimeout;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Tooltip of a chart.\n *\n * @class\n * @name Highcharts.Tooltip\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.TooltipOptions} options\n * Tooltip options.\n */\n var Tooltip = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Tooltip(chart, options) {\n /* *\n *\n * Properties\n *\n * */\n this.allowShared = true;\n this.container = void 0;\n this.crosshairs = [];\n this.distance = 0;\n this.isHidden = true;\n this.isSticky = false;\n this.now = {};\n this.options = {};\n this.outside = false;\n this.chart = chart;\n this.init(chart, options);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * In styled mode, apply the default filter for the tooltip drop-shadow. It\n * needs to have an id specific to the chart, otherwise there will be issues\n * when one tooltip adopts the filter of a different chart, specifically one\n * where the container is hidden.\n *\n * @private\n * @function Highcharts.Tooltip#applyFilter\n */\n Tooltip.prototype.applyFilter = function () {\n var chart = this.chart;\n chart.renderer.definition({\n tagName: 'filter',\n attributes: {\n id: 'drop-shadow-' + chart.index,\n opacity: 0.5\n },\n children: [{\n tagName: 'feGaussianBlur',\n attributes: {\n 'in': 'SourceAlpha',\n stdDeviation: 1\n }\n }, {\n tagName: 'feOffset',\n attributes: {\n dx: 1,\n dy: 1\n }\n }, {\n tagName: 'feComponentTransfer',\n children: [{\n tagName: 'feFuncA',\n attributes: {\n type: 'linear',\n slope: 0.3\n }\n }]\n }, {\n tagName: 'feMerge',\n children: [{\n tagName: 'feMergeNode'\n }, {\n tagName: 'feMergeNode',\n attributes: {\n 'in': 'SourceGraphic'\n }\n }]\n }]\n });\n };\n /**\n * Build the body (lines) of the tooltip by iterating over the items and\n * returning one entry for each item, abstracting this functionality allows\n * to easily overwrite and extend it.\n *\n * @private\n * @function Highcharts.Tooltip#bodyFormatter\n */\n Tooltip.prototype.bodyFormatter = function (items) {\n return items.map(function (item) {\n var tooltipOptions = item.series.tooltipOptions;\n return (tooltipOptions[(item.point.formatPrefix || 'point') + 'Formatter'] ||\n item.point.tooltipFormatter).call(item.point, tooltipOptions[(item.point.formatPrefix || 'point') + 'Format'] || '');\n });\n };\n /**\n * Destroy the single tooltips in a split tooltip.\n * If the tooltip is active then it is not destroyed, unless forced to.\n *\n * @private\n * @function Highcharts.Tooltip#cleanSplit\n *\n * @param {boolean} [force]\n * Force destroy all tooltips.\n */\n Tooltip.prototype.cleanSplit = function (force) {\n this.chart.series.forEach(function (series) {\n var tt = series && series.tt;\n if (tt) {\n if (!tt.isActive || force) {\n series.tt = tt.destroy();\n }\n else {\n tt.isActive = false;\n }\n }\n });\n };\n /**\n * In case no user defined formatter is given, this will be used. Note that\n * the context here is an object holding point, series, x, y etc.\n *\n * @function Highcharts.Tooltip#defaultFormatter\n *\n * @param {Highcharts.Tooltip} tooltip\n *\n * @return {string|Array}\n * Returns a string (single tooltip and shared)\n * or an array of strings (split tooltip)\n */\n Tooltip.prototype.defaultFormatter = function (tooltip) {\n var items = this.points || splat(this);\n var s;\n // Build the header\n s = [tooltip.tooltipFooterHeaderFormatter(items[0])];\n // build the values\n s = s.concat(tooltip.bodyFormatter(items));\n // footer\n s.push(tooltip.tooltipFooterHeaderFormatter(items[0], true));\n return s;\n };\n /**\n * Removes and destroys the tooltip and its elements.\n *\n * @function Highcharts.Tooltip#destroy\n */\n Tooltip.prototype.destroy = function () {\n // Destroy and clear local variables\n if (this.label) {\n this.label = this.label.destroy();\n }\n if (this.split && this.tt) {\n this.cleanSplit(true);\n this.tt = this.tt.destroy();\n }\n if (this.renderer) {\n this.renderer = this.renderer.destroy();\n discardElement(this.container);\n }\n U.clearTimeout(this.hideTimer);\n U.clearTimeout(this.tooltipTimeout);\n };\n /**\n * Extendable method to get the anchor position of the tooltip\n * from a point or set of points\n *\n * @private\n * @function Highcharts.Tooltip#getAnchor\n */\n Tooltip.prototype.getAnchor = function (points, mouseEvent) {\n var chart = this.chart,\n pointer = chart.pointer,\n inverted = chart.inverted,\n plotTop = chart.plotTop,\n plotLeft = chart.plotLeft;\n var ret,\n yAxis,\n xAxis,\n plotX = 0,\n plotY = 0;\n points = splat(points);\n // When tooltip follows mouse, relate the position to the mouse\n if (this.followPointer && mouseEvent) {\n if (typeof mouseEvent.chartX === 'undefined') {\n mouseEvent = pointer.normalize(mouseEvent);\n }\n ret = [\n mouseEvent.chartX - plotLeft,\n mouseEvent.chartY - plotTop\n ];\n // Some series types use a specificly calculated tooltip position for\n // each point\n }\n else if (points[0].tooltipPos) {\n ret = points[0].tooltipPos;\n // Calculate the average position and adjust for axis positions\n }\n else {\n points.forEach(function (point) {\n yAxis = point.series.yAxis;\n xAxis = point.series.xAxis;\n plotX += point.plotX || 0;\n plotY += (point.plotLow ?\n (point.plotLow + (point.plotHigh || 0)) / 2 :\n (point.plotY || 0));\n // Adjust position for positioned axes (top/left settings)\n if (xAxis && yAxis) {\n if (!inverted) { // #1151\n plotX += xAxis.pos - plotLeft;\n plotY += yAxis.pos - plotTop;\n }\n else { // #14771\n plotX += (plotTop + chart.plotHeight - xAxis.len - xAxis.pos);\n plotY += (plotLeft + chart.plotWidth - yAxis.len - yAxis.pos);\n }\n }\n });\n plotX /= points.length;\n plotY /= points.length;\n // Use the average position for multiple points\n ret = [\n inverted ? chart.plotWidth - plotY : plotX,\n inverted ? chart.plotHeight - plotX : plotY\n ];\n // When shared, place the tooltip next to the mouse (#424)\n if (this.shared && points.length > 1 && mouseEvent) {\n if (inverted) {\n ret[0] = mouseEvent.chartX - plotLeft;\n }\n else {\n ret[1] = mouseEvent.chartY - plotTop;\n }\n }\n }\n return ret.map(Math.round);\n };\n /**\n * Creates the Tooltip label element if it does not exist, then returns it.\n *\n * @function Highcharts.Tooltip#getLabel\n *\n * @return {Highcharts.SVGElement}\n * Tooltip label\n */\n Tooltip.prototype.getLabel = function () {\n var tooltip = this,\n styledMode = this.chart.styledMode,\n options = this.options,\n doSplit = this.split && this.allowShared,\n className = ('tooltip' + (defined(options.className) ?\n ' ' + options.className :\n '')),\n pointerEvents = (options.style.pointerEvents ||\n (this.shouldStickOnContact() ? 'auto' : 'none'));\n var container,\n renderer = this.chart.renderer;\n // If changing from a split tooltip to a non-split tooltip, we must\n // destroy it in order to get the SVG right. #13868.\n if (tooltip.label) {\n var wasSplit = !tooltip.label.hasClass('highcharts-label');\n if ((doSplit && !wasSplit) || (!doSplit && wasSplit)) {\n tooltip.destroy();\n }\n }\n if (!this.label) {\n if (this.outside) {\n var chartStyle = this.chart.options.chart.style,\n Renderer = RendererRegistry.getRendererType();\n /**\n * Reference to the tooltip's container, when\n * [Highcharts.Tooltip#outside] is set to true, otherwise\n * it's undefined.\n *\n * @name Highcharts.Tooltip#container\n * @type {Highcharts.HTMLDOMElement|undefined}\n */\n this.container = container = H.doc.createElement('div');\n container.className = 'highcharts-tooltip-container';\n css(container, {\n position: 'absolute',\n top: '1px',\n pointerEvents: pointerEvents,\n zIndex: Math.max(this.options.style.zIndex || 0, (chartStyle && chartStyle.zIndex || 0) + 3)\n });\n H.doc.body.appendChild(container);\n /**\n * Reference to the tooltip's renderer, when\n * [Highcharts.Tooltip#outside] is set to true, otherwise\n * it's undefined.\n *\n * @name Highcharts.Tooltip#renderer\n * @type {Highcharts.SVGRenderer|undefined}\n */\n this.renderer = renderer = new Renderer(container, 0, 0, chartStyle, void 0, void 0, renderer.styledMode);\n }\n // Create the label\n if (doSplit) {\n this.label = renderer.g(className);\n }\n else {\n this.label = renderer\n .label('', 0, 0, options.shape, void 0, void 0, options.useHTML, void 0, className)\n .attr({\n padding: options.padding,\n r: options.borderRadius\n });\n if (!styledMode) {\n this.label\n .attr({\n fill: options.backgroundColor,\n 'stroke-width': options.borderWidth\n })\n // #2301, #2657\n .css(options.style)\n .css({ pointerEvents: pointerEvents })\n .shadow(options.shadow);\n }\n }\n if (styledMode && options.shadow) {\n // Apply the drop-shadow filter\n this.applyFilter();\n this.label.attr({\n filter: 'url(#drop-shadow-' + this.chart.index + ')'\n });\n }\n // Split tooltip use updateTooltipContainer to position the tooltip\n // container.\n if (tooltip.outside && !tooltip.split) {\n var label_1 = this.label;\n var xSetter_1 = label_1.xSetter,\n ySetter_1 = label_1.ySetter;\n label_1.xSetter = function (value) {\n xSetter_1.call(label_1, tooltip.distance);\n container.style.left = value + 'px';\n };\n label_1.ySetter = function (value) {\n ySetter_1.call(label_1, tooltip.distance);\n container.style.top = value + 'px';\n };\n }\n this.label\n .attr({ zIndex: 8 })\n .add();\n }\n return this.label;\n };\n /**\n * Place the tooltip in a chart without spilling over and not covering the\n * point itself.\n *\n * @function Highcharts.Tooltip#getPosition\n *\n * @param {number} boxWidth\n * Width of the tooltip box.\n *\n * @param {number} boxHeight\n * Height of the tooltip box.\n *\n * @param {Highcharts.Point} point\n * Tooltip related point.\n *\n * @return {Highcharts.PositionObject}\n * Recommended position of the tooltip.\n */\n Tooltip.prototype.getPosition = function (boxWidth, boxHeight, point) {\n var chart = this.chart,\n distance = this.distance,\n ret = {}, \n // Don't use h if chart isn't inverted (#7242) ???\n h = (chart.inverted && point.h) || 0, // #4117 ???\n outside = this.outside,\n outerWidth = outside ?\n // substract distance to prevent scrollbars\n doc.documentElement.clientWidth - 2 * distance :\n chart.chartWidth,\n outerHeight = outside ?\n Math.max(doc.body.scrollHeight,\n doc.documentElement.scrollHeight,\n doc.body.offsetHeight,\n doc.documentElement.offsetHeight,\n doc.documentElement.clientHeight) :\n chart.chartHeight,\n chartPosition = chart.pointer.getChartPosition(),\n scaleX = function (val) { return ( // eslint-disable-line no-confusing-arrow\n val * chartPosition.scaleX); },\n scaleY = function (val) { return ( // eslint-disable-line no-confusing-arrow\n val * chartPosition.scaleY); }, \n // Build parameter arrays for firstDimension()/secondDimension()\n buildDimensionArray = function (dim) {\n var isX = dim === 'x';\n return [\n dim,\n isX ? outerWidth : outerHeight,\n isX ? boxWidth : boxHeight\n ].concat(outside ? [\n // If we are using tooltip.outside, we need to scale the\n // position to match scaling of the container in case there\n // is a transform/zoom on the container. #11329\n isX ? scaleX(boxWidth) : scaleY(boxHeight),\n isX ? chartPosition.left - distance +\n scaleX(point.plotX + chart.plotLeft) :\n chartPosition.top - distance +\n scaleY(point.plotY + chart.plotTop),\n 0,\n isX ? outerWidth : outerHeight\n ] : [\n // Not outside, no scaling is needed\n isX ? boxWidth : boxHeight,\n isX ? point.plotX + chart.plotLeft :\n point.plotY + chart.plotTop,\n isX ? chart.plotLeft : chart.plotTop,\n isX ? chart.plotLeft + chart.plotWidth :\n chart.plotTop + chart.plotHeight\n ]);\n };\n var first = buildDimensionArray('y'), second = buildDimensionArray('x'), swapped;\n // Handle negative points or reversed axis (#13780)\n var flipped = !!point.negative;\n if (!chart.polar &&\n chart.hoverSeries &&\n chart.hoverSeries.yAxis &&\n chart.hoverSeries.yAxis.reversed) {\n flipped = !flipped;\n }\n // The far side is right or bottom\n var preferFarSide = !this.followPointer &&\n pick(point.ttBelow, !chart.inverted === flipped), // #4984\n /*\n * Handle the preferred dimension. When the preferred dimension is\n * tooltip on top or bottom of the point,\n it will look for space\n * there.\n *\n * @private\n */\n firstDimension = function (dim,\n outerSize,\n innerSize,\n scaledInnerSize, // #11329\n point,\n min,\n max) {\n var scaledDist = outside ?\n (dim === 'y' ? scaleY(distance) : scaleX(distance)) :\n distance,\n scaleDiff = (innerSize - scaledInnerSize) / 2,\n roomLeft = scaledInnerSize < point - distance,\n roomRight = point + distance + scaledInnerSize < outerSize,\n alignedLeft = point - scaledDist - innerSize + scaleDiff,\n alignedRight = point + scaledDist - scaleDiff;\n if (preferFarSide && roomRight) {\n ret[dim] = alignedRight;\n }\n else if (!preferFarSide && roomLeft) {\n ret[dim] = alignedLeft;\n }\n else if (roomLeft) {\n ret[dim] = Math.min(max - scaledInnerSize, alignedLeft - h < 0 ? alignedLeft : alignedLeft - h);\n }\n else if (roomRight) {\n ret[dim] = Math.max(min, alignedRight + h + innerSize > outerSize ?\n alignedRight :\n alignedRight + h);\n }\n else {\n return false;\n }\n }, \n /*\n * Handle the secondary dimension. If the preferred dimension is\n * tooltip on top or bottom of the point, the second dimension is to\n * align the tooltip above the point, trying to align center but\n * allowing left or right align within the chart box.\n *\n * @private\n */\n secondDimension = function (dim, outerSize, innerSize, scaledInnerSize, // #11329\n point) {\n var retVal;\n // Too close to the edge, return false and swap dimensions\n if (point < distance || point > outerSize - distance) {\n retVal = false;\n // Align left/top\n }\n else if (point < innerSize / 2) {\n ret[dim] = 1;\n // Align right/bottom\n }\n else if (point > outerSize - scaledInnerSize / 2) {\n ret[dim] = outerSize - scaledInnerSize - 2;\n // Align center\n }\n else {\n ret[dim] = point - innerSize / 2;\n }\n return retVal;\n }, \n /*\n * Swap the dimensions\n */\n swap = function (count) {\n var temp = first;\n first = second;\n second = temp;\n swapped = count;\n }, run = function () {\n if (firstDimension.apply(0, first) !== false) {\n if (secondDimension.apply(0, second) === false &&\n !swapped) {\n swap(true);\n run();\n }\n }\n else if (!swapped) {\n swap(true);\n run();\n }\n else {\n ret.x = ret.y = 0;\n }\n };\n // Under these conditions, prefer the tooltip on the side of the point\n if (chart.inverted || this.len > 1) {\n swap();\n }\n run();\n return ret;\n };\n /**\n * Hides the tooltip with a fade out animation.\n *\n * @function Highcharts.Tooltip#hide\n *\n * @param {number} [delay]\n * The fade out in milliseconds. If no value is provided the value\n * of the tooltip.hideDelay option is used. A value of 0 disables\n * the fade out animation.\n */\n Tooltip.prototype.hide = function (delay) {\n var tooltip = this;\n // disallow duplicate timers (#1728, #1766)\n U.clearTimeout(this.hideTimer);\n delay = pick(delay, this.options.hideDelay);\n if (!this.isHidden) {\n this.hideTimer = syncTimeout(function () {\n // If there is a delay, do fadeOut with the default duration. If\n // the hideDelay is 0, we assume no animation is wanted, so we\n // pass 0 duration. #12994.\n tooltip.getLabel().fadeOut(delay ? void 0 : delay);\n tooltip.isHidden = true;\n }, delay);\n }\n };\n /**\n * @private\n * @function Highcharts.Tooltip#init\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.TooltipOptions} options\n * Tooltip options.\n */\n Tooltip.prototype.init = function (chart, options) {\n /**\n * Chart of the tooltip.\n *\n * @readonly\n * @name Highcharts.Tooltip#chart\n * @type {Highcharts.Chart}\n */\n this.chart = chart;\n /**\n * Used tooltip options.\n *\n * @readonly\n * @name Highcharts.Tooltip#options\n * @type {Highcharts.TooltipOptions}\n */\n this.options = options;\n /**\n * List of crosshairs.\n *\n * @private\n * @readonly\n * @name Highcharts.Tooltip#crosshairs\n * @type {Array}\n */\n this.crosshairs = [];\n /**\n * Current values of x and y when animating.\n *\n * @private\n * @readonly\n * @name Highcharts.Tooltip#now\n * @type {Highcharts.PositionObject}\n */\n this.now = { x: 0, y: 0 };\n /**\n * Tooltips are initially hidden.\n *\n * @private\n * @readonly\n * @name Highcharts.Tooltip#isHidden\n * @type {boolean}\n */\n this.isHidden = true;\n /**\n * True, if the tooltip is split into one label per series, with the\n * header close to the axis.\n *\n * @readonly\n * @name Highcharts.Tooltip#split\n * @type {boolean|undefined}\n */\n this.split = options.split && !chart.inverted && !chart.polar;\n /**\n * When the tooltip is shared, the entire plot area will capture mouse\n * movement or touch events.\n *\n * @readonly\n * @name Highcharts.Tooltip#shared\n * @type {boolean|undefined}\n */\n this.shared = options.shared || this.split;\n /**\n * Whether to allow the tooltip to render outside the chart's SVG\n * element box. By default (false), the tooltip is rendered within the\n * chart's SVG element, which results in the tooltip being aligned\n * inside the chart area.\n *\n * @readonly\n * @name Highcharts.Tooltip#outside\n * @type {boolean}\n *\n * @todo\n * Split tooltip does not support outside in the first iteration. Should\n * not be too complicated to implement.\n */\n this.outside = pick(options.outside, Boolean(chart.scrollablePixelsX || chart.scrollablePixelsY));\n };\n Tooltip.prototype.shouldStickOnContact = function (pointerEvent) {\n return !!(!this.followPointer &&\n this.options.stickOnContact &&\n (!pointerEvent || this.chart.pointer.inClass(pointerEvent.target, 'highcharts-tooltip')));\n };\n /**\n * Moves the tooltip with a soft animation to a new position.\n *\n * @private\n * @function Highcharts.Tooltip#move\n *\n * @param {number} x\n *\n * @param {number} y\n *\n * @param {number} anchorX\n *\n * @param {number} anchorY\n */\n Tooltip.prototype.move = function (x, y, anchorX, anchorY) {\n var tooltip = this,\n now = tooltip.now,\n animate = tooltip.options.animation !== false &&\n !tooltip.isHidden &&\n // When we get close to the target position, abort animation and\n // land on the right place (#3056)\n (Math.abs(x - now.x) > 1 || Math.abs(y - now.y) > 1),\n skipAnchor = tooltip.followPointer || tooltip.len > 1;\n // Get intermediate values for animation\n extend(now, {\n x: animate ? (2 * now.x + x) / 3 : x,\n y: animate ? (now.y + y) / 2 : y,\n anchorX: skipAnchor ?\n void 0 :\n animate ? (2 * now.anchorX + anchorX) / 3 : anchorX,\n anchorY: skipAnchor ?\n void 0 :\n animate ? (now.anchorY + anchorY) / 2 : anchorY\n });\n // Move to the intermediate value\n tooltip.getLabel().attr(now);\n tooltip.drawTracker();\n // Run on next tick of the mouse tracker\n if (animate) {\n // Never allow two timeouts\n U.clearTimeout(this.tooltipTimeout);\n // Set the fixed interval ticking for the smooth tooltip\n this.tooltipTimeout = setTimeout(function () {\n // The interval function may still be running during destroy,\n // so check that the chart is really there before calling.\n if (tooltip) {\n tooltip.move(x, y, anchorX, anchorY);\n }\n }, 32);\n }\n };\n /**\n * Refresh the tooltip's text and position.\n *\n * @function Highcharts.Tooltip#refresh\n *\n * @param {Highcharts.Point|Array} pointOrPoints\n * Either a point or an array of points.\n *\n * @param {Highcharts.PointerEventObject} [mouseEvent]\n * Mouse event, that is responsible for the refresh and should be\n * used for the tooltip update.\n */\n Tooltip.prototype.refresh = function (pointOrPoints, mouseEvent) {\n var tooltip = this,\n chart = this.chart,\n options = tooltip.options,\n points = splat(pointOrPoints),\n point = points[0],\n pointConfig = [],\n formatter = options.formatter || tooltip.defaultFormatter,\n shared = tooltip.shared,\n styledMode = chart.styledMode;\n var textConfig = {};\n if (!options.enabled || !point.series) { // #16820\n return;\n }\n U.clearTimeout(this.hideTimer);\n // A switch saying if this specific tooltip configuration allows shared\n // or split modes\n tooltip.allowShared = !(!isArray(pointOrPoints) &&\n pointOrPoints.series &&\n pointOrPoints.series.noSharedTooltip);\n // get the reference point coordinates (pie charts use tooltipPos)\n tooltip.followPointer = (!tooltip.split && point.series.tooltipOptions.followPointer);\n var anchor = tooltip.getAnchor(pointOrPoints,\n mouseEvent),\n x = anchor[0],\n y = anchor[1];\n // shared tooltip, array is sent over\n if (shared && tooltip.allowShared) {\n chart.pointer.applyInactiveState(points);\n // Now set hover state for the choosen ones:\n points.forEach(function (item) {\n item.setState('hover');\n pointConfig.push(item.getLabelConfig());\n });\n textConfig = {\n x: point.category,\n y: point.y\n };\n textConfig.points = pointConfig;\n // single point tooltip\n }\n else {\n textConfig = point.getLabelConfig();\n }\n this.len = pointConfig.length; // #6128\n var text = formatter.call(textConfig,\n tooltip);\n // register the current series\n var currentSeries = point.series;\n this.distance = pick(currentSeries.tooltipOptions.distance, 16);\n // update the inner HTML\n if (text === false) {\n this.hide();\n }\n else {\n // update text\n if (tooltip.split && tooltip.allowShared) { // #13868\n this.renderSplit(text, points);\n }\n else {\n var checkX_1 = x;\n var checkY_1 = y;\n if (mouseEvent && chart.pointer.isDirectTouch) {\n checkX_1 = mouseEvent.chartX - chart.plotLeft;\n checkY_1 = mouseEvent.chartY - chart.plotTop;\n }\n // #11493, #13095\n if (chart.polar ||\n currentSeries.options.clip === false ||\n points.some(function (p) {\n return p.series.shouldShowTooltip(checkX_1, checkY_1);\n })) {\n var label = tooltip.getLabel();\n // Prevent the tooltip from flowing over the chart box\n // (#6659)\n if (!options.style.width || styledMode) {\n label.css({\n width: this.chart.spacingBox.width + 'px'\n });\n }\n label.attr({\n text: text && text.join ?\n text.join('') :\n text\n });\n // Set the stroke color of the box to reflect the point\n label.removeClass(/highcharts-color-[\\d]+/g)\n .addClass('highcharts-color-' +\n pick(point.colorIndex, currentSeries.colorIndex));\n if (!styledMode) {\n label.attr({\n stroke: (options.borderColor ||\n point.color ||\n currentSeries.color ||\n \"#666666\" /* Palette.neutralColor60 */)\n });\n }\n tooltip.updatePosition({\n plotX: x,\n plotY: y,\n negative: point.negative,\n ttBelow: point.ttBelow,\n h: anchor[2] || 0\n });\n }\n else {\n tooltip.hide();\n return;\n }\n }\n // show it\n if (tooltip.isHidden && tooltip.label) {\n tooltip.label.attr({\n opacity: 1\n }).show();\n }\n tooltip.isHidden = false;\n }\n fireEvent(this, 'refresh');\n };\n /**\n * Render the split tooltip. Loops over each point's text and adds\n * a label next to the point, then uses the distribute function to\n * find best non-overlapping positions.\n *\n * @private\n * @function Highcharts.Tooltip#renderSplit\n *\n * @param {string|Array<(boolean|string)>} labels\n *\n * @param {Array} points\n */\n Tooltip.prototype.renderSplit = function (labels, points) {\n var tooltip = this;\n var chart = tooltip.chart,\n _a = tooltip.chart,\n chartWidth = _a.chartWidth,\n chartHeight = _a.chartHeight,\n plotHeight = _a.plotHeight,\n plotLeft = _a.plotLeft,\n plotTop = _a.plotTop,\n pointer = _a.pointer,\n _b = _a.scrollablePixelsY,\n scrollablePixelsY = _b === void 0 ? 0 : _b,\n scrollablePixelsX = _a.scrollablePixelsX,\n _c = _a.scrollingContainer,\n _d = _c === void 0 ? { scrollLeft: 0,\n scrollTop: 0 } : _c,\n scrollLeft = _d.scrollLeft,\n scrollTop = _d.scrollTop,\n styledMode = _a.styledMode,\n distance = tooltip.distance,\n options = tooltip.options,\n positioner = tooltip.options.positioner;\n // The area which the tooltip should be limited to. Limit to scrollable\n // plot area if enabled, otherwise limit to the chart container. If\n // outside is true it should be the whole viewport\n var bounds = (tooltip.outside &&\n typeof scrollablePixelsX !== 'number') ?\n doc.documentElement.getBoundingClientRect() : {\n left: scrollLeft,\n right: scrollLeft + chartWidth,\n top: scrollTop,\n bottom: scrollTop + chartHeight\n };\n var tooltipLabel = tooltip.getLabel();\n var ren = this.renderer || chart.renderer;\n var headerTop = Boolean(chart.xAxis[0] && chart.xAxis[0].opposite);\n var _e = pointer.getChartPosition(),\n chartLeft = _e.left,\n chartTop = _e.top;\n var distributionBoxTop = plotTop + scrollTop;\n var headerHeight = 0;\n var adjustedPlotHeight = plotHeight - scrollablePixelsY;\n /**\n * Calculates the anchor position for the partial tooltip\n *\n * @private\n * @param {Highcharts.Point} point The point related to the tooltip\n * @return {Object} Returns an object with anchorX and anchorY\n */\n function getAnchor(point) {\n var isHeader = point.isHeader,\n _a = point.plotX,\n plotX = _a === void 0 ? 0 : _a,\n _b = point.plotY,\n plotY = _b === void 0 ? 0 : _b,\n series = point.series;\n var anchorX;\n var anchorY;\n if (isHeader) {\n // Set anchorX to plotX\n anchorX = plotLeft + plotX;\n // Set anchorY to center of visible plot area.\n anchorY = plotTop + plotHeight / 2;\n }\n else {\n var xAxis = series.xAxis,\n yAxis = series.yAxis;\n // Set anchorX to plotX. Limit to within xAxis.\n anchorX = xAxis.pos + clamp(plotX, -distance, xAxis.len + distance);\n // Set anchorY, limit to the scrollable plot area\n if (series.shouldShowTooltip(0, yAxis.pos - plotTop + plotY, {\n ignoreX: true\n })) {\n anchorY = yAxis.pos + plotY;\n }\n }\n // Limit values to plot area\n anchorX = clamp(anchorX, bounds.left - distance, bounds.right + distance);\n return { anchorX: anchorX, anchorY: anchorY };\n }\n /**\n * Calculates the position of the partial tooltip\n *\n * @private\n * @param {number} anchorX\n * The partial tooltip anchor x position\n *\n * @param {number} anchorY\n * The partial tooltip anchor y position\n *\n * @param {boolean|undefined} isHeader\n * Whether the partial tooltip is a header\n *\n * @param {number} boxWidth\n * Width of the partial tooltip\n *\n * @return {Highcharts.PositionObject}\n * Returns the partial tooltip x and y position\n */\n function defaultPositioner(anchorX, anchorY, isHeader, boxWidth, alignedLeft) {\n if (alignedLeft === void 0) { alignedLeft = true; }\n var y;\n var x;\n if (isHeader) {\n y = headerTop ? 0 : adjustedPlotHeight;\n x = clamp(anchorX - (boxWidth / 2), bounds.left, bounds.right - boxWidth - (tooltip.outside ? chartLeft : 0));\n }\n else {\n y = anchorY - distributionBoxTop;\n x = alignedLeft ?\n anchorX - boxWidth - distance :\n anchorX + distance;\n x = clamp(x, alignedLeft ? x : bounds.left, bounds.right);\n }\n // NOTE: y is relative to distributionBoxTop\n return { x: x, y: y };\n }\n /**\n * Updates the attributes and styling of the partial tooltip. Creates a\n * new partial tooltip if it does not exists.\n *\n * @private\n * @param {Highcharts.SVGElement|undefined} partialTooltip\n * The partial tooltip to update\n * @param {Highcharts.Point} point\n * The point related to the partial tooltip\n * @param {boolean|string} str The text for the partial tooltip\n * @return {Highcharts.SVGElement} Returns the updated partial tooltip\n */\n function updatePartialTooltip(partialTooltip, point, str) {\n var tt = partialTooltip;\n var isHeader = point.isHeader,\n series = point.series;\n var colorClass = 'highcharts-color-' + pick(point.colorIndex, series.colorIndex, 'none');\n if (!tt) {\n var attribs = {\n padding: options.padding,\n r: options.borderRadius\n };\n if (!styledMode) {\n attribs.fill = options.backgroundColor;\n attribs['stroke-width'] = options.borderWidth;\n }\n tt = ren\n .label('', 0, 0, (options[isHeader ? 'headerShape' : 'shape']), void 0, void 0, options.useHTML)\n .addClass((isHeader ? 'highcharts-tooltip-header ' : '') +\n 'highcharts-tooltip-box ' +\n colorClass)\n .attr(attribs)\n .add(tooltipLabel);\n }\n tt.isActive = true;\n tt.attr({\n text: str\n });\n if (!styledMode) {\n tt.css(options.style)\n .shadow(options.shadow)\n .attr({\n stroke: (options.borderColor ||\n point.color ||\n series.color ||\n \"#333333\" /* Palette.neutralColor80 */)\n });\n }\n return tt;\n }\n // Graceful degradation for legacy formatters\n if (isString(labels)) {\n labels = [false, labels];\n }\n // Create the individual labels for header and points, ignore footer\n var boxes = labels.slice(0,\n points.length + 1).reduce(function (boxes,\n str,\n i) {\n if (str !== false && str !== '') {\n var point = (points[i - 1] ||\n {\n // Item 0 is the header. Instead of this, we could also\n // use the crosshair label\n isHeader: true,\n plotX: points[0].plotX,\n plotY: plotHeight,\n series: {}\n });\n var isHeader = point.isHeader;\n // Store the tooltip label referance on the series\n var owner = isHeader ? tooltip : point.series;\n var tt = owner.tt = updatePartialTooltip(owner.tt,\n point,\n str.toString());\n // Get X position now, so we can move all to the other side in\n // case of overflow\n var bBox = tt.getBBox();\n var boxWidth = bBox.width + tt.strokeWidth();\n if (isHeader) {\n headerHeight = bBox.height;\n adjustedPlotHeight += headerHeight;\n if (headerTop) {\n distributionBoxTop -= headerHeight;\n }\n }\n var _a = getAnchor(point),\n anchorX = _a.anchorX,\n anchorY = _a.anchorY;\n if (typeof anchorY === 'number') {\n var size = bBox.height + 1;\n var boxPosition = (positioner ?\n positioner.call(tooltip,\n boxWidth,\n size,\n point) :\n defaultPositioner(anchorX,\n anchorY,\n isHeader,\n boxWidth));\n boxes.push({\n // 0-align to the top, 1-align to the bottom\n align: positioner ? 0 : void 0,\n anchorX: anchorX,\n anchorY: anchorY,\n boxWidth: boxWidth,\n point: point,\n rank: pick(boxPosition.rank, isHeader ? 1 : 0),\n size: size,\n target: boxPosition.y,\n tt: tt,\n x: boxPosition.x\n });\n }\n else {\n // Hide tooltips which anchorY is outside the visible plot\n // area\n tt.isActive = false;\n }\n }\n return boxes;\n }, []);\n // Realign the tooltips towards the right if there is not enough space\n // to the left and there is space to to the right\n if (!positioner && boxes.some(function (box) {\n // Always realign if the beginning of a label is outside bounds\n var outside = tooltip.outside;\n var boxStart = (outside ? chartLeft : 0) + box.anchorX;\n if (boxStart < bounds.left &&\n boxStart + box.boxWidth < bounds.right) {\n return true;\n }\n // Otherwise, check if there is more space available to the right\n return boxStart < (chartLeft - bounds.left) + box.boxWidth &&\n bounds.right - boxStart > boxStart;\n })) {\n boxes = boxes.map(function (box) {\n var _a = defaultPositioner(box.anchorX,\n box.anchorY,\n box.point.isHeader,\n box.boxWidth,\n false),\n x = _a.x,\n y = _a.y;\n return extend(box, {\n target: y,\n x: x\n });\n });\n }\n // Clean previous run (for missing points)\n tooltip.cleanSplit();\n // Distribute and put in place\n distribute(boxes, adjustedPlotHeight);\n var boxExtremes = {\n left: chartLeft,\n right: chartLeft\n };\n // Get the extremes from series tooltips\n boxes.forEach(function (box) {\n var x = box.x,\n boxWidth = box.boxWidth,\n isHeader = box.isHeader;\n if (!isHeader) {\n if (tooltip.outside && chartLeft + x < boxExtremes.left) {\n boxExtremes.left = chartLeft + x;\n }\n if (!isHeader &&\n tooltip.outside &&\n boxExtremes.left + boxWidth > boxExtremes.right) {\n boxExtremes.right = chartLeft + x;\n }\n }\n });\n boxes.forEach(function (box) {\n var x = box.x,\n anchorX = box.anchorX,\n anchorY = box.anchorY,\n pos = box.pos,\n isHeader = box.point.isHeader;\n var attributes = {\n visibility: typeof pos === 'undefined' ? 'hidden' : 'inherit',\n x: x,\n /* NOTE: y should equal pos to be consistent with !split\n * tooltip,\n but is currently relative to plotTop. Is left as is\n * to avoid breaking change. Remove distributionBoxTop to make\n * it consistent.\n */\n y: pos + distributionBoxTop,\n anchorX: anchorX,\n anchorY: anchorY\n };\n // Handle left-aligned tooltips overflowing the chart area\n if (tooltip.outside && x < anchorX) {\n var offset = chartLeft - boxExtremes.left;\n // Skip this if there is no overflow\n if (offset > 0) {\n if (!isHeader) {\n attributes.x = x + offset;\n attributes.anchorX = anchorX + offset;\n }\n if (isHeader) {\n attributes.x = (boxExtremes.right - boxExtremes.left) / 2;\n attributes.anchorX = anchorX + offset;\n }\n }\n }\n // Put the label in place\n box.tt.attr(attributes);\n });\n /* If we have a seperate tooltip container, then update the necessary\n * container properties.\n * Test that tooltip has its own container and renderer before executing\n * the operation.\n */\n var container = tooltip.container,\n outside = tooltip.outside,\n renderer = tooltip.renderer;\n if (outside && container && renderer) {\n // Set container size to fit the bounds\n var _f = tooltipLabel.getBBox(),\n width = _f.width,\n height = _f.height,\n x = _f.x,\n y = _f.y;\n renderer.setSize(width + x, height + y, false);\n // Position the tooltip container to the chart container\n container.style.left = boxExtremes.left + 'px';\n container.style.top = chartTop + 'px';\n }\n };\n /**\n * If the `stickOnContact` option is active, this will add a tracker shape.\n *\n * @private\n * @function Highcharts.Tooltip#drawTracker\n */\n Tooltip.prototype.drawTracker = function () {\n var tooltip = this;\n if (!this.shouldStickOnContact()) {\n if (tooltip.tracker) {\n tooltip.tracker.destroy();\n }\n return;\n }\n var chart = tooltip.chart;\n var label = tooltip.label;\n var points = tooltip.shared ? chart.hoverPoints : chart.hoverPoint;\n if (!label || !points) {\n return;\n }\n var box = {\n x: 0,\n y: 0,\n width: 0,\n height: 0\n };\n // Combine anchor and tooltip\n var anchorPos = this.getAnchor(points);\n var labelBBox = label.getBBox();\n anchorPos[0] += chart.plotLeft - label.translateX;\n anchorPos[1] += chart.plotTop - label.translateY;\n // When the mouse pointer is between the anchor point and the label,\n // the label should stick.\n box.x = Math.min(0, anchorPos[0]);\n box.y = Math.min(0, anchorPos[1]);\n box.width = (anchorPos[0] < 0 ?\n Math.max(Math.abs(anchorPos[0]), (labelBBox.width - anchorPos[0])) :\n Math.max(Math.abs(anchorPos[0]), labelBBox.width));\n box.height = (anchorPos[1] < 0 ?\n Math.max(Math.abs(anchorPos[1]), (labelBBox.height - Math.abs(anchorPos[1]))) :\n Math.max(Math.abs(anchorPos[1]), labelBBox.height));\n if (tooltip.tracker) {\n tooltip.tracker.attr(box);\n }\n else {\n tooltip.tracker = label.renderer\n .rect(box)\n .addClass('highcharts-tracker')\n .add(label);\n if (!chart.styledMode) {\n tooltip.tracker.attr({\n fill: 'rgba(0,0,0,0)'\n });\n }\n }\n };\n /**\n * @private\n */\n Tooltip.prototype.styledModeFormat = function (formatString) {\n return formatString\n .replace('style=\"font-size: 10px\"', 'class=\"highcharts-header\"')\n .replace(/style=\"color:{(point|series)\\.color}\"/g, 'class=\"highcharts-color-{$1.colorIndex}\"');\n };\n /**\n * Format the footer/header of the tooltip\n * #3397: abstraction to enable formatting of footer and header\n *\n * @private\n * @function Highcharts.Tooltip#tooltipFooterHeaderFormatter\n */\n Tooltip.prototype.tooltipFooterHeaderFormatter = function (labelConfig, isFooter) {\n var series = labelConfig.series,\n tooltipOptions = series.tooltipOptions,\n xAxis = series.xAxis,\n dateTime = xAxis && xAxis.dateTime,\n e = {\n isFooter: isFooter,\n labelConfig: labelConfig\n };\n var xDateFormat = tooltipOptions.xDateFormat,\n formatString = tooltipOptions[isFooter ? 'footerFormat' : 'headerFormat'];\n fireEvent(this, 'headerFormatter', e, function (e) {\n // Guess the best date format based on the closest point distance\n // (#568, #3418)\n if (dateTime && !xDateFormat && isNumber(labelConfig.key)) {\n xDateFormat = dateTime.getXDateFormat(labelConfig.key, tooltipOptions.dateTimeLabelFormats);\n }\n // Insert the footer date format if any\n if (dateTime && xDateFormat) {\n ((labelConfig.point && labelConfig.point.tooltipDateKeys) ||\n ['key']).forEach(function (key) {\n formatString = formatString.replace('{point.' + key + '}', '{point.' + key + ':' + xDateFormat + '}');\n });\n }\n // Replace default header style with class name\n if (series.chart.styledMode) {\n formatString = this.styledModeFormat(formatString);\n }\n e.text = format(formatString, {\n point: labelConfig,\n series: series\n }, this.chart);\n });\n return e.text;\n };\n /**\n * Updates the tooltip with the provided tooltip options.\n *\n * @function Highcharts.Tooltip#update\n *\n * @param {Highcharts.TooltipOptions} options\n * The tooltip options to update.\n */\n Tooltip.prototype.update = function (options) {\n this.destroy();\n // Update user options (#6218)\n merge(true, this.chart.options.tooltip.userOptions, options);\n this.init(this.chart, merge(true, this.options, options));\n };\n /**\n * Find the new position and perform the move\n *\n * @private\n * @function Highcharts.Tooltip#updatePosition\n *\n * @param {Highcharts.Point} point\n */\n Tooltip.prototype.updatePosition = function (point) {\n var chart = this.chart,\n options = this.options,\n pointer = chart.pointer,\n label = this.getLabel(), \n // Needed for outside: true (#11688)\n chartPosition = pointer.getChartPosition(),\n pos = (options.positioner || this.getPosition).call(this,\n label.width,\n label.height,\n point);\n var anchorX = point.plotX + chart.plotLeft,\n anchorY = point.plotY + chart.plotTop,\n pad;\n // Set the renderer size dynamically to prevent document size to change\n if (this.outside) {\n pad = options.borderWidth + 2 * this.distance;\n this.renderer.setSize(label.width + pad, label.height + pad, false);\n // Anchor and tooltip container need scaling if chart container has\n // scale transform/css zoom. #11329.\n if (chartPosition.scaleX !== 1 || chartPosition.scaleY !== 1) {\n css(this.container, {\n transform: \"scale(\".concat(chartPosition.scaleX, \", \").concat(chartPosition.scaleY, \")\")\n });\n anchorX *= chartPosition.scaleX;\n anchorY *= chartPosition.scaleY;\n }\n anchorX += chartPosition.left - pos.x;\n anchorY += chartPosition.top - pos.y;\n }\n // do the move\n this.move(Math.round(pos.x), Math.round(pos.y || 0), // can be undefined (#3977)\n anchorX, anchorY);\n };\n return Tooltip;\n }());\n /* *\n *\n * Default export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Callback function to format the text of the tooltip from scratch.\n *\n * In case of single or shared tooltips, a string should be be returned. In case\n * of splitted tooltips, it should return an array where the first item is the\n * header, and subsequent items are mapped to the points. Return `false` to\n * disable tooltip for a specific point on series.\n *\n * @callback Highcharts.TooltipFormatterCallbackFunction\n *\n * @param {Highcharts.TooltipFormatterContextObject} this\n * Context to format\n *\n * @param {Highcharts.Tooltip} tooltip\n * The tooltip instance\n *\n * @return {false|string|Array<(string|null|undefined)>|null|undefined}\n * Formatted text or false\n */\n /**\n * Configuration for the tooltip formatters.\n *\n * @interface Highcharts.TooltipFormatterContextObject\n * @extends Highcharts.PointLabelObject\n */ /**\n * Array of points in shared tooltips.\n * @name Highcharts.TooltipFormatterContextObject#points\n * @type {Array|undefined}\n */\n /**\n * A callback function to place the tooltip in a specific position.\n *\n * @callback Highcharts.TooltipPositionerCallbackFunction\n *\n * @param {Highcharts.Tooltip} this\n * Tooltip context of the callback.\n *\n * @param {number} labelWidth\n * Width of the tooltip.\n *\n * @param {number} labelHeight\n * Height of the tooltip.\n *\n * @param {Highcharts.TooltipPositionerPointObject} point\n * Point information for positioning a tooltip.\n *\n * @return {Highcharts.PositionObject}\n * New position for the tooltip.\n */\n /**\n * Point information for positioning a tooltip.\n *\n * @interface Highcharts.TooltipPositionerPointObject\n * @extends Highcharts.Point\n */ /**\n * If `tooltip.split` option is enabled and positioner is called for each of the\n * boxes separately, this property indicates the call on the xAxis header, which\n * is not a point itself.\n * @name Highcharts.TooltipPositionerPointObject#isHeader\n * @type {boolean}\n */ /**\n * The reference point relative to the plot area. Add chart.plotLeft to get the\n * full coordinates.\n * @name Highcharts.TooltipPositionerPointObject#plotX\n * @type {number}\n */ /**\n * The reference point relative to the plot area. Add chart.plotTop to get the\n * full coordinates.\n * @name Highcharts.TooltipPositionerPointObject#plotY\n * @type {number}\n */\n /**\n * @typedef {\"callout\"|\"circle\"|\"square\"} Highcharts.TooltipShapeValue\n */\n ''; // keeps doclets above in JS file\n\n return Tooltip;\n });\n _registerModule(_modules, 'Core/Series/Point.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Defaults.js'], _modules['Core/FormatUtilities.js'], _modules['Core/Utilities.js']], function (AST, A, D, F, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var animObject = A.animObject;\n var defaultOptions = D.defaultOptions;\n var format = F.format;\n var addEvent = U.addEvent,\n defined = U.defined,\n erase = U.erase,\n extend = U.extend,\n fireEvent = U.fireEvent,\n getNestedProperty = U.getNestedProperty,\n isArray = U.isArray,\n isFunction = U.isFunction,\n isNumber = U.isNumber,\n isObject = U.isObject,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick,\n syncTimeout = U.syncTimeout,\n removeEvent = U.removeEvent,\n uniqueKey = U.uniqueKey;\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /* *\n *\n * Class\n *\n * */\n /**\n * The Point object. The point objects are generated from the `series.data`\n * configuration objects or raw numbers. They can be accessed from the\n * `Series.points` array. Other ways to instantiate points are through {@link\n * Highcharts.Series#addPoint} or {@link Highcharts.Series#setData}.\n *\n * @class\n * @name Highcharts.Point\n */\n var Point = /** @class */ (function () {\n function Point() {\n /* *\n *\n * Properties\n *\n * */\n /**\n * For categorized axes this property holds the category name for the\n * point. For other axes it holds the X value.\n *\n * @name Highcharts.Point#category\n * @type {number|string}\n */\n this.category = void 0;\n /**\n * The point's current color index, used in styled mode instead of\n * `color`. The color index is inserted in class names used for styling.\n *\n * @name Highcharts.Point#colorIndex\n * @type {number}\n */\n this.colorIndex = void 0;\n this.formatPrefix = 'point';\n this.id = void 0;\n this.isNull = false;\n /**\n * The name of the point. The name can be given as the first position of the\n * point configuration array, or as a `name` property in the configuration:\n *\n * @example\n * // Array config\n * data: [\n * ['John', 1],\n * ['Jane', 2]\n * ]\n *\n * // Object config\n * data: [{\n * name: 'John',\n * y: 1\n * }, {\n * name: 'Jane',\n * y: 2\n * }]\n *\n * @name Highcharts.Point#name\n * @type {string}\n */\n this.name = void 0;\n /**\n * The point's options as applied in the initial configuration, or\n * extended through `Point.update`.\n *\n * In TypeScript you have to extend `PointOptionsObject` via an\n * additional interface to allow custom data options:\n *\n * ```\n * declare interface PointOptionsObject {\n * customProperty: string;\n * }\n * ```\n *\n * @name Highcharts.Point#options\n * @type {Highcharts.PointOptionsObject}\n */\n this.options = void 0;\n /**\n * The percentage for points in a stacked series or pies.\n *\n * @name Highcharts.Point#percentage\n * @type {number|undefined}\n */\n this.percentage = void 0;\n this.selected = false;\n /**\n * The series object associated with the point.\n *\n * @name Highcharts.Point#series\n * @type {Highcharts.Series}\n */\n this.series = void 0;\n /**\n * The attributes of the rendered SVG shape like in `column` or `pie`\n * series.\n *\n * @readonly\n * @name Highcharts.Point#shapeArgs\n * @type {Readonly|undefined}\n */\n this.shapeArgs = void 0;\n /**\n * The total of values in either a stack for stacked series, or a pie in a\n * pie series.\n *\n * @name Highcharts.Point#total\n * @type {number|undefined}\n */\n this.total = void 0;\n /**\n * For certain series types, like pie charts, where individual points can\n * be shown or hidden.\n *\n * @name Highcharts.Point#visible\n * @type {boolean}\n * @default true\n */\n this.visible = true;\n this.x = void 0;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Animate SVG elements associated with the point.\n *\n * @private\n * @function Highcharts.Point#animateBeforeDestroy\n */\n Point.prototype.animateBeforeDestroy = function () {\n var point = this,\n animateParams = { x: point.startXPos,\n opacity: 0 },\n graphicalProps = point.getGraphicalProps();\n graphicalProps.singular.forEach(function (prop) {\n var isDataLabel = prop === 'dataLabel';\n point[prop] = point[prop].animate(isDataLabel ? {\n x: point[prop].startXPos,\n y: point[prop].startYPos,\n opacity: 0\n } : animateParams);\n });\n graphicalProps.plural.forEach(function (plural) {\n point[plural].forEach(function (item) {\n if (item.element) {\n item.animate(extend({ x: point.startXPos }, (item.startYPos ? {\n x: item.startXPos,\n y: item.startYPos\n } : {})));\n }\n });\n });\n };\n /**\n * Apply the options containing the x and y data and possible some extra\n * properties. Called on point init or from point.update.\n *\n * @private\n * @function Highcharts.Point#applyOptions\n *\n * @param {Highcharts.PointOptionsType} options\n * The point options as defined in series.data.\n *\n * @param {number} [x]\n * Optionally, the x value.\n *\n * @return {Highcharts.Point}\n * The Point instance.\n */\n Point.prototype.applyOptions = function (options, x) {\n var point = this,\n series = point.series,\n pointValKey = series.options.pointValKey || series.pointValKey;\n options = Point.prototype.optionsToObject.call(this, options);\n // copy options directly to point\n extend(point, options);\n point.options = point.options ?\n extend(point.options, options) :\n options;\n // Since options are copied into the Point instance, some accidental\n // options must be shielded (#5681)\n if (options.group) {\n delete point.group;\n }\n if (options.dataLabels) {\n delete point.dataLabels;\n }\n /**\n * The y value of the point.\n * @name Highcharts.Point#y\n * @type {number|undefined}\n */\n // For higher dimension series types. For instance, for ranges, point.y\n // is mapped to point.low.\n if (pointValKey) {\n point.y = Point.prototype.getNestedProperty.call(point, pointValKey);\n }\n point.isNull = this.isValid && !this.isValid();\n point.formatPrefix = point.isNull ? 'null' : 'point'; // #9233, #10874\n // The point is initially selected by options (#5777)\n if (point.selected) {\n point.state = 'select';\n }\n /**\n * The x value of the point.\n * @name Highcharts.Point#x\n * @type {number}\n */\n // If no x is set by now, get auto incremented value. All points must\n // have an x value, however the y value can be null to create a gap in\n // the series\n if ('name' in point &&\n typeof x === 'undefined' &&\n series.xAxis &&\n series.xAxis.hasNames) {\n point.x = series.xAxis.nameToX(point);\n }\n if (typeof point.x === 'undefined' && series) {\n if (typeof x === 'undefined') {\n point.x = series.autoIncrement();\n }\n else {\n point.x = x;\n }\n }\n else if (isNumber(options.x) && series.options.relativeXValue) {\n point.x = series.autoIncrement(options.x);\n }\n return point;\n };\n /**\n * Destroy a point to clear memory. Its reference still stays in\n * `series.data`.\n *\n * @private\n * @function Highcharts.Point#destroy\n */\n Point.prototype.destroy = function () {\n var point = this,\n series = point.series,\n chart = series.chart,\n dataSorting = series.options.dataSorting,\n hoverPoints = chart.hoverPoints,\n globalAnimation = point.series.chart.renderer.globalAnimation,\n animation = animObject(globalAnimation);\n var prop;\n /**\n * Allow to call after animation.\n * @private\n */\n function destroyPoint() {\n // Remove all events and elements\n if (point.graphic ||\n point.graphics ||\n point.dataLabel ||\n point.dataLabels) {\n removeEvent(point);\n point.destroyElements();\n }\n for (prop in point) { // eslint-disable-line guard-for-in\n point[prop] = null;\n }\n }\n if (point.legendItem) {\n // pies have legend items\n chart.legend.destroyItem(point);\n }\n if (hoverPoints) {\n point.setState();\n erase(hoverPoints, point);\n if (!hoverPoints.length) {\n chart.hoverPoints = null;\n }\n }\n if (point === chart.hoverPoint) {\n point.onMouseOut();\n }\n // Remove properties after animation\n if (!dataSorting || !dataSorting.enabled) {\n destroyPoint();\n }\n else {\n this.animateBeforeDestroy();\n syncTimeout(destroyPoint, animation.duration);\n }\n chart.pointCount--;\n };\n /**\n * Destroy SVG elements associated with the point.\n *\n * @private\n * @function Highcharts.Point#destroyElements\n * @param {Highcharts.Dictionary} [kinds]\n */\n Point.prototype.destroyElements = function (kinds) {\n var point = this,\n props = point.getGraphicalProps(kinds);\n props.singular.forEach(function (prop) {\n point[prop] = point[prop].destroy();\n });\n props.plural.forEach(function (plural) {\n point[plural].forEach(function (item) {\n if (item.element) {\n item.destroy();\n }\n });\n delete point[plural];\n });\n };\n /**\n * Fire an event on the Point object.\n *\n * @private\n * @function Highcharts.Point#firePointEvent\n *\n * @param {string} eventType\n * Type of the event.\n *\n * @param {Highcharts.Dictionary|Event} [eventArgs]\n * Additional event arguments.\n *\n * @param {Highcharts.EventCallbackFunction|Function} [defaultFunction]\n * Default event handler.\n *\n * @emits Highcharts.Point#event:*\n */\n Point.prototype.firePointEvent = function (eventType, eventArgs, defaultFunction) {\n var point = this,\n series = this.series,\n seriesOptions = series.options;\n // load event handlers on demand to save time on mouseover/out\n if (seriesOptions.point.events[eventType] ||\n (point.options &&\n point.options.events &&\n point.options.events[eventType])) {\n point.importEvents();\n }\n // add default handler if in selection mode\n if (eventType === 'click' && seriesOptions.allowPointSelect) {\n defaultFunction = function (event) {\n // Control key is for Windows, meta (= Cmd key) for Mac, Shift\n // for Opera.\n if (point.select) { // #2911\n point.select(null, event.ctrlKey || event.metaKey || event.shiftKey);\n }\n };\n }\n fireEvent(point, eventType, eventArgs, defaultFunction);\n };\n /**\n * Get the CSS class names for individual points. Used internally where the\n * returned value is set on every point.\n *\n * @function Highcharts.Point#getClassName\n *\n * @return {string}\n * The class names.\n */\n Point.prototype.getClassName = function () {\n var point = this;\n return 'highcharts-point' +\n (point.selected ? ' highcharts-point-select' : '') +\n (point.negative ? ' highcharts-negative' : '') +\n (point.isNull ? ' highcharts-null-point' : '') +\n (typeof point.colorIndex !== 'undefined' ?\n ' highcharts-color-' + point.colorIndex : '') +\n (point.options.className ? ' ' + point.options.className : '') +\n (point.zone && point.zone.className ? ' ' +\n point.zone.className.replace('highcharts-negative', '') : '');\n };\n /**\n * Get props of all existing graphical point elements.\n *\n * @private\n * @function Highcharts.Point#getGraphicalProps\n */\n Point.prototype.getGraphicalProps = function (kinds) {\n var point = this,\n props = [],\n graphicalProps = { singular: [],\n plural: [] };\n var prop,\n i;\n kinds = kinds || { graphic: 1, dataLabel: 1 };\n if (kinds.graphic) {\n props.push('graphic', 'shadowGroup');\n }\n if (kinds.dataLabel) {\n props.push('dataLabel', 'dataLabelPath', 'dataLabelUpper', 'connector');\n }\n i = props.length;\n while (i--) {\n prop = props[i];\n if (point[prop]) {\n graphicalProps.singular.push(prop);\n }\n }\n [\n 'graphic',\n 'dataLabel',\n 'connector'\n ].forEach(function (prop) {\n var plural = prop + 's';\n if (kinds[prop] && point[plural]) {\n graphicalProps.plural.push(plural);\n }\n });\n return graphicalProps;\n };\n /**\n * Return the configuration hash needed for the data label and tooltip\n * formatters.\n *\n * @function Highcharts.Point#getLabelConfig\n *\n * @return {Highcharts.PointLabelObject}\n * Abstract object used in formatters and formats.\n */\n Point.prototype.getLabelConfig = function () {\n return {\n x: this.category,\n y: this.y,\n color: this.color,\n colorIndex: this.colorIndex,\n key: this.name || this.category,\n series: this.series,\n point: this,\n percentage: this.percentage,\n total: this.total || this.stackTotal\n };\n };\n /**\n * Returns the value of the point property for a given value.\n * @private\n */\n Point.prototype.getNestedProperty = function (key) {\n if (!key) {\n return;\n }\n if (key.indexOf('custom.') === 0) {\n return getNestedProperty(key, this.options);\n }\n return this[key];\n };\n /**\n * In a series with `zones`, return the zone that the point belongs to.\n *\n * @function Highcharts.Point#getZone\n *\n * @return {Highcharts.SeriesZonesOptionsObject}\n * The zone item.\n */\n Point.prototype.getZone = function () {\n var series = this.series,\n zones = series.zones,\n zoneAxis = series.zoneAxis || 'y';\n var zone,\n i = 0;\n zone = zones[i];\n while (this[zoneAxis] >= zone.value) {\n zone = zones[++i];\n }\n // For resetting or reusing the point (#8100)\n if (!this.nonZonedColor) {\n this.nonZonedColor = this.color;\n }\n if (zone && zone.color && !this.options.color) {\n this.color = zone.color;\n }\n else {\n this.color = this.nonZonedColor;\n }\n return zone;\n };\n /**\n * Utility to check if point has new shape type. Used in column series and\n * all others that are based on column series.\n * @private\n */\n Point.prototype.hasNewShapeType = function () {\n var point = this;\n var oldShapeType = point.graphic &&\n (point.graphic.symbolName || point.graphic.element.nodeName);\n return oldShapeType !== this.shapeType;\n };\n /**\n * Initialize the point. Called internally based on the `series.data`\n * option.\n *\n * @function Highcharts.Point#init\n *\n * @param {Highcharts.Series} series\n * The series object containing this point.\n *\n * @param {Highcharts.PointOptionsType} options\n * The data in either number, array or object format.\n *\n * @param {number} [x]\n * Optionally, the X value of the point.\n *\n * @return {Highcharts.Point}\n * The Point instance.\n *\n * @emits Highcharts.Point#event:afterInit\n */\n Point.prototype.init = function (series, options, x) {\n this.series = series;\n this.applyOptions(options, x);\n // Add a unique ID to the point if none is assigned\n this.id = defined(this.id) ? this.id : uniqueKey();\n this.resolveColor();\n series.chart.pointCount++;\n fireEvent(this, 'afterInit');\n return this;\n };\n /**\n * Determine if point is valid.\n * @private\n * @function Highcharts.Point#isValid\n */\n Point.prototype.isValid = function () {\n return this.x !== null && isNumber(this.y);\n };\n /**\n * Transform number or array configs into objects. Also called for object\n * configs. Used internally to unify the different configuration formats for\n * points. For example, a simple number `10` in a line series will be\n * transformed to `{ y: 10 }`, and an array config like `[1, 10]` in a\n * scatter series will be transformed to `{ x: 1, y: 10 }`.\n *\n * @deprecated\n * @function Highcharts.Point#optionsToObject\n *\n * @param {Highcharts.PointOptionsType} options\n * Series data options.\n *\n * @return {Highcharts.Dictionary<*>}\n * Transformed point options.\n */\n Point.prototype.optionsToObject = function (options) {\n var series = this.series,\n keys = series.options.keys,\n pointArrayMap = keys || series.pointArrayMap || ['y'],\n valueCount = pointArrayMap.length;\n var ret = {},\n firstItemType,\n i = 0,\n j = 0;\n if (isNumber(options) || options === null) {\n ret[pointArrayMap[0]] = options;\n }\n else if (isArray(options)) {\n // with leading x value\n if (!keys && options.length > valueCount) {\n firstItemType = typeof options[0];\n if (firstItemType === 'string') {\n ret.name = options[0];\n }\n else if (firstItemType === 'number') {\n ret.x = options[0];\n }\n i++;\n }\n while (j < valueCount) {\n // Skip undefined positions for keys\n if (!keys || typeof options[i] !== 'undefined') {\n if (pointArrayMap[j].indexOf('.') > 0) {\n // Handle nested keys, e.g. ['color.pattern.image']\n // Avoid function call unless necessary.\n Point.prototype.setNestedProperty(ret, options[i], pointArrayMap[j]);\n }\n else {\n ret[pointArrayMap[j]] = options[i];\n }\n }\n i++;\n j++;\n }\n }\n else if (typeof options === 'object') {\n ret = options;\n // This is the fastest way to detect if there are individual point\n // dataLabels that need to be considered in drawDataLabels. These\n // can only occur in object configs.\n if (options.dataLabels) {\n series._hasPointLabels = true;\n }\n // Same approach as above for markers\n if (options.marker) {\n series._hasPointMarkers = true;\n }\n }\n return ret;\n };\n /**\n * @private\n * @function Highcharts.Point#resolveColor\n */\n Point.prototype.resolveColor = function () {\n var series = this.series,\n optionsChart = series.chart.options.chart,\n styledMode = series.chart.styledMode;\n var color,\n colors,\n colorCount = optionsChart.colorCount,\n colorIndex;\n // remove points nonZonedColor for later recalculation\n delete this.nonZonedColor;\n if (series.options.colorByPoint) {\n if (!styledMode) {\n colors = series.options.colors || series.chart.options.colors;\n color = colors[series.colorCounter];\n colorCount = colors.length;\n }\n colorIndex = series.colorCounter;\n series.colorCounter++;\n // loop back to zero\n if (series.colorCounter === colorCount) {\n series.colorCounter = 0;\n }\n }\n else {\n if (!styledMode) {\n color = series.color;\n }\n colorIndex = series.colorIndex;\n }\n this.colorIndex = pick(this.options.colorIndex, colorIndex);\n /**\n * The point's current color.\n *\n * @name Highcharts.Point#color\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject|undefined}\n */\n this.color = pick(this.options.color, color);\n };\n /**\n * Set a value in an object, on the property defined by key. The key\n * supports nested properties using dot notation. The function modifies the\n * input object and does not make a copy.\n *\n * @function Highcharts.Point#setNestedProperty\n *\n * @param {T} object\n * The object to set the value on.\n *\n * @param {*} value\n * The value to set.\n *\n * @param {string} key\n * Key to the property to set.\n *\n * @return {T}\n * The modified object.\n */\n Point.prototype.setNestedProperty = function (object, value, key) {\n var nestedKeys = key.split('.');\n nestedKeys.reduce(function (result, key, i, arr) {\n var isLastKey = arr.length - 1 === i;\n result[key] = (isLastKey ?\n value :\n isObject(result[key], true) ?\n result[key] :\n {});\n return result[key];\n }, object);\n return object;\n };\n Point.prototype.shouldDraw = function () {\n return !this.isNull;\n };\n /**\n * Extendable method for formatting each point's tooltip line.\n *\n * @function Highcharts.Point#tooltipFormatter\n *\n * @param {string} pointFormat\n * The point format.\n *\n * @return {string}\n * A string to be concatenated in to the common tooltip text.\n */\n Point.prototype.tooltipFormatter = function (pointFormat) {\n // Insert options for valueDecimals, valuePrefix, and valueSuffix\n var series = this.series, seriesTooltipOptions = series.tooltipOptions, valueDecimals = pick(seriesTooltipOptions.valueDecimals, ''), valuePrefix = seriesTooltipOptions.valuePrefix || '', valueSuffix = seriesTooltipOptions.valueSuffix || '';\n // Replace default point style with class name\n if (series.chart.styledMode) {\n pointFormat =\n series.chart.tooltip.styledModeFormat(pointFormat);\n }\n // Loop over the point array map and replace unformatted values with\n // sprintf formatting markup\n (series.pointArrayMap || ['y']).forEach(function (key) {\n key = '{point.' + key; // without the closing bracket\n if (valuePrefix || valueSuffix) {\n pointFormat = pointFormat.replace(RegExp(key + '}', 'g'), valuePrefix + key + '}' + valueSuffix);\n }\n pointFormat = pointFormat.replace(RegExp(key + '}', 'g'), key + ':,.' + valueDecimals + 'f}');\n });\n return format(pointFormat, {\n point: this,\n series: this.series\n }, series.chart);\n };\n /**\n * Update point with new options (typically x/y data) and optionally redraw\n * the series.\n *\n * @sample highcharts/members/point-update-column/\n * Update column value\n * @sample highcharts/members/point-update-pie/\n * Update pie slice\n * @sample maps/members/point-update/\n * Update map area value in Highmaps\n *\n * @function Highcharts.Point#update\n *\n * @param {Highcharts.PointOptionsType} options\n * The point options. Point options are handled as described under\n * the `series.type.data` item for each series type. For example\n * for a line series, if options is a single number, the point will\n * be given that number as the marin y value. If it is an array, it\n * will be interpreted as x and y values respectively. If it is an\n * object, advanced options are applied.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the point is updated. If doing\n * more operations on the chart, it is best practice to set\n * `redraw` to false and call `chart.redraw()` after.\n *\n * @param {boolean|Partial} [animation=true]\n * Whether to apply animation, and optionally animation\n * configuration.\n *\n * @emits Highcharts.Point#event:update\n */\n Point.prototype.update = function (options, redraw, animation, runEvent) {\n var point = this,\n series = point.series,\n graphic = point.graphic,\n chart = series.chart,\n seriesOptions = series.options;\n var i;\n redraw = pick(redraw, true);\n /**\n * @private\n */\n function update() {\n point.applyOptions(options);\n // Update visuals, #4146\n // Handle mock graphic elements for a11y, #12718\n var hasMockGraphic = graphic && point.hasMockGraphic;\n var shouldDestroyGraphic = point.y === null ?\n !hasMockGraphic :\n hasMockGraphic;\n if (graphic && shouldDestroyGraphic) {\n point.graphic = graphic.destroy();\n delete point.hasMockGraphic;\n }\n if (isObject(options, true)) {\n // Destroy so we can get new elements\n if (graphic && graphic.element) {\n // \"null\" is also a valid symbol\n if (options &&\n options.marker &&\n typeof options.marker.symbol !== 'undefined') {\n point.graphic = graphic.destroy();\n }\n }\n if (options && options.dataLabels && point.dataLabel) {\n point.dataLabel = point.dataLabel.destroy(); // #2468\n }\n if (point.connector) {\n point.connector = point.connector.destroy(); // #7243\n }\n }\n // record changes in the parallel arrays\n i = point.index;\n series.updateParallelArrays(point, i);\n // Record the options to options.data. If the old or the new config\n // is an object, use point options, otherwise use raw options\n // (#4701, #4916).\n seriesOptions.data[i] = (isObject(seriesOptions.data[i], true) ||\n isObject(options, true)) ?\n point.options :\n pick(options, seriesOptions.data[i]);\n // redraw\n series.isDirty = series.isDirtyData = true;\n if (!series.fixedBox && series.hasCartesianSeries) { // #1906, #2320\n chart.isDirtyBox = true;\n }\n if (seriesOptions.legendType === 'point') { // #1831, #1885\n chart.isDirtyLegend = true;\n }\n if (redraw) {\n chart.redraw(animation);\n }\n }\n // Fire the event with a default handler of doing the update\n if (runEvent === false) { // When called from setData\n update();\n }\n else {\n point.firePointEvent('update', { options: options }, update);\n }\n };\n /**\n * Remove a point and optionally redraw the series and if necessary the axes\n *\n * @sample highcharts/plotoptions/series-point-events-remove/\n * Remove point and confirm\n * @sample highcharts/members/point-remove/\n * Remove pie slice\n * @sample maps/members/point-remove/\n * Remove selected points in Highmaps\n *\n * @function Highcharts.Point#remove\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or wait for an explicit call. When\n * doing more operations on the chart, for example running\n * `point.remove()` in a loop, it is best practice to set `redraw`\n * to false and call `chart.redraw()` after.\n *\n * @param {boolean|Partial} [animation=false]\n * Whether to apply animation, and optionally animation\n * configuration.\n */\n Point.prototype.remove = function (redraw, animation) {\n this.series.removePoint(this.series.data.indexOf(this), redraw, animation);\n };\n /**\n * Toggle the selection status of a point.\n *\n * @see Highcharts.Chart#getSelectedPoints\n *\n * @sample highcharts/members/point-select/\n * Select a point from a button\n * @sample highcharts/chart/events-selection-points/\n * Select a range of points through a drag selection\n * @sample maps/series/data-id/\n * Select a point in Highmaps\n *\n * @function Highcharts.Point#select\n *\n * @param {boolean} [selected]\n * When `true`, the point is selected. When `false`, the point is\n * unselected. When `null` or `undefined`, the selection state is toggled.\n *\n * @param {boolean} [accumulate=false]\n * When `true`, the selection is added to other selected points.\n * When `false`, other selected points are deselected. Internally in\n * Highcharts, when\n * [allowPointSelect](https://api.highcharts.com/highcharts/plotOptions.series.allowPointSelect)\n * is `true`, selected points are accumulated on Control, Shift or Cmd\n * clicking the point.\n *\n * @emits Highcharts.Point#event:select\n * @emits Highcharts.Point#event:unselect\n */\n Point.prototype.select = function (selected, accumulate) {\n var point = this,\n series = point.series,\n chart = series.chart;\n selected = pick(selected, !point.selected);\n this.selectedStaging = selected;\n // fire the event with the default handler\n point.firePointEvent(selected ? 'select' : 'unselect', { accumulate: accumulate }, function () {\n /**\n * Whether the point is selected or not.\n *\n * @see Point#select\n * @see Chart#getSelectedPoints\n *\n * @name Highcharts.Point#selected\n * @type {boolean}\n */\n point.selected = point.options.selected = selected;\n series.options.data[series.data.indexOf(point)] =\n point.options;\n point.setState(selected && 'select');\n // unselect all other points unless Ctrl or Cmd + click\n if (!accumulate) {\n chart.getSelectedPoints().forEach(function (loopPoint) {\n var loopSeries = loopPoint.series;\n if (loopPoint.selected && loopPoint !== point) {\n loopPoint.selected = loopPoint.options.selected =\n false;\n loopSeries.options.data[loopSeries.data.indexOf(loopPoint)] = loopPoint.options;\n // Programatically selecting a point should restore\n // normal state, but when click happened on other\n // point, set inactive state to match other points\n loopPoint.setState(chart.hoverPoints &&\n loopSeries.options.inactiveOtherPoints ?\n 'inactive' : '');\n loopPoint.firePointEvent('unselect');\n }\n });\n }\n });\n delete this.selectedStaging;\n };\n /**\n * Runs on mouse over the point. Called internally from mouse and touch\n * events.\n *\n * @function Highcharts.Point#onMouseOver\n *\n * @param {Highcharts.PointerEventObject} [e]\n * The event arguments.\n */\n Point.prototype.onMouseOver = function (e) {\n var point = this,\n series = point.series,\n chart = series.chart,\n pointer = chart.pointer;\n e = e ?\n pointer.normalize(e) :\n // In cases where onMouseOver is called directly without an event\n pointer.getChartCoordinatesFromPoint(point, chart.inverted);\n pointer.runPointActions(e, point);\n };\n /**\n * Runs on mouse out from the point. Called internally from mouse and touch\n * events.\n *\n * @function Highcharts.Point#onMouseOut\n * @emits Highcharts.Point#event:mouseOut\n */\n Point.prototype.onMouseOut = function () {\n var point = this,\n chart = point.series.chart;\n point.firePointEvent('mouseOut');\n if (!point.series.options.inactiveOtherPoints) {\n (chart.hoverPoints || []).forEach(function (p) {\n p.setState();\n });\n }\n chart.hoverPoints = chart.hoverPoint = null;\n };\n /**\n * Import events from the series' and point's options. Only do it on\n * demand, to save processing time on hovering.\n *\n * @private\n * @function Highcharts.Point#importEvents\n */\n Point.prototype.importEvents = function () {\n if (!this.hasImportedEvents) {\n var point_1 = this,\n options = merge(point_1.series.options.point,\n point_1.options),\n events = options.events;\n point_1.events = events;\n objectEach(events, function (event, eventType) {\n if (isFunction(event)) {\n addEvent(point_1, eventType, event);\n }\n });\n this.hasImportedEvents = true;\n }\n };\n /**\n * Set the point's state.\n *\n * @function Highcharts.Point#setState\n *\n * @param {Highcharts.PointStateValue|\"\"} [state]\n * The new state, can be one of `'hover'`, `'select'`, `'inactive'`,\n * or `''` (an empty string), `'normal'` or `undefined` to set to\n * normal state.\n * @param {boolean} [move]\n * State for animation.\n *\n * @emits Highcharts.Point#event:afterSetState\n */\n Point.prototype.setState = function (state, move) {\n var point = this,\n series = point.series,\n previousState = point.state,\n stateOptions = (series.options.states[state || 'normal'] ||\n {}),\n markerOptions = (defaultOptions.plotOptions[series.type].marker &&\n series.options.marker),\n normalDisabled = (markerOptions && markerOptions.enabled === false),\n markerStateOptions = ((markerOptions &&\n markerOptions.states &&\n markerOptions.states[state || 'normal']) || {}),\n stateDisabled = markerStateOptions.enabled === false,\n pointMarker = point.marker || {},\n chart = series.chart,\n hasMarkers = (markerOptions && series.markerAttribs);\n var halo = series.halo,\n markerAttribs,\n pointAttribs,\n pointAttribsAnimation,\n stateMarkerGraphic = series.stateMarkerGraphic,\n newSymbol;\n state = state || ''; // empty string\n if (\n // already has this state\n (state === point.state && !move) ||\n // selected points don't respond to hover\n (point.selected && state !== 'select') ||\n // series' state options is disabled\n (stateOptions.enabled === false) ||\n // general point marker's state options is disabled\n (state && (stateDisabled ||\n (normalDisabled &&\n markerStateOptions.enabled === false))) ||\n // individual point marker's state options is disabled\n (state &&\n pointMarker.states &&\n pointMarker.states[state] &&\n pointMarker.states[state].enabled === false) // #1610\n ) {\n return;\n }\n point.state = state;\n if (hasMarkers) {\n markerAttribs = series.markerAttribs(point, state);\n }\n // Apply hover styles to the existing point\n // Prevent from mocked null points (#14966)\n if (point.graphic && !point.hasMockGraphic) {\n if (previousState) {\n point.graphic.removeClass('highcharts-point-' + previousState);\n }\n if (state) {\n point.graphic.addClass('highcharts-point-' + state);\n }\n if (!chart.styledMode) {\n pointAttribs = series.pointAttribs(point, state);\n pointAttribsAnimation = pick(chart.options.chart.animation, stateOptions.animation);\n var opacity_1 = pointAttribs.opacity;\n // Some inactive points (e.g. slices in pie) should apply\n // opacity also for their labels\n if (isNumber(opacity_1)) {\n (point.dataLabels || []).forEach(function (label) {\n if (label &&\n !label.hasClass('highcharts-data-label-hidden')) {\n label.animate({ opacity: opacity_1 }, pointAttribsAnimation);\n }\n });\n if (point.connector) {\n point.connector.animate({ opacity: opacity_1 }, pointAttribsAnimation);\n }\n }\n point.graphic.animate(pointAttribs, pointAttribsAnimation);\n }\n if (markerAttribs) {\n point.graphic.animate(markerAttribs, pick(\n // Turn off globally:\n chart.options.chart.animation, markerStateOptions.animation, markerOptions.animation));\n }\n // Zooming in from a range with no markers to a range with markers\n if (stateMarkerGraphic) {\n stateMarkerGraphic.hide();\n }\n }\n else {\n // if a graphic is not applied to each point in the normal state,\n // create a shared graphic for the hover state\n if (state && markerStateOptions) {\n newSymbol = pointMarker.symbol || series.symbol;\n // If the point has another symbol than the previous one, throw\n // away the state marker graphic and force a new one (#1459)\n if (stateMarkerGraphic &&\n stateMarkerGraphic.currentSymbol !== newSymbol) {\n stateMarkerGraphic = stateMarkerGraphic.destroy();\n }\n // Add a new state marker graphic\n if (markerAttribs) {\n if (!stateMarkerGraphic) {\n if (newSymbol) {\n series.stateMarkerGraphic = stateMarkerGraphic =\n chart.renderer\n .symbol(newSymbol, markerAttribs.x, markerAttribs.y, markerAttribs.width, markerAttribs.height)\n .add(series.markerGroup);\n stateMarkerGraphic.currentSymbol = newSymbol;\n }\n // Move the existing graphic\n }\n else {\n stateMarkerGraphic[move ? 'animate' : 'attr']({\n x: markerAttribs.x,\n y: markerAttribs.y\n });\n }\n }\n if (!chart.styledMode && stateMarkerGraphic &&\n point.state !== 'inactive') {\n stateMarkerGraphic.attr(series.pointAttribs(point, state));\n }\n }\n if (stateMarkerGraphic) {\n stateMarkerGraphic[state && point.isInside ? 'show' : 'hide'](); // #2450\n stateMarkerGraphic.element.point = point; // #4310\n stateMarkerGraphic.addClass(point.getClassName(), true);\n }\n }\n // Show me your halo\n var haloOptions = stateOptions.halo;\n var markerGraphic = (point.graphic || stateMarkerGraphic);\n var markerVisibility = (markerGraphic && markerGraphic.visibility || 'inherit');\n if (haloOptions &&\n haloOptions.size &&\n markerGraphic &&\n markerVisibility !== 'hidden' &&\n !point.isCluster) {\n if (!halo) {\n series.halo = halo = chart.renderer.path()\n // #5818, #5903, #6705\n .add(markerGraphic.parentGroup);\n }\n halo.show()[move ? 'animate' : 'attr']({\n d: point.haloPath(haloOptions.size)\n });\n halo.attr({\n 'class': 'highcharts-halo highcharts-color-' +\n pick(point.colorIndex, series.colorIndex) +\n (point.className ? ' ' + point.className : ''),\n 'visibility': markerVisibility,\n 'zIndex': -1 // #4929, #8276\n });\n halo.point = point; // #6055\n if (!chart.styledMode) {\n halo.attr(extend({\n 'fill': point.color || series.color,\n 'fill-opacity': haloOptions.opacity\n }, AST.filterUserAttributes(haloOptions.attributes || {})));\n }\n }\n else if (halo && halo.point && halo.point.haloPath) {\n // Animate back to 0 on the current halo point (#6055)\n halo.animate({ d: halo.point.haloPath(0) }, null, \n // Hide after unhovering. The `complete` callback runs in the\n // halo's context (#7681).\n halo.hide);\n }\n fireEvent(point, 'afterSetState', { state: state });\n };\n /**\n * Get the path definition for the halo, which is usually a shadow-like\n * circle around the currently hovered point.\n *\n * @function Highcharts.Point#haloPath\n *\n * @param {number} size\n * The radius of the circular halo.\n *\n * @return {Highcharts.SVGPathArray}\n * The path definition.\n */\n Point.prototype.haloPath = function (size) {\n var series = this.series,\n chart = series.chart;\n return chart.renderer.symbols.circle(Math.floor(this.plotX) - size, this.plotY - size, size * 2, size * 2);\n };\n return Point;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Function callback when a series point is clicked. Return false to cancel the\n * action.\n *\n * @callback Highcharts.PointClickCallbackFunction\n *\n * @param {Highcharts.Point} this\n * The point where the event occured.\n *\n * @param {Highcharts.PointClickEventObject} event\n * Event arguments.\n */\n /**\n * Common information for a click event on a series point.\n *\n * @interface Highcharts.PointClickEventObject\n * @extends Highcharts.PointerEventObject\n */ /**\n * Clicked point.\n * @name Highcharts.PointClickEventObject#point\n * @type {Highcharts.Point}\n */\n /**\n * Configuration for the data label and tooltip formatters.\n *\n * @interface Highcharts.PointLabelObject\n */ /**\n * The point's current color.\n * @name Highcharts.PointLabelObject#color\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject|undefined}\n */ /**\n * The point's current color index, used in styled mode instead of `color`. The\n * color index is inserted in class names used for styling.\n * @name Highcharts.PointLabelObject#colorIndex\n * @type {number}\n */ /**\n * The name of the related point.\n * @name Highcharts.PointLabelObject#key\n * @type {string|undefined}\n */ /**\n * The percentage for related points in a stacked series or pies.\n * @name Highcharts.PointLabelObject#percentage\n * @type {number}\n */ /**\n * The related point. The point name, if defined, is available through\n * `this.point.name`.\n * @name Highcharts.PointLabelObject#point\n * @type {Highcharts.Point}\n */ /**\n * The related series. The series name is available through `this.series.name`.\n * @name Highcharts.PointLabelObject#series\n * @type {Highcharts.Series}\n */ /**\n * The total of values in either a stack for stacked series, or a pie in a pie\n * series.\n * @name Highcharts.PointLabelObject#total\n * @type {number|undefined}\n */ /**\n * For categorized axes this property holds the category name for the point. For\n * other axes it holds the X value.\n * @name Highcharts.PointLabelObject#x\n * @type {number|string|undefined}\n */ /**\n * The y value of the point.\n * @name Highcharts.PointLabelObject#y\n * @type {number|null|undefined}\n */\n /**\n * Gets fired when the mouse leaves the area close to the point.\n *\n * @callback Highcharts.PointMouseOutCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {global.PointerEvent} event\n * Event that occured.\n */\n /**\n * Gets fired when the mouse enters the area close to the point.\n *\n * @callback Highcharts.PointMouseOverCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {global.Event} event\n * Event that occured.\n */\n /**\n * The generic point options for all series.\n *\n * In TypeScript you have to extend `PointOptionsObject` with an additional\n * declaration to allow custom data options:\n *\n * ```\n * declare interface PointOptionsObject {\n * customProperty: string;\n * }\n * ```\n *\n * @interface Highcharts.PointOptionsObject\n */\n /**\n * Possible option types for a data point. Use `null` to indicate a gap.\n *\n * @typedef {number|string|Highcharts.PointOptionsObject|Array<(number|string|null)>|null} Highcharts.PointOptionsType\n */\n /**\n * Gets fired when the point is removed using the `.remove()` method.\n *\n * @callback Highcharts.PointRemoveCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {global.Event} event\n * Event that occured.\n */\n /**\n * Possible key values for the point state options.\n *\n * @typedef {\"hover\"|\"inactive\"|\"normal\"|\"select\"} Highcharts.PointStateValue\n */\n /**\n * Gets fired when the point is updated programmatically through the `.update()`\n * method.\n *\n * @callback Highcharts.PointUpdateCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {Highcharts.PointUpdateEventObject} event\n * Event that occured.\n */\n /**\n * Information about the update event.\n *\n * @interface Highcharts.PointUpdateEventObject\n * @extends global.Event\n */ /**\n * Options data of the update event.\n * @name Highcharts.PointUpdateEventObject#options\n * @type {Highcharts.PointOptionsType}\n */\n /**\n * @interface Highcharts.PointEventsOptionsObject\n */ /**\n * Fires when the point is selected either programmatically or following a click\n * on the point. One parameter, `event`, is passed to the function. Returning\n * `false` cancels the operation.\n * @name Highcharts.PointEventsOptionsObject#select\n * @type {Highcharts.PointSelectCallbackFunction|undefined}\n */ /**\n * Fires when the point is unselected either programmatically or following a\n * click on the point. One parameter, `event`, is passed to the function.\n * Returning `false` cancels the operation.\n * @name Highcharts.PointEventsOptionsObject#unselect\n * @type {Highcharts.PointUnselectCallbackFunction|undefined}\n */\n /**\n * Information about the select/unselect event.\n *\n * @interface Highcharts.PointInteractionEventObject\n * @extends global.Event\n */ /**\n * @name Highcharts.PointInteractionEventObject#accumulate\n * @type {boolean}\n */\n /**\n * Gets fired when the point is selected either programmatically or following a\n * click on the point.\n *\n * @callback Highcharts.PointSelectCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {Highcharts.PointInteractionEventObject} event\n * Event that occured.\n */\n /**\n * Fires when the point is unselected either programmatically or following a\n * click on the point.\n *\n * @callback Highcharts.PointUnselectCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {Highcharts.PointInteractionEventObject} event\n * Event that occured.\n */\n ''; // keeps doclets above in JS file.\n\n return Point;\n });\n _registerModule(_modules, 'Core/Pointer.js', [_modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Tooltip.js'], _modules['Core/Utilities.js']], function (Color, H, Tooltip, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var color = Color.parse;\n var charts = H.charts,\n noop = H.noop;\n var addEvent = U.addEvent,\n attr = U.attr,\n css = U.css,\n defined = U.defined,\n extend = U.extend,\n find = U.find,\n fireEvent = U.fireEvent,\n isNumber = U.isNumber,\n isObject = U.isObject,\n objectEach = U.objectEach,\n offset = U.offset,\n pick = U.pick,\n splat = U.splat;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The mouse and touch tracker object. Each {@link Chart} item has one\n * associated Pointer item that can be accessed from the {@link Chart.pointer}\n * property.\n *\n * @class\n * @name Highcharts.Pointer\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.Options} options\n * The root options object. The pointer uses options from the chart and tooltip\n * structures.\n */\n var Pointer = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Pointer(chart, options) {\n this.lastValidTouch = {};\n this.pinchDown = [];\n this.runChartClick = false;\n this.eventsToUnbind = [];\n this.chart = chart;\n this.hasDragged = false;\n this.options = options;\n this.init(chart, options);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set inactive state to all series that are not currently hovered,\n * or, if `inactiveOtherPoints` is set to true, set inactive state to\n * all points within that series.\n *\n * @private\n * @function Highcharts.Pointer#applyInactiveState\n *\n * @param {Array} points\n * Currently hovered points\n */\n Pointer.prototype.applyInactiveState = function (points) {\n var activeSeries = [],\n series;\n // Get all active series from the hovered points\n (points || []).forEach(function (item) {\n series = item.series;\n // Include itself\n activeSeries.push(series);\n // Include parent series\n if (series.linkedParent) {\n activeSeries.push(series.linkedParent);\n }\n // Include all child series\n if (series.linkedSeries) {\n activeSeries = activeSeries.concat(series.linkedSeries);\n }\n // Include navigator series\n if (series.navigatorSeries) {\n activeSeries.push(series.navigatorSeries);\n }\n });\n // Now loop over all series, filtering out active series\n this.chart.series.forEach(function (inactiveSeries) {\n if (activeSeries.indexOf(inactiveSeries) === -1) {\n // Inactive series\n inactiveSeries.setState('inactive', true);\n }\n else if (inactiveSeries.options.inactiveOtherPoints) {\n // Active series, but other points should be inactivated\n inactiveSeries.setAllPointsToState('inactive');\n }\n });\n };\n /**\n * Destroys the Pointer object and disconnects DOM events.\n *\n * @function Highcharts.Pointer#destroy\n */\n Pointer.prototype.destroy = function () {\n var pointer = this;\n this.eventsToUnbind.forEach(function (unbind) { return unbind(); });\n this.eventsToUnbind = [];\n if (!H.chartCount) {\n if (Pointer.unbindDocumentMouseUp) {\n Pointer.unbindDocumentMouseUp = Pointer.unbindDocumentMouseUp();\n }\n if (Pointer.unbindDocumentTouchEnd) {\n Pointer.unbindDocumentTouchEnd = (Pointer.unbindDocumentTouchEnd());\n }\n }\n // memory and CPU leak\n clearInterval(pointer.tooltipTimeout);\n objectEach(pointer, function (_val, prop) {\n pointer[prop] = void 0;\n });\n };\n /**\n * Calculate attrs for selection marker.\n * @private\n * @function Highcharts.Pointer#getSelectionMarkerAttrs\n * @emits getSelectionMarkerAttrs\n */\n Pointer.prototype.getSelectionMarkerAttrs = function (chartX, chartY) {\n var _this = this;\n var e = {\n args: { chartX: chartX,\n chartY: chartY },\n attrs: {},\n shapeType: 'rect'\n };\n fireEvent(this, 'getSelectionMarkerAttrs', e, function (e) {\n var _a = _this,\n chart = _a.chart,\n _b = _a.mouseDownX,\n mouseDownX = _b === void 0 ? 0 : _b,\n _c = _a.mouseDownY,\n mouseDownY = _c === void 0 ? 0 : _c,\n zoomHor = _a.zoomHor,\n zoomVert = _a.zoomVert,\n attrs = e.attrs;\n var size;\n attrs.x = chart.plotLeft;\n attrs.y = chart.plotTop;\n attrs.width = zoomHor ? 1 : chart.plotWidth;\n attrs.height = zoomVert ? 1 : chart.plotHeight;\n // Adjust the width of the selection marker\n if (zoomHor) {\n size = chartX - mouseDownX;\n attrs.width = Math.abs(size);\n attrs.x = (size > 0 ? 0 : size) + mouseDownX;\n }\n // Adjust the height of the selection marker\n if (zoomVert) {\n size = chartY - mouseDownY;\n attrs.height = Math.abs(size);\n attrs.y = (size > 0 ? 0 : size) + mouseDownY;\n }\n });\n return e;\n };\n /**\n * Perform a drag operation in response to a mousemove event while the mouse\n * is down.\n * @private\n * @function Highcharts.Pointer#drag\n */\n Pointer.prototype.drag = function (e) {\n var chart = this.chart,\n chartOptions = chart.options.chart,\n plotLeft = chart.plotLeft,\n plotTop = chart.plotTop,\n plotWidth = chart.plotWidth,\n plotHeight = chart.plotHeight,\n mouseDownX = (this.mouseDownX || 0),\n mouseDownY = (this.mouseDownY || 0),\n panningEnabled = isObject(chartOptions.panning) ?\n chartOptions.panning && chartOptions.panning.enabled :\n chartOptions.panning,\n panKey = (chartOptions.panKey && e[chartOptions.panKey + 'Key']);\n var chartX = e.chartX,\n chartY = e.chartY,\n clickedInside,\n selectionMarker = this.selectionMarker;\n // If the device supports both touch and mouse (like IE11), and we are\n // touch-dragging inside the plot area, don't handle the mouse event.\n // #4339.\n if (selectionMarker && selectionMarker.touch) {\n return;\n }\n // If the mouse is outside the plot area, adjust to coordinates\n // inside to prevent the selection marker from going outside\n if (chartX < plotLeft) {\n chartX = plotLeft;\n }\n else if (chartX > plotLeft + plotWidth) {\n chartX = plotLeft + plotWidth;\n }\n if (chartY < plotTop) {\n chartY = plotTop;\n }\n else if (chartY > plotTop + plotHeight) {\n chartY = plotTop + plotHeight;\n }\n // determine if the mouse has moved more than 10px\n this.hasDragged = Math.sqrt(Math.pow(mouseDownX - chartX, 2) +\n Math.pow(mouseDownY - chartY, 2));\n if (this.hasDragged > 10) {\n clickedInside = chart.isInsidePlot(mouseDownX - plotLeft, mouseDownY - plotTop, {\n visiblePlotOnly: true\n });\n var _a = this.getSelectionMarkerAttrs(chartX,\n chartY),\n shapeType = _a.shapeType,\n attrs = _a.attrs;\n // make a selection\n if ((chart.hasCartesianSeries || chart.mapView) &&\n (this.zoomX || this.zoomY) &&\n clickedInside &&\n !panKey) {\n if (!selectionMarker) {\n this.selectionMarker = selectionMarker =\n chart.renderer[shapeType]();\n selectionMarker\n .attr({\n 'class': 'highcharts-selection-marker',\n zIndex: 7\n })\n .add();\n if (!chart.styledMode) {\n selectionMarker.attr({\n fill: chartOptions.selectionMarkerFill ||\n color(\"#335cad\" /* Palette.highlightColor80 */)\n .setOpacity(0.25).get()\n });\n }\n }\n }\n if (selectionMarker) {\n selectionMarker.attr(attrs);\n }\n // panning\n if (clickedInside &&\n !selectionMarker &&\n panningEnabled) {\n chart.pan(e, chartOptions.panning);\n }\n }\n };\n /**\n * Start a drag operation.\n * @private\n * @function Highcharts.Pointer#dragStart\n */\n Pointer.prototype.dragStart = function (e) {\n var chart = this.chart;\n // Record the start position\n chart.mouseIsDown = e.type;\n chart.cancelClick = false;\n chart.mouseDownX = this.mouseDownX = e.chartX;\n chart.mouseDownY = this.mouseDownY = e.chartY;\n };\n /**\n * Get selection box to calculate extremes\n * @private\n * @function Highcharts.Pointer#getSelectionBox\n * @emits getSelectionBox\n */\n Pointer.prototype.getSelectionBox = function (marker) {\n var e = {\n args: { marker: marker },\n result: {}\n };\n fireEvent(this, 'getSelectionBox', e, function (e) {\n e.result = {\n x: marker.attr ? +marker.attr('x') : marker.x,\n y: marker.attr ? +marker.attr('y') : marker.y,\n width: marker.attr ? marker.attr('width') : marker.width,\n height: marker.attr ? marker.attr('height') : marker.height\n };\n });\n return e.result;\n };\n /**\n * On mouse up or touch end across the entire document, drop the selection.\n * @private\n * @function Highcharts.Pointer#drop\n */\n Pointer.prototype.drop = function (e) {\n var pointer = this,\n chart = this.chart,\n hasPinched = this.hasPinched;\n if (this.selectionMarker) {\n var _a = this.getSelectionBox(this.selectionMarker),\n x_1 = _a.x,\n y_1 = _a.y,\n width_1 = _a.width,\n height_1 = _a.height;\n var selectionData_1 = {\n originalEvent: e,\n xAxis: [],\n yAxis: [],\n x: x_1,\n y: y_1,\n width: width_1,\n height: height_1\n }, \n // Start by false runZoom, unless when we have a mapView, in\n // which case the zoom will be handled in the selection event.\n runZoom_1 = Boolean(chart.mapView);\n // a selection has been made\n if (this.hasDragged || hasPinched) {\n // record each axis' min and max\n chart.axes.forEach(function (axis) {\n if (axis.zoomEnabled &&\n defined(axis.min) &&\n (hasPinched ||\n pointer[{\n xAxis: 'zoomX',\n yAxis: 'zoomY'\n }[axis.coll]]) &&\n isNumber(x_1) &&\n isNumber(y_1) &&\n isNumber(width_1) &&\n isNumber(height_1)) { // #859, #3569\n var horiz = axis.horiz,\n minPixelPadding = e.type === 'touchend' ?\n axis.minPixelPadding :\n 0, // #1207, #3075\n selectionMin = axis.toValue((horiz ? x_1 : y_1) + minPixelPadding),\n selectionMax = axis.toValue((horiz ? x_1 + width_1 : y_1 + height_1) -\n minPixelPadding);\n selectionData_1[axis.coll].push({\n axis: axis,\n // Min/max for reversed axes\n min: Math.min(selectionMin, selectionMax),\n max: Math.max(selectionMin, selectionMax)\n });\n runZoom_1 = true;\n }\n });\n if (runZoom_1) {\n fireEvent(chart, 'selection', selectionData_1, function (args) {\n chart.zoom(extend(args, hasPinched ?\n { animation: false } :\n null));\n });\n }\n }\n if (isNumber(chart.index)) {\n this.selectionMarker = this.selectionMarker.destroy();\n }\n // Reset scaling preview\n if (hasPinched) {\n this.scaleGroups();\n }\n }\n // Reset all. Check isNumber because it may be destroyed on mouse up\n // (#877)\n if (chart && isNumber(chart.index)) {\n css(chart.container, { cursor: chart._cursor });\n chart.cancelClick = this.hasDragged > 10; // #370\n chart.mouseIsDown = this.hasDragged = this.hasPinched = false;\n this.pinchDown = [];\n }\n };\n /**\n * Finds the closest point to a set of coordinates, using the k-d-tree\n * algorithm.\n *\n * @function Highcharts.Pointer#findNearestKDPoint\n *\n * @param {Array} series\n * All the series to search in.\n *\n * @param {boolean|undefined} shared\n * Whether it is a shared tooltip or not.\n *\n * @param {Highcharts.PointerEventObject} e\n * The pointer event object, containing chart coordinates of the pointer.\n *\n * @return {Highcharts.Point|undefined}\n * The point closest to given coordinates.\n */\n Pointer.prototype.findNearestKDPoint = function (series, shared, e) {\n var closest;\n /** @private */\n function sort(p1, p2) {\n var isCloserX = p1.distX - p2.distX,\n isCloser = p1.dist - p2.dist,\n isAbove = ((p2.series.group && p2.series.group.zIndex) -\n (p1.series.group && p1.series.group.zIndex));\n var result;\n // We have two points which are not in the same place on xAxis\n // and shared tooltip:\n if (isCloserX !== 0 && shared) { // #5721\n result = isCloserX;\n // Points are not exactly in the same place on x/yAxis:\n }\n else if (isCloser !== 0) {\n result = isCloser;\n // The same xAxis and yAxis position, sort by z-index:\n }\n else if (isAbove !== 0) {\n result = isAbove;\n // The same zIndex, sort by array index:\n }\n else {\n result =\n p1.series.index > p2.series.index ?\n -1 :\n 1;\n }\n return result;\n }\n series.forEach(function (s) {\n var noSharedTooltip = s.noSharedTooltip && shared,\n compareX = (!noSharedTooltip &&\n s.options.findNearestPointBy.indexOf('y') < 0),\n point = s.searchPoint(e,\n compareX);\n if ( // Check that we actually found a point on the series.\n isObject(point, true) && point.series &&\n // Use the new point if it is closer.\n (!isObject(closest, true) ||\n (sort(closest, point) > 0))) {\n closest = point;\n }\n });\n return closest;\n };\n /**\n * @private\n * @function Highcharts.Pointer#getChartCoordinatesFromPoint\n */\n Pointer.prototype.getChartCoordinatesFromPoint = function (point, inverted) {\n var series = point.series,\n xAxis = series.xAxis,\n yAxis = series.yAxis,\n shapeArgs = point.shapeArgs;\n if (xAxis && yAxis) {\n var x = pick(point.clientX,\n point.plotX);\n var y = point.plotY || 0;\n if (point.isNode &&\n shapeArgs &&\n isNumber(shapeArgs.x) &&\n isNumber(shapeArgs.y)) {\n x = shapeArgs.x;\n y = shapeArgs.y;\n }\n return inverted ? {\n chartX: yAxis.len + yAxis.pos - y,\n chartY: xAxis.len + xAxis.pos - x\n } : {\n chartX: x + xAxis.pos,\n chartY: y + yAxis.pos\n };\n }\n if (shapeArgs && shapeArgs.x && shapeArgs.y) {\n // E.g. pies do not have axes\n return {\n chartX: shapeArgs.x,\n chartY: shapeArgs.y\n };\n }\n };\n /**\n * Return the cached chartPosition if it is available on the Pointer,\n * otherwise find it. Running offset is quite expensive, so it should be\n * avoided when we know the chart hasn't moved.\n *\n * @function Highcharts.Pointer#getChartPosition\n *\n * @return {Highcharts.ChartPositionObject}\n * The offset of the chart container within the page\n */\n Pointer.prototype.getChartPosition = function () {\n if (this.chartPosition) {\n return this.chartPosition;\n }\n var container = this.chart.container;\n var pos = offset(container);\n this.chartPosition = {\n left: pos.left,\n top: pos.top,\n scaleX: 1,\n scaleY: 1\n };\n var offsetWidth = container.offsetWidth;\n var offsetHeight = container.offsetHeight;\n // #13342 - tooltip was not visible in Chrome, when chart\n // updates height.\n if (offsetWidth > 2 && // #13342\n offsetHeight > 2 // #13342\n ) {\n this.chartPosition.scaleX = pos.width / offsetWidth;\n this.chartPosition.scaleY = pos.height / offsetHeight;\n }\n return this.chartPosition;\n };\n /**\n * Get the click position in terms of axis values.\n *\n * @function Highcharts.Pointer#getCoordinates\n *\n * @param {Highcharts.PointerEventObject} e\n * Pointer event, extended with `chartX` and `chartY` properties.\n *\n * @return {Highcharts.PointerAxisCoordinatesObject}\n * Axis coordinates.\n */\n Pointer.prototype.getCoordinates = function (e) {\n var coordinates = {\n xAxis: [],\n yAxis: []\n };\n this.chart.axes.forEach(function (axis) {\n coordinates[axis.isXAxis ? 'xAxis' : 'yAxis'].push({\n axis: axis,\n value: axis.toValue(e[axis.horiz ? 'chartX' : 'chartY'])\n });\n });\n return coordinates;\n };\n /**\n * Calculates what is the current hovered point/points and series.\n *\n * @private\n * @function Highcharts.Pointer#getHoverData\n *\n * @param {Highcharts.Point|undefined} existingHoverPoint\n * The point currently being hovered.\n *\n * @param {Highcharts.Series|undefined} existingHoverSeries\n * The series currently being hovered.\n *\n * @param {Array} series\n * All the series in the chart.\n *\n * @param {boolean} isDirectTouch\n * Is the pointer directly hovering the point.\n *\n * @param {boolean|undefined} shared\n * Whether it is a shared tooltip or not.\n *\n * @param {Highcharts.PointerEventObject} [e]\n * The triggering event, containing chart coordinates of the pointer.\n *\n * @return {Object}\n * Object containing resulting hover data: hoverPoint, hoverSeries, and\n * hoverPoints.\n */\n Pointer.prototype.getHoverData = function (existingHoverPoint, existingHoverSeries, series, isDirectTouch, shared, e) {\n var hoverPoints = [],\n useExisting = !!(isDirectTouch && existingHoverPoint),\n filter = function (s) {\n return (s.visible &&\n !(!shared && s.directTouch) && // #3821\n pick(s.options.enableMouseTracking,\n true));\n };\n var hoverSeries = existingHoverSeries, \n // Which series to look in for the hover point\n searchSeries, \n // Parameters needed for beforeGetHoverData event.\n eventArgs = {\n chartX: e ? e.chartX : void 0,\n chartY: e ? e.chartY : void 0,\n shared: shared\n };\n // Find chart.hoverPane and update filter method in polar.\n fireEvent(this, 'beforeGetHoverData', eventArgs);\n var notSticky = hoverSeries && !hoverSeries.stickyTracking;\n searchSeries = notSticky ?\n // Only search on hovered series if it has stickyTracking false\n [hoverSeries] :\n // Filter what series to look in.\n series.filter(function (s) { return s.stickyTracking &&\n (eventArgs.filter || filter)(s); });\n // Use existing hovered point or find the one closest to coordinates.\n var hoverPoint = useExisting || !e ?\n existingHoverPoint :\n this.findNearestKDPoint(searchSeries,\n shared,\n e);\n // Assign hover series\n hoverSeries = hoverPoint && hoverPoint.series;\n // If we have a hoverPoint, assign hoverPoints.\n if (hoverPoint) {\n // When tooltip is shared, it displays more than one point\n if (shared && !hoverSeries.noSharedTooltip) {\n searchSeries = series.filter(function (s) {\n return eventArgs.filter ?\n eventArgs.filter(s) : filter(s) && !s.noSharedTooltip;\n });\n // Get all points with the same x value as the hoverPoint\n searchSeries.forEach(function (s) {\n var point = find(s.points,\n function (p) {\n return p.x === hoverPoint.x && !p.isNull;\n });\n if (isObject(point)) {\n /*\n * Boost returns a minimal point. Convert it to a usable\n * point for tooltip and states.\n */\n if (s.boosted && s.boost) {\n point = s.boost.getPoint(point);\n }\n hoverPoints.push(point);\n }\n });\n }\n else {\n hoverPoints.push(hoverPoint);\n }\n }\n // Check whether the hoverPoint is inside pane we are hovering over.\n eventArgs = { hoverPoint: hoverPoint };\n fireEvent(this, 'afterGetHoverData', eventArgs);\n return {\n hoverPoint: eventArgs.hoverPoint,\n hoverSeries: hoverSeries,\n hoverPoints: hoverPoints\n };\n };\n /**\n * @private\n * @function Highcharts.Pointer#getPointFromEvent\n */\n Pointer.prototype.getPointFromEvent = function (e) {\n var target = e.target,\n point;\n while (target && !point) {\n point = target.point;\n target = target.parentNode;\n }\n return point;\n };\n /**\n * @private\n * @function Highcharts.Pointer#onTrackerMouseOut\n */\n Pointer.prototype.onTrackerMouseOut = function (e) {\n var chart = this.chart;\n var relatedTarget = e.relatedTarget || e.toElement;\n var series = chart.hoverSeries;\n this.isDirectTouch = false;\n if (series &&\n relatedTarget &&\n !series.stickyTracking &&\n !this.inClass(relatedTarget, 'highcharts-tooltip') &&\n (!this.inClass(relatedTarget, 'highcharts-series-' + series.index) || // #2499, #4465, #5553\n !this.inClass(relatedTarget, 'highcharts-tracker'))) {\n series.onMouseOut();\n }\n };\n /**\n * Utility to detect whether an element has, or has a parent with, a\n * specific class name. Used on detection of tracker objects and on deciding\n * whether hovering the tooltip should cause the active series to mouse out.\n *\n * @function Highcharts.Pointer#inClass\n *\n * @param {Highcharts.SVGDOMElement|Highcharts.HTMLDOMElement} element\n * The element to investigate.\n *\n * @param {string} className\n * The class name to look for.\n *\n * @return {boolean|undefined}\n * True if either the element or one of its parents has the given class\n * name.\n */\n Pointer.prototype.inClass = function (element, className) {\n var elem = element,\n elemClassName;\n while (elem) {\n elemClassName = attr(elem, 'class');\n if (elemClassName) {\n if (elemClassName.indexOf(className) !== -1) {\n return true;\n }\n if (elemClassName.indexOf('highcharts-container') !== -1) {\n return false;\n }\n }\n elem = elem.parentElement;\n }\n };\n /**\n * Initialize the Pointer.\n *\n * @private\n * @function Highcharts.Pointer#init\n *\n * @param {Highcharts.Chart} chart\n * The Chart instance.\n *\n * @param {Highcharts.Options} options\n * The root options object. The pointer uses options from the chart and\n * tooltip structures.\n */\n Pointer.prototype.init = function (chart, options) {\n // Store references\n this.options = options;\n this.chart = chart;\n // Do we need to handle click on a touch device?\n this.runChartClick = Boolean(options.chart.events && options.chart.events.click);\n this.pinchDown = [];\n this.lastValidTouch = {};\n if (Tooltip) {\n /**\n * Tooltip object for points of series.\n *\n * @name Highcharts.Chart#tooltip\n * @type {Highcharts.Tooltip}\n */\n chart.tooltip = new Tooltip(chart, options.tooltip);\n }\n this.setDOMEvents();\n };\n /**\n * Takes a browser event object and extends it with custom Highcharts\n * properties `chartX` and `chartY` in order to work on the internal\n * coordinate system.\n *\n * On map charts, the properties `lon` and `lat` are added to the event\n * object given that the chart has projection information.\n *\n * @function Highcharts.Pointer#normalize\n *\n * @param {global.MouseEvent|global.PointerEvent|global.TouchEvent} e\n * Event object in standard browsers.\n *\n * @param {Highcharts.OffsetObject} [chartPosition]\n * Additional chart offset.\n *\n * @return {Highcharts.PointerEventObject}\n * A browser event with extended properties `chartX` and `chartY`.\n */\n Pointer.prototype.normalize = function (e, chartPosition) {\n var touches = e.touches;\n // iOS (#2757)\n var ePos = (touches ?\n touches.length ?\n touches.item(0) :\n (pick(// #13534\n touches.changedTouches,\n e.changedTouches))[0] :\n e);\n // Get mouse position\n if (!chartPosition) {\n chartPosition = this.getChartPosition();\n }\n var chartX = ePos.pageX - chartPosition.left,\n chartY = ePos.pageY - chartPosition.top;\n // #11329 - when there is scaling on a parent element, we need to take\n // this into account\n chartX /= chartPosition.scaleX;\n chartY /= chartPosition.scaleY;\n return extend(e, {\n chartX: Math.round(chartX),\n chartY: Math.round(chartY)\n });\n };\n /**\n * @private\n * @function Highcharts.Pointer#onContainerClick\n */\n Pointer.prototype.onContainerClick = function (e) {\n var chart = this.chart;\n var hoverPoint = chart.hoverPoint;\n var pEvt = this.normalize(e);\n var plotLeft = chart.plotLeft;\n var plotTop = chart.plotTop;\n if (!chart.cancelClick) {\n // On tracker click, fire the series and point events. #783, #1583\n if (hoverPoint &&\n this.inClass(pEvt.target, 'highcharts-tracker')) {\n // the series click event\n fireEvent(hoverPoint.series, 'click', extend(pEvt, {\n point: hoverPoint\n }));\n // the point click event\n if (chart.hoverPoint) { // it may be destroyed (#1844)\n hoverPoint.firePointEvent('click', pEvt);\n }\n // When clicking outside a tracker, fire a chart event\n }\n else {\n extend(pEvt, this.getCoordinates(pEvt));\n // fire a click event in the chart\n if (chart.isInsidePlot(pEvt.chartX - plotLeft, pEvt.chartY - plotTop, {\n visiblePlotOnly: true\n })) {\n fireEvent(chart, 'click', pEvt);\n }\n }\n }\n };\n /**\n * @private\n * @function Highcharts.Pointer#onContainerMouseDown\n */\n Pointer.prototype.onContainerMouseDown = function (e) {\n var isPrimaryButton = ((e.buttons || e.button) & 1) === 1;\n // Normalize before the 'if' for the legacy IE (#7850)\n e = this.normalize(e);\n // #11635, Firefox does not reliable fire move event after click scroll\n if (H.isFirefox &&\n e.button !== 0) {\n this.onContainerMouseMove(e);\n }\n // #11635, limiting to primary button (incl. IE 8 support)\n if (typeof e.button === 'undefined' ||\n isPrimaryButton) {\n this.zoomOption(e);\n // #295, #13737 solve conflict between container drag and chart zoom\n if (isPrimaryButton &&\n e.preventDefault) {\n e.preventDefault();\n }\n this.dragStart(e);\n }\n };\n /**\n * When mouse leaves the container, hide the tooltip.\n * @private\n * @function Highcharts.Pointer#onContainerMouseLeave\n */\n Pointer.prototype.onContainerMouseLeave = function (e) {\n var chart = charts[pick(Pointer.hoverChartIndex, -1)];\n var tooltip = this.chart.tooltip;\n e = this.normalize(e);\n // #4886, MS Touch end fires mouseleave but with no related target\n if (chart &&\n (e.relatedTarget || e.toElement)) {\n chart.pointer.reset();\n // Also reset the chart position, used in #149 fix\n chart.pointer.chartPosition = void 0;\n }\n // #11635, Firefox wheel scroll does not fire out events consistently\n if (tooltip && !tooltip.isHidden) {\n this.reset();\n }\n };\n /**\n * When mouse enters the container, delete pointer's chartPosition.\n * @private\n * @function Highcharts.Pointer#onContainerMouseEnter\n */\n Pointer.prototype.onContainerMouseEnter = function (e) {\n delete this.chartPosition;\n };\n /**\n * The mousemove, touchmove and touchstart event handler\n * @private\n * @function Highcharts.Pointer#onContainerMouseMove\n */\n Pointer.prototype.onContainerMouseMove = function (e) {\n var chart = this.chart,\n tooltip = chart.tooltip,\n pEvt = this.normalize(e);\n this.setHoverChartIndex();\n // In IE8 we apparently need this returnValue set to false in order to\n // avoid text being selected. But in Chrome, e.returnValue is prevented,\n // plus we don't need to run e.preventDefault to prevent selected text\n // in modern browsers. So we set it conditionally. Remove it when IE8 is\n // no longer needed. #2251, #3224.\n if (!pEvt.preventDefault) {\n pEvt.returnValue = false;\n }\n if (chart.mouseIsDown === 'mousedown' || this.touchSelect(pEvt)) {\n this.drag(pEvt);\n }\n // Show the tooltip and run mouse over events (#977)\n if (!chart.openMenu &&\n (this.inClass(pEvt.target, 'highcharts-tracker') ||\n chart.isInsidePlot(pEvt.chartX - chart.plotLeft, pEvt.chartY - chart.plotTop, {\n visiblePlotOnly: true\n })) &&\n // If the tooltip has stickOnContact enabled, do nothing. This\n // applies regardless of any combinations of the `split` and\n // `useHTML` options.\n !(tooltip &&\n tooltip.shouldStickOnContact(pEvt))) {\n if (this.inClass(pEvt.target, 'highcharts-no-tooltip')) {\n this.reset(false, 0);\n }\n else {\n this.runPointActions(pEvt);\n }\n }\n };\n /**\n * @private\n * @function Highcharts.Pointer#onDocumentTouchEnd\n */\n Pointer.prototype.onDocumentTouchEnd = function (e) {\n var hoverChart = charts[pick(Pointer.hoverChartIndex, -1)];\n if (hoverChart) {\n hoverChart.pointer.drop(e);\n }\n };\n /**\n * @private\n * @function Highcharts.Pointer#onContainerTouchMove\n */\n Pointer.prototype.onContainerTouchMove = function (e) {\n if (this.touchSelect(e)) {\n this.onContainerMouseMove(e);\n }\n else {\n this.touch(e);\n }\n };\n /**\n * @private\n * @function Highcharts.Pointer#onContainerTouchStart\n */\n Pointer.prototype.onContainerTouchStart = function (e) {\n if (this.touchSelect(e)) {\n this.onContainerMouseDown(e);\n }\n else {\n this.zoomOption(e);\n this.touch(e, true);\n }\n };\n /**\n * Special handler for mouse move that will hide the tooltip when the mouse\n * leaves the plotarea. Issue #149 workaround. The mouseleave event does not\n * always fire.\n * @private\n * @function Highcharts.Pointer#onDocumentMouseMove\n */\n Pointer.prototype.onDocumentMouseMove = function (e) {\n var chart = this.chart;\n var tooltip = chart.tooltip;\n var chartPosition = this.chartPosition;\n var pEvt = this.normalize(e,\n chartPosition);\n // If we're outside, hide the tooltip\n if (chartPosition &&\n !chart.isInsidePlot(pEvt.chartX - chart.plotLeft, pEvt.chartY - chart.plotTop, {\n visiblePlotOnly: true\n }) &&\n !(tooltip &&\n tooltip.shouldStickOnContact(pEvt)) &&\n !this.inClass(pEvt.target, 'highcharts-tracker')) {\n this.reset();\n }\n };\n /**\n * @private\n * @function Highcharts.Pointer#onDocumentMouseUp\n */\n Pointer.prototype.onDocumentMouseUp = function (e) {\n var chart = charts[pick(Pointer.hoverChartIndex, -1)];\n if (chart) {\n chart.pointer.drop(e);\n }\n };\n /**\n * Handle touch events with two touches\n * @private\n * @function Highcharts.Pointer#pinch\n */\n Pointer.prototype.pinch = function (e) {\n var self = this,\n chart = self.chart,\n pinchDown = self.pinchDown,\n touches = (e.touches || []),\n touchesLength = touches.length,\n lastValidTouch = self.lastValidTouch,\n hasZoom = self.hasZoom,\n transform = {},\n fireClickEvent = touchesLength === 1 && ((self.inClass(e.target, 'highcharts-tracker') &&\n chart.runTrackerClick) ||\n self.runChartClick),\n clip = {},\n tooltip = self.chart.tooltip,\n followTouchMove = touchesLength === 1 &&\n pick((tooltip && tooltip.options.followTouchMove),\n true);\n var selectionMarker = self.selectionMarker;\n // Don't initiate panning until the user has pinched. This prevents us\n // from blocking page scrolling as users scroll down a long page\n // (#4210).\n if (touchesLength > 1) {\n self.initiated = true;\n }\n else if (followTouchMove) {\n // #16119: Prevent blocking scroll when single-finger panning is\n // not enabled\n self.initiated = false;\n }\n // On touch devices, only proceed to trigger click if a handler is\n // defined\n if (hasZoom &&\n self.initiated &&\n !fireClickEvent &&\n e.cancelable !== false) {\n e.preventDefault();\n }\n // Normalize each touch\n [].map.call(touches, function (e) {\n return self.normalize(e);\n });\n // Register the touch start position\n if (e.type === 'touchstart') {\n [].forEach.call(touches, function (e, i) {\n pinchDown[i] = { chartX: e.chartX, chartY: e.chartY };\n });\n lastValidTouch.x = [pinchDown[0].chartX, pinchDown[1] &&\n pinchDown[1].chartX];\n lastValidTouch.y = [pinchDown[0].chartY, pinchDown[1] &&\n pinchDown[1].chartY];\n // Identify the data bounds in pixels\n chart.axes.forEach(function (axis) {\n if (axis.zoomEnabled) {\n var bounds = chart.bounds[axis.horiz ? 'h' : 'v'],\n minPixelPadding = axis.minPixelPadding,\n min = axis.toPixels(Math.min(pick(axis.options.min,\n axis.dataMin),\n axis.dataMin)),\n max = axis.toPixels(Math.max(pick(axis.options.max,\n axis.dataMax),\n axis.dataMax)),\n absMin = Math.min(min,\n max),\n absMax = Math.max(min,\n max);\n // Store the bounds for use in the touchmove handler\n bounds.min = Math.min(axis.pos, absMin - minPixelPadding);\n bounds.max = Math.max(axis.pos + axis.len, absMax + minPixelPadding);\n }\n });\n self.res = true; // reset on next move\n // Optionally move the tooltip on touchmove\n }\n else if (followTouchMove) {\n this.runPointActions(self.normalize(e));\n // Event type is touchmove, handle panning and pinching\n }\n else if (pinchDown.length) { // can be 0 when releasing, if touchend\n // fires first\n fireEvent(chart, 'touchpan', { originalEvent: e }, function () {\n // Set the marker\n if (!selectionMarker) {\n // @todo It's a mock object, so maybe we need a separate\n // interface\n self.selectionMarker = selectionMarker = extend({\n destroy: noop,\n touch: true\n }, chart.plotBox);\n }\n self.pinchTranslate(pinchDown, touches, transform, selectionMarker, clip, lastValidTouch);\n self.hasPinched = hasZoom;\n // Scale and translate the groups to provide visual feedback\n // during pinching\n self.scaleGroups(transform, clip);\n });\n if (self.res) {\n self.res = false;\n this.reset(false, 0);\n }\n }\n };\n /**\n * Run translation operations\n * @private\n * @function Highcharts.Pointer#pinchTranslate\n */\n Pointer.prototype.pinchTranslate = function (pinchDown, touches, transform, selectionMarker, clip, lastValidTouch) {\n if (this.zoomHor) {\n this.pinchTranslateDirection(true, pinchDown, touches, transform, selectionMarker, clip, lastValidTouch);\n }\n if (this.zoomVert) {\n this.pinchTranslateDirection(false, pinchDown, touches, transform, selectionMarker, clip, lastValidTouch);\n }\n };\n /**\n * Run translation operations for each direction (horizontal and vertical)\n * independently.\n * @private\n * @function Highcharts.Pointer#pinchTranslateDirection\n */\n Pointer.prototype.pinchTranslateDirection = function (horiz, pinchDown, touches, transform, selectionMarker, clip, lastValidTouch, forcedScale) {\n var chart = this.chart, xy = horiz ? 'x' : 'y', XY = horiz ? 'X' : 'Y', sChartXY = ('chart' + XY), wh = horiz ? 'width' : 'height', plotLeftTop = chart['plot' + (horiz ? 'Left' : 'Top')], inverted = chart.inverted, bounds = chart.bounds[horiz ? 'h' : 'v'], singleTouch = pinchDown.length === 1, touch0Start = pinchDown[0][sChartXY], touch1Start = !singleTouch && pinchDown[1][sChartXY], setScale = function () {\n // Don't zoom if fingers are too close on this axis\n if (typeof touch1Now === 'number' &&\n Math.abs(touch0Start - touch1Start) > 20) {\n scale = forcedScale ||\n Math.abs(touch0Now - touch1Now) /\n Math.abs(touch0Start - touch1Start);\n }\n clipXY = ((plotLeftTop - touch0Now) / scale) + touch0Start;\n selectionWH = chart['plot' + (horiz ? 'Width' : 'Height')] / scale;\n };\n var selectionWH,\n selectionXY,\n clipXY,\n scale = forcedScale || 1,\n touch0Now = touches[0][sChartXY],\n touch1Now = !singleTouch && touches[1][sChartXY],\n outOfBounds;\n // Set the scale, first pass\n setScale();\n // The clip position (x or y) is altered if out of bounds, the selection\n // position is not\n selectionXY = clipXY;\n // Out of bounds\n if (selectionXY < bounds.min) {\n selectionXY = bounds.min;\n outOfBounds = true;\n }\n else if (selectionXY + selectionWH > bounds.max) {\n selectionXY = bounds.max - selectionWH;\n outOfBounds = true;\n }\n // Is the chart dragged off its bounds, determined by dataMin and\n // dataMax?\n if (outOfBounds) {\n // Modify the touchNow position in order to create an elastic drag\n // movement. This indicates to the user that the chart is responsive\n // but can't be dragged further.\n touch0Now -= 0.8 * (touch0Now - lastValidTouch[xy][0]);\n if (typeof touch1Now === 'number') {\n touch1Now -= 0.8 * (touch1Now - lastValidTouch[xy][1]);\n }\n // Set the scale, second pass to adapt to the modified touchNow\n // positions\n setScale();\n }\n else {\n lastValidTouch[xy] = [touch0Now, touch1Now];\n }\n // Set geometry for clipping, selection and transformation\n if (!inverted) {\n clip[xy] = clipXY - plotLeftTop;\n clip[wh] = selectionWH;\n }\n var scaleKey = inverted ?\n (horiz ? 'scaleY' : 'scaleX') : 'scale' + XY;\n var transformScale = inverted ? 1 / scale : scale;\n selectionMarker[wh] = selectionWH;\n selectionMarker[xy] = selectionXY;\n transform[scaleKey] = scale;\n transform['translate' + XY] = (transformScale * plotLeftTop) +\n (touch0Now - (transformScale * touch0Start));\n };\n /**\n * Reset the tracking by hiding the tooltip, the hover series state and the\n * hover point\n *\n * @function Highcharts.Pointer#reset\n *\n * @param {boolean} [allowMove]\n * Instead of destroying the tooltip altogether, allow moving it if\n * possible.\n *\n * @param {number} [delay]\n */\n Pointer.prototype.reset = function (allowMove, delay) {\n var pointer = this,\n chart = pointer.chart,\n hoverSeries = chart.hoverSeries,\n hoverPoint = chart.hoverPoint,\n hoverPoints = chart.hoverPoints,\n tooltip = chart.tooltip,\n tooltipPoints = tooltip && tooltip.shared ?\n hoverPoints :\n hoverPoint;\n // Check if the points have moved outside the plot area (#1003, #4736,\n // #5101)\n if (allowMove && tooltipPoints) {\n splat(tooltipPoints).forEach(function (point) {\n if (point.series.isCartesian &&\n typeof point.plotX === 'undefined') {\n allowMove = false;\n }\n });\n }\n // Just move the tooltip, #349\n if (allowMove) {\n if (tooltip && tooltipPoints && splat(tooltipPoints).length) {\n tooltip.refresh(tooltipPoints);\n if (tooltip.shared && hoverPoints) { // #8284\n hoverPoints.forEach(function (point) {\n point.setState(point.state, true);\n if (point.series.isCartesian) {\n if (point.series.xAxis.crosshair) {\n point.series.xAxis\n .drawCrosshair(null, point);\n }\n if (point.series.yAxis.crosshair) {\n point.series.yAxis\n .drawCrosshair(null, point);\n }\n }\n });\n }\n else if (hoverPoint) { // #2500\n hoverPoint.setState(hoverPoint.state, true);\n chart.axes.forEach(function (axis) {\n if (axis.crosshair &&\n hoverPoint.series[axis.coll] === axis) {\n axis.drawCrosshair(null, hoverPoint);\n }\n });\n }\n }\n // Full reset\n }\n else {\n if (hoverPoint) {\n hoverPoint.onMouseOut();\n }\n if (hoverPoints) {\n hoverPoints.forEach(function (point) {\n point.setState();\n });\n }\n if (hoverSeries) {\n hoverSeries.onMouseOut();\n }\n if (tooltip) {\n tooltip.hide(delay);\n }\n if (pointer.unDocMouseMove) {\n pointer.unDocMouseMove = pointer.unDocMouseMove();\n }\n // Remove crosshairs\n chart.axes.forEach(function (axis) {\n axis.hideCrosshair();\n });\n pointer.hoverX = chart.hoverPoints = chart.hoverPoint = null;\n }\n };\n /**\n * With line type charts with a single tracker, get the point closest to the\n * mouse. Run Point.onMouseOver and display tooltip for the point or points.\n *\n * @private\n * @function Highcharts.Pointer#runPointActions\n *\n * @emits Highcharts.Point#event:mouseOut\n * @emits Highcharts.Point#event:mouseOver\n */\n Pointer.prototype.runPointActions = function (e, p) {\n var pointer = this,\n chart = pointer.chart,\n series = chart.series,\n tooltip = (chart.tooltip && chart.tooltip.options.enabled ?\n chart.tooltip :\n void 0),\n shared = (tooltip ?\n tooltip.shared :\n false);\n var hoverPoint = p || chart.hoverPoint,\n hoverSeries = hoverPoint && hoverPoint.series || chart.hoverSeries;\n var // onMouseOver or already hovering a series with directTouch\n isDirectTouch = (!e || e.type !== 'touchmove') && (!!p || ((hoverSeries && hoverSeries.directTouch) &&\n pointer.isDirectTouch)),\n hoverData = this.getHoverData(hoverPoint,\n hoverSeries,\n series,\n isDirectTouch,\n shared,\n e);\n // Update variables from hoverData.\n hoverPoint = hoverData.hoverPoint;\n hoverSeries = hoverData.hoverSeries;\n var points = hoverData.hoverPoints,\n followPointer = hoverSeries &&\n hoverSeries.tooltipOptions.followPointer &&\n !hoverSeries.tooltipOptions.split,\n useSharedTooltip = (shared &&\n hoverSeries &&\n !hoverSeries.noSharedTooltip);\n // Refresh tooltip for kdpoint if new hover point or tooltip was hidden\n // #3926, #4200\n if (hoverPoint &&\n // !(hoverSeries && hoverSeries.directTouch) &&\n (hoverPoint !== chart.hoverPoint || (tooltip && tooltip.isHidden))) {\n (chart.hoverPoints || []).forEach(function (p) {\n if (points.indexOf(p) === -1) {\n p.setState();\n }\n });\n // Set normal state to previous series\n if (chart.hoverSeries !== hoverSeries) {\n hoverSeries.onMouseOver();\n }\n pointer.applyInactiveState(points);\n // Do mouseover on all points (#3919, #3985, #4410, #5622)\n (points || []).forEach(function (p) {\n p.setState('hover');\n });\n // If tracking is on series in stead of on each point,\n // fire mouseOver on hover point. // #4448\n if (chart.hoverPoint) {\n chart.hoverPoint.firePointEvent('mouseOut');\n }\n // Hover point may have been destroyed in the event handlers (#7127)\n if (!hoverPoint.series) {\n return;\n }\n /**\n * Contains all hovered points.\n *\n * @name Highcharts.Chart#hoverPoints\n * @type {Array|null}\n */\n chart.hoverPoints = points;\n /**\n * Contains the original hovered point.\n *\n * @name Highcharts.Chart#hoverPoint\n * @type {Highcharts.Point|null}\n */\n chart.hoverPoint = hoverPoint;\n /**\n * Hover state should not be lost when axis is updated (#12569)\n * Axis.update runs pointer.reset which uses chart.hoverPoint.state\n * to apply state which does not exist in hoverPoint yet.\n * The mouseOver event should be triggered when hoverPoint\n * is correct.\n */\n hoverPoint.firePointEvent('mouseOver', void 0, function () {\n // Draw tooltip if necessary\n if (tooltip && hoverPoint) {\n tooltip.refresh(useSharedTooltip ? points : hoverPoint, e);\n }\n });\n // Update positions (regardless of kdpoint or hoverPoint)\n }\n else if (followPointer && tooltip && !tooltip.isHidden) {\n var anchor = tooltip.getAnchor([{}],\n e);\n if (chart.isInsidePlot(anchor[0], anchor[1], {\n visiblePlotOnly: true\n })) {\n tooltip.updatePosition({ plotX: anchor[0], plotY: anchor[1] });\n }\n }\n // Start the event listener to pick up the tooltip and crosshairs\n if (!pointer.unDocMouseMove) {\n pointer.unDocMouseMove = addEvent(chart.container.ownerDocument, 'mousemove', function (e) {\n var chart = charts[Pointer.hoverChartIndex];\n if (chart) {\n chart.pointer.onDocumentMouseMove(e);\n }\n });\n pointer.eventsToUnbind.push(pointer.unDocMouseMove);\n }\n // Issues related to crosshair #4927, #5269 #5066, #5658\n chart.axes.forEach(function drawAxisCrosshair(axis) {\n var snap = pick((axis.crosshair || {}).snap,\n true);\n var point;\n if (snap) {\n point = chart.hoverPoint; // #13002\n if (!point || point.series[axis.coll] !== axis) {\n point = find(points, function (p) {\n return p.series && p.series[axis.coll] === axis;\n });\n }\n }\n // Axis has snapping crosshairs, and one of the hover points belongs\n // to axis. Always call drawCrosshair when it is not snap.\n if (point || !snap) {\n axis.drawCrosshair(e, point);\n // Axis has snapping crosshairs, but no hover point belongs to axis\n }\n else {\n axis.hideCrosshair();\n }\n });\n };\n /**\n * Scale series groups to a certain scale and translation.\n * @private\n * @function Highcharts.Pointer#scaleGroups\n */\n Pointer.prototype.scaleGroups = function (attribs, clip) {\n var chart = this.chart;\n // Scale each series\n chart.series.forEach(function (series) {\n var seriesAttribs = attribs || series.getPlotBox(); // #1701\n if (series.group &&\n ((series.xAxis && series.xAxis.zoomEnabled) ||\n chart.mapView)) {\n series.group.attr(seriesAttribs);\n if (series.markerGroup) {\n series.markerGroup.attr(seriesAttribs);\n series.markerGroup.clip(clip ? chart.clipRect : null);\n }\n if (series.dataLabelsGroup) {\n series.dataLabelsGroup.attr(seriesAttribs);\n }\n }\n });\n // Clip\n chart.clipRect.attr(clip || chart.clipBox);\n };\n /**\n * Set the JS DOM events on the container and document. This method should\n * contain a one-to-one assignment between methods and their handlers. Any\n * advanced logic should be moved to the handler reflecting the event's\n * name.\n * @private\n * @function Highcharts.Pointer#setDOMEvents\n */\n Pointer.prototype.setDOMEvents = function () {\n var _this = this;\n var container = this.chart.container,\n ownerDoc = container.ownerDocument;\n container.onmousedown = this.onContainerMouseDown.bind(this);\n container.onmousemove = this.onContainerMouseMove.bind(this);\n container.onclick = this.onContainerClick.bind(this);\n this.eventsToUnbind.push(addEvent(container, 'mouseenter', this.onContainerMouseEnter.bind(this)));\n this.eventsToUnbind.push(addEvent(container, 'mouseleave', this.onContainerMouseLeave.bind(this)));\n if (!Pointer.unbindDocumentMouseUp) {\n Pointer.unbindDocumentMouseUp = addEvent(ownerDoc, 'mouseup', this.onDocumentMouseUp.bind(this));\n }\n // In case we are dealing with overflow, reset the chart position when\n // scrolling parent elements\n var parent = this.chart.renderTo.parentElement;\n while (parent && parent.tagName !== 'BODY') {\n this.eventsToUnbind.push(addEvent(parent, 'scroll', function () {\n delete _this.chartPosition;\n }));\n parent = parent.parentElement;\n }\n if (H.hasTouch) {\n this.eventsToUnbind.push(addEvent(container, 'touchstart', this.onContainerTouchStart.bind(this), { passive: false }));\n this.eventsToUnbind.push(addEvent(container, 'touchmove', this.onContainerTouchMove.bind(this), { passive: false }));\n if (!Pointer.unbindDocumentTouchEnd) {\n Pointer.unbindDocumentTouchEnd = addEvent(ownerDoc, 'touchend', this.onDocumentTouchEnd.bind(this), { passive: false });\n }\n }\n };\n /**\n * Sets the index of the hovered chart and leaves the previous hovered\n * chart, to reset states like tooltip.\n * @private\n * @function Highcharts.Pointer#setHoverChartIndex\n */\n Pointer.prototype.setHoverChartIndex = function () {\n var chart = this.chart;\n var hoverChart = H.charts[pick(Pointer.hoverChartIndex, -1)];\n if (hoverChart &&\n hoverChart !== chart) {\n hoverChart.pointer.onContainerMouseLeave({ relatedTarget: chart.container });\n }\n if (!hoverChart ||\n !hoverChart.mouseIsDown) {\n Pointer.hoverChartIndex = chart.index;\n }\n };\n /**\n * General touch handler shared by touchstart and touchmove.\n * @private\n * @function Highcharts.Pointer#touch\n */\n Pointer.prototype.touch = function (e, start) {\n var chart = this.chart;\n var hasMoved,\n pinchDown,\n isInside;\n this.setHoverChartIndex();\n if (e.touches.length === 1) {\n e = this.normalize(e);\n isInside = chart.isInsidePlot(e.chartX - chart.plotLeft, e.chartY - chart.plotTop, {\n visiblePlotOnly: true\n });\n if (isInside && !chart.openMenu) {\n // Run mouse events and display tooltip etc\n if (start) {\n this.runPointActions(e);\n }\n // Android fires touchmove events after the touchstart even if\n // the finger hasn't moved, or moved only a pixel or two. In iOS\n // however, the touchmove doesn't fire unless the finger moves\n // more than ~4px. So we emulate this behaviour in Android by\n // checking how much it moved, and cancelling on small\n // distances. #3450.\n if (e.type === 'touchmove') {\n pinchDown = this.pinchDown;\n hasMoved = pinchDown[0] ? Math.sqrt(// #5266\n Math.pow(pinchDown[0].chartX - e.chartX, 2) +\n Math.pow(pinchDown[0].chartY - e.chartY, 2)) >= 4 : false;\n }\n if (pick(hasMoved, true)) {\n this.pinch(e);\n }\n }\n else if (start) {\n // Hide the tooltip on touching outside the plot area (#1203)\n this.reset();\n }\n }\n else if (e.touches.length === 2) {\n this.pinch(e);\n }\n };\n /**\n * Returns true if the chart is set up for zooming by single touch and the\n * event is capable\n * @private\n * @function Highcharts.Pointer#touchSelect\n */\n Pointer.prototype.touchSelect = function (e) {\n return Boolean(this.chart.options.chart.zooming.singleTouch &&\n e.touches &&\n e.touches.length === 1);\n };\n /**\n * Resolve the zoomType option, this is reset on all touch start and mouse\n * down events.\n * @private\n * @function Highcharts.Pointer#zoomOption\n */\n Pointer.prototype.zoomOption = function (e) {\n var chart = this.chart,\n options = chart.options.chart,\n inverted = chart.inverted;\n var zoomType = options.zooming.type || '',\n zoomX,\n zoomY;\n // Look for the pinchType option\n if (/touch/.test(e.type)) {\n zoomType = pick(options.zooming.pinchType, zoomType);\n }\n this.zoomX = zoomX = /x/.test(zoomType);\n this.zoomY = zoomY = /y/.test(zoomType);\n this.zoomHor = (zoomX && !inverted) || (zoomY && inverted);\n this.zoomVert = (zoomY && !inverted) || (zoomX && inverted);\n this.hasZoom = zoomX || zoomY;\n };\n return Pointer;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Chart position and scale.\n *\n * @interface Highcharts.ChartPositionObject\n */ /**\n * @name Highcharts.ChartPositionObject#left\n * @type {number}\n */ /**\n * @name Highcharts.ChartPositionObject#scaleX\n * @type {number}\n */ /**\n * @name Highcharts.ChartPositionObject#scaleY\n * @type {number}\n */ /**\n * @name Highcharts.ChartPositionObject#top\n * @type {number}\n */\n /**\n * One position in relation to an axis.\n *\n * @interface Highcharts.PointerAxisCoordinateObject\n */ /**\n * Related axis.\n *\n * @name Highcharts.PointerAxisCoordinateObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * Axis value.\n *\n * @name Highcharts.PointerAxisCoordinateObject#value\n * @type {number}\n */\n /**\n * Positions in terms of axis values.\n *\n * @interface Highcharts.PointerAxisCoordinatesObject\n */ /**\n * Positions on the x-axis.\n * @name Highcharts.PointerAxisCoordinatesObject#xAxis\n * @type {Array}\n */ /**\n * Positions on the y-axis.\n * @name Highcharts.PointerAxisCoordinatesObject#yAxis\n * @type {Array}\n */\n /**\n * Pointer coordinates.\n *\n * @interface Highcharts.PointerCoordinatesObject\n */ /**\n * @name Highcharts.PointerCoordinatesObject#chartX\n * @type {number}\n */ /**\n * @name Highcharts.PointerCoordinatesObject#chartY\n * @type {number}\n */\n /**\n * A native browser mouse or touch event, extended with position information\n * relative to the {@link Chart.container}.\n *\n * @interface Highcharts.PointerEventObject\n * @extends global.PointerEvent\n */ /**\n * The X coordinate of the pointer interaction relative to the chart.\n *\n * @name Highcharts.PointerEventObject#chartX\n * @type {number}\n */ /**\n * The Y coordinate of the pointer interaction relative to the chart.\n *\n * @name Highcharts.PointerEventObject#chartY\n * @type {number}\n */\n /**\n * Axis-specific data of a selection.\n *\n * @interface Highcharts.SelectDataObject\n */ /**\n * The selected Axis.\n * @name Highcharts.SelectDataObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * The maximum axis value, either automatic or set manually.\n * @name Highcharts.SelectDataObject#max\n * @type {number}\n */ /**\n * The minimum axis value, either automatic or set manually.\n * @name Highcharts.SelectDataObject#min\n * @type {number}\n */\n /**\n * Object for select events.\n * The primary axes are `xAxis[0]` and `yAxis[0]`. Remember the unit of a\n * datetime axis is milliseconds since 1970-01-01 00:00:00.\n *\n * @interface Highcharts.SelectEventObject\n */ /**\n * The related browser event.\n * @name Highcharts.SelectEventObject#originalEvent\n * @type {global.Event}\n */ /**\n * Indicates a reset event to restore default state.\n * @name Highcharts.SelectEventObject#resetSelection\n * @type {boolean|undefined}\n */ /**\n * Arrays containing the axes of each dimension and each axis' min and max\n * values.\n * @name Highcharts.SelectEventObject#xAxis\n * @type {Array}\n */ /**\n * Arrays containing the axes of each dimension and each axis' min and max\n * values.\n * @name Highcharts.SelectEventObject#yAxis\n * @type {Array}\n */\n ''; // keeps doclets above in JS file\n\n return Pointer;\n });\n _registerModule(_modules, 'Core/MSPointer.js', [_modules['Core/Globals.js'], _modules['Core/Pointer.js'], _modules['Core/Utilities.js']], function (H, Pointer, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var charts = H.charts,\n doc = H.doc,\n noop = H.noop,\n win = H.win;\n var addEvent = U.addEvent,\n css = U.css,\n objectEach = U.objectEach,\n pick = U.pick,\n removeEvent = U.removeEvent;\n /* *\n *\n * Constants\n *\n * */\n // The touches object keeps track of the points being touched at all times\n var touches = {};\n var hasPointerEvent = !!win.PointerEvent;\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /** @private */\n function getWebkitTouches() {\n var fake = [];\n fake.item = function (i) {\n return this[i];\n };\n objectEach(touches, function (touch) {\n fake.push({\n pageX: touch.pageX,\n pageY: touch.pageY,\n target: touch.target\n });\n });\n return fake;\n }\n /** @private */\n function translateMSPointer(e, method, wktype, func) {\n var chart = charts[Pointer.hoverChartIndex || NaN];\n if ((e.pointerType === 'touch' ||\n e.pointerType === e.MSPOINTER_TYPE_TOUCH) && chart) {\n var p = chart.pointer;\n func(e);\n p[method]({\n type: wktype,\n target: e.currentTarget,\n preventDefault: noop,\n touches: getWebkitTouches()\n });\n }\n }\n /* *\n *\n * Class\n *\n * */\n /** @private */\n var MSPointer = /** @class */ (function (_super) {\n __extends(MSPointer, _super);\n function MSPointer() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n /* *\n *\n * Static Functions\n *\n * */\n MSPointer.isRequired = function () {\n return !!(!H.hasTouch && (win.PointerEvent || win.MSPointerEvent));\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Add or remove the MS Pointer specific events\n * @private\n * @function Highcharts.Pointer#batchMSEvents\n */\n MSPointer.prototype.batchMSEvents = function (fn) {\n fn(this.chart.container, hasPointerEvent ? 'pointerdown' : 'MSPointerDown', this.onContainerPointerDown);\n fn(this.chart.container, hasPointerEvent ? 'pointermove' : 'MSPointerMove', this.onContainerPointerMove);\n fn(doc, hasPointerEvent ? 'pointerup' : 'MSPointerUp', this.onDocumentPointerUp);\n };\n // Destroy MS events also\n MSPointer.prototype.destroy = function () {\n this.batchMSEvents(removeEvent);\n _super.prototype.destroy.call(this);\n };\n // Disable default IE actions for pinch and such on chart element\n MSPointer.prototype.init = function (chart, options) {\n _super.prototype.init.call(this, chart, options);\n if (this.hasZoom) { // #4014\n css(chart.container, {\n '-ms-touch-action': 'none',\n 'touch-action': 'none'\n });\n }\n };\n /**\n * @private\n * @function Highcharts.Pointer#onContainerPointerDown\n */\n MSPointer.prototype.onContainerPointerDown = function (e) {\n translateMSPointer(e, 'onContainerTouchStart', 'touchstart', function (e) {\n touches[e.pointerId] = {\n pageX: e.pageX,\n pageY: e.pageY,\n target: e.currentTarget\n };\n });\n };\n /**\n * @private\n * @function Highcharts.Pointer#onContainerPointerMove\n */\n MSPointer.prototype.onContainerPointerMove = function (e) {\n translateMSPointer(e, 'onContainerTouchMove', 'touchmove', function (e) {\n touches[e.pointerId] = ({ pageX: e.pageX, pageY: e.pageY });\n if (!touches[e.pointerId].target) {\n touches[e.pointerId].target = e.currentTarget;\n }\n });\n };\n /**\n * @private\n * @function Highcharts.Pointer#onDocumentPointerUp\n */\n MSPointer.prototype.onDocumentPointerUp = function (e) {\n translateMSPointer(e, 'onDocumentTouchEnd', 'touchend', function (e) {\n delete touches[e.pointerId];\n });\n };\n // Add IE specific touch events to chart\n MSPointer.prototype.setDOMEvents = function () {\n var tooltip = this.chart.tooltip;\n _super.prototype.setDOMEvents.call(this);\n if (this.hasZoom ||\n pick((tooltip && tooltip.options.followTouchMove), true)) {\n this.batchMSEvents(addEvent);\n }\n };\n return MSPointer;\n }(Pointer));\n /* *\n *\n * Default Export\n *\n * */\n\n return MSPointer;\n });\n _registerModule(_modules, 'Core/Legend/Legend.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/FormatUtilities.js'], _modules['Core/Globals.js'], _modules['Core/Series/Point.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Utilities.js']], function (A, F, H, Point, R, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var animObject = A.animObject,\n setAnimation = A.setAnimation;\n var format = F.format;\n var isFirefox = H.isFirefox,\n marginNames = H.marginNames,\n win = H.win;\n var distribute = R.distribute;\n var addEvent = U.addEvent,\n createElement = U.createElement,\n css = U.css,\n defined = U.defined,\n discardElement = U.discardElement,\n find = U.find,\n fireEvent = U.fireEvent,\n isNumber = U.isNumber,\n merge = U.merge,\n pick = U.pick,\n relativeLength = U.relativeLength,\n stableSort = U.stableSort,\n syncTimeout = U.syncTimeout,\n wrap = U.wrap;\n /* *\n *\n * Class\n *\n * */\n /**\n * The overview of the chart's series. The legend object is instanciated\n * internally in the chart constructor, and is available from the `chart.legend`\n * property. Each chart has only one legend.\n *\n * @class\n * @name Highcharts.Legend\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.LegendOptions} options\n * Legend options.\n */\n var Legend = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Legend(chart, options) {\n /* *\n *\n * Properties\n *\n * */\n this.allItems = [];\n this.box = void 0;\n this.contentGroup = void 0;\n this.display = false;\n this.group = void 0;\n this.initialItemY = 0;\n this.itemHeight = 0;\n this.itemMarginBottom = 0;\n this.itemMarginTop = 0;\n this.itemX = 0;\n this.itemY = 0;\n this.lastItemY = 0;\n this.lastLineHeight = 0;\n this.legendHeight = 0;\n this.legendWidth = 0;\n this.maxItemWidth = 0;\n this.maxLegendWidth = 0;\n this.offsetWidth = 0;\n this.options = void 0;\n this.padding = 0;\n this.pages = [];\n this.proximate = false;\n this.scrollGroup = void 0;\n this.symbolHeight = 0;\n this.symbolWidth = 0;\n this.titleHeight = 0;\n this.totalItemWidth = 0;\n this.widthOption = 0;\n this.chart = chart;\n this.init(chart, options);\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Initialize the legend.\n *\n * @private\n * @function Highcharts.Legend#init\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.LegendOptions} options\n * Legend options.\n */\n Legend.prototype.init = function (chart, options) {\n /**\n * Chart of this legend.\n *\n * @readonly\n * @name Highcharts.Legend#chart\n * @type {Highcharts.Chart}\n */\n this.chart = chart;\n this.setOptions(options);\n if (options.enabled) {\n // Render it\n this.render();\n // move checkboxes\n addEvent(this.chart, 'endResize', function () {\n this.legend.positionCheckboxes();\n });\n if (this.proximate) {\n this.unchartrender = addEvent(this.chart, 'render', function () {\n this.legend.proximatePositions();\n this.legend.positionItems();\n });\n }\n else if (this.unchartrender) {\n this.unchartrender();\n }\n }\n };\n /**\n * @private\n * @function Highcharts.Legend#setOptions\n * @param {Highcharts.LegendOptions} options\n */\n Legend.prototype.setOptions = function (options) {\n var padding = pick(options.padding, 8);\n /**\n * Legend options.\n *\n * @readonly\n * @name Highcharts.Legend#options\n * @type {Highcharts.LegendOptions}\n */\n this.options = options;\n if (!this.chart.styledMode) {\n this.itemStyle = options.itemStyle;\n this.itemHiddenStyle = merge(this.itemStyle, options.itemHiddenStyle);\n }\n this.itemMarginTop = options.itemMarginTop || 0;\n this.itemMarginBottom = options.itemMarginBottom || 0;\n this.padding = padding;\n this.initialItemY = padding - 5; // 5 is pixels above the text\n this.symbolWidth = pick(options.symbolWidth, 16);\n this.pages = [];\n this.proximate = options.layout === 'proximate' && !this.chart.inverted;\n // #12705: baseline has to be reset on every update\n this.baseline = void 0;\n };\n /**\n * Update the legend with new options. Equivalent to running `chart.update`\n * with a legend configuration option.\n *\n * @sample highcharts/legend/legend-update/\n * Legend update\n *\n * @function Highcharts.Legend#update\n *\n * @param {Highcharts.LegendOptions} options\n * Legend options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the axis is altered. If doing more\n * operations on the chart, it is a good idea to set redraw to false and\n * call {@link Chart#redraw} after. Whether to redraw the chart.\n *\n * @emits Highcharts.Legends#event:afterUpdate\n */\n Legend.prototype.update = function (options, redraw) {\n var chart = this.chart;\n this.setOptions(merge(true, this.options, options));\n this.destroy();\n chart.isDirtyLegend = chart.isDirtyBox = true;\n if (pick(redraw, true)) {\n chart.redraw();\n }\n fireEvent(this, 'afterUpdate');\n };\n /**\n * Set the colors for the legend item.\n *\n * @private\n * @function Highcharts.Legend#colorizeItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n * A Series or Point instance\n * @param {boolean} [visible=false]\n * Dimmed or colored\n *\n * @todo\n * Make events official: Fires the event `afterColorizeItem`.\n */\n Legend.prototype.colorizeItem = function (item, visible) {\n var _a = item.legendItem || {},\n group = _a.group,\n label = _a.label,\n line = _a.line,\n symbol = _a.symbol;\n if (group) {\n group[visible ? 'removeClass' : 'addClass']('highcharts-legend-item-hidden');\n }\n if (!this.chart.styledMode) {\n var legend = this,\n options = legend.options,\n hiddenColor = legend.itemHiddenStyle.color,\n textColor = visible ?\n options.itemStyle.color :\n hiddenColor,\n symbolColor = visible ?\n (item.color || hiddenColor) :\n hiddenColor,\n markerOptions = item.options && item.options.marker;\n var symbolAttr = { fill: symbolColor };\n if (label) {\n label.css({\n fill: textColor,\n color: textColor // #1553, oldIE\n });\n }\n if (line) {\n line.attr({ stroke: symbolColor });\n }\n if (symbol) {\n // Apply marker options\n if (markerOptions && symbol.isMarker) { // #585\n symbolAttr = item.pointAttribs();\n if (!visible) {\n // #6769\n symbolAttr.stroke = symbolAttr.fill = hiddenColor;\n }\n }\n symbol.attr(symbolAttr);\n }\n }\n fireEvent(this, 'afterColorizeItem', { item: item, visible: visible });\n };\n /**\n * @private\n * @function Highcharts.Legend#positionItems\n */\n Legend.prototype.positionItems = function () {\n // Now that the legend width and height are established, put the items\n // in the final position\n this.allItems.forEach(this.positionItem, this);\n if (!this.chart.isResizing) {\n this.positionCheckboxes();\n }\n };\n /**\n * Position the legend item.\n *\n * @private\n * @function Highcharts.Legend#positionItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n * The item to position\n */\n Legend.prototype.positionItem = function (item) {\n var _this = this;\n var legend = this,\n _a = item.legendItem || {},\n group = _a.group,\n _b = _a.x,\n x = _b === void 0 ? 0 : _b,\n _c = _a.y,\n y = _c === void 0 ? 0 : _c,\n options = legend.options,\n symbolPadding = options.symbolPadding,\n ltr = !options.rtl,\n checkbox = item.checkbox;\n if (group && group.element) {\n var attribs = {\n translateX: ltr ?\n x :\n legend.legendWidth - x - 2 * symbolPadding - 4,\n translateY: y\n };\n var complete = function () {\n fireEvent(_this, 'afterPositionItem', { item: item });\n };\n group[defined(group.translateY) ? 'animate' : 'attr'](attribs, void 0, complete);\n }\n if (checkbox) {\n checkbox.x = x;\n checkbox.y = y;\n }\n };\n /**\n * Destroy a single legend item, used internally on removing series items.\n *\n * @private\n * @function Highcharts.Legend#destroyItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n * The item to remove\n */\n Legend.prototype.destroyItem = function (item) {\n var checkbox = item.checkbox,\n legendItem = item.legendItem || {};\n // destroy SVG elements\n for (var _i = 0, _a = ['group', 'label', 'line', 'symbol']; _i < _a.length; _i++) {\n var key = _a[_i];\n if (legendItem[key]) {\n legendItem[key] = legendItem[key].destroy();\n }\n }\n if (checkbox) {\n discardElement(checkbox);\n }\n item.legendItem = void 0;\n };\n /**\n * Destroy the legend. Used internally. To reflow objects, `chart.redraw`\n * must be called after destruction.\n *\n * @private\n * @function Highcharts.Legend#destroy\n */\n Legend.prototype.destroy = function () {\n var legend = this;\n // Destroy items\n for (var _i = 0, _a = this.getAllItems(); _i < _a.length; _i++) {\n var item = _a[_i];\n this.destroyItem(item);\n }\n // Destroy legend elements\n for (var _b = 0, _c = [\n 'clipRect',\n 'up',\n 'down',\n 'pager',\n 'nav',\n 'box',\n 'title',\n 'group'\n ]; _b < _c.length; _b++) {\n var key = _c[_b];\n if (legend[key]) {\n legend[key] = legend[key].destroy();\n }\n }\n this.display = null; // Reset in .render on update.\n };\n /**\n * Position the checkboxes after the width is determined.\n *\n * @private\n * @function Highcharts.Legend#positionCheckboxes\n */\n Legend.prototype.positionCheckboxes = function () {\n var alignAttr = this.group && this.group.alignAttr,\n clipHeight = this.clipHeight || this.legendHeight,\n titleHeight = this.titleHeight;\n var translateY;\n if (alignAttr) {\n translateY = alignAttr.translateY;\n this.allItems.forEach(function (item) {\n var checkbox = item.checkbox;\n var top;\n if (checkbox) {\n top = translateY + titleHeight + checkbox.y +\n (this.scrollOffset || 0) + 3;\n css(checkbox, {\n left: (alignAttr.translateX + item.checkboxOffset +\n checkbox.x - 20) + 'px',\n top: top + 'px',\n display: this.proximate || (top > translateY - 6 &&\n top < translateY + clipHeight - 6) ?\n '' :\n 'none'\n });\n }\n }, this);\n }\n };\n /**\n * Render the legend title on top of the legend.\n *\n * @private\n * @function Highcharts.Legend#renderTitle\n */\n Legend.prototype.renderTitle = function () {\n var options = this.options,\n padding = this.padding,\n titleOptions = options.title;\n var bBox,\n titleHeight = 0;\n if (titleOptions.text) {\n if (!this.title) {\n /**\n * SVG element of the legend title.\n *\n * @readonly\n * @name Highcharts.Legend#title\n * @type {Highcharts.SVGElement}\n */\n this.title = this.chart.renderer.label(titleOptions.text, padding - 3, padding - 4, void 0, void 0, void 0, options.useHTML, void 0, 'legend-title')\n .attr({ zIndex: 1 });\n if (!this.chart.styledMode) {\n this.title.css(titleOptions.style);\n }\n this.title.add(this.group);\n }\n // Set the max title width (#7253)\n if (!titleOptions.width) {\n this.title.css({\n width: this.maxLegendWidth + 'px'\n });\n }\n bBox = this.title.getBBox();\n titleHeight = bBox.height;\n this.offsetWidth = bBox.width; // #1717\n this.contentGroup.attr({ translateY: titleHeight });\n }\n this.titleHeight = titleHeight;\n };\n /**\n * Set the legend item text.\n *\n * @function Highcharts.Legend#setText\n * @param {Highcharts.Point|Highcharts.Series} item\n * The item for which to update the text in the legend.\n */\n Legend.prototype.setText = function (item) {\n var options = this.options;\n item.legendItem.label.attr({\n text: options.labelFormat ?\n format(options.labelFormat, item, this.chart) :\n options.labelFormatter.call(item)\n });\n };\n /**\n * Render a single specific legend item. Called internally from the `render`\n * function.\n *\n * @private\n * @function Highcharts.Legend#renderItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n * The item to render.\n */\n Legend.prototype.renderItem = function (item) {\n var legend = this,\n legendItem = item.legendItem = item.legendItem || {},\n chart = legend.chart,\n renderer = chart.renderer,\n options = legend.options,\n horizontal = options.layout === 'horizontal',\n symbolWidth = legend.symbolWidth,\n symbolPadding = options.symbolPadding || 0,\n itemStyle = legend.itemStyle,\n itemHiddenStyle = legend.itemHiddenStyle,\n itemDistance = horizontal ? pick(options.itemDistance, 20) : 0,\n ltr = !options.rtl,\n isSeries = !item.series,\n series = !isSeries && item.series.drawLegendSymbol ?\n item.series :\n item,\n seriesOptions = series.options,\n showCheckbox = (legend.createCheckboxForItem) &&\n seriesOptions &&\n seriesOptions.showCheckbox,\n useHTML = options.useHTML,\n itemClassName = item.options.className;\n var label = legendItem.label, \n // full width minus text width\n itemExtraWidth = symbolWidth + symbolPadding +\n itemDistance + (showCheckbox ? 20 : 0);\n if (!label) { // generate it once, later move it\n // Generate the group box, a group to hold the symbol and text. Text\n // is to be appended in Legend class.\n legendItem.group = renderer\n .g('legend-item')\n .addClass('highcharts-' + series.type + '-series ' +\n 'highcharts-color-' + item.colorIndex +\n (itemClassName ? ' ' + itemClassName : '') +\n (isSeries ?\n ' highcharts-series-' + item.index :\n ''))\n .attr({ zIndex: 1 })\n .add(legend.scrollGroup);\n // Generate the list item text and add it to the group\n legendItem.label = label = renderer.text('', ltr ?\n symbolWidth + symbolPadding :\n -symbolPadding, legend.baseline || 0, useHTML);\n if (!chart.styledMode) {\n // merge to prevent modifying original (#1021)\n label.css(merge(item.visible ?\n itemStyle :\n itemHiddenStyle));\n }\n label\n .attr({\n align: ltr ? 'left' : 'right',\n zIndex: 2\n })\n .add(legendItem.group);\n // Get the baseline for the first item - the font size is equal for\n // all\n if (!legend.baseline) {\n legend.fontMetrics = renderer.fontMetrics(chart.styledMode ? 12 : itemStyle.fontSize, label);\n legend.baseline =\n legend.fontMetrics.f + 3 + legend.itemMarginTop;\n label.attr('y', legend.baseline);\n legend.symbolHeight =\n options.symbolHeight || legend.fontMetrics.f;\n if (options.squareSymbol) {\n legend.symbolWidth = pick(options.symbolWidth, Math.max(legend.symbolHeight, 16));\n itemExtraWidth = legend.symbolWidth + symbolPadding +\n itemDistance + (showCheckbox ? 20 : 0);\n if (ltr) {\n label.attr('x', legend.symbolWidth + symbolPadding);\n }\n }\n }\n // Draw the legend symbol inside the group box\n series.drawLegendSymbol(legend, item);\n if (legend.setItemEvents) {\n legend.setItemEvents(item, label, useHTML);\n }\n }\n // Add the HTML checkbox on top\n if (showCheckbox && !item.checkbox && legend.createCheckboxForItem) {\n legend.createCheckboxForItem(item);\n }\n // Colorize the items\n legend.colorizeItem(item, item.visible);\n // Take care of max width and text overflow (#6659)\n if (chart.styledMode || !itemStyle.width) {\n label.css({\n width: ((options.itemWidth ||\n legend.widthOption ||\n chart.spacingBox.width) - itemExtraWidth) + 'px'\n });\n }\n // Always update the text\n legend.setText(item);\n // calculate the positions for the next line\n var bBox = label.getBBox();\n var fontMetricsH = (legend.fontMetrics && legend.fontMetrics.h) || 0;\n item.itemWidth = item.checkboxOffset =\n options.itemWidth ||\n legendItem.labelWidth ||\n bBox.width + itemExtraWidth;\n legend.maxItemWidth = Math.max(legend.maxItemWidth, item.itemWidth);\n legend.totalItemWidth += item.itemWidth;\n legend.itemHeight = item.itemHeight = Math.round(legendItem.labelHeight ||\n // use bBox for multiline (#16398)\n (bBox.height > fontMetricsH * 1.5 ? bBox.height : fontMetricsH));\n };\n /**\n * Get the position of the item in the layout. We now know the\n * maxItemWidth from the previous loop.\n *\n * @private\n * @function Highcharts.Legend#layoutItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n */\n Legend.prototype.layoutItem = function (item) {\n var options = this.options,\n padding = this.padding,\n horizontal = options.layout === 'horizontal',\n itemHeight = item.itemHeight,\n itemMarginBottom = this.itemMarginBottom,\n itemMarginTop = this.itemMarginTop,\n itemDistance = horizontal ? pick(options.itemDistance, 20) : 0,\n maxLegendWidth = this.maxLegendWidth,\n itemWidth = (options.alignColumns &&\n this.totalItemWidth > maxLegendWidth) ?\n this.maxItemWidth :\n item.itemWidth,\n legendItem = item.legendItem || {};\n // If the item exceeds the width, start a new line\n if (horizontal &&\n this.itemX - padding + itemWidth > maxLegendWidth) {\n this.itemX = padding;\n if (this.lastLineHeight) { // Not for the first line (#10167)\n this.itemY += (itemMarginTop +\n this.lastLineHeight +\n itemMarginBottom);\n }\n this.lastLineHeight = 0; // reset for next line (#915, #3976)\n }\n // Set the edge positions\n this.lastItemY = itemMarginTop + this.itemY + itemMarginBottom;\n this.lastLineHeight = Math.max(// #915\n itemHeight, this.lastLineHeight);\n // cache the position of the newly generated or reordered items\n legendItem.x = this.itemX;\n legendItem.y = this.itemY;\n // advance\n if (horizontal) {\n this.itemX += itemWidth;\n }\n else {\n this.itemY +=\n itemMarginTop + itemHeight + itemMarginBottom;\n this.lastLineHeight = itemHeight;\n }\n // the width of the widest item\n this.offsetWidth = this.widthOption || Math.max((horizontal ? this.itemX - padding - (item.checkbox ?\n // decrease by itemDistance only when no checkbox #4853\n 0 :\n itemDistance) : itemWidth) + padding, this.offsetWidth);\n };\n /**\n * Get all items, which is one item per series for most series and one\n * item per point for pie series and its derivatives. Fires the event\n * `afterGetAllItems`.\n *\n * @private\n * @function Highcharts.Legend#getAllItems\n * @return {Array<(Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series)>}\n * The current items in the legend.\n * @emits Highcharts.Legend#event:afterGetAllItems\n */\n Legend.prototype.getAllItems = function () {\n var allItems = [];\n this.chart.series.forEach(function (series) {\n var seriesOptions = series && series.options;\n // Handle showInLegend. If the series is linked to another series,\n // defaults to false.\n if (series && pick(seriesOptions.showInLegend, !defined(seriesOptions.linkedTo) ? void 0 : false, true)) {\n // Use points or series for the legend item depending on\n // legendType\n allItems = allItems.concat((series.legendItem || {}).labels ||\n (seriesOptions.legendType === 'point' ?\n series.data :\n series));\n }\n });\n fireEvent(this, 'afterGetAllItems', { allItems: allItems });\n return allItems;\n };\n /**\n * Get a short, three letter string reflecting the alignment and layout.\n *\n * @private\n * @function Highcharts.Legend#getAlignment\n * @return {string}\n * The alignment, empty string if floating\n */\n Legend.prototype.getAlignment = function () {\n var options = this.options;\n // Use the first letter of each alignment option in order to detect\n // the side. (#4189 - use charAt(x) notation instead of [x] for IE7)\n if (this.proximate) {\n return options.align.charAt(0) + 'tv';\n }\n return options.floating ? '' : (options.align.charAt(0) +\n options.verticalAlign.charAt(0) +\n options.layout.charAt(0));\n };\n /**\n * Adjust the chart margins by reserving space for the legend on only one\n * side of the chart. If the position is set to a corner, top or bottom is\n * reserved for horizontal legends and left or right for vertical ones.\n *\n * @private\n * @function Highcharts.Legend#adjustMargins\n * @param {Array} margin\n * @param {Array} spacing\n */\n Legend.prototype.adjustMargins = function (margin, spacing) {\n var chart = this.chart,\n options = this.options,\n alignment = this.getAlignment();\n if (alignment) {\n ([\n /(lth|ct|rth)/,\n /(rtv|rm|rbv)/,\n /(rbh|cb|lbh)/,\n /(lbv|lm|ltv)/\n ]).forEach(function (alignments, side) {\n if (alignments.test(alignment) && !defined(margin[side])) {\n // Now we have detected on which side of the chart we should\n // reserve space for the legend\n chart[marginNames[side]] = Math.max(chart[marginNames[side]], (chart.legend[(side + 1) % 2 ? 'legendHeight' : 'legendWidth'] +\n [1, -1, -1, 1][side] * options[(side % 2) ? 'x' : 'y'] +\n pick(options.margin, 12) +\n spacing[side] +\n (chart.titleOffset[side] || 0)));\n }\n });\n }\n };\n /**\n * @private\n * @function Highcharts.Legend#proximatePositions\n */\n Legend.prototype.proximatePositions = function () {\n var chart = this.chart,\n boxes = [],\n alignLeft = this.options.align === 'left';\n this.allItems.forEach(function (item) {\n var lastPoint,\n height,\n useFirstPoint = alignLeft,\n target,\n top;\n if (item.yAxis) {\n if (item.xAxis.options.reversed) {\n useFirstPoint = !useFirstPoint;\n }\n if (item.points) {\n lastPoint = find(useFirstPoint ?\n item.points :\n item.points.slice(0).reverse(), function (item) {\n return isNumber(item.plotY);\n });\n }\n height = this.itemMarginTop +\n item.legendItem.label.getBBox().height +\n this.itemMarginBottom;\n top = item.yAxis.top - chart.plotTop;\n if (item.visible) {\n target = lastPoint ?\n lastPoint.plotY :\n item.yAxis.height;\n target += top - 0.3 * height;\n }\n else {\n target = top + item.yAxis.height;\n }\n boxes.push({\n target: target,\n size: height,\n item: item\n });\n }\n }, this);\n var legendItem;\n for (var _i = 0, _a = distribute(boxes, chart.plotHeight); _i < _a.length; _i++) {\n var box = _a[_i];\n legendItem = box.item.legendItem || {};\n if (box.pos) {\n legendItem.y = chart.plotTop - chart.spacing[0] + box.pos;\n }\n }\n };\n /**\n * Render the legend. This method can be called both before and after\n * `chart.render`. If called after, it will only rearrange items instead\n * of creating new ones. Called internally on initial render and after\n * redraws.\n *\n * @private\n * @function Highcharts.Legend#render\n */\n Legend.prototype.render = function () {\n var legend = this,\n chart = legend.chart,\n renderer = chart.renderer,\n options = legend.options,\n padding = legend.padding, \n // add each series or point\n allItems = legend.getAllItems();\n var display,\n legendWidth,\n legendHeight,\n legendGroup = legend.group,\n allowedWidth,\n box = legend.box;\n legend.itemX = padding;\n legend.itemY = legend.initialItemY;\n legend.offsetWidth = 0;\n legend.lastItemY = 0;\n legend.widthOption = relativeLength(options.width, chart.spacingBox.width - padding);\n // Compute how wide the legend is allowed to be\n allowedWidth = chart.spacingBox.width - 2 * padding - options.x;\n if (['rm', 'lm'].indexOf(legend.getAlignment().substring(0, 2)) > -1) {\n allowedWidth /= 2;\n }\n legend.maxLegendWidth = legend.widthOption || allowedWidth;\n if (!legendGroup) {\n /**\n * SVG group of the legend.\n *\n * @readonly\n * @name Highcharts.Legend#group\n * @type {Highcharts.SVGElement}\n */\n legend.group = legendGroup = renderer\n .g('legend')\n .addClass(options.className || '')\n .attr({ zIndex: 7 })\n .add();\n legend.contentGroup = renderer\n .g()\n .attr({ zIndex: 1 }) // above background\n .add(legendGroup);\n legend.scrollGroup = renderer\n .g()\n .add(legend.contentGroup);\n }\n legend.renderTitle();\n // sort by legendIndex\n stableSort(allItems, function (a, b) {\n return ((a.options && a.options.legendIndex) || 0) -\n ((b.options && b.options.legendIndex) || 0);\n });\n // reversed legend\n if (options.reversed) {\n allItems.reverse();\n }\n /**\n * All items for the legend, which is an array of series for most series\n * and an array of points for pie series and its derivatives.\n *\n * @readonly\n * @name Highcharts.Legend#allItems\n * @type {Array<(Highcharts.Point|Highcharts.Series)>}\n */\n legend.allItems = allItems;\n legend.display = display = !!allItems.length;\n // Render the items. First we run a loop to set the text and properties\n // and read all the bounding boxes. The next loop computes the item\n // positions based on the bounding boxes.\n legend.lastLineHeight = 0;\n legend.maxItemWidth = 0;\n legend.totalItemWidth = 0;\n legend.itemHeight = 0;\n allItems.forEach(legend.renderItem, legend);\n allItems.forEach(legend.layoutItem, legend);\n // Get the box\n legendWidth = (legend.widthOption || legend.offsetWidth) + padding;\n legendHeight = legend.lastItemY + legend.lastLineHeight +\n legend.titleHeight;\n legendHeight = legend.handleOverflow(legendHeight);\n legendHeight += padding;\n // Draw the border and/or background\n if (!box) {\n /**\n * SVG element of the legend box.\n *\n * @readonly\n * @name Highcharts.Legend#box\n * @type {Highcharts.SVGElement}\n */\n legend.box = box = renderer.rect()\n .addClass('highcharts-legend-box')\n .attr({\n r: options.borderRadius\n })\n .add(legendGroup);\n }\n // Presentational\n if (!chart.styledMode) {\n box\n .attr({\n stroke: options.borderColor,\n 'stroke-width': options.borderWidth || 0,\n fill: options.backgroundColor || 'none'\n })\n .shadow(options.shadow);\n }\n if (legendWidth > 0 && legendHeight > 0) {\n box[box.placed ? 'animate' : 'attr'](box.crisp.call({}, {\n x: 0,\n y: 0,\n width: legendWidth,\n height: legendHeight\n }, box.strokeWidth()));\n }\n // hide the border if no items\n legendGroup[display ? 'show' : 'hide']();\n // Open for responsiveness\n if (chart.styledMode && legendGroup.getStyle('display') === 'none') {\n legendWidth = legendHeight = 0;\n }\n legend.legendWidth = legendWidth;\n legend.legendHeight = legendHeight;\n if (display) {\n legend.align();\n }\n if (!this.proximate) {\n this.positionItems();\n }\n fireEvent(this, 'afterRender');\n };\n /**\n * Align the legend to chart's box.\n *\n * @private\n * @function Highcharts.align\n * @param {Highcharts.BBoxObject} alignTo\n */\n Legend.prototype.align = function (alignTo) {\n if (alignTo === void 0) { alignTo = this.chart.spacingBox; }\n var chart = this.chart,\n options = this.options;\n // If aligning to the top and the layout is horizontal, adjust for\n // the title (#7428)\n var y = alignTo.y;\n if (/(lth|ct|rth)/.test(this.getAlignment()) &&\n chart.titleOffset[0] > 0) {\n y += chart.titleOffset[0];\n }\n else if (/(lbh|cb|rbh)/.test(this.getAlignment()) &&\n chart.titleOffset[2] > 0) {\n y -= chart.titleOffset[2];\n }\n if (y !== alignTo.y) {\n alignTo = merge(alignTo, { y: y });\n }\n if (!chart.hasRendered) {\n // Avoid animation when adjusting alignment for responsiveness and\n // colorAxis label layout\n this.group.placed = false;\n }\n this.group.align(merge(options, {\n width: this.legendWidth,\n height: this.legendHeight,\n verticalAlign: this.proximate ? 'top' : options.verticalAlign\n }), true, alignTo);\n };\n /**\n * Set up the overflow handling by adding navigation with up and down arrows\n * below the legend.\n *\n * @private\n * @function Highcharts.Legend#handleOverflow\n */\n Legend.prototype.handleOverflow = function (legendHeight) {\n var legend = this,\n chart = this.chart,\n renderer = chart.renderer,\n options = this.options,\n optionsY = options.y,\n alignTop = options.verticalAlign === 'top',\n padding = this.padding,\n maxHeight = options.maxHeight,\n navOptions = options.navigation,\n animation = pick(navOptions.animation,\n true),\n arrowSize = navOptions.arrowSize || 12,\n pages = this.pages,\n allItems = this.allItems,\n clipToHeight = function (height) {\n if (typeof height === 'number') {\n clipRect.attr({\n height: height\n });\n }\n else if (clipRect) { // Reset (#5912)\n legend.clipRect = clipRect.destroy();\n legend.contentGroup.clip();\n }\n // useHTML\n if (legend.contentGroup.div) {\n legend.contentGroup.div.style.clip = height ?\n 'rect(' + padding + 'px,9999px,' +\n (padding + height) + 'px,0)' :\n 'auto';\n }\n }, addTracker = function (key) {\n legend[key] = renderer\n .circle(0, 0, arrowSize * 1.3)\n .translate(arrowSize / 2, arrowSize / 2)\n .add(nav);\n if (!chart.styledMode) {\n legend[key].attr('fill', 'rgba(0,0,0,0.0001)');\n }\n return legend[key];\n };\n var clipHeight,\n lastY,\n legendItem,\n spaceHeight = (chart.spacingBox.height +\n (alignTop ? -optionsY : optionsY) - padding),\n nav = this.nav,\n clipRect = this.clipRect;\n // Adjust the height\n if (options.layout === 'horizontal' &&\n options.verticalAlign !== 'middle' &&\n !options.floating) {\n spaceHeight /= 2;\n }\n if (maxHeight) {\n spaceHeight = Math.min(spaceHeight, maxHeight);\n }\n // Reset the legend height and adjust the clipping rectangle\n pages.length = 0;\n if (legendHeight &&\n spaceHeight > 0 &&\n legendHeight > spaceHeight &&\n navOptions.enabled !== false) {\n this.clipHeight = clipHeight =\n Math.max(spaceHeight - 20 - this.titleHeight - padding, 0);\n this.currentPage = pick(this.currentPage, 1);\n this.fullHeight = legendHeight;\n // Fill pages with Y positions so that the top of each a legend item\n // defines the scroll top for each page (#2098)\n allItems.forEach(function (item, i) {\n legendItem = item.legendItem || {};\n var y = legendItem.y || 0,\n h = Math.round(legendItem.label.getBBox().height);\n var len = pages.length;\n if (!len || (y - pages[len - 1] > clipHeight &&\n (lastY || y) !== pages[len - 1])) {\n pages.push(lastY || y);\n len++;\n }\n // Keep track of which page each item is on\n legendItem.pageIx = len - 1;\n if (lastY) {\n (allItems[i - 1].legendItem || {}).pageIx = len - 1;\n }\n // add the last page if needed (#2617, #13683)\n if (\n // check the last item\n i === allItems.length - 1 &&\n // if adding next page is needed\n y + h - pages[len - 1] > clipHeight &&\n // and will fully fit inside a new page\n h <= clipHeight) {\n pages.push(y);\n legendItem.pageIx = len;\n }\n if (y !== lastY) {\n lastY = y;\n }\n });\n // Only apply clipping if needed. Clipping causes blurred legend in\n // PDF export (#1787)\n if (!clipRect) {\n clipRect = legend.clipRect =\n renderer.clipRect(0, padding, 9999, 0);\n legend.contentGroup.clip(clipRect);\n }\n clipToHeight(clipHeight);\n // Add navigation elements\n if (!nav) {\n this.nav = nav = renderer.g()\n .attr({ zIndex: 1 })\n .add(this.group);\n this.up = renderer\n .symbol('triangle', 0, 0, arrowSize, arrowSize)\n .add(nav);\n addTracker('upTracker')\n .on('click', function () {\n legend.scroll(-1, animation);\n });\n this.pager = renderer.text('', 15, 10)\n .addClass('highcharts-legend-navigation');\n if (!chart.styledMode && navOptions.style) {\n this.pager.css(navOptions.style);\n }\n this.pager.add(nav);\n this.down = renderer\n .symbol('triangle-down', 0, 0, arrowSize, arrowSize)\n .add(nav);\n addTracker('downTracker')\n .on('click', function () {\n legend.scroll(1, animation);\n });\n }\n // Set initial position\n legend.scroll(0);\n legendHeight = spaceHeight;\n // Reset\n }\n else if (nav) {\n clipToHeight();\n this.nav = nav.destroy(); // #6322\n this.scrollGroup.attr({\n translateY: 1\n });\n this.clipHeight = 0; // #1379\n }\n return legendHeight;\n };\n /**\n * Scroll the legend by a number of pages.\n *\n * @private\n * @function Highcharts.Legend#scroll\n *\n * @param {number} scrollBy\n * The number of pages to scroll.\n *\n * @param {boolean|Partial} [animation]\n * Whether and how to apply animation.\n *\n */\n Legend.prototype.scroll = function (scrollBy, animation) {\n var _this = this;\n var chart = this.chart,\n pages = this.pages,\n pageCount = pages.length,\n clipHeight = this.clipHeight,\n navOptions = this.options.navigation,\n pager = this.pager,\n padding = this.padding;\n var currentPage = this.currentPage + scrollBy;\n // When resizing while looking at the last page\n if (currentPage > pageCount) {\n currentPage = pageCount;\n }\n if (currentPage > 0) {\n if (typeof animation !== 'undefined') {\n setAnimation(animation, chart);\n }\n this.nav.attr({\n translateX: padding,\n translateY: clipHeight + this.padding + 7 + this.titleHeight,\n visibility: 'inherit'\n });\n [this.up, this.upTracker].forEach(function (elem) {\n elem.attr({\n 'class': currentPage === 1 ?\n 'highcharts-legend-nav-inactive' :\n 'highcharts-legend-nav-active'\n });\n });\n pager.attr({\n text: currentPage + '/' + pageCount\n });\n [this.down, this.downTracker].forEach(function (elem) {\n elem.attr({\n // adjust to text width\n x: 18 + this.pager.getBBox().width,\n 'class': currentPage === pageCount ?\n 'highcharts-legend-nav-inactive' :\n 'highcharts-legend-nav-active'\n });\n }, this);\n if (!chart.styledMode) {\n this.up\n .attr({\n fill: currentPage === 1 ?\n navOptions.inactiveColor :\n navOptions.activeColor\n });\n this.upTracker\n .css({\n cursor: currentPage === 1 ? 'default' : 'pointer'\n });\n this.down\n .attr({\n fill: currentPage === pageCount ?\n navOptions.inactiveColor :\n navOptions.activeColor\n });\n this.downTracker\n .css({\n cursor: currentPage === pageCount ?\n 'default' :\n 'pointer'\n });\n }\n this.scrollOffset = -pages[currentPage - 1] + this.initialItemY;\n this.scrollGroup.animate({\n translateY: this.scrollOffset\n });\n this.currentPage = currentPage;\n this.positionCheckboxes();\n // Fire event after scroll animation is complete\n var animOptions = animObject(pick(animation,\n chart.renderer.globalAnimation,\n true));\n syncTimeout(function () {\n fireEvent(_this, 'afterScroll', { currentPage: currentPage });\n }, animOptions.duration);\n }\n };\n /**\n * @private\n * @function Highcharts.Legend#setItemEvents\n * @param {Highcharts.BubbleLegendItem|Point|Highcharts.Series} item\n * @param {Highcharts.SVGElement} legendLabel\n * @param {boolean} [useHTML=false]\n * @emits Highcharts.Point#event:legendItemClick\n * @emits Highcharts.Series#event:legendItemClick\n */\n Legend.prototype.setItemEvents = function (item, legendLabel, useHTML) {\n var legend = this,\n legendItem = item.legendItem || {},\n boxWrapper = legend.chart.renderer.boxWrapper,\n isPoint = item instanceof Point,\n activeClass = 'highcharts-legend-' +\n (isPoint ? 'point' : 'series') + '-active',\n styledMode = legend.chart.styledMode, \n // When `useHTML`, the symbol is rendered in other group, so\n // we need to apply events listeners to both places\n legendElements = useHTML ?\n [legendLabel,\n legendItem.symbol] :\n [legendItem.group];\n var setOtherItemsState = function (state) {\n legend.allItems.forEach(function (otherItem) {\n if (item !== otherItem) {\n [otherItem]\n .concat(otherItem.linkedSeries || [])\n .forEach(function (otherItem) {\n otherItem.setState(state, !isPoint);\n });\n }\n });\n };\n // Set the events on the item group, or in case of useHTML, the item\n // itself (#1249)\n for (var _i = 0, legendElements_1 = legendElements; _i < legendElements_1.length; _i++) {\n var element = legendElements_1[_i];\n if (element) {\n element\n .on('mouseover', function () {\n if (item.visible) {\n setOtherItemsState('inactive');\n }\n item.setState('hover');\n // A CSS class to dim or hide other than the hovered\n // series.\n // Works only if hovered series is visible (#10071).\n if (item.visible) {\n boxWrapper.addClass(activeClass);\n }\n if (!styledMode) {\n legendLabel.css(legend.options.itemHoverStyle);\n }\n })\n .on('mouseout', function () {\n if (!legend.chart.styledMode) {\n legendLabel.css(merge(item.visible ?\n legend.itemStyle :\n legend.itemHiddenStyle));\n }\n setOtherItemsState('');\n // A CSS class to dim or hide other than the hovered\n // series.\n boxWrapper.removeClass(activeClass);\n item.setState();\n })\n .on('click', function (event) {\n var strLegendItemClick = 'legendItemClick',\n fnLegendItemClick = function () {\n if (item.setVisible) {\n item.setVisible();\n }\n // Reset inactive state\n setOtherItemsState(item.visible ? 'inactive' : '');\n };\n // A CSS class to dim or hide other than the hovered\n // series. Event handling in iOS causes the activeClass\n // to be added prior to click in some cases (#7418).\n boxWrapper.removeClass(activeClass);\n // Pass over the click/touch event. #4.\n event = {\n browserEvent: event\n };\n // click the name or symbol\n if (item.firePointEvent) { // point\n item.firePointEvent(strLegendItemClick, event, fnLegendItemClick);\n }\n else {\n fireEvent(item, strLegendItemClick, event, fnLegendItemClick);\n }\n });\n }\n }\n };\n /**\n * @private\n * @function Highcharts.Legend#createCheckboxForItem\n * @param {Highcharts.BubbleLegendItem|Point|Highcharts.Series} item\n * @emits Highcharts.Series#event:checkboxClick\n */\n Legend.prototype.createCheckboxForItem = function (item) {\n var legend = this;\n item.checkbox = createElement('input', {\n type: 'checkbox',\n className: 'highcharts-legend-checkbox',\n checked: item.selected,\n defaultChecked: item.selected // required by IE7\n }, legend.options.itemCheckboxStyle, legend.chart.container);\n addEvent(item.checkbox, 'click', function (event) {\n var target = event.target;\n fireEvent(item.series || item, 'checkboxClick', {\n checked: target.checked,\n item: item\n }, function () {\n item.select();\n });\n });\n };\n return Legend;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @interface Highcharts.LegendItemObject\n */ /**\n * @name Highcharts.LegendItemObject#item\n * @type {Highcharts.SVGElement|undefined}\n */ /**\n * @name Highcharts.LegendItemObject#line\n * @type {Highcharts.SVGElement|undefined}\n */ /**\n * @name Highcharts.LegendItemObject#symbol\n * @type {Highcharts.SVGElement|undefined}\n */\n /**\n * Gets fired when the legend item belonging to a point is clicked. The default\n * action is to toggle the visibility of the point. This can be prevented by\n * returning `false` or calling `event.preventDefault()`.\n *\n * @callback Highcharts.PointLegendItemClickCallbackFunction\n *\n * @param {Highcharts.Point} this\n * The point on which the event occured.\n *\n * @param {Highcharts.PointLegendItemClickEventObject} event\n * The event that occured.\n */\n /**\n * Information about the legend click event.\n *\n * @interface Highcharts.PointLegendItemClickEventObject\n */ /**\n * Related browser event.\n * @name Highcharts.PointLegendItemClickEventObject#browserEvent\n * @type {Highcharts.PointerEvent}\n */ /**\n * Prevent the default action of toggle the visibility of the point.\n * @name Highcharts.PointLegendItemClickEventObject#preventDefault\n * @type {Function}\n */ /**\n * Related point.\n * @name Highcharts.PointLegendItemClickEventObject#target\n * @type {Highcharts.Point}\n */ /**\n * Event type.\n * @name Highcharts.PointLegendItemClickEventObject#type\n * @type {\"legendItemClick\"}\n */\n /**\n * Series color as used by the legend and some series types.\n * @name Highcharts.Series#color\n * @type {Highcharts.ColorType|undefined}\n */ /**\n * Legend data for the series.\n * @name Highcharts.Series#legendItem\n * @type {Highcharts.LegendItemObject|undefined}\n * @since 10.3.0\n */\n /**\n * Gets fired when the legend item belonging to a series is clicked. The default\n * action is to toggle the visibility of the series. This can be prevented by\n * returning `false` or calling `event.preventDefault()`.\n *\n * @callback Highcharts.SeriesLegendItemClickCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesLegendItemClickEventObject} event\n * The event that occured.\n */\n /**\n * Information about the legend click event.\n *\n * @interface Highcharts.SeriesLegendItemClickEventObject\n */ /**\n * Related browser event.\n * @name Highcharts.SeriesLegendItemClickEventObject#browserEvent\n * @type {Highcharts.PointerEvent}\n */ /**\n * Prevent the default action of toggle the visibility of the series.\n * @name Highcharts.SeriesLegendItemClickEventObject#preventDefault\n * @type {Function}\n */ /**\n * Related series.\n * @name Highcharts.SeriesLegendItemClickEventObject#target\n * @type {Highcharts.Series}\n */ /**\n * Event type.\n * @name Highcharts.SeriesLegendItemClickEventObject#type\n * @type {\"legendItemClick\"}\n */\n (''); // keeps doclets above in JS file\n\n return Legend;\n });\n _registerModule(_modules, 'Core/Series/SeriesRegistry.js', [_modules['Core/Globals.js'], _modules['Core/Defaults.js'], _modules['Core/Series/Point.js'], _modules['Core/Utilities.js']], function (H, D, Point, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var defaultOptions = D.defaultOptions;\n var extendClass = U.extendClass,\n merge = U.merge;\n /* *\n *\n * Namespace\n *\n * */\n var SeriesRegistry;\n (function (SeriesRegistry) {\n /* *\n *\n * Properties\n *\n * */\n /**\n * @internal\n * @todo Move `Globals.seriesTypes` code to her.\n */\n SeriesRegistry.seriesTypes = H.seriesTypes;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Registers class pattern of a series.\n *\n * @private\n */\n function registerSeriesType(seriesType, SeriesClass) {\n var defaultPlotOptions = defaultOptions.plotOptions || {},\n seriesOptions = SeriesClass.defaultOptions,\n seriesProto = SeriesClass.prototype;\n seriesProto.type = seriesType;\n if (!seriesProto.pointClass) {\n seriesProto.pointClass = Point;\n }\n if (seriesOptions) {\n defaultPlotOptions[seriesType] = seriesOptions;\n }\n SeriesRegistry.seriesTypes[seriesType] = SeriesClass;\n }\n SeriesRegistry.registerSeriesType = registerSeriesType;\n /**\n * Old factory to create new series prototypes.\n *\n * @deprecated\n * @function Highcharts.seriesType\n *\n * @param {string} type\n * The series type name.\n *\n * @param {string} parent\n * The parent series type name. Use `line` to inherit from the basic\n * {@link Series} object.\n *\n * @param {Highcharts.SeriesOptionsType|Highcharts.Dictionary<*>} options\n * The additional default options that are merged with the parent's options.\n *\n * @param {Highcharts.Dictionary<*>} [props]\n * The properties (functions and primitives) to set on the new prototype.\n *\n * @param {Highcharts.Dictionary<*>} [pointProps]\n * Members for a series-specific extension of the {@link Point} prototype if\n * needed.\n *\n * @return {Highcharts.Series}\n * The newly created prototype as extended from {@link Series} or its\n * derivatives.\n */\n function seriesType(type, parent, options, seriesProto, pointProto) {\n var defaultPlotOptions = defaultOptions.plotOptions || {};\n parent = parent || '';\n // Merge the options\n defaultPlotOptions[type] = merge(defaultPlotOptions[parent], options);\n // Create the class\n registerSeriesType(type, extendClass(SeriesRegistry.seriesTypes[parent] || function () { }, seriesProto));\n SeriesRegistry.seriesTypes[type].prototype.type = type;\n // Create the point class if needed\n if (pointProto) {\n SeriesRegistry.seriesTypes[type].prototype.pointClass = extendClass(Point, pointProto);\n }\n return SeriesRegistry.seriesTypes[type];\n }\n SeriesRegistry.seriesType = seriesType;\n })(SeriesRegistry || (SeriesRegistry = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return SeriesRegistry;\n });\n _registerModule(_modules, 'Core/Chart/Chart.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Axis/Axis.js'], _modules['Core/Defaults.js'], _modules['Core/FormatUtilities.js'], _modules['Core/Foundation.js'], _modules['Core/Globals.js'], _modules['Core/Legend/Legend.js'], _modules['Core/MSPointer.js'], _modules['Core/Pointer.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Time.js'], _modules['Core/Utilities.js'], _modules['Core/Renderer/HTML/AST.js']], function (A, Axis, D, FormatUtilities, Foundation, H, Legend, MSPointer, Pointer, RendererRegistry, SeriesRegistry, SVGRenderer, Time, U, AST) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var animate = A.animate,\n animObject = A.animObject,\n setAnimation = A.setAnimation;\n var defaultOptions = D.defaultOptions,\n defaultTime = D.defaultTime;\n var numberFormat = FormatUtilities.numberFormat;\n var registerEventOptions = Foundation.registerEventOptions;\n var charts = H.charts,\n doc = H.doc,\n marginNames = H.marginNames,\n svg = H.svg,\n win = H.win;\n var seriesTypes = SeriesRegistry.seriesTypes;\n var addEvent = U.addEvent,\n attr = U.attr,\n cleanRecursively = U.cleanRecursively,\n createElement = U.createElement,\n css = U.css,\n defined = U.defined,\n discardElement = U.discardElement,\n erase = U.erase,\n error = U.error,\n extend = U.extend,\n find = U.find,\n fireEvent = U.fireEvent,\n getStyle = U.getStyle,\n isArray = U.isArray,\n isNumber = U.isNumber,\n isObject = U.isObject,\n isString = U.isString,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick,\n pInt = U.pInt,\n relativeLength = U.relativeLength,\n removeEvent = U.removeEvent,\n splat = U.splat,\n syncTimeout = U.syncTimeout,\n uniqueKey = U.uniqueKey;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The Chart class. The recommended constructor is {@link Highcharts#chart}.\n *\n * @example\n * let chart = Highcharts.chart('container', {\n * title: {\n * text: 'My chart'\n * },\n * series: [{\n * data: [1, 3, 2, 4]\n * }]\n * })\n *\n * @class\n * @name Highcharts.Chart\n *\n * @param {string|Highcharts.HTMLDOMElement} [renderTo]\n * The DOM element to render to, or its id.\n *\n * @param {Highcharts.Options} options\n * The chart options structure.\n *\n * @param {Highcharts.ChartCallbackFunction} [callback]\n * Function to run when the chart has loaded and and all external images\n * are loaded. Defining a\n * [chart.events.load](https://api.highcharts.com/highcharts/chart.events.load)\n * handler is equivalent.\n */\n var Chart = /** @class */ (function () {\n function Chart(a, b, c) {\n this.axes = void 0;\n this.axisOffset = void 0;\n this.bounds = void 0;\n this.chartHeight = void 0;\n this.chartWidth = void 0;\n this.clipBox = void 0;\n this.colorCounter = void 0;\n this.container = void 0;\n this.eventOptions = void 0;\n this.index = void 0;\n this.isResizing = void 0;\n this.labelCollectors = void 0;\n this.legend = void 0;\n this.margin = void 0;\n this.numberFormatter = void 0;\n this.options = void 0;\n this.plotBox = void 0;\n this.plotHeight = void 0;\n this.plotLeft = void 0;\n this.plotTop = void 0;\n this.plotWidth = void 0;\n this.pointCount = void 0;\n this.pointer = void 0;\n this.renderer = void 0;\n this.renderTo = void 0;\n this.series = void 0;\n this.sharedClips = {};\n this.spacing = void 0;\n this.spacingBox = void 0;\n this.symbolCounter = void 0;\n this.time = void 0;\n this.titleOffset = void 0;\n this.userOptions = void 0;\n this.xAxis = void 0;\n this.yAxis = void 0;\n this.getArgs(a, b, c);\n }\n /**\n * Factory function for basic charts.\n *\n * @example\n * // Render a chart in to div#container\n * let chart = Highcharts.chart('container', {\n * title: {\n * text: 'My chart'\n * },\n * series: [{\n * data: [1, 3, 2, 4]\n * }]\n * });\n *\n * @function Highcharts.chart\n *\n * @param {string|Highcharts.HTMLDOMElement} [renderTo]\n * The DOM element to render to, or its id.\n *\n * @param {Highcharts.Options} options\n * The chart options structure.\n *\n * @param {Highcharts.ChartCallbackFunction} [callback]\n * Function to run when the chart has loaded and and all external images are\n * loaded. Defining a\n * [chart.events.load](https://api.highcharts.com/highcharts/chart.events.load)\n * handler is equivalent.\n *\n * @return {Highcharts.Chart}\n * Returns the Chart object.\n */\n Chart.chart = function (a, b, c) {\n return new Chart(a, b, c);\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Handle the arguments passed to the constructor.\n *\n * @private\n * @function Highcharts.Chart#getArgs\n *\n * @param {...Array<*>} arguments\n * All arguments for the constructor.\n *\n * @emits Highcharts.Chart#event:init\n * @emits Highcharts.Chart#event:afterInit\n */\n Chart.prototype.getArgs = function (a, b, c) {\n // Remove the optional first argument, renderTo, and\n // set it on this.\n if (isString(a) || a.nodeName) {\n this.renderTo = a;\n this.init(b, c);\n }\n else {\n this.init(a, b);\n }\n };\n /**\n * Overridable function that initializes the chart. The constructor's\n * arguments are passed on directly.\n *\n * @function Highcharts.Chart#init\n *\n * @param {Highcharts.Options} userOptions\n * Custom options.\n *\n * @param {Function} [callback]\n * Function to run when the chart has loaded and and all external\n * images are loaded.\n *\n *\n * @emits Highcharts.Chart#event:init\n * @emits Highcharts.Chart#event:afterInit\n */\n Chart.prototype.init = function (userOptions, callback) {\n // Handle regular options\n var userPlotOptions = userOptions.plotOptions || {};\n // Fire the event with a default function\n fireEvent(this, 'init', { args: arguments }, function () {\n var options = merge(defaultOptions,\n userOptions); // do the merge\n var optionsChart = options.chart;\n // Override (by copy of user options) or clear tooltip options\n // in chart.options.plotOptions (#6218)\n objectEach(options.plotOptions, function (typeOptions, type) {\n if (isObject(typeOptions)) { // #8766\n typeOptions.tooltip = (userPlotOptions[type] && // override by copy:\n merge(userPlotOptions[type].tooltip)) || void 0; // or clear\n }\n });\n // User options have higher priority than default options\n // (#6218). In case of exporting: path is changed\n options.tooltip.userOptions = (userOptions.chart &&\n userOptions.chart.forExport &&\n userOptions.tooltip.userOptions) || userOptions.tooltip;\n /**\n * The original options given to the constructor or a chart factory\n * like {@link Highcharts.chart} and {@link Highcharts.stockChart}.\n *\n * @name Highcharts.Chart#userOptions\n * @type {Highcharts.Options}\n */\n this.userOptions = userOptions;\n this.margin = [];\n this.spacing = [];\n // Pixel data bounds for touch zoom\n this.bounds = { h: {}, v: {} };\n // An array of functions that returns labels that should be\n // considered for anti-collision\n this.labelCollectors = [];\n this.callback = callback;\n this.isResizing = 0;\n var zooming = optionsChart.zooming = optionsChart.zooming || {};\n // Other options have no default so just pick\n if (userOptions.chart && !userOptions.chart.zooming) {\n zooming.resetButton = optionsChart.resetZoomButton;\n }\n zooming.key = pick(zooming.key, optionsChart.zoomKey);\n zooming.pinchType = pick(zooming.pinchType, optionsChart.pinchType);\n zooming.singleTouch = pick(zooming.singleTouch, optionsChart.zoomBySingleTouch);\n zooming.type = pick(zooming.type, optionsChart.zoomType);\n /**\n * The options structure for the chart after merging\n * {@link #defaultOptions} and {@link #userOptions}. It contains\n * members for the sub elements like series, legend, tooltip etc.\n *\n * @name Highcharts.Chart#options\n * @type {Highcharts.Options}\n */\n this.options = options;\n /**\n * All the axes in the chart.\n *\n * @see Highcharts.Chart.xAxis\n * @see Highcharts.Chart.yAxis\n *\n * @name Highcharts.Chart#axes\n * @type {Array}\n */\n this.axes = [];\n /**\n * All the current series in the chart.\n *\n * @name Highcharts.Chart#series\n * @type {Array}\n */\n this.series = [];\n /**\n * The `Time` object associated with the chart. Since v6.0.5,\n * time settings can be applied individually for each chart. If\n * no individual settings apply, the `Time` object is shared by\n * all instances.\n *\n * @name Highcharts.Chart#time\n * @type {Highcharts.Time}\n */\n this.time =\n userOptions.time && Object.keys(userOptions.time).length ?\n new Time(userOptions.time) :\n H.time;\n /**\n * Callback function to override the default function that formats\n * all the numbers in the chart. Returns a string with the formatted\n * number.\n *\n * @name Highcharts.Chart#numberFormatter\n * @type {Highcharts.NumberFormatterCallbackFunction}\n */\n this.numberFormatter = optionsChart.numberFormatter || numberFormat;\n /**\n * Whether the chart is in styled mode, meaning all presentatinoal\n * attributes are avoided.\n *\n * @name Highcharts.Chart#styledMode\n * @type {boolean}\n */\n this.styledMode = optionsChart.styledMode;\n this.hasCartesianSeries = optionsChart.showAxes;\n var chart = this;\n /**\n * Index position of the chart in the {@link Highcharts#charts}\n * property.\n *\n * @name Highcharts.Chart#index\n * @type {number}\n * @readonly\n */\n chart.index = charts.length; // Add the chart to the global lookup\n charts.push(chart);\n H.chartCount++;\n // Chart event handlers\n registerEventOptions(this, optionsChart);\n /**\n * A collection of the X axes in the chart.\n *\n * @name Highcharts.Chart#xAxis\n * @type {Array}\n */\n chart.xAxis = [];\n /**\n * A collection of the Y axes in the chart.\n *\n * @name Highcharts.Chart#yAxis\n * @type {Array}\n *\n * @todo\n * Make events official: Fire the event `afterInit`.\n */\n chart.yAxis = [];\n chart.pointCount = chart.colorCounter = chart.symbolCounter = 0;\n // Fire after init but before first render, before axes and series\n // have been initialized.\n fireEvent(chart, 'afterInit');\n chart.firstRender();\n });\n };\n /**\n * Internal function to unitialize an individual series.\n *\n * @private\n * @function Highcharts.Chart#initSeries\n */\n Chart.prototype.initSeries = function (options) {\n var chart = this,\n optionsChart = chart.options.chart,\n type = (options.type ||\n optionsChart.type ||\n optionsChart.defaultSeriesType),\n SeriesClass = seriesTypes[type];\n // No such series type\n if (!SeriesClass) {\n error(17, true, chart, { missingModuleFor: type });\n }\n var series = new SeriesClass();\n if (typeof series.init === 'function') {\n series.init(chart, options);\n }\n return series;\n };\n /**\n * Internal function to set data for all series with enabled sorting.\n *\n * @private\n * @function Highcharts.Chart#setSeriesData\n */\n Chart.prototype.setSeriesData = function () {\n this.getSeriesOrderByLinks().forEach(function (series) {\n // We need to set data for series with sorting after series init\n if (!series.points && !series.data && series.enabledDataSorting) {\n series.setData(series.options.data, false);\n }\n });\n };\n /**\n * Sort and return chart series in order depending on the number of linked\n * series.\n *\n * @private\n * @function Highcharts.Series#getSeriesOrderByLinks\n */\n Chart.prototype.getSeriesOrderByLinks = function () {\n return this.series.concat().sort(function (a, b) {\n if (a.linkedSeries.length || b.linkedSeries.length) {\n return b.linkedSeries.length - a.linkedSeries.length;\n }\n return 0;\n });\n };\n /**\n * Order all series above a given index. When series are added and ordered\n * by configuration, only the last series is handled (#248, #1123, #2456,\n * #6112). This function is called on series initialization and destroy.\n *\n * @private\n * @function Highcharts.Series#orderSeries\n * @param {number} [fromIndex]\n * If this is given, only the series above this index are handled.\n */\n Chart.prototype.orderSeries = function (fromIndex) {\n var series = this.series;\n for (var i = (fromIndex || 0), iEnd = series.length; i < iEnd; ++i) {\n if (series[i]) {\n /**\n * Contains the series' index in the `Chart.series` array.\n *\n * @name Highcharts.Series#index\n * @type {number}\n * @readonly\n */\n series[i].index = i;\n series[i].name = series[i].getName();\n }\n }\n };\n /**\n * Check whether a given point is within the plot area.\n *\n * @function Highcharts.Chart#isInsidePlot\n *\n * @param {number} plotX\n * Pixel x relative to the plot area.\n *\n * @param {number} plotY\n * Pixel y relative to the plot area.\n *\n * @param {Highcharts.ChartIsInsideOptionsObject} [options]\n * Options object.\n *\n * @return {boolean}\n * Returns true if the given point is inside the plot area.\n */\n Chart.prototype.isInsidePlot = function (plotX, plotY, options) {\n var _a;\n if (options === void 0) { options = {}; }\n var _b = this,\n inverted = _b.inverted,\n plotBox = _b.plotBox,\n plotLeft = _b.plotLeft,\n plotTop = _b.plotTop,\n scrollablePlotBox = _b.scrollablePlotBox;\n var scrollLeft = 0,\n scrollTop = 0;\n if (options.visiblePlotOnly && this.scrollingContainer) {\n (_a = this.scrollingContainer, scrollLeft = _a.scrollLeft, scrollTop = _a.scrollTop);\n }\n var series = options.series,\n box = (options.visiblePlotOnly && scrollablePlotBox) || plotBox,\n x = options.inverted ? plotY : plotX,\n y = options.inverted ? plotX : plotY,\n e = {\n x: x,\n y: y,\n isInsidePlot: true,\n options: options\n };\n if (!options.ignoreX) {\n var xAxis = (series &&\n (inverted && !this.polar ? series.yAxis : series.xAxis)) || {\n pos: plotLeft,\n len: Infinity\n };\n var chartX = options.paneCoordinates ?\n xAxis.pos + x : plotLeft + x;\n if (!(chartX >= Math.max(scrollLeft + plotLeft, xAxis.pos) &&\n chartX <= Math.min(scrollLeft + plotLeft + box.width, xAxis.pos + xAxis.len))) {\n e.isInsidePlot = false;\n }\n }\n if (!options.ignoreY && e.isInsidePlot) {\n var yAxis = (options.axis && !options.axis.isXAxis && options.axis) || (series && (inverted ? series.xAxis : series.yAxis)) || {\n pos: plotTop,\n len: Infinity\n };\n var chartY = options.paneCoordinates ?\n yAxis.pos + y : plotTop + y;\n if (!(chartY >= Math.max(scrollTop + plotTop, yAxis.pos) &&\n chartY <= Math.min(scrollTop + plotTop + box.height, yAxis.pos + yAxis.len))) {\n e.isInsidePlot = false;\n }\n }\n fireEvent(this, 'afterIsInsidePlot', e);\n return e.isInsidePlot;\n };\n /**\n * Redraw the chart after changes have been done to the data, axis extremes\n * chart size or chart elements. All methods for updating axes, series or\n * points have a parameter for redrawing the chart. This is `true` by\n * default. But in many cases you want to do more than one operation on the\n * chart before redrawing, for example add a number of points. In those\n * cases it is a waste of resources to redraw the chart for each new point\n * added. So you add the points and call `chart.redraw()` after.\n *\n * @function Highcharts.Chart#redraw\n *\n * @param {boolean|Partial} [animation]\n * If or how to apply animation to the redraw.\n *\n * @emits Highcharts.Chart#event:afterSetExtremes\n * @emits Highcharts.Chart#event:beforeRedraw\n * @emits Highcharts.Chart#event:predraw\n * @emits Highcharts.Chart#event:redraw\n * @emits Highcharts.Chart#event:render\n * @emits Highcharts.Chart#event:updatedData\n */\n Chart.prototype.redraw = function (animation) {\n fireEvent(this, 'beforeRedraw');\n var chart = this,\n axes = chart.hasCartesianSeries ? chart.axes : chart.colorAxis || [],\n series = chart.series,\n pointer = chart.pointer,\n legend = chart.legend,\n legendUserOptions = chart.userOptions.legend,\n renderer = chart.renderer,\n isHiddenChart = renderer.isHidden(),\n afterRedraw = [];\n var hasDirtyStacks,\n hasStackedSeries,\n i,\n isDirtyBox = chart.isDirtyBox,\n redrawLegend = chart.isDirtyLegend,\n serie;\n // Handle responsive rules, not only on resize (#6130)\n if (chart.setResponsive) {\n chart.setResponsive(false);\n }\n // Set the global animation. When chart.hasRendered is not true, the\n // redraw call comes from a responsive rule and animation should not\n // occur.\n setAnimation(chart.hasRendered ? animation : false, chart);\n if (isHiddenChart) {\n chart.temporaryDisplay();\n }\n // Adjust title layout (reflow multiline text)\n chart.layOutTitles();\n // link stacked series\n i = series.length;\n while (i--) {\n serie = series[i];\n if (serie.options.stacking || serie.options.centerInCategory) {\n hasStackedSeries = true;\n if (serie.isDirty) {\n hasDirtyStacks = true;\n break;\n }\n }\n }\n if (hasDirtyStacks) { // mark others as dirty\n i = series.length;\n while (i--) {\n serie = series[i];\n if (serie.options.stacking) {\n serie.isDirty = true;\n }\n }\n }\n // Handle updated data in the series\n series.forEach(function (serie) {\n if (serie.isDirty) {\n if (serie.options.legendType === 'point') {\n if (typeof serie.updateTotals === 'function') {\n serie.updateTotals();\n }\n redrawLegend = true;\n }\n else if (legendUserOptions &&\n (legendUserOptions.labelFormatter ||\n legendUserOptions.labelFormat)) {\n redrawLegend = true; // #2165\n }\n }\n if (serie.isDirtyData) {\n fireEvent(serie, 'updatedData');\n }\n });\n // handle added or removed series\n if (redrawLegend && legend && legend.options.enabled) {\n // draw legend graphics\n legend.render();\n chart.isDirtyLegend = false;\n }\n // reset stacks\n if (hasStackedSeries) {\n chart.getStacks();\n }\n // set axes scales\n axes.forEach(function (axis) {\n axis.updateNames();\n axis.setScale();\n });\n chart.getMargins(); // #3098\n // If one axis is dirty, all axes must be redrawn (#792, #2169)\n axes.forEach(function (axis) {\n if (axis.isDirty) {\n isDirtyBox = true;\n }\n });\n // redraw axes\n axes.forEach(function (axis) {\n // Fire 'afterSetExtremes' only if extremes are set\n var key = axis.min + ',' + axis.max;\n if (axis.extKey !== key) { // #821, #4452\n axis.extKey = key;\n // prevent a recursive call to chart.redraw() (#1119)\n afterRedraw.push(function () {\n fireEvent(axis, 'afterSetExtremes', extend(axis.eventArgs, axis.getExtremes())); // #747, #751\n delete axis.eventArgs;\n });\n }\n if (isDirtyBox || hasStackedSeries) {\n axis.redraw();\n }\n });\n // the plot areas size has changed\n if (isDirtyBox) {\n chart.drawChartBox();\n }\n // Fire an event before redrawing series, used by the boost module to\n // clear previous series renderings.\n fireEvent(chart, 'predraw');\n // redraw affected series\n series.forEach(function (serie) {\n if ((isDirtyBox || serie.isDirty) && serie.visible) {\n serie.redraw();\n }\n // Set it here, otherwise we will have unlimited 'updatedData' calls\n // for a hidden series after setData(). Fixes #6012\n serie.isDirtyData = false;\n });\n // move tooltip or reset\n if (pointer) {\n pointer.reset(true);\n }\n // redraw if canvas\n renderer.draw();\n // Fire the events\n fireEvent(chart, 'redraw');\n fireEvent(chart, 'render');\n if (isHiddenChart) {\n chart.temporaryDisplay(true);\n }\n // Fire callbacks that are put on hold until after the redraw\n afterRedraw.forEach(function (callback) {\n callback.call();\n });\n };\n /**\n * Get an axis, series or point object by `id` as given in the configuration\n * options. Returns `undefined` if no item is found.\n *\n * @sample highcharts/plotoptions/series-id/\n * Get series by id\n *\n * @function Highcharts.Chart#get\n *\n * @param {string} id\n * The id as given in the configuration options.\n *\n * @return {Highcharts.Axis|Highcharts.Series|Highcharts.Point|undefined}\n * The retrieved item.\n */\n Chart.prototype.get = function (id) {\n var series = this.series;\n /**\n * @private\n */\n function itemById(item) {\n return (item.id === id ||\n (item.options && item.options.id === id));\n }\n var ret = \n // Search axes\n find(this.axes,\n itemById) ||\n // Search series\n find(this.series,\n itemById);\n // Search points\n for (var i = 0; !ret && i < series.length; i++) {\n ret = find(series[i].points || [], itemById);\n }\n return ret;\n };\n /**\n * Create the Axis instances based on the config options.\n *\n * @private\n * @function Highcharts.Chart#getAxes\n * @emits Highcharts.Chart#event:afterGetAxes\n * @emits Highcharts.Chart#event:getAxes\n */\n Chart.prototype.getAxes = function () {\n var chart = this,\n options = this.options,\n xAxisOptions = options.xAxis = splat(options.xAxis || {}),\n yAxisOptions = options.yAxis = splat(options.yAxis || {});\n fireEvent(this, 'getAxes');\n // make sure the options are arrays and add some members\n xAxisOptions.forEach(function (axis, i) {\n axis.index = i;\n axis.isX = true;\n });\n yAxisOptions.forEach(function (axis, i) {\n axis.index = i;\n });\n // concatenate all axis options into one array\n var optionsArray = xAxisOptions.concat(yAxisOptions);\n optionsArray.forEach(function (axisOptions) {\n new Axis(chart, axisOptions); // eslint-disable-line no-new\n });\n fireEvent(this, 'afterGetAxes');\n };\n /**\n * Returns an array of all currently selected points in the chart. Points\n * can be selected by clicking or programmatically by the\n * {@link Highcharts.Point#select}\n * function.\n *\n * @sample highcharts/plotoptions/series-allowpointselect-line/\n * Get selected points\n *\n * @function Highcharts.Chart#getSelectedPoints\n *\n * @return {Array}\n * The currently selected points.\n */\n Chart.prototype.getSelectedPoints = function () {\n return this.series.reduce(function (acc, series) {\n // For one-to-one points inspect series.data in order to retrieve\n // points outside the visible range (#6445). For grouped data,\n // inspect the generated series.points.\n series.getPointsCollection()\n .forEach(function (point) {\n if (pick(point.selectedStaging, point.selected)) {\n acc.push(point);\n }\n });\n return acc;\n }, []);\n };\n /**\n * Returns an array of all currently selected series in the chart. Series\n * can be selected either programmatically by the\n * {@link Highcharts.Series#select}\n * function or by checking the checkbox next to the legend item if\n * [series.showCheckBox](https://api.highcharts.com/highcharts/plotOptions.series.showCheckbox)\n * is true.\n *\n * @sample highcharts/members/chart-getselectedseries/\n * Get selected series\n *\n * @function Highcharts.Chart#getSelectedSeries\n *\n * @return {Array}\n * The currently selected series.\n */\n Chart.prototype.getSelectedSeries = function () {\n return this.series.filter(function (serie) {\n return serie.selected;\n });\n };\n /**\n * Set a new title or subtitle for the chart.\n *\n * @sample highcharts/members/chart-settitle/\n * Set title text and styles\n *\n * @function Highcharts.Chart#setTitle\n *\n * @param {Highcharts.TitleOptions} [titleOptions]\n * New title options. The title text itself is set by the\n * `titleOptions.text` property.\n *\n * @param {Highcharts.SubtitleOptions} [subtitleOptions]\n * New subtitle options. The subtitle text itself is set by the\n * `subtitleOptions.text` property.\n *\n * @param {boolean} [redraw]\n * Whether to redraw the chart or wait for a later call to\n * `chart.redraw()`.\n */\n Chart.prototype.setTitle = function (titleOptions, subtitleOptions, redraw) {\n this.applyDescription('title', titleOptions);\n this.applyDescription('subtitle', subtitleOptions);\n // The initial call also adds the caption. On update, chart.update will\n // relay to Chart.setCaption.\n this.applyDescription('caption', void 0);\n this.layOutTitles(redraw);\n };\n /**\n * Apply a title, subtitle or caption for the chart\n *\n * @private\n * @function Highcharts.Chart#applyDescription\n * @param name {string}\n * Either title, subtitle or caption\n * @param {Highcharts.TitleOptions|Highcharts.SubtitleOptions|Highcharts.CaptionOptions|undefined} explicitOptions\n * The options to set, will be merged with default options.\n */\n Chart.prototype.applyDescription = function (name, explicitOptions) {\n var chart = this;\n // Default style\n var style = name === 'title' ? {\n color: \"#333333\" /* Palette.neutralColor80 */,\n fontSize: this.options.isStock ? '16px' : '18px' // #2944\n } : {\n color: \"#666666\" /* Palette.neutralColor60 */\n };\n // Merge default options with explicit options\n var options = this.options[name] = merge(\n // Default styles\n (!this.styledMode && { style: style }),\n this.options[name],\n explicitOptions);\n var elem = this[name];\n if (elem && explicitOptions) {\n this[name] = elem = elem.destroy(); // remove old\n }\n if (options && !elem) {\n elem = this.renderer.text(options.text, 0, 0, options.useHTML)\n .attr({\n align: options.align,\n 'class': 'highcharts-' + name,\n zIndex: options.zIndex || 4\n })\n .add();\n // Update methods, shortcut to Chart.setTitle, Chart.setSubtitle and\n // Chart.setCaption\n elem.update = function (updateOptions) {\n var fn = {\n title: 'setTitle',\n subtitle: 'setSubtitle',\n caption: 'setCaption'\n }[name];\n chart[fn](updateOptions);\n };\n // Presentational\n if (!this.styledMode) {\n elem.css(options.style);\n }\n /**\n * The chart title. The title has an `update` method that allows\n * modifying the options directly or indirectly via\n * `chart.update`.\n *\n * @sample highcharts/members/title-update/\n * Updating titles\n *\n * @name Highcharts.Chart#title\n * @type {Highcharts.TitleObject}\n */\n /**\n * The chart subtitle. The subtitle has an `update` method that\n * allows modifying the options directly or indirectly via\n * `chart.update`.\n *\n * @name Highcharts.Chart#subtitle\n * @type {Highcharts.SubtitleObject}\n */\n this[name] = elem;\n }\n };\n /**\n * Internal function to lay out the chart title, subtitle and caption, and\n * cache the full offset height for use in `getMargins`. The result is\n * stored in `this.titleOffset`.\n *\n * @private\n * @function Highcharts.Chart#layOutTitles\n *\n * @param {boolean} [redraw=true]\n * @emits Highcharts.Chart#event:afterLayOutTitles\n */\n Chart.prototype.layOutTitles = function (redraw) {\n var titleOffset = [0, 0, 0],\n renderer = this.renderer,\n spacingBox = this.spacingBox;\n // Lay out the title and the subtitle respectively\n ['title', 'subtitle', 'caption'].forEach(function (key) {\n var title = this[key], titleOptions = (this.options[key]), verticalAlign = titleOptions.verticalAlign || 'top', offset = key === 'title' ?\n verticalAlign === 'top' ? -3 : 0 :\n // Floating subtitle (#6574)\n verticalAlign === 'top' ? titleOffset[0] + 2 : 0;\n var titleSize,\n height;\n if (title) {\n if (!this.styledMode) {\n titleSize = (titleOptions.style &&\n titleOptions.style.fontSize);\n }\n titleSize = renderer.fontMetrics(titleSize, title).b;\n title\n .css({\n width: (titleOptions.width ||\n spacingBox.width + (titleOptions.widthAdjust || 0)) + 'px'\n });\n // Skip the cache for HTML (#3481, #11666)\n height = Math.round(title.getBBox(titleOptions.useHTML).height);\n title.align(extend({\n y: verticalAlign === 'bottom' ?\n titleSize :\n offset + titleSize,\n height: height\n }, titleOptions), false, 'spacingBox');\n if (!titleOptions.floating) {\n if (verticalAlign === 'top') {\n titleOffset[0] = Math.ceil(titleOffset[0] +\n height);\n }\n else if (verticalAlign === 'bottom') {\n titleOffset[2] = Math.ceil(titleOffset[2] +\n height);\n }\n }\n }\n }, this);\n // Handle title.margin and caption.margin\n if (titleOffset[0] &&\n (this.options.title.verticalAlign || 'top') === 'top') {\n titleOffset[0] += this.options.title.margin;\n }\n if (titleOffset[2] &&\n this.options.caption.verticalAlign === 'bottom') {\n titleOffset[2] += this.options.caption.margin;\n }\n var requiresDirtyBox = (!this.titleOffset ||\n this.titleOffset.join(',') !== titleOffset.join(','));\n // Used in getMargins\n this.titleOffset = titleOffset;\n fireEvent(this, 'afterLayOutTitles');\n if (!this.isDirtyBox && requiresDirtyBox) {\n this.isDirtyBox = this.isDirtyLegend = requiresDirtyBox;\n // Redraw if necessary (#2719, #2744)\n if (this.hasRendered && pick(redraw, true) && this.isDirtyBox) {\n this.redraw();\n }\n }\n };\n /**\n * Internal function to get the chart width and height according to options\n * and container size. Sets {@link Chart.chartWidth} and\n * {@link Chart.chartHeight}.\n *\n * @private\n * @function Highcharts.Chart#getChartSize\n */\n Chart.prototype.getChartSize = function () {\n var chart = this,\n optionsChart = chart.options.chart,\n widthOption = optionsChart.width,\n heightOption = optionsChart.height,\n renderTo = chart.renderTo;\n // Get inner width and height\n if (!defined(widthOption)) {\n chart.containerWidth = getStyle(renderTo, 'width');\n }\n if (!defined(heightOption)) {\n chart.containerHeight = getStyle(renderTo, 'height');\n }\n /**\n * The current pixel width of the chart.\n *\n * @name Highcharts.Chart#chartWidth\n * @type {number}\n */\n chart.chartWidth = Math.max(// #1393\n 0, widthOption || chart.containerWidth || 600 // #1460\n );\n /**\n * The current pixel height of the chart.\n *\n * @name Highcharts.Chart#chartHeight\n * @type {number}\n */\n chart.chartHeight = Math.max(0, relativeLength(heightOption, chart.chartWidth) ||\n (chart.containerHeight > 1 ?\n chart.containerHeight :\n 400));\n };\n /**\n * If the renderTo element has no offsetWidth, most likely one or more of\n * its parents are hidden. Loop up the DOM tree to temporarily display the\n * parents, then save the original display properties, and when the true\n * size is retrieved, reset them. Used on first render and on redraws.\n *\n * @private\n * @function Highcharts.Chart#temporaryDisplay\n *\n * @param {boolean} [revert]\n * Revert to the saved original styles.\n */\n Chart.prototype.temporaryDisplay = function (revert) {\n var node = this.renderTo,\n tempStyle;\n if (!revert) {\n while (node && node.style) {\n // When rendering to a detached node, it needs to be temporarily\n // attached in order to read styling and bounding boxes (#5783,\n // #7024).\n if (!doc.body.contains(node) && !node.parentNode) {\n node.hcOrigDetached = true;\n doc.body.appendChild(node);\n }\n if (getStyle(node, 'display', false) === 'none' ||\n node.hcOricDetached) {\n node.hcOrigStyle = {\n display: node.style.display,\n height: node.style.height,\n overflow: node.style.overflow\n };\n tempStyle = {\n display: 'block',\n overflow: 'hidden'\n };\n if (node !== this.renderTo) {\n tempStyle.height = 0;\n }\n css(node, tempStyle);\n // If it still doesn't have an offset width after setting\n // display to block, it probably has an !important priority\n // #2631, 6803\n if (!node.offsetWidth) {\n node.style.setProperty('display', 'block', 'important');\n }\n }\n node = node.parentNode;\n if (node === doc.body) {\n break;\n }\n }\n }\n else {\n while (node && node.style) {\n if (node.hcOrigStyle) {\n css(node, node.hcOrigStyle);\n delete node.hcOrigStyle;\n }\n if (node.hcOrigDetached) {\n doc.body.removeChild(node);\n node.hcOrigDetached = false;\n }\n node = node.parentNode;\n }\n }\n };\n /**\n * Set the {@link Chart.container|chart container's} class name, in\n * addition to `highcharts-container`.\n *\n * @function Highcharts.Chart#setClassName\n *\n * @param {string} [className]\n * The additional class name.\n */\n Chart.prototype.setClassName = function (className) {\n this.container.className = 'highcharts-container ' + (className || '');\n };\n /**\n * Get the containing element, determine the size and create the inner\n * container div to hold the chart.\n *\n * @private\n * @function Highcharts.Chart#afterGetContainer\n * @emits Highcharts.Chart#event:afterGetContainer\n */\n Chart.prototype.getContainer = function () {\n var chart = this,\n options = chart.options,\n optionsChart = options.chart,\n indexAttrName = 'data-highcharts-chart',\n containerId = uniqueKey();\n var containerStyle,\n renderTo = chart.renderTo;\n if (!renderTo) {\n chart.renderTo = renderTo =\n optionsChart.renderTo;\n }\n if (isString(renderTo)) {\n chart.renderTo = renderTo =\n doc.getElementById(renderTo);\n }\n // Display an error if the renderTo is wrong\n if (!renderTo) {\n error(13, true, chart);\n }\n // If the container already holds a chart, destroy it. The check for\n // hasRendered is there because web pages that are saved to disk from\n // the browser, will preserve the data-highcharts-chart attribute and\n // the SVG contents, but not an interactive chart. So in this case,\n // charts[oldChartIndex] will point to the wrong chart if any (#2609).\n var oldChartIndex = pInt(attr(renderTo,\n indexAttrName));\n if (isNumber(oldChartIndex) &&\n charts[oldChartIndex] &&\n charts[oldChartIndex].hasRendered) {\n charts[oldChartIndex].destroy();\n }\n // Make a reference to the chart from the div\n attr(renderTo, indexAttrName, chart.index);\n // remove previous chart\n renderTo.innerHTML = AST.emptyHTML;\n // If the container doesn't have an offsetWidth, it has or is a child of\n // a node that has display:none. We need to temporarily move it out to a\n // visible state to determine the size, else the legend and tooltips\n // won't render properly. The skipClone option is used in sparklines as\n // a micro optimization, saving about 1-2 ms each chart.\n if (!optionsChart.skipClone && !renderTo.offsetWidth) {\n chart.temporaryDisplay();\n }\n // get the width and height\n chart.getChartSize();\n var chartWidth = chart.chartWidth;\n var chartHeight = chart.chartHeight;\n // Allow table cells and flex-boxes to shrink without the chart blocking\n // them out (#6427)\n css(renderTo, { overflow: 'hidden' });\n // Create the inner container\n if (!chart.styledMode) {\n containerStyle = extend({\n position: 'relative',\n // needed for context menu (avoidscrollbars) and content\n // overflow in IE\n overflow: 'hidden',\n width: chartWidth + 'px',\n height: chartHeight + 'px',\n textAlign: 'left',\n lineHeight: 'normal',\n zIndex: 0,\n '-webkit-tap-highlight-color': 'rgba(0,0,0,0)',\n userSelect: 'none',\n 'touch-action': 'manipulation',\n outline: 'none'\n }, optionsChart.style || {});\n }\n /**\n * The containing HTML element of the chart. The container is\n * dynamically inserted into the element given as the `renderTo`\n * parameter in the {@link Highcharts#chart} constructor.\n *\n * @name Highcharts.Chart#container\n * @type {Highcharts.HTMLDOMElement}\n */\n var container = createElement('div', {\n id: containerId\n },\n containerStyle,\n renderTo);\n chart.container = container;\n // cache the cursor (#1650)\n chart._cursor = container.style.cursor;\n // Initialize the renderer\n var Renderer = optionsChart.renderer || !svg ?\n RendererRegistry.getRendererType(optionsChart.renderer) :\n SVGRenderer;\n /**\n * The renderer instance of the chart. Each chart instance has only one\n * associated renderer.\n *\n * @name Highcharts.Chart#renderer\n * @type {Highcharts.SVGRenderer}\n */\n chart.renderer = new Renderer(container, chartWidth, chartHeight, void 0, optionsChart.forExport, options.exporting && options.exporting.allowHTML, chart.styledMode);\n // Set the initial animation from the options\n setAnimation(void 0, chart);\n chart.setClassName(optionsChart.className);\n if (!chart.styledMode) {\n chart.renderer.setStyle(optionsChart.style);\n }\n else {\n // Initialize definitions\n for (var key in options.defs) { // eslint-disable-line guard-for-in\n this.renderer.definition(options.defs[key]);\n }\n }\n // Add a reference to the charts index\n chart.renderer.chartIndex = chart.index;\n fireEvent(this, 'afterGetContainer');\n };\n /**\n * Calculate margins by rendering axis labels in a preliminary position.\n * Title, subtitle and legend have already been rendered at this stage, but\n * will be moved into their final positions.\n *\n * @private\n * @function Highcharts.Chart#getMargins\n * @emits Highcharts.Chart#event:getMargins\n */\n Chart.prototype.getMargins = function (skipAxes) {\n var _a = this,\n spacing = _a.spacing,\n margin = _a.margin,\n titleOffset = _a.titleOffset;\n this.resetMargins();\n // Adjust for title and subtitle\n if (titleOffset[0] && !defined(margin[0])) {\n this.plotTop = Math.max(this.plotTop, titleOffset[0] + spacing[0]);\n }\n if (titleOffset[2] && !defined(margin[2])) {\n this.marginBottom = Math.max(this.marginBottom, titleOffset[2] + spacing[2]);\n }\n // Adjust for legend\n if (this.legend && this.legend.display) {\n this.legend.adjustMargins(margin, spacing);\n }\n fireEvent(this, 'getMargins');\n if (!skipAxes) {\n this.getAxisMargins();\n }\n };\n /**\n * @private\n * @function Highcharts.Chart#getAxisMargins\n */\n Chart.prototype.getAxisMargins = function () {\n var chart = this, \n // [top, right, bottom, left]\n axisOffset = chart.axisOffset = [0, 0, 0, 0],\n colorAxis = chart.colorAxis,\n margin = chart.margin,\n getOffset = function (axes) {\n axes.forEach(function (axis) {\n if (axis.visible) {\n axis.getOffset();\n }\n });\n };\n // pre-render axes to get labels offset width\n if (chart.hasCartesianSeries) {\n getOffset(chart.axes);\n }\n else if (colorAxis && colorAxis.length) {\n getOffset(colorAxis);\n }\n // Add the axis offsets\n marginNames.forEach(function (m, side) {\n if (!defined(margin[side])) {\n chart[m] += axisOffset[side];\n }\n });\n chart.setChartSize();\n };\n /**\n * Reflows the chart to its container. By default, the chart reflows\n * automatically to its container following a `window.resize` event, as per\n * the [chart.reflow](https://api.highcharts.com/highcharts/chart.reflow)\n * option. However, there are no reliable events for div resize, so if the\n * container is resized without a window resize event, this must be called\n * explicitly.\n *\n * @sample highcharts/members/chart-reflow/\n * Resize div and reflow\n * @sample highcharts/chart/events-container/\n * Pop up and reflow\n *\n * @function Highcharts.Chart#reflow\n *\n * @param {global.Event} [e]\n * Event arguments. Used primarily when the function is called\n * internally as a response to window resize.\n */\n Chart.prototype.reflow = function (e) {\n var chart = this, optionsChart = chart.options.chart, renderTo = chart.renderTo, hasUserSize = (defined(optionsChart.width) &&\n defined(optionsChart.height)), width = optionsChart.width || getStyle(renderTo, 'width'), height = optionsChart.height || getStyle(renderTo, 'height'), target = e ? e.target : win;\n delete chart.pointer.chartPosition;\n // Width and height checks for display:none. Target is doc in IE8 and\n // Opera, win in Firefox, Chrome and IE9.\n if (!hasUserSize &&\n !chart.isPrinting &&\n width &&\n height &&\n (target === win || target === doc)) {\n if (width !== chart.containerWidth ||\n height !== chart.containerHeight) {\n U.clearTimeout(chart.reflowTimeout);\n // When called from window.resize, e is set, else it's called\n // directly (#2224)\n chart.reflowTimeout = syncTimeout(function () {\n // Set size, it may have been destroyed in the meantime\n // (#1257)\n if (chart.container) {\n chart.setSize(void 0, void 0, false);\n }\n }, e ? 100 : 0);\n }\n chart.containerWidth = width;\n chart.containerHeight = height;\n }\n };\n /**\n * Toggle the event handlers necessary for auto resizing, depending on the\n * `chart.reflow` option.\n *\n * @private\n * @function Highcharts.Chart#setReflow\n */\n Chart.prototype.setReflow = function (reflow) {\n var chart = this;\n if (reflow !== false && !this.unbindReflow) {\n this.unbindReflow = addEvent(win, 'resize', function (e) {\n // a removed event listener still runs in Edge and IE if the\n // listener was removed while the event runs, so check if the\n // chart is not destroyed (#11609)\n if (chart.options) {\n chart.reflow(e);\n }\n });\n addEvent(this, 'destroy', this.unbindReflow);\n }\n else if (reflow === false && this.unbindReflow) {\n // Unbind and unset\n this.unbindReflow = this.unbindReflow();\n }\n // The following will add listeners to re-fit the chart before and after\n // printing (#2284). However it only works in WebKit. Should have worked\n // in Firefox, but not supported in IE.\n /*\n if (win.matchMedia) {\n win.matchMedia('print').addListener(function reflow() {\n chart.reflow();\n });\n }\n //*/\n };\n /**\n * Resize the chart to a given width and height. In order to set the width\n * only, the height argument may be skipped. To set the height only, pass\n * `undefined` for the width.\n *\n * @sample highcharts/members/chart-setsize-button/\n * Test resizing from buttons\n * @sample highcharts/members/chart-setsize-jquery-resizable/\n * Add a jQuery UI resizable\n * @sample stock/members/chart-setsize/\n * Highcharts Stock with UI resizable\n *\n * @function Highcharts.Chart#setSize\n *\n * @param {number|null} [width]\n * The new pixel width of the chart. Since v4.2.6, the argument can\n * be `undefined` in order to preserve the current value (when\n * setting height only), or `null` to adapt to the width of the\n * containing element.\n *\n * @param {number|null} [height]\n * The new pixel height of the chart. Since v4.2.6, the argument can\n * be `undefined` in order to preserve the current value, or `null`\n * in order to adapt to the height of the containing element.\n *\n * @param {boolean|Partial} [animation=true]\n * Whether and how to apply animation.\n *\n *\n * @emits Highcharts.Chart#event:endResize\n * @emits Highcharts.Chart#event:resize\n */\n Chart.prototype.setSize = function (width, height, animation) {\n var chart = this,\n renderer = chart.renderer;\n // Handle the isResizing counter\n chart.isResizing += 1;\n // set the animation for the current process\n setAnimation(animation, chart);\n var globalAnimation = renderer.globalAnimation;\n chart.oldChartHeight = chart.chartHeight;\n chart.oldChartWidth = chart.chartWidth;\n if (typeof width !== 'undefined') {\n chart.options.chart.width = width;\n }\n if (typeof height !== 'undefined') {\n chart.options.chart.height = height;\n }\n chart.getChartSize();\n // Resize the container with the global animation applied if enabled\n // (#2503)\n if (!chart.styledMode) {\n (globalAnimation ? animate : css)(chart.container, {\n width: chart.chartWidth + 'px',\n height: chart.chartHeight + 'px'\n }, globalAnimation);\n }\n chart.setChartSize(true);\n renderer.setSize(chart.chartWidth, chart.chartHeight, globalAnimation);\n // handle axes\n chart.axes.forEach(function (axis) {\n axis.isDirty = true;\n axis.setScale();\n });\n chart.isDirtyLegend = true; // force legend redraw\n chart.isDirtyBox = true; // force redraw of plot and chart border\n chart.layOutTitles(); // #2857\n chart.getMargins();\n chart.redraw(globalAnimation);\n chart.oldChartHeight = null;\n fireEvent(chart, 'resize');\n // Fire endResize and set isResizing back. If animation is disabled,\n // fire without delay\n syncTimeout(function () {\n if (chart) {\n fireEvent(chart, 'endResize', null, function () {\n chart.isResizing -= 1;\n });\n }\n }, animObject(globalAnimation).duration);\n };\n /**\n * Set the public chart properties. This is done before and after the\n * pre-render to determine margin sizes.\n *\n * @private\n * @function Highcharts.Chart#setChartSize\n * @emits Highcharts.Chart#event:afterSetChartSize\n */\n Chart.prototype.setChartSize = function (skipAxes) {\n var chart = this,\n inverted = chart.inverted,\n renderer = chart.renderer,\n chartWidth = chart.chartWidth,\n chartHeight = chart.chartHeight,\n optionsChart = chart.options.chart,\n spacing = chart.spacing,\n clipOffset = chart.clipOffset;\n var plotLeft,\n plotTop,\n plotWidth,\n plotHeight;\n /**\n * The current left position of the plot area in pixels.\n *\n * @name Highcharts.Chart#plotLeft\n * @type {number}\n */\n chart.plotLeft = plotLeft = Math.round(chart.plotLeft);\n /**\n * The current top position of the plot area in pixels.\n *\n * @name Highcharts.Chart#plotTop\n * @type {number}\n */\n chart.plotTop = plotTop = Math.round(chart.plotTop);\n /**\n * The current width of the plot area in pixels.\n *\n * @name Highcharts.Chart#plotWidth\n * @type {number}\n */\n chart.plotWidth = plotWidth = Math.max(0, Math.round(chartWidth - plotLeft - chart.marginRight));\n /**\n * The current height of the plot area in pixels.\n *\n * @name Highcharts.Chart#plotHeight\n * @type {number}\n */\n chart.plotHeight = plotHeight = Math.max(0, Math.round(chartHeight - plotTop - chart.marginBottom));\n chart.plotSizeX = inverted ? plotHeight : plotWidth;\n chart.plotSizeY = inverted ? plotWidth : plotHeight;\n chart.plotBorderWidth = optionsChart.plotBorderWidth || 0;\n // Set boxes used for alignment\n chart.spacingBox = renderer.spacingBox = {\n x: spacing[3],\n y: spacing[0],\n width: chartWidth - spacing[3] - spacing[1],\n height: chartHeight - spacing[0] - spacing[2]\n };\n chart.plotBox = renderer.plotBox = {\n x: plotLeft,\n y: plotTop,\n width: plotWidth,\n height: plotHeight\n };\n var plotBorderWidth = 2 * Math.floor(chart.plotBorderWidth / 2),\n clipX = Math.ceil(Math.max(plotBorderWidth,\n clipOffset[3]) / 2),\n clipY = Math.ceil(Math.max(plotBorderWidth,\n clipOffset[0]) / 2);\n chart.clipBox = {\n x: clipX,\n y: clipY,\n width: Math.floor(chart.plotSizeX -\n Math.max(plotBorderWidth, clipOffset[1]) / 2 -\n clipX),\n height: Math.max(0, Math.floor(chart.plotSizeY -\n Math.max(plotBorderWidth, clipOffset[2]) / 2 -\n clipY))\n };\n if (!skipAxes) {\n chart.axes.forEach(function (axis) {\n axis.setAxisSize();\n axis.setAxisTranslation();\n });\n renderer.alignElements();\n }\n fireEvent(chart, 'afterSetChartSize', { skipAxes: skipAxes });\n };\n /**\n * Initial margins before auto size margins are applied.\n *\n * @private\n * @function Highcharts.Chart#resetMargins\n */\n Chart.prototype.resetMargins = function () {\n fireEvent(this, 'resetMargins');\n var chart = this,\n chartOptions = chart.options.chart;\n // Create margin and spacing array\n ['margin', 'spacing'].forEach(function splashArrays(target) {\n var value = chartOptions[target],\n values = isObject(value) ? value : [value,\n value,\n value,\n value];\n [\n 'Top',\n 'Right',\n 'Bottom',\n 'Left'\n ].forEach(function (sideName, side) {\n chart[target][side] = pick(chartOptions[target + sideName], values[side]);\n });\n });\n // Set margin names like chart.plotTop, chart.plotLeft,\n // chart.marginRight, chart.marginBottom.\n marginNames.forEach(function (m, side) {\n chart[m] = pick(chart.margin[side], chart.spacing[side]);\n });\n chart.axisOffset = [0, 0, 0, 0]; // top, right, bottom, left\n chart.clipOffset = [0, 0, 0, 0];\n };\n /**\n * Internal function to draw or redraw the borders and backgrounds for chart\n * and plot area.\n *\n * @private\n * @function Highcharts.Chart#drawChartBox\n * @emits Highcharts.Chart#event:afterDrawChartBox\n */\n Chart.prototype.drawChartBox = function () {\n var chart = this,\n optionsChart = chart.options.chart,\n renderer = chart.renderer,\n chartWidth = chart.chartWidth,\n chartHeight = chart.chartHeight,\n styledMode = chart.styledMode,\n plotBGImage = chart.plotBGImage,\n chartBackgroundColor = optionsChart.backgroundColor,\n plotBackgroundColor = optionsChart.plotBackgroundColor,\n plotBackgroundImage = optionsChart.plotBackgroundImage,\n plotLeft = chart.plotLeft,\n plotTop = chart.plotTop,\n plotWidth = chart.plotWidth,\n plotHeight = chart.plotHeight,\n plotBox = chart.plotBox,\n clipRect = chart.clipRect,\n clipBox = chart.clipBox;\n var chartBackground = chart.chartBackground,\n plotBackground = chart.plotBackground,\n plotBorder = chart.plotBorder,\n chartBorderWidth,\n mgn,\n bgAttr,\n verb = 'animate';\n // Chart area\n if (!chartBackground) {\n chart.chartBackground = chartBackground = renderer.rect()\n .addClass('highcharts-background')\n .add();\n verb = 'attr';\n }\n if (!styledMode) {\n // Presentational\n chartBorderWidth = optionsChart.borderWidth || 0;\n mgn = chartBorderWidth + (optionsChart.shadow ? 8 : 0);\n bgAttr = {\n fill: chartBackgroundColor || 'none'\n };\n if (chartBorderWidth || chartBackground['stroke-width']) { // #980\n bgAttr.stroke = optionsChart.borderColor;\n bgAttr['stroke-width'] = chartBorderWidth;\n }\n chartBackground\n .attr(bgAttr)\n .shadow(optionsChart.shadow);\n }\n else {\n chartBorderWidth = mgn = chartBackground.strokeWidth();\n }\n chartBackground[verb]({\n x: mgn / 2,\n y: mgn / 2,\n width: chartWidth - mgn - chartBorderWidth % 2,\n height: chartHeight - mgn - chartBorderWidth % 2,\n r: optionsChart.borderRadius\n });\n // Plot background\n verb = 'animate';\n if (!plotBackground) {\n verb = 'attr';\n chart.plotBackground = plotBackground = renderer.rect()\n .addClass('highcharts-plot-background')\n .add();\n }\n plotBackground[verb](plotBox);\n if (!styledMode) {\n // Presentational attributes for the background\n plotBackground\n .attr({\n fill: plotBackgroundColor || 'none'\n })\n .shadow(optionsChart.plotShadow);\n // Create the background image\n if (plotBackgroundImage) {\n if (!plotBGImage) {\n chart.plotBGImage = renderer.image(plotBackgroundImage, plotLeft, plotTop, plotWidth, plotHeight).add();\n }\n else {\n if (plotBackgroundImage !== plotBGImage.attr('href')) {\n plotBGImage.attr('href', plotBackgroundImage);\n }\n plotBGImage.animate(plotBox);\n }\n }\n }\n // Plot clip\n if (!clipRect) {\n chart.clipRect = renderer.clipRect(clipBox);\n }\n else {\n clipRect.animate({\n width: clipBox.width,\n height: clipBox.height\n });\n }\n // Plot area border\n verb = 'animate';\n if (!plotBorder) {\n verb = 'attr';\n chart.plotBorder = plotBorder = renderer.rect()\n .addClass('highcharts-plot-border')\n .attr({\n zIndex: 1 // Above the grid\n })\n .add();\n }\n if (!styledMode) {\n // Presentational\n plotBorder.attr({\n stroke: optionsChart.plotBorderColor,\n 'stroke-width': optionsChart.plotBorderWidth || 0,\n fill: 'none'\n });\n }\n plotBorder[verb](plotBorder.crisp({\n x: plotLeft,\n y: plotTop,\n width: plotWidth,\n height: plotHeight\n }, -plotBorder.strokeWidth())); // #3282 plotBorder should be negative;\n // reset\n chart.isDirtyBox = false;\n fireEvent(this, 'afterDrawChartBox');\n };\n /**\n * Detect whether a certain chart property is needed based on inspecting its\n * options and series. This mainly applies to the chart.inverted property,\n * and in extensions to the chart.angular and chart.polar properties.\n *\n * @private\n * @function Highcharts.Chart#propFromSeries\n */\n Chart.prototype.propFromSeries = function () {\n var chart = this,\n optionsChart = chart.options.chart,\n seriesOptions = chart.options.series;\n var i,\n klass,\n value;\n /**\n * The flag is set to `true` if a series of the chart is inverted.\n *\n * @name Highcharts.Chart#inverted\n * @type {boolean|undefined}\n */\n ['inverted', 'angular', 'polar'].forEach(function (key) {\n // The default series type's class\n klass = seriesTypes[(optionsChart.type || optionsChart.defaultSeriesType)];\n // Get the value from available chart-wide properties\n value =\n // It is set in the options:\n optionsChart[key] ||\n // The default series class:\n (klass && klass.prototype[key]);\n // requires it\n // 4. Check if any the chart's series require it\n i = seriesOptions && seriesOptions.length;\n while (!value && i--) {\n klass = seriesTypes[seriesOptions[i].type];\n if (klass && klass.prototype[key]) {\n value = true;\n }\n }\n // Set the chart property\n chart[key] = value;\n });\n };\n /**\n * Internal function to link two or more series together, based on the\n * `linkedTo` option. This is done from `Chart.render`, and after\n * `Chart.addSeries` and `Series.remove`.\n *\n * @private\n * @function Highcharts.Chart#linkSeries\n * @emits Highcharts.Chart#event:afterLinkSeries\n */\n Chart.prototype.linkSeries = function () {\n var chart = this,\n chartSeries = chart.series;\n // Reset links\n chartSeries.forEach(function (series) {\n series.linkedSeries.length = 0;\n });\n // Apply new links\n chartSeries.forEach(function (series) {\n var linkedTo = series.options.linkedTo;\n if (isString(linkedTo)) {\n if (linkedTo === ':previous') {\n linkedTo = chart.series[series.index - 1];\n }\n else {\n linkedTo = chart.get(linkedTo);\n }\n // #3341 avoid mutual linking\n if (linkedTo && linkedTo.linkedParent !== series) {\n linkedTo.linkedSeries.push(series);\n series.linkedParent = linkedTo;\n if (linkedTo.enabledDataSorting) {\n series.setDataSortingOptions();\n }\n series.visible = pick(series.options.visible, linkedTo.options.visible, series.visible); // #3879\n }\n }\n });\n fireEvent(this, 'afterLinkSeries');\n };\n /**\n * Render series for the chart.\n *\n * @private\n * @function Highcharts.Chart#renderSeries\n */\n Chart.prototype.renderSeries = function () {\n this.series.forEach(function (serie) {\n serie.translate();\n serie.render();\n });\n };\n /**\n * Render labels for the chart.\n *\n * @private\n * @function Highcharts.Chart#renderLabels\n */\n Chart.prototype.renderLabels = function () {\n var chart = this,\n labels = chart.options.labels;\n if (labels.items) {\n labels.items.forEach(function (label) {\n var style = extend(labels.style,\n label.style),\n x = pInt(style.left) + chart.plotLeft,\n y = pInt(style.top) + chart.plotTop + 12;\n // delete to prevent rewriting in IE\n delete style.left;\n delete style.top;\n chart.renderer.text(label.html, x, y)\n .attr({ zIndex: 2 })\n .css(style)\n .add();\n });\n }\n };\n /**\n * Render all graphics for the chart. Runs internally on initialization.\n *\n * @private\n * @function Highcharts.Chart#render\n */\n Chart.prototype.render = function () {\n var chart = this,\n axes = chart.axes,\n colorAxis = chart.colorAxis,\n renderer = chart.renderer,\n options = chart.options,\n renderAxes = function (axes) {\n axes.forEach(function (axis) {\n if (axis.visible) {\n axis.render();\n }\n });\n };\n var correction = 0; // correction for X axis labels\n // Title\n chart.setTitle();\n /**\n * The overview of the chart's series.\n *\n * @name Highcharts.Chart#legend\n * @type {Highcharts.Legend}\n */\n chart.legend = new Legend(chart, options.legend);\n // Get stacks\n if (chart.getStacks) {\n chart.getStacks();\n }\n // Get chart margins\n chart.getMargins(true);\n chart.setChartSize();\n // Record preliminary dimensions for later comparison\n var tempWidth = chart.plotWidth;\n axes.some(function (axis) {\n if (axis.horiz &&\n axis.visible &&\n axis.options.labels.enabled &&\n axis.series.length) {\n // 21 is the most common correction for X axis labels\n correction = 21;\n return true;\n }\n });\n // use Math.max to prevent negative plotHeight\n chart.plotHeight = Math.max(chart.plotHeight - correction, 0);\n var tempHeight = chart.plotHeight;\n // Get margins by pre-rendering axes\n axes.forEach(function (axis) {\n axis.setScale();\n });\n chart.getAxisMargins();\n // If the plot area size has changed significantly, calculate tick\n // positions again\n var redoHorizontal = tempWidth / chart.plotWidth > 1.1;\n // Height is more sensitive, use lower threshold\n var redoVertical = tempHeight / chart.plotHeight > 1.05;\n if (redoHorizontal || redoVertical) {\n axes.forEach(function (axis) {\n if ((axis.horiz && redoHorizontal) ||\n (!axis.horiz && redoVertical)) {\n // update to reflect the new margins\n axis.setTickInterval(true);\n }\n });\n chart.getMargins(); // second pass to check for new labels\n }\n // Draw the borders and backgrounds\n chart.drawChartBox();\n // Axes\n if (chart.hasCartesianSeries) {\n renderAxes(axes);\n }\n else if (colorAxis && colorAxis.length) {\n renderAxes(colorAxis);\n }\n // The series\n if (!chart.seriesGroup) {\n chart.seriesGroup = renderer.g('series-group')\n .attr({ zIndex: 3 })\n .add();\n }\n chart.renderSeries();\n // Labels\n chart.renderLabels();\n // Credits\n chart.addCredits();\n // Handle responsiveness\n if (chart.setResponsive) {\n chart.setResponsive();\n }\n // Set flag\n chart.hasRendered = true;\n };\n /**\n * Set a new credits label for the chart.\n *\n * @sample highcharts/credits/credits-update/\n * Add and update credits\n *\n * @function Highcharts.Chart#addCredits\n *\n * @param {Highcharts.CreditsOptions} [credits]\n * A configuration object for the new credits.\n */\n Chart.prototype.addCredits = function (credits) {\n var chart = this,\n creds = merge(true,\n this.options.credits,\n credits);\n if (creds.enabled && !this.credits) {\n /**\n * The chart's credits label. The label has an `update` method that\n * allows setting new options as per the\n * [credits options set](https://api.highcharts.com/highcharts/credits).\n *\n * @name Highcharts.Chart#credits\n * @type {Highcharts.SVGElement}\n */\n this.credits = this.renderer.text(creds.text + (this.mapCredits || ''), 0, 0)\n .addClass('highcharts-credits')\n .on('click', function () {\n if (creds.href) {\n win.location.href = creds.href;\n }\n })\n .attr({\n align: creds.position.align,\n zIndex: 8\n });\n if (!chart.styledMode) {\n this.credits.css(creds.style);\n }\n this.credits\n .add()\n .align(creds.position);\n // Dynamically update\n this.credits.update = function (options) {\n chart.credits = chart.credits.destroy();\n chart.addCredits(options);\n };\n }\n };\n /**\n * Remove the chart and purge memory. This method is called internally\n * before adding a second chart into the same container, as well as on\n * window unload to prevent leaks.\n *\n * @sample highcharts/members/chart-destroy/\n * Destroy the chart from a button\n * @sample stock/members/chart-destroy/\n * Destroy with Highcharts Stock\n *\n * @function Highcharts.Chart#destroy\n *\n * @emits Highcharts.Chart#event:destroy\n */\n Chart.prototype.destroy = function () {\n var chart = this,\n axes = chart.axes,\n series = chart.series,\n container = chart.container,\n parentNode = container && container.parentNode;\n var i;\n // fire the chart.destoy event\n fireEvent(chart, 'destroy');\n // Delete the chart from charts lookup array\n if (chart.renderer.forExport) {\n erase(charts, chart); // #6569\n }\n else {\n charts[chart.index] = void 0;\n }\n H.chartCount--;\n chart.renderTo.removeAttribute('data-highcharts-chart');\n // remove events\n removeEvent(chart);\n // ==== Destroy collections:\n // Destroy axes\n i = axes.length;\n while (i--) {\n axes[i] = axes[i].destroy();\n }\n // Destroy scroller & scroller series before destroying base series\n if (this.scroller && this.scroller.destroy) {\n this.scroller.destroy();\n }\n // Destroy each series\n i = series.length;\n while (i--) {\n series[i] = series[i].destroy();\n }\n // ==== Destroy chart properties:\n [\n 'title', 'subtitle', 'chartBackground', 'plotBackground',\n 'plotBGImage', 'plotBorder', 'seriesGroup', 'clipRect', 'credits',\n 'pointer', 'rangeSelector', 'legend', 'resetZoomButton', 'tooltip',\n 'renderer'\n ].forEach(function (name) {\n var prop = chart[name];\n if (prop && prop.destroy) {\n chart[name] = prop.destroy();\n }\n });\n // Remove container and all SVG, check container as it can break in IE\n // when destroyed before finished loading\n if (container) {\n container.innerHTML = AST.emptyHTML;\n removeEvent(container);\n if (parentNode) {\n discardElement(container);\n }\n }\n // clean it all up\n objectEach(chart, function (val, key) {\n delete chart[key];\n });\n };\n /**\n * Prepare for first rendering after all data are loaded.\n *\n * @private\n * @function Highcharts.Chart#firstRender\n * @emits Highcharts.Chart#event:beforeRender\n */\n Chart.prototype.firstRender = function () {\n var chart = this,\n options = chart.options;\n // Hook for oldIE to check whether the chart is ready to render\n if (chart.isReadyToRender && !chart.isReadyToRender()) {\n return;\n }\n // Create the container\n chart.getContainer();\n chart.resetMargins();\n chart.setChartSize();\n // Set the common chart properties (mainly invert) from the given series\n chart.propFromSeries();\n // get axes\n chart.getAxes();\n // Initialize the series\n (isArray(options.series) ? options.series : []).forEach(\n // #9680\n function (serieOptions) {\n chart.initSeries(serieOptions);\n });\n chart.linkSeries();\n chart.setSeriesData();\n // Run an event after axes and series are initialized, but before\n // render. At this stage, the series data is indexed and cached in the\n // xData and yData arrays, so we can access those before rendering. Used\n // in Highcharts Stock.\n fireEvent(chart, 'beforeRender');\n // depends on inverted and on margins being set\n if (Pointer) {\n if (MSPointer.isRequired()) {\n chart.pointer = new MSPointer(chart, options);\n }\n else {\n /**\n * The Pointer that keeps track of mouse and touch interaction.\n *\n * @memberof Highcharts.Chart\n * @name pointer\n * @type {Highcharts.Pointer}\n * @instance\n */\n chart.pointer = new Pointer(chart, options);\n }\n }\n chart.render();\n chart.pointer.getChartPosition(); // #14973\n // Fire the load event if there are no external images\n if (!chart.renderer.imgCount && !chart.hasLoaded) {\n chart.onload();\n }\n // If the chart was rendered outside the top container, put it back in\n // (#3679)\n chart.temporaryDisplay(true);\n };\n /**\n * Internal function that runs on chart load, async if any images are loaded\n * in the chart. Runs the callbacks and triggers the `load` and `render`\n * events.\n *\n * @private\n * @function Highcharts.Chart#onload\n * @emits Highcharts.Chart#event:load\n * @emits Highcharts.Chart#event:render\n */\n Chart.prototype.onload = function () {\n // Run callbacks, first the ones registered by modules, then user's one\n this.callbacks.concat([this.callback]).forEach(function (fn) {\n // Chart destroyed in its own callback (#3600)\n if (fn && typeof this.index !== 'undefined') {\n fn.apply(this, [this]);\n }\n }, this);\n fireEvent(this, 'load');\n fireEvent(this, 'render');\n // Set up auto resize, check for not destroyed (#6068)\n if (defined(this.index)) {\n this.setReflow(this.options.chart.reflow);\n }\n this.warnIfA11yModuleNotLoaded();\n // Don't run again\n this.hasLoaded = true;\n };\n /**\n * Emit console warning if the a11y module is not loaded.\n */\n Chart.prototype.warnIfA11yModuleNotLoaded = function () {\n var _a = this,\n options = _a.options,\n title = _a.title;\n if (options && !this.accessibility) {\n // Make chart behave as an image with the title as alt text\n this.renderer.boxWrapper.attr({\n role: 'img',\n 'aria-label': (title && title.element.textContent) || ''\n });\n if (!(options.accessibility && options.accessibility.enabled === false)) {\n error('Highcharts warning: Consider including the ' +\n '\"accessibility.js\" module to make your chart more ' +\n 'usable for people with disabilities. Set the ' +\n '\"accessibility.enabled\" option to false to remove this ' +\n 'warning. See https://www.highcharts.com/docs/accessibility/accessibility-module.', false, this);\n }\n }\n };\n /**\n * Add a series to the chart after render time. Note that this method should\n * never be used when adding data synchronously at chart render time, as it\n * adds expense to the calculations and rendering. When adding data at the\n * same time as the chart is initialized, add the series as a configuration\n * option instead. With multiple axes, the `offset` is dynamically adjusted.\n *\n * @sample highcharts/members/chart-addseries/\n * Add a series from a button\n * @sample stock/members/chart-addseries/\n * Add a series in Highcharts Stock\n *\n * @function Highcharts.Chart#addSeries\n *\n * @param {Highcharts.SeriesOptionsType} options\n * The config options for the series.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after adding.\n *\n * @param {boolean|Partial} [animation]\n * Whether to apply animation, and optionally animation\n * configuration.\n *\n * @return {Highcharts.Series}\n * The newly created series object.\n *\n * @emits Highcharts.Chart#event:addSeries\n * @emits Highcharts.Chart#event:afterAddSeries\n */\n Chart.prototype.addSeries = function (options, redraw, animation) {\n var chart = this;\n var series;\n if (options) { // <- not necessary\n redraw = pick(redraw, true); // defaults to true\n fireEvent(chart, 'addSeries', { options: options }, function () {\n series = chart.initSeries(options);\n chart.isDirtyLegend = true;\n chart.linkSeries();\n if (series.enabledDataSorting) {\n // We need to call `setData` after `linkSeries`\n series.setData(options.data, false);\n }\n fireEvent(chart, 'afterAddSeries', { series: series });\n if (redraw) {\n chart.redraw(animation);\n }\n });\n }\n return series;\n };\n /**\n * Add an axis to the chart after render time. Note that this method should\n * never be used when adding data synchronously at chart render time, as it\n * adds expense to the calculations and rendering. When adding data at the\n * same time as the chart is initialized, add the axis as a configuration\n * option instead.\n *\n * @sample highcharts/members/chart-addaxis/\n * Add and remove axes\n *\n * @function Highcharts.Chart#addAxis\n *\n * @param {Highcharts.AxisOptions} options\n * The axis options.\n *\n * @param {boolean} [isX=false]\n * Whether it is an X axis or a value axis.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after adding.\n *\n * @param {boolean|Partial} [animation=true]\n * Whether and how to apply animation in the redraw.\n *\n * @return {Highcharts.Axis}\n * The newly generated Axis object.\n */\n Chart.prototype.addAxis = function (options, isX, redraw, animation) {\n return this.createAxis(isX ? 'xAxis' : 'yAxis', { axis: options, redraw: redraw, animation: animation });\n };\n /**\n * Add a color axis to the chart after render time. Note that this method\n * should never be used when adding data synchronously at chart render time,\n * as it adds expense to the calculations and rendering. When adding data at\n * the same time as the chart is initialized, add the axis as a\n * configuration option instead.\n *\n * @sample highcharts/members/chart-addaxis/\n * Add and remove axes\n *\n * @function Highcharts.Chart#addColorAxis\n *\n * @param {Highcharts.ColorAxisOptions} options\n * The axis options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after adding.\n *\n * @param {boolean|Partial} [animation=true]\n * Whether and how to apply animation in the redraw.\n *\n * @return {Highcharts.ColorAxis}\n * The newly generated Axis object.\n */\n Chart.prototype.addColorAxis = function (options, redraw, animation) {\n return this.createAxis('colorAxis', { axis: options, redraw: redraw, animation: animation });\n };\n /**\n * Factory for creating different axis types.\n *\n * @private\n * @function Highcharts.Chart#createAxis\n *\n * @param {string} type\n * An axis type.\n *\n * @param {...Array<*>} arguments\n * All arguments for the constructor.\n *\n * @return {Highcharts.Axis | Highcharts.ColorAxis}\n * The newly generated Axis object.\n */\n Chart.prototype.createAxis = function (type, options) {\n var axis = new Axis(this,\n merge(options.axis, {\n index: this[type].length,\n isX: type === 'xAxis'\n }));\n if (pick(options.redraw, true)) {\n this.redraw(options.animation);\n }\n return axis;\n };\n /**\n * Dim the chart and show a loading text or symbol. Options for the loading\n * screen are defined in {@link\n * https://api.highcharts.com/highcharts/loading|the loading options}.\n *\n * @sample highcharts/members/chart-hideloading/\n * Show and hide loading from a button\n * @sample highcharts/members/chart-showloading/\n * Apply different text labels\n * @sample stock/members/chart-show-hide-loading/\n * Toggle loading in Highcharts Stock\n *\n * @function Highcharts.Chart#showLoading\n *\n * @param {string} [str]\n * An optional text to show in the loading label instead of the\n * default one. The default text is set in\n * [lang.loading](https://api.highcharts.com/highcharts/lang.loading).\n */\n Chart.prototype.showLoading = function (str) {\n var chart = this,\n options = chart.options,\n loadingOptions = options.loading,\n setLoadingSize = function () {\n if (loadingDiv) {\n css(loadingDiv, {\n left: chart.plotLeft + 'px',\n top: chart.plotTop + 'px',\n width: chart.plotWidth + 'px',\n height: chart.plotHeight + 'px'\n });\n }\n };\n var loadingDiv = chart.loadingDiv,\n loadingSpan = chart.loadingSpan;\n // create the layer at the first call\n if (!loadingDiv) {\n chart.loadingDiv = loadingDiv = createElement('div', {\n className: 'highcharts-loading highcharts-loading-hidden'\n }, null, chart.container);\n }\n if (!loadingSpan) {\n chart.loadingSpan = loadingSpan = createElement('span', { className: 'highcharts-loading-inner' }, null, loadingDiv);\n addEvent(chart, 'redraw', setLoadingSize); // #1080\n }\n loadingDiv.className = 'highcharts-loading';\n // Update text\n AST.setElementHTML(loadingSpan, pick(str, options.lang.loading, ''));\n if (!chart.styledMode) {\n // Update visuals\n css(loadingDiv, extend(loadingOptions.style, {\n zIndex: 10\n }));\n css(loadingSpan, loadingOptions.labelStyle);\n // Show it\n if (!chart.loadingShown) {\n css(loadingDiv, {\n opacity: 0,\n display: ''\n });\n animate(loadingDiv, {\n opacity: loadingOptions.style.opacity || 0.5\n }, {\n duration: loadingOptions.showDuration || 0\n });\n }\n }\n chart.loadingShown = true;\n setLoadingSize();\n };\n /**\n * Hide the loading layer.\n *\n * @see Highcharts.Chart#showLoading\n *\n * @sample highcharts/members/chart-hideloading/\n * Show and hide loading from a button\n * @sample stock/members/chart-show-hide-loading/\n * Toggle loading in Highcharts Stock\n *\n * @function Highcharts.Chart#hideLoading\n */\n Chart.prototype.hideLoading = function () {\n var options = this.options,\n loadingDiv = this.loadingDiv;\n if (loadingDiv) {\n loadingDiv.className =\n 'highcharts-loading highcharts-loading-hidden';\n if (!this.styledMode) {\n animate(loadingDiv, {\n opacity: 0\n }, {\n duration: options.loading.hideDuration || 100,\n complete: function () {\n css(loadingDiv, { display: 'none' });\n }\n });\n }\n }\n this.loadingShown = false;\n };\n /**\n * A generic function to update any element of the chart. Elements can be\n * enabled and disabled, moved, re-styled, re-formatted etc.\n *\n * A special case is configuration objects that take arrays, for example\n * [xAxis](https://api.highcharts.com/highcharts/xAxis),\n * [yAxis](https://api.highcharts.com/highcharts/yAxis) or\n * [series](https://api.highcharts.com/highcharts/series). For these\n * collections, an `id` option is used to map the new option set to an\n * existing object. If an existing object of the same id is not found, the\n * corresponding item is updated. So for example, running `chart.update`\n * with a series item without an id, will cause the existing chart's series\n * with the same index in the series array to be updated. When the\n * `oneToOne` parameter is true, `chart.update` will also take care of\n * adding and removing items from the collection. Read more under the\n * parameter description below.\n *\n * Note that when changing series data, `chart.update` may mutate the passed\n * data options.\n *\n * See also the\n * [responsive option set](https://api.highcharts.com/highcharts/responsive).\n * Switching between `responsive.rules` basically runs `chart.update` under\n * the hood.\n *\n * @sample highcharts/members/chart-update/\n * Update chart geometry\n *\n * @function Highcharts.Chart#update\n *\n * @param {Highcharts.Options} options\n * A configuration object for the new chart options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart.\n *\n * @param {boolean} [oneToOne=false]\n * When `true`, the `series`, `xAxis`, `yAxis` and `annotations`\n * collections will be updated one to one, and items will be either\n * added or removed to match the new updated options. For example,\n * if the chart has two series and we call `chart.update` with a\n * configuration containing three series, one will be added. If we\n * call `chart.update` with one series, one will be removed. Setting\n * an empty `series` array will remove all series, but leaving out\n * the`series` property will leave all series untouched. If the\n * series have id's, the new series options will be matched by id,\n * and the remaining ones removed.\n *\n * @param {boolean|Partial} [animation=true]\n * Whether to apply animation, and optionally animation\n * configuration.\n *\n * @emits Highcharts.Chart#event:update\n * @emits Highcharts.Chart#event:afterUpdate\n */\n Chart.prototype.update = function (options, redraw, oneToOne, animation) {\n var chart = this,\n adders = {\n credits: 'addCredits',\n title: 'setTitle',\n subtitle: 'setSubtitle',\n caption: 'setCaption'\n },\n isResponsiveOptions = options.isResponsiveOptions,\n itemsForRemoval = [];\n var updateAllAxes,\n updateAllSeries,\n runSetSize;\n fireEvent(chart, 'update', { options: options });\n // If there are responsive rules in action, undo the responsive rules\n // before we apply the updated options and replay the responsive rules\n // on top from the chart.redraw function (#9617).\n if (!isResponsiveOptions) {\n chart.setResponsive(false, true);\n }\n options = cleanRecursively(options, chart.options);\n chart.userOptions = merge(chart.userOptions, options);\n // If the top-level chart option is present, some special updates are\n // required\n var optionsChart = options.chart;\n if (optionsChart) {\n merge(true, chart.options.chart, optionsChart);\n // Setter function\n if ('className' in optionsChart) {\n chart.setClassName(optionsChart.className);\n }\n if ('reflow' in optionsChart) {\n chart.setReflow(optionsChart.reflow);\n }\n if ('inverted' in optionsChart ||\n 'polar' in optionsChart ||\n 'type' in optionsChart) {\n // Parse options.chart.inverted and options.chart.polar together\n // with the available series.\n chart.propFromSeries();\n updateAllAxes = true;\n }\n if ('alignTicks' in optionsChart) { // #6452\n updateAllAxes = true;\n }\n if ('events' in optionsChart) {\n // Chart event handlers\n registerEventOptions(this, optionsChart);\n }\n objectEach(optionsChart, function (val, key) {\n if (chart.propsRequireUpdateSeries.indexOf('chart.' + key) !==\n -1) {\n updateAllSeries = true;\n }\n // Only dirty box\n if (chart.propsRequireDirtyBox.indexOf(key) !== -1) {\n chart.isDirtyBox = true;\n }\n // Chart setSize\n if (chart.propsRequireReflow.indexOf(key) !== -1) {\n if (isResponsiveOptions) {\n chart.isDirtyBox = true;\n }\n else {\n runSetSize = true;\n }\n }\n });\n if (!chart.styledMode && optionsChart.style) {\n chart.renderer.setStyle(chart.options.chart.style || {});\n }\n }\n // Moved up, because tooltip needs updated plotOptions (#6218)\n if (!chart.styledMode && options.colors) {\n this.options.colors = options.colors;\n }\n if (options.time) {\n // Maintaining legacy global time. If the chart is instanciated\n // first with global time, then updated with time options, we need\n // to create a new Time instance to avoid mutating the global time\n // (#10536).\n if (this.time === defaultTime) {\n this.time = new Time(options.time);\n }\n // If we're updating, the time class is different from other chart\n // classes (chart.legend, chart.tooltip etc) in that it doesn't know\n // about the chart. The other chart[something].update functions also\n // set the chart.options[something]. For the time class however we\n // need to update the chart options separately. #14230.\n merge(true, chart.options.time, options.time);\n }\n // Some option stuctures correspond one-to-one to chart objects that\n // have update methods, for example\n // options.credits => chart.credits\n // options.legend => chart.legend\n // options.title => chart.title\n // options.tooltip => chart.tooltip\n // options.subtitle => chart.subtitle\n // options.mapNavigation => chart.mapNavigation\n // options.navigator => chart.navigator\n // options.scrollbar => chart.scrollbar\n objectEach(options, function (val, key) {\n if (chart[key] &&\n typeof chart[key].update === 'function') {\n chart[key].update(val, false);\n // If a one-to-one object does not exist, look for an adder function\n }\n else if (typeof chart[adders[key]] === 'function') {\n chart[adders[key]](val);\n // Else, just merge the options. For nodes like loading, noData,\n // plotOptions\n }\n else if (key !== 'colors' &&\n chart.collectionsWithUpdate.indexOf(key) === -1) {\n merge(true, chart.options[key], options[key]);\n }\n if (key !== 'chart' &&\n chart.propsRequireUpdateSeries.indexOf(key) !== -1) {\n updateAllSeries = true;\n }\n });\n // Setters for collections. For axes and series, each item is referred\n // by an id. If the id is not found, it defaults to the corresponding\n // item in the collection, so setting one series without an id, will\n // update the first series in the chart. Setting two series without\n // an id will update the first and the second respectively (#6019)\n // chart.update and responsive.\n this.collectionsWithUpdate.forEach(function (coll) {\n var indexMap;\n if (options[coll]) {\n // In stock charts, the navigator series are also part of the\n // chart.series array, but those series should not be handled\n // here (#8196) and neither should the navigator axis (#9671).\n indexMap = [];\n chart[coll].forEach(function (s, i) {\n if (!s.options.isInternal) {\n indexMap.push(pick(s.options.index, i));\n }\n });\n splat(options[coll]).forEach(function (newOptions, i) {\n var hasId = defined(newOptions.id);\n var item;\n // Match by id\n if (hasId) {\n item = chart.get(newOptions.id);\n }\n // No match by id found, match by index instead\n if (!item && chart[coll]) {\n item = chart[coll][indexMap ? indexMap[i] : i];\n // Check if we grabbed an item with an exising but\n // different id (#13541)\n if (item && hasId && defined(item.options.id)) {\n item = void 0;\n }\n }\n if (item && item.coll === coll) {\n item.update(newOptions, false);\n if (oneToOne) {\n item.touched = true;\n }\n }\n // If oneToOne and no matching item is found, add one\n if (!item && oneToOne && chart.collectionsWithInit[coll]) {\n chart.collectionsWithInit[coll][0].apply(chart, \n // [newOptions, ...extraArguments, redraw=false]\n [\n newOptions\n ].concat(\n // Not all initializers require extra args\n chart.collectionsWithInit[coll][1] || []).concat([\n false\n ])).touched = true;\n }\n });\n // Add items for removal\n if (oneToOne) {\n chart[coll].forEach(function (item) {\n if (!item.touched && !item.options.isInternal) {\n itemsForRemoval.push(item);\n }\n else {\n delete item.touched;\n }\n });\n }\n }\n });\n itemsForRemoval.forEach(function (item) {\n if (item.chart && item.remove) { // #9097, avoid removing twice\n item.remove(false);\n }\n });\n if (updateAllAxes) {\n chart.axes.forEach(function (axis) {\n axis.update({}, false);\n });\n }\n // Certain options require the whole series structure to be thrown away\n // and rebuilt\n if (updateAllSeries) {\n chart.getSeriesOrderByLinks().forEach(function (series) {\n // Avoid removed navigator series\n if (series.chart) {\n series.update({}, false);\n }\n }, this);\n }\n // Update size. Redraw is forced.\n var newWidth = optionsChart && optionsChart.width;\n var newHeight = optionsChart && (isString(optionsChart.height) ?\n relativeLength(optionsChart.height,\n newWidth || chart.chartWidth) :\n optionsChart.height);\n if (\n // In this case, run chart.setSize with newWidth and newHeight which\n // are undefined, only for reflowing chart elements because margin\n // or spacing has been set (#8190)\n runSetSize ||\n // In this case, the size is actually set\n (isNumber(newWidth) && newWidth !== chart.chartWidth) ||\n (isNumber(newHeight) && newHeight !== chart.chartHeight)) {\n chart.setSize(newWidth, newHeight, animation);\n }\n else if (pick(redraw, true)) {\n chart.redraw(animation);\n }\n fireEvent(chart, 'afterUpdate', {\n options: options,\n redraw: redraw,\n animation: animation\n });\n };\n /**\n * Shortcut to set the subtitle options. This can also be done from {@link\n * Chart#update} or {@link Chart#setTitle}.\n *\n * @function Highcharts.Chart#setSubtitle\n *\n * @param {Highcharts.SubtitleOptions} options\n * New subtitle options. The subtitle text itself is set by the\n * `options.text` property.\n */\n Chart.prototype.setSubtitle = function (options, redraw) {\n this.applyDescription('subtitle', options);\n this.layOutTitles(redraw);\n };\n /**\n * Set the caption options. This can also be done from {@link\n * Chart#update}.\n *\n * @function Highcharts.Chart#setCaption\n *\n * @param {Highcharts.CaptionOptions} options\n * New caption options. The caption text itself is set by the\n * `options.text` property.\n */\n Chart.prototype.setCaption = function (options, redraw) {\n this.applyDescription('caption', options);\n this.layOutTitles(redraw);\n };\n /**\n * Display the zoom button, so users can reset zoom to the default view\n * settings.\n *\n * @function Highcharts.Chart#showResetZoom\n *\n * @emits Highcharts.Chart#event:afterShowResetZoom\n * @emits Highcharts.Chart#event:beforeShowResetZoom\n */\n Chart.prototype.showResetZoom = function () {\n var chart = this,\n lang = defaultOptions.lang,\n btnOptions = chart.options.chart.zooming.resetButton,\n theme = btnOptions.theme,\n alignTo = (btnOptions.relativeTo === 'chart' ||\n btnOptions.relativeTo === 'spacingBox' ?\n null :\n 'scrollablePlotBox');\n /**\n * @private\n */\n function zoomOut() {\n chart.zoomOut();\n }\n fireEvent(this, 'beforeShowResetZoom', null, function () {\n chart.resetZoomButton = chart.renderer\n .button(lang.resetZoom, null, null, zoomOut, theme)\n .attr({\n align: btnOptions.position.align,\n title: lang.resetZoomTitle\n })\n .addClass('highcharts-reset-zoom')\n .add()\n .align(btnOptions.position, false, alignTo);\n });\n fireEvent(this, 'afterShowResetZoom');\n };\n /**\n * Zoom the chart out after a user has zoomed in. See also\n * [Axis.setExtremes](/class-reference/Highcharts.Axis#setExtremes).\n *\n * @function Highcharts.Chart#zoomOut\n *\n * @emits Highcharts.Chart#event:selection\n */\n Chart.prototype.zoomOut = function () {\n fireEvent(this, 'selection', { resetSelection: true }, this.zoom);\n };\n /**\n * Zoom into a given portion of the chart given by axis coordinates.\n *\n * @private\n * @function Highcharts.Chart#zoom\n * @param {Highcharts.SelectEventObject} event\n */\n Chart.prototype.zoom = function (event) {\n var chart = this,\n pointer = chart.pointer;\n var displayButton = false,\n hasZoomed;\n // If zoom is called with no arguments, reset the axes\n if (!event || event.resetSelection) {\n chart.axes.forEach(function (axis) {\n hasZoomed = axis.zoom();\n });\n pointer.initiated = false; // #6804\n }\n else { // else, zoom in on all axes\n event.xAxis.concat(event.yAxis).forEach(function (axisData) {\n var axis = axisData.axis,\n isXAxis = axis.isXAxis;\n // don't zoom more than minRange\n if (pointer[isXAxis ? 'zoomX' : 'zoomY'] &&\n (defined(pointer.mouseDownX) &&\n defined(pointer.mouseDownY) &&\n chart.isInsidePlot(pointer.mouseDownX - chart.plotLeft, pointer.mouseDownY - chart.plotTop, { axis: axis })) || !defined(chart.inverted ? pointer.mouseDownX : pointer.mouseDownY)) {\n hasZoomed = axis.zoom(axisData.min, axisData.max);\n if (axis.displayBtn) {\n displayButton = true;\n }\n }\n });\n }\n // Show or hide the Reset zoom button\n var resetZoomButton = chart.resetZoomButton;\n if (displayButton && !resetZoomButton) {\n chart.showResetZoom();\n }\n else if (!displayButton && isObject(resetZoomButton)) {\n chart.resetZoomButton = resetZoomButton.destroy();\n }\n // Redraw\n if (hasZoomed) {\n chart.redraw(pick(chart.options.chart.animation, event && event.animation, chart.pointCount < 100));\n }\n };\n /**\n * Pan the chart by dragging the mouse across the pane. This function is\n * called on mouse move, and the distance to pan is computed from chartX\n * compared to the first chartX position in the dragging operation.\n *\n * @private\n * @function Highcharts.Chart#pan\n * @param {Highcharts.PointerEventObject} e\n * @param {string} panning\n */\n Chart.prototype.pan = function (e, panning) {\n var chart = this,\n hoverPoints = chart.hoverPoints,\n panningOptions = (typeof panning === 'object' ?\n panning :\n {\n enabled: panning,\n type: 'x'\n }),\n chartOptions = chart.options.chart;\n if (chartOptions && chartOptions.panning) {\n chartOptions.panning = panningOptions;\n }\n var type = panningOptions.type;\n var doRedraw;\n fireEvent(this, 'pan', { originalEvent: e }, function () {\n // remove active points for shared tooltip\n if (hoverPoints) {\n hoverPoints.forEach(function (point) {\n point.setState();\n });\n }\n var axes = chart.xAxis;\n if (type === 'xy') {\n axes = axes.concat(chart.yAxis);\n }\n else if (type === 'y') {\n axes = chart.yAxis;\n }\n var nextMousePos = {};\n axes.forEach(function (axis) {\n if (!axis.options.panningEnabled || axis.options.isInternal) {\n return;\n }\n var horiz = axis.horiz, mousePos = e[horiz ? 'chartX' : 'chartY'], mouseDown = horiz ? 'mouseDownX' : 'mouseDownY', startPos = chart[mouseDown], halfPointRange = axis.minPointOffset || 0, pointRangeDirection = (axis.reversed && !chart.inverted) ||\n (!axis.reversed && chart.inverted) ?\n -1 :\n 1, extremes = axis.getExtremes(), panMin = axis.toValue(startPos - mousePos, true) +\n halfPointRange * pointRangeDirection, panMax = axis.toValue(startPos + axis.len - mousePos, true) -\n ((halfPointRange * pointRangeDirection) ||\n (axis.isXAxis && axis.pointRangePadding) ||\n 0), flipped = panMax < panMin, hasVerticalPanning = axis.hasVerticalPanning();\n var newMin = flipped ? panMax : panMin,\n newMax = flipped ? panMin : panMax,\n panningState = axis.panningState,\n spill;\n // General calculations of panning state.\n // This is related to using vertical panning. (#11315).\n if (hasVerticalPanning &&\n !axis.isXAxis && (!panningState || panningState.isDirty)) {\n axis.series.forEach(function (series) {\n var processedData = series.getProcessedData(true),\n dataExtremes = series.getExtremes(processedData.yData,\n true);\n if (!panningState) {\n panningState = {\n startMin: Number.MAX_VALUE,\n startMax: -Number.MAX_VALUE\n };\n }\n if (isNumber(dataExtremes.dataMin) &&\n isNumber(dataExtremes.dataMax)) {\n panningState.startMin = Math.min(pick(series.options.threshold, Infinity), dataExtremes.dataMin, panningState.startMin);\n panningState.startMax = Math.max(pick(series.options.threshold, -Infinity), dataExtremes.dataMax, panningState.startMax);\n }\n });\n }\n var paddedMin = Math.min(pick(panningState && panningState.startMin,\n extremes.dataMin),\n halfPointRange ?\n extremes.min :\n axis.toValue(axis.toPixels(extremes.min) -\n axis.minPixelPadding));\n var paddedMax = Math.max(pick(panningState && panningState.startMax,\n extremes.dataMax),\n halfPointRange ?\n extremes.max :\n axis.toValue(axis.toPixels(extremes.max) +\n axis.minPixelPadding));\n axis.panningState = panningState;\n // It is not necessary to calculate extremes on ordinal axis,\n // because they are already calculated, so we don't want to\n // override them.\n if (!axis.isOrdinal) {\n // If the new range spills over, either to the min or max,\n // adjust the new range.\n spill = paddedMin - newMin;\n if (spill > 0) {\n newMax += spill;\n newMin = paddedMin;\n }\n spill = newMax - paddedMax;\n if (spill > 0) {\n newMax = paddedMax;\n newMin -= spill;\n }\n // Set new extremes if they are actually new\n if (axis.series.length &&\n newMin !== extremes.min &&\n newMax !== extremes.max &&\n newMin >= paddedMin &&\n newMax <= paddedMax) {\n axis.setExtremes(newMin, newMax, false, false, { trigger: 'pan' });\n if (!chart.resetZoomButton &&\n // Show reset zoom button only when both newMin and\n // newMax values are between padded axis range.\n newMin !== paddedMin &&\n newMax !== paddedMax &&\n type.match('y')) {\n chart.showResetZoom();\n axis.displayBtn = false;\n }\n doRedraw = true;\n }\n // set new reference for next run:\n nextMousePos[mouseDown] = mousePos;\n }\n });\n objectEach(nextMousePos, function (pos, down) {\n chart[down] = pos;\n });\n if (doRedraw) {\n chart.redraw(false);\n }\n css(chart.container, { cursor: 'move' });\n });\n };\n return Chart;\n }());\n extend(Chart.prototype, {\n // Hook for adding callbacks in modules\n callbacks: [],\n /**\n * These collections (arrays) implement `Chart.addSomethig` method used in\n * chart.update() to create new object in the collection. Equivalent for\n * deleting is resolved by simple `Somethig.remove()`.\n *\n * Note: We need to define these references after initializers are bound to\n * chart's prototype.\n *\n * @private\n */\n collectionsWithInit: {\n // collectionName: [ initializingMethod, [extraArguments] ]\n xAxis: [Chart.prototype.addAxis, [true]],\n yAxis: [Chart.prototype.addAxis, [false]],\n series: [Chart.prototype.addSeries]\n },\n /**\n * These collections (arrays) implement update() methods with support for\n * one-to-one option.\n * @private\n */\n collectionsWithUpdate: [\n 'xAxis',\n 'yAxis',\n 'series'\n ],\n /**\n * These properties cause isDirtyBox to be set to true when updating. Can be\n * extended from plugins.\n * @private\n */\n propsRequireDirtyBox: [\n 'backgroundColor',\n 'borderColor',\n 'borderWidth',\n 'borderRadius',\n 'plotBackgroundColor',\n 'plotBackgroundImage',\n 'plotBorderColor',\n 'plotBorderWidth',\n 'plotShadow',\n 'shadow'\n ],\n /**\n * These properties require a full reflow of chart elements, best\n * implemented through running `Chart.setSize` internally (#8190).\n * @private\n */\n propsRequireReflow: [\n 'margin',\n 'marginTop',\n 'marginRight',\n 'marginBottom',\n 'marginLeft',\n 'spacing',\n 'spacingTop',\n 'spacingRight',\n 'spacingBottom',\n 'spacingLeft'\n ],\n /**\n * These properties cause all series to be updated when updating. Can be\n * extended from plugins.\n * @private\n */\n propsRequireUpdateSeries: [\n 'chart.inverted',\n 'chart.polar',\n 'chart.ignoreHiddenSeries',\n 'chart.type',\n 'colors',\n 'plotOptions',\n 'time',\n 'tooltip'\n ]\n });\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Callback for chart constructors.\n *\n * @callback Highcharts.ChartCallbackFunction\n *\n * @param {Highcharts.Chart} chart\n * Created chart.\n */\n /**\n * Format a number and return a string based on input settings.\n *\n * @callback Highcharts.NumberFormatterCallbackFunction\n *\n * @param {number} number\n * The input number to format.\n *\n * @param {number} decimals\n * The amount of decimals. A value of -1 preserves the amount in the\n * input number.\n *\n * @param {string} [decimalPoint]\n * The decimal point, defaults to the one given in the lang options, or\n * a dot.\n *\n * @param {string} [thousandsSep]\n * The thousands separator, defaults to the one given in the lang\n * options, or a space character.\n *\n * @return {string} The formatted number.\n */\n /**\n * The chart title. The title has an `update` method that allows modifying the\n * options directly or indirectly via `chart.update`.\n *\n * @interface Highcharts.TitleObject\n * @extends Highcharts.SVGElement\n */ /**\n * Modify options for the title.\n *\n * @function Highcharts.TitleObject#update\n *\n * @param {Highcharts.TitleOptions} titleOptions\n * Options to modify.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the title is altered. If doing more\n * operations on the chart, it is a good idea to set redraw to false and\n * call {@link Chart#redraw} after.\n */\n /**\n * The chart subtitle. The subtitle has an `update` method that\n * allows modifying the options directly or indirectly via\n * `chart.update`.\n *\n * @interface Highcharts.SubtitleObject\n * @extends Highcharts.SVGElement\n */ /**\n * Modify options for the subtitle.\n *\n * @function Highcharts.SubtitleObject#update\n *\n * @param {Highcharts.SubtitleOptions} subtitleOptions\n * Options to modify.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the subtitle is altered. If doing\n * more operations on the chart, it is a good idea to set redraw to false\n * and call {@link Chart#redraw} after.\n */\n /**\n * The chart caption. The caption has an `update` method that\n * allows modifying the options directly or indirectly via\n * `chart.update`.\n *\n * @interface Highcharts.CaptionObject\n * @extends Highcharts.SVGElement\n */ /**\n * Modify options for the caption.\n *\n * @function Highcharts.CaptionObject#update\n *\n * @param {Highcharts.CaptionOptions} captionOptions\n * Options to modify.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the caption is altered. If doing\n * more operations on the chart, it is a good idea to set redraw to false\n * and call {@link Chart#redraw} after.\n */\n /**\n * @interface Highcharts.ChartIsInsideOptionsObject\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#axis\n * @type {Highcharts.Axis|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#ignoreX\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#ignoreY\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#inverted\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#paneCoordinates\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#series\n * @type {Highcharts.Series|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#visiblePlotOnly\n * @type {boolean|undefined}\n */\n ''; // keeps doclets above in JS file\n\n return Chart;\n });\n _registerModule(_modules, 'Core/Legend/LegendSymbol.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var merge = U.merge,\n pick = U.pick;\n /* *\n *\n * Namespace\n *\n * */\n var LegendSymbol;\n (function (LegendSymbol) {\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Get the series' symbol in the legend.\n *\n * This method should be overridable to create custom symbols through\n * Highcharts.seriesTypes[type].prototype.drawLegendSymbol.\n *\n * @private\n * @function Highcharts.LegendSymbolMixin.drawLineMarker\n *\n * @param {Highcharts.Legend} legend\n * The legend object.\n */\n function drawLineMarker(legend) {\n var legendItem = this.legendItem = this.legendItem || {},\n options = this.options,\n symbolWidth = legend.symbolWidth,\n symbolHeight = legend.symbolHeight,\n generalRadius = symbolHeight / 2,\n renderer = this.chart.renderer,\n legendItemGroup = legendItem.group,\n verticalCenter = legend.baseline -\n Math.round(legend.fontMetrics.b * 0.3);\n var attr = {},\n legendSymbol,\n markerOptions = options.marker;\n // Draw the line\n if (!this.chart.styledMode) {\n attr = {\n 'stroke-width': options.lineWidth || 0\n };\n if (options.dashStyle) {\n attr.dashstyle = options.dashStyle;\n }\n }\n legendItem.line = renderer\n .path([\n ['M', 0, verticalCenter],\n ['L', symbolWidth, verticalCenter]\n ])\n .addClass('highcharts-graph')\n .attr(attr)\n .add(legendItemGroup);\n // Draw the marker\n if (markerOptions && markerOptions.enabled !== false && symbolWidth) {\n // Do not allow the marker to be larger than the symbolHeight\n var radius = Math.min(pick(markerOptions.radius,\n generalRadius),\n generalRadius);\n // Restrict symbol markers size\n if (this.symbol.indexOf('url') === 0) {\n markerOptions = merge(markerOptions, {\n width: symbolHeight,\n height: symbolHeight\n });\n radius = 0;\n }\n legendItem.symbol = legendSymbol = renderer\n .symbol(this.symbol, (symbolWidth / 2) - radius, verticalCenter - radius, 2 * radius, 2 * radius, markerOptions)\n .addClass('highcharts-point')\n .add(legendItemGroup);\n legendSymbol.isMarker = true;\n }\n }\n LegendSymbol.drawLineMarker = drawLineMarker;\n /**\n * Get the series' symbol in the legend.\n *\n * This method should be overridable to create custom symbols through\n * Highcharts.seriesTypes[type].prototype.drawLegendSymbol.\n *\n * @private\n * @function Highcharts.LegendSymbolMixin.drawRectangle\n *\n * @param {Highcharts.Legend} legend\n * The legend object\n *\n * @param {Highcharts.Point|Highcharts.Series} item\n * The series (this) or point\n */\n function drawRectangle(legend, item) {\n var legendItem = item.legendItem || {},\n options = legend.options,\n symbolHeight = legend.symbolHeight,\n square = options.squareSymbol,\n symbolWidth = square ? symbolHeight : legend.symbolWidth;\n legendItem.symbol = this.chart.renderer\n .rect(square ? (legend.symbolWidth - symbolHeight) / 2 : 0, legend.baseline - symbolHeight + 1, // #3988\n symbolWidth, symbolHeight, pick(legend.options.symbolRadius, symbolHeight / 2))\n .addClass('highcharts-point')\n .attr({\n zIndex: 3\n })\n .add(legendItem.group);\n }\n LegendSymbol.drawRectangle = drawRectangle;\n })(LegendSymbol || (LegendSymbol = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return LegendSymbol;\n });\n _registerModule(_modules, 'Core/Series/SeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * General options for all series types.\n *\n * @optionparent plotOptions.series\n */\n var seriesDefaults = {\n // base series options\n /**\n * The SVG value used for the `stroke-linecap` and `stroke-linejoin`\n * of a line graph. Round means that lines are rounded in the ends and\n * bends.\n *\n * @type {Highcharts.SeriesLinecapValue}\n * @default round\n * @since 3.0.7\n * @apioption plotOptions.line.linecap\n */\n /**\n * Pixel width of the graph line.\n *\n * @see In styled mode, the line stroke-width can be set with the\n * `.highcharts-graph` class name.\n *\n * @sample {highcharts} highcharts/plotoptions/series-linewidth-general/\n * On all series\n * @sample {highcharts} highcharts/plotoptions/series-linewidth-specific/\n * On one single series\n *\n * @product highcharts highstock\n *\n * @private\n */\n lineWidth: 2,\n /**\n * For some series, there is a limit that shuts down animation\n * by default when the total number of points in the chart is too high.\n * For example, for a column chart and its derivatives, animation does\n * not run if there is more than 250 points totally. To disable this\n * cap, set `animationLimit` to `Infinity`. This option works if animation\n * is fired on individual points, not on a group of points like e.g. during\n * the initial animation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-animationlimit/\n * Animation limit on updating individual points\n *\n * @type {number}\n * @apioption plotOptions.series.animationLimit\n */\n /**\n * Allow this series' points to be selected by clicking on the graphic\n * (columns, point markers, pie slices, map areas etc).\n *\n * The selected points can be handled by point select and unselect\n * events, or collectively by the [getSelectedPoints\n * ](/class-reference/Highcharts.Chart#getSelectedPoints) function.\n *\n * And alternative way of selecting points is through dragging.\n *\n * @sample {highcharts} highcharts/plotoptions/series-allowpointselect-line/\n * Line\n * @sample {highcharts} highcharts/plotoptions/series-allowpointselect-column/\n * Column\n * @sample {highcharts} highcharts/plotoptions/series-allowpointselect-pie/\n * Pie\n * @sample {highcharts} highcharts/chart/events-selection-points/\n * Select a range of points through a drag selection\n * @sample {highmaps} maps/plotoptions/series-allowpointselect/\n * Map area\n * @sample {highmaps} maps/plotoptions/mapbubble-allowpointselect/\n * Map bubble\n *\n * @since 1.2.0\n *\n * @private\n */\n allowPointSelect: false,\n /**\n * When true, each point or column edge is rounded to its nearest pixel\n * in order to render sharp on screen. In some cases, when there are a\n * lot of densely packed columns, this leads to visible difference\n * in column widths or distance between columns. In these cases,\n * setting `crisp` to `false` may look better, even though each column\n * is rendered blurry.\n *\n * @sample {highcharts} highcharts/plotoptions/column-crisp-false/\n * Crisp is false\n *\n * @since 5.0.10\n * @product highcharts highstock gantt\n *\n * @private\n */\n crisp: true,\n /**\n * If true, a checkbox is displayed next to the legend item to allow\n * selecting the series. The state of the checkbox is determined by\n * the `selected` option.\n *\n * @productdesc {highmaps}\n * Note that if a `colorAxis` is defined, the color axis is represented\n * in the legend, not the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-showcheckbox-true/\n * Show select box\n *\n * @since 1.2.0\n *\n * @private\n */\n showCheckbox: false,\n /**\n * Enable or disable the initial animation when a series is displayed.\n * The animation can also be set as a configuration object. Please\n * note that this option only applies to the initial animation of the\n * series itself. For other animations, see [chart.animation](\n * #chart.animation) and the animation parameter under the API methods.\n * The following properties are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * - `duration`: The duration of the animation in milliseconds. (Defaults to\n * `1000`)\n *\n * - `easing`: Can be a string reference to an easing function set on\n * the `Math` object or a function. See the _Custom easing function_\n * demo below. (Defaults to `easeInOutSine`)\n *\n * Due to poor performance, animation is disabled in old IE browsers\n * for several chart types.\n *\n * @sample {highcharts} highcharts/plotoptions/series-animation-disabled/\n * Animation disabled\n * @sample {highcharts} highcharts/plotoptions/series-animation-slower/\n * Slower animation\n * @sample {highcharts} highcharts/plotoptions/series-animation-easing/\n * Custom easing function\n * @sample {highstock} stock/plotoptions/animation-slower/\n * Slower animation\n * @sample {highstock} stock/plotoptions/animation-easing/\n * Custom easing function\n * @sample {highmaps} maps/plotoptions/series-animation-true/\n * Animation enabled on map series\n * @sample {highmaps} maps/plotoptions/mapbubble-animation-false/\n * Disabled on mapbubble series\n *\n * @type {boolean|Highcharts.AnimationOptionsObject}\n * @default {highcharts} true\n * @default {highstock} true\n * @default {highmaps} false\n *\n * @private\n */\n animation: {\n /** @ignore-option */\n duration: 1000\n },\n /**\n * An additional class name to apply to the series' graphical elements.\n * This option does not replace default class names of the graphical\n * element.\n *\n * @type {string}\n * @since 5.0.0\n * @apioption plotOptions.series.className\n */\n /**\n * Disable this option to allow series rendering in the whole plotting\n * area.\n *\n * **Note:** Clipping should be always enabled when\n * [chart.zoomType](#chart.zoomType) is set\n *\n * @sample {highcharts} highcharts/plotoptions/series-clip/\n * Disabled clipping\n *\n * @default true\n * @type {boolean}\n * @since 3.0.0\n * @apioption plotOptions.series.clip\n */\n /**\n * The main color of the series. In line type series it applies to the\n * line and the point markers unless otherwise specified. In bar type\n * series it applies to the bars unless a color is specified per point.\n * The default value is pulled from the `options.colors` array.\n *\n * In styled mode, the color can be defined by the\n * [colorIndex](#plotOptions.series.colorIndex) option. Also, the series\n * color can be set with the `.highcharts-series`,\n * `.highcharts-color-{n}`, `.highcharts-{type}-series` or\n * `.highcharts-series-{n}` class, or individual classes given by the\n * `className` option.\n *\n * @productdesc {highmaps}\n * In maps, the series color is rarely used, as most choropleth maps use\n * the color to denote the value of each point. The series color can\n * however be used in a map with multiple series holding categorized\n * data.\n *\n * @sample {highcharts} highcharts/plotoptions/series-color-general/\n * General plot option\n * @sample {highcharts} highcharts/plotoptions/series-color-specific/\n * One specific series\n * @sample {highcharts} highcharts/plotoptions/series-color-area/\n * Area color\n * @sample {highcharts} highcharts/series/infographic/\n * Pattern fill\n * @sample {highmaps} maps/demo/category-map/\n * Category map by multiple series\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption plotOptions.series.color\n */\n /**\n * Styled mode only. A specific color index to use for the series, so its\n * graphic representations are given the class name `highcharts-color-{n}`.\n *\n * @sample {highcharts} highcharts/css/colorindex/\n * Series and point color index\n *\n * @type {number}\n * @since 5.0.0\n * @apioption plotOptions.series.colorIndex\n */\n /**\n * Whether to connect a graph line across null points, or render a gap\n * between the two points on either side of the null.\n *\n * @sample {highcharts} highcharts/plotoptions/series-connectnulls-false/\n * False by default\n * @sample {highcharts} highcharts/plotoptions/series-connectnulls-true/\n * True\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock\n * @apioption plotOptions.series.connectNulls\n */\n /**\n * You can set the cursor to \"pointer\" if you have click events attached\n * to the series, to signal to the user that the points and lines can\n * be clicked.\n *\n * In styled mode, the series cursor can be set with the same classes\n * as listed under [series.color](#plotOptions.series.color).\n *\n * @sample {highcharts} highcharts/plotoptions/series-cursor-line/\n * On line graph\n * @sample {highcharts} highcharts/plotoptions/series-cursor-column/\n * On columns\n * @sample {highcharts} highcharts/plotoptions/series-cursor-scatter/\n * On scatter markers\n * @sample {highstock} stock/plotoptions/cursor/\n * Pointer on a line graph\n * @sample {highmaps} maps/plotoptions/series-allowpointselect/\n * Map area\n * @sample {highmaps} maps/plotoptions/mapbubble-allowpointselect/\n * Map bubble\n *\n * @type {string|Highcharts.CursorValue}\n * @apioption plotOptions.series.cursor\n */\n /**\n * A reserved subspace to store options and values for customized\n * functionality. Here you can add additional data for your own event\n * callbacks and formatter callbacks.\n *\n * @sample {highcharts} highcharts/point/custom/\n * Point and series with custom data\n *\n * @type {Highcharts.Dictionary<*>}\n * @apioption plotOptions.series.custom\n */\n /**\n * Name of the dash style to use for the graph, or for some series types\n * the outline of each shape.\n *\n * In styled mode, the\n * [stroke dash-array](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/css/series-dashstyle/)\n * can be set with the same classes as listed under\n * [series.color](#plotOptions.series.color).\n *\n * @sample {highcharts} highcharts/plotoptions/series-dashstyle-all/\n * Possible values demonstrated\n * @sample {highcharts} highcharts/plotoptions/series-dashstyle/\n * Chart suitable for printing in black and white\n * @sample {highstock} highcharts/plotoptions/series-dashstyle-all/\n * Possible values demonstrated\n * @sample {highmaps} highcharts/plotoptions/series-dashstyle-all/\n * Possible values demonstrated\n * @sample {highmaps} maps/plotoptions/series-dashstyle/\n * Dotted borders on a map\n *\n * @type {Highcharts.DashStyleValue}\n * @default Solid\n * @since 2.1\n * @apioption plotOptions.series.dashStyle\n */\n /**\n * A description of the series to add to the screen reader information\n * about the series.\n *\n * @type {string}\n * @since 5.0.0\n * @requires modules/accessibility\n * @apioption plotOptions.series.description\n */\n /**\n * Options for the series data sorting.\n *\n * @type {Highcharts.DataSortingOptionsObject}\n * @since 8.0.0\n * @product highcharts highstock\n * @apioption plotOptions.series.dataSorting\n */\n /**\n * Enable or disable data sorting for the series. Use [xAxis.reversed](\n * #xAxis.reversed) to change the sorting order.\n *\n * @sample {highcharts} highcharts/datasorting/animation/\n * Data sorting in scatter-3d\n * @sample {highcharts} highcharts/datasorting/labels-animation/\n * Axis labels animation\n * @sample {highcharts} highcharts/datasorting/dependent-sorting/\n * Dependent series sorting\n * @sample {highcharts} highcharts/datasorting/independent-sorting/\n * Independent series sorting\n *\n * @type {boolean}\n * @since 8.0.0\n * @apioption plotOptions.series.dataSorting.enabled\n */\n /**\n * Whether to allow matching points by name in an update. If this option\n * is disabled, points will be matched by order.\n *\n * @sample {highcharts} highcharts/datasorting/match-by-name/\n * Enabled match by name\n *\n * @type {boolean}\n * @since 8.0.0\n * @apioption plotOptions.series.dataSorting.matchByName\n */\n /**\n * Determines what data value should be used to sort by.\n *\n * @sample {highcharts} highcharts/datasorting/sort-key/\n * Sort key as `z` value\n *\n * @type {string}\n * @since 8.0.0\n * @default y\n * @apioption plotOptions.series.dataSorting.sortKey\n */\n /**\n * Enable or disable the mouse tracking for a specific series. This\n * includes point tooltips and click events on graphs and points. For\n * large datasets it improves performance.\n *\n * @sample {highcharts} highcharts/plotoptions/series-enablemousetracking-false/\n * No mouse tracking\n * @sample {highmaps} maps/plotoptions/series-enablemousetracking-false/\n * No mouse tracking\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.enableMouseTracking\n */\n /**\n * Whether to use the Y extremes of the total chart width or only the\n * zoomed area when zooming in on parts of the X axis. By default, the\n * Y axis adjusts to the min and max of the visible data. Cartesian\n * series only.\n *\n * @type {boolean}\n * @default false\n * @since 4.1.6\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.getExtremesFromAll\n */\n /**\n * An array specifying which option maps to which key in the data point\n * array. This makes it convenient to work with unstructured data arrays\n * from different sources.\n *\n * @see [series.data](#series.line.data)\n *\n * @sample {highcharts|highstock} highcharts/series/data-keys/\n * An extended data array with keys\n * @sample {highcharts|highstock} highcharts/series/data-nested-keys/\n * Nested keys used to access object properties\n *\n * @type {Array}\n * @since 4.1.6\n * @apioption plotOptions.series.keys\n */\n /**\n * The line cap used for line ends and line joins on the graph.\n *\n * @sample highcharts/series-line/linecap/\n * Line cap comparison\n *\n * @type {Highcharts.SeriesLinecapValue}\n * @default round\n * @product highcharts highstock\n * @apioption plotOptions.series.linecap\n */\n /**\n * The [id](#series.id) of another series to link to. Additionally,\n * the value can be \":previous\" to link to the previous series. When\n * two series are linked, only the first one appears in the legend.\n * Toggling the visibility of this also toggles the linked series.\n *\n * If master series uses data sorting and linked series does not have\n * its own sorting definition, the linked series will be sorted in the\n * same order as the master one.\n *\n * @sample {highcharts|highstock} highcharts/demo/arearange-line/\n * Linked series\n *\n * @type {string}\n * @since 3.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.linkedTo\n */\n /**\n * Options for the corresponding navigator series if `showInNavigator`\n * is `true` for this series. Available options are the same as any\n * series, documented at [plotOptions](#plotOptions.series) and\n * [series](#series).\n *\n * These options are merged with options in [navigator.series](\n * #navigator.series), and will take precedence if the same option is\n * defined both places.\n *\n * @see [navigator.series](#navigator.series)\n *\n * @type {Highcharts.PlotSeriesOptions}\n * @since 5.0.0\n * @product highstock\n * @apioption plotOptions.series.navigatorOptions\n */\n /**\n * The color for the parts of the graph or points that are below the\n * [threshold](#plotOptions.series.threshold). Note that `zones` takes\n * precedence over the negative color. Using `negativeColor` is\n * equivalent to applying a zone with value of 0.\n *\n * @see In styled mode, a negative color is applied by setting this option\n * to `true` combined with the `.highcharts-negative` class name.\n *\n * @sample {highcharts} highcharts/plotoptions/series-negative-color/\n * Spline, area and column\n * @sample {highcharts} highcharts/plotoptions/arearange-negativecolor/\n * Arearange\n * @sample {highcharts} highcharts/css/series-negative-color/\n * Styled mode\n * @sample {highstock} highcharts/plotoptions/series-negative-color/\n * Spline, area and column\n * @sample {highstock} highcharts/plotoptions/arearange-negativecolor/\n * Arearange\n * @sample {highmaps} highcharts/plotoptions/series-negative-color/\n * Spline, area and column\n * @sample {highmaps} highcharts/plotoptions/arearange-negativecolor/\n * Arearange\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 3.0\n * @apioption plotOptions.series.negativeColor\n */\n /**\n * Same as\n * [accessibility.series.descriptionFormatter](#accessibility.series.descriptionFormatter),\n * but for an individual series. Overrides the chart wide configuration.\n *\n * @type {Function}\n * @since 5.0.12\n * @apioption plotOptions.series.pointDescriptionFormatter\n */\n /**\n * If no x values are given for the points in a series, `pointInterval`\n * defines the interval of the x values. For example, if a series\n * contains one value every decade starting from year 0, set\n * `pointInterval` to `10`. In true `datetime` axes, the `pointInterval`\n * is set in milliseconds.\n *\n * It can be also be combined with `pointIntervalUnit` to draw irregular\n * time intervals.\n *\n * If combined with `relativeXValue`, an x value can be set on each\n * point, and the `pointInterval` is added x times to the `pointStart`\n * setting.\n *\n * Please note that this options applies to the _series data_, not the\n * interval of the axis ticks, which is independent.\n *\n * @sample {highcharts} highcharts/plotoptions/series-pointstart-datetime/\n * Datetime X axis\n * @sample {highcharts} highcharts/plotoptions/series-relativexvalue/\n * Relative x value\n * @sample {highstock} stock/plotoptions/pointinterval-pointstart/\n * Using pointStart and pointInterval\n * @sample {highstock} stock/plotoptions/relativexvalue/\n * Relative x value\n *\n * @type {number}\n * @default 1\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.pointInterval\n */\n /**\n * On datetime series, this allows for setting the\n * [pointInterval](#plotOptions.series.pointInterval) to irregular time\n * units, `day`, `month` and `year`. A day is usually the same as 24\n * hours, but `pointIntervalUnit` also takes the DST crossover into\n * consideration when dealing with local time. Combine this option with\n * `pointInterval` to draw weeks, quarters, 6 months, 10 years etc.\n *\n * Please note that this options applies to the _series data_, not the\n * interval of the axis ticks, which is independent.\n *\n * @sample {highcharts} highcharts/plotoptions/series-pointintervalunit/\n * One point a month\n * @sample {highstock} highcharts/plotoptions/series-pointintervalunit/\n * One point a month\n *\n * @type {string}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @validvalue [\"day\", \"month\", \"year\"]\n * @apioption plotOptions.series.pointIntervalUnit\n */\n /**\n * Possible values: `\"on\"`, `\"between\"`, `number`.\n *\n * In a column chart, when pointPlacement is `\"on\"`, the point will not\n * create any padding of the X axis. In a polar column chart this means\n * that the first column points directly north. If the pointPlacement is\n * `\"between\"`, the columns will be laid out between ticks. This is\n * useful for example for visualising an amount between two points in\n * time or in a certain sector of a polar chart.\n *\n * Since Highcharts 3.0.2, the point placement can also be numeric,\n * where 0 is on the axis value, -0.5 is between this value and the\n * previous, and 0.5 is between this value and the next. Unlike the\n * textual options, numeric point placement options won't affect axis\n * padding.\n *\n * Note that pointPlacement needs a [pointRange](\n * #plotOptions.series.pointRange) to work. For column series this is\n * computed, but for line-type series it needs to be set.\n *\n * For the `xrange` series type and gantt charts, if the Y axis is a\n * category axis, the `pointPlacement` applies to the Y axis rather than\n * the (typically datetime) X axis.\n *\n * Defaults to `undefined` in cartesian charts, `\"between\"` in polar\n * charts.\n *\n * @see [xAxis.tickmarkPlacement](#xAxis.tickmarkPlacement)\n *\n * @sample {highcharts|highstock} highcharts/plotoptions/series-pointplacement-between/\n * Between in a column chart\n * @sample {highcharts|highstock} highcharts/plotoptions/series-pointplacement-numeric/\n * Numeric placement for custom layout\n * @sample {highcharts|highstock} maps/plotoptions/heatmap-pointplacement/\n * Placement in heatmap\n *\n * @type {string|number}\n * @since 2.3.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.pointPlacement\n */\n /**\n * If no x values are given for the points in a series, pointStart\n * defines on what value to start. For example, if a series contains one\n * yearly value starting from 1945, set pointStart to 1945.\n *\n * If combined with `relativeXValue`, an x value can be set on each\n * point. The x value from the point options is multiplied by\n * `pointInterval` and added to `pointStart` to produce a modified x\n * value.\n *\n * @sample {highcharts} highcharts/plotoptions/series-pointstart-linear/\n * Linear\n * @sample {highcharts} highcharts/plotoptions/series-pointstart-datetime/\n * Datetime\n * @sample {highcharts} highcharts/plotoptions/series-relativexvalue/\n * Relative x value\n * @sample {highstock} stock/plotoptions/pointinterval-pointstart/\n * Using pointStart and pointInterval\n * @sample {highstock} stock/plotoptions/relativexvalue/\n * Relative x value\n *\n * @type {number}\n * @default 0\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.pointStart\n */\n /**\n * When true, X values in the data set are relative to the current\n * `pointStart`, `pointInterval` and `pointIntervalUnit` settings. This\n * allows compression of the data for datasets with irregular X values.\n *\n * The real X values are computed on the formula `f(x) = ax + b`, where\n * `a` is the `pointInterval` (optionally with a time unit given by\n * `pointIntervalUnit`), and `b` is the `pointStart`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-relativexvalue/\n * Relative X value\n * @sample {highstock} stock/plotoptions/relativexvalue/\n * Relative X value\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock\n * @apioption plotOptions.series.relativeXValue\n */\n /**\n * Whether to select the series initially. If `showCheckbox` is true,\n * the checkbox next to the series name in the legend will be checked\n * for a selected series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-selected/\n * One out of two series selected\n *\n * @type {boolean}\n * @default false\n * @since 1.2.0\n * @apioption plotOptions.series.selected\n */\n /**\n * Whether to apply a drop shadow to the graph line. Since 2.3 the\n * shadow can be an object configuration containing `color`, `offsetX`,\n * `offsetY`, `opacity` and `width`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-shadow/\n * Shadow enabled\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n * @default false\n * @apioption plotOptions.series.shadow\n */\n /**\n * Whether to display this particular series or series type in the\n * legend. Standalone series are shown in legend by default, and linked\n * series are not. Since v7.2.0 it is possible to show series that use\n * colorAxis by setting this option to `true`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-showinlegend/\n * One series in the legend, one hidden\n *\n * @type {boolean}\n * @apioption plotOptions.series.showInLegend\n */\n /**\n * Whether or not to show the series in the navigator. Takes precedence\n * over [navigator.baseSeries](#navigator.baseSeries) if defined.\n *\n * @type {boolean}\n * @since 5.0.0\n * @product highstock\n * @apioption plotOptions.series.showInNavigator\n */\n /**\n * If set to `true`, the accessibility module will skip past the points\n * in this series for keyboard navigation.\n *\n * @type {boolean}\n * @since 5.0.12\n * @apioption plotOptions.series.skipKeyboardNavigation\n */\n /**\n * Whether to stack the values of each series on top of each other.\n * Possible values are `undefined` to disable, `\"normal\"` to stack by\n * value or `\"percent\"`.\n *\n * When stacking is enabled, data must be sorted\n * in ascending X order.\n *\n * Some stacking options are related to specific series types. In the\n * streamgraph series type, the stacking option is set to `\"stream\"`.\n * The second one is `\"overlap\"`, which only applies to waterfall\n * series.\n *\n * @see [yAxis.reversedStacks](#yAxis.reversedStacks)\n *\n * @sample {highcharts} highcharts/plotoptions/series-stacking-line/\n * Line\n * @sample {highcharts} highcharts/plotoptions/series-stacking-column/\n * Column\n * @sample {highcharts} highcharts/plotoptions/series-stacking-bar/\n * Bar\n * @sample {highcharts} highcharts/plotoptions/series-stacking-area/\n * Area\n * @sample {highcharts} highcharts/plotoptions/series-stacking-percent-line/\n * Line\n * @sample {highcharts} highcharts/plotoptions/series-stacking-percent-column/\n * Column\n * @sample {highcharts} highcharts/plotoptions/series-stacking-percent-bar/\n * Bar\n * @sample {highcharts} highcharts/plotoptions/series-stacking-percent-area/\n * Area\n * @sample {highcharts} highcharts/plotoptions/series-waterfall-with-normal-stacking\n * Waterfall with normal stacking\n * @sample {highcharts} highcharts/plotoptions/series-waterfall-with-overlap-stacking\n * Waterfall with overlap stacking\n * @sample {highstock} stock/plotoptions/stacking/\n * Area\n *\n * @type {string}\n * @product highcharts highstock\n * @validvalue [\"normal\", \"overlap\", \"percent\", \"stream\"]\n * @apioption plotOptions.series.stacking\n */\n /**\n * Whether to apply steps to the line. Possible values are `left`,\n * `center` and `right`.\n *\n * @sample {highcharts} highcharts/plotoptions/line-step/\n * Different step line options\n * @sample {highcharts} highcharts/plotoptions/area-step/\n * Stepped, stacked area\n * @sample {highstock} stock/plotoptions/line-step/\n * Step line\n *\n * @type {string}\n * @since 1.2.5\n * @product highcharts highstock\n * @validvalue [\"left\", \"center\", \"right\"]\n * @apioption plotOptions.series.step\n */\n /**\n * The threshold, also called zero level or base level. For line type\n * series this is only used in conjunction with\n * [negativeColor](#plotOptions.series.negativeColor).\n *\n * @see [softThreshold](#plotOptions.series.softThreshold).\n *\n * @type {number|null}\n * @default 0\n * @since 3.0\n * @product highcharts highstock\n * @apioption plotOptions.series.threshold\n */\n /**\n * Set the initial visibility of the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-visible/\n * Two series, one hidden and one visible\n * @sample {highstock} stock/plotoptions/series-visibility/\n * Hidden series\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.visible\n */\n /**\n * Defines the Axis on which the zones are applied.\n *\n * @see [zones](#plotOptions.series.zones)\n *\n * @sample {highcharts} highcharts/series/color-zones-zoneaxis-x/\n * Zones on the X-Axis\n * @sample {highstock} highcharts/series/color-zones-zoneaxis-x/\n * Zones on the X-Axis\n *\n * @type {string}\n * @default y\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zoneAxis\n */\n /**\n * General event handlers for the series items. These event hooks can\n * also be attached to the series at run time using the\n * `Highcharts.addEvent` function.\n *\n * @declare Highcharts.SeriesEventsOptionsObject\n *\n * @private\n */\n events: {},\n /**\n * Fires after the series has finished its initial animation, or in case\n * animation is disabled, immediately as the series is displayed.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-afteranimate/\n * Show label after animate\n * @sample {highstock} highcharts/plotoptions/series-events-afteranimate/\n * Show label after animate\n *\n * @type {Highcharts.SeriesAfterAnimateCallbackFunction}\n * @since 4.0\n * @product highcharts highstock gantt\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.afterAnimate\n */\n /**\n * Fires when the checkbox next to the series' name in the legend is\n * clicked. One parameter, `event`, is passed to the function. The state\n * of the checkbox is found by `event.checked`. The checked item is\n * found by `event.item`. Return `false` to prevent the default action\n * which is to toggle the select state of the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-checkboxclick/\n * Alert checkbox status\n *\n * @type {Highcharts.SeriesCheckboxClickCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.checkboxClick\n */\n /**\n * Fires when the series is clicked. One parameter, `event`, is passed\n * to the function, containing common event information. Additionally,\n * `event.point` holds a pointer to the nearest point on the graph.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-click/\n * Alert click info\n * @sample {highstock} stock/plotoptions/series-events-click/\n * Alert click info\n * @sample {highmaps} maps/plotoptions/series-events-click/\n * Display click info in subtitle\n *\n * @type {Highcharts.SeriesClickCallbackFunction}\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.click\n */\n /**\n * Fires when the series is hidden after chart generation time, either\n * by clicking the legend item or by calling `.hide()`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-hide/\n * Alert when the series is hidden by clicking the legend item\n *\n * @type {Highcharts.SeriesHideCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.hide\n */\n /**\n * Fires when the legend item belonging to the series is clicked. One\n * parameter, `event`, is passed to the function. The default action\n * is to toggle the visibility of the series. This can be prevented\n * by returning `false` or calling `event.preventDefault()`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-legenditemclick/\n * Confirm hiding and showing\n *\n * @type {Highcharts.SeriesLegendItemClickCallbackFunction}\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.legendItemClick\n */\n /**\n * Fires when the mouse leaves the graph. One parameter, `event`, is\n * passed to the function, containing common event information. If the\n * [stickyTracking](#plotOptions.series) option is true, `mouseOut`\n * doesn't happen before the mouse enters another graph or leaves the\n * plot area.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-mouseover-sticky/\n * With sticky tracking by default\n * @sample {highcharts} highcharts/plotoptions/series-events-mouseover-no-sticky/\n * Without sticky tracking\n *\n * @type {Highcharts.SeriesMouseOutCallbackFunction}\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.mouseOut\n */\n /**\n * Fires when the mouse enters the graph. One parameter, `event`, is\n * passed to the function, containing common event information.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-mouseover-sticky/\n * With sticky tracking by default\n * @sample {highcharts} highcharts/plotoptions/series-events-mouseover-no-sticky/\n * Without sticky tracking\n *\n * @type {Highcharts.SeriesMouseOverCallbackFunction}\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.mouseOver\n */\n /**\n * Fires when the series is shown after chart generation time, either\n * by clicking the legend item or by calling `.show()`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-show/\n * Alert when the series is shown by clicking the legend item.\n *\n * @type {Highcharts.SeriesShowCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.show\n */\n /**\n * Options for the point markers of line-like series. Properties like\n * `fillColor`, `lineColor` and `lineWidth` define the visual appearance\n * of the markers. Other series types, like column series, don't have\n * markers, but have visual options on the series level instead.\n *\n * In styled mode, the markers can be styled with the\n * `.highcharts-point`, `.highcharts-point-hover` and\n * `.highcharts-point-select` class names.\n *\n * @declare Highcharts.PointMarkerOptionsObject\n *\n * @private\n */\n marker: {\n /**\n * Enable or disable the point marker. If `undefined`, the markers\n * are hidden when the data is dense, and shown for more widespread\n * data points.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-enabled/\n * Disabled markers\n * @sample {highcharts} highcharts/plotoptions/series-marker-enabled-false/\n * Disabled in normal state but enabled on hover\n * @sample {highstock} stock/plotoptions/series-marker/\n * Enabled markers\n *\n * @type {boolean}\n * @default {highcharts} undefined\n * @default {highstock} false\n * @apioption plotOptions.series.marker.enabled\n */\n /**\n * The threshold for how dense the point markers should be before\n * they are hidden, given that `enabled` is not defined. The number\n * indicates the horizontal distance between the two closest points\n * in the series, as multiples of the `marker.radius`. In other\n * words, the default value of 2 means points are hidden if\n * overlapping horizontally.\n *\n * @sample highcharts/plotoptions/series-marker-enabledthreshold\n * A higher threshold\n *\n * @since 6.0.5\n */\n enabledThreshold: 2,\n /**\n * The fill color of the point marker. When `undefined`, the series'\n * or point's color is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-fillcolor/\n * White fill\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption plotOptions.series.marker.fillColor\n */\n /**\n * Image markers only. Set the image width explicitly. When using\n * this option, a `width` must also be set.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-width-height/\n * Fixed width and height\n * @sample {highstock} highcharts/plotoptions/series-marker-width-height/\n * Fixed width and height\n *\n * @type {number}\n * @since 4.0.4\n * @apioption plotOptions.series.marker.height\n */\n /**\n * The color of the point marker's outline. When `undefined`, the\n * series' or point's color is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-fillcolor/\n * Inherit from series color (undefined)\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n lineColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The width of the point marker's outline.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-fillcolor/\n * 2px blue marker\n */\n lineWidth: 0,\n /**\n * The radius of the point marker.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-radius/\n * Bigger markers\n *\n * @default {highstock} 2\n * @default {highcharts} 4\n *\n */\n radius: 4,\n /**\n * A predefined shape or symbol for the marker. When undefined, the\n * symbol is pulled from options.symbols. Other possible values are\n * `'circle'`, `'square'`,`'diamond'`, `'triangle'` and\n * `'triangle-down'`.\n *\n * Additionally, the URL to a graphic can be given on this form:\n * `'url(graphic.png)'`. Note that for the image to be applied to\n * exported charts, its URL needs to be accessible by the export\n * server.\n *\n * Custom callbacks for symbol path generation can also be added to\n * `Highcharts.SVGRenderer.prototype.symbols`. The callback is then\n * used by its method name, as shown in the demo.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-symbol/\n * Predefined, graphic and custom markers\n * @sample {highstock} highcharts/plotoptions/series-marker-symbol/\n * Predefined, graphic and custom markers\n *\n * @type {string}\n * @apioption plotOptions.series.marker.symbol\n */\n /**\n * Image markers only. Set the image width explicitly. When using\n * this option, a `height` must also be set.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-width-height/\n * Fixed width and height\n * @sample {highstock} highcharts/plotoptions/series-marker-width-height/\n * Fixed width and height\n *\n * @type {number}\n * @since 4.0.4\n * @apioption plotOptions.series.marker.width\n */\n /**\n * States for a single point marker.\n *\n * @declare Highcharts.PointStatesOptionsObject\n */\n states: {\n /**\n * The normal state of a single point marker. Currently only\n * used for setting animation when returning to normal state\n * from hover.\n *\n * @declare Highcharts.PointStatesNormalOptionsObject\n */\n normal: {\n /**\n * Animation when returning to normal state after hovering.\n *\n * @type {boolean|Partial}\n */\n animation: true\n },\n /**\n * The hover state for a single point marker.\n *\n * @declare Highcharts.PointStatesHoverOptionsObject\n */\n hover: {\n /**\n * Animation when hovering over the marker.\n *\n * @type {boolean|Partial}\n */\n animation: {\n /** @internal */\n duration: 50\n },\n /**\n * Enable or disable the point marker.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-hover-enabled/\n * Disabled hover state\n */\n enabled: true,\n /**\n * The fill color of the marker in hover state. When\n * `undefined`, the series' or point's fillColor for normal\n * state is used.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption plotOptions.series.marker.states.hover.fillColor\n */\n /**\n * The color of the point marker's outline. When\n * `undefined`, the series' or point's lineColor for normal\n * state is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-hover-linecolor/\n * White fill color, black line color\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption plotOptions.series.marker.states.hover.lineColor\n */\n /**\n * The width of the point marker's outline. When\n * `undefined`, the series' or point's lineWidth for normal\n * state is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-hover-linewidth/\n * 3px line width\n *\n * @type {number}\n * @apioption plotOptions.series.marker.states.hover.lineWidth\n */\n /**\n * The radius of the point marker. In hover state, it\n * defaults to the normal state's radius + 2 as per the\n * [radiusPlus](#plotOptions.series.marker.states.hover.radiusPlus)\n * option.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-hover-radius/\n * 10px radius\n *\n * @type {number}\n * @apioption plotOptions.series.marker.states.hover.radius\n */\n /**\n * The number of pixels to increase the radius of the\n * hovered point.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 5 pixels greater radius on hover\n * @sample {highstock} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 5 pixels greater radius on hover\n *\n * @since 4.0.3\n */\n radiusPlus: 2,\n /**\n * The additional line width for a hovered point.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 2 pixels wider on hover\n * @sample {highstock} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 2 pixels wider on hover\n *\n * @since 4.0.3\n */\n lineWidthPlus: 1\n },\n /**\n * The appearance of the point marker when selected. In order to\n * allow a point to be selected, set the\n * `series.allowPointSelect` option to true.\n *\n * @declare Highcharts.PointStatesSelectOptionsObject\n */\n select: {\n /**\n * Enable or disable visible feedback for selection.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-enabled/\n * Disabled select state\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.marker.states.select.enabled\n */\n /**\n * The radius of the point marker. In hover state, it\n * defaults to the normal state's radius + 2.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-radius/\n * 10px radius for selected points\n *\n * @type {number}\n * @apioption plotOptions.series.marker.states.select.radius\n */\n /**\n * The fill color of the point marker.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-fillcolor/\n * Solid red discs for selected points\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n fillColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * The color of the point marker's outline. When\n * `undefined`, the series' or point's color is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-linecolor/\n * Red line color for selected points\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n lineColor: \"#000000\" /* Palette.neutralColor100 */,\n /**\n * The width of the point marker's outline.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-linewidth/\n * 3px line width for selected points\n */\n lineWidth: 2\n }\n }\n },\n /**\n * Properties for each single point.\n *\n * @declare Highcharts.PlotSeriesPointOptions\n *\n * @private\n */\n point: {\n /**\n * Fires when a point is clicked. One parameter, `event`, is passed\n * to the function, containing common event information.\n *\n * If the `series.allowPointSelect` option is true, the default\n * action for the point's click event is to toggle the point's\n * select state. Returning `false` cancels this action.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-click/\n * Click marker to alert values\n * @sample {highcharts} highcharts/plotoptions/series-point-events-click-column/\n * Click column\n * @sample {highcharts} highcharts/plotoptions/series-point-events-click-url/\n * Go to URL\n * @sample {highmaps} maps/plotoptions/series-point-events-click/\n * Click marker to display values\n * @sample {highmaps} maps/plotoptions/series-point-events-click-url/\n * Go to URL\n *\n * @type {Highcharts.PointClickCallbackFunction}\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.click\n */\n /**\n * Fires when the mouse leaves the area close to the point. One\n * parameter, `event`, is passed to the function, containing common\n * event information.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-mouseover/\n * Show values in the chart's corner on mouse over\n *\n * @type {Highcharts.PointMouseOutCallbackFunction}\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.mouseOut\n */\n /**\n * Fires when the mouse enters the area close to the point. One\n * parameter, `event`, is passed to the function, containing common\n * event information.\n *\n * Returning `false` cancels the default behavior, which is to show a\n * tooltip for the point.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-mouseover/\n * Show values in the chart's corner on mouse over\n *\n * @type {Highcharts.PointMouseOverCallbackFunction}\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.mouseOver\n */\n /**\n * Fires when the point is removed using the `.remove()` method. One\n * parameter, `event`, is passed to the function. Returning `false`\n * cancels the operation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-remove/\n * Remove point and confirm\n *\n * @type {Highcharts.PointRemoveCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.remove\n */\n /**\n * Fires when the point is selected either programmatically or\n * following a click on the point. One parameter, `event`, is passed\n * to the function. Returning `false` cancels the operation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-select/\n * Report the last selected point\n * @sample {highmaps} maps/plotoptions/series-allowpointselect/\n * Report select and unselect\n *\n * @type {Highcharts.PointSelectCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.select\n */\n /**\n * Fires when the point is unselected either programmatically or\n * following a click on the point. One parameter, `event`, is passed\n * to the function.\n * Returning `false` cancels the operation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-unselect/\n * Report the last unselected point\n * @sample {highmaps} maps/plotoptions/series-allowpointselect/\n * Report select and unselect\n *\n * @type {Highcharts.PointUnselectCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.unselect\n */\n /**\n * Fires when the point is updated programmatically through the\n * `.update()` method. One parameter, `event`, is passed to the\n * function. The new point options can be accessed through\n * `event.options`. Returning `false` cancels the operation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-update/\n * Confirm point updating\n *\n * @type {Highcharts.PointUpdateCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.update\n */\n /**\n * Events for each single point.\n *\n * @declare Highcharts.PointEventsOptionsObject\n */\n events: {}\n },\n /**\n * Options for the series data labels, appearing next to each data\n * point.\n *\n * Since v6.2.0, multiple data labels can be applied to each single\n * point by defining them as an array of configs.\n *\n * In styled mode, the data labels can be styled with the\n * `.highcharts-data-label-box` and `.highcharts-data-label` class names\n * ([see example](https://www.highcharts.com/samples/highcharts/css/series-datalabels)).\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-enabled\n * Data labels enabled\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-multiple\n * Multiple data labels on a bar series\n * @sample {highcharts} highcharts/css/series-datalabels\n * Style mode example\n *\n * @type {*|Array<*>}\n * @product highcharts highstock highmaps gantt\n *\n * @private\n */\n dataLabels: {\n /**\n * Enable or disable the initial animation when a series is\n * displayed for the `dataLabels`. The animation can also be set as\n * a configuration object. Please note that this option only\n * applies to the initial animation.\n * For other animations, see [chart.animation](#chart.animation)\n * and the animation parameter under the API methods.\n * The following properties are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * @sample {highcharts} highcharts/plotoptions/animation-defer/\n * Animation defer settings\n *\n * @type {boolean|Partial}\n * @since 8.2.0\n * @apioption plotOptions.series.dataLabels.animation\n */\n animation: {},\n /**\n * The animation delay time in milliseconds.\n * Set to `0` renders dataLabel immediately.\n * As `undefined` inherits defer time from the [series.animation.defer](#plotOptions.series.animation.defer).\n *\n * @type {number}\n * @since 8.2.0\n * @apioption plotOptions.series.dataLabels.animation.defer\n */\n /**\n * The alignment of the data label compared to the point. If\n * `right`, the right side of the label should be touching the\n * point. For points with an extent, like columns, the alignments\n * also dictates how to align it inside the box, as given with the\n * [inside](#plotOptions.column.dataLabels.inside)\n * option. Can be one of `left`, `center` or `right`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-align-left/\n * Left aligned\n * @sample {highcharts} highcharts/plotoptions/bar-datalabels-align-inside-bar/\n * Data labels inside the bar\n *\n * @type {Highcharts.AlignValue|null}\n */\n align: 'center',\n /**\n * Whether to allow data labels to overlap. To make the labels less\n * sensitive for overlapping, the\n * [dataLabels.padding](#plotOptions.series.dataLabels.padding)\n * can be set to 0.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-allowoverlap-false/\n * Don't allow overlap\n *\n * @type {boolean}\n * @default false\n * @since 4.1.0\n * @apioption plotOptions.series.dataLabels.allowOverlap\n */\n /**\n * The background color or gradient for the data label.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n * @sample {highmaps} maps/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.backgroundColor\n */\n /**\n * The border color for the data label. Defaults to `undefined`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.borderColor\n */\n /**\n * The border radius in pixels for the data label.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n * @sample {highmaps} maps/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {number}\n * @default 0\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.borderRadius\n */\n /**\n * The border width in pixels for the data label.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {number}\n * @default 0\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.borderWidth\n */\n /**\n * A class name for the data label. Particularly in styled mode,\n * this can be used to give each series' or point's data label\n * unique styling. In addition to this option, a default color class\n * name is added so that we can give the labels a contrast text\n * shadow.\n *\n * @sample {highcharts} highcharts/css/data-label-contrast/\n * Contrast text shadow\n * @sample {highcharts} highcharts/css/series-datalabels/\n * Styling by CSS\n *\n * @type {string}\n * @since 5.0.0\n * @apioption plotOptions.series.dataLabels.className\n */\n /**\n * This options is deprecated.\n * Use [style.color](#plotOptions.series.dataLabels.style) instead.\n *\n * The text color for the data labels. Defaults to `undefined`. For\n * certain series types, like column or map, the data labels can be\n * drawn inside the points. In this case the data label will be\n * drawn with maximum contrast by default. Additionally, it will be\n * given a `text-outline` style with the opposite color, to further\n * increase the contrast. This can be overridden by setting the\n * `text-outline` style to `none` in the `dataLabels.style` option.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-color/\n * Red data labels\n * @sample {highmaps} maps/demo/color-axis/\n * White data labels\n *\n * @see [style.color](#plotOptions.series.dataLabels.style)\n *\n * @type {Highcharts.ColorType}\n * @deprecated 10.3\n * @apioption plotOptions.series.dataLabels.color\n */\n /**\n * Whether to hide data labels that are outside the plot area. By\n * default, the data label is moved inside the plot area according\n * to the\n * [overflow](#plotOptions.series.dataLabels.overflow)\n * option.\n *\n * @type {boolean}\n * @default true\n * @since 2.3.3\n * @apioption plotOptions.series.dataLabels.crop\n */\n /**\n * Whether to defer displaying the data labels until the initial\n * series animation has finished. Setting to `false` renders the\n * data label immediately. If set to `true` inherits the defer\n * time set in [plotOptions.series.animation](#plotOptions.series.animation).\n * If set to a number, a defer time is specified in milliseconds.\n *\n * @sample highcharts/plotoptions/animation-defer\n * Set defer time\n *\n * @since 4.0.0\n * @type {boolean|number}\n * @product highcharts highstock gantt\n */\n defer: true,\n /**\n * Enable or disable the data labels.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-enabled/\n * Data labels enabled\n * @sample {highmaps} maps/demo/color-axis/\n * Data labels enabled\n *\n * @type {boolean}\n * @default false\n * @apioption plotOptions.series.dataLabels.enabled\n */\n /**\n * A declarative filter to control of which data labels to display.\n * The declarative filter is designed for use when callback\n * functions are not available, like when the chart options require\n * a pure JSON structure or for use with graphical editors. For\n * programmatic control, use the `formatter` instead, and return\n * `undefined` to disable a single data label.\n *\n * @example\n * filter: {\n * property: 'percentage',\n * operator: '>',\n * value: 4\n * }\n *\n * @sample {highcharts} highcharts/demo/pie-monochrome\n * Data labels filtered by percentage\n *\n * @declare Highcharts.DataLabelsFilterOptionsObject\n * @since 6.0.3\n * @apioption plotOptions.series.dataLabels.filter\n */\n /**\n * The operator to compare by. Can be one of `>`, `<`, `>=`, `<=`,\n * `==`, and `===`.\n *\n * @type {string}\n * @validvalue [\">\", \"<\", \">=\", \"<=\", \"==\", \"===\"]\n * @apioption plotOptions.series.dataLabels.filter.operator\n */\n /**\n * The point property to filter by. Point options are passed\n * directly to properties, additionally there are `y` value,\n * `percentage` and others listed under {@link Highcharts.Point}\n * members.\n *\n * @type {string}\n * @apioption plotOptions.series.dataLabels.filter.property\n */\n /**\n * The value to compare against.\n *\n * @type {number}\n * @apioption plotOptions.series.dataLabels.filter.value\n */\n /**\n * A\n * [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for the data label. Available variables are the same as for\n * `formatter`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-format/\n * Add a unit\n * @sample {highmaps} maps/plotoptions/series-datalabels-format/\n * Formatted value in the data label\n *\n * @type {string}\n * @default y\n * @default point.value\n * @since 3.0\n * @apioption plotOptions.series.dataLabels.format\n */\n // eslint-disable-next-line valid-jsdoc\n /**\n * Callback JavaScript function to format the data label. Note that if a\n * `format` is defined, the format takes precedence and the formatter is\n * ignored.\n *\n * @sample {highmaps} maps/plotoptions/series-datalabels-format/\n * Formatted value\n *\n * @type {Highcharts.DataLabelsFormatterCallbackFunction}\n */\n formatter: function () {\n var numberFormatter = this.series.chart.numberFormatter;\n return typeof this.y !== 'number' ?\n '' : numberFormatter(this.y, -1);\n },\n /**\n * For points with an extent, like columns or map areas, whether to\n * align the data label inside the box or to the actual value point.\n * Defaults to `false` in most cases, `true` in stacked columns.\n *\n * @type {boolean}\n * @since 3.0\n * @apioption plotOptions.series.dataLabels.inside\n */\n /**\n * Format for points with the value of null. Works analogously to\n * [format](#plotOptions.series.dataLabels.format). `nullFormat` can\n * be applied only to series which support displaying null points\n * i.e `heatmap` or `tilemap`. Does not work with series that don't\n * display null points, like `line`, `column`, `bar` or `pie`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-nullformat/\n * Format data label for null points in heat map\n *\n * @type {boolean|string}\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.nullFormat\n */\n /**\n * Callback JavaScript function that defines formatting for points\n * with the value of null. Works analogously to\n * [formatter](#plotOptions.series.dataLabels.formatter).\n * `nullFormatter` can be applied only to series which support\n * displaying null points i.e `heatmap` or `tilemap`. Does not work\n * with series that don't display null points, like `line`, `column`,\n * `bar` or `pie`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-nullformat/\n * Format data label for null points in heat map\n *\n * @type {Highcharts.DataLabelsFormatterCallbackFunction}\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.nullFormatter\n */\n /**\n * How to handle data labels that flow outside the plot area. The\n * default is `\"justify\"`, which aligns them inside the plot area.\n * For columns and bars, this means it will be moved inside the bar.\n * To display data labels outside the plot area, set `crop` to\n * `false` and `overflow` to `\"allow\"`.\n *\n * @type {Highcharts.DataLabelsOverflowValue}\n * @default justify\n * @since 3.0.6\n * @apioption plotOptions.series.dataLabels.overflow\n */\n /**\n * When either the `borderWidth` or the `backgroundColor` is set,\n * this is the padding within the box.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n * @sample {highmaps} maps/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @since 2.2.1\n */\n padding: 5,\n /**\n * Aligns data labels relative to points. If `center` alignment is\n * not possible, it defaults to `right`.\n *\n * @type {Highcharts.AlignValue}\n * @default center\n * @apioption plotOptions.series.dataLabels.position\n */\n /**\n * Text rotation in degrees. Note that due to a more complex\n * structure, backgrounds, borders and padding will be lost on a\n * rotated data label.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-rotation/\n * Vertical labels\n *\n * @type {number}\n * @default 0\n * @apioption plotOptions.series.dataLabels.rotation\n */\n /**\n * The shadow of the box. Works best with `borderWidth` or\n * `backgroundColor`. Since 2.3 the shadow can be an object\n * configuration containing `color`, `offsetX`, `offsetY`, `opacity`\n * and `width`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n * @default false\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.shadow\n */\n /**\n * The name of a symbol to use for the border around the label.\n * Symbols are predefined functions on the Renderer object.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-shape/\n * A callout for annotations\n *\n * @type {string}\n * @default square\n * @since 4.1.2\n * @apioption plotOptions.series.dataLabels.shape\n */\n /**\n * Styles for the label. The default `color` setting is\n * `\"contrast\"`, which is a pseudo color that Highcharts picks up\n * and applies the maximum contrast to the underlying point item,\n * for example the bar in a bar chart.\n *\n * The `textOutline` is a pseudo property that applies an outline of\n * the given width with the given color, which by default is the\n * maximum contrast to the text. So a bright text color will result\n * in a black text outline for maximum readability on a mixed\n * background. In some cases, especially with grayscale text, the\n * text outline doesn't work well, in which cases it can be disabled\n * by setting it to `\"none\"`. When `useHTML` is true, the\n * `textOutline` will not be picked up. In this, case, the same\n * effect can be acheived through the `text-shadow` CSS property.\n *\n * For some series types, where each point has an extent, like for\n * example tree maps, the data label may overflow the point. There\n * are two strategies for handling overflow. By default, the text\n * will wrap to multiple lines. The other strategy is to set\n * `style.textOverflow` to `ellipsis`, which will keep the text on\n * one line plus it will break inside long words.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-style/\n * Bold labels\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-overflow/\n * Long labels truncated with an ellipsis in a pie\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-overflow-wrap/\n * Long labels are wrapped in a pie\n * @sample {highmaps} maps/demo/color-axis/\n * Bold labels\n *\n * @type {Highcharts.CSSObject}\n * @since 4.1.0\n * @apioption plotOptions.series.dataLabels.style\n */\n style: {\n /** @internal */\n fontSize: '11px',\n /** @internal */\n fontWeight: 'bold',\n /** @internal */\n color: 'contrast',\n /** @internal */\n textOutline: '1px contrast'\n },\n /**\n * Options for a label text which should follow marker's shape.\n * Border and background are disabled for a label that follows a\n * path.\n *\n * **Note:** Only SVG-based renderer supports this option. Setting\n * `useHTML` to true will disable this option.\n *\n * @declare Highcharts.DataLabelsTextPathOptionsObject\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.textPath\n */\n /**\n * Presentation attributes for the text path.\n *\n * @type {Highcharts.SVGAttributes}\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.textPath.attributes\n */\n /**\n * Enable or disable `textPath` option for link's or marker's data\n * labels.\n *\n * @type {boolean}\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.textPath.enabled\n */\n /**\n * Whether to\n * [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n *\n * @type {boolean}\n * @default false\n * @apioption plotOptions.series.dataLabels.useHTML\n */\n /**\n * The vertical alignment of a data label. Can be one of `top`,\n * `middle` or `bottom`. The default value depends on the data, for\n * instance in a column chart, the label is above positive values\n * and below negative values.\n *\n * @type {Highcharts.VerticalAlignValue|null}\n * @since 2.3.3\n */\n verticalAlign: 'bottom',\n /**\n * The x position offset of the label relative to the point in\n * pixels.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-rotation/\n * Vertical and positioned\n * @sample {highcharts} highcharts/plotoptions/bar-datalabels-align-inside-bar/\n * Data labels inside the bar\n */\n x: 0,\n /**\n * The z index of the data labels. Use a `zIndex` of 6 to display it above\n * the series, or use a `zIndex` of 2 to display it behind the series.\n *\n * @type {number}\n * @default 6\n * @since 2.3.5\n * @apioption plotOptions.series.dataLabels.zIndex\n */\n /**\n * The y position offset of the label relative to the point in\n * pixels.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-rotation/\n * Vertical and positioned\n */\n y: 0\n },\n /**\n * When the series contains less points than the crop threshold, all\n * points are drawn, even if the points fall outside the visible plot\n * area at the current zoom. The advantage of drawing all points\n * (including markers and columns), is that animation is performed on\n * updates. On the other hand, when the series contains more points than\n * the crop threshold, the series data is cropped to only contain points\n * that fall within the plot area. The advantage of cropping away\n * invisible points is to increase performance on large series.\n *\n * @since 2.2\n * @product highcharts highstock\n *\n * @private\n */\n cropThreshold: 300,\n /**\n * Opacity of a series parts: line, fill (e.g. area) and dataLabels.\n *\n * @see [states.inactive.opacity](#plotOptions.series.states.inactive.opacity)\n *\n * @since 7.1.0\n *\n * @private\n */\n opacity: 1,\n /**\n * The width of each point on the x axis. For example in a column chart\n * with one value each day, the pointRange would be 1 day (= 24 * 3600\n * * 1000 milliseconds). This is normally computed automatically, but\n * this option can be used to override the automatic value.\n *\n * @product highstock\n *\n * @private\n */\n pointRange: 0,\n /**\n * When this is true, the series will not cause the Y axis to cross\n * the zero plane (or [threshold](#plotOptions.series.threshold) option)\n * unless the data actually crosses the plane.\n *\n * For example, if `softThreshold` is `false`, a series of 0, 1, 2,\n * 3 will make the Y axis show negative values according to the\n * `minPadding` option. If `softThreshold` is `true`, the Y axis starts\n * at 0.\n *\n * @since 4.1.9\n * @product highcharts highstock\n *\n * @private\n */\n softThreshold: true,\n /**\n * @declare Highcharts.SeriesStatesOptionsObject\n *\n * @private\n */\n states: {\n /**\n * The normal state of a series, or for point items in column, pie\n * and similar series. Currently only used for setting animation\n * when returning to normal state from hover.\n *\n * @declare Highcharts.SeriesStatesNormalOptionsObject\n */\n normal: {\n /**\n * Animation when returning to normal state after hovering.\n *\n * @type {boolean|Partial}\n */\n animation: true\n },\n /**\n * Options for the hovered series. These settings override the\n * normal state options when a series is moused over or touched.\n *\n * @declare Highcharts.SeriesStatesHoverOptionsObject\n */\n hover: {\n /**\n * Enable separate styles for the hovered series to visualize\n * that the user hovers either the series itself or the legend.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-enabled/\n * Line\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-enabled-column/\n * Column\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-enabled-pie/\n * Pie\n *\n * @type {boolean}\n * @default true\n * @since 1.2\n * @apioption plotOptions.series.states.hover.enabled\n */\n /**\n * Animation setting for hovering the graph in line-type series.\n *\n * @type {boolean|Partial}\n * @since 5.0.8\n * @product highcharts highstock\n */\n animation: {\n /**\n * The duration of the hover animation in milliseconds. By\n * default the hover state animates quickly in, and slowly\n * back to normal.\n *\n * @internal\n */\n duration: 50\n },\n /**\n * Pixel width of the graph line. By default this property is\n * undefined, and the `lineWidthPlus` property dictates how much\n * to increase the linewidth from normal state.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-linewidth/\n * 5px line on hover\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption plotOptions.series.states.hover.lineWidth\n */\n /**\n * The additional line width for the graph of a hovered series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 5 pixels wider\n * @sample {highstock} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 5 pixels wider\n *\n * @since 4.0.3\n * @product highcharts highstock\n */\n lineWidthPlus: 1,\n /**\n * In Highcharts 1.0, the appearance of all markers belonging\n * to the hovered series. For settings on the hover state of the\n * individual point, see\n * [marker.states.hover](#plotOptions.series.marker.states.hover).\n *\n * @deprecated\n *\n * @extends plotOptions.series.marker\n * @excluding states, symbol\n * @product highcharts highstock\n */\n marker: {\n // lineWidth: base + 1,\n // radius: base + 1\n },\n /**\n * Options for the halo appearing around the hovered point in\n * line-type series as well as outside the hovered slice in pie\n * charts. By default the halo is filled by the current point or\n * series color with an opacity of 0.25\\. The halo can be\n * disabled by setting the `halo` option to `null`.\n *\n * In styled mode, the halo is styled with the\n * `.highcharts-halo` class, with colors inherited from\n * `.highcharts-color-{n}`.\n *\n * @sample {highcharts} highcharts/plotoptions/halo/\n * Halo options\n * @sample {highstock} highcharts/plotoptions/halo/\n * Halo options\n *\n * @declare Highcharts.SeriesStatesHoverHaloOptionsObject\n * @type {null|*}\n * @since 4.0\n * @product highcharts highstock\n */\n halo: {\n /**\n * A collection of SVG attributes to override the appearance\n * of the halo, for example `fill`, `stroke` and\n * `stroke-width`.\n *\n * @type {Highcharts.SVGAttributes}\n * @since 4.0\n * @product highcharts highstock\n * @apioption plotOptions.series.states.hover.halo.attributes\n */\n /**\n * The pixel size of the halo. For point markers this is the\n * radius of the halo. For pie slices it is the width of the\n * halo outside the slice. For bubbles it defaults to 5 and\n * is the width of the halo outside the bubble.\n *\n * @since 4.0\n * @product highcharts highstock\n */\n size: 10,\n /**\n * Opacity for the halo unless a specific fill is overridden\n * using the `attributes` setting. Note that Highcharts is\n * only able to apply opacity to colors of hex or rgb(a)\n * formats.\n *\n * @since 4.0\n * @product highcharts highstock\n */\n opacity: 0.25\n }\n },\n /**\n * Specific options for point in selected states, after being\n * selected by\n * [allowPointSelect](#plotOptions.series.allowPointSelect)\n * or programmatically.\n *\n * @sample maps/plotoptions/series-allowpointselect/\n * Allow point select demo\n *\n * @declare Highcharts.SeriesStatesSelectOptionsObject\n * @extends plotOptions.series.states.hover\n * @excluding brightness\n */\n select: {\n animation: {\n /** @internal */\n duration: 0\n }\n },\n /**\n * The opposite state of a hover for series.\n *\n * @sample highcharts/plotoptions/series-states-inactive-disabled\n * Disabled inactive state\n *\n * @declare Highcharts.SeriesStatesInactiveOptionsObject\n */\n inactive: {\n /**\n * Enable or disable the inactive state for a series\n *\n * @sample highcharts/plotoptions/series-states-inactive-disabled\n * Disabled inactive state\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.states.inactive.enabled\n */\n /**\n * The animation for entering the inactive state.\n *\n * @type {boolean|Partial}\n */\n animation: {\n /** @internal */\n duration: 50\n },\n /**\n * Opacity of series elements (dataLabels, line, area).\n *\n * @type {number}\n */\n opacity: 0.2\n }\n },\n /**\n * Sticky tracking of mouse events. When true, the `mouseOut` event on a\n * series isn't triggered until the mouse moves over another series, or\n * out of the plot area. When false, the `mouseOut` event on a series is\n * triggered when the mouse leaves the area around the series' graph or\n * markers. This also implies the tooltip when not shared. When\n * `stickyTracking` is false and `tooltip.shared` is false, the tooltip\n * will be hidden when moving the mouse between series. Defaults to true\n * for line and area type series, but to false for columns, pies etc.\n *\n * **Note:** The boost module will force this option because of\n * technical limitations.\n *\n * @sample {highcharts} highcharts/plotoptions/series-stickytracking-true/\n * True by default\n * @sample {highcharts} highcharts/plotoptions/series-stickytracking-false/\n * False\n *\n * @default {highcharts} true\n * @default {highstock} true\n * @default {highmaps} false\n * @since 2.0\n *\n * @private\n */\n stickyTracking: true,\n /**\n * A configuration object for the tooltip rendering of each single\n * series. Properties are inherited from [tooltip](#tooltip), but only\n * the following properties can be defined on a series level.\n *\n * @declare Highcharts.SeriesTooltipOptionsObject\n * @since 2.3\n * @extends tooltip\n * @excluding animation, backgroundColor, borderColor, borderRadius,\n * borderWidth, className, crosshairs, enabled, formatter,\n * headerShape, hideDelay, outside, padding, positioner,\n * shadow, shape, shared, snap, split, stickOnContact,\n * style, useHTML\n * @apioption plotOptions.series.tooltip\n */\n /**\n * When a series contains a data array that is longer than this, only\n * one dimensional arrays of numbers, or two dimensional arrays with\n * x and y values are allowed. Also, only the first point is tested,\n * and the rest are assumed to be the same format. This saves expensive\n * data checking and indexing in long series. Set it to `0` disable.\n *\n * Note:\n * In boost mode turbo threshold is forced. Only array of numbers or\n * two dimensional arrays are allowed.\n *\n * @since 2.2\n * @product highcharts highstock gantt\n *\n * @private\n */\n turboThreshold: 1000,\n /**\n * An array defining zones within a series. Zones can be applied to the\n * X axis, Y axis or Z axis for bubbles, according to the `zoneAxis`\n * option. The zone definitions have to be in ascending order regarding\n * to the value.\n *\n * In styled mode, the color zones are styled with the\n * `.highcharts-zone-{n}` class, or custom classed from the `className`\n * option\n * ([view live demo](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/css/color-zones/)).\n *\n * @see [zoneAxis](#plotOptions.series.zoneAxis)\n *\n * @sample {highcharts} highcharts/series/color-zones-simple/\n * Color zones\n * @sample {highstock} highcharts/series/color-zones-simple/\n * Color zones\n *\n * @declare Highcharts.SeriesZonesOptionsObject\n * @type {Array<*>}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones\n */\n /**\n * Styled mode only. A custom class name for the zone.\n *\n * @sample highcharts/css/color-zones/\n * Zones styled by class name\n *\n * @type {string}\n * @since 5.0.0\n * @apioption plotOptions.series.zones.className\n */\n /**\n * Defines the color of the series.\n *\n * @see [series color](#plotOptions.series.color)\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones.color\n */\n /**\n * A name for the dash style to use for the graph.\n *\n * @see [plotOptions.series.dashStyle](#plotOptions.series.dashStyle)\n *\n * @sample {highcharts|highstock} highcharts/series/color-zones-dashstyle-dot/\n * Dashed line indicates prognosis\n *\n * @type {Highcharts.DashStyleValue}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones.dashStyle\n */\n /**\n * Defines the fill color for the series (in area type series)\n *\n * @see [fillColor](#plotOptions.area.fillColor)\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones.fillColor\n */\n /**\n * The value up to where the zone extends, if undefined the zones\n * stretches to the last value in the series.\n *\n * @type {number}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones.value\n */\n /**\n * When using dual or multiple color axes, this number defines which\n * colorAxis the particular series is connected to. It refers to\n * either the\n * {@link #colorAxis.id|axis id}\n * or the index of the axis in the colorAxis array, with 0 being the\n * first. Set this option to false to prevent a series from connecting\n * to the default color axis.\n *\n * Since v7.2.0 the option can also be an axis id or an axis index\n * instead of a boolean flag.\n *\n * @sample highcharts/coloraxis/coloraxis-with-pie/\n * Color axis with pie series\n * @sample highcharts/coloraxis/multiple-coloraxis/\n * Multiple color axis\n *\n * @type {number|string|boolean}\n * @default 0\n * @product highcharts highstock highmaps\n * @apioption plotOptions.series.colorAxis\n */\n /**\n * Determines what data value should be used to calculate point color\n * if `colorAxis` is used. Requires to set `min` and `max` if some\n * custom point property is used or if approximation for data grouping\n * is set to `'sum'`.\n *\n * @sample highcharts/coloraxis/custom-color-key/\n * Custom color key\n * @sample highcharts/coloraxis/color-key-with-stops/\n * Custom colorKey with color axis stops\n * @sample highcharts/coloraxis/changed-default-color-key/\n * Changed default color key\n *\n * @type {string}\n * @default y\n * @since 7.2.0\n * @product highcharts highstock highmaps\n * @apioption plotOptions.series.colorKey\n */\n /**\n * Determines whether the series should look for the nearest point\n * in both dimensions or just the x-dimension when hovering the series.\n * Defaults to `'xy'` for scatter series and `'x'` for most other\n * series. If the data has duplicate x-values, it is recommended to\n * set this to `'xy'` to allow hovering over all points.\n *\n * Applies only to series types using nearest neighbor search (not\n * direct hover) for tooltip.\n *\n * @sample {highcharts} highcharts/series/findnearestpointby/\n * Different hover behaviors\n * @sample {highstock} highcharts/series/findnearestpointby/\n * Different hover behaviors\n * @sample {highmaps} highcharts/series/findnearestpointby/\n * Different hover behaviors\n *\n * @since 5.0.10\n * @validvalue [\"x\", \"xy\"]\n *\n * @private\n */\n findNearestPointBy: 'x'\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return seriesDefaults;\n });\n _registerModule(_modules, 'Core/Series/Series.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Defaults.js'], _modules['Core/Foundation.js'], _modules['Core/Globals.js'], _modules['Core/Legend/LegendSymbol.js'], _modules['Core/Series/Point.js'], _modules['Core/Series/SeriesDefaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (A, D, F, H, LegendSymbol, Point, SeriesDefaults, SeriesRegistry, SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var animObject = A.animObject,\n setAnimation = A.setAnimation;\n var defaultOptions = D.defaultOptions;\n var registerEventOptions = F.registerEventOptions;\n var hasTouch = H.hasTouch,\n svg = H.svg,\n win = H.win;\n var seriesTypes = SeriesRegistry.seriesTypes;\n var addEvent = U.addEvent,\n arrayMax = U.arrayMax,\n arrayMin = U.arrayMin,\n clamp = U.clamp,\n cleanRecursively = U.cleanRecursively,\n correctFloat = U.correctFloat,\n defined = U.defined,\n erase = U.erase,\n error = U.error,\n extend = U.extend,\n find = U.find,\n fireEvent = U.fireEvent,\n getNestedProperty = U.getNestedProperty,\n isArray = U.isArray,\n isNumber = U.isNumber,\n isString = U.isString,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick,\n removeEvent = U.removeEvent,\n splat = U.splat,\n syncTimeout = U.syncTimeout;\n /* *\n *\n * Class\n *\n * */\n /**\n * This is the base series prototype that all other series types inherit from.\n * A new series is initialized either through the\n * [series](https://api.highcharts.com/highcharts/series)\n * option structure, or after the chart is initialized, through\n * {@link Highcharts.Chart#addSeries}.\n *\n * The object can be accessed in a number of ways. All series and point event\n * handlers give a reference to the `series` object. The chart object has a\n * {@link Highcharts.Chart#series|series} property that is a collection of all\n * the chart's series. The point objects and axis objects also have the same\n * reference.\n *\n * Another way to reference the series programmatically is by `id`. Add an id\n * in the series configuration options, and get the series object by\n * {@link Highcharts.Chart#get}.\n *\n * Configuration options for the series are given in three levels. Options for\n * all series in a chart are given in the\n * [plotOptions.series](https://api.highcharts.com/highcharts/plotOptions.series)\n * object. Then options for all series of a specific type\n * are given in the plotOptions of that type, for example `plotOptions.line`.\n * Next, options for one single series are given in the series array, or as\n * arguments to `chart.addSeries`.\n *\n * The data in the series is stored in various arrays.\n *\n * - First, `series.options.data` contains all the original config options for\n * each point whether added by options or methods like `series.addPoint`.\n *\n * - Next, `series.data` contains those values converted to points, but in case\n * the series data length exceeds the `cropThreshold`, or if the data is\n * grouped, `series.data` doesn't contain all the points. It only contains the\n * points that have been created on demand.\n *\n * - Then there's `series.points` that contains all currently visible point\n * objects. In case of cropping, the cropped-away points are not part of this\n * array. The `series.points` array starts at `series.cropStart` compared to\n * `series.data` and `series.options.data`. If however the series data is\n * grouped, these can't be correlated one to one.\n *\n * - `series.xData` and `series.processedXData` contain clean x values,\n * equivalent to `series.data` and `series.points`.\n *\n * - `series.yData` and `series.processedYData` contain clean y values,\n * equivalent to `series.data` and `series.points`.\n *\n * @class\n * @name Highcharts.Series\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.SeriesOptionsType|object} options\n * The series options.\n */\n var Series = /** @class */ (function () {\n function Series() {\n /* *\n *\n * Static Properties\n *\n * */\n this._i = void 0;\n this.chart = void 0;\n this.data = void 0;\n this.eventOptions = void 0;\n this.eventsToUnbind = void 0;\n this.index = void 0;\n this.linkedSeries = void 0;\n this.options = void 0;\n this.points = void 0;\n this.processedXData = void 0;\n this.processedYData = void 0;\n this.tooltipOptions = void 0;\n this.userOptions = void 0;\n this.xAxis = void 0;\n this.yAxis = void 0;\n this.zones = void 0;\n /** eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n Series.prototype.init = function (chart, userOptions) {\n fireEvent(this, 'init', { options: userOptions });\n var series = this,\n chartSeries = chart.series;\n // The 'eventsToUnbind' property moved from prototype into the\n // Series init to avoid reference to the same array between\n // the different series and charts. #12959, #13937\n this.eventsToUnbind = [];\n /**\n * Read only. The chart that the series belongs to.\n *\n * @name Highcharts.Series#chart\n * @type {Highcharts.Chart}\n */\n series.chart = chart;\n /**\n * Read only. The series' type, like \"line\", \"area\", \"column\" etc.\n * The type in the series options anc can be altered using\n * {@link Series#update}.\n *\n * @name Highcharts.Series#type\n * @type {string}\n */\n /**\n * Read only. The series' current options. To update, use\n * {@link Series#update}.\n *\n * @name Highcharts.Series#options\n * @type {Highcharts.SeriesOptionsType}\n */\n series.options = series.setOptions(userOptions);\n var options = series.options;\n series.linkedSeries = [];\n // bind the axes\n series.bindAxes();\n extend(series, {\n /**\n * The series name as given in the options. Defaults to\n * \"Series {n}\".\n *\n * @name Highcharts.Series#name\n * @type {string}\n */\n name: options.name,\n state: '',\n /**\n * Read only. The series' visibility state as set by {@link\n * Series#show}, {@link Series#hide}, or in the initial\n * configuration.\n *\n * @name Highcharts.Series#visible\n * @type {boolean}\n */\n visible: options.visible !== false,\n /**\n * Read only. The series' selected state as set by {@link\n * Highcharts.Series#select}.\n *\n * @name Highcharts.Series#selected\n * @type {boolean}\n */\n selected: options.selected === true // false by default\n });\n registerEventOptions(this, options);\n var events = options.events;\n if ((events && events.click) ||\n (options.point &&\n options.point.events &&\n options.point.events.click) ||\n options.allowPointSelect) {\n chart.runTrackerClick = true;\n }\n series.getColor();\n series.getSymbol();\n // Initialize the parallel data arrays\n series.parallelArrays.forEach(function (key) {\n if (!series[key + 'Data']) {\n series[key + 'Data'] = [];\n }\n });\n // Mark cartesian\n if (series.isCartesian) {\n chart.hasCartesianSeries = true;\n }\n // Get the index and register the series in the chart. The index is\n // one more than the current latest series index (#5960).\n var lastSeries;\n if (chartSeries.length) {\n lastSeries = chartSeries[chartSeries.length - 1];\n }\n series._i = pick(lastSeries && lastSeries._i, -1) + 1;\n series.opacity = series.options.opacity;\n // Insert the series and re-order all series above the insertion\n // point.\n chart.orderSeries(this.insert(chartSeries));\n // Set options for series with sorting and set data later.\n if (options.dataSorting && options.dataSorting.enabled) {\n series.setDataSortingOptions();\n }\n else if (!series.points && !series.data) {\n series.setData(options.data, false);\n }\n fireEvent(this, 'afterInit');\n };\n /**\n * Check whether the series item is itself or inherits from a certain\n * series type.\n *\n * @function Highcharts.Series#is\n * @param {string} type The type of series to check for, can be either\n * featured or custom series types. For example `column`, `pie`,\n * `ohlc` etc.\n *\n * @return {boolean}\n * True if this item is or inherits from the given type.\n */\n Series.prototype.is = function (type) {\n return seriesTypes[type] && this instanceof seriesTypes[type];\n };\n /**\n * Insert the series in a collection with other series, either the chart\n * series or yAxis series, in the correct order according to the index\n * option. Used internally when adding series.\n *\n * @private\n * @function Highcharts.Series#insert\n * @param {Array} collection\n * A collection of series, like `chart.series` or `xAxis.series`.\n * @return {number}\n * The index of the series in the collection.\n */\n Series.prototype.insert = function (collection) {\n var indexOption = this.options.index;\n var i;\n // Insert by index option\n if (isNumber(indexOption)) {\n i = collection.length;\n while (i--) {\n // Loop down until the interted element has higher index\n if (indexOption >=\n pick(collection[i].options.index, collection[i]._i)) {\n collection.splice(i + 1, 0, this);\n break;\n }\n }\n if (i === -1) {\n collection.unshift(this);\n }\n i = i + 1;\n // Or just push it to the end\n }\n else {\n collection.push(this);\n }\n return pick(i, collection.length - 1);\n };\n /**\n * Set the xAxis and yAxis properties of cartesian series, and register\n * the series in the `axis.series` array.\n *\n * @private\n * @function Highcharts.Series#bindAxes\n */\n Series.prototype.bindAxes = function () {\n var series = this,\n seriesOptions = series.options,\n chart = series.chart;\n var axisOptions;\n fireEvent(this, 'bindAxes', null, function () {\n // repeat for xAxis and yAxis\n (series.axisTypes || []).forEach(function (AXIS) {\n var index = 0;\n // loop through the chart's axis objects\n chart[AXIS].forEach(function (axis) {\n axisOptions = axis.options;\n // apply if the series xAxis or yAxis option mathches\n // the number of the axis, or if undefined, use the\n // first axis\n if ((seriesOptions[AXIS] === index &&\n !axisOptions.isInternal) ||\n (typeof seriesOptions[AXIS] !==\n 'undefined' &&\n seriesOptions[AXIS] === axisOptions.id) ||\n (typeof seriesOptions[AXIS] ===\n 'undefined' &&\n axisOptions.index === 0)) {\n // register this series in the axis.series lookup\n series.insert(axis.series);\n // set this series.xAxis or series.yAxis reference\n /**\n * Read only. The unique xAxis object associated\n * with the series.\n *\n * @name Highcharts.Series#xAxis\n * @type {Highcharts.Axis}\n */\n /**\n * Read only. The unique yAxis object associated\n * with the series.\n *\n * @name Highcharts.Series#yAxis\n * @type {Highcharts.Axis}\n */\n series[AXIS] = axis;\n // mark dirty for redraw\n axis.isDirty = true;\n }\n if (!axisOptions.isInternal) {\n index++;\n }\n });\n // The series needs an X and an Y axis\n if (!series[AXIS] &&\n series.optionalAxis !== AXIS) {\n error(18, true, chart);\n }\n });\n });\n fireEvent(this, 'afterBindAxes');\n };\n /**\n * For simple series types like line and column, the data values are\n * held in arrays like xData and yData for quick lookup to find extremes\n * and more. For multidimensional series like bubble and map, this can\n * be extended with arrays like zData and valueData by adding to the\n * `series.parallelArrays` array.\n *\n * @private\n * @function Highcharts.Series#updateParallelArrays\n */\n Series.prototype.updateParallelArrays = function (point, i) {\n var series = point.series,\n args = arguments,\n fn = isNumber(i) ?\n // Insert the value in the given position\n function (key) {\n var val = key === 'y' && series.toYData ?\n series.toYData(point) :\n point[key];\n series[key + 'Data'][i] = val;\n } :\n // Apply the method specified in i with the following\n // arguments as arguments\n function (key) {\n Array.prototype[i].apply(series[key + 'Data'], Array.prototype.slice.call(args, 2));\n };\n series.parallelArrays.forEach(fn);\n };\n /**\n * Define hasData functions for series. These return true if there\n * are data points on this series within the plot area.\n *\n * @private\n * @function Highcharts.Series#hasData\n */\n Series.prototype.hasData = function () {\n return ((this.visible &&\n typeof this.dataMax !== 'undefined' &&\n typeof this.dataMin !== 'undefined') || ( // #3703\n this.visible &&\n this.yData &&\n this.yData.length > 0) // #9758\n );\n };\n /**\n * Return an auto incremented x value based on the pointStart and\n * pointInterval options. This is only used if an x value is not given\n * for the point that calls autoIncrement.\n *\n * @private\n * @function Highcharts.Series#autoIncrement\n */\n Series.prototype.autoIncrement = function (x) {\n var options = this.options,\n pointIntervalUnit = options.pointIntervalUnit,\n relativeXValue = options.relativeXValue,\n time = this.chart.time;\n var xIncrement = this.xIncrement,\n date,\n pointInterval;\n xIncrement = pick(xIncrement, options.pointStart, 0);\n this.pointInterval = pointInterval = pick(this.pointInterval, options.pointInterval, 1);\n if (relativeXValue && isNumber(x)) {\n pointInterval *= x;\n }\n // Added code for pointInterval strings\n if (pointIntervalUnit) {\n date = new time.Date(xIncrement);\n if (pointIntervalUnit === 'day') {\n time.set('Date', date, time.get('Date', date) + pointInterval);\n }\n else if (pointIntervalUnit === 'month') {\n time.set('Month', date, time.get('Month', date) + pointInterval);\n }\n else if (pointIntervalUnit === 'year') {\n time.set('FullYear', date, time.get('FullYear', date) + pointInterval);\n }\n pointInterval = date.getTime() - xIncrement;\n }\n if (relativeXValue && isNumber(x)) {\n return xIncrement + pointInterval;\n }\n this.xIncrement = xIncrement + pointInterval;\n return xIncrement;\n };\n /**\n * Internal function to set properties for series if data sorting is\n * enabled.\n *\n * @private\n * @function Highcharts.Series#setDataSortingOptions\n */\n Series.prototype.setDataSortingOptions = function () {\n var options = this.options;\n extend(this, {\n requireSorting: false,\n sorted: false,\n enabledDataSorting: true,\n allowDG: false\n });\n // To allow unsorted data for column series.\n if (!defined(options.pointRange)) {\n options.pointRange = 1;\n }\n };\n /**\n * Set the series options by merging from the options tree. Called\n * internally on initializing and updating series. This function will\n * not redraw the series. For API usage, use {@link Series#update}.\n * @private\n * @function Highcharts.Series#setOptions\n * @param {Highcharts.SeriesOptionsType} itemOptions\n * The series options.\n * @emits Highcharts.Series#event:afterSetOptions\n */\n Series.prototype.setOptions = function (itemOptions) {\n var chart = this.chart,\n chartOptions = chart.options,\n plotOptions = chartOptions.plotOptions,\n userOptions = chart.userOptions || {},\n seriesUserOptions = merge(itemOptions),\n styledMode = chart.styledMode,\n e = {\n plotOptions: plotOptions,\n userOptions: seriesUserOptions\n };\n var zone;\n fireEvent(this, 'setOptions', e);\n // These may be modified by the event\n var typeOptions = e.plotOptions[this.type],\n userPlotOptions = (userOptions.plotOptions || {});\n // use copy to prevent undetected changes (#9762)\n /**\n * Contains series options by the user without defaults.\n * @name Highcharts.Series#userOptions\n * @type {Highcharts.SeriesOptionsType}\n */\n this.userOptions = e.userOptions;\n var options = merge(typeOptions,\n plotOptions.series, \n // #3881, chart instance plotOptions[type] should trump\n // plotOptions.series\n userOptions.plotOptions &&\n userOptions.plotOptions[this.type],\n seriesUserOptions);\n // The tooltip options are merged between global and series specific\n // options. Importance order asscendingly:\n // globals: (1)tooltip, (2)plotOptions.series,\n // (3)plotOptions[this.type]\n // init userOptions with possible later updates: 4-6 like 1-3 and\n // (7)this series options\n this.tooltipOptions = merge(defaultOptions.tooltip, // 1\n defaultOptions.plotOptions.series &&\n defaultOptions.plotOptions.series.tooltip, // 2\n defaultOptions.plotOptions[this.type].tooltip, // 3\n chartOptions.tooltip.userOptions, // 4\n plotOptions.series &&\n plotOptions.series.tooltip, // 5\n plotOptions[this.type].tooltip, // 6\n seriesUserOptions.tooltip // 7\n );\n // When shared tooltip, stickyTracking is true by default,\n // unless user says otherwise.\n this.stickyTracking = pick(seriesUserOptions.stickyTracking, userPlotOptions[this.type] &&\n userPlotOptions[this.type].stickyTracking, userPlotOptions.series && userPlotOptions.series.stickyTracking, (this.tooltipOptions.shared && !this.noSharedTooltip ?\n true :\n options.stickyTracking));\n // Delete marker object if not allowed (#1125)\n if (typeOptions.marker === null) {\n delete options.marker;\n }\n // Handle color zones\n this.zoneAxis = options.zoneAxis;\n var zones = this.zones = (options.zones || []).slice();\n if ((options.negativeColor || options.negativeFillColor) &&\n !options.zones) {\n zone = {\n value: options[this.zoneAxis + 'Threshold'] ||\n options.threshold ||\n 0,\n className: 'highcharts-negative'\n };\n if (!styledMode) {\n zone.color = options.negativeColor;\n zone.fillColor = options.negativeFillColor;\n }\n zones.push(zone);\n }\n if (zones.length) { // Push one extra zone for the rest\n if (defined(zones[zones.length - 1].value)) {\n zones.push(styledMode ? {} : {\n color: this.color,\n fillColor: this.fillColor\n });\n }\n }\n fireEvent(this, 'afterSetOptions', { options: options });\n return options;\n };\n /**\n * Return series name in \"Series {Number}\" format or the one defined by\n * a user. This method can be simply overridden as series name format\n * can vary (e.g. technical indicators).\n *\n * @function Highcharts.Series#getName\n *\n * @return {string}\n * The series name.\n */\n Series.prototype.getName = function () {\n // #4119\n return pick(this.options.name, 'Series ' + (this.index + 1));\n };\n /**\n * @private\n * @function Highcharts.Series#getCyclic\n */\n Series.prototype.getCyclic = function (prop, value, defaults) {\n var chart = this.chart, userOptions = this.userOptions, indexName = prop + 'Index', counterName = prop + 'Counter', len = defaults ? defaults.length : pick(chart.options.chart[prop + 'Count'], chart[prop + 'Count']);\n var i,\n setting;\n if (!value) {\n // Pick up either the colorIndex option, or the _colorIndex\n // after Series.update()\n setting = pick(userOptions[indexName], userOptions['_' + indexName]);\n if (defined(setting)) { // after Series.update()\n i = setting;\n }\n else {\n // #6138\n if (!chart.series.length) {\n chart[counterName] = 0;\n }\n userOptions['_' + indexName] = i =\n chart[counterName] % len;\n chart[counterName] += 1;\n }\n if (defaults) {\n value = defaults[i];\n }\n }\n // Set the colorIndex\n if (typeof i !== 'undefined') {\n this[indexName] = i;\n }\n this[prop] = value;\n };\n /**\n * Get the series' color based on either the options or pulled from\n * global options.\n *\n * @private\n * @function Highcharts.Series#getColor\n */\n Series.prototype.getColor = function () {\n if (this.chart.styledMode) {\n this.getCyclic('color');\n }\n else if (this.options.colorByPoint) {\n this.color = \"#cccccc\" /* Palette.neutralColor20 */;\n }\n else {\n this.getCyclic('color', this.options.color ||\n defaultOptions.plotOptions[this.type].color, this.chart.options.colors);\n }\n };\n /**\n * Get all points' instances created for this series.\n *\n * @private\n * @function Highcharts.Series#getPointsCollection\n */\n Series.prototype.getPointsCollection = function () {\n return (this.hasGroupedData ? this.points : this.data) || [];\n };\n /**\n * Get the series' symbol based on either the options or pulled from\n * global options.\n *\n * @private\n * @function Highcharts.Series#getSymbol\n */\n Series.prototype.getSymbol = function () {\n var seriesMarkerOption = this.options.marker;\n this.getCyclic('symbol', seriesMarkerOption.symbol, this.chart.options.symbols);\n };\n /**\n * Finds the index of an existing point that matches the given point\n * options.\n *\n * @private\n * @function Highcharts.Series#findPointIndex\n * @param {Highcharts.PointOptionsObject} optionsObject\n * The options of the point.\n * @param {number} fromIndex\n * The index to start searching from, used for optimizing series with\n * required sorting.\n * @return {number|undefined}\n * Returns the index of a matching point, or undefined if no match is found.\n */\n Series.prototype.findPointIndex = function (optionsObject, fromIndex) {\n var id = optionsObject.id,\n x = optionsObject.x,\n oldData = this.points,\n dataSorting = this.options.dataSorting;\n var matchingPoint,\n matchedById,\n pointIndex;\n if (id) {\n var item = this.chart.get(id);\n if (item instanceof Point) {\n matchingPoint = item;\n }\n }\n else if (this.linkedParent ||\n this.enabledDataSorting ||\n this.options.relativeXValue) {\n var matcher = function (oldPoint) { return !oldPoint.touched &&\n oldPoint.index === optionsObject.index; };\n if (dataSorting && dataSorting.matchByName) {\n matcher = function (oldPoint) { return !oldPoint.touched &&\n oldPoint.name === optionsObject.name; };\n }\n else if (this.options.relativeXValue) {\n matcher = function (oldPoint) { return !oldPoint.touched &&\n oldPoint.options.x === optionsObject.x; };\n }\n matchingPoint = find(oldData, matcher);\n // Add unmatched point as a new point\n if (!matchingPoint) {\n return void 0;\n }\n }\n if (matchingPoint) {\n pointIndex = matchingPoint && matchingPoint.index;\n if (typeof pointIndex !== 'undefined') {\n matchedById = true;\n }\n }\n // Search for the same X in the existing data set\n if (typeof pointIndex === 'undefined' && isNumber(x)) {\n pointIndex = this.xData.indexOf(x, fromIndex);\n }\n // Reduce pointIndex if data is cropped\n if (pointIndex !== -1 &&\n typeof pointIndex !== 'undefined' &&\n this.cropped) {\n pointIndex = (pointIndex >= this.cropStart) ?\n pointIndex - this.cropStart : pointIndex;\n }\n if (!matchedById &&\n isNumber(pointIndex) &&\n oldData[pointIndex] && oldData[pointIndex].touched) {\n pointIndex = void 0;\n }\n return pointIndex;\n };\n /**\n * Internal function called from setData. If the point count is the same\n * as it was, or if there are overlapping X values, just run\n * Point.update which is cheaper, allows animation, and keeps references\n * to points. This also allows adding or removing points if the X-es\n * don't match.\n *\n * @private\n * @function Highcharts.Series#updateData\n */\n Series.prototype.updateData = function (data, animation) {\n var options = this.options,\n dataSorting = options.dataSorting,\n oldData = this.points,\n pointsToAdd = [],\n requireSorting = this.requireSorting,\n equalLength = data.length === oldData.length;\n var hasUpdatedByKey,\n i,\n point,\n lastIndex,\n succeeded = true;\n this.xIncrement = null;\n // Iterate the new data\n data.forEach(function (pointOptions, i) {\n var optionsObject = (defined(pointOptions) &&\n this.pointClass.prototype.optionsToObject.call({ series: this },\n pointOptions)) || {};\n var pointIndex;\n // Get the x of the new data point\n var x = optionsObject.x,\n id = optionsObject.id;\n if (id || isNumber(x)) {\n pointIndex = this.findPointIndex(optionsObject, lastIndex);\n // Matching X not found\n // or used already due to ununique x values (#8995),\n // add point (but later)\n if (pointIndex === -1 ||\n typeof pointIndex === 'undefined') {\n pointsToAdd.push(pointOptions);\n // Matching X found, update\n }\n else if (oldData[pointIndex] &&\n pointOptions !== options.data[pointIndex]) {\n oldData[pointIndex].update(pointOptions, false, null, false);\n // Mark it touched, below we will remove all points that\n // are not touched.\n oldData[pointIndex].touched = true;\n // Speed optimize by only searching after last known\n // index. Performs ~20% bettor on large data sets.\n if (requireSorting) {\n lastIndex = pointIndex + 1;\n }\n // Point exists, no changes, don't remove it\n }\n else if (oldData[pointIndex]) {\n oldData[pointIndex].touched = true;\n }\n // If the length is equal and some of the nodes had a\n // match in the same position, we don't want to remove\n // non-matches.\n if (!equalLength ||\n i !== pointIndex ||\n (dataSorting && dataSorting.enabled) ||\n this.hasDerivedData) {\n hasUpdatedByKey = true;\n }\n }\n else {\n // Gather all points that are not matched\n pointsToAdd.push(pointOptions);\n }\n }, this);\n // Remove points that don't exist in the updated data set\n if (hasUpdatedByKey) {\n i = oldData.length;\n while (i--) {\n point = oldData[i];\n if (point && !point.touched && point.remove) {\n point.remove(false, animation);\n }\n }\n // If we did not find keys (ids or x-values), and the length is the\n // same, update one-to-one\n }\n else if (equalLength && (!dataSorting || !dataSorting.enabled)) {\n data.forEach(function (point, i) {\n // .update doesn't exist on a linked, hidden series (#3709)\n // (#10187)\n if (point !== oldData[i].y && (oldData[i].update)) {\n oldData[i].update(point, false, null, false);\n }\n });\n // Don't add new points since those configs are used above\n pointsToAdd.length = 0;\n // Did not succeed in updating data\n }\n else {\n succeeded = false;\n }\n oldData.forEach(function (point) {\n if (point) {\n point.touched = false;\n }\n });\n if (!succeeded) {\n return false;\n }\n // Add new points\n pointsToAdd.forEach(function (point) {\n this.addPoint(point, false, null, null, false);\n }, this);\n if (this.xIncrement === null &&\n this.xData &&\n this.xData.length) {\n this.xIncrement = arrayMax(this.xData);\n this.autoIncrement();\n }\n return true;\n };\n /**\n * Apply a new set of data to the series and optionally redraw it. The\n * new data array is passed by reference (except in case of\n * `updatePoints`), and may later be mutated when updating the chart\n * data.\n *\n * Note the difference in behaviour when setting the same amount of\n * points, or a different amount of points, as handled by the\n * `updatePoints` parameter.\n *\n * @sample highcharts/members/series-setdata/\n * Set new data from a button\n * @sample highcharts/members/series-setdata-pie/\n * Set data in a pie\n * @sample stock/members/series-setdata/\n * Set new data in Highcharts Stock\n * @sample maps/members/series-setdata/\n * Set new data in Highmaps\n *\n * @function Highcharts.Series#setData\n *\n * @param {Array} data\n * Takes an array of data in the same format as described under\n * `series.{type}.data` for the given series type, for example a\n * line series would take data in the form described under\n * [series.line.data](https://api.highcharts.com/highcharts/series.line.data).\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the series is altered. If\n * doing more operations on the chart, it is a good idea to set\n * redraw to false and call {@link Chart#redraw} after.\n *\n * @param {boolean|Partial} [animation]\n * When the updated data is the same length as the existing data,\n * points will be updated by default, and animation visualizes\n * how the points are changed. Set false to disable animation, or\n * a configuration object to set duration or easing.\n *\n * @param {boolean} [updatePoints=true]\n * When this is true, points will be updated instead of replaced\n * whenever possible. This occurs a) when the updated data is the\n * same length as the existing data, b) when points are matched\n * by their id's, or c) when points can be matched by X values.\n * This allows updating with animation and performs better. In\n * this case, the original array is not passed by reference. Set\n * `false` to prevent.\n */\n Series.prototype.setData = function (data, redraw, animation, updatePoints) {\n if (redraw === void 0) { redraw = true; }\n var series = this,\n oldData = series.points,\n oldDataLength = (oldData && oldData.length) || 0,\n options = series.options,\n chart = series.chart,\n dataSorting = options.dataSorting,\n xAxis = series.xAxis,\n turboThreshold = options.turboThreshold,\n xData = this.xData,\n yData = this.yData,\n pointArrayMap = series.pointArrayMap,\n valueCount = pointArrayMap && pointArrayMap.length,\n keys = options.keys;\n var i,\n pt,\n updatedData,\n indexOfX = 0,\n indexOfY = 1,\n firstPoint = null,\n copiedData;\n if (!chart.options.chart.allowMutatingData) { // #4259\n // Remove old reference\n if (options.data) {\n delete series.options.data;\n }\n if (series.userOptions.data) {\n delete series.userOptions.data;\n }\n copiedData = merge(true, data);\n }\n data = copiedData || data || [];\n var dataLength = data.length;\n if (dataSorting && dataSorting.enabled) {\n data = this.sortData(data);\n }\n // First try to run Point.update which is cheaper, allows animation,\n // and keeps references to points.\n if (chart.options.chart.allowMutatingData &&\n updatePoints !== false &&\n dataLength &&\n oldDataLength &&\n !series.cropped &&\n !series.hasGroupedData &&\n series.visible &&\n // Soft updating has no benefit in boost, and causes JS error\n // (#8355)\n !series.boosted) {\n updatedData = this.updateData(data, animation);\n }\n if (!updatedData) {\n // Reset properties\n series.xIncrement = null;\n series.colorCounter = 0; // for series with colorByPoint (#1547)\n // Update parallel arrays\n this.parallelArrays.forEach(function (key) {\n series[key + 'Data'].length = 0;\n });\n // In turbo mode, only one- or twodimensional arrays of numbers\n // are allowed. The first value is tested, and we assume that\n // all the rest are defined the same way. Although the 'for'\n // loops are similar, they are repeated inside each if-else\n // conditional for max performance.\n if (turboThreshold && dataLength > turboThreshold) {\n firstPoint = series.getFirstValidPoint(data);\n if (isNumber(firstPoint)) { // assume all points are numbers\n for (i = 0; i < dataLength; i++) {\n xData[i] = this.autoIncrement();\n yData[i] = data[i];\n }\n // Assume all points are arrays when first point is\n }\n else if (isArray(firstPoint)) {\n if (valueCount) { // [x, low, high] or [x, o, h, l, c]\n if (firstPoint.length === valueCount) {\n for (i = 0; i < dataLength; i++) {\n xData[i] = this.autoIncrement();\n yData[i] = data[i];\n }\n }\n else {\n for (i = 0; i < dataLength; i++) {\n pt = data[i];\n xData[i] = pt[0];\n yData[i] =\n pt.slice(1, valueCount + 1);\n }\n }\n }\n else { // [x, y]\n if (keys) {\n indexOfX = keys.indexOf('x');\n indexOfY = keys.indexOf('y');\n indexOfX = indexOfX >= 0 ? indexOfX : 0;\n indexOfY = indexOfY >= 0 ? indexOfY : 1;\n }\n if (firstPoint.length === 1) {\n indexOfY = 0;\n }\n if (indexOfX === indexOfY) {\n for (i = 0; i < dataLength; i++) {\n xData[i] = this.autoIncrement();\n yData[i] = data[i][indexOfY];\n }\n }\n else {\n for (i = 0; i < dataLength; i++) {\n pt = data[i];\n xData[i] = pt[indexOfX];\n yData[i] = pt[indexOfY];\n }\n }\n }\n }\n else {\n // Highcharts expects configs to be numbers or arrays in\n // turbo mode\n error(12, false, chart);\n }\n }\n else {\n for (i = 0; i < dataLength; i++) {\n // stray commas in oldIE:\n if (typeof data[i] !== 'undefined') {\n pt = { series: series };\n series.pointClass.prototype.applyOptions.apply(pt, [data[i]]);\n series.updateParallelArrays(pt, i);\n }\n }\n }\n // Forgetting to cast strings to numbers is a common caveat when\n // handling CSV or JSON\n if (yData && isString(yData[0])) {\n error(14, true, chart);\n }\n series.data = [];\n series.options.data = series.userOptions.data = data;\n // destroy old points\n i = oldDataLength;\n while (i--) {\n if (oldData[i] && (oldData[i].destroy)) {\n oldData[i].destroy();\n }\n }\n // reset minRange (#878)\n if (xAxis) {\n xAxis.minRange = xAxis.userMinRange;\n }\n // redraw\n series.isDirty = chart.isDirtyBox = true;\n series.isDirtyData = !!oldData;\n animation = false;\n }\n // Typically for pie series, points need to be processed and\n // generated prior to rendering the legend\n if (options.legendType === 'point') {\n this.processData();\n this.generatePoints();\n }\n if (redraw) {\n chart.redraw(animation);\n }\n };\n /**\n * Internal function to sort series data\n *\n * @private\n * @function Highcharts.Series#sortData\n * @param {Array} data\n * Force data grouping.\n */\n Series.prototype.sortData = function (data) {\n var series = this,\n options = series.options,\n dataSorting = options.dataSorting,\n sortKey = dataSorting.sortKey || 'y',\n getPointOptionsObject = function (series,\n pointOptions) {\n return (defined(pointOptions) &&\n series.pointClass.prototype.optionsToObject.call({\n series: series\n },\n pointOptions)) || {};\n };\n data.forEach(function (pointOptions, i) {\n data[i] = getPointOptionsObject(series, pointOptions);\n data[i].index = i;\n }, this);\n // Sorting\n var sortedData = data.concat().sort(function (a,\n b) {\n var aValue = getNestedProperty(sortKey,\n a);\n var bValue = getNestedProperty(sortKey,\n b);\n return bValue < aValue ? -1 : bValue > aValue ? 1 : 0;\n });\n // Set x value depending on the position in the array\n sortedData.forEach(function (point, i) {\n point.x = i;\n }, this);\n // Set the same x for linked series points if they don't have their\n // own sorting\n if (series.linkedSeries) {\n series.linkedSeries.forEach(function (linkedSeries) {\n var options = linkedSeries.options,\n seriesData = options.data;\n if ((!options.dataSorting ||\n !options.dataSorting.enabled) &&\n seriesData) {\n seriesData.forEach(function (pointOptions, i) {\n seriesData[i] = getPointOptionsObject(linkedSeries, pointOptions);\n if (data[i]) {\n seriesData[i].x = data[i].x;\n seriesData[i].index = i;\n }\n });\n linkedSeries.setData(seriesData, false);\n }\n });\n }\n return data;\n };\n /**\n * Internal function to process the data by cropping away unused data\n * points if the series is longer than the crop threshold. This saves\n * computing time for large series.\n *\n * @private\n * @function Highcharts.Series#getProcessedData\n * @param {boolean} [forceExtremesFromAll]\n * Force getting extremes of a total series data range.\n */\n Series.prototype.getProcessedData = function (forceExtremesFromAll) {\n var series = this,\n xAxis = series.xAxis,\n options = series.options,\n cropThreshold = options.cropThreshold,\n getExtremesFromAll = forceExtremesFromAll ||\n series.getExtremesFromAll ||\n options.getExtremesFromAll, // #4599\n isCartesian = series.isCartesian,\n val2lin = xAxis && xAxis.val2lin,\n isLog = !!(xAxis && xAxis.logarithmic);\n var croppedData,\n cropped,\n cropStart = 0,\n distance,\n closestPointRange,\n i, // loop variable\n xExtremes,\n min,\n max, \n // copied during slice operation:\n processedXData = series.xData,\n processedYData = series.yData,\n throwOnUnsorted = series.requireSorting,\n updatingNames = false;\n var dataLength = processedXData.length;\n if (xAxis) {\n // corrected for log axis (#3053)\n xExtremes = xAxis.getExtremes();\n min = xExtremes.min;\n max = xExtremes.max;\n updatingNames = !!(xAxis.categories && !xAxis.names.length);\n }\n // optionally filter out points outside the plot area\n if (isCartesian &&\n series.sorted &&\n !getExtremesFromAll &&\n (!cropThreshold ||\n dataLength > cropThreshold ||\n series.forceCrop)) {\n // it's outside current extremes\n if (processedXData[dataLength - 1] < min ||\n processedXData[0] > max) {\n processedXData = [];\n processedYData = [];\n // only crop if it's actually spilling out\n }\n else if (series.yData && (processedXData[0] < min ||\n processedXData[dataLength - 1] > max)) {\n croppedData = this.cropData(series.xData, series.yData, min, max);\n processedXData = croppedData.xData;\n processedYData = croppedData.yData;\n cropStart = croppedData.start;\n cropped = true;\n }\n }\n // Find the closest distance between processed points\n i = processedXData.length || 1;\n while (--i) {\n distance = (isLog ?\n (val2lin(processedXData[i]) -\n val2lin(processedXData[i - 1])) :\n (processedXData[i] -\n processedXData[i - 1]));\n if (distance > 0 &&\n (typeof closestPointRange === 'undefined' ||\n distance < closestPointRange)) {\n closestPointRange = distance;\n // Unsorted data is not supported by the line tooltip, as well\n // as data grouping and navigation in Stock charts (#725) and\n // width calculation of columns (#1900).\n // Avoid warning during the premature processing pass in\n // updateNames (#16104).\n }\n else if (distance < 0 && throwOnUnsorted && !updatingNames) {\n error(15, false, series.chart);\n throwOnUnsorted = false; // Only once\n }\n }\n return {\n xData: processedXData,\n yData: processedYData,\n cropped: cropped,\n cropStart: cropStart,\n closestPointRange: closestPointRange\n };\n };\n /**\n * Internal function to apply processed data.\n * In Highcharts Stock, this function is extended to provide data grouping.\n *\n * @private\n * @function Highcharts.Series#processData\n * @param {boolean} [force]\n * Force data grouping.\n */\n Series.prototype.processData = function (force) {\n var series = this,\n xAxis = series.xAxis;\n // If the series data or axes haven't changed, don't go through\n // this. Return false to pass the message on to override methods\n // like in data grouping.\n if (series.isCartesian &&\n !series.isDirty &&\n !xAxis.isDirty &&\n !series.yAxis.isDirty &&\n !force) {\n return false;\n }\n var processedData = series.getProcessedData();\n // Record the properties\n series.cropped = processedData.cropped; // undefined or true\n series.cropStart = processedData.cropStart;\n series.processedXData = processedData.xData;\n series.processedYData = processedData.yData;\n series.closestPointRange = (series.basePointRange = processedData.closestPointRange);\n fireEvent(series, 'afterProcessData');\n };\n /**\n * Iterate over xData and crop values between min and max. Returns\n * object containing crop start/end cropped xData with corresponding\n * part of yData, dataMin and dataMax within the cropped range.\n *\n * @private\n * @function Highcharts.Series#cropData\n */\n Series.prototype.cropData = function (xData, yData, min, max, cropShoulder) {\n var dataLength = xData.length;\n var i,\n j,\n cropStart = 0,\n cropEnd = dataLength;\n // line-type series need one point outside\n cropShoulder = pick(cropShoulder, this.cropShoulder);\n // iterate up to find slice start\n for (i = 0; i < dataLength; i++) {\n if (xData[i] >= min) {\n cropStart = Math.max(0, i - cropShoulder);\n break;\n }\n }\n // proceed to find slice end\n for (j = i; j < dataLength; j++) {\n if (xData[j] > max) {\n cropEnd = j + cropShoulder;\n break;\n }\n }\n return {\n xData: xData.slice(cropStart, cropEnd),\n yData: yData.slice(cropStart, cropEnd),\n start: cropStart,\n end: cropEnd\n };\n };\n /**\n * Generate the data point after the data has been processed by cropping\n * away unused points and optionally grouped in Highcharts Stock.\n *\n * @private\n * @function Highcharts.Series#generatePoints\n */\n Series.prototype.generatePoints = function () {\n var series = this,\n options = series.options,\n dataOptions = (series.processedData || options.data),\n processedXData = series.processedXData,\n processedYData = series.processedYData,\n PointClass = series.pointClass,\n processedDataLength = processedXData.length,\n cropStart = series.cropStart || 0,\n hasGroupedData = series.hasGroupedData,\n keys = options.keys,\n points = [],\n groupCropStartIndex = (options.dataGrouping &&\n options.dataGrouping.groupAll ?\n cropStart :\n 0);\n var dataLength,\n cursor,\n point,\n i,\n data = series.data;\n if (!data && !hasGroupedData) {\n var arr = [];\n arr.length = dataOptions.length;\n data = series.data = arr;\n }\n if (keys && hasGroupedData) {\n // grouped data has already applied keys (#6590)\n series.options.keys = false;\n }\n for (i = 0; i < processedDataLength; i++) {\n cursor = cropStart + i;\n if (!hasGroupedData) {\n point = data[cursor];\n // #970:\n if (!point &&\n typeof dataOptions[cursor] !== 'undefined') {\n data[cursor] = point = (new PointClass()).init(series, dataOptions[cursor], processedXData[i]);\n }\n }\n else {\n // splat the y data in case of ohlc data array\n point = (new PointClass()).init(series, [processedXData[i]].concat(splat(processedYData[i])));\n point.dataGroup = series.groupMap[groupCropStartIndex + i];\n if (point.dataGroup.options) {\n point.options = point.dataGroup.options;\n extend(point, point.dataGroup.options);\n // Collision of props and options (#9770)\n delete point.dataLabels;\n }\n }\n if (point) { // #6279\n /**\n * Contains the point's index in the `Series.points` array.\n *\n * @name Highcharts.Point#index\n * @type {number}\n * @readonly\n */\n // For faster access in Point.update\n point.index = hasGroupedData ?\n (groupCropStartIndex + i) : cursor;\n points[i] = point;\n }\n }\n // restore keys options (#6590)\n series.options.keys = keys;\n // Hide cropped-away points - this only runs when the number of\n // points is above cropThreshold, or when swithching view from\n // non-grouped data to grouped data (#637)\n if (data &&\n (processedDataLength !== (dataLength = data.length) ||\n hasGroupedData)) {\n for (i = 0; i < dataLength; i++) {\n // when has grouped data, clear all points\n if (i === cropStart && !hasGroupedData) {\n i += processedDataLength;\n }\n if (data[i]) {\n data[i].destroyElements();\n data[i].plotX = void 0; // #1003\n }\n }\n }\n /**\n * Read only. An array containing those values converted to points.\n * In case the series data length exceeds the `cropThreshold`, or if\n * the data is grouped, `series.data` doesn't contain all the\n * points. Also, in case a series is hidden, the `data` array may be\n * empty. To access raw values, `series.options.data` will always be\n * up to date. `Series.data` only contains the points that have been\n * created on demand. To modify the data, use\n * {@link Highcharts.Series#setData} or\n * {@link Highcharts.Point#update}.\n *\n * @see Series.points\n *\n * @name Highcharts.Series#data\n * @type {Array}\n */\n series.data = data;\n /**\n * An array containing all currently visible point objects. In case\n * of cropping, the cropped-away points are not part of this array.\n * The `series.points` array starts at `series.cropStart` compared\n * to `series.data` and `series.options.data`. If however the series\n * data is grouped, these can't be correlated one to one. To modify\n * the data, use {@link Highcharts.Series#setData} or\n * {@link Highcharts.Point#update}.\n *\n * @name Highcharts.Series#points\n * @type {Array}\n */\n series.points = points;\n fireEvent(this, 'afterGeneratePoints');\n };\n /**\n * Get current X extremes for the visible data.\n *\n * @private\n * @function Highcharts.Series#getXExtremes\n * @param {Array} xData\n * The data to inspect. Defaults to the current data within the visible\n * range.\n */\n Series.prototype.getXExtremes = function (xData) {\n return {\n min: arrayMin(xData),\n max: arrayMax(xData)\n };\n };\n /**\n * Calculate Y extremes for the visible data. The result is returned\n * as an object with `dataMin` and `dataMax` properties.\n *\n * @private\n * @function Highcharts.Series#getExtremes\n * @param {Array} [yData]\n * The data to inspect. Defaults to the current data within the visible\n * range.\n * @param {boolean} [forceExtremesFromAll]\n * Force getting extremes of a total series data range.\n */\n Series.prototype.getExtremes = function (yData, forceExtremesFromAll) {\n var xAxis = this.xAxis,\n yAxis = this.yAxis,\n xData = this.processedXData || this.xData,\n activeYData = [], \n // Handle X outside the viewed area. This does not work with\n // non-sorted data like scatter (#7639).\n shoulder = this.requireSorting ? this.cropShoulder : 0,\n positiveValuesOnly = yAxis ? yAxis.positiveValuesOnly : false;\n // #2117, need to compensate for log X axis\n var xExtremes,\n validValue,\n withinRange,\n x,\n y,\n i,\n j,\n xMin = 0,\n xMax = 0,\n activeCounter = 0;\n yData = yData || this.stackedYData || this.processedYData || [];\n var yDataLength = yData.length;\n if (xAxis) {\n xExtremes = xAxis.getExtremes();\n xMin = xExtremes.min;\n xMax = xExtremes.max;\n }\n for (i = 0; i < yDataLength; i++) {\n x = xData[i];\n y = yData[i];\n // For points within the visible range, including the first\n // point outside the visible range (#7061), consider y extremes.\n validValue = ((isNumber(y) || isArray(y)) &&\n ((y.length || y > 0) || !positiveValuesOnly));\n withinRange = (forceExtremesFromAll ||\n this.getExtremesFromAll ||\n this.options.getExtremesFromAll ||\n this.cropped ||\n !xAxis || // for colorAxis support\n ((xData[i + shoulder] || x) >= xMin &&\n (xData[i - shoulder] || x) <= xMax));\n if (validValue && withinRange) {\n j = y.length;\n if (j) { // array, like ohlc or range data\n while (j--) {\n if (isNumber(y[j])) { // #7380, #11513\n activeYData[activeCounter++] = y[j];\n }\n }\n }\n else {\n activeYData[activeCounter++] = y;\n }\n }\n }\n var dataExtremes = {\n activeYData: activeYData,\n dataMin: arrayMin(activeYData),\n dataMax: arrayMax(activeYData)\n };\n fireEvent(this, 'afterGetExtremes', { dataExtremes: dataExtremes });\n return dataExtremes;\n };\n /**\n * Set the current data extremes as `dataMin` and `dataMax` on the\n * Series item. Use this only when the series properties should be\n * updated.\n *\n * @private\n * @function Highcharts.Series#applyExtremes\n */\n Series.prototype.applyExtremes = function () {\n var dataExtremes = this.getExtremes();\n /**\n * Contains the minimum value of the series' data point. Some series\n * types like `networkgraph` do not support this property as they\n * lack a `y`-value.\n * @name Highcharts.Series#dataMin\n * @type {number|undefined}\n * @readonly\n */\n this.dataMin = dataExtremes.dataMin;\n /**\n * Contains the maximum value of the series' data point. Some series\n * types like `networkgraph` do not support this property as they\n * lack a `y`-value.\n * @name Highcharts.Series#dataMax\n * @type {number|undefined}\n * @readonly\n */\n this.dataMax = dataExtremes.dataMax;\n return dataExtremes;\n };\n /**\n * Find and return the first non null point in the data\n *\n * @private\n * @function Highcharts.Series.getFirstValidPoint\n * @param {Array} data\n * Array of options for points\n */\n Series.prototype.getFirstValidPoint = function (data) {\n var dataLength = data.length;\n var i = 0,\n firstPoint = null;\n while (firstPoint === null && i < dataLength) {\n firstPoint = data[i];\n i++;\n }\n return firstPoint;\n };\n /**\n * Translate data points from raw data values to chart specific\n * positioning data needed later in the `drawPoints` and `drawGraph`\n * functions. This function can be overridden in plugins and custom\n * series type implementations.\n *\n * @function Highcharts.Series#translate\n *\n * @emits Highcharts.Series#events:translate\n */\n Series.prototype.translate = function () {\n if (!this.processedXData) { // hidden series\n this.processData();\n }\n this.generatePoints();\n var series = this,\n options = series.options,\n stacking = options.stacking,\n xAxis = series.xAxis,\n categories = xAxis.categories,\n enabledDataSorting = series.enabledDataSorting,\n yAxis = series.yAxis,\n points = series.points,\n dataLength = points.length,\n pointPlacement = series.pointPlacementToXValue(), // #7860\n dynamicallyPlaced = Boolean(pointPlacement),\n threshold = options.threshold,\n stackThreshold = options.startFromThreshold ? threshold : 0,\n zoneAxis = this.zoneAxis || 'y';\n var i,\n plotX,\n lastPlotX,\n stackIndicator,\n closestPointRangePx = Number.MAX_VALUE;\n /**\n * Plotted coordinates need to be within a limited range. Drawing\n * too far outside the viewport causes various rendering issues\n * (#3201, #3923, #7555).\n * @private\n */\n function limitedRange(val) {\n return clamp(val, -1e5, 1e5);\n }\n // Translate each point\n for (i = 0; i < dataLength; i++) {\n var point = points[i],\n xValue = point.x;\n var pointStack = void 0,\n stackValues = void 0,\n yValue = point.y,\n yBottom = point.low;\n var stack = stacking && yAxis.stacking && yAxis.stacking.stacks[(series.negStacks &&\n yValue <\n (stackThreshold ? 0 : threshold) ?\n '-' :\n '') + series.stackKey];\n if (yAxis.positiveValuesOnly &&\n !yAxis.validatePositiveValue(yValue) ||\n xAxis.positiveValuesOnly &&\n !xAxis.validatePositiveValue(xValue)) {\n point.isNull = true;\n }\n /**\n * The translated X value for the point in terms of pixels. Relative\n * to the X axis position if the series has one, otherwise relative\n * to the plot area. Depending on the series type this value might\n * not be defined.\n * @name Highcharts.Point#plotX\n * @type {number|undefined}\n */\n point.plotX = plotX = correctFloat(// #5236\n // Get the plotX translation\n limitedRange(xAxis.translate(// #3923\n xValue, 0, 0, 0, 1, pointPlacement, this.type === 'flags')) // #3923\n );\n // Calculate the bottom y value for stacked series\n if (stacking &&\n series.visible &&\n stack &&\n stack[xValue]) {\n stackIndicator = series.getStackIndicator(stackIndicator, xValue, series.index);\n if (!point.isNull) {\n pointStack = stack[xValue];\n stackValues =\n pointStack.points[stackIndicator.key];\n }\n }\n if (isArray(stackValues)) {\n yBottom = stackValues[0];\n yValue = stackValues[1];\n if (yBottom === stackThreshold &&\n stackIndicator.key ===\n stack[xValue].base) {\n yBottom = pick((isNumber(threshold) && threshold), yAxis.min);\n }\n // #1200, #1232\n if (yAxis.positiveValuesOnly && yBottom <= 0) {\n yBottom = null;\n }\n point.total = point.stackTotal = pointStack.total;\n point.percentage =\n pointStack.total &&\n (point.y / pointStack.total * 100);\n point.stackY = yValue;\n // Place the stack label\n // in case of variwide series (where widths of points are\n // different in most cases), stack labels are positioned\n // wrongly, so the call of the setOffset is omited here and\n // labels are correctly positioned later, at the end of the\n // variwide's translate function (#10962)\n if (!series.irregularWidths) {\n pointStack.setOffset(series.pointXOffset || 0, series.barW || 0);\n }\n }\n // Set translated yBottom or remove it\n point.yBottom = defined(yBottom) ?\n limitedRange(yAxis.translate(yBottom, 0, 1, 0, 1)) :\n null;\n // General hook, used for Highcharts Stock compare and cumulative\n if (series.dataModify) {\n yValue = series.dataModify.modifyValue(yValue, i);\n }\n // Set the the plotY value, reset it for redraws\n // #3201\n point.plotY = void 0;\n if (isNumber(yValue)) {\n var translated = yAxis.translate(yValue,\n false,\n true,\n false,\n true);\n if (typeof translated !== 'undefined') {\n /**\n * The translated Y value for the point in terms of pixels.\n * Relative to the Y axis position if the series has one,\n * otherwise relative to the plot area. Depending on the\n * series type this value might not be defined.\n * @name Highcharts.Point#plotY\n * @type {number|undefined}\n */\n point.plotY = limitedRange(translated);\n }\n }\n point.isInside = this.isPointInside(point);\n // Set client related positions for mouse tracking\n point.clientX = dynamicallyPlaced ?\n correctFloat(xAxis.translate(xValue, 0, 0, 0, 1, pointPlacement)) :\n plotX; // #1514, #5383, #5518\n // Negative points. For bubble charts, this means negative z\n // values (#9728)\n point.negative = point[zoneAxis] < (options[zoneAxis + 'Threshold'] ||\n threshold ||\n 0);\n // some API data\n point.category = pick(categories && categories[point.x], point.x);\n // Determine auto enabling of markers (#3635, #5099)\n if (!point.isNull && point.visible !== false) {\n if (typeof lastPlotX !== 'undefined') {\n closestPointRangePx = Math.min(closestPointRangePx, Math.abs(plotX - lastPlotX));\n }\n lastPlotX = plotX;\n }\n // Find point zone\n point.zone = this.zones.length ? point.getZone() : void 0;\n // Animate new points with data sorting\n if (!point.graphic && series.group && enabledDataSorting) {\n point.isNew = true;\n }\n }\n series.closestPointRangePx = closestPointRangePx;\n fireEvent(this, 'afterTranslate');\n };\n /**\n * Return the series points with null points filtered out.\n *\n * @function Highcharts.Series#getValidPoints\n *\n * @param {Array} [points]\n * The points to inspect, defaults to {@link Series.points}.\n *\n * @param {boolean} [insideOnly=false]\n * Whether to inspect only the points that are inside the visible view.\n *\n * @param {boolean} [allowNull=false]\n * Whether to allow null points to pass as valid points.\n *\n * @return {Array}\n * The valid points.\n */\n Series.prototype.getValidPoints = function (points, insideOnly, allowNull) {\n var chart = this.chart;\n // #3916, #5029, #5085\n return (points || this.points || []).filter(function (point) {\n if (insideOnly && !chart.isInsidePlot(point.plotX, point.plotY, { inverted: chart.inverted })) {\n return false;\n }\n return point.visible !== false &&\n (allowNull || !point.isNull);\n });\n };\n /**\n * Get the clipping for the series. Could be called for a series to\n * initiate animating the clip or to set the final clip (only width\n * and x).\n *\n * @private\n * @function Highcharts.Series#getClip\n */\n Series.prototype.getClipBox = function () {\n var _a = this,\n chart = _a.chart,\n xAxis = _a.xAxis,\n yAxis = _a.yAxis;\n // If no axes on the series, use global clipBox\n var seriesBox = merge(chart.clipBox);\n // Otherwise, use clipBox.width which is corrected for plotBorderWidth\n // and clipOffset\n if (xAxis && xAxis.len !== chart.plotSizeX) {\n seriesBox.width = xAxis.len;\n }\n if (yAxis && yAxis.len !== chart.plotSizeY) {\n seriesBox.height = yAxis.len;\n }\n return seriesBox;\n };\n /**\n * Get the shared clip key, creating it if it doesn't exist.\n *\n * @private\n * @function Highcharts.Series#getSharedClipKey\n */\n Series.prototype.getSharedClipKey = function () {\n this.sharedClipKey = (this.options.xAxis || 0) + ',' +\n (this.options.yAxis || 0);\n return this.sharedClipKey;\n };\n /**\n * Set the clipping for the series. For animated series the clip is later\n * modified.\n *\n * @private\n * @function Highcharts.Series#setClip\n */\n Series.prototype.setClip = function () {\n var _a = this,\n chart = _a.chart,\n group = _a.group,\n markerGroup = _a.markerGroup,\n sharedClips = chart.sharedClips,\n renderer = chart.renderer,\n clipBox = this.getClipBox(),\n sharedClipKey = this.getSharedClipKey(); // #4526\n var clipRect = sharedClips[sharedClipKey];\n // If a clipping rectangle for the same set of axes does not exist,\n // create it\n if (!clipRect) {\n sharedClips[sharedClipKey] = clipRect = renderer.clipRect(clipBox);\n // When setting chart size, or when the series is rendered again before\n // starting animating, in compliance to a responsive rule\n }\n else {\n clipRect.animate(clipBox);\n }\n if (group) {\n // When clip is false, reset to no clip after animation\n group.clip(this.options.clip === false ? void 0 : clipRect);\n }\n // Unclip temporary animation clip\n if (markerGroup) {\n markerGroup.clip();\n }\n };\n /**\n * Animate in the series. Called internally twice. First with the `init`\n * parameter set to true, which sets up the initial state of the\n * animation. Then when ready, it is called with the `init` parameter\n * undefined, in order to perform the actual animation.\n *\n * @function Highcharts.Series#animate\n *\n * @param {boolean} [init]\n * Initialize the animation.\n */\n Series.prototype.animate = function (init) {\n var _a = this, chart = _a.chart, group = _a.group, markerGroup = _a.markerGroup, inverted = chart.inverted, animation = animObject(this.options.animation), \n // The key for temporary animation clips\n animationClipKey = [\n this.getSharedClipKey(),\n animation.duration,\n animation.easing,\n animation.defer\n ].join(',');\n var animationClipRect = chart.sharedClips[animationClipKey],\n markerAnimationClipRect = chart.sharedClips[animationClipKey + 'm'];\n // Initialize the animation. Set up the clipping rectangle.\n if (init && group) {\n var clipBox = this.getClipBox();\n // Create temporary animation clips\n if (!animationClipRect) {\n clipBox.width = 0;\n if (inverted) {\n clipBox.x = chart.plotHeight;\n }\n animationClipRect = chart.renderer.clipRect(clipBox);\n chart.sharedClips[animationClipKey] = animationClipRect;\n var markerClipBox = {\n // Include the width of the first marker\n x: inverted ? (chart.plotSizeX || 0) + 99 : -99,\n y: inverted ? -chart.plotLeft : -chart.plotTop,\n width: 99,\n height: inverted ? chart.chartWidth : chart.chartHeight\n };\n markerAnimationClipRect = chart.renderer.clipRect(markerClipBox);\n chart.sharedClips[animationClipKey + 'm'] = markerAnimationClipRect;\n }\n else {\n // When height changes during animation, typically due to\n // responsive settings\n animationClipRect.attr('height', clipBox.height);\n }\n group.clip(animationClipRect);\n if (markerGroup) {\n markerGroup.clip(markerAnimationClipRect);\n }\n // Run the animation\n }\n else if (animationClipRect &&\n // Only first series in this pane\n !animationClipRect.hasClass('highcharts-animating')) {\n var finalBox = this.getClipBox(),\n step_1 = animation.step;\n // Only do this when there are actually markers\n if (markerGroup && markerGroup.element.childNodes.length) {\n // To provide as smooth animation as possible, update the marker\n // group clipping in steps of the main group animation\n animation.step = function (val, fx) {\n if (step_1) {\n step_1.apply(fx, arguments);\n }\n if (markerAnimationClipRect &&\n markerAnimationClipRect.element) {\n markerAnimationClipRect.attr(fx.prop, fx.prop === 'width' ? val + 99 : val);\n }\n };\n }\n animationClipRect\n .addClass('highcharts-animating')\n .animate(finalBox, animation);\n }\n };\n /**\n * This runs after animation to land on the final plot clipping.\n *\n * @private\n * @function Highcharts.Series#afterAnimate\n *\n * @emits Highcharts.Series#event:afterAnimate\n */\n Series.prototype.afterAnimate = function () {\n var _this = this;\n this.setClip();\n // Destroy temporary clip rectangles that are no longer in use\n objectEach(this.chart.sharedClips, function (clip, key, sharedClips) {\n if (clip && !_this.chart.container.querySelector(\"[clip-path=\\\"url(#\".concat(clip.id, \")\\\"]\"))) {\n clip.destroy();\n delete sharedClips[key];\n }\n });\n this.finishedAnimating = true;\n fireEvent(this, 'afterAnimate');\n };\n /**\n * Draw the markers for line-like series types, and columns or other\n * graphical representation for {@link Point} objects for other series\n * types. The resulting element is typically stored as\n * {@link Point.graphic}, and is created on the first call and updated\n * and moved on subsequent calls.\n *\n * @function Highcharts.Series#drawPoints\n */\n Series.prototype.drawPoints = function (points) {\n if (points === void 0) { points = this.points; }\n var series = this,\n chart = series.chart,\n options = series.options,\n seriesMarkerOptions = options.marker,\n markerGroup = (series[series.specialGroup] ||\n series.markerGroup),\n xAxis = series.xAxis,\n globallyEnabled = pick(seriesMarkerOptions.enabled, !xAxis || xAxis.isRadial ? true : null, \n // Use larger or equal as radius is null in bubbles (#6321)\n series.closestPointRangePx >= (seriesMarkerOptions.enabledThreshold *\n seriesMarkerOptions.radius));\n var i,\n point,\n graphic,\n verb,\n pointMarkerOptions,\n hasPointMarker,\n markerAttribs;\n if (seriesMarkerOptions.enabled !== false ||\n series._hasPointMarkers) {\n for (i = 0; i < points.length; i++) {\n point = points[i];\n graphic = point.graphic;\n verb = graphic ? 'animate' : 'attr';\n pointMarkerOptions = point.marker || {};\n hasPointMarker = !!point.marker;\n var shouldDrawMarker = ((globallyEnabled &&\n typeof pointMarkerOptions.enabled === 'undefined') || pointMarkerOptions.enabled) && !point.isNull && point.visible !== false;\n // only draw the point if y is defined\n if (shouldDrawMarker) {\n // Shortcuts\n var symbol = pick(pointMarkerOptions.symbol,\n series.symbol, 'rect');\n markerAttribs = series.markerAttribs(point, (point.selected && 'select'));\n // Set starting position for point sliding animation.\n if (series.enabledDataSorting) {\n point.startXPos = xAxis.reversed ?\n -(markerAttribs.width || 0) :\n xAxis.width;\n }\n var isInside = point.isInside !== false;\n if (graphic) { // update\n // Since the marker group isn't clipped, each\n // individual marker must be toggled\n graphic[isInside ? 'show' : 'hide'](isInside)\n .animate(markerAttribs);\n }\n else if (isInside &&\n ((markerAttribs.width || 0) > 0 || point.hasImage)) {\n /**\n * The graphic representation of the point.\n * Typically this is a simple shape, like a `rect`\n * for column charts or `path` for line markers, but\n * for some complex series types like boxplot or 3D\n * charts, the graphic may be a `g` element\n * containing other shapes. The graphic is generated\n * the first time {@link Series#drawPoints} runs,\n * and updated and moved on subsequent runs.\n *\n * @name Point#graphic\n * @type {SVGElement}\n */\n point.graphic = graphic = chart.renderer\n .symbol(symbol, markerAttribs.x, markerAttribs.y, markerAttribs.width, markerAttribs.height, hasPointMarker ?\n pointMarkerOptions :\n seriesMarkerOptions)\n .add(markerGroup);\n // Sliding animation for new points\n if (series.enabledDataSorting &&\n chart.hasRendered) {\n graphic.attr({\n x: point.startXPos\n });\n verb = 'animate';\n }\n }\n if (graphic && verb === 'animate') { // update\n // Since the marker group isn't clipped, each\n // individual marker must be toggled\n graphic[isInside ? 'show' : 'hide'](isInside)\n .animate(markerAttribs);\n }\n // Presentational attributes\n if (graphic && !chart.styledMode) {\n graphic[verb](series.pointAttribs(point, (point.selected && 'select')));\n }\n if (graphic) {\n graphic.addClass(point.getClassName(), true);\n }\n }\n else if (graphic) {\n point.graphic = graphic.destroy(); // #1269\n }\n }\n }\n };\n /**\n * Get non-presentational attributes for a point. Used internally for\n * both styled mode and classic. Can be overridden for different series\n * types.\n *\n * @see Series#pointAttribs\n *\n * @function Highcharts.Series#markerAttribs\n *\n * @param {Highcharts.Point} point\n * The Point to inspect.\n *\n * @param {string} [state]\n * The state, can be either `hover`, `select` or undefined.\n *\n * @return {Highcharts.SVGAttributes}\n * A hash containing those attributes that are not settable from CSS.\n */\n Series.prototype.markerAttribs = function (point, state) {\n var seriesOptions = this.options,\n seriesMarkerOptions = seriesOptions.marker,\n pointMarkerOptions = point.marker || {},\n symbol = (pointMarkerOptions.symbol ||\n seriesMarkerOptions.symbol);\n var seriesStateOptions,\n pointStateOptions,\n radius = pick(pointMarkerOptions.radius,\n seriesMarkerOptions && seriesMarkerOptions.radius);\n // Handle hover and select states\n if (state) {\n seriesStateOptions = seriesMarkerOptions.states[state];\n pointStateOptions = pointMarkerOptions.states &&\n pointMarkerOptions.states[state];\n radius = pick(pointStateOptions && pointStateOptions.radius, seriesStateOptions && seriesStateOptions.radius, radius && radius + (seriesStateOptions && seriesStateOptions.radiusPlus ||\n 0));\n }\n point.hasImage = symbol && symbol.indexOf('url') === 0;\n if (point.hasImage) {\n radius = 0; // and subsequently width and height is not set\n }\n var attribs = isNumber(radius) ? {\n // Math.floor for #1843:\n x: seriesOptions.crisp ?\n Math.floor(point.plotX - radius) :\n point.plotX - radius,\n y: point.plotY - radius\n } : {};\n if (radius) {\n attribs.width = attribs.height = 2 * radius;\n }\n return attribs;\n };\n /**\n * Internal function to get presentational attributes for each point.\n * Unlike {@link Series#markerAttribs}, this function should return\n * those attributes that can also be set in CSS. In styled mode,\n * `pointAttribs` won't be called.\n *\n * @private\n * @function Highcharts.Series#pointAttribs\n *\n * @param {Highcharts.Point} [point]\n * The point instance to inspect.\n *\n * @param {string} [state]\n * The point state, can be either `hover`, `select` or 'normal'. If\n * undefined, normal state is assumed.\n *\n * @return {Highcharts.SVGAttributes}\n * The presentational attributes to be set on the point.\n */\n Series.prototype.pointAttribs = function (point, state) {\n var seriesMarkerOptions = this.options.marker,\n pointOptions = point && point.options,\n pointMarkerOptions = ((pointOptions && pointOptions.marker) || {}),\n pointColorOption = pointOptions && pointOptions.color,\n pointColor = point && point.color,\n zoneColor = point && point.zone && point.zone.color;\n var seriesStateOptions,\n pointStateOptions,\n color = this.color,\n fill,\n stroke,\n strokeWidth = pick(pointMarkerOptions.lineWidth,\n seriesMarkerOptions.lineWidth),\n opacity = 1;\n color = (pointColorOption ||\n zoneColor ||\n pointColor ||\n color);\n fill = (pointMarkerOptions.fillColor ||\n seriesMarkerOptions.fillColor ||\n color);\n stroke = (pointMarkerOptions.lineColor ||\n seriesMarkerOptions.lineColor ||\n color);\n // Handle hover and select states\n state = state || 'normal';\n if (state) {\n seriesStateOptions = (seriesMarkerOptions.states[state] || {});\n pointStateOptions = (pointMarkerOptions.states &&\n pointMarkerOptions.states[state]) || {};\n strokeWidth = pick(pointStateOptions.lineWidth, seriesStateOptions.lineWidth, strokeWidth + pick(pointStateOptions.lineWidthPlus, seriesStateOptions.lineWidthPlus, 0));\n fill = (pointStateOptions.fillColor ||\n seriesStateOptions.fillColor ||\n fill);\n stroke = (pointStateOptions.lineColor ||\n seriesStateOptions.lineColor ||\n stroke);\n opacity = pick(pointStateOptions.opacity, seriesStateOptions.opacity, opacity);\n }\n return {\n 'stroke': stroke,\n 'stroke-width': strokeWidth,\n 'fill': fill,\n 'opacity': opacity\n };\n };\n /**\n * Clear DOM objects and free up memory.\n *\n * @private\n * @function Highcharts.Series#destroy\n *\n * @emits Highcharts.Series#event:destroy\n */\n Series.prototype.destroy = function (keepEventsForUpdate) {\n var series = this,\n chart = series.chart,\n issue134 = /AppleWebKit\\/533/.test(win.navigator.userAgent),\n data = series.data || [];\n var destroy,\n i,\n point,\n axis;\n // add event hook\n fireEvent(series, 'destroy', { keepEventsForUpdate: keepEventsForUpdate });\n // remove events\n this.removeEvents(keepEventsForUpdate);\n // erase from axes\n (series.axisTypes || []).forEach(function (AXIS) {\n axis = series[AXIS];\n if (axis && axis.series) {\n erase(axis.series, series);\n axis.isDirty = axis.forceRedraw = true;\n }\n });\n // remove legend items\n if (series.legendItem) {\n series.chart.legend.destroyItem(series);\n }\n // destroy all points with their elements\n i = data.length;\n while (i--) {\n point = data[i];\n if (point && point.destroy) {\n point.destroy();\n }\n }\n if (series.clips) {\n series.clips.forEach(function (clip) { return clip.destroy(); });\n }\n // Clear the animation timeout if we are destroying the series\n // during initial animation\n U.clearTimeout(series.animationTimeout);\n // Destroy all SVGElements associated to the series\n objectEach(series, function (val, prop) {\n // Survive provides a hook for not destroying\n if (val instanceof SVGElement && !val.survive) {\n // issue 134 workaround\n destroy = issue134 && prop === 'group' ?\n 'hide' :\n 'destroy';\n val[destroy]();\n }\n });\n // remove from hoverSeries\n if (chart.hoverSeries === series) {\n chart.hoverSeries = void 0;\n }\n erase(chart.series, series);\n chart.orderSeries();\n // clear all members\n objectEach(series, function (val, prop) {\n if (!keepEventsForUpdate || prop !== 'hcEvents') {\n delete series[prop];\n }\n });\n };\n /**\n * Clip the graphs into zones for colors and styling.\n *\n * @private\n * @function Highcharts.Series#applyZones\n */\n Series.prototype.applyZones = function () {\n var series = this,\n chart = this.chart,\n renderer = chart.renderer,\n zones = this.zones,\n clips = (this.clips || []),\n graph = this.graph,\n area = this.area,\n plotSizeMax = Math.max(chart.plotWidth,\n chart.plotHeight),\n axis = this[(this.zoneAxis || 'y') + 'Axis'],\n inverted = chart.inverted;\n var translatedFrom,\n translatedTo,\n clipAttr,\n extremes,\n reversed,\n horiz,\n pxRange,\n pxPosMin,\n pxPosMax,\n zoneArea,\n zoneGraph,\n ignoreZones = false;\n if (zones.length &&\n (graph || area) &&\n axis &&\n typeof axis.min !== 'undefined') {\n reversed = axis.reversed;\n horiz = axis.horiz;\n // The use of the Color Threshold assumes there are no gaps\n // so it is safe to hide the original graph and area\n // unless it is not waterfall series, then use showLine property\n // to set lines between columns to be visible (#7862)\n if (graph && !this.showLine) {\n graph.hide();\n }\n if (area) {\n area.hide();\n }\n // Create the clips\n extremes = axis.getExtremes();\n zones.forEach(function (threshold, i) {\n translatedFrom = reversed ?\n (horiz ? chart.plotWidth : 0) :\n (horiz ? 0 : (axis.toPixels(extremes.min) || 0));\n translatedFrom = clamp(pick(translatedTo, translatedFrom), 0, plotSizeMax);\n translatedTo = clamp(Math.round(axis.toPixels(pick(threshold.value, extremes.max), true) || 0), 0, plotSizeMax);\n if (ignoreZones) {\n translatedFrom = translatedTo =\n axis.toPixels(extremes.max);\n }\n pxRange = Math.abs(translatedFrom - translatedTo);\n pxPosMin = Math.min(translatedFrom, translatedTo);\n pxPosMax = Math.max(translatedFrom, translatedTo);\n if (axis.isXAxis) {\n clipAttr = {\n x: inverted ? pxPosMax : pxPosMin,\n y: 0,\n width: pxRange,\n height: plotSizeMax\n };\n if (!horiz) {\n clipAttr.x = chart.plotHeight - clipAttr.x;\n }\n }\n else {\n clipAttr = {\n x: 0,\n y: inverted ? pxPosMax : pxPosMin,\n width: plotSizeMax,\n height: pxRange\n };\n if (horiz) {\n clipAttr.y = chart.plotWidth - clipAttr.y;\n }\n }\n // VML SUPPPORT\n if (inverted && renderer.isVML) {\n if (axis.isXAxis) {\n clipAttr = {\n x: 0,\n y: reversed ? pxPosMin : pxPosMax,\n height: clipAttr.width,\n width: chart.chartWidth\n };\n }\n else {\n clipAttr = {\n x: (clipAttr.y -\n chart.plotLeft -\n chart.spacingBox.x),\n y: 0,\n width: clipAttr.height,\n height: chart.chartHeight\n };\n }\n }\n // END OF VML SUPPORT\n if (clips[i]) {\n clips[i].animate(clipAttr);\n }\n else {\n clips[i] = renderer.clipRect(clipAttr);\n }\n // when no data, graph zone is not applied and after setData\n // clip was ignored. As a result, it should be applied each\n // time.\n zoneArea = series['zone-area-' + i];\n zoneGraph = series['zone-graph-' + i];\n if (graph && zoneGraph) {\n zoneGraph.clip(clips[i]);\n }\n if (area && zoneArea) {\n zoneArea.clip(clips[i]);\n }\n // if this zone extends out of the axis, ignore the others\n ignoreZones = threshold.value > extremes.max;\n // Clear translatedTo for indicators\n if (series.resetZones && translatedTo === 0) {\n translatedTo = void 0;\n }\n });\n this.clips = clips;\n }\n else if (series.visible) {\n // If zones were removed, restore graph and area\n if (graph) {\n graph.show();\n }\n if (area) {\n area.show();\n }\n }\n };\n /**\n * Initialize and perform group inversion on series.group and\n * series.markerGroup.\n *\n * @private\n * @function Highcharts.Series#invertGroups\n */\n Series.prototype.invertGroups = function (inverted) {\n var series = this,\n chart = series.chart;\n /**\n * @private\n */\n function setInvert() {\n ['group', 'markerGroup'].forEach(function (groupName) {\n if (series[groupName]) {\n // VML/HTML needs explicit attributes for flipping\n if (chart.renderer.isVML) {\n series[groupName].attr({\n width: series.yAxis.len,\n height: series.xAxis.len\n });\n }\n series[groupName].width = series.yAxis.len;\n series[groupName].height = series.xAxis.len;\n // If inverted polar, don't invert series group\n series[groupName].invert(series.isRadialSeries ? false : inverted);\n }\n });\n }\n // Pie, go away (#1736)\n if (!series.xAxis) {\n return;\n }\n // A fixed size is needed for inversion to work\n series.eventsToUnbind.push(addEvent(chart, 'resize', setInvert));\n // Do it now\n setInvert();\n // On subsequent render and redraw, just do setInvert without\n // setting up events again\n series.invertGroups = setInvert;\n };\n /**\n * General abstraction for creating plot groups like series.group,\n * series.dataLabelsGroup and series.markerGroup. On subsequent calls,\n * the group will only be adjusted to the updated plot size.\n *\n * @private\n * @function Highcharts.Series#plotGroup\n */\n Series.prototype.plotGroup = function (prop, name, visibility, zIndex, parent) {\n var group = this[prop];\n var isNew = !group,\n attrs = {\n visibility: visibility,\n zIndex: zIndex || 0.1 // IE8 and pointer logic use this\n };\n // Avoid setting undefined opacity, or in styled mode\n if (typeof this.opacity !== 'undefined' &&\n !this.chart.styledMode && this.state !== 'inactive' // #13719\n ) {\n attrs.opacity = this.opacity;\n }\n // Generate it on first call\n if (isNew) {\n this[prop] = group = this.chart.renderer\n .g()\n .add(parent);\n }\n // Add the class names, and replace existing ones as response to\n // Series.update (#6660)\n group.addClass(('highcharts-' + name +\n ' highcharts-series-' + this.index +\n ' highcharts-' + this.type + '-series ' +\n (defined(this.colorIndex) ?\n 'highcharts-color-' + this.colorIndex + ' ' :\n '') +\n (this.options.className || '') +\n (group.hasClass('highcharts-tracker') ?\n ' highcharts-tracker' :\n '')), true);\n // Place it on first and subsequent (redraw) calls\n group.attr(attrs)[isNew ? 'attr' : 'animate'](this.getPlotBox());\n return group;\n };\n /**\n * Get the translation and scale for the plot area of this series.\n *\n * @function Highcharts.Series#getPlotBox\n */\n Series.prototype.getPlotBox = function () {\n var chart = this.chart;\n var xAxis = this.xAxis,\n yAxis = this.yAxis;\n // Swap axes for inverted (#2339)\n if (chart.inverted) {\n xAxis = yAxis;\n yAxis = this.xAxis;\n }\n return {\n translateX: xAxis ? xAxis.left : chart.plotLeft,\n translateY: yAxis ? yAxis.top : chart.plotTop,\n scaleX: 1,\n scaleY: 1\n };\n };\n /**\n * Removes the event handlers attached previously with addEvents.\n * @private\n * @function Highcharts.Series#removeEvents\n */\n Series.prototype.removeEvents = function (keepEventsForUpdate) {\n var series = this;\n if (!keepEventsForUpdate) {\n // remove all events\n removeEvent(series);\n }\n if (series.eventsToUnbind.length) {\n // remove only internal events for proper update\n // #12355 - solves problem with multiple destroy events\n series.eventsToUnbind.forEach(function (unbind) {\n unbind();\n });\n series.eventsToUnbind.length = 0;\n }\n };\n /**\n * Render the graph and markers. Called internally when first rendering\n * and later when redrawing the chart. This function can be extended in\n * plugins, but normally shouldn't be called directly.\n *\n * @function Highcharts.Series#render\n *\n * @emits Highcharts.Series#event:afterRender\n */\n Series.prototype.render = function () {\n var series = this,\n chart = series.chart,\n options = series.options,\n animOptions = animObject(options.animation),\n visibility = series.visible ?\n 'inherit' : 'hidden', // #2597\n zIndex = options.zIndex,\n hasRendered = series.hasRendered,\n chartSeriesGroup = chart.seriesGroup,\n inverted = chart.inverted;\n // Animation doesn't work in IE8 quirks when the group div is\n // hidden, and looks bad in other oldIE\n var animDuration = (!series.finishedAnimating && chart.renderer.isSVG) ?\n animOptions.duration : 0;\n fireEvent(this, 'render');\n // the group\n var group = series.plotGroup('group', 'series', visibility, zIndex, chartSeriesGroup);\n series.markerGroup = series.plotGroup('markerGroup', 'markers', visibility, zIndex, chartSeriesGroup);\n // Initial clipping, applies to columns etc. (#3839).\n if (options.clip !== false) {\n series.setClip();\n }\n // Initialize the animation\n if (series.animate && animDuration) {\n series.animate(true);\n }\n // SVGRenderer needs to know this before drawing elements (#1089,\n // #1795)\n group.inverted = pick(series.invertible, series.isCartesian) ?\n inverted : false;\n // Draw the graph if any\n if (series.drawGraph) {\n series.drawGraph();\n series.applyZones();\n }\n // Draw the points\n if (series.visible) {\n series.drawPoints();\n }\n // Draw the data labels\n if (series.drawDataLabels) {\n series.drawDataLabels();\n }\n // In pie charts, slices are added to the DOM, but actual rendering\n // is postponed until labels reserved their space\n if (series.redrawPoints) {\n series.redrawPoints();\n }\n // draw the mouse tracking area\n if (series.drawTracker &&\n series.options.enableMouseTracking !== false) {\n series.drawTracker();\n }\n // Handle inverted series and tracker groups\n series.invertGroups(inverted);\n // Run the animation\n if (series.animate && animDuration) {\n series.animate();\n }\n // Call the afterAnimate function on animation complete (but don't\n // overwrite the animation.complete option which should be available\n // to the user).\n if (!hasRendered) {\n // Additional time if defer is defined before afterAnimate\n // will be triggered\n if (animDuration && animOptions.defer) {\n animDuration += animOptions.defer;\n }\n series.animationTimeout = syncTimeout(function () {\n series.afterAnimate();\n }, animDuration || 0);\n }\n // Means data is in accordance with what you see\n series.isDirty = false;\n // (See #322) series.isDirty = series.isDirtyData = false; // means\n // data is in accordance with what you see\n series.hasRendered = true;\n fireEvent(series, 'afterRender');\n };\n /**\n * Redraw the series. This function is called internally from\n * `chart.redraw` and normally shouldn't be called directly.\n * @private\n * @function Highcharts.Series#redraw\n */\n Series.prototype.redraw = function () {\n var series = this,\n chart = series.chart, \n // cache it here as it is set to false in render, but used after\n wasDirty = series.isDirty || series.isDirtyData,\n group = series.group,\n xAxis = series.xAxis,\n yAxis = series.yAxis;\n // reposition on resize\n if (group) {\n if (chart.inverted) {\n group.attr({\n width: chart.plotWidth,\n height: chart.plotHeight\n });\n }\n group.animate({\n translateX: pick(xAxis && xAxis.left, chart.plotLeft),\n translateY: pick(yAxis && yAxis.top, chart.plotTop)\n });\n }\n series.translate();\n series.render();\n if (wasDirty) { // #3868, #3945\n delete this.kdTree;\n }\n };\n /**\n * Find the nearest point from a pointer event. This applies to series that\n * use k-d-trees to get the nearest point. Native pointer events must be\n * normalized using `Pointer.normalize`, that adds `chartX` and `chartY`\n * properties.\n *\n * @sample highcharts/demo/synchronized-charts\n * Synchronized charts with tooltips\n *\n * @function Highcharts.Series#searchPoint\n *\n * @param {Highcharts.PointerEvent} e\n * The normalized pointer event\n * @param {boolean} [compareX=false]\n * Search only by the X value, not Y\n *\n * @return {Point|undefined}\n * The closest point to the pointer event\n */\n Series.prototype.searchPoint = function (e, compareX) {\n var series = this,\n xAxis = series.xAxis,\n yAxis = series.yAxis,\n inverted = series.chart.inverted;\n return this.searchKDTree({\n clientX: inverted ?\n xAxis.len - e.chartY + xAxis.pos :\n e.chartX - xAxis.pos,\n plotY: inverted ?\n yAxis.len - e.chartX + yAxis.pos :\n e.chartY - yAxis.pos\n }, compareX, e);\n };\n /**\n * Build the k-d-tree that is used by mouse and touch interaction to get\n * the closest point. Line-like series typically have a one-dimensional\n * tree where points are searched along the X axis, while scatter-like\n * series typically search in two dimensions, X and Y.\n *\n * @private\n * @function Highcharts.Series#buildKDTree\n */\n Series.prototype.buildKDTree = function (e) {\n // Prevent multiple k-d-trees from being built simultaneously\n // (#6235)\n this.buildingKdTree = true;\n var series = this,\n dimensions = series.options.findNearestPointBy\n .indexOf('y') > -1 ? 2 : 1;\n /**\n * Internal function\n * @private\n */\n function _kdtree(points, depth, dimensions) {\n var length = points && points.length;\n var axis,\n median;\n if (length) {\n // alternate between the axis\n axis = series.kdAxisArray[depth % dimensions];\n // sort point array\n points.sort(function (a, b) {\n return a[axis] - b[axis];\n });\n median = Math.floor(length / 2);\n // build and return nod\n return {\n point: points[median],\n left: _kdtree(points.slice(0, median), depth + 1, dimensions),\n right: _kdtree(points.slice(median + 1), depth + 1, dimensions)\n };\n }\n }\n /**\n * Start the recursive build process with a clone of the points\n * array and null points filtered out. (#3873)\n * @private\n */\n function startRecursive() {\n series.kdTree = _kdtree(series.getValidPoints(null, \n // For line-type series restrict to plot area, but\n // column-type series not (#3916, #4511)\n !series.directTouch), dimensions, dimensions);\n series.buildingKdTree = false;\n }\n delete series.kdTree;\n // For testing tooltips, don't build async. Also if touchstart, we\n // may be dealing with click events on mobile, so don't delay\n // (#6817).\n syncTimeout(startRecursive, series.options.kdNow || (e && e.type === 'touchstart') ? 0 : 1);\n };\n /**\n * @private\n * @function Highcharts.Series#searchKDTree\n */\n Series.prototype.searchKDTree = function (point, compareX, e) {\n var series = this,\n kdX = this.kdAxisArray[0],\n kdY = this.kdAxisArray[1],\n kdComparer = compareX ? 'distX' : 'dist',\n kdDimensions = series.options.findNearestPointBy\n .indexOf('y') > -1 ? 2 : 1;\n /**\n * Set the one and two dimensional distance on the point object.\n * @private\n */\n function setDistance(p1, p2) {\n var x = (defined(p1[kdX]) &&\n defined(p2[kdX])) ?\n Math.pow(p1[kdX] - p2[kdX], 2) :\n null,\n y = (defined(p1[kdY]) &&\n defined(p2[kdY])) ?\n Math.pow(p1[kdY] - p2[kdY], 2) :\n null,\n r = (x || 0) + (y || 0);\n p2.dist = defined(r) ? Math.sqrt(r) : Number.MAX_VALUE;\n p2.distX = defined(x) ? Math.sqrt(x) : Number.MAX_VALUE;\n }\n /**\n * @private\n */\n function _search(search, tree, depth, dimensions) {\n var point = tree.point,\n axis = series.kdAxisArray[depth % dimensions];\n var nPoint1,\n nPoint2,\n ret = point;\n setDistance(search, point);\n // Pick side based on distance to splitting point\n var tdist = search[axis] - point[axis], sideA = tdist < 0 ? 'left' : 'right', sideB = tdist < 0 ? 'right' : 'left';\n // End of tree\n if (tree[sideA]) {\n nPoint1 = _search(search, tree[sideA], depth + 1, dimensions);\n ret = (nPoint1[kdComparer] <\n ret[kdComparer] ?\n nPoint1 :\n point);\n }\n if (tree[sideB]) {\n // compare distance to current best to splitting point to\n // decide whether to check side B or not\n if (Math.sqrt(tdist * tdist) < ret[kdComparer]) {\n nPoint2 = _search(search, tree[sideB], depth + 1, dimensions);\n ret = (nPoint2[kdComparer] <\n ret[kdComparer] ?\n nPoint2 :\n ret);\n }\n }\n return ret;\n }\n if (!this.kdTree && !this.buildingKdTree) {\n this.buildKDTree(e);\n }\n if (this.kdTree) {\n return _search(point, this.kdTree, kdDimensions, kdDimensions);\n }\n };\n /**\n * @private\n * @function Highcharts.Series#pointPlacementToXValue\n */\n Series.prototype.pointPlacementToXValue = function () {\n var _a = this,\n _b = _a.options,\n pointPlacement = _b.pointPlacement,\n pointRange = _b.pointRange,\n axis = _a.xAxis;\n var factor = pointPlacement;\n // Point placement is relative to each series pointRange (#5889)\n if (factor === 'between') {\n factor = axis.reversed ? -0.5 : 0.5; // #11955\n }\n return isNumber(factor) ?\n factor * (pointRange || axis.pointRange) :\n 0;\n };\n /**\n * @private\n * @function Highcharts.Series#isPointInside\n */\n Series.prototype.isPointInside = function (point) {\n var _a = this,\n chart = _a.chart,\n xAxis = _a.xAxis,\n yAxis = _a.yAxis,\n isInside = (typeof point.plotY !== 'undefined' &&\n typeof point.plotX !== 'undefined' &&\n point.plotY >= 0 &&\n point.plotY <= (yAxis ? yAxis.len : chart.plotHeight) &&\n point.plotX >= 0 &&\n point.plotX <= (xAxis ? xAxis.len : chart.plotWidth));\n return isInside;\n };\n /**\n * Draw the tracker object that sits above all data labels and markers to\n * track mouse events on the graph or points. For the line type charts\n * the tracker uses the same graphPath, but with a greater stroke width\n * for better control.\n * @private\n */\n Series.prototype.drawTracker = function () {\n var series = this,\n options = series.options,\n trackByArea = options.trackByArea,\n trackerPath = [].concat(trackByArea ?\n series.areaPath :\n series.graphPath), \n // trackerPathLength = trackerPath.length,\n chart = series.chart,\n pointer = chart.pointer,\n renderer = chart.renderer,\n snap = chart.options.tooltip.snap,\n tracker = series.tracker,\n onMouseOver = function (e) {\n if (chart.hoverSeries !== series) {\n series.onMouseOver();\n }\n }, \n /*\n * Empirical lowest possible opacities for TRACKER_FILL for an\n * element to stay invisible but clickable\n * IE6: 0.002\n * IE7: 0.002\n * IE8: 0.002\n * IE9: 0.00000000001 (unlimited)\n * IE10: 0.0001 (exporting only)\n * FF: 0.00000000001 (unlimited)\n * Chrome: 0.000001\n * Safari: 0.000001\n * Opera: 0.00000000001 (unlimited)\n */\n TRACKER_FILL = 'rgba(192,192,192,' + (svg ? 0.0001 : 0.002) + ')';\n var i;\n // Draw the tracker\n if (tracker) {\n tracker.attr({ d: trackerPath });\n }\n else if (series.graph) { // create\n series.tracker = renderer.path(trackerPath)\n .attr({\n visibility: series.visible ? 'inherit' : 'hidden',\n zIndex: 2\n })\n .addClass(trackByArea ?\n 'highcharts-tracker-area' :\n 'highcharts-tracker-line')\n .add(series.group);\n if (!chart.styledMode) {\n series.tracker.attr({\n 'stroke-linecap': 'round',\n 'stroke-linejoin': 'round',\n stroke: TRACKER_FILL,\n fill: trackByArea ? TRACKER_FILL : 'none',\n 'stroke-width': series.graph.strokeWidth() +\n (trackByArea ? 0 : 2 * snap)\n });\n }\n // The tracker is added to the series group, which is clipped, but\n // is covered by the marker group. So the marker group also needs to\n // capture events.\n [\n series.tracker,\n series.markerGroup,\n series.dataLabelsGroup\n ].forEach(function (tracker) {\n if (tracker) {\n tracker.addClass('highcharts-tracker')\n .on('mouseover', onMouseOver)\n .on('mouseout', function (e) {\n pointer.onTrackerMouseOut(e);\n });\n if (options.cursor && !chart.styledMode) {\n tracker.css({ cursor: options.cursor });\n }\n if (hasTouch) {\n tracker.on('touchstart', onMouseOver);\n }\n }\n });\n }\n fireEvent(this, 'afterDrawTracker');\n };\n /**\n * Add a point to the series after render time. The point can be added at\n * the end, or by giving it an X value, to the start or in the middle of the\n * series.\n *\n * @sample highcharts/members/series-addpoint-append/\n * Append point\n * @sample highcharts/members/series-addpoint-append-and-shift/\n * Append and shift\n * @sample highcharts/members/series-addpoint-x-and-y/\n * Both X and Y values given\n * @sample highcharts/members/series-addpoint-pie/\n * Append pie slice\n * @sample stock/members/series-addpoint/\n * Append 100 points in Highcharts Stock\n * @sample stock/members/series-addpoint-shift/\n * Append and shift in Highcharts Stock\n * @sample maps/members/series-addpoint/\n * Add a point in Highmaps\n *\n * @function Highcharts.Series#addPoint\n *\n * @param {Highcharts.PointOptionsType} options\n * The point options. If options is a single number, a point with\n * that y value is appended to the series. If it is an array, it will\n * be interpreted as x and y values respectively. If it is an\n * object, advanced options as outlined under `series.data` are\n * applied.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the point is added. When adding\n * more than one point, it is highly recommended that the redraw\n * option be set to false, and instead {@link Chart#redraw} is\n * explicitly called after the adding of points is finished.\n * Otherwise, the chart will redraw after adding each point.\n *\n * @param {boolean} [shift=false]\n * If true, a point is shifted off the start of the series as one is\n * appended to the end.\n *\n * @param {boolean|Partial} [animation]\n * Whether to apply animation, and optionally animation\n * configuration.\n *\n * @param {boolean} [withEvent=true]\n * Used internally, whether to fire the series `addPoint` event.\n *\n * @emits Highcharts.Series#event:addPoint\n */\n Series.prototype.addPoint = function (options, redraw, shift, animation, withEvent) {\n var series = this,\n seriesOptions = series.options,\n data = series.data,\n chart = series.chart,\n xAxis = series.xAxis,\n names = xAxis && xAxis.hasNames && xAxis.names,\n dataOptions = seriesOptions.data,\n xData = series.xData;\n var isInTheMiddle,\n i;\n // Optional redraw, defaults to true\n redraw = pick(redraw, true);\n // Get options and push the point to xData, yData and series.options. In\n // series.generatePoints the Point instance will be created on demand\n // and pushed to the series.data array.\n var point = { series: series };\n series.pointClass.prototype.applyOptions.apply(point, [options]);\n var x = point.x;\n // Get the insertion point\n i = xData.length;\n if (series.requireSorting && x < xData[i - 1]) {\n isInTheMiddle = true;\n while (i && xData[i - 1] > x) {\n i--;\n }\n }\n // Insert undefined item\n series.updateParallelArrays(point, 'splice', i, 0, 0);\n // Update it\n series.updateParallelArrays(point, i);\n if (names && point.name) {\n names[x] = point.name;\n }\n dataOptions.splice(i, 0, options);\n if (isInTheMiddle ||\n // When processedData is present we need to splice an empty slot\n // into series.data, otherwise generatePoints won't pick it up.\n series.processedData) {\n series.data.splice(i, 0, null);\n series.processData();\n }\n // Generate points to be added to the legend (#1329)\n if (seriesOptions.legendType === 'point') {\n series.generatePoints();\n }\n // Shift the first point off the parallel arrays\n if (shift) {\n if (data[0] && (data[0].remove)) {\n data[0].remove(false);\n }\n else {\n data.shift();\n series.updateParallelArrays(point, 'shift');\n dataOptions.shift();\n }\n }\n // Fire event\n if (withEvent !== false) {\n fireEvent(series, 'addPoint', { point: point });\n }\n // redraw\n series.isDirty = true;\n series.isDirtyData = true;\n if (redraw) {\n chart.redraw(animation); // Animation is set anyway on redraw, #5665\n }\n };\n /**\n * Remove a point from the series. Unlike the\n * {@link Highcharts.Point#remove} method, this can also be done on a point\n * that is not instanciated because it is outside the view or subject to\n * Highcharts Stock data grouping.\n *\n * @sample highcharts/members/series-removepoint/\n * Remove cropped point\n *\n * @function Highcharts.Series#removePoint\n *\n * @param {number} i\n * The index of the point in the {@link Highcharts.Series.data|data}\n * array.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the point is added. When\n * removing more than one point, it is highly recommended that the\n * `redraw` option be set to `false`, and instead {@link\n * Highcharts.Chart#redraw} is explicitly called after the adding of\n * points is finished.\n *\n * @param {boolean|Partial} [animation]\n * Whether and optionally how the series should be animated.\n *\n * @emits Highcharts.Point#event:remove\n */\n Series.prototype.removePoint = function (i, redraw, animation) {\n var series = this,\n data = series.data,\n point = data[i],\n points = series.points,\n chart = series.chart,\n remove = function () {\n if (points && points.length === data.length) { // #4935\n points.splice(i, 1);\n }\n data.splice(i, 1);\n series.options.data.splice(i, 1);\n series.updateParallelArrays(point || { series: series }, 'splice', i, 1);\n if (point) {\n point.destroy();\n }\n // redraw\n series.isDirty = true;\n series.isDirtyData = true;\n if (redraw) {\n chart.redraw();\n }\n };\n setAnimation(animation, chart);\n redraw = pick(redraw, true);\n // Fire the event with a default handler of removing the point\n if (point) {\n point.firePointEvent('remove', null, remove);\n }\n else {\n remove();\n }\n };\n /**\n * Remove a series and optionally redraw the chart.\n *\n * @sample highcharts/members/series-remove/\n * Remove first series from a button\n *\n * @function Highcharts.Series#remove\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or wait for an explicit call to\n * {@link Highcharts.Chart#redraw}.\n *\n * @param {boolean|Partial} [animation]\n * Whether to apply animation, and optionally animation\n * configuration.\n *\n * @param {boolean} [withEvent=true]\n * Used internally, whether to fire the series `remove` event.\n *\n * @emits Highcharts.Series#event:remove\n */\n Series.prototype.remove = function (redraw, animation, withEvent, keepEvents) {\n var series = this,\n chart = series.chart;\n /**\n * @private\n */\n function remove() {\n // Destroy elements\n series.destroy(keepEvents);\n // Redraw\n chart.isDirtyLegend = chart.isDirtyBox = true;\n chart.linkSeries();\n if (pick(redraw, true)) {\n chart.redraw(animation);\n }\n }\n // Fire the event with a default handler of removing the point\n if (withEvent !== false) {\n fireEvent(series, 'remove', null, remove);\n }\n else {\n remove();\n }\n };\n /**\n * Update the series with a new set of options. For a clean and precise\n * handling of new options, all methods and elements from the series are\n * removed, and it is initialized from scratch. Therefore, this method is\n * more performance expensive than some other utility methods like {@link\n * Series#setData} or {@link Series#setVisible}.\n *\n * Note that `Series.update` may mutate the passed `data` options.\n *\n * @sample highcharts/members/series-update/\n * Updating series options\n * @sample maps/members/series-update/\n * Update series options in Highmaps\n *\n * @function Highcharts.Series#update\n *\n * @param {Highcharts.SeriesOptionsType} options\n * New options that will be merged with the series' existing options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the series is altered. If doing\n * more operations on the chart, it is a good idea to set redraw to\n * false and call {@link Chart#redraw} after.\n *\n * @emits Highcharts.Series#event:update\n * @emits Highcharts.Series#event:afterUpdate\n */\n Series.prototype.update = function (options, redraw) {\n options = cleanRecursively(options, this.userOptions);\n fireEvent(this, 'update', { options: options });\n var series = this,\n chart = series.chart, \n // must use user options when changing type because series.options\n // is merged in with type specific plotOptions\n oldOptions = series.userOptions,\n initialType = series.initialType || series.type,\n plotOptions = chart.options.plotOptions,\n initialSeriesProto = seriesTypes[initialType].prototype,\n groups = [\n 'group',\n 'markerGroup',\n 'dataLabelsGroup',\n 'transformGroup',\n 'shadowGroup'\n ], \n // Animation must be enabled when calling update before the initial\n // animation has first run. This happens when calling update\n // directly after chart initialization, or when applying responsive\n // rules (#6912).\n animation = series.finishedAnimating && { animation: false },\n kinds = {};\n var seriesOptions,\n n,\n preserve = [\n 'eventOptions',\n 'navigatorSeries',\n 'baseSeries'\n ],\n newType = (options.type ||\n oldOptions.type ||\n chart.options.chart.type);\n var keepPoints = !(\n // Indicators, histograms etc recalculate the data. It should be\n // possible to omit this.\n this.hasDerivedData ||\n // New type requires new point classes\n (newType && newType !== this.type) ||\n // New options affecting how the data points are built\n typeof options.pointStart !== 'undefined' ||\n typeof options.pointInterval !== 'undefined' ||\n typeof options.relativeXValue !== 'undefined' ||\n options.joinBy ||\n options.mapData || // #11636\n // Changes to data grouping requires new points in new group\n series.hasOptionChanged('dataGrouping') ||\n series.hasOptionChanged('pointStart') ||\n series.hasOptionChanged('pointInterval') ||\n series.hasOptionChanged('pointIntervalUnit') ||\n series.hasOptionChanged('keys'));\n newType = newType || initialType;\n if (keepPoints) {\n preserve.push('data', 'isDirtyData', 'points', 'processedData', // #17057\n 'processedXData', 'processedYData', 'xIncrement', 'cropped', '_hasPointMarkers', '_hasPointLabels', 'clips', // #15420\n // Networkgraph (#14397)\n 'nodes', 'layout', \n // Treemap\n 'level', \n // Map specific, consider moving it to series-specific preserve-\n // properties (#10617)\n 'mapMap', 'mapData', 'minY', 'maxY', 'minX', 'maxX');\n if (options.visible !== false) {\n preserve.push('area', 'graph');\n }\n series.parallelArrays.forEach(function (key) {\n preserve.push(key + 'Data');\n });\n if (options.data) {\n // setData uses dataSorting options so we need to update them\n // earlier\n if (options.dataSorting) {\n extend(series.options.dataSorting, options.dataSorting);\n }\n this.setData(options.data, false);\n }\n }\n // Do the merge, with some forced options\n options = merge(oldOptions, animation, {\n // When oldOptions.index is null it should't be cleared.\n // Otherwise navigator series will have wrong indexes (#10193).\n index: typeof oldOptions.index === 'undefined' ?\n series.index : oldOptions.index,\n pointStart: pick(\n // when updating from blank (#7933)\n (plotOptions &&\n plotOptions.series &&\n plotOptions.series.pointStart), oldOptions.pointStart, \n // when updating after addPoint\n series.xData[0])\n }, (!keepPoints && { data: series.options.data }), options);\n // Merge does not merge arrays, but replaces them. Since points were\n // updated, `series.options.data` has correct merged options, use it:\n if (keepPoints && options.data) {\n options.data = series.options.data;\n }\n // Make sure preserved properties are not destroyed (#3094)\n preserve = groups.concat(preserve);\n preserve.forEach(function (prop) {\n preserve[prop] = series[prop];\n delete series[prop];\n });\n var casting = false;\n if (seriesTypes[newType]) {\n casting = newType !== series.type;\n // Destroy the series and delete all properties, it will be\n // reinserted within the `init` call below\n series.remove(false, false, false, true);\n if (casting) {\n // Modern browsers including IE11\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(series, seriesTypes[newType].prototype);\n // Legacy (IE < 11)\n }\n else {\n var ownEvents = Object.hasOwnProperty.call(series, 'hcEvents') && series.hcEvents;\n for (n in initialSeriesProto) { // eslint-disable-line guard-for-in\n series[n] = void 0;\n }\n // Reinsert all methods and properties from the new type\n // prototype (#2270, #3719).\n extend(series, seriesTypes[newType].prototype);\n // The events are tied to the prototype chain, don't copy if\n // they're not the series' own\n if (ownEvents) {\n series.hcEvents = ownEvents;\n }\n else {\n delete series.hcEvents;\n }\n }\n }\n }\n else {\n error(17, true, chart, { missingModuleFor: newType });\n }\n // Re-register groups (#3094) and other preserved properties\n preserve.forEach(function (prop) {\n series[prop] = preserve[prop];\n });\n series.init(chart, options);\n // Remove particular elements of the points. Check `series.options`\n // because we need to consider the options being set on plotOptions as\n // well.\n if (keepPoints && this.points) {\n seriesOptions = series.options;\n // What kind of elements to destroy\n if (seriesOptions.visible === false) {\n kinds.graphic = 1;\n kinds.dataLabel = 1;\n }\n else if (!series._hasPointLabels) {\n var marker = seriesOptions.marker,\n dataLabels = seriesOptions.dataLabels;\n if (marker && (marker.enabled === false ||\n (oldOptions.marker && oldOptions.marker.symbol) !==\n marker.symbol // #10870, #15946\n )) {\n kinds.graphic = 1;\n }\n if (dataLabels &&\n dataLabels.enabled === false) {\n kinds.dataLabel = 1;\n }\n }\n for (var _a = 0, _b = this.points; _a < _b.length; _a++) {\n var point = _b[_a];\n if (point && point.series) {\n point.resolveColor();\n // Destroy elements in order to recreate based on updated\n // series options.\n if (Object.keys(kinds).length) {\n point.destroyElements(kinds);\n }\n if (seriesOptions.showInLegend === false &&\n point.legendItem) {\n chart.legend.destroyItem(point);\n }\n }\n }\n }\n series.initialType = initialType;\n chart.linkSeries(); // Links are lost in series.remove (#3028)\n // #15383: Fire updatedData if the type has changed to keep linked\n // series such as indicators updated\n if (casting && series.linkedSeries.length) {\n series.isDirtyData = true;\n }\n fireEvent(this, 'afterUpdate');\n if (pick(redraw, true)) {\n chart.redraw(keepPoints ? void 0 : false);\n }\n };\n /**\n * Used from within series.update\n * @private\n */\n Series.prototype.setName = function (name) {\n this.name = this.options.name = this.userOptions.name = name;\n this.chart.isDirtyLegend = true;\n };\n /**\n * Check if the option has changed.\n * @private\n */\n Series.prototype.hasOptionChanged = function (optionName) {\n var chart = this.chart,\n option = this.options[optionName],\n plotOptions = chart.options.plotOptions,\n oldOption = this.userOptions[optionName];\n if (oldOption) {\n return option !== oldOption;\n }\n return option !==\n pick(plotOptions &&\n plotOptions[this.type] &&\n plotOptions[this.type][optionName], plotOptions &&\n plotOptions.series &&\n plotOptions.series[optionName], option);\n };\n /**\n * Runs on mouse over the series graphical items.\n *\n * @function Highcharts.Series#onMouseOver\n * @emits Highcharts.Series#event:mouseOver\n */\n Series.prototype.onMouseOver = function () {\n var series = this,\n chart = series.chart,\n hoverSeries = chart.hoverSeries,\n pointer = chart.pointer;\n pointer.setHoverChartIndex();\n // set normal state to previous series\n if (hoverSeries && hoverSeries !== series) {\n hoverSeries.onMouseOut();\n }\n // trigger the event, but to save processing time,\n // only if defined\n if (series.options.events.mouseOver) {\n fireEvent(series, 'mouseOver');\n }\n // hover this\n series.setState('hover');\n /**\n * Contains the original hovered series.\n *\n * @name Highcharts.Chart#hoverSeries\n * @type {Highcharts.Series|null}\n */\n chart.hoverSeries = series;\n };\n /**\n * Runs on mouse out of the series graphical items.\n *\n * @function Highcharts.Series#onMouseOut\n *\n * @emits Highcharts.Series#event:mouseOut\n */\n Series.prototype.onMouseOut = function () {\n // trigger the event only if listeners exist\n var series = this,\n options = series.options,\n chart = series.chart,\n tooltip = chart.tooltip,\n hoverPoint = chart.hoverPoint;\n // #182, set to null before the mouseOut event fires\n chart.hoverSeries = null;\n // trigger mouse out on the point, which must be in this series\n if (hoverPoint) {\n hoverPoint.onMouseOut();\n }\n // fire the mouse out event\n if (series && options.events.mouseOut) {\n fireEvent(series, 'mouseOut');\n }\n // hide the tooltip\n if (tooltip &&\n !series.stickyTracking &&\n (!tooltip.shared || series.noSharedTooltip)) {\n tooltip.hide();\n }\n // Reset all inactive states\n chart.series.forEach(function (s) {\n s.setState('', true);\n });\n };\n /**\n * Set the state of the series. Called internally on mouse interaction\n * operations, but it can also be called directly to visually\n * highlight a series.\n *\n * @function Highcharts.Series#setState\n *\n * @param {Highcharts.SeriesStateValue|\"\"} [state]\n * The new state, can be either `'hover'`, `'inactive'`, `'select'`,\n * or `''` (an empty string), `'normal'` or `undefined` to set to\n * normal state.\n * @param {boolean} [inherit]\n * Determines if state should be inherited by points too.\n */\n Series.prototype.setState = function (state, inherit) {\n var series = this,\n options = series.options,\n graph = series.graph,\n inactiveOtherPoints = options.inactiveOtherPoints,\n stateOptions = options.states, \n // By default a quick animation to hover/inactive,\n // slower to un-hover\n stateAnimation = pick((stateOptions[state || 'normal'] &&\n stateOptions[state || 'normal'].animation),\n series.chart.options.chart.animation);\n var attribs,\n lineWidth = options.lineWidth,\n i = 0,\n opacity = options.opacity;\n state = state || '';\n if (series.state !== state) {\n // Toggle class names\n [\n series.group,\n series.markerGroup,\n series.dataLabelsGroup\n ].forEach(function (group) {\n if (group) {\n // Old state\n if (series.state) {\n group.removeClass('highcharts-series-' + series.state);\n }\n // New state\n if (state) {\n group.addClass('highcharts-series-' + state);\n }\n }\n });\n series.state = state;\n if (!series.chart.styledMode) {\n if (stateOptions[state] &&\n stateOptions[state].enabled === false) {\n return;\n }\n if (state) {\n lineWidth = (stateOptions[state].lineWidth ||\n lineWidth + (stateOptions[state].lineWidthPlus || 0)); // #4035\n opacity = pick(stateOptions[state].opacity, opacity);\n }\n if (graph && !graph.dashstyle) {\n attribs = {\n 'stroke-width': lineWidth\n };\n // Animate the graph stroke-width.\n graph.animate(attribs, stateAnimation);\n while (series['zone-graph-' + i]) {\n series['zone-graph-' + i].animate(attribs, stateAnimation);\n i = i + 1;\n }\n }\n // For some types (pie, networkgraph, sankey) opacity is\n // resolved on a point level\n if (!inactiveOtherPoints) {\n [\n series.group,\n series.markerGroup,\n series.dataLabelsGroup,\n series.labelBySeries\n ].forEach(function (group) {\n if (group) {\n group.animate({\n opacity: opacity\n }, stateAnimation);\n }\n });\n }\n }\n }\n // Don't loop over points on a series that doesn't apply inactive state\n // to siblings markers (e.g. line, column)\n if (inherit && inactiveOtherPoints && series.points) {\n series.setAllPointsToState(state || void 0);\n }\n };\n /**\n * Set the state for all points in the series.\n *\n * @function Highcharts.Series#setAllPointsToState\n *\n * @private\n *\n * @param {string} [state]\n * Can be either `hover` or undefined to set to normal state.\n */\n Series.prototype.setAllPointsToState = function (state) {\n this.points.forEach(function (point) {\n if (point.setState) {\n point.setState(state);\n }\n });\n };\n /**\n * Show or hide the series.\n *\n * @function Highcharts.Series#setVisible\n *\n * @param {boolean} [visible]\n * True to show the series, false to hide. If undefined, the visibility is\n * toggled.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the series is altered. If doing more\n * operations on the chart, it is a good idea to set redraw to false and\n * call {@link Chart#redraw|chart.redraw()} after.\n *\n * @emits Highcharts.Series#event:hide\n * @emits Highcharts.Series#event:show\n */\n Series.prototype.setVisible = function (vis, redraw) {\n var series = this,\n chart = series.chart,\n ignoreHiddenSeries = chart.options.chart.ignoreHiddenSeries,\n oldVisibility = series.visible;\n // if called without an argument, toggle visibility\n series.visible =\n vis =\n series.options.visible =\n series.userOptions.visible =\n typeof vis === 'undefined' ? !oldVisibility : vis; // #5618\n var showOrHide = vis ? 'show' : 'hide';\n // show or hide elements\n [\n 'group',\n 'dataLabelsGroup',\n 'markerGroup',\n 'tracker',\n 'tt'\n ].forEach(function (key) {\n if (series[key]) {\n series[key][showOrHide]();\n }\n });\n // hide tooltip (#1361)\n if (chart.hoverSeries === series ||\n (chart.hoverPoint && chart.hoverPoint.series) === series) {\n series.onMouseOut();\n }\n if (series.legendItem) {\n chart.legend.colorizeItem(series, vis);\n }\n // rescale or adapt to resized chart\n series.isDirty = true;\n // in a stack, all other series are affected\n if (series.options.stacking) {\n chart.series.forEach(function (otherSeries) {\n if (otherSeries.options.stacking && otherSeries.visible) {\n otherSeries.isDirty = true;\n }\n });\n }\n // show or hide linked series\n series.linkedSeries.forEach(function (otherSeries) {\n otherSeries.setVisible(vis, false);\n });\n if (ignoreHiddenSeries) {\n chart.isDirtyBox = true;\n }\n fireEvent(series, showOrHide);\n if (redraw !== false) {\n chart.redraw();\n }\n };\n /**\n * Show the series if hidden.\n *\n * @sample highcharts/members/series-hide/\n * Toggle visibility from a button\n *\n * @function Highcharts.Series#show\n * @emits Highcharts.Series#event:show\n */\n Series.prototype.show = function () {\n this.setVisible(true);\n };\n /**\n * Hide the series if visible. If the\n * [chart.ignoreHiddenSeries](https://api.highcharts.com/highcharts/chart.ignoreHiddenSeries)\n * option is true, the chart is redrawn without this series.\n *\n * @sample highcharts/members/series-hide/\n * Toggle visibility from a button\n *\n * @function Highcharts.Series#hide\n * @emits Highcharts.Series#event:hide\n */\n Series.prototype.hide = function () {\n this.setVisible(false);\n };\n /**\n * Select or unselect the series. This means its\n * {@link Highcharts.Series.selected|selected}\n * property is set, the checkbox in the legend is toggled and when selected,\n * the series is returned by the {@link Highcharts.Chart#getSelectedSeries}\n * function.\n *\n * @sample highcharts/members/series-select/\n * Select a series from a button\n *\n * @function Highcharts.Series#select\n *\n * @param {boolean} [selected]\n * True to select the series, false to unselect. If undefined, the selection\n * state is toggled.\n *\n * @emits Highcharts.Series#event:select\n * @emits Highcharts.Series#event:unselect\n */\n Series.prototype.select = function (selected) {\n var series = this;\n series.selected =\n selected =\n this.options.selected = (typeof selected === 'undefined' ?\n !series.selected :\n selected);\n if (series.checkbox) {\n series.checkbox.checked = selected;\n }\n fireEvent(series, selected ? 'select' : 'unselect');\n };\n /**\n * Checks if a tooltip should be shown for a given point.\n *\n * @private\n */\n Series.prototype.shouldShowTooltip = function (plotX, plotY, options) {\n if (options === void 0) { options = {}; }\n options.series = this;\n options.visiblePlotOnly = true;\n return this.chart.isInsidePlot(plotX, plotY, options);\n };\n Series.defaultOptions = SeriesDefaults;\n /**\n * Registry of all available series types.\n *\n * @name Highcharts.Series.types\n * @type {Highcharts.Dictionary}\n */\n Series.types = SeriesRegistry.seriesTypes;\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Registers a series class to be accessible via `Series.types`.\n *\n * @function Highcharts.Series.registerType\n *\n * @param {string} seriesType\n * The series type as an identifier string in lower case.\n *\n * @param {Function} SeriesClass\n * The series class as a class pattern or a constructor function with\n * prototype.\n */\n Series.registerType = SeriesRegistry.registerSeriesType;\n return Series;\n }());\n extend(Series.prototype, {\n axisTypes: ['xAxis', 'yAxis'],\n coll: 'series',\n colorCounter: 0,\n cropShoulder: 1,\n directTouch: false,\n drawLegendSymbol: LegendSymbol.drawLineMarker,\n isCartesian: true,\n kdAxisArray: ['clientX', 'plotY'],\n // each point's x and y values are stored in this.xData and this.yData:\n parallelArrays: ['x', 'y'],\n pointClass: Point,\n requireSorting: true,\n // requires the data to be sorted:\n sorted: true\n });\n /* *\n *\n * Registry\n *\n * */\n SeriesRegistry.series = Series;\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * This is a placeholder type of the possible series options for\n * [Highcharts](../highcharts/series), [Highcharts Stock](../highstock/series),\n * [Highmaps](../highmaps/series), and [Gantt](../gantt/series).\n *\n * In TypeScript is this dynamically generated to reference all possible types\n * of series options.\n *\n * @ignore-declaration\n * @typedef {Highcharts.SeriesOptions|Highcharts.Dictionary<*>} Highcharts.SeriesOptionsType\n */\n /**\n * Options for `dataSorting`.\n *\n * @interface Highcharts.DataSortingOptionsObject\n * @since 8.0.0\n */ /**\n * Enable or disable data sorting for the series.\n * @name Highcharts.DataSortingOptionsObject#enabled\n * @type {boolean|undefined}\n */ /**\n * Whether to allow matching points by name in an update.\n * @name Highcharts.DataSortingOptionsObject#matchByName\n * @type {boolean|undefined}\n */ /**\n * Determines what data value should be used to sort by.\n * @name Highcharts.DataSortingOptionsObject#sortKey\n * @type {string|undefined}\n */\n /**\n * Function callback when a series has been animated.\n *\n * @callback Highcharts.SeriesAfterAnimateCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesAfterAnimateEventObject} event\n * Event arguments.\n */\n /**\n * Event information regarding completed animation of a series.\n *\n * @interface Highcharts.SeriesAfterAnimateEventObject\n */ /**\n * Animated series.\n * @name Highcharts.SeriesAfterAnimateEventObject#target\n * @type {Highcharts.Series}\n */ /**\n * Event type.\n * @name Highcharts.SeriesAfterAnimateEventObject#type\n * @type {\"afterAnimate\"}\n */\n /**\n * Function callback when the checkbox next to the series' name in the legend is\n * clicked.\n *\n * @callback Highcharts.SeriesCheckboxClickCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesCheckboxClickEventObject} event\n * Event arguments.\n */\n /**\n * Event information regarding check of a series box.\n *\n * @interface Highcharts.SeriesCheckboxClickEventObject\n */ /**\n * Whether the box has been checked.\n * @name Highcharts.SeriesCheckboxClickEventObject#checked\n * @type {boolean}\n */ /**\n * Related series.\n * @name Highcharts.SeriesCheckboxClickEventObject#item\n * @type {Highcharts.Series}\n */ /**\n * Related series.\n * @name Highcharts.SeriesCheckboxClickEventObject#target\n * @type {Highcharts.Series}\n */ /**\n * Event type.\n * @name Highcharts.SeriesCheckboxClickEventObject#type\n * @type {\"checkboxClick\"}\n */\n /**\n * Function callback when a series is clicked. Return false to cancel toogle\n * actions.\n *\n * @callback Highcharts.SeriesClickCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesClickEventObject} event\n * Event arguments.\n */\n /**\n * Common information for a click event on a series.\n *\n * @interface Highcharts.SeriesClickEventObject\n * @extends global.Event\n */ /**\n * Nearest point on the graph.\n * @name Highcharts.SeriesClickEventObject#point\n * @type {Highcharts.Point}\n */\n /**\n * Gets fired when the series is hidden after chart generation time, either by\n * clicking the legend item or by calling `.hide()`.\n *\n * @callback Highcharts.SeriesHideCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * The SVG value used for the `stroke-linecap` and `stroke-linejoin` of a line\n * graph.\n *\n * @typedef {\"butt\"|\"round\"|\"square\"|string} Highcharts.SeriesLinecapValue\n */\n /**\n * Gets fired when the legend item belonging to the series is clicked. The\n * default action is to toggle the visibility of the series. This can be\n * prevented by returning `false` or calling `event.preventDefault()`.\n *\n * @callback Highcharts.SeriesLegendItemClickCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesLegendItemClickEventObject} event\n * The event that occured.\n */\n /**\n * Information about the event.\n *\n * @interface Highcharts.SeriesLegendItemClickEventObject\n */ /**\n * Related browser event.\n * @name Highcharts.SeriesLegendItemClickEventObject#browserEvent\n * @type {global.PointerEvent}\n */ /**\n * Prevent the default action of toggle the visibility of the series.\n * @name Highcharts.SeriesLegendItemClickEventObject#preventDefault\n * @type {Function}\n */ /**\n * Related series.\n * @name Highcharts.SeriesCheckboxClickEventObject#target\n * @type {Highcharts.Series}\n */ /**\n * Event type.\n * @name Highcharts.SeriesCheckboxClickEventObject#type\n * @type {\"checkboxClick\"}\n */\n /**\n * Gets fired when the mouse leaves the graph.\n *\n * @callback Highcharts.SeriesMouseOutCallbackFunction\n *\n * @param {Highcharts.Series} this\n * Series where the event occured.\n *\n * @param {global.PointerEvent} event\n * Event that occured.\n */\n /**\n * Gets fired when the mouse enters the graph.\n *\n * @callback Highcharts.SeriesMouseOverCallbackFunction\n *\n * @param {Highcharts.Series} this\n * Series where the event occured.\n *\n * @param {global.PointerEvent} event\n * Event that occured.\n */\n /**\n * Translation and scale for the plot area of a series.\n *\n * @interface Highcharts.SeriesPlotBoxObject\n */ /**\n * @name Highcharts.SeriesPlotBoxObject#scaleX\n * @type {number}\n */ /**\n * @name Highcharts.SeriesPlotBoxObject#scaleY\n * @type {number}\n */ /**\n * @name Highcharts.SeriesPlotBoxObject#translateX\n * @type {number}\n */ /**\n * @name Highcharts.SeriesPlotBoxObject#translateY\n * @type {number}\n */\n /**\n * Gets fired when the series is shown after chart generation time, either by\n * clicking the legend item or by calling `.show()`.\n *\n * @callback Highcharts.SeriesShowCallbackFunction\n *\n * @param {Highcharts.Series} this\n * Series where the event occured.\n *\n * @param {global.Event} event\n * Event that occured.\n */\n /**\n * Possible key values for the series state options.\n *\n * @typedef {\"hover\"|\"inactive\"|\"normal\"|\"select\"} Highcharts.SeriesStateValue\n */\n ''; // detach doclets above\n /* *\n *\n * API Options\n *\n * */\n /**\n * Series options for specific data and the data itself. In TypeScript you\n * have to cast the series options to specific series types, to get all\n * possible options for a series.\n *\n * @example\n * // TypeScript example\n * Highcharts.chart('container', {\n * series: [{\n * color: '#06C',\n * data: [[0, 1], [2, 3]]\n * } as Highcharts.SeriesLineOptions ]\n * });\n *\n * @type {Array<*>}\n * @apioption series\n */\n /**\n * An id for the series. This can be used after render time to get a pointer\n * to the series object through `chart.get()`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-id/\n * Get series by id\n *\n * @type {string}\n * @since 1.2.0\n * @apioption series.id\n */\n /**\n * The index of the series in the chart, affecting the internal index in the\n * `chart.series` array, the visible Z index as well as the order in the\n * legend.\n *\n * @type {number}\n * @since 2.3.0\n * @apioption series.index\n */\n /**\n * The sequential index of the series in the legend.\n *\n * @see [legend.reversed](#legend.reversed),\n * [yAxis.reversedStacks](#yAxis.reversedStacks)\n *\n * @sample {highcharts|highstock} highcharts/series/legendindex/\n * Legend in opposite order\n *\n * @type {number}\n * @apioption series.legendIndex\n */\n /**\n * The name of the series as shown in the legend, tooltip etc.\n *\n * @sample {highcharts} highcharts/series/name/\n * Series name\n * @sample {highmaps} maps/demo/category-map/\n * Series name\n *\n * @type {string}\n * @apioption series.name\n */\n /**\n * This option allows grouping series in a stacked chart. The stack option\n * can be a string or anything else, as long as the grouped series' stack\n * options match each other after conversion into a string.\n *\n * @sample {highcharts} highcharts/series/stack/\n * Stacked and grouped columns\n *\n * @type {number|string}\n * @since 2.1\n * @product highcharts highstock\n * @apioption series.stack\n */\n /**\n * The type of series, for example `line` or `column`. By default, the\n * series type is inherited from [chart.type](#chart.type), so unless the\n * chart is a combination of series types, there is no need to set it on the\n * series level.\n *\n * @sample {highcharts} highcharts/series/type/\n * Line and column in the same chart\n * @sample highcharts/series/type-dynamic/\n * Dynamic types with button selector\n * @sample {highmaps} maps/demo/mapline-mappoint/\n * Multiple types in the same map\n *\n * @type {string}\n * @apioption series.type\n */\n /**\n * When using dual or multiple x axes, this number defines which xAxis the\n * particular series is connected to. It refers to either the\n * {@link #xAxis.id|axis id}\n * or the index of the axis in the xAxis array, with 0 being the first.\n *\n * @type {number|string}\n * @default 0\n * @product highcharts highstock\n * @apioption series.xAxis\n */\n /**\n * When using dual or multiple y axes, this number defines which yAxis the\n * particular series is connected to. It refers to either the\n * {@link #yAxis.id|axis id}\n * or the index of the axis in the yAxis array, with 0 being the first.\n *\n * @sample {highcharts} highcharts/series/yaxis/\n * Apply the column series to the secondary Y axis\n *\n * @type {number|string}\n * @default 0\n * @product highcharts highstock\n * @apioption series.yAxis\n */\n /**\n * Define the visual z index of the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-zindex-default/\n * With no z index, the series defined last are on top\n * @sample {highcharts} highcharts/plotoptions/series-zindex/\n * With a z index, the series with the highest z index is on top\n * @sample {highstock} highcharts/plotoptions/series-zindex-default/\n * With no z index, the series defined last are on top\n * @sample {highstock} highcharts/plotoptions/series-zindex/\n * With a z index, the series with the highest z index is on top\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption series.zIndex\n */\n ''; // include precedent doclets in transpilat\n\n return Series;\n });\n _registerModule(_modules, 'Extensions/ScrollablePlotArea.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Axis/Axis.js'], _modules['Core/Chart/Chart.js'], _modules['Core/Series/Series.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Utilities.js']], function (A, Axis, Chart, Series, RendererRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * Highcharts feature to make the Y axis stay fixed when scrolling the chart\n * horizontally on mobile devices. Supports left and right side axes.\n */\n /*\n WIP on vertical scrollable plot area (#9378). To do:\n - Bottom axis positioning\n - Test with Gantt\n - Look for size optimizing the code\n - API and demos\n */\n var stop = A.stop;\n var addEvent = U.addEvent,\n createElement = U.createElement,\n defined = U.defined,\n merge = U.merge,\n pick = U.pick;\n /* eslint-disable no-invalid-this, valid-jsdoc */\n addEvent(Chart, 'afterSetChartSize', function (e) {\n var scrollablePlotArea = this.options.chart.scrollablePlotArea,\n scrollableMinWidth = scrollablePlotArea && scrollablePlotArea.minWidth,\n scrollableMinHeight = scrollablePlotArea && scrollablePlotArea.minHeight,\n scrollablePixelsX,\n scrollablePixelsY,\n corrections;\n if (!this.renderer.forExport) {\n // The amount of pixels to scroll, the difference between chart\n // width and scrollable width\n if (scrollableMinWidth) {\n this.scrollablePixelsX = scrollablePixelsX = Math.max(0, scrollableMinWidth - this.chartWidth);\n if (scrollablePixelsX) {\n this.scrollablePlotBox = (this.renderer.scrollablePlotBox = merge(this.plotBox));\n this.plotBox.width = this.plotWidth += scrollablePixelsX;\n if (this.inverted) {\n this.clipBox.height += scrollablePixelsX;\n }\n else {\n this.clipBox.width += scrollablePixelsX;\n }\n corrections = {\n // Corrections for right side\n 1: { name: 'right', value: scrollablePixelsX }\n };\n }\n // Currently we can only do either X or Y\n }\n else if (scrollableMinHeight) {\n this.scrollablePixelsY = scrollablePixelsY = Math.max(0, scrollableMinHeight - this.chartHeight);\n if (defined(scrollablePixelsY)) {\n this.scrollablePlotBox = (this.renderer.scrollablePlotBox = merge(this.plotBox));\n this.plotBox.height = this.plotHeight += scrollablePixelsY;\n if (this.inverted) {\n this.clipBox.width += scrollablePixelsY;\n }\n else {\n this.clipBox.height += scrollablePixelsY;\n }\n corrections = {\n 2: { name: 'bottom', value: scrollablePixelsY }\n };\n }\n }\n if (corrections && !e.skipAxes) {\n this.axes.forEach(function (axis) {\n // For right and bottom axes, only fix the plot line length\n if (corrections[axis.side]) {\n // Get the plot lines right in getPlotLinePath,\n // temporarily set it to the adjusted plot width.\n axis.getPlotLinePath = function () {\n var marginName = corrections[axis.side].name,\n correctionValue = corrections[axis.side].value, \n // axis.right or axis.bottom\n margin = this[marginName],\n path;\n // Temporarily adjust\n this[marginName] = margin - correctionValue;\n path = Axis.prototype.getPlotLinePath.apply(this, arguments);\n // Reset\n this[marginName] = margin;\n return path;\n };\n }\n else {\n // Apply the corrected plotWidth\n axis.setAxisSize();\n axis.setAxisTranslation();\n }\n });\n }\n }\n });\n addEvent(Chart, 'render', function () {\n if (this.scrollablePixelsX || this.scrollablePixelsY) {\n if (this.setUpScrolling) {\n this.setUpScrolling();\n }\n this.applyFixed();\n }\n else if (this.fixedDiv) { // Has been in scrollable mode\n this.applyFixed();\n }\n });\n /**\n * @private\n * @function Highcharts.Chart#setUpScrolling\n * @return {void}\n */\n Chart.prototype.setUpScrolling = function () {\n var _this = this;\n var css = {\n WebkitOverflowScrolling: 'touch',\n overflowX: 'hidden',\n overflowY: 'hidden'\n };\n if (this.scrollablePixelsX) {\n css.overflowX = 'auto';\n }\n if (this.scrollablePixelsY) {\n css.overflowY = 'auto';\n }\n // Insert a container with position relative\n // that scrolling and fixed container renders to (#10555)\n this.scrollingParent = createElement('div', {\n className: 'highcharts-scrolling-parent'\n }, {\n position: 'relative'\n }, this.renderTo);\n // Add the necessary divs to provide scrolling\n this.scrollingContainer = createElement('div', {\n 'className': 'highcharts-scrolling'\n }, css, this.scrollingParent);\n // On scroll, reset the chart position because it applies to the scrolled\n // container\n addEvent(this.scrollingContainer, 'scroll', function () {\n if (_this.pointer) {\n delete _this.pointer.chartPosition;\n }\n });\n this.innerContainer = createElement('div', {\n 'className': 'highcharts-inner-container'\n }, null, this.scrollingContainer);\n // Now move the container inside\n this.innerContainer.appendChild(this.container);\n // Don't run again\n this.setUpScrolling = null;\n };\n /**\n * These elements are moved over to the fixed renderer and stay fixed when the\n * user scrolls the chart\n * @private\n */\n Chart.prototype.moveFixedElements = function () {\n var container = this.container,\n fixedRenderer = this.fixedRenderer,\n fixedSelectors = [\n '.highcharts-contextbutton',\n '.highcharts-credits',\n '.highcharts-legend',\n '.highcharts-legend-checkbox',\n '.highcharts-navigator-series',\n '.highcharts-navigator-xaxis',\n '.highcharts-navigator-yaxis',\n '.highcharts-navigator',\n '.highcharts-reset-zoom',\n '.highcharts-drillup-button',\n '.highcharts-scrollbar',\n '.highcharts-subtitle',\n '.highcharts-title'\n ],\n axisClass;\n if (this.scrollablePixelsX && !this.inverted) {\n axisClass = '.highcharts-yaxis';\n }\n else if (this.scrollablePixelsX && this.inverted) {\n axisClass = '.highcharts-xaxis';\n }\n else if (this.scrollablePixelsY && !this.inverted) {\n axisClass = '.highcharts-xaxis';\n }\n else if (this.scrollablePixelsY && this.inverted) {\n axisClass = '.highcharts-yaxis';\n }\n if (axisClass) {\n fixedSelectors.push(\"\" + axisClass + \":not(.highcharts-radial-axis)\", \"\" + axisClass + \"-labels:not(.highcharts-radial-axis-labels)\");\n }\n fixedSelectors.forEach(function (className) {\n [].forEach.call(container.querySelectorAll(className), function (elem) {\n (elem.namespaceURI === fixedRenderer.SVG_NS ?\n fixedRenderer.box :\n fixedRenderer.box.parentNode).appendChild(elem);\n elem.style.pointerEvents = 'auto';\n });\n });\n };\n /**\n * @private\n * @function Highcharts.Chart#applyFixed\n * @return {void}\n */\n Chart.prototype.applyFixed = function () {\n var firstTime = !this.fixedDiv,\n chartOptions = this.options.chart,\n scrollableOptions = chartOptions.scrollablePlotArea,\n Renderer = RendererRegistry.getRendererType();\n var fixedRenderer,\n scrollableWidth,\n scrollableHeight;\n // First render\n if (firstTime) {\n this.fixedDiv = createElement('div', {\n className: 'highcharts-fixed'\n }, {\n position: 'absolute',\n overflow: 'hidden',\n pointerEvents: 'none',\n zIndex: (chartOptions.style && chartOptions.style.zIndex || 0) + 2,\n top: 0\n }, null, true);\n if (this.scrollingContainer) {\n this.scrollingContainer.parentNode.insertBefore(this.fixedDiv, this.scrollingContainer);\n }\n this.renderTo.style.overflow = 'visible';\n this.fixedRenderer = fixedRenderer = new Renderer(this.fixedDiv, this.chartWidth, this.chartHeight, this.options.chart.style);\n // Mask\n this.scrollableMask = fixedRenderer\n .path()\n .attr({\n fill: this.options.chart.backgroundColor || '#fff',\n 'fill-opacity': pick(scrollableOptions.opacity, 0.85),\n zIndex: -1\n })\n .addClass('highcharts-scrollable-mask')\n .add();\n addEvent(this, 'afterShowResetZoom', this.moveFixedElements);\n addEvent(this, 'afterApplyDrilldown', this.moveFixedElements);\n addEvent(this, 'afterLayOutTitles', this.moveFixedElements);\n }\n else {\n // Set the size of the fixed renderer to the visible width\n this.fixedRenderer.setSize(this.chartWidth, this.chartHeight);\n }\n if (this.scrollableDirty || firstTime) {\n this.scrollableDirty = false;\n this.moveFixedElements();\n }\n // Increase the size of the scrollable renderer and background\n scrollableWidth = this.chartWidth + (this.scrollablePixelsX || 0);\n scrollableHeight = this.chartHeight + (this.scrollablePixelsY || 0);\n stop(this.container);\n this.container.style.width = scrollableWidth + 'px';\n this.container.style.height = scrollableHeight + 'px';\n this.renderer.boxWrapper.attr({\n width: scrollableWidth,\n height: scrollableHeight,\n viewBox: [0, 0, scrollableWidth, scrollableHeight].join(' ')\n });\n this.chartBackground.attr({\n width: scrollableWidth,\n height: scrollableHeight\n });\n this.scrollingContainer.style.height = this.chartHeight + 'px';\n // Set scroll position\n if (firstTime) {\n if (scrollableOptions.scrollPositionX) {\n this.scrollingContainer.scrollLeft =\n this.scrollablePixelsX *\n scrollableOptions.scrollPositionX;\n }\n if (scrollableOptions.scrollPositionY) {\n this.scrollingContainer.scrollTop =\n this.scrollablePixelsY *\n scrollableOptions.scrollPositionY;\n }\n }\n // Mask behind the left and right side\n var axisOffset = this.axisOffset,\n maskTop = this.plotTop - axisOffset[0] - 1,\n maskLeft = this.plotLeft - axisOffset[3] - 1,\n maskBottom = this.plotTop + this.plotHeight + axisOffset[2] + 1,\n maskRight = this.plotLeft + this.plotWidth + axisOffset[1] + 1,\n maskPlotRight = this.plotLeft + this.plotWidth -\n (this.scrollablePixelsX || 0),\n maskPlotBottom = this.plotTop + this.plotHeight -\n (this.scrollablePixelsY || 0),\n d;\n if (this.scrollablePixelsX) {\n d = [\n // Left side\n ['M', 0, maskTop],\n ['L', this.plotLeft - 1, maskTop],\n ['L', this.plotLeft - 1, maskBottom],\n ['L', 0, maskBottom],\n ['Z'],\n // Right side\n ['M', maskPlotRight, maskTop],\n ['L', this.chartWidth, maskTop],\n ['L', this.chartWidth, maskBottom],\n ['L', maskPlotRight, maskBottom],\n ['Z']\n ];\n }\n else if (this.scrollablePixelsY) {\n d = [\n // Top side\n ['M', maskLeft, 0],\n ['L', maskLeft, this.plotTop - 1],\n ['L', maskRight, this.plotTop - 1],\n ['L', maskRight, 0],\n ['Z'],\n // Bottom side\n ['M', maskLeft, maskPlotBottom],\n ['L', maskLeft, this.chartHeight],\n ['L', maskRight, this.chartHeight],\n ['L', maskRight, maskPlotBottom],\n ['Z']\n ];\n }\n else {\n d = [['M', 0, 0]];\n }\n if (this.redrawTrigger !== 'adjustHeight') {\n this.scrollableMask.attr({ d: d });\n }\n };\n addEvent(Axis, 'afterInit', function () {\n this.chart.scrollableDirty = true;\n });\n addEvent(Series, 'show', function () {\n this.chart.scrollableDirty = true;\n });\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Options for a scrollable plot area. This feature provides a minimum size for\n * the plot area of the chart. If the size gets smaller than this, typically\n * on mobile devices, a native browser scrollbar is presented. This scrollbar\n * provides smooth scrolling for the contents of the plot area, whereas the\n * title, legend and unaffected axes are fixed.\n *\n * Since v7.1.2, a scrollable plot area can be defined for either horizontal or\n * vertical scrolling, depending on whether the `minWidth` or `minHeight`\n * option is set.\n *\n * @sample highcharts/chart/scrollable-plotarea\n * Scrollable plot area\n * @sample highcharts/chart/scrollable-plotarea-vertical\n * Vertically scrollable plot area\n * @sample {gantt} gantt/chart/scrollable-plotarea-vertical\n * Gantt chart with vertically scrollable plot area\n *\n * @since 6.1.0\n * @product highcharts gantt\n * @apioption chart.scrollablePlotArea\n */\n /**\n * The minimum height for the plot area. If it gets smaller than this, the plot\n * area will become scrollable.\n *\n * @type {number}\n * @since 7.1.2\n * @apioption chart.scrollablePlotArea.minHeight\n */\n /**\n * The minimum width for the plot area. If it gets smaller than this, the plot\n * area will become scrollable.\n *\n * @type {number}\n * @since 6.1.0\n * @apioption chart.scrollablePlotArea.minWidth\n */\n /**\n * The initial scrolling position of the scrollable plot area. Ranges from 0 to\n * 1, where 0 aligns the plot area to the left and 1 aligns it to the right.\n * Typically we would use 1 if the chart has right aligned Y axes.\n *\n * @type {number}\n * @since 6.1.0\n * @apioption chart.scrollablePlotArea.scrollPositionX\n */\n /**\n * The initial scrolling position of the scrollable plot area. Ranges from 0 to\n * 1, where 0 aligns the plot area to the top and 1 aligns it to the bottom.\n *\n * @type {number}\n * @since 7.1.2\n * @apioption chart.scrollablePlotArea.scrollPositionY\n */\n /**\n * The opacity of mask applied on one of the sides of the plot\n * area.\n *\n * @sample {highcharts} highcharts/chart/scrollable-plotarea-opacity\n * Disabled opacity for the mask\n *\n * @type {number}\n * @default 0.85\n * @since 7.1.1\n * @apioption chart.scrollablePlotArea.opacity\n */\n (''); // keep doclets above in transpiled file\n\n });\n _registerModule(_modules, 'Core/Axis/Stacking/StackItem.js', [_modules['Core/FormatUtilities.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (FU, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var format = FU.format;\n var Series = SeriesRegistry.series;\n var defined = U.defined,\n destroyObjectProperties = U.destroyObjectProperties,\n isNumber = U.isNumber,\n pick = U.pick;\n /* *\n *\n * Class\n *\n * */\n /**\n * The class for stacks. Each stack, on a specific X value and either negative\n * or positive, has its own stack item.\n * @private\n */\n var StackItem = /** @class */ (function () {\n /* *\n *\n * Constructor\n *\n * */\n function StackItem(axis, options, isNegative, x, stackOption) {\n var inverted = axis.chart.inverted;\n this.axis = axis;\n // Tells if the stack is negative\n this.isNegative = isNegative;\n // Save the options to be able to style the label\n this.options = options = options || {};\n // Save the x value to be able to position the label later\n this.x = x;\n // Initialize total value\n this.total = null;\n this.cumulative = null;\n // This will keep each points' extremes stored by series.index and point\n // index\n this.points = {};\n this.hasValidPoints = false;\n // Save the stack option on the series configuration object,\n // and whether to treat it as percent\n this.stack = stackOption;\n this.leftCliff = 0;\n this.rightCliff = 0;\n // The align options and text align varies on whether the stack is\n // negative and if the chart is inverted or not.\n // First test the user supplied value, then use the dynamic.\n this.alignOptions = {\n align: options.align ||\n (inverted ? (isNegative ? 'left' : 'right') : 'center'),\n verticalAlign: options.verticalAlign ||\n (inverted ? 'middle' : (isNegative ? 'bottom' : 'top')),\n y: options.y,\n x: options.x\n };\n this.textAlign = options.textAlign ||\n (inverted ? (isNegative ? 'right' : 'left') : 'center');\n }\n /**\n * @private\n */\n StackItem.prototype.destroy = function () {\n destroyObjectProperties(this, this.axis);\n };\n /**\n * Renders the stack total label and adds it to the stack label group.\n * @private\n */\n StackItem.prototype.render = function (group) {\n var chart = this.axis.chart,\n options = this.options,\n formatOption = options.format,\n str = formatOption ? // format the text in the label\n format(formatOption,\n this,\n chart) :\n options.formatter.call(this);\n // Change the text to reflect the new total and set visibility to hidden\n // in case the serie is hidden\n if (this.label) {\n this.label.attr({ text: str, visibility: 'hidden' });\n }\n else {\n // Create new label\n this.label = chart.renderer\n .label(str, null, null, options.shape, null, null, options.useHTML, false, 'stack-labels');\n var attr = {\n r: options.borderRadius || 0,\n text: str,\n rotation: options.rotation,\n // set default padding to 5 as it is in datalabels #12308\n padding: pick(options.padding, 5),\n visibility: 'hidden' // hidden until setOffset is called\n };\n if (!chart.styledMode) {\n attr.fill = options.backgroundColor;\n attr.stroke = options.borderColor;\n attr['stroke-width'] = options.borderWidth;\n this.label.css(options.style);\n }\n this.label.attr(attr);\n if (!this.label.added) {\n this.label.add(group); // add to the labels-group\n }\n }\n // Rank it higher than data labels (#8742)\n this.label.labelrank = chart.plotSizeY;\n };\n /**\n * Sets the offset that the stack has from the x value and repositions the\n * label.\n * @private\n */\n StackItem.prototype.setOffset = function (xOffset, xWidth, boxBottom, boxTop, defaultX) {\n var axis = this.axis,\n chart = axis.chart, \n // stack value translated mapped to chart coordinates\n y = axis.translate(axis.stacking.usePercentage ?\n 100 :\n (boxTop ?\n boxTop :\n this.total), 0, 0, 0, 1),\n yZero = axis.translate(boxBottom ? boxBottom : 0), // stack origin\n // x position:\n x = pick(defaultX,\n chart.xAxis[0].translate(this.x)) +\n xOffset,\n stackBox = defined(y) && this.getStackBox(chart,\n this,\n x,\n y,\n xWidth, \n // stack height:\n Math.abs(y - yZero),\n axis),\n label = this.label,\n isNegative = this.isNegative,\n textAlign = this.textAlign;\n if (label && stackBox) {\n var bBox = label.getBBox(),\n padding = label.padding;\n var boxOffsetX = void 0,\n isJustify = pick(this.options.overflow, 'justify') === 'justify',\n visible = void 0;\n if (textAlign === 'left') {\n boxOffsetX = chart.inverted ? -padding : padding;\n }\n else if (textAlign === 'right') {\n boxOffsetX = bBox.width;\n }\n else {\n if (chart.inverted && textAlign === 'center') {\n boxOffsetX = bBox.width / 2;\n }\n else {\n boxOffsetX = chart.inverted ?\n (isNegative ? bBox.width + padding : -padding) :\n bBox.width / 2;\n }\n }\n var boxOffsetY = chart.inverted ?\n bBox.height / 2 : (isNegative ? -padding : bBox.height);\n // Reset alignOptions property after justify #12337\n this.alignOptions.x = pick(this.options.x, 0);\n this.alignOptions.y = pick(this.options.y, 0);\n // Set the stackBox position\n stackBox.x -= boxOffsetX;\n stackBox.y -= boxOffsetY;\n // Align the label to the box\n label.align(this.alignOptions, null, stackBox);\n // Check if label is inside the plotArea #12294\n if (chart.isInsidePlot(label.alignAttr.x + boxOffsetX - this.alignOptions.x, label.alignAttr.y + boxOffsetY - this.alignOptions.y)) {\n label.show();\n }\n else {\n // Move label away to avoid the overlapping issues\n label.hide();\n isJustify = false;\n }\n if (isJustify) {\n // Justify stackLabel into the stackBox\n Series.prototype.justifyDataLabel.call(this.axis, label, this.alignOptions, label.alignAttr, bBox, stackBox);\n }\n label.attr({\n x: label.alignAttr.x,\n y: label.alignAttr.y\n });\n if (pick(!isJustify && this.options.crop, true)) {\n visible =\n isNumber(label.x) &&\n isNumber(label.y) &&\n chart.isInsidePlot(label.x - padding + label.width, label.y) &&\n chart.isInsidePlot(label.x + padding, label.y);\n if (!visible) {\n label.hide();\n }\n }\n }\n };\n /**\n * @private\n * @function Highcharts.StackItem#getStackBox\n */\n StackItem.prototype.getStackBox = function (chart, stackItem, x, y, xWidth, h, axis) {\n var reversed = stackItem.axis.reversed,\n inverted = chart.inverted,\n axisPos = axis.height + axis.pos -\n (inverted ? chart.plotLeft : chart.plotTop),\n neg = (stackItem.isNegative && !reversed) ||\n (!stackItem.isNegative && reversed); // #4056\n return {\n x: inverted ?\n (neg ? y - axis.right : y - h + axis.pos - chart.plotLeft) :\n x + chart.xAxis[0].transB - chart.plotLeft,\n y: inverted ?\n axis.height - x - xWidth :\n (neg ?\n (axisPos - y - h) :\n axisPos - y),\n width: inverted ? h : xWidth,\n height: inverted ? xWidth : h\n };\n };\n return StackItem;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Stack of data points\n *\n * @product highcharts\n *\n * @interface Highcharts.StackItemObject\n */ /**\n * Alignment settings\n * @name Highcharts.StackItemObject#alignOptions\n * @type {Highcharts.AlignObject}\n */ /**\n * Related axis\n * @name Highcharts.StackItemObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * Cumulative value of the stacked data points\n * @name Highcharts.StackItemObject#cumulative\n * @type {number}\n */ /**\n * True if on the negative side\n * @name Highcharts.StackItemObject#isNegative\n * @type {boolean}\n */ /**\n * Related SVG element\n * @name Highcharts.StackItemObject#label\n * @type {Highcharts.SVGElement}\n */ /**\n * Related stack options\n * @name Highcharts.StackItemObject#options\n * @type {Highcharts.YAxisStackLabelsOptions}\n */ /**\n * Total value of the stacked data points\n * @name Highcharts.StackItemObject#total\n * @type {number}\n */ /**\n * Shared x value of the stack\n * @name Highcharts.StackItemObject#x\n * @type {number}\n */\n ''; // keeps doclets above in JS file\n\n return StackItem;\n });\n _registerModule(_modules, 'Core/Axis/Stacking/StackingAxis.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Axis/Axis.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Axis/Stacking/StackItem.js'], _modules['Core/Utilities.js']], function (A, Axis, SeriesRegistry, StackItem, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var getDeferredAnimation = A.getDeferredAnimation;\n var seriesProto = SeriesRegistry.series.prototype;\n var addEvent = U.addEvent,\n correctFloat = U.correctFloat,\n defined = U.defined,\n destroyObjectProperties = U.destroyObjectProperties,\n fireEvent = U.fireEvent,\n isArray = U.isArray,\n isNumber = U.isNumber,\n objectEach = U.objectEach,\n pick = U.pick;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Generate stacks for each series and calculate stacks total values\n *\n * @private\n * @function Highcharts.Chart#getStacks\n */\n function chartGetStacks() {\n var chart = this,\n inverted = chart.inverted;\n // reset stacks for each yAxis\n chart.yAxis.forEach(function (axis) {\n if (axis.stacking && axis.stacking.stacks && axis.hasVisibleSeries) {\n axis.stacking.oldStacks = axis.stacking.stacks;\n }\n });\n chart.series.forEach(function (series) {\n var xAxisOptions = series.xAxis && series.xAxis.options || {};\n if (series.options.stacking &&\n (series.visible === true ||\n chart.options.chart.ignoreHiddenSeries === false)) {\n series.stackKey = [\n series.type,\n pick(series.options.stack, ''),\n inverted ? xAxisOptions.top : xAxisOptions.left,\n inverted ? xAxisOptions.height : xAxisOptions.width\n ].join(',');\n }\n });\n }\n /**\n * @private\n */\n function onAxisDestroy() {\n var stacking = this.stacking;\n if (!stacking) {\n return;\n }\n var stacks = stacking.stacks;\n // Destroy each stack total\n objectEach(stacks, function (stack, stackKey) {\n destroyObjectProperties(stack);\n stacks[stackKey] = null;\n });\n if (stacking &&\n stacking.stackTotalGroup) {\n stacking.stackTotalGroup.destroy();\n }\n }\n /**\n * @private\n */\n function onAxisInit() {\n var axis = this;\n if (!axis.stacking) {\n axis.stacking = new AxisAdditions(axis);\n }\n }\n /**\n * Get stack indicator, according to it's x-value, to determine points with the\n * same x-value\n *\n * @private\n * @function Highcharts.Series#getStackIndicator\n */\n function seriesGetStackIndicator(stackIndicator, x, index, key) {\n // Update stack indicator, when:\n // first point in a stack || x changed || stack type (negative vs positive)\n // changed:\n if (!defined(stackIndicator) ||\n stackIndicator.x !== x ||\n (key && stackIndicator.stackKey !== key)) {\n stackIndicator = {\n x: x,\n index: 0,\n key: key,\n stackKey: key\n };\n }\n else {\n (stackIndicator).index++;\n }\n stackIndicator.key =\n [index, x, stackIndicator.index].join(',');\n return stackIndicator;\n }\n /**\n * Iterate over all stacks and compute the absolute values to percent\n *\n * @private\n * @function Highcharts.Series#modifyStacks\n */\n function seriesModifyStacks() {\n var series = this,\n yAxis = series.yAxis,\n stackKey = series.stackKey,\n stacks = yAxis.stacking.stacks,\n processedXData = series.processedXData,\n stacking = series.options.stacking,\n stacker = series[stacking + 'Stacker'];\n var stackIndicator;\n if (stacker) { // Modifier function exists (Series.percentStacker etc.)\n [stackKey, '-' + stackKey].forEach(function (key) {\n var i = processedXData.length,\n x,\n stack,\n pointExtremes;\n while (i--) {\n x = processedXData[i];\n stackIndicator = series.getStackIndicator(stackIndicator, x, series.index, key);\n stack = stacks[key] && stacks[key][x];\n pointExtremes =\n stack && stack.points[stackIndicator.key];\n if (pointExtremes) {\n stacker.call(series, pointExtremes, stack, i);\n }\n }\n });\n }\n }\n /**\n * Modifier function for percent stacks. Blows up the stack to 100%.\n *\n * @private\n * @function Highcharts.Series#percentStacker\n */\n function seriesPercentStacker(pointExtremes, stack, i) {\n var totalFactor = stack.total ? 100 / stack.total : 0;\n // Y bottom value\n pointExtremes[0] = correctFloat(pointExtremes[0] * totalFactor);\n // Y value\n pointExtremes[1] = correctFloat(pointExtremes[1] * totalFactor);\n this.stackedYData[i] = pointExtremes[1];\n }\n /**\n * Set grouped points in a stack-like object. When `centerInCategory` is true,\n * and `stacking` is not enabled, we need a pseudo (horizontal) stack in order\n * to handle grouping of points within the same category.\n *\n * @private\n * @function Highcharts.Series#setStackedPoints\n * @return {void}\n */\n function seriesSetGroupedPoints() {\n var stacking = this.yAxis.stacking;\n if (this.options.centerInCategory &&\n (this.is('column') || this.is('columnrange')) &&\n // With stacking enabled, we already have stacks that we can compute\n // from\n !this.options.stacking &&\n // With only one series, we don't need to consider centerInCategory\n this.chart.series.length > 1) {\n seriesProto.setStackedPoints.call(this, 'group');\n // After updating, if we now have proper stacks, we must delete the group\n // pseudo stacks (#14986)\n }\n else if (stacking) {\n objectEach(stacking.stacks, function (type, key) {\n if (key.slice(-5) === 'group') {\n objectEach(type, function (stack) { return stack.destroy(); });\n delete stacking.stacks[key];\n }\n });\n }\n }\n /**\n * Adds series' points value to corresponding stack\n *\n * @private\n * @function Highcharts.Series#setStackedPoints\n */\n function seriesSetStackedPoints(stackingParam) {\n var stacking = stackingParam || this.options.stacking;\n if (!stacking || (this.visible !== true &&\n this.chart.options.chart.ignoreHiddenSeries !== false)) {\n return;\n }\n var series = this, xData = series.processedXData, yData = series.processedYData, stackedYData = [], yDataLength = yData.length, seriesOptions = series.options, threshold = seriesOptions.threshold, stackThreshold = pick(seriesOptions.startFromThreshold && threshold, 0), stackOption = seriesOptions.stack, stackKey = stackingParam ? \"\" + series.type + \",\".concat(stacking) : series.stackKey, negKey = '-' + stackKey, negStacks = series.negStacks, yAxis = series.yAxis, stacks = yAxis.stacking.stacks, oldStacks = yAxis.stacking.oldStacks;\n var stackIndicator,\n isNegative,\n stack,\n other,\n key,\n pointKey,\n i,\n x,\n y;\n yAxis.stacking.stacksTouched += 1;\n // loop over the non-null y values and read them into a local array\n for (i = 0; i < yDataLength; i++) {\n x = xData[i];\n y = yData[i];\n stackIndicator = series.getStackIndicator(stackIndicator, x, series.index);\n pointKey = stackIndicator.key;\n // Read stacked values into a stack based on the x value,\n // the sign of y and the stack key. Stacking is also handled for null\n // values (#739)\n isNegative = negStacks && y < (stackThreshold ? 0 : threshold);\n key = isNegative ? negKey : stackKey;\n // Create empty object for this stack if it doesn't exist yet\n if (!stacks[key]) {\n stacks[key] = {};\n }\n // Initialize StackItem for this x\n if (!stacks[key][x]) {\n if (oldStacks[key] &&\n oldStacks[key][x]) {\n stacks[key][x] = oldStacks[key][x];\n stacks[key][x].total = null;\n }\n else {\n stacks[key][x] = new StackItem(yAxis, yAxis.options.stackLabels, !!isNegative, x, stackOption);\n }\n }\n // If the StackItem doesn't exist, create it first\n stack = stacks[key][x];\n if (y !== null) {\n stack.points[pointKey] = stack.points[series.index] =\n [pick(stack.cumulative, stackThreshold)];\n // Record the base of the stack\n if (!defined(stack.cumulative)) {\n stack.base = pointKey;\n }\n stack.touched = yAxis.stacking.stacksTouched;\n // In area charts, if there are multiple points on the same X value,\n // let the area fill the full span of those points\n if (stackIndicator.index > 0 && series.singleStacks === false) {\n stack.points[pointKey][0] =\n stack.points[series.index + ',' + x + ',0'][0];\n }\n // When updating to null, reset the point stack (#7493)\n }\n else {\n stack.points[pointKey] = stack.points[series.index] =\n null;\n }\n // Add value to the stack total\n if (stacking === 'percent') {\n // Percent stacked column, totals are the same for the positive and\n // negative stacks\n other = isNegative ? stackKey : negKey;\n if (negStacks && stacks[other] && stacks[other][x]) {\n other = stacks[other][x];\n stack.total = other.total =\n Math.max(other.total, stack.total) +\n Math.abs(y) ||\n 0;\n // Percent stacked areas\n }\n else {\n stack.total =\n correctFloat(stack.total + (Math.abs(y) || 0));\n }\n }\n else if (stacking === 'group') {\n if (isArray(y)) {\n y = y[0];\n }\n // In this stack, the total is the number of valid points\n if (y !== null) {\n stack.total = (stack.total || 0) + 1;\n }\n }\n else {\n stack.total = correctFloat(stack.total + (y || 0));\n }\n if (stacking === 'group') {\n // This point's index within the stack, pushed to stack.points[1]\n stack.cumulative = (stack.total || 1) - 1;\n }\n else {\n stack.cumulative =\n pick(stack.cumulative, stackThreshold) + (y || 0);\n }\n if (y !== null) {\n stack.points[pointKey].push(stack.cumulative);\n stackedYData[i] = stack.cumulative;\n stack.hasValidPoints = true;\n }\n }\n if (stacking === 'percent') {\n yAxis.stacking.usePercentage = true;\n }\n if (stacking !== 'group') {\n this.stackedYData = stackedYData; // To be used in getExtremes\n }\n // Reset old stacks\n yAxis.stacking.oldStacks = {};\n }\n /* *\n *\n * Classes\n *\n * */\n /**\n * Adds stacking support to axes.\n * @private\n * @class\n */\n var AxisAdditions = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function AxisAdditions(axis) {\n this.oldStacks = {};\n this.stacks = {};\n this.stacksTouched = 0;\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Build the stacks from top down\n * @private\n */\n AxisAdditions.prototype.buildStacks = function () {\n var stacking = this;\n var axis = stacking.axis;\n var axisSeries = axis.series;\n var reversedStacks = axis.options.reversedStacks;\n var len = axisSeries.length;\n var actualSeries,\n i;\n if (!axis.isXAxis) {\n stacking.usePercentage = false;\n i = len;\n while (i--) {\n actualSeries = axisSeries[reversedStacks ? i : len - i - 1];\n actualSeries.setStackedPoints();\n actualSeries.setGroupedPoints();\n }\n // Loop up again to compute percent and stream stack\n for (i = 0; i < len; i++) {\n axisSeries[i].modifyStacks();\n }\n fireEvent(axis, 'afterBuildStacks');\n }\n };\n /**\n * @private\n */\n AxisAdditions.prototype.cleanStacks = function () {\n var stacking = this,\n axis = stacking.axis;\n var stacks;\n if (!axis.isXAxis) {\n if (stacking.oldStacks) {\n stacks = stacking.stacks = stacking.oldStacks;\n }\n // reset stacks\n objectEach(stacks, function (type) {\n objectEach(type, function (stack) {\n stack.cumulative = stack.total;\n });\n });\n }\n };\n /**\n * Set all the stacks to initial states and destroy unused ones.\n * @private\n */\n AxisAdditions.prototype.resetStacks = function () {\n var stacking = this,\n axis = stacking.axis,\n stacks = stacking.stacks;\n if (!axis.isXAxis) {\n objectEach(stacks, function (type) {\n objectEach(type, function (stack, x) {\n // Clean up memory after point deletion (#1044, #4320)\n if (isNumber(stack.touched) &&\n stack.touched < stacking.stacksTouched) {\n stack.destroy();\n delete type[x];\n // Reset stacks\n }\n else {\n stack.total = null;\n stack.cumulative = null;\n }\n });\n });\n }\n };\n /**\n * @private\n */\n AxisAdditions.prototype.renderStackTotals = function () {\n var stacking = this,\n axis = stacking.axis,\n chart = axis.chart,\n renderer = chart.renderer,\n stacks = stacking.stacks,\n stackLabelsAnim = axis.options.stackLabels &&\n axis.options.stackLabels.animation,\n animationConfig = getDeferredAnimation(chart,\n stackLabelsAnim || false),\n stackTotalGroup = stacking.stackTotalGroup = (stacking.stackTotalGroup ||\n renderer\n .g('stack-labels')\n .attr({\n zIndex: 6,\n opacity: 0\n })\n .add());\n // plotLeft/Top will change when y axis gets wider so we need to\n // translate the stackTotalGroup at every render call. See bug #506\n // and #516\n stackTotalGroup.translate(chart.plotLeft, chart.plotTop);\n // Render each stack total\n objectEach(stacks, function (type) {\n objectEach(type, function (stack) {\n stack.render(stackTotalGroup);\n });\n });\n stackTotalGroup.animate({\n opacity: 1\n }, animationConfig);\n };\n return AxisAdditions;\n }());\n /* *\n *\n * Composition\n *\n * */\n var StackingAxis;\n (function (StackingAxis) {\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extends axis with stacking support.\n * @private\n */\n function compose(AxisClass, ChartClass, SeriesClass) {\n if (composedClasses.indexOf(AxisClass) === -1) {\n composedClasses.push(AxisClass);\n addEvent(AxisClass, 'init', onAxisInit);\n addEvent(AxisClass, 'destroy', onAxisDestroy);\n }\n if (composedClasses.indexOf(ChartClass) === -1) {\n composedClasses.push(ChartClass);\n var chartProto = ChartClass.prototype;\n chartProto.getStacks = chartGetStacks;\n }\n if (composedClasses.indexOf(SeriesClass) === -1) {\n composedClasses.push(SeriesClass);\n var seriesProto_1 = SeriesClass.prototype;\n seriesProto_1.getStackIndicator = seriesGetStackIndicator;\n seriesProto_1.modifyStacks = seriesModifyStacks;\n seriesProto_1.percentStacker = seriesPercentStacker;\n seriesProto_1.setGroupedPoints = seriesSetGroupedPoints;\n seriesProto_1.setStackedPoints = seriesSetStackedPoints;\n }\n }\n StackingAxis.compose = compose;\n })(StackingAxis || (StackingAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return StackingAxis;\n });\n _registerModule(_modules, 'Series/Line/LineSeries.js', [_modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (Series, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var defined = U.defined,\n merge = U.merge;\n /* *\n *\n * Class\n *\n * */\n /**\n * The line series is the base type and is therefor the series base prototype.\n *\n * @private\n */\n var LineSeries = /** @class */ (function (_super) {\n __extends(LineSeries, _super);\n function LineSeries() {\n /* *\n *\n * Static Functions\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.data = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Draw the graph. Called internally when rendering line-like series\n * types. The first time it generates the `series.graph` item and\n * optionally other series-wide items like `series.area` for area\n * charts. On subsequent calls these items are updated with new\n * positions and attributes.\n *\n * @function Highcharts.Series#drawGraph\n */\n LineSeries.prototype.drawGraph = function () {\n var series = this,\n options = this.options,\n graphPath = (this.gappedPath || this.getGraphPath).call(this),\n styledMode = this.chart.styledMode;\n var props = [[\n 'graph',\n 'highcharts-graph'\n ]];\n // Presentational properties\n if (!styledMode) {\n props[0].push((options.lineColor ||\n this.color ||\n \"#cccccc\" /* Palette.neutralColor20 */ // when colorByPoint = true\n ), options.dashStyle);\n }\n props = series.getZonesGraphs(props);\n // Draw the graph\n props.forEach(function (prop, i) {\n var graphKey = prop[0];\n var attribs,\n graph = series[graphKey];\n var verb = graph ? 'animate' : 'attr';\n if (graph) {\n graph.endX = series.preventGraphAnimation ?\n null :\n graphPath.xMap;\n graph.animate({ d: graphPath });\n }\n else if (graphPath.length) { // #1487\n /**\n * SVG element of area-based charts. Can be used for styling\n * purposes. If zones are configured, this element will be\n * hidden and replaced by multiple zone areas, accessible\n * via `series['zone-area-x']` (where x is a number,\n * starting with 0).\n *\n * @name Highcharts.Series#area\n * @type {Highcharts.SVGElement|undefined}\n */\n /**\n * SVG element of line-based charts. Can be used for styling\n * purposes. If zones are configured, this element will be\n * hidden and replaced by multiple zone lines, accessible\n * via `series['zone-graph-x']` (where x is a number,\n * starting with 0).\n *\n * @name Highcharts.Series#graph\n * @type {Highcharts.SVGElement|undefined}\n */\n series[graphKey] = graph = series.chart.renderer\n .path(graphPath)\n .addClass(prop[1])\n .attr({ zIndex: 1 }) // #1069\n .add(series.group);\n }\n if (graph && !styledMode) {\n attribs = {\n 'stroke': prop[2],\n 'stroke-width': options.lineWidth,\n // Polygon series use filled graph\n 'fill': (series.fillGraph && series.color) || 'none'\n };\n if (prop[3]) {\n attribs.dashstyle = prop[3];\n }\n else if (options.linecap !== 'square') {\n attribs['stroke-linecap'] =\n attribs['stroke-linejoin'] = 'round';\n }\n graph[verb](attribs)\n // Add shadow to normal series (0) or to first\n // zone (1) #3932\n .shadow((i < 2) && options.shadow);\n }\n // Helpers for animation\n if (graph) {\n graph.startX = graphPath.xMap;\n graph.isArea = graphPath.isArea; // For arearange animation\n }\n });\n };\n // eslint-disable-next-line valid-jsdoc\n /**\n * Get the graph path.\n *\n * @private\n */\n LineSeries.prototype.getGraphPath = function (points, nullsAsZeroes, connectCliffs) {\n var series = this,\n options = series.options,\n graphPath = [],\n xMap = [];\n var gap,\n step = options.step;\n points = points || series.points;\n // Bottom of a stack is reversed\n var reversed = points.reversed;\n if (reversed) {\n points.reverse();\n }\n // Reverse the steps (#5004)\n step = {\n right: 1,\n center: 2\n }[step] || (step && 3);\n if (step && reversed) {\n step = 4 - step;\n }\n // Remove invalid points, especially in spline (#5015)\n points = this.getValidPoints(points, false, !(options.connectNulls && !nullsAsZeroes && !connectCliffs));\n // Build the line\n points.forEach(function (point, i) {\n var plotX = point.plotX,\n plotY = point.plotY,\n lastPoint = points[i - 1];\n // the path to this point from the previous\n var pathToPoint;\n if ((point.leftCliff || (lastPoint && lastPoint.rightCliff)) &&\n !connectCliffs) {\n gap = true; // ... and continue\n }\n // Line series, nullsAsZeroes is not handled\n if (point.isNull && !defined(nullsAsZeroes) && i > 0) {\n gap = !options.connectNulls;\n // Area series, nullsAsZeroes is set\n }\n else if (point.isNull && !nullsAsZeroes) {\n gap = true;\n }\n else {\n if (i === 0 || gap) {\n pathToPoint = [[\n 'M',\n point.plotX,\n point.plotY\n ]];\n // Generate the spline as defined in the SplineSeries object\n }\n else if (series.getPointSpline) {\n pathToPoint = [series.getPointSpline(points, point, i)];\n }\n else if (step) {\n if (step === 1) { // right\n pathToPoint = [[\n 'L',\n lastPoint.plotX,\n plotY\n ]];\n }\n else if (step === 2) { // center\n pathToPoint = [[\n 'L',\n (lastPoint.plotX + plotX) / 2,\n lastPoint.plotY\n ], [\n 'L',\n (lastPoint.plotX + plotX) / 2,\n plotY\n ]];\n }\n else {\n pathToPoint = [[\n 'L',\n plotX,\n lastPoint.plotY\n ]];\n }\n pathToPoint.push([\n 'L',\n plotX,\n plotY\n ]);\n }\n else {\n // normal line to next point\n pathToPoint = [[\n 'L',\n plotX,\n plotY\n ]];\n }\n // Prepare for animation. When step is enabled, there are\n // two path nodes for each x value.\n xMap.push(point.x);\n if (step) {\n xMap.push(point.x);\n if (step === 2) { // step = center (#8073)\n xMap.push(point.x);\n }\n }\n graphPath.push.apply(graphPath, pathToPoint);\n gap = false;\n }\n });\n graphPath.xMap = xMap;\n series.graphPath = graphPath;\n return graphPath;\n };\n // eslint-disable-next-line valid-jsdoc\n /**\n * Get zones properties for building graphs. Extendable by series with\n * multiple lines within one series.\n *\n * @private\n */\n LineSeries.prototype.getZonesGraphs = function (props) {\n // Add the zone properties if any\n this.zones.forEach(function (zone, i) {\n var propset = [\n 'zone-graph-' + i,\n 'highcharts-graph highcharts-zone-graph-' + i + ' ' +\n (zone.className || '')\n ];\n if (!this.chart.styledMode) {\n propset.push((zone.color || this.color), (zone.dashStyle || this.options.dashStyle));\n }\n props.push(propset);\n }, this);\n return props;\n };\n LineSeries.defaultOptions = merge(Series.defaultOptions, \n /**\n * General options for all series types.\n *\n * @optionparent plotOptions.series\n */\n {\n // nothing here yet\n });\n return LineSeries;\n }(Series));\n SeriesRegistry.registerSeriesType('line', LineSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A line series displays information as a series of data points connected by\n * straight line segments.\n *\n * @sample {highcharts} highcharts/demo/line-basic/\n * Line chart\n * @sample {highstock} stock/demo/basic-line/\n * Line chart\n *\n * @extends plotOptions.series\n * @product highcharts highstock\n * @apioption plotOptions.line\n */\n /**\n * The SVG value used for the `stroke-linecap` and `stroke-linejoin`\n * of a line graph. Round means that lines are rounded in the ends and\n * bends.\n *\n * @type {Highcharts.SeriesLinecapValue}\n * @default round\n * @since 3.0.7\n * @apioption plotOptions.line.linecap\n */\n /**\n * A `line` series. If the [type](#series.line.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.line\n * @excluding dataParser,dataURL\n * @product highcharts highstock\n * @apioption series.line\n */\n /**\n * An array of data points for the series. For the `line` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 1],\n * [1, 2],\n * [2, 8]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.line.turboThreshold),\n * this option is not available.\n * ```js\n * data: [{\n * x: 1,\n * y: 9,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 6,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * **Note:** In TypeScript you have to extend `PointOptionsObject` with an\n * additional declaration to allow custom data types:\n * ```ts\n * declare module `highcharts` {\n * interface PointOptionsObject {\n * custom: Record;\n * }\n * }\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @declare Highcharts.PointOptionsObject\n * @type {Array|null|*>}\n * @apioption series.line.data\n */\n /**\n * An additional, individual class name for the data point's graphic\n * representation.\n *\n * @type {string}\n * @since 5.0.0\n * @product highcharts gantt\n * @apioption series.line.data.className\n */\n /**\n * Individual color for the point. By default the color is pulled from\n * the global `colors` array.\n *\n * In styled mode, the `color` option doesn't take effect. Instead, use\n * `colorIndex`.\n *\n * @sample {highcharts} highcharts/point/color/\n * Mark the highest point\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts highstock gantt\n * @apioption series.line.data.color\n */\n /**\n * A specific color index to use for the point, so its graphic representations\n * are given the class name `highcharts-color-{n}`. In styled mode this will\n * change the color of the graphic. In non-styled mode, the color is set by the\n * `fill` attribute, so the change in class name won't have a visual effect by\n * default.\n *\n * @sample {highcharts} highcharts/css/colorindex/\n * Series and point color index\n *\n * @type {number}\n * @since 5.0.0\n * @product highcharts gantt\n * @apioption series.line.data.colorIndex\n */\n /**\n * A reserved subspace to store options and values for customized functionality.\n * Here you can add additional data for your own event callbacks and formatter\n * callbacks.\n *\n * @sample {highcharts} highcharts/point/custom/\n * Point and series with custom data\n *\n * @type {Highcharts.Dictionary<*>}\n * @apioption series.line.data.custom\n */\n /**\n * Individual data label for each point. The options are the same as\n * the ones for [plotOptions.series.dataLabels](\n * #plotOptions.series.dataLabels).\n *\n * @sample highcharts/point/datalabels/\n * Show a label for the last value\n *\n * @declare Highcharts.DataLabelsOptions\n * @extends plotOptions.line.dataLabels\n * @product highcharts highstock gantt\n * @apioption series.line.data.dataLabels\n */\n /**\n * A description of the point to add to the screen reader information\n * about the point.\n *\n * @type {string}\n * @since 5.0.0\n * @requires modules/accessibility\n * @apioption series.line.data.description\n */\n /**\n * An id for the point. This can be used after render time to get a\n * pointer to the point object through `chart.get()`.\n *\n * @sample {highcharts} highcharts/point/id/\n * Remove an id'd point\n *\n * @type {string}\n * @since 1.2.0\n * @product highcharts highstock gantt\n * @apioption series.line.data.id\n */\n /**\n * The rank for this point's data label in case of collision. If two\n * data labels are about to overlap, only the one with the highest `labelrank`\n * will be drawn.\n *\n * @type {number}\n * @apioption series.line.data.labelrank\n */\n /**\n * The name of the point as shown in the legend, tooltip, dataLabels, etc.\n *\n * @see [xAxis.uniqueNames](#xAxis.uniqueNames)\n *\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Point names\n *\n * @type {string}\n * @apioption series.line.data.name\n */\n /**\n * Whether the data point is selected initially.\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock gantt\n * @apioption series.line.data.selected\n */\n /**\n * The x value of the point. For datetime axes, the X value is the timestamp\n * in milliseconds since 1970.\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption series.line.data.x\n */\n /**\n * The y value of the point.\n *\n * @type {number|null}\n * @product highcharts highstock\n * @apioption series.line.data.y\n */\n /**\n * The individual point events.\n *\n * @extends plotOptions.series.point.events\n * @product highcharts highstock gantt\n * @apioption series.line.data.events\n */\n /**\n * Options for the point markers of line-like series.\n *\n * @declare Highcharts.PointMarkerOptionsObject\n * @extends plotOptions.series.marker\n * @product highcharts highstock\n * @apioption series.line.data.marker\n */\n ''; // include precedent doclets in transpilat\n\n return LineSeries;\n });\n _registerModule(_modules, 'Series/Area/AreaSeries.js', [_modules['Core/Color/Color.js'], _modules['Core/Legend/LegendSymbol.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (Color, LegendSymbol, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var color = Color.parse;\n var LineSeries = SeriesRegistry.seriesTypes.line;\n var extend = U.extend,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick;\n /* *\n *\n * Class\n *\n * */\n /**\n * Area series type.\n *\n * @private\n * @class\n * @name AreaSeries\n *\n * @augments LineSeries\n */\n var AreaSeries = /** @class */ (function (_super) {\n __extends(AreaSeries, _super);\n function AreaSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n _this.data = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Draw the graph and the underlying area. This method calls the Series\n * base function and adds the area. The areaPath is calculated in the\n * getSegmentPath method called from Series.prototype.drawGraph.\n * @private\n */\n AreaSeries.prototype.drawGraph = function () {\n // Define or reset areaPath\n this.areaPath = [];\n // Call the base method\n _super.prototype.drawGraph.apply(this);\n // Define local variables\n var series = this,\n areaPath = this.areaPath,\n options = this.options,\n zones = this.zones,\n props = [[\n 'area',\n 'highcharts-area',\n this.color,\n options.fillColor\n ]]; // area name, main color, fill color\n zones.forEach(function (zone,\n i) {\n props.push([\n 'zone-area-' + i,\n 'highcharts-area highcharts-zone-area-' + i + ' ' +\n zone.className,\n zone.color || series.color,\n zone.fillColor || options.fillColor\n ]);\n });\n props.forEach(function (prop) {\n var areaKey = prop[0],\n attribs = {};\n var area = series[areaKey];\n var verb = area ? 'animate' : 'attr';\n // Create or update the area\n if (area) { // update\n area.endX = series.preventGraphAnimation ?\n null :\n areaPath.xMap;\n area.animate({ d: areaPath });\n }\n else { // create\n attribs.zIndex = 0; // #1069\n area = series[areaKey] = series.chart.renderer\n .path(areaPath)\n .addClass(prop[1])\n .add(series.group);\n area.isArea = true;\n }\n if (!series.chart.styledMode) {\n attribs.fill = pick(prop[3], color(prop[2])\n .setOpacity(pick(options.fillOpacity, 0.75))\n .get());\n }\n area[verb](attribs);\n area.startX = areaPath.xMap;\n area.shiftUnit = options.step ? 2 : 1;\n });\n };\n /**\n * @private\n */\n AreaSeries.prototype.getGraphPath = function (points) {\n var getGraphPath = LineSeries.prototype.getGraphPath, options = this.options, stacking = options.stacking, yAxis = this.yAxis, bottomPoints = [], graphPoints = [], seriesIndex = this.index, stacks = yAxis.stacking.stacks[this.stackKey], threshold = options.threshold, translatedThreshold = Math.round(// #10909\n yAxis.getThreshold(options.threshold)), connectNulls = pick(// #10574\n options.connectNulls, stacking === 'percent'), \n // To display null points in underlying stacked series, this\n // series graph must be broken, and the area also fall down to\n // fill the gap left by the null point. #2069\n addDummyPoints = function (i, otherI, side) {\n var point = points[i], stackedValues = stacking &&\n stacks[point.x].points[seriesIndex], nullVal = point[side + 'Null'] || 0, cliffVal = point[side + 'Cliff'] || 0;\n var top,\n bottom,\n isNull = true;\n if (cliffVal || nullVal) {\n top = (nullVal ?\n stackedValues[0] :\n stackedValues[1]) + cliffVal;\n bottom = stackedValues[0] + cliffVal;\n isNull = !!nullVal;\n }\n else if (!stacking &&\n points[otherI] &&\n points[otherI].isNull) {\n top = bottom = threshold;\n }\n // Add to the top and bottom line of the area\n if (typeof top !== 'undefined') {\n graphPoints.push({\n plotX: plotX,\n plotY: top === null ?\n translatedThreshold :\n yAxis.getThreshold(top),\n isNull: isNull,\n isCliff: true\n });\n bottomPoints.push({\n plotX: plotX,\n plotY: bottom === null ?\n translatedThreshold :\n yAxis.getThreshold(bottom),\n doCurve: false // #1041, gaps in areaspline areas\n });\n }\n };\n var plotX,\n isNull,\n yBottom;\n // Find what points to use\n points = points || this.points;\n // Fill in missing points\n if (stacking) {\n points = this.getStackPoints(points);\n }\n for (var i = 0, iEnd = points.length; i < iEnd; ++i) {\n // Reset after series.update of stacking property (#12033)\n if (!stacking) {\n points[i].leftCliff = points[i].rightCliff =\n points[i].leftNull = points[i].rightNull = void 0;\n }\n isNull = points[i].isNull;\n plotX = pick(points[i].rectPlotX, points[i].plotX);\n yBottom = stacking ?\n pick(points[i].yBottom, translatedThreshold) :\n translatedThreshold;\n if (!isNull || connectNulls) {\n if (!connectNulls) {\n addDummyPoints(i, i - 1, 'left');\n }\n // Skip null point when stacking is false and connectNulls\n // true\n if (!(isNull && !stacking && connectNulls)) {\n graphPoints.push(points[i]);\n bottomPoints.push({\n x: i,\n plotX: plotX,\n plotY: yBottom\n });\n }\n if (!connectNulls) {\n addDummyPoints(i, i + 1, 'right');\n }\n }\n }\n var topPath = getGraphPath.call(this,\n graphPoints,\n true,\n true);\n bottomPoints.reversed = true;\n var bottomPath = getGraphPath.call(this,\n bottomPoints,\n true,\n true);\n var firstBottomPoint = bottomPath[0];\n if (firstBottomPoint && firstBottomPoint[0] === 'M') {\n bottomPath[0] = ['L', firstBottomPoint[1], firstBottomPoint[2]];\n }\n var areaPath = topPath.concat(bottomPath);\n if (areaPath.length) {\n areaPath.push(['Z']);\n }\n // TODO: don't set leftCliff and rightCliff when connectNulls?\n var graphPath = getGraphPath\n .call(this,\n graphPoints,\n false,\n connectNulls);\n areaPath.xMap = topPath.xMap;\n this.areaPath = areaPath;\n return graphPath;\n };\n /**\n * Return an array of stacked points, where null and missing points are\n * replaced by dummy points in order for gaps to be drawn correctly in\n * stacks.\n * @private\n */\n AreaSeries.prototype.getStackPoints = function (points) {\n var series = this,\n segment = [],\n keys = [],\n xAxis = this.xAxis,\n yAxis = this.yAxis,\n stack = yAxis.stacking.stacks[this.stackKey],\n pointMap = {},\n yAxisSeries = yAxis.series,\n seriesLength = yAxisSeries.length,\n upOrDown = yAxis.options.reversedStacks ? 1 : -1,\n seriesIndex = yAxisSeries.indexOf(series);\n points = points || this.points;\n if (this.options.stacking) {\n for (var i = 0; i < points.length; i++) {\n // Reset after point update (#7326)\n points[i].leftNull = points[i].rightNull = void 0;\n // Create a map where we can quickly look up the points by\n // their X values.\n pointMap[points[i].x] = points[i];\n }\n // Sort the keys (#1651)\n objectEach(stack, function (stackX, x) {\n // nulled after switching between\n // grouping and not (#1651, #2336)\n if (stackX.total !== null) {\n keys.push(x);\n }\n });\n keys.sort(function (a, b) {\n return a - b;\n });\n var visibleSeries_1 = yAxisSeries.map(function (s) { return s.visible; });\n keys.forEach(function (x, idx) {\n var y = 0,\n stackPoint,\n stackedValues;\n if (pointMap[x] && !pointMap[x].isNull) {\n segment.push(pointMap[x]);\n // Find left and right cliff. -1 goes left, 1 goes\n // right.\n [-1, 1].forEach(function (direction) {\n var nullName = direction === 1 ?\n 'rightNull' :\n 'leftNull',\n cliffName = direction === 1 ?\n 'rightCliff' :\n 'leftCliff',\n otherStack = stack[keys[idx + direction]];\n var cliff = 0;\n // If there is a stack next to this one,\n // to the left or to the right...\n if (otherStack) {\n var i = seriesIndex;\n // Can go either up or down,\n // depending on reversedStacks\n while (i >= 0 && i < seriesLength) {\n var si = yAxisSeries[i].index;\n stackPoint = otherStack.points[si];\n if (!stackPoint) {\n // If the next point in this series is\n // missing, mark the point with\n // point.leftNull or point.rightNull = true.\n if (si === series.index) {\n pointMap[x][nullName] = true;\n // If there are missing points in the next\n // stack in any of the series below this\n // one, we need to substract the missing\n // values and add a hiatus to the left or\n // right.\n }\n else if (visibleSeries_1[i]) {\n stackedValues = stack[x].points[si];\n if (stackedValues) {\n cliff -= (stackedValues[1] -\n stackedValues[0]);\n }\n }\n }\n // When reversedStacks is true, loop up,\n // else loop down\n i += upOrDown;\n }\n }\n pointMap[x][cliffName] = cliff;\n });\n // There is no point for this X value in this series, so we\n // insert a dummy point in order for the areas to be drawn\n // correctly.\n }\n else {\n // Loop down the stack to find the series below this\n // one that has a value (#1991)\n var i = seriesIndex;\n while (i >= 0 && i < seriesLength) {\n var si = yAxisSeries[i].index;\n stackPoint = stack[x].points[si];\n if (stackPoint) {\n y = stackPoint[1];\n break;\n }\n // When reversedStacks is true, loop up, else loop\n // down\n i += upOrDown;\n }\n y = pick(y, 0);\n y = yAxis.translate(// #6272\n y, 0, 1, 0, 1);\n segment.push({\n isNull: true,\n plotX: xAxis.translate(// #6272\n x, 0, 0, 0, 1),\n x: x,\n plotY: y,\n yBottom: y\n });\n }\n });\n }\n return segment;\n };\n /**\n * The area series type.\n *\n * @sample {highcharts} highcharts/demo/area-basic/\n * Area chart\n * @sample {highstock} stock/demo/area/\n * Area chart\n *\n * @extends plotOptions.line\n * @excluding useOhlcData\n * @product highcharts highstock\n * @optionparent plotOptions.area\n */\n AreaSeries.defaultOptions = merge(LineSeries.defaultOptions, {\n /**\n * @see [fillColor](#plotOptions.area.fillColor)\n * @see [fillOpacity](#plotOptions.area.fillOpacity)\n *\n * @apioption plotOptions.area.color\n */\n /**\n * Fill color or gradient for the area. When `null`, the series' `color`\n * is used with the series' `fillOpacity`.\n *\n * In styled mode, the fill color can be set with the `.highcharts-area`\n * class name.\n *\n * @see [color](#plotOptions.area.color)\n * @see [fillOpacity](#plotOptions.area.fillOpacity)\n *\n * @sample {highcharts} highcharts/plotoptions/area-fillcolor-default/\n * Null by default\n * @sample {highcharts} highcharts/plotoptions/area-fillcolor-gradient/\n * Gradient\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts highstock\n * @apioption plotOptions.area.fillColor\n */\n /**\n * Fill opacity for the area. When you set an explicit `fillColor`,\n * the `fillOpacity` is not applied. Instead, you should define the\n * opacity in the `fillColor` with an rgba color definition. The\n * `fillOpacity` setting, also the default setting, overrides the alpha\n * component of the `color` setting.\n *\n * In styled mode, the fill opacity can be set with the\n * `.highcharts-area` class name.\n *\n * @see [color](#plotOptions.area.color)\n * @see [fillColor](#plotOptions.area.fillColor)\n *\n * @sample {highcharts} highcharts/plotoptions/area-fillopacity/\n * Automatic fill color and fill opacity of 0.1\n *\n * @type {number}\n * @default {highcharts} 0.75\n * @default {highstock} 0.75\n * @product highcharts highstock\n * @apioption plotOptions.area.fillOpacity\n */\n /**\n * A separate color for the graph line. By default the line takes the\n * `color` of the series, but the lineColor setting allows setting a\n * separate color for the line without altering the `fillColor`.\n *\n * In styled mode, the line stroke can be set with the\n * `.highcharts-graph` class name.\n *\n * @sample {highcharts} highcharts/plotoptions/area-linecolor/\n * Dark gray line\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts highstock\n * @apioption plotOptions.area.lineColor\n */\n /**\n * A separate color for the negative part of the area.\n *\n * In styled mode, a negative color is set with the\n * `.highcharts-negative` class name.\n *\n * @see [negativeColor](#plotOptions.area.negativeColor)\n *\n * @sample {highcharts} highcharts/css/series-negative-color/\n * Negative color in styled mode\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 3.0\n * @product highcharts\n * @apioption plotOptions.area.negativeFillColor\n */\n /**\n * Whether the whole area or just the line should respond to mouseover\n * tooltips and other mouse or touch events.\n *\n * @sample {highcharts|highstock} highcharts/plotoptions/area-trackbyarea/\n * Display the tooltip when the area is hovered\n *\n * @type {boolean}\n * @default false\n * @since 1.1.6\n * @product highcharts highstock\n * @apioption plotOptions.area.trackByArea\n */\n /**\n * The Y axis value to serve as the base for the area, for\n * distinguishing between values above and below a threshold. The area\n * between the graph and the threshold is filled.\n *\n * * If a number is given, the Y axis will scale to the threshold.\n * * If `null`, the scaling behaves like a line series with fill between\n * the graph and the Y axis minimum.\n * * If `Infinity` or `-Infinity`, the area between the graph and the\n * corresponding Y axis extreme is filled (since v6.1.0).\n *\n * @sample {highcharts} highcharts/plotoptions/area-threshold/\n * A threshold of 100\n * @sample {highcharts} highcharts/plotoptions/area-threshold-infinity/\n * A threshold of Infinity\n *\n * @type {number|null}\n * @since 2.0\n * @product highcharts highstock\n */\n threshold: 0\n });\n return AreaSeries;\n }(LineSeries));\n extend(AreaSeries.prototype, {\n singleStacks: false,\n drawLegendSymbol: LegendSymbol.drawRectangle\n });\n SeriesRegistry.registerSeriesType('area', AreaSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A `area` series. If the [type](#series.area.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.area\n * @excluding dataParser, dataURL, useOhlcData\n * @product highcharts highstock\n * @apioption series.area\n */\n /**\n * @see [fillColor](#series.area.fillColor)\n * @see [fillOpacity](#series.area.fillOpacity)\n *\n * @apioption series.area.color\n */\n /**\n * An array of data points for the series. For the `area` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` * and `pointInterval` given in the series options. If the\n * axis has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 9],\n * [1, 7],\n * [2, 6]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.area.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 9,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 6,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @product highcharts highstock\n * @apioption series.area.data\n */\n /**\n * @see [color](#series.area.color)\n * @see [fillOpacity](#series.area.fillOpacity)\n *\n * @apioption series.area.fillColor\n */\n /**\n * @see [color](#series.area.color)\n * @see [fillColor](#series.area.fillColor)\n *\n * @default {highcharts} 0.75\n * @default {highstock} 0.75\n * @apioption series.area.fillOpacity\n */\n ''; // adds doclets above to transpilat\n\n return AreaSeries;\n });\n _registerModule(_modules, 'Series/Spline/SplineSeries.js', [_modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var LineSeries = SeriesRegistry.seriesTypes.line;\n var merge = U.merge,\n pick = U.pick;\n /* *\n *\n * Class\n *\n * */\n /**\n * Spline series type.\n *\n * @private\n */\n var SplineSeries = /** @class */ (function (_super) {\n __extends(SplineSeries, _super);\n function SplineSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.data = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Get the spline segment from a given point's previous neighbour to the\n * given point.\n *\n * @private\n * @function Highcharts.seriesTypes.spline#getPointSpline\n */\n SplineSeries.prototype.getPointSpline = function (points, point, i) {\n var \n // 1 means control points midway between points, 2 means 1/3\n // from the point, 3 is 1/4 etc\n smoothing = 1.5,\n denom = smoothing + 1,\n plotX = point.plotX || 0,\n plotY = point.plotY || 0,\n lastPoint = points[i - 1],\n nextPoint = points[i + 1];\n var leftContX,\n leftContY,\n rightContX,\n rightContY;\n /**\n * @private\n */\n function doCurve(otherPoint) {\n return otherPoint &&\n !otherPoint.isNull &&\n otherPoint.doCurve !== false &&\n // #6387, area splines next to null:\n !point.isCliff;\n }\n // Find control points\n if (doCurve(lastPoint) && doCurve(nextPoint)) {\n var lastX = lastPoint.plotX || 0,\n lastY = lastPoint.plotY || 0,\n nextX = nextPoint.plotX || 0,\n nextY = nextPoint.plotY || 0;\n var correction = 0;\n leftContX = (smoothing * plotX + lastX) / denom;\n leftContY = (smoothing * plotY + lastY) / denom;\n rightContX = (smoothing * plotX + nextX) / denom;\n rightContY = (smoothing * plotY + nextY) / denom;\n // Have the two control points make a straight line through main\n // point\n if (rightContX !== leftContX) { // #5016, division by zero\n correction = (((rightContY - leftContY) *\n (rightContX - plotX)) /\n (rightContX - leftContX) + plotY - rightContY);\n }\n leftContY += correction;\n rightContY += correction;\n // to prevent false extremes, check that control points are\n // between neighbouring points' y values\n if (leftContY > lastY && leftContY > plotY) {\n leftContY = Math.max(lastY, plotY);\n // mirror of left control point\n rightContY = 2 * plotY - leftContY;\n }\n else if (leftContY < lastY && leftContY < plotY) {\n leftContY = Math.min(lastY, plotY);\n rightContY = 2 * plotY - leftContY;\n }\n if (rightContY > nextY && rightContY > plotY) {\n rightContY = Math.max(nextY, plotY);\n leftContY = 2 * plotY - rightContY;\n }\n else if (rightContY < nextY && rightContY < plotY) {\n rightContY = Math.min(nextY, plotY);\n leftContY = 2 * plotY - rightContY;\n }\n // record for drawing in next point\n point.rightContX = rightContX;\n point.rightContY = rightContY;\n }\n // Visualize control points for debugging\n /*\n if (leftContX) {\n this.chart.renderer.circle(\n leftContX + this.chart.plotLeft,\n leftContY + this.chart.plotTop,\n 2\n )\n .attr({\n stroke: 'red',\n 'stroke-width': 2,\n fill: 'none',\n zIndex: 9\n })\n .add();\n this.chart.renderer.path(['M', leftContX + this.chart.plotLeft,\n leftContY + this.chart.plotTop,\n 'L', plotX + this.chart.plotLeft, plotY + this.chart.plotTop])\n .attr({\n stroke: 'red',\n 'stroke-width': 2,\n zIndex: 9\n })\n .add();\n }\n if (rightContX) {\n this.chart.renderer.circle(\n rightContX + this.chart.plotLeft,\n rightContY + this.chart.plotTop,\n 2\n )\n .attr({\n stroke: 'green',\n 'stroke-width': 2,\n fill: 'none',\n zIndex: 9\n })\n .add();\n this.chart.renderer.path(['M', rightContX + this.chart.plotLeft,\n rightContY + this.chart.plotTop,\n 'L', plotX + this.chart.plotLeft, plotY + this.chart.plotTop])\n .attr({\n stroke: 'green',\n 'stroke-width': 2,\n zIndex: 9\n })\n .add();\n }\n // */\n var ret = [\n 'C',\n pick(lastPoint.rightContX,\n lastPoint.plotX, 0),\n pick(lastPoint.rightContY,\n lastPoint.plotY, 0),\n pick(leftContX,\n plotX, 0),\n pick(leftContY,\n plotY, 0),\n plotX,\n plotY\n ];\n // reset for updating series later\n lastPoint.rightContX = lastPoint.rightContY = void 0;\n return ret;\n };\n /**\n * A spline series is a special type of line series, where the segments\n * between the data points are smoothed.\n *\n * @sample {highcharts} highcharts/demo/spline-irregular-time/\n * Spline chart\n * @sample {highstock} stock/demo/spline/\n * Spline chart\n *\n * @extends plotOptions.series\n * @excluding step, boostThreshold, boostBlending\n * @product highcharts highstock\n * @optionparent plotOptions.spline\n */\n SplineSeries.defaultOptions = merge(LineSeries.defaultOptions);\n return SplineSeries;\n }(LineSeries));\n SeriesRegistry.registerSeriesType('spline', SplineSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A `spline` series. If the [type](#series.spline.type) option is\n * not specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.spline\n * @excluding dataParser, dataURL, step, boostThreshold, boostBlending\n * @product highcharts highstock\n * @apioption series.spline\n */\n /**\n * An array of data points for the series. For the `spline` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 9],\n * [1, 2],\n * [2, 8]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.spline.turboThreshold),\n * this option is not available.\n * ```js\n * data: [{\n * x: 1,\n * y: 9,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 0,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @product highcharts highstock\n * @apioption series.spline.data\n */\n ''; // adds doclets above intro transpilat\n\n return SplineSeries;\n });\n _registerModule(_modules, 'Series/AreaSpline/AreaSplineSeries.js', [_modules['Series/Spline/SplineSeries.js'], _modules['Core/Legend/LegendSymbol.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (SplineSeries, LegendSymbol, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var _a = SeriesRegistry.seriesTypes,\n AreaSeries = _a.area,\n areaProto = _a.area.prototype;\n var extend = U.extend,\n merge = U.merge;\n /* *\n *\n * Class\n *\n * */\n /**\n * AreaSpline series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.areaspline\n *\n * @augments Highcharts.Series\n */\n var AreaSplineSeries = /** @class */ (function (_super) {\n __extends(AreaSplineSeries, _super);\n function AreaSplineSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.data = void 0;\n _this.points = void 0;\n _this.options = void 0;\n return _this;\n }\n AreaSplineSeries.defaultOptions = merge(SplineSeries.defaultOptions, AreaSeries.defaultOptions);\n return AreaSplineSeries;\n }(SplineSeries));\n extend(AreaSplineSeries.prototype, {\n getGraphPath: areaProto.getGraphPath,\n getStackPoints: areaProto.getStackPoints,\n drawGraph: areaProto.drawGraph,\n drawLegendSymbol: LegendSymbol.drawRectangle\n });\n SeriesRegistry.registerSeriesType('areaspline', AreaSplineSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * The area spline series is an area series where the graph between the\n * points is smoothed into a spline.\n *\n * @sample {highcharts} highcharts/demo/areaspline/\n * Area spline chart\n * @sample {highstock} stock/demo/areaspline/\n * Area spline chart\n *\n * @extends plotOptions.area\n * @excluding step, boostThreshold, boostBlending\n * @product highcharts highstock\n * @apioption plotOptions.areaspline\n */\n /**\n * @see [fillColor](#plotOptions.areaspline.fillColor)\n * @see [fillOpacity](#plotOptions.areaspline.fillOpacity)\n *\n * @apioption plotOptions.areaspline.color\n */\n /**\n * @see [color](#plotOptions.areaspline.color)\n * @see [fillOpacity](#plotOptions.areaspline.fillOpacity)\n *\n * @apioption plotOptions.areaspline.fillColor\n */\n /**\n * @see [color](#plotOptions.areaspline.color)\n * @see [fillColor](#plotOptions.areaspline.fillColor)\n *\n * @default 0.75\n * @apioption plotOptions.areaspline.fillOpacity\n */\n /**\n * A `areaspline` series. If the [type](#series.areaspline.type) option\n * is not specified, it is inherited from [chart.type](#chart.type).\n *\n *\n * @extends series,plotOptions.areaspline\n * @excluding dataParser, dataURL, step, boostThreshold, boostBlending\n * @product highcharts highstock\n * @apioption series.areaspline\n */\n /**\n * @see [fillColor](#series.areaspline.fillColor)\n * @see [fillOpacity](#series.areaspline.fillOpacity)\n *\n * @apioption series.areaspline.color\n */\n /**\n * An array of data points for the series. For the `areaspline` series\n * type, points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 10],\n * [1, 9],\n * [2, 3]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.areaspline.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 4,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 4,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @product highcharts highstock\n * @apioption series.areaspline.data\n */\n /**\n * @see [color](#series.areaspline.color)\n * @see [fillOpacity](#series.areaspline.fillOpacity)\n *\n * @apioption series.areaspline.fillColor\n */\n /**\n * @see [color](#series.areaspline.color)\n * @see [fillColor](#series.areaspline.fillColor)\n *\n * @default 0.75\n * @apioption series.areaspline.fillOpacity\n */\n ''; // adds doclets above into transpilat\n\n return AreaSplineSeries;\n });\n _registerModule(_modules, 'Series/Column/ColumnSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Column series display one column per value along an X axis.\n *\n * @sample {highcharts} highcharts/demo/column-basic/\n * Column chart\n * @sample {highstock} stock/demo/column/\n * Column chart\n *\n * @extends plotOptions.line\n * @excluding connectEnds, connectNulls, gapSize, gapUnit, linecap,\n * lineWidth, marker, step, useOhlcData\n * @product highcharts highstock\n * @optionparent plotOptions.column\n */\n var ColumnSeriesDefaults = {\n /**\n * The corner radius of the border surrounding each column or bar.\n *\n * @sample {highcharts} highcharts/plotoptions/column-borderradius/\n * Rounded columns\n *\n * @product highcharts highstock gantt\n */\n borderRadius: 0,\n /**\n * When using automatic point colors pulled from the global\n * [colors](colors) or series-specific\n * [plotOptions.column.colors](series.colors) collections,\n this option\n * determines whether the chart should receive one color per series or\n * one color per point.\n *\n * In styled mode,\n the `colors` or `series.colors` arrays are not\n * supported,\n and instead this option gives the points individual color\n * class names on the form `highcharts-color-{n}`.\n *\n * @see [series colors](#plotOptions.column.colors)\n *\n * @sample {highcharts} highcharts/plotoptions/column-colorbypoint-false/\n * False by default\n * @sample {highcharts} highcharts/plotoptions/column-colorbypoint-true/\n * True\n *\n * @type {boolean}\n * @default false\n * @since 2.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.colorByPoint\n */\n /**\n * A series specific or series type specific color set to apply instead\n * of the global [colors](#colors) when [colorByPoint](\n * #plotOptions.column.colorByPoint) is true.\n *\n * @type {Array}\n * @since 3.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.colors\n */\n /**\n * When `true`,\n the columns will center in the category,\n ignoring null\n * or missing points. When `false`,\n space will be reserved for null or\n * missing points.\n *\n * @sample {highcharts} highcharts/series-column/centerincategory/\n * Center in category\n *\n * @since 8.0.1\n * @product highcharts highstock gantt\n */\n centerInCategory: false,\n /**\n * Padding between each value groups,\n in x axis units.\n *\n * @sample {highcharts} highcharts/plotoptions/column-grouppadding-default/\n * 0.2 by default\n * @sample {highcharts} highcharts/plotoptions/column-grouppadding-none/\n * No group padding - all columns are evenly spaced\n *\n * @product highcharts highstock gantt\n */\n groupPadding: 0.2,\n /**\n * Whether to group non-stacked columns or to let them render\n * independent of each other. Non-grouped columns will be laid out\n * individually and overlap each other.\n *\n * @sample {highcharts} highcharts/plotoptions/column-grouping-false/\n * Grouping disabled\n * @sample {highstock} highcharts/plotoptions/column-grouping-false/\n * Grouping disabled\n *\n * @type {boolean}\n * @default true\n * @since 2.3.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.grouping\n */\n /** @ignore-option */\n marker: null,\n /**\n * The maximum allowed pixel width for a column,\n translated to the\n * height of a bar in a bar chart. This prevents the columns from\n * becoming too wide when there is a small number of points in the\n * chart.\n *\n * @see [pointWidth](#plotOptions.column.pointWidth)\n *\n * @sample {highcharts} highcharts/plotoptions/column-maxpointwidth-20/\n * Limited to 50\n * @sample {highstock} highcharts/plotoptions/column-maxpointwidth-20/\n * Limited to 50\n *\n * @type {number}\n * @since 4.1.8\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.maxPointWidth\n */\n /**\n * Padding between each column or bar,\n in x axis units.\n *\n * @sample {highcharts} highcharts/plotoptions/column-pointpadding-default/\n * 0.1 by default\n * @sample {highcharts} highcharts/plotoptions/column-pointpadding-025/\n * 0.25\n * @sample {highcharts} highcharts/plotoptions/column-pointpadding-none/\n * 0 for tightly packed columns\n *\n * @product highcharts highstock gantt\n */\n pointPadding: 0.1,\n /**\n * A pixel value specifying a fixed width for each column or bar point.\n * When set to `undefined`,\n the width is calculated from the\n * `pointPadding` and `groupPadding`. The width effects the dimension\n * that is not based on the point value. For column series it is the\n * hoizontal length and for bar series it is the vertical length.\n *\n * @see [maxPointWidth](#plotOptions.column.maxPointWidth)\n *\n * @sample {highcharts} highcharts/plotoptions/column-pointwidth-20/\n * 20px wide columns regardless of chart width or the amount of\n * data points\n *\n * @type {number}\n * @since 1.2.5\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.pointWidth\n */\n /**\n * A pixel value specifying a fixed width for the column or bar.\n * Overrides pointWidth on the series.\n *\n * @see [series.pointWidth](#plotOptions.column.pointWidth)\n *\n * @type {number}\n * @default undefined\n * @since 7.0.0\n * @product highcharts highstock gantt\n * @apioption series.column.data.pointWidth\n */\n /**\n * The minimal height for a column or width for a bar. By default,\n * 0 values are not shown. To visualize a 0 (or close to zero) point,\n * set the minimal point length to a pixel value like 3\\. In stacked\n * column charts,\n minPointLength might not be respected for tightly\n * packed values.\n *\n * @sample {highcharts} highcharts/plotoptions/column-minpointlength/\n * Zero base value\n * @sample {highcharts} highcharts/plotoptions/column-minpointlength-pos-and-neg/\n * Positive and negative close to zero values\n *\n * @product highcharts highstock gantt\n */\n minPointLength: 0,\n /**\n * When the series contains less points than the crop threshold,\n all\n * points are drawn,\n event if the points fall outside the visible plot\n * area at the current zoom. The advantage of drawing all points\n * (including markers and columns),\n is that animation is performed on\n * updates. On the other hand,\n when the series contains more points than\n * the crop threshold,\n the series data is cropped to only contain points\n * that fall within the plot area. The advantage of cropping away\n * invisible points is to increase performance on large series.\n *\n * @product highcharts highstock gantt\n */\n cropThreshold: 50,\n /**\n * The X axis range that each point is valid for. This determines the\n * width of the column. On a categorized axis,\n the range will be 1\n * by default (one category unit). On linear and datetime axes,\n the\n * range will be computed as the distance between the two closest data\n * points.\n *\n * The default `null` means it is computed automatically,\n but this\n * option can be used to override the automatic value.\n *\n * This option is set by default to 1 if data sorting is enabled.\n *\n * @sample {highcharts} highcharts/plotoptions/column-pointrange/\n * Set the point range to one day on a data set with one week\n * between the points\n *\n * @type {number|null}\n * @since 2.3\n * @product highcharts highstock gantt\n */\n pointRange: null,\n states: {\n /**\n * Options for the hovered point. These settings override the normal\n * state options when a point is moused over or touched.\n *\n * @extends plotOptions.series.states.hover\n * @excluding halo,\n lineWidth,\n lineWidthPlus,\n marker\n * @product highcharts highstock gantt\n */\n hover: {\n /** @ignore-option */\n halo: false,\n /**\n * A specific border color for the hovered point. Defaults to\n * inherit the normal state border color.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts gantt\n * @apioption plotOptions.column.states.hover.borderColor\n */\n /**\n * A specific color for the hovered point.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts gantt\n * @apioption plotOptions.column.states.hover.color\n */\n /**\n * How much to brighten the point on interaction. Requires the\n * main color to be defined in hex or rgb(a) format.\n *\n * In styled mode,\n the hover brightening is by default replaced\n * with a fill-opacity set in the `.highcharts-point:hover`\n * rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-states-hover-brightness/\n * Brighten by 0.5\n *\n * @product highcharts highstock gantt\n */\n brightness: 0.1\n },\n /**\n * Options for the selected point. These settings override the\n * normal state options when a point is selected.\n *\n * @extends plotOptions.series.states.select\n * @excluding halo,\n lineWidth,\n lineWidthPlus,\n marker\n * @product highcharts highstock gantt\n */\n select: {\n /**\n * A specific color for the selected point.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #cccccc\n * @product highcharts highstock gantt\n */\n color: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * A specific border color for the selected point.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #000000\n * @product highcharts highstock gantt\n */\n borderColor: \"#000000\" /* Palette.neutralColor100 */\n }\n },\n dataLabels: {\n align: void 0,\n verticalAlign: void 0,\n /**\n * The y position offset of the label relative to the point in\n * pixels.\n *\n * @type {number}\n */\n y: void 0\n },\n // false doesn't work well: https://jsfiddle.net/highcharts/hz8fopan/14/\n /** @ignore-option */\n startFromThreshold: true,\n stickyTracking: false,\n tooltip: {\n distance: 6\n },\n /**\n * The Y axis value to serve as the base for the columns,\n for\n * distinguishing between values above and below a threshold. If `null`,\n * the columns extend from the padding Y axis minimum.\n *\n * @type {number|null}\n * @since 2.0\n * @product highcharts\n */\n threshold: 0,\n /**\n * The width of the border surrounding each column or bar. Defaults to\n * `1` when there is room for a border,\n but to `0` when the columns are\n * so dense that a border would cover the next column.\n *\n * In styled mode,\n the stroke width can be set with the\n * `.highcharts-point` rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-borderwidth/\n * 2px black border\n *\n * @type {number}\n * @default undefined\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.borderWidth\n */\n /**\n * The color of the border surrounding each column or bar.\n *\n * In styled mode,\n the border stroke can be set with the\n * `.highcharts-point` rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-bordercolor/\n * Dark gray border\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #ffffff\n * @product highcharts highstock gantt\n */\n borderColor: \"#ffffff\" /* Palette.backgroundColor */\n };\n /**\n * A `column` series. If the [type](#series.column.type) option is\n * not specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.column\n * @excluding connectNulls, dataParser, dataURL, gapSize, gapUnit, linecap,\n * lineWidth, marker, connectEnds, step\n * @product highcharts highstock\n * @apioption series.column\n */\n /**\n * An array of data points for the series. For the `column` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 6],\n * [1, 2],\n * [2, 6]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.column.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 9,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 6,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @excluding marker\n * @product highcharts highstock\n * @apioption series.column.data\n */\n /**\n * The color of the border surrounding the column or bar.\n *\n * In styled mode, the border stroke can be set with the `.highcharts-point`\n * rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-bordercolor/\n * Dark gray border\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts highstock\n * @apioption series.column.data.borderColor\n */\n /**\n * The width of the border surrounding the column or bar.\n *\n * In styled mode, the stroke width can be set with the `.highcharts-point`\n * rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-borderwidth/\n * 2px black border\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption series.column.data.borderWidth\n */\n /**\n * A name for the dash style to use for the column or bar. Overrides\n * dashStyle on the series.\n *\n * In styled mode, the stroke dash-array can be set with the same classes as\n * listed under [data.color](#series.column.data.color).\n *\n * @see [series.pointWidth](#plotOptions.column.dashStyle)\n *\n * @type {Highcharts.DashStyleValue}\n * @apioption series.column.data.dashStyle\n */\n /**\n * A pixel value specifying a fixed width for the column or bar. Overrides\n * pointWidth on the series. The width effects the dimension that is not based\n * on the point value.\n *\n * @see [series.pointWidth](#plotOptions.column.pointWidth)\n *\n * @type {number}\n * @apioption series.column.data.pointWidth\n */\n /**\n * @excluding halo, lineWidth, lineWidthPlus, marker\n * @product highcharts highstock\n * @apioption series.column.states.hover\n */\n /**\n * @excluding halo, lineWidth, lineWidthPlus, marker\n * @product highcharts highstock\n * @apioption series.column.states.select\n */\n ''; // keeps doclets above in JS file\n /* *\n *\n * Default Export\n *\n * */\n\n return ColumnSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Column/ColumnSeries.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Color/Color.js'], _modules['Series/Column/ColumnSeriesDefaults.js'], _modules['Core/Globals.js'], _modules['Core/Legend/LegendSymbol.js'], _modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (A, Color, ColumnSeriesDefaults, H, LegendSymbol, Series, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var animObject = A.animObject;\n var color = Color.parse;\n var hasTouch = H.hasTouch,\n noop = H.noop;\n var clamp = U.clamp,\n css = U.css,\n defined = U.defined,\n extend = U.extend,\n fireEvent = U.fireEvent,\n isArray = U.isArray,\n isNumber = U.isNumber,\n merge = U.merge,\n pick = U.pick,\n objectEach = U.objectEach;\n /* *\n *\n * Class\n *\n * */\n /**\n * The column series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.column\n *\n * @augments Highcharts.Series\n */\n var ColumnSeries = /** @class */ (function (_super) {\n __extends(ColumnSeries, _super);\n function ColumnSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.borderWidth = void 0;\n _this.data = void 0;\n _this.group = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Animate the column heights one by one from zero.\n *\n * @private\n * @function Highcharts.seriesTypes.column#animate\n *\n * @param {boolean} init\n * Whether to initialize the animation or run it\n */\n ColumnSeries.prototype.animate = function (init) {\n var series = this,\n yAxis = this.yAxis,\n options = series.options,\n inverted = this.chart.inverted,\n attr = {},\n translateProp = inverted ?\n 'translateX' :\n 'translateY';\n var translateStart,\n translatedThreshold;\n if (init) {\n attr.scaleY = 0.001;\n translatedThreshold = clamp(yAxis.toPixels(options.threshold), yAxis.pos, yAxis.pos + yAxis.len);\n if (inverted) {\n attr.translateX = translatedThreshold - yAxis.len;\n }\n else {\n attr.translateY = translatedThreshold;\n }\n // apply finnal clipping (used in Highcharts Stock) (#7083)\n // animation is done by scaleY, so cliping is for panes\n if (series.clipBox) {\n series.setClip();\n }\n series.group.attr(attr);\n }\n else { // run the animation\n translateStart = Number(series.group.attr(translateProp));\n series.group.animate({ scaleY: 1 }, extend(animObject(series.options.animation), {\n // Do the scale synchronously to ensure smooth\n // updating (#5030, #7228)\n step: function (val, fx) {\n if (series.group) {\n attr[translateProp] = translateStart +\n fx.pos * (yAxis.pos - translateStart);\n series.group.attr(attr);\n }\n }\n }));\n }\n };\n /**\n * Initialize the series. Extends the basic Series.init method by\n * marking other series of the same type as dirty.\n *\n * @private\n * @function Highcharts.seriesTypes.column#init\n */\n ColumnSeries.prototype.init = function (chart, options) {\n _super.prototype.init.apply(this, arguments);\n var series = this;\n chart = series.chart;\n // if the series is added dynamically, force redraw of other\n // series affected by a new column\n if (chart.hasRendered) {\n chart.series.forEach(function (otherSeries) {\n if (otherSeries.type === series.type) {\n otherSeries.isDirty = true;\n }\n });\n }\n };\n /**\n * Return the width and x offset of the columns adjusted for grouping,\n * groupPadding, pointPadding, pointWidth etc.\n *\n * @private\n * @function Highcharts.seriesTypes.column#getColumnMetrics\n */\n ColumnSeries.prototype.getColumnMetrics = function () {\n var series = this,\n options = series.options,\n xAxis = series.xAxis,\n yAxis = series.yAxis,\n reversedStacks = xAxis.options.reversedStacks, \n // Keep backward compatibility: reversed xAxis had reversed\n // stacks\n reverseStacks = (xAxis.reversed && !reversedStacks) ||\n (!xAxis.reversed && reversedStacks),\n stackGroups = {};\n var stackKey,\n columnCount = 0;\n // Get the total number of column type series. This is called on\n // every series. Consider moving this logic to a chart.orderStacks()\n // function and call it on init, addSeries and removeSeries\n if (options.grouping === false) {\n columnCount = 1;\n }\n else {\n series.chart.series.forEach(function (otherSeries) {\n var otherYAxis = otherSeries.yAxis,\n otherOptions = otherSeries.options;\n var columnIndex;\n if (otherSeries.type === series.type &&\n (otherSeries.visible ||\n !series.chart.options.chart.ignoreHiddenSeries) &&\n yAxis.len === otherYAxis.len &&\n yAxis.pos === otherYAxis.pos) { // #642, #2086\n if (otherOptions.stacking &&\n otherOptions.stacking !== 'group') {\n stackKey = otherSeries.stackKey;\n if (typeof stackGroups[stackKey] ===\n 'undefined') {\n stackGroups[stackKey] = columnCount++;\n }\n columnIndex = stackGroups[stackKey];\n }\n else if (otherOptions.grouping !== false) { // #1162\n columnIndex = columnCount++;\n }\n otherSeries.columnIndex = columnIndex;\n }\n });\n }\n var categoryWidth = Math.min(Math.abs(xAxis.transA) * ((xAxis.ordinal && xAxis.ordinal.slope) ||\n options.pointRange ||\n xAxis.closestPointRange ||\n xAxis.tickInterval ||\n 1), // #2610\n xAxis.len // #1535\n ),\n groupPadding = categoryWidth * options.groupPadding,\n groupWidth = categoryWidth - 2 * groupPadding,\n pointOffsetWidth = groupWidth / (columnCount || 1),\n pointWidth = Math.min(options.maxPointWidth || xAxis.len,\n pick(options.pointWidth,\n pointOffsetWidth * (1 - 2 * options.pointPadding))),\n pointPadding = (pointOffsetWidth - pointWidth) / 2, \n // #1251, #3737\n colIndex = (series.columnIndex || 0) + (reverseStacks ? 1 : 0),\n pointXOffset = pointPadding +\n (groupPadding +\n colIndex * pointOffsetWidth -\n (categoryWidth / 2)) * (reverseStacks ? -1 : 1);\n // Save it for reading in linked series (Error bars particularly)\n series.columnMetrics = {\n width: pointWidth,\n offset: pointXOffset,\n paddedWidth: pointOffsetWidth,\n columnCount: columnCount\n };\n return series.columnMetrics;\n };\n /**\n * Make the columns crisp. The edges are rounded to the nearest full\n * pixel.\n *\n * @private\n * @function Highcharts.seriesTypes.column#crispCol\n */\n ColumnSeries.prototype.crispCol = function (x, y, w, h) {\n var chart = this.chart,\n borderWidth = this.borderWidth,\n xCrisp = -(borderWidth % 2 ? 0.5 : 0);\n var right,\n yCrisp = borderWidth % 2 ? 0.5 : 1;\n if (chart.inverted && chart.renderer.isVML) {\n yCrisp += 1;\n }\n // Horizontal. We need to first compute the exact right edge, then\n // round it and compute the width from there.\n if (this.options.crisp) {\n right = Math.round(x + w) + xCrisp;\n x = Math.round(x) + xCrisp;\n w = right - x;\n }\n // Vertical\n var bottom = Math.round(y + h) + yCrisp,\n fromTop = Math.abs(y) <= 0.5 && bottom > 0.5; // #4504, #4656\n y = Math.round(y) + yCrisp;\n h = bottom - y;\n // Top edges are exceptions\n if (fromTop && h) { // #5146\n y -= 1;\n h += 1;\n }\n return {\n x: x,\n y: y,\n width: w,\n height: h\n };\n };\n /**\n * Adjust for missing columns, according to the `centerInCategory`\n * option. Missing columns are either single points or stacks where the\n * point or points are either missing or null.\n *\n * @private\n * @function Highcharts.seriesTypes.column#adjustForMissingColumns\n * @param {number} x\n * The x coordinate of the column, left side\n *\n * @param {number} pointWidth\n * The pointWidth, already computed upstream\n *\n * @param {Highcharts.ColumnPoint} point\n * The point instance\n *\n * @param {Highcharts.ColumnMetricsObject} metrics\n * The series-wide column metrics\n *\n * @return {number}\n * The adjusted x position, or the original if not adjusted\n */\n ColumnSeries.prototype.adjustForMissingColumns = function (x, pointWidth, point, metrics) {\n var _this = this;\n var stacking = this.options.stacking;\n if (!point.isNull && metrics.columnCount > 1) {\n var reversedStacks_1 = this.yAxis.options.reversedStacks;\n var indexInCategory_1 = 0,\n totalInCategory_1 = reversedStacks_1 ? 0 : -metrics.columnCount;\n // Loop over all the stacks on the Y axis. When stacking is enabled,\n // these are real point stacks. When stacking is not enabled, but\n // `centerInCategory` is true, there is one stack handling the\n // grouping of points in each category. This is done in the\n // `setGroupedPoints` function.\n objectEach(this.yAxis.stacking && this.yAxis.stacking.stacks, function (stack) {\n if (typeof point.x === 'number') {\n var stackItem_1 = stack[point.x.toString()];\n if (stackItem_1) {\n var pointValues = stackItem_1.points[_this.index];\n // If true `stacking` is enabled, count the total\n // number of non-null stacks in the category, and\n // note which index this point is within those\n // stacks.\n if (stacking) {\n if (pointValues) {\n indexInCategory_1 = totalInCategory_1;\n }\n if (stackItem_1.hasValidPoints) {\n reversedStacks_1 ? // #16169\n totalInCategory_1++ : totalInCategory_1--;\n }\n // If `stacking` is not enabled, look for the index\n }\n else if (isArray(pointValues)) {\n // If there are multiple points with the same X\n // then gather all series in category, and\n // assign index\n var seriesIndexes = Object\n .keys(stackItem_1.points)\n .filter(function (pointKey) {\n // Filter out duplicate X's\n return !pointKey.match(',') &&\n // Filter out null points\n stackItem_1.points[pointKey] &&\n stackItem_1.points[pointKey].length > 1;\n })\n .map(parseFloat)\n .sort(function (a, b) { return b - a; });\n indexInCategory_1 = seriesIndexes.indexOf(_this.index);\n totalInCategory_1 = seriesIndexes.length;\n }\n }\n }\n });\n // Compute the adjusted x position\n var boxWidth = (totalInCategory_1 - 1) * metrics.paddedWidth +\n pointWidth;\n x = (point.plotX || 0) + boxWidth / 2 - pointWidth -\n indexInCategory_1 * metrics.paddedWidth;\n }\n return x;\n };\n /**\n * Translate each point to the plot area coordinate system and find\n * shape positions\n *\n * @private\n * @function Highcharts.seriesTypes.column#translate\n */\n ColumnSeries.prototype.translate = function () {\n var series = this,\n chart = series.chart,\n options = series.options,\n dense = series.dense =\n series.closestPointRange * series.xAxis.transA < 2,\n borderWidth = series.borderWidth = pick(options.borderWidth,\n dense ? 0 : 1 // #3635\n ),\n xAxis = series.xAxis,\n yAxis = series.yAxis,\n threshold = options.threshold,\n translatedThreshold = series.translatedThreshold =\n yAxis.getThreshold(threshold),\n minPointLength = pick(options.minPointLength, 5),\n metrics = series.getColumnMetrics(),\n seriesPointWidth = metrics.width,\n seriesXOffset = series.pointXOffset = metrics.offset,\n dataMin = series.dataMin,\n dataMax = series.dataMax;\n // postprocessed for border width\n var seriesBarW = series.barW =\n Math.max(seriesPointWidth, 1 + 2 * borderWidth);\n if (chart.inverted) {\n translatedThreshold -= 0.5; // #3355\n }\n // When the pointPadding is 0, we want the columns to be packed\n // tightly, so we allow individual columns to have individual sizes.\n // When pointPadding is greater, we strive for equal-width columns\n // (#2694).\n if (options.pointPadding) {\n seriesBarW = Math.ceil(seriesBarW);\n }\n Series.prototype.translate.apply(series);\n // Record the new values\n series.points.forEach(function (point) {\n var yBottom = pick(point.yBottom,\n translatedThreshold),\n safeDistance = 999 + Math.abs(yBottom),\n plotX = point.plotX || 0, \n // Don't draw too far outside plot area (#1303, #2241,\n // #4264)\n plotY = clamp(point.plotY, -safeDistance,\n yAxis.len + safeDistance);\n var up,\n barY = Math.min(plotY,\n yBottom),\n barH = Math.max(plotY,\n yBottom) - barY,\n pointWidth = seriesPointWidth,\n barX = plotX + seriesXOffset,\n barW = seriesBarW;\n // Handle options.minPointLength\n if (minPointLength && Math.abs(barH) < minPointLength) {\n barH = minPointLength;\n up = (!yAxis.reversed && !point.negative) ||\n (yAxis.reversed && point.negative);\n // Reverse zeros if there's no positive value in the series\n // in visible range (#7046)\n if (isNumber(threshold) &&\n isNumber(dataMax) &&\n point.y === threshold &&\n dataMax <= threshold &&\n // and if there's room for it (#7311)\n (yAxis.min || 0) < threshold &&\n // if all points are the same value (i.e zero) not draw\n // as negative points (#10646), but only if there's room\n // for it (#14876)\n (dataMin !== dataMax || (yAxis.max || 0) <= threshold)) {\n up = !up;\n }\n // If stacked...\n barY = (Math.abs(barY - translatedThreshold) > minPointLength ?\n // ...keep position\n yBottom - minPointLength :\n // #1485, #4051\n translatedThreshold -\n (up ? minPointLength : 0));\n }\n // Handle point.options.pointWidth\n // @todo Handle grouping/stacking too. Calculate offset properly\n if (defined(point.options.pointWidth)) {\n pointWidth = barW =\n Math.ceil(point.options.pointWidth);\n barX -= Math.round((pointWidth - seriesPointWidth) / 2);\n }\n // Adjust for null or missing points\n if (options.centerInCategory) {\n barX = series.adjustForMissingColumns(barX, pointWidth, point, metrics);\n }\n // Cache for access in polar\n point.barX = barX;\n point.pointWidth = pointWidth;\n // Fix the tooltip on center of grouped columns (#1216, #424,\n // #3648)\n point.tooltipPos = chart.inverted ?\n [\n clamp(yAxis.len + yAxis.pos - chart.plotLeft - plotY, yAxis.pos - chart.plotLeft, yAxis.len + yAxis.pos - chart.plotLeft),\n xAxis.len + xAxis.pos - chart.plotTop - barX - barW / 2,\n barH\n ] :\n [\n xAxis.left - chart.plotLeft + barX + barW / 2,\n clamp(plotY + yAxis.pos -\n chart.plotTop, yAxis.pos - chart.plotTop, yAxis.len + yAxis.pos - chart.plotTop),\n barH\n ];\n // Register shape type and arguments to be used in drawPoints\n // Allow shapeType defined on pointClass level\n point.shapeType = series.pointClass.prototype.shapeType || 'rect';\n point.shapeArgs = series.crispCol.apply(series, point.isNull ?\n // #3169, drilldown from null must have a position to work\n // from #6585, dataLabel should be placed on xAxis, not\n // floating in the middle of the chart\n [barX, translatedThreshold, barW, 0] :\n [barX, barY, barW, barH]);\n });\n };\n /**\n * Columns have no graph\n *\n * @private\n * @function Highcharts.seriesTypes.column#drawGraph\n */\n ColumnSeries.prototype.drawGraph = function () {\n this.group[this.dense ? 'addClass' : 'removeClass']('highcharts-dense-data');\n };\n /**\n * Get presentational attributes\n *\n * @private\n * @function Highcharts.seriesTypes.column#pointAttribs\n */\n ColumnSeries.prototype.pointAttribs = function (point, state) {\n var options = this.options, p2o = this.pointAttrToOptions || {}, strokeOption = p2o.stroke || 'borderColor', strokeWidthOption = p2o['stroke-width'] || 'borderWidth';\n var stateOptions,\n zone,\n brightness,\n fill = (point && point.color) || this.color, \n // set to fill when borderColor null:\n stroke = ((point && point[strokeOption]) ||\n options[strokeOption] ||\n fill),\n dashstyle = (point && point.options.dashStyle) || options.dashStyle,\n strokeWidth = (point && point[strokeWidthOption]) ||\n options[strokeWidthOption] ||\n this[strokeWidthOption] || 0,\n opacity = pick(point && point.opacity,\n options.opacity, 1);\n // Handle zone colors\n if (point && this.zones.length) {\n zone = point.getZone();\n // When zones are present, don't use point.color (#4267).\n // Changed order (#6527), added support for colorAxis (#10670)\n fill = (point.options.color ||\n (zone && (zone.color || point.nonZonedColor)) ||\n this.color);\n if (zone) {\n stroke = zone.borderColor || stroke;\n dashstyle = zone.dashStyle || dashstyle;\n strokeWidth = zone.borderWidth || strokeWidth;\n }\n }\n // Select or hover states\n if (state && point) {\n stateOptions = merge(options.states[state], \n // #6401\n point.options.states &&\n point.options.states[state] ||\n {});\n brightness = stateOptions.brightness;\n fill =\n stateOptions.color || (typeof brightness !== 'undefined' &&\n color(fill)\n .brighten(stateOptions.brightness)\n .get()) || fill;\n stroke = stateOptions[strokeOption] || stroke;\n strokeWidth =\n stateOptions[strokeWidthOption] || strokeWidth;\n dashstyle = stateOptions.dashStyle || dashstyle;\n opacity = pick(stateOptions.opacity, opacity);\n }\n var ret = {\n fill: fill,\n stroke: stroke,\n 'stroke-width': strokeWidth,\n opacity: opacity\n };\n if (dashstyle) {\n ret.dashstyle = dashstyle;\n }\n return ret;\n };\n /**\n * Draw the columns. For bars, the series.group is rotated, so the same\n * coordinates apply for columns and bars. This method is inherited by\n * scatter series.\n *\n * @private\n * @function Highcharts.seriesTypes.column#drawPoints\n */\n ColumnSeries.prototype.drawPoints = function (points) {\n if (points === void 0) { points = this.points; }\n var series = this,\n chart = this.chart,\n options = series.options,\n renderer = chart.renderer,\n animationLimit = options.animationLimit || 250;\n var shapeArgs;\n // draw the columns\n points.forEach(function (point) {\n var plotY = point.plotY;\n var graphic = point.graphic,\n hasGraphic = !!graphic,\n verb = graphic && chart.pointCount < animationLimit ?\n 'animate' : 'attr';\n if (isNumber(plotY) && point.y !== null) {\n shapeArgs = point.shapeArgs;\n // When updating a series between 2d and 3d or cartesian and\n // polar, the shape type changes.\n if (graphic && point.hasNewShapeType()) {\n graphic = graphic.destroy();\n }\n // Set starting position for point sliding animation.\n if (series.enabledDataSorting) {\n point.startXPos = series.xAxis.reversed ?\n -(shapeArgs ? (shapeArgs.width || 0) : 0) :\n series.xAxis.width;\n }\n if (!graphic) {\n point.graphic = graphic =\n renderer[point.shapeType](shapeArgs)\n .add(point.group || series.group);\n if (graphic &&\n series.enabledDataSorting &&\n chart.hasRendered &&\n chart.pointCount < animationLimit) {\n graphic.attr({\n x: point.startXPos\n });\n hasGraphic = true;\n verb = 'animate';\n }\n }\n if (graphic && hasGraphic) { // update\n graphic[verb](merge(shapeArgs));\n }\n // Border radius is not stylable (#6900)\n if (options.borderRadius) {\n graphic[verb]({\n r: options.borderRadius\n });\n }\n // Presentational\n if (!chart.styledMode) {\n graphic[verb](series.pointAttribs(point, (point.selected && 'select')))\n .shadow(point.allowShadow !== false && options.shadow, null, options.stacking && !options.borderRadius);\n }\n if (graphic) {\n graphic.addClass(point.getClassName(), true);\n graphic.attr({\n visibility: point.visible ? 'inherit' : 'hidden'\n });\n }\n }\n else if (graphic) {\n point.graphic = graphic.destroy(); // #1269\n }\n });\n };\n /**\n * Draw the tracker for a point.\n * @private\n */\n ColumnSeries.prototype.drawTracker = function () {\n var series = this,\n chart = series.chart,\n pointer = chart.pointer,\n onMouseOver = function (e) {\n var point = pointer.getPointFromEvent(e);\n // undefined on graph in scatterchart\n if (typeof point !== 'undefined') {\n pointer.isDirectTouch = true;\n point.onMouseOver(e);\n }\n };\n var dataLabels;\n // Add reference to the point\n series.points.forEach(function (point) {\n dataLabels = (isArray(point.dataLabels) ?\n point.dataLabels :\n (point.dataLabel ? [point.dataLabel] : []));\n if (point.graphic) {\n point.graphic.element.point = point;\n }\n dataLabels.forEach(function (dataLabel) {\n if (dataLabel.div) {\n dataLabel.div.point = point;\n }\n else {\n dataLabel.element.point = point;\n }\n });\n });\n // Add the event listeners, we need to do this only once\n if (!series._hasTracking) {\n series.trackerGroups.forEach(function (key) {\n if (series[key]) {\n // we don't always have dataLabelsGroup\n series[key]\n .addClass('highcharts-tracker')\n .on('mouseover', onMouseOver)\n .on('mouseout', function (e) {\n pointer.onTrackerMouseOut(e);\n });\n if (hasTouch) {\n series[key].on('touchstart', onMouseOver);\n }\n if (!chart.styledMode && series.options.cursor) {\n series[key]\n .css(css)\n .css({ cursor: series.options.cursor });\n }\n }\n });\n series._hasTracking = true;\n }\n fireEvent(this, 'afterDrawTracker');\n };\n /**\n * Remove this series from the chart\n *\n * @private\n * @function Highcharts.seriesTypes.column#remove\n */\n ColumnSeries.prototype.remove = function () {\n var series = this,\n chart = series.chart;\n // column and bar series affects other series of the same type\n // as they are either stacked or grouped\n if (chart.hasRendered) {\n chart.series.forEach(function (otherSeries) {\n if (otherSeries.type === series.type) {\n otherSeries.isDirty = true;\n }\n });\n }\n Series.prototype.remove.apply(series, arguments);\n };\n ColumnSeries.defaultOptions = merge(Series.defaultOptions, ColumnSeriesDefaults);\n return ColumnSeries;\n }(Series));\n extend(ColumnSeries.prototype, {\n cropShoulder: 0,\n // When tooltip is not shared, this series (and derivatives) requires\n // direct touch/hover. KD-tree does not apply.\n directTouch: true,\n /**\n * Use a solid rectangle like the area series types\n *\n * @private\n * @function Highcharts.seriesTypes.column#drawLegendSymbol\n *\n * @param {Highcharts.Legend} legend\n * The legend object\n *\n * @param {Highcharts.Series|Highcharts.Point} item\n * The series (this) or point\n */\n drawLegendSymbol: LegendSymbol.drawRectangle,\n getSymbol: noop,\n // use separate negative stacks, unlike area stacks where a negative\n // point is substracted from previous (#1910)\n negStacks: true,\n trackerGroups: ['group', 'dataLabelsGroup']\n });\n SeriesRegistry.registerSeriesType('column', ColumnSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Adjusted width and x offset of the columns for grouping.\n *\n * @private\n * @interface Highcharts.ColumnMetricsObject\n */ /**\n * Width of the columns.\n * @name Highcharts.ColumnMetricsObject#width\n * @type {number}\n */ /**\n * Offset of the columns.\n * @name Highcharts.ColumnMetricsObject#offset\n * @type {number}\n */\n ''; // detach doclets above\n\n return ColumnSeries;\n });\n _registerModule(_modules, 'Core/Series/DataLabel.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/FormatUtilities.js'], _modules['Core/Utilities.js']], function (A, F, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var getDeferredAnimation = A.getDeferredAnimation;\n var format = F.format;\n var defined = U.defined,\n extend = U.extend,\n fireEvent = U.fireEvent,\n isArray = U.isArray,\n isString = U.isString,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick,\n splat = U.splat;\n /* *\n *\n * Composition\n *\n * */\n /* eslint-disable valid-jsdoc */\n var DataLabel;\n (function (DataLabel) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Align each individual data label.\n * @private\n */\n function alignDataLabel(point, dataLabel, options, alignTo, isNew) {\n var series = this,\n chart = this.chart,\n inverted = this.isCartesian && chart.inverted,\n enabledDataSorting = this.enabledDataSorting,\n plotX = pick(point.dlBox && point.dlBox.centerX,\n point.plotX),\n plotY = point.plotY,\n rotation = options.rotation,\n align = options.align,\n isInsidePlot = defined(plotX) &&\n defined(plotY) &&\n chart.isInsidePlot(plotX,\n Math.round(plotY), {\n inverted: inverted,\n paneCoordinates: true,\n series: series\n }),\n setStartPos = function (alignOptions) {\n if (enabledDataSorting && series.xAxis && !justify) {\n series.setDataLabelStartPos(point,\n dataLabel,\n isNew,\n isInsidePlot,\n alignOptions);\n }\n };\n var baseline,\n rotCorr, // rotation correction\n // Math.round for rounding errors (#2683), alignTo to allow column\n // labels (#2700)\n alignAttr, // the final position;\n justify = pick(options.overflow, (enabledDataSorting ? 'none' : 'justify')) === 'justify', visible = this.visible &&\n point.visible !== false &&\n (point.series.forceDL ||\n (enabledDataSorting && !justify) ||\n isInsidePlot ||\n (\n // If the data label is inside the align box, it is\n // enough that parts of the align box is inside the\n // plot area (#12370). When stacking, it is always\n // inside regardless of the option (#15148).\n pick(options.inside, !!this.options.stacking) &&\n alignTo &&\n chart.isInsidePlot(plotX, inverted ?\n alignTo.x + 1 :\n alignTo.y + alignTo.height - 1, {\n inverted: inverted,\n paneCoordinates: true,\n series: series\n })));\n if (visible && defined(plotX) && defined(plotY)) {\n if (rotation) {\n dataLabel.attr({ align: align });\n }\n var bBox = dataLabel.getBBox(true),\n bBoxCorrection = [0, 0];\n baseline = chart.renderer.fontMetrics(chart.styledMode ? void 0 : options.style.fontSize, dataLabel).b;\n // The alignment box is a singular point\n alignTo = extend({\n x: inverted ? this.yAxis.len - plotY : plotX,\n y: Math.round(inverted ? this.xAxis.len - plotX : plotY),\n width: 0,\n height: 0\n }, alignTo);\n // Add the text size for alignment calculation\n extend(options, {\n width: bBox.width,\n height: bBox.height\n });\n // Allow a hook for changing alignment in the last moment, then do\n // the alignment\n if (rotation) {\n justify = false; // Not supported for rotated text\n rotCorr = chart.renderer.rotCorr(baseline, rotation); // #3723\n alignAttr = {\n x: (alignTo.x +\n (options.x || 0) +\n alignTo.width / 2 +\n rotCorr.x),\n y: (alignTo.y +\n (options.y || 0) +\n { top: 0, middle: 0.5, bottom: 1 }[options.verticalAlign] *\n alignTo.height)\n };\n bBoxCorrection = [\n bBox.x - Number(dataLabel.attr('x')),\n bBox.y - Number(dataLabel.attr('y'))\n ];\n setStartPos(alignAttr); // data sorting\n dataLabel[isNew ? 'attr' : 'animate'](alignAttr);\n }\n else {\n setStartPos(alignTo); // data sorting\n dataLabel.align(options, void 0, alignTo);\n alignAttr = dataLabel.alignAttr;\n }\n // Handle justify or crop\n if (justify && alignTo.height >= 0) { // #8830\n this.justifyDataLabel(dataLabel, options, alignAttr, bBox, alignTo, isNew);\n // Now check that the data label is within the plot area\n }\n else if (pick(options.crop, true)) {\n var x = alignAttr.x,\n y = alignAttr.y;\n x += bBoxCorrection[0];\n y += bBoxCorrection[1];\n // Uncomment this block to visualize the bounding boxes used for\n // determining visibility\n /*\n chart.renderer.rect(\n chart.plotLeft + alignAttr.x + bBox.x,\n chart.plotTop + alignAttr.y + bBox.y + 9999,\n bBox.width,\n bBox.height\n ).attr({\n stroke: 'rgba(0, 0, 0, 0.3)',\n 'stroke-width': 0.5\n }).add();\n chart.renderer.circle(\n chart.plotLeft + alignAttr.x,\n chart.plotTop + alignAttr.y,\n 2\n ).attr({\n fill: 'red',\n zIndex: 20\n }).add();\n // */\n visible =\n chart.isInsidePlot(x, y, {\n paneCoordinates: true,\n series: series\n }) &&\n chart.isInsidePlot(x + bBox.width, y + bBox.height, {\n paneCoordinates: true,\n series: series\n });\n }\n // When we're using a shape, make it possible with a connector or an\n // arrow pointing to thie point\n if (options.shape && !rotation) {\n dataLabel[isNew ? 'attr' : 'animate']({\n anchorX: inverted ?\n chart.plotWidth - point.plotY :\n point.plotX,\n anchorY: inverted ?\n chart.plotHeight - point.plotX :\n point.plotY\n });\n }\n }\n // To use alignAttr property in hideOverlappingLabels\n if (isNew && enabledDataSorting) {\n dataLabel.placed = false;\n }\n // Show or hide based on the final aligned position\n if (!visible && (!enabledDataSorting || justify)) {\n dataLabel.hide();\n dataLabel.placed = false; // don't animate back in\n }\n else {\n dataLabel.show();\n }\n }\n /**\n * Handle the dataLabels.filter option.\n * @private\n */\n function applyFilter(point, options) {\n var filter = options.filter;\n if (filter) {\n var op = filter.operator;\n var prop = point[filter.property];\n var val = filter.value;\n if ((op === '>' && prop > val) ||\n (op === '<' && prop < val) ||\n (op === '>=' && prop >= val) ||\n (op === '<=' && prop <= val) ||\n (op === '==' && prop == val) || // eslint-disable-line eqeqeq\n (op === '===' && prop === val)) {\n return true;\n }\n return false;\n }\n return true;\n }\n /**\n * @private\n */\n function compose(SeriesClass) {\n if (composedClasses.indexOf(SeriesClass) === -1) {\n var seriesProto = SeriesClass.prototype;\n composedClasses.push(SeriesClass);\n seriesProto.alignDataLabel = alignDataLabel;\n seriesProto.drawDataLabels = drawDataLabels;\n seriesProto.justifyDataLabel = justifyDataLabel;\n seriesProto.setDataLabelStartPos = setDataLabelStartPos;\n }\n }\n DataLabel.compose = compose;\n /**\n * Draw the data labels\n * @private\n */\n function drawDataLabels(points) {\n if (points === void 0) { points = this.points; }\n var series = this,\n chart = series.chart,\n seriesOptions = series.options,\n hasRendered = series.hasRendered || 0,\n renderer = chart.renderer,\n _a = chart.options.chart,\n backgroundColor = _a.backgroundColor,\n plotBackgroundColor = _a.plotBackgroundColor,\n contrastColor = renderer.getContrast((isString(plotBackgroundColor) && plotBackgroundColor) ||\n (isString(backgroundColor) && backgroundColor) ||\n \"#000000\" /* Palette.neutralColor100 */);\n var seriesDlOptions = seriesOptions.dataLabels,\n pointOptions,\n dataLabelsGroup;\n var dataLabelAnim = seriesDlOptions.animation,\n animationConfig = seriesDlOptions.defer ?\n getDeferredAnimation(chart,\n dataLabelAnim,\n series) :\n { defer: 0,\n duration: 0 };\n // Merge in plotOptions.dataLabels for series\n seriesDlOptions = mergeArrays(mergeArrays(chart.options.plotOptions &&\n chart.options.plotOptions.series &&\n chart.options.plotOptions.series.dataLabels, chart.options.plotOptions &&\n chart.options.plotOptions[series.type] &&\n chart.options.plotOptions[series.type].dataLabels), seriesDlOptions);\n fireEvent(this, 'drawDataLabels');\n if (isArray(seriesDlOptions) ||\n seriesDlOptions.enabled ||\n series._hasPointLabels) {\n // Create a separate group for the data labels to avoid rotation\n dataLabelsGroup = series.plotGroup('dataLabelsGroup', 'data-labels', !hasRendered ? 'hidden' : 'inherit', // #5133, #10220\n seriesDlOptions.zIndex || 6);\n dataLabelsGroup.attr({ opacity: +hasRendered }); // #3300\n if (!hasRendered) {\n var group = series.dataLabelsGroup;\n if (group) {\n if (series.visible) { // #2597, #3023, #3024\n dataLabelsGroup.show();\n }\n group[seriesOptions.animation ? 'animate' : 'attr']({ opacity: 1 }, animationConfig);\n }\n }\n // Make the labels for each point\n points.forEach(function (point) {\n // Merge in series options for the point.\n // @note dataLabelAttribs (like pointAttribs) would eradicate\n // the need for dlOptions, and simplify the section below.\n pointOptions = splat(mergeArrays(seriesDlOptions, \n // dlOptions is used in treemaps\n (point.dlOptions ||\n (point.options && point.options.dataLabels))));\n // Handle each individual data label for this point\n pointOptions.forEach(function (labelOptions, i) {\n // Options for one datalabel\n var labelEnabled = (labelOptions.enabled &&\n // #2282, #4641, #7112, #10049\n (!point.isNull || point.dataLabelOnNull) &&\n applyFilter(point,\n labelOptions)),\n connector = point.connectors ?\n point.connectors[i] :\n point.connector;\n var labelConfig,\n formatString,\n labelText,\n style,\n rotation,\n attr,\n dataLabel = point.dataLabels ?\n point.dataLabels[i] : point.dataLabel,\n isNew = !dataLabel;\n var labelDistance = pick(labelOptions.distance,\n point.labelDistance);\n if (labelEnabled) {\n // Create individual options structure that can be\n // extended without affecting others\n labelConfig = point.getLabelConfig();\n formatString = pick(labelOptions[point.formatPrefix + 'Format'], labelOptions.format);\n labelText = defined(formatString) ?\n format(formatString, labelConfig, chart) :\n (labelOptions[point.formatPrefix + 'Formatter'] ||\n labelOptions.formatter).call(labelConfig, labelOptions);\n style = labelOptions.style;\n rotation = labelOptions.rotation;\n if (!chart.styledMode) {\n // Determine the color\n style.color = pick(labelOptions.color, style.color, series.color, \"#000000\" /* Palette.neutralColor100 */);\n // Get automated contrast color\n if (style.color === 'contrast') {\n point.contrastColor = renderer.getContrast((point.color || series.color));\n style.color = (!defined(labelDistance) &&\n labelOptions.inside) ||\n labelDistance < 0 ||\n !!seriesOptions.stacking ?\n point.contrastColor :\n contrastColor;\n }\n else {\n delete point.contrastColor;\n }\n if (seriesOptions.cursor) {\n style.cursor = seriesOptions.cursor;\n }\n }\n attr = {\n r: labelOptions.borderRadius || 0,\n rotation: rotation,\n padding: labelOptions.padding,\n zIndex: 1\n };\n if (!chart.styledMode) {\n attr.fill = labelOptions.backgroundColor;\n attr.stroke = labelOptions.borderColor;\n attr['stroke-width'] = labelOptions.borderWidth;\n }\n // Remove unused attributes (#947)\n objectEach(attr, function (val, name) {\n if (typeof val === 'undefined') {\n delete attr[name];\n }\n });\n }\n // If the point is outside the plot area, destroy it. #678,\n // #820\n if (dataLabel && (!labelEnabled ||\n !defined(labelText) ||\n !!dataLabel.div !== !!labelOptions.useHTML ||\n (\n // Change from no rotation to rotation and\n // vice versa. Don't use defined() because\n // rotation = 0 means also rotation = undefined\n (!dataLabel.rotation ||\n !labelOptions.rotation) &&\n dataLabel.rotation !== labelOptions.rotation))) {\n isNew = true;\n point.dataLabel = dataLabel =\n point.dataLabel && point.dataLabel.destroy();\n if (point.dataLabels) {\n // Remove point.dataLabels if this was the last one\n if (point.dataLabels.length === 1) {\n delete point.dataLabels;\n }\n else {\n delete point.dataLabels[i];\n }\n }\n if (!i) {\n delete point.dataLabel;\n }\n if (connector) {\n point.connector = point.connector.destroy();\n if (point.connectors) {\n // Remove point.connectors if this was the last\n // one\n if (point.connectors.length === 1) {\n delete point.connectors;\n }\n else {\n delete point.connectors[i];\n }\n }\n }\n }\n // Individual labels are disabled if the are explicitly\n // disabled in the point options, or if they fall outside\n // the plot area.\n if (labelEnabled && defined(labelText)) {\n if (!dataLabel) {\n // Create new label element\n point.dataLabels = point.dataLabels || [];\n dataLabel = point.dataLabels[i] = rotation ?\n // Labels don't rotate, use text element\n renderer.text(labelText, 0, 0, labelOptions.useHTML)\n .addClass('highcharts-data-label') :\n // We can use label\n renderer.label(labelText, 0, 0, labelOptions.shape, null, null, labelOptions.useHTML, null, 'data-label');\n // Store for backwards compatibility\n if (!i) {\n point.dataLabel = dataLabel;\n }\n dataLabel.addClass(' highcharts-data-label-color-' +\n point.colorIndex +\n ' ' + (labelOptions.className || '') +\n ( // #3398\n labelOptions.useHTML ?\n ' highcharts-tracker' :\n ''));\n }\n else {\n // Use old element and just update text\n attr.text = labelText;\n }\n // Store data label options for later access\n dataLabel.options = labelOptions;\n dataLabel.attr(attr);\n if (!chart.styledMode) {\n // Styles must be applied before add in order to\n // read text bounding box\n dataLabel.css(style).shadow(labelOptions.shadow);\n }\n var textPathOptions = labelOptions[point.formatPrefix + 'TextPath'] ||\n labelOptions.textPath;\n if (textPathOptions && !labelOptions.useHTML) {\n dataLabel.setTextPath((point.getDataLabelPath &&\n point.getDataLabelPath(dataLabel)) || point.graphic, textPathOptions);\n if (point.dataLabelPath &&\n !textPathOptions.enabled) {\n // clean the DOM\n point.dataLabelPath = (point.dataLabelPath.destroy());\n }\n }\n if (!dataLabel.added) {\n dataLabel.add(dataLabelsGroup);\n }\n // Now the data label is created and placed at 0,0, so\n // we need to align it\n series.alignDataLabel(point, dataLabel, labelOptions, null, isNew);\n }\n else if (dataLabel) {\n dataLabel.hide();\n }\n });\n });\n }\n fireEvent(this, 'afterDrawDataLabels');\n }\n /**\n * If data labels fall partly outside the plot area, align them back in, in\n * a way that doesn't hide the point.\n * @private\n */\n function justifyDataLabel(dataLabel, options, alignAttr, bBox, alignTo, isNew) {\n var chart = this.chart,\n align = options.align,\n verticalAlign = options.verticalAlign,\n padding = dataLabel.box ? 0 : (dataLabel.padding || 0);\n var _a = options.x,\n x = _a === void 0 ? 0 : _a,\n _b = options.y,\n y = _b === void 0 ? 0 : _b,\n off,\n justified;\n // Off left\n off = (alignAttr.x || 0) + padding;\n if (off < 0) {\n if (align === 'right' && x >= 0) {\n options.align = 'left';\n options.inside = true;\n }\n else {\n x -= off;\n }\n justified = true;\n }\n // Off right\n off = (alignAttr.x || 0) + bBox.width - padding;\n if (off > chart.plotWidth) {\n if (align === 'left' && x <= 0) {\n options.align = 'right';\n options.inside = true;\n }\n else {\n x += chart.plotWidth - off;\n }\n justified = true;\n }\n // Off top\n off = alignAttr.y + padding;\n if (off < 0) {\n if (verticalAlign === 'bottom' && y >= 0) {\n options.verticalAlign = 'top';\n options.inside = true;\n }\n else {\n y -= off;\n }\n justified = true;\n }\n // Off bottom\n off = (alignAttr.y || 0) + bBox.height - padding;\n if (off > chart.plotHeight) {\n if (verticalAlign === 'top' && y <= 0) {\n options.verticalAlign = 'bottom';\n options.inside = true;\n }\n else {\n y += chart.plotHeight - off;\n }\n justified = true;\n }\n if (justified) {\n options.x = x;\n options.y = y;\n dataLabel.placed = !isNew;\n dataLabel.align(options, void 0, alignTo);\n }\n return justified;\n }\n /**\n * Merge two objects that can be arrays. If one of them is an array, the\n * other is merged into each element. If both are arrays, each element is\n * merged by index. If neither are arrays, we use normal merge.\n * @private\n */\n function mergeArrays(one, two) {\n var res = [],\n i;\n if (isArray(one) && !isArray(two)) {\n res = one.map(function (el) {\n return merge(el, two);\n });\n }\n else if (isArray(two) && !isArray(one)) {\n res = two.map(function (el) {\n return merge(one, el);\n });\n }\n else if (!isArray(one) && !isArray(two)) {\n res = merge(one, two);\n }\n else {\n i = Math.max(one.length, two.length);\n while (i--) {\n res[i] = merge(one[i], two[i]);\n }\n }\n return res;\n }\n /**\n * Set starting position for data label sorting animation.\n * @private\n */\n function setDataLabelStartPos(point, dataLabel, isNew, isInside, alignOptions) {\n var chart = this.chart,\n inverted = chart.inverted,\n xAxis = this.xAxis,\n reversed = xAxis.reversed,\n labelCenter = inverted ? dataLabel.height / 2 : dataLabel.width / 2,\n pointWidth = point.pointWidth,\n halfWidth = pointWidth ? pointWidth / 2 : 0;\n dataLabel.startXPos = inverted ?\n alignOptions.x :\n (reversed ?\n -labelCenter - halfWidth :\n xAxis.width - labelCenter + halfWidth);\n dataLabel.startYPos = inverted ?\n (reversed ?\n this.yAxis.height - labelCenter + halfWidth :\n -labelCenter - halfWidth) : alignOptions.y;\n // We need to handle visibility in case of sorting point outside plot\n // area\n if (!isInside) {\n dataLabel\n .attr({ opacity: 1 })\n .animate({ opacity: 0 }, void 0, dataLabel.hide);\n }\n else if (dataLabel.visibility === 'hidden') {\n dataLabel.show();\n dataLabel\n .attr({ opacity: 0 })\n .animate({ opacity: 1 });\n }\n // Save start position on first render, but do not change position\n if (!chart.hasRendered) {\n return;\n }\n // Set start position\n if (isNew) {\n dataLabel.attr({ x: dataLabel.startXPos, y: dataLabel.startYPos });\n }\n dataLabel.placed = true;\n }\n })(DataLabel || (DataLabel = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Callback JavaScript function to format the data label as a string. Note that\n * if a `format` is defined, the format takes precedence and the formatter is\n * ignored.\n *\n * @callback Highcharts.DataLabelsFormatterCallbackFunction\n *\n * @param {Highcharts.PointLabelObject} this\n * Data label context to format\n *\n * @param {Highcharts.DataLabelsOptions} options\n * [API options](/highcharts/plotOptions.series.dataLabels) of the data label\n *\n * @return {number|string|null|undefined}\n * Formatted data label text\n */\n /**\n * Values for handling data labels that flow outside the plot area.\n *\n * @typedef {\"allow\"|\"justify\"} Highcharts.DataLabelsOverflowValue\n */\n ''; // keeps doclets above in JS file\n\n return DataLabel;\n });\n _registerModule(_modules, 'Series/Column/ColumnDataLabel.js', [_modules['Core/Series/DataLabel.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (DataLabel, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var Series = SeriesRegistry.series;\n var merge = U.merge,\n pick = U.pick;\n /* *\n *\n * Composition\n *\n * */\n var ColumnDataLabel;\n (function (ColumnDataLabel) {\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Override the basic data label alignment by adjusting for the position of\n * the column.\n * @private\n */\n function alignDataLabel(point, dataLabel, options, alignTo, isNew) {\n var inverted = this.chart.inverted,\n series = point.series,\n xLen = (series.xAxis ? series.xAxis.len : this.chart.plotSizeX) || 0,\n yLen = (series.yAxis ? series.yAxis.len : this.chart.plotSizeY) || 0, \n // data label box for alignment\n dlBox = point.dlBox || point.shapeArgs,\n below = pick(point.below, // range series\n point.plotY >\n pick(this.translatedThreshold,\n yLen)), \n // draw it inside the box?\n inside = pick(options.inside, !!this.options.stacking),\n overshoot;\n // Align to the column itself, or the top of it\n if (dlBox) { // Area range uses this method but not alignTo\n alignTo = merge(dlBox);\n if (alignTo.y < 0) {\n alignTo.height += alignTo.y;\n alignTo.y = 0;\n }\n // If parts of the box overshoots outside the plot area, modify the\n // box to center the label inside\n overshoot = alignTo.y + alignTo.height - yLen;\n if (overshoot > 0 && overshoot < alignTo.height) {\n alignTo.height -= overshoot;\n }\n if (inverted) {\n alignTo = {\n x: yLen - alignTo.y - alignTo.height,\n y: xLen - alignTo.x - alignTo.width,\n width: alignTo.height,\n height: alignTo.width\n };\n }\n // Compute the alignment box\n if (!inside) {\n if (inverted) {\n alignTo.x += below ? 0 : alignTo.width;\n alignTo.width = 0;\n }\n else {\n alignTo.y += below ? alignTo.height : 0;\n alignTo.height = 0;\n }\n }\n }\n // When alignment is undefined (typically columns and bars), display the\n // individual point below or above the point depending on the threshold\n options.align = pick(options.align, !inverted || inside ? 'center' : below ? 'right' : 'left');\n options.verticalAlign = pick(options.verticalAlign, inverted || inside ? 'middle' : below ? 'top' : 'bottom');\n // Call the parent method\n Series.prototype.alignDataLabel.call(this, point, dataLabel, options, alignTo, isNew);\n // If label was justified and we have contrast, set it:\n if (options.inside && point.contrastColor) {\n dataLabel.css({\n color: point.contrastColor\n });\n }\n }\n /** @private */\n function compose(ColumnSeriesClass) {\n DataLabel.compose(Series);\n if (composedClasses.indexOf(ColumnSeriesClass) === -1) {\n composedClasses.push(ColumnSeriesClass);\n ColumnSeriesClass.prototype.alignDataLabel = alignDataLabel;\n }\n }\n ColumnDataLabel.compose = compose;\n })(ColumnDataLabel || (ColumnDataLabel = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return ColumnDataLabel;\n });\n _registerModule(_modules, 'Series/Bar/BarSeries.js', [_modules['Series/Column/ColumnSeries.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (ColumnSeries, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var extend = U.extend,\n merge = U.merge;\n /* *\n *\n * Class\n *\n * */\n /**\n * Bar series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.bar\n *\n * @augments Highcharts.Series\n */\n var BarSeries = /** @class */ (function (_super) {\n __extends(BarSeries, _super);\n function BarSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.data = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n }\n /**\n * A bar series is a special type of column series where the columns are\n * horizontal.\n *\n * @sample highcharts/demo/bar-basic/\n * Bar chart\n *\n * @extends plotOptions.column\n * @product highcharts\n * @optionparent plotOptions.bar\n */\n BarSeries.defaultOptions = merge(ColumnSeries.defaultOptions, {\n // nothing here yet\n });\n return BarSeries;\n }(ColumnSeries));\n extend(BarSeries.prototype, {\n inverted: true\n });\n SeriesRegistry.registerSeriesType('bar', BarSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A `bar` series. If the [type](#series.bar.type) option is not specified,\n * it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.bar\n * @excluding connectNulls, dashStyle, dataParser, dataURL, gapSize, gapUnit,\n * linecap, lineWidth, marker, connectEnds, step\n * @product highcharts\n * @apioption series.bar\n */\n /**\n * An array of data points for the series. For the `bar` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 5],\n * [1, 10],\n * [2, 3]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.bar.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 1,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 10,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.column.data\n * @product highcharts\n * @apioption series.bar.data\n */\n /**\n * @excluding halo,lineWidth,lineWidthPlus,marker\n * @product highcharts highstock\n * @apioption series.bar.states.hover\n */\n /**\n * @excluding halo,lineWidth,lineWidthPlus,marker\n * @product highcharts highstock\n * @apioption series.bar.states.select\n */\n ''; // gets doclets above into transpilat\n\n return BarSeries;\n });\n _registerModule(_modules, 'Series/Scatter/ScatterSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A scatter plot uses cartesian coordinates to display values for two\n * variables for a set of data.\n *\n * @sample {highcharts} highcharts/demo/scatter/\n * Scatter plot\n *\n * @extends plotOptions.line\n * @excluding cropThreshold, pointPlacement, shadow, useOhlcData\n * @product highcharts highstock\n * @optionparent plotOptions.scatter\n */\n var ScatterSeriesDefaults = {\n /**\n * The width of the line connecting the data points.\n *\n * @sample {highcharts} highcharts/plotoptions/scatter-linewidth-none/\n * 0 by default\n * @sample {highcharts} highcharts/plotoptions/scatter-linewidth-1/\n * 1px\n *\n * @product highcharts highstock\n */\n lineWidth: 0,\n findNearestPointBy: 'xy',\n /**\n * Apply a jitter effect for the rendered markers. When plotting\n * discrete values,\n a little random noise may help telling the points\n * apart. The jitter setting applies a random displacement of up to `n`\n * axis units in either direction. So for example on a horizontal X\n * axis,\n setting the `jitter.x` to 0.24 will render the point in a\n * random position between 0.24 units to the left and 0.24 units to the\n * right of the true axis position. On a category axis,\n setting it to\n * 0.5 will fill up the bin and make the data appear continuous.\n *\n * When rendered on top of a box plot or a column series,\n a jitter value\n * of 0.24 will correspond to the underlying series' default\n * [groupPadding](\n * https://api.highcharts.com/highcharts/plotOptions.column.groupPadding)\n * and [pointPadding](\n * https://api.highcharts.com/highcharts/plotOptions.column.pointPadding)\n * settings.\n *\n * @sample {highcharts} highcharts/series-scatter/jitter\n * Jitter on a scatter plot\n *\n * @sample {highcharts} highcharts/series-scatter/jitter-boxplot\n * Jittered scatter plot on top of a box plot\n *\n * @product highcharts highstock\n * @since 7.0.2\n */\n jitter: {\n /**\n * The maximal X offset for the random jitter effect.\n */\n x: 0,\n /**\n * The maximal Y offset for the random jitter effect.\n */\n y: 0\n },\n marker: {\n enabled: true // Overrides auto-enabling in line series (#3647)\n },\n /**\n * Sticky tracking of mouse events. When true,\n the `mouseOut` event\n * on a series isn't triggered until the mouse moves over another\n * series,\n or out of the plot area. When false,\n the `mouseOut` event on\n * a series is triggered when the mouse leaves the area around the\n * series' graph or markers. This also implies the tooltip. When\n * `stickyTracking` is false and `tooltip.shared` is false,\n the tooltip\n * will be hidden when moving the mouse between series.\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock highmaps\n * @apioption plotOptions.scatter.stickyTracking\n */\n /**\n * A configuration object for the tooltip rendering of each single\n * series. Properties are inherited from [tooltip](#tooltip).\n * Overridable properties are `headerFormat`,\n `pointFormat`,\n * `yDecimals`,\n `xDateFormat`,\n `yPrefix` and `ySuffix`. Unlike other\n * series,\n in a scatter plot the series.name by default shows in the\n * headerFormat and point.x and point.y in the pointFormat.\n *\n * @product highcharts highstock highmaps\n */\n tooltip: {\n /**\n * @product highcharts highstock\n */\n headerFormat: '\\u25CF ' +\n ' {series.name}
',\n pointFormat: 'x: {point.x}
y: {point.y}
'\n }\n };\n /**\n * A `scatter` series. If the [type](#series.scatter.type) option is\n * not specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.scatter\n * @excluding cropThreshold, dataParser, dataURL, useOhlcData\n * @product highcharts highstock\n * @apioption series.scatter\n */\n /**\n * An array of data points for the series. For the `scatter` series\n * type, points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 0],\n * [1, 8],\n * [2, 9]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.scatter.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 2,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 4,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @product highcharts highstock\n * @apioption series.scatter.data\n */\n ''; // keeps doclets above in JS file\n /* *\n *\n * Default Export\n *\n * */\n\n return ScatterSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Scatter/ScatterSeries.js', [_modules['Series/Scatter/ScatterSeriesDefaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (ScatterSeriesDefaults, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var _a = SeriesRegistry.seriesTypes,\n ColumnSeries = _a.column,\n LineSeries = _a.line;\n var addEvent = U.addEvent,\n extend = U.extend,\n merge = U.merge;\n /* *\n *\n * Class\n *\n * */\n /**\n * Scatter series type.\n *\n * @private\n */\n var ScatterSeries = /** @class */ (function (_super) {\n __extends(ScatterSeries, _super);\n function ScatterSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.data = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Optionally add the jitter effect.\n * @private\n */\n ScatterSeries.prototype.applyJitter = function () {\n var series = this,\n jitter = this.options.jitter,\n len = this.points.length;\n /**\n * Return a repeatable, pseudo-random number based on an integer\n * seed.\n * @private\n */\n function unrandom(seed) {\n var rand = Math.sin(seed) * 10000;\n return rand - Math.floor(rand);\n }\n if (jitter) {\n this.points.forEach(function (point, i) {\n ['x', 'y'].forEach(function (dim, j) {\n var axis,\n plotProp = 'plot' + dim.toUpperCase(),\n min,\n max,\n translatedJitter;\n if (jitter[dim] && !point.isNull) {\n axis = series[dim + 'Axis'];\n translatedJitter =\n jitter[dim] * axis.transA;\n if (axis && !axis.isLog) {\n // Identify the outer bounds of the jitter range\n min = Math.max(0, point[plotProp] - translatedJitter);\n max = Math.min(axis.len, point[plotProp] + translatedJitter);\n // Find a random position within this range\n point[plotProp] = min +\n (max - min) * unrandom(i + j * len);\n // Update clientX for the tooltip k-d-tree\n if (dim === 'x') {\n point.clientX = point.plotX;\n }\n }\n }\n });\n });\n }\n };\n /**\n * @private\n */\n ScatterSeries.prototype.drawGraph = function () {\n if (this.options.lineWidth) {\n _super.prototype.drawGraph.call(this);\n }\n else if (this.graph) {\n this.graph = this.graph.destroy();\n }\n };\n ScatterSeries.defaultOptions = merge(LineSeries.defaultOptions, ScatterSeriesDefaults);\n return ScatterSeries;\n }(LineSeries));\n extend(ScatterSeries.prototype, {\n drawTracker: ColumnSeries.prototype.drawTracker,\n sorted: false,\n requireSorting: false,\n noSharedTooltip: true,\n trackerGroups: ['group', 'markerGroup', 'dataLabelsGroup'],\n takeOrdinalPosition: false // #2342\n });\n /* *\n *\n * Events\n *\n * */\n /* eslint-disable no-invalid-this */\n addEvent(ScatterSeries, 'afterTranslate', function () {\n this.applyJitter();\n });\n SeriesRegistry.registerSeriesType('scatter', ScatterSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return ScatterSeries;\n });\n _registerModule(_modules, 'Series/CenteredUtilities.js', [_modules['Core/Globals.js'], _modules['Core/Series/Series.js'], _modules['Core/Utilities.js']], function (H, Series, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var deg2rad = H.deg2rad;\n var fireEvent = U.fireEvent,\n isNumber = U.isNumber,\n pick = U.pick,\n relativeLength = U.relativeLength;\n /**\n * @private\n */\n var CenteredUtilities;\n (function (CenteredUtilities) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Get the center of the pie based on the size and center options relative\n * to the plot area. Borrowed by the polar and gauge series types.\n *\n * @private\n * @function Highcharts.CenteredSeriesMixin.getCenter\n */\n function getCenter() {\n var options = this.options,\n chart = this.chart,\n slicingRoom = 2 * (options.slicedOffset || 0),\n plotWidth = chart.plotWidth - 2 * slicingRoom,\n plotHeight = chart.plotHeight - 2 * slicingRoom,\n centerOption = options.center,\n smallestSize = Math.min(plotWidth,\n plotHeight),\n thickness = options.thickness;\n var handleSlicingRoom,\n size = options.size,\n innerSize = options.innerSize || 0,\n i,\n value;\n if (typeof size === 'string') {\n size = parseFloat(size);\n }\n if (typeof innerSize === 'string') {\n innerSize = parseFloat(innerSize);\n }\n var positions = [\n pick(centerOption[0], '50%'),\n pick(centerOption[1], '50%'),\n // Prevent from negative values\n pick(size && size < 0 ? void 0 : options.size, '100%'),\n pick(innerSize && innerSize < 0 ? void 0 : options.innerSize || 0, '0%')\n ];\n // No need for inner size in angular (gauges) series but still required\n // for pie series\n if (chart.angular && !(this instanceof Series)) {\n positions[3] = 0;\n }\n for (i = 0; i < 4; ++i) {\n value = positions[i];\n handleSlicingRoom = i < 2 || (i === 2 && /%$/.test(value));\n // i == 0: centerX, relative to width\n // i == 1: centerY, relative to height\n // i == 2: size, relative to smallestSize\n // i == 3: innerSize, relative to size\n positions[i] = relativeLength(value, [plotWidth, plotHeight, smallestSize, positions[2]][i]) + (handleSlicingRoom ? slicingRoom : 0);\n }\n // innerSize cannot be larger than size (#3632)\n if (positions[3] > positions[2]) {\n positions[3] = positions[2];\n }\n // thickness overrides innerSize, need to be less than pie size (#6647)\n if (isNumber(thickness) &&\n thickness * 2 < positions[2] && thickness > 0) {\n positions[3] = positions[2] - thickness * 2;\n }\n fireEvent(this, 'afterGetCenter', { positions: positions });\n return positions;\n }\n CenteredUtilities.getCenter = getCenter;\n /**\n * getStartAndEndRadians - Calculates start and end angles in radians.\n * Used in series types such as pie and sunburst.\n *\n * @private\n * @function Highcharts.CenteredSeriesMixin.getStartAndEndRadians\n *\n * @param {number} [start]\n * Start angle in degrees.\n *\n * @param {number} [end]\n * Start angle in degrees.\n *\n * @return {Highcharts.RadianAngles}\n * Returns an object containing start and end angles as radians.\n */\n function getStartAndEndRadians(start, end) {\n var startAngle = isNumber(start) ? start : 0, // must be a number\n endAngle = ((isNumber(end) && // must be a number\n end > startAngle && // must be larger than the start angle\n // difference must be less than 360 degrees\n (end - startAngle) < 360) ?\n end :\n startAngle + 360),\n correction = -90;\n return {\n start: deg2rad * (startAngle + correction),\n end: deg2rad * (endAngle + correction)\n };\n }\n CenteredUtilities.getStartAndEndRadians = getStartAndEndRadians;\n })(CenteredUtilities || (CenteredUtilities = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @private\n * @interface Highcharts.RadianAngles\n */ /**\n * @name Highcharts.RadianAngles#end\n * @type {number}\n */ /**\n * @name Highcharts.RadianAngles#start\n * @type {number}\n */\n ''; // keeps doclets above in JS file\n\n return CenteredUtilities;\n });\n _registerModule(_modules, 'Series/Pie/PiePoint.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Series/Point.js'], _modules['Core/Utilities.js']], function (A, Point, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var setAnimation = A.setAnimation;\n var addEvent = U.addEvent,\n defined = U.defined,\n extend = U.extend,\n isNumber = U.isNumber,\n pick = U.pick,\n relativeLength = U.relativeLength;\n /* *\n *\n * Class\n *\n * */\n var PiePoint = /** @class */ (function (_super) {\n __extends(PiePoint, _super);\n function PiePoint() {\n /* *\n *\n * Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n _this.labelDistance = void 0;\n _this.options = void 0;\n _this.series = void 0;\n return _this;\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Extendable method for getting the path of the connector between the\n * data label and the pie slice.\n * @private\n */\n PiePoint.prototype.getConnectorPath = function () {\n var labelPosition = this.labelPosition,\n options = this.series.options.dataLabels,\n predefinedShapes = this.connectorShapes;\n var connectorShape = options.connectorShape;\n // find out whether to use the predefined shape\n if (predefinedShapes[connectorShape]) {\n connectorShape = predefinedShapes[connectorShape];\n }\n return connectorShape.call(this, {\n // pass simplified label position object for user's convenience\n x: labelPosition.final.x,\n y: labelPosition.final.y,\n alignment: labelPosition.alignment\n }, labelPosition.connectorPosition, options);\n };\n /**\n * @private\n */\n PiePoint.prototype.getTranslate = function () {\n return this.sliced ? this.slicedTranslation : {\n translateX: 0,\n translateY: 0\n };\n };\n /**\n * @private\n */\n PiePoint.prototype.haloPath = function (size) {\n var shapeArgs = this.shapeArgs;\n return this.sliced || !this.visible ?\n [] :\n this.series.chart.renderer.symbols.arc(shapeArgs.x, shapeArgs.y, shapeArgs.r + size, shapeArgs.r + size, {\n // Substract 1px to ensure the background is not bleeding\n // through between the halo and the slice (#7495).\n innerR: shapeArgs.r - 1,\n start: shapeArgs.start,\n end: shapeArgs.end\n });\n };\n /**\n * Initialize the pie slice.\n * @private\n */\n PiePoint.prototype.init = function () {\n var _this = this;\n _super.prototype.init.apply(this, arguments);\n this.name = pick(this.name, 'Slice');\n // add event listener for select\n var toggleSlice = function (e) {\n _this.slice(e.type === 'select');\n };\n addEvent(this, 'select', toggleSlice);\n addEvent(this, 'unselect', toggleSlice);\n return this;\n };\n /**\n * Negative points are not valid (#1530, #3623, #5322)\n * @private\n */\n PiePoint.prototype.isValid = function () {\n return isNumber(this.y) && this.y >= 0;\n };\n /**\n * Toggle the visibility of a pie slice or other data point. Note that this\n * method is available only for some series, like pie, treemap and sunburst.\n *\n * @function Highcharts.Point#setVisible\n *\n * @param {boolean} [vis]\n * True to show the pie slice or other data point, false to hide. If\n * undefined, the visibility is toggled.\n *\n * @param {boolean} [redraw] Whether to redraw the chart after the point is\n * altered. If doing more operations on the chart, it is a good idea to set\n * redraw to false and call {@link Chart#redraw|chart.redraw()} after.\n *\n */\n PiePoint.prototype.setVisible = function (vis, redraw) {\n var _this = this;\n var series = this.series,\n chart = series.chart,\n ignoreHiddenPoint = series.options.ignoreHiddenPoint;\n redraw = pick(redraw, ignoreHiddenPoint);\n if (vis !== this.visible) {\n // If called without an argument, toggle visibility\n this.visible = this.options.visible = vis =\n typeof vis === 'undefined' ? !this.visible : vis;\n // update userOptions.data\n series.options.data[series.data.indexOf(this)] =\n this.options;\n // Show and hide associated elements. This is performed\n // regardless of redraw or not, because chart.redraw only\n // handles full series.\n ['graphic', 'dataLabel', 'connector', 'shadowGroup'].forEach(function (key) {\n if (_this[key]) {\n _this[key][vis ? 'show' : 'hide'](vis);\n }\n });\n if (this.legendItem) {\n chart.legend.colorizeItem(this, vis);\n }\n // #4170, hide halo after hiding point\n if (!vis && this.state === 'hover') {\n this.setState('');\n }\n // Handle ignore hidden slices\n if (ignoreHiddenPoint) {\n series.isDirty = true;\n }\n if (redraw) {\n chart.redraw();\n }\n }\n };\n /**\n * Set or toggle whether the slice is cut out from the pie.\n * @private\n *\n * @param {boolean} sliced\n * When undefined, the slice state is toggled.\n *\n * @param {boolean} [redraw]\n * Whether to redraw the chart. True by default.\n *\n * @param {boolean|Partial} [animation]\n * Animation options.\n */\n PiePoint.prototype.slice = function (sliced, redraw, animation) {\n var series = this.series,\n chart = series.chart;\n setAnimation(animation, chart);\n // redraw is true by default\n redraw = pick(redraw, true);\n /**\n * Pie series only. Whether to display a slice offset from the\n * center.\n * @name Highcharts.Point#sliced\n * @type {boolean|undefined}\n */\n // if called without an argument, toggle\n this.sliced = this.options.sliced = sliced =\n defined(sliced) ? sliced : !this.sliced;\n // update userOptions.data\n series.options.data[series.data.indexOf(this)] =\n this.options;\n if (this.graphic) {\n this.graphic.animate(this.getTranslate());\n }\n if (this.shadowGroup) {\n this.shadowGroup.animate(this.getTranslate());\n }\n };\n return PiePoint;\n }(Point));\n extend(PiePoint.prototype, {\n connectorShapes: {\n // only one available before v7.0.0\n fixedOffset: function (labelPosition, connectorPosition, options) {\n var breakAt = connectorPosition.breakAt,\n touchingSliceAt = connectorPosition.touchingSliceAt,\n lineSegment = options.softConnector ? [\n 'C',\n // 1st control point (of the curve)\n labelPosition.x +\n // 5 gives the connector a little horizontal bend\n (labelPosition.alignment === 'left' ? -5 : 5),\n labelPosition.y,\n 2 * breakAt.x - touchingSliceAt.x,\n 2 * breakAt.y - touchingSliceAt.y,\n breakAt.x,\n breakAt.y //\n ] : [\n 'L',\n breakAt.x,\n breakAt.y\n ];\n // assemble the path\n return ([\n ['M', labelPosition.x, labelPosition.y],\n lineSegment,\n ['L', touchingSliceAt.x, touchingSliceAt.y]\n ]);\n },\n straight: function (labelPosition, connectorPosition) {\n var touchingSliceAt = connectorPosition.touchingSliceAt;\n // direct line to the slice\n return [\n ['M', labelPosition.x, labelPosition.y],\n ['L', touchingSliceAt.x, touchingSliceAt.y]\n ];\n },\n crookedLine: function (labelPosition, connectorPosition, options) {\n var touchingSliceAt = connectorPosition.touchingSliceAt,\n series = this.series,\n pieCenterX = series.center[0],\n plotWidth = series.chart.plotWidth,\n plotLeft = series.chart.plotLeft,\n alignment = labelPosition.alignment,\n radius = this.shapeArgs.r,\n crookDistance = relativeLength(// % to fraction\n options.crookDistance, 1),\n crookX = alignment === 'left' ?\n pieCenterX + radius + (plotWidth + plotLeft -\n pieCenterX - radius) * (1 - crookDistance) :\n plotLeft + (pieCenterX - radius) * crookDistance,\n segmentWithCrook = [\n 'L',\n crookX,\n labelPosition.y\n ];\n var useCrook = true;\n // crookedLine formula doesn't make sense if the path overlaps\n // the label - use straight line instead in that case\n if (alignment === 'left' ?\n (crookX > labelPosition.x || crookX < touchingSliceAt.x) :\n (crookX < labelPosition.x || crookX > touchingSliceAt.x)) {\n useCrook = false;\n }\n // assemble the path\n var path = [['M',\n labelPosition.x,\n labelPosition.y]];\n if (useCrook) {\n path.push(segmentWithCrook);\n }\n path.push(['L', touchingSliceAt.x, touchingSliceAt.y]);\n return path;\n }\n }\n });\n /* *\n *\n * Default Export\n *\n * */\n\n return PiePoint;\n });\n _registerModule(_modules, 'Series/Pie/PieSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A pie chart is a circular graphic which is divided into slices to\n * illustrate numerical proportion.\n *\n * @sample highcharts/demo/pie-basic/\n * Pie chart\n *\n * @extends plotOptions.line\n * @excluding animationLimit, boostThreshold, connectEnds, connectNulls,\n * cropThreshold, dashStyle, dataSorting, dragDrop,\n * findNearestPointBy, getExtremesFromAll, label, lineWidth,\n * linkedTo, marker, negativeColor, pointInterval,\n * pointIntervalUnit, pointPlacement, pointStart,\n * softThreshold, stacking, step, threshold, turboThreshold,\n * zoneAxis, zones, dataSorting, boostBlending\n * @product highcharts highmaps\n * @optionparent plotOptions.pie\n *\n * @private\n */\n var PieSeriesDefaults = {\n /**\n * @excluding legendItemClick\n * @apioption plotOptions.pie.events\n */\n /**\n * Fires when the checkbox next to the point name in the legend is\n * clicked. One parameter, event, is passed to the function. The state\n * of the checkbox is found by event.checked. The checked item is found\n * by event.item. Return false to prevent the default action which is to\n * toggle the select state of the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-checkboxclick/\n * Alert checkbox status\n *\n * @type {Function}\n * @since 1.2.0\n * @product highcharts highmaps\n * @context Highcharts.Point\n * @apioption plotOptions.pie.events.checkboxClick\n */\n /**\n * Fires when the legend item belonging to the pie point (slice) is\n * clicked. The `this` keyword refers to the point itself. One\n * parameter, `event`, is passed to the function, containing common\n * event information. The default action is to toggle the visibility of\n * the point. This can be prevented by calling `event.preventDefault()`.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-point-events-legenditemclick/\n * Confirm toggle visibility\n *\n * @type {Highcharts.PointLegendItemClickCallbackFunction}\n * @since 1.2.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.point.events.legendItemClick\n */\n /**\n * The center of the pie chart relative to the plot area. Can be\n * percentages or pixel values. The default behaviour (as of 3.0) is to\n * center the pie so that all slices and data labels are within the plot\n * area. As a consequence, the pie may actually jump around in a chart\n * with dynamic values, as the data labels move. In that case, the\n * center should be explicitly set, for example to `[\"50%\", \"50%\"]`.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-center/\n * Centered at 100, 100\n *\n * @type {Array<(number|string|null),(number|string|null)>}\n * @default [null, null]\n * @product highcharts highmaps\n *\n * @private\n */\n center: [null, null],\n /**\n * The color of the pie series. A pie series is represented as an empty\n * circle if the total sum of its values is 0. Use this property to\n * define the color of its border.\n *\n * In styled mode, the color can be defined by the\n * [colorIndex](#plotOptions.series.colorIndex) option. Also, the series\n * color can be set with the `.highcharts-series`,\n * `.highcharts-color-{n}`, `.highcharts-{type}-series` or\n * `.highcharts-series-{n}` class, or individual classes given by the\n * `className` option.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-emptyseries/\n * Empty pie series\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #cccccc\n * @apioption plotOptions.pie.color\n */\n /**\n * @product highcharts\n *\n * @private\n */\n clip: false,\n /**\n * @ignore-option\n *\n * @private\n */\n colorByPoint: true,\n /**\n * A series specific or series type specific color set to use instead\n * of the global [colors](#colors).\n *\n * @sample {highcharts} highcharts/demo/pie-monochrome/\n * Set default colors for all pies\n *\n * @type {Array}\n * @since 3.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.colors\n */\n /**\n * @declare Highcharts.SeriesPieDataLabelsOptionsObject\n * @extends plotOptions.series.dataLabels\n * @excluding align, allowOverlap, inside, staggerLines, step\n * @private\n */\n dataLabels: {\n /**\n * Alignment method for data labels. Possible values are:\n *\n * - `plotEdges`: Each label touches the nearest vertical edge of\n * the plot area.\n *\n * - `connectors`: Connectors have the same x position and the\n * widest label of each half (left & right) touches the nearest\n * vertical edge of the plot area.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-alignto-connectors/\n * alignTo: connectors\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-alignto-plotedges/\n * alignTo: plotEdges\n *\n * @type {string}\n * @since 7.0.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.dataLabels.alignTo\n */\n allowOverlap: true,\n /**\n * The color of the line connecting the data label to the pie slice.\n * The default color is the same as the point's color.\n *\n * In styled mode, the connector stroke is given in the\n * `.highcharts-data-label-connector` class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-connectorcolor/\n * Blue connectors\n * @sample {highcharts} highcharts/css/pie-point/\n * Styled connectors\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.1\n * @product highcharts highmaps\n * @apioption plotOptions.pie.dataLabels.connectorColor\n */\n /**\n * The distance from the data label to the connector. Note that\n * data labels also have a default `padding`, so in order for the\n * connector to touch the text, the `padding` must also be 0.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-connectorpadding/\n * No padding\n *\n * @since 2.1\n * @product highcharts highmaps\n */\n connectorPadding: 5,\n /**\n * Specifies the method that is used to generate the connector path.\n * Highcharts provides 3 built-in connector shapes: `'fixedOffset'`\n * (default), `'straight'` and `'crookedLine'`. Using\n * `'crookedLine'` has the most sense (in most of the cases) when\n * `'alignTo'` is set.\n *\n * Users can provide their own method by passing a function instead\n * of a String. 3 arguments are passed to the callback:\n *\n * - Object that holds the information about the coordinates of the\n * label (`x` & `y` properties) and how the label is located in\n * relation to the pie (`alignment` property). `alignment` can by\n * one of the following:\n * `'left'` (pie on the left side of the data label),\n * `'right'` (pie on the right side of the data label) or\n * `'center'` (data label overlaps the pie).\n *\n * - Object that holds the information about the position of the\n * connector. Its `touchingSliceAt` porperty tells the position\n * of the place where the connector touches the slice.\n *\n * - Data label options\n *\n * The function has to return an SVG path definition in array form\n * (see the example).\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-connectorshape-string/\n * connectorShape is a String\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-connectorshape-function/\n * connectorShape is a function\n *\n * @type {string|Function}\n * @since 7.0.0\n * @product highcharts highmaps\n */\n connectorShape: 'fixedOffset',\n /**\n * The width of the line connecting the data label to the pie slice.\n *\n * In styled mode, the connector stroke width is given in the\n * `.highcharts-data-label-connector` class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-connectorwidth-disabled/\n * Disable the connector\n * @sample {highcharts} highcharts/css/pie-point/\n * Styled connectors\n *\n * @type {number}\n * @default 1\n * @since 2.1\n * @product highcharts highmaps\n * @apioption plotOptions.pie.dataLabels.connectorWidth\n */\n /**\n * Works only if `connectorShape` is `'crookedLine'`. It defines how\n * far from the vertical plot edge the coonnector path should be\n * crooked.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-crookdistance/\n * crookDistance set to 90%\n *\n * @since 7.0.0\n * @product highcharts highmaps\n */\n crookDistance: '70%',\n /**\n * The distance of the data label from the pie's edge. Negative\n * numbers put the data label on top of the pie slices. Can also be\n * defined as a percentage of pie's radius. Connectors are only\n * shown for data labels outside the pie.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-distance/\n * Data labels on top of the pie\n *\n * @type {number|string}\n * @since 2.1\n * @product highcharts highmaps\n */\n distance: 30,\n enabled: true,\n /**\n * A\n * [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for the data label. Available variables are the same as for\n * `formatter`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-format/\n * Add a unit\n *\n * @type {string}\n * @default undefined\n * @since 3.0\n * @apioption plotOptions.pie.dataLabels.format\n */\n // eslint-disable-next-line valid-jsdoc\n /**\n * Callback JavaScript function to format the data label. Note that\n * if a `format` is defined, the format takes precedence and the\n * formatter is ignored.\n *\n * @type {Highcharts.DataLabelsFormatterCallbackFunction}\n * @default function () { return this.point.isNull ? void 0 : this.point.name; }\n */\n formatter: function () {\n return this.point.isNull ? void 0 : this.point.name;\n },\n /**\n * Whether to render the connector as a soft arc or a line with\n * sharp break. Works only if `connectorShape` equals to\n * `fixedOffset`.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-softconnector-true/\n * Soft\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-softconnector-false/\n * Non soft\n *\n * @since 2.1.7\n * @product highcharts highmaps\n */\n softConnector: true,\n /**\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-overflow\n * Long labels truncated with an ellipsis\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-overflow-wrap\n * Long labels are wrapped\n *\n * @type {Highcharts.CSSObject}\n * @apioption plotOptions.pie.dataLabels.style\n */\n x: 0\n },\n /**\n * If the total sum of the pie's values is 0, the series is represented\n * as an empty circle . The `fillColor` option defines the color of that\n * circle. Use [pie.borderWidth](#plotOptions.pie.borderWidth) to set\n * the border thickness.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-emptyseries/\n * Empty pie series\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @private\n */\n fillColor: void 0,\n /**\n * The end angle of the pie in degrees where 0 is top and 90 is right.\n * Defaults to `startAngle` plus 360.\n *\n * @sample {highcharts} highcharts/demo/pie-semi-circle/\n * Semi-circle donut\n *\n * @type {number}\n * @since 1.3.6\n * @product highcharts highmaps\n * @apioption plotOptions.pie.endAngle\n */\n /**\n * Thickness describing the ring size for a donut type chart,\n * overriding [innerSize](#plotOptions.pie.innerSize).\n *\n * @type {number}\n * @default undefined\n * @product highcharts\n * @since 10.1.0\n * @apioption plotOptions.pie.thickness\n * @private\n */\n /**\n * Equivalent to [chart.ignoreHiddenSeries](#chart.ignoreHiddenSeries),\n * this option tells whether the series shall be redrawn as if the\n * hidden point were `null`.\n *\n * The default value changed from `false` to `true` with Highcharts\n * 3.0.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-ignorehiddenpoint/\n * True, the hiddden point is ignored\n *\n * @since 2.3.0\n * @product highcharts highmaps\n *\n * @private\n */\n ignoreHiddenPoint: true,\n /**\n * @ignore-option\n *\n * @private\n */\n inactiveOtherPoints: true,\n /**\n * The size of the inner diameter for the pie. A size greater than 0\n * renders a donut chart. Can be a percentage or pixel value.\n * Percentages are relative to the pie size. Pixel values are given as\n * integers. Setting overridden by thickness.\n *\n *\n * Note: in Highcharts < 4.1.2, the percentage was relative to the plot\n * area, not the pie size.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-innersize-80px/\n * 80px inner size\n * @sample {highcharts} highcharts/plotoptions/pie-innersize-50percent/\n * 50% of the plot area\n * @sample {highcharts} highcharts/demo/3d-pie-donut/\n * 3D donut\n *\n * @type {number|string}\n * @default 0\n * @since 2.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.innerSize\n */\n /**\n * @ignore-option\n *\n * @private\n */\n legendType: 'point',\n /**\n * @ignore-option\n *\n * @private\n */\n marker: null,\n /**\n * The minimum size for a pie in response to auto margins. The pie will\n * try to shrink to make room for data labels in side the plot area,\n * but only to this size.\n *\n * @type {number|string}\n * @default 80\n * @since 3.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.minSize\n */\n /**\n * The diameter of the pie relative to the plot area. Can be a\n * percentage or pixel value. Pixel values are given as integers. The\n * default behaviour (as of 3.0) is to scale to the plot area and give\n * room for data labels within the plot area.\n * [slicedOffset](#plotOptions.pie.slicedOffset) is also included in the\n * default size calculation. As a consequence, the size of the pie may\n * vary when points are updated and data labels more around. In that\n * case it is best to set a fixed value, for example `\"75%\"`.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-size/\n * Smaller pie\n *\n * @type {number|string|null}\n * @product highcharts highmaps\n *\n * @private\n */\n size: null,\n /**\n * Whether to display this particular series or series type in the\n * legend. Since 2.1, pies are not shown in the legend by default.\n *\n * @sample {highcharts} highcharts/plotoptions/series-showinlegend/\n * One series in the legend, one hidden\n *\n * @product highcharts highmaps\n *\n * @private\n */\n showInLegend: false,\n /**\n * If a point is sliced, moved out from the center, how many pixels\n * should it be moved?.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-slicedoffset-20/\n * 20px offset\n *\n * @product highcharts highmaps\n *\n * @private\n */\n slicedOffset: 10,\n /**\n * The start angle of the pie slices in degrees where 0 is top and 90\n * right.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-startangle-90/\n * Start from right\n *\n * @type {number}\n * @default 0\n * @since 2.3.4\n * @product highcharts highmaps\n * @apioption plotOptions.pie.startAngle\n */\n /**\n * Sticky tracking of mouse events. When true, the `mouseOut` event\n * on a series isn't triggered until the mouse moves over another\n * series, or out of the plot area. When false, the `mouseOut` event on\n * a series is triggered when the mouse leaves the area around the\n * series' graph or markers. This also implies the tooltip. When\n * `stickyTracking` is false and `tooltip.shared` is false, the tooltip\n * will be hidden when moving the mouse between series.\n *\n * @product highcharts highmaps\n *\n * @private\n */\n stickyTracking: false,\n tooltip: {\n followPointer: true\n },\n /**\n * The color of the border surrounding each slice. When `null`, the\n * border takes the same color as the slice fill. This can be used\n * together with a `borderWidth` to fill drawing gaps created by\n * antialiazing artefacts in borderless pies.\n *\n * In styled mode, the border stroke is given in the `.highcharts-point`\n * class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-bordercolor-black/\n * Black border\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #ffffff\n * @product highcharts highmaps\n *\n * @private\n */\n borderColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The width of the border surrounding each slice.\n *\n * When setting the border width to 0, there may be small gaps between\n * the slices due to SVG antialiasing artefacts. To work around this,\n * keep the border width at 0.5 or 1, but set the `borderColor` to\n * `null` instead.\n *\n * In styled mode, the border stroke width is given in the\n * `.highcharts-point` class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-borderwidth/\n * 3px border\n *\n * @product highcharts highmaps\n *\n * @private\n */\n borderWidth: 1,\n /**\n * @ignore-option\n * @private\n */\n lineWidth: void 0,\n states: {\n /**\n * @extends plotOptions.series.states.hover\n * @excluding marker, lineWidth, lineWidthPlus\n * @product highcharts highmaps\n */\n hover: {\n /**\n * How much to brighten the point on interaction. Requires the\n * main color to be defined in hex or rgb(a) format.\n *\n * In styled mode, the hover brightness is by default replaced\n * by a fill-opacity given in the `.highcharts-point-hover`\n * class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-states-hover-brightness/\n * Brightened by 0.5\n *\n * @product highcharts highmaps\n */\n brightness: 0.1\n }\n }\n };\n /**\n * A `pie` series. If the [type](#series.pie.type) option is not specified,\n * it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.pie\n * @excluding cropThreshold, dataParser, dataURL, linkedTo, stack, xAxis, yAxis,\n * dataSorting, step, boostThreshold, boostBlending\n * @product highcharts highmaps\n * @apioption series.pie\n */\n /**\n * An array of data points for the series. For the `pie` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.pie.turboThreshold),\n * this option is not available.\n * ```js\n * data: [{\n * y: 1,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * y: 7,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @excluding marker, x\n * @product highcharts highmaps\n * @apioption series.pie.data\n */\n /**\n * @type {Highcharts.SeriesPieDataLabelsOptionsObject}\n * @product highcharts highmaps\n * @apioption series.pie.data.dataLabels\n */\n /**\n * The sequential index of the data point in the legend.\n *\n * @type {number}\n * @product highcharts highmaps\n * @apioption series.pie.data.legendIndex\n */\n /**\n * Whether to display a slice offset from the center.\n *\n * @sample {highcharts} highcharts/point/sliced/\n * One sliced point\n *\n * @type {boolean}\n * @product highcharts highmaps\n * @apioption series.pie.data.sliced\n */\n /**\n * @extends plotOptions.pie.dataLabels\n * @excluding align, allowOverlap, inside, staggerLines, step\n * @product highcharts highmaps\n * @apioption series.pie.dataLabels\n */\n /**\n * @excluding legendItemClick\n * @product highcharts highmaps\n * @apioption series.pie.events\n */\n ''; // placeholder for transpiled doclets above\n /* *\n *\n * Default Export\n *\n * */\n\n return PieSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Pie/PieSeries.js', [_modules['Series/CenteredUtilities.js'], _modules['Series/Column/ColumnSeries.js'], _modules['Core/Globals.js'], _modules['Core/Legend/LegendSymbol.js'], _modules['Series/Pie/PiePoint.js'], _modules['Series/Pie/PieSeriesDefaults.js'], _modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/Symbols.js'], _modules['Core/Utilities.js']], function (CU, ColumnSeries, H, LegendSymbol, PiePoint, PieSeriesDefaults, Series, SeriesRegistry, Symbols, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var getStartAndEndRadians = CU.getStartAndEndRadians;\n var noop = H.noop;\n var clamp = U.clamp,\n extend = U.extend,\n fireEvent = U.fireEvent,\n merge = U.merge,\n pick = U.pick,\n relativeLength = U.relativeLength;\n /* *\n *\n * Class\n *\n * */\n /**\n * Pie series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.pie\n *\n * @augments Highcharts.Series\n */\n var PieSeries = /** @class */ (function (_super) {\n __extends(PieSeries, _super);\n function PieSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.center = void 0;\n _this.data = void 0;\n _this.maxLabelDistance = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Animates the pies in.\n * @private\n */\n PieSeries.prototype.animate = function (init) {\n var series = this,\n points = series.points,\n startAngleRad = series.startAngleRad;\n if (!init) {\n points.forEach(function (point) {\n var graphic = point.graphic,\n args = point.shapeArgs;\n if (graphic && args) {\n // start values\n graphic.attr({\n // animate from inner radius (#779)\n r: pick(point.startR, (series.center && series.center[3] / 2)),\n start: startAngleRad,\n end: startAngleRad\n });\n // animate\n graphic.animate({\n r: args.r,\n start: args.start,\n end: args.end\n }, series.options.animation);\n }\n });\n }\n };\n /**\n * Called internally to draw auxiliary graph in pie-like series in\n * situtation when the default graph is not sufficient enough to present\n * the data well. Auxiliary graph is saved in the same object as\n * regular graph.\n * @private\n */\n PieSeries.prototype.drawEmpty = function () {\n var start = this.startAngleRad,\n end = this.endAngleRad,\n options = this.options;\n var centerX,\n centerY;\n // Draw auxiliary graph if there're no visible points.\n if (this.total === 0 && this.center) {\n centerX = this.center[0];\n centerY = this.center[1];\n if (!this.graph) {\n this.graph = this.chart.renderer\n .arc(centerX, centerY, this.center[1] / 2, 0, start, end)\n .addClass('highcharts-empty-series')\n .add(this.group);\n }\n this.graph.attr({\n d: Symbols.arc(centerX, centerY, this.center[2] / 2, 0, {\n start: start,\n end: end,\n innerR: this.center[3] / 2\n })\n });\n if (!this.chart.styledMode) {\n this.graph.attr({\n 'stroke-width': options.borderWidth,\n fill: options.fillColor || 'none',\n stroke: options.color || \"#cccccc\" /* Palette.neutralColor20 */\n });\n }\n }\n else if (this.graph) { // Destroy the graph object.\n this.graph = this.graph.destroy();\n }\n };\n /**\n * Slices in pie chart are initialized in DOM, but it's shapes and\n * animations are normally run in `drawPoints()`.\n * @private\n */\n PieSeries.prototype.drawPoints = function () {\n var renderer = this.chart.renderer;\n this.points.forEach(function (point) {\n // When updating a series between 2d and 3d or cartesian and\n // polar, the shape type changes.\n if (point.graphic && point.hasNewShapeType()) {\n point.graphic = point.graphic.destroy();\n }\n if (!point.graphic) {\n point.graphic = renderer[point.shapeType](point.shapeArgs)\n .add(point.series.group);\n point.delayedRendering = true;\n }\n });\n };\n /**\n * Extend the generatePoints method by adding total and percentage\n * properties to each point\n * @private\n */\n PieSeries.prototype.generatePoints = function () {\n _super.prototype.generatePoints.call(this);\n this.updateTotals();\n };\n /**\n * Utility for getting the x value from a given y, used for\n * anticollision logic in data labels. Added point for using specific\n * points' label distance.\n * @private\n */\n PieSeries.prototype.getX = function (y, left, point) {\n var center = this.center, \n // Variable pie has individual radius\n radius = this.radii ?\n this.radii[point.index] || 0 :\n center[2] / 2;\n var angle = Math.asin(clamp((y - center[1]) / (radius + point.labelDistance), -1, 1));\n var x = center[0] +\n (left ? -1 : 1) *\n (Math.cos(angle) * (radius + point.labelDistance)) +\n (point.labelDistance > 0 ?\n (left ? -1 : 1) * this.options.dataLabels.padding :\n 0);\n return x;\n };\n /**\n * Define hasData function for non-cartesian series. Returns true if the\n * series has points at all.\n * @private\n */\n PieSeries.prototype.hasData = function () {\n return !!this.processedXData.length; // != 0\n };\n /**\n * Draw the data points\n * @private\n */\n PieSeries.prototype.redrawPoints = function () {\n var series = this,\n chart = series.chart,\n renderer = chart.renderer,\n shadow = series.options.shadow;\n var groupTranslation,\n graphic,\n pointAttr,\n shapeArgs;\n this.drawEmpty();\n if (shadow && !series.shadowGroup && !chart.styledMode) {\n series.shadowGroup = renderer\n .g('shadow')\n .attr({ zIndex: -1 })\n .add(series.group);\n }\n // draw the slices\n series.points.forEach(function (point) {\n var animateTo = {};\n graphic = point.graphic;\n if (!point.isNull && graphic) {\n var shadowGroup = void 0;\n shapeArgs = point.shapeArgs;\n // If the point is sliced, use special translation, else use\n // plot area translation\n groupTranslation = point.getTranslate();\n if (!chart.styledMode) {\n // Put the shadow behind all points\n shadowGroup = point.shadowGroup;\n if (shadow && !shadowGroup) {\n shadowGroup = point.shadowGroup = renderer\n .g('shadow')\n .add(series.shadowGroup);\n }\n if (shadowGroup) {\n shadowGroup.attr(groupTranslation);\n }\n pointAttr = series.pointAttribs(point, (point.selected && 'select'));\n }\n // Draw the slice\n if (!point.delayedRendering) {\n graphic\n .setRadialReference(series.center);\n if (!chart.styledMode) {\n merge(true, animateTo, pointAttr);\n }\n merge(true, animateTo, shapeArgs, groupTranslation);\n graphic.animate(animateTo);\n }\n else {\n graphic\n .setRadialReference(series.center)\n .attr(shapeArgs)\n .attr(groupTranslation);\n if (!chart.styledMode) {\n graphic\n .attr(pointAttr)\n .attr({ 'stroke-linejoin': 'round' })\n .shadow(shadow, shadowGroup);\n }\n point.delayedRendering = false;\n }\n graphic.attr({\n visibility: point.visible ? 'inherit' : 'hidden'\n });\n graphic.addClass(point.getClassName(), true);\n }\n else if (graphic) {\n point.graphic = graphic.destroy();\n }\n });\n };\n /**\n * Utility for sorting data labels.\n * @private\n */\n PieSeries.prototype.sortByAngle = function (points, sign) {\n points.sort(function (a, b) {\n return ((typeof a.angle !== 'undefined') &&\n (b.angle - a.angle) * sign);\n });\n };\n /**\n * Do translation for pie slices\n * @private\n */\n PieSeries.prototype.translate = function (positions) {\n fireEvent(this, 'translate');\n this.generatePoints();\n var series = this,\n precision = 1000, // issue #172\n options = series.options,\n slicedOffset = options.slicedOffset,\n connectorOffset = slicedOffset + (options.borderWidth || 0),\n radians = getStartAndEndRadians(options.startAngle,\n options.endAngle),\n startAngleRad = series.startAngleRad = radians.start,\n endAngleRad = series.endAngleRad = radians.end,\n circ = endAngleRad - startAngleRad, // 2 * Math.PI,\n points = series.points,\n labelDistance = options.dataLabels.distance,\n ignoreHiddenPoint = options.ignoreHiddenPoint,\n len = points.length;\n var finalConnectorOffset,\n start,\n end,\n angle, \n // the x component of the radius vector for a given point\n radiusX,\n radiusY,\n i,\n point,\n cumulative = 0;\n // Get positions - either an integer or a percentage string must be\n // given. If positions are passed as a parameter, we're in a\n // recursive loop for adjusting space for data labels.\n if (!positions) {\n series.center = positions = series.getCenter();\n }\n // Calculate the geometry for each point\n for (i = 0; i < len; i++) {\n point = points[i];\n // set start and end angle\n start = startAngleRad + (cumulative * circ);\n if (point.isValid() &&\n (!ignoreHiddenPoint || point.visible)) {\n cumulative += point.percentage / 100;\n }\n end = startAngleRad + (cumulative * circ);\n // set the shape\n var shapeArgs = {\n x: positions[0],\n y: positions[1],\n r: positions[2] / 2,\n innerR: positions[3] / 2,\n start: Math.round(start * precision) / precision,\n end: Math.round(end * precision) / precision\n };\n point.shapeType = 'arc';\n point.shapeArgs = shapeArgs;\n // Used for distance calculation for specific point.\n point.labelDistance = pick((point.options.dataLabels &&\n point.options.dataLabels.distance), labelDistance);\n // Compute point.labelDistance if it's defined as percentage\n // of slice radius (#8854)\n point.labelDistance = relativeLength(point.labelDistance, shapeArgs.r);\n // Saved for later dataLabels distance calculation.\n series.maxLabelDistance = Math.max(series.maxLabelDistance || 0, point.labelDistance);\n // The angle must stay within -90 and 270 (#2645)\n angle = (end + start) / 2;\n if (angle > 1.5 * Math.PI) {\n angle -= 2 * Math.PI;\n }\n else if (angle < -Math.PI / 2) {\n angle += 2 * Math.PI;\n }\n // Center for the sliced out slice\n point.slicedTranslation = {\n translateX: Math.round(Math.cos(angle) * slicedOffset),\n translateY: Math.round(Math.sin(angle) * slicedOffset)\n };\n // set the anchor point for tooltips\n radiusX = Math.cos(angle) * positions[2] / 2;\n radiusY = Math.sin(angle) * positions[2] / 2;\n point.tooltipPos = [\n positions[0] + radiusX * 0.7,\n positions[1] + radiusY * 0.7\n ];\n point.half = angle < -Math.PI / 2 || angle > Math.PI / 2 ?\n 1 :\n 0;\n point.angle = angle;\n // Set the anchor point for data labels. Use point.labelDistance\n // instead of labelDistance // #1174\n // finalConnectorOffset - not override connectorOffset value.\n finalConnectorOffset = Math.min(connectorOffset, point.labelDistance / 5); // #1678\n point.labelPosition = {\n natural: {\n // initial position of the data label - it's utilized for\n // finding the final position for the label\n x: positions[0] + radiusX + Math.cos(angle) *\n point.labelDistance,\n y: positions[1] + radiusY + Math.sin(angle) *\n point.labelDistance\n },\n 'final': {\n // used for generating connector path -\n // initialized later in drawDataLabels function\n // x: undefined,\n // y: undefined\n },\n // left - pie on the left side of the data label\n // right - pie on the right side of the data label\n // center - data label overlaps the pie\n alignment: point.labelDistance < 0 ?\n 'center' : point.half ? 'right' : 'left',\n connectorPosition: {\n breakAt: {\n x: positions[0] + radiusX + Math.cos(angle) *\n finalConnectorOffset,\n y: positions[1] + radiusY + Math.sin(angle) *\n finalConnectorOffset\n },\n touchingSliceAt: {\n x: positions[0] + radiusX,\n y: positions[1] + radiusY\n }\n }\n };\n }\n fireEvent(series, 'afterTranslate');\n };\n /**\n * Recompute total chart sum and update percentages of points.\n * @private\n */\n PieSeries.prototype.updateTotals = function () {\n var points = this.points,\n len = points.length,\n ignoreHiddenPoint = this.options.ignoreHiddenPoint;\n var i,\n point,\n total = 0;\n // Get the total sum\n for (i = 0; i < len; i++) {\n point = points[i];\n if (point.isValid() &&\n (!ignoreHiddenPoint || point.visible)) {\n total += point.y;\n }\n }\n this.total = total;\n // Set each point's properties\n for (i = 0; i < len; i++) {\n point = points[i];\n point.percentage =\n (total > 0 && (point.visible || !ignoreHiddenPoint)) ?\n point.y / total * 100 :\n 0;\n point.total = total;\n }\n };\n PieSeries.defaultOptions = merge(Series.defaultOptions, PieSeriesDefaults);\n return PieSeries;\n }(Series));\n extend(PieSeries.prototype, {\n axisTypes: [],\n directTouch: true,\n drawGraph: void 0,\n drawLegendSymbol: LegendSymbol.drawRectangle,\n drawTracker: ColumnSeries.prototype.drawTracker,\n getCenter: CU.getCenter,\n getSymbol: noop,\n isCartesian: false,\n noSharedTooltip: true,\n pointAttribs: ColumnSeries.prototype.pointAttribs,\n pointClass: PiePoint,\n requireSorting: false,\n searchPoint: noop,\n trackerGroups: ['group', 'dataLabelsGroup']\n });\n SeriesRegistry.registerSeriesType('pie', PieSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return PieSeries;\n });\n _registerModule(_modules, 'Series/Pie/PieDataLabel.js', [_modules['Core/Series/DataLabel.js'], _modules['Core/Globals.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (DataLabel, H, R, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var noop = H.noop;\n var distribute = R.distribute;\n var Series = SeriesRegistry.series;\n var arrayMax = U.arrayMax,\n clamp = U.clamp,\n defined = U.defined,\n merge = U.merge,\n pick = U.pick,\n relativeLength = U.relativeLength;\n /* *\n *\n * Composition\n *\n * */\n var ColumnDataLabel;\n (function (ColumnDataLabel) {\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n var dataLabelPositioners = {\n // Based on the value computed in Highcharts' distribute algorithm.\n radialDistributionY: function (point) {\n return point.top + point.distributeBox.pos;\n },\n // get the x - use the natural x position for labels near the\n // top and bottom, to prevent the top and botton slice\n // connectors from touching each other on either side\n // Based on the value computed in Highcharts' distribute algorithm.\n radialDistributionX: function (series, point, y, naturalY) {\n return series.getX(y < point.top + 2 || y > point.bottom - 2 ?\n naturalY :\n y, point.half, point);\n },\n // dataLabels.distance determines the x position of the label\n justify: function (point, radius, seriesCenter) {\n return seriesCenter[0] + (point.half ? -1 : 1) *\n (radius + point.labelDistance);\n },\n // Left edges of the left-half labels touch the left edge of the plot\n // area. Right edges of the right-half labels touch the right edge of\n // the plot area.\n alignToPlotEdges: function (dataLabel, half, plotWidth, plotLeft) {\n var dataLabelWidth = dataLabel.getBBox().width;\n return half ? dataLabelWidth + plotLeft :\n plotWidth - dataLabelWidth - plotLeft;\n },\n // Connectors of each side end in the same x position. Labels are\n // aligned to them. Left edge of the widest left-half label touches the\n // left edge of the plot area. Right edge of the widest right-half label\n // touches the right edge of the plot area.\n alignToConnectors: function (points, half, plotWidth, plotLeft) {\n var maxDataLabelWidth = 0,\n dataLabelWidth;\n // find widest data label\n points.forEach(function (point) {\n dataLabelWidth = point.dataLabel.getBBox().width;\n if (dataLabelWidth > maxDataLabelWidth) {\n maxDataLabelWidth = dataLabelWidth;\n }\n });\n return half ? maxDataLabelWidth + plotLeft :\n plotWidth - maxDataLabelWidth - plotLeft;\n }\n };\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /** @private */\n function compose(PieSeriesClass) {\n DataLabel.compose(Series);\n if (composedClasses.indexOf(PieSeriesClass) === -1) {\n composedClasses.push(PieSeriesClass);\n var pieProto = PieSeriesClass.prototype;\n pieProto.dataLabelPositioners = dataLabelPositioners;\n pieProto.alignDataLabel = noop;\n pieProto.drawDataLabels = drawDataLabels;\n pieProto.placeDataLabels = placeDataLabels;\n pieProto.verifyDataLabelOverflow = verifyDataLabelOverflow;\n }\n }\n ColumnDataLabel.compose = compose;\n /**\n * Override the base drawDataLabels method by pie specific functionality\n * @private\n */\n function drawDataLabels() {\n var series = this,\n data = series.data,\n chart = series.chart,\n options = series.options.dataLabels || {},\n connectorPadding = options.connectorPadding,\n plotWidth = chart.plotWidth,\n plotHeight = chart.plotHeight,\n plotLeft = chart.plotLeft,\n maxWidth = Math.round(chart.chartWidth / 3),\n seriesCenter = series.center,\n radius = seriesCenter[2] / 2,\n centerY = seriesCenter[1],\n halves = [\n [],\n [] // left\n ],\n overflow = [0, 0, 0, 0], // top, right, bottom, left\n dataLabelPositioners = series.dataLabelPositioners;\n var point,\n connectorWidth,\n connector,\n dataLabel,\n dataLabelWidth, \n // labelPos,\n labelPosition,\n labelHeight, \n // divide the points into right and left halves for anti collision\n x,\n y,\n visibility,\n j,\n pointDataLabelsOptions;\n // get out if not enabled\n if (!series.visible ||\n (!options.enabled &&\n !series._hasPointLabels)) {\n return;\n }\n // Reset all labels that have been shortened\n data.forEach(function (point) {\n if (point.dataLabel && point.visible && point.dataLabel.shortened) {\n point.dataLabel\n .attr({\n width: 'auto'\n }).css({\n width: 'auto',\n textOverflow: 'clip'\n });\n point.dataLabel.shortened = false;\n }\n });\n // run parent method\n Series.prototype.drawDataLabels.apply(series);\n data.forEach(function (point) {\n if (point.dataLabel) {\n if (point.visible) { // #407, #2510\n // Arrange points for detection collision\n halves[point.half].push(point);\n // Reset positions (#4905)\n point.dataLabel._pos = null;\n // Avoid long labels squeezing the pie size too far down\n if (!defined(options.style.width) &&\n !defined(point.options.dataLabels &&\n point.options.dataLabels.style &&\n point.options.dataLabels.style.width)) {\n if (point.dataLabel.getBBox().width > maxWidth) {\n point.dataLabel.css({\n // Use a fraction of the maxWidth to avoid\n // wrapping close to the end of the string.\n width: Math.round(maxWidth * 0.7) + 'px'\n });\n point.dataLabel.shortened = true;\n }\n }\n }\n else {\n point.dataLabel = point.dataLabel.destroy();\n // Workaround to make pies destroy multiple datalabels\n // correctly. This logic needs rewriting to support multiple\n // datalabels fully.\n if (point.dataLabels && point.dataLabels.length === 1) {\n delete point.dataLabels;\n }\n }\n }\n });\n /* Loop over the points in each half, starting from the top and bottom\n * of the pie to detect overlapping labels.\n */\n halves.forEach(function (points, i) {\n var length = points.length,\n positions = [];\n var top,\n bottom,\n naturalY,\n sideOverflow,\n size,\n distributionLength;\n if (!length) {\n return;\n }\n // Sort by angle\n series.sortByAngle(points, i - 0.5);\n // Only do anti-collision when we have dataLabels outside the pie\n // and have connectors. (#856)\n if (series.maxLabelDistance > 0) {\n top = Math.max(0, centerY - radius - series.maxLabelDistance);\n bottom = Math.min(centerY + radius + series.maxLabelDistance, chart.plotHeight);\n points.forEach(function (point) {\n // check if specific points' label is outside the pie\n if (point.labelDistance > 0 && point.dataLabel) {\n // point.top depends on point.labelDistance value\n // Used for calculation of y value in getX method\n point.top = Math.max(0, centerY - radius - point.labelDistance);\n point.bottom = Math.min(centerY + radius + point.labelDistance, chart.plotHeight);\n size = point.dataLabel.getBBox().height || 21;\n // point.positionsIndex is needed for getting index of\n // parameter related to specific point inside positions\n // array - not every point is in positions array.\n point.distributeBox = {\n target: point.labelPosition.natural.y -\n point.top + size / 2,\n size: size,\n rank: point.y\n };\n positions.push(point.distributeBox);\n }\n });\n distributionLength = bottom + size - top;\n distribute(positions, distributionLength, distributionLength / 5);\n }\n // Now the used slots are sorted, fill them up sequentially\n for (j = 0; j < length; j++) {\n point = points[j];\n // labelPos = point.labelPos;\n labelPosition = point.labelPosition;\n dataLabel = point.dataLabel;\n visibility = point.visible === false ? 'hidden' : 'inherit';\n naturalY = labelPosition.natural.y;\n y = naturalY;\n if (positions && defined(point.distributeBox)) {\n if (typeof point.distributeBox.pos === 'undefined') {\n visibility = 'hidden';\n }\n else {\n labelHeight = point.distributeBox.size;\n // Find label's y position\n y = dataLabelPositioners\n .radialDistributionY(point);\n }\n }\n // It is needed to delete point.positionIndex for\n // dynamically added points etc.\n delete point.positionIndex; // @todo unused\n // Find label's x position\n // justify is undocumented in the API - preserve support for it\n if (options.justify) {\n x = dataLabelPositioners.justify(point, radius, seriesCenter);\n }\n else {\n switch (options.alignTo) {\n case 'connectors':\n x = dataLabelPositioners.alignToConnectors(points, i, plotWidth, plotLeft);\n break;\n case 'plotEdges':\n x = dataLabelPositioners.alignToPlotEdges(dataLabel, i, plotWidth, plotLeft);\n break;\n default:\n x = dataLabelPositioners.radialDistributionX(series, point, y, naturalY);\n }\n }\n // Record the placement and visibility\n dataLabel._attr = {\n visibility: visibility,\n align: labelPosition.alignment\n };\n pointDataLabelsOptions = point.options.dataLabels || {};\n dataLabel._pos = {\n x: (x +\n pick(pointDataLabelsOptions.x, options.x) + // (#12985)\n ({\n left: connectorPadding,\n right: -connectorPadding\n }[labelPosition.alignment] || 0)),\n // 10 is for the baseline (label vs text)\n y: (y +\n pick(pointDataLabelsOptions.y, options.y) - // (#12985)\n 10)\n };\n // labelPos.x = x;\n // labelPos.y = y;\n labelPosition.final.x = x;\n labelPosition.final.y = y;\n // Detect overflowing data labels\n if (pick(options.crop, true)) {\n dataLabelWidth = dataLabel.getBBox().width;\n sideOverflow = null;\n // Overflow left\n if (x - dataLabelWidth < connectorPadding &&\n i === 1 // left half\n ) {\n sideOverflow = Math.round(dataLabelWidth - x + connectorPadding);\n overflow[3] = Math.max(sideOverflow, overflow[3]);\n // Overflow right\n }\n else if (x + dataLabelWidth > plotWidth - connectorPadding &&\n i === 0 // right half\n ) {\n sideOverflow = Math.round(x + dataLabelWidth - plotWidth + connectorPadding);\n overflow[1] = Math.max(sideOverflow, overflow[1]);\n }\n // Overflow top\n if (y - labelHeight / 2 < 0) {\n overflow[0] = Math.max(Math.round(-y + labelHeight / 2), overflow[0]);\n // Overflow left\n }\n else if (y + labelHeight / 2 > plotHeight) {\n overflow[2] = Math.max(Math.round(y + labelHeight / 2 - plotHeight), overflow[2]);\n }\n dataLabel.sideOverflow = sideOverflow;\n }\n } // for each point\n }); // for each half\n // Do not apply the final placement and draw the connectors until we\n // have verified that labels are not spilling over.\n if (arrayMax(overflow) === 0 ||\n this.verifyDataLabelOverflow(overflow)) {\n // Place the labels in the final position\n this.placeDataLabels();\n this.points.forEach(function (point) {\n // #8864: every connector can have individual options\n pointDataLabelsOptions =\n merge(options, point.options.dataLabels);\n connectorWidth =\n pick(pointDataLabelsOptions.connectorWidth, 1);\n // Draw the connector\n if (connectorWidth) {\n var isNew = void 0;\n connector = point.connector;\n dataLabel = point.dataLabel;\n if (dataLabel &&\n dataLabel._pos &&\n point.visible &&\n point.labelDistance > 0) {\n visibility = dataLabel._attr.visibility;\n isNew = !connector;\n if (isNew) {\n point.connector = connector = chart.renderer\n .path()\n .addClass('highcharts-data-label-connector ' +\n ' highcharts-color-' + point.colorIndex +\n (point.className ?\n ' ' + point.className :\n ''))\n .add(series.dataLabelsGroup);\n if (!chart.styledMode) {\n connector.attr({\n 'stroke-width': connectorWidth,\n 'stroke': (pointDataLabelsOptions.connectorColor ||\n point.color ||\n \"#666666\" /* Palette.neutralColor60 */)\n });\n }\n }\n connector[isNew ? 'attr' : 'animate']({\n d: point.getConnectorPath()\n });\n connector.attr('visibility', visibility);\n }\n else if (connector) {\n point.connector = connector.destroy();\n }\n }\n });\n }\n }\n /**\n * Perform the final placement of the data labels after we have verified\n * that they fall within the plot area.\n * @private\n */\n function placeDataLabels() {\n this.points.forEach(function (point) {\n var dataLabel = point.dataLabel,\n _pos;\n if (dataLabel && point.visible) {\n _pos = dataLabel._pos;\n if (_pos) {\n // Shorten data labels with ellipsis if they still overflow\n // after the pie has reached minSize (#223).\n if (dataLabel.sideOverflow) {\n dataLabel._attr.width =\n Math.max(dataLabel.getBBox().width -\n dataLabel.sideOverflow, 0);\n dataLabel.css({\n width: dataLabel._attr.width + 'px',\n textOverflow: ((this.options.dataLabels.style || {})\n .textOverflow ||\n 'ellipsis')\n });\n dataLabel.shortened = true;\n }\n dataLabel.attr(dataLabel._attr);\n dataLabel[dataLabel.moved ? 'animate' : 'attr'](_pos);\n dataLabel.moved = true;\n }\n else if (dataLabel) {\n dataLabel.attr({ y: -9999 });\n }\n }\n // Clear for update\n delete point.distributeBox;\n }, this);\n }\n /**\n * Verify whether the data labels are allowed to draw, or we should run more\n * translation and data label positioning to keep them inside the plot area.\n * Returns true when data labels are ready to draw.\n * @private\n */\n function verifyDataLabelOverflow(overflow) {\n var center = this.center,\n options = this.options,\n centerOption = options.center,\n minSize = options.minSize || 80,\n newSize = minSize, \n // If a size is set, return true and don't try to shrink the pie\n // to fit the labels.\n ret = options.size !== null;\n if (!ret) {\n // Handle horizontal size and center\n if (centerOption[0] !== null) { // Fixed center\n newSize = Math.max(center[2] -\n Math.max(overflow[1], overflow[3]), minSize);\n }\n else { // Auto center\n newSize = Math.max(\n // horizontal overflow\n center[2] - overflow[1] - overflow[3], minSize);\n // horizontal center\n center[0] += (overflow[3] - overflow[1]) / 2;\n }\n // Handle vertical size and center\n if (centerOption[1] !== null) { // Fixed center\n newSize = clamp(newSize, minSize, center[2] - Math.max(overflow[0], overflow[2]));\n }\n else { // Auto center\n newSize = clamp(newSize, minSize, \n // vertical overflow\n center[2] - overflow[0] - overflow[2]);\n // vertical center\n center[1] += (overflow[0] - overflow[2]) / 2;\n }\n // If the size must be decreased, we need to run translate and\n // drawDataLabels again\n if (newSize < center[2]) {\n center[2] = newSize;\n center[3] = Math.min(// #3632\n options.thickness ?\n Math.max(0, newSize - options.thickness * 2) :\n Math.max(0, relativeLength(options.innerSize || 0, newSize)), newSize); // #6647\n this.translate(center);\n if (this.drawDataLabels) {\n this.drawDataLabels();\n }\n // Else, return true to indicate that the pie and its labels is\n // within the plot area\n }\n else {\n ret = true;\n }\n }\n return ret;\n }\n })(ColumnDataLabel || (ColumnDataLabel = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return ColumnDataLabel;\n });\n _registerModule(_modules, 'Extensions/OverlappingDataLabels.js', [_modules['Core/Chart/Chart.js'], _modules['Core/Utilities.js']], function (Chart, U) {\n /* *\n *\n * Highcharts module to hide overlapping data labels.\n * This module is included in Highcharts.\n *\n * (c) 2009-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var addEvent = U.addEvent,\n fireEvent = U.fireEvent,\n isArray = U.isArray,\n isNumber = U.isNumber,\n objectEach = U.objectEach,\n pick = U.pick;\n /**\n * Internal type\n * @private\n */\n /* eslint-disable no-invalid-this */\n // Collect potensial overlapping data labels. Stack labels probably don't need\n // to be considered because they are usually accompanied by data labels that lie\n // inside the columns.\n addEvent(Chart, 'render', function collectAndHide() {\n var chart = this,\n labels = [];\n // Consider external label collectors\n (this.labelCollectors || []).forEach(function (collector) {\n labels = labels.concat(collector());\n });\n (this.yAxis || []).forEach(function (yAxis) {\n if (yAxis.stacking &&\n yAxis.options.stackLabels &&\n !yAxis.options.stackLabels.allowOverlap) {\n objectEach(yAxis.stacking.stacks, function (stack) {\n objectEach(stack, function (stackItem) {\n if (stackItem.label) {\n labels.push(stackItem.label);\n }\n });\n });\n }\n });\n (this.series || []).forEach(function (series) {\n var dlOptions = series.options.dataLabels;\n if (series.visible &&\n !(dlOptions.enabled === false && !series._hasPointLabels)) { // #3866\n var push = function (points) {\n return points.forEach(function (point) {\n if (point.visible) {\n var dataLabels = (isArray(point.dataLabels) ?\n point.dataLabels :\n (point.dataLabel ? [point.dataLabel] : []));\n dataLabels.forEach(function (label) {\n var options = label.options;\n label.labelrank = pick(options.labelrank, point.labelrank, point.shapeArgs && point.shapeArgs.height); // #4118\n if (!options.allowOverlap) {\n labels.push(label);\n }\n else { // #13449\n label.oldOpacity = label.opacity;\n label.newOpacity = 1;\n hideOrShow(label, chart);\n }\n });\n }\n });\n };\n push(series.nodes || []);\n push(series.points);\n }\n });\n this.hideOverlappingLabels(labels);\n });\n /**\n * Hide overlapping labels. Labels are moved and faded in and out on zoom to\n * provide a smooth visual imression.\n *\n * @private\n * @function Highcharts.Chart#hideOverlappingLabels\n * @param {Array} labels\n * Rendered data labels\n * @requires modules/overlapping-datalabels\n */\n Chart.prototype.hideOverlappingLabels = function (labels) {\n var chart = this,\n len = labels.length,\n ren = chart.renderer,\n label,\n i,\n j,\n label1,\n label2,\n box1,\n box2,\n isLabelAffected = false,\n isIntersectRect = function (box1,\n box2) {\n return !(box2.x >= box1.x + box1.width ||\n box2.x + box2.width <= box1.x ||\n box2.y >= box1.y + box1.height ||\n box2.y + box2.height <= box1.y);\n }, \n // Get the box with its position inside the chart, as opposed to getBBox\n // that only reports the position relative to the parent.\n getAbsoluteBox = function (label) {\n var pos,\n parent,\n bBox, \n // Substract the padding if no background or border (#4333)\n padding = label.box ? 0 : (label.padding || 0),\n lineHeightCorrection = 0,\n xOffset = 0,\n boxWidth,\n alignValue;\n if (label &&\n (!label.alignAttr || label.placed)) {\n pos = label.alignAttr || {\n x: label.attr('x'),\n y: label.attr('y')\n };\n parent = label.parentGroup;\n // Get width and height if pure text nodes (stack labels)\n if (!label.width) {\n bBox = label.getBBox();\n label.width = bBox.width;\n label.height = bBox.height;\n // Labels positions are computed from top left corner, so\n // we need to substract the text height from text nodes too.\n lineHeightCorrection = ren\n .fontMetrics(null, label.element).h;\n }\n boxWidth = label.width - 2 * padding;\n alignValue = {\n left: '0',\n center: '0.5',\n right: '1'\n }[label.alignValue];\n if (alignValue) {\n xOffset = +alignValue * boxWidth;\n }\n else if (isNumber(label.x) &&\n Math.round(label.x) !== label.translateX) {\n xOffset = label.x - label.translateX;\n }\n return {\n x: pos.x + (parent.translateX || 0) + padding -\n (xOffset || 0),\n y: pos.y + (parent.translateY || 0) + padding -\n lineHeightCorrection,\n width: label.width - 2 * padding,\n height: label.height - 2 * padding\n };\n }\n };\n for (i = 0; i < len; i++) {\n label = labels[i];\n if (label) {\n // Mark with initial opacity\n label.oldOpacity = label.opacity;\n label.newOpacity = 1;\n label.absoluteBox = getAbsoluteBox(label);\n }\n }\n // Prevent a situation in a gradually rising slope, that each label will\n // hide the previous one because the previous one always has lower rank.\n labels.sort(function (a, b) {\n return (b.labelrank || 0) - (a.labelrank || 0);\n });\n // Detect overlapping labels\n for (i = 0; i < len; i++) {\n label1 = labels[i];\n box1 = label1 && label1.absoluteBox;\n for (j = i + 1; j < len; ++j) {\n label2 = labels[j];\n box2 = label2 && label2.absoluteBox;\n if (box1 &&\n box2 &&\n label1 !== label2 && // #6465, polar chart with connectEnds\n label1.newOpacity !== 0 &&\n label2.newOpacity !== 0 &&\n // #15863 dataLabels are no longer hidden by translation\n label1.visibility !== 'hidden' &&\n label2.visibility !== 'hidden') {\n if (isIntersectRect(box1, box2)) {\n (label1.labelrank < label2.labelrank ? label1 : label2)\n .newOpacity = 0;\n }\n }\n }\n }\n // Hide or show\n labels.forEach(function (label) {\n if (hideOrShow(label, chart)) {\n isLabelAffected = true;\n }\n });\n if (isLabelAffected) {\n fireEvent(chart, 'afterHideAllOverlappingLabels');\n }\n };\n /**\n * Hide or show labels based on opacity.\n *\n * @private\n * @function hideOrShow\n * @param {Highcharts.SVGElement} label\n * The label.\n * @param {Highcharts.Chart} chart\n * The chart that contains the label.\n * @return {boolean}\n * Whether label is affected\n */\n function hideOrShow(label, chart) {\n var complete,\n newOpacity,\n isLabelAffected = false;\n if (label) {\n newOpacity = label.newOpacity;\n if (label.oldOpacity !== newOpacity) {\n // Make sure the label is completely hidden to avoid catching clicks\n // (#4362)\n if (label.alignAttr && label.placed) { // data labels\n label[newOpacity ? 'removeClass' : 'addClass']('highcharts-data-label-hidden');\n complete = function () {\n if (!chart.styledMode) {\n label.css({\n pointerEvents: newOpacity ? 'auto' : 'none'\n });\n }\n };\n isLabelAffected = true;\n // Animate or set the opacity\n label.alignAttr.opacity = newOpacity;\n label[label.isOld ? 'animate' : 'attr'](label.alignAttr, null, complete);\n fireEvent(chart, 'afterHideOverlappingLabel');\n }\n else { // other labels, tick labels\n label.attr({\n opacity: newOpacity\n });\n }\n }\n label.isOld = true;\n }\n return isLabelAffected;\n }\n\n });\n _registerModule(_modules, 'Core/Responsive.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var extend = U.extend,\n find = U.find,\n isArray = U.isArray,\n isObject = U.isObject,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick,\n splat = U.splat,\n uniqueKey = U.uniqueKey;\n /* *\n *\n * Composition\n *\n * */\n var Responsive;\n (function (Responsive) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * @private\n */\n function compose(ChartClass) {\n if (composedClasses.indexOf(ChartClass) === -1) {\n composedClasses.push(ChartClass);\n extend(ChartClass.prototype, Additions.prototype);\n }\n return ChartClass;\n }\n Responsive.compose = compose;\n /* *\n *\n * Class\n *\n * */\n var Additions = /** @class */ (function () {\n function Additions() {\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get the current values for a given set of options. Used before we\n * update the chart with a new responsiveness rule.\n *\n * @todo Restore axis options (by id?). The matching of items in\n * collections bears resemblance to the oneToOne matching in\n * Chart.update. Probably we can refactor out that matching and reuse it\n * in both functions.\n *\n * @private\n * @function Highcharts.Chart#currentOptions\n */\n Additions.prototype.currentOptions = function (options) {\n var chart = this, ret = {};\n /**\n * Recurse over a set of options and its current values,\n * and store the current values in the ret object.\n */\n function getCurrent(options, curr, ret, depth) {\n var i;\n objectEach(options, function (val, key) {\n if (!depth &&\n chart.collectionsWithUpdate.indexOf(key) > -1 &&\n curr[key]) {\n val = splat(val);\n ret[key] = [];\n // Iterate over collections like series, xAxis or yAxis\n // and map the items by index.\n for (i = 0; i < Math.max(val.length, curr[key].length); i++) {\n // Item exists in current data (#6347)\n if (curr[key][i]) {\n // If the item is missing from the new data, we\n // need to save the whole config structure. Like\n // when responsively updating from a dual axis\n // layout to a single axis and back (#13544).\n if (val[i] === void 0) {\n ret[key][i] = curr[key][i];\n // Otherwise, proceed\n }\n else {\n ret[key][i] = {};\n getCurrent(val[i], curr[key][i], ret[key][i], depth + 1);\n }\n }\n }\n }\n else if (isObject(val)) {\n ret[key] = isArray(val) ? [] : {};\n getCurrent(val, curr[key] || {}, ret[key], depth + 1);\n }\n else if (typeof curr[key] === 'undefined') { // #10286\n ret[key] = null;\n }\n else {\n ret[key] = curr[key];\n }\n });\n }\n getCurrent(options, this.options, ret, 0);\n return ret;\n };\n /**\n * Handle a single responsiveness rule.\n *\n * @private\n * @function Highcharts.Chart#matchResponsiveRule\n * @param {Highcharts.ResponsiveRulesOptions} rule\n * @param {Array} matches\n */\n Additions.prototype.matchResponsiveRule = function (rule, matches) {\n var condition = rule.condition,\n fn = condition.callback || function () {\n return (this.chartWidth <= pick(condition.maxWidth,\n Number.MAX_VALUE) &&\n this.chartHeight <= pick(condition.maxHeight,\n Number.MAX_VALUE) &&\n this.chartWidth >= pick(condition.minWidth, 0) &&\n this.chartHeight >= pick(condition.minHeight, 0));\n };\n if (fn.call(this)) {\n matches.push(rule._id);\n }\n };\n /**\n * Update the chart based on the current chart/document size and options\n * for responsiveness.\n *\n * @private\n * @function Highcharts.Chart#setResponsive\n * @param {boolean} [redraw=true]\n * @param {boolean} [reset=false]\n * Reset by un-applying all rules. Chart.update resets all rules before\n * applying updated options.\n */\n Additions.prototype.setResponsive = function (redraw, reset) {\n var _this = this;\n var options = this.options.responsive,\n currentResponsive = this.currentResponsive;\n var ruleIds = [],\n undoOptions;\n if (!reset && options && options.rules) {\n options.rules.forEach(function (rule) {\n if (typeof rule._id === 'undefined') {\n rule._id = uniqueKey();\n }\n _this.matchResponsiveRule(rule, ruleIds /* , redraw */);\n }, this);\n }\n // Merge matching rules\n var mergedOptions = merge.apply(void 0,\n ruleIds\n .map(function (ruleId) { return find((options || {}).rules || [],\n function (rule) { return (rule._id === ruleId); }); })\n .map(function (rule) { return (rule && rule.chartOptions); }));\n mergedOptions.isResponsiveOptions = true;\n // Stringified key for the rules that currently apply.\n ruleIds = (ruleIds.toString() || void 0);\n var currentRuleIds = (currentResponsive && currentResponsive.ruleIds);\n // Changes in what rules apply\n if (ruleIds !== currentRuleIds) {\n // Undo previous rules. Before we apply a new set of rules, we\n // need to roll back completely to base options (#6291).\n if (currentResponsive) {\n this.update(currentResponsive.undoOptions, redraw, true);\n }\n if (ruleIds) {\n // Get undo-options for matching rules\n undoOptions = this.currentOptions(mergedOptions);\n undoOptions.isResponsiveOptions = true;\n this.currentResponsive = {\n ruleIds: ruleIds,\n mergedOptions: mergedOptions,\n undoOptions: undoOptions\n };\n this.update(mergedOptions, redraw, true);\n }\n else {\n this.currentResponsive = void 0;\n }\n }\n };\n return Additions;\n }());\n })(Responsive || (Responsive = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * A callback function to gain complete control on when the responsive rule\n * applies.\n *\n * @callback Highcharts.ResponsiveCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * Chart context.\n *\n * @return {boolean}\n * Return `true` if it applies.\n */\n (''); // keeps doclets above in JS file\n /* *\n *\n * API Options\n *\n * */\n /**\n * Allows setting a set of rules to apply for different screen or chart\n * sizes. Each rule specifies additional chart options.\n *\n * @sample {highstock} stock/demo/responsive/\n * Stock chart\n * @sample highcharts/responsive/axis/\n * Axis\n * @sample highcharts/responsive/legend/\n * Legend\n * @sample highcharts/responsive/classname/\n * Class name\n *\n * @since 5.0.0\n * @apioption responsive\n */\n /**\n * A set of rules for responsive settings. The rules are executed from\n * the top down.\n *\n * @sample {highcharts} highcharts/responsive/axis/\n * Axis changes\n * @sample {highstock} highcharts/responsive/axis/\n * Axis changes\n * @sample {highmaps} highcharts/responsive/axis/\n * Axis changes\n *\n * @type {Array<*>}\n * @since 5.0.0\n * @apioption responsive.rules\n */\n /**\n * A full set of chart options to apply as overrides to the general\n * chart options. The chart options are applied when the given rule\n * is active.\n *\n * A special case is configuration objects that take arrays, for example\n * [xAxis](#xAxis), [yAxis](#yAxis) or [series](#series). For these\n * collections, an `id` option is used to map the new option set to\n * an existing object. If an existing object of the same id is not found,\n * the item of the same indexupdated. So for example, setting `chartOptions`\n * with two series items without an `id`, will cause the existing chart's\n * two series to be updated with respective options.\n *\n * @sample {highstock} stock/demo/responsive/\n * Stock chart\n * @sample highcharts/responsive/axis/\n * Axis\n * @sample highcharts/responsive/legend/\n * Legend\n * @sample highcharts/responsive/classname/\n * Class name\n *\n * @type {Highcharts.Options}\n * @since 5.0.0\n * @apioption responsive.rules.chartOptions\n */\n /**\n * Under which conditions the rule applies.\n *\n * @since 5.0.0\n * @apioption responsive.rules.condition\n */\n /**\n * A callback function to gain complete control on when the responsive\n * rule applies. Return `true` if it applies. This opens for checking\n * against other metrics than the chart size, for example the document\n * size or other elements.\n *\n * @type {Highcharts.ResponsiveCallbackFunction}\n * @since 5.0.0\n * @context Highcharts.Chart\n * @apioption responsive.rules.condition.callback\n */\n /**\n * The responsive rule applies if the chart height is less than this.\n *\n * @type {number}\n * @since 5.0.0\n * @apioption responsive.rules.condition.maxHeight\n */\n /**\n * The responsive rule applies if the chart width is less than this.\n *\n * @sample highcharts/responsive/axis/\n * Max width is 500\n *\n * @type {number}\n * @since 5.0.0\n * @apioption responsive.rules.condition.maxWidth\n */\n /**\n * The responsive rule applies if the chart height is greater than this.\n *\n * @type {number}\n * @default 0\n * @since 5.0.0\n * @apioption responsive.rules.condition.minHeight\n */\n /**\n * The responsive rule applies if the chart width is greater than this.\n *\n * @type {number}\n * @default 0\n * @since 5.0.0\n * @apioption responsive.rules.condition.minWidth\n */\n (''); // keeps doclets above in JS file\n\n return Responsive;\n });\n _registerModule(_modules, 'masters/highcharts.src.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js'], _modules['Core/Defaults.js'], _modules['Core/Animation/Fx.js'], _modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Renderer/HTML/AST.js'], _modules['Core/FormatUtilities.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Renderer/HTML/HTMLElement.js'], _modules['Core/Renderer/HTML/HTMLRenderer.js'], _modules['Core/Axis/Axis.js'], _modules['Core/Axis/DateTimeAxis.js'], _modules['Core/Axis/LogarithmicAxis.js'], _modules['Core/Axis/PlotLineOrBand/PlotLineOrBand.js'], _modules['Core/Axis/Tick.js'], _modules['Core/Tooltip.js'], _modules['Core/Series/Point.js'], _modules['Core/Pointer.js'], _modules['Core/MSPointer.js'], _modules['Core/Legend/Legend.js'], _modules['Core/Chart/Chart.js'], _modules['Core/Axis/Stacking/StackingAxis.js'], _modules['Core/Axis/Stacking/StackItem.js'], _modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Series/Column/ColumnSeries.js'], _modules['Series/Column/ColumnDataLabel.js'], _modules['Series/Pie/PieSeries.js'], _modules['Series/Pie/PieDataLabel.js'], _modules['Core/Series/DataLabel.js'], _modules['Core/Responsive.js'], _modules['Core/Color/Color.js'], _modules['Core/Time.js']], function (Highcharts, Utilities, Defaults, Fx, Animation, AST, FormatUtilities, RendererUtilities, SVGElement, SVGRenderer, HTMLElement, HTMLRenderer, Axis, DateTimeAxis, LogarithmicAxis, PlotLineOrBand, Tick, Tooltip, Point, Pointer, MSPointer, Legend, Chart, StackingAxis, StackItem, Series, SeriesRegistry, ColumnSeries, ColumnDataLabel, PieSeries, PieDataLabel, DataLabel, Responsive, Color, Time) {\n\n var G = Highcharts;\n // Animation\n G.animate = Animation.animate;\n G.animObject = Animation.animObject;\n G.getDeferredAnimation = Animation.getDeferredAnimation;\n G.setAnimation = Animation.setAnimation;\n G.stop = Animation.stop;\n G.timers = Fx.timers;\n // Classes\n G.AST = AST;\n G.Axis = Axis;\n G.Chart = Chart;\n G.chart = Chart.chart;\n G.Fx = Fx;\n G.Legend = Legend;\n G.PlotLineOrBand = PlotLineOrBand;\n G.Point = Point;\n G.Pointer = (MSPointer.isRequired() ? MSPointer : Pointer);\n G.Series = Series;\n G.StackItem = StackItem;\n G.SVGElement = SVGElement;\n G.SVGRenderer = SVGRenderer;\n G.Tick = Tick;\n G.Time = Time;\n G.Tooltip = Tooltip;\n // Color\n G.Color = Color;\n G.color = Color.parse;\n // Compositions\n HTMLRenderer.compose(SVGRenderer);\n HTMLElement.compose(SVGElement);\n // DefaultOptions\n G.defaultOptions = Defaults.defaultOptions;\n G.getOptions = Defaults.getOptions;\n G.time = Defaults.defaultTime;\n G.setOptions = Defaults.setOptions;\n // Format Utilities\n G.dateFormat = FormatUtilities.dateFormat;\n G.format = FormatUtilities.format;\n G.numberFormat = FormatUtilities.numberFormat;\n // Utilities\n G.addEvent = Utilities.addEvent;\n G.arrayMax = Utilities.arrayMax;\n G.arrayMin = Utilities.arrayMin;\n G.attr = Utilities.attr;\n G.clearTimeout = Utilities.clearTimeout;\n G.correctFloat = Utilities.correctFloat;\n G.createElement = Utilities.createElement;\n G.css = Utilities.css;\n G.defined = Utilities.defined;\n G.destroyObjectProperties = Utilities.destroyObjectProperties;\n G.discardElement = Utilities.discardElement;\n G.distribute = RendererUtilities.distribute;\n G.erase = Utilities.erase;\n G.error = Utilities.error;\n G.extend = Utilities.extend;\n G.extendClass = Utilities.extendClass;\n G.find = Utilities.find;\n G.fireEvent = Utilities.fireEvent;\n G.getMagnitude = Utilities.getMagnitude;\n G.getStyle = Utilities.getStyle;\n G.inArray = Utilities.inArray;\n G.isArray = Utilities.isArray;\n G.isClass = Utilities.isClass;\n G.isDOMElement = Utilities.isDOMElement;\n G.isFunction = Utilities.isFunction;\n G.isNumber = Utilities.isNumber;\n G.isObject = Utilities.isObject;\n G.isString = Utilities.isString;\n G.keys = Utilities.keys;\n G.merge = Utilities.merge;\n G.normalizeTickInterval = Utilities.normalizeTickInterval;\n G.objectEach = Utilities.objectEach;\n G.offset = Utilities.offset;\n G.pad = Utilities.pad;\n G.pick = Utilities.pick;\n G.pInt = Utilities.pInt;\n G.relativeLength = Utilities.relativeLength;\n G.removeEvent = Utilities.removeEvent;\n G.seriesType = SeriesRegistry.seriesType;\n G.splat = Utilities.splat;\n G.stableSort = Utilities.stableSort;\n G.syncTimeout = Utilities.syncTimeout;\n G.timeUnits = Utilities.timeUnits;\n G.uniqueKey = Utilities.uniqueKey;\n G.useSerialIds = Utilities.useSerialIds;\n G.wrap = Utilities.wrap;\n // Compositions\n ColumnDataLabel.compose(ColumnSeries);\n DataLabel.compose(Series);\n DateTimeAxis.compose(Axis);\n LogarithmicAxis.compose(Axis);\n PieDataLabel.compose(PieSeries);\n PlotLineOrBand.compose(Axis);\n Responsive.compose(Chart);\n StackingAxis.compose(Axis, Chart, Series);\n // Default Export\n\n return G;\n });\n _modules['masters/highcharts.src.js']._modules = _modules;\n return _modules['masters/highcharts.src.js'];\n}));","/**\n * @license Highstock JS v10.3.1 (2022-10-31)\n *\n * (c) 2009-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n */\n(function (root, factory) {\n if (typeof module === 'object' && module.exports) {\n factory['default'] = factory;\n module.exports = root.document ?\n factory(root) :\n factory;\n } else if (typeof define === 'function' && define.amd) {\n define('highcharts/highstock', function () {\n return factory(root);\n });\n } else {\n if (root.Highcharts) {\n root.Highcharts.error(16, true);\n }\n root.Highcharts = factory(root);\n }\n}(typeof window !== 'undefined' ? window : this, function (window) {\n 'use strict';\n var _modules = {};\n function _registerModule(obj, path, args, fn) {\n if (!obj.hasOwnProperty(path)) {\n obj[path] = fn.apply(null, args);\n\n if (typeof CustomEvent === 'function') {\n window.dispatchEvent(\n new CustomEvent(\n 'HighchartsModuleLoaded',\n { detail: { path: path, module: obj[path] }\n })\n );\n }\n }\n }\n _registerModule(_modules, 'Core/Globals.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Namespace\n *\n * */\n /**\n * Shared Highcharts properties.\n * @private\n */\n var Globals;\n (function (Globals) {\n /* *\n *\n * Constants\n *\n * */\n Globals.SVG_NS = 'http://www.w3.org/2000/svg', Globals.product = 'Highcharts', Globals.version = '10.3.1', Globals.win = (typeof window !== 'undefined' ?\n window :\n {}), // eslint-disable-line node/no-unsupported-features/es-builtins\n Globals.doc = Globals.win.document, Globals.svg = (Globals.doc &&\n Globals.doc.createElementNS &&\n !!Globals.doc.createElementNS(Globals.SVG_NS, 'svg').createSVGRect), Globals.userAgent = (Globals.win.navigator && Globals.win.navigator.userAgent) || '', Globals.isChrome = Globals.userAgent.indexOf('Chrome') !== -1, Globals.isFirefox = Globals.userAgent.indexOf('Firefox') !== -1, Globals.isMS = /(edge|msie|trident)/i.test(Globals.userAgent) && !Globals.win.opera, Globals.isSafari = !Globals.isChrome && Globals.userAgent.indexOf('Safari') !== -1, Globals.isTouchDevice = /(Mobile|Android|Windows Phone)/.test(Globals.userAgent), Globals.isWebKit = Globals.userAgent.indexOf('AppleWebKit') !== -1, Globals.deg2rad = Math.PI * 2 / 360, Globals.hasBidiBug = (Globals.isFirefox &&\n parseInt(Globals.userAgent.split('Firefox/')[1], 10) < 4 // issue #38\n ), Globals.hasTouch = !!Globals.win.TouchEvent, Globals.marginNames = [\n 'plotTop',\n 'marginRight',\n 'marginBottom',\n 'plotLeft'\n ], Globals.noop = function () { }, Globals.supportsPassiveEvents = (function () {\n // Checks whether the browser supports passive events, (#11353).\n var supportsPassive = false;\n // Object.defineProperty doesn't work on IE as well as passive\n // events - instead of using polyfill, we can exclude IE totally.\n if (!Globals.isMS) {\n var opts = Object.defineProperty({}, 'passive', {\n get: function () {\n supportsPassive = true;\n }\n });\n if (Globals.win.addEventListener && Globals.win.removeEventListener) {\n Globals.win.addEventListener('testPassive', Globals.noop, opts);\n Globals.win.removeEventListener('testPassive', Globals.noop, opts);\n }\n }\n return supportsPassive;\n }());\n /**\n * An array containing the current chart objects in the page. A chart's\n * position in the array is preserved throughout the page's lifetime. When\n * a chart is destroyed, the array item becomes `undefined`.\n *\n * @name Highcharts.charts\n * @type {Array}\n */\n Globals.charts = [];\n /**\n * A hook for defining additional date format specifiers. New\n * specifiers are defined as key-value pairs by using the\n * specifier as key, and a function which takes the timestamp as\n * value. This function returns the formatted portion of the\n * date.\n *\n * @sample highcharts/global/dateformats/\n * Adding support for week number\n *\n * @name Highcharts.dateFormats\n * @type {Record}\n */\n Globals.dateFormats = {};\n /**\n * @private\n * @deprecated\n * @todo Use only `Core/Series/SeriesRegistry.seriesTypes`\n */\n Globals.seriesTypes = {};\n /**\n * @private\n */\n Globals.symbolSizes = {};\n /* *\n *\n * Properties\n *\n * */\n // eslint-disable-next-line prefer-const\n Globals.chartCount = 0;\n })(Globals || (Globals = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Theme options that should get applied to the chart. In module mode it\n * might not be possible to change this property because of read-only\n * restrictions, instead use {@link Highcharts.setOptions}.\n *\n * @deprecated\n * @name Highcharts.theme\n * @type {Highcharts.Options}\n */\n (''); // keeps doclets above in JS file\n\n return Globals;\n });\n _registerModule(_modules, 'Core/Utilities.js', [_modules['Core/Globals.js']], function (H) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var charts = H.charts,\n doc = H.doc,\n win = H.win;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Provide error messages for debugging, with links to online explanation. This\n * function can be overridden to provide custom error handling.\n *\n * @sample highcharts/chart/highcharts-error/\n * Custom error handler\n *\n * @function Highcharts.error\n *\n * @param {number|string} code\n * The error code. See\n * [errors.xml](https://github.com/highcharts/highcharts/blob/master/errors/errors.xml)\n * for available codes. If it is a string, the error message is printed\n * directly in the console.\n *\n * @param {boolean} [stop=false]\n * Whether to throw an error or just log a warning in the console.\n *\n * @param {Highcharts.Chart} [chart]\n * Reference to the chart that causes the error. Used in 'debugger'\n * module to display errors directly on the chart.\n * Important note: This argument is undefined for errors that lack\n * access to the Chart instance. In such case, the error will be\n * displayed on the last created chart.\n *\n * @param {Highcharts.Dictionary} [params]\n * Additional parameters for the generated message.\n *\n * @return {void}\n */\n function error(code, stop, chart, params) {\n var severity = stop ? 'Highcharts error' : 'Highcharts warning';\n if (code === 32) {\n code = \"\" + severity + \": Deprecated member\";\n }\n var isCode = isNumber(code);\n var message = isCode ?\n \"\" + severity + \" #\" + code + \": www.highcharts.com/errors/\" + code + \"/\" :\n code.toString();\n var defaultHandler = function () {\n if (stop) {\n throw new Error(message);\n }\n // else ...\n if (win.console &&\n error.messages.indexOf(message) === -1 // prevent console flooting\n ) {\n console.warn(message); // eslint-disable-line no-console\n }\n };\n if (typeof params !== 'undefined') {\n var additionalMessages_1 = '';\n if (isCode) {\n message += '?';\n }\n objectEach(params, function (value, key) {\n additionalMessages_1 += \"\\n - \".concat(key, \": \").concat(value);\n if (isCode) {\n message += encodeURI(key) + '=' + encodeURI(value);\n }\n });\n message += additionalMessages_1;\n }\n fireEvent(H, 'displayError', { chart: chart, code: code, message: message, params: params }, defaultHandler);\n error.messages.push(message);\n }\n (function (error) {\n error.messages = [];\n })(error || (error = {}));\n /* eslint-disable valid-jsdoc */\n /**\n * Utility function to deep merge two or more objects and return a third object.\n * If the first argument is true, the contents of the second object is copied\n * into the first object. The merge function can also be used with a single\n * object argument to create a deep copy of an object.\n *\n * @function Highcharts.merge\n *\n * @param {boolean} extend\n * Whether to extend the left-side object (a) or return a whole new\n * object.\n *\n * @param {T|undefined} a\n * The first object to extend. When only this is given, the function\n * returns a deep copy.\n *\n * @param {...Array} [n]\n * An object to merge into the previous one.\n *\n * @return {T}\n * The merged object. If the first argument is true, the return is the\n * same as the second argument.\n */ /**\n * Utility function to deep merge two or more objects and return a third object.\n * The merge function can also be used with a single object argument to create a\n * deep copy of an object.\n *\n * @function Highcharts.merge\n *\n * @param {T|undefined} a\n * The first object to extend. When only this is given, the function\n * returns a deep copy.\n *\n * @param {...Array} [n]\n * An object to merge into the previous one.\n *\n * @return {T}\n * The merged object. If the first argument is true, the return is the\n * same as the second argument.\n */\n function merge() {\n /* eslint-enable valid-jsdoc */\n var i,\n args = arguments,\n ret = {};\n var doCopy = function (copy,\n original) {\n // An object is replacing a primitive\n if (typeof copy !== 'object') {\n copy = {};\n }\n objectEach(original, function (value, key) {\n // Prototype pollution (#14883)\n if (key === '__proto__' || key === 'constructor') {\n return;\n }\n // Copy the contents of objects, but not arrays or DOM nodes\n if (isObject(value, true) &&\n !isClass(value) &&\n !isDOMElement(value)) {\n copy[key] = doCopy(copy[key] || {}, value);\n // Primitives and arrays are copied over directly\n }\n else {\n copy[key] = original[key];\n }\n });\n return copy;\n };\n // If first argument is true, copy into the existing object. Used in\n // setOptions.\n if (args[0] === true) {\n ret = args[1];\n args = Array.prototype.slice.call(args, 2);\n }\n // For each argument, extend the return\n var len = args.length;\n for (i = 0; i < len; i++) {\n ret = doCopy(ret, args[i]);\n }\n return ret;\n }\n /**\n * Constrain a value to within a lower and upper threshold.\n *\n * @private\n * @param {number} value The initial value\n * @param {number} min The lower threshold\n * @param {number} max The upper threshold\n * @return {number} Returns a number value within min and max.\n */\n function clamp(value, min, max) {\n return value > min ? value < max ? value : max : min;\n }\n // eslint-disable-next-line valid-jsdoc\n /**\n * Remove settings that have not changed, to avoid unnecessary rendering or\n * computing (#9197).\n * @private\n */\n function cleanRecursively(newer, older) {\n var result = {};\n objectEach(newer, function (_val, key) {\n var ob;\n // Dive into objects (except DOM nodes)\n if (isObject(newer[key], true) &&\n !newer.nodeType && // #10044\n older[key]) {\n ob = cleanRecursively(newer[key], older[key]);\n if (Object.keys(ob).length) {\n result[key] = ob;\n }\n // Arrays, primitives and DOM nodes are copied directly\n }\n else if (isObject(newer[key]) ||\n newer[key] !== older[key] ||\n // If the newer key is explicitly undefined, keep it (#10525)\n (key in newer && !(key in older))) {\n result[key] = newer[key];\n }\n });\n return result;\n }\n /**\n * Shortcut for parseInt\n *\n * @private\n * @function Highcharts.pInt\n *\n * @param {*} s\n * any\n *\n * @param {number} [mag]\n * Magnitude\n *\n * @return {number}\n * number\n */\n function pInt(s, mag) {\n return parseInt(s, mag || 10);\n }\n /**\n * Utility function to check for string type.\n *\n * @function Highcharts.isString\n *\n * @param {*} s\n * The item to check.\n *\n * @return {boolean}\n * True if the argument is a string.\n */\n function isString(s) {\n return typeof s === 'string';\n }\n /**\n * Utility function to check if an item is an array.\n *\n * @function Highcharts.isArray\n *\n * @param {*} obj\n * The item to check.\n *\n * @return {boolean}\n * True if the argument is an array.\n */\n function isArray(obj) {\n var str = Object.prototype.toString.call(obj);\n return str === '[object Array]' || str === '[object Array Iterator]';\n }\n /**\n * Utility function to check if an item is of type object.\n *\n * @function Highcharts.isObject\n *\n * @param {*} obj\n * The item to check.\n *\n * @param {boolean} [strict=false]\n * Also checks that the object is not an array.\n *\n * @return {boolean}\n * True if the argument is an object.\n */\n function isObject(obj, strict) {\n return (!!obj &&\n typeof obj === 'object' &&\n (!strict || !isArray(obj))); // eslint-disable-line @typescript-eslint/no-explicit-any\n }\n /**\n * Utility function to check if an Object is a HTML Element.\n *\n * @function Highcharts.isDOMElement\n *\n * @param {*} obj\n * The item to check.\n *\n * @return {boolean}\n * True if the argument is a HTML Element.\n */\n function isDOMElement(obj) {\n return isObject(obj) && typeof obj.nodeType === 'number';\n }\n /**\n * Utility function to check if an Object is a class.\n *\n * @function Highcharts.isClass\n *\n * @param {object|undefined} obj\n * The item to check.\n *\n * @return {boolean}\n * True if the argument is a class.\n */\n function isClass(obj) {\n var c = obj && obj.constructor;\n return !!(isObject(obj, true) &&\n !isDOMElement(obj) &&\n (c && c.name && c.name !== 'Object'));\n }\n /**\n * Utility function to check if an item is a number and it is finite (not NaN,\n * Infinity or -Infinity).\n *\n * @function Highcharts.isNumber\n *\n * @param {*} n\n * The item to check.\n *\n * @return {boolean}\n * True if the item is a finite number\n */\n function isNumber(n) {\n return typeof n === 'number' && !isNaN(n) && n < Infinity && n > -Infinity;\n }\n /**\n * Remove the last occurence of an item from an array.\n *\n * @function Highcharts.erase\n *\n * @param {Array<*>} arr\n * The array.\n *\n * @param {*} item\n * The item to remove.\n *\n * @return {void}\n */\n function erase(arr, item) {\n var i = arr.length;\n while (i--) {\n if (arr[i] === item) {\n arr.splice(i, 1);\n break;\n }\n }\n }\n /**\n * Check if an object is null or undefined.\n *\n * @function Highcharts.defined\n *\n * @param {*} obj\n * The object to check.\n *\n * @return {boolean}\n * False if the object is null or undefined, otherwise true.\n */\n function defined(obj) {\n return typeof obj !== 'undefined' && obj !== null;\n }\n /**\n * Set or get an attribute or an object of attributes.\n *\n * To use as a setter, pass a key and a value, or let the second argument be a\n * collection of keys and values. When using a collection, passing a value of\n * `null` or `undefined` will remove the attribute.\n *\n * To use as a getter, pass only a string as the second argument.\n *\n * @function Highcharts.attr\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGDOMElement} elem\n * The DOM element to receive the attribute(s).\n *\n * @param {string|Highcharts.HTMLAttributes|Highcharts.SVGAttributes} [keyOrAttribs]\n * The property or an object of key-value pairs.\n *\n * @param {number|string} [value]\n * The value if a single property is set.\n *\n * @return {string|null|undefined}\n * When used as a getter, return the value.\n */\n function attr(elem, keyOrAttribs, value) {\n var isGetter = isString(keyOrAttribs) && !defined(value);\n var ret;\n var attrSingle = function (value,\n key) {\n // Set the value\n if (defined(value)) {\n elem.setAttribute(key,\n value);\n // Get the value\n }\n else if (isGetter) {\n ret = elem.getAttribute(key);\n // IE7 and below cannot get class through getAttribute (#7850)\n if (!ret && key === 'class') {\n ret = elem.getAttribute(key + 'Name');\n }\n // Remove the value\n }\n else {\n elem.removeAttribute(key);\n }\n };\n // If keyOrAttribs is a string\n if (isString(keyOrAttribs)) {\n attrSingle(value, keyOrAttribs);\n // Else if keyOrAttribs is defined, it is a hash of key/value pairs\n }\n else {\n objectEach(keyOrAttribs, attrSingle);\n }\n return ret;\n }\n /**\n * Check if an element is an array, and if not, make it into an array.\n *\n * @function Highcharts.splat\n *\n * @param {*} obj\n * The object to splat.\n *\n * @return {Array}\n * The produced or original array.\n */\n function splat(obj) {\n return isArray(obj) ? obj : [obj];\n }\n /**\n * Set a timeout if the delay is given, otherwise perform the function\n * synchronously.\n *\n * @function Highcharts.syncTimeout\n *\n * @param {Function} fn\n * The function callback.\n *\n * @param {number} delay\n * Delay in milliseconds.\n *\n * @param {*} [context]\n * An optional context to send to the function callback.\n *\n * @return {number}\n * An identifier for the timeout that can later be cleared with\n * Highcharts.clearTimeout. Returns -1 if there is no timeout.\n */\n function syncTimeout(fn, delay, context) {\n if (delay > 0) {\n return setTimeout(fn, delay, context);\n }\n fn.call(0, context);\n return -1;\n }\n /**\n * Internal clear timeout. The function checks that the `id` was not removed\n * (e.g. by `chart.destroy()`). For the details see\n * [issue #7901](https://github.com/highcharts/highcharts/issues/7901).\n *\n * @function Highcharts.clearTimeout\n *\n * @param {number|undefined} id\n * Id of a timeout.\n */\n function internalClearTimeout(id) {\n if (defined(id)) {\n clearTimeout(id);\n }\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Utility function to extend an object with the members of another.\n *\n * @function Highcharts.extend\n *\n * @param {T|undefined} a\n * The object to be extended.\n *\n * @param {Partial} b\n * The object to add to the first one.\n *\n * @return {T}\n * Object a, the original object.\n */\n function extend(a, b) {\n /* eslint-enable valid-jsdoc */\n var n;\n if (!a) {\n a = {};\n }\n for (n in b) { // eslint-disable-line guard-for-in\n a[n] = b[n];\n }\n return a;\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Return the first value that is not null or undefined.\n *\n * @function Highcharts.pick\n *\n * @param {...Array} items\n * Variable number of arguments to inspect.\n *\n * @return {T}\n * The value of the first argument that is not null or undefined.\n */\n function pick() {\n var args = arguments;\n var length = args.length;\n for (var i = 0; i < length; i++) {\n var arg = args[i];\n if (typeof arg !== 'undefined' && arg !== null) {\n return arg;\n }\n }\n }\n /**\n * Set CSS on a given element.\n *\n * @function Highcharts.css\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGDOMElement} el\n * An HTML DOM element.\n *\n * @param {Highcharts.CSSObject} styles\n * Style object with camel case property names.\n *\n * @return {void}\n */\n function css(el, styles) {\n if (H.isMS && !H.svg) { // #2686\n if (styles && defined(styles.opacity)) {\n styles.filter = \"alpha(opacity=\".concat(styles.opacity * 100, \")\");\n }\n }\n extend(el.style, styles);\n }\n /**\n * Utility function to create an HTML element with attributes and styles.\n *\n * @function Highcharts.createElement\n *\n * @param {string} tag\n * The HTML tag.\n *\n * @param {Highcharts.HTMLAttributes} [attribs]\n * Attributes as an object of key-value pairs.\n *\n * @param {Highcharts.CSSObject} [styles]\n * Styles as an object of key-value pairs.\n *\n * @param {Highcharts.HTMLDOMElement} [parent]\n * The parent HTML object.\n *\n * @param {boolean} [nopad=false]\n * If true, remove all padding, border and margin.\n *\n * @return {Highcharts.HTMLDOMElement}\n * The created DOM element.\n */\n function createElement(tag, attribs, styles, parent, nopad) {\n var el = doc.createElement(tag);\n if (attribs) {\n extend(el, attribs);\n }\n if (nopad) {\n css(el, { padding: '0', border: 'none', margin: '0' });\n }\n if (styles) {\n css(el, styles);\n }\n if (parent) {\n parent.appendChild(el);\n }\n return el;\n }\n // eslint-disable-next-line valid-jsdoc\n /**\n * Extend a prototyped class by new members.\n *\n * @function Highcharts.extendClass\n *\n * @param {Highcharts.Class} parent\n * The parent prototype to inherit.\n *\n * @param {Highcharts.Dictionary<*>} members\n * A collection of prototype members to add or override compared to the\n * parent prototype.\n *\n * @return {Highcharts.Class}\n * A new prototype.\n */\n function extendClass(parent, members) {\n var obj = (function () { });\n obj.prototype = new parent(); // eslint-disable-line new-cap\n extend(obj.prototype, members);\n return obj;\n }\n /**\n * Left-pad a string to a given length by adding a character repetitively.\n *\n * @function Highcharts.pad\n *\n * @param {number} number\n * The input string or number.\n *\n * @param {number} [length]\n * The desired string length.\n *\n * @param {string} [padder=0]\n * The character to pad with.\n *\n * @return {string}\n * The padded string.\n */\n function pad(number, length, padder) {\n return new Array((length || 2) +\n 1 -\n String(number)\n .replace('-', '')\n .length).join(padder || '0') + number;\n }\n /**\n * Return a length based on either the integer value, or a percentage of a base.\n *\n * @function Highcharts.relativeLength\n *\n * @param {Highcharts.RelativeSize} value\n * A percentage string or a number.\n *\n * @param {number} base\n * The full length that represents 100%.\n *\n * @param {number} [offset=0]\n * A pixel offset to apply for percentage values. Used internally in\n * axis positioning.\n *\n * @return {number}\n * The computed length.\n */\n function relativeLength(value, base, offset) {\n return (/%$/).test(value) ?\n (base * parseFloat(value) / 100) + (offset || 0) :\n parseFloat(value);\n }\n /**\n * Wrap a method with extended functionality, preserving the original function.\n *\n * @function Highcharts.wrap\n *\n * @param {*} obj\n * The context object that the method belongs to. In real cases, this is\n * often a prototype.\n *\n * @param {string} method\n * The name of the method to extend.\n *\n * @param {Highcharts.WrapProceedFunction} func\n * A wrapper function callback. This function is called with the same\n * arguments as the original function, except that the original function\n * is unshifted and passed as the first argument.\n */\n function wrap(obj, method, func) {\n var proceed = obj[method];\n obj[method] = function () {\n var outerArgs = arguments,\n scope = this;\n return func.apply(this, [\n function () {\n return proceed.apply(scope, arguments.length ? arguments : outerArgs);\n }\n ].concat([].slice.call(arguments)));\n };\n }\n /**\n * Get the magnitude of a number.\n *\n * @function Highcharts.getMagnitude\n *\n * @param {number} num\n * The number.\n *\n * @return {number}\n * The magnitude, where 1-9 are magnitude 1, 10-99 magnitude 2 etc.\n */\n function getMagnitude(num) {\n return Math.pow(10, Math.floor(Math.log(num) / Math.LN10));\n }\n /**\n * Take an interval and normalize it to multiples of round numbers.\n *\n * @deprecated\n * @function Highcharts.normalizeTickInterval\n *\n * @param {number} interval\n * The raw, un-rounded interval.\n *\n * @param {Array<*>} [multiples]\n * Allowed multiples.\n *\n * @param {number} [magnitude]\n * The magnitude of the number.\n *\n * @param {boolean} [allowDecimals]\n * Whether to allow decimals.\n *\n * @param {boolean} [hasTickAmount]\n * If it has tickAmount, avoid landing on tick intervals lower than\n * original.\n *\n * @return {number}\n * The normalized interval.\n *\n * @todo\n * Move this function to the Axis prototype. It is here only for historical\n * reasons.\n */\n function normalizeTickInterval(interval, multiples, magnitude, allowDecimals, hasTickAmount) {\n var i,\n retInterval = interval;\n // round to a tenfold of 1, 2, 2.5 or 5\n magnitude = pick(magnitude, getMagnitude(interval));\n var normalized = interval / magnitude;\n // multiples for a linear scale\n if (!multiples) {\n multiples = hasTickAmount ?\n // Finer grained ticks when the tick amount is hard set, including\n // when alignTicks is true on multiple axes (#4580).\n [1, 1.2, 1.5, 2, 2.5, 3, 4, 5, 6, 8, 10] :\n // Else, let ticks fall on rounder numbers\n [1, 2, 2.5, 5, 10];\n // the allowDecimals option\n if (allowDecimals === false) {\n if (magnitude === 1) {\n multiples = multiples.filter(function (num) {\n return num % 1 === 0;\n });\n }\n else if (magnitude <= 0.1) {\n multiples = [1 / magnitude];\n }\n }\n }\n // normalize the interval to the nearest multiple\n for (i = 0; i < multiples.length; i++) {\n retInterval = multiples[i];\n // only allow tick amounts smaller than natural\n if ((hasTickAmount &&\n retInterval * magnitude >= interval) ||\n (!hasTickAmount &&\n (normalized <=\n (multiples[i] +\n (multiples[i + 1] || multiples[i])) / 2))) {\n break;\n }\n }\n // Multiply back to the correct magnitude. Correct floats to appropriate\n // precision (#6085).\n retInterval = correctFloat(retInterval * magnitude, -Math.round(Math.log(0.001) / Math.LN10));\n return retInterval;\n }\n /**\n * Sort an object array and keep the order of equal items. The ECMAScript\n * standard does not specify the behaviour when items are equal.\n *\n * @function Highcharts.stableSort\n *\n * @param {Array<*>} arr\n * The array to sort.\n *\n * @param {Function} sortFunction\n * The function to sort it with, like with regular Array.prototype.sort.\n */\n function stableSort(arr, sortFunction) {\n // @todo It seems like Chrome since v70 sorts in a stable way internally,\n // plus all other browsers do it, so over time we may be able to remove this\n // function\n var length = arr.length;\n var sortValue,\n i;\n // Add index to each item\n for (i = 0; i < length; i++) {\n arr[i].safeI = i; // stable sort index\n }\n arr.sort(function (a, b) {\n sortValue = sortFunction(a, b);\n return sortValue === 0 ? a.safeI - b.safeI : sortValue;\n });\n // Remove index from items\n for (i = 0; i < length; i++) {\n delete arr[i].safeI; // stable sort index\n }\n }\n /**\n * Non-recursive method to find the lowest member of an array. `Math.min` raises\n * a maximum call stack size exceeded error in Chrome when trying to apply more\n * than 150.000 points. This method is slightly slower, but safe.\n *\n * @function Highcharts.arrayMin\n *\n * @param {Array<*>} data\n * An array of numbers.\n *\n * @return {number}\n * The lowest number.\n */\n function arrayMin(data) {\n var i = data.length,\n min = data[0];\n while (i--) {\n if (data[i] < min) {\n min = data[i];\n }\n }\n return min;\n }\n /**\n * Non-recursive method to find the lowest member of an array. `Math.max` raises\n * a maximum call stack size exceeded error in Chrome when trying to apply more\n * than 150.000 points. This method is slightly slower, but safe.\n *\n * @function Highcharts.arrayMax\n *\n * @param {Array<*>} data\n * An array of numbers.\n *\n * @return {number}\n * The highest number.\n */\n function arrayMax(data) {\n var i = data.length,\n max = data[0];\n while (i--) {\n if (data[i] > max) {\n max = data[i];\n }\n }\n return max;\n }\n /**\n * Utility method that destroys any SVGElement instances that are properties on\n * the given object. It loops all properties and invokes destroy if there is a\n * destroy method. The property is then delete.\n *\n * @function Highcharts.destroyObjectProperties\n *\n * @param {*} obj\n * The object to destroy properties on.\n *\n * @param {*} [except]\n * Exception, do not destroy this property, only delete it.\n */\n function destroyObjectProperties(obj, except) {\n objectEach(obj, function (val, n) {\n // If the object is non-null and destroy is defined\n if (val && val !== except && val.destroy) {\n // Invoke the destroy\n val.destroy();\n }\n // Delete the property from the object.\n delete obj[n];\n });\n }\n /**\n * Discard a HTML element\n *\n * @function Highcharts.discardElement\n *\n * @param {Highcharts.HTMLDOMElement} element\n * The HTML node to discard.\n */\n function discardElement(element) {\n if (element && element.parentElement) {\n element.parentElement.removeChild(element);\n }\n }\n /**\n * Fix JS round off float errors.\n *\n * @function Highcharts.correctFloat\n *\n * @param {number} num\n * A float number to fix.\n *\n * @param {number} [prec=14]\n * The precision.\n *\n * @return {number}\n * The corrected float number.\n */\n function correctFloat(num, prec) {\n // When the number is higher than 1e14 use the number (#16275)\n return num > 1e14 ? num : parseFloat(num.toPrecision(prec || 14));\n }\n /**\n * The time unit lookup\n *\n * @ignore\n */\n var timeUnits = {\n millisecond: 1,\n second: 1000,\n minute: 60000,\n hour: 3600000,\n day: 24 * 3600000,\n week: 7 * 24 * 3600000,\n month: 28 * 24 * 3600000,\n year: 364 * 24 * 3600000\n };\n /**\n * Easing definition\n *\n * @private\n * @function Math.easeInOutSine\n *\n * @param {number} pos\n * Current position, ranging from 0 to 1.\n *\n * @return {number}\n * Ease result\n */\n Math.easeInOutSine = function (pos) {\n return -0.5 * (Math.cos(Math.PI * pos) - 1);\n };\n /**\n * Returns the value of a property path on a given object.\n *\n * @private\n * @function getNestedProperty\n *\n * @param {string} path\n * Path to the property, for example `custom.myValue`.\n *\n * @param {unknown} obj\n * Instance containing the property on the specific path.\n *\n * @return {unknown}\n * The unknown property value.\n */\n function getNestedProperty(path, parent) {\n var pathElements = path.split('.');\n while (pathElements.length && defined(parent)) {\n var pathElement = pathElements.shift();\n // Filter on the key\n if (typeof pathElement === 'undefined' ||\n pathElement === '__proto__') {\n return; // undefined\n }\n var child = parent[pathElement];\n // Filter on the child\n if (!defined(child) ||\n typeof child === 'function' ||\n typeof child.nodeType === 'number' ||\n child === win) {\n return; // undefined\n }\n // Else, proceed\n parent = child;\n }\n return parent;\n }\n /**\n * Get the computed CSS value for given element and property, only for numerical\n * properties. For width and height, the dimension of the inner box (excluding\n * padding) is returned. Used for fitting the chart within the container.\n *\n * @function Highcharts.getStyle\n *\n * @param {Highcharts.HTMLDOMElement} el\n * An HTML element.\n *\n * @param {string} prop\n * The property name.\n *\n * @param {boolean} [toInt=true]\n * Parse to integer.\n *\n * @return {number|string|undefined}\n * The style value.\n */\n function getStyle(el, prop, toInt) {\n var customGetStyle = (H.getStyle || // oldie getStyle\n getStyle);\n var style;\n // For width and height, return the actual inner pixel size (#4913)\n if (prop === 'width') {\n var offsetWidth = Math.min(el.offsetWidth,\n el.scrollWidth);\n // In flex boxes, we need to use getBoundingClientRect and floor it,\n // because scrollWidth doesn't support subpixel precision (#6427) ...\n var boundingClientRectWidth = el.getBoundingClientRect &&\n el.getBoundingClientRect().width;\n // ...unless if the containing div or its parents are transform-scaled\n // down, in which case the boundingClientRect can't be used as it is\n // also scaled down (#9871, #10498).\n if (boundingClientRectWidth < offsetWidth &&\n boundingClientRectWidth >= offsetWidth - 1) {\n offsetWidth = Math.floor(boundingClientRectWidth);\n }\n return Math.max(0, // #8377\n (offsetWidth -\n (customGetStyle(el, 'padding-left', true) || 0) -\n (customGetStyle(el, 'padding-right', true) || 0)));\n }\n if (prop === 'height') {\n return Math.max(0, // #8377\n (Math.min(el.offsetHeight, el.scrollHeight) -\n (customGetStyle(el, 'padding-top', true) || 0) -\n (customGetStyle(el, 'padding-bottom', true) || 0)));\n }\n if (!win.getComputedStyle) {\n // SVG not supported, forgot to load oldie.js?\n error(27, true);\n }\n // Otherwise, get the computed style\n var css = win.getComputedStyle(el,\n void 0); // eslint-disable-line no-undefined\n if (css) {\n style = css.getPropertyValue(prop);\n if (pick(toInt, prop !== 'opacity')) {\n style = pInt(style);\n }\n }\n return style;\n }\n /**\n * Search for an item in an array.\n *\n * @function Highcharts.inArray\n *\n * @deprecated\n *\n * @param {*} item\n * The item to search for.\n *\n * @param {Array<*>} arr\n * The array or node collection to search in.\n *\n * @param {number} [fromIndex=0]\n * The index to start searching from.\n *\n * @return {number}\n * The index within the array, or -1 if not found.\n */\n function inArray(item, arr, fromIndex) {\n error(32, false, void 0, { 'Highcharts.inArray': 'use Array.indexOf' });\n return arr.indexOf(item, fromIndex);\n }\n /**\n * Return the value of the first element in the array that satisfies the\n * provided testing function.\n *\n * @function Highcharts.find\n *\n * @param {Array} arr\n * The array to test.\n *\n * @param {Function} callback\n * The callback function. The function receives the item as the first\n * argument. Return `true` if this item satisfies the condition.\n *\n * @return {T|undefined}\n * The value of the element.\n */\n var find = Array.prototype.find ?\n function (arr,\n callback) {\n return arr.find(callback);\n } :\n // Legacy implementation. PhantomJS, IE <= 11 etc. #7223.\n function (arr, callback) {\n var i;\n var length = arr.length;\n for (i = 0; i < length; i++) {\n if (callback(arr[i], i)) { // eslint-disable-line node/callback-return\n return arr[i];\n }\n }\n };\n /**\n * Returns an array of a given object's own properties.\n *\n * @function Highcharts.keys\n * @deprecated\n *\n * @param {*} obj\n * The object of which the properties are to be returned.\n *\n * @return {Array}\n * An array of strings that represents all the properties.\n */\n function keys(obj) {\n error(32, false, void 0, { 'Highcharts.keys': 'use Object.keys' });\n return Object.keys(obj);\n }\n /**\n * Get the element's offset position, corrected for `overflow: auto`.\n *\n * @function Highcharts.offset\n *\n * @param {global.Element} el\n * The DOM element.\n *\n * @return {Highcharts.OffsetObject}\n * An object containing `left` and `top` properties for the position in\n * the page.\n */\n function offset(el) {\n var docElem = doc.documentElement,\n box = (el.parentElement || el.parentNode) ?\n el.getBoundingClientRect() :\n { top: 0,\n left: 0,\n width: 0,\n height: 0 };\n return {\n top: box.top + (win.pageYOffset || docElem.scrollTop) -\n (docElem.clientTop || 0),\n left: box.left + (win.pageXOffset || docElem.scrollLeft) -\n (docElem.clientLeft || 0),\n width: box.width,\n height: box.height\n };\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Iterate over object key pairs in an object.\n *\n * @function Highcharts.objectEach\n *\n * @param {*} obj\n * The object to iterate over.\n *\n * @param {Highcharts.ObjectEachCallbackFunction} fn\n * The iterator callback. It passes three arguments:\n * * value - The property value.\n * * key - The property key.\n * * obj - The object that objectEach is being applied to.\n *\n * @param {T} [ctx]\n * The context.\n */\n function objectEach(obj, fn, ctx) {\n /* eslint-enable valid-jsdoc */\n for (var key in obj) {\n if (Object.hasOwnProperty.call(obj, key)) {\n fn.call(ctx || obj[key], obj[key], key, obj);\n }\n }\n }\n /**\n * Iterate over an array.\n *\n * @deprecated\n * @function Highcharts.each\n *\n * @param {Array<*>} arr\n * The array to iterate over.\n *\n * @param {Function} fn\n * The iterator callback. It passes three arguments:\n * - `item`: The array item.\n * - `index`: The item's index in the array.\n * - `arr`: The array that each is being applied to.\n *\n * @param {*} [ctx]\n * The context.\n *\n * @return {void}\n */\n /**\n * Filter an array by a callback.\n *\n * @deprecated\n * @function Highcharts.grep\n *\n * @param {Array<*>} arr\n * The array to filter.\n *\n * @param {Function} callback\n * The callback function. The function receives the item as the first\n * argument. Return `true` if the item is to be preserved.\n *\n * @return {Array<*>}\n * A new, filtered array.\n */\n /**\n * Map an array by a callback.\n *\n * @deprecated\n * @function Highcharts.map\n *\n * @param {Array<*>} arr\n * The array to map.\n *\n * @param {Function} fn\n * The callback function. Return the new value for the new array.\n *\n * @return {Array<*>}\n * A new array item with modified items.\n */\n /**\n * Reduce an array to a single value.\n *\n * @deprecated\n * @function Highcharts.reduce\n *\n * @param {Array<*>} arr\n * The array to reduce.\n *\n * @param {Function} fn\n * The callback function. Return the reduced value. Receives 4\n * arguments: Accumulated/reduced value, current value, current array\n * index, and the array.\n *\n * @param {*} initialValue\n * The initial value of the accumulator.\n *\n * @return {*}\n * The reduced value.\n */\n /**\n * Test whether at least one element in the array passes the test implemented by\n * the provided function.\n *\n * @deprecated\n * @function Highcharts.some\n *\n * @param {Array<*>} arr\n * The array to test\n *\n * @param {Function} fn\n * The function to run on each item. Return truty to pass the test.\n * Receives arguments `currentValue`, `index` and `array`.\n *\n * @param {*} ctx\n * The context.\n *\n * @return {boolean}\n */\n objectEach({\n map: 'map',\n each: 'forEach',\n grep: 'filter',\n reduce: 'reduce',\n some: 'some'\n }, function (val, key) {\n H[key] = function (arr) {\n var _a;\n error(32, false, void 0, (_a = {}, _a[\"Highcharts.\".concat(key)] = \"use Array.\".concat(val), _a));\n return Array.prototype[val].apply(arr, [].slice.call(arguments, 1));\n };\n });\n /* eslint-disable valid-jsdoc */\n /**\n * Add an event listener.\n *\n * @function Highcharts.addEvent\n *\n * @param {Highcharts.Class|T} el\n * The element or object to add a listener to. It can be a\n * {@link HTMLDOMElement}, an {@link SVGElement} or any other object.\n *\n * @param {string} type\n * The event type.\n *\n * @param {Highcharts.EventCallbackFunction|Function} fn\n * The function callback to execute when the event is fired.\n *\n * @param {Highcharts.EventOptionsObject} [options]\n * Options for adding the event.\n *\n * @return {Function}\n * A callback function to remove the added event.\n */\n function addEvent(el, type, fn, options) {\n /* eslint-enable valid-jsdoc */\n if (options === void 0) { options = {}; }\n // Add hcEvents to either the prototype (in case we're running addEvent on a\n // class) or the instance. If hasOwnProperty('hcEvents') is false, it is\n // inherited down the prototype chain, in which case we need to set the\n // property on this instance (which may itself be a prototype).\n var owner = typeof el === 'function' && el.prototype || el;\n if (!Object.hasOwnProperty.call(owner, 'hcEvents')) {\n owner.hcEvents = {};\n }\n var events = owner.hcEvents;\n // Allow click events added to points, otherwise they will be prevented by\n // the TouchPointer.pinch function after a pinch zoom operation (#7091).\n if (H.Point && // without H a dependency loop occurs\n el instanceof H.Point &&\n el.series &&\n el.series.chart) {\n el.series.chart.runTrackerClick = true;\n }\n // Handle DOM events\n // If the browser supports passive events, add it to improve performance\n // on touch events (#11353).\n var addEventListener = (el.addEventListener || H.addEventListenerPolyfill);\n if (addEventListener) {\n addEventListener.call(el, type, fn, H.supportsPassiveEvents ? {\n passive: options.passive === void 0 ?\n type.indexOf('touch') !== -1 : options.passive,\n capture: false\n } : false);\n }\n if (!events[type]) {\n events[type] = [];\n }\n var eventObject = {\n fn: fn,\n order: typeof options.order === 'number' ? options.order : Infinity\n };\n events[type].push(eventObject);\n // Order the calls\n events[type].sort(function (a, b) { return a.order - b.order; });\n // Return a function that can be called to remove this event.\n return function () {\n removeEvent(el, type, fn);\n };\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Remove an event that was added with {@link Highcharts#addEvent}.\n *\n * @function Highcharts.removeEvent\n *\n * @param {Highcharts.Class|T} el\n * The element to remove events on.\n *\n * @param {string} [type]\n * The type of events to remove. If undefined, all events are removed\n * from the element.\n *\n * @param {Highcharts.EventCallbackFunction} [fn]\n * The specific callback to remove. If undefined, all events that match\n * the element and optionally the type are removed.\n *\n * @return {void}\n */\n function removeEvent(el, type, fn) {\n /* eslint-enable valid-jsdoc */\n /**\n * @private\n */\n function removeOneEvent(type, fn) {\n var removeEventListener = (el.removeEventListener || H.removeEventListenerPolyfill);\n if (removeEventListener) {\n removeEventListener.call(el, type, fn, false);\n }\n }\n /**\n * @private\n */\n function removeAllEvents(eventCollection) {\n var types,\n len;\n if (!el.nodeName) {\n return; // break on non-DOM events\n }\n if (type) {\n types = {};\n types[type] = true;\n }\n else {\n types = eventCollection;\n }\n objectEach(types, function (_val, n) {\n if (eventCollection[n]) {\n len = eventCollection[n].length;\n while (len--) {\n removeOneEvent(n, eventCollection[n][len].fn);\n }\n }\n });\n }\n var owner = typeof el === 'function' && el.prototype || el;\n if (Object.hasOwnProperty.call(owner, 'hcEvents')) {\n var events = owner.hcEvents;\n if (type) {\n var typeEvents = (events[type] || []);\n if (fn) {\n events[type] = typeEvents.filter(function (obj) {\n return fn !== obj.fn;\n });\n removeOneEvent(type, fn);\n }\n else {\n removeAllEvents(events);\n events[type] = [];\n }\n }\n else {\n removeAllEvents(events);\n delete owner.hcEvents;\n }\n }\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Fire an event that was registered with {@link Highcharts#addEvent}.\n *\n * @function Highcharts.fireEvent\n *\n * @param {T} el\n * The object to fire the event on. It can be a {@link HTMLDOMElement},\n * an {@link SVGElement} or any other object.\n *\n * @param {string} type\n * The type of event.\n *\n * @param {Highcharts.Dictionary<*>|Event} [eventArguments]\n * Custom event arguments that are passed on as an argument to the event\n * handler.\n *\n * @param {Highcharts.EventCallbackFunction|Function} [defaultFunction]\n * The default function to execute if the other listeners haven't\n * returned false.\n *\n * @return {void}\n */\n function fireEvent(el, type, eventArguments, defaultFunction) {\n /* eslint-enable valid-jsdoc */\n var e,\n i;\n eventArguments = eventArguments || {};\n if (doc.createEvent &&\n (el.dispatchEvent ||\n (el.fireEvent &&\n // Enable firing events on Highcharts instance.\n el !== H))) {\n e = doc.createEvent('Events');\n e.initEvent(type, true, true);\n eventArguments = extend(e, eventArguments);\n if (el.dispatchEvent) {\n el.dispatchEvent(eventArguments);\n }\n else {\n el.fireEvent(type, eventArguments);\n }\n }\n else if (el.hcEvents) {\n if (!eventArguments.target) {\n // We're running a custom event\n extend(eventArguments, {\n // Attach a simple preventDefault function to skip\n // default handler if called. The built-in\n // defaultPrevented property is not overwritable (#5112)\n preventDefault: function () {\n eventArguments.defaultPrevented = true;\n },\n // Setting target to native events fails with clicking\n // the zoom-out button in Chrome.\n target: el,\n // If the type is not set, we're running a custom event\n // (#2297). If it is set, we're running a browser event,\n // and setting it will cause en error in IE8 (#2465).\n type: type\n });\n }\n var events = [];\n var object = el;\n var multilevel = false;\n // Recurse up the inheritance chain and collect hcEvents set as own\n // objects on the prototypes.\n while (object.hcEvents) {\n if (Object.hasOwnProperty.call(object, 'hcEvents') &&\n object.hcEvents[type]) {\n if (events.length) {\n multilevel = true;\n }\n events.unshift.apply(events, object.hcEvents[type]);\n }\n object = Object.getPrototypeOf(object);\n }\n // For performance reasons, only sort the event handlers in case we are\n // dealing with multiple levels in the prototype chain. Otherwise, the\n // events are already sorted in the addEvent function.\n if (multilevel) {\n // Order the calls\n events.sort(function (a, b) { return a.order - b.order; });\n }\n // Call the collected event handlers\n events.forEach(function (obj) {\n // If the event handler returns false, prevent the default handler\n // from executing\n if (obj.fn.call(el, eventArguments) === false) {\n eventArguments.preventDefault();\n }\n });\n }\n // Run the default if not prevented\n if (defaultFunction && !eventArguments.defaultPrevented) {\n defaultFunction.call(el, eventArguments);\n }\n }\n var serialMode;\n /**\n * Get a unique key for using in internal element id's and pointers. The key is\n * composed of a random hash specific to this Highcharts instance, and a\n * counter.\n *\n * @example\n * let id = uniqueKey(); // => 'highcharts-x45f6hp-0'\n *\n * @function Highcharts.uniqueKey\n *\n * @return {string}\n * A unique key.\n */\n var uniqueKey = (function () {\n var hash = Math.random().toString(36).substring(2, 9) + '-';\n var id = 0;\n return function () {\n return 'highcharts-' + (serialMode ? '' : hash) + id++;\n };\n }());\n /**\n * Activates a serial mode for element IDs provided by\n * {@link Highcharts.uniqueKey}. This mode can be used in automated tests, where\n * a simple comparison of two rendered SVG graphics is needed.\n *\n * **Note:** This is only for testing purposes and will break functionality in\n * webpages with multiple charts.\n *\n * @example\n * if (\n * process &&\n * process.env.NODE_ENV === 'development'\n * ) {\n * Highcharts.useSerialIds(true);\n * }\n *\n * @function Highcharts.useSerialIds\n *\n * @param {boolean} [mode]\n * Changes the state of serial mode.\n *\n * @return {boolean|undefined}\n * State of the serial mode.\n */\n function useSerialIds(mode) {\n return (serialMode = pick(mode, serialMode));\n }\n function isFunction(obj) {\n return typeof obj === 'function';\n }\n // Register Highcharts as a plugin in jQuery\n if (win.jQuery) {\n /**\n * Highcharts-extended JQuery.\n *\n * @external JQuery\n */\n /**\n * Helper function to return the chart of the current JQuery selector\n * element.\n *\n * @function external:JQuery#highcharts\n *\n * @return {Highcharts.Chart}\n * The chart that is linked to the JQuery selector element.\n */ /**\n * Factory function to create a chart in the current JQuery selector\n * element.\n *\n * @function external:JQuery#highcharts\n *\n * @param {'Chart'|'Map'|'StockChart'|string} [className]\n * Name of the factory class in the Highcharts namespace.\n *\n * @param {Highcharts.Options} [options]\n * The chart options structure.\n *\n * @param {Highcharts.ChartCallbackFunction} [callback]\n * Function to run when the chart has loaded and and all external\n * images are loaded. Defining a\n * [chart.events.load](https://api.highcharts.com/highcharts/chart.events.load)\n * handler is equivalent.\n *\n * @return {JQuery}\n * The current JQuery selector.\n */\n win.jQuery.fn.highcharts = function () {\n var args = [].slice.call(arguments);\n if (this[0]) { // this[0] is the renderTo div\n // Create the chart\n if (args[0]) {\n new H[ // eslint-disable-line computed-property-spacing, no-new\n // Constructor defaults to Chart\n isString(args[0]) ? args.shift() : 'Chart'](this[0], args[0], args[1]);\n return this;\n }\n // When called without parameters or with the return argument,\n // return an existing chart\n return charts[attr(this[0], 'data-highcharts-chart')];\n }\n };\n }\n /* *\n *\n * Default Export\n *\n * */\n // TODO use named exports when supported.\n var Utilities = {\n addEvent: addEvent,\n arrayMax: arrayMax,\n arrayMin: arrayMin,\n attr: attr,\n clamp: clamp,\n cleanRecursively: cleanRecursively,\n clearTimeout: internalClearTimeout,\n correctFloat: correctFloat,\n createElement: createElement,\n css: css,\n defined: defined,\n destroyObjectProperties: destroyObjectProperties,\n discardElement: discardElement,\n erase: erase,\n error: error,\n extend: extend,\n extendClass: extendClass,\n find: find,\n fireEvent: fireEvent,\n getMagnitude: getMagnitude,\n getNestedProperty: getNestedProperty,\n getStyle: getStyle,\n inArray: inArray,\n isArray: isArray,\n isClass: isClass,\n isDOMElement: isDOMElement,\n isFunction: isFunction,\n isNumber: isNumber,\n isObject: isObject,\n isString: isString,\n keys: keys,\n merge: merge,\n normalizeTickInterval: normalizeTickInterval,\n objectEach: objectEach,\n offset: offset,\n pad: pad,\n pick: pick,\n pInt: pInt,\n relativeLength: relativeLength,\n removeEvent: removeEvent,\n splat: splat,\n stableSort: stableSort,\n syncTimeout: syncTimeout,\n timeUnits: timeUnits,\n uniqueKey: uniqueKey,\n useSerialIds: useSerialIds,\n wrap: wrap\n };\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * An animation configuration. Animation configurations can also be defined as\n * booleans, where `false` turns off animation and `true` defaults to a duration\n * of 500ms and defer of 0ms.\n *\n * @interface Highcharts.AnimationOptionsObject\n */ /**\n * A callback function to exectute when the animation finishes.\n * @name Highcharts.AnimationOptionsObject#complete\n * @type {Function|undefined}\n */ /**\n * The animation defer in milliseconds.\n * @name Highcharts.AnimationOptionsObject#defer\n * @type {number|undefined}\n */ /**\n * The animation duration in milliseconds.\n * @name Highcharts.AnimationOptionsObject#duration\n * @type {number|undefined}\n */ /**\n * The name of an easing function as defined on the `Math` object.\n * @name Highcharts.AnimationOptionsObject#easing\n * @type {string|Function|undefined}\n */ /**\n * A callback function to execute on each step of each attribute or CSS property\n * that's being animated. The first argument contains information about the\n * animation and progress.\n * @name Highcharts.AnimationOptionsObject#step\n * @type {Function|undefined}\n */\n /**\n * Creates a frame for the animated SVG element.\n *\n * @callback Highcharts.AnimationStepCallbackFunction\n *\n * @param {Highcharts.SVGElement} this\n * The SVG element to animate.\n *\n * @return {void}\n */\n /**\n * Interface description for a class.\n *\n * @interface Highcharts.Class\n * @extends Function\n */ /**\n * Class costructor.\n * @function Highcharts.Class#new\n * @param {...Array<*>} args\n * Constructor arguments.\n * @return {T}\n * Class instance.\n */\n /**\n * A style object with camel case property names to define visual appearance of\n * a SVG element or HTML element. The properties can be whatever styles are\n * supported on the given SVG or HTML element.\n *\n * @example\n * {\n * fontFamily: 'monospace',\n * fontSize: '1.2em'\n * }\n *\n * @interface Highcharts.CSSObject\n */ /**\n * @name Highcharts.CSSObject#[key:string]\n * @type {boolean|number|string|undefined}\n */ /**\n * Background style for the element.\n * @name Highcharts.CSSObject#background\n * @type {string|undefined}\n */ /**\n * Background color of the element.\n * @name Highcharts.CSSObject#backgroundColor\n * @type {Highcharts.ColorString|undefined}\n */ /**\n * Border style for the element.\n * @name Highcharts.CSSObject#border\n * @type {string|undefined}\n */ /**\n * Radius of the element border.\n * @name Highcharts.CSSObject#borderRadius\n * @type {number|undefined}\n */ /**\n * Color used in the element. The 'contrast' option is a Highcharts custom\n * property that results in black or white, depending on the background of the\n * element.\n * @name Highcharts.CSSObject#color\n * @type {'contrast'|Highcharts.ColorString|undefined}\n */ /**\n * Style of the mouse cursor when resting over the element.\n * @name Highcharts.CSSObject#cursor\n * @type {Highcharts.CursorValue|undefined}\n */ /**\n * Font family of the element text. Multiple values have to be in decreasing\n * preference order and separated by comma.\n * @name Highcharts.CSSObject#fontFamily\n * @type {string|undefined}\n */ /**\n * Font size of the element text.\n * @name Highcharts.CSSObject#fontSize\n * @type {string|undefined}\n */ /**\n * Font weight of the element text.\n * @name Highcharts.CSSObject#fontWeight\n * @type {string|undefined}\n */ /**\n * Height of the element.\n * @name Highcharts.CSSObject#height\n * @type {number|undefined}\n */ /**\n * Width of the element border.\n * @name Highcharts.CSSObject#lineWidth\n * @type {number|undefined}\n */ /**\n * Opacity of the element.\n * @name Highcharts.CSSObject#opacity\n * @type {number|undefined}\n */ /**\n * Space around the element content.\n * @name Highcharts.CSSObject#padding\n * @type {string|undefined}\n */ /**\n * Behaviour of the element when the mouse cursor rests over it.\n * @name Highcharts.CSSObject#pointerEvents\n * @type {string|undefined}\n */ /**\n * Positioning of the element.\n * @name Highcharts.CSSObject#position\n * @type {string|undefined}\n */ /**\n * Alignment of the element text.\n * @name Highcharts.CSSObject#textAlign\n * @type {string|undefined}\n */ /**\n * Additional decoration of the element text.\n * @name Highcharts.CSSObject#textDecoration\n * @type {string|undefined}\n */ /**\n * Outline style of the element text.\n * @name Highcharts.CSSObject#textOutline\n * @type {string|undefined}\n */ /**\n * Line break style of the element text. Highcharts SVG elements support\n * `ellipsis` when a `width` is set.\n * @name Highcharts.CSSObject#textOverflow\n * @type {string|undefined}\n */ /**\n * Top spacing of the element relative to the parent element.\n * @name Highcharts.CSSObject#top\n * @type {string|undefined}\n */ /**\n * Animated transition of selected element properties.\n * @name Highcharts.CSSObject#transition\n * @type {string|undefined}\n */ /**\n * Line break style of the element text.\n * @name Highcharts.CSSObject#whiteSpace\n * @type {string|undefined}\n */ /**\n * Width of the element.\n * @name Highcharts.CSSObject#width\n * @type {number|undefined}\n */\n /**\n * All possible cursor styles.\n *\n * @typedef {'alias'|'all-scroll'|'auto'|'cell'|'col-resize'|'context-menu'|'copy'|'crosshair'|'default'|'e-resize'|'ew-resize'|'grab'|'grabbing'|'help'|'move'|'n-resize'|'ne-resize'|'nesw-resize'|'no-drop'|'none'|'not-allowed'|'ns-resize'|'nw-resize'|'nwse-resize'|'pointer'|'progress'|'row-resize'|'s-resize'|'se-resize'|'sw-resize'|'text'|'vertical-text'|'w-resize'|'wait'|'zoom-in'|'zoom-out'} Highcharts.CursorValue\n */\n /**\n * All possible dash styles.\n *\n * @typedef {'Dash'|'DashDot'|'Dot'|'LongDash'|'LongDashDot'|'LongDashDotDot'|'ShortDash'|'ShortDashDot'|'ShortDashDotDot'|'ShortDot'|'Solid'} Highcharts.DashStyleValue\n */\n /**\n * Generic dictionary in TypeScript notation.\n * Use the native `AnyRecord` instead.\n *\n * @deprecated\n * @interface Highcharts.Dictionary\n */ /**\n * @name Highcharts.Dictionary#[key:string]\n * @type {T}\n */\n /**\n * The function callback to execute when the event is fired. The `this` context\n * contains the instance, that fired the event.\n *\n * @callback Highcharts.EventCallbackFunction\n *\n * @param {T} this\n *\n * @param {Highcharts.Dictionary<*>|Event} [eventArguments]\n * Event arguments.\n *\n * @return {boolean|void}\n */\n /**\n * The event options for adding function callback.\n *\n * @interface Highcharts.EventOptionsObject\n */ /**\n * The order the event handler should be called. This opens for having one\n * handler be called before another, independent of in which order they were\n * added.\n * @name Highcharts.EventOptionsObject#order\n * @type {number}\n */ /**\n * Whether an event should be passive or not.\n * When set to `true`, the function specified by listener will never call\n * `preventDefault()`.\n * @name Highcharts.EventOptionsObject#passive\n * @type boolean\n */\n /**\n * Formats data as a string. Usually the data is accessible throught the `this`\n * keyword.\n *\n * @callback Highcharts.FormatterCallbackFunction\n *\n * @param {T} this\n * Context to format\n *\n * @return {string}\n * Formatted text\n */\n /**\n * An object of key-value pairs for HTML attributes.\n *\n * @typedef {Highcharts.Dictionary} Highcharts.HTMLAttributes\n */\n /**\n * An HTML DOM element. The type is a reference to the regular HTMLElement in\n * the global scope.\n *\n * @typedef {global.HTMLElement} Highcharts.HTMLDOMElement\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement\n */\n /**\n * The iterator callback.\n *\n * @callback Highcharts.ObjectEachCallbackFunction\n *\n * @param {T} this\n * The context.\n *\n * @param {*} value\n * The property value.\n *\n * @param {string} key\n * The property key.\n *\n * @param {*} obj\n * The object that objectEach is being applied to.\n */\n /**\n * An object containing `left` and `top` properties for the position in the\n * page.\n *\n * @interface Highcharts.OffsetObject\n */ /**\n * Left distance to the page border.\n * @name Highcharts.OffsetObject#left\n * @type {number}\n */ /**\n * Top distance to the page border.\n * @name Highcharts.OffsetObject#top\n * @type {number}\n */\n /**\n * Describes a range.\n *\n * @interface Highcharts.RangeObject\n */ /**\n * Maximum number of the range.\n * @name Highcharts.RangeObject#max\n * @type {number}\n */ /**\n * Minimum number of the range.\n * @name Highcharts.RangeObject#min\n * @type {number}\n */\n /**\n * If a number is given, it defines the pixel length. If a percentage string is\n * given, like for example `'50%'`, the setting defines a length relative to a\n * base size, for example the size of a container.\n *\n * @typedef {number|string} Highcharts.RelativeSize\n */\n /**\n * Proceed function to call original (wrapped) function.\n *\n * @callback Highcharts.WrapProceedFunction\n *\n * @param {*} [arg1]\n * Optional argument. Without any arguments defaults to first argument of\n * the wrapping function.\n *\n * @param {*} [arg2]\n * Optional argument. Without any arguments defaults to second argument\n * of the wrapping function.\n *\n * @param {*} [arg3]\n * Optional argument. Without any arguments defaults to third argument of\n * the wrapping function.\n *\n * @return {*}\n * Return value of the original function.\n */\n /**\n * The Highcharts object is the placeholder for all other members, and various\n * utility functions. The most important member of the namespace would be the\n * chart constructor.\n *\n * @example\n * let chart = Highcharts.chart('container', { ... });\n *\n * @namespace Highcharts\n */\n ''; // detach doclets above\n\n return Utilities;\n });\n _registerModule(_modules, 'Core/Chart/ChartDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * General options for the chart.\n *\n * @optionparent chart\n */\n var ChartDefaults = {\n /**\n * Default `mapData` for all series,\n in terms of a GeoJSON or TopoJSON\n * object. If set to a string,\n it functions as an index into the\n * `Highcharts.maps` array.\n *\n * For picking out individual shapes and geometries to use for each series\n * of the map,\n see [series.mapData](#series.map.mapData).\n *\n * @sample maps/demo/geojson\n * Loading GeoJSON data\n * @sample maps/chart/topojson\n * Loading TopoJSON data\n *\n * @type {string|Array<*>|Highcharts.GeoJSON|Highcharts.TopoJSON}\n * @since 5.0.0\n * @product highmaps\n * @apioption chart.map\n */\n /**\n * Set lat/lon transformation definitions for the chart. If not defined,\n * these are extracted from the map data.\n *\n * @type {*}\n * @since 5.0.0\n * @product highmaps\n * @apioption chart.mapTransforms\n */\n /**\n * When using multiple axes,\n the ticks of two or more opposite axes\n * will automatically be aligned by adding ticks to the axis or axes\n * with the least ticks,\n as if `tickAmount` were specified.\n *\n * This can be prevented by setting `alignTicks` to false. If the grid\n * lines look messy,\n it's a good idea to hide them for the secondary\n * axis by setting `gridLineWidth` to 0.\n *\n * If `startOnTick` or `endOnTick` in the axis options are set to false,\n * then the `alignTicks ` will be disabled for the axis.\n *\n * Disabled for logarithmic axes.\n *\n * @sample {highcharts} highcharts/chart/alignticks-true/\n * True by default\n * @sample {highcharts} highcharts/chart/alignticks-false/\n * False\n * @sample {highstock} stock/chart/alignticks-true/\n * True by default\n * @sample {highstock} stock/chart/alignticks-false/\n * False\n *\n * @type {boolean}\n * @default true\n * @product highcharts highstock gantt\n * @apioption chart.alignTicks\n */\n /**\n * When using multiple axes,\n align the thresholds. When this is true,\n other\n * ticks will also be aligned.\n *\n * Note that for line series and some other series types,\n the `threshold`\n * option is set to `null` by default. This will in turn cause their y-axis\n * to not have a threshold. In order to avoid that,\n set the series\n * `threshold` to 0 or another number.\n *\n * If `startOnTick` or `endOnTick` in the axis options are set to false,\n or\n * if the axis is logarithmic,\n the threshold will not be aligned.\n *\n * @sample {highcharts} highcharts/chart/alignthresholds/ Set to true\n *\n * @since 10.0.0\n * @product highcharts highstock gantt\n * @apioption chart.alignThresholds\n */\n alignThresholds: false,\n /**\n * Set the overall animation for all chart updating. Animation can be\n * disabled throughout the chart by setting it to false here. It can\n * be overridden for each individual API method as a function parameter.\n * The only animation not affected by this option is the initial series\n * animation,\n see [plotOptions.series.animation](\n * #plotOptions.series.animation).\n *\n * The animation can either be set as a boolean or a configuration\n * object. If `true`,\n it will use the 'swing' jQuery easing and a\n * duration of 500 ms. If used as a configuration object,\n the following\n * properties are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * - `duration`: The duration of the animation in milliseconds.\n *\n * - `easing`: A string reference to an easing function set on the\n * `Math` object. See\n * [the easing demo](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-animation-easing/).\n *\n * When zooming on a series with less than 100 points,\n the chart redraw\n * will be done with animation,\n but in case of more data points,\n it is\n * necessary to set this option to ensure animation on zoom.\n *\n * @sample {highcharts} highcharts/chart/animation-none/\n * Updating with no animation\n * @sample {highcharts} highcharts/chart/animation-duration/\n * With a longer duration\n * @sample {highcharts} highcharts/chart/animation-easing/\n * With a jQuery UI easing\n * @sample {highmaps} maps/chart/animation-none/\n * Updating with no animation\n * @sample {highmaps} maps/chart/animation-duration/\n * With a longer duration\n *\n * @type {boolean|Partial}\n * @default undefined\n * @apioption chart.animation\n */\n /**\n * A CSS class name to apply to the charts container `div`,\n allowing\n * unique CSS styling for each chart.\n *\n * @type {string}\n * @apioption chart.className\n */\n /**\n * Event listeners for the chart.\n *\n * @apioption chart.events\n */\n /**\n * Fires when a series is added to the chart after load time,\n using the\n * `addSeries` method. One parameter,\n `event`,\n is passed to the\n * function,\n containing common event information. Through\n * `event.options` you can access the series options that were passed to\n * the `addSeries` method. Returning false prevents the series from\n * being added.\n *\n * @sample {highcharts} highcharts/chart/events-addseries/\n * Alert on add series\n * @sample {highstock} stock/chart/events-addseries/\n * Alert on add series\n *\n * @type {Highcharts.ChartAddSeriesCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Chart\n * @apioption chart.events.addSeries\n */\n /**\n * Fires when clicking on the plot background. One parameter,\n `event`,\n * is passed to the function,\n containing common event information.\n *\n * Information on the clicked spot can be found through `event.xAxis`\n * and `event.yAxis`,\n which are arrays containing the axes of each\n * dimension and each axis' value at the clicked spot. The primary axes\n * are `event.xAxis[0]` and `event.yAxis[0]`. Remember the unit of a\n * datetime axis is milliseconds since 1970-01-01 00:00:00.\n *\n * ```js\n * click: function(e) {\n * console.log(\n * Highcharts.dateFormat('%Y-%m-%d %H:%M:%S',\n e.xAxis[0].value),\n * e.yAxis[0].value\n * )\n * }\n * ```\n *\n * @sample {highcharts} highcharts/chart/events-click/\n * Alert coordinates on click\n * @sample {highcharts} highcharts/chart/events-container/\n * Alternatively,\n attach event to container\n * @sample {highstock} stock/chart/events-click/\n * Alert coordinates on click\n * @sample {highstock} highcharts/chart/events-container/\n * Alternatively,\n attach event to container\n * @sample {highmaps} maps/chart/events-click/\n * Record coordinates on click\n * @sample {highmaps} highcharts/chart/events-container/\n * Alternatively,\n attach event to container\n *\n * @type {Highcharts.ChartClickCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Chart\n * @apioption chart.events.click\n */\n /**\n * Fires when the chart is finished loading. Since v4.2.2,\n it also waits\n * for images to be loaded,\n for example from point markers. One\n * parameter,\n `event`,\n is passed to the function,\n containing common\n * event information.\n *\n * There is also a second parameter to the chart constructor where a\n * callback function can be passed to be executed on chart.load.\n *\n * @sample {highcharts} highcharts/chart/events-load/\n * Alert on chart load\n * @sample {highstock} stock/chart/events-load/\n * Alert on chart load\n * @sample {highmaps} maps/chart/events-load/\n * Add series on chart load\n *\n * @type {Highcharts.ChartLoadCallbackFunction}\n * @context Highcharts.Chart\n * @apioption chart.events.load\n */\n /**\n * Fires when the chart is redrawn,\n either after a call to\n * `chart.redraw()` or after an axis,\n series or point is modified with\n * the `redraw` option set to `true`. One parameter,\n `event`,\n is passed\n * to the function,\n containing common event information.\n *\n * @sample {highcharts} highcharts/chart/events-redraw/\n * Alert on chart redraw\n * @sample {highstock} stock/chart/events-redraw/\n * Alert on chart redraw when adding a series or moving the\n * zoomed range\n * @sample {highmaps} maps/chart/events-redraw/\n * Set subtitle on chart redraw\n *\n * @type {Highcharts.ChartRedrawCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Chart\n * @apioption chart.events.redraw\n */\n /**\n * Fires after initial load of the chart (directly after the `load`\n * event),\n and after each redraw (directly after the `redraw` event).\n *\n * @type {Highcharts.ChartRenderCallbackFunction}\n * @since 5.0.7\n * @context Highcharts.Chart\n * @apioption chart.events.render\n */\n /**\n * Fires when an area of the chart has been selected. Selection is\n * enabled by setting the chart's zoomType. One parameter,\n `event`,\n is\n * passed to the function,\n containing common event information. The\n * default action for the selection event is to zoom the chart to the\n * selected area. It can be prevented by calling\n * `event.preventDefault()` or return false.\n *\n * Information on the selected area can be found through `event.xAxis`\n * and `event.yAxis`,\n which are arrays containing the axes of each\n * dimension and each axis' min and max values. The primary axes are\n * `event.xAxis[0]` and `event.yAxis[0]`. Remember the unit of a\n * datetime axis is milliseconds since 1970-01-01 00:00:00.\n *\n * ```js\n * selection: function(event) {\n * // log the min and max of the primary, datetime x-axis\n * console.log(\n * Highcharts.dateFormat(\n * '%Y-%m-%d %H:%M:%S',\n * event.xAxis[0].min\n * ),\n * Highcharts.dateFormat(\n * '%Y-%m-%d %H:%M:%S',\n * event.xAxis[0].max\n * )\n * );\n * // log the min and max of the y axis\n * console.log(event.yAxis[0].min, event.yAxis[0].max);\n * }\n * ```\n *\n * @sample {highcharts} highcharts/chart/events-selection/\n * Report on selection and reset\n * @sample {highcharts} highcharts/chart/events-selection-points/\n * Select a range of points through a drag selection\n * @sample {highstock} stock/chart/events-selection/\n * Report on selection and reset\n * @sample {highstock} highcharts/chart/events-selection-points/\n * Select a range of points through a drag selection\n * (Highcharts)\n *\n * @type {Highcharts.ChartSelectionCallbackFunction}\n * @apioption chart.events.selection\n */\n /**\n * The margin between the outer edge of the chart and the plot area.\n * The numbers in the array designate top, right, bottom and left\n * respectively. Use the options `marginTop`, `marginRight`,\n * `marginBottom` and `marginLeft` for shorthand setting of one option.\n *\n * By default there is no margin. The actual space is dynamically\n * calculated from the offset of axis labels, axis title, title,\n * subtitle and legend in addition to the `spacingTop`, `spacingRight`,\n * `spacingBottom` and `spacingLeft` options.\n *\n * @sample {highcharts} highcharts/chart/margins-zero/\n * Zero margins\n * @sample {highstock} stock/chart/margin-zero/\n * Zero margins\n *\n * @type {number|Array}\n * @apioption chart.margin\n */\n /**\n * The margin between the bottom outer edge of the chart and the plot\n * area. Use this to set a fixed pixel value for the margin as opposed\n * to the default dynamic margin. See also `spacingBottom`.\n *\n * @sample {highcharts} highcharts/chart/marginbottom/\n * 100px bottom margin\n * @sample {highstock} stock/chart/marginbottom/\n * 100px bottom margin\n * @sample {highmaps} maps/chart/margin/\n * 100px margins\n *\n * @type {number}\n * @since 2.0\n * @apioption chart.marginBottom\n */\n /**\n * The margin between the left outer edge of the chart and the plot\n * area. Use this to set a fixed pixel value for the margin as opposed\n * to the default dynamic margin. See also `spacingLeft`.\n *\n * @sample {highcharts} highcharts/chart/marginleft/\n * 150px left margin\n * @sample {highstock} stock/chart/marginleft/\n * 150px left margin\n * @sample {highmaps} maps/chart/margin/\n * 100px margins\n *\n * @type {number}\n * @since 2.0\n * @apioption chart.marginLeft\n */\n /**\n * The margin between the right outer edge of the chart and the plot\n * area. Use this to set a fixed pixel value for the margin as opposed\n * to the default dynamic margin. See also `spacingRight`.\n *\n * @sample {highcharts} highcharts/chart/marginright/\n * 100px right margin\n * @sample {highstock} stock/chart/marginright/\n * 100px right margin\n * @sample {highmaps} maps/chart/margin/\n * 100px margins\n *\n * @type {number}\n * @since 2.0\n * @apioption chart.marginRight\n */\n /**\n * The margin between the top outer edge of the chart and the plot area.\n * Use this to set a fixed pixel value for the margin as opposed to\n * the default dynamic margin. See also `spacingTop`.\n *\n * @sample {highcharts} highcharts/chart/margintop/ 100px top margin\n * @sample {highstock} stock/chart/margintop/\n * 100px top margin\n * @sample {highmaps} maps/chart/margin/\n * 100px margins\n *\n * @type {number}\n * @since 2.0\n * @apioption chart.marginTop\n */\n /**\n * Callback function to override the default function that formats all\n * the numbers in the chart. Returns a string with the formatted number.\n *\n * @sample highcharts/members/highcharts-numberformat\n * Arabic digits in Highcharts\n * @type {Highcharts.NumberFormatterCallbackFunction}\n * @since 8.0.0\n * @apioption chart.numberFormatter\n */\n /**\n * Allows setting a key to switch between zooming and panning. Can be\n * one of `alt`, `ctrl`, `meta` (the command key on Mac and Windows\n * key on Windows) or `shift`. The keys are mapped directly to the key\n * properties of the click event argument (`event.altKey`,\n * `event.ctrlKey`, `event.metaKey` and `event.shiftKey`).\n *\n * @type {string}\n * @since 4.0.3\n * @product highcharts gantt\n * @validvalue [\"alt\", \"ctrl\", \"meta\", \"shift\"]\n * @apioption chart.panKey\n */\n /**\n * Allow panning in a chart. Best used with [panKey](#chart.panKey)\n * to combine zooming and panning.\n *\n * On touch devices, when the [tooltip.followTouchMove](\n * #tooltip.followTouchMove) option is `true` (default), panning\n * requires two fingers. To allow panning with one finger, set\n * `followTouchMove` to `false`.\n *\n * @sample {highcharts} highcharts/chart/pankey/ Zooming and panning\n * @sample {highstock} stock/chart/panning/ Zooming and xy panning\n */\n panning: {\n /**\n * Enable or disable chart panning.\n *\n * @type {boolean}\n * @default {highcharts} false\n * @default {highstock|highmaps} true\n */\n enabled: false,\n /**\n * Decides in what dimensions the user can pan the chart. Can be\n * one of `x`, `y`, or `xy`.\n *\n * @sample {highcharts} highcharts/chart/panning-type\n * Zooming and xy panning\n *\n * @declare Highcharts.OptionsChartPanningTypeValue\n * @type {string}\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @default {highcharts|highstock} x\n * @default {highmaps} xy\n */\n type: 'x'\n },\n /**\n * Equivalent to [zoomType](#chart.zoomType), but for multitouch\n * gestures only. By default, the `pinchType` is the same as the\n * `zoomType` setting. However, pinching can be enabled separately in\n * some cases, for example in stock charts where a mouse drag pans the\n * chart, while pinching is enabled. When [tooltip.followTouchMove](\n * #tooltip.followTouchMove) is true, pinchType only applies to\n * two-finger touches.\n *\n * @type {string}\n * @default {highcharts} undefined\n * @default {highstock} x\n * @since 3.0\n * @product highcharts highstock gantt\n * @deprecated\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @apioption chart.pinchType\n */\n /**\n * Whether to apply styled mode. When in styled mode, no presentational\n * attributes or CSS are applied to the chart SVG. Instead, CSS rules\n * are required to style the chart. The default style sheet is\n * available from `https://code.highcharts.com/css/highcharts.css`.\n *\n * @type {boolean}\n * @default false\n * @since 7.0\n * @apioption chart.styledMode\n */\n styledMode: false,\n /**\n * The corner radius of the outer chart border.\n *\n * @sample {highcharts} highcharts/chart/borderradius/\n * 20px radius\n * @sample {highstock} stock/chart/border/\n * 10px radius\n * @sample {highmaps} maps/chart/border/\n * Border options\n *\n */\n borderRadius: 0,\n /**\n * In styled mode, this sets how many colors the class names\n * should rotate between. With ten colors, series (or points) are\n * given class names like `highcharts-color-0`, `highcharts-color-0`\n * [...] `highcharts-color-9`. The equivalent in non-styled mode\n * is to set colors using the [colors](#colors) setting.\n *\n * @since 5.0.0\n */\n colorCount: 10,\n /**\n * By default, (because of memory and performance reasons) the chart does\n * not copy the data but keeps it as a reference. In some cases, this might\n * result in mutating the original data source. In order to prevent that,\n * set that property to false. Please note that changing that might decrease\n * performance, especially with bigger sets of data.\n *\n * @type {boolean}\n * @since 10.1.0\n */\n allowMutatingData: true,\n /**\n * Alias of `type`.\n *\n * @sample {highcharts} highcharts/chart/defaultseriestype/\n * Bar\n *\n * @deprecated\n *\n * @product highcharts\n */\n defaultSeriesType: 'line',\n /**\n * If true, the axes will scale to the remaining visible series once\n * one series is hidden. If false, hiding and showing a series will\n * not affect the axes or the other series. For stacks, once one series\n * within the stack is hidden, the rest of the stack will close in\n * around it even if the axis is not affected.\n *\n * @sample {highcharts} highcharts/chart/ignorehiddenseries-true/\n * True by default\n * @sample {highcharts} highcharts/chart/ignorehiddenseries-false/\n * False\n * @sample {highcharts} highcharts/chart/ignorehiddenseries-true-stacked/\n * True with stack\n * @sample {highstock} stock/chart/ignorehiddenseries-true/\n * True by default\n * @sample {highstock} stock/chart/ignorehiddenseries-false/\n * False\n *\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n ignoreHiddenSeries: true,\n /**\n * Whether to invert the axes so that the x axis is vertical and y axis\n * is horizontal. When `true`, the x axis is [reversed](#xAxis.reversed)\n * by default.\n *\n * @productdesc {highcharts}\n * If a bar series is present in the chart, it will be inverted\n * automatically. Inverting the chart doesn't have an effect if there\n * are no cartesian series in the chart, or if the chart is\n * [polar](#chart.polar).\n *\n * @sample {highcharts} highcharts/chart/inverted/\n * Inverted line\n * @sample {highstock} stock/navigator/inverted/\n * Inverted stock chart\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock gantt\n * @apioption chart.inverted\n */\n /**\n * The distance between the outer edge of the chart and the content,\n * like title or legend, or axis title and labels if present. The\n * numbers in the array designate top, right, bottom and left\n * respectively. Use the options spacingTop, spacingRight, spacingBottom\n * and spacingLeft options for shorthand setting of one option.\n *\n * @type {Array}\n * @see [chart.margin](#chart.margin)\n * @default [10, 10, 15, 10]\n * @since 3.0.6\n */\n spacing: [10, 10, 15, 10],\n /**\n * The button that appears after a selection zoom, allowing the user\n * to reset zoom.\n *\n * @since 2.2\n * @deprecated 10.2.1\n */\n resetZoomButton: {\n /**\n * What frame the button placement should be related to. Can be\n * either `plotBox` or `spacingBox`.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-relativeto/\n * Relative to the chart\n * @sample {highstock} highcharts/chart/resetzoombutton-relativeto/\n * Relative to the chart\n *\n * @type {Highcharts.ButtonRelativeToValue}\n * @default plot\n * @apioption chart.resetZoomButton.relativeTo\n */\n /**\n * A collection of attributes for the button. The object takes SVG\n * attributes like `fill`, `stroke`, `stroke-width` or `r`, the\n * border radius. The theme also supports `style`, a collection of\n * CSS properties for the text. Equivalent attributes for the hover\n * state are given in `theme.states.hover`.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-theme/\n * Theming the button\n * @sample {highstock} highcharts/chart/resetzoombutton-theme/\n * Theming the button\n *\n * @type {Highcharts.SVGAttributes}\n */\n theme: {\n /**\n * @internal\n */\n zIndex: 6\n },\n /**\n * The position of the button.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n * @sample {highstock} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n * @sample {highmaps} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n *\n * @type {Highcharts.AlignObject}\n */\n position: {\n /**\n * The horizontal alignment of the button.\n */\n align: 'right',\n /**\n * The horizontal offset of the button.\n */\n x: -10,\n /**\n * The vertical alignment of the button.\n *\n * @type {Highcharts.VerticalAlignValue}\n * @default top\n * @apioption chart.resetZoomButton.position.verticalAlign\n */\n /**\n * The vertical offset of the button.\n */\n y: 10\n }\n },\n /**\n * The pixel width of the plot area border.\n *\n * @sample {highcharts} highcharts/chart/plotborderwidth/\n * 1px border\n * @sample {highstock} stock/chart/plotborder/\n * 2px border\n * @sample {highmaps} maps/chart/plotborder/\n * Plot border options\n *\n * @type {number}\n * @default 0\n * @apioption chart.plotBorderWidth\n */\n /**\n * Whether to apply a drop shadow to the plot area. Requires that\n * plotBackgroundColor be set. The shadow can be an object configuration\n * containing `color`, `offsetX`, `offsetY`, `opacity` and `width`.\n *\n * @sample {highcharts} highcharts/chart/plotshadow/\n * Plot shadow\n * @sample {highstock} stock/chart/plotshadow/\n * Plot shadow\n * @sample {highmaps} maps/chart/plotborder/\n * Plot border options\n *\n * @type {boolean|Highcharts.CSSObject}\n * @default false\n * @apioption chart.plotShadow\n */\n /**\n * When true, cartesian charts like line, spline, area and column are\n * transformed into the polar coordinate system. This produces _polar\n * charts_, also known as _radar charts_.\n *\n * @sample {highcharts} highcharts/demo/polar/\n * Polar chart\n * @sample {highcharts} highcharts/demo/polar-wind-rose/\n * Wind rose, stacked polar column chart\n * @sample {highcharts} highcharts/demo/polar-spider/\n * Spider web chart\n * @sample {highcharts} highcharts/parallel-coordinates/polar/\n * Star plot, multivariate data in a polar chart\n *\n * @type {boolean}\n * @default false\n * @since 2.3.0\n * @product highcharts\n * @requires highcharts-more\n * @apioption chart.polar\n */\n /**\n * Whether to reflow the chart to fit the width of the container div\n * on resizing the window.\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * True by default\n * @sample {highcharts} highcharts/chart/reflow-false/\n * False\n * @sample {highstock} stock/chart/reflow-true/\n * True by default\n * @sample {highstock} stock/chart/reflow-false/\n * False\n * @sample {highmaps} maps/chart/reflow-true/\n * True by default\n * @sample {highmaps} maps/chart/reflow-false/\n * False\n *\n * @type {boolean}\n * @default true\n * @since 2.1\n * @apioption chart.reflow\n */\n /**\n * The HTML element where the chart will be rendered. If it is a string,\n * the element by that id is used. The HTML element can also be passed\n * by direct reference, or as the first argument of the chart\n * constructor, in which case the option is not needed.\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * String\n * @sample {highcharts} highcharts/chart/renderto-object/\n * Object reference\n * @sample {highstock} stock/chart/renderto-string/\n * String\n * @sample {highstock} stock/chart/renderto-object/\n * Object reference\n *\n * @type {string|Highcharts.HTMLDOMElement}\n * @apioption chart.renderTo\n */\n /**\n * The background color of the marker square when selecting (zooming\n * in on) an area of the chart.\n *\n * @see In styled mode, the selection marker fill is set with the\n * `.highcharts-selection-marker` class.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default rgba(51,92,173,0.25)\n * @since 2.1.7\n * @apioption chart.selectionMarkerFill\n */\n /**\n * Whether to apply a drop shadow to the outer chart area. Requires\n * that backgroundColor be set. The shadow can be an object\n * configuration containing `color`, `offsetX`, `offsetY`, `opacity` and\n * `width`.\n *\n * @sample {highcharts} highcharts/chart/shadow/\n * Shadow\n * @sample {highstock} stock/chart/shadow/\n * Shadow\n * @sample {highmaps} maps/chart/border/\n * Chart border and shadow\n *\n * @type {boolean|Highcharts.CSSObject}\n * @default false\n * @apioption chart.shadow\n */\n /**\n * Whether to show the axes initially. This only applies to empty charts\n * where series are added dynamically, as axes are automatically added\n * to cartesian series.\n *\n * @sample {highcharts} highcharts/chart/showaxes-false/\n * False by default\n * @sample {highcharts} highcharts/chart/showaxes-true/\n * True\n *\n * @type {boolean}\n * @since 1.2.5\n * @product highcharts gantt\n * @apioption chart.showAxes\n */\n /**\n * The space between the bottom edge of the chart and the content (plot\n * area, axis title and labels, title, subtitle or legend in top\n * position).\n *\n * @sample {highcharts} highcharts/chart/spacingbottom/\n * Spacing bottom set to 100\n * @sample {highstock} stock/chart/spacingbottom/\n * Spacing bottom set to 100\n * @sample {highmaps} maps/chart/spacing/\n * Spacing 100 all around\n *\n * @type {number}\n * @default 15\n * @since 2.1\n * @apioption chart.spacingBottom\n */\n /**\n * The space between the left edge of the chart and the content (plot\n * area, axis title and labels, title, subtitle or legend in top\n * position).\n *\n * @sample {highcharts} highcharts/chart/spacingleft/\n * Spacing left set to 100\n * @sample {highstock} stock/chart/spacingleft/\n * Spacing left set to 100\n * @sample {highmaps} maps/chart/spacing/\n * Spacing 100 all around\n *\n * @type {number}\n * @default 10\n * @since 2.1\n * @apioption chart.spacingLeft\n */\n /**\n * The space between the right edge of the chart and the content (plot\n * area, axis title and labels, title, subtitle or legend in top\n * position).\n *\n * @sample {highcharts} highcharts/chart/spacingright-100/\n * Spacing set to 100\n * @sample {highcharts} highcharts/chart/spacingright-legend/\n * Legend in right position with default spacing\n * @sample {highstock} stock/chart/spacingright/\n * Spacing set to 100\n * @sample {highmaps} maps/chart/spacing/\n * Spacing 100 all around\n *\n * @type {number}\n * @default 10\n * @since 2.1\n * @apioption chart.spacingRight\n */\n /**\n * The space between the top edge of the chart and the content (plot\n * area, axis title and labels, title, subtitle or legend in top\n * position).\n *\n * @sample {highcharts} highcharts/chart/spacingtop-100/\n * A top spacing of 100\n * @sample {highcharts} highcharts/chart/spacingtop-10/\n * Floating chart title makes the plot area align to the default\n * spacingTop of 10.\n * @sample {highstock} stock/chart/spacingtop/\n * A top spacing of 100\n * @sample {highmaps} maps/chart/spacing/\n * Spacing 100 all around\n *\n * @type {number}\n * @default 10\n * @since 2.1\n * @apioption chart.spacingTop\n */\n /**\n * Additional CSS styles to apply inline to the container `div`. Note\n * that since the default font styles are applied in the renderer, it\n * is ignorant of the individual chart options and must be set globally.\n *\n * @see In styled mode, general chart styles can be set with the\n * `.highcharts-root` class.\n * @sample {highcharts} highcharts/chart/style-serif-font/\n * Using a serif type font\n * @sample {highcharts} highcharts/css/em/\n * Styled mode with relative font sizes\n * @sample {highstock} stock/chart/style/\n * Using a serif type font\n * @sample {highmaps} maps/chart/style-serif-font/\n * Using a serif type font\n *\n * @type {Highcharts.CSSObject}\n * @default {\"fontFamily\": \"\\\"Lucida Grande\\\", \\\"Lucida Sans Unicode\\\", Verdana, Arial, Helvetica, sans-serif\",\"fontSize\":\"12px\"}\n * @apioption chart.style\n */\n /**\n * The default series type for the chart. Can be any of the chart types\n * listed under [plotOptions](#plotOptions) and [series](#series) or can\n * be a series provided by an additional module.\n *\n * In TypeScript this option has no effect in sense of typing and\n * instead the `type` option must always be set in the series.\n *\n * @sample {highcharts} highcharts/chart/type-bar/\n * Bar\n * @sample {highstock} stock/chart/type/\n * Areaspline\n * @sample {highmaps} maps/chart/type-mapline/\n * Mapline\n *\n * @type {string}\n * @default {highcharts} line\n * @default {highstock} line\n * @default {highmaps} map\n * @since 2.1.0\n * @apioption chart.type\n */\n /**\n * Decides in what dimensions the user can zoom by dragging the mouse.\n * Can be one of `x`, `y` or `xy`.\n *\n * @see [panKey](#chart.panKey)\n *\n * @sample {highcharts} highcharts/chart/zoomtype-none/\n * None by default\n * @sample {highcharts} highcharts/chart/zoomtype-x/\n * X\n * @sample {highcharts} highcharts/chart/zoomtype-y/\n * Y\n * @sample {highcharts} highcharts/chart/zoomtype-xy/\n * Xy\n * @sample {highcharts} highcharts/chart/zoomtype-polar/\n * Zoom on polar chart\n * @sample {highstock} stock/demo/basic-line/\n * None by default\n * @sample {highstock} stock/chart/zoomtype-x/\n * X\n * @sample {highstock} stock/chart/zoomtype-y/\n * Y\n * @sample {highstock} stock/chart/zoomtype-xy/\n * Xy\n * @sample {highmaps} maps/chart/zoomtype-xy/\n * Map with selection zoom\n *\n * @type {string}\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @deprecated\n * @apioption chart.zoomType\n */\n /**\n * Enables zooming by a single touch, in combination with\n * [chart.zoomType](#chart.zoomType). When enabled, two-finger pinch\n * will still work as set up by [chart.pinchType](#chart.pinchType).\n * However, `zoomBySingleTouch` will interfere with touch-dragging the\n * chart to read the tooltip. And especially when vertical zooming is\n * enabled, it will make it hard to scroll vertically on the page.\n * @since 9.0.0\n * @sample highcharts/chart/zoombysingletouch\n * Zoom by single touch enabled, with buttons to toggle\n * @product highcharts highstock gantt\n * @deprecated\n */\n zoomBySingleTouch: false,\n /**\n * Chart zooming options.\n * @since 10.2.1\n */\n zooming: {\n /**\n * Equivalent to [type](#chart.zooming.type), but for multitouch\n * gestures only. By default, the `pinchType` is the same as the\n * `type` setting. However, pinching can be enabled separately in\n * some cases, for example in stock charts where a mouse drag pans the\n * chart, while pinching is enabled. When [tooltip.followTouchMove](\n * #tooltip.followTouchMove) is true, pinchType only applies to\n * two-finger touches.\n *\n * @type {string}\n * @default {highcharts} undefined\n * @default {highstock} x\n * @product highcharts highstock gantt\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @apioption chart.zooming.pinchType\n */\n /**\n * Decides in what dimensions the user can zoom by dragging the mouse.\n * Can be one of `x`, `y` or `xy`.\n *\n * @declare Highcharts.OptionsChartZoomingTypeValue\n * @type {string}\n * @default {highcharts} undefined\n * @product highcharts highstock gantt\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @apioption chart.zooming.type\n */\n /**\n * Set a key to hold when dragging to zoom the chart. This is useful to\n * avoid zooming while moving points. Should be set different than\n * [chart.panKey](#chart.panKey).\n *\n * @type {string}\n * @default {highcharts} undefined\n * @validvalue [\"alt\", \"ctrl\", \"meta\", \"shift\"]\n * @requires modules/draggable-points\n * @apioption chart.zooming.key\n */\n /**\n * Enables zooming by a single touch, in combination with\n * [chart.zooming.type](#chart.zooming.type). When enabled, two-finger\n * pinch will still work as set up by [chart.zooming.pinchType]\n * (#chart.zooming.pinchType). However, `singleTouch` will interfere\n * with touch-dragging the chart to read the tooltip. And especially\n * when vertical zooming is enabled, it will make it hard to scroll\n * vertically on the page.\n *\n * @sample highcharts/chart/zoombysingletouch\n * Zoom by single touch enabled, with buttons to toggle\n *\n * @product highcharts highstock gantt\n */\n singleTouch: false,\n /**\n * The button that appears after a selection zoom, allowing the user\n * to reset zoom.\n */\n resetButton: {\n /**\n * What frame the button placement should be related to. Can be\n * either `plotBox` or `spacingBox`.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-relativeto/\n * Relative to the chart\n * @sample {highstock} highcharts/chart/resetzoombutton-relativeto/\n * Relative to the chart\n *\n * @type {Highcharts.ButtonRelativeToValue}\n * @default plot\n * @apioption chart.zooming.resetButton.relativeTo\n */\n /**\n * A collection of attributes for the button. The object takes SVG\n * attributes like `fill`, `stroke`, `stroke-width` or `r`, the\n * border radius. The theme also supports `style`, a collection of\n * CSS properties for the text. Equivalent attributes for the hover\n * state are given in `theme.states.hover`.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-theme/\n * Theming the button\n * @sample {highstock} highcharts/chart/resetzoombutton-theme/\n * Theming the button\n *\n * @type {Highcharts.SVGAttributes}\n * @since 10.2.1\n */\n theme: {\n /** @internal */\n zIndex: 6\n },\n /**\n * The position of the button.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n * @sample {highstock} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n * @sample {highmaps} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n *\n * @type {Highcharts.AlignObject}\n * @since 10.2.1\n */\n position: {\n /**\n * The horizontal alignment of the button.\n */\n align: 'right',\n /**\n * The horizontal offset of the button.\n */\n x: -10,\n /**\n * The vertical alignment of the button.\n *\n * @type {Highcharts.VerticalAlignValue}\n * @default top\n * @apioption chart.zooming.resetButton.position.verticalAlign\n */\n /**\n * The vertical offset of the button.\n */\n y: 10\n }\n }\n },\n /**\n * An explicit width for the chart. By default (when `null`) the width\n * is calculated from the offset width of the containing element.\n *\n * @sample {highcharts} highcharts/chart/width/\n * 800px wide\n * @sample {highstock} stock/chart/width/\n * 800px wide\n * @sample {highmaps} maps/chart/size/\n * Chart with explicit size\n *\n * @type {null|number|string}\n */\n width: null,\n /**\n * An explicit height for the chart. If a _number_, the height is\n * given in pixels. If given a _percentage string_ (for example\n * `'56%'`), the height is given as the percentage of the actual chart\n * width. This allows for preserving the aspect ratio across responsive\n * sizes.\n *\n * By default (when `null`) the height is calculated from the offset\n * height of the containing element, or 400 pixels if the containing\n * element's height is 0.\n *\n * @sample {highcharts} highcharts/chart/height/\n * 500px height\n * @sample {highstock} stock/chart/height/\n * 300px height\n * @sample {highmaps} maps/chart/size/\n * Chart with explicit size\n * @sample highcharts/chart/height-percent/\n * Highcharts with percentage height\n *\n * @type {null|number|string}\n */\n height: null,\n /**\n * The color of the outer chart border.\n *\n * @see In styled mode, the stroke is set with the\n * `.highcharts-background` class.\n *\n * @sample {highcharts} highcharts/chart/bordercolor/\n * Brown border\n * @sample {highstock} stock/chart/border/\n * Brown border\n * @sample {highmaps} maps/chart/border/\n * Border options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n borderColor: \"#335cad\" /* Palette.highlightColor80 */,\n /**\n * The pixel width of the outer chart border.\n *\n * @see In styled mode, the stroke is set with the\n * `.highcharts-background` class.\n *\n * @sample {highcharts} highcharts/chart/borderwidth/\n * 5px border\n * @sample {highstock} stock/chart/border/\n * 2px border\n * @sample {highmaps} maps/chart/border/\n * Border options\n *\n * @type {number}\n * @default 0\n * @apioption chart.borderWidth\n */\n /**\n * The background color or gradient for the outer chart area.\n *\n * @see In styled mode, the background is set with the\n * `.highcharts-background` class.\n *\n * @sample {highcharts} highcharts/chart/backgroundcolor-color/\n * Color\n * @sample {highcharts} highcharts/chart/backgroundcolor-gradient/\n * Gradient\n * @sample {highstock} stock/chart/backgroundcolor-color/\n * Color\n * @sample {highstock} stock/chart/backgroundcolor-gradient/\n * Gradient\n * @sample {highmaps} maps/chart/backgroundcolor-color/\n * Color\n * @sample {highmaps} maps/chart/backgroundcolor-gradient/\n * Gradient\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n backgroundColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The background color or gradient for the plot area.\n *\n * @see In styled mode, the plot background is set with the\n * `.highcharts-plot-background` class.\n *\n * @sample {highcharts} highcharts/chart/plotbackgroundcolor-color/\n * Color\n * @sample {highcharts} highcharts/chart/plotbackgroundcolor-gradient/\n * Gradient\n * @sample {highstock} stock/chart/plotbackgroundcolor-color/\n * Color\n * @sample {highstock} stock/chart/plotbackgroundcolor-gradient/\n * Gradient\n * @sample {highmaps} maps/chart/plotbackgroundcolor-color/\n * Color\n * @sample {highmaps} maps/chart/plotbackgroundcolor-gradient/\n * Gradient\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption chart.plotBackgroundColor\n */\n /**\n * The URL for an image to use as the plot background. To set an image\n * as the background for the entire chart, set a CSS background image\n * to the container element. Note that for the image to be applied to\n * exported charts, its URL needs to be accessible by the export server.\n *\n * @see In styled mode, a plot background image can be set with the\n * `.highcharts-plot-background` class and a [custom pattern](\n * https://www.highcharts.com/docs/chart-design-and-style/\n * gradients-shadows-and-patterns).\n *\n * @sample {highcharts} highcharts/chart/plotbackgroundimage/\n * Skies\n * @sample {highstock} stock/chart/plotbackgroundimage/\n * Skies\n *\n * @type {string}\n * @apioption chart.plotBackgroundImage\n */\n /**\n * The color of the inner chart or plot area border.\n *\n * @see In styled mode, a plot border stroke can be set with the\n * `.highcharts-plot-border` class.\n *\n * @sample {highcharts} highcharts/chart/plotbordercolor/\n * Blue border\n * @sample {highstock} stock/chart/plotborder/\n * Blue border\n * @sample {highmaps} maps/chart/plotborder/\n * Plot border options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n plotBorderColor: \"#cccccc\" /* Palette.neutralColor20 */\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return ChartDefaults;\n });\n _registerModule(_modules, 'Core/Color/Color.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var isNumber = U.isNumber,\n merge = U.merge,\n pInt = U.pInt;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Handle color operations. Some object methods are chainable.\n *\n * @class\n * @name Highcharts.Color\n *\n * @param {Highcharts.ColorType} input\n * The input color in either rbga or hex format\n */\n var Color = /** @class */ (function () {\n /* *\n *\n * Constructor\n *\n * */\n function Color(input) {\n this.rgba = [NaN, NaN, NaN, NaN];\n this.input = input;\n var GlobalColor = H.Color;\n // Backwards compatibility, allow class overwrite\n if (GlobalColor && GlobalColor !== Color) {\n return new GlobalColor(input);\n }\n // Backwards compatibility, allow instanciation without new (#13053)\n if (!(this instanceof Color)) {\n return new Color(input);\n }\n this.init(input);\n }\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Creates a color instance out of a color string or object.\n *\n * @function Highcharts.Color.parse\n *\n * @param {Highcharts.ColorType} [input]\n * The input color in either rbga or hex format.\n *\n * @return {Highcharts.Color}\n * Color instance.\n */\n Color.parse = function (input) {\n return input ? new Color(input) : Color.None;\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Parse the input color to rgba array\n *\n * @private\n * @function Highcharts.Color#init\n *\n * @param {Highcharts.ColorType} input\n * The input color in either rbga or hex format\n */\n Color.prototype.init = function (input) {\n var result,\n rgba,\n i,\n parser;\n // Gradients\n if (typeof input === 'object' &&\n typeof input.stops !== 'undefined') {\n this.stops = input.stops.map(function (stop) { return new Color(stop[1]); });\n // Solid colors\n }\n else if (typeof input === 'string') {\n this.input = input = (Color.names[input.toLowerCase()] || input);\n // Bitmasking as input[0] is not working for legacy IE.\n if (input.charAt(0) === '#') {\n var len = input.length,\n col = parseInt(input.substr(1), 16);\n // Handle long-form, e.g. #AABBCC\n if (len === 7) {\n rgba = [\n (col & 0xFF0000) >> 16,\n (col & 0xFF00) >> 8,\n (col & 0xFF),\n 1\n ];\n // Handle short-form, e.g. #ABC\n // In short form, the value is assumed to be the same\n // for both nibbles for each component. e.g. #ABC = #AABBCC\n }\n else if (len === 4) {\n rgba = [\n (((col & 0xF00) >> 4) |\n (col & 0xF00) >> 8),\n (((col & 0xF0) >> 4) |\n (col & 0xF0)),\n ((col & 0xF) << 4) | (col & 0xF),\n 1\n ];\n }\n }\n // Otherwise, check regex parsers\n if (!rgba) {\n i = Color.parsers.length;\n while (i-- && !rgba) {\n parser = Color.parsers[i];\n result = parser.regex.exec(input);\n if (result) {\n rgba = parser.parse(result);\n }\n }\n }\n }\n if (rgba) {\n this.rgba = rgba;\n }\n };\n /**\n * Return the color or gradient stops in the specified format\n *\n * @function Highcharts.Color#get\n *\n * @param {string} [format]\n * Possible values are 'a', 'rgb', 'rgba' (default).\n *\n * @return {Highcharts.ColorType}\n * This color as a string or gradient stops.\n */\n Color.prototype.get = function (format) {\n var input = this.input,\n rgba = this.rgba;\n if (typeof input === 'object' &&\n typeof this.stops !== 'undefined') {\n var ret_1 = merge(input);\n ret_1.stops = [].slice.call(ret_1.stops);\n this.stops.forEach(function (stop, i) {\n ret_1.stops[i] = [\n ret_1.stops[i][0],\n stop.get(format)\n ];\n });\n return ret_1;\n }\n // it's NaN if gradient colors on a column chart\n if (rgba && isNumber(rgba[0])) {\n if (format === 'rgb' || (!format && rgba[3] === 1)) {\n return 'rgb(' + rgba[0] + ',' + rgba[1] + ',' + rgba[2] + ')';\n }\n if (format === 'a') {\n return \"\".concat(rgba[3]);\n }\n return 'rgba(' + rgba.join(',') + ')';\n }\n return input;\n };\n /**\n * Brighten the color instance.\n *\n * @function Highcharts.Color#brighten\n *\n * @param {number} alpha\n * The alpha value.\n *\n * @return {Highcharts.Color}\n * This color with modifications.\n */\n Color.prototype.brighten = function (alpha) {\n var rgba = this.rgba;\n if (this.stops) {\n this.stops.forEach(function (stop) {\n stop.brighten(alpha);\n });\n }\n else if (isNumber(alpha) && alpha !== 0) {\n for (var i = 0; i < 3; i++) {\n rgba[i] += pInt(alpha * 255);\n if (rgba[i] < 0) {\n rgba[i] = 0;\n }\n if (rgba[i] > 255) {\n rgba[i] = 255;\n }\n }\n }\n return this;\n };\n /**\n * Set the color's opacity to a given alpha value.\n *\n * @function Highcharts.Color#setOpacity\n *\n * @param {number} alpha\n * Opacity between 0 and 1.\n *\n * @return {Highcharts.Color}\n * Color with modifications.\n */\n Color.prototype.setOpacity = function (alpha) {\n this.rgba[3] = alpha;\n return this;\n };\n /**\n * Return an intermediate color between two colors.\n *\n * @function Highcharts.Color#tweenTo\n *\n * @param {Highcharts.Color} to\n * The color object to tween to.\n *\n * @param {number} pos\n * The intermediate position, where 0 is the from color (current color\n * item), and 1 is the `to` color.\n *\n * @return {Highcharts.ColorType}\n * The intermediate color in rgba notation, or unsupported type.\n */\n Color.prototype.tweenTo = function (to, pos) {\n var fromRgba = this.rgba,\n toRgba = to.rgba;\n // Unsupported color, return to-color (#3920, #7034)\n if (!isNumber(fromRgba[0]) || !isNumber(toRgba[0])) {\n return to.input || 'none';\n }\n // Check for has alpha, because rgba colors perform worse due to\n // lack of support in WebKit.\n var hasAlpha = (toRgba[3] !== 1 || fromRgba[3] !== 1);\n return (hasAlpha ? 'rgba(' : 'rgb(') +\n Math.round(toRgba[0] + (fromRgba[0] - toRgba[0]) * (1 - pos)) +\n ',' +\n Math.round(toRgba[1] + (fromRgba[1] - toRgba[1]) * (1 - pos)) +\n ',' +\n Math.round(toRgba[2] + (fromRgba[2] - toRgba[2]) * (1 - pos)) +\n (hasAlpha ?\n (',' +\n (toRgba[3] + (fromRgba[3] - toRgba[3]) * (1 - pos))) :\n '') +\n ')';\n };\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * Collection of named colors. Can be extended from the outside by adding\n * colors to Highcharts.Color.names.\n * @private\n */\n Color.names = {\n white: '#ffffff',\n black: '#000000'\n };\n /**\n * Collection of parsers. This can be extended from the outside by pushing\n * parsers to `Color.parsers`.\n */\n Color.parsers = [{\n // RGBA color\n // eslint-disable-next-line max-len\n regex: /rgba\\(\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*,\\s*([0-9]?(?:\\.[0-9]+)?)\\s*\\)/,\n parse: function (result) {\n return [\n pInt(result[1]),\n pInt(result[2]),\n pInt(result[3]),\n parseFloat(result[4], 10)\n ];\n }\n }, {\n // RGB color\n regex: /rgb\\(\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*\\)/,\n parse: function (result) {\n return [pInt(result[1]), pInt(result[2]), pInt(result[3]), 1];\n }\n }];\n // Must be last static member for init cycle\n Color.None = new Color('');\n return Color;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * A valid color to be parsed and handled by Highcharts. Highcharts internally\n * supports hex colors like `#ffffff`, rgb colors like `rgb(255,255,255)` and\n * rgba colors like `rgba(255,255,255,1)`. Other colors may be supported by the\n * browsers and displayed correctly, but Highcharts is not able to process them\n * and apply concepts like opacity and brightening.\n *\n * @typedef {string} Highcharts.ColorString\n */\n /**\n * A valid color type than can be parsed and handled by Highcharts. It can be a\n * color string, a gradient object, or a pattern object.\n *\n * @typedef {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject} Highcharts.ColorType\n */\n /**\n * Gradient options instead of a solid color.\n *\n * @example\n * // Linear gradient used as a color option\n * color: {\n * linearGradient: { x1: 0, x2: 0, y1: 0, y2: 1 },\n * stops: [\n * [0, '#003399'], // start\n * [0.5, '#ffffff'], // middle\n * [1, '#3366AA'] // end\n * ]\n * }\n *\n * @interface Highcharts.GradientColorObject\n */ /**\n * Holds an object that defines the start position and the end position relative\n * to the shape.\n * @name Highcharts.GradientColorObject#linearGradient\n * @type {Highcharts.LinearGradientColorObject|undefined}\n */ /**\n * Holds an object that defines the center position and the radius.\n * @name Highcharts.GradientColorObject#radialGradient\n * @type {Highcharts.RadialGradientColorObject|undefined}\n */ /**\n * The first item in each tuple is the position in the gradient, where 0 is the\n * start of the gradient and 1 is the end of the gradient. Multiple stops can be\n * applied. The second item is the color for each stop. This color can also be\n * given in the rgba format.\n * @name Highcharts.GradientColorObject#stops\n * @type {Array}\n */\n /**\n * Color stop tuple.\n *\n * @see Highcharts.GradientColorObject\n *\n * @interface Highcharts.GradientColorStopObject\n */ /**\n * @name Highcharts.GradientColorStopObject#0\n * @type {number}\n */ /**\n * @name Highcharts.GradientColorStopObject#1\n * @type {Highcharts.ColorString}\n */ /**\n * @name Highcharts.GradientColorStopObject#color\n * @type {Highcharts.Color|undefined}\n */\n /**\n * Defines the start position and the end position for a gradient relative\n * to the shape. Start position (x1, y1) and end position (x2, y2) are relative\n * to the shape, where 0 means top/left and 1 is bottom/right.\n *\n * @interface Highcharts.LinearGradientColorObject\n */ /**\n * Start horizontal position of the gradient. Float ranges 0-1.\n * @name Highcharts.LinearGradientColorObject#x1\n * @type {number}\n */ /**\n * End horizontal position of the gradient. Float ranges 0-1.\n * @name Highcharts.LinearGradientColorObject#x2\n * @type {number}\n */ /**\n * Start vertical position of the gradient. Float ranges 0-1.\n * @name Highcharts.LinearGradientColorObject#y1\n * @type {number}\n */ /**\n * End vertical position of the gradient. Float ranges 0-1.\n * @name Highcharts.LinearGradientColorObject#y2\n * @type {number}\n */\n /**\n * Defines the center position and the radius for a gradient.\n *\n * @interface Highcharts.RadialGradientColorObject\n */ /**\n * Center horizontal position relative to the shape. Float ranges 0-1.\n * @name Highcharts.RadialGradientColorObject#cx\n * @type {number}\n */ /**\n * Center vertical position relative to the shape. Float ranges 0-1.\n * @name Highcharts.RadialGradientColorObject#cy\n * @type {number}\n */ /**\n * Radius relative to the shape. Float ranges 0-1.\n * @name Highcharts.RadialGradientColorObject#r\n * @type {number}\n */\n /**\n * Creates a color instance out of a color string.\n *\n * @function Highcharts.color\n *\n * @param {Highcharts.ColorType} input\n * The input color in either rbga or hex format\n *\n * @return {Highcharts.Color}\n * Color instance\n */\n (''); // detach doclets above\n\n return Color;\n });\n _registerModule(_modules, 'Core/Color/Palettes.js', [], function () {\n /**\n * Series palettes for Highcharts. Series colors are defined in highcharts.scss.\n * **Do not edit this file!** This file is generated using the 'gulp palette' task.\n */\n var SeriesPalettes = {\n /**\n * Colors for data series and points.\n */\n colors: [\n '#7cb5ec',\n '#434348',\n '#90ed7d',\n '#f7a35c',\n '#8085e9',\n '#f15c80',\n '#e4d354',\n '#2b908f',\n '#f45b5b',\n '#91e8e1'\n ]\n };\n\n return SeriesPalettes;\n });\n _registerModule(_modules, 'Core/Time.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var win = H.win;\n var defined = U.defined,\n error = U.error,\n extend = U.extend,\n isObject = U.isObject,\n merge = U.merge,\n objectEach = U.objectEach,\n pad = U.pad,\n pick = U.pick,\n splat = U.splat,\n timeUnits = U.timeUnits;\n /* *\n *\n * Constants\n *\n * */\n var hasNewSafariBug = H.isSafari &&\n win.Intl &&\n win.Intl.DateTimeFormat.prototype.formatRange;\n // To do: Remove this when we no longer need support for Safari < v14.1\n var hasOldSafariBug = H.isSafari &&\n win.Intl &&\n !win.Intl.DateTimeFormat.prototype.formatRange;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The Time class. Time settings are applied in general for each page using\n * `Highcharts.setOptions`, or individually for each Chart item through the\n * [time](https://api.highcharts.com/highcharts/time) options set.\n *\n * The Time object is available from {@link Highcharts.Chart#time},\n * which refers to `Highcharts.time` if no individual time settings are\n * applied.\n *\n * @example\n * // Apply time settings globally\n * Highcharts.setOptions({\n * time: {\n * timezone: 'Europe/London'\n * }\n * });\n *\n * // Apply time settings by instance\n * let chart = Highcharts.chart('container', {\n * time: {\n * timezone: 'America/New_York'\n * },\n * series: [{\n * data: [1, 4, 3, 5]\n * }]\n * });\n *\n * // Use the Time object\n * console.log(\n * 'Current time in New York',\n * chart.time.dateFormat('%Y-%m-%d %H:%M:%S', Date.now())\n * );\n *\n * @since 6.0.5\n *\n * @class\n * @name Highcharts.Time\n *\n * @param {Highcharts.TimeOptions} [options]\n * Time options as defined in [chart.options.time](/highcharts/time).\n */\n var Time = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Time(options) {\n /* *\n *\n * Properties\n *\n * */\n this.options = {};\n this.useUTC = false;\n this.variableTimezone = false;\n this.Date = win.Date;\n /**\n * Get the time zone offset based on the current timezone information as\n * set in the global options.\n *\n * @function Highcharts.Time#getTimezoneOffset\n *\n * @param {number} timestamp\n * The JavaScript timestamp to inspect.\n *\n * @return {number}\n * The timezone offset in minutes compared to UTC.\n */\n this.getTimezoneOffset = this.timezoneOffsetFunction();\n this.update(options);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Time units used in `Time.get` and `Time.set`\n *\n * @typedef {\"Date\"|\"Day\"|\"FullYear\"|\"Hours\"|\"Milliseconds\"|\"Minutes\"|\"Month\"|\"Seconds\"} Highcharts.TimeUnitValue\n */\n /**\n * Get the value of a date object in given units, and subject to the Time\n * object's current timezone settings. This function corresponds directly to\n * JavaScripts `Date.getXXX / Date.getUTCXXX`, so instead of calling\n * `date.getHours()` or `date.getUTCHours()` we will call\n * `time.get('Hours')`.\n *\n * @function Highcharts.Time#get\n *\n * @param {Highcharts.TimeUnitValue} unit\n * @param {Date} date\n *\n * @return {number}\n * The given time unit\n */\n Time.prototype.get = function (unit, date) {\n if (this.variableTimezone || this.timezoneOffset) {\n var realMs = date.getTime();\n var ms = realMs - this.getTimezoneOffset(date);\n date.setTime(ms); // Temporary adjust to timezone\n var ret = date['getUTC' + unit]();\n date.setTime(realMs); // Reset\n return ret;\n }\n // UTC time with no timezone handling\n if (this.useUTC) {\n return date['getUTC' + unit]();\n }\n // Else, local time\n return date['get' + unit]();\n };\n /**\n * Set the value of a date object in given units, and subject to the Time\n * object's current timezone settings. This function corresponds directly to\n * JavaScripts `Date.setXXX / Date.setUTCXXX`, so instead of calling\n * `date.setHours(0)` or `date.setUTCHours(0)` we will call\n * `time.set('Hours', 0)`.\n *\n * @function Highcharts.Time#set\n *\n * @param {Highcharts.TimeUnitValue} unit\n * @param {Date} date\n * @param {number} value\n *\n * @return {number}\n * The epoch milliseconds of the updated date\n */\n Time.prototype.set = function (unit, date, value) {\n // UTC time with timezone handling\n if (this.variableTimezone || this.timezoneOffset) {\n // For lower order time units, just set it directly using UTC\n // time\n if (unit === 'Milliseconds' ||\n unit === 'Seconds' ||\n (unit === 'Minutes' &&\n this.getTimezoneOffset(date) % 3600000 === 0) // #13961\n ) {\n return date['setUTC' + unit](value);\n }\n // Higher order time units need to take the time zone into\n // account\n // Adjust by timezone\n var offset = this.getTimezoneOffset(date);\n var ms = date.getTime() - offset;\n date.setTime(ms);\n date['setUTC' + unit](value);\n var newOffset = this.getTimezoneOffset(date);\n ms = date.getTime() + newOffset;\n return date.setTime(ms);\n }\n // UTC time with no timezone handling\n if (this.useUTC ||\n // leap calculation in UTC only\n (hasNewSafariBug && unit === 'FullYear')) {\n return date['setUTC' + unit](value);\n }\n // Else, local time\n return date['set' + unit](value);\n };\n /**\n * Update the Time object with current options. It is called internally on\n * initializing Highcharts, after running `Highcharts.setOptions` and on\n * `Chart.update`.\n *\n * @private\n * @function Highcharts.Time#update\n *\n * @param {Highcharts.TimeOptions} [options]\n *\n */\n Time.prototype.update = function (options) {\n if (options === void 0) { options = {}; }\n var useUTC = pick(options.useUTC,\n true);\n this.options = options = merge(true, this.options, options);\n // Allow using a different Date class\n this.Date = options.Date || win.Date || Date;\n this.useUTC = useUTC;\n this.timezoneOffset = (useUTC && options.timezoneOffset) || void 0;\n this.getTimezoneOffset = this.timezoneOffsetFunction();\n /*\n * The time object has options allowing for variable time zones, meaning\n * the axis ticks or series data needs to consider this.\n */\n this.variableTimezone = useUTC && !!(options.getTimezoneOffset ||\n options.timezone);\n };\n /**\n * Make a time and returns milliseconds. Interprets the inputs as UTC time,\n * local time or a specific timezone time depending on the current time\n * settings.\n *\n * @function Highcharts.Time#makeTime\n *\n * @param {number} year\n * The year\n *\n * @param {number} month\n * The month. Zero-based, so January is 0.\n *\n * @param {number} [date=1]\n * The day of the month\n *\n * @param {number} [hours=0]\n * The hour of the day, 0-23.\n *\n * @param {number} [minutes=0]\n * The minutes\n *\n * @param {number} [seconds=0]\n * The seconds\n *\n * @return {number}\n * The time in milliseconds since January 1st 1970.\n */\n Time.prototype.makeTime = function (year, month, date, hours, minutes, seconds) {\n var d,\n offset,\n newOffset;\n if (this.useUTC) {\n d = this.Date.UTC.apply(0, arguments);\n offset = this.getTimezoneOffset(d);\n d += offset;\n newOffset = this.getTimezoneOffset(d);\n if (offset !== newOffset) {\n d += newOffset - offset;\n // A special case for transitioning from summer time to winter time.\n // When the clock is set back, the same time is repeated twice, i.e.\n // 02:30 am is repeated since the clock is set back from 3 am to\n // 2 am. We need to make the same time as local Date does.\n }\n else if (offset - 36e5 === this.getTimezoneOffset(d - 36e5) &&\n !hasOldSafariBug) {\n d -= 36e5;\n }\n }\n else {\n d = new this.Date(year, month, pick(date, 1), pick(hours, 0), pick(minutes, 0), pick(seconds, 0)).getTime();\n }\n return d;\n };\n /**\n * Sets the getTimezoneOffset function. If the `timezone` option is set, a\n * default getTimezoneOffset function with that timezone is returned. If\n * a `getTimezoneOffset` option is defined, it is returned. If neither are\n * specified, the function using the `timezoneOffset` option or 0 offset is\n * returned.\n *\n * @private\n * @function Highcharts.Time#timezoneOffsetFunction\n *\n * @return {Function}\n * A getTimezoneOffset function\n */\n Time.prototype.timezoneOffsetFunction = function () {\n var time = this,\n options = this.options,\n getTimezoneOffset = options.getTimezoneOffset,\n moment = options.moment || win.moment;\n if (!this.useUTC) {\n return function (timestamp) {\n return new Date(timestamp.toString()).getTimezoneOffset() * 60000;\n };\n }\n if (options.timezone) {\n if (!moment) {\n // getTimezoneOffset-function stays undefined because it depends\n // on Moment.js\n error(25);\n }\n else {\n return function (timestamp) {\n return -moment.tz(timestamp, options.timezone).utcOffset() * 60000;\n };\n }\n }\n // If not timezone is set, look for the getTimezoneOffset callback\n if (this.useUTC && getTimezoneOffset) {\n return function (timestamp) {\n return getTimezoneOffset(timestamp.valueOf()) * 60000;\n };\n }\n // Last, use the `timezoneOffset` option if set\n return function () {\n return (time.timezoneOffset || 0) * 60000;\n };\n };\n /**\n * Formats a JavaScript date timestamp (milliseconds since Jan 1st 1970)\n * into a human readable date string. The available format keys are listed\n * below. Additional formats can be given in the\n * {@link Highcharts.dateFormats} hook.\n *\n * Supported format keys:\n * - `%a`: Short weekday, like 'Mon'\n * - `%A`: Long weekday, like 'Monday'\n * - `%d`: Two digit day of the month, 01 to 31\n * - `%e`: Day of the month, 1 through 31\n * - `%w`: Day of the week, 0 through 6\n * - `%b`: Short month, like 'Jan'\n * - `%B`: Long month, like 'January'\n * - `%m`: Two digit month number, 01 through 12\n * - `%y`: Two digits year, like 09 for 2009\n * - `%Y`: Four digits year, like 2009\n * - `%H`: Two digits hours in 24h format, 00 through 23\n * - `%k`: Hours in 24h format, 0 through 23\n * - `%I`: Two digits hours in 12h format, 00 through 11\n * - `%l`: Hours in 12h format, 1 through 12\n * - `%M`: Two digits minutes, 00 through 59\n * - `%p`: Upper case AM or PM\n * - `%P`: Lower case AM or PM\n * - `%S`: Two digits seconds, 00 through 59\n * - `%L`: Milliseconds (naming from Ruby)\n *\n * @example\n * const time = new Highcharts.Time();\n * const s = time.dateFormat('%Y-%m-%d %H:%M:%S', Date.UTC(2020, 0, 1));\n * console.log(s); // => 2020-01-01 00:00:00\n *\n * @function Highcharts.Time#dateFormat\n *\n * @param {string} format\n * The desired format where various time representations are\n * prefixed with %.\n *\n * @param {number} [timestamp]\n * The JavaScript timestamp.\n *\n * @param {boolean} [capitalize=false]\n * Upper case first letter in the return.\n *\n * @return {string}\n * The formatted date.\n */\n Time.prototype.dateFormat = function (format, timestamp, capitalize) {\n if (!defined(timestamp) || isNaN(timestamp)) {\n return (H.defaultOptions.lang &&\n H.defaultOptions.lang.invalidDate ||\n '');\n }\n format = pick(format, '%Y-%m-%d %H:%M:%S');\n var time = this, date = new this.Date(timestamp), \n // get the basic time values\n hours = this.get('Hours', date), day = this.get('Day', date), dayOfMonth = this.get('Date', date), month = this.get('Month', date), fullYear = this.get('FullYear', date), lang = H.defaultOptions.lang, langWeekdays = (lang && lang.weekdays), shortWeekdays = (lang && lang.shortWeekdays), \n // List all format keys. Custom formats can be added from the\n // outside.\n replacements = extend({\n // Day\n // Short weekday, like 'Mon'\n a: shortWeekdays ?\n shortWeekdays[day] :\n langWeekdays[day].substr(0, 3),\n // Long weekday, like 'Monday'\n A: langWeekdays[day],\n // Two digit day of the month, 01 to 31\n d: pad(dayOfMonth),\n // Day of the month, 1 through 31\n e: pad(dayOfMonth, 2, ' '),\n // Day of the week, 0 through 6\n w: day,\n // Week (none implemented)\n // 'W': weekNumber(),\n // Month\n // Short month, like 'Jan'\n b: lang.shortMonths[month],\n // Long month, like 'January'\n B: lang.months[month],\n // Two digit month number, 01 through 12\n m: pad(month + 1),\n // Month number, 1 through 12 (#8150)\n o: month + 1,\n // Year\n // Two digits year, like 09 for 2009\n y: fullYear.toString().substr(2, 2),\n // Four digits year, like 2009\n Y: fullYear,\n // Time\n // Two digits hours in 24h format, 00 through 23\n H: pad(hours),\n // Hours in 24h format, 0 through 23\n k: hours,\n // Two digits hours in 12h format, 00 through 11\n I: pad((hours % 12) || 12),\n // Hours in 12h format, 1 through 12\n l: (hours % 12) || 12,\n // Two digits minutes, 00 through 59\n M: pad(this.get('Minutes', date)),\n // Upper case AM or PM\n p: hours < 12 ? 'AM' : 'PM',\n // Lower case AM or PM\n P: hours < 12 ? 'am' : 'pm',\n // Two digits seconds, 00 through 59\n S: pad(date.getSeconds()),\n // Milliseconds (naming from Ruby)\n L: pad(Math.floor(timestamp % 1000), 3)\n }, H.dateFormats);\n // Do the replaces\n objectEach(replacements, function (val, key) {\n // Regex would do it in one line, but this is faster\n while (format.indexOf('%' + key) !== -1) {\n format = format.replace('%' + key, typeof val === 'function' ? val.call(time, timestamp) : val);\n }\n });\n // Optionally capitalize the string and return\n return capitalize ?\n (format.substr(0, 1).toUpperCase() +\n format.substr(1)) :\n format;\n };\n /**\n * Resolve legacy formats of dateTimeLabelFormats (strings and arrays) into\n * an object.\n * @private\n * @param {string|Array|Highcharts.Dictionary} f\n * General format description\n * @return {Highcharts.Dictionary}\n * The object definition\n */\n Time.prototype.resolveDTLFormat = function (f) {\n if (!isObject(f, true)) { // check for string or array\n f = splat(f);\n return {\n main: f[0],\n from: f[1],\n to: f[2]\n };\n }\n return f;\n };\n /**\n * Return an array with time positions distributed on round time values\n * right and right after min and max. Used in datetime axes as well as for\n * grouping data on a datetime axis.\n *\n * @function Highcharts.Time#getTimeTicks\n *\n * @param {Highcharts.TimeNormalizedObject} normalizedInterval\n * The interval in axis values (ms) and the count\n *\n * @param {number} [min]\n * The minimum in axis values\n *\n * @param {number} [max]\n * The maximum in axis values\n *\n * @param {number} [startOfWeek=1]\n *\n * @return {Highcharts.AxisTickPositionsArray}\n * Time positions\n */\n Time.prototype.getTimeTicks = function (normalizedInterval, min, max, startOfWeek) {\n var time = this,\n Date = time.Date,\n tickPositions = [],\n higherRanks = {}, \n // When crossing DST, use the max. Resolves #6278.\n minDate = new Date(min),\n interval = normalizedInterval.unitRange,\n count = normalizedInterval.count || 1;\n var i,\n minYear, // used in months and years as a basis for Date.UTC()\n variableDayLength,\n minDay;\n startOfWeek = pick(startOfWeek, 1);\n if (defined(min)) { // #1300\n time.set('Milliseconds', minDate, interval >= timeUnits.second ?\n 0 : // #3935\n count * Math.floor(time.get('Milliseconds', minDate) / count)); // #3652, #3654\n if (interval >= timeUnits.second) { // second\n time.set('Seconds', minDate, interval >= timeUnits.minute ?\n 0 : // #3935\n count * Math.floor(time.get('Seconds', minDate) / count));\n }\n if (interval >= timeUnits.minute) { // minute\n time.set('Minutes', minDate, interval >= timeUnits.hour ?\n 0 :\n count * Math.floor(time.get('Minutes', minDate) / count));\n }\n if (interval >= timeUnits.hour) { // hour\n time.set('Hours', minDate, interval >= timeUnits.day ?\n 0 :\n count * Math.floor(time.get('Hours', minDate) / count));\n }\n if (interval >= timeUnits.day) { // day\n time.set('Date', minDate, interval >= timeUnits.month ?\n 1 :\n Math.max(1, count * Math.floor(time.get('Date', minDate) / count)));\n }\n if (interval >= timeUnits.month) { // month\n time.set('Month', minDate, interval >= timeUnits.year ? 0 :\n count * Math.floor(time.get('Month', minDate) / count));\n minYear = time.get('FullYear', minDate);\n }\n if (interval >= timeUnits.year) { // year\n minYear -= minYear % count;\n time.set('FullYear', minDate, minYear);\n }\n // week is a special case that runs outside the hierarchy\n if (interval === timeUnits.week) {\n // get start of current week, independent of count\n minDay = time.get('Day', minDate);\n time.set('Date', minDate, (time.get('Date', minDate) -\n minDay + startOfWeek +\n // We don't want to skip days that are before\n // startOfWeek (#7051)\n (minDay < startOfWeek ? -7 : 0)));\n }\n // Get basics for variable time spans\n minYear = time.get('FullYear', minDate);\n var minMonth = time.get('Month', minDate), minDateDate = time.get('Date', minDate), minHours = time.get('Hours', minDate);\n // Redefine min to the floored/rounded minimum time (#7432)\n min = minDate.getTime();\n // Handle local timezone offset\n if ((time.variableTimezone || !time.useUTC) && defined(max)) {\n // Detect whether we need to take the DST crossover into\n // consideration. If we're crossing over DST, the day length may\n // be 23h or 25h and we need to compute the exact clock time for\n // each tick instead of just adding hours. This comes at a cost,\n // so first we find out if it is needed (#4951).\n variableDayLength = (\n // Long range, assume we're crossing over.\n max - min > 4 * timeUnits.month ||\n // Short range, check if min and max are in different time\n // zones.\n time.getTimezoneOffset(min) !==\n time.getTimezoneOffset(max));\n }\n // Iterate and add tick positions at appropriate values\n var t = minDate.getTime();\n i = 1;\n while (t < max) {\n tickPositions.push(t);\n // if the interval is years, use Date.UTC to increase years\n if (interval === timeUnits.year) {\n t = time.makeTime(minYear + i * count, 0);\n // if the interval is months, use Date.UTC to increase months\n }\n else if (interval === timeUnits.month) {\n t = time.makeTime(minYear, minMonth + i * count);\n // if we're using global time, the interval is not fixed as it\n // jumps one hour at the DST crossover\n }\n else if (variableDayLength &&\n (interval === timeUnits.day || interval === timeUnits.week)) {\n t = time.makeTime(minYear, minMonth, minDateDate +\n i * count * (interval === timeUnits.day ? 1 : 7));\n }\n else if (variableDayLength &&\n interval === timeUnits.hour &&\n count > 1) {\n // make sure higher ranks are preserved across DST (#6797,\n // #7621)\n t = time.makeTime(minYear, minMonth, minDateDate, minHours + i * count);\n // else, the interval is fixed and we use simple addition\n }\n else {\n t += interval * count;\n }\n i++;\n }\n // push the last time\n tickPositions.push(t);\n // Handle higher ranks. Mark new days if the time is on midnight\n // (#950, #1649, #1760, #3349). Use a reasonable dropout threshold\n // to prevent looping over dense data grouping (#6156).\n if (interval <= timeUnits.hour && tickPositions.length < 10000) {\n tickPositions.forEach(function (t) {\n if (\n // Speed optimization, no need to run dateFormat unless\n // we're on a full or half hour\n t % 1800000 === 0 &&\n // Check for local or global midnight\n time.dateFormat('%H%M%S%L', t) === '000000000') {\n higherRanks[t] = 'day';\n }\n });\n }\n }\n // record information on the chosen unit - for dynamic label formatter\n tickPositions.info = extend(normalizedInterval, {\n higherRanks: higherRanks,\n totalRange: interval * count\n });\n return tickPositions;\n };\n /**\n * Get the optimal date format for a point, based on a range.\n *\n * @private\n * @function Highcharts.Time#getDateFormat\n *\n * @param {number} range\n * The time range\n *\n * @param {number} timestamp\n * The timestamp of the date\n *\n * @param {number} startOfWeek\n * An integer representing the first day of the week, where 0 is\n * Sunday.\n *\n * @param {Highcharts.Dictionary} dateTimeLabelFormats\n * A map of time units to formats.\n *\n * @return {string}\n * The optimal date format for a point.\n */\n Time.prototype.getDateFormat = function (range, timestamp, startOfWeek, dateTimeLabelFormats) {\n var dateStr = this.dateFormat('%m-%d %H:%M:%S.%L', timestamp), blank = '01-01 00:00:00.000', strpos = {\n millisecond: 15,\n second: 12,\n minute: 9,\n hour: 6,\n day: 3\n };\n var n = 'millisecond', \n // for sub-millisecond data, #4223\n lastN = n;\n for (n in timeUnits) { // eslint-disable-line guard-for-in\n // If the range is exactly one week and we're looking at a\n // Sunday/Monday, go for the week format\n if (range === timeUnits.week &&\n +this.dateFormat('%w', timestamp) === startOfWeek &&\n dateStr.substr(6) === blank.substr(6)) {\n n = 'week';\n break;\n }\n // The first format that is too great for the range\n if (timeUnits[n] > range) {\n n = lastN;\n break;\n }\n // If the point is placed every day at 23:59, we need to show\n // the minutes as well. #2637.\n if (strpos[n] &&\n dateStr.substr(strpos[n]) !== blank.substr(strpos[n])) {\n break;\n }\n // Weeks are outside the hierarchy, only apply them on\n // Mondays/Sundays like in the first condition\n if (n !== 'week') {\n lastN = n;\n }\n }\n return this.resolveDTLFormat(dateTimeLabelFormats[n]).main;\n };\n return Time;\n }());\n /* *\n *\n * Default export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Normalized interval.\n *\n * @interface Highcharts.TimeNormalizedObject\n */ /**\n * The count.\n *\n * @name Highcharts.TimeNormalizedObject#count\n * @type {number|undefined}\n */ /**\n * The interval in axis values (ms).\n *\n * @name Highcharts.TimeNormalizedObject#unitRange\n * @type {number}\n */\n /**\n * Function of an additional date format specifier.\n *\n * @callback Highcharts.TimeFormatCallbackFunction\n *\n * @param {number} timestamp\n * The time to format.\n *\n * @return {string}\n * The formatted portion of the date.\n */\n /**\n * Time ticks.\n *\n * @interface Highcharts.AxisTickPositionsArray\n * @extends global.Array\n */ /**\n * @name Highcharts.AxisTickPositionsArray#info\n * @type {Highcharts.TimeTicksInfoObject|undefined}\n */\n /**\n * A callback to return the time zone offset for a given datetime. It\n * takes the timestamp in terms of milliseconds since January 1 1970,\n * and returns the timezone offset in minutes. This provides a hook\n * for drawing time based charts in specific time zones using their\n * local DST crossover dates, with the help of external libraries.\n *\n * @callback Highcharts.TimezoneOffsetCallbackFunction\n *\n * @param {number} timestamp\n * Timestamp in terms of milliseconds since January 1 1970.\n *\n * @return {number}\n * Timezone offset in minutes.\n */\n /**\n * Allows to manually load the `moment.js` library from Highcharts options\n * instead of the `window`.\n * In case of loading the library from a `script` tag,\n * this option is not needed, it will be loaded from there by default.\n *\n * @type {Function}\n * @since 8.2.0\n * @apioption time.moment\n */\n ''; // keeps doclets above in JS file\n\n return Time;\n });\n _registerModule(_modules, 'Core/Defaults.js', [_modules['Core/Chart/ChartDefaults.js'], _modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Color/Palettes.js'], _modules['Core/Time.js'], _modules['Core/Utilities.js']], function (ChartDefaults, Color, H, Palettes, Time, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var color = Color.parse;\n var isTouchDevice = H.isTouchDevice,\n svg = H.svg;\n var merge = U.merge;\n /* *\n *\n * API Options\n *\n * */\n /**\n * Global default settings.\n *\n * @name Highcharts.defaultOptions\n * @type {Highcharts.Options}\n */ /**\n * @optionparent\n * @private\n */\n var defaultOptions = {\n /**\n * An array containing the default colors for the chart's series. When\n * all colors are used, new colors are pulled from the start again.\n *\n * Default colors can also be set on a series or series.type basis,\n * see [column.colors](#plotOptions.column.colors),\n * [pie.colors](#plotOptions.pie.colors).\n *\n * In styled mode, the colors option doesn't exist. Instead, colors\n * are defined in CSS and applied either through series or point class\n * names, or through the [chart.colorCount](#chart.colorCount) option.\n *\n *\n * ### Legacy\n *\n * In Highcharts 3.x, the default colors were:\n * ```js\n * colors: ['#2f7ed8', '#0d233a', '#8bbc21', '#910000', '#1aadce',\n * '#492970', '#f28f43', '#77a1e5', '#c42525', '#a6c96a']\n * ```\n *\n * In Highcharts 2.x, the default colors were:\n * ```js\n * colors: ['#4572A7', '#AA4643', '#89A54E', '#80699B', '#3D96AE',\n * '#DB843D', '#92A8CD', '#A47D7C', '#B5CA92']\n * ```\n *\n * @sample {highcharts} highcharts/chart/colors/\n * Assign a global color theme\n *\n * @type {Array<(Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject)>}\n * @default [\"#7cb5ec\", \"#434348\", \"#90ed7d\", \"#f7a35c\", \"#8085e9\",\n * \"#f15c80\", \"#e4d354\", \"#2b908f\", \"#f45b5b\", \"#91e8e1\"]\n */\n colors: Palettes.colors,\n /**\n * Styled mode only. Configuration object for adding SVG definitions for\n * reusable elements. See [gradients, shadows and\n * patterns](https://www.highcharts.com/docs/chart-design-and-style/gradients-shadows-and-patterns)\n * for more information and code examples.\n *\n * @type {*}\n * @since 5.0.0\n * @apioption defs\n */\n /**\n * @ignore-option\n */\n symbols: ['circle', 'diamond', 'square', 'triangle', 'triangle-down'],\n /**\n * The language object is global and it can't be set on each chart\n * initialization. Instead, use `Highcharts.setOptions` to set it before any\n * chart is initialized.\n *\n * ```js\n * Highcharts.setOptions({\n * lang: {\n * months: [\n * 'Janvier', 'Février', 'Mars', 'Avril',\n * 'Mai', 'Juin', 'Juillet', 'Août',\n * 'Septembre', 'Octobre', 'Novembre', 'Décembre'\n * ],\n * weekdays: [\n * 'Dimanche', 'Lundi', 'Mardi', 'Mercredi',\n * 'Jeudi', 'Vendredi', 'Samedi'\n * ]\n * }\n * });\n * ```\n */\n lang: {\n /**\n * The loading text that appears when the chart is set into the loading\n * state following a call to `chart.showLoading`.\n */\n loading: 'Loading...',\n /**\n * An array containing the months names. Corresponds to the `%B` format\n * in `Highcharts.dateFormat()`.\n *\n * @type {Array}\n * @default [\"January\", \"February\", \"March\", \"April\", \"May\", \"June\",\n * \"July\", \"August\", \"September\", \"October\", \"November\",\n * \"December\"]\n */\n months: [\n 'January', 'February', 'March', 'April', 'May', 'June', 'July',\n 'August', 'September', 'October', 'November', 'December'\n ],\n /**\n * An array containing the months names in abbreviated form. Corresponds\n * to the `%b` format in `Highcharts.dateFormat()`.\n *\n * @type {Array}\n * @default [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\",\n * \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"]\n */\n shortMonths: [\n 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul',\n 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'\n ],\n /**\n * An array containing the weekday names.\n *\n * @type {Array}\n * @default [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\",\n * \"Friday\", \"Saturday\"]\n */\n weekdays: [\n 'Sunday', 'Monday', 'Tuesday', 'Wednesday',\n 'Thursday', 'Friday', 'Saturday'\n ],\n /**\n * Short week days, starting Sunday. If not specified, Highcharts uses\n * the first three letters of the `lang.weekdays` option.\n *\n * @sample highcharts/lang/shortweekdays/\n * Finnish two-letter abbreviations\n *\n * @type {Array}\n * @since 4.2.4\n * @apioption lang.shortWeekdays\n */\n /**\n * What to show in a date field for invalid dates. Defaults to an empty\n * string.\n *\n * @type {string}\n * @since 4.1.8\n * @product highcharts highstock\n * @apioption lang.invalidDate\n */\n /**\n * The title appearing on hovering the zoom in button. The text itself\n * defaults to \"+\" and can be changed in the button options.\n *\n * @type {string}\n * @default Zoom in\n * @product highmaps\n * @apioption lang.zoomIn\n */\n /**\n * The title appearing on hovering the zoom out button. The text itself\n * defaults to \"-\" and can be changed in the button options.\n *\n * @type {string}\n * @default Zoom out\n * @product highmaps\n * @apioption lang.zoomOut\n */\n /**\n * The default decimal point used in the `Highcharts.numberFormat`\n * method unless otherwise specified in the function arguments.\n *\n * @since 1.2.2\n */\n decimalPoint: '.',\n /**\n * [Metric prefixes](https://en.wikipedia.org/wiki/Metric_prefix) used\n * to shorten high numbers in axis labels. Replacing any of the\n * positions with `null` causes the full number to be written. Setting\n * `numericSymbols` to `null` disables shortening altogether.\n *\n * @sample {highcharts} highcharts/lang/numericsymbols/\n * Replacing the symbols with text\n * @sample {highstock} highcharts/lang/numericsymbols/\n * Replacing the symbols with text\n *\n * @type {Array}\n * @default [\"k\", \"M\", \"G\", \"T\", \"P\", \"E\"]\n * @since 2.3.0\n */\n numericSymbols: ['k', 'M', 'G', 'T', 'P', 'E'],\n /**\n * The magnitude of [numericSymbols](#lang.numericSymbol) replacements.\n * Use 10000 for Japanese, Korean and various Chinese locales, which\n * use symbols for 10^4, 10^8 and 10^12.\n *\n * @sample highcharts/lang/numericsymbolmagnitude/\n * 10000 magnitude for Japanese\n *\n * @type {number}\n * @default 1000\n * @since 5.0.3\n * @apioption lang.numericSymbolMagnitude\n */\n /**\n * The text for the label appearing when a chart is zoomed.\n *\n * @since 1.2.4\n */\n resetZoom: 'Reset zoom',\n /**\n * The tooltip title for the label appearing when a chart is zoomed.\n *\n * @since 1.2.4\n */\n resetZoomTitle: 'Reset zoom level 1:1',\n /**\n * The default thousands separator used in the `Highcharts.numberFormat`\n * method unless otherwise specified in the function arguments. Defaults\n * to a single space character, which is recommended in\n * [ISO 31-0](https://en.wikipedia.org/wiki/ISO_31-0#Numbers) and works\n * across Anglo-American and continental European languages.\n *\n * @default \\u0020\n * @since 1.2.2\n */\n thousandsSep: ' '\n },\n /**\n * Global options that don't apply to each chart. These options, like\n * the `lang` options, must be set using the `Highcharts.setOptions`\n * method.\n *\n * ```js\n * Highcharts.setOptions({\n * global: {\n * useUTC: false\n * }\n * });\n * ```\n */\n /**\n * _Canvg rendering for Android 2.x is removed as of Highcharts 5.0\\.\n * Use the [libURL](#exporting.libURL) option to configure exporting._\n *\n * The URL to the additional file to lazy load for Android 2.x devices.\n * These devices don't support SVG, so we download a helper file that\n * contains [canvg](https://github.com/canvg/canvg), its dependency\n * rbcolor, and our own CanVG Renderer class. To avoid hotlinking to\n * our site, you can install canvas-tools.js on your own server and\n * change this option accordingly.\n *\n * @deprecated\n *\n * @type {string}\n * @default https://code.highcharts.com/{version}/modules/canvas-tools.js\n * @product highcharts highmaps\n * @apioption global.canvasToolsURL\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.useUTC](#time.useUTC) that supports individual time settings\n * per chart.\n *\n * @deprecated\n *\n * @type {boolean}\n * @apioption global.useUTC\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.Date](#time.Date) that supports individual time settings\n * per chart.\n *\n * @deprecated\n *\n * @type {Function}\n * @product highcharts highstock\n * @apioption global.Date\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.getTimezoneOffset](#time.getTimezoneOffset) that supports\n * individual time settings per chart.\n *\n * @deprecated\n *\n * @type {Function}\n * @product highcharts highstock\n * @apioption global.getTimezoneOffset\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.timezone](#time.timezone) that supports individual time\n * settings per chart.\n *\n * @deprecated\n *\n * @type {string}\n * @product highcharts highstock\n * @apioption global.timezone\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.timezoneOffset](#time.timezoneOffset) that supports individual\n * time settings per chart.\n *\n * @deprecated\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption global.timezoneOffset\n */\n global: {},\n /**\n * Time options that can apply globally or to individual charts. These\n * settings affect how `datetime` axes are laid out, how tooltips are\n * formatted, how series\n * [pointIntervalUnit](#plotOptions.series.pointIntervalUnit) works and how\n * the Highcharts Stock range selector handles time.\n *\n * The common use case is that all charts in the same Highcharts object\n * share the same time settings, in which case the global settings are set\n * using `setOptions`.\n *\n * ```js\n * // Apply time settings globally\n * Highcharts.setOptions({\n * time: {\n * timezone: 'Europe/London'\n * }\n * });\n * // Apply time settings by instance\n * let chart = Highcharts.chart('container', {\n * time: {\n * timezone: 'America/New_York'\n * },\n * series: [{\n * data: [1, 4, 3, 5]\n * }]\n * });\n *\n * // Use the Time object\n * console.log(\n * 'Current time in New York',\n * chart.time.dateFormat('%Y-%m-%d %H:%M:%S', Date.now())\n * );\n * ```\n *\n * Since v6.0.5, the time options were moved from the `global` obect to the\n * `time` object, and time options can be set on each individual chart.\n *\n * @sample {highcharts|highstock}\n * highcharts/time/timezone/\n * Set the timezone globally\n * @sample {highcharts}\n * highcharts/time/individual/\n * Set the timezone per chart instance\n * @sample {highstock}\n * stock/time/individual/\n * Set the timezone per chart instance\n *\n * @since 6.0.5\n * @optionparent time\n */\n time: {\n /**\n * A custom `Date` class for advanced date handling. For example,\n * [JDate](https://github.com/tahajahangir/jdate) can be hooked in to\n * handle Jalali dates.\n *\n * @type {*}\n * @since 4.0.4\n * @product highcharts highstock gantt\n */\n Date: void 0,\n /**\n * A callback to return the time zone offset for a given datetime. It\n * takes the timestamp in terms of milliseconds since January 1 1970,\n * and returns the timezone offset in minutes. This provides a hook\n * for drawing time based charts in specific time zones using their\n * local DST crossover dates, with the help of external libraries.\n *\n * @see [global.timezoneOffset](#global.timezoneOffset)\n *\n * @sample {highcharts|highstock} highcharts/time/gettimezoneoffset/\n * Use moment.js to draw Oslo time regardless of browser locale\n *\n * @type {Highcharts.TimezoneOffsetCallbackFunction}\n * @since 4.1.0\n * @product highcharts highstock gantt\n */\n getTimezoneOffset: void 0,\n /**\n * Requires [moment.js](https://momentjs.com/). If the timezone option\n * is specified, it creates a default\n * [getTimezoneOffset](#time.getTimezoneOffset) function that looks\n * up the specified timezone in moment.js. If moment.js is not included,\n * this throws a Highcharts error in the console, but does not crash the\n * chart.\n *\n * @see [getTimezoneOffset](#time.getTimezoneOffset)\n *\n * @sample {highcharts|highstock} highcharts/time/timezone/\n * Europe/Oslo\n *\n * @type {string}\n * @since 5.0.7\n * @product highcharts highstock gantt\n */\n timezone: void 0,\n /**\n * The timezone offset in minutes. Positive values are west, negative\n * values are east of UTC, as in the ECMAScript\n * [getTimezoneOffset](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/getTimezoneOffset)\n * method. Use this to display UTC based data in a predefined time zone.\n *\n * @see [time.getTimezoneOffset](#time.getTimezoneOffset)\n *\n * @sample {highcharts|highstock} highcharts/time/timezoneoffset/\n * Timezone offset\n *\n * @since 3.0.8\n * @product highcharts highstock gantt\n */\n timezoneOffset: 0,\n /**\n * Whether to use UTC time for axis scaling, tickmark placement and\n * time display in `Highcharts.dateFormat`. Advantages of using UTC\n * is that the time displays equally regardless of the user agent's\n * time zone settings. Local time can be used when the data is loaded\n * in real time or when correct Daylight Saving Time transitions are\n * required.\n *\n * @sample {highcharts} highcharts/time/useutc-true/\n * True by default\n * @sample {highcharts} highcharts/time/useutc-false/\n * False\n */\n useUTC: true\n },\n chart: ChartDefaults,\n /**\n * The chart's main title.\n *\n * @sample {highmaps} maps/title/title/\n * Title options demonstrated\n */\n title: {\n /**\n * When the title is floating, the plot area will not move to make space\n * for it.\n *\n * @sample {highcharts} highcharts/chart/zoomtype-none/\n * False by default\n * @sample {highcharts} highcharts/title/floating/\n * True - title on top of the plot area\n * @sample {highstock} stock/chart/title-floating/\n * True - title on top of the plot area\n *\n * @type {boolean}\n * @default false\n * @since 2.1\n * @apioption title.floating\n */\n /**\n * CSS styles for the title. Use this for font styling, but use `align`,\n * `x` and `y` for text alignment.\n *\n * In styled mode, the title style is given in the `.highcharts-title`\n * class.\n *\n * @sample {highcharts} highcharts/title/style/\n * Custom color and weight\n * @sample {highstock} stock/chart/title-style/\n * Custom color and weight\n * @sample highcharts/css/titles/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n * @default {highcharts|highmaps} { \"color\": \"#333333\", \"fontSize\": \"18px\" }\n * @default {highstock} { \"color\": \"#333333\", \"fontSize\": \"16px\" }\n * @apioption title.style\n */\n /**\n * Whether to\n * [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the text.\n *\n * @type {boolean}\n * @default false\n * @apioption title.useHTML\n */\n /**\n * The vertical alignment of the title. Can be one of `\"top\"`,\n * `\"middle\"` and `\"bottom\"`. When a value is given, the title behaves\n * as if [floating](#title.floating) were `true`.\n *\n * @sample {highcharts} highcharts/title/verticalalign/\n * Chart title in bottom right corner\n * @sample {highstock} stock/chart/title-verticalalign/\n * Chart title in bottom right corner\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 2.1\n * @apioption title.verticalAlign\n */\n /**\n * The x position of the title relative to the alignment within\n * `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @sample {highcharts} highcharts/title/align/\n * Aligned to the plot area (x = 70px = margin left - spacing\n * left)\n * @sample {highstock} stock/chart/title-align/\n * Aligned to the plot area (x = 50px = margin left - spacing\n * left)\n *\n * @type {number}\n * @default 0\n * @since 2.0\n * @apioption title.x\n */\n /**\n * The y position of the title relative to the alignment within\n * [chart.spacingTop](#chart.spacingTop) and [chart.spacingBottom](\n * #chart.spacingBottom). By default it depends on the font size.\n *\n * @sample {highcharts} highcharts/title/y/\n * Title inside the plot area\n * @sample {highstock} stock/chart/title-verticalalign/\n * Chart title in bottom right corner\n *\n * @type {number}\n * @since 2.0\n * @apioption title.y\n */\n /**\n * The title of the chart. To disable the title, set the `text` to\n * `undefined`.\n *\n * @sample {highcharts} highcharts/title/text/\n * Custom title\n * @sample {highstock} stock/chart/title-text/\n * Custom title\n *\n * @default {highcharts|highmaps} Chart title\n * @default {highstock} undefined\n */\n text: 'Chart title',\n /**\n * The horizontal alignment of the title. Can be one of \"left\", \"center\"\n * and \"right\".\n *\n * @sample {highcharts} highcharts/title/align/\n * Aligned to the plot area (x = 70px = margin left - spacing\n * left)\n * @sample {highstock} stock/chart/title-align/\n * Aligned to the plot area (x = 50px = margin left - spacing\n * left)\n *\n * @type {Highcharts.AlignValue}\n * @since 2.0\n */\n align: 'center',\n /**\n * The margin between the title and the plot area, or if a subtitle\n * is present, the margin between the subtitle and the plot area.\n *\n * @sample {highcharts} highcharts/title/margin-50/\n * A chart title margin of 50\n * @sample {highcharts} highcharts/title/margin-subtitle/\n * The same margin applied with a subtitle\n * @sample {highstock} stock/chart/title-margin/\n * A chart title margin of 50\n *\n * @since 2.1\n */\n margin: 15,\n /**\n * Adjustment made to the title width, normally to reserve space for\n * the exporting burger menu.\n *\n * @sample highcharts/title/widthadjust/\n * Wider menu, greater padding\n *\n * @since 4.2.5\n */\n widthAdjust: -44\n },\n /**\n * The chart's subtitle. This can be used both to display a subtitle below\n * the main title, and to display random text anywhere in the chart. The\n * subtitle can be updated after chart initialization through the\n * `Chart.setTitle` method.\n *\n * @sample {highmaps} maps/title/subtitle/\n * Subtitle options demonstrated\n */\n subtitle: {\n /**\n * When the subtitle is floating, the plot area will not move to make\n * space for it.\n *\n * @sample {highcharts} highcharts/subtitle/floating/\n * Floating title and subtitle\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote floating at bottom right of plot area\n *\n * @type {boolean}\n * @default false\n * @since 2.1\n * @apioption subtitle.floating\n */\n /**\n * CSS styles for the title.\n *\n * In styled mode, the subtitle style is given in the\n * `.highcharts-subtitle` class.\n *\n * @sample {highcharts} highcharts/subtitle/style/\n * Custom color and weight\n * @sample {highcharts} highcharts/css/titles/\n * Styled mode\n * @sample {highstock} stock/chart/subtitle-style\n * Custom color and weight\n * @sample {highstock} highcharts/css/titles/\n * Styled mode\n * @sample {highmaps} highcharts/css/titles/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#666666\"}\n * @apioption subtitle.style\n */\n /**\n * Whether to\n * [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the text.\n *\n * @type {boolean}\n * @default false\n * @apioption subtitle.useHTML\n */\n /**\n * The vertical alignment of the title. Can be one of `\"top\"`,\n * `\"middle\"` and `\"bottom\"`. When middle, the subtitle behaves as\n * floating.\n *\n * @sample {highcharts} highcharts/subtitle/verticalalign/\n * Footnote at the bottom right of plot area\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote at the bottom right of plot area\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 2.1\n * @apioption subtitle.verticalAlign\n */\n /**\n * The x position of the subtitle relative to the alignment within\n * `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @sample {highcharts} highcharts/subtitle/align/\n * Footnote at right of plot area\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote at the bottom right of plot area\n *\n * @type {number}\n * @default 0\n * @since 2.0\n * @apioption subtitle.x\n */\n /**\n * The y position of the subtitle relative to the alignment within\n * `chart.spacingTop` and `chart.spacingBottom`. By default the subtitle\n * is laid out below the title unless the title is floating.\n *\n * @sample {highcharts} highcharts/subtitle/verticalalign/\n * Footnote at the bottom right of plot area\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote at the bottom right of plot area\n *\n * @type {number}\n * @since 2.0\n * @apioption subtitle.y\n */\n /**\n * The subtitle of the chart.\n *\n * @sample {highcharts|highstock} highcharts/subtitle/text/\n * Custom subtitle\n * @sample {highcharts|highstock} highcharts/subtitle/text-formatted/\n * Formatted and linked text.\n */\n text: '',\n /**\n * The horizontal alignment of the subtitle. Can be one of \"left\",\n * \"center\" and \"right\".\n *\n * @sample {highcharts} highcharts/subtitle/align/\n * Footnote at right of plot area\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote at bottom right of plot area\n *\n * @type {Highcharts.AlignValue}\n * @since 2.0\n */\n align: 'center',\n /**\n * Adjustment made to the subtitle width, normally to reserve space\n * for the exporting burger menu.\n *\n * @see [title.widthAdjust](#title.widthAdjust)\n *\n * @sample highcharts/title/widthadjust/\n * Wider menu, greater padding\n *\n * @since 4.2.5\n */\n widthAdjust: -44\n },\n /**\n * The chart's caption, which will render below the chart and will be part\n * of exported charts. The caption can be updated after chart initialization\n * through the `Chart.update` or `Chart.caption.update` methods.\n *\n * @sample highcharts/caption/text/\n * A chart with a caption\n * @since 7.2.0\n */\n caption: {\n /**\n * When the caption is floating, the plot area will not move to make\n * space for it.\n *\n * @type {boolean}\n * @default false\n * @apioption caption.floating\n */\n /**\n * The margin between the caption and the plot area.\n */\n margin: 15,\n /**\n * CSS styles for the caption.\n *\n * In styled mode, the caption style is given in the\n * `.highcharts-caption` class.\n *\n * @sample {highcharts} highcharts/css/titles/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#666666\"}\n * @apioption caption.style\n */\n /**\n * Whether to\n * [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the text.\n *\n * @type {boolean}\n * @default false\n * @apioption caption.useHTML\n */\n /**\n * The x position of the caption relative to the alignment within\n * `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @type {number}\n * @default 0\n * @apioption caption.x\n */\n /**\n * The y position of the caption relative to the alignment within\n * `chart.spacingTop` and `chart.spacingBottom`.\n *\n * @type {number}\n * @apioption caption.y\n */\n /**\n * The caption text of the chart.\n *\n * @sample {highcharts} highcharts/caption/text/\n * Custom caption\n */\n text: '',\n /**\n * The horizontal alignment of the caption. Can be one of \"left\",\n * \"center\" and \"right\".\n *\n * @type {Highcharts.AlignValue}\n */\n align: 'left',\n /**\n * The vertical alignment of the caption. Can be one of `\"top\"`,\n * `\"middle\"` and `\"bottom\"`. When middle, the caption behaves as\n * floating.\n *\n * @type {Highcharts.VerticalAlignValue}\n */\n verticalAlign: 'bottom'\n },\n /**\n * The plotOptions is a wrapper object for config objects for each series\n * type. The config objects for each series can also be overridden for\n * each series item as given in the series array.\n *\n * Configuration options for the series are given in three levels. Options\n * for all series in a chart are given in the [plotOptions.series](\n * #plotOptions.series) object. Then options for all series of a specific\n * type are given in the plotOptions of that type, for example\n * `plotOptions.line`. Next, options for one single series are given in\n * [the series array](#series).\n */\n plotOptions: {},\n /**\n * HTML labels that can be positioned anywhere in the chart area.\n *\n * This option is deprecated since v7.1.2. Instead, use\n * [annotations](#annotations) that support labels.\n *\n * @deprecated\n * @product highcharts highstock\n */\n labels: {\n /**\n * An HTML label that can be positioned anywhere in the chart area.\n *\n * @deprecated\n * @type {Array<*>}\n * @apioption labels.items\n */\n /**\n * Inner HTML or text for the label.\n *\n * @deprecated\n * @type {string}\n * @apioption labels.items.html\n */\n /**\n * CSS styles for each label. To position the label, use left and top\n * like this:\n * ```js\n * style: {\n * left: '100px',\n * top: '100px'\n * }\n * ```\n *\n * @deprecated\n * @type {Highcharts.CSSObject}\n * @apioption labels.items.style\n */\n /**\n * Shared CSS styles for all labels.\n *\n * @deprecated\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#333333\", \"position\": \"absolute\"}\n */\n style: {\n /**\n * @ignore-option\n */\n position: 'absolute',\n /**\n * @ignore-option\n */\n color: \"#333333\" /* Palette.neutralColor80 */\n }\n },\n /**\n * The legend is a box containing a symbol and name for each series\n * item or point item in the chart. Each series (or points in case\n * of pie charts) is represented by a symbol and its name in the legend.\n *\n * It is possible to override the symbol creator function and create\n * [custom legend symbols](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/studies/legend-custom-symbol/).\n *\n * @productdesc {highmaps}\n * A Highmaps legend by default contains one legend item per series, but if\n * a `colorAxis` is defined, the axis will be displayed in the legend.\n * Either as a gradient, or as multiple legend items for `dataClasses`.\n */\n legend: {\n /**\n * The background color of the legend.\n *\n * @see In styled mode, the legend background fill can be applied with\n * the `.highcharts-legend-box` class.\n *\n * @sample {highcharts} highcharts/legend/backgroundcolor/\n * Yellowish background\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption legend.backgroundColor\n */\n /**\n * The width of the drawn border around the legend.\n *\n * @see In styled mode, the legend border stroke width can be applied\n * with the `.highcharts-legend-box` class.\n *\n * @sample {highcharts} highcharts/legend/borderwidth/\n * 2px border width\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n *\n * @type {number}\n * @default 0\n * @apioption legend.borderWidth\n */\n /**\n * Enable or disable the legend. There is also a series-specific option,\n * [showInLegend](#plotOptions.series.showInLegend), that can hide the\n * series from the legend. In some series types this is `false` by\n * default, so it must set to `true` in order to show the legend for the\n * series.\n *\n * @sample {highcharts} highcharts/legend/enabled-false/ Legend disabled\n * @sample {highstock} stock/legend/align/ Various legend options\n * @sample {highmaps} maps/legend/enabled-false/ Legend disabled\n *\n * @default {highstock} false\n * @default {highmaps} true\n * @default {gantt} false\n */\n enabled: true,\n /**\n * The horizontal alignment of the legend box within the chart area.\n * Valid values are `left`, `center` and `right`.\n *\n * In the case that the legend is aligned in a corner position, the\n * `layout` option will determine whether to place it above/below\n * or on the side of the plot area.\n *\n * @sample {highcharts} highcharts/legend/align/\n * Legend at the right of the chart\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/alignment/\n * Legend alignment\n *\n * @type {Highcharts.AlignValue}\n * @since 2.0\n */\n align: 'center',\n /**\n * If the [layout](legend.layout) is `horizontal` and the legend items\n * span over two lines or more, whether to align the items into vertical\n * columns. Setting this to `false` makes room for more items, but will\n * look more messy.\n *\n * @since 6.1.0\n */\n alignColumns: true,\n /**\n * A CSS class name to apply to the legend group.\n */\n className: 'highcharts-no-tooltip',\n /**\n * When the legend is floating, the plot area ignores it and is allowed\n * to be placed below it.\n *\n * @sample {highcharts} highcharts/legend/floating-false/\n * False by default\n * @sample {highcharts} highcharts/legend/floating-true/\n * True\n * @sample {highmaps} maps/legend/alignment/\n * Floating legend\n *\n * @type {boolean}\n * @default false\n * @since 2.1\n * @apioption legend.floating\n */\n /**\n * The layout of the legend items. Can be one of `horizontal` or\n * `vertical` or `proximate`. When `proximate`, the legend items will be\n * placed as close as possible to the graphs they're representing,\n * except in inverted charts or when the legend position doesn't allow\n * it.\n *\n * @sample {highcharts} highcharts/legend/layout-horizontal/\n * Horizontal by default\n * @sample {highcharts} highcharts/legend/layout-vertical/\n * Vertical\n * @sample highcharts/legend/layout-proximate\n * Labels proximate to the data\n * @sample {highstock} stock/legend/layout-horizontal/\n * Horizontal by default\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Vertical with data classes\n * @sample {highmaps} maps/legend/layout-vertical/\n * Vertical with color axis gradient\n *\n * @validvalue [\"horizontal\", \"vertical\", \"proximate\"]\n */\n layout: 'horizontal',\n /**\n * In a legend with horizontal layout, the itemDistance defines the\n * pixel distance between each item.\n *\n * @sample {highcharts} highcharts/legend/layout-horizontal/\n * 50px item distance\n * @sample {highstock} highcharts/legend/layout-horizontal/\n * 50px item distance\n *\n * @type {number}\n * @default {highcharts} 20\n * @default {highstock} 20\n * @default {highmaps} 8\n * @since 3.0.3\n * @apioption legend.itemDistance\n */\n /**\n * The pixel bottom margin for each legend item.\n *\n * @sample {highcharts|highstock} highcharts/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n *\n * @type {number}\n * @default 0\n * @since 2.2.0\n * @apioption legend.itemMarginBottom\n */\n /**\n * The pixel top margin for each legend item.\n *\n * @sample {highcharts|highstock} highcharts/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n *\n * @type {number}\n * @default 0\n * @since 2.2.0\n * @apioption legend.itemMarginTop\n */\n /**\n * The width for each legend item. By default the items are laid out\n * successively. In a [horizontal layout](legend.layout), if the items\n * are laid out across two rows or more, they will be vertically aligned\n * depending on the [legend.alignColumns](legend.alignColumns) option.\n *\n * @sample {highcharts} highcharts/legend/itemwidth-default/\n * Undefined by default\n * @sample {highcharts} highcharts/legend/itemwidth-80/\n * 80 for aligned legend items\n *\n * @type {number}\n * @since 2.0\n * @apioption legend.itemWidth\n */\n /**\n * A [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for each legend label. Available variables relates to properties on\n * the series, or the point in case of pies.\n *\n * @type {string}\n * @default {name}\n * @since 1.3\n * @apioption legend.labelFormat\n */\n /* eslint-disable valid-jsdoc */\n /**\n * Callback function to format each of the series' labels. The `this`\n * keyword refers to the series object, or the point object in case of\n * pie charts. By default the series or point name is printed.\n *\n * @productdesc {highmaps}\n * In Highmaps the context can also be a data class in case of a\n * `colorAxis`.\n *\n * @sample {highcharts} highcharts/legend/labelformatter/\n * Add text\n * @sample {highmaps} maps/legend/labelformatter/\n * Data classes with label formatter\n *\n * @type {Highcharts.FormatterCallbackFunction}\n */\n labelFormatter: function () {\n /** eslint-enable valid-jsdoc */\n return this.name;\n },\n /**\n * Line height for the legend items. Deprecated as of 2.1\\. Instead,\n * the line height for each item can be set using\n * `itemStyle.lineHeight`, and the padding between items using\n * `itemMarginTop` and `itemMarginBottom`.\n *\n * @sample {highcharts} highcharts/legend/lineheight/\n * Setting padding\n *\n * @deprecated\n *\n * @type {number}\n * @default 16\n * @since 2.0\n * @product highcharts gantt\n * @apioption legend.lineHeight\n */\n /**\n * If the plot area sized is calculated automatically and the legend is\n * not floating, the legend margin is the space between the legend and\n * the axis labels or plot area.\n *\n * @sample {highcharts} highcharts/legend/margin-default/\n * 12 pixels by default\n * @sample {highcharts} highcharts/legend/margin-30/\n * 30 pixels\n *\n * @type {number}\n * @default 12\n * @since 2.1\n * @apioption legend.margin\n */\n /**\n * Maximum pixel height for the legend. When the maximum height is\n * extended, navigation will show.\n *\n * @type {number}\n * @since 2.3.0\n * @apioption legend.maxHeight\n */\n /**\n * The color of the drawn border around the legend.\n *\n * @see In styled mode, the legend border stroke can be applied with the\n * `.highcharts-legend-box` class.\n *\n * @sample {highcharts} highcharts/legend/bordercolor/\n * Brown border\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n borderColor: \"#999999\" /* Palette.neutralColor40 */,\n /**\n * The border corner radius of the legend.\n *\n * @sample {highcharts} highcharts/legend/borderradius-default/\n * Square by default\n * @sample {highcharts} highcharts/legend/borderradius-round/\n * 5px rounded\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n */\n borderRadius: 0,\n /**\n * Options for the paging or navigation appearing when the legend is\n * overflown. Navigation works well on screen, but not in static\n * exported images. One way of working around that is to\n * [increase the chart height in\n * export](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/legend/navigation-enabled-false/).\n */\n navigation: {\n /**\n * How to animate the pages when navigating up or down. A value of\n * `true` applies the default navigation given in the\n * `chart.animation` option. Additional options can be given as an\n * object containing values for easing and duration.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {boolean|Partial}\n * @default true\n * @since 2.2.4\n * @apioption legend.navigation.animation\n */\n /**\n * The pixel size of the up and down arrows in the legend paging\n * navigation.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {number}\n * @default 12\n * @since 2.2.4\n * @apioption legend.navigation.arrowSize\n */\n /**\n * Whether to enable the legend navigation. In most cases, disabling\n * the navigation results in an unwanted overflow.\n *\n * See also the\n * [adapt chart to legend](https://github.com/highcharts/adapt-chart-to-legend)\n * plugin for a solution to extend the chart height to make room for\n * the legend, optionally in exported charts only.\n *\n * @type {boolean}\n * @default true\n * @since 4.2.4\n * @apioption legend.navigation.enabled\n */\n /**\n * Text styles for the legend page navigation.\n *\n * @see In styled mode, the navigation items are styled with the\n * `.highcharts-legend-navigation` class.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {Highcharts.CSSObject}\n * @since 2.2.4\n * @apioption legend.navigation.style\n */\n /**\n * The color for the active up or down arrow in the legend page\n * navigation.\n *\n * @see In styled mode, the active arrow be styled with the\n * `.highcharts-legend-nav-active` class.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.2.4\n */\n activeColor: \"#003399\" /* Palette.highlightColor100 */,\n /**\n * The color of the inactive up or down arrow in the legend page\n * navigation. .\n *\n * @see In styled mode, the inactive arrow be styled with the\n * `.highcharts-legend-nav-inactive` class.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.2.4\n */\n inactiveColor: \"#cccccc\" /* Palette.neutralColor20 */\n },\n /**\n * The inner padding of the legend box.\n *\n * @sample {highcharts|highstock} highcharts/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n *\n * @type {number}\n * @default 8\n * @since 2.2.0\n * @apioption legend.padding\n */\n /**\n * Whether to reverse the order of the legend items compared to the\n * order of the series or points as defined in the configuration object.\n *\n * @see [yAxis.reversedStacks](#yAxis.reversedStacks),\n * [series.legendIndex](#series.legendIndex)\n *\n * @sample {highcharts} highcharts/legend/reversed/\n * Stacked bar with reversed legend\n *\n * @type {boolean}\n * @default false\n * @since 1.2.5\n * @apioption legend.reversed\n */\n /**\n * Whether to show the symbol on the right side of the text rather than\n * the left side. This is common in Arabic and Hebrew.\n *\n * @sample {highcharts} highcharts/legend/rtl/\n * Symbol to the right\n *\n * @type {boolean}\n * @default false\n * @since 2.2\n * @apioption legend.rtl\n */\n /**\n * CSS styles for the legend area. In the 1.x versions the position\n * of the legend area was determined by CSS. In 2.x, the position is\n * determined by properties like `align`, `verticalAlign`, `x` and `y`,\n * but the styles are still parsed for backwards compatibility.\n *\n * @deprecated\n *\n * @type {Highcharts.CSSObject}\n * @product highcharts highstock\n * @apioption legend.style\n */\n /**\n * CSS styles for each legend item. Only a subset of CSS is supported,\n * notably those options related to text. The default `textOverflow`\n * property makes long texts truncate. Set it to `undefined` to wrap\n * text instead. A `width` property can be added to control the text\n * width.\n *\n * @see In styled mode, the legend items can be styled with the\n * `.highcharts-legend-item` class.\n *\n * @sample {highcharts} highcharts/legend/itemstyle/\n * Bold black text\n * @sample {highmaps} maps/legend/itemstyle/\n * Item text styles\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#333333\", \"cursor\": \"pointer\", \"fontSize\": \"12px\", \"fontWeight\": \"bold\", \"textOverflow\": \"ellipsis\"}\n */\n itemStyle: {\n /**\n * @ignore\n */\n color: \"#333333\" /* Palette.neutralColor80 */,\n /**\n * @ignore\n */\n cursor: 'pointer',\n /**\n * @ignore\n */\n fontSize: '12px',\n /**\n * @ignore\n */\n fontWeight: 'bold',\n /**\n * @ignore\n */\n textOverflow: 'ellipsis'\n },\n /**\n * CSS styles for each legend item in hover mode. Only a subset of\n * CSS is supported, notably those options related to text. Properties\n * are inherited from `style` unless overridden here.\n *\n * @see In styled mode, the hovered legend items can be styled with\n * the `.highcharts-legend-item:hover` pesudo-class.\n *\n * @sample {highcharts} highcharts/legend/itemhoverstyle/\n * Red on hover\n * @sample {highmaps} maps/legend/itemstyle/\n * Item text styles\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#000000\"}\n */\n itemHoverStyle: {\n /**\n * @ignore\n */\n color: \"#000000\" /* Palette.neutralColor100 */\n },\n /**\n * CSS styles for each legend item when the corresponding series or\n * point is hidden. Only a subset of CSS is supported, notably those\n * options related to text. Properties are inherited from `style`\n * unless overridden here.\n *\n * @see In styled mode, the hidden legend items can be styled with\n * the `.highcharts-legend-item-hidden` class.\n *\n * @sample {highcharts} highcharts/legend/itemhiddenstyle/\n * Darker gray color\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#cccccc\"}\n */\n itemHiddenStyle: {\n /**\n * @ignore\n */\n color: \"#cccccc\" /* Palette.neutralColor20 */\n },\n /**\n * Whether to apply a drop shadow to the legend. A `backgroundColor`\n * also needs to be applied for this to take effect. The shadow can be\n * an object configuration containing `color`, `offsetX`, `offsetY`,\n * `opacity` and `width`.\n *\n * @sample {highcharts} highcharts/legend/shadow/\n * White background and drop shadow\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n *\n * @type {boolean|Highcharts.CSSObject}\n */\n shadow: false,\n /**\n * Default styling for the checkbox next to a legend item when\n * `showCheckbox` is true.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"width\": \"13px\", \"height\": \"13px\", \"position\":\"absolute\"}\n */\n itemCheckboxStyle: {\n /**\n * @ignore\n */\n position: 'absolute',\n /**\n * @ignore\n */\n width: '13px',\n /**\n * @ignore\n */\n height: '13px'\n },\n // itemWidth: undefined,\n /**\n * When this is true, the legend symbol width will be the same as\n * the symbol height, which in turn defaults to the font size of the\n * legend items.\n *\n * @since 5.0.0\n */\n squareSymbol: true,\n /**\n * The pixel height of the symbol for series types that use a rectangle\n * in the legend. Defaults to the font size of legend items.\n *\n * @productdesc {highmaps}\n * In Highmaps, when the symbol is the gradient of a vertical color\n * axis, the height defaults to 200.\n *\n * @sample {highmaps} maps/legend/layout-vertical-sized/\n * Sized vertical gradient\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * No distance between data classes\n *\n * @type {number}\n * @since 3.0.8\n * @apioption legend.symbolHeight\n */\n /**\n * The border radius of the symbol for series types that use a rectangle\n * in the legend. Defaults to half the `symbolHeight`.\n *\n * @sample {highcharts} highcharts/legend/symbolradius/\n * Round symbols\n * @sample {highstock} highcharts/legend/symbolradius/\n * Round symbols\n * @sample {highmaps} highcharts/legend/symbolradius/\n * Round symbols\n *\n * @type {number}\n * @since 3.0.8\n * @apioption legend.symbolRadius\n */\n /**\n * The pixel width of the legend item symbol. When the `squareSymbol`\n * option is set, this defaults to the `symbolHeight`, otherwise 16.\n *\n * @productdesc {highmaps}\n * In Highmaps, when the symbol is the gradient of a horizontal color\n * axis, the width defaults to 200.\n *\n * @sample {highcharts} highcharts/legend/symbolwidth/\n * Greater symbol width and padding\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n * @sample {highmaps} maps/legend/layout-vertical-sized/\n * Sized vertical gradient\n *\n * @type {number}\n * @apioption legend.symbolWidth\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the legend item texts.\n *\n * Prior to 4.1.7, when using HTML, [legend.navigation](\n * #legend.navigation) was disabled.\n *\n * @type {boolean}\n * @default false\n * @apioption legend.useHTML\n */\n /**\n * For a color axis with data classes, how many decimals to render in\n * the legend. The default preserves the decimals of the range numbers.\n *\n * @type {number}\n * @default -1\n * @product highcharts highmaps\n * @apioption legend.valueDecimals\n */\n /**\n * For a color axis with data classes, a suffix for the range numbers in\n * the legend.\n *\n * @type {string}\n * @default ''\n * @product highcharts highmaps\n * @apioption legend.valueSuffix\n */\n /**\n * The width of the legend box. If a number is set, it translates to\n * pixels. Since v7.0.2 it allows setting a percent string of the full\n * chart width, for example `40%`.\n *\n * Defaults to the full chart width for legends below or above the\n * chart, half the chart width for legends to the left and right.\n *\n * @sample {highcharts} highcharts/legend/width/\n * Aligned to the plot area\n * @sample {highcharts} highcharts/legend/width-percent/\n * A percent of the chart width\n *\n * @type {number|string}\n * @since 2.0\n * @apioption legend.width\n */\n /**\n * The pixel padding between the legend item symbol and the legend\n * item text.\n *\n * @sample {highcharts} highcharts/legend/symbolpadding/\n * Greater symbol width and padding\n */\n symbolPadding: 5,\n /**\n * The vertical alignment of the legend box. Can be one of `top`,\n * `middle` or `bottom`. Vertical position can be further determined\n * by the `y` option.\n *\n * In the case that the legend is aligned in a corner position, the\n * `layout` option will determine whether to place it above/below\n * or on the side of the plot area.\n *\n * When the [layout](#legend.layout) option is `proximate`, the\n * `verticalAlign` option doesn't apply.\n *\n * @sample {highcharts} highcharts/legend/verticalalign/\n * Legend 100px from the top of the chart\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/alignment/\n * Legend alignment\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 2.0\n */\n verticalAlign: 'bottom',\n // width: undefined,\n /**\n * The x offset of the legend relative to its horizontal alignment\n * `align` within chart.spacingLeft and chart.spacingRight. Negative\n * x moves it to the left, positive x moves it to the right.\n *\n * @sample {highcharts} highcharts/legend/width/\n * Aligned to the plot area\n *\n * @since 2.0\n */\n x: 0,\n /**\n * The vertical offset of the legend relative to it's vertical alignment\n * `verticalAlign` within chart.spacingTop and chart.spacingBottom.\n * Negative y moves it up, positive y moves it down.\n *\n * @sample {highcharts} highcharts/legend/verticalalign/\n * Legend 100px from the top of the chart\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/alignment/\n * Legend alignment\n *\n * @since 2.0\n */\n y: 0,\n /**\n * A title to be added on top of the legend.\n *\n * @sample {highcharts} highcharts/legend/title/\n * Legend title\n * @sample {highmaps} maps/legend/alignment/\n * Legend with title\n *\n * @since 3.0\n */\n title: {\n /**\n * A text or HTML string for the title.\n *\n * @type {string}\n * @since 3.0\n * @apioption legend.title.text\n */\n /**\n * Generic CSS styles for the legend title.\n *\n * @see In styled mode, the legend title is styled with the\n * `.highcharts-legend-title` class.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"fontWeight\": \"bold\"}\n * @since 3.0\n */\n style: {\n /**\n * @ignore\n */\n fontWeight: 'bold'\n }\n }\n },\n /**\n * The loading options control the appearance of the loading screen\n * that covers the plot area on chart operations. This screen only\n * appears after an explicit call to `chart.showLoading()`. It is a\n * utility for developers to communicate to the end user that something\n * is going on, for example while retrieving new data via an XHR connection.\n * The \"Loading...\" text itself is not part of this configuration\n * object, but part of the `lang` object.\n */\n loading: {\n /**\n * The duration in milliseconds of the fade out effect.\n *\n * @sample highcharts/loading/hideduration/\n * Fade in and out over a second\n *\n * @type {number}\n * @default 100\n * @since 1.2.0\n * @apioption loading.hideDuration\n */\n /**\n * The duration in milliseconds of the fade in effect.\n *\n * @sample highcharts/loading/hideduration/\n * Fade in and out over a second\n *\n * @type {number}\n * @default 100\n * @since 1.2.0\n * @apioption loading.showDuration\n */\n /**\n * CSS styles for the loading label `span`.\n *\n * @see In styled mode, the loading label is styled with the\n * `.highcharts-loading-inner` class.\n *\n * @sample {highcharts|highmaps} highcharts/loading/labelstyle/\n * Vertically centered\n * @sample {highstock} stock/loading/general/\n * Label styles\n *\n * @type {Highcharts.CSSObject}\n * @default {\"fontWeight\": \"bold\", \"position\": \"relative\", \"top\": \"45%\"}\n * @since 1.2.0\n */\n labelStyle: {\n /**\n * @ignore\n */\n fontWeight: 'bold',\n /**\n * @ignore\n */\n position: 'relative',\n /**\n * @ignore\n */\n top: '45%'\n },\n /**\n * CSS styles for the loading screen that covers the plot area.\n *\n * In styled mode, the loading label is styled with the\n * `.highcharts-loading` class.\n *\n * @sample {highcharts|highmaps} highcharts/loading/style/\n * Gray plot area, white text\n * @sample {highstock} stock/loading/general/\n * Gray plot area, white text\n *\n * @type {Highcharts.CSSObject}\n * @default {\"position\": \"absolute\", \"backgroundColor\": \"#ffffff\", \"opacity\": 0.5, \"textAlign\": \"center\"}\n * @since 1.2.0\n */\n style: {\n /**\n * @ignore\n */\n position: 'absolute',\n /**\n * @ignore\n */\n backgroundColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * @ignore\n */\n opacity: 0.5,\n /**\n * @ignore\n */\n textAlign: 'center'\n }\n },\n /**\n * Options for the tooltip that appears when the user hovers over a\n * series or point.\n *\n * @declare Highcharts.TooltipOptions\n */\n tooltip: {\n /**\n * The color of the tooltip border. When `undefined`, the border takes\n * the color of the corresponding series or point.\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * Follow series by default\n * @sample {highcharts} highcharts/tooltip/bordercolor-black/\n * Black border\n * @sample {highstock} stock/tooltip/general/\n * Styled tooltip\n * @sample {highmaps} maps/tooltip/background-border/\n * Background and border demo\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption tooltip.borderColor\n */\n /**\n * A CSS class name to apply to the tooltip's container div,\n * allowing unique CSS styling for each chart.\n *\n * @type {string}\n * @apioption tooltip.className\n */\n /**\n * Since 4.1, the crosshair definitions are moved to the Axis object\n * in order for a better separation from the tooltip. See\n * [xAxis.crosshair](#xAxis.crosshair).\n *\n * @sample {highcharts} highcharts/tooltip/crosshairs-x/\n * Enable a crosshair for the x value\n *\n * @deprecated\n *\n * @type {*}\n * @default true\n * @apioption tooltip.crosshairs\n */\n /**\n * Distance from point to tooltip in pixels.\n *\n * @type {number}\n * @default 16\n * @apioption tooltip.distance\n */\n /**\n * Whether the tooltip should follow the mouse as it moves across\n * columns, pie slices and other point types with an extent.\n * By default it behaves this way for pie, polygon, map, sankey\n * and wordcloud series by override in the `plotOptions`\n * for those series types.\n *\n * Does not apply if [split](#tooltip.split) is `true`.\n *\n * For touch moves to behave the same way, [followTouchMove](\n * #tooltip.followTouchMove) must be `true` also.\n *\n * @type {boolean}\n * @default {highcharts} false\n * @default {highstock} false\n * @default {highmaps} true\n * @since 3.0\n * @apioption tooltip.followPointer\n */\n /**\n * Whether the tooltip should update as the finger moves on a touch\n * device. If this is `true` and [chart.panning](#chart.panning) is\n * set,`followTouchMove` will take over one-finger touches, so the user\n * needs to use two fingers for zooming and panning.\n *\n * Note the difference to [followPointer](#tooltip.followPointer) that\n * only defines the _position_ of the tooltip. If `followPointer` is\n * false in for example a column series, the tooltip will show above or\n * below the column, but as `followTouchMove` is true, the tooltip will\n * jump from column to column as the user swipes across the plot area.\n *\n * @type {boolean}\n * @default {highcharts} true\n * @default {highstock} true\n * @default {highmaps} false\n * @since 3.0.1\n * @apioption tooltip.followTouchMove\n */\n /**\n * Callback function to format the text of the tooltip from scratch. In\n * case of single or [shared](#tooltip.shared) tooltips, a string should\n * be returned. In case of [split](#tooltip.split) tooltips, it should\n * return an array where the first item is the header, and subsequent\n * items are mapped to the points. Return `false` to disable tooltip for\n * a specific point on series.\n *\n * A subset of HTML is supported. Unless `useHTML` is true, the HTML of\n * the tooltip is parsed and converted to SVG, therefore this isn't a\n * complete HTML renderer. The following HTML tags are supported: `b`,\n * `br`, `em`, `i`, `span`, `strong`. Spans can be styled with a `style`\n * attribute, but only text-related CSS, that is shared with SVG, is\n * handled.\n *\n * The available data in the formatter differ a bit depending on whether\n * the tooltip is shared or split, or belongs to a single point. In a\n * shared/split tooltip, all properties except `x`, which is common for\n * all points, are kept in an array, `this.points`.\n *\n * Available data are:\n *\n * - **this.percentage (not shared) /**\n * **this.points[i].percentage (shared)**:\n * Stacked series and pies only. The point's percentage of the total.\n *\n * - **this.point (not shared) / this.points[i].point (shared)**:\n * The point object. The point name, if defined, is available through\n * `this.point.name`.\n *\n * - **this.points**:\n * In a shared tooltip, this is an array containing all other\n * properties for each point.\n *\n * - **this.series (not shared) / this.points[i].series (shared)**:\n * The series object. The series name is available through\n * `this.series.name`.\n *\n * - **this.total (not shared) / this.points[i].total (shared)**:\n * Stacked series only. The total value at this point's x value.\n *\n * - **this.x**:\n * The x value. This property is the same regardless of the tooltip\n * being shared or not.\n *\n * - **this.y (not shared) / this.points[i].y (shared)**:\n * The y value.\n *\n * @sample {highcharts} highcharts/tooltip/formatter-simple/\n * Simple string formatting\n * @sample {highcharts} highcharts/tooltip/formatter-shared/\n * Formatting with shared tooltip\n * @sample {highcharts|highstock} highcharts/tooltip/formatter-split/\n * Formatting with split tooltip\n * @sample highcharts/tooltip/formatter-conditional-default/\n * Extending default formatter\n * @sample {highstock} stock/tooltip/formatter/\n * Formatting with shared tooltip\n * @sample {highmaps} maps/tooltip/formatter/\n * String formatting\n *\n * @type {Highcharts.TooltipFormatterCallbackFunction}\n * @apioption tooltip.formatter\n */\n /**\n * Callback function to format the text of the tooltip for\n * visible null points.\n * Works analogously to [formatter](#tooltip.formatter).\n *\n * @sample highcharts/plotoptions/series-nullformat\n * Format data label and tooltip for null point.\n *\n * @type {Highcharts.TooltipFormatterCallbackFunction}\n * @apioption tooltip.nullFormatter\n */\n /**\n * Whether to allow the tooltip to render outside the chart's SVG\n * element box. By default (`false`), the tooltip is rendered within the\n * chart's SVG element, which results in the tooltip being aligned\n * inside the chart area. For small charts, this may result in clipping\n * or overlapping. When `true`, a separate SVG element is created and\n * overlaid on the page, allowing the tooltip to be aligned inside the\n * page itself.\n *\n * Defaults to `true` if `chart.scrollablePlotArea` is activated,\n * otherwise `false`.\n *\n * @sample highcharts/tooltip/outside\n * Small charts with tooltips outside\n *\n * @type {boolean|undefined}\n * @default undefined\n * @since 6.1.1\n * @apioption tooltip.outside\n */\n /**\n * A callback function for formatting the HTML output for a single point\n * in the tooltip. Like the `pointFormat` string, but with more\n * flexibility.\n *\n * @type {Highcharts.FormatterCallbackFunction}\n * @since 4.1.0\n * @context Highcharts.Point\n * @apioption tooltip.pointFormatter\n */\n /**\n * A callback function to place the tooltip in a custom position. The\n * callback receives three parameters: `labelWidth`, `labelHeight` and\n * `point`, where point contains values for `plotX` and `plotY` telling\n * where the reference point is in the plot area. Add `chart.plotLeft`\n * and `chart.plotTop` to get the full coordinates.\n *\n * To find the actual hovered `Point` instance, use\n * `this.chart.hoverPoint`. For shared or split tooltips, all the hover\n * points are available in `this.chart.hoverPoints`.\n *\n * Since v7, when [tooltip.split](#tooltip.split) option is enabled,\n * positioner is called for each of the boxes separately, including\n * xAxis header. xAxis header is not a point, instead `point` argument\n * contains info: `{ plotX: Number, plotY: Number, isHeader: Boolean }`\n *\n * The return should be an object containing x and y values, for example\n * `{ x: 100, y: 100 }`.\n *\n * @sample {highcharts} highcharts/tooltip/positioner/\n * A fixed tooltip position\n * @sample {highstock} stock/tooltip/positioner/\n * A fixed tooltip position on top of the chart\n * @sample {highmaps} maps/tooltip/positioner/\n * A fixed tooltip position\n * @sample {highstock} stock/tooltip/split-positioner/\n * Split tooltip with fixed positions\n * @sample {highstock} stock/tooltip/positioner-scrollable-plotarea/\n * Scrollable plot area combined with tooltip positioner\n *\n * @type {Highcharts.TooltipPositionerCallbackFunction}\n * @since 2.2.4\n * @apioption tooltip.positioner\n */\n /**\n * Split the tooltip into one label per series, with the header close\n * to the axis. This is recommended over [shared](#tooltip.shared)\n * tooltips for charts with multiple line series, generally making them\n * easier to read. This option takes precedence over `tooltip.shared`.\n *\n * @productdesc {highstock} In Highcharts Stock, tooltips are split\n * by default since v6.0.0. Stock charts typically contain\n * multi-dimension points and multiple panes, making split tooltips\n * the preferred layout over\n * the previous `shared` tooltip.\n *\n * @sample highcharts/tooltip/split/\n * Split tooltip\n * @sample {highcharts|highstock} highcharts/tooltip/formatter-split/\n * Split tooltip and custom formatter callback\n *\n * @type {boolean}\n * @default {highcharts} false\n * @default {highstock} true\n * @since 5.0.0\n * @product highcharts highstock\n * @apioption tooltip.split\n */\n /**\n * Prevents the tooltip from switching or closing, when touched or\n * pointed.\n *\n * @sample highcharts/tooltip/stickoncontact/\n * Tooltip sticks on pointer contact\n *\n * @type {boolean}\n * @since 8.0.1\n * @apioption tooltip.stickOnContact\n */\n /**\n * Use HTML to render the contents of the tooltip instead of SVG. Using\n * HTML allows advanced formatting like tables and images in the\n * tooltip. It is also recommended for rtl languages as it works around\n * rtl bugs in early Firefox.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/footerformat/\n * A table for value alignment\n * @sample {highcharts|highstock} highcharts/tooltip/fullhtml/\n * Full HTML tooltip\n * @sample {highmaps} maps/tooltip/usehtml/\n * Pure HTML tooltip\n *\n * @type {boolean}\n * @default false\n * @since 2.2\n * @apioption tooltip.useHTML\n */\n /**\n * How many decimals to show in each series' y value. This is\n * overridable in each series' tooltip options object. The default is to\n * preserve all decimals.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n * @sample {highmaps} maps/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n *\n * @type {number|undefined}\n * @since 2.2\n * @apioption tooltip.valueDecimals\n */\n /**\n * A string to prepend to each series' y value. Overridable in each\n * series' tooltip options object.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n * @sample {highmaps} maps/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n *\n * @type {string}\n * @since 2.2\n * @apioption tooltip.valuePrefix\n */\n /**\n * A string to append to each series' y value. Overridable in each\n * series' tooltip options object.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n * @sample {highmaps} maps/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n *\n * @type {string}\n * @since 2.2\n * @apioption tooltip.valueSuffix\n */\n /**\n * The format for the date in the tooltip header if the X axis is a\n * datetime axis. The default is a best guess based on the smallest\n * distance between points in the chart.\n *\n * @sample {highcharts} highcharts/tooltip/xdateformat/\n * A different format\n *\n * @type {string}\n * @product highcharts highstock gantt\n * @apioption tooltip.xDateFormat\n */\n /**\n * How many decimals to show for the `point.change`\n * or the `point.cumulativeSum` value when the `series.compare`\n * or the `series.cumulative` option is set.\n * This is overridable in each series' tooltip options object.\n *\n * @type {number}\n * @default 2\n * @since 1.0.1\n * @product highstock\n * @apioption tooltip.changeDecimals\n */\n /**\n * Enable or disable the tooltip.\n *\n * @sample {highcharts} highcharts/tooltip/enabled/\n * Disabled\n * @sample {highcharts} highcharts/plotoptions/series-point-events-mouseover/\n * Disable tooltip and show values on chart instead\n */\n enabled: true,\n /**\n * Enable or disable animation of the tooltip.\n *\n * @type {boolean}\n * @default true\n * @since 2.3.0\n */\n animation: svg,\n /**\n * The radius of the rounded border corners.\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * 5px by default\n * @sample {highcharts} highcharts/tooltip/borderradius-0/\n * Square borders\n * @sample {highmaps} maps/tooltip/background-border/\n * Background and border demo\n */\n borderRadius: 3,\n /**\n * For series on datetime axes, the date format in the tooltip's\n * header will by default be guessed based on the closest data points.\n * This member gives the default string representations used for\n * each unit. For an overview of the replacement codes, see\n * [dateFormat](/class-reference/Highcharts.Time#dateFormat).\n *\n * @see [xAxis.dateTimeLabelFormats](#xAxis.dateTimeLabelFormats)\n *\n * @type {Highcharts.Dictionary}\n * @product highcharts highstock gantt\n */\n dateTimeLabelFormats: {\n /** @internal */\n millisecond: '%A, %b %e, %H:%M:%S.%L',\n /** @internal */\n second: '%A, %b %e, %H:%M:%S',\n /** @internal */\n minute: '%A, %b %e, %H:%M',\n /** @internal */\n hour: '%A, %b %e, %H:%M',\n /** @internal */\n day: '%A, %b %e, %Y',\n /** @internal */\n week: 'Week from %A, %b %e, %Y',\n /** @internal */\n month: '%B %Y',\n /** @internal */\n year: '%Y'\n },\n /**\n * A string to append to the tooltip format.\n *\n * @sample {highcharts} highcharts/tooltip/footerformat/\n * A table for value alignment\n * @sample {highmaps} maps/tooltip/format/\n * Format demo\n *\n * @since 2.2\n */\n footerFormat: '',\n /**\n * The name of a symbol to use for the border around the tooltip\n * header. Applies only when [tooltip.split](#tooltip.split) is\n * enabled.\n *\n * Custom callbacks for symbol path generation can also be added to\n * `Highcharts.SVGRenderer.prototype.symbols` the same way as for\n * [series.marker.symbol](plotOptions.line.marker.symbol).\n *\n * @see [tooltip.shape](#tooltip.shape)\n *\n * @sample {highstock} stock/tooltip/split-positioner/\n * Different shapes for header and split boxes\n *\n * @type {Highcharts.TooltipShapeValue}\n * @validvalue [\"callout\", \"square\"]\n * @since 7.0\n */\n headerShape: 'callout',\n /**\n * The number of milliseconds to wait until the tooltip is hidden when\n * mouse out from a point or chart.\n *\n * @since 3.0\n */\n hideDelay: 500,\n /**\n * Padding inside the tooltip, in pixels.\n *\n * @since 5.0.0\n */\n padding: 8,\n /**\n * The name of a symbol to use for the border around the tooltip. Can\n * be one of: `\"callout\"`, `\"circle\"` or `\"rect\"`. When\n * [tooltip.split](#tooltip.split)\n * option is enabled, shape is applied to all boxes except header, which\n * is controlled by\n * [tooltip.headerShape](#tooltip.headerShape).\n *\n * Custom callbacks for symbol path generation can also be added to\n * `Highcharts.SVGRenderer.prototype.symbols` the same way as for\n * [series.marker.symbol](plotOptions.line.marker.symbol).\n *\n * @type {Highcharts.TooltipShapeValue}\n * @since 4.0\n */\n shape: 'callout',\n /**\n * When the tooltip is shared, the entire plot area will capture mouse\n * movement or touch events. Tooltip texts for series types with ordered\n * data (not pie, scatter, flags etc) will be shown in a single bubble.\n * This is recommended for single series charts and for tablet/mobile\n * optimized charts.\n *\n * See also [tooltip.split](#tooltip.split), that is better suited for\n * charts with many series, especially line-type series. The\n * `tooltip.split` option takes precedence over `tooltip.shared`.\n *\n * @sample {highcharts} highcharts/tooltip/shared-false/\n * False by default\n * @sample {highcharts} highcharts/tooltip/shared-true/\n * True\n * @sample {highcharts} highcharts/tooltip/shared-x-crosshair/\n * True with x axis crosshair\n * @sample {highcharts} highcharts/tooltip/shared-true-mixed-types/\n * True with mixed series types\n *\n * @since 2.1\n * @product highcharts highstock\n */\n shared: false,\n /**\n * Proximity snap for graphs or single points. It defaults to 10 for\n * mouse-powered devices and 25 for touch devices.\n *\n * Note that in most cases the whole plot area captures the mouse\n * movement, and in these cases `tooltip.snap` doesn't make sense. This\n * applies when [stickyTracking](#plotOptions.series.stickyTracking)\n * is `true` (default) and when the tooltip is [shared](#tooltip.shared)\n * or [split](#tooltip.split).\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * 10 px by default\n * @sample {highcharts} highcharts/tooltip/snap-50/\n * 50 px on graph\n *\n * @type {number}\n * @default 10/25\n * @since 1.2.0\n * @product highcharts highstock\n */\n snap: isTouchDevice ? 25 : 10,\n /**\n * The HTML of the tooltip header line. Variables are enclosed by\n * curly brackets. Available variables are `point.key`, `series.name`,\n * `series.color` and other members from the `point` and `series`\n * objects. The `point.key` variable contains the category name, x\n * value or datetime string depending on the type of axis. For datetime\n * axes, the `point.key` date format can be set using\n * `tooltip.xDateFormat`.\n *\n * @sample {highcharts} highcharts/tooltip/footerformat/\n * An HTML table in the tooltip\n * @sample {highstock} highcharts/tooltip/footerformat/\n * An HTML table in the tooltip\n * @sample {highmaps} maps/tooltip/format/\n * Format demo\n *\n * @type {string}\n * @apioption tooltip.headerFormat\n */\n headerFormat: '{point.key}
',\n /**\n * The HTML of the null point's line in the tooltip. Works analogously\n * to [pointFormat](#tooltip.pointFormat).\n *\n * @sample {highcharts} highcharts/plotoptions/series-nullformat\n * Format data label and tooltip for null point.\n *\n * @type {string}\n * @apioption tooltip.nullFormat\n */\n /**\n * The HTML of the point's line in the tooltip. Variables are enclosed\n * by curly brackets. Available variables are `point.x`, `point.y`,\n * `series.name` and `series.color` and other properties on the same\n * form. Furthermore, `point.y` can be extended by the\n * `tooltip.valuePrefix` and `tooltip.valueSuffix` variables. This can\n * also be overridden for each series, which makes it a good hook for\n * displaying units.\n *\n * In styled mode, the dot is colored by a class name rather\n * than the point color.\n *\n * @sample {highcharts} highcharts/tooltip/pointformat/\n * A different point format with value suffix\n * @sample {highcharts|highstock} highcharts/tooltip/pointformat-extra-information/\n * Show extra information about points in the tooltip\n * @sample {highmaps} maps/tooltip/format/\n * Format demo\n *\n * @type {string}\n * @since 2.2\n * @apioption tooltip.pointFormat\n */\n pointFormat: '\\u25CF {series.name}: {point.y}
',\n /**\n * The background color or gradient for the tooltip.\n *\n * In styled mode, the stroke width is set in the\n * `.highcharts-tooltip-box` class.\n *\n * @sample {highcharts} highcharts/tooltip/backgroundcolor-solid/\n * Yellowish background\n * @sample {highcharts} highcharts/tooltip/backgroundcolor-gradient/\n * Gradient\n * @sample {highcharts} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n * @sample {highstock} stock/tooltip/general/\n * Custom tooltip\n * @sample {highstock} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n * @sample {highmaps} maps/tooltip/background-border/\n * Background and border demo\n * @sample {highmaps} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n backgroundColor: color(\"#f7f7f7\" /* Palette.neutralColor3 */)\n // @todo: Disallow undefined as input for colors\n .setOpacity(0.85).get(),\n /**\n * The pixel width of the tooltip border.\n *\n * In styled mode, the stroke width is set in the\n * `.highcharts-tooltip-box` class.\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * 2px by default\n * @sample {highcharts} highcharts/tooltip/borderwidth/\n * No border (shadow only)\n * @sample {highcharts} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n * @sample {highstock} stock/tooltip/general/\n * Custom tooltip\n * @sample {highstock} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n * @sample {highmaps} maps/tooltip/background-border/\n * Background and border demo\n * @sample {highmaps} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n */\n borderWidth: 1,\n /**\n * Whether to apply a drop shadow to the tooltip.\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * True by default\n * @sample {highcharts} highcharts/tooltip/shadow/\n * False\n * @sample {highmaps} maps/tooltip/positioner/\n * Fixed tooltip position, border and shadow disabled\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n */\n shadow: true,\n /**\n * Prevents the tooltip from switching or closing when touched or\n * pointed.\n *\n * @sample highcharts/tooltip/stickoncontact/\n * Tooltip sticks on pointer contact\n *\n * @since 8.0.1\n */\n stickOnContact: false,\n /**\n * CSS styles for the tooltip. The tooltip can also be styled through\n * the CSS class `.highcharts-tooltip`.\n *\n * Note that the default `pointerEvents` style makes the tooltip ignore\n * mouse events, so in order to use clickable tooltips, this value must\n * be set to `auto`.\n *\n * @sample {highcharts} highcharts/tooltip/style/\n * Greater padding, bold text\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @internal */\n color: \"#333333\" /* Palette.neutralColor80 */,\n /** @internal */\n cursor: 'default',\n /** @internal */\n fontSize: '12px',\n /** @internal */\n whiteSpace: 'nowrap'\n },\n /**\n * Use HTML to render the contents of the tooltip instead of SVG. Using\n * HTML allows advanced formatting like tables and images in the\n * tooltip. It is also recommended for rtl languages as it works around\n * rtl bugs in early Firefox.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/footerformat/\n * A table for value alignment\n * @sample {highcharts|highstock} highcharts/tooltip/fullhtml/\n * Full HTML tooltip\n * @sample {highmaps} maps/tooltip/usehtml/\n * Pure HTML tooltip\n *\n * @since 2.2\n */\n useHTML: false\n },\n /**\n * Highchart by default puts a credits label in the lower right corner\n * of the chart. This can be changed using these options.\n */\n credits: {\n /**\n * Credits for map source to be concatenated with conventional credit\n * text. By default this is a format string that collects copyright\n * information from the map if available.\n *\n * @see [mapTextFull](#credits.mapTextFull)\n * @see [text](#credits.text)\n *\n * @type {string}\n * @default \\u00a9 {geojson.copyrightShort}\n * @since 4.2.2\n * @product highmaps\n * @apioption credits.mapText\n */\n /**\n * Detailed credits for map source to be displayed on hover of credits\n * text. By default this is a format string that collects copyright\n * information from the map if available.\n *\n * @see [mapText](#credits.mapText)\n * @see [text](#credits.text)\n *\n * @type {string}\n * @default {geojson.copyright}\n * @since 4.2.2\n * @product highmaps\n * @apioption credits.mapTextFull\n */\n /**\n * Whether to show the credits text.\n *\n * @sample {highcharts} highcharts/credits/enabled-false/\n * Credits disabled\n * @sample {highstock} stock/credits/enabled/\n * Credits disabled\n * @sample {highmaps} maps/credits/enabled-false/\n * Credits disabled\n */\n enabled: true,\n /**\n * The URL for the credits label.\n *\n * @sample {highcharts} highcharts/credits/href/\n * Custom URL and text\n * @sample {highmaps} maps/credits/customized/\n * Custom URL and text\n */\n href: 'https://www.highcharts.com?credits',\n /**\n * Position configuration for the credits label.\n *\n * @sample {highcharts} highcharts/credits/position-left/\n * Left aligned\n * @sample {highcharts} highcharts/credits/position-left/\n * Left aligned\n * @sample {highmaps} maps/credits/customized/\n * Left aligned\n * @sample {highmaps} maps/credits/customized/\n * Left aligned\n *\n * @type {Highcharts.AlignObject}\n * @since 2.1\n */\n position: {\n /** @internal */\n align: 'right',\n /** @internal */\n x: -10,\n /** @internal */\n verticalAlign: 'bottom',\n /** @internal */\n y: -5\n },\n /**\n * CSS styles for the credits label.\n *\n * @see In styled mode, credits styles can be set with the\n * `.highcharts-credits` class.\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @internal */\n cursor: 'pointer',\n /** @internal */\n color: \"#999999\" /* Palette.neutralColor40 */,\n /** @internal */\n fontSize: '9px'\n },\n /**\n * The text for the credits label.\n *\n * @productdesc {highmaps}\n * If a map is loaded as GeoJSON, the text defaults to\n * `Highcharts @ {map-credits}`. Otherwise, it defaults to\n * `Highcharts.com`.\n *\n * @sample {highcharts} highcharts/credits/href/\n * Custom URL and text\n * @sample {highmaps} maps/credits/customized/\n * Custom URL and text\n */\n text: 'Highcharts.com'\n }\n };\n /* eslint-disable spaced-comment */\n\n defaultOptions.chart.styledMode = false;\n\n '';\n var defaultTime = new Time(merge(defaultOptions.global,\n defaultOptions.time));\n /**\n * Get the updated default options. Until 3.0.7, merely exposing defaultOptions\n * for outside modules wasn't enough because the setOptions method created a new\n * object.\n *\n * @function Highcharts.getOptions\n *\n * @return {Highcharts.Options}\n * Default options.\n */\n function getOptions() {\n return defaultOptions;\n }\n /**\n * Merge the default options with custom options and return the new options\n * structure. Commonly used for defining reusable templates.\n *\n * @sample highcharts/global/useutc-false Setting a global option\n * @sample highcharts/members/setoptions Applying a global theme\n *\n * @function Highcharts.setOptions\n *\n * @param {Highcharts.Options} options\n * The new custom chart options.\n *\n * @return {Highcharts.Options}\n * Updated options.\n */\n function setOptions(options) {\n // Copy in the default options\n merge(true, defaultOptions, options);\n // Update the time object\n if (options.time || options.global) {\n if (H.time) {\n H.time.update(merge(defaultOptions.global, defaultOptions.time, options.global, options.time));\n }\n else {\n /**\n * Global `Time` object with default options. Since v6.0.5, time\n * settings can be applied individually for each chart. If no\n * individual settings apply, this `Time` object is shared by all\n * instances.\n *\n * @name Highcharts.time\n * @type {Highcharts.Time}\n */\n H.time = defaultTime;\n }\n }\n return defaultOptions;\n }\n /* *\n *\n * Default Export\n *\n * */\n var DefaultOptions = {\n defaultOptions: defaultOptions,\n defaultTime: defaultTime,\n getOptions: getOptions,\n setOptions: setOptions\n };\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @typedef {\"plotBox\"|\"spacingBox\"} Highcharts.ButtonRelativeToValue\n */\n /**\n * Gets fired when a series is added to the chart after load time, using the\n * `addSeries` method. Returning `false` prevents the series from being added.\n *\n * @callback Highcharts.ChartAddSeriesCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {Highcharts.ChartAddSeriesEventObject} event\n * The event that occured.\n */\n /**\n * Contains common event information. Through the `options` property you can\n * access the series options that were passed to the `addSeries` method.\n *\n * @interface Highcharts.ChartAddSeriesEventObject\n */ /**\n * The series options that were passed to the `addSeries` method.\n * @name Highcharts.ChartAddSeriesEventObject#options\n * @type {Highcharts.SeriesOptionsType}\n */ /**\n * Prevents the default behaviour of the event.\n * @name Highcharts.ChartAddSeriesEventObject#preventDefault\n * @type {Function}\n */ /**\n * The event target.\n * @name Highcharts.ChartAddSeriesEventObject#target\n * @type {Highcharts.Chart}\n */ /**\n * The event type.\n * @name Highcharts.ChartAddSeriesEventObject#type\n * @type {\"addSeries\"}\n */\n /**\n * Gets fired when clicking on the plot background.\n *\n * @callback Highcharts.ChartClickCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {Highcharts.PointerEventObject} event\n * The event that occured.\n */\n /**\n * Contains an axes of the clicked spot.\n *\n * @interface Highcharts.ChartClickEventAxisObject\n */ /**\n * Axis at the clicked spot.\n * @name Highcharts.ChartClickEventAxisObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * Axis value at the clicked spot.\n * @name Highcharts.ChartClickEventAxisObject#value\n * @type {number}\n */\n /**\n * Contains information about the clicked spot on the chart. Remember the unit\n * of a datetime axis is milliseconds since 1970-01-01 00:00:00.\n *\n * @interface Highcharts.ChartClickEventObject\n * @extends Highcharts.PointerEventObject\n */ /**\n * Information about the x-axis on the clicked spot.\n * @name Highcharts.ChartClickEventObject#xAxis\n * @type {Array}\n */ /**\n * Information about the y-axis on the clicked spot.\n * @name Highcharts.ChartClickEventObject#yAxis\n * @type {Array}\n */ /**\n * Information about the z-axis on the clicked spot.\n * @name Highcharts.ChartClickEventObject#zAxis\n * @type {Array|undefined}\n */\n /**\n * Gets fired when the chart is finished loading.\n *\n * @callback Highcharts.ChartLoadCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * Fires when the chart is redrawn, either after a call to `chart.redraw()` or\n * after an axis, series or point is modified with the `redraw` option set to\n * `true`.\n *\n * @callback Highcharts.ChartRedrawCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * Gets fired after initial load of the chart (directly after the `load` event),\n * and after each redraw (directly after the `redraw` event).\n *\n * @callback Highcharts.ChartRenderCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * Gets fired when an area of the chart has been selected. The default action\n * for the selection event is to zoom the chart to the selected area. It can be\n * prevented by calling `event.preventDefault()` or return false.\n *\n * @callback Highcharts.ChartSelectionCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {Highcharts.SelectEventObject} event\n * Event informations\n *\n * @return {boolean|undefined}\n * Return false to prevent the default action, usually zoom.\n */\n (''); // detach doclets above\n\n return DefaultOptions;\n });\n _registerModule(_modules, 'Core/Animation/Fx.js', [_modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (Color, H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var color = Color.parse;\n var win = H.win;\n var isNumber = U.isNumber,\n objectEach = U.objectEach;\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /* *\n *\n * Class\n *\n * */\n /**\n * An animator object used internally. One instance applies to one property\n * (attribute or style prop) on one element. Animation is always initiated\n * through {@link SVGElement#animate}.\n *\n * @example\n * let rect = renderer.rect(0, 0, 10, 10).add();\n * rect.animate({ width: 100 });\n *\n * @private\n * @class\n * @name Highcharts.Fx\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGElement} elem\n * The element to animate.\n *\n * @param {Partial} options\n * Animation options.\n *\n * @param {string} prop\n * The single attribute or CSS property to animate.\n */\n var Fx = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Fx(elem, options, prop) {\n this.pos = NaN;\n this.options = options;\n this.elem = elem;\n this.prop = prop;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set the current step of a path definition on SVGElement.\n *\n * @function Highcharts.Fx#dSetter\n *\n */\n Fx.prototype.dSetter = function () {\n var paths = this.paths,\n start = paths && paths[0],\n end = paths && paths[1],\n now = this.now || 0;\n var path = [];\n // Land on the final path without adjustment points appended in the ends\n if (now === 1 || !start || !end) {\n path = this.toD || [];\n }\n else if (start.length === end.length && now < 1) {\n for (var i = 0; i < end.length; i++) {\n // Tween between the start segment and the end segment. Start\n // with a copy of the end segment and tween the appropriate\n // numerics\n var startSeg = start[i];\n var endSeg = end[i];\n var tweenSeg = [];\n for (var j = 0; j < endSeg.length; j++) {\n var startItem = startSeg[j];\n var endItem = endSeg[j];\n // Tween numbers\n if (isNumber(startItem) &&\n isNumber(endItem) &&\n // Arc boolean flags\n !(endSeg[0] === 'A' && (j === 4 || j === 5))) {\n tweenSeg[j] = startItem + now * (endItem - startItem);\n // Strings, take directly from the end segment\n }\n else {\n tweenSeg[j] = endItem;\n }\n }\n path.push(tweenSeg);\n }\n // If animation is finished or length not matching, land on right value\n }\n else {\n path = end;\n }\n this.elem.attr('d', path, void 0, true);\n };\n /**\n * Update the element with the current animation step.\n *\n * @function Highcharts.Fx#update\n *\n */\n Fx.prototype.update = function () {\n var elem = this.elem,\n prop = this.prop, // if destroyed, it is null\n now = this.now,\n step = this.options.step;\n // Animation setter defined from outside\n if (this[prop + 'Setter']) {\n this[prop + 'Setter']();\n // Other animations on SVGElement\n }\n else if (elem.attr) {\n if (elem.element) {\n elem.attr(prop, now, null, true);\n }\n // HTML styles, raw HTML content like container size\n }\n else {\n elem.style[prop] = now + this.unit;\n }\n if (step) {\n step.call(elem, now, this);\n }\n };\n /**\n * Run an animation.\n *\n * @function Highcharts.Fx#run\n *\n * @param {number} from\n * The current value, value to start from.\n *\n * @param {number} to\n * The end value, value to land on.\n *\n * @param {string} unit\n * The property unit, for example `px`.\n *\n */\n Fx.prototype.run = function (from, to, unit) {\n var self = this,\n options = self.options,\n timer = function (gotoEnd) {\n return timer.stopped ? false : self.step(gotoEnd);\n }, requestAnimationFrame = win.requestAnimationFrame ||\n function (step) {\n setTimeout(step, 13);\n }, step = function () {\n for (var i = 0; i < Fx.timers.length; i++) {\n if (!Fx.timers[i]()) {\n Fx.timers.splice(i--, 1);\n }\n }\n if (Fx.timers.length) {\n requestAnimationFrame(step);\n }\n };\n if (from === to && !this.elem['forceAnimate:' + this.prop]) {\n delete options.curAnim[this.prop];\n if (options.complete &&\n Object.keys(options.curAnim).length === 0) {\n options.complete.call(this.elem);\n }\n }\n else { // #7166\n this.startTime = +new Date();\n this.start = from;\n this.end = to;\n this.unit = unit;\n this.now = this.start;\n this.pos = 0;\n timer.elem = this.elem;\n timer.prop = this.prop;\n if (timer() && Fx.timers.push(timer) === 1) {\n requestAnimationFrame(step);\n }\n }\n };\n /**\n * Run a single step in the animation.\n *\n * @function Highcharts.Fx#step\n *\n * @param {boolean} [gotoEnd]\n * Whether to go to the endpoint of the animation after abort.\n *\n * @return {boolean}\n * Returns `true` if animation continues.\n */\n Fx.prototype.step = function (gotoEnd) {\n var t = +new Date(),\n options = this.options,\n elem = this.elem,\n complete = options.complete,\n duration = options.duration,\n curAnim = options.curAnim;\n var ret,\n done;\n if ((elem.attr) && !elem.element) { // #2616, element is destroyed\n ret = false;\n }\n else if (gotoEnd || t >= duration + this.startTime) {\n this.now = this.end;\n this.pos = 1;\n this.update();\n curAnim[this.prop] = true;\n done = true;\n objectEach(curAnim, function (val) {\n if (val !== true) {\n done = false;\n }\n });\n if (done && complete) {\n complete.call(elem);\n }\n ret = false;\n }\n else {\n this.pos = options.easing((t - this.startTime) / duration);\n this.now = this.start + ((this.end -\n this.start) * this.pos);\n this.update();\n ret = true;\n }\n return ret;\n };\n /**\n * Prepare start and end values so that the path can be animated one to one.\n *\n * @function Highcharts.Fx#initPath\n *\n * @param {Highcharts.SVGElement} elem\n * The SVGElement item.\n *\n * @param {Highcharts.SVGPathArray|undefined} fromD\n * Starting path definition.\n *\n * @param {Highcharts.SVGPathArray} toD\n * Ending path definition.\n *\n * @return {Array}\n * An array containing start and end paths in array form so that\n * they can be animated in parallel.\n */\n Fx.prototype.initPath = function (elem, fromD, toD) {\n var startX = elem.startX,\n endX = elem.endX,\n end = toD.slice(), // copy\n isArea = elem.isArea,\n positionFactor = isArea ? 2 : 1;\n var shift,\n fullLength,\n i,\n reverse,\n start = fromD && fromD.slice(); // copy\n if (!start) {\n return [end,\n end];\n }\n /**\n * If shifting points, prepend a dummy point to the end path.\n * @private\n */\n function prepend(arr, other) {\n while (arr.length < fullLength) {\n // Move to, line to or curve to?\n var moveSegment = arr[0],\n otherSegment = other[fullLength - arr.length];\n if (otherSegment && moveSegment[0] === 'M') {\n if (otherSegment[0] === 'C') {\n arr[0] = [\n 'C',\n moveSegment[1],\n moveSegment[2],\n moveSegment[1],\n moveSegment[2],\n moveSegment[1],\n moveSegment[2]\n ];\n }\n else {\n arr[0] = ['L', moveSegment[1], moveSegment[2]];\n }\n }\n // Prepend a copy of the first point\n arr.unshift(moveSegment);\n // For areas, the bottom path goes back again to the left, so we\n // need to append a copy of the last point.\n if (isArea) {\n var z = arr.pop();\n arr.push(arr[arr.length - 1], z); // append point and the Z\n }\n }\n }\n /**\n * Copy and append last point until the length matches the end length.\n * @private\n */\n function append(arr, other) {\n while (arr.length < fullLength) {\n // Pull out the slice that is going to be appended or inserted.\n // In a line graph, the positionFactor is 1, and the last point\n // is sliced out. In an area graph, the positionFactor is 2,\n // causing the middle two points to be sliced out, since an area\n // path starts at left, follows the upper path then turns and\n // follows the bottom back.\n var segmentToAdd = arr[Math.floor(arr.length / positionFactor) - 1].slice();\n // Disable the first control point of curve segments\n if (segmentToAdd[0] === 'C') {\n segmentToAdd[1] = segmentToAdd[5];\n segmentToAdd[2] = segmentToAdd[6];\n }\n if (!isArea) {\n arr.push(segmentToAdd);\n }\n else {\n var lowerSegmentToAdd = arr[Math.floor(arr.length / positionFactor)].slice();\n arr.splice(arr.length / 2, 0, segmentToAdd, lowerSegmentToAdd);\n }\n }\n }\n // For sideways animation, find out how much we need to shift to get the\n // start path Xs to match the end path Xs.\n if (startX && endX && endX.length) {\n for (i = 0; i < startX.length; i++) {\n // Moving left, new points coming in on right\n if (startX[i] === endX[0]) {\n shift = i;\n break;\n // Moving right\n }\n else if (startX[0] ===\n endX[endX.length - startX.length + i]) {\n shift = i;\n reverse = true;\n break;\n // Fixed from the right side, \"scaling\" left\n }\n else if (startX[startX.length - 1] ===\n endX[endX.length - startX.length + i]) {\n shift = startX.length - i;\n break;\n }\n }\n if (typeof shift === 'undefined') {\n start = [];\n }\n }\n if (start.length && isNumber(shift)) {\n // The common target length for the start and end array, where both\n // arrays are padded in opposite ends\n fullLength = end.length + shift * positionFactor;\n if (!reverse) {\n prepend(end, start);\n append(start, end);\n }\n else {\n prepend(start, end);\n append(end, start);\n }\n }\n return [start, end];\n };\n /**\n * Handle animation of the color attributes directly.\n *\n * @function Highcharts.Fx#fillSetter\n *\n */\n Fx.prototype.fillSetter = function () {\n Fx.prototype.strokeSetter.apply(this, arguments);\n };\n /**\n * Handle animation of the color attributes directly.\n *\n * @function Highcharts.Fx#strokeSetter\n *\n */\n Fx.prototype.strokeSetter = function () {\n this.elem.attr(this.prop, color(this.start).tweenTo(color(this.end), this.pos), void 0, true);\n };\n /* *\n *\n * Static Properties\n *\n * */\n Fx.timers = [];\n return Fx;\n }());\n /* *\n *\n * Default Export\n *\n * */\n\n return Fx;\n });\n _registerModule(_modules, 'Core/Animation/AnimationUtilities.js', [_modules['Core/Animation/Fx.js'], _modules['Core/Utilities.js']], function (Fx, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var defined = U.defined,\n getStyle = U.getStyle,\n isArray = U.isArray,\n isNumber = U.isNumber,\n isObject = U.isObject,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set the global animation to either a given value, or fall back to the given\n * chart's animation option.\n *\n * @function Highcharts.setAnimation\n *\n * @param {boolean|Partial|undefined} animation\n * The animation object.\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @todo\n * This function always relates to a chart, and sets a property on the renderer,\n * so it should be moved to the SVGRenderer.\n */\n function setAnimation(animation, chart) {\n chart.renderer.globalAnimation = pick(animation, chart.options.chart.animation, true);\n }\n /**\n * Get the animation in object form, where a disabled animation is always\n * returned as `{ duration: 0 }`.\n *\n * @function Highcharts.animObject\n *\n * @param {boolean|Highcharts.AnimationOptionsObject} [animation=0]\n * An animation setting. Can be an object with duration, complete and\n * easing properties, or a boolean to enable or disable.\n *\n * @return {Highcharts.AnimationOptionsObject}\n * An object with at least a duration property.\n */\n function animObject(animation) {\n return isObject(animation) ?\n merge({ duration: 500, defer: 0 }, animation) :\n { duration: animation ? 500 : 0, defer: 0 };\n }\n /**\n * Get the defer as a number value from series animation options.\n *\n * @function Highcharts.getDeferredAnimation\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {boolean|Highcharts.AnimationOptionsObject} animation\n * An animation setting. Can be an object with duration, complete and\n * easing properties, or a boolean to enable or disable.\n *\n * @param {Highcharts.Series} [series]\n * Series to defer animation.\n *\n * @return {number}\n * The numeric value.\n */\n function getDeferredAnimation(chart, animation, series) {\n var labelAnimation = animObject(animation),\n s = series ? [series] : chart.series;\n var defer = 0,\n duration = 0;\n s.forEach(function (series) {\n var seriesAnim = animObject(series.options.animation);\n defer = animation && defined(animation.defer) ?\n labelAnimation.defer :\n Math.max(defer, seriesAnim.duration + seriesAnim.defer);\n duration = Math.min(labelAnimation.duration, seriesAnim.duration);\n });\n // Disable defer for exporting\n if (chart.renderer.forExport) {\n defer = 0;\n }\n var anim = {\n defer: Math.max(0,\n defer - duration),\n duration: Math.min(defer,\n duration)\n };\n return anim;\n }\n /**\n * The global animate method, which uses Fx to create individual animators.\n *\n * @function Highcharts.animate\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGElement} el\n * The element to animate.\n *\n * @param {Highcharts.CSSObject|Highcharts.SVGAttributes} params\n * An object containing key-value pairs of the properties to animate.\n * Supports numeric as pixel-based CSS properties for HTML objects and\n * attributes for SVGElements.\n *\n * @param {Partial} [opt]\n * Animation options.\n *\n * @return {void}\n */\n function animate(el, params, opt) {\n var start,\n unit = '',\n end,\n fx,\n args;\n if (!isObject(opt)) { // Number or undefined/null\n args = arguments;\n opt = {\n duration: args[2],\n easing: args[3],\n complete: args[4]\n };\n }\n if (!isNumber(opt.duration)) {\n opt.duration = 400;\n }\n opt.easing = typeof opt.easing === 'function' ?\n opt.easing :\n (Math[opt.easing] || Math.easeInOutSine);\n opt.curAnim = merge(params);\n objectEach(params, function (val, prop) {\n // Stop current running animation of this property\n stop(el, prop);\n fx = new Fx(el, opt, prop);\n end = void 0;\n if (prop === 'd' && isArray(params.d)) {\n fx.paths = fx.initPath(el, el.pathArray, params.d);\n fx.toD = params.d;\n start = 0;\n end = 1;\n }\n else if (el.attr) {\n start = el.attr(prop);\n }\n else {\n start = parseFloat(getStyle(el, prop)) || 0;\n if (prop !== 'opacity') {\n unit = 'px';\n }\n }\n if (!end) {\n end = val;\n }\n if (typeof end === 'string' && end.match('px')) {\n end = end.replace(/px/g, ''); // #4351\n }\n fx.run(start, end, unit);\n });\n }\n /**\n * Stop running animation.\n *\n * @function Highcharts.stop\n *\n * @param {Highcharts.SVGElement} el\n * The SVGElement to stop animation on.\n *\n * @param {string} [prop]\n * The property to stop animating. If given, the stop method will stop a\n * single property from animating, while others continue.\n *\n * @return {void}\n *\n * @todo\n * A possible extension to this would be to stop a single property, when\n * we want to continue animating others. Then assign the prop to the timer\n * in the Fx.run method, and check for the prop here. This would be an\n * improvement in all cases where we stop the animation from .attr. Instead of\n * stopping everything, we can just stop the actual attributes we're setting.\n */\n function stop(el, prop) {\n var i = Fx.timers.length;\n // Remove timers related to this element (#4519)\n while (i--) {\n if (Fx.timers[i].elem === el && (!prop || prop === Fx.timers[i].prop)) {\n Fx.timers[i].stopped = true; // #4667\n }\n }\n }\n var animationExports = {\n animate: animate,\n animObject: animObject,\n getDeferredAnimation: getDeferredAnimation,\n setAnimation: setAnimation,\n stop: stop\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return animationExports;\n });\n _registerModule(_modules, 'Core/Renderer/HTML/AST.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * (c) 2010-2020 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var SVG_NS = H.SVG_NS,\n win = H.win;\n var attr = U.attr,\n createElement = U.createElement,\n css = U.css,\n error = U.error,\n isFunction = U.isFunction,\n isString = U.isString,\n objectEach = U.objectEach,\n splat = U.splat;\n var trustedTypes = win.trustedTypes;\n /* *\n *\n * Constants\n *\n * */\n // Create the trusted type policy. This should not be exposed.\n var trustedTypesPolicy = (trustedTypes &&\n isFunction(trustedTypes.createPolicy) &&\n trustedTypes.createPolicy('highcharts', {\n createHTML: function (s) { return s; }\n }));\n var emptyHTML = trustedTypesPolicy ?\n trustedTypesPolicy.createHTML('') :\n '';\n // In IE8, DOMParser is undefined. IE9 and PhantomJS are only able to parse XML.\n var hasValidDOMParser = (function () {\n try {\n return Boolean(new DOMParser().parseFromString(emptyHTML, 'text/html'));\n }\n catch (e) {\n return false;\n }\n }());\n /* *\n *\n * Class\n *\n * */\n /**\n * The AST class represents an abstract syntax tree of HTML or SVG content. It\n * can take HTML as an argument, parse it, optionally transform it to SVG, then\n * perform sanitation before inserting it into the DOM.\n *\n * @class\n * @name Highcharts.AST\n *\n * @param {string|Array} source\n * Either an HTML string or an ASTNode list to populate the tree.\n */\n var AST = /** @class */ (function () {\n /* *\n *\n * Constructor\n *\n * */\n // Construct an AST from HTML markup, or wrap an array of existing AST nodes\n function AST(source) {\n this.nodes = typeof source === 'string' ?\n this.parseMarkup(source) : source;\n }\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Filter an object of SVG or HTML attributes against the allow list.\n *\n * @static\n *\n * @function Highcharts.AST#filterUserAttributes\n *\n * @param {Highcharts.SVGAttributes} attributes The attributes to filter\n *\n * @return {Highcharts.SVGAttributes}\n * The filtered attributes\n */\n AST.filterUserAttributes = function (attributes) {\n objectEach(attributes, function (val, key) {\n var valid = true;\n if (AST.allowedAttributes.indexOf(key) === -1) {\n valid = false;\n }\n if (['background', 'dynsrc', 'href', 'lowsrc', 'src']\n .indexOf(key) !== -1) {\n valid = isString(val) && AST.allowedReferences.some(function (ref) { return val.indexOf(ref) === 0; });\n }\n if (!valid) {\n error(33, false, void 0, {\n 'Invalid attribute in config': \"\".concat(key)\n });\n delete attributes[key];\n }\n });\n return attributes;\n };\n AST.parseStyle = function (style) {\n return style\n .split(';')\n .reduce(function (styles, line) {\n var pair = line.split(':').map(function (s) { return s.trim(); }),\n key = pair.shift();\n if (key && pair.length) {\n styles[key.replace(/-([a-z])/g, function (g) { return g[1].toUpperCase(); })] = pair.join(':'); // #17146\n }\n return styles;\n }, {});\n };\n /**\n * Utility function to set html content for an element by passing in a\n * markup string. The markup is safely parsed by the AST class to avoid\n * XSS vulnerabilities. This function should be used instead of setting\n * `innerHTML` in all cases where the content is not fully trusted.\n *\n * @static\n * @function Highcharts.AST#setElementHTML\n *\n * @param {SVGDOMElement|HTMLDOMElement} el\n * Node to set content of.\n *\n * @param {string} html\n * Markup string\n */\n AST.setElementHTML = function (el, html) {\n el.innerHTML = AST.emptyHTML; // Clear previous\n if (html) {\n var ast = new AST(html);\n ast.addToDOM(el);\n }\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Add the tree defined as a hierarchical JS structure to the DOM\n *\n * @function Highcharts.AST#addToDOM\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGDOMElement} parent\n * The node where it should be added\n *\n * @return {Highcharts.HTMLDOMElement|Highcharts.SVGDOMElement}\n * The inserted node.\n */\n AST.prototype.addToDOM = function (parent) {\n /**\n * @private\n * @param {Highcharts.ASTNode} subtree\n * HTML/SVG definition\n * @param {Element} [subParent]\n * parent node\n * @return {Highcharts.SVGDOMElement|Highcharts.HTMLDOMElement}\n * The inserted node.\n */\n function recurse(subtree, subParent) {\n var ret;\n splat(subtree).forEach(function (item) {\n var tagName = item.tagName;\n var textNode = item.textContent ?\n H.doc.createTextNode(item.textContent) :\n void 0;\n // Whether to ignore the AST filtering totally, #15345\n var bypassHTMLFiltering = AST.bypassHTMLFiltering;\n var node;\n if (tagName) {\n if (tagName === '#text') {\n node = textNode;\n }\n else if (AST.allowedTags.indexOf(tagName) !== -1 ||\n bypassHTMLFiltering) {\n var NS = tagName === 'svg' ?\n SVG_NS :\n (subParent.namespaceURI || SVG_NS);\n var element = H.doc.createElementNS(NS,\n tagName);\n var attributes_1 = item.attributes || {};\n // Apply attributes from root of AST node, legacy from\n // from before TextBuilder\n objectEach(item, function (val, key) {\n if (key !== 'tagName' &&\n key !== 'attributes' &&\n key !== 'children' &&\n key !== 'style' &&\n key !== 'textContent') {\n attributes_1[key] = val;\n }\n });\n attr(element, bypassHTMLFiltering ?\n attributes_1 :\n AST.filterUserAttributes(attributes_1));\n if (item.style) {\n css(element, item.style);\n }\n // Add text content\n if (textNode) {\n element.appendChild(textNode);\n }\n // Recurse\n recurse(item.children || [], element);\n node = element;\n }\n else {\n error(33, false, void 0, {\n 'Invalid tagName in config': tagName\n });\n }\n }\n // Add to the tree\n if (node) {\n subParent.appendChild(node);\n }\n ret = node;\n });\n // Return last node added (on top level it's the only one)\n return ret;\n }\n return recurse(this.nodes, parent);\n };\n /**\n * Parse HTML/SVG markup into AST Node objects. Used internally from the\n * constructor.\n *\n * @private\n *\n * @function Highcharts.AST#getNodesFromMarkup\n *\n * @param {string} markup The markup string.\n *\n * @return {Array} The parsed nodes.\n */\n AST.prototype.parseMarkup = function (markup) {\n var nodes = [];\n markup = markup\n .trim()\n // The style attribute throws a warning when parsing when CSP is\n // enabled (#6884), so use an alias and pick it up below\n // Make all quotation marks parse correctly to DOM (#17627)\n .replace(/ style=([\"'])/g, ' data-style=$1');\n var doc;\n if (hasValidDOMParser) {\n doc = new DOMParser().parseFromString(trustedTypesPolicy ?\n trustedTypesPolicy.createHTML(markup) :\n markup, 'text/html');\n }\n else {\n var body = createElement('div');\n body.innerHTML = markup;\n doc = { body: body };\n }\n var appendChildNodes = function (node,\n addTo) {\n var tagName = node.nodeName.toLowerCase();\n // Add allowed tags\n var astNode = {\n tagName: tagName\n };\n if (tagName === '#text') {\n astNode.textContent = node.textContent || '';\n }\n var parsedAttributes = node.attributes;\n // Add attributes\n if (parsedAttributes) {\n var attributes_2 = {};\n [].forEach.call(parsedAttributes, function (attrib) {\n if (attrib.name === 'data-style') {\n astNode.style = AST.parseStyle(attrib.value);\n }\n else {\n attributes_2[attrib.name] = attrib.value;\n }\n });\n astNode.attributes = attributes_2;\n }\n // Handle children\n if (node.childNodes.length) {\n var children_1 = [];\n [].forEach.call(node.childNodes, function (childNode) {\n appendChildNodes(childNode, children_1);\n });\n if (children_1.length) {\n astNode.children = children_1;\n }\n }\n addTo.push(astNode);\n };\n [].forEach.call(doc.body.childNodes, function (childNode) { return appendChildNodes(childNode, nodes); });\n return nodes;\n };\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * The list of allowed SVG or HTML attributes, used for sanitizing\n * potentially harmful content from the chart configuration before adding to\n * the DOM.\n *\n * @example\n * // Allow a custom, trusted attribute\n * Highcharts.AST.allowedAttributes.push('data-value');\n *\n * @name Highcharts.AST.allowedAttributes\n * @static\n */\n AST.allowedAttributes = [\n 'aria-controls',\n 'aria-describedby',\n 'aria-expanded',\n 'aria-haspopup',\n 'aria-hidden',\n 'aria-label',\n 'aria-labelledby',\n 'aria-live',\n 'aria-pressed',\n 'aria-readonly',\n 'aria-roledescription',\n 'aria-selected',\n 'class',\n 'clip-path',\n 'color',\n 'colspan',\n 'cx',\n 'cy',\n 'd',\n 'dx',\n 'dy',\n 'disabled',\n 'fill',\n 'height',\n 'href',\n 'id',\n 'in',\n 'markerHeight',\n 'markerWidth',\n 'offset',\n 'opacity',\n 'orient',\n 'padding',\n 'paddingLeft',\n 'paddingRight',\n 'patternUnits',\n 'r',\n 'refX',\n 'refY',\n 'role',\n 'scope',\n 'slope',\n 'src',\n 'startOffset',\n 'stdDeviation',\n 'stroke',\n 'stroke-linecap',\n 'stroke-width',\n 'style',\n 'tableValues',\n 'result',\n 'rowspan',\n 'summary',\n 'target',\n 'tabindex',\n 'text-align',\n 'text-anchor',\n 'textAnchor',\n 'textLength',\n 'title',\n 'type',\n 'valign',\n 'width',\n 'x',\n 'x1',\n 'x2',\n 'y',\n 'y1',\n 'y2',\n 'zIndex'\n ];\n /**\n * The list of allowed references for referring attributes like `href` and\n * `src`. Attribute values will only be allowed if they start with one of\n * these strings.\n *\n * @example\n * // Allow tel:\n * Highcharts.AST.allowedReferences.push('tel:');\n *\n * @name Highcharts.AST.allowedReferences\n * @static\n */\n AST.allowedReferences = [\n 'https://',\n 'http://',\n 'mailto:',\n '/',\n '../',\n './',\n '#'\n ];\n /**\n * The list of allowed SVG or HTML tags, used for sanitizing potentially\n * harmful content from the chart configuration before adding to the DOM.\n *\n * @example\n * // Allow a custom, trusted tag\n * Highcharts.AST.allowedTags.push('blink'); // ;)\n *\n * @name Highcharts.AST.allowedTags\n * @static\n */\n AST.allowedTags = [\n 'a',\n 'abbr',\n 'b',\n 'br',\n 'button',\n 'caption',\n 'circle',\n 'clipPath',\n 'code',\n 'dd',\n 'defs',\n 'div',\n 'dl',\n 'dt',\n 'em',\n 'feComponentTransfer',\n 'feFuncA',\n 'feFuncB',\n 'feFuncG',\n 'feFuncR',\n 'feGaussianBlur',\n 'feOffset',\n 'feMerge',\n 'feMergeNode',\n 'filter',\n 'h1',\n 'h2',\n 'h3',\n 'h4',\n 'h5',\n 'h6',\n 'hr',\n 'i',\n 'img',\n 'li',\n 'linearGradient',\n 'marker',\n 'ol',\n 'p',\n 'path',\n 'pattern',\n 'pre',\n 'rect',\n 'small',\n 'span',\n 'stop',\n 'strong',\n 'style',\n 'sub',\n 'sup',\n 'svg',\n 'table',\n 'text',\n 'textPath',\n 'thead',\n 'tbody',\n 'tspan',\n 'td',\n 'th',\n 'tr',\n 'u',\n 'ul',\n '#text'\n ];\n AST.emptyHTML = emptyHTML;\n /**\n * Allow all custom SVG and HTML attributes, references and tags (together\n * with potentially harmful ones) to be added to the DOM from the chart\n * configuration. In other words, disable the the allow-listing which is the\n * primary functionality of the AST.\n *\n * WARNING: Setting this property to `true` while allowing untrusted user\n * data in the chart configuration will expose your application to XSS\n * security risks!\n *\n * Note that in case you want to allow a known set of tags or attributes,\n * you should allow-list them instead of disabling the filtering totally.\n * See [allowedAttributes](Highcharts.AST#.allowedAttributes),\n * [allowedReferences](Highcharts.AST#.allowedReferences) and\n * [allowedTags](Highcharts.AST#.allowedTags). The `bypassHTMLFiltering`\n * setting is intended only for those cases where allow-listing is not\n * practical, and the chart configuration already comes from a secure\n * source.\n *\n * @example\n * // Allow all custom attributes, references and tags (disable DOM XSS\n * // filtering)\n * Highcharts.AST.bypassHTMLFiltering = true;\n *\n * @name Highcharts.AST.bypassHTMLFiltering\n * @static\n */\n AST.bypassHTMLFiltering = false;\n return AST;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Serialized form of an SVG/HTML definition, including children.\n *\n * @interface Highcharts.ASTNode\n */ /**\n * @name Highcharts.ASTNode#attributes\n * @type {Highcharts.SVGAttributes|undefined}\n */ /**\n * @name Highcharts.ASTNode#children\n * @type {Array|undefined}\n */ /**\n * @name Highcharts.ASTNode#tagName\n * @type {string|undefined}\n */ /**\n * @name Highcharts.ASTNode#textContent\n * @type {string|undefined}\n */\n (''); // keeps doclets above in file\n\n return AST;\n });\n _registerModule(_modules, 'Core/FormatUtilities.js', [_modules['Core/Defaults.js'], _modules['Core/Utilities.js']], function (D, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var defaultOptions = D.defaultOptions,\n defaultTime = D.defaultTime;\n var getNestedProperty = U.getNestedProperty,\n isNumber = U.isNumber,\n pick = U.pick,\n pInt = U.pInt;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Formats a JavaScript date timestamp (milliseconds since Jan 1st 1970) into a\n * human readable date string. The format is a subset of the formats for PHP's\n * [strftime](https://www.php.net/manual/en/function.strftime.php) function.\n * Additional formats can be given in the {@link Highcharts.dateFormats} hook.\n *\n * Since v6.0.5, all internal dates are formatted through the\n * {@link Highcharts.Chart#time} instance to respect chart-level time settings.\n * The `Highcharts.dateFormat` function only reflects global time settings set\n * with `setOptions`.\n *\n * Supported format keys:\n * - `%a`: Short weekday, like 'Mon'\n * - `%A`: Long weekday, like 'Monday'\n * - `%d`: Two digit day of the month, 01 to 31\n * - `%e`: Day of the month, 1 through 31\n * - `%w`: Day of the week, 0 through 6\n * - `%b`: Short month, like 'Jan'\n * - `%B`: Long month, like 'January'\n * - `%m`: Two digit month number, 01 through 12\n * - `%y`: Two digits year, like 09 for 2009\n * - `%Y`: Four digits year, like 2009\n * - `%H`: Two digits hours in 24h format, 00 through 23\n * - `%k`: Hours in 24h format, 0 through 23\n * - `%I`: Two digits hours in 12h format, 00 through 11\n * - `%l`: Hours in 12h format, 1 through 12\n * - `%M`: Two digits minutes, 00 through 59\n * - `%p`: Upper case AM or PM\n * - `%P`: Lower case AM or PM\n * - `%S`: Two digits seconds, 00 through 59\n * - `%L`: Milliseconds (naming from Ruby)\n *\n * @function Highcharts.dateFormat\n *\n * @param {string} format\n * The desired format where various time representations are prefixed\n * with `%`.\n *\n * @param {number} timestamp\n * The JavaScript timestamp.\n *\n * @param {boolean} [capitalize=false]\n * Upper case first letter in the return.\n *\n * @return {string}\n * The formatted date.\n */\n function dateFormat(format, timestamp, capitalize) {\n return defaultTime.dateFormat(format, timestamp, capitalize);\n }\n /**\n * Format a string according to a subset of the rules of Python's String.format\n * method.\n *\n * @example\n * let s = Highcharts.format(\n * 'The {color} fox was {len:.2f} feet long',\n * { color: 'red', len: Math.PI }\n * );\n * // => The red fox was 3.14 feet long\n *\n * @function Highcharts.format\n *\n * @param {string} str\n * The string to format.\n *\n * @param {Record} ctx\n * The context, a collection of key-value pairs where each key is\n * replaced by its value.\n *\n * @param {Highcharts.Chart} [chart]\n * A `Chart` instance used to get numberFormatter and time.\n *\n * @return {string}\n * The formatted string.\n */\n function format(str, ctx, chart) {\n var splitter = '{',\n isInside = false,\n segment,\n valueAndFormat,\n val,\n index;\n var floatRegex = /f$/;\n var decRegex = /\\.([0-9])/;\n var lang = defaultOptions.lang;\n var time = chart && chart.time || defaultTime;\n var numberFormatter = chart && chart.numberFormatter || numberFormat;\n var ret = [];\n while (str) {\n index = str.indexOf(splitter);\n if (index === -1) {\n break;\n }\n segment = str.slice(0, index);\n if (isInside) { // we're on the closing bracket looking back\n valueAndFormat = segment.split(':');\n val = getNestedProperty(valueAndFormat.shift() || '', ctx);\n // Format the replacement\n if (valueAndFormat.length && typeof val === 'number') {\n segment = valueAndFormat.join(':');\n if (floatRegex.test(segment)) { // float\n var decimals = parseInt((segment.match(decRegex) || ['', '-1'])[1], 10);\n if (val !== null) {\n val = numberFormatter(val, decimals, lang.decimalPoint, segment.indexOf(',') > -1 ? lang.thousandsSep : '');\n }\n }\n else {\n val = time.dateFormat(segment, val);\n }\n }\n // Push the result and advance the cursor\n ret.push(val);\n }\n else {\n ret.push(segment);\n }\n str = str.slice(index + 1); // the rest\n isInside = !isInside; // toggle\n splitter = isInside ? '}' : '{'; // now look for next matching bracket\n }\n ret.push(str);\n return ret.join('');\n }\n /**\n * Format a number and return a string based on input settings.\n *\n * @sample highcharts/members/highcharts-numberformat/\n * Custom number format\n *\n * @function Highcharts.numberFormat\n *\n * @param {number} number\n * The input number to format.\n *\n * @param {number} decimals\n * The amount of decimals. A value of -1 preserves the amount in the\n * input number.\n *\n * @param {string} [decimalPoint]\n * The decimal point, defaults to the one given in the lang options, or\n * a dot.\n *\n * @param {string} [thousandsSep]\n * The thousands separator, defaults to the one given in the lang\n * options, or a space character.\n *\n * @return {string}\n * The formatted number.\n */\n function numberFormat(number, decimals, decimalPoint, thousandsSep) {\n number = +number || 0;\n decimals = +decimals;\n var ret,\n fractionDigits;\n var lang = defaultOptions.lang, origDec = (number.toString().split('.')[1] || '').split('e')[0].length, exponent = number.toString().split('e'), firstDecimals = decimals;\n if (decimals === -1) {\n // Preserve decimals. Not huge numbers (#3793).\n decimals = Math.min(origDec, 20);\n }\n else if (!isNumber(decimals)) {\n decimals = 2;\n }\n else if (decimals && exponent[1] && exponent[1] < 0) {\n // Expose decimals from exponential notation (#7042)\n fractionDigits = decimals + +exponent[1];\n if (fractionDigits >= 0) {\n // remove too small part of the number while keeping the notation\n exponent[0] = (+exponent[0]).toExponential(fractionDigits)\n .split('e')[0];\n decimals = fractionDigits;\n }\n else {\n // fractionDigits < 0\n exponent[0] = exponent[0].split('.')[0] || 0;\n if (decimals < 20) {\n // use number instead of exponential notation (#7405)\n number = (exponent[0] * Math.pow(10, exponent[1]))\n .toFixed(decimals);\n }\n else {\n // or zero\n number = 0;\n }\n exponent[1] = 0;\n }\n }\n // Add another decimal to avoid rounding errors of float numbers. (#4573)\n // Then use toFixed to handle rounding.\n var roundedNumber = (Math.abs(exponent[1] ? exponent[0] : number) +\n Math.pow(10, -Math.max(decimals,\n origDec) - 1)).toFixed(decimals);\n // A string containing the positive integer component of the number\n var strinteger = String(pInt(roundedNumber));\n // Leftover after grouping into thousands. Can be 0, 1 or 2.\n var thousands = strinteger.length > 3 ? strinteger.length % 3 : 0;\n // Language\n decimalPoint = pick(decimalPoint, lang.decimalPoint);\n thousandsSep = pick(thousandsSep, lang.thousandsSep);\n // Start building the return\n ret = number < 0 ? '-' : '';\n // Add the leftover after grouping into thousands. For example, in the\n // number 42 000 000, this line adds 42.\n ret += thousands ? strinteger.substr(0, thousands) + thousandsSep : '';\n if (+exponent[1] < 0 && !firstDecimals) {\n ret = '0';\n }\n else {\n // Add the remaining thousands groups, joined by the thousands separator\n ret += strinteger\n .substr(thousands)\n .replace(/(\\d{3})(?=\\d)/g, '$1' + thousandsSep);\n }\n // Add the decimal point and the decimal component\n if (decimals) {\n // Get the decimal component\n ret += decimalPoint + roundedNumber.slice(-decimals);\n }\n if (exponent[1] && +ret !== 0) {\n ret += 'e' + exponent[1];\n }\n return ret;\n }\n /* *\n *\n * Default Export\n *\n * */\n var FormatUtilities = {\n dateFormat: dateFormat,\n format: format,\n numberFormat: numberFormat\n };\n\n return FormatUtilities;\n });\n _registerModule(_modules, 'Core/Renderer/RendererUtilities.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Imports\n *\n * */\n var clamp = U.clamp,\n pick = U.pick,\n stableSort = U.stableSort;\n /* *\n *\n * Namespace\n *\n * */\n var RendererUtilities;\n (function (RendererUtilities) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * General distribution algorithm for distributing labels of differing size\n * along a confined length in two dimensions. The algorithm takes an array\n * of objects containing a size, a target and a rank. It will place the\n * labels as close as possible to their targets, skipping the lowest ranked\n * labels if necessary.\n * @private\n */\n function distribute(boxes, len, maxDistance) {\n // Original array will be altered with added .pos\n var origBoxes = boxes,\n reducedLen = origBoxes.reducedLen || len,\n sortByRank = function (a,\n b) {\n return (b.rank || 0) - (a.rank || 0);\n }, sortByTarget = function (a, b) {\n return a.target - b.target;\n };\n var i,\n overlapping = true,\n restBoxes = [], // The outranked overshoot\n box,\n target,\n total = 0;\n // If the total size exceeds the len, remove those boxes with the lowest\n // rank\n i = boxes.length;\n while (i--) {\n total += boxes[i].size;\n }\n // Sort by rank, then slice away overshoot\n if (total > reducedLen) {\n stableSort(boxes, sortByRank);\n i = 0;\n total = 0;\n while (total <= reducedLen) {\n total += boxes[i].size;\n i++;\n }\n restBoxes = boxes.splice(i - 1, boxes.length);\n }\n // Order by target\n stableSort(boxes, sortByTarget);\n // So far we have been mutating the original array. Now\n // create a copy with target arrays\n boxes = boxes.map(function (box) { return ({\n size: box.size,\n targets: [box.target],\n align: pick(box.align, 0.5)\n }); });\n while (overlapping) {\n // Initial positions: target centered in box\n i = boxes.length;\n while (i--) {\n box = boxes[i];\n // Composite box, average of targets\n target = (Math.min.apply(0, box.targets) +\n Math.max.apply(0, box.targets)) / 2;\n box.pos = clamp(target - box.size * box.align, 0, len - box.size);\n }\n // Detect overlap and join boxes\n i = boxes.length;\n overlapping = false;\n while (i--) {\n // Overlap\n if (i > 0 &&\n boxes[i - 1].pos + boxes[i - 1].size >\n boxes[i].pos) {\n // Add this size to the previous box\n boxes[i - 1].size += boxes[i].size;\n boxes[i - 1].targets = boxes[i - 1]\n .targets\n .concat(boxes[i].targets);\n boxes[i - 1].align = 0.5;\n // Overlapping right, push left\n if (boxes[i - 1].pos + boxes[i - 1].size > len) {\n boxes[i - 1].pos = len - boxes[i - 1].size;\n }\n boxes.splice(i, 1); // Remove this item\n overlapping = true;\n }\n }\n }\n // Add the rest (hidden boxes)\n origBoxes.push.apply(origBoxes, restBoxes);\n // Now the composite boxes are placed, we need to put the original boxes\n // within them\n i = 0;\n boxes.some(function (box) {\n var posInCompositeBox = 0;\n // Exceeded maxDistance => abort\n return (box.targets || []).some(function () {\n origBoxes[i].pos = box.pos + posInCompositeBox;\n // If the distance between the position and the target exceeds\n // maxDistance, abort the loop and decrease the length in\n // increments of 10% to recursively reduce the number of\n // visible boxes by rank. Once all boxes are within the\n // maxDistance, we're good.\n if (typeof maxDistance !== 'undefined' &&\n Math.abs(origBoxes[i].pos - origBoxes[i].target) > maxDistance) {\n // Reset the positions that are already set\n origBoxes\n .slice(0, i + 1)\n .forEach(function (box) { return delete box.pos; });\n // Try with a smaller length\n origBoxes.reducedLen =\n (origBoxes.reducedLen || len) - (len * 0.1);\n // Recurse\n if (origBoxes.reducedLen > len * 0.1) {\n distribute(origBoxes, len, maxDistance);\n }\n // Exceeded maxDistance => abort\n return true;\n }\n posInCompositeBox += origBoxes[i].size;\n i++;\n return false;\n });\n });\n // Add the rest (hidden) boxes and sort by target\n stableSort(origBoxes, sortByTarget);\n return origBoxes;\n }\n RendererUtilities.distribute = distribute;\n })(RendererUtilities || (RendererUtilities = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return RendererUtilities;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/SVGElement.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (A, Color, H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var animate = A.animate,\n animObject = A.animObject,\n stop = A.stop;\n var deg2rad = H.deg2rad,\n doc = H.doc,\n noop = H.noop,\n svg = H.svg,\n SVG_NS = H.SVG_NS,\n win = H.win;\n var addEvent = U.addEvent,\n attr = U.attr,\n createElement = U.createElement,\n css = U.css,\n defined = U.defined,\n erase = U.erase,\n extend = U.extend,\n fireEvent = U.fireEvent,\n isArray = U.isArray,\n isFunction = U.isFunction,\n isNumber = U.isNumber,\n isString = U.isString,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick,\n pInt = U.pInt,\n removeEvent = U.removeEvent,\n syncTimeout = U.syncTimeout,\n uniqueKey = U.uniqueKey;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The SVGElement prototype is a JavaScript wrapper for SVG elements used in the\n * rendering layer of Highcharts. Combined with the\n * {@link Highcharts.SVGRenderer}\n * object, these prototypes allow freeform annotation in the charts or even in\n * HTML pages without instanciating a chart. The SVGElement can also wrap HTML\n * labels, when `text` or `label` elements are created with the `useHTML`\n * parameter.\n *\n * The SVGElement instances are created through factory functions on the\n * {@link Highcharts.SVGRenderer}\n * object, like\n * {@link Highcharts.SVGRenderer#rect|rect},\n * {@link Highcharts.SVGRenderer#path|path},\n * {@link Highcharts.SVGRenderer#text|text},\n * {@link Highcharts.SVGRenderer#label|label},\n * {@link Highcharts.SVGRenderer#g|g}\n * and more.\n *\n * @class\n * @name Highcharts.SVGElement\n */\n var SVGElement = /** @class */ (function () {\n function SVGElement() {\n /* *\n *\n * Properties\n *\n * */\n this.element = void 0;\n this.onEvents = {};\n this.opacity = 1; // Default base for animation\n this.renderer = void 0;\n this.SVG_NS = SVG_NS;\n // Custom attributes used for symbols, these should be filtered out when\n // setting SVGElement attributes (#9375).\n this.symbolCustomAttribs = [\n 'x',\n 'y',\n 'width',\n 'height',\n 'r',\n 'start',\n 'end',\n 'innerR',\n 'anchorX',\n 'anchorY',\n 'rounded'\n ];\n }\n // @todo public zIndex?: number;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get the current value of an attribute or pseudo attribute,\n * used mainly for animation. Called internally from\n * the {@link Highcharts.SVGRenderer#attr} function.\n *\n * @private\n * @function Highcharts.SVGElement#_defaultGetter\n *\n * @param {string} key\n * Property key.\n *\n * @return {number|string}\n * Property value.\n */\n SVGElement.prototype._defaultGetter = function (key) {\n var ret = pick(this[key + 'Value'], // align getter\n this[key],\n this.element ? this.element.getAttribute(key) : null, 0);\n if (/^[\\-0-9\\.]+$/.test(ret)) { // is numerical\n ret = parseFloat(ret);\n }\n return ret;\n };\n /**\n * @private\n * @function Highcharts.SVGElement#_defaultSetter\n *\n * @param {string} value\n *\n * @param {string} key\n *\n * @param {Highcharts.SVGDOMElement} element\n *\n */\n SVGElement.prototype._defaultSetter = function (value, key, element) {\n element.setAttribute(key, value);\n };\n /**\n * Add the element to the DOM. All elements must be added this way.\n *\n * @sample highcharts/members/renderer-g\n * Elements added to a group\n *\n * @function Highcharts.SVGElement#add\n *\n * @param {Highcharts.SVGElement} [parent]\n * The parent item to add it to. If undefined, the element is added\n * to the {@link Highcharts.SVGRenderer.box}.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n SVGElement.prototype.add = function (parent) {\n var renderer = this.renderer,\n element = this.element;\n var inserted;\n if (parent) {\n this.parentGroup = parent;\n }\n // Mark as inverted\n this.parentInverted = parent && parent.inverted;\n // Build formatted text\n if (typeof this.textStr !== 'undefined' &&\n this.element.nodeName === 'text' // Not for SVGLabel instances\n ) {\n renderer.buildText(this);\n }\n // Mark as added\n this.added = true;\n // If we're adding to renderer root, or other elements in the group\n // have a z index, we need to handle it\n if (!parent || parent.handleZ || this.zIndex) {\n inserted = this.zIndexSetter();\n }\n // If zIndex is not handled, append at the end\n if (!inserted) {\n (parent ?\n parent.element :\n renderer.box).appendChild(element);\n }\n // fire an event for internal hooks\n if (this.onAdd) {\n this.onAdd();\n }\n return this;\n };\n /**\n * Add a class name to an element.\n *\n * @function Highcharts.SVGElement#addClass\n *\n * @param {string} className\n * The new class name to add.\n *\n * @param {boolean} [replace=false]\n * When true, the existing class name(s) will be overwritten with the new\n * one. When false, the new one is added.\n *\n * @return {Highcharts.SVGElement}\n * Return the SVG element for chainability.\n */\n SVGElement.prototype.addClass = function (className, replace) {\n var currentClassName = replace ? '' : (this.attr('class') || '');\n // Trim the string and remove duplicates\n className = (className || '')\n .split(/ /g)\n .reduce(function (newClassName, name) {\n if (currentClassName.indexOf(name) === -1) {\n newClassName.push(name);\n }\n return newClassName;\n }, (currentClassName ?\n [currentClassName] :\n []))\n .join(' ');\n if (className !== currentClassName) {\n this.attr('class', className);\n }\n return this;\n };\n /**\n * This method is executed in the end of `attr()`, after setting all\n * attributes in the hash. In can be used to efficiently consolidate\n * multiple attributes in one SVG property -- e.g., translate, rotate and\n * scale are merged in one \"transform\" attribute in the SVG node.\n *\n * @private\n * @function Highcharts.SVGElement#afterSetters\n */\n SVGElement.prototype.afterSetters = function () {\n // Update transform. Do this outside the loop to prevent redundant\n // updating for batch setting of attributes.\n if (this.doTransform) {\n this.updateTransform();\n this.doTransform = false;\n }\n };\n /**\n * Align the element relative to the chart or another box.\n *\n * @function Highcharts.SVGElement#align\n *\n * @param {Highcharts.AlignObject} [alignOptions]\n * The alignment options. The function can be called without this\n * parameter in order to re-align an element after the box has been\n * updated.\n *\n * @param {boolean} [alignByTranslate]\n * Align element by translation.\n *\n * @param {string|Highcharts.BBoxObject} [box]\n * The box to align to, needs a width and height. When the box is a\n * string, it refers to an object in the Renderer. For example, when\n * box is `spacingBox`, it refers to `Renderer.spacingBox` which\n * holds `width`, `height`, `x` and `y` properties.\n *\n * @return {Highcharts.SVGElement} Returns the SVGElement for chaining.\n */\n SVGElement.prototype.align = function (alignOptions, alignByTranslate, box) {\n var attribs = {},\n renderer = this.renderer,\n alignedObjects = renderer.alignedObjects;\n var x,\n y,\n alignTo,\n alignFactor,\n vAlignFactor;\n // First call on instanciate\n if (alignOptions) {\n this.alignOptions = alignOptions;\n this.alignByTranslate = alignByTranslate;\n if (!box || isString(box)) {\n this.alignTo = alignTo = box || 'renderer';\n // prevent duplicates, like legendGroup after resize\n erase(alignedObjects, this);\n alignedObjects.push(this);\n box = void 0; // reassign it below\n }\n // When called on resize, no arguments are supplied\n }\n else {\n alignOptions = this.alignOptions;\n alignByTranslate = this.alignByTranslate;\n alignTo = this.alignTo;\n }\n box = pick(box, renderer[alignTo], alignTo === 'scrollablePlotBox' ?\n renderer.plotBox : void 0, renderer);\n // Assign variables\n var align = alignOptions.align,\n vAlign = alignOptions.verticalAlign;\n // default: left align\n x = (box.x || 0) + (alignOptions.x || 0);\n // default: top align\n y = (box.y || 0) + (alignOptions.y || 0);\n // Align\n if (align === 'right') {\n alignFactor = 1;\n }\n else if (align === 'center') {\n alignFactor = 2;\n }\n if (alignFactor) {\n x += (box.width - (alignOptions.width || 0)) /\n alignFactor;\n }\n attribs[alignByTranslate ? 'translateX' : 'x'] = Math.round(x);\n // Vertical align\n if (vAlign === 'bottom') {\n vAlignFactor = 1;\n }\n else if (vAlign === 'middle') {\n vAlignFactor = 2;\n }\n if (vAlignFactor) {\n y += (box.height - (alignOptions.height || 0)) /\n vAlignFactor;\n }\n attribs[alignByTranslate ? 'translateY' : 'y'] = Math.round(y);\n // Animate only if already placed\n this[this.placed ? 'animate' : 'attr'](attribs);\n this.placed = true;\n this.alignAttr = attribs;\n return this;\n };\n /**\n * @private\n * @function Highcharts.SVGElement#alignSetter\n * @param {\"left\"|\"center\"|\"right\"} value\n */\n SVGElement.prototype.alignSetter = function (value) {\n var convert = {\n left: 'start',\n center: 'middle',\n right: 'end'\n };\n if (convert[value]) {\n this.alignValue = value;\n this.element.setAttribute('text-anchor', convert[value]);\n }\n };\n /**\n * Animate to given attributes or CSS properties.\n *\n * @sample highcharts/members/element-on/\n * Setting some attributes by animation\n *\n * @function Highcharts.SVGElement#animate\n *\n * @param {Highcharts.SVGAttributes} params\n * SVG attributes or CSS to animate.\n *\n * @param {boolean|Partial} [options]\n * Animation options.\n *\n * @param {Function} [complete]\n * Function to perform at the end of animation.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n SVGElement.prototype.animate = function (params, options, complete) {\n var _this = this;\n var animOptions = animObject(pick(options,\n this.renderer.globalAnimation,\n true)),\n deferTime = animOptions.defer;\n // When the page is hidden save resources in the background by not\n // running animation at all (#9749).\n if (pick(doc.hidden, doc.msHidden, doc.webkitHidden, false)) {\n animOptions.duration = 0;\n }\n if (animOptions.duration !== 0) {\n // allows using a callback with the global animation without\n // overwriting it\n if (complete) {\n animOptions.complete = complete;\n }\n // If defer option is defined delay the animation #12901\n syncTimeout(function () {\n if (_this.element) {\n animate(_this, params, animOptions);\n }\n }, deferTime);\n }\n else {\n this.attr(params, void 0, complete || animOptions.complete);\n // Call the end step synchronously\n objectEach(params, function (val, prop) {\n if (animOptions.step) {\n animOptions.step.call(this, val, { prop: prop, pos: 1, elem: this });\n }\n }, this);\n }\n return this;\n };\n /**\n * Apply a text outline through a custom CSS property, by copying the text\n * element and apply stroke to the copy. Used internally. Contrast checks at\n * [example](https://jsfiddle.net/highcharts/43soe9m1/2/).\n *\n * @example\n * // Specific color\n * text.css({\n * textOutline: '1px black'\n * });\n * // Automatic contrast\n * text.css({\n * color: '#000000', // black text\n * textOutline: '1px contrast' // => white outline\n * });\n *\n * @private\n * @function Highcharts.SVGElement#applyTextOutline\n *\n * @param {string} textOutline\n * A custom CSS `text-outline` setting, defined by `width color`.\n */\n SVGElement.prototype.applyTextOutline = function (textOutline) {\n var elem = this.element,\n hasContrast = textOutline.indexOf('contrast') !== -1,\n styles = {};\n // When the text shadow is set to contrast, use dark stroke for light\n // text and vice versa.\n if (hasContrast) {\n styles.textOutline = textOutline = textOutline.replace(/contrast/g, this.renderer.getContrast(elem.style.fill));\n }\n // Extract the stroke width and color\n var parts = textOutline.split(' ');\n var color = parts[parts.length - 1];\n var strokeWidth = parts[0];\n if (strokeWidth && strokeWidth !== 'none' && H.svg) {\n this.fakeTS = true; // Fake text shadow\n // Since the stroke is applied on center of the actual outline, we\n // need to double it to get the correct stroke-width outside the\n // glyphs.\n strokeWidth = strokeWidth.replace(/(^[\\d\\.]+)(.*?)$/g, function (match, digit, unit) {\n return (2 * Number(digit)) + unit;\n });\n // Remove shadows from previous runs.\n this.removeTextOutline();\n var outline_1 = doc.createElementNS(SVG_NS, 'tspan');\n attr(outline_1, {\n 'class': 'highcharts-text-outline',\n fill: color,\n stroke: color,\n 'stroke-width': strokeWidth,\n 'stroke-linejoin': 'round'\n });\n // For each of the tspans and text nodes, create a copy in the\n // outline.\n var parentElem = elem.querySelector('textPath') || elem;\n [].forEach.call(parentElem.childNodes, function (childNode) {\n var clone = childNode.cloneNode(true);\n if (clone.removeAttribute) {\n ['fill', 'stroke', 'stroke-width', 'stroke'].forEach(function (prop) { return clone\n .removeAttribute(prop); });\n }\n outline_1.appendChild(clone);\n });\n // Collect the sum of dy from all children, included nested ones\n var totalHeight_1 = 0;\n [].forEach.call(parentElem.querySelectorAll('text tspan'), function (element) {\n totalHeight_1 += Number(element.getAttribute('dy'));\n });\n // Insert an absolutely positioned break before the original text\n // to keep it in place\n var br = doc.createElementNS(SVG_NS, 'tspan');\n br.textContent = '\\u200B';\n // Reset the position for the following text\n attr(br, {\n x: Number(elem.getAttribute('x')),\n dy: -totalHeight_1\n });\n // Insert the outline\n outline_1.appendChild(br);\n parentElem.insertBefore(outline_1, parentElem.firstChild);\n }\n };\n /**\n * @function Highcharts.SVGElement#attr\n * @param {string} key\n * @return {number|string}\n */ /**\n * Apply native and custom attributes to the SVG elements.\n *\n * In order to set the rotation center for rotation, set x and y to 0 and\n * use `translateX` and `translateY` attributes to position the element\n * instead.\n *\n * Attributes frequently used in Highcharts are `fill`, `stroke`,\n * `stroke-width`.\n *\n * @sample highcharts/members/renderer-rect/\n * Setting some attributes\n *\n * @example\n * // Set multiple attributes\n * element.attr({\n * stroke: 'red',\n * fill: 'blue',\n * x: 10,\n * y: 10\n * });\n *\n * // Set a single attribute\n * element.attr('stroke', 'red');\n *\n * // Get an attribute\n * element.attr('stroke'); // => 'red'\n *\n * @function Highcharts.SVGElement#attr\n *\n * @param {string|Highcharts.SVGAttributes} [hash]\n * The native and custom SVG attributes.\n *\n * @param {number|string|Highcharts.SVGPathArray} [val]\n * If the type of the first argument is `string`, the second can be a\n * value, which will serve as a single attribute setter. If the first\n * argument is a string and the second is undefined, the function\n * serves as a getter and the current value of the property is\n * returned.\n *\n * @param {Function} [complete]\n * A callback function to execute after setting the attributes. This\n * makes the function compliant and interchangeable with the\n * {@link SVGElement#animate} function.\n *\n * @param {boolean} [continueAnimation=true]\n * Used internally when `.attr` is called as part of an animation\n * step. Otherwise, calling `.attr` for an attribute will stop\n * animation for that attribute.\n *\n * @return {Highcharts.SVGElement}\n * If used as a setter, it returns the current\n * {@link Highcharts.SVGElement} so the calls can be chained. If\n * used as a getter, the current value of the attribute is returned.\n */\n SVGElement.prototype.attr = function (hash, val, complete, continueAnimation) {\n var element = this.element,\n symbolCustomAttribs = this.symbolCustomAttribs;\n var key,\n hasSetSymbolSize,\n ret = this,\n skipAttr,\n setter;\n // single key-value pair\n if (typeof hash === 'string' && typeof val !== 'undefined') {\n key = hash;\n hash = {};\n hash[key] = val;\n }\n // used as a getter: first argument is a string, second is undefined\n if (typeof hash === 'string') {\n ret = (this[hash + 'Getter'] ||\n this._defaultGetter).call(this, hash, element);\n // setter\n }\n else {\n objectEach(hash, function eachAttribute(val, key) {\n skipAttr = false;\n // Unless .attr is from the animator update, stop current\n // running animation of this property\n if (!continueAnimation) {\n stop(this, key);\n }\n // Special handling of symbol attributes\n if (this.symbolName &&\n symbolCustomAttribs.indexOf(key) !== -1) {\n if (!hasSetSymbolSize) {\n this.symbolAttr(hash);\n hasSetSymbolSize = true;\n }\n skipAttr = true;\n }\n if (this.rotation && (key === 'x' || key === 'y')) {\n this.doTransform = true;\n }\n if (!skipAttr) {\n setter = (this[key + 'Setter'] ||\n this._defaultSetter);\n setter.call(this, val, key, element);\n // Let the shadow follow the main element\n if (!this.styledMode &&\n this.shadows &&\n /^(width|height|visibility|x|y|d|transform|cx|cy|r)$/\n .test(key)) {\n this.updateShadows(key, val, setter);\n }\n }\n }, this);\n this.afterSetters();\n }\n // In accordance with animate, run a complete callback\n if (complete) {\n complete.call(this);\n }\n return ret;\n };\n /**\n * Apply a clipping rectangle to this element.\n *\n * @function Highcharts.SVGElement#clip\n *\n * @param {Highcharts.ClipRectElement} [clipRect]\n * The clipping rectangle. If skipped, the current clip is removed.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVG element to allow chaining.\n */\n SVGElement.prototype.clip = function (clipRect) {\n return this.attr('clip-path', clipRect ?\n 'url(' + this.renderer.url + '#' + clipRect.id + ')' :\n 'none');\n };\n /**\n * Calculate the coordinates needed for drawing a rectangle crisply and\n * return the calculated attributes.\n *\n * @function Highcharts.SVGElement#crisp\n *\n * @param {Highcharts.RectangleObject} rect\n * Rectangle to crisp.\n *\n * @param {number} [strokeWidth]\n * The stroke width to consider when computing crisp positioning. It can\n * also be set directly on the rect parameter.\n *\n * @return {Highcharts.RectangleObject}\n * The modified rectangle arguments.\n */\n SVGElement.prototype.crisp = function (rect, strokeWidth) {\n var wrapper = this;\n strokeWidth = strokeWidth || rect.strokeWidth || 0;\n // Math.round because strokeWidth can sometimes have roundoff errors\n var normalizer = Math.round(strokeWidth) % 2 / 2;\n // normalize for crisp edges\n rect.x = Math.floor(rect.x || wrapper.x || 0) + normalizer;\n rect.y = Math.floor(rect.y || wrapper.y || 0) + normalizer;\n rect.width = Math.floor((rect.width || wrapper.width || 0) - 2 * normalizer);\n rect.height = Math.floor((rect.height || wrapper.height || 0) - 2 * normalizer);\n if (defined(rect.strokeWidth)) {\n rect.strokeWidth = strokeWidth;\n }\n return rect;\n };\n /**\n * Build and apply an SVG gradient out of a common JavaScript configuration\n * object. This function is called from the attribute setters. An event\n * hook is added for supporting other complex color types.\n *\n * @private\n * @function Highcharts.SVGElement#complexColor\n *\n * @param {Highcharts.GradientColorObject|Highcharts.PatternObject} colorOptions\n * The gradient or pattern options structure.\n *\n * @param {string} prop\n * The property to apply, can either be `fill` or `stroke`.\n *\n * @param {Highcharts.SVGDOMElement} elem\n * SVG element to apply the gradient on.\n */\n SVGElement.prototype.complexColor = function (colorOptions, prop, elem) {\n var renderer = this.renderer;\n var colorObject,\n gradName,\n gradAttr,\n radAttr,\n gradients,\n stops,\n stopColor,\n stopOpacity,\n radialReference,\n id,\n key = [],\n value;\n fireEvent(this.renderer, 'complexColor', {\n args: arguments\n }, function () {\n // Apply linear or radial gradients\n if (colorOptions.radialGradient) {\n gradName = 'radialGradient';\n }\n else if (colorOptions.linearGradient) {\n gradName = 'linearGradient';\n }\n if (gradName) {\n gradAttr = colorOptions[gradName];\n gradients = renderer.gradients;\n stops = colorOptions.stops;\n radialReference = elem.radialReference;\n // Keep < 2.2 kompatibility\n if (isArray(gradAttr)) {\n colorOptions[gradName] = gradAttr = {\n x1: gradAttr[0],\n y1: gradAttr[1],\n x2: gradAttr[2],\n y2: gradAttr[3],\n gradientUnits: 'userSpaceOnUse'\n };\n }\n // Correct the radial gradient for the radial reference system\n if (gradName === 'radialGradient' &&\n radialReference &&\n !defined(gradAttr.gradientUnits)) {\n // Save the radial attributes for updating\n radAttr = gradAttr;\n gradAttr = merge(gradAttr, renderer.getRadialAttr(radialReference, radAttr), { gradientUnits: 'userSpaceOnUse' });\n }\n // Build the unique key to detect whether we need to create a\n // new element (#1282)\n objectEach(gradAttr, function (value, n) {\n if (n !== 'id') {\n key.push(n, value);\n }\n });\n objectEach(stops, function (val) {\n key.push(val);\n });\n key = key.join(',');\n // Check if a gradient object with the same config object is\n // created within this renderer\n if (gradients[key]) {\n id = gradients[key].attr('id');\n }\n else {\n // Set the id and create the element\n gradAttr.id = id = uniqueKey();\n var gradientObject_1 = gradients[key] =\n renderer.createElement(gradName)\n .attr(gradAttr)\n .add(renderer.defs);\n gradientObject_1.radAttr = radAttr;\n // The gradient needs to keep a list of stops to be able to\n // destroy them\n gradientObject_1.stops = [];\n stops.forEach(function (stop) {\n if (stop[1].indexOf('rgba') === 0) {\n colorObject = Color.parse(stop[1]);\n stopColor = colorObject.get('rgb');\n stopOpacity = colorObject.get('a');\n }\n else {\n stopColor = stop[1];\n stopOpacity = 1;\n }\n var stopObject = renderer.createElement('stop').attr({\n offset: stop[0],\n 'stop-color': stopColor,\n 'stop-opacity': stopOpacity\n }).add(gradientObject_1);\n // Add the stop element to the gradient\n gradientObject_1.stops.push(stopObject);\n });\n }\n // Set the reference to the gradient object\n value = 'url(' + renderer.url + '#' + id + ')';\n elem.setAttribute(prop, value);\n elem.gradient = key;\n // Allow the color to be concatenated into tooltips formatters\n // etc. (#2995)\n colorOptions.toString = function () {\n return value;\n };\n }\n });\n };\n /**\n * Set styles for the element. In addition to CSS styles supported by\n * native SVG and HTML elements, there are also some custom made for\n * Highcharts, like `width`, `ellipsis` and `textOverflow` for SVG text\n * elements.\n *\n * @sample highcharts/members/renderer-text-on-chart/\n * Styled text\n *\n * @function Highcharts.SVGElement#css\n *\n * @param {Highcharts.CSSObject} styles\n * The new CSS styles.\n *\n * @return {Highcharts.SVGElement}\n * Return the SVG element for chaining.\n */\n SVGElement.prototype.css = function (styles) {\n var oldStyles = this.styles,\n newStyles = {},\n elem = this.element;\n var textWidth,\n hasNew = !oldStyles;\n // convert legacy\n if (styles.color) {\n styles.fill = styles.color;\n }\n // Filter out existing styles to increase performance (#2640)\n if (oldStyles) {\n objectEach(styles, function (value, n) {\n if (oldStyles && oldStyles[n] !== value) {\n newStyles[n] = value;\n hasNew = true;\n }\n });\n }\n if (hasNew) {\n // Merge the new styles with the old ones\n if (oldStyles) {\n styles = extend(oldStyles, newStyles);\n }\n // Get the text width from style\n // Previously set, unset it (#8234)\n if (styles.width === null || styles.width === 'auto') {\n delete this.textWidth;\n // Apply new\n }\n else if (elem.nodeName.toLowerCase() === 'text' &&\n styles.width) {\n textWidth = this.textWidth = pInt(styles.width);\n }\n // store object\n this.styles = styles;\n if (textWidth && (!svg && this.renderer.forExport)) {\n delete styles.width;\n }\n var stylesToApply_1 = merge(styles);\n if (elem.namespaceURI === this.SVG_NS) {\n // These CSS properties are interpreted internally by the SVG\n // renderer, but are not supported by SVG and should not be\n // added to the DOM. In styled mode, no CSS should find its way\n // to the DOM whatsoever (#6173, #6474).\n ['textOutline', 'textOverflow', 'width'].forEach(function (key) { return (stylesToApply_1 &&\n delete stylesToApply_1[key]); });\n }\n css(elem, stylesToApply_1);\n if (this.added) {\n // Rebuild text after added. Cache mechanisms in the buildText\n // will prevent building if there are no significant changes.\n if (this.element.nodeName === 'text') {\n this.renderer.buildText(this);\n }\n // Apply text outline after added\n if (styles.textOutline) {\n this.applyTextOutline(styles.textOutline);\n }\n }\n }\n return this;\n };\n /**\n * @private\n * @function Highcharts.SVGElement#dashstyleSetter\n * @param {string} value\n */\n SVGElement.prototype.dashstyleSetter = function (value) {\n var i,\n strokeWidth = this['stroke-width'];\n // If \"inherit\", like maps in IE, assume 1 (#4981). With HC5 and the new\n // strokeWidth function, we should be able to use that instead.\n if (strokeWidth === 'inherit') {\n strokeWidth = 1;\n }\n value = value && value.toLowerCase();\n if (value) {\n var v = value\n .replace('shortdashdotdot', '3,1,1,1,1,1,')\n .replace('shortdashdot', '3,1,1,1')\n .replace('shortdot', '1,1,')\n .replace('shortdash', '3,1,')\n .replace('longdash', '8,3,')\n .replace(/dot/g, '1,3,')\n .replace('dash', '4,3,')\n .replace(/,$/, '')\n .split(','); // ending comma\n i = v.length;\n while (i--) {\n v[i] = '' + (pInt(v[i]) * pick(strokeWidth, NaN));\n }\n value = v.join(',').replace(/NaN/g, 'none'); // #3226\n this.element.setAttribute('stroke-dasharray', value);\n }\n };\n /**\n * Destroy the element and element wrapper and clear up the DOM and event\n * hooks.\n *\n * @function Highcharts.SVGElement#destroy\n */\n SVGElement.prototype.destroy = function () {\n var wrapper = this,\n element = wrapper.element || {},\n renderer = wrapper.renderer,\n ownerSVGElement = element.ownerSVGElement;\n var parentToClean = (renderer.isSVG &&\n element.nodeName === 'SPAN' &&\n wrapper.parentGroup ||\n void 0),\n grandParent,\n i;\n // remove events\n element.onclick = element.onmouseout = element.onmouseover =\n element.onmousemove = element.point = null;\n stop(wrapper); // stop running animations\n if (wrapper.clipPath && ownerSVGElement) {\n var clipPath_1 = wrapper.clipPath;\n // Look for existing references to this clipPath and remove them\n // before destroying the element (#6196).\n // The upper case version is for Edge\n [].forEach.call(ownerSVGElement.querySelectorAll('[clip-path],[CLIP-PATH]'), function (el) {\n if (el.getAttribute('clip-path').indexOf(clipPath_1.element.id) > -1) {\n el.removeAttribute('clip-path');\n }\n });\n wrapper.clipPath = clipPath_1.destroy();\n }\n // Destroy stops in case this is a gradient object @todo old code?\n if (wrapper.stops) {\n for (i = 0; i < wrapper.stops.length; i++) {\n wrapper.stops[i].destroy();\n }\n wrapper.stops.length = 0;\n wrapper.stops = void 0;\n }\n // remove element\n wrapper.safeRemoveChild(element);\n if (!renderer.styledMode) {\n wrapper.destroyShadows();\n }\n // In case of useHTML, clean up empty containers emulating SVG groups\n // (#1960, #2393, #2697).\n while (parentToClean &&\n parentToClean.div &&\n parentToClean.div.childNodes.length === 0) {\n grandParent = parentToClean.parentGroup;\n wrapper.safeRemoveChild(parentToClean.div);\n delete parentToClean.div;\n parentToClean = grandParent;\n }\n // remove from alignObjects\n if (wrapper.alignTo) {\n erase(renderer.alignedObjects, wrapper);\n }\n objectEach(wrapper, function (val, key) {\n // Destroy child elements of a group\n if (wrapper[key] &&\n wrapper[key].parentGroup === wrapper &&\n wrapper[key].destroy) {\n wrapper[key].destroy();\n }\n // Delete all properties\n delete wrapper[key];\n });\n return;\n };\n /**\n * Destroy shadows on the element.\n *\n * @private\n * @function Highcharts.SVGElement#destroyShadows\n *\n */\n SVGElement.prototype.destroyShadows = function () {\n (this.shadows || []).forEach(function (shadow) {\n this.safeRemoveChild(shadow);\n }, this);\n this.shadows = void 0;\n };\n /**\n * @private\n * @function Highcharts.SVGElement#dSettter\n * @param {number|string|Highcharts.SVGPathArray} value\n * @param {string} key\n * @param {Highcharts.SVGDOMElement} element\n */\n SVGElement.prototype.dSetter = function (value, key, element) {\n if (isArray(value)) {\n // Backwards compatibility, convert one-dimensional array into an\n // array of segments\n if (typeof value[0] === 'string') {\n value = this.renderer.pathToSegments(value);\n }\n this.pathArray = value;\n value = value.reduce(function (acc, seg, i) {\n if (!seg || !seg.join) {\n return (seg || '').toString();\n }\n return (i ? acc + ' ' : '') + seg.join(' ');\n }, '');\n }\n if (/(NaN| {2}|^$)/.test(value)) {\n value = 'M 0 0';\n }\n // Check for cache before resetting. Resetting causes disturbance in the\n // DOM, causing flickering in some cases in Edge/IE (#6747). Also\n // possible performance gain.\n if (this[key] !== value) {\n element.setAttribute(key, value);\n this[key] = value;\n }\n };\n /**\n * Fade out an element by animating its opacity down to 0, and hide it on\n * complete. Used internally for the tooltip.\n *\n * @function Highcharts.SVGElement#fadeOut\n *\n * @param {number} [duration=150]\n * The fade duration in milliseconds.\n */\n SVGElement.prototype.fadeOut = function (duration) {\n var elemWrapper = this;\n elemWrapper.animate({\n opacity: 0\n }, {\n duration: pick(duration, 150),\n complete: function () {\n // #3088, assuming we're only using this for tooltips\n elemWrapper.hide();\n }\n });\n };\n /**\n * @private\n * @function Highcharts.SVGElement#fillSetter\n * @param {Highcharts.ColorType} value\n * @param {string} key\n * @param {Highcharts.SVGDOMElement} element\n */\n SVGElement.prototype.fillSetter = function (value, key, element) {\n if (typeof value === 'string') {\n element.setAttribute(key, value);\n }\n else if (value) {\n this.complexColor(value, key, element);\n }\n };\n /**\n * Get the bounding box (width, height, x and y) for the element. Generally\n * used to get rendered text size. Since this is called a lot in charts,\n * the results are cached based on text properties, in order to save DOM\n * traffic. The returned bounding box includes the rotation, so for example\n * a single text line of rotation 90 will report a greater height, and a\n * width corresponding to the line-height.\n *\n * @sample highcharts/members/renderer-on-chart/\n * Draw a rectangle based on a text's bounding box\n *\n * @function Highcharts.SVGElement#getBBox\n *\n * @param {boolean} [reload]\n * Skip the cache and get the updated DOM bouding box.\n *\n * @param {number} [rot]\n * Override the element's rotation. This is internally used on axis\n * labels with a value of 0 to find out what the bounding box would\n * be have been if it were not rotated.\n *\n * @return {Highcharts.BBoxObject}\n * The bounding box with `x`, `y`, `width` and `height` properties.\n */\n SVGElement.prototype.getBBox = function (reload, rot) {\n var wrapper = this,\n alignValue = wrapper.alignValue,\n element = wrapper.element,\n renderer = wrapper.renderer,\n styles = wrapper.styles,\n textStr = wrapper.textStr,\n cache = renderer.cache,\n cacheKeys = renderer.cacheKeys,\n isSVG = element.namespaceURI === wrapper.SVG_NS,\n rotation = pick(rot,\n wrapper.rotation, 0),\n fontSize = renderer.styledMode ? (element &&\n SVGElement.prototype.getStyle.call(element, 'font-size')) : (styles && styles.fontSize);\n var bBox,\n width,\n height,\n toggleTextShadowShim,\n cacheKey;\n // Avoid undefined and null (#7316)\n if (defined(textStr)) {\n cacheKey = textStr.toString();\n // Since numbers are monospaced, and numerical labels appear a lot\n // in a chart, we assume that a label of n characters has the same\n // bounding box as others of the same length. Unless there is inner\n // HTML in the label. In that case, leave the numbers as is (#5899).\n if (cacheKey.indexOf('<') === -1) {\n cacheKey = cacheKey.replace(/[0-9]/g, '0');\n }\n // Properties that affect bounding box\n cacheKey += [\n '',\n rotation,\n fontSize,\n wrapper.textWidth,\n alignValue,\n styles && styles.textOverflow,\n styles && styles.fontWeight // #12163\n ].join(',');\n }\n if (cacheKey && !reload) {\n bBox = cache[cacheKey];\n }\n // No cache found\n if (!bBox) {\n // SVG elements\n if (isSVG || renderer.forExport) {\n try { // Fails in Firefox if the container has display: none.\n // When the text shadow shim is used, we need to hide the\n // fake shadows to get the correct bounding box (#3872)\n toggleTextShadowShim = this.fakeTS && function (display) {\n var outline = element.querySelector('.highcharts-text-outline');\n if (outline) {\n css(outline, { display: display });\n }\n };\n // Workaround for #3842, Firefox reporting wrong bounding\n // box for shadows\n if (isFunction(toggleTextShadowShim)) {\n toggleTextShadowShim('none');\n }\n bBox = element.getBBox ?\n // SVG: use extend because IE9 is not allowed to change\n // width and height in case of rotation (below)\n extend({}, element.getBBox()) : {\n // HTML elements with `exporting.allowHTML` and\n // legacy IE in export mode\n width: element.offsetWidth,\n height: element.offsetHeight,\n x: 0,\n y: 0\n };\n // #3842\n if (isFunction(toggleTextShadowShim)) {\n toggleTextShadowShim('');\n }\n }\n catch (e) {\n '';\n }\n // If the bBox is not set, the try-catch block above failed. The\n // other condition is for Opera that returns a width of\n // -Infinity on hidden elements.\n if (!bBox || bBox.width < 0) {\n bBox = { x: 0, y: 0, width: 0, height: 0 };\n }\n // VML Renderer or useHTML within SVG\n }\n else {\n bBox = wrapper.htmlGetBBox();\n }\n // True SVG elements as well as HTML elements in modern browsers\n // using the .useHTML option need to compensated for rotation\n if (renderer.isSVG) {\n width = bBox.width;\n height = bBox.height;\n // Workaround for wrong bounding box in IE, Edge and Chrome on\n // Windows. With Highcharts' default font, IE and Edge report\n // a box height of 16.899 and Chrome rounds it to 17. If this\n // stands uncorrected, it results in more padding added below\n // the text than above when adding a label border or background.\n // Also vertical positioning is affected.\n // https://jsfiddle.net/highcharts/em37nvuj/\n // (#1101, #1505, #1669, #2568, #6213).\n if (isSVG) {\n bBox.height = height = ({\n '11px,17': 14,\n '13px,20': 16\n }[\"\" + (fontSize || '') + \",\".concat(Math.round(height))] ||\n height);\n }\n // Adjust for rotated text\n if (rotation) {\n var baseline = Number(element.getAttribute('y') || 0) - bBox.y,\n alignFactor = {\n 'right': 1,\n 'center': 0.5\n }[alignValue || 0] || 0,\n rad = rotation * deg2rad,\n rad90 = (rotation - 90) * deg2rad,\n wCosRad = width * Math.cos(rad),\n wSinRad = width * Math.sin(rad),\n cosRad90 = Math.cos(rad90),\n sinRad90 = Math.sin(rad90), \n // Find the starting point on the left side baseline of\n // the text\n pX = bBox.x + alignFactor * (width - wCosRad),\n pY = bBox.y + baseline - alignFactor * wSinRad, \n // Find all corners\n aX = pX + baseline * cosRad90,\n bX = aX + wCosRad,\n cX = bX - height * cosRad90,\n dX = cX - wCosRad,\n aY = pY + baseline * sinRad90,\n bY = aY + wSinRad,\n cY = bY - height * sinRad90,\n dY = cY - wSinRad;\n // Deduct the bounding box from the corners\n bBox.x = Math.min(aX, bX, cX, dX);\n bBox.y = Math.min(aY, bY, cY, dY);\n bBox.width = Math.max(aX, bX, cX, dX) - bBox.x;\n bBox.height = Math.max(aY, bY, cY, dY) - bBox.y;\n }\n }\n // Cache it. When loading a chart in a hidden iframe in Firefox and\n // IE/Edge, the bounding box height is 0, so don't cache it (#5620).\n if (cacheKey && (textStr === '' || bBox.height > 0)) {\n // Rotate (#4681)\n while (cacheKeys.length > 250) {\n delete cache[cacheKeys.shift()];\n }\n if (!cache[cacheKey]) {\n cacheKeys.push(cacheKey);\n }\n cache[cacheKey] = bBox;\n }\n }\n return bBox;\n };\n /**\n * Get the computed style. Only in styled mode.\n *\n * @example\n * chart.series[0].points[0].graphic.getStyle('stroke-width'); // => '1px'\n *\n * @function Highcharts.SVGElement#getStyle\n *\n * @param {string} prop\n * The property name to check for.\n *\n * @return {string}\n * The current computed value.\n */\n SVGElement.prototype.getStyle = function (prop) {\n return win\n .getComputedStyle(this.element || this, '')\n .getPropertyValue(prop);\n };\n /**\n * Check if an element has the given class name.\n *\n * @function Highcharts.SVGElement#hasClass\n *\n * @param {string} className\n * The class name to check for.\n *\n * @return {boolean}\n * Whether the class name is found.\n */\n SVGElement.prototype.hasClass = function (className) {\n return ('' + this.attr('class'))\n .split(' ')\n .indexOf(className) !== -1;\n };\n /**\n * Hide the element, similar to setting the `visibility` attribute to\n * `hidden`.\n *\n * @function Highcharts.SVGElement#hide\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n SVGElement.prototype.hide = function () {\n return this.attr({ visibility: 'hidden' });\n };\n /**\n * @private\n */\n SVGElement.prototype.htmlGetBBox = function () {\n return { height: 0, width: 0, x: 0, y: 0 };\n };\n /**\n * Initialize the SVG element. This function only exists to make the\n * initialization process overridable. It should not be called directly.\n *\n * @function Highcharts.SVGElement#init\n *\n * @param {Highcharts.SVGRenderer} renderer\n * The SVGRenderer instance to initialize to.\n *\n * @param {string} nodeName\n * The SVG node name.\n */\n SVGElement.prototype.init = function (renderer, nodeName) {\n /**\n * The primary DOM node. Each `SVGElement` instance wraps a main DOM\n * node, but may also represent more nodes.\n *\n * @name Highcharts.SVGElement#element\n * @type {Highcharts.SVGDOMElement|Highcharts.HTMLDOMElement}\n */\n this.element = nodeName === 'span' ?\n createElement(nodeName) :\n doc.createElementNS(this.SVG_NS, nodeName);\n /**\n * The renderer that the SVGElement belongs to.\n *\n * @name Highcharts.SVGElement#renderer\n * @type {Highcharts.SVGRenderer}\n */\n this.renderer = renderer;\n fireEvent(this, 'afterInit');\n };\n /**\n * Invert a group, rotate and flip. This is used internally on inverted\n * charts, where the points and graphs are drawn as if not inverted, then\n * the series group elements are inverted.\n *\n * @function Highcharts.SVGElement#invert\n *\n * @param {boolean} inverted\n * Whether to invert or not. An inverted shape can be un-inverted by\n * setting it to false.\n *\n * @return {Highcharts.SVGElement}\n * Return the SVGElement for chaining.\n */\n SVGElement.prototype.invert = function (inverted) {\n this.inverted = inverted;\n this.updateTransform();\n return this;\n };\n /**\n * Add an event listener. This is a simple setter that replaces the\n * previous event of the same type added by this function, as opposed to\n * the {@link Highcharts#addEvent} function.\n *\n * @sample highcharts/members/element-on/\n * A clickable rectangle\n *\n * @function Highcharts.SVGElement#on\n *\n * @param {string} eventType\n * The event type.\n *\n * @param {Function} handler\n * The handler callback.\n *\n * @return {Highcharts.SVGElement}\n * The SVGElement for chaining.\n */\n SVGElement.prototype.on = function (eventType, handler) {\n var onEvents = this.onEvents;\n if (onEvents[eventType]) {\n // Unbind existing event\n onEvents[eventType]();\n }\n onEvents[eventType] = addEvent(this.element, eventType, handler);\n return this;\n };\n /**\n * @private\n * @function Highcharts.SVGElement#opacitySetter\n * @param {string} value\n * @param {string} key\n * @param {Highcharts.SVGDOMElement} element\n */\n SVGElement.prototype.opacitySetter = function (value, key, element) {\n // Round off to avoid float errors, like tests where opacity lands on\n // 9.86957e-06 instead of 0\n var opacity = Number(Number(value).toFixed(3));\n this.opacity = opacity;\n element.setAttribute(key, opacity);\n };\n /**\n * Remove a class name from the element.\n *\n * @function Highcharts.SVGElement#removeClass\n *\n * @param {string|RegExp} className\n * The class name to remove.\n *\n * @return {Highcharts.SVGElement} Returns the SVG element for chainability.\n */\n SVGElement.prototype.removeClass = function (className) {\n return this.attr('class', ('' + this.attr('class'))\n .replace(isString(className) ?\n new RegExp(\"(^| )\".concat(className, \"( |$)\")) : // #12064, #13590\n className, ' ')\n .replace(/ +/g, ' ')\n .trim());\n };\n /**\n *\n * @private\n */\n SVGElement.prototype.removeTextOutline = function () {\n var outline = this.element\n .querySelector('tspan.highcharts-text-outline');\n if (outline) {\n this.safeRemoveChild(outline);\n }\n };\n /**\n * Removes an element from the DOM.\n *\n * @private\n * @function Highcharts.SVGElement#safeRemoveChild\n *\n * @param {Highcharts.SVGDOMElement|Highcharts.HTMLDOMElement} element\n * The DOM node to remove.\n */\n SVGElement.prototype.safeRemoveChild = function (element) {\n var parentNode = element.parentNode;\n if (parentNode) {\n parentNode.removeChild(element);\n }\n };\n /**\n * Set the coordinates needed to draw a consistent radial gradient across\n * a shape regardless of positioning inside the chart. Used on pie slices\n * to make all the slices have the same radial reference point.\n *\n * @function Highcharts.SVGElement#setRadialReference\n *\n * @param {Array} coordinates\n * The center reference. The format is `[centerX, centerY, diameter]` in\n * pixels.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n SVGElement.prototype.setRadialReference = function (coordinates) {\n var existingGradient = (this.element.gradient &&\n this.renderer.gradients[this.element.gradient]);\n this.element.radialReference = coordinates;\n // On redrawing objects with an existing gradient, the gradient needs\n // to be repositioned (#3801)\n if (existingGradient && existingGradient.radAttr) {\n existingGradient.animate(this.renderer.getRadialAttr(coordinates, existingGradient.radAttr));\n }\n return this;\n };\n /**\n * Set a text path for a `text` or `label` element, allowing the text to\n * flow along a path.\n *\n * In order to unset the path for an existing element, call `setTextPath`\n * with `{ enabled: false }` as the second argument.\n *\n * @sample highcharts/members/renderer-textpath/ Text path demonstrated\n *\n * @function Highcharts.SVGElement#setTextPath\n *\n * @param {Highcharts.SVGElement|undefined} path\n * Path to follow. If undefined, it allows changing options for the\n * existing path.\n *\n * @param {Highcharts.DataLabelsTextPathOptionsObject} textPathOptions\n * Options.\n *\n * @return {Highcharts.SVGElement} Returns the SVGElement for chaining.\n */\n SVGElement.prototype.setTextPath = function (path, textPathOptions) {\n var _this = this;\n // Defaults\n textPathOptions = merge(true, {\n enabled: true,\n attributes: {\n dy: -5,\n startOffset: '50%',\n textAnchor: 'middle'\n }\n }, textPathOptions);\n var url = this.renderer.url,\n textWrapper = this.text || this,\n textPath = textWrapper.textPath,\n attributes = textPathOptions.attributes,\n enabled = textPathOptions.enabled;\n path = path || (textPath && textPath.path);\n // Remove previously added event\n if (textPath) {\n textPath.undo();\n }\n if (path && enabled) {\n var undo = addEvent(textWrapper, 'afterModifyTree',\n function (e) {\n if (path && enabled) {\n // Set ID for the path\n var textPathId = path.attr('id');\n if (!textPathId) {\n path.attr('id', textPathId = uniqueKey());\n }\n // Set attributes for the \n var textAttribs = {\n // dx/dy options must by set on (parent), the\n // rest should be set on \n x: 0,\n y: 0\n };\n if (defined(attributes.dx)) {\n textAttribs.dx = attributes.dx;\n delete attributes.dx;\n }\n if (defined(attributes.dy)) {\n textAttribs.dy = attributes.dy;\n delete attributes.dy;\n }\n textWrapper.attr(textAttribs);\n // Handle label properties\n _this.attr({ transform: '' });\n if (_this.box) {\n _this.box = _this.box.destroy();\n }\n // Wrap the nodes in a textPath\n var children = e.nodes.slice(0);\n e.nodes.length = 0;\n e.nodes[0] = {\n tagName: 'textPath',\n attributes: extend(attributes, {\n 'text-anchor': attributes.textAnchor,\n href: \"\" + url + \"#\".concat(textPathId)\n }),\n children: children\n };\n }\n });\n // Set the reference\n textWrapper.textPath = { path: path, undo: undo };\n }\n else {\n textWrapper.attr({ dx: 0, dy: 0 });\n delete textWrapper.textPath;\n }\n if (this.added) {\n // Rebuild text after added\n textWrapper.textCache = '';\n this.renderer.buildText(textWrapper);\n }\n return this;\n };\n /**\n * Add a shadow to the element. Must be called after the element is added to\n * the DOM. In styled mode, this method is not used, instead use `defs` and\n * filters.\n *\n * @example\n * renderer.rect(10, 100, 100, 100)\n * .attr({ fill: 'red' })\n * .shadow(true);\n *\n * @function Highcharts.SVGElement#shadow\n *\n * @param {boolean|Highcharts.ShadowOptionsObject} [shadowOptions]\n * The shadow options. If `true`, the default options are applied. If\n * `false`, the current shadow will be removed.\n *\n * @param {Highcharts.SVGElement} [group]\n * The SVG group element where the shadows will be applied. The\n * default is to add it to the same parent as the current element.\n * Internally, this is ised for pie slices, where all the shadows are\n * added to an element behind all the slices.\n *\n * @param {boolean} [cutOff]\n * Used internally for column shadows.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n SVGElement.prototype.shadow = function (shadowOptions, group, cutOff) {\n var shadows = [],\n element = this.element,\n oldShadowOptions = this.oldShadowOptions,\n defaultShadowOptions = {\n color: \"#000000\" /* Palette.neutralColor100 */,\n offsetX: this.parentInverted ? -1 : 1,\n offsetY: this.parentInverted ? -1 : 1,\n opacity: 0.15,\n width: 3\n };\n var i,\n shadow,\n strokeWidth,\n shadowElementOpacity,\n update = false, \n // compensate for inverted plot area\n transform,\n options;\n if (shadowOptions === true) {\n options = defaultShadowOptions;\n }\n else if (typeof shadowOptions === 'object') {\n options = extend(defaultShadowOptions, shadowOptions);\n }\n // Update shadow when options change (#12091).\n if (options) {\n // Go over each key to look for change\n if (options && oldShadowOptions) {\n objectEach(options, function (value, key) {\n if (value !== oldShadowOptions[key]) {\n update = true;\n }\n });\n }\n if (update) {\n this.destroyShadows();\n }\n this.oldShadowOptions = options;\n }\n if (!options) {\n this.destroyShadows();\n }\n else if (!this.shadows) {\n shadowElementOpacity = options.opacity / options.width;\n transform = this.parentInverted ?\n \"translate(\".concat(options.offsetY, \", \").concat(options.offsetX, \")\") :\n \"translate(\".concat(options.offsetX, \", \").concat(options.offsetY, \")\");\n for (i = 1; i <= options.width; i++) {\n shadow = element.cloneNode(false);\n strokeWidth = (options.width * 2) + 1 - (2 * i);\n attr(shadow, {\n stroke: (shadowOptions.color ||\n \"#000000\" /* Palette.neutralColor100 */),\n 'stroke-opacity': shadowElementOpacity * i,\n 'stroke-width': strokeWidth,\n transform: transform,\n fill: 'none'\n });\n shadow.setAttribute('class', (shadow.getAttribute('class') || '') + ' highcharts-shadow');\n if (cutOff) {\n attr(shadow, 'height', Math.max(attr(shadow, 'height') - strokeWidth, 0));\n shadow.cutHeight = strokeWidth;\n }\n if (group) {\n group.element.appendChild(shadow);\n }\n else if (element.parentNode) {\n element.parentNode.insertBefore(shadow, element);\n }\n shadows.push(shadow);\n }\n this.shadows = shadows;\n }\n return this;\n };\n /**\n * Show the element after it has been hidden.\n *\n * @function Highcharts.SVGElement#show\n *\n * @param {boolean} [inherit=true]\n * Set the visibility attribute to `inherit` rather than `visible`.\n * The difference is that an element with `visibility=\"visible\"`\n * will be visible even if the parent is hidden.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n SVGElement.prototype.show = function (inherit) {\n if (inherit === void 0) { inherit = true; }\n return this.attr({ visibility: inherit ? 'inherit' : 'visible' });\n };\n /**\n * WebKit and Batik have problems with a stroke-width of zero, so in this\n * case we remove the stroke attribute altogether. #1270, #1369, #3065,\n * #3072.\n *\n * @private\n * @function Highcharts.SVGElement#strokeSetter\n * @param {number|string|ColorType} value\n * @param {string} key\n * @param {Highcharts.SVGDOMElement} element\n */\n SVGElement.prototype.strokeSetter = function (value, key, element) {\n this[key] = value;\n // Only apply the stroke attribute if the stroke width is defined and\n // larger than 0\n if (this.stroke && this['stroke-width']) {\n // Use prototype as instance may be overridden\n SVGElement.prototype.fillSetter.call(this, this.stroke, 'stroke', element);\n element.setAttribute('stroke-width', this['stroke-width']);\n this.hasStroke = true;\n }\n else if (key === 'stroke-width' && value === 0 && this.hasStroke) {\n element.removeAttribute('stroke');\n this.hasStroke = false;\n }\n else if (this.renderer.styledMode && this['stroke-width']) {\n element.setAttribute('stroke-width', this['stroke-width']);\n this.hasStroke = true;\n }\n };\n /**\n * Get the computed stroke width in pixel values. This is used extensively\n * when drawing shapes to ensure the shapes are rendered crisp and\n * positioned correctly relative to each other. Using\n * `shape-rendering: crispEdges` leaves us less control over positioning,\n * for example when we want to stack columns next to each other, or position\n * things pixel-perfectly within the plot box.\n *\n * The common pattern when placing a shape is:\n * - Create the SVGElement and add it to the DOM. In styled mode, it will\n * now receive a stroke width from the style sheet. In classic mode we\n * will add the `stroke-width` attribute.\n * - Read the computed `elem.strokeWidth()`.\n * - Place it based on the stroke width.\n *\n * @function Highcharts.SVGElement#strokeWidth\n *\n * @return {number}\n * The stroke width in pixels. Even if the given stroke widtch (in CSS or by\n * attributes) is based on `em` or other units, the pixel size is returned.\n */\n SVGElement.prototype.strokeWidth = function () {\n // In non-styled mode, read the stroke width as set by .attr\n if (!this.renderer.styledMode) {\n return this['stroke-width'] || 0;\n }\n // In styled mode, read computed stroke width\n var val = this.getStyle('stroke-width');\n var ret = 0,\n dummy;\n // Read pixel values directly\n if (val.indexOf('px') === val.length - 2) {\n ret = pInt(val);\n // Other values like em, pt etc need to be measured\n }\n else if (val !== '') {\n dummy = doc.createElementNS(SVG_NS, 'rect');\n attr(dummy, {\n width: val,\n 'stroke-width': 0\n });\n this.element.parentNode.appendChild(dummy);\n ret = dummy.getBBox().width;\n dummy.parentNode.removeChild(dummy);\n }\n return ret;\n };\n /**\n * If one of the symbol size affecting parameters are changed,\n * check all the others only once for each call to an element's\n * .attr() method\n *\n * @private\n * @function Highcharts.SVGElement#symbolAttr\n *\n * @param {Highcharts.SVGAttributes} hash\n * The attributes to set.\n */\n SVGElement.prototype.symbolAttr = function (hash) {\n var wrapper = this;\n [\n 'x',\n 'y',\n 'r',\n 'start',\n 'end',\n 'width',\n 'height',\n 'innerR',\n 'anchorX',\n 'anchorY',\n 'clockwise'\n ].forEach(function (key) {\n wrapper[key] = pick(hash[key], wrapper[key]);\n });\n wrapper.attr({\n d: wrapper.renderer.symbols[wrapper.symbolName](wrapper.x, wrapper.y, wrapper.width, wrapper.height, wrapper)\n });\n };\n /**\n * @private\n * @function Highcharts.SVGElement#textSetter\n * @param {string} value\n */\n SVGElement.prototype.textSetter = function (value) {\n if (value !== this.textStr) {\n // Delete size caches when the text changes\n // delete this.bBox; // old code in series-label\n delete this.textPxLength;\n this.textStr = value;\n if (this.added) {\n this.renderer.buildText(this);\n }\n }\n };\n /**\n * @private\n * @function Highcharts.SVGElement#titleSetter\n * @param {string} value\n */\n SVGElement.prototype.titleSetter = function (value) {\n var el = this.element;\n var titleNode = el.getElementsByTagName('title')[0] ||\n doc.createElementNS(this.SVG_NS, 'title');\n // Move to first child\n if (el.insertBefore) {\n el.insertBefore(titleNode, el.firstChild);\n }\n else {\n el.appendChild(titleNode);\n }\n // Replace text content and escape markup\n titleNode.textContent =\n // #3276, #3895\n String(pick(value, ''))\n .replace(/<[^>]*>/g, '')\n .replace(/</g, '<')\n .replace(/>/g, '>');\n };\n /**\n * Bring the element to the front. Alternatively, a new zIndex can be set.\n *\n * @sample highcharts/members/element-tofront/\n * Click an element to bring it to front\n *\n * @function Highcharts.SVGElement#toFront\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n SVGElement.prototype.toFront = function () {\n var element = this.element;\n element.parentNode.appendChild(element);\n return this;\n };\n /**\n * Move an object and its children by x and y values.\n *\n * @function Highcharts.SVGElement#translate\n *\n * @param {number} x\n * The x value.\n *\n * @param {number} y\n * The y value.\n *\n * @return {Highcharts.SVGElement}\n * Translated element.\n */\n SVGElement.prototype.translate = function (x, y) {\n return this.attr({\n translateX: x,\n translateY: y\n });\n };\n /**\n * Update the shadow elements with new attributes.\n *\n * @private\n * @function Highcharts.SVGElement#updateShadows\n *\n * @param {string} key\n * The attribute name.\n *\n * @param {number} value\n * The value of the attribute.\n *\n * @param {Function} setter\n * The setter function, inherited from the parent wrapper.\n */\n SVGElement.prototype.updateShadows = function (key, value, setter) {\n var shadows = this.shadows;\n if (shadows) {\n var i = shadows.length;\n while (i--) {\n setter.call(shadows[i], key === 'height' ?\n Math.max(value - (shadows[i].cutHeight || 0), 0) :\n key === 'd' ? this.d : value, key, shadows[i]);\n }\n }\n };\n /**\n * Update the transform attribute based on internal properties. Deals with\n * the custom `translateX`, `translateY`, `rotation`, `scaleX` and `scaleY`\n * attributes and updates the SVG `transform` attribute.\n *\n * @private\n * @function Highcharts.SVGElement#updateTransform\n */\n SVGElement.prototype.updateTransform = function () {\n var wrapper = this,\n scaleX = wrapper.scaleX,\n scaleY = wrapper.scaleY,\n inverted = wrapper.inverted,\n rotation = wrapper.rotation,\n matrix = wrapper.matrix,\n element = wrapper.element;\n var translateX = wrapper.translateX || 0,\n translateY = wrapper.translateY || 0;\n // Flipping affects translate as adjustment for flipping around the\n // group's axis\n if (inverted) {\n translateX += wrapper.width;\n translateY += wrapper.height;\n }\n // Apply translate. Nearly all transformed elements have translation,\n // so instead of checking for translate = 0, do it always (#1767,\n // #1846).\n var transform = ['translate(' + translateX + ',' + translateY + ')'];\n // apply matrix\n if (defined(matrix)) {\n transform.push('matrix(' + matrix.join(',') + ')');\n }\n // apply rotation\n if (inverted) {\n transform.push('rotate(90) scale(-1,1)');\n }\n else if (rotation) { // text rotation\n transform.push('rotate(' + rotation + ' ' +\n pick(this.rotationOriginX, element.getAttribute('x'), 0) +\n ' ' +\n pick(this.rotationOriginY, element.getAttribute('y') || 0) + ')');\n }\n // apply scale\n if (defined(scaleX) || defined(scaleY)) {\n transform.push('scale(' + pick(scaleX, 1) + ' ' + pick(scaleY, 1) + ')');\n }\n if (transform.length && !(wrapper.text || wrapper).textPath) {\n element.setAttribute('transform', transform.join(' '));\n }\n };\n /**\n * @private\n * @function Highcharts.SVGElement#visibilitySetter\n *\n * @param {string} value\n *\n * @param {string} key\n *\n * @param {Highcharts.SVGDOMElement} element\n *\n */\n SVGElement.prototype.visibilitySetter = function (value, key, element) {\n // IE9-11 doesn't handle visibilty:inherit well, so we remove the\n // attribute instead (#2881, #3909)\n if (value === 'inherit') {\n element.removeAttribute(key);\n }\n else if (this[key] !== value) { // #6747\n element.setAttribute(key, value);\n }\n this[key] = value;\n };\n /**\n * @private\n * @function Highcharts.SVGElement#xGetter\n */\n SVGElement.prototype.xGetter = function (key) {\n if (this.element.nodeName === 'circle') {\n if (key === 'x') {\n key = 'cx';\n }\n else if (key === 'y') {\n key = 'cy';\n }\n }\n return this._defaultGetter(key);\n };\n /**\n * @private\n * @function Highcharts.SVGElement#zIndexSetter\n */\n SVGElement.prototype.zIndexSetter = function (value, key) {\n var renderer = this.renderer,\n parentGroup = this.parentGroup,\n parentWrapper = parentGroup || renderer,\n parentNode = parentWrapper.element || renderer.box,\n element = this.element,\n svgParent = parentNode === renderer.box;\n var childNodes,\n otherElement,\n otherZIndex,\n inserted = false,\n undefinedOtherZIndex,\n run = this.added,\n i;\n if (defined(value)) {\n // So we can read it for other elements in the group\n element.setAttribute('data-z-index', value);\n value = +value;\n if (this[key] === value) {\n // Only update when needed (#3865)\n run = false;\n }\n }\n else if (defined(this[key])) {\n element.removeAttribute('data-z-index');\n }\n this[key] = value;\n // Insert according to this and other elements' zIndex. Before .add() is\n // called, nothing is done. Then on add, or by later calls to\n // zIndexSetter, the node is placed on the right place in the DOM.\n if (run) {\n value = this.zIndex;\n if (value && parentGroup) {\n parentGroup.handleZ = true;\n }\n childNodes = parentNode.childNodes;\n for (i = childNodes.length - 1; i >= 0 && !inserted; i--) {\n otherElement = childNodes[i];\n otherZIndex = otherElement.getAttribute('data-z-index');\n undefinedOtherZIndex = !defined(otherZIndex);\n if (otherElement !== element) {\n if (\n // Negative zIndex versus no zIndex:\n // On all levels except the highest. If the parent is\n // , then we don't want to put items before \n // or \n value < 0 &&\n undefinedOtherZIndex &&\n !svgParent &&\n !i) {\n parentNode.insertBefore(element, childNodes[i]);\n inserted = true;\n }\n else if (\n // Insert after the first element with a lower zIndex\n pInt(otherZIndex) <= value ||\n // If negative zIndex, add this before first undefined\n // zIndex element\n (undefinedOtherZIndex &&\n (!defined(value) || value >= 0))) {\n parentNode.insertBefore(element, childNodes[i + 1] || null // null for oldIE export\n );\n inserted = true;\n }\n }\n }\n if (!inserted) {\n parentNode.insertBefore(element, childNodes[svgParent ? 3 : 0] || null // null for oldIE\n );\n inserted = true;\n }\n }\n return inserted;\n };\n return SVGElement;\n }());\n // Some shared setters and getters\n SVGElement.prototype['stroke-widthSetter'] = SVGElement.prototype.strokeSetter;\n SVGElement.prototype.yGetter = SVGElement.prototype.xGetter;\n SVGElement.prototype.matrixSetter =\n SVGElement.prototype.rotationOriginXSetter =\n SVGElement.prototype.rotationOriginYSetter =\n SVGElement.prototype.rotationSetter =\n SVGElement.prototype.scaleXSetter =\n SVGElement.prototype.scaleYSetter =\n SVGElement.prototype.translateXSetter =\n SVGElement.prototype.translateYSetter =\n SVGElement.prototype.verticalAlignSetter = function (value, key) {\n this[key] = value;\n this.doTransform = true;\n };\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Reference to the global SVGElement class as a workaround for a name conflict\n * in the Highcharts namespace.\n *\n * @global\n * @typedef {global.SVGElement} GlobalSVGElement\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/SVGElement\n */\n /**\n * The horizontal alignment of an element.\n *\n * @typedef {\"center\"|\"left\"|\"right\"} Highcharts.AlignValue\n */\n /**\n * Options to align the element relative to the chart or another box.\n *\n * @interface Highcharts.AlignObject\n */ /**\n * Horizontal alignment. Can be one of `left`, `center` and `right`.\n *\n * @name Highcharts.AlignObject#align\n * @type {Highcharts.AlignValue|undefined}\n *\n * @default left\n */ /**\n * Vertical alignment. Can be one of `top`, `middle` and `bottom`.\n *\n * @name Highcharts.AlignObject#verticalAlign\n * @type {Highcharts.VerticalAlignValue|undefined}\n *\n * @default top\n */ /**\n * Horizontal pixel offset from alignment.\n *\n * @name Highcharts.AlignObject#x\n * @type {number|undefined}\n *\n * @default 0\n */ /**\n * Vertical pixel offset from alignment.\n *\n * @name Highcharts.AlignObject#y\n * @type {number|undefined}\n *\n * @default 0\n */ /**\n * Use the `transform` attribute with translateX and translateY custom\n * attributes to align this elements rather than `x` and `y` attributes.\n *\n * @name Highcharts.AlignObject#alignByTranslate\n * @type {boolean|undefined}\n *\n * @default false\n */\n /**\n * Bounding box of an element.\n *\n * @interface Highcharts.BBoxObject\n * @extends Highcharts.PositionObject\n */ /**\n * Height of the bounding box.\n *\n * @name Highcharts.BBoxObject#height\n * @type {number}\n */ /**\n * Width of the bounding box.\n *\n * @name Highcharts.BBoxObject#width\n * @type {number}\n */ /**\n * Horizontal position of the bounding box.\n *\n * @name Highcharts.BBoxObject#x\n * @type {number}\n */ /**\n * Vertical position of the bounding box.\n *\n * @name Highcharts.BBoxObject#y\n * @type {number}\n */\n /**\n * An object of key-value pairs for SVG attributes. Attributes in Highcharts\n * elements for the most parts correspond to SVG, but some are specific to\n * Highcharts, like `zIndex`, `rotation`, `rotationOriginX`,\n * `rotationOriginY`, `translateX`, `translateY`, `scaleX` and `scaleY`. SVG\n * attributes containing a hyphen are _not_ camel-cased, they should be\n * quoted to preserve the hyphen.\n *\n * @example\n * {\n * 'stroke': '#ff0000', // basic\n * 'stroke-width': 2, // hyphenated\n * 'rotation': 45 // custom\n * 'd': ['M', 10, 10, 'L', 30, 30, 'z'] // path definition, note format\n * }\n *\n * @interface Highcharts.SVGAttributes\n */ /**\n * @name Highcharts.SVGAttributes#[key:string]\n * @type {*}\n */ /**\n * @name Highcharts.SVGAttributes#d\n * @type {string|Highcharts.SVGPathArray|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#dx\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#dy\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#fill\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#inverted\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#matrix\n * @type {Array|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#rotation\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#rotationOriginX\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#rotationOriginY\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#scaleX\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#scaleY\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#stroke\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#style\n * @type {string|Highcharts.CSSObject|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#translateX\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#translateY\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#zIndex\n * @type {number|undefined}\n */\n /**\n * An SVG DOM element. The type is a reference to the regular SVGElement in the\n * global scope.\n *\n * @typedef {globals.GlobalSVGElement} Highcharts.SVGDOMElement\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/SVGElement\n */\n /**\n * The vertical alignment of an element.\n *\n * @typedef {\"bottom\"|\"middle\"|\"top\"} Highcharts.VerticalAlignValue\n */\n ''; // keeps doclets above in JS file\n\n return SVGElement;\n });\n _registerModule(_modules, 'Core/Renderer/RendererRegistry.js', [_modules['Core/Globals.js']], function (H) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Namespace\n *\n * */\n var RendererRegistry;\n (function (RendererRegistry) {\n /* *\n *\n * Constants\n *\n * */\n RendererRegistry.rendererTypes = {};\n /* *\n *\n * Variables\n *\n * */\n var defaultRenderer;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Gets a registered renderer class. If no renderer type is provided or the\n * requested renderer was not founded, the default renderer is returned.\n *\n * @param {string} [rendererType]\n * Renderer type or the default renderer.\n *\n * @return {Highcharts.Class}\n * Returns the requested renderer class or the default renderer class.\n */\n function getRendererType(rendererType) {\n if (rendererType === void 0) { rendererType = defaultRenderer; }\n return (RendererRegistry.rendererTypes[rendererType] || RendererRegistry.rendererTypes[defaultRenderer]);\n }\n RendererRegistry.getRendererType = getRendererType;\n /**\n * Register a renderer class.\n *\n * @param {string} rendererType\n * Renderer type to register.\n *\n * @param {Highcharts.Class} rendererClass\n * Returns the requested renderer class or the default renderer class.\n *\n * @param {boolean} setAsDefault\n * Sets the renderer class as the default renderer.\n */\n function registerRendererType(rendererType, rendererClass, setAsDefault) {\n RendererRegistry.rendererTypes[rendererType] = rendererClass;\n if (!defaultRenderer || setAsDefault) {\n defaultRenderer = rendererType;\n H.Renderer = rendererClass; // compatibility\n }\n }\n RendererRegistry.registerRendererType = registerRendererType;\n })(RendererRegistry || (RendererRegistry = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return RendererRegistry;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/SVGLabel.js', [_modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var defined = U.defined,\n extend = U.extend,\n isNumber = U.isNumber,\n merge = U.merge,\n pick = U.pick,\n removeEvent = U.removeEvent;\n /* *\n *\n * Class\n *\n * */\n /**\n * SVG label to render text.\n * @private\n * @class\n * @name Highcharts.SVGLabel\n * @augments Highcharts.SVGElement\n */\n var SVGLabel = /** @class */ (function (_super) {\n __extends(SVGLabel, _super);\n /* *\n *\n * Constructor\n *\n * */\n function SVGLabel(renderer, str, x, y, shape, anchorX, anchorY, useHTML, baseline, className) {\n var _this = _super.call(this) || this;\n _this.paddingLeftSetter = _this.paddingSetter;\n _this.paddingRightSetter = _this.paddingSetter;\n _this.init(renderer, 'g');\n _this.textStr = str;\n _this.x = x;\n _this.y = y;\n _this.anchorX = anchorX;\n _this.anchorY = anchorY;\n _this.baseline = baseline;\n _this.className = className;\n _this.addClass(className === 'button' ?\n 'highcharts-no-tooltip' :\n 'highcharts-label');\n if (className) {\n _this.addClass('highcharts-' + className);\n }\n // Create the text element. An undefined text content prevents redundant\n // box calculation (#16121)\n _this.text = renderer.text(void 0, 0, 0, useHTML).attr({ zIndex: 1 });\n // Validate the shape argument\n var hasBGImage;\n if (typeof shape === 'string') {\n hasBGImage = /^url\\((.*?)\\)$/.test(shape);\n if (hasBGImage || _this.renderer.symbols[shape]) {\n _this.symbolKey = shape;\n }\n }\n _this.bBox = SVGLabel.emptyBBox;\n _this.padding = 3;\n _this.baselineOffset = 0;\n _this.needsBox = renderer.styledMode || hasBGImage;\n _this.deferredAttr = {};\n _this.alignFactor = 0;\n return _this;\n }\n /* *\n *\n * Functions\n *\n * */\n SVGLabel.prototype.alignSetter = function (value) {\n var alignFactor = ({\n left: 0,\n center: 0.5,\n right: 1\n })[value];\n if (alignFactor !== this.alignFactor) {\n this.alignFactor = alignFactor;\n // Bounding box exists, means we're dynamically changing\n if (this.bBox && isNumber(this.xSetting)) {\n this.attr({ x: this.xSetting }); // #5134\n }\n }\n };\n SVGLabel.prototype.anchorXSetter = function (value, key) {\n this.anchorX = value;\n this.boxAttr(key, Math.round(value) - this.getCrispAdjust() - this.xSetting);\n };\n SVGLabel.prototype.anchorYSetter = function (value, key) {\n this.anchorY = value;\n this.boxAttr(key, value - this.ySetting);\n };\n /*\n * Set a box attribute, or defer it if the box is not yet created\n */\n SVGLabel.prototype.boxAttr = function (key, value) {\n if (this.box) {\n this.box.attr(key, value);\n }\n else {\n this.deferredAttr[key] = value;\n }\n };\n /*\n * Pick up some properties and apply them to the text instead of the\n * wrapper.\n */\n SVGLabel.prototype.css = function (styles) {\n if (styles) {\n var textStyles_1 = {};\n // Create a copy to avoid altering the original object\n // (#537)\n styles = merge(styles);\n SVGLabel.textProps.forEach(function (prop) {\n if (typeof styles[prop] !== 'undefined') {\n textStyles_1[prop] = styles[prop];\n delete styles[prop];\n }\n });\n this.text.css(textStyles_1);\n var isWidth = 'width' in textStyles_1, isFontStyle = ('fontSize' in textStyles_1 ||\n 'fontWeight' in textStyles_1);\n // Update existing text, box (#9400, #12163)\n if (isFontStyle) {\n this.updateTextPadding();\n }\n else if (isWidth) {\n this.updateBoxSize();\n }\n }\n return SVGElement.prototype.css.call(this, styles);\n };\n /*\n * Destroy and release memory.\n */\n SVGLabel.prototype.destroy = function () {\n // Added by button implementation\n removeEvent(this.element, 'mouseenter');\n removeEvent(this.element, 'mouseleave');\n if (this.text) {\n this.text.destroy();\n }\n if (this.box) {\n this.box = this.box.destroy();\n }\n // Call base implementation to destroy the rest\n SVGElement.prototype.destroy.call(this);\n return void 0;\n };\n SVGLabel.prototype.fillSetter = function (value, key) {\n if (value) {\n this.needsBox = true;\n }\n // for animation getter (#6776)\n this.fill = value;\n this.boxAttr(key, value);\n };\n /*\n * Return the bounding box of the box, not the group.\n */\n SVGLabel.prototype.getBBox = function () {\n // If we have a text string and the DOM bBox was 0, it typically means\n // that the label was first rendered hidden, so we need to update the\n // bBox (#15246)\n if (this.textStr && this.bBox.width === 0 && this.bBox.height === 0) {\n this.updateBoxSize();\n }\n var padding = this.padding;\n var paddingLeft = pick(this.paddingLeft,\n padding);\n return {\n width: this.width,\n height: this.height,\n x: this.bBox.x - paddingLeft,\n y: this.bBox.y - padding\n };\n };\n SVGLabel.prototype.getCrispAdjust = function () {\n return this.renderer.styledMode && this.box ?\n this.box.strokeWidth() % 2 / 2 :\n (this['stroke-width'] ? parseInt(this['stroke-width'], 10) : 0) % 2 / 2;\n };\n SVGLabel.prototype.heightSetter = function (value) {\n this.heightSetting = value;\n };\n /*\n * After the text element is added, get the desired size of the border\n * box and add it before the text in the DOM.\n */\n SVGLabel.prototype.onAdd = function () {\n var str = this.textStr;\n this.text.add(this);\n this.attr({\n // Alignment is available now (#3295, 0 not rendered if given\n // as a value)\n text: (defined(str) ? str : ''),\n x: this.x,\n y: this.y\n });\n if (this.box && defined(this.anchorX)) {\n this.attr({\n anchorX: this.anchorX,\n anchorY: this.anchorY\n });\n }\n };\n SVGLabel.prototype.paddingSetter = function (value, key) {\n if (!isNumber(value)) {\n this[key] = void 0;\n }\n else if (value !== this[key]) {\n this[key] = value;\n this.updateTextPadding();\n }\n };\n SVGLabel.prototype.rSetter = function (value, key) {\n this.boxAttr(key, value);\n };\n SVGLabel.prototype.shadow = function (b) {\n if (b && !this.renderer.styledMode) {\n this.updateBoxSize();\n if (this.box) {\n this.box.shadow(b);\n }\n }\n return this;\n };\n SVGLabel.prototype.strokeSetter = function (value, key) {\n // for animation getter (#6776)\n this.stroke = value;\n this.boxAttr(key, value);\n };\n SVGLabel.prototype['stroke-widthSetter'] = function (value, key) {\n if (value) {\n this.needsBox = true;\n }\n this['stroke-width'] = value;\n this.boxAttr(key, value);\n };\n SVGLabel.prototype['text-alignSetter'] = function (value) {\n this.textAlign = value;\n };\n SVGLabel.prototype.textSetter = function (text) {\n if (typeof text !== 'undefined') {\n // Must use .attr to ensure transforms are done (#10009)\n this.text.attr({ text: text });\n }\n this.updateTextPadding();\n };\n /*\n * This function runs after the label is added to the DOM (when the bounding\n * box is available), and after the text of the label is updated to detect\n * the new bounding box and reflect it in the border box.\n */\n SVGLabel.prototype.updateBoxSize = function () {\n var text = this.text,\n style = text.element.style,\n attribs = {},\n padding = this.padding, \n // #12165 error when width is null (auto)\n // #12163 when fontweight: bold, recalculate bBox withot cache\n // #3295 && 3514 box failure when string equals 0\n bBox = this.bBox = (((!isNumber(this.widthSetting) ||\n !isNumber(this.heightSetting) ||\n this.textAlign) && defined(text.textStr)) ?\n text.getBBox() :\n SVGLabel.emptyBBox);\n var crispAdjust;\n this.width = this.getPaddedWidth();\n this.height = (this.heightSetting || bBox.height || 0) + 2 * padding;\n var metrics = this.renderer.fontMetrics(style && style.fontSize,\n text);\n // Update the label-scoped y offset. Math.min because of inline\n // style (#9400)\n this.baselineOffset = padding + Math.min(\n // When applicable, use the font size of the first line (#15707)\n (this.text.firstLineMetrics || metrics).b, \n // When the height is 0, there is no bBox, so go with the font\n // metrics. Highmaps CSS demos.\n bBox.height || Infinity);\n // #15491: Vertical centering\n if (this.heightSetting) {\n this.baselineOffset += (this.heightSetting - metrics.h) / 2;\n }\n if (this.needsBox && !text.textPath) {\n // Create the border box if it is not already present\n if (!this.box) {\n // Symbol definition exists (#5324)\n var box = this.box = this.symbolKey ?\n this.renderer.symbol(this.symbolKey) :\n this.renderer.rect();\n box.addClass(// Don't use label className for buttons\n (this.className === 'button' ?\n '' : 'highcharts-label-box') +\n (this.className ?\n ' highcharts-' + this.className + '-box' : ''));\n box.add(this);\n }\n crispAdjust = this.getCrispAdjust();\n attribs.x = crispAdjust;\n attribs.y = ((this.baseline ? -this.baselineOffset : 0) + crispAdjust);\n // Apply the box attributes\n attribs.width = Math.round(this.width);\n attribs.height = Math.round(this.height);\n this.box.attr(extend(attribs, this.deferredAttr));\n this.deferredAttr = {};\n }\n };\n /*\n * This function runs after setting text or padding, but only if padding\n * is changed.\n */\n SVGLabel.prototype.updateTextPadding = function () {\n var text = this.text;\n if (!text.textPath) {\n this.updateBoxSize();\n // Determine y based on the baseline\n var textY = this.baseline ? 0 : this.baselineOffset;\n var textX = pick(this.paddingLeft,\n this.padding);\n // compensate for alignment\n if (defined(this.widthSetting) &&\n this.bBox &&\n (this.textAlign === 'center' || this.textAlign === 'right')) {\n textX += { center: 0.5, right: 1 }[this.textAlign] * (this.widthSetting - this.bBox.width);\n }\n // update if anything changed\n if (textX !== text.x || textY !== text.y) {\n text.attr('x', textX);\n // #8159 - prevent misplaced data labels in treemap\n // (useHTML: true)\n if (text.hasBoxWidthChanged) {\n this.bBox = text.getBBox(true);\n }\n if (typeof textY !== 'undefined') {\n text.attr('y', textY);\n }\n }\n // record current values\n text.x = textX;\n text.y = textY;\n }\n };\n SVGLabel.prototype.widthSetter = function (value) {\n // width:auto => null\n this.widthSetting = isNumber(value) ? value : void 0;\n };\n SVGLabel.prototype.getPaddedWidth = function () {\n var padding = this.padding;\n var paddingLeft = pick(this.paddingLeft,\n padding);\n var paddingRight = pick(this.paddingRight,\n padding);\n return ((this.widthSetting || this.bBox.width || 0) +\n paddingLeft +\n paddingRight);\n };\n SVGLabel.prototype.xSetter = function (value) {\n this.x = value; // for animation getter\n if (this.alignFactor) {\n value -= this.alignFactor * this.getPaddedWidth();\n // Force animation even when setting to the same value (#7898)\n this['forceAnimate:x'] = true;\n }\n this.xSetting = Math.round(value);\n this.attr('translateX', this.xSetting);\n };\n SVGLabel.prototype.ySetter = function (value) {\n this.ySetting = this.y = Math.round(value);\n this.attr('translateY', this.ySetting);\n };\n /* *\n *\n * Static Properties\n *\n * */\n SVGLabel.emptyBBox = {\n width: 0,\n height: 0,\n x: 0,\n y: 0\n };\n /**\n * For labels, these CSS properties are applied to the `text` node directly.\n *\n * @private\n * @name Highcharts.SVGLabel#textProps\n * @type {Array}\n */\n SVGLabel.textProps = [\n 'color', 'direction', 'fontFamily', 'fontSize', 'fontStyle',\n 'fontWeight', 'lineHeight', 'textAlign', 'textDecoration',\n 'textOutline', 'textOverflow', 'width'\n ];\n return SVGLabel;\n }(SVGElement));\n /* *\n *\n * Default Export\n *\n * */\n\n return SVGLabel;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/Symbols.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var defined = U.defined,\n isNumber = U.isNumber,\n pick = U.pick;\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable require-jsdoc, valid-jsdoc */\n function arc(x, y, w, h, options) {\n var arc = [];\n if (options) {\n var start = options.start || 0,\n rx = pick(options.r,\n w),\n ry = pick(options.r,\n h || w),\n proximity = 0.001,\n fullCircle = (Math.abs((options.end || 0) - start - 2 * Math.PI) <\n proximity), \n // Substract a small number to prevent cos and sin of start\n // and end from becoming equal on 360 arcs (related: #1561)\n end = (options.end || 0) - proximity,\n innerRadius = options.innerR,\n open_1 = pick(options.open,\n fullCircle),\n cosStart = Math.cos(start),\n sinStart = Math.sin(start),\n cosEnd = Math.cos(end),\n sinEnd = Math.sin(end), \n // Proximity takes care of rounding errors around PI (#6971)\n longArc = pick(options.longArc,\n end - start - Math.PI < proximity ? 0 : 1);\n arc.push([\n 'M',\n x + rx * cosStart,\n y + ry * sinStart\n ], [\n 'A',\n rx,\n ry,\n 0,\n longArc,\n pick(options.clockwise, 1),\n x + rx * cosEnd,\n y + ry * sinEnd\n ]);\n if (defined(innerRadius)) {\n arc.push(open_1 ?\n [\n 'M',\n x + innerRadius * cosEnd,\n y + innerRadius * sinEnd\n ] : [\n 'L',\n x + innerRadius * cosEnd,\n y + innerRadius * sinEnd\n ], [\n 'A',\n innerRadius,\n innerRadius,\n 0,\n longArc,\n // Clockwise - opposite to the outer arc clockwise\n defined(options.clockwise) ? 1 - options.clockwise : 0,\n x + innerRadius * cosStart,\n y + innerRadius * sinStart\n ]);\n }\n if (!open_1) {\n arc.push(['Z']);\n }\n }\n return arc;\n }\n /**\n * Callout shape used for default tooltips, also used for rounded\n * rectangles in VML\n */\n function callout(x, y, w, h, options) {\n var arrowLength = 6,\n halfDistance = 6,\n r = Math.min((options && options.r) || 0,\n w,\n h),\n safeDistance = r + halfDistance,\n anchorX = options && options.anchorX,\n anchorY = options && options.anchorY || 0;\n var path = roundedRect(x,\n y,\n w,\n h, { r: r });\n if (!isNumber(anchorX)) {\n return path;\n }\n // Anchor on right side\n if (x + anchorX >= w) {\n // Chevron\n if (anchorY > y + safeDistance &&\n anchorY < y + h - safeDistance) {\n path.splice(3, 1, ['L', x + w, anchorY - halfDistance], ['L', x + w + arrowLength, anchorY], ['L', x + w, anchorY + halfDistance], ['L', x + w, y + h - r]);\n // Simple connector\n }\n else {\n path.splice(3, 1, ['L', x + w, h / 2], ['L', anchorX, anchorY], ['L', x + w, h / 2], ['L', x + w, y + h - r]);\n }\n // Anchor on left side\n }\n else if (x + anchorX <= 0) {\n // Chevron\n if (anchorY > y + safeDistance &&\n anchorY < y + h - safeDistance) {\n path.splice(7, 1, ['L', x, anchorY + halfDistance], ['L', x - arrowLength, anchorY], ['L', x, anchorY - halfDistance], ['L', x, y + r]);\n // Simple connector\n }\n else {\n path.splice(7, 1, ['L', x, h / 2], ['L', anchorX, anchorY], ['L', x, h / 2], ['L', x, y + r]);\n }\n }\n else if ( // replace bottom\n anchorY &&\n anchorY > h &&\n anchorX > x + safeDistance &&\n anchorX < x + w - safeDistance) {\n path.splice(5, 1, ['L', anchorX + halfDistance, y + h], ['L', anchorX, y + h + arrowLength], ['L', anchorX - halfDistance, y + h], ['L', x + r, y + h]);\n }\n else if ( // replace top\n anchorY &&\n anchorY < 0 &&\n anchorX > x + safeDistance &&\n anchorX < x + w - safeDistance) {\n path.splice(1, 1, ['L', anchorX - halfDistance, y], ['L', anchorX, y - arrowLength], ['L', anchorX + halfDistance, y], ['L', w - r, y]);\n }\n return path;\n }\n function circle(x, y, w, h) {\n // Return a full arc\n return arc(x + w / 2, y + h / 2, w / 2, h / 2, {\n start: Math.PI * 0.5,\n end: Math.PI * 2.5,\n open: false\n });\n }\n function diamond(x, y, w, h) {\n return [\n ['M', x + w / 2, y],\n ['L', x + w, y + h / 2],\n ['L', x + w / 2, y + h],\n ['L', x, y + h / 2],\n ['Z']\n ];\n }\n // #15291\n function rect(x, y, w, h, options) {\n if (options && options.r) {\n return roundedRect(x, y, w, h, options);\n }\n return [\n ['M', x, y],\n ['L', x + w, y],\n ['L', x + w, y + h],\n ['L', x, y + h],\n ['Z']\n ];\n }\n function roundedRect(x, y, w, h, options) {\n var r = (options && options.r) || 0;\n return [\n ['M', x + r, y],\n ['L', x + w - r, y],\n ['C', x + w, y, x + w, y, x + w, y + r],\n ['L', x + w, y + h - r],\n ['C', x + w, y + h, x + w, y + h, x + w - r, y + h],\n ['L', x + r, y + h],\n ['C', x, y + h, x, y + h, x, y + h - r],\n ['L', x, y + r],\n ['C', x, y, x, y, x + r, y] // top-left corner\n ];\n }\n function triangle(x, y, w, h) {\n return [\n ['M', x + w / 2, y],\n ['L', x + w, y + h],\n ['L', x, y + h],\n ['Z']\n ];\n }\n function triangleDown(x, y, w, h) {\n return [\n ['M', x, y],\n ['L', x + w, y],\n ['L', x + w / 2, y + h],\n ['Z']\n ];\n }\n var Symbols = {\n arc: arc,\n callout: callout,\n circle: circle,\n diamond: diamond,\n rect: rect,\n roundedRect: roundedRect,\n square: rect,\n triangle: triangle,\n 'triangle-down': triangleDown\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return Symbols;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/TextBuilder.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (AST, H, U) {\n /* *\n *\n * (c) 2010-2020 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var doc = H.doc,\n SVG_NS = H.SVG_NS,\n win = H.win;\n var attr = U.attr,\n extend = U.extend,\n fireEvent = U.fireEvent,\n isString = U.isString,\n objectEach = U.objectEach,\n pick = U.pick;\n /* *\n *\n * Class\n *\n * */\n /**\n * SVG Text Builder\n * @private\n * @class\n * @name Highcharts.TextBuilder\n */\n var TextBuilder = /** @class */ (function () {\n function TextBuilder(svgElement) {\n var textStyles = svgElement.styles;\n this.renderer = svgElement.renderer;\n this.svgElement = svgElement;\n this.width = svgElement.textWidth;\n this.textLineHeight = textStyles && textStyles.lineHeight;\n this.textOutline = textStyles && textStyles.textOutline;\n this.ellipsis = Boolean(textStyles && textStyles.textOverflow === 'ellipsis');\n this.noWrap = Boolean(textStyles && textStyles.whiteSpace === 'nowrap');\n this.fontSize = textStyles && textStyles.fontSize;\n }\n /**\n * Build an SVG representation of the pseudo HTML given in the object's\n * svgElement.\n *\n * @private\n *\n * @return {void}.\n */\n TextBuilder.prototype.buildSVG = function () {\n var wrapper = this.svgElement, textNode = wrapper.element, renderer = wrapper.renderer, textStr = pick(wrapper.textStr, '').toString(), hasMarkup = textStr.indexOf('<') !== -1, childNodes = textNode.childNodes, tempParent = this.width && !wrapper.added && renderer.box, regexMatchBreaks = //g, \n // The buildText code is quite heavy, so if we're not changing\n // something that affects the text, skip it (#6113).\n textCache = [\n textStr,\n this.ellipsis,\n this.noWrap,\n this.textLineHeight,\n this.textOutline,\n this.fontSize,\n this.width\n ].join(',');\n if (textCache === wrapper.textCache) {\n return;\n }\n wrapper.textCache = textCache;\n delete wrapper.actualWidth;\n // Remove old text\n for (var i = childNodes.length; i--;) {\n textNode.removeChild(childNodes[i]);\n }\n // Simple strings, add text directly and return\n if (!hasMarkup &&\n !this.ellipsis &&\n !this.width &&\n !wrapper.textPath &&\n (textStr.indexOf(' ') === -1 ||\n (this.noWrap && !regexMatchBreaks.test(textStr)))) {\n textNode.appendChild(doc.createTextNode(this.unescapeEntities(textStr)));\n // Complex strings, add more logic\n }\n else if (textStr !== '') {\n if (tempParent) {\n // attach it to the DOM to read offset width\n tempParent.appendChild(textNode);\n }\n // Step 1. Parse the markup safely and directly into a tree\n // structure.\n var ast = new AST(textStr);\n // Step 2. Do as many as we can of the modifications to the tree\n // structure before it is added to the DOM\n this.modifyTree(ast.nodes);\n ast.addToDOM(textNode);\n // Step 3. Some modifications can't be done until the structure is\n // in the DOM, because we need to read computed metrics.\n this.modifyDOM();\n // Add title if an ellipsis was added\n if (this.ellipsis &&\n (textNode.textContent || '').indexOf('\\u2026') !== -1) {\n wrapper.attr('title', this.unescapeEntities(wrapper.textStr || '', ['<', '>']) // #7179\n );\n }\n if (tempParent) {\n tempParent.removeChild(textNode);\n }\n }\n // Apply the text outline\n if (isString(this.textOutline) && wrapper.applyTextOutline) {\n wrapper.applyTextOutline(this.textOutline);\n }\n };\n /**\n * Modify the DOM of the generated SVG structure. This function only does\n * operations that cannot be done until the elements are attached to the\n * DOM, like doing layout based on rendered metrics of the added elements.\n *\n * @private\n *\n */\n TextBuilder.prototype.modifyDOM = function () {\n var _this = this;\n var wrapper = this.svgElement;\n var x = attr(wrapper.element, 'x');\n wrapper.firstLineMetrics = void 0;\n // Remove empty tspans (including breaks) from the beginning because\n // SVG's getBBox doesn't count empty lines. The use case is tooltip\n // where the header is empty. By doing this in the DOM rather than in\n // the AST, we can inspect the textContent directly and don't have to\n // recurse down to look for valid content.\n var firstChild;\n while ((firstChild = wrapper.element.firstChild)) {\n if (/^[\\s\\u200B]*$/.test(firstChild.textContent || ' ')) {\n wrapper.element.removeChild(firstChild);\n }\n else {\n break;\n }\n }\n // Modify hard line breaks by applying the rendered line height\n [].forEach.call(wrapper.element.querySelectorAll('tspan.highcharts-br'), function (br, i) {\n if (br.nextSibling && br.previousSibling) { // #5261\n if (i === 0 && br.previousSibling.nodeType === 1) {\n wrapper.firstLineMetrics = wrapper.renderer\n .fontMetrics(void 0, br.previousSibling);\n }\n attr(br, {\n // Since the break is inserted in front of the next\n // line, we need to use the next sibling for the line\n // height\n dy: _this.getLineHeight(br.nextSibling),\n x: x\n });\n }\n });\n // Constrain the line width, either by ellipsis or wrapping\n var width = this.width || 0;\n if (!width) {\n return;\n }\n // Insert soft line breaks into each text node\n var modifyTextNode = function (textNode,\n parentElement) {\n var text = textNode.textContent || '';\n var words = text\n .replace(/([^\\^])-/g, '$1- ') // Split on hyphens\n // .trim()\n .split(' '); // #1273\n var hasWhiteSpace = !_this.noWrap && (words.length > 1 || wrapper.element.childNodes.length > 1);\n var dy = _this.getLineHeight(parentElement);\n var lineNo = 0;\n var startAt = wrapper.actualWidth;\n if (_this.ellipsis) {\n if (text) {\n _this.truncate(textNode, text, void 0, 0, \n // Target width\n Math.max(0, \n // Substract the font face to make room for the\n // ellipsis itself\n width - parseInt(_this.fontSize || 12, 10)), \n // Build the text to test for\n function (text, currentIndex) {\n return text.substring(0, currentIndex) + '\\u2026';\n });\n }\n }\n else if (hasWhiteSpace) {\n var lines = [];\n // Remove preceding siblings in order to make the text length\n // calculation correct in the truncate function\n var precedingSiblings = [];\n while (parentElement.firstChild &&\n parentElement.firstChild !== textNode) {\n precedingSiblings.push(parentElement.firstChild);\n parentElement.removeChild(parentElement.firstChild);\n }\n while (words.length) {\n // Apply the previous line\n if (words.length && !_this.noWrap && lineNo > 0) {\n lines.push(textNode.textContent || '');\n textNode.textContent = words.join(' ')\n .replace(/- /g, '-');\n }\n // For each line, truncate the remaining\n // words into the line length.\n _this.truncate(textNode, void 0, words, lineNo === 0 ? (startAt || 0) : 0, width, \n // Build the text to test for\n function (t, currentIndex) {\n return words\n .slice(0, currentIndex)\n .join(' ')\n .replace(/- /g, '-');\n });\n startAt = wrapper.actualWidth;\n lineNo++;\n }\n // Reinsert the preceding child nodes\n precedingSiblings.forEach(function (childNode) {\n parentElement.insertBefore(childNode, textNode);\n });\n // Insert the previous lines before the original text node\n lines.forEach(function (line) {\n // Insert the line\n parentElement.insertBefore(doc.createTextNode(line), textNode);\n // Insert a break\n var br = doc.createElementNS(SVG_NS, 'tspan');\n br.textContent = '\\u200B'; // zero-width space\n attr(br, { dy: dy, x: x });\n parentElement.insertBefore(br, textNode);\n });\n }\n };\n // Recurse down the DOM tree and handle line breaks for each text node\n var modifyChildren = (function (node) {\n var childNodes = [].slice.call(node.childNodes);\n childNodes.forEach(function (childNode) {\n if (childNode.nodeType === win.Node.TEXT_NODE) {\n modifyTextNode(childNode, node);\n }\n else {\n // Reset word-wrap width readings after hard breaks\n if (childNode.className.baseVal\n .indexOf('highcharts-br') !== -1) {\n wrapper.actualWidth = 0;\n }\n // Recurse down to child node\n modifyChildren(childNode);\n }\n });\n });\n modifyChildren(wrapper.element);\n };\n /**\n * Get the rendered line height of a , or pure text node.\n *\n * @param {DOMElementType|Text} node The node to check for\n *\n * @return {number} The rendered line height\n */\n TextBuilder.prototype.getLineHeight = function (node) {\n var fontSizeStyle;\n // If the node is a text node, use its parent\n var element = (node.nodeType === win.Node.TEXT_NODE) ?\n node.parentElement :\n node;\n if (!this.renderer.styledMode) {\n fontSizeStyle =\n element && /(px|em)$/.test(element.style.fontSize) ?\n element.style.fontSize :\n (this.fontSize || this.renderer.style.fontSize || 12);\n }\n return this.textLineHeight ?\n parseInt(this.textLineHeight.toString(), 10) :\n this.renderer.fontMetrics(fontSizeStyle, element || this.svgElement.element).h;\n };\n /**\n * Transform a pseudo HTML AST node tree into an SVG structure. We do as\n * much heavy lifting as we can here, before doing the final processing in\n * the modifyDOM function. The original data is mutated.\n *\n * @private\n *\n * @param {ASTNode[]} nodes The AST nodes\n *\n */\n TextBuilder.prototype.modifyTree = function (nodes) {\n var _this = this;\n var modifyChild = function (node,\n i) {\n var _a = node.attributes,\n attributes = _a === void 0 ? {} : _a,\n children = node.children,\n _b = node.style,\n style = _b === void 0 ? {} : _b,\n tagName = node.tagName,\n styledMode = _this.renderer.styledMode;\n // Apply styling to text tags\n if (tagName === 'b' || tagName === 'strong') {\n if (styledMode) {\n // eslint-disable-next-line dot-notation\n attributes['class'] = 'highcharts-strong';\n }\n else {\n style.fontWeight = 'bold';\n }\n }\n else if (tagName === 'i' || tagName === 'em') {\n if (styledMode) {\n // eslint-disable-next-line dot-notation\n attributes['class'] = 'highcharts-emphasized';\n }\n else {\n style.fontStyle = 'italic';\n }\n }\n // Modify styling\n if (style && style.color) {\n style.fill = style.color;\n }\n // Handle breaks\n if (tagName === 'br') {\n attributes['class'] = 'highcharts-br'; // eslint-disable-line dot-notation\n node.textContent = '\\u200B'; // zero-width space\n // Trim whitespace off the beginning of new lines\n var nextNode = nodes[i + 1];\n if (nextNode && nextNode.textContent) {\n nextNode.textContent =\n nextNode.textContent.replace(/^ +/gm, '');\n }\n // If an anchor has direct text node children, the text is unable to\n // wrap because there is no `getSubStringLength` function on the\n // element. Therefore we need to wrap the child text node or nodes\n // in a tspan. #16173.\n }\n else if (tagName === 'a' &&\n children &&\n children.some(function (child) { return child.tagName === '#text'; })) {\n node.children = [{ children: children, tagName: 'tspan' }];\n }\n if (tagName !== '#text' && tagName !== 'a') {\n node.tagName = 'tspan';\n }\n extend(node, { attributes: attributes, style: style });\n // Recurse\n if (children) {\n children\n .filter(function (c) { return c.tagName !== '#text'; })\n .forEach(modifyChild);\n }\n };\n nodes.forEach(modifyChild);\n fireEvent(this.svgElement, 'afterModifyTree', { nodes: nodes });\n };\n /*\n * Truncate the text node contents to a given length. Used when the css\n * width is set. If the `textOverflow` is `ellipsis`, the text is truncated\n * character by character to the given length. If not, the text is\n * word-wrapped line by line.\n */\n TextBuilder.prototype.truncate = function (textNode, text, words, startAt, width, getString) {\n var svgElement = this.svgElement;\n var renderer = svgElement.renderer,\n rotation = svgElement.rotation;\n // Cache the lengths to avoid checking the same twice\n var lengths = [];\n // Word wrap cannot be truncated to shorter than one word, ellipsis\n // text can be completely blank.\n var minIndex = words ? 1 : 0;\n var maxIndex = (text || words || '').length;\n var currentIndex = maxIndex;\n var str;\n var actualWidth;\n var getSubStringLength = function (charEnd,\n concatenatedEnd) {\n // charEnd is used when finding the character-by-character\n // break for ellipsis, concatenatedEnd is used for word-by-word\n // break for word wrapping.\n var end = concatenatedEnd || charEnd;\n var parentNode = textNode.parentNode;\n if (parentNode && typeof lengths[end] === 'undefined') {\n // Modern browsers\n if (parentNode.getSubStringLength) {\n // Fails with DOM exception on unit-tests/legend/members\n // of unknown reason. Desired width is 0, text content\n // is \"5\" and end is 1.\n try {\n lengths[end] = startAt +\n parentNode.getSubStringLength(0, words ? end + 1 : end);\n }\n catch (e) {\n '';\n }\n // Legacy\n }\n else if (renderer.getSpanWidth) { // #9058 jsdom\n textNode.textContent = getString(text || words, charEnd);\n lengths[end] = startAt +\n renderer.getSpanWidth(svgElement, textNode);\n }\n }\n return lengths[end];\n };\n svgElement.rotation = 0; // discard rotation when computing box\n actualWidth = getSubStringLength(textNode.textContent.length);\n if (startAt + actualWidth > width) {\n // Do a binary search for the index where to truncate the text\n while (minIndex <= maxIndex) {\n currentIndex = Math.ceil((minIndex + maxIndex) / 2);\n // When checking words for word-wrap, we need to build the\n // string and measure the subStringLength at the concatenated\n // word length.\n if (words) {\n str = getString(words, currentIndex);\n }\n actualWidth = getSubStringLength(currentIndex, str && str.length - 1);\n if (minIndex === maxIndex) {\n // Complete\n minIndex = maxIndex + 1;\n }\n else if (actualWidth > width) {\n // Too large. Set max index to current.\n maxIndex = currentIndex - 1;\n }\n else {\n // Within width. Set min index to current.\n minIndex = currentIndex;\n }\n }\n // If max index was 0 it means the shortest possible text was also\n // too large. For ellipsis that means only the ellipsis, while for\n // word wrap it means the whole first word.\n if (maxIndex === 0) {\n // Remove ellipsis\n textNode.textContent = '';\n // If the new text length is one less than the original, we don't\n // need the ellipsis\n }\n else if (!(text && maxIndex === text.length - 1)) {\n textNode.textContent = str || getString(text || words, currentIndex);\n }\n }\n // When doing line wrapping, prepare for the next line by removing the\n // items from this line.\n if (words) {\n words.splice(0, currentIndex);\n }\n svgElement.actualWidth = actualWidth;\n svgElement.rotation = rotation; // Apply rotation again.\n };\n /*\n * Un-escape HTML entities based on the public `renderer.escapes` list\n *\n * @private\n *\n * @param {string} inputStr The string to unescape\n * @param {Array} [except] Exceptions\n *\n * @return {string} The processed string\n */\n TextBuilder.prototype.unescapeEntities = function (inputStr, except) {\n objectEach(this.renderer.escapes, function (value, key) {\n if (!except || except.indexOf(value) === -1) {\n inputStr = inputStr.toString().replace(new RegExp(value, 'g'), key);\n }\n });\n return inputStr;\n };\n return TextBuilder;\n }());\n\n return TextBuilder;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/SVGRenderer.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Renderer/SVG/SVGLabel.js'], _modules['Core/Renderer/SVG/Symbols.js'], _modules['Core/Renderer/SVG/TextBuilder.js'], _modules['Core/Utilities.js']], function (AST, Color, H, RendererRegistry, SVGElement, SVGLabel, Symbols, TextBuilder, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var charts = H.charts,\n deg2rad = H.deg2rad,\n doc = H.doc,\n isFirefox = H.isFirefox,\n isMS = H.isMS,\n isWebKit = H.isWebKit,\n noop = H.noop,\n SVG_NS = H.SVG_NS,\n symbolSizes = H.symbolSizes,\n win = H.win;\n var addEvent = U.addEvent,\n attr = U.attr,\n createElement = U.createElement,\n css = U.css,\n defined = U.defined,\n destroyObjectProperties = U.destroyObjectProperties,\n extend = U.extend,\n isArray = U.isArray,\n isNumber = U.isNumber,\n isObject = U.isObject,\n isString = U.isString,\n merge = U.merge,\n pick = U.pick,\n pInt = U.pInt,\n uniqueKey = U.uniqueKey;\n /* *\n *\n * Variables\n *\n * */\n var hasInternalReferenceBug;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Allows direct access to the Highcharts rendering layer in order to draw\n * primitive shapes like circles, rectangles, paths or text directly on a chart,\n * or independent from any chart. The SVGRenderer represents a wrapper object\n * for SVG in modern browsers. Through the VMLRenderer, part of the `oldie.js`\n * module, it also brings vector graphics to IE <= 8.\n *\n * An existing chart's renderer can be accessed through {@link Chart.renderer}.\n * The renderer can also be used completely decoupled from a chart.\n *\n * @sample highcharts/members/renderer-on-chart\n * Annotating a chart programmatically.\n * @sample highcharts/members/renderer-basic\n * Independent SVG drawing.\n *\n * @example\n * // Use directly without a chart object.\n * let renderer = new Highcharts.Renderer(parentNode, 600, 400);\n *\n * @class\n * @name Highcharts.SVGRenderer\n *\n * @param {Highcharts.HTMLDOMElement} container\n * Where to put the SVG in the web page.\n *\n * @param {number} width\n * The width of the SVG.\n *\n * @param {number} height\n * The height of the SVG.\n *\n * @param {Highcharts.CSSObject} [style]\n * The box style, if not in styleMode\n *\n * @param {boolean} [forExport=false]\n * Whether the rendered content is intended for export.\n *\n * @param {boolean} [allowHTML=true]\n * Whether the renderer is allowed to include HTML text, which will be\n * projected on top of the SVG.\n *\n * @param {boolean} [styledMode=false]\n * Whether the renderer belongs to a chart that is in styled mode.\n * If it does, it will avoid setting presentational attributes in\n * some cases, but not when set explicitly through `.attr` and `.css`\n * etc.\n */\n var SVGRenderer = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function SVGRenderer(container, width, height, style, forExport, allowHTML, styledMode) {\n /* *\n *\n * Properties\n *\n * */\n this.alignedObjects = void 0;\n /**\n * The root `svg` node of the renderer.\n *\n * @name Highcharts.SVGRenderer#box\n * @type {Highcharts.SVGDOMElement}\n */\n this.box = void 0;\n /**\n * The wrapper for the root `svg` node of the renderer.\n *\n * @name Highcharts.SVGRenderer#boxWrapper\n * @type {Highcharts.SVGElement}\n */\n this.boxWrapper = void 0;\n this.cache = void 0;\n this.cacheKeys = void 0;\n this.chartIndex = void 0;\n /**\n * A pointer to the `defs` node of the root SVG.\n *\n * @name Highcharts.SVGRenderer#defs\n * @type {Highcharts.SVGElement}\n */\n this.defs = void 0;\n this.globalAnimation = void 0;\n this.gradients = void 0;\n this.height = void 0;\n this.imgCount = void 0;\n this.isSVG = void 0;\n this.style = void 0;\n /**\n * Page url used for internal references.\n *\n * @private\n * @name Highcharts.SVGRenderer#url\n * @type {string}\n */\n this.url = void 0;\n this.width = void 0;\n this.init(container, width, height, style, forExport, allowHTML, styledMode);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Initialize the SVGRenderer. Overridable initializer function that takes\n * the same parameters as the constructor.\n *\n * @function Highcharts.SVGRenderer#init\n *\n * @param {Highcharts.HTMLDOMElement} container\n * Where to put the SVG in the web page.\n *\n * @param {number} width\n * The width of the SVG.\n *\n * @param {number} height\n * The height of the SVG.\n *\n * @param {Highcharts.CSSObject} [style]\n * The box style, if not in styleMode\n *\n * @param {boolean} [forExport=false]\n * Whether the rendered content is intended for export.\n *\n * @param {boolean} [allowHTML=true]\n * Whether the renderer is allowed to include HTML text, which will be\n * projected on top of the SVG.\n *\n * @param {boolean} [styledMode=false]\n * Whether the renderer belongs to a chart that is in styled mode. If it\n * does, it will avoid setting presentational attributes in some cases, but\n * not when set explicitly through `.attr` and `.css` etc.\n */\n SVGRenderer.prototype.init = function (container, width, height, style, forExport, allowHTML, styledMode) {\n var renderer = this,\n boxWrapper = renderer\n .createElement('svg')\n .attr({\n version: '1.1',\n 'class': 'highcharts-root'\n }),\n element = boxWrapper.element;\n if (!styledMode) {\n boxWrapper.css(this.getStyle(style));\n }\n container.appendChild(element);\n // Always use ltr on the container, otherwise text-anchor will be\n // flipped and text appear outside labels, buttons, tooltip etc (#3482)\n attr(container, 'dir', 'ltr');\n // For browsers other than IE, add the namespace attribute (#1978)\n if (container.innerHTML.indexOf('xmlns') === -1) {\n attr(element, 'xmlns', this.SVG_NS);\n }\n // object properties\n renderer.isSVG = true;\n this.box = element;\n this.boxWrapper = boxWrapper;\n renderer.alignedObjects = [];\n this.url = this.getReferenceURL();\n // Add description\n var desc = this.createElement('desc').add();\n desc.element.appendChild(doc.createTextNode('Created with Highcharts 10.3.1'));\n renderer.defs = this.createElement('defs').add();\n renderer.allowHTML = allowHTML;\n renderer.forExport = forExport;\n renderer.styledMode = styledMode;\n renderer.gradients = {}; // Object where gradient SvgElements are stored\n renderer.cache = {}; // Cache for numerical bounding boxes\n renderer.cacheKeys = [];\n renderer.imgCount = 0;\n renderer.setSize(width, height, false);\n // Issue 110 workaround:\n // In Firefox, if a div is positioned by percentage, its pixel position\n // may land between pixels. The container itself doesn't display this,\n // but an SVG element inside this container will be drawn at subpixel\n // precision. In order to draw sharp lines, this must be compensated\n // for. This doesn't seem to work inside iframes though (like in\n // jsFiddle).\n var subPixelFix,\n rect;\n if (isFirefox && container.getBoundingClientRect) {\n subPixelFix = function () {\n css(container, { left: 0, top: 0 });\n rect = container.getBoundingClientRect();\n css(container, {\n left: (Math.ceil(rect.left) - rect.left) + 'px',\n top: (Math.ceil(rect.top) - rect.top) + 'px'\n });\n };\n // run the fix now\n subPixelFix();\n // run it on resize\n renderer.unSubPixelFix = addEvent(win, 'resize', subPixelFix);\n }\n };\n /**\n * General method for adding a definition to the SVG `defs` tag. Can be used\n * for gradients, fills, filters etc. Styled mode only. A hook for adding\n * general definitions to the SVG's defs tag. Definitions can be referenced\n * from the CSS by its `id`. Read more in\n * [gradients, shadows and patterns](https://www.highcharts.com/docs/chart-design-and-style/gradients-shadows-and-patterns).\n * Styled mode only.\n *\n * @function Highcharts.SVGRenderer#definition\n *\n * @param {Highcharts.ASTNode} def\n * A serialized form of an SVG definition, including children.\n *\n * @return {Highcharts.SVGElement}\n * The inserted node.\n */\n SVGRenderer.prototype.definition = function (def) {\n var ast = new AST([def]);\n return ast.addToDOM(this.defs.element);\n };\n /**\n * Get the prefix needed for internal URL references to work in certain\n * cases. Some older browser versions had a bug where internal url\n * references in SVG attributes, on the form `url(#some-id)`, would fail if\n * a base tag was present in the page. There were also issues with\n * `history.pushState` related to this prefix.\n *\n * Related issues: #24, #672, #1070, #5244.\n *\n * The affected browsers are:\n * - Chrome <= 53 (May 2018)\n * - Firefox <= 51 (January 2017)\n * - Safari/Mac <= 12.1 (2018 or 2019)\n * - Safari/iOS <= 13\n *\n * @todo Remove this hack when time has passed. All the affected browsers\n * are evergreens, so it is increasingly unlikely that users are affected by\n * the bug.\n *\n * @return {string}\n * The prefix to use. An empty string for modern browsers.\n */\n SVGRenderer.prototype.getReferenceURL = function () {\n if ((isFirefox || isWebKit) &&\n doc.getElementsByTagName('base').length) {\n // Detect if a clip path is taking effect by performing a hit test\n // outside the clipped area. If the hit element is the rectangle\n // that was supposed to be clipped, the bug is present. This only\n // has to be performed once per page load, so we store the result\n // locally in the module.\n if (!defined(hasInternalReferenceBug)) {\n var id = uniqueKey();\n var ast = new AST([{\n tagName: 'svg',\n attributes: {\n width: 8,\n height: 8\n },\n children: [{\n tagName: 'defs',\n children: [{\n tagName: 'clipPath',\n attributes: {\n id: id\n },\n children: [{\n tagName: 'rect',\n attributes: {\n width: 4,\n height: 4\n }\n }]\n }]\n }, {\n tagName: 'rect',\n attributes: {\n id: 'hitme',\n width: 8,\n height: 8,\n 'clip-path': \"url(#\".concat(id, \")\"),\n fill: 'rgba(0,0,0,0.001)'\n }\n }]\n }]);\n var svg = ast.addToDOM(doc.body);\n css(svg, {\n position: 'fixed',\n top: 0,\n left: 0,\n zIndex: 9e5\n });\n var hitElement = doc.elementFromPoint(6, 6);\n hasInternalReferenceBug = (hitElement && hitElement.id) === 'hitme';\n doc.body.removeChild(svg);\n }\n if (hasInternalReferenceBug) {\n return win.location.href\n .split('#')[0] // remove the hash\n .replace(/<[^>]*>/g, '') // wing cut HTML\n // escape parantheses and quotes\n .replace(/([\\('\\)])/g, '\\\\$1')\n // replace spaces (needed for Safari only)\n .replace(/ /g, '%20');\n }\n }\n return '';\n };\n /**\n * Get the global style setting for the renderer.\n *\n * @private\n * @function Highcharts.SVGRenderer#getStyle\n *\n * @param {Highcharts.CSSObject} style\n * Style settings.\n *\n * @return {Highcharts.CSSObject}\n * The style settings mixed with defaults.\n */\n SVGRenderer.prototype.getStyle = function (style) {\n this.style = extend({\n fontFamily: '\"Lucida Grande\", \"Lucida Sans Unicode\", ' +\n 'Arial, Helvetica, sans-serif',\n fontSize: '12px'\n }, style);\n return this.style;\n };\n /**\n * Apply the global style on the renderer, mixed with the default styles.\n *\n * @function Highcharts.SVGRenderer#setStyle\n *\n * @param {Highcharts.CSSObject} style\n * CSS to apply.\n */\n SVGRenderer.prototype.setStyle = function (style) {\n this.boxWrapper.css(this.getStyle(style));\n };\n /**\n * Detect whether the renderer is hidden. This happens when one of the\n * parent elements has `display: none`. Used internally to detect when we\n * needto render preliminarily in another div to get the text bounding boxes\n * right.\n *\n * @function Highcharts.SVGRenderer#isHidden\n *\n * @return {boolean}\n * True if it is hidden.\n */\n SVGRenderer.prototype.isHidden = function () {\n return !this.boxWrapper.getBBox().width;\n };\n /**\n * Destroys the renderer and its allocated members.\n *\n * @function Highcharts.SVGRenderer#destroy\n *\n * @return {null}\n * Pass through value.\n */\n SVGRenderer.prototype.destroy = function () {\n var renderer = this,\n rendererDefs = renderer.defs;\n renderer.box = null;\n renderer.boxWrapper = renderer.boxWrapper.destroy();\n // Call destroy on all gradient elements\n destroyObjectProperties(renderer.gradients || {});\n renderer.gradients = null;\n // Defs are null in VMLRenderer\n // Otherwise, destroy them here.\n if (rendererDefs) {\n renderer.defs = rendererDefs.destroy();\n }\n // Remove sub pixel fix handler (#982)\n if (renderer.unSubPixelFix) {\n renderer.unSubPixelFix();\n }\n renderer.alignedObjects = null;\n return null;\n };\n /**\n * Create a wrapper for an SVG element. Serves as a factory for\n * {@link SVGElement}, but this function is itself mostly called from\n * primitive factories like {@link SVGRenderer#path}, {@link\n * SVGRenderer#rect} or {@link SVGRenderer#text}.\n *\n * @function Highcharts.SVGRenderer#createElement\n *\n * @param {string} nodeName\n * The node name, for example `rect`, `g` etc.\n *\n * @return {Highcharts.SVGElement}\n * The generated SVGElement.\n */\n SVGRenderer.prototype.createElement = function (nodeName) {\n var wrapper = new this.Element();\n wrapper.init(this, nodeName);\n return wrapper;\n };\n /**\n * Get converted radial gradient attributes according to the radial\n * reference. Used internally from the {@link SVGElement#colorGradient}\n * function.\n *\n * @private\n * @function Highcharts.SVGRenderer#getRadialAttr\n */\n SVGRenderer.prototype.getRadialAttr = function (radialReference, gradAttr) {\n return {\n cx: (radialReference[0] - radialReference[2] / 2) +\n (gradAttr.cx || 0) * radialReference[2],\n cy: (radialReference[1] - radialReference[2] / 2) +\n (gradAttr.cy || 0) * radialReference[2],\n r: (gradAttr.r || 0) * radialReference[2]\n };\n };\n /**\n * Parse a simple HTML string into SVG tspans. Called internally when text\n * is set on an SVGElement. The function supports a subset of HTML tags, CSS\n * text features like `width`, `text-overflow`, `white-space`, and also\n * attributes like `href` and `style`.\n *\n * @private\n * @function Highcharts.SVGRenderer#buildText\n *\n * @param {Highcharts.SVGElement} wrapper\n * The parent SVGElement.\n */\n SVGRenderer.prototype.buildText = function (wrapper) {\n new TextBuilder(wrapper).buildSVG();\n };\n /**\n * Returns white for dark colors and black for bright colors, based on W3C's\n * definition of [Relative luminance](\n * https://www.w3.org/WAI/GL/wiki/Relative_luminance).\n *\n * @function Highcharts.SVGRenderer#getContrast\n *\n * @param {Highcharts.ColorString} color\n * The color to get the contrast for.\n *\n * @return {Highcharts.ColorString}\n * The contrast color, either `#000000` or `#FFFFFF`.\n */\n SVGRenderer.prototype.getContrast = function (color) {\n // #6216, #17273\n var rgba = Color.parse(color).rgba\n .map(function (b8) {\n var c = b8 / 255;\n return c <= 0.03928 ?\n c / 12.92 :\n Math.pow((c + 0.055) / 1.055, 2.4);\n });\n // Relative luminance\n var l = 0.2126 * rgba[0] + 0.7152 * rgba[1] + 0.0722 * rgba[2];\n // Use white or black based on which provides more contrast\n return 1.05 / (l + 0.05) > (l + 0.05) / 0.05 ? '#FFFFFF' : '#000000';\n };\n /**\n * Create a button with preset states.\n *\n * @function Highcharts.SVGRenderer#button\n *\n * @param {string} text\n * The text or HTML to draw.\n *\n * @param {number} x\n * The x position of the button's left side.\n *\n * @param {number} y\n * The y position of the button's top side.\n *\n * @param {Highcharts.EventCallbackFunction} callback\n * The function to execute on button click or touch.\n *\n * @param {Highcharts.SVGAttributes} [theme]\n * SVG attributes for the normal state.\n *\n * @param {Highcharts.SVGAttributes} [hoverState]\n * SVG attributes for the hover state.\n *\n * @param {Highcharts.SVGAttributes} [selectState]\n * SVG attributes for the pressed state.\n *\n * @param {Highcharts.SVGAttributes} [disabledState]\n * SVG attributes for the disabled state.\n *\n * @param {Highcharts.SymbolKeyValue} [shape=rect]\n * The shape type.\n *\n * @param {boolean} [useHTML=false]\n * Whether to use HTML to render the label.\n *\n * @return {Highcharts.SVGElement}\n * The button element.\n */\n SVGRenderer.prototype.button = function (text, x, y, callback, theme, hoverState, selectState, disabledState, shape, useHTML) {\n if (theme === void 0) { theme = {}; }\n var label = this.label(text,\n x,\n y,\n shape,\n void 0,\n void 0,\n useHTML,\n void 0, 'button'),\n styledMode = this.styledMode,\n states = theme.states || {};\n var curState = 0;\n theme = merge(theme);\n delete theme.states;\n var normalStyle = merge({\n color: \"#333333\" /* Palette.neutralColor80 */,\n cursor: 'pointer',\n fontWeight: 'normal'\n },\n theme.style);\n delete theme.style;\n // Remove stylable attributes. Pass in the ButtonThemeObject and get the\n // SVGAttributes subset back.\n var normalState = AST.filterUserAttributes(theme);\n // Default, non-stylable attributes\n label.attr(merge({ padding: 8, r: 2 }, normalState));\n // Presentational. The string type is a mistake, it is just for\n // compliance with SVGAttribute and is not used in button theme.\n var hoverStyle,\n selectStyle,\n disabledStyle;\n if (!styledMode) {\n // Normal state - prepare the attributes\n normalState = merge({\n fill: \"#f7f7f7\" /* Palette.neutralColor3 */,\n stroke: \"#cccccc\" /* Palette.neutralColor20 */,\n 'stroke-width': 1\n }, normalState);\n // Hover state\n hoverState = merge(normalState, {\n fill: \"#e6e6e6\" /* Palette.neutralColor10 */\n }, AST.filterUserAttributes(hoverState || states.hover || {}));\n hoverStyle = hoverState.style;\n delete hoverState.style;\n // Pressed state\n selectState = merge(normalState, {\n fill: \"#e6ebf5\" /* Palette.highlightColor10 */,\n style: {\n color: \"#000000\" /* Palette.neutralColor100 */,\n fontWeight: 'bold'\n }\n }, AST.filterUserAttributes(selectState || states.select || {}));\n selectStyle = selectState.style;\n delete selectState.style;\n // Disabled state\n disabledState = merge(normalState, {\n style: {\n color: \"#cccccc\" /* Palette.neutralColor20 */\n }\n }, AST.filterUserAttributes(disabledState || states.disabled || {}));\n disabledStyle = disabledState.style;\n delete disabledState.style;\n }\n // Add the events. IE9 and IE10 need mouseover and mouseout to function\n // (#667).\n addEvent(label.element, isMS ? 'mouseover' : 'mouseenter', function () {\n if (curState !== 3) {\n label.setState(1);\n }\n });\n addEvent(label.element, isMS ? 'mouseout' : 'mouseleave', function () {\n if (curState !== 3) {\n label.setState(curState);\n }\n });\n label.setState = function (state) {\n // Hover state is temporary, don't record it\n if (state !== 1) {\n label.state = curState = state;\n }\n // Update visuals\n label\n .removeClass(/highcharts-button-(normal|hover|pressed|disabled)/)\n .addClass('highcharts-button-' +\n ['normal', 'hover', 'pressed', 'disabled'][state || 0]);\n if (!styledMode) {\n label\n .attr([\n normalState,\n hoverState,\n selectState,\n disabledState\n ][state || 0]);\n var css_1 = [\n normalStyle,\n hoverStyle,\n selectStyle,\n disabledStyle\n ][state || 0];\n if (isObject(css_1)) {\n label.css(css_1);\n }\n }\n };\n // Presentational attributes\n if (!styledMode) {\n label\n .attr(normalState)\n .css(extend({ cursor: 'default' }, normalStyle));\n // HTML labels don't need to handle pointer events because click and\n // mouseenter/mouseleave is bound to the underlying element.\n // Should this be reconsidered, we need more complex logic to share\n // events between the and its
counterpart, and avoid\n // triggering mouseenter/mouseleave when hovering from one to the\n // other (#17440).\n if (useHTML) {\n label.text.css({ pointerEvents: 'none' });\n }\n }\n return label\n .on('touchstart', function (e) { return e.stopPropagation(); })\n .on('click', function (e) {\n if (curState !== 3) {\n callback.call(label, e);\n }\n });\n };\n /**\n * Make a straight line crisper by not spilling out to neighbour pixels.\n *\n * @function Highcharts.SVGRenderer#crispLine\n *\n * @param {Highcharts.SVGPathArray} points\n * The original points on the format `[['M', 0, 0], ['L', 100, 0]]`.\n *\n * @param {number} width\n * The width of the line.\n *\n * @param {string} [roundingFunction=round]\n * The rounding function name on the `Math` object, can be one of\n * `round`, `floor` or `ceil`.\n *\n * @return {Highcharts.SVGPathArray}\n * The original points array, but modified to render crisply.\n */\n SVGRenderer.prototype.crispLine = function (points, width, roundingFunction) {\n if (roundingFunction === void 0) { roundingFunction = 'round'; }\n var start = points[0];\n var end = points[1];\n // Normalize to a crisp line\n if (defined(start[1]) && start[1] === end[1]) {\n // Substract due to #1129. Now bottom and left axis gridlines behave\n // the same.\n start[1] = end[1] =\n Math[roundingFunction](start[1]) - (width % 2 / 2);\n }\n if (defined(start[2]) && start[2] === end[2]) {\n start[2] = end[2] =\n Math[roundingFunction](start[2]) + (width % 2 / 2);\n }\n return points;\n };\n /**\n * Draw a path, wraps the SVG `path` element.\n *\n * @sample highcharts/members/renderer-path-on-chart/\n * Draw a path in a chart\n * @sample highcharts/members/renderer-path/\n * Draw a path independent from a chart\n *\n * @example\n * let path = renderer.path(['M', 10, 10, 'L', 30, 30, 'z'])\n * .attr({ stroke: '#ff00ff' })\n * .add();\n *\n * @function Highcharts.SVGRenderer#path\n *\n * @param {Highcharts.SVGPathArray} [path]\n * An SVG path definition in array form.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n *\n */ /**\n * Draw a path, wraps the SVG `path` element.\n *\n * @function Highcharts.SVGRenderer#path\n *\n * @param {Highcharts.SVGAttributes} [attribs]\n * The initial attributes.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n SVGRenderer.prototype.path = function (path) {\n var attribs = (this.styledMode ? {} : {\n fill: 'none'\n });\n if (isArray(path)) {\n attribs.d = path;\n }\n else if (isObject(path)) { // attributes\n extend(attribs, path);\n }\n return this.createElement('path').attr(attribs);\n };\n /**\n * Draw a circle, wraps the SVG `circle` element.\n *\n * @sample highcharts/members/renderer-circle/\n * Drawing a circle\n *\n * @function Highcharts.SVGRenderer#circle\n *\n * @param {number} [x]\n * The center x position.\n *\n * @param {number} [y]\n * The center y position.\n *\n * @param {number} [r]\n * The radius.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */ /**\n * Draw a circle, wraps the SVG `circle` element.\n *\n * @function Highcharts.SVGRenderer#circle\n *\n * @param {Highcharts.SVGAttributes} [attribs]\n * The initial attributes.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n SVGRenderer.prototype.circle = function (x, y, r) {\n var attribs = (isObject(x) ?\n x :\n typeof x === 'undefined' ? {} : { x: x, y: y, r: r }), wrapper = this.createElement('circle');\n // Setting x or y translates to cx and cy\n wrapper.xSetter = wrapper.ySetter = function (value, key, element) {\n element.setAttribute('c' + key, value);\n };\n return wrapper.attr(attribs);\n };\n /**\n * Draw and return an arc.\n *\n * @sample highcharts/members/renderer-arc/\n * Drawing an arc\n *\n * @function Highcharts.SVGRenderer#arc\n *\n * @param {number} [x=0]\n * Center X position.\n *\n * @param {number} [y=0]\n * Center Y position.\n *\n * @param {number} [r=0]\n * The outer radius' of the arc.\n *\n * @param {number} [innerR=0]\n * Inner radius like used in donut charts.\n *\n * @param {number} [start=0]\n * The starting angle of the arc in radians, where 0 is to the right and\n * `-Math.PI/2` is up.\n *\n * @param {number} [end=0]\n * The ending angle of the arc in radians, where 0 is to the right and\n * `-Math.PI/2` is up.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */ /**\n * Draw and return an arc. Overloaded function that takes arguments object.\n *\n * @function Highcharts.SVGRenderer#arc\n *\n * @param {Highcharts.SVGAttributes} attribs\n * Initial SVG attributes.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n SVGRenderer.prototype.arc = function (x, y, r, innerR, start, end) {\n var options;\n if (isObject(x)) {\n options = x;\n y = options.y;\n r = options.r;\n innerR = options.innerR;\n start = options.start;\n end = options.end;\n x = options.x;\n }\n else {\n options = { innerR: innerR, start: start, end: end };\n }\n // Arcs are defined as symbols for the ability to set\n // attributes in attr and animate\n var arc = this.symbol('arc',\n x,\n y,\n r,\n r,\n options);\n arc.r = r; // #959\n return arc;\n };\n /**\n * Draw and return a rectangle.\n *\n * @function Highcharts.SVGRenderer#rect\n *\n * @param {number} [x]\n * Left position.\n *\n * @param {number} [y]\n * Top position.\n *\n * @param {number} [width]\n * Width of the rectangle.\n *\n * @param {number} [height]\n * Height of the rectangle.\n *\n * @param {number} [r]\n * Border corner radius.\n *\n * @param {number} [strokeWidth]\n * A stroke width can be supplied to allow crisp drawing.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */ /**\n * Draw and return a rectangle.\n *\n * @sample highcharts/members/renderer-rect-on-chart/\n * Draw a rectangle in a chart\n * @sample highcharts/members/renderer-rect/\n * Draw a rectangle independent from a chart\n *\n * @function Highcharts.SVGRenderer#rect\n *\n * @param {Highcharts.SVGAttributes} [attributes]\n * General SVG attributes for the rectangle.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n SVGRenderer.prototype.rect = function (x, y, width, height, r, strokeWidth) {\n r = isObject(x) ? x.r : r;\n var wrapper = this.createElement('rect');\n var attribs = (isObject(x) ?\n x :\n typeof x === 'undefined' ?\n {} :\n {\n x: x,\n y: y,\n width: Math.max(width, 0),\n height: Math.max(height, 0)\n });\n if (!this.styledMode) {\n if (typeof strokeWidth !== 'undefined') {\n attribs['stroke-width'] = strokeWidth;\n attribs = wrapper.crisp(attribs);\n }\n attribs.fill = 'none';\n }\n if (r) {\n attribs.r = r;\n }\n wrapper.rSetter = function (value, _key, element) {\n wrapper.r = value;\n attr(element, {\n rx: value,\n ry: value\n });\n };\n wrapper.rGetter = function () {\n return wrapper.r || 0;\n };\n return wrapper.attr(attribs);\n };\n /**\n * Resize the {@link SVGRenderer#box} and re-align all aligned child\n * elements.\n *\n * @sample highcharts/members/renderer-g/\n * Show and hide grouped objects\n *\n * @function Highcharts.SVGRenderer#setSize\n *\n * @param {number} width\n * The new pixel width.\n *\n * @param {number} height\n * The new pixel height.\n *\n * @param {boolean|Partial} [animate=true]\n * Whether and how to animate.\n */\n SVGRenderer.prototype.setSize = function (width, height, animate) {\n var renderer = this;\n renderer.width = width;\n renderer.height = height;\n renderer.boxWrapper.animate({\n width: width,\n height: height\n }, {\n step: function () {\n this.attr({\n viewBox: '0 0 ' + this.attr('width') + ' ' +\n this.attr('height')\n });\n },\n duration: pick(animate, true) ? void 0 : 0\n });\n renderer.alignElements();\n };\n /**\n * Create and return an svg group element. Child\n * {@link Highcharts.SVGElement} objects are added to the group by using the\n * group as the first parameter in {@link Highcharts.SVGElement#add|add()}.\n *\n * @function Highcharts.SVGRenderer#g\n *\n * @param {string} [name]\n * The group will be given a class name of `highcharts-{name}`. This\n * can be used for styling and scripting.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n SVGRenderer.prototype.g = function (name) {\n var elem = this.createElement('g');\n return name ?\n elem.attr({ 'class': 'highcharts-' + name }) :\n elem;\n };\n /**\n * Display an image.\n *\n * @sample highcharts/members/renderer-image-on-chart/\n * Add an image in a chart\n * @sample highcharts/members/renderer-image/\n * Add an image independent of a chart\n *\n * @function Highcharts.SVGRenderer#image\n *\n * @param {string} src\n * The image source.\n *\n * @param {number} [x]\n * The X position.\n *\n * @param {number} [y]\n * The Y position.\n *\n * @param {number} [width]\n * The image width. If omitted, it defaults to the image file width.\n *\n * @param {number} [height]\n * The image height. If omitted it defaults to the image file\n * height.\n *\n * @param {Function} [onload]\n * Event handler for image load.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n SVGRenderer.prototype.image = function (src, x, y, width, height, onload) {\n var attribs = { preserveAspectRatio: 'none' }, setSVGImageSource = function (el, src) {\n // Set the href in the xlink namespace\n if (el.setAttributeNS) {\n el.setAttributeNS('http://www.w3.org/1999/xlink', 'href', src);\n }\n else {\n // could be exporting in IE\n // using href throws \"not supported\" in ie7 and under,\n // requries regex shim to fix later\n el.setAttribute('hc-svg-href', src);\n }\n };\n // Optional properties (#11756)\n if (isNumber(x)) {\n attribs.x = x;\n }\n if (isNumber(y)) {\n attribs.y = y;\n }\n if (isNumber(width)) {\n attribs.width = width;\n }\n if (isNumber(height)) {\n attribs.height = height;\n }\n var elemWrapper = this.createElement('image').attr(attribs),\n onDummyLoad = function (e) {\n setSVGImageSource(elemWrapper.element,\n src);\n onload.call(elemWrapper, e);\n };\n // Add load event if supplied\n if (onload) {\n // We have to use a dummy HTML image since IE support for SVG image\n // load events is very buggy. First set a transparent src, wait for\n // dummy to load, and then add the real src to the SVG image.\n setSVGImageSource(elemWrapper.element, 'data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==' /* eslint-disable-line */);\n var dummy = new win.Image();\n addEvent(dummy, 'load', onDummyLoad);\n dummy.src = src;\n if (dummy.complete) {\n onDummyLoad({});\n }\n }\n else {\n setSVGImageSource(elemWrapper.element, src);\n }\n return elemWrapper;\n };\n /**\n * Draw a symbol out of pre-defined shape paths from\n * {@link SVGRenderer#symbols}.\n * It is used in Highcharts for point makers, which cake a `symbol` option,\n * and label and button backgrounds like in the tooltip and stock flags.\n *\n * @function Highcharts.SVGRenderer#symbol\n *\n * @param {string} symbol\n * The symbol name.\n *\n * @param {number} [x]\n * The X coordinate for the top left position.\n *\n * @param {number} [y]\n * The Y coordinate for the top left position.\n *\n * @param {number} [width]\n * The pixel width.\n *\n * @param {number} [height]\n * The pixel height.\n *\n * @param {Highcharts.SymbolOptionsObject} [options]\n * Additional options, depending on the actual symbol drawn.\n *\n * @return {Highcharts.SVGElement}\n * SVG symbol.\n */\n SVGRenderer.prototype.symbol = function (symbol, x, y, width, height, options) {\n var ren = this,\n imageRegex = /^url\\((.*?)\\)$/,\n isImage = imageRegex.test(symbol),\n sym = (!isImage && (this.symbols[symbol] ? symbol : 'circle')), \n // get the symbol definition function\n symbolFn = (sym && this.symbols[sym]);\n var obj,\n path,\n imageSrc,\n centerImage;\n if (symbolFn) {\n // Check if there's a path defined for this symbol\n if (typeof x === 'number') {\n path = symbolFn.call(this.symbols, Math.round(x || 0), Math.round(y || 0), width || 0, height || 0, options);\n }\n obj = this.path(path);\n if (!ren.styledMode) {\n obj.attr('fill', 'none');\n }\n // expando properties for use in animate and attr\n extend(obj, {\n symbolName: (sym || void 0),\n x: x,\n y: y,\n width: width,\n height: height\n });\n if (options) {\n extend(obj, options);\n }\n // Image symbols\n }\n else if (isImage) {\n imageSrc = symbol.match(imageRegex)[1];\n // Create the image synchronously, add attribs async\n var img_1 = obj = this.image(imageSrc);\n // The image width is not always the same as the symbol width. The\n // image may be centered within the symbol, as is the case when\n // image shapes are used as label backgrounds, for example in flags.\n img_1.imgwidth = pick(symbolSizes[imageSrc] && symbolSizes[imageSrc].width, options && options.width);\n img_1.imgheight = pick(symbolSizes[imageSrc] && symbolSizes[imageSrc].height, options && options.height);\n /**\n * Set the size and position\n */\n centerImage = function (obj) { return obj.attr({\n width: obj.width,\n height: obj.height\n }); };\n /**\n * Width and height setters that take both the image's physical size\n * and the label size into consideration, and translates the image\n * to center within the label.\n */\n ['width', 'height'].forEach(function (key) {\n img_1[key + 'Setter'] = function (value, key) {\n this[key] = value;\n var _a = this,\n alignByTranslate = _a.alignByTranslate,\n element = _a.element,\n width = _a.width,\n height = _a.height,\n imgwidth = _a.imgwidth,\n imgheight = _a.imgheight;\n var imgSize = this['img' + key];\n if (defined(imgSize)) {\n var scale = 1;\n // Scale and center the image within its container.\n // The name `backgroundSize` is taken from the CSS spec,\n // but the value `within` is made up. Other possible\n // values in the spec, `cover` and `contain`, can be\n // implemented if needed.\n if (options &&\n options.backgroundSize === 'within' &&\n width &&\n height) {\n scale = Math.min(width / imgwidth, height / imgheight);\n imgSize = Math.round(imgSize * scale);\n // Update both width and height to keep the ratio\n // correct (#17315)\n attr(element, {\n width: Math.round(imgwidth * scale),\n height: Math.round(imgheight * scale)\n });\n }\n else if (element) {\n element.setAttribute(key, imgSize);\n }\n if (!alignByTranslate) {\n this.translate(((width || 0) - (imgSize * scale)) / 2, ((height || 0) - (imgSize * scale)) / 2);\n }\n }\n };\n });\n if (defined(x)) {\n img_1.attr({\n x: x,\n y: y\n });\n }\n img_1.isImg = true;\n if (defined(img_1.imgwidth) && defined(img_1.imgheight)) {\n centerImage(img_1);\n }\n else {\n // Initialize image to be 0 size so export will still function\n // if there's no cached sizes.\n img_1.attr({ width: 0, height: 0 });\n // Create a dummy JavaScript image to get the width and height.\n createElement('img', {\n onload: function () {\n var chart = charts[ren.chartIndex];\n // Special case for SVGs on IE11, the width is not\n // accessible until the image is part of the DOM\n // (#2854).\n if (this.width === 0) {\n css(this, {\n position: 'absolute',\n top: '-999em'\n });\n doc.body.appendChild(this);\n }\n // Center the image\n symbolSizes[imageSrc] = {\n width: this.width,\n height: this.height\n };\n img_1.imgwidth = this.width;\n img_1.imgheight = this.height;\n if (img_1.element) {\n centerImage(img_1);\n }\n // Clean up after #2854 workaround.\n if (this.parentNode) {\n this.parentNode.removeChild(this);\n }\n // Fire the load event when all external images are\n // loaded\n ren.imgCount--;\n if (!ren.imgCount && chart && !chart.hasLoaded) {\n chart.onload();\n }\n },\n src: imageSrc\n });\n this.imgCount++;\n }\n }\n return obj;\n };\n /**\n * Define a clipping rectangle. The clipping rectangle is later applied\n * to {@link SVGElement} objects through the {@link SVGElement#clip}\n * function.\n *\n * @example\n * let circle = renderer.circle(100, 100, 100)\n * .attr({ fill: 'red' })\n * .add();\n * let clipRect = renderer.clipRect(100, 100, 100, 100);\n *\n * // Leave only the lower right quarter visible\n * circle.clip(clipRect);\n *\n * @function Highcharts.SVGRenderer#clipRect\n *\n * @param {number} [x]\n *\n * @param {number} [y]\n *\n * @param {number} [width]\n *\n * @param {number} [height]\n *\n * @return {Highcharts.ClipRectElement}\n * A clipping rectangle.\n */\n SVGRenderer.prototype.clipRect = function (x, y, width, height) {\n var \n // Add a hyphen at the end to avoid confusion in testing indexes\n // -1 and -10, -11 etc (#6550)\n id = uniqueKey() + '-', clipPath = this.createElement('clipPath').attr({\n id: id\n }).add(this.defs), wrapper = this.rect(x, y, width, height, 0).add(clipPath);\n wrapper.id = id;\n wrapper.clipPath = clipPath;\n wrapper.count = 0;\n return wrapper;\n };\n /**\n * Draw text. The text can contain a subset of HTML, like spans and anchors\n * and some basic text styling of these. For more advanced features like\n * border and background, use {@link Highcharts.SVGRenderer#label} instead.\n * To update the text after render, run `text.attr({ text: 'New text' })`.\n *\n * @sample highcharts/members/renderer-text-on-chart/\n * Annotate the chart freely\n * @sample highcharts/members/renderer-on-chart/\n * Annotate with a border and in response to the data\n * @sample highcharts/members/renderer-text/\n * Formatted text\n *\n * @function Highcharts.SVGRenderer#text\n *\n * @param {string} [str]\n * The text of (subset) HTML to draw.\n *\n * @param {number} [x]\n * The x position of the text's lower left corner.\n *\n * @param {number} [y]\n * The y position of the text's lower left corner.\n *\n * @param {boolean} [useHTML=false]\n * Use HTML to render the text.\n *\n * @return {Highcharts.SVGElement}\n * The text object.\n */\n SVGRenderer.prototype.text = function (str, x, y, useHTML) {\n var renderer = this,\n attribs = {};\n if (useHTML && (renderer.allowHTML || !renderer.forExport)) {\n return renderer.html(str, x, y);\n }\n attribs.x = Math.round(x || 0); // X always needed for line-wrap logic\n if (y) {\n attribs.y = Math.round(y);\n }\n if (defined(str)) {\n attribs.text = str;\n }\n var wrapper = renderer.createElement('text').attr(attribs);\n if (!useHTML || (renderer.forExport && !renderer.allowHTML)) {\n wrapper.xSetter = function (value, key, element) {\n var tspans = element.getElementsByTagName('tspan'),\n parentVal = element.getAttribute(key);\n for (var i = 0, tspan = void 0; i < tspans.length; i++) {\n tspan = tspans[i];\n // If the x values are equal, the tspan represents a line\n // break\n if (tspan.getAttribute(key) === parentVal) {\n tspan.setAttribute(key, value);\n }\n }\n element.setAttribute(key, value);\n };\n }\n return wrapper;\n };\n /**\n * Utility to return the baseline offset and total line height from the font\n * size.\n *\n * @function Highcharts.SVGRenderer#fontMetrics\n *\n * @param {number|string} [fontSize]\n * The current font size to inspect. If not given, the font size\n * will be found from the DOM element.\n *\n * @param {Highcharts.SVGElement|Highcharts.SVGDOMElement} [elem]\n * The element to inspect for a current font size.\n *\n * @return {Highcharts.FontMetricsObject}\n * The font metrics.\n */\n SVGRenderer.prototype.fontMetrics = function (fontSize, elem) {\n if ((this.styledMode || !/px/.test(fontSize)) &&\n (win.getComputedStyle) // old IE doesn't support it\n ) {\n fontSize = elem && SVGElement.prototype.getStyle.call(elem, 'font-size');\n }\n else {\n fontSize = fontSize ||\n // When the elem is a DOM element (#5932)\n (elem && elem.style && elem.style.fontSize) ||\n // Fall back on the renderer style default\n (this.style && this.style.fontSize);\n }\n // Handle different units\n if (/px/.test(fontSize)) {\n fontSize = pInt(fontSize);\n }\n else {\n fontSize = 12;\n }\n // Empirical values found by comparing font size and bounding box\n // height. Applies to the default font family.\n // https://jsfiddle.net/highcharts/7xvn7/\n var lineHeight = (fontSize < 24 ?\n fontSize + 3 :\n Math.round(fontSize * 1.2)),\n baseline = Math.round(lineHeight * 0.8);\n return {\n h: lineHeight,\n b: baseline,\n f: fontSize\n };\n };\n /**\n * Correct X and Y positioning of a label for rotation (#1764).\n *\n * @private\n * @function Highcharts.SVGRenderer#rotCorr\n */\n SVGRenderer.prototype.rotCorr = function (baseline, rotation, alterY) {\n var y = baseline;\n if (rotation && alterY) {\n y = Math.max(y * Math.cos(rotation * deg2rad), 4);\n }\n return {\n x: (-baseline / 3) * Math.sin(rotation * deg2rad),\n y: y\n };\n };\n /**\n * Compatibility function to convert the legacy one-dimensional path array\n * into an array of segments.\n *\n * It is used in maps to parse the `path` option, and in SVGRenderer.dSetter\n * to support legacy paths from demos.\n *\n * @private\n * @function Highcharts.SVGRenderer#pathToSegments\n */\n SVGRenderer.prototype.pathToSegments = function (path) {\n var ret = [];\n var segment = [];\n var commandLength = {\n A: 8,\n C: 7,\n H: 2,\n L: 3,\n M: 3,\n Q: 5,\n S: 5,\n T: 3,\n V: 2\n };\n // Short, non-typesafe parsing of the one-dimensional array. It splits\n // the path on any string. This is not type checked against the tuple\n // types, but is shorter, and doesn't require specific checks for any\n // command type in SVG.\n for (var i = 0; i < path.length; i++) {\n // Command skipped, repeat previous or insert L/l for M/m\n if (isString(segment[0]) &&\n isNumber(path[i]) &&\n segment.length === commandLength[(segment[0].toUpperCase())]) {\n path.splice(i, 0, segment[0].replace('M', 'L').replace('m', 'l'));\n }\n // Split on string\n if (typeof path[i] === 'string') {\n if (segment.length) {\n ret.push(segment.slice(0));\n }\n segment.length = 0;\n }\n segment.push(path[i]);\n }\n ret.push(segment.slice(0));\n return ret;\n /*\n // Fully type-safe version where each tuple type is checked. The\n // downside is filesize and a lack of flexibility for unsupported\n // commands\n const ret: SVGPath = [],\n commands = {\n A: 7,\n C: 6,\n H: 1,\n L: 2,\n M: 2,\n Q: 4,\n S: 4,\n T: 2,\n V: 1,\n Z: 0\n };\n\n let i = 0,\n lastI = 0,\n lastCommand;\n\n while (i < path.length) {\n const item = path[i];\n\n let command;\n\n if (typeof item === 'string') {\n command = item;\n i += 1;\n } else {\n command = lastCommand || 'M';\n }\n\n // Upper case\n const commandUC = command.toUpperCase();\n\n if (commandUC in commands) {\n\n // No numeric parameters\n if (command === 'Z' || command === 'z') {\n ret.push([command]);\n\n // One numeric parameter\n } else {\n const val0 = path[i];\n if (typeof val0 === 'number') {\n\n // Horizontal line to\n if (command === 'H' || command === 'h') {\n ret.push([command, val0]);\n i += 1;\n\n // Vertical line to\n } else if (command === 'V' || command === 'v') {\n ret.push([command, val0]);\n i += 1;\n\n // Two numeric parameters\n } else {\n const val1 = path[i + 1];\n if (typeof val1 === 'number') {\n // lineTo\n if (command === 'L' || command === 'l') {\n ret.push([command, val0, val1]);\n i += 2;\n\n // moveTo\n } else if (command === 'M' || command === 'm') {\n ret.push([command, val0, val1]);\n i += 2;\n\n // Smooth quadratic bezier\n } else if (command === 'T' || command === 't') {\n ret.push([command, val0, val1]);\n i += 2;\n\n // Four numeric parameters\n } else {\n const val2 = path[i + 2],\n val3 = path[i + 3];\n if (\n typeof val2 === 'number' &&\n typeof val3 === 'number'\n ) {\n // Quadratic bezier to\n if (\n command === 'Q' ||\n command === 'q'\n ) {\n ret.push([\n command,\n val0,\n val1,\n val2,\n val3\n ]);\n i += 4;\n\n // Smooth cubic bezier to\n } else if (\n command === 'S' ||\n command === 's'\n ) {\n ret.push([\n command,\n val0,\n val1,\n val2,\n val3\n ]);\n i += 4;\n\n // Six numeric parameters\n } else {\n const val4 = path[i + 4],\n val5 = path[i + 5];\n\n if (\n typeof val4 === 'number' &&\n typeof val5 === 'number'\n ) {\n // Curve to\n if (\n command === 'C' ||\n command === 'c'\n ) {\n ret.push([\n command,\n val0,\n val1,\n val2,\n val3,\n val4,\n val5\n ]);\n i += 6;\n\n // Seven numeric parameters\n } else {\n const val6 = path[i + 6];\n\n // Arc to\n if (\n typeof val6 ===\n 'number' &&\n (\n command === 'A' ||\n command === 'a'\n )\n ) {\n ret.push([\n command,\n val0,\n val1,\n val2,\n val3,\n val4,\n val5,\n val6\n ]);\n i += 7;\n\n }\n\n }\n }\n }\n }\n }\n }\n\n }\n }\n }\n }\n\n // An unmarked command following a moveTo is a lineTo\n lastCommand = command === 'M' ? 'L' : command;\n\n if (i === lastI) {\n break;\n }\n lastI = i;\n }\n return ret;\n */\n };\n /**\n * Draw a label, which is an extended text element with support for border\n * and background. Highcharts creates a `g` element with a text and a `path`\n * or `rect` inside, to make it behave somewhat like a HTML div. Border and\n * background are set through `stroke`, `stroke-width` and `fill` attributes\n * using the {@link Highcharts.SVGElement#attr|attr} method. To update the\n * text after render, run `label.attr({ text: 'New text' })`.\n *\n * @sample highcharts/members/renderer-label-on-chart/\n * A label on the chart\n *\n * @function Highcharts.SVGRenderer#label\n *\n * @param {string} str\n * The initial text string or (subset) HTML to render.\n *\n * @param {number} x\n * The x position of the label's left side.\n *\n * @param {number} [y]\n * The y position of the label's top side or baseline, depending on\n * the `baseline` parameter.\n *\n * @param {string} [shape='rect']\n * The shape of the label's border/background, if any. Defaults to\n * `rect`. Other possible values are `callout` or other shapes\n * defined in {@link Highcharts.SVGRenderer#symbols}.\n *\n * @param {number} [anchorX]\n * In case the `shape` has a pointer, like a flag, this is the\n * coordinates it should be pinned to.\n *\n * @param {number} [anchorY]\n * In case the `shape` has a pointer, like a flag, this is the\n * coordinates it should be pinned to.\n *\n * @param {boolean} [useHTML=false]\n * Whether to use HTML to render the label.\n *\n * @param {boolean} [baseline=false]\n * Whether to position the label relative to the text baseline,\n * like {@link Highcharts.SVGRenderer#text|renderer.text}, or to the\n * upper border of the rectangle.\n *\n * @param {string} [className]\n * Class name for the group.\n *\n * @return {Highcharts.SVGElement}\n * The generated label.\n */\n SVGRenderer.prototype.label = function (str, x, y, shape, anchorX, anchorY, useHTML, baseline, className) {\n return new SVGLabel(this, str, x, y, shape, anchorX, anchorY, useHTML, baseline, className);\n };\n /**\n * Re-align all aligned elements.\n *\n * @private\n * @function Highcharts.SVGRenderer#alignElements\n */\n SVGRenderer.prototype.alignElements = function () {\n this.alignedObjects.forEach(function (el) { return el.align(); });\n };\n return SVGRenderer;\n }());\n extend(SVGRenderer.prototype, {\n /**\n * A pointer to the renderer's associated Element class. The VMLRenderer\n * will have a pointer to VMLElement here.\n *\n * @name Highcharts.SVGRenderer#Element\n * @type {Highcharts.SVGElement}\n */\n Element: SVGElement,\n SVG_NS: SVG_NS,\n /**\n * A collection of characters mapped to HTML entities. When `useHTML` on an\n * element is true, these entities will be rendered correctly by HTML. In\n * the SVG pseudo-HTML, they need to be unescaped back to simple characters,\n * so for example `<` will render as `<`.\n *\n * @example\n * // Add support for unescaping quotes\n * Highcharts.SVGRenderer.prototype.escapes['\"'] = '"';\n *\n * @name Highcharts.SVGRenderer#escapes\n * @type {Highcharts.Dictionary}\n */\n escapes: {\n '&': '&',\n '<': '<',\n '>': '>',\n \"'\": ''',\n '\"': '"'\n },\n /**\n * An extendable collection of functions for defining symbol paths.\n *\n * @name Highcharts.SVGRenderer#symbols\n * @type {Highcharts.SymbolDictionary}\n */\n symbols: Symbols,\n /**\n * Dummy function for plugins, called every time the renderer is updated.\n * Prior to Highcharts 5, this was used for the canvg renderer.\n *\n * @deprecated\n * @function Highcharts.SVGRenderer#draw\n */\n draw: noop\n });\n /* *\n *\n * Registry\n *\n * */\n RendererRegistry.registerRendererType('svg', SVGRenderer, true);\n /* *\n *\n * Export Default\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * A clipping rectangle that can be applied to one or more {@link SVGElement}\n * instances. It is instanciated with the {@link SVGRenderer#clipRect} function\n * and applied with the {@link SVGElement#clip} function.\n *\n * @example\n * let circle = renderer.circle(100, 100, 100)\n * .attr({ fill: 'red' })\n * .add();\n * let clipRect = renderer.clipRect(100, 100, 100, 100);\n *\n * // Leave only the lower right quarter visible\n * circle.clip(clipRect);\n *\n * @typedef {Highcharts.SVGElement} Highcharts.ClipRectElement\n */\n /**\n * The font metrics.\n *\n * @interface Highcharts.FontMetricsObject\n */ /**\n * The baseline relative to the top of the box.\n *\n * @name Highcharts.FontMetricsObject#b\n * @type {number}\n */ /**\n * The font size.\n *\n * @name Highcharts.FontMetricsObject#f\n * @type {number}\n */ /**\n * The line height.\n *\n * @name Highcharts.FontMetricsObject#h\n * @type {number}\n */\n /**\n * An object containing `x` and `y` properties for the position of an element.\n *\n * @interface Highcharts.PositionObject\n */ /**\n * X position of the element.\n * @name Highcharts.PositionObject#x\n * @type {number}\n */ /**\n * Y position of the element.\n * @name Highcharts.PositionObject#y\n * @type {number}\n */\n /**\n * A rectangle.\n *\n * @interface Highcharts.RectangleObject\n */ /**\n * Height of the rectangle.\n * @name Highcharts.RectangleObject#height\n * @type {number}\n */ /**\n * Width of the rectangle.\n * @name Highcharts.RectangleObject#width\n * @type {number}\n */ /**\n * Horizontal position of the rectangle.\n * @name Highcharts.RectangleObject#x\n * @type {number}\n */ /**\n * Vertical position of the rectangle.\n * @name Highcharts.RectangleObject#y\n * @type {number}\n */\n /**\n * The shadow options.\n *\n * @interface Highcharts.ShadowOptionsObject\n */ /**\n * The shadow color.\n * @name Highcharts.ShadowOptionsObject#color\n * @type {Highcharts.ColorString|undefined}\n * @default #000000\n */ /**\n * The horizontal offset from the element.\n *\n * @name Highcharts.ShadowOptionsObject#offsetX\n * @type {number|undefined}\n * @default 1\n */ /**\n * The vertical offset from the element.\n * @name Highcharts.ShadowOptionsObject#offsetY\n * @type {number|undefined}\n * @default 1\n */ /**\n * The shadow opacity.\n *\n * @name Highcharts.ShadowOptionsObject#opacity\n * @type {number|undefined}\n * @default 0.15\n */ /**\n * The shadow width or distance from the element.\n * @name Highcharts.ShadowOptionsObject#width\n * @type {number|undefined}\n * @default 3\n */\n /**\n * @interface Highcharts.SizeObject\n */ /**\n * @name Highcharts.SizeObject#height\n * @type {number}\n */ /**\n * @name Highcharts.SizeObject#width\n * @type {number}\n */\n /**\n * Array of path commands, that will go into the `d` attribute of an SVG\n * element.\n *\n * @typedef {Array<(Array|Array|Array|Array|Array|Array)>} Highcharts.SVGPathArray\n */\n /**\n * Possible path commands in an SVG path array. Valid values are `A`, `C`, `H`,\n * `L`, `M`, `Q`, `S`, `T`, `V`, `Z`.\n *\n * @typedef {string} Highcharts.SVGPathCommand\n * @validvalue [\"a\",\"c\",\"h\",\"l\",\"m\",\"q\",\"s\",\"t\",\"v\",\"z\",\"A\",\"C\",\"H\",\"L\",\"M\",\"Q\",\"S\",\"T\",\"V\",\"Z\"]\n */\n /**\n * An extendable collection of functions for defining symbol paths. Symbols are\n * used internally for point markers, button and label borders and backgrounds,\n * or custom shapes. Extendable by adding to {@link SVGRenderer#symbols}.\n *\n * @interface Highcharts.SymbolDictionary\n */ /**\n * @name Highcharts.SymbolDictionary#[key:string]\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#arc\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#callout\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#circle\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#diamond\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#square\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#triangle\n * @type {Function|undefined}\n */\n /**\n * Can be one of `arc`, `callout`, `circle`, `diamond`, `square`, `triangle`,\n * and `triangle-down`. Symbols are used internally for point markers, button\n * and label borders and backgrounds, or custom shapes. Extendable by adding to\n * {@link SVGRenderer#symbols}.\n *\n * @typedef {\"arc\"|\"callout\"|\"circle\"|\"diamond\"|\"square\"|\"triangle\"|\"triangle-down\"} Highcharts.SymbolKeyValue\n */\n /**\n * Additional options, depending on the actual symbol drawn.\n *\n * @interface Highcharts.SymbolOptionsObject\n */ /**\n * The anchor X position for the `callout` symbol. This is where the chevron\n * points to.\n *\n * @name Highcharts.SymbolOptionsObject#anchorX\n * @type {number|undefined}\n */ /**\n * The anchor Y position for the `callout` symbol. This is where the chevron\n * points to.\n *\n * @name Highcharts.SymbolOptionsObject#anchorY\n * @type {number|undefined}\n */ /**\n * The end angle of an `arc` symbol.\n *\n * @name Highcharts.SymbolOptionsObject#end\n * @type {number|undefined}\n */ /**\n * Whether to draw `arc` symbol open or closed.\n *\n * @name Highcharts.SymbolOptionsObject#open\n * @type {boolean|undefined}\n */ /**\n * The radius of an `arc` symbol, or the border radius for the `callout` symbol.\n *\n * @name Highcharts.SymbolOptionsObject#r\n * @type {number|undefined}\n */ /**\n * The start angle of an `arc` symbol.\n *\n * @name Highcharts.SymbolOptionsObject#start\n * @type {number|undefined}\n */\n (''); // keeps doclets above in transpiled file\n\n return SVGRenderer;\n });\n _registerModule(_modules, 'Core/Renderer/HTML/HTMLElement.js', [_modules['Core/Globals.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (H, SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var isFirefox = H.isFirefox,\n isMS = H.isMS,\n isWebKit = H.isWebKit,\n win = H.win;\n var css = U.css,\n defined = U.defined,\n extend = U.extend,\n pick = U.pick,\n pInt = U.pInt;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable valid-jsdoc */\n var HTMLElement = /** @class */ (function (_super) {\n __extends(HTMLElement, _super);\n function HTMLElement() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Modifies SVGElement to support HTML elements.\n * @private\n */\n HTMLElement.compose = function (SVGElementClass) {\n if (HTMLElement.composedClasses.indexOf(SVGElementClass) === -1) {\n HTMLElement.composedClasses.push(SVGElementClass);\n var htmlElementProto = HTMLElement.prototype,\n svgElementProto = SVGElementClass.prototype;\n svgElementProto.getSpanCorrection = htmlElementProto\n .getSpanCorrection;\n svgElementProto.htmlCss = htmlElementProto.htmlCss;\n svgElementProto.htmlGetBBox = htmlElementProto.htmlGetBBox;\n svgElementProto.htmlUpdateTransform = htmlElementProto\n .htmlUpdateTransform;\n svgElementProto.setSpanRotation = htmlElementProto.setSpanRotation;\n }\n return SVGElementClass;\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get the correction in X and Y positioning as the element is rotated.\n * @private\n */\n HTMLElement.prototype.getSpanCorrection = function (width, baseline, alignCorrection) {\n this.xCorr = -width * alignCorrection;\n this.yCorr = -baseline;\n };\n /**\n * Apply CSS to HTML elements. This is used in text within SVG rendering and\n * by the VML renderer\n * @private\n */\n HTMLElement.prototype.htmlCss = function (styles) {\n var wrapper = this,\n element = wrapper.element, \n // When setting or unsetting the width style, we need to update\n // transform (#8809)\n isSettingWidth = (element.tagName === 'SPAN' &&\n styles &&\n 'width' in styles),\n textWidth = pick(isSettingWidth && styles.width,\n void 0);\n var doTransform;\n if (isSettingWidth) {\n delete styles.width;\n wrapper.textWidth = textWidth;\n doTransform = true;\n }\n if (styles && styles.textOverflow === 'ellipsis') {\n styles.whiteSpace = 'nowrap';\n styles.overflow = 'hidden';\n }\n wrapper.styles = extend(wrapper.styles, styles);\n css(wrapper.element, styles);\n // Now that all styles are applied, to the transform\n if (doTransform) {\n wrapper.htmlUpdateTransform();\n }\n return wrapper;\n };\n /**\n * VML and useHTML method for calculating the bounding box based on offsets.\n */\n HTMLElement.prototype.htmlGetBBox = function () {\n var wrapper = this,\n element = wrapper.element;\n return {\n x: element.offsetLeft,\n y: element.offsetTop,\n width: element.offsetWidth,\n height: element.offsetHeight\n };\n };\n /**\n * VML override private method to update elements based on internal\n * properties based on SVG transform.\n * @private\n */\n HTMLElement.prototype.htmlUpdateTransform = function () {\n // aligning non added elements is expensive\n if (!this.added) {\n this.alignOnAdd = true;\n return;\n }\n var wrapper = this,\n renderer = wrapper.renderer,\n elem = wrapper.element,\n translateX = wrapper.translateX || 0,\n translateY = wrapper.translateY || 0,\n x = wrapper.x || 0,\n y = wrapper.y || 0,\n align = wrapper.textAlign || 'left',\n alignCorrection = {\n left: 0,\n center: 0.5,\n right: 1\n }[align],\n styles = wrapper.styles,\n whiteSpace = styles && styles.whiteSpace;\n /** @private */\n function getTextPxLength() {\n if (wrapper.textPxLength) {\n return wrapper.textPxLength;\n }\n // Reset multiline/ellipsis in order to read width (#4928,\n // #5417)\n css(elem, {\n width: '',\n whiteSpace: whiteSpace || 'nowrap'\n });\n return elem.offsetWidth;\n }\n // apply translate\n css(elem, {\n marginLeft: translateX,\n marginTop: translateY\n });\n if (!renderer.styledMode && wrapper.shadows) { // used in labels/tooltip\n wrapper.shadows.forEach(function (shadow) {\n css(shadow, {\n marginLeft: translateX + 1,\n marginTop: translateY + 1\n });\n });\n }\n // apply inversion\n if (wrapper.inverted) { // wrapper is a group\n [].forEach.call(elem.childNodes, function (child) {\n renderer.invertChild(child, elem);\n });\n }\n if (elem.tagName === 'SPAN') {\n var rotation = wrapper.rotation, textWidth = wrapper.textWidth && pInt(wrapper.textWidth), currentTextTransform = [\n rotation,\n align,\n elem.innerHTML,\n wrapper.textWidth,\n wrapper.textAlign\n ].join(',');\n var baseline = void 0,\n hasBoxWidthChanged = false;\n // Update textWidth. Use the memoized textPxLength if possible, to\n // avoid the getTextPxLength function using elem.offsetWidth.\n // Calling offsetWidth affects rendering time as it forces layout\n // (#7656).\n if (textWidth !== wrapper.oldTextWidth) { // #983, #1254\n var textPxLength = getTextPxLength();\n if (((textWidth > wrapper.oldTextWidth) ||\n textPxLength > textWidth) && (\n // Only set the width if the text is able to word-wrap,\n // or text-overflow is ellipsis (#9537)\n /[ \\-]/.test(elem.textContent || elem.innerText) ||\n elem.style.textOverflow === 'ellipsis')) {\n css(elem, {\n width: (textPxLength > textWidth) || rotation ?\n textWidth + 'px' :\n 'auto',\n display: 'block',\n whiteSpace: whiteSpace || 'normal' // #3331\n });\n wrapper.oldTextWidth = textWidth;\n hasBoxWidthChanged = true; // #8159\n }\n }\n wrapper.hasBoxWidthChanged = hasBoxWidthChanged; // #8159\n // Do the calculations and DOM access only if properties changed\n if (currentTextTransform !== wrapper.cTT) {\n baseline = renderer.fontMetrics(elem.style.fontSize, elem).b;\n // Renderer specific handling of span rotation, but only if we\n // have something to update.\n if (defined(rotation) &&\n ((rotation !== (wrapper.oldRotation || 0)) ||\n (align !== wrapper.oldAlign))) {\n wrapper.setSpanRotation(rotation, alignCorrection, baseline);\n }\n wrapper.getSpanCorrection(\n // Avoid elem.offsetWidth if we can, it affects rendering\n // time heavily (#7656)\n ((!defined(rotation) && wrapper.textPxLength) || // #7920\n elem.offsetWidth), baseline, alignCorrection, rotation, align);\n }\n // apply position with correction\n css(elem, {\n left: (x + (wrapper.xCorr || 0)) + 'px',\n top: (y + (wrapper.yCorr || 0)) + 'px'\n });\n // record current text transform\n wrapper.cTT = currentTextTransform;\n wrapper.oldRotation = rotation;\n wrapper.oldAlign = align;\n }\n };\n /**\n * Set the rotation of an individual HTML span.\n * @private\n */\n HTMLElement.prototype.setSpanRotation = function (rotation, alignCorrection, baseline) {\n var getTransformKey = function () { return (isMS &&\n !/Edge/.test(win.navigator.userAgent) ?\n '-ms-transform' :\n isWebKit ?\n '-webkit-transform' :\n isFirefox ?\n 'MozTransform' :\n win.opera ?\n '-o-transform' :\n void 0); };\n var rotationStyle = {},\n cssTransformKey = getTransformKey();\n if (cssTransformKey) {\n rotationStyle[cssTransformKey] = rotationStyle.transform =\n 'rotate(' + rotation + 'deg)';\n rotationStyle[cssTransformKey + (isFirefox ? 'Origin' : '-origin')] = rotationStyle.transformOrigin =\n (alignCorrection * 100) + '% ' + baseline + 'px';\n css(this.element, rotationStyle);\n }\n };\n /* *\n *\n * Static Properties\n *\n * */\n HTMLElement.composedClasses = [];\n return HTMLElement;\n }(SVGElement));\n /* *\n *\n * Default Export\n *\n * */\n\n return HTMLElement;\n });\n _registerModule(_modules, 'Core/Renderer/HTML/HTMLRenderer.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Utilities.js']], function (AST, SVGElement, SVGRenderer, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var attr = U.attr,\n createElement = U.createElement,\n extend = U.extend,\n pick = U.pick;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable valid-jsdoc */\n // Extend SvgRenderer for useHTML option.\n var HTMLRenderer = /** @class */ (function (_super) {\n __extends(HTMLRenderer, _super);\n function HTMLRenderer() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n /* *\n *\n * Static Functions\n *\n * */\n /** @private */\n HTMLRenderer.compose = function (SVGRendererClass) {\n if (HTMLRenderer.composedClasses.indexOf(SVGRendererClass) === -1) {\n HTMLRenderer.composedClasses.push(SVGRendererClass);\n var htmlRendererProto = HTMLRenderer.prototype,\n svgRendererProto = SVGRendererClass.prototype;\n svgRendererProto.html = htmlRendererProto.html;\n }\n return SVGRendererClass;\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Create HTML text node. This is used by the VML renderer as well as the\n * SVG renderer through the useHTML option.\n *\n * @private\n * @function Highcharts.SVGRenderer#html\n *\n * @param {string} str\n * The text of (subset) HTML to draw.\n *\n * @param {number} x\n * The x position of the text's lower left corner.\n *\n * @param {number} y\n * The y position of the text's lower left corner.\n *\n * @return {Highcharts.HTMLDOMElement}\n * HTML element.\n */\n HTMLRenderer.prototype.html = function (str, x, y) {\n var wrapper = this.createElement('span'), element = wrapper.element, renderer = wrapper.renderer, isSVG = renderer.isSVG, addSetters = function (gWrapper, style) {\n // These properties are set as attributes on the SVG group, and\n // as identical CSS properties on the div. (#3542)\n ['opacity', 'visibility'].forEach(function (prop) {\n gWrapper[prop + 'Setter'] = function (value, key, elem) {\n var styleObject = gWrapper.div ?\n gWrapper.div.style :\n style;\n SVGElement.prototype[prop + 'Setter']\n .call(this, value, key, elem);\n if (styleObject) {\n styleObject[key] = value;\n }\n };\n });\n gWrapper.addedSetters = true;\n };\n // Text setter\n wrapper.textSetter = function (value) {\n if (value !== this.textStr) {\n delete this.bBox;\n delete this.oldTextWidth;\n AST.setElementHTML(this.element, pick(value, ''));\n this.textStr = value;\n wrapper.doTransform = true;\n }\n };\n // Add setters for the element itself (#4938)\n if (isSVG) { // #4938, only for HTML within SVG\n addSetters(wrapper, wrapper.element.style);\n }\n // Various setters which rely on update transform\n wrapper.xSetter =\n wrapper.ySetter =\n wrapper.alignSetter =\n wrapper.rotationSetter =\n function (value, key) {\n if (key === 'align') {\n // Do not overwrite the SVGElement.align method. Same as VML.\n wrapper.alignValue = wrapper.textAlign = value;\n }\n else {\n wrapper[key] = value;\n }\n wrapper.doTransform = true;\n };\n // Runs at the end of .attr()\n wrapper.afterSetters = function () {\n // Update transform. Do this outside the loop to prevent redundant\n // updating for batch setting of attributes.\n if (this.doTransform) {\n this.htmlUpdateTransform();\n this.doTransform = false;\n }\n };\n // Set the default attributes\n wrapper\n .attr({\n text: str,\n x: Math.round(x),\n y: Math.round(y)\n })\n .css({\n position: 'absolute'\n });\n if (!renderer.styledMode) {\n wrapper.css({\n fontFamily: this.style.fontFamily,\n fontSize: this.style.fontSize\n });\n }\n // Keep the whiteSpace style outside the wrapper.styles collection\n element.style.whiteSpace = 'nowrap';\n // Use the HTML specific .css method\n wrapper.css = wrapper.htmlCss;\n // This is specific for HTML within SVG\n if (isSVG) {\n wrapper.add = function (svgGroupWrapper) {\n var container = renderer.box.parentNode,\n parents = [];\n var htmlGroup,\n parentGroup;\n this.parentGroup = svgGroupWrapper;\n // Create a mock group to hold the HTML elements\n if (svgGroupWrapper) {\n htmlGroup = svgGroupWrapper.div;\n if (!htmlGroup) {\n // Read the parent chain into an array and read from top\n // down\n parentGroup = svgGroupWrapper;\n while (parentGroup) {\n parents.push(parentGroup);\n // Move up to the next parent group\n parentGroup = parentGroup.parentGroup;\n }\n // Ensure dynamically updating position when any parent\n // is translated\n parents.reverse().forEach(function (parentGroup) {\n var cls = attr(parentGroup.element, 'class');\n /**\n * Common translate setter for X and Y on the HTML\n * group. Reverted the fix for #6957 du to\n * positioning problems and offline export (#7254,\n * #7280, #7529)\n * @private\n * @param {*} value\n * @param {string} key\n */\n function translateSetter(value, key) {\n parentGroup[key] = value;\n if (key === 'translateX') {\n htmlGroupStyle.left = value + 'px';\n }\n else {\n htmlGroupStyle.top = value + 'px';\n }\n parentGroup.doTransform = true;\n }\n // Create a HTML div and append it to the parent div\n // to emulate the SVG group structure\n var parentGroupStyles = parentGroup.styles || {};\n htmlGroup =\n parentGroup.div =\n parentGroup.div || createElement('div', cls ? { className: cls } : void 0, {\n position: 'absolute',\n left: (parentGroup.translateX || 0) + 'px',\n top: (parentGroup.translateY || 0) + 'px',\n display: parentGroup.display,\n opacity: parentGroup.opacity,\n cursor: parentGroupStyles.cursor,\n pointerEvents: (\n // #5595\n parentGroupStyles.pointerEvents),\n visibility: parentGroup.visibility\n // the top group is appended to container\n }, htmlGroup || container);\n // Shortcut\n var htmlGroupStyle = htmlGroup.style;\n // Set listeners to update the HTML div's position\n // whenever the SVG group position is changed.\n extend(parentGroup, {\n // (#7287) Pass htmlGroup to use\n // the related group\n classSetter: (function (htmlGroup) {\n return function (value) {\n this.element.setAttribute('class', value);\n htmlGroup.className = value;\n };\n }(htmlGroup)),\n on: function () {\n if (parents[0].div) { // #6418\n wrapper.on.apply({\n element: parents[0].div,\n onEvents: parentGroup.onEvents\n }, arguments);\n }\n return parentGroup;\n },\n translateXSetter: translateSetter,\n translateYSetter: translateSetter\n });\n if (!parentGroup.addedSetters) {\n addSetters(parentGroup);\n }\n });\n }\n }\n else {\n htmlGroup = container;\n }\n htmlGroup.appendChild(element);\n // Shared with VML:\n wrapper.added = true;\n if (wrapper.alignOnAdd) {\n wrapper.htmlUpdateTransform();\n }\n return wrapper;\n };\n }\n return wrapper;\n };\n /* *\n *\n * Static Properties\n *\n * */\n HTMLRenderer.composedClasses = [];\n return HTMLRenderer;\n }(SVGRenderer));\n /* *\n *\n * Default Export\n *\n * */\n\n return HTMLRenderer;\n });\n _registerModule(_modules, 'Core/Axis/AxisDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Namespace\n *\n * */\n var AxisDefaults;\n (function (AxisDefaults) {\n /* *\n *\n * Constants\n *\n * */\n /**\n * The X axis or category axis. Normally this is the horizontal axis,\n * though if the chart is inverted this is the vertical axis. In case of\n * multiple axes, the xAxis node is an array of configuration objects.\n *\n * See the [Axis class](/class-reference/Highcharts.Axis) for programmatic\n * access to the axis.\n *\n * @productdesc {highmaps}\n * In Highmaps, the axis is hidden, but it is used behind the scenes to\n * control features like zooming and panning. Zooming is in effect the same\n * as setting the extremes of one of the exes.\n *\n * @type {*|Array<*>}\n * @optionparent xAxis\n */\n AxisDefaults.defaultXAxisOptions = {\n /**\n * When using multiple axis, the ticks of two or more opposite axes\n * will automatically be aligned by adding ticks to the axis or axes\n * with the least ticks, as if `tickAmount` were specified.\n *\n * This can be prevented by setting `alignTicks` to false. If the grid\n * lines look messy, it's a good idea to hide them for the secondary\n * axis by setting `gridLineWidth` to 0.\n *\n * If `startOnTick` or `endOnTick` in an Axis options are set to false,\n * then the `alignTicks ` will be disabled for the Axis.\n *\n * Disabled for logarithmic axes.\n *\n * @product highcharts highstock gantt\n */\n alignTicks: true,\n /**\n * Whether to allow decimals in this axis' ticks. When counting\n * integers, like persons or hits on a web page, decimals should\n * be avoided in the labels. By default, decimals are allowed on small\n * scale axes.\n *\n * @see [minTickInterval](#xAxis.minTickInterval)\n *\n * @sample {highcharts|highstock} highcharts/yaxis/allowdecimals-true/\n * True by default\n * @sample {highcharts|highstock} highcharts/yaxis/allowdecimals-false/\n * False\n *\n * @type {boolean|undefined}\n * @default undefined\n * @since 2.0\n */\n allowDecimals: void 0,\n /**\n * When using an alternate grid color, a band is painted across the\n * plot area between every other grid line.\n *\n * @sample {highcharts} highcharts/yaxis/alternategridcolor/\n * Alternate grid color on the Y axis\n * @sample {highstock} stock/xaxis/alternategridcolor/\n * Alternate grid color on the Y axis\n *\n * @type {Highcharts.ColorType}\n * @apioption xAxis.alternateGridColor\n */\n /**\n * An array defining breaks in the axis, the sections defined will be\n * left out and all the points shifted closer to each other.\n *\n * @productdesc {highcharts}\n * Requires that the broken-axis.js module is loaded.\n *\n * @sample {highcharts} highcharts/axisbreak/break-simple/\n * Simple break\n * @sample {highcharts|highstock} highcharts/axisbreak/break-visualized/\n * Advanced with callback\n * @sample {highstock} stock/demo/intraday-breaks/\n * Break on nights and weekends\n *\n * @type {Array<*>}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks\n */\n /**\n * A number indicating how much space should be left between the start\n * and the end of the break. The break size is given in axis units,\n * so for instance on a `datetime` axis, a break size of 3600000 would\n * indicate the equivalent of an hour.\n *\n * @type {number}\n * @default 0\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks.breakSize\n */\n /**\n * The point where the break starts.\n *\n * @type {number}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks.from\n */\n /**\n * Defines an interval after which the break appears again. By default\n * the breaks do not repeat.\n *\n * @type {number}\n * @default 0\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks.repeat\n */\n /**\n * The point where the break ends.\n *\n * @type {number}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks.to\n */\n /**\n * If categories are present for the xAxis, names are used instead of\n * numbers for that axis.\n *\n * Since Highcharts 3.0, categories can also\n * be extracted by giving each point a [name](#series.data) and setting\n * axis [type](#xAxis.type) to `category`. However, if you have multiple\n * series, best practice remains defining the `categories` array.\n *\n * Example: `categories: ['Apples', 'Bananas', 'Oranges']`\n *\n * @sample {highcharts} highcharts/demo/line-labels/\n * With\n * @sample {highcharts} highcharts/xaxis/categories/\n * Without\n *\n * @type {Array}\n * @product highcharts gantt\n * @apioption xAxis.categories\n */\n /**\n * The highest allowed value for automatically computed axis extremes.\n *\n * @see [floor](#xAxis.floor)\n *\n * @sample {highcharts|highstock} highcharts/yaxis/floor-ceiling/\n * Floor and ceiling\n *\n * @type {number}\n * @since 4.0\n * @product highcharts highstock gantt\n * @apioption xAxis.ceiling\n */\n /**\n * A class name that opens for styling the axis by CSS, especially in\n * Highcharts styled mode. The class name is applied to group elements\n * for the grid, axis elements and labels.\n *\n * @sample {highcharts|highstock|highmaps} highcharts/css/axis/\n * Multiple axes with separate styling\n *\n * @type {string}\n * @since 5.0.0\n * @apioption xAxis.className\n */\n /**\n * Configure a crosshair that follows either the mouse pointer or the\n * hovered point.\n *\n * In styled mode, the crosshairs are styled in the\n * `.highcharts-crosshair`, `.highcharts-crosshair-thin` or\n * `.highcharts-xaxis-category` classes.\n *\n * @productdesc {highstock}\n * In Highcharts stock, by default, the crosshair is enabled on the\n * X axis and disabled on the Y axis.\n *\n * @sample {highcharts} highcharts/xaxis/crosshair-both/\n * Crosshair on both axes\n * @sample {highstock} stock/xaxis/crosshairs-xy/\n * Crosshair on both axes, with y axis label\n * @sample {highmaps} highcharts/xaxis/crosshair-both/\n * Crosshair on both axes\n *\n * @declare Highcharts.AxisCrosshairOptions\n * @type {boolean|*}\n * @default false\n * @since 4.1\n * @apioption xAxis.crosshair\n */\n /**\n * A class name for the crosshair, especially as a hook for styling.\n *\n * @type {string}\n * @since 5.0.0\n * @apioption xAxis.crosshair.className\n */\n /**\n * The color of the crosshair. Defaults to `#cccccc` for numeric and\n * datetime axes, and `rgba(204,214,235,0.25)` for category axes, where\n * the crosshair by default highlights the whole category.\n *\n * @sample {highcharts|highstock|highmaps} highcharts/xaxis/crosshair-customized/\n * Customized crosshairs\n *\n * @type {Highcharts.ColorType}\n * @default #cccccc\n * @since 4.1\n * @apioption xAxis.crosshair.color\n */\n /**\n * The dash style for the crosshair. See\n * [plotOptions.series.dashStyle](#plotOptions.series.dashStyle)\n * for possible values.\n *\n * @sample {highcharts|highmaps} highcharts/xaxis/crosshair-dotted/\n * Dotted crosshair\n * @sample {highstock} stock/xaxis/crosshair-dashed/\n * Dashed X axis crosshair\n *\n * @type {Highcharts.DashStyleValue}\n * @default Solid\n * @since 4.1\n * @apioption xAxis.crosshair.dashStyle\n */\n /**\n * A label on the axis next to the crosshair.\n *\n * In styled mode, the label is styled with the\n * `.highcharts-crosshair-label` class.\n *\n * @sample {highstock} stock/xaxis/crosshair-label/\n * Crosshair labels\n * @sample {highstock} highcharts/css/crosshair-label/\n * Style mode\n *\n * @declare Highcharts.AxisCrosshairLabelOptions\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label\n */\n /**\n * Alignment of the label compared to the axis. Defaults to `\"left\"` for\n * right-side axes, `\"right\"` for left-side axes and `\"center\"` for\n * horizontal axes.\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.align\n */\n /**\n * The background color for the label. Defaults to the related series\n * color, or `#666666` if that is not available.\n *\n * @type {Highcharts.ColorType}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.backgroundColor\n */\n /**\n * The border color for the crosshair label\n *\n * @type {Highcharts.ColorType}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.borderColor\n */\n /**\n * The border corner radius of the crosshair label.\n *\n * @type {number}\n * @default 3\n * @since 2.1.10\n * @product highstock\n * @apioption xAxis.crosshair.label.borderRadius\n */\n /**\n * The border width for the crosshair label.\n *\n * @type {number}\n * @default 0\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.borderWidth\n */\n /**\n * Flag to enable crosshair's label.\n *\n * @sample {highstock} stock/xaxis/crosshairs-xy/\n * Enabled label for yAxis' crosshair\n *\n * @type {boolean}\n * @default false\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.enabled\n */\n /**\n * A format string for the crosshair label. Defaults to `{value}` for\n * numeric axes and `{value:%b %d, %Y}` for datetime axes.\n *\n * @type {string}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.format\n */\n /**\n * Formatter function for the label text.\n *\n * @type {Highcharts.XAxisCrosshairLabelFormatterCallbackFunction}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.formatter\n */\n /**\n * Padding inside the crosshair label.\n *\n * @type {number}\n * @default 8\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.padding\n */\n /**\n * The shape to use for the label box.\n *\n * @type {string}\n * @default callout\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.shape\n */\n /**\n * Text styles for the crosshair label.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"white\", \"fontWeight\": \"normal\", \"fontSize\": \"11px\", \"textAlign\": \"center\"}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.style\n */\n /**\n * Whether the crosshair should snap to the point or follow the pointer\n * independent of points.\n *\n * @sample {highcharts|highstock} highcharts/xaxis/crosshair-snap-false/\n * True by default\n * @sample {highmaps} maps/demo/latlon-advanced/\n * Snap is false\n *\n * @type {boolean}\n * @default true\n * @since 4.1\n * @apioption xAxis.crosshair.snap\n */\n /**\n * The pixel width of the crosshair. Defaults to 1 for numeric or\n * datetime axes, and for one category width for category axes.\n *\n * @sample {highcharts} highcharts/xaxis/crosshair-customized/\n * Customized crosshairs\n * @sample {highstock} highcharts/xaxis/crosshair-customized/\n * Customized crosshairs\n * @sample {highmaps} highcharts/xaxis/crosshair-customized/\n * Customized crosshairs\n *\n * @type {number}\n * @default 1\n * @since 4.1\n * @apioption xAxis.crosshair.width\n */\n /**\n * The Z index of the crosshair. Higher Z indices allow drawing the\n * crosshair on top of the series or behind the grid lines.\n *\n * @type {number}\n * @default 2\n * @since 4.1\n * @apioption xAxis.crosshair.zIndex\n */\n /**\n * Whether to pan axis. If `chart.panning` is enabled, the option\n * allows to disable panning on an individual axis.\n */\n panningEnabled: true,\n /**\n * The Z index for the axis group.\n */\n zIndex: 2,\n /**\n * Whether to zoom axis. If `chart.zoomType` is set, the option allows\n * to disable zooming on an individual axis.\n *\n * @sample {highcharts} highcharts/xaxis/zoomenabled/\n * Zoom enabled is false\n */\n zoomEnabled: true,\n /**\n * For a datetime axis, the scale will automatically adjust to the\n * appropriate unit. This member gives the default string\n * representations used for each unit. For intermediate values,\n * different units may be used, for example the `day` unit can be used\n * on midnight and `hour` unit be used for intermediate values on the\n * same axis.\n *\n * For an overview of the replacement codes, see\n * [dateFormat](/class-reference/Highcharts.Time#dateFormat).\n *\n * Defaults to:\n * ```js\n * {\n * millisecond: '%H:%M:%S.%L',\n * second: '%H:%M:%S',\n * minute: '%H:%M',\n * hour: '%H:%M',\n * day: '%e. %b',\n * week: '%e. %b',\n * month: '%b \\'%y',\n * year: '%Y'\n * }\n * ```\n *\n * @sample {highcharts} highcharts/xaxis/datetimelabelformats/\n * Different day format on X axis\n * @sample {highstock} stock/xaxis/datetimelabelformats/\n * More information in x axis labels\n *\n * @declare Highcharts.AxisDateTimeLabelFormatsOptions\n * @product highcharts highstock gantt\n */\n dateTimeLabelFormats: {\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n millisecond: {\n main: '%H:%M:%S.%L',\n range: false\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n second: {\n main: '%H:%M:%S',\n range: false\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n minute: {\n main: '%H:%M',\n range: false\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n hour: {\n main: '%H:%M',\n range: false\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n day: {\n main: '%e. %b'\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n week: {\n main: '%e. %b'\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n month: {\n main: '%b \\'%y'\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n year: {\n main: '%Y'\n }\n },\n /**\n * Whether to force the axis to end on a tick. Use this option with\n * the `maxPadding` option to control the axis end.\n *\n * @productdesc {highstock}\n * In Highcharts Stock, `endOnTick` is always `false` when the navigator\n * is enabled, to prevent jumpy scrolling.\n *\n * @sample {highcharts} highcharts/yaxis/endontick/\n * True by default\n * @sample {highcharts} highcharts/yaxis/endontick-false/\n * False\n * @sample {highstock} stock/demo/basic-line/\n * True by default\n * @sample {highstock} stock/xaxis/endontick/\n * False\n *\n * @since 1.2.0\n */\n endOnTick: false,\n /**\n * Event handlers for the axis.\n *\n * @type {*}\n * @apioption xAxis.events\n */\n /**\n * An event fired after the breaks have rendered.\n *\n * @see [breaks](#xAxis.breaks)\n *\n * @sample {highcharts} highcharts/axisbreak/break-event/\n * AfterBreak Event\n *\n * @type {Highcharts.AxisEventCallbackFunction}\n * @since 4.1.0\n * @product highcharts gantt\n * @apioption xAxis.events.afterBreaks\n */\n /**\n * As opposed to the `setExtremes` event, this event fires after the\n * final min and max values are computed and corrected for `minRange`.\n *\n * Fires when the minimum and maximum is set for the axis, either by\n * calling the `.setExtremes()` method or by selecting an area in the\n * chart. One parameter, `event`, is passed to the function, containing\n * common event information.\n *\n * The new user set minimum and maximum values can be found by\n * `event.min` and `event.max`. These reflect the axis minimum and\n * maximum in axis values. The actual data extremes are found in\n * `event.dataMin` and `event.dataMax`.\n *\n * @type {Highcharts.AxisSetExtremesEventCallbackFunction}\n * @since 2.3\n * @context Highcharts.Axis\n * @apioption xAxis.events.afterSetExtremes\n */\n /**\n * An event fired when a break from this axis occurs on a point.\n *\n * @see [breaks](#xAxis.breaks)\n *\n * @sample {highcharts} highcharts/axisbreak/break-visualized/\n * Visualization of a Break\n *\n * @type {Highcharts.AxisPointBreakEventCallbackFunction}\n * @since 4.1.0\n * @product highcharts gantt\n * @context Highcharts.Axis\n * @apioption xAxis.events.pointBreak\n */\n /**\n * An event fired when a point falls inside a break from this axis.\n *\n * @type {Highcharts.AxisPointBreakEventCallbackFunction}\n * @product highcharts highstock gantt\n * @context Highcharts.Axis\n * @apioption xAxis.events.pointInBreak\n */\n /**\n * Fires when the minimum and maximum is set for the axis, either by\n * calling the `.setExtremes()` method or by selecting an area in the\n * chart. One parameter, `event`, is passed to the function,\n * containing common event information.\n *\n * The new user set minimum and maximum values can be found by\n * `event.min` and `event.max`. These reflect the axis minimum and\n * maximum in data values. When an axis is zoomed all the way out from\n * the \"Reset zoom\" button, `event.min` and `event.max` are null, and\n * the new extremes are set based on `this.dataMin` and `this.dataMax`.\n *\n * @sample {highstock} stock/xaxis/events-setextremes/\n * Log new extremes on x axis\n *\n * @type {Highcharts.AxisSetExtremesEventCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Axis\n * @apioption xAxis.events.setExtremes\n */\n /**\n * The lowest allowed value for automatically computed axis extremes.\n *\n * @see [ceiling](#yAxis.ceiling)\n *\n * @sample {highcharts} highcharts/yaxis/floor-ceiling/\n * Floor and ceiling\n * @sample {highstock} stock/demo/lazy-loading/\n * Prevent negative stock price on Y axis\n *\n * @type {number}\n * @since 4.0\n * @product highcharts highstock gantt\n * @apioption xAxis.floor\n */\n /**\n * The dash or dot style of the grid lines. For possible values, see\n * [this demonstration](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-dashstyle-all/).\n *\n * @sample {highcharts} highcharts/yaxis/gridlinedashstyle/\n * Long dashes\n * @sample {highstock} stock/xaxis/gridlinedashstyle/\n * Long dashes\n *\n * @type {Highcharts.DashStyleValue}\n * @since 1.2\n */\n gridLineDashStyle: 'Solid',\n /**\n * The Z index of the grid lines.\n *\n * @sample {highcharts|highstock} highcharts/xaxis/gridzindex/\n * A Z index of 4 renders the grid above the graph\n *\n * @product highcharts highstock gantt\n */\n gridZIndex: 1,\n /**\n * An id for the axis. This can be used after render time to get\n * a pointer to the axis object through `chart.get()`.\n *\n * @sample {highcharts} highcharts/xaxis/id/\n * Get the object\n * @sample {highstock} stock/xaxis/id/\n * Get the object\n *\n * @type {string}\n * @since 1.2.0\n * @apioption xAxis.id\n */\n /**\n * The axis labels show the number or category for each tick.\n *\n * Since v8.0.0: Labels are animated in categorized x-axis with\n * updating data if `tickInterval` and `step` is set to 1.\n *\n * @productdesc {highmaps}\n * X and Y axis labels are by default disabled in Highmaps, but the\n * functionality is inherited from Highcharts and used on `colorAxis`,\n * and can be enabled on X and Y axes too.\n */\n labels: {\n /**\n * What part of the string the given position is anchored to.\n * If `left`, the left side of the string is at the axis position.\n * Can be one of `\"left\"`, `\"center\"` or `\"right\"`. Defaults to\n * an intelligent guess based on which side of the chart the axis\n * is on and the rotation of the label.\n *\n * @see [reserveSpace](#xAxis.labels.reserveSpace)\n *\n * @sample {highcharts} highcharts/xaxis/labels-align-left/\n * Left\n * @sample {highcharts} highcharts/xaxis/labels-align-right/\n * Right\n * @sample {highcharts} highcharts/xaxis/labels-reservespace-true/\n * Left-aligned labels on a vertical category axis\n *\n * @type {Highcharts.AlignValue}\n * @apioption xAxis.labels.align\n */\n /**\n * Whether to allow the axis labels to overlap.\n * When false, overlapping labels are hidden.\n *\n * @sample {highcharts} highcharts/xaxis/labels-allowoverlap-true/\n * X axis labels overlap enabled\n *\n * @type {boolean}\n * @default false\n * @apioption xAxis.labels.allowOverlap\n *\n */\n /**\n * For horizontal axes, the allowed degrees of label rotation\n * to prevent overlapping labels. If there is enough space,\n * labels are not rotated. As the chart gets narrower, it\n * will start rotating the labels -45 degrees, then remove\n * every second label and try again with rotations 0 and -45 etc.\n * Set it to `undefined` to disable rotation, which will\n * cause the labels to word-wrap if possible. Defaults to `[-45]``\n * on bottom and top axes, `undefined` on left and right axes.\n *\n * @sample {highcharts|highstock} highcharts/xaxis/labels-autorotation-default/\n * Default auto rotation of 0 or -45\n * @sample {highcharts|highstock} highcharts/xaxis/labels-autorotation-0-90/\n * Custom graded auto rotation\n *\n * @type {Array}\n * @default undefined\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.labels.autoRotation\n */\n autoRotation: void 0,\n /**\n * When each category width is more than this many pixels, we don't\n * apply auto rotation. Instead, we lay out the axis label with word\n * wrap. A lower limit makes sense when the label contains multiple\n * short words that don't extend the available horizontal space for\n * each label.\n *\n * @sample {highcharts} highcharts/xaxis/labels-autorotationlimit/\n * Lower limit\n *\n * @since 4.1.5\n * @product highcharts gantt\n */\n autoRotationLimit: 80,\n /**\n * Polar charts only. The label's pixel distance from the perimeter\n * of the plot area.\n *\n * @type {number}\n * @default undefined\n * @product highcharts gantt\n */\n distance: void 0,\n /**\n * Enable or disable the axis labels.\n *\n * @sample {highcharts} highcharts/xaxis/labels-enabled/\n * X axis labels disabled\n * @sample {highstock} stock/xaxis/labels-enabled/\n * X axis labels disabled\n *\n * @default {highcharts|highstock|gantt} true\n * @default {highmaps} false\n */\n enabled: true,\n /**\n * A format string for the axis label. The context is available as\n * format string variables. For example, you can use `{text}` to\n * insert the default formatted text. The recommended way of adding\n * units for the label is using `text`, for example `{text} km`.\n *\n * To add custom numeric or datetime formatting, use `{value}` with\n * formatting, for example `{value:.1f}` or `{value:%Y-%m-%d}`.\n *\n * See\n * [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for more examples of formatting.\n *\n * The default value is not specified due to the dynamic\n * nature of the default implementation.\n *\n * @sample {highcharts|highstock} highcharts/yaxis/labels-format/\n * Add units to Y axis label\n * @sample {highcharts} highcharts/xaxis/labels-format-linked/\n * Linked category names\n * @sample {highcharts} highcharts/xaxis/labels-format-custom/\n * Custom number format\n *\n * @type {string}\n * @since 3.0\n * @apioption xAxis.labels.format\n */\n /**\n * Callback JavaScript function to format the label. The value\n * is given by `this.value`. Additional properties for `this` are\n * `axis`, `chart`, `isFirst`, `isLast` and `text` which holds the\n * value of the default formatter.\n *\n * Defaults to a built in function returning a formatted string\n * depending on whether the axis is `category`, `datetime`,\n * `numeric` or other.\n *\n * @sample {highcharts} highcharts/xaxis/labels-formatter-linked/\n * Linked category names\n * @sample {highcharts} highcharts/xaxis/labels-formatter-extended/\n * Modified numeric labels\n * @sample {highstock} stock/xaxis/labels-formatter/\n * Added units on Y axis\n *\n * @type {Highcharts.AxisLabelsFormatterCallbackFunction}\n * @apioption xAxis.labels.formatter\n */\n /**\n * The number of pixels to indent the labels per level in a treegrid\n * axis.\n *\n * @sample gantt/treegrid-axis/demo\n * Indentation 10px by default.\n * @sample gantt/treegrid-axis/indentation-0px\n * Indentation set to 0px.\n *\n * @product gantt\n */\n indentation: 10,\n /**\n * Horizontal axis only. When `staggerLines` is not set,\n * `maxStaggerLines` defines how many lines the axis is allowed to\n * add to automatically avoid overlapping X labels. Set to `1` to\n * disable overlap detection.\n *\n * @deprecated\n * @type {number}\n * @default 5\n * @since 1.3.3\n * @apioption xAxis.labels.maxStaggerLines\n */\n /**\n * How to handle overflowing labels on horizontal axis. If set to\n * `\"allow\"`, it will not be aligned at all. By default it\n * `\"justify\"` labels inside the chart area. If there is room to\n * move it, it will be aligned to the edge, else it will be removed.\n *\n * @since 2.2.5\n * @validvalue [\"allow\", \"justify\"]\n */\n overflow: 'justify',\n /**\n * The pixel padding for axis labels, to ensure white space between\n * them.\n *\n * @product highcharts gantt\n */\n padding: 5,\n /**\n * Whether to reserve space for the labels. By default, space is\n * reserved for the labels in these cases:\n *\n * * On all horizontal axes.\n * * On vertical axes if `label.align` is `right` on a left-side\n * axis or `left` on a right-side axis.\n * * On vertical axes if `label.align` is `center`.\n *\n * This can be turned off when for example the labels are rendered\n * inside the plot area instead of outside.\n *\n * @see [labels.align](#xAxis.labels.align)\n *\n * @sample {highcharts} highcharts/xaxis/labels-reservespace/\n * No reserved space, labels inside plot\n * @sample {highcharts} highcharts/xaxis/labels-reservespace-true/\n * Left-aligned labels on a vertical category axis\n *\n * @type {boolean}\n * @since 4.1.10\n * @product highcharts gantt\n * @apioption xAxis.labels.reserveSpace\n */\n reserveSpace: void 0,\n /**\n * Rotation of the labels in degrees. When `undefined`, the\n * `autoRotation` option takes precedence.\n *\n * @sample {highcharts} highcharts/xaxis/labels-rotation/\n * X axis labels rotated 90°\n *\n * @type {number}\n * @default 0\n * @apioption xAxis.labels.rotation\n */\n rotation: void 0,\n /**\n * Horizontal axes only. The number of lines to spread the labels\n * over to make room or tighter labels. 0 disables staggering.\n *\n * @sample {highcharts} highcharts/xaxis/labels-staggerlines/\n * Show labels over two lines\n * @sample {highstock} stock/xaxis/labels-staggerlines/\n * Show labels over two lines\n *\n * @since 2.1\n */\n staggerLines: 0,\n /**\n * To show only every _n_'th label on the axis, set the step to _n_.\n * Setting the step to 2 shows every other label.\n *\n * By default, when 0, the step is calculated automatically to avoid\n * overlap. To prevent this, set it to 1\\. This usually only\n * happens on a category axis, and is often a sign that you have\n * chosen the wrong axis type.\n *\n * Read more at\n * [Axis docs](https://www.highcharts.com/docs/chart-concepts/axes)\n * => What axis should I use?\n *\n * @sample {highcharts} highcharts/xaxis/labels-step/\n * Showing only every other axis label on a categorized\n * x-axis\n * @sample {highcharts} highcharts/xaxis/labels-step-auto/\n * Auto steps on a category axis\n *\n * @since 2.1\n */\n step: 0,\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n */\n useHTML: false,\n /**\n * The x position offset of all labels relative to the tick\n * positions on the axis.\n *\n * @sample {highcharts} highcharts/xaxis/labels-x/\n * Y axis labels placed on grid lines\n */\n x: 0,\n /**\n * The y position offset of all labels relative to the tick\n * positions on the axis. The default makes it adapt to the font\n * size of the bottom axis.\n *\n * @sample {highcharts} highcharts/xaxis/labels-x/\n * Y axis labels placed on grid lines\n *\n * @type {number}\n * @apioption xAxis.labels.y\n */\n /**\n * The Z index for the axis labels.\n */\n zIndex: 7,\n /**\n * CSS styles for the label. Use `whiteSpace: 'nowrap'` to prevent\n * wrapping of category labels. Use `textOverflow: 'none'` to\n * prevent ellipsis (dots).\n *\n * In styled mode, the labels are styled with the\n * `.highcharts-axis-labels` class.\n *\n * @sample {highcharts} highcharts/xaxis/labels-style/\n * Red X axis labels\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @internal */\n color: \"#666666\" /* Palette.neutralColor60 */,\n /** @internal */\n cursor: 'default',\n /** @internal */\n fontSize: '11px'\n }\n },\n /**\n * The left position as the horizontal axis. If it's a number, it is\n * interpreted as pixel position relative to the chart.\n *\n * Since Highcharts v5.0.13: If it's a percentage string, it is\n * interpreted as percentages of the plot width, offset from plot area\n * left.\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption xAxis.left\n */\n /**\n * The top position as the vertical axis. If it's a number, it is\n * interpreted as pixel position relative to the chart.\n *\n * Since Highcharts 2: If it's a percentage string, it is interpreted\n * as percentages of the plot height, offset from plot area top.\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption xAxis.top\n */\n /**\n * Index of another axis that this axis is linked to. When an axis is\n * linked to a master axis, it will take the same extremes as\n * the master, but as assigned by min or max or by setExtremes.\n * It can be used to show additional info, or to ease reading the\n * chart by duplicating the scales.\n *\n * @sample {highcharts} highcharts/xaxis/linkedto/\n * Different string formats of the same date\n * @sample {highcharts} highcharts/yaxis/linkedto/\n * Y values on both sides\n *\n * @type {number}\n * @since 2.0.2\n * @product highcharts highstock gantt\n * @apioption xAxis.linkedTo\n */\n /**\n * The maximum value of the axis. If `null`, the max value is\n * automatically calculated.\n *\n * If the [endOnTick](#yAxis.endOnTick) option is true, the `max` value\n * might be rounded up.\n *\n * If a [tickAmount](#yAxis.tickAmount) is set, the axis may be extended\n * beyond the set max in order to reach the given number of ticks. The\n * same may happen in a chart with multiple axes, determined by [chart.\n * alignTicks](#chart), where a `tickAmount` is applied internally.\n *\n * @sample {highcharts} highcharts/yaxis/max-200/\n * Y axis max of 200\n * @sample {highcharts} highcharts/yaxis/max-logarithmic/\n * Y axis max on logarithmic axis\n * @sample {highstock} stock/xaxis/min-max/\n * Fixed min and max on X axis\n *\n * @type {number|null}\n * @apioption xAxis.max\n */\n /**\n * Padding of the max value relative to the length of the axis. A\n * padding of 0.05 will make a 100px axis 5px longer. This is useful\n * when you don't want the highest data value to appear on the edge\n * of the plot area. When the axis' `max` option is set or a max extreme\n * is set using `axis.setExtremes()`, the maxPadding will be ignored.\n *\n * @productdesc {highstock}\n * For an [ordinal](#xAxis.ordinal) axis, `minPadding` and `maxPadding`\n * are ignored. Use [overscroll](#xAxis.overscroll) instead.\n *\n * @sample {highcharts} highcharts/yaxis/maxpadding/\n * Max padding of 0.25 on y axis\n * @sample {highstock} stock/xaxis/minpadding-maxpadding/\n * Greater min- and maxPadding\n * @sample {highmaps} maps/chart/plotbackgroundcolor-gradient/\n * Add some padding\n *\n * @default {highcharts} 0.01\n * @default {highstock|highmaps} 0\n * @since 1.2.0\n */\n maxPadding: 0.01,\n /**\n * Deprecated. Use `minRange` instead.\n *\n * @deprecated\n * @type {number}\n * @product highcharts highstock\n * @apioption xAxis.maxZoom\n */\n /**\n * The minimum value of the axis. If `null` the min value is\n * automatically calculated.\n *\n * If the [startOnTick](#yAxis.startOnTick) option is true (default),\n * the `min` value might be rounded down.\n *\n * The automatically calculated minimum value is also affected by\n * [floor](#yAxis.floor), [softMin](#yAxis.softMin),\n * [minPadding](#yAxis.minPadding), [minRange](#yAxis.minRange)\n * as well as [series.threshold](#plotOptions.series.threshold)\n * and [series.softThreshold](#plotOptions.series.softThreshold).\n *\n * @sample {highcharts} highcharts/yaxis/min-startontick-false/\n * -50 with startOnTick to false\n * @sample {highcharts} highcharts/yaxis/min-startontick-true/\n * -50 with startOnTick true by default\n * @sample {highstock} stock/xaxis/min-max/\n * Set min and max on X axis\n *\n * @type {number|null}\n * @apioption xAxis.min\n */\n /**\n * The dash or dot style of the minor grid lines. For possible values,\n * see [this demonstration](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-dashstyle-all/).\n *\n * @sample {highcharts} highcharts/yaxis/minorgridlinedashstyle/\n * Long dashes on minor grid lines\n * @sample {highstock} stock/xaxis/minorgridlinedashstyle/\n * Long dashes on minor grid lines\n *\n * @type {Highcharts.DashStyleValue}\n * @since 1.2\n */\n minorGridLineDashStyle: 'Solid',\n /**\n * Specific tick interval in axis units for the minor ticks. On a linear\n * axis, if `\"auto\"`, the minor tick interval is calculated as a fifth\n * of the tickInterval. If `null` or `undefined`, minor ticks are not\n * shown.\n *\n * On logarithmic axes, the unit is the power of the value. For example,\n * setting the minorTickInterval to 1 puts one tick on each of 0.1, 1,\n * 10, 100 etc. Setting the minorTickInterval to 0.1 produces 9 ticks\n * between 1 and 10, 10 and 100 etc.\n *\n * If user settings dictate minor ticks to become too dense, they don't\n * make sense, and will be ignored to prevent performance problems.\n *\n * @sample {highcharts} highcharts/yaxis/minortickinterval-null/\n * Null by default\n * @sample {highcharts} highcharts/yaxis/minortickinterval-5/\n * 5 units\n * @sample {highcharts} highcharts/yaxis/minortickinterval-log-auto/\n * \"auto\"\n * @sample {highcharts} highcharts/yaxis/minortickinterval-log/\n * 0.1\n * @sample {highstock} stock/demo/basic-line/\n * Null by default\n * @sample {highstock} stock/xaxis/minortickinterval-auto/\n * \"auto\"\n *\n * @type {number|string|null}\n * @apioption xAxis.minorTickInterval\n */\n /**\n * The pixel length of the minor tick marks.\n *\n * @sample {highcharts} highcharts/yaxis/minorticklength/\n * 10px on Y axis\n * @sample {highstock} stock/xaxis/minorticks/\n * 10px on Y axis\n */\n minorTickLength: 2,\n /**\n * The position of the minor tick marks relative to the axis line.\n * Can be one of `inside` and `outside`.\n *\n * @sample {highcharts} highcharts/yaxis/minortickposition-outside/\n * Outside by default\n * @sample {highcharts} highcharts/yaxis/minortickposition-inside/\n * Inside\n * @sample {highstock} stock/xaxis/minorticks/\n * Inside\n *\n * @validvalue [\"inside\", \"outside\"]\n */\n minorTickPosition: 'outside',\n /**\n * Enable or disable minor ticks. Unless\n * [minorTickInterval](#xAxis.minorTickInterval) is set, the tick\n * interval is calculated as a fifth of the `tickInterval`.\n *\n * On a logarithmic axis, minor ticks are laid out based on a best\n * guess, attempting to enter approximately 5 minor ticks between\n * each major tick.\n *\n * Prior to v6.0.0, ticks were unabled in auto layout by setting\n * `minorTickInterval` to `\"auto\"`.\n *\n * @productdesc {highcharts}\n * On axes using [categories](#xAxis.categories), minor ticks are not\n * supported.\n *\n * @sample {highcharts} highcharts/yaxis/minorticks-true/\n * Enabled on linear Y axis\n *\n * @type {boolean}\n * @default false\n * @since 6.0.0\n * @apioption xAxis.minorTicks\n */\n /**\n * The pixel width of the minor tick mark.\n *\n * @sample {highcharts} highcharts/yaxis/minortickwidth/\n * 3px width\n * @sample {highstock} stock/xaxis/minorticks/\n * 1px width\n *\n * @type {number}\n * @default 0\n * @apioption xAxis.minorTickWidth\n */\n /**\n * Padding of the min value relative to the length of the axis. A\n * padding of 0.05 will make a 100px axis 5px longer. This is useful\n * when you don't want the lowest data value to appear on the edge\n * of the plot area. When the axis' `min` option is set or a min extreme\n * is set using `axis.setExtremes()`, the minPadding will be ignored.\n *\n * @productdesc {highstock}\n * For an [ordinal](#xAxis.ordinal) axis, `minPadding` and `maxPadding`\n * are ignored. Use [overscroll](#xAxis.overscroll) instead.\n *\n * @sample {highcharts} highcharts/yaxis/minpadding/\n * Min padding of 0.2\n * @sample {highstock} stock/xaxis/minpadding-maxpadding/\n * Greater min- and maxPadding\n * @sample {highmaps} maps/chart/plotbackgroundcolor-gradient/\n * Add some padding\n *\n * @default {highcharts} 0.01\n * @default {highstock|highmaps} 0\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n minPadding: 0.01,\n /**\n * The minimum range to display on this axis. The entire axis will not\n * be allowed to span over a smaller interval than this. For example,\n * for a datetime axis the main unit is milliseconds. If minRange is\n * set to 3600000, you can't zoom in more than to one hour.\n *\n * The default minRange for the x axis is five times the smallest\n * interval between any of the data points.\n *\n * On a logarithmic axis, the unit for the minimum range is the power.\n * So a minRange of 1 means that the axis can be zoomed to 10-100,\n * 100-1000, 1000-10000 etc.\n *\n * **Note**: The `minPadding`, `maxPadding`, `startOnTick` and\n * `endOnTick` settings also affect how the extremes of the axis\n * are computed.\n *\n * @sample {highcharts} highcharts/xaxis/minrange/\n * Minimum range of 5\n * @sample {highstock} stock/xaxis/minrange/\n * Max zoom of 6 months overrides user selections\n *\n * @type {number}\n * @apioption xAxis.minRange\n */\n /**\n * The minimum tick interval allowed in axis values. For example on\n * zooming in on an axis with daily data, this can be used to prevent\n * the axis from showing hours. Defaults to the closest distance between\n * two points on the axis.\n *\n * @type {number}\n * @since 2.3.0\n * @apioption xAxis.minTickInterval\n */\n /**\n * The distance in pixels from the plot area to the axis line.\n * A positive offset moves the axis with it's line, labels and ticks\n * away from the plot area. This is typically used when two or more\n * axes are displayed on the same side of the plot. With multiple\n * axes the offset is dynamically adjusted to avoid collision, this\n * can be overridden by setting offset explicitly.\n *\n * @sample {highcharts} highcharts/yaxis/offset/\n * Y axis offset of 70\n * @sample {highcharts} highcharts/yaxis/offset-centered/\n * Axes positioned in the center of the plot\n * @sample {highstock} stock/xaxis/offset/\n * Y axis offset by 70 px\n *\n * @type {number}\n */\n offset: void 0,\n /**\n * Whether to display the axis on the opposite side of the normal. The\n * normal is on the left side for vertical axes and bottom for\n * horizontal, so the opposite sides will be right and top respectively.\n * This is typically used with dual or multiple axes.\n *\n * @sample {highcharts} highcharts/yaxis/opposite/\n * Secondary Y axis opposite\n * @sample {highstock} stock/xaxis/opposite/\n * Y axis on left side\n *\n * @default {highcharts|highstock|highmaps} false\n * @default {gantt} true\n */\n opposite: false,\n /**\n * In an ordinal axis, the points are equally spaced in the chart\n * regardless of the actual time or x distance between them. This means\n * that missing data periods (e.g. nights or weekends for a stock chart)\n * will not take up space in the chart.\n * Having `ordinal: false` will show any gaps created by the `gapSize`\n * setting proportionate to their duration.\n *\n * In stock charts the X axis is ordinal by default, unless\n * the boost module is used and at least one of the series' data length\n * exceeds the [boostThreshold](#series.line.boostThreshold).\n *\n * For an ordinal axis, `minPadding` and `maxPadding` are ignored. Use\n * [overscroll](#xAxis.overscroll) instead.\n *\n * @sample {highstock} stock/xaxis/ordinal-true/\n * True by default\n * @sample {highstock} stock/xaxis/ordinal-false/\n * False\n *\n * @see [overscroll](#xAxis.overscroll)\n *\n * @type {boolean}\n * @default true\n * @since 1.1\n * @product highstock\n * @apioption xAxis.ordinal\n */\n /**\n * Additional range on the right side of the xAxis. Works similar to\n * `xAxis.maxPadding`, but value is set in milliseconds. Can be set for\n * both main `xAxis` and the navigator's `xAxis`.\n *\n * @sample {highstock} stock/xaxis/overscroll/\n * One minute overscroll with live data\n *\n * @type {number}\n * @default 0\n * @since 6.0.0\n * @product highstock\n * @apioption xAxis.overscroll\n */\n /**\n * Refers to the index in the [panes](#panes) array. Used for circular\n * gauges and polar charts. When the option is not set then first pane\n * will be used.\n *\n * @sample highcharts/demo/gauge-vu-meter\n * Two gauges with different center\n *\n * @type {number}\n * @product highcharts\n * @apioption xAxis.pane\n */\n /**\n * The zoomed range to display when only defining one or none of `min`\n * or `max`. For example, to show the latest month, a range of one month\n * can be set.\n *\n * @sample {highstock} stock/xaxis/range/\n * Setting a zoomed range when the rangeSelector is disabled\n *\n * @type {number}\n * @product highstock\n * @apioption xAxis.range\n */\n /**\n * Whether to reverse the axis so that the highest number is closest\n * to the origin. If the chart is inverted, the x axis is reversed by\n * default.\n *\n * @sample {highcharts} highcharts/yaxis/reversed/\n * Reversed Y axis\n * @sample {highstock} stock/xaxis/reversed/\n * Reversed Y axis\n *\n * @type {boolean}\n * @default undefined\n * @apioption xAxis.reversed\n */\n reversed: void 0,\n /**\n * This option determines how stacks should be ordered within a group.\n * For example reversed xAxis also reverses stacks, so first series\n * comes last in a group. To keep order like for non-reversed xAxis\n * enable this option.\n *\n * @sample {highcharts} highcharts/xaxis/reversedstacks/\n * Reversed stacks comparison\n * @sample {highstock} highcharts/xaxis/reversedstacks/\n * Reversed stacks comparison\n *\n * @since 6.1.1\n * @product highcharts highstock\n */\n reversedStacks: false,\n /**\n * An optional scrollbar to display on the X axis in response to\n * limiting the minimum and maximum of the axis values.\n *\n * In styled mode, all the presentational options for the scrollbar are\n * replaced by the classes `.highcharts-scrollbar-thumb`,\n * `.highcharts-scrollbar-arrow`, `.highcharts-scrollbar-button`,\n * `.highcharts-scrollbar-rifles` and `.highcharts-scrollbar-track`.\n *\n * @sample {highstock} stock/yaxis/heatmap-scrollbars/\n * Heatmap with both scrollbars\n *\n * @extends scrollbar\n * @since 4.2.6\n * @product highstock\n * @apioption xAxis.scrollbar\n */\n /**\n * Whether to show the axis line and title when the axis has no data.\n *\n * @sample {highcharts} highcharts/yaxis/showempty/\n * When clicking the legend to hide series, one axis preserves\n * line and title, the other doesn't\n * @sample {highstock} highcharts/yaxis/showempty/\n * When clicking the legend to hide series, one axis preserves\n * line and title, the other doesn't\n *\n * @since 1.1\n */\n showEmpty: true,\n /**\n * Whether to show the first tick label.\n *\n * @sample {highcharts} highcharts/xaxis/showfirstlabel-false/\n * Set to false on X axis\n * @sample {highstock} stock/xaxis/showfirstlabel/\n * Labels below plot lines on Y axis\n */\n showFirstLabel: true,\n /**\n * Whether to show the last tick label. Defaults to `true` on cartesian\n * charts, and `false` on polar charts.\n *\n * @sample {highcharts} highcharts/xaxis/showlastlabel-true/\n * Set to true on X axis\n * @sample {highstock} stock/xaxis/showfirstlabel/\n * Labels below plot lines on Y axis\n *\n * @type {boolean}\n * @default undefined\n * @product highcharts highstock gantt\n */\n showLastLabel: true,\n /**\n * A soft maximum for the axis. If the series data maximum is less than\n * this, the axis will stay at this maximum, but if the series data\n * maximum is higher, the axis will flex to show all data.\n *\n * @sample highcharts/yaxis/softmin-softmax/\n * Soft min and max\n *\n * @type {number}\n * @since 5.0.1\n * @product highcharts highstock gantt\n * @apioption xAxis.softMax\n */\n /**\n * A soft minimum for the axis. If the series data minimum is greater\n * than this, the axis will stay at this minimum, but if the series\n * data minimum is lower, the axis will flex to show all data.\n *\n * @sample highcharts/yaxis/softmin-softmax/\n * Soft min and max\n *\n * @type {number}\n * @since 5.0.1\n * @product highcharts highstock gantt\n * @apioption xAxis.softMin\n */\n /**\n * For datetime axes, this decides where to put the tick between weeks.\n * 0 = Sunday, 1 = Monday.\n *\n * @sample {highcharts} highcharts/xaxis/startofweek-monday/\n * Monday by default\n * @sample {highcharts} highcharts/xaxis/startofweek-sunday/\n * Sunday\n * @sample {highstock} stock/xaxis/startofweek-1\n * Monday by default\n * @sample {highstock} stock/xaxis/startofweek-0\n * Sunday\n *\n * @product highcharts highstock gantt\n */\n startOfWeek: 1,\n /**\n * Whether to force the axis to start on a tick. Use this option with\n * the `minPadding` option to control the axis start.\n *\n * @productdesc {highstock}\n * In Highcharts Stock, `startOnTick` is always `false` when\n * the navigator is enabled, to prevent jumpy scrolling.\n *\n * @sample {highcharts} highcharts/xaxis/startontick-false/\n * False by default\n * @sample {highcharts} highcharts/xaxis/startontick-true/\n * True\n *\n * @since 1.2.0\n */\n startOnTick: false,\n /**\n * The amount of ticks to draw on the axis. This opens up for aligning\n * the ticks of multiple charts or panes within a chart. This option\n * overrides the `tickPixelInterval` option.\n *\n * This option only has an effect on linear axes. Datetime, logarithmic\n * or category axes are not affected.\n *\n * @sample {highcharts} highcharts/yaxis/tickamount/\n * 8 ticks on Y axis\n * @sample {highstock} highcharts/yaxis/tickamount/\n * 8 ticks on Y axis\n *\n * @type {number}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.tickAmount\n */\n /**\n * The interval of the tick marks in axis units. When `undefined`, the\n * tick interval is computed to approximately follow the\n * [tickPixelInterval](#xAxis.tickPixelInterval) on linear and datetime\n * axes. On categorized axes, a `undefined` tickInterval will default to\n * 1, one category. Note that datetime axes are based on milliseconds,\n * so for example an interval of one day is expressed as\n * `24 * 3600 * 1000`.\n *\n * On logarithmic axes, the tickInterval is based on powers, so a\n * tickInterval of 1 means one tick on each of 0.1, 1, 10, 100 etc. A\n * tickInterval of 2 means a tick of 0.1, 10, 1000 etc. A tickInterval\n * of 0.2 puts a tick on 0.1, 0.2, 0.4, 0.6, 0.8, 1, 2, 4, 6, 8, 10, 20,\n * 40 etc.\n *\n *\n * If the tickInterval is too dense for labels to be drawn, Highcharts\n * may remove ticks.\n *\n * If the chart has multiple axes, the [alignTicks](#chart.alignTicks)\n * option may interfere with the `tickInterval` setting.\n *\n * @see [tickPixelInterval](#xAxis.tickPixelInterval)\n * @see [tickPositions](#xAxis.tickPositions)\n * @see [tickPositioner](#xAxis.tickPositioner)\n *\n * @sample {highcharts} highcharts/xaxis/tickinterval-5/\n * Tick interval of 5 on a linear axis\n * @sample {highstock} stock/xaxis/tickinterval/\n * Tick interval of 0.01 on Y axis\n *\n * @type {number}\n * @apioption xAxis.tickInterval\n */\n /**\n * The pixel length of the main tick marks.\n *\n * @sample {highcharts} highcharts/xaxis/ticklength/\n * 20 px tick length on the X axis\n * @sample {highstock} stock/xaxis/ticks/\n * Formatted ticks on X axis\n */\n tickLength: 10,\n /**\n * If tickInterval is `null` this option sets the approximate pixel\n * interval of the tick marks. Not applicable to categorized axis.\n *\n * The tick interval is also influenced by the [minTickInterval](\n * #xAxis.minTickInterval) option, that, by default prevents ticks from\n * being denser than the data points.\n *\n * @see [tickInterval](#xAxis.tickInterval)\n * @see [tickPositioner](#xAxis.tickPositioner)\n * @see [tickPositions](#xAxis.tickPositions)\n *\n * @sample {highcharts} highcharts/xaxis/tickpixelinterval-50/\n * 50 px on X axis\n * @sample {highstock} stock/xaxis/tickpixelinterval/\n * 200 px on X axis\n */\n tickPixelInterval: 100,\n /**\n * For categorized axes only. If `on` the tick mark is placed in the\n * center of the category, if `between` the tick mark is placed between\n * categories. The default is `between` if the `tickInterval` is 1, else\n * `on`.\n *\n * @sample {highcharts} highcharts/xaxis/tickmarkplacement-between/\n * \"between\" by default\n * @sample {highcharts} highcharts/xaxis/tickmarkplacement-on/\n * \"on\"\n *\n * @product highcharts gantt\n * @validvalue [\"on\", \"between\"]\n */\n tickmarkPlacement: 'between',\n /**\n * The position of the major tick marks relative to the axis line.\n * Can be one of `inside` and `outside`.\n *\n * @sample {highcharts} highcharts/xaxis/tickposition-outside/\n * \"outside\" by default\n * @sample {highcharts} highcharts/xaxis/tickposition-inside/\n * \"inside\"\n * @sample {highstock} stock/xaxis/ticks/\n * Formatted ticks on X axis\n *\n * @validvalue [\"inside\", \"outside\"]\n */\n tickPosition: 'outside',\n /**\n * A callback function returning array defining where the ticks are\n * laid out on the axis. This overrides the default behaviour of\n * [tickPixelInterval](#xAxis.tickPixelInterval) and [tickInterval](\n * #xAxis.tickInterval). The automatic tick positions are accessible\n * through `this.tickPositions` and can be modified by the callback.\n *\n * @see [tickPositions](#xAxis.tickPositions)\n *\n * @sample {highcharts} highcharts/xaxis/tickpositions-tickpositioner/\n * Demo of tickPositions and tickPositioner\n * @sample {highstock} highcharts/xaxis/tickpositions-tickpositioner/\n * Demo of tickPositions and tickPositioner\n *\n * @type {Highcharts.AxisTickPositionerCallbackFunction}\n * @apioption xAxis.tickPositioner\n */\n /**\n * An array defining where the ticks are laid out on the axis. This\n * overrides the default behaviour of [tickPixelInterval](\n * #xAxis.tickPixelInterval) and [tickInterval](#xAxis.tickInterval).\n *\n * @see [tickPositioner](#xAxis.tickPositioner)\n *\n * @sample {highcharts} highcharts/xaxis/tickpositions-tickpositioner/\n * Demo of tickPositions and tickPositioner\n * @sample {highstock} highcharts/xaxis/tickpositions-tickpositioner/\n * Demo of tickPositions and tickPositioner\n *\n * @type {Array}\n * @apioption xAxis.tickPositions\n */\n /**\n * The pixel width of the major tick marks. Defaults to 0 on category\n * axes, otherwise 1.\n *\n * In styled mode, the stroke width is given in the `.highcharts-tick`\n * class, but in order for the element to be generated on category axes,\n * the option must be explicitly set to 1.\n *\n * @sample {highcharts} highcharts/xaxis/tickwidth/\n * 10 px width\n * @sample {highcharts} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/ticks/\n * Formatted ticks on X axis\n * @sample {highstock} highcharts/css/axis-grid/\n * Styled mode\n *\n * @type {undefined|number}\n * @default {highstock} 1\n * @default {highmaps} 0\n * @apioption xAxis.tickWidth\n */\n /**\n * The axis title, showing next to the axis line.\n *\n * @productdesc {highmaps}\n * In Highmaps, the axis is hidden by default, but adding an axis title\n * is still possible. X axis and Y axis titles will appear at the bottom\n * and left by default.\n */\n title: {\n /**\n * Alignment of the title relative to the axis values. Possible\n * values are \"low\", \"middle\" or \"high\".\n *\n * @sample {highcharts} highcharts/xaxis/title-align-low/\n * \"low\"\n * @sample {highcharts} highcharts/xaxis/title-align-center/\n * \"middle\" by default\n * @sample {highcharts} highcharts/xaxis/title-align-high/\n * \"high\"\n * @sample {highcharts} highcharts/yaxis/title-offset/\n * Place the Y axis title on top of the axis\n * @sample {highstock} stock/xaxis/title-align/\n * Aligned to \"high\" value\n *\n * @type {Highcharts.AxisTitleAlignValue}\n */\n align: 'middle',\n /**\n * Deprecated. Set the `text` to `undefined` to disable the title.\n *\n * @deprecated\n * @type {boolean}\n * @product highcharts\n * @apioption xAxis.title.enabled\n */\n /**\n * The pixel distance between the axis labels or line and the title.\n * Defaults to 0 for horizontal axes, 10 for vertical\n *\n * @sample {highcharts} highcharts/xaxis/title-margin/\n * Y axis title margin of 60\n *\n * @type {number}\n * @apioption xAxis.title.margin\n */\n /**\n * The distance of the axis title from the axis line. By default,\n * this distance is computed from the offset width of the labels,\n * the labels' distance from the axis and the title's margin.\n * However when the offset option is set, it overrides all this.\n *\n * @sample {highcharts} highcharts/yaxis/title-offset/\n * Place the axis title on top of the axis\n * @sample {highstock} highcharts/yaxis/title-offset/\n * Place the axis title on top of the Y axis\n *\n * @type {number}\n * @since 2.2.0\n * @apioption xAxis.title.offset\n */\n /**\n * Whether to reserve space for the title when laying out the axis.\n *\n * @type {boolean}\n * @default true\n * @since 5.0.11\n * @product highcharts highstock gantt\n * @apioption xAxis.title.reserveSpace\n */\n /**\n * The rotation of the text in degrees. 0 is horizontal, 270 is\n * vertical reading from bottom to top.\n *\n * @sample {highcharts} highcharts/yaxis/title-offset/\n * Horizontal\n */\n rotation: 0,\n /**\n * The actual text of the axis title. It can contain basic HTML tags\n * like `b`, `i` and `span` with style.\n *\n * @sample {highcharts} highcharts/xaxis/title-text/\n * Custom HTML\n * @sample {highstock} stock/xaxis/title-text/\n * Titles for both axes\n *\n * @type {string|null}\n * @apioption xAxis.title.text\n */\n /**\n * Alignment of the text, can be `\"left\"`, `\"right\"` or `\"center\"`.\n * Default alignment depends on the\n * [title.align](xAxis.title.align):\n *\n * Horizontal axes:\n * - for `align` = `\"low\"`, `textAlign` is set to `left`\n * - for `align` = `\"middle\"`, `textAlign` is set to `center`\n * - for `align` = `\"high\"`, `textAlign` is set to `right`\n *\n * Vertical axes:\n * - for `align` = `\"low\"` and `opposite` = `true`, `textAlign` is\n * set to `right`\n * - for `align` = `\"low\"` and `opposite` = `false`, `textAlign` is\n * set to `left`\n * - for `align` = `\"middle\"`, `textAlign` is set to `center`\n * - for `align` = `\"high\"` and `opposite` = `true` `textAlign` is\n * set to `left`\n * - for `align` = `\"high\"` and `opposite` = `false` `textAlign` is\n * set to `right`\n *\n * @type {Highcharts.AlignValue}\n * @apioption xAxis.title.textAlign\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the axis title.\n *\n * @product highcharts highstock gantt\n */\n useHTML: false,\n /**\n * Horizontal pixel offset of the title position.\n *\n * @since 4.1.6\n * @product highcharts highstock gantt\n */\n x: 0,\n /**\n * Vertical pixel offset of the title position.\n *\n * @product highcharts highstock gantt\n */\n y: 0,\n /**\n * CSS styles for the title. If the title text is longer than the\n * axis length, it will wrap to multiple lines by default. This can\n * be customized by setting `textOverflow: 'ellipsis'`, by\n * setting a specific `width` or by setting `whiteSpace: 'nowrap'`.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-axis-title` class.\n *\n * @sample {highcharts} highcharts/xaxis/title-style/\n * Red\n * @sample {highcharts} highcharts/css/axis/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @internal */\n color: \"#666666\" /* Palette.neutralColor60 */\n }\n },\n /**\n * The type of axis. Can be one of `linear`, `logarithmic`, `datetime`\n * or `category`. In a datetime axis, the numbers are given in\n * milliseconds, and tick marks are placed on appropriate values like\n * full hours or days. In a category axis, the\n * [point names](#series.line.data.name) of the chart's series are used\n * for categories, if not a [categories](#xAxis.categories) array is\n * defined.\n *\n * @sample {highcharts} highcharts/xaxis/type-linear/\n * Linear\n * @sample {highcharts} highcharts/yaxis/type-log/\n * Logarithmic\n * @sample {highcharts} highcharts/yaxis/type-log-minorgrid/\n * Logarithmic with minor grid lines\n * @sample {highcharts} highcharts/xaxis/type-log-both/\n * Logarithmic on two axes\n * @sample {highcharts} highcharts/yaxis/type-log-negative/\n * Logarithmic with extension to emulate negative values\n *\n * @type {Highcharts.AxisTypeValue}\n * @product highcharts gantt\n */\n type: 'linear',\n /**\n * If there are multiple axes on the same side of the chart, the pixel\n * margin between the axes. Defaults to 0 on vertical axes, 15 on\n * horizontal axes.\n *\n * @type {number}\n * @since 7.0.3\n * @apioption xAxis.margin\n */\n /**\n * Applies only when the axis `type` is `category`. When `uniqueNames`\n * is true, points are placed on the X axis according to their names.\n * If the same point name is repeated in the same or another series,\n * the point is placed on the same X position as other points of the\n * same name. When `uniqueNames` is false, the points are laid out in\n * increasing X positions regardless of their names, and the X axis\n * category will take the name of the last point in each position.\n *\n * @sample {highcharts} highcharts/xaxis/uniquenames-true/\n * True by default\n * @sample {highcharts} highcharts/xaxis/uniquenames-false/\n * False\n *\n * @since 4.2.7\n * @product highcharts gantt\n */\n uniqueNames: true,\n /**\n * Datetime axis only. An array determining what time intervals the\n * ticks are allowed to fall on. Each array item is an array where the\n * first value is the time unit and the second value another array of\n * allowed multiples.\n *\n * Defaults to:\n * ```js\n * units: [[\n * 'millisecond', // unit name\n * [1, 2, 5, 10, 20, 25, 50, 100, 200, 500] // allowed multiples\n * ], [\n * 'second',\n * [1, 2, 5, 10, 15, 30]\n * ], [\n * 'minute',\n * [1, 2, 5, 10, 15, 30]\n * ], [\n * 'hour',\n * [1, 2, 3, 4, 6, 8, 12]\n * ], [\n * 'day',\n * [1, 2]\n * ], [\n * 'week',\n * [1, 2]\n * ], [\n * 'month',\n * [1, 2, 3, 4, 6]\n * ], [\n * 'year',\n * null\n * ]]\n * ```\n *\n * @type {Array|null)>>}\n * @product highcharts highstock gantt\n * @apioption xAxis.units\n */\n /**\n * Whether axis, including axis title, line, ticks and labels, should\n * be visible.\n *\n * @since 4.1.9\n * @product highcharts highstock gantt\n */\n visible: true,\n /**\n * Color of the minor, secondary grid lines.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-minor-grid-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/minorgridlinecolor/\n * Bright grey lines from Y axis\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/minorgridlinecolor/\n * Bright grey lines from Y axis\n *\n * @type {Highcharts.ColorType}\n * @default #f2f2f2\n */\n minorGridLineColor: \"#f2f2f2\" /* Palette.neutralColor5 */,\n /**\n * Width of the minor, secondary grid lines.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-grid-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/minorgridlinewidth/\n * 2px lines from Y axis\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/minorgridlinewidth/\n * 2px lines from Y axis\n */\n minorGridLineWidth: 1,\n /**\n * Color for the minor tick marks.\n *\n * @sample {highcharts} highcharts/yaxis/minortickcolor/\n * Black tick marks on Y axis\n * @sample {highstock} stock/xaxis/minorticks/\n * Black tick marks on Y axis\n *\n * @type {Highcharts.ColorType}\n * @default #999999\n */\n minorTickColor: \"#999999\" /* Palette.neutralColor40 */,\n /**\n * The color of the line marking the axis itself.\n *\n * In styled mode, the line stroke is given in the\n * `.highcharts-axis-line` or `.highcharts-xaxis-line` class.\n *\n * @productdesc {highmaps}\n * In Highmaps, the axis line is hidden by default, because the axis is\n * not visible by default.\n *\n * @sample {highcharts} highcharts/yaxis/linecolor/\n * A red line on Y axis\n * @sample {highcharts|highstock} highcharts/css/axis/\n * Axes in styled mode\n * @sample {highstock} stock/xaxis/linecolor/\n * A red line on X axis\n *\n * @type {Highcharts.ColorType}\n * @default #ccd6eb\n */\n lineColor: \"#ccd6eb\" /* Palette.highlightColor20 */,\n /**\n * The width of the line marking the axis itself.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-axis-line` or `.highcharts-xaxis-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/linecolor/\n * A 1px line on Y axis\n * @sample {highcharts|highstock} highcharts/css/axis/\n * Axes in styled mode\n * @sample {highstock} stock/xaxis/linewidth/\n * A 2px line on X axis\n *\n * @default {highcharts|highstock} 1\n * @default {highmaps} 0\n */\n lineWidth: 1,\n /**\n * Color of the grid lines extending the ticks across the plot area.\n *\n * In styled mode, the stroke is given in the `.highcharts-grid-line`\n * class.\n *\n * @productdesc {highmaps}\n * In Highmaps, the grid lines are hidden by default.\n *\n * @sample {highcharts} highcharts/yaxis/gridlinecolor/\n * Green lines\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/gridlinecolor/\n * Green lines\n *\n * @type {Highcharts.ColorType}\n * @default #e6e6e6\n */\n gridLineColor: \"#e6e6e6\" /* Palette.neutralColor10 */,\n /**\n * The width of the grid lines extending the ticks across the plot area.\n * Defaults to 1 on the Y axis and 0 on the X axis, except for 3d\n * charts.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-grid-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/gridlinewidth/\n * 2px lines\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/gridlinewidth/\n * 2px lines\n *\n * @type {number}\n * @apioption xAxis.gridLineWidth\n */\n gridLineWidth: void 0,\n /**\n * The height as the vertical axis. If it's a number, it is\n * interpreted as pixels.\n *\n * Since Highcharts 2: If it's a percentage string, it is interpreted\n * as percentages of the total plot height.\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption xAxis.height\n */\n /**\n * The width as the horizontal axis. If it's a number, it is interpreted\n * as pixels.\n *\n * Since Highcharts v5.0.13: If it's a percentage string, it is\n * interpreted as percentages of the total plot width.\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption xAxis.width\n */\n /**\n * Color for the main tick marks.\n *\n * In styled mode, the stroke is given in the `.highcharts-tick`\n * class.\n *\n * @sample {highcharts} highcharts/xaxis/tickcolor/\n * Red ticks on X axis\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/ticks/\n * Formatted ticks on X axis\n *\n * @type {Highcharts.ColorType}\n * @default #ccd6eb\n */\n tickColor: \"#ccd6eb\" /* Palette.highlightColor20 */\n // tickWidth: 1\n };\n /**\n * The Y axis or value axis. Normally this is the vertical axis,\n * though if the chart is inverted this is the horizontal axis.\n * In case of multiple axes, the yAxis node is an array of\n * configuration objects.\n *\n * See [the Axis object](/class-reference/Highcharts.Axis) for programmatic\n * access to the axis.\n *\n * @type {*|Array<*>}\n * @extends xAxis\n * @excluding currentDateIndicator,ordinal,overscroll\n * @optionparent yAxis\n */\n AxisDefaults.defaultYAxisOptions = {\n /**\n * The type of axis. Can be one of `linear`, `logarithmic`, `datetime`,\n * `category` or `treegrid`. Defaults to `treegrid` for Gantt charts,\n * `linear` for other chart types.\n *\n * In a datetime axis, the numbers are given in milliseconds, and tick\n * marks are placed on appropriate values, like full hours or days. In a\n * category or treegrid axis, the [point names](#series.line.data.name)\n * of the chart's series are used for categories, if a\n * [categories](#xAxis.categories) array is not defined.\n *\n * @sample {highcharts} highcharts/yaxis/type-log-minorgrid/\n * Logarithmic with minor grid lines\n * @sample {highcharts} highcharts/yaxis/type-log-negative/\n * Logarithmic with extension to emulate negative values\n * @sample {gantt} gantt/treegrid-axis/demo\n * Treegrid axis\n *\n * @type {Highcharts.AxisTypeValue}\n * @default {highcharts} linear\n * @default {gantt} treegrid\n * @product highcharts gantt\n * @apioption yAxis.type\n */\n /**\n * The height of the Y axis. If it's a number, it is interpreted as\n * pixels.\n *\n * Since Highcharts 2: If it's a percentage string, it is interpreted as\n * percentages of the total plot height.\n *\n * @see [yAxis.top](#yAxis.top)\n *\n * @sample {highstock} stock/demo/candlestick-and-volume/\n * Percentage height panes\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption yAxis.height\n */\n /**\n * Solid gauge only. Unless [stops](#yAxis.stops) are set, the color\n * to represent the maximum value of the Y axis.\n *\n * @sample {highcharts} highcharts/yaxis/mincolor-maxcolor/\n * Min and max colors\n *\n * @type {Highcharts.ColorType}\n * @default #003399\n * @since 4.0\n * @product highcharts\n * @apioption yAxis.maxColor\n */\n /**\n * Solid gauge only. Unless [stops](#yAxis.stops) are set, the color\n * to represent the minimum value of the Y axis.\n *\n * @sample {highcharts} highcharts/yaxis/mincolor-maxcolor/\n * Min and max color\n *\n * @type {Highcharts.ColorType}\n * @default #e6ebf5\n * @since 4.0\n * @product highcharts\n * @apioption yAxis.minColor\n */\n /**\n * Whether to reverse the axis so that the highest number is closest\n * to the origin.\n *\n * @sample {highcharts} highcharts/yaxis/reversed/\n * Reversed Y axis\n * @sample {highstock} stock/xaxis/reversed/\n * Reversed Y axis\n *\n * @type {boolean}\n * @default {highcharts} false\n * @default {highstock} false\n * @default {highmaps} true\n * @default {gantt} true\n * @apioption yAxis.reversed\n */\n /**\n * If `true`, the first series in a stack will be drawn on top in a\n * positive, non-reversed Y axis. If `false`, the first series is in\n * the base of the stack.\n *\n * @sample {highcharts} highcharts/yaxis/reversedstacks-false/\n * Non-reversed stacks\n * @sample {highstock} highcharts/yaxis/reversedstacks-false/\n * Non-reversed stacks\n *\n * @type {boolean}\n * @default true\n * @since 3.0.10\n * @product highcharts highstock\n * @apioption yAxis.reversedStacks\n */\n reversedStacks: true,\n /**\n * Solid gauge series only. Color stops for the solid gauge. Use this\n * in cases where a linear gradient between a `minColor` and `maxColor`\n * is not sufficient. The stops is an array of tuples, where the first\n * item is a float between 0 and 1 assigning the relative position in\n * the gradient, and the second item is the color.\n *\n * For solid gauges, the Y axis also inherits the concept of\n * [data classes](https://api.highcharts.com/highmaps#colorAxis.dataClasses)\n * from the Highmaps color axis.\n *\n * @sample {highcharts} highcharts/demo/gauge-solid/\n * Gauge with stops\n *\n * @see [minColor](#yAxis.minColor)\n * @see [maxColor](#yAxis.maxColor)\n *\n * @type {Array>}\n * @since 4.0\n * @product highcharts\n * @apioption yAxis.stops\n */\n /**\n * The pixel width of the major tick marks.\n *\n * @sample {highcharts} highcharts/xaxis/tickwidth/ 10 px width\n * @sample {highstock} stock/xaxis/ticks/ Formatted ticks on X axis\n *\n * @type {number}\n * @default 0\n * @product highcharts highstock gantt\n * @apioption yAxis.tickWidth\n */\n /**\n * Whether to force the axis to end on a tick. Use this option with\n * the `maxPadding` option to control the axis end.\n *\n * This option is always disabled, when panning type is\n * either `y` or `xy`.\n *\n * @see [type](#chart.panning.type)\n *\n *\n * @sample {highcharts} highcharts/yaxis/endontick/\n * True by default\n * @sample {highcharts} highcharts/yaxis/endontick-false/\n * False\n * @sample {highstock} stock/demo/basic-line/\n * True by default\n * @sample {highstock} stock/xaxis/endontick/\n * False for Y axis\n *\n * @since 1.2.0\n */\n endOnTick: true,\n /**\n * Padding of the max value relative to the length of the axis. A\n * padding of 0.05 will make a 100px axis 5px longer. This is useful\n * when you don't want the highest data value to appear on the edge\n * of the plot area. When the axis' `max` option is set or a max extreme\n * is set using `axis.setExtremes()`, the maxPadding will be ignored.\n *\n * Also the `softThreshold` option takes precedence over `maxPadding`,\n * so if the data is tangent to the threshold, `maxPadding` may not\n * apply unless `softThreshold` is set to false.\n *\n * @sample {highcharts} highcharts/yaxis/maxpadding-02/\n * Max padding of 0.2\n * @sample {highstock} stock/xaxis/minpadding-maxpadding/\n * Greater min- and maxPadding\n *\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n maxPadding: 0.05,\n /**\n * Padding of the min value relative to the length of the axis. A\n * padding of 0.05 will make a 100px axis 5px longer. This is useful\n * when you don't want the lowest data value to appear on the edge\n * of the plot area. When the axis' `min` option is set or a max extreme\n * is set using `axis.setExtremes()`, the maxPadding will be ignored.\n *\n * Also the `softThreshold` option takes precedence over `minPadding`,\n * so if the data is tangent to the threshold, `minPadding` may not\n * apply unless `softThreshold` is set to false.\n *\n * @sample {highcharts} highcharts/yaxis/minpadding/\n * Min padding of 0.2\n * @sample {highstock} stock/xaxis/minpadding-maxpadding/\n * Greater min- and maxPadding\n *\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n minPadding: 0.05,\n /**\n * @productdesc {highstock}\n * In Highcharts Stock 1.x, the Y axis was placed\n * on the left side by default.\n *\n * @sample {highcharts} highcharts/yaxis/opposite/\n * Secondary Y axis opposite\n * @sample {highstock} stock/xaxis/opposite/\n * Y axis on left side\n *\n * @type {boolean}\n * @default {highstock} true\n * @default {highcharts} false\n * @product highstock highcharts gantt\n * @apioption yAxis.opposite\n */\n /**\n * @see [tickInterval](#xAxis.tickInterval)\n * @see [tickPositioner](#xAxis.tickPositioner)\n * @see [tickPositions](#xAxis.tickPositions)\n */\n tickPixelInterval: 72,\n /**\n * Whether to show the last tick label.\n *\n * @productdesc {highcharts|gantt}\n * Defaults to `true` on cartesian charts, and `false` on polar charts.\n *\n * @productdesc {highstock}\n * Defaults to `true` for categorized yAxis and `false` for other types\n * of yAxis.\n *\n * @default undefined\n */\n showLastLabel: true,\n /**\n * @extends xAxis.labels\n */\n labels: {\n /**\n * Angular gauges and solid gauges only.\n * The label's pixel distance from the perimeter of the plot area.\n *\n * Since v7.1.2: If it's a percentage string, it is interpreted the\n * same as [series.radius](#plotOptions.gauge.radius), so label can be\n * aligned under the gauge's shape.\n *\n * @sample {highcharts} highcharts/yaxis/labels-distance/\n * Labels centered under the arc\n *\n * @type {number|string}\n * @default -25\n * @product highcharts\n * @apioption yAxis.labels.distance\n */\n /**\n * The y position offset of all labels relative to the tick\n * positions on the axis. For polar and radial axis consider the use\n * of the [distance](#yAxis.labels.distance) option.\n *\n * @sample {highcharts} highcharts/xaxis/labels-x/\n * Y axis labels placed on grid lines\n *\n * @type {number}\n * @default {highcharts} 3\n * @default {highstock} -2\n * @default {highmaps} 3\n * @apioption yAxis.labels.y\n */\n /**\n * What part of the string the given position is anchored to. Can\n * be one of `\"left\"`, `\"center\"` or `\"right\"`. The exact position\n * also depends on the `labels.x` setting.\n *\n * Angular gauges and solid gauges defaults to `\"center\"`.\n * Solid gauges with two labels have additional option `\"auto\"`\n * for automatic horizontal and vertical alignment.\n *\n * @see [yAxis.labels.distance](#yAxis.labels.distance)\n *\n * @sample {highcharts} highcharts/yaxis/labels-align-left/\n * Left\n * @sample {highcharts} highcharts/series-solidgauge/labels-auto-aligned/\n * Solid gauge labels auto aligned\n *\n * @type {Highcharts.AlignValue}\n * @default {highstock} right\n * @apioption yAxis.labels.align\n */\n /**\n * The x position offset of all labels relative to the tick\n * positions on the axis. Defaults to -15 for left axis, 15 for\n * right axis.\n *\n * @sample {highcharts} highcharts/xaxis/labels-x/\n * Y axis labels placed on grid lines\n */\n x: -8\n },\n /**\n * @productdesc {highmaps}\n * In Highmaps, the axis line is hidden by default, because the axis is\n * not visible by default.\n *\n * @type {Highcharts.ColorType}\n * @apioption yAxis.lineColor\n */\n /**\n * @sample {highcharts} highcharts/yaxis/max-200/\n * Y axis max of 200\n * @sample {highcharts} highcharts/yaxis/max-logarithmic/\n * Y axis max on logarithmic axis\n * @sample {highstock} stock/yaxis/min-max/\n * Fixed min and max on Y axis\n *\n * @apioption yAxis.max\n */\n /**\n * @sample {highcharts} highcharts/yaxis/min-startontick-false/\n * -50 with startOnTick to false\n * @sample {highcharts} highcharts/yaxis/min-startontick-true/\n * -50 with startOnTick true by default\n * @sample {highstock} stock/yaxis/min-max/\n * Fixed min and max on Y axis\n *\n * @apioption yAxis.min\n */\n /**\n * An optional scrollbar to display on the Y axis in response to\n * limiting the minimum an maximum of the axis values.\n *\n * In styled mode, all the presentational options for the scrollbar\n * are replaced by the classes `.highcharts-scrollbar-thumb`,\n * `.highcharts-scrollbar-arrow`, `.highcharts-scrollbar-button`,\n * `.highcharts-scrollbar-rifles` and `.highcharts-scrollbar-track`.\n *\n * @sample {highstock} stock/yaxis/scrollbar/\n * Scrollbar on the Y axis\n *\n * @extends scrollbar\n * @since 4.2.6\n * @product highstock\n * @excluding height\n * @apioption yAxis.scrollbar\n */\n /**\n * Enable the scrollbar on the Y axis.\n *\n * @sample {highstock} stock/yaxis/scrollbar/\n * Enabled on Y axis\n *\n * @type {boolean}\n * @default false\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.enabled\n */\n /**\n * Pixel margin between the scrollbar and the axis elements.\n *\n * @type {number}\n * @default 10\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.margin\n */\n /* eslint-disable highcharts/doclet-apioption-last */\n /**\n * Defines the position of the scrollbar. By default, it is positioned\n * on the opposite of the main axis (right side of the chart).\n * However, in the case of RTL languages could be set to `false`\n * which positions the scrollbar on the left.\n *\n * Works only for vertical axes.\n * This means yAxis in a non-inverted chart and xAxis in the inverted.\n *\n * @sample stock/yaxis/scrollbar-opposite/\n * A scrollbar not on the opposite side\n *\n * @type {boolean}\n * @default true\n * @since 9.3.0\n *\n * @apioption yAxis.scrollbar.opposite\n * @apioption xAxis.scrollbar.opposite\n *\n */\n /* eslint-enable highcharts/doclet-apioption-last */\n /**\n * Whether to show the scrollbar when it is fully zoomed out at max\n * range. Setting it to `false` on the Y axis makes the scrollbar stay\n * hidden until the user zooms in, like common in browsers.\n *\n * @type {boolean}\n * @default true\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.showFull\n */\n /**\n * The width of a vertical scrollbar or height of a horizontal\n * scrollbar. Defaults to 20 on touch devices.\n *\n * @type {number}\n * @default 14\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.size\n */\n /**\n * Z index of the scrollbar elements.\n *\n * @type {number}\n * @default 3\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.zIndex\n */\n /**\n * A soft maximum for the axis. If the series data maximum is less\n * than this, the axis will stay at this maximum, but if the series\n * data maximum is higher, the axis will flex to show all data.\n *\n * **Note**: The [series.softThreshold](\n * #plotOptions.series.softThreshold) option takes precedence over this\n * option.\n *\n * @sample highcharts/yaxis/softmin-softmax/\n * Soft min and max\n *\n * @type {number}\n * @since 5.0.1\n * @product highcharts highstock gantt\n * @apioption yAxis.softMax\n */\n /**\n * A soft minimum for the axis. If the series data minimum is greater\n * than this, the axis will stay at this minimum, but if the series\n * data minimum is lower, the axis will flex to show all data.\n *\n * **Note**: The [series.softThreshold](\n * #plotOptions.series.softThreshold) option takes precedence over this\n * option.\n *\n * @sample highcharts/yaxis/softmin-softmax/\n * Soft min and max\n *\n * @type {number}\n * @since 5.0.1\n * @product highcharts highstock gantt\n * @apioption yAxis.softMin\n */\n /**\n * Defines the horizontal alignment of the stack total label. Can be one\n * of `\"left\"`, `\"center\"` or `\"right\"`. The default value is calculated\n * at runtime and depends on orientation and whether the stack is\n * positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-align-left/\n * Aligned to the left\n * @sample {highcharts} highcharts/yaxis/stacklabels-align-center/\n * Aligned in center\n * @sample {highcharts} highcharts/yaxis/stacklabels-align-right/\n * Aligned to the right\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.align\n */\n /**\n * A format string for the data label. Available variables are the same\n * as for `formatter`.\n *\n * @type {string}\n * @default {total}\n * @since 3.0.2\n * @product highcharts highstock\n * @apioption yAxis.stackLabels.format\n */\n /**\n * Rotation of the labels in degrees.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-rotation/\n * Labels rotated 45°\n *\n * @type {number}\n * @default 0\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.rotation\n */\n /**\n * The text alignment for the label. While `align` determines where the\n * texts anchor point is placed with regards to the stack, `textAlign`\n * determines how the text is aligned against its anchor point. Possible\n * values are `\"left\"`, `\"center\"` and `\"right\"`. The default value is\n * calculated at runtime and depends on orientation and whether the\n * stack is positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-textalign-left/\n * Label in center position but text-aligned left\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.textAlign\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n *\n * @type {boolean}\n * @default false\n * @since 3.0\n * @product highcharts highstock\n * @apioption yAxis.stackLabels.useHTML\n */\n /**\n * Defines the vertical alignment of the stack total label. Can be one\n * of `\"top\"`, `\"middle\"` or `\"bottom\"`. The default value is calculated\n * at runtime and depends on orientation and whether the stack is\n * positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-verticalalign-top/\n * Vertically aligned top\n * @sample {highcharts} highcharts/yaxis/stacklabels-verticalalign-middle/\n * Vertically aligned middle\n * @sample {highcharts} highcharts/yaxis/stacklabels-verticalalign-bottom/\n * Vertically aligned bottom\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.verticalAlign\n */\n /**\n * The x position offset of the label relative to the left of the\n * stacked bar. The default value is calculated at runtime and depends\n * on orientation and whether the stack is positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-x/\n * Stack total labels with x offset\n *\n * @type {number}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.x\n */\n /**\n * The y position offset of the label relative to the tick position\n * on the axis. The default value is calculated at runtime and depends\n * on orientation and whether the stack is positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-y/\n * Stack total labels with y offset\n *\n * @type {number}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.y\n */\n /**\n * Whether to force the axis to start on a tick. Use this option with\n * the `maxPadding` option to control the axis start.\n *\n * This option is always disabled, when panning type is\n * either `y` or `xy`.\n *\n * @see [type](#chart.panning.type)\n *\n * @sample {highcharts} highcharts/xaxis/startontick-false/\n * False by default\n * @sample {highcharts} highcharts/xaxis/startontick-true/\n * True\n * @sample {highstock} stock/xaxis/endontick/\n * False for Y axis\n *\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n startOnTick: true,\n title: {\n /**\n * The pixel distance between the axis labels and the title.\n * Positive values are outside the axis line, negative are inside.\n *\n * @sample {highcharts} highcharts/xaxis/title-margin/\n * Y axis title margin of 60\n *\n * @type {number}\n * @default 40\n * @apioption yAxis.title.margin\n */\n /**\n * The rotation of the text in degrees. 0 is horizontal, 270 is\n * vertical reading from bottom to top.\n *\n * @sample {highcharts} highcharts/yaxis/title-offset/\n * Horizontal\n */\n rotation: 270,\n /**\n * The actual text of the axis title. Horizontal texts can contain\n * HTML, but rotated texts are painted using vector techniques and\n * must be clean text. The Y axis title is disabled by setting the\n * `text` option to `undefined`.\n *\n * @sample {highcharts} highcharts/xaxis/title-text/\n * Custom HTML\n *\n * @type {string|null}\n * @default {highcharts} Values\n * @default {highstock} undefined\n * @product highcharts highstock gantt\n */\n text: 'Values'\n },\n /**\n * The top position of the Y axis. If it's a number, it is interpreted\n * as pixel position relative to the chart.\n *\n * Since Highcharts 2: If it's a percentage string, it is interpreted as\n * percentages of the plot height, offset from plot area top.\n *\n * @see [yAxis.height](#yAxis.height)\n *\n * @sample {highstock} stock/demo/candlestick-and-volume/\n * Percentage height panes\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption yAxis.top\n */\n /**\n * The stack labels show the total value for each bar in a stacked\n * column or bar chart. The label will be placed on top of positive\n * columns and below negative columns. In case of an inverted column\n * chart or a bar chart the label is placed to the right of positive\n * bars and to the left of negative bars.\n *\n * @product highcharts\n */\n stackLabels: {\n /**\n * Enable or disable the initial animation when a series is\n * displayed for the `stackLabels`. The animation can also be set as\n * a configuration object. Please note that this option only\n * applies to the initial animation.\n * For other animations, see [chart.animation](#chart.animation)\n * and the animation parameter under the API methods.\n * The following properties are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * @sample {highcharts} highcharts/plotoptions/animation-defer/\n * Animation defer settings\n * @type {boolean|Partial}\n * @since 8.2.0\n * @apioption yAxis.stackLabels.animation\n */\n animation: {},\n /**\n * The animation delay time in milliseconds.\n * Set to `0` renders stackLabel immediately.\n * As `undefined` inherits defer time from the [series.animation.defer](#plotOptions.series.animation.defer).\n *\n * @type {number}\n * @since 8.2.0\n * @apioption yAxis.stackLabels.animation.defer\n */\n /**\n * Allow the stack labels to overlap.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-allowoverlap-false/\n * Default false\n *\n * @since 5.0.13\n * @product highcharts\n */\n allowOverlap: false,\n /**\n * The background color or gradient for the stack label.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-box/\n * Stack labels box options\n * @type {Highcharts.ColorType}\n * @since 8.1.0\n * @apioption yAxis.stackLabels.backgroundColor\n */\n /**\n * The border color for the stack label. Defaults to `undefined`.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-box/\n * Stack labels box options\n * @type {Highcharts.ColorType}\n * @since 8.1.0\n * @apioption yAxis.stackLabels.borderColor\n */\n /**\n * The border radius in pixels for the stack label.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-box/\n * Stack labels box options\n * @type {number}\n * @default 0\n * @since 8.1.0\n * @apioption yAxis.stackLabels.borderRadius\n */\n /**\n * The border width in pixels for the stack label.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-box/\n * Stack labels box options\n * @type {number}\n * @default 0\n * @since 8.1.0\n * @apioption yAxis.stackLabels.borderWidth\n */\n /**\n * Enable or disable the stack total labels.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-enabled/\n * Enabled stack total labels\n * @sample {highcharts} highcharts/yaxis/stacklabels-enabled-waterfall/\n * Enabled stack labels in waterfall chart\n *\n * @since 2.1.5\n * @product highcharts\n */\n enabled: false,\n /**\n * Whether to hide stack labels that are outside the plot area.\n * By default, the stack label is moved\n * inside the plot area according to the\n * [overflow](/highcharts/#yAxis/stackLabels/overflow)\n * option.\n *\n * @type {boolean}\n * @since 7.1.3\n */\n crop: true,\n /**\n * How to handle stack total labels that flow outside the plot area.\n * The default is set to `\"justify\"`,\n * which aligns them inside the plot area.\n * For columns and bars, this means it will be moved inside the bar.\n * To display stack labels outside the plot area,\n * set `crop` to `false` and `overflow` to `\"allow\"`.\n *\n * @sample highcharts/yaxis/stacklabels-overflow/\n * Stack labels flows outside the plot area.\n *\n * @type {Highcharts.DataLabelsOverflowValue}\n * @since 7.1.3\n */\n overflow: 'justify',\n /* eslint-disable valid-jsdoc */\n /**\n * Callback JavaScript function to format the label. The value is\n * given by `this.total`.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-formatter/\n * Added units to stack total value\n *\n * @type {Highcharts.FormatterCallbackFunction}\n * @since 2.1.5\n * @product highcharts\n */\n formatter: function () {\n var numberFormatter = this.axis.chart.numberFormatter;\n /* eslint-enable valid-jsdoc */\n return numberFormatter(this.total || 0, -1);\n },\n /**\n * CSS styles for the label.\n *\n * In styled mode, the styles are set in the\n * `.highcharts-stack-label` class.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-style/\n * Red stack total labels\n *\n * @type {Highcharts.CSSObject}\n * @since 2.1.5\n * @product highcharts\n */\n style: {\n /** @internal */\n color: \"#000000\" /* Palette.neutralColor100 */,\n /** @internal */\n fontSize: '11px',\n /** @internal */\n fontWeight: 'bold',\n /** @internal */\n textOutline: '1px contrast'\n }\n },\n gridLineWidth: 1,\n lineWidth: 0\n // tickWidth: 0\n };\n /**\n * The Z axis or depth axis for 3D plots.\n *\n * See the [Axis class](/class-reference/Highcharts.Axis) for programmatic\n * access to the axis.\n *\n * @sample {highcharts} highcharts/3d/scatter-zaxis-categories/\n * Z-Axis with Categories\n * @sample {highcharts} highcharts/3d/scatter-zaxis-grid/\n * Z-Axis with styling\n *\n * @type {*|Array<*>}\n * @extends xAxis\n * @since 5.0.0\n * @product highcharts\n * @excluding breaks, crosshair, height, left, lineColor, lineWidth,\n * nameToX, showEmpty, top, width\n * @apioption zAxis\n */\n // This variable extends the defaultOptions for left axes.\n AxisDefaults.defaultLeftAxisOptions = {\n labels: {\n x: -15\n },\n title: {\n rotation: 270\n }\n };\n // This variable extends the defaultOptions for right axes.\n AxisDefaults.defaultRightAxisOptions = {\n labels: {\n x: 15\n },\n title: {\n rotation: 90\n }\n };\n // This variable extends the defaultOptions for bottom axes.\n AxisDefaults.defaultBottomAxisOptions = {\n labels: {\n autoRotation: [-45],\n x: 0\n // overflow: undefined,\n // staggerLines: null\n },\n margin: 15,\n title: {\n rotation: 0\n }\n };\n // This variable extends the defaultOptions for top axes.\n AxisDefaults.defaultTopAxisOptions = {\n labels: {\n autoRotation: [-45],\n x: 0\n // overflow: undefined\n // staggerLines: null\n },\n margin: 15,\n title: {\n rotation: 0\n }\n };\n })(AxisDefaults || (AxisDefaults = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return AxisDefaults;\n });\n _registerModule(_modules, 'Core/Foundation.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var addEvent = U.addEvent,\n isFunction = U.isFunction,\n objectEach = U.objectEach,\n removeEvent = U.removeEvent;\n /* *\n *\n * Class Namespace\n *\n * */\n var Foundation;\n (function (Foundation) {\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Register event options. If an event handler is set on the options, it\n * should be subject to Chart.update, Axis.update and Series.update. This is\n * contrary to general handlers that are set directly using addEvent either\n * on the class or on the instance. #6538, #6943, #10861.\n * @private\n */\n function registerEventOptions(component, options) {\n // A lookup over those events that are added by _options_ (not\n // programmatically). These are updated through .update()\n component.eventOptions = component.eventOptions || {};\n // Register event listeners\n objectEach(options.events, function (event, eventType) {\n // If event does not exist, or is changed by the .update()\n // function\n if (component.eventOptions[eventType] !== event) {\n // Remove existing if set by option\n if (component.eventOptions[eventType]) {\n removeEvent(component, eventType, component.eventOptions[eventType]);\n delete component.eventOptions[eventType];\n }\n if (isFunction(event)) {\n component.eventOptions[eventType] = event;\n addEvent(component, eventType, event);\n }\n }\n });\n }\n Foundation.registerEventOptions = registerEventOptions;\n })(Foundation || (Foundation = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return Foundation;\n });\n _registerModule(_modules, 'Core/Axis/Tick.js', [_modules['Core/FormatUtilities.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (F, H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var deg2rad = H.deg2rad;\n var clamp = U.clamp,\n correctFloat = U.correctFloat,\n defined = U.defined,\n destroyObjectProperties = U.destroyObjectProperties,\n extend = U.extend,\n fireEvent = U.fireEvent,\n isNumber = U.isNumber,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The Tick class.\n *\n * @class\n * @name Highcharts.Tick\n *\n * @param {Highcharts.Axis} axis\n * The axis of the tick.\n *\n * @param {number} pos\n * The position of the tick on the axis in terms of axis values.\n *\n * @param {string} [type]\n * The type of tick, either 'minor' or an empty string\n *\n * @param {boolean} [noLabel=false]\n * Whether to disable the label or not. Defaults to false.\n *\n * @param {Object} [parameters]\n * Optional parameters for the tick.\n */\n var Tick = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Tick(axis, pos, type, noLabel, parameters) {\n this.isNew = true;\n this.isNewLabel = true;\n /**\n * The related axis of the tick.\n * @name Highcharts.Tick#axis\n * @type {Highcharts.Axis}\n */\n this.axis = axis;\n /**\n * The logical position of the tick on the axis in terms of axis values.\n * @name Highcharts.Tick#pos\n * @type {number}\n */\n this.pos = pos;\n /**\n * The tick type, which can be `\"minor\"`, or an empty string.\n * @name Highcharts.Tick#type\n * @type {string}\n */\n this.type = type || '';\n this.parameters = parameters || {};\n /**\n * The mark offset of the tick on the axis. Usually `undefined`, numeric\n * for grid axes.\n * @name Highcharts.Tick#tickmarkOffset\n * @type {number|undefined}\n */\n this.tickmarkOffset = this.parameters.tickmarkOffset;\n this.options = this.parameters.options;\n fireEvent(this, 'init');\n if (!type && !noLabel) {\n this.addLabel();\n }\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Write the tick label.\n *\n * @private\n * @function Highcharts.Tick#addLabel\n */\n Tick.prototype.addLabel = function () {\n var tick = this,\n axis = tick.axis,\n options = axis.options,\n chart = axis.chart,\n categories = axis.categories,\n log = axis.logarithmic,\n names = axis.names,\n pos = tick.pos,\n labelOptions = pick(tick.options && tick.options.labels,\n options.labels),\n tickPositions = axis.tickPositions,\n isFirst = pos === tickPositions[0],\n isLast = pos === tickPositions[tickPositions.length - 1],\n animateLabels = (!labelOptions.step || labelOptions.step === 1) &&\n axis.tickInterval === 1,\n tickPositionInfo = tickPositions.info;\n var label = tick.label,\n dateTimeLabelFormat,\n dateTimeLabelFormats,\n i;\n // The context value\n var value = this.parameters.category || (categories ?\n pick(categories[pos],\n names[pos],\n pos) :\n pos);\n if (log && isNumber(value)) {\n value = correctFloat(log.lin2log(value));\n }\n // Set the datetime label format. If a higher rank is set for this\n // position, use that. If not, use the general format.\n if (axis.dateTime) {\n if (tickPositionInfo) {\n dateTimeLabelFormats = chart.time.resolveDTLFormat(options.dateTimeLabelFormats[(!options.grid &&\n tickPositionInfo.higherRanks[pos]) ||\n tickPositionInfo.unitName]);\n dateTimeLabelFormat = dateTimeLabelFormats.main;\n }\n else if (isNumber(value)) { // #1441\n dateTimeLabelFormat = axis.dateTime.getXDateFormat(value, options.dateTimeLabelFormats ||\n {});\n }\n }\n // set properties for access in render method\n /**\n * True if the tick is the first one on the axis.\n * @name Highcharts.Tick#isFirst\n * @readonly\n * @type {boolean|undefined}\n */\n tick.isFirst = isFirst;\n /**\n * True if the tick is the last one on the axis.\n * @name Highcharts.Tick#isLast\n * @readonly\n * @type {boolean|undefined}\n */\n tick.isLast = isLast;\n // Get the string\n var ctx = {\n axis: axis,\n chart: chart,\n dateTimeLabelFormat: dateTimeLabelFormat,\n isFirst: isFirst,\n isLast: isLast,\n pos: pos,\n tick: tick,\n tickPositionInfo: tickPositionInfo,\n value: value\n };\n // Fire an event that allows modifying the context for use in\n // `labels.format` and `labels.formatter`.\n fireEvent(this, 'labelFormat', ctx);\n // Label formatting. When `labels.format` is given, we first run the\n // defaultFormatter and append the result to the context as `text`.\n // Handy for adding prefix or suffix while keeping default number\n // formatting.\n var labelFormatter = function (ctx) {\n if (labelOptions.formatter) {\n return labelOptions.formatter.call(ctx,\n ctx);\n }\n if (labelOptions.format) {\n ctx.text = axis.defaultLabelFormatter.call(ctx, ctx);\n return F.format(labelOptions.format, ctx, chart);\n }\n return axis.defaultLabelFormatter.call(ctx, ctx);\n };\n var str = labelFormatter.call(ctx,\n ctx);\n // Set up conditional formatting based on the format list if existing.\n var list = dateTimeLabelFormats && dateTimeLabelFormats.list;\n if (list) {\n tick.shortenLabel = function () {\n for (i = 0; i < list.length; i++) {\n extend(ctx, { dateTimeLabelFormat: list[i] });\n label.attr({\n text: labelFormatter.call(ctx, ctx)\n });\n if (label.getBBox().width <\n axis.getSlotWidth(tick) - 2 *\n labelOptions.padding) {\n return;\n }\n }\n label.attr({\n text: ''\n });\n };\n }\n else {\n // #15692\n tick.shortenLabel = void 0;\n }\n // Call only after first render\n if (animateLabels && axis._addedPlotLB) {\n tick.moveLabel(str, labelOptions);\n }\n // First call\n if (!defined(label) && !tick.movedLabel) {\n /**\n * The rendered text label of the tick.\n * @name Highcharts.Tick#label\n * @type {Highcharts.SVGElement|undefined}\n */\n tick.label = label = tick.createLabel({ x: 0, y: 0 }, str, labelOptions);\n // Base value to detect change for new calls to getBBox\n tick.rotation = 0;\n // update\n }\n else if (label && label.textStr !== str && !animateLabels) {\n // When resetting text, also reset the width if dynamically set\n // (#8809)\n if (label.textWidth &&\n !labelOptions.style.width &&\n !label.styles.width) {\n label.css({ width: null });\n }\n label.attr({ text: str });\n label.textPxLength = label.getBBox().width;\n }\n };\n /**\n * Render and return the label of the tick.\n *\n * @private\n * @function Highcharts.Tick#createLabel\n */\n Tick.prototype.createLabel = function (xy, str, labelOptions) {\n var axis = this.axis,\n chart = axis.chart,\n label = defined(str) && labelOptions.enabled ?\n chart.renderer\n .text(str,\n xy.x,\n xy.y,\n labelOptions.useHTML)\n .add(axis.labelGroup) :\n null;\n // Un-rotated length\n if (label) {\n // Without position absolute, IE export sometimes is wrong\n if (!chart.styledMode) {\n label.css(merge(labelOptions.style));\n }\n label.textPxLength = label.getBBox().width;\n }\n return label;\n };\n /**\n * Destructor for the tick prototype\n *\n * @private\n * @function Highcharts.Tick#destroy\n */\n Tick.prototype.destroy = function () {\n destroyObjectProperties(this, this.axis);\n };\n /**\n * Gets the x and y positions for ticks in terms of pixels.\n *\n * @private\n * @function Highcharts.Tick#getPosition\n *\n * @param {boolean} horiz\n * Whether the tick is on an horizontal axis or not.\n *\n * @param {number} tickPos\n * Position of the tick.\n *\n * @param {number} tickmarkOffset\n * Tickmark offset for all ticks.\n *\n * @param {boolean} [old]\n * Whether the axis has changed or not.\n *\n * @return {Highcharts.PositionObject}\n * The tick position.\n *\n * @emits Highcharts.Tick#event:afterGetPosition\n */\n Tick.prototype.getPosition = function (horiz, tickPos, tickmarkOffset, old) {\n var axis = this.axis,\n chart = axis.chart,\n cHeight = (old && chart.oldChartHeight) || chart.chartHeight,\n pos = {\n x: horiz ?\n correctFloat(axis.translate(tickPos + tickmarkOffset,\n void 0,\n void 0,\n old) +\n axis.transB) :\n (axis.left +\n axis.offset +\n (axis.opposite ?\n (((old && chart.oldChartWidth) ||\n chart.chartWidth) -\n axis.right -\n axis.left) :\n 0)),\n y: horiz ?\n (cHeight -\n axis.bottom +\n axis.offset -\n (axis.opposite ? axis.height : 0)) :\n correctFloat(cHeight -\n axis.translate(tickPos + tickmarkOffset,\n void 0,\n void 0,\n old) -\n axis.transB)\n };\n // Chrome workaround for #10516\n pos.y = clamp(pos.y, -1e5, 1e5);\n fireEvent(this, 'afterGetPosition', { pos: pos });\n return pos;\n };\n /**\n * Get the x, y position of the tick label\n * @private\n */\n Tick.prototype.getLabelPosition = function (x, y, label, horiz, labelOptions, tickmarkOffset, index, step) {\n var axis = this.axis,\n transA = axis.transA,\n reversed = ( // #7911\n axis.isLinked && axis.linkedParent ?\n axis.linkedParent.reversed :\n axis.reversed),\n staggerLines = axis.staggerLines,\n rotCorr = axis.tickRotCorr || { x: 0,\n y: 0 }, \n // Adjust for label alignment if we use reserveSpace: true (#5286)\n labelOffsetCorrection = (!horiz && !axis.reserveSpaceDefault ?\n -axis.labelOffset * (axis.labelAlign === 'center' ? 0.5 : 1) :\n 0),\n pos = {};\n var yOffset,\n line;\n if (axis.side === 0) {\n yOffset = label.rotation ? -8 : -label.getBBox().height;\n }\n else if (axis.side === 2) {\n yOffset = rotCorr.y + 8;\n }\n else {\n // #3140, #3140\n yOffset = Math.cos(label.rotation * deg2rad) *\n (rotCorr.y - label.getBBox(false, 0).height / 2);\n }\n if (defined(labelOptions.y)) {\n yOffset = axis.side === 0 && axis.horiz ?\n labelOptions.y + yOffset :\n labelOptions.y;\n }\n x = x +\n labelOptions.x +\n labelOffsetCorrection +\n rotCorr.x -\n (tickmarkOffset && horiz ?\n tickmarkOffset * transA * (reversed ? -1 : 1) :\n 0);\n y = y + yOffset - (tickmarkOffset && !horiz ?\n tickmarkOffset * transA * (reversed ? 1 : -1) : 0);\n // Correct for staggered labels\n if (staggerLines) {\n line = (index / (step || 1) % staggerLines);\n if (axis.opposite) {\n line = staggerLines - line - 1;\n }\n y += line * (axis.labelOffset / staggerLines);\n }\n pos.x = x;\n pos.y = Math.round(y);\n fireEvent(this, 'afterGetLabelPosition', { pos: pos, tickmarkOffset: tickmarkOffset, index: index });\n return pos;\n };\n /**\n * Get the offset height or width of the label\n *\n * @private\n * @function Highcharts.Tick#getLabelSize\n */\n Tick.prototype.getLabelSize = function () {\n return this.label ?\n this.label.getBBox()[this.axis.horiz ? 'height' : 'width'] :\n 0;\n };\n /**\n * Extendible method to return the path of the marker\n * @private\n */\n Tick.prototype.getMarkPath = function (x, y, tickLength, tickWidth, horiz, renderer) {\n return renderer.crispLine([[\n 'M',\n x,\n y\n ], [\n 'L',\n x + (horiz ? 0 : -tickLength),\n y + (horiz ? tickLength : 0)\n ]], tickWidth);\n };\n /**\n * Handle the label overflow by adjusting the labels to the left and right\n * edge, or hide them if they collide into the neighbour label.\n *\n * @private\n * @function Highcharts.Tick#handleOverflow\n */\n Tick.prototype.handleOverflow = function (xy) {\n var tick = this,\n axis = this.axis,\n labelOptions = axis.options.labels,\n pxPos = xy.x,\n chartWidth = axis.chart.chartWidth,\n spacing = axis.chart.spacing,\n leftBound = pick(axis.labelLeft,\n Math.min(axis.pos,\n spacing[3])),\n rightBound = pick(axis.labelRight,\n Math.max(!axis.isRadial ? axis.pos + axis.len : 0,\n chartWidth - spacing[1])),\n label = this.label,\n rotation = this.rotation,\n factor = {\n left: 0,\n center: 0.5,\n right: 1\n }[axis.labelAlign || label.attr('align')],\n labelWidth = label.getBBox().width,\n slotWidth = axis.getSlotWidth(tick),\n xCorrection = factor,\n css = {};\n var modifiedSlotWidth = slotWidth,\n goRight = 1,\n leftPos,\n rightPos,\n textWidth;\n // Check if the label overshoots the chart spacing box. If it does, move\n // it. If it now overshoots the slotWidth, add ellipsis.\n if (!rotation && labelOptions.overflow === 'justify') {\n leftPos = pxPos - factor * labelWidth;\n rightPos = pxPos + (1 - factor) * labelWidth;\n if (leftPos < leftBound) {\n modifiedSlotWidth =\n xy.x + modifiedSlotWidth * (1 - factor) - leftBound;\n }\n else if (rightPos > rightBound) {\n modifiedSlotWidth =\n rightBound - xy.x + modifiedSlotWidth * factor;\n goRight = -1;\n }\n modifiedSlotWidth = Math.min(slotWidth, modifiedSlotWidth); // #4177\n if (modifiedSlotWidth < slotWidth && axis.labelAlign === 'center') {\n xy.x += (goRight *\n (slotWidth -\n modifiedSlotWidth -\n xCorrection * (slotWidth - Math.min(labelWidth, modifiedSlotWidth))));\n }\n // If the label width exceeds the available space, set a text width\n // to be picked up below. Also, if a width has been set before, we\n // need to set a new one because the reported labelWidth will be\n // limited by the box (#3938).\n if (labelWidth > modifiedSlotWidth ||\n (axis.autoRotation && (label.styles || {}).width)) {\n textWidth = modifiedSlotWidth;\n }\n // Add ellipsis to prevent rotated labels to be clipped against the edge\n // of the chart\n }\n else if (rotation < 0 &&\n pxPos - factor * labelWidth < leftBound) {\n textWidth = Math.round(pxPos / Math.cos(rotation * deg2rad) - leftBound);\n }\n else if (rotation > 0 &&\n pxPos + factor * labelWidth > rightBound) {\n textWidth = Math.round((chartWidth - pxPos) /\n Math.cos(rotation * deg2rad));\n }\n if (textWidth) {\n if (tick.shortenLabel) {\n tick.shortenLabel();\n }\n else {\n css.width = Math.floor(textWidth) + 'px';\n if (!(labelOptions.style || {}).textOverflow) {\n css.textOverflow = 'ellipsis';\n }\n label.css(css);\n }\n }\n };\n /**\n * Try to replace the label if the same one already exists.\n *\n * @private\n * @function Highcharts.Tick#moveLabel\n */\n Tick.prototype.moveLabel = function (str, labelOptions) {\n var tick = this,\n label = tick.label,\n axis = tick.axis,\n reversed = axis.reversed;\n var moved = false,\n labelPos,\n xPos,\n yPos;\n if (label && label.textStr === str) {\n tick.movedLabel = label;\n moved = true;\n delete tick.label;\n }\n else { // Find a label with the same string\n objectEach(axis.ticks, function (currentTick) {\n if (!moved &&\n !currentTick.isNew &&\n currentTick !== tick &&\n currentTick.label &&\n currentTick.label.textStr === str) {\n tick.movedLabel = currentTick.label;\n moved = true;\n currentTick.labelPos = tick.movedLabel.xy;\n delete currentTick.label;\n }\n });\n }\n // Create new label if the actual one is moved\n if (!moved && (tick.labelPos || label)) {\n labelPos = tick.labelPos || label.xy;\n xPos = axis.horiz ?\n (reversed ? 0 : axis.width + axis.left) : labelPos.x;\n yPos = axis.horiz ?\n labelPos.y : (reversed ? (axis.width + axis.left) : 0);\n tick.movedLabel = tick.createLabel({ x: xPos, y: yPos }, str, labelOptions);\n if (tick.movedLabel) {\n tick.movedLabel.attr({ opacity: 0 });\n }\n }\n };\n /**\n * Put everything in place\n *\n * @private\n * @param {number} index\n *\n * @param {boolean} [old]\n * Use old coordinates to prepare an animation into new position\n *\n * @param {number} [opacity]\n */\n Tick.prototype.render = function (index, old, opacity) {\n var tick = this,\n axis = tick.axis,\n horiz = axis.horiz,\n pos = tick.pos,\n tickmarkOffset = pick(tick.tickmarkOffset,\n axis.tickmarkOffset),\n xy = tick.getPosition(horiz,\n pos,\n tickmarkOffset,\n old),\n x = xy.x,\n y = xy.y,\n reverseCrisp = ((horiz && x === axis.pos + axis.len) ||\n (!horiz && y === axis.pos)) ? -1 : 1; // #1480, #1687\n var labelOpacity = pick(opacity,\n tick.label && tick.label.newOpacity, // #15528\n 1);\n opacity = pick(opacity, 1);\n this.isActive = true;\n // Create the grid line\n this.renderGridLine(old, opacity, reverseCrisp);\n // create the tick mark\n this.renderMark(xy, opacity, reverseCrisp);\n // the label is created on init - now move it into place\n this.renderLabel(xy, old, labelOpacity, index);\n tick.isNew = false;\n fireEvent(this, 'afterRender');\n };\n /**\n * Renders the gridLine.\n *\n * @private\n * @function Highcharts.Tick#renderGridLine\n * @param {boolean} old Whether or not the tick is old\n * @param {number} opacity The opacity of the grid line\n * @param {number} reverseCrisp Modifier for avoiding overlapping 1 or -1\n */\n Tick.prototype.renderGridLine = function (old, opacity, reverseCrisp) {\n var tick = this,\n axis = tick.axis,\n options = axis.options,\n attribs = {},\n pos = tick.pos,\n type = tick.type,\n tickmarkOffset = pick(tick.tickmarkOffset,\n axis.tickmarkOffset),\n renderer = axis.chart.renderer;\n var gridLine = tick.gridLine,\n gridLinePath,\n gridLineWidth = options.gridLineWidth,\n gridLineColor = options.gridLineColor,\n dashStyle = options.gridLineDashStyle;\n if (tick.type === 'minor') {\n gridLineWidth = options.minorGridLineWidth;\n gridLineColor = options.minorGridLineColor;\n dashStyle = options.minorGridLineDashStyle;\n }\n if (!gridLine) {\n if (!axis.chart.styledMode) {\n attribs.stroke = gridLineColor;\n attribs['stroke-width'] = gridLineWidth || 0;\n attribs.dashstyle = dashStyle;\n }\n if (!type) {\n attribs.zIndex = 1;\n }\n if (old) {\n opacity = 0;\n }\n /**\n * The rendered grid line of the tick.\n * @name Highcharts.Tick#gridLine\n * @type {Highcharts.SVGElement|undefined}\n */\n tick.gridLine = gridLine = renderer.path()\n .attr(attribs)\n .addClass('highcharts-' + (type ? type + '-' : '') + 'grid-line')\n .add(axis.gridGroup);\n }\n if (gridLine) {\n gridLinePath = axis.getPlotLinePath({\n value: pos + tickmarkOffset,\n lineWidth: gridLine.strokeWidth() * reverseCrisp,\n force: 'pass',\n old: old\n });\n // If the parameter 'old' is set, the current call will be followed\n // by another call, therefore do not do any animations this time\n if (gridLinePath) {\n gridLine[old || tick.isNew ? 'attr' : 'animate']({\n d: gridLinePath,\n opacity: opacity\n });\n }\n }\n };\n /**\n * Renders the tick mark.\n *\n * @private\n * @function Highcharts.Tick#renderMark\n * @param {Highcharts.PositionObject} xy The position vector of the mark\n * @param {number} opacity The opacity of the mark\n * @param {number} reverseCrisp Modifier for avoiding overlapping 1 or -1\n */\n Tick.prototype.renderMark = function (xy, opacity, reverseCrisp) {\n var tick = this, axis = tick.axis, options = axis.options, renderer = axis.chart.renderer, type = tick.type, tickSize = axis.tickSize(type ? type + 'Tick' : 'tick'), x = xy.x, y = xy.y, tickWidth = pick(options[type !== 'minor' ? 'tickWidth' : 'minorTickWidth'], !type && axis.isXAxis ? 1 : 0), // X axis defaults to 1\n tickColor = options[type !== 'minor' ? 'tickColor' : 'minorTickColor'];\n var mark = tick.mark;\n var isNewMark = !mark;\n if (tickSize) {\n // negate the length\n if (axis.opposite) {\n tickSize[0] = -tickSize[0];\n }\n // First time, create it\n if (!mark) {\n /**\n * The rendered mark of the tick.\n * @name Highcharts.Tick#mark\n * @type {Highcharts.SVGElement|undefined}\n */\n tick.mark = mark = renderer.path()\n .addClass('highcharts-' + (type ? type + '-' : '') + 'tick')\n .add(axis.axisGroup);\n if (!axis.chart.styledMode) {\n mark.attr({\n stroke: tickColor,\n 'stroke-width': tickWidth\n });\n }\n }\n mark[isNewMark ? 'attr' : 'animate']({\n d: tick.getMarkPath(x, y, tickSize[0], mark.strokeWidth() * reverseCrisp, axis.horiz, renderer),\n opacity: opacity\n });\n }\n };\n /**\n * Renders the tick label.\n * Note: The label should already be created in init(), so it should only\n * have to be moved into place.\n *\n * @private\n * @function Highcharts.Tick#renderLabel\n * @param {Highcharts.PositionObject} xy The position vector of the label\n * @param {boolean} old Whether or not the tick is old\n * @param {number} opacity The opacity of the label\n * @param {number} index The index of the tick\n */\n Tick.prototype.renderLabel = function (xy, old, opacity, index) {\n var tick = this,\n axis = tick.axis,\n horiz = axis.horiz,\n options = axis.options,\n label = tick.label,\n labelOptions = options.labels,\n step = labelOptions.step,\n tickmarkOffset = pick(tick.tickmarkOffset,\n axis.tickmarkOffset),\n x = xy.x,\n y = xy.y;\n var show = true;\n if (label && isNumber(x)) {\n label.xy = xy = tick.getLabelPosition(x, y, label, horiz, labelOptions, tickmarkOffset, index, step);\n // Apply show first and show last. If the tick is both first and\n // last, it is a single centered tick, in which case we show the\n // label anyway (#2100).\n if ((tick.isFirst &&\n !tick.isLast &&\n !options.showFirstLabel) ||\n (tick.isLast &&\n !tick.isFirst &&\n !options.showLastLabel)) {\n show = false;\n // Handle label overflow and show or hide accordingly\n }\n else if (horiz &&\n !labelOptions.step &&\n !labelOptions.rotation &&\n !old &&\n opacity !== 0) {\n tick.handleOverflow(xy);\n }\n // apply step\n if (step && index % step) {\n // show those indices dividable by step\n show = false;\n }\n // Set the new position, and show or hide\n if (show && isNumber(xy.y)) {\n xy.opacity = opacity;\n label[tick.isNewLabel ? 'attr' : 'animate'](xy).show(true);\n tick.isNewLabel = false;\n }\n else {\n label.hide(); // #1338, #15863\n tick.isNewLabel = true;\n }\n }\n };\n /**\n * Replace labels with the moved ones to perform animation. Additionally\n * destroy unused labels.\n *\n * @private\n * @function Highcharts.Tick#replaceMovedLabel\n */\n Tick.prototype.replaceMovedLabel = function () {\n var tick = this,\n label = tick.label,\n axis = tick.axis,\n reversed = axis.reversed;\n var x,\n y;\n // Animate and destroy\n if (label && !tick.isNew) {\n x = axis.horiz ? (reversed ? axis.left : axis.width + axis.left) : label.xy.x;\n y = axis.horiz ?\n label.xy.y :\n (reversed ? axis.width + axis.top : axis.top);\n label.animate({ x: x, y: y, opacity: 0 }, void 0, label.destroy);\n delete tick.label;\n }\n axis.isDirty = true;\n tick.label = tick.movedLabel;\n delete tick.movedLabel;\n };\n return Tick;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Optional parameters for the tick.\n * @private\n * @interface Highcharts.TickParametersObject\n */ /**\n * Set category for the tick.\n * @name Highcharts.TickParametersObject#category\n * @type {string|undefined}\n */ /**\n * @name Highcharts.TickParametersObject#options\n * @type {Highcharts.Dictionary|undefined}\n */ /**\n * Set tickmarkOffset for the tick.\n * @name Highcharts.TickParametersObject#tickmarkOffset\n * @type {number|undefined}\n */\n /**\n * Additonal time tick information.\n *\n * @interface Highcharts.TimeTicksInfoObject\n * @extends Highcharts.TimeNormalizedObject\n */ /**\n * @name Highcharts.TimeTicksInfoObject#higherRanks\n * @type {Array}\n */ /**\n * @name Highcharts.TimeTicksInfoObject#totalRange\n * @type {number}\n */\n (''); // keeps doclets above in JS file\n\n return Tick;\n });\n _registerModule(_modules, 'Core/Axis/Axis.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Axis/AxisDefaults.js'], _modules['Core/Color/Color.js'], _modules['Core/Defaults.js'], _modules['Core/Foundation.js'], _modules['Core/Globals.js'], _modules['Core/Axis/Tick.js'], _modules['Core/Utilities.js']], function (A, AxisDefaults, Color, D, F, H, Tick, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var animObject = A.animObject;\n var defaultOptions = D.defaultOptions;\n var registerEventOptions = F.registerEventOptions;\n var deg2rad = H.deg2rad;\n var arrayMax = U.arrayMax,\n arrayMin = U.arrayMin,\n clamp = U.clamp,\n correctFloat = U.correctFloat,\n defined = U.defined,\n destroyObjectProperties = U.destroyObjectProperties,\n erase = U.erase,\n error = U.error,\n extend = U.extend,\n fireEvent = U.fireEvent,\n isArray = U.isArray,\n isNumber = U.isNumber,\n isString = U.isString,\n merge = U.merge,\n normalizeTickInterval = U.normalizeTickInterval,\n objectEach = U.objectEach,\n pick = U.pick,\n relativeLength = U.relativeLength,\n removeEvent = U.removeEvent,\n splat = U.splat,\n syncTimeout = U.syncTimeout;\n var getNormalizedTickInterval = function (axis,\n tickInterval) { return normalizeTickInterval(tickInterval,\n void 0,\n void 0,\n pick(axis.options.allowDecimals, \n // If the tick interval is greather than 0.5, avoid decimals, as\n // linear axes are often used to render discrete values (#3363). If\n // a tick amount is set, allow decimals by default, as it increases\n // the chances for a good fit.\n tickInterval < 0.5 || axis.tickAmount !== void 0), !!axis.tickAmount); };\n /* *\n *\n * Class\n *\n * */\n /**\n * Create a new axis object. Called internally when instanciating a new chart or\n * adding axes by {@link Highcharts.Chart#addAxis}.\n *\n * A chart can have from 0 axes (pie chart) to multiples. In a normal, single\n * series cartesian chart, there is one X axis and one Y axis.\n *\n * The X axis or axes are referenced by {@link Highcharts.Chart.xAxis}, which is\n * an array of Axis objects. If there is only one axis, it can be referenced\n * through `chart.xAxis[0]`, and multiple axes have increasing indices. The same\n * pattern goes for Y axes.\n *\n * If you need to get the axes from a series object, use the `series.xAxis` and\n * `series.yAxis` properties. These are not arrays, as one series can only be\n * associated to one X and one Y axis.\n *\n * A third way to reference the axis programmatically is by `id`. Add an `id` in\n * the axis configuration options, and get the axis by\n * {@link Highcharts.Chart#get}.\n *\n * Configuration options for the axes are given in options.xAxis and\n * options.yAxis.\n *\n * @class\n * @name Highcharts.Axis\n *\n * @param {Highcharts.Chart} chart\n * The Chart instance to apply the axis on.\n *\n * @param {Highcharts.AxisOptions} userOptions\n * Axis options.\n */\n var Axis = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Axis(chart, userOptions) {\n this.alternateBands = void 0;\n this.bottom = void 0;\n this.chart = void 0;\n this.closestPointRange = void 0;\n this.coll = void 0;\n this.eventOptions = void 0;\n this.hasNames = void 0;\n this.hasVisibleSeries = void 0;\n this.height = void 0;\n this.isLinked = void 0;\n this.labelEdge = void 0; // @todo\n this.labelFormatter = void 0;\n this.left = void 0;\n this.len = void 0;\n this.max = void 0;\n this.maxLabelLength = void 0;\n this.min = void 0;\n this.minorTickInterval = void 0;\n this.minorTicks = void 0;\n this.minPixelPadding = void 0;\n this.names = void 0;\n this.offset = void 0;\n this.options = void 0;\n this.overlap = void 0;\n this.paddedTicks = void 0;\n this.plotLinesAndBands = void 0;\n this.plotLinesAndBandsGroups = void 0;\n this.pointRange = void 0;\n this.pointRangePadding = void 0;\n this.pos = void 0;\n this.positiveValuesOnly = void 0;\n this.right = void 0;\n this.series = void 0;\n this.side = void 0;\n this.tickAmount = void 0;\n this.tickInterval = void 0;\n this.tickmarkOffset = void 0;\n this.tickPositions = void 0;\n this.tickRotCorr = void 0;\n this.ticks = void 0;\n this.top = void 0;\n this.transA = void 0;\n this.transB = void 0;\n this.translationSlope = void 0;\n this.userOptions = void 0;\n this.visible = void 0;\n this.width = void 0;\n this.zoomEnabled = void 0;\n this.init(chart, userOptions);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Overrideable function to initialize the axis.\n *\n * @see {@link Axis}\n *\n * @function Highcharts.Axis#init\n *\n * @param {Highcharts.Chart} chart\n * The Chart instance to apply the axis on.\n *\n * @param {AxisOptions} userOptions\n * Axis options.\n *\n * @emits Highcharts.Axis#event:afterInit\n * @emits Highcharts.Axis#event:init\n */\n Axis.prototype.init = function (chart, userOptions) {\n var isXAxis = userOptions.isX,\n axis = this;\n /**\n * The Chart that the axis belongs to.\n *\n * @name Highcharts.Axis#chart\n * @type {Highcharts.Chart}\n */\n axis.chart = chart;\n /**\n * Whether the axis is horizontal.\n *\n * @name Highcharts.Axis#horiz\n * @type {boolean|undefined}\n */\n axis.horiz = chart.inverted && !axis.isZAxis ? !isXAxis : isXAxis;\n /**\n * Whether the axis is the x-axis.\n *\n * @name Highcharts.Axis#isXAxis\n * @type {boolean|undefined}\n */\n axis.isXAxis = isXAxis;\n /**\n * The collection where the axis belongs, for example `xAxis`, `yAxis`\n * or `colorAxis`. Corresponds to properties on Chart, for example\n * {@link Chart.xAxis}.\n *\n * @name Highcharts.Axis#coll\n * @type {string}\n */\n axis.coll = axis.coll || (isXAxis ? 'xAxis' : 'yAxis');\n fireEvent(this, 'init', { userOptions: userOptions });\n // Needed in setOptions\n axis.opposite = pick(userOptions.opposite, axis.opposite);\n /**\n * The side on which the axis is rendered. 0 is top, 1 is right, 2\n * is bottom and 3 is left.\n *\n * @name Highcharts.Axis#side\n * @type {number}\n */\n axis.side = pick(userOptions.side, axis.side, (axis.horiz ?\n (axis.opposite ? 0 : 2) : // top : bottom\n (axis.opposite ? 1 : 3)) // right : left\n );\n /**\n * Current options for the axis after merge of defaults and user's\n * options.\n *\n * @name Highcharts.Axis#options\n * @type {Highcharts.AxisOptions}\n */\n axis.setOptions(userOptions);\n var options = this.options,\n labelsOptions = options.labels,\n type = options.type;\n /**\n * User's options for this axis without defaults.\n *\n * @name Highcharts.Axis#userOptions\n * @type {Highcharts.AxisOptions}\n */\n axis.userOptions = userOptions;\n axis.minPixelPadding = 0;\n /**\n * Whether the axis is reversed. Based on the `axis.reversed`,\n * option, but inverted charts have reversed xAxis by default.\n *\n * @name Highcharts.Axis#reversed\n * @type {boolean}\n */\n axis.reversed = pick(options.reversed, axis.reversed);\n axis.visible = options.visible;\n axis.zoomEnabled = options.zoomEnabled;\n // Initial categories\n axis.hasNames =\n type === 'category' || options.categories === true;\n /**\n * If categories are present for the axis, names are used instead of\n * numbers for that axis.\n *\n * Since Highcharts 3.0, categories can also be extracted by giving each\n * point a name and setting axis type to `category`. However, if you\n * have multiple series, best practice remains defining the `categories`\n * array.\n *\n * @see [xAxis.categories](/highcharts/xAxis.categories)\n *\n * @name Highcharts.Axis#categories\n * @type {Array}\n * @readonly\n */\n axis.categories = options.categories || (axis.hasNames ? [] : void 0);\n if (!axis.names) { // Preserve on update (#3830)\n axis.names = [];\n axis.names.keys = {};\n }\n // Placeholder for plotlines and plotbands groups\n axis.plotLinesAndBandsGroups = {};\n // Shorthand types\n axis.positiveValuesOnly = !!axis.logarithmic;\n // Flag, if axis is linked to another axis\n axis.isLinked = defined(options.linkedTo);\n /**\n * List of major ticks mapped by postition on axis.\n *\n * @see {@link Highcharts.Tick}\n *\n * @name Highcharts.Axis#ticks\n * @type {Highcharts.Dictionary}\n */\n axis.ticks = {};\n axis.labelEdge = [];\n /**\n * List of minor ticks mapped by position on the axis.\n *\n * @see {@link Highcharts.Tick}\n *\n * @name Highcharts.Axis#minorTicks\n * @type {Highcharts.Dictionary}\n */\n axis.minorTicks = {};\n // List of plotLines/Bands\n axis.plotLinesAndBands = [];\n // Alternate bands\n axis.alternateBands = {};\n // Axis metrics\n axis.len = 0;\n axis.minRange = axis.userMinRange = options.minRange || options.maxZoom;\n axis.range = options.range;\n axis.offset = options.offset || 0;\n /**\n * The maximum value of the axis. In a logarithmic axis, this is the\n * logarithm of the real value, and the real value can be obtained from\n * {@link Axis#getExtremes}.\n *\n * @name Highcharts.Axis#max\n * @type {number|null}\n */\n axis.max = null;\n /**\n * The minimum value of the axis. In a logarithmic axis, this is the\n * logarithm of the real value, and the real value can be obtained from\n * {@link Axis#getExtremes}.\n *\n * @name Highcharts.Axis#min\n * @type {number|null}\n */\n axis.min = null;\n /**\n * The processed crosshair options.\n *\n * @name Highcharts.Axis#crosshair\n * @type {boolean|Highcharts.AxisCrosshairOptions}\n */\n var crosshair = pick(options.crosshair,\n splat(chart.options.tooltip.crosshairs)[isXAxis ? 0 : 1]);\n axis.crosshair = crosshair === true ? {} : crosshair;\n // Register. Don't add it again on Axis.update().\n if (chart.axes.indexOf(axis) === -1) { //\n if (isXAxis) { // #2713\n chart.axes.splice(chart.xAxis.length, 0, axis);\n }\n else {\n chart.axes.push(axis);\n }\n chart[axis.coll].push(axis);\n }\n /**\n * All series associated to the axis.\n *\n * @name Highcharts.Axis#series\n * @type {Array}\n */\n axis.series = axis.series || []; // populated by Series\n // Reversed axis\n if (chart.inverted &&\n !axis.isZAxis &&\n isXAxis &&\n typeof axis.reversed === 'undefined') {\n axis.reversed = true;\n }\n axis.labelRotation = isNumber(labelsOptions.rotation) ?\n labelsOptions.rotation :\n void 0;\n // Register event listeners\n registerEventOptions(axis, options);\n fireEvent(this, 'afterInit');\n };\n /**\n * Merge and set options.\n *\n * @private\n * @function Highcharts.Axis#setOptions\n *\n * @param {Highcharts.AxisOptions} userOptions\n * Axis options.\n *\n * @emits Highcharts.Axis#event:afterSetOptions\n */\n Axis.prototype.setOptions = function (userOptions) {\n this.options = merge(AxisDefaults.defaultXAxisOptions, (this.coll === 'yAxis') && AxisDefaults.defaultYAxisOptions, [\n AxisDefaults.defaultTopAxisOptions,\n AxisDefaults.defaultRightAxisOptions,\n AxisDefaults.defaultBottomAxisOptions,\n AxisDefaults.defaultLeftAxisOptions\n ][this.side], merge(\n // if set in setOptions (#1053):\n defaultOptions[this.coll], userOptions));\n fireEvent(this, 'afterSetOptions', { userOptions: userOptions });\n };\n /**\n * The default label formatter. The context is a special config object for\n * the label. In apps, use the\n * [labels.formatter](https://api.highcharts.com/highcharts/xAxis.labels.formatter)\n * instead, except when a modification is needed.\n *\n * @function Highcharts.Axis#defaultLabelFormatter\n *\n * @param {Highcharts.AxisLabelsFormatterContextObject} this\n * Formatter context of axis label.\n *\n * @param {Highcharts.AxisLabelsFormatterContextObject} [ctx]\n * Formatter context of axis label.\n *\n * @return {string}\n * The formatted label content.\n */\n Axis.prototype.defaultLabelFormatter = function (ctx) {\n var axis = this.axis,\n chart = this.chart,\n numberFormatter = chart.numberFormatter,\n value = isNumber(this.value) ? this.value : NaN,\n time = axis.chart.time,\n categories = axis.categories,\n dateTimeLabelFormat = this.dateTimeLabelFormat,\n lang = defaultOptions.lang,\n numericSymbols = lang.numericSymbols,\n numSymMagnitude = lang.numericSymbolMagnitude || 1000, \n // make sure the same symbol is added for all labels on a linear\n // axis\n numericSymbolDetector = axis.logarithmic ?\n Math.abs(value) :\n axis.tickInterval;\n var i = numericSymbols && numericSymbols.length,\n multi,\n ret;\n if (categories) {\n ret = \"\".concat(this.value);\n }\n else if (dateTimeLabelFormat) { // datetime axis\n ret = time.dateFormat(dateTimeLabelFormat, value);\n }\n else if (i && numericSymbolDetector >= 1000) {\n // Decide whether we should add a numeric symbol like k (thousands)\n // or M (millions). If we are to enable this in tooltip or other\n // places as well, we can move this logic to the numberFormatter and\n // enable it by a parameter.\n while (i-- && typeof ret === 'undefined') {\n multi = Math.pow(numSymMagnitude, i + 1);\n if (\n // Only accept a numeric symbol when the distance is more\n // than a full unit. So for example if the symbol is k, we\n // don't accept numbers like 0.5k.\n numericSymbolDetector >= multi &&\n // Accept one decimal before the symbol. Accepts 0.5k but\n // not 0.25k. How does this work with the previous?\n (value * 10) % multi === 0 &&\n numericSymbols[i] !== null &&\n value !== 0) { // #5480\n ret = numberFormatter(value / multi, -1) + numericSymbols[i];\n }\n }\n }\n if (typeof ret === 'undefined') {\n if (Math.abs(value) >= 10000) { // add thousands separators\n ret = numberFormatter(value, -1);\n }\n else { // small numbers\n ret = numberFormatter(value, -1, void 0, ''); // #2466\n }\n }\n return ret;\n };\n /**\n * Get the minimum and maximum for the series of each axis. The function\n * analyzes the axis series and updates `this.dataMin` and `this.dataMax`.\n *\n * @private\n * @function Highcharts.Axis#getSeriesExtremes\n *\n * @emits Highcharts.Axis#event:afterGetSeriesExtremes\n * @emits Highcharts.Axis#event:getSeriesExtremes\n */\n Axis.prototype.getSeriesExtremes = function () {\n var axis = this,\n chart = axis.chart;\n var xExtremes;\n fireEvent(this, 'getSeriesExtremes', null, function () {\n axis.hasVisibleSeries = false;\n // Reset properties in case we're redrawing (#3353)\n axis.dataMin = axis.dataMax = axis.threshold = null;\n axis.softThreshold = !axis.isXAxis;\n if (axis.stacking) {\n axis.stacking.buildStacks();\n }\n // loop through this axis' series\n axis.series.forEach(function (series) {\n if (series.visible ||\n !chart.options.chart.ignoreHiddenSeries) {\n var seriesOptions = series.options;\n var xData = void 0,\n threshold = seriesOptions.threshold,\n seriesDataMin = void 0,\n seriesDataMax = void 0;\n axis.hasVisibleSeries = true;\n // Validate threshold in logarithmic axes\n if (axis.positiveValuesOnly && threshold <= 0) {\n threshold = null;\n }\n // Get dataMin and dataMax for X axes\n if (axis.isXAxis) {\n xData = series.xData;\n if (xData.length) {\n xData = axis.logarithmic ?\n xData.filter(axis.validatePositiveValue) :\n xData;\n xExtremes = series.getXExtremes(xData);\n // If xData contains values which is not numbers,\n // then filter them out. To prevent performance hit,\n // we only do this after we have already found\n // seriesDataMin because in most cases all data is\n // valid. #5234.\n seriesDataMin = xExtremes.min;\n seriesDataMax = xExtremes.max;\n if (!isNumber(seriesDataMin) &&\n // #5010:\n !(seriesDataMin instanceof Date)) {\n xData = xData.filter(isNumber);\n xExtremes = series.getXExtremes(xData);\n // Do it again with valid data\n seriesDataMin = xExtremes.min;\n seriesDataMax = xExtremes.max;\n }\n if (xData.length) {\n axis.dataMin = Math.min(pick(axis.dataMin, seriesDataMin), seriesDataMin);\n axis.dataMax = Math.max(pick(axis.dataMax, seriesDataMax), seriesDataMax);\n }\n }\n // Get dataMin and dataMax for Y axes, as well as handle\n // stacking and processed data\n }\n else {\n // Get this particular series extremes\n var dataExtremes = series.applyExtremes();\n // Get the dataMin and dataMax so far. If percentage is\n // used, the min and max are always 0 and 100. If\n // seriesDataMin and seriesDataMax is null, then series\n // doesn't have active y data, we continue with nulls\n if (isNumber(dataExtremes.dataMin)) {\n seriesDataMin = dataExtremes.dataMin;\n axis.dataMin = Math.min(pick(axis.dataMin, seriesDataMin), seriesDataMin);\n }\n if (isNumber(dataExtremes.dataMax)) {\n seriesDataMax = dataExtremes.dataMax;\n axis.dataMax = Math.max(pick(axis.dataMax, seriesDataMax), seriesDataMax);\n }\n // Adjust to threshold\n if (defined(threshold)) {\n axis.threshold = threshold;\n }\n // If any series has a hard threshold, it takes\n // precedence\n if (!seriesOptions.softThreshold ||\n axis.positiveValuesOnly) {\n axis.softThreshold = false;\n }\n }\n }\n });\n });\n fireEvent(this, 'afterGetSeriesExtremes');\n };\n /**\n * Translate from axis value to pixel position on the chart, or back. Use\n * the `toPixels` and `toValue` functions in applications.\n *\n * @private\n * @function Highcharts.Axis#translate\n */\n Axis.prototype.translate = function (val, backwards, cvsCoord, old, handleLog, pointPlacement) {\n var axis = (this.linkedParent || this), // #1417\n localMin = (old && axis.old ? axis.old.min : axis.min);\n if (!isNumber(localMin)) {\n return NaN;\n }\n var minPixelPadding = axis.minPixelPadding,\n doPostTranslate = (axis.isOrdinal ||\n axis.brokenAxis && axis.brokenAxis.hasBreaks ||\n (axis.logarithmic && handleLog)) && axis.lin2val;\n var sign = 1,\n cvsOffset = 0,\n localA = old && axis.old ? axis.old.transA : axis.transA,\n returnValue = 0;\n if (!localA) {\n localA = axis.transA;\n }\n // In vertical axes, the canvas coordinates start from 0 at the top like\n // in SVG.\n if (cvsCoord) {\n sign *= -1; // canvas coordinates inverts the value\n cvsOffset = axis.len;\n }\n // Handle reversed axis\n if (axis.reversed) {\n sign *= -1;\n cvsOffset -= sign * (axis.sector || axis.len);\n }\n // From pixels to value\n if (backwards) { // reverse translation\n val = val * sign + cvsOffset;\n val -= minPixelPadding;\n // from chart pixel to value:\n returnValue = val / localA + localMin;\n if (doPostTranslate) { // log, ordinal and broken axis\n returnValue = axis.lin2val(returnValue);\n }\n // From value to pixels\n }\n else {\n if (doPostTranslate) { // log, ordinal and broken axis\n val = axis.val2lin(val);\n }\n var value = sign * (val - localMin) * localA;\n returnValue = (!axis.isRadial ? correctFloat(value) : value) +\n cvsOffset +\n (sign * minPixelPadding) +\n (isNumber(pointPlacement) ? localA * pointPlacement : 0);\n }\n return returnValue;\n };\n /**\n * Translate a value in terms of axis units into pixels within the chart.\n *\n * @function Highcharts.Axis#toPixels\n *\n * @param {number} value\n * A value in terms of axis units.\n *\n * @param {boolean} paneCoordinates\n * Whether to return the pixel coordinate relative to the chart or just the\n * axis/pane itself.\n *\n * @return {number}\n * Pixel position of the value on the chart or axis.\n */\n Axis.prototype.toPixels = function (value, paneCoordinates) {\n return this.translate(value, false, !this.horiz, void 0, true) +\n (paneCoordinates ? 0 : this.pos);\n };\n /**\n * Translate a pixel position along the axis to a value in terms of axis\n * units.\n *\n * @function Highcharts.Axis#toValue\n *\n * @param {number} pixel\n * The pixel value coordinate.\n *\n * @param {boolean} [paneCoordinates=false]\n * Whether the input pixel is relative to the chart or just the axis/pane\n * itself.\n *\n * @return {number}\n * The axis value.\n */\n Axis.prototype.toValue = function (pixel, paneCoordinates) {\n return this.translate(pixel - (paneCoordinates ? 0 : this.pos), true, !this.horiz, void 0, true);\n };\n /**\n * Create the path for a plot line that goes from the given value on\n * this axis, across the plot to the opposite side. Also used internally for\n * grid lines and crosshairs.\n *\n * @function Highcharts.Axis#getPlotLinePath\n *\n * @param {Highcharts.AxisPlotLinePathOptionsObject} options\n * Options for the path.\n *\n * @return {Highcharts.SVGPathArray|null}\n * The SVG path definition for the plot line.\n */\n Axis.prototype.getPlotLinePath = function (options) {\n var axis = this,\n chart = axis.chart,\n axisLeft = axis.left,\n axisTop = axis.top,\n old = options.old,\n value = options.value,\n lineWidth = options.lineWidth,\n cHeight = (old && chart.oldChartHeight) || chart.chartHeight,\n cWidth = (old && chart.oldChartWidth) || chart.chartWidth,\n transB = axis.transB;\n var translatedValue = options.translatedValue,\n force = options.force,\n x1,\n y1,\n x2,\n y2,\n skip;\n // eslint-disable-next-line valid-jsdoc\n /**\n * Check if x is between a and b. If not, either move to a/b\n * or skip, depending on the force parameter.\n * @private\n */\n function between(x, a, b) {\n if (force !== 'pass' && x < a || x > b) {\n if (force) {\n x = clamp(x, a, b);\n }\n else {\n skip = true;\n }\n }\n return x;\n }\n var evt = {\n value: value,\n lineWidth: lineWidth,\n old: old,\n force: force,\n acrossPanes: options.acrossPanes,\n translatedValue: translatedValue\n };\n fireEvent(this, 'getPlotLinePath', evt, function (e) {\n translatedValue = pick(translatedValue, axis.translate(value, void 0, void 0, old));\n // Keep the translated value within sane bounds, and avoid Infinity\n // to fail the isNumber test (#7709).\n translatedValue = clamp(translatedValue, -1e5, 1e5);\n x1 = x2 = Math.round(translatedValue + transB);\n y1 = y2 = Math.round(cHeight - translatedValue - transB);\n if (!isNumber(translatedValue)) { // no min or max\n skip = true;\n force = false; // #7175, don't force it when path is invalid\n }\n else if (axis.horiz) {\n y1 = axisTop;\n y2 = cHeight - axis.bottom;\n x1 = x2 = between(x1, axisLeft, axisLeft + axis.width);\n }\n else {\n x1 = axisLeft;\n x2 = cWidth - axis.right;\n y1 = y2 = between(y1, axisTop, axisTop + axis.height);\n }\n e.path = skip && !force ?\n null :\n chart.renderer.crispLine([['M', x1, y1], ['L', x2, y2]], lineWidth || 1);\n });\n return evt.path;\n };\n /**\n * Internal function to get the tick positions of a linear axis to round\n * values like whole tens or every five.\n *\n * @function Highcharts.Axis#getLinearTickPositions\n *\n * @param {number} tickInterval\n * The normalized tick interval.\n *\n * @param {number} min\n * Axis minimum.\n *\n * @param {number} max\n * Axis maximum.\n *\n * @return {Array}\n * An array of axis values where ticks should be placed.\n */\n Axis.prototype.getLinearTickPositions = function (tickInterval, min, max) {\n var roundedMin = correctFloat(Math.floor(min / tickInterval) * tickInterval),\n roundedMax = correctFloat(Math.ceil(max / tickInterval) * tickInterval),\n tickPositions = [];\n var pos,\n lastPos,\n precision;\n // When the precision is higher than what we filter out in\n // correctFloat, skip it (#6183).\n if (correctFloat(roundedMin + tickInterval) === roundedMin) {\n precision = 20;\n }\n // For single points, add a tick regardless of the relative position\n // (#2662, #6274)\n if (this.single) {\n return [min];\n }\n // Populate the intermediate values\n pos = roundedMin;\n while (pos <= roundedMax) {\n // Place the tick on the rounded value\n tickPositions.push(pos);\n // Always add the raw tickInterval, not the corrected one.\n pos = correctFloat(pos + tickInterval, precision);\n // If the interval is not big enough in the current min - max range\n // to actually increase the loop variable, we need to break out to\n // prevent endless loop. Issue #619\n if (pos === lastPos) {\n break;\n }\n // Record the last value\n lastPos = pos;\n }\n return tickPositions;\n };\n /**\n * Resolve the new minorTicks/minorTickInterval options into the legacy\n * loosely typed minorTickInterval option.\n *\n * @function Highcharts.Axis#getMinorTickInterval\n *\n * @return {number|\"auto\"|null}\n * Legacy option\n */\n Axis.prototype.getMinorTickInterval = function () {\n var options = this.options;\n if (options.minorTicks === true) {\n return pick(options.minorTickInterval, 'auto');\n }\n if (options.minorTicks === false) {\n return null;\n }\n return options.minorTickInterval;\n };\n /**\n * Internal function to return the minor tick positions. For logarithmic\n * axes, the same logic as for major ticks is reused.\n *\n * @function Highcharts.Axis#getMinorTickPositions\n *\n * @return {Array}\n * An array of axis values where ticks should be placed.\n */\n Axis.prototype.getMinorTickPositions = function () {\n var axis = this,\n options = axis.options,\n tickPositions = axis.tickPositions,\n minorTickInterval = axis.minorTickInterval,\n pointRangePadding = axis.pointRangePadding || 0,\n min = axis.min - pointRangePadding, // #1498\n max = axis.max + pointRangePadding, // #1498\n range = max - min;\n var minorTickPositions = [],\n pos;\n // If minor ticks get too dense, they are hard to read, and may cause\n // long running script. So we don't draw them.\n if (range && range / minorTickInterval < axis.len / 3) { // #3875\n var logarithmic_1 = axis.logarithmic;\n if (logarithmic_1) {\n // For each interval in the major ticks, compute the minor ticks\n // separately.\n this.paddedTicks.forEach(function (_pos, i, paddedTicks) {\n if (i) {\n minorTickPositions.push.apply(minorTickPositions, logarithmic_1.getLogTickPositions(minorTickInterval, paddedTicks[i - 1], paddedTicks[i], true));\n }\n });\n }\n else if (axis.dateTime &&\n this.getMinorTickInterval() === 'auto') { // #1314\n minorTickPositions = minorTickPositions.concat(axis.getTimeTicks(axis.dateTime.normalizeTimeTickInterval(minorTickInterval), min, max, options.startOfWeek));\n }\n else {\n for (pos = min + (tickPositions[0] - min) % minorTickInterval; pos <= max; pos += minorTickInterval) {\n // Very, very, tight grid lines (#5771)\n if (pos === minorTickPositions[0]) {\n break;\n }\n minorTickPositions.push(pos);\n }\n }\n }\n if (minorTickPositions.length !== 0) {\n axis.trimTicks(minorTickPositions); // #3652 #3743 #1498 #6330\n }\n return minorTickPositions;\n };\n /**\n * Adjust the min and max for the minimum range. Keep in mind that the\n * series data is not yet processed, so we don't have information on data\n * cropping and grouping, or updated `axis.pointRange` or\n * `series.pointRange`. The data can't be processed until we have finally\n * established min and max.\n *\n * @private\n * @function Highcharts.Axis#adjustForMinRange\n */\n Axis.prototype.adjustForMinRange = function () {\n var axis = this,\n options = axis.options,\n log = axis.logarithmic;\n var min = axis.min,\n max = axis.max,\n zoomOffset,\n spaceAvailable,\n closestDataRange = 0,\n i,\n distance,\n xData,\n loopLength,\n minArgs,\n maxArgs,\n minRange;\n // Set the automatic minimum range based on the closest point distance\n if (axis.isXAxis &&\n typeof axis.minRange === 'undefined' &&\n !log) {\n if (defined(options.min) ||\n defined(options.max) ||\n defined(options.floor) ||\n defined(options.ceiling)) {\n axis.minRange = null; // don't do this again\n }\n else {\n // Find the closest distance between raw data points, as opposed\n // to closestPointRange that applies to processed points\n // (cropped and grouped)\n axis.series.forEach(function (series) {\n xData = series.xData;\n loopLength = series.xIncrement ? 1 : xData.length - 1;\n if (xData.length > 1) {\n for (i = loopLength; i > 0; i--) {\n distance = xData[i] - xData[i - 1];\n if (!closestDataRange ||\n distance < closestDataRange) {\n closestDataRange = distance;\n }\n }\n }\n });\n axis.minRange = Math.min(closestDataRange * 5, axis.dataMax - axis.dataMin);\n }\n }\n // if minRange is exceeded, adjust\n if (max - min < axis.minRange) {\n spaceAvailable =\n axis.dataMax - axis.dataMin >=\n axis.minRange;\n minRange = axis.minRange;\n zoomOffset = (minRange - max + min) / 2;\n // if min and max options have been set, don't go beyond it\n minArgs = [\n min - zoomOffset,\n pick(options.min, min - zoomOffset)\n ];\n // If space is available, stay within the data range\n if (spaceAvailable) {\n minArgs[2] = axis.logarithmic ?\n axis.logarithmic.log2lin(axis.dataMin) :\n axis.dataMin;\n }\n min = arrayMax(minArgs);\n maxArgs = [\n min + minRange,\n pick(options.max, min + minRange)\n ];\n // If space is availabe, stay within the data range\n if (spaceAvailable) {\n maxArgs[2] = log ?\n log.log2lin(axis.dataMax) :\n axis.dataMax;\n }\n max = arrayMin(maxArgs);\n // now if the max is adjusted, adjust the min back\n if (max - min < minRange) {\n minArgs[0] = max - minRange;\n minArgs[1] = pick(options.min, max - minRange);\n min = arrayMax(minArgs);\n }\n }\n // Record modified extremes\n axis.min = min;\n axis.max = max;\n };\n /**\n * Find the closestPointRange across all series.\n *\n * @private\n * @function Highcharts.Axis#getClosest\n */\n Axis.prototype.getClosest = function () {\n var ret;\n if (this.categories) {\n ret = 1;\n }\n else {\n this.series.forEach(function (series) {\n var seriesClosest = series.closestPointRange,\n visible = series.visible ||\n !series.chart.options.chart.ignoreHiddenSeries;\n if (!series.noSharedTooltip &&\n defined(seriesClosest) &&\n visible) {\n ret = defined(ret) ?\n Math.min(ret, seriesClosest) :\n seriesClosest;\n }\n });\n }\n return ret;\n };\n /**\n * When a point name is given and no x, search for the name in the existing\n * categories, or if categories aren't provided, search names or create a\n * new category (#2522).\n *\n * @private\n * @function Highcharts.Axis#nameToX\n *\n * @param {Highcharts.Point} point\n * The point to inspect.\n *\n * @return {number}\n * The X value that the point is given.\n */\n Axis.prototype.nameToX = function (point) {\n var explicitCategories = isArray(this.options.categories),\n names = explicitCategories ? this.categories : this.names;\n var nameX = point.options.x,\n x;\n point.series.requireSorting = false;\n if (!defined(nameX)) {\n nameX = this.options.uniqueNames && names ?\n (explicitCategories ?\n names.indexOf(point.name) :\n pick(names.keys[point.name], -1)) :\n point.series.autoIncrement();\n }\n if (nameX === -1) { // Not found in currenct categories\n if (!explicitCategories && names) {\n x = names.length;\n }\n }\n else {\n x = nameX;\n }\n // Write the last point's name to the names array\n if (typeof x !== 'undefined') {\n this.names[x] = point.name;\n // Backwards mapping is much faster than array searching (#7725)\n this.names.keys[point.name] = x;\n }\n else if (point.x) {\n x = point.x; // #17438\n }\n return x;\n };\n /**\n * When changes have been done to series data, update the axis.names.\n *\n * @private\n * @function Highcharts.Axis#updateNames\n */\n Axis.prototype.updateNames = function () {\n var axis = this,\n names = this.names,\n i = names.length;\n if (i > 0) {\n Object.keys(names.keys).forEach(function (key) {\n delete (names.keys)[key];\n });\n names.length = 0;\n this.minRange = this.userMinRange; // Reset\n (this.series || []).forEach(function (series) {\n // Reset incrementer (#5928)\n series.xIncrement = null;\n // When adding a series, points are not yet generated\n if (!series.points || series.isDirtyData) {\n // When we're updating the series with data that is longer\n // than it was, and cropThreshold is passed, we need to make\n // sure that the axis.max is increased _before_ running the\n // premature processData. Otherwise this early iteration of\n // processData will crop the points to axis.max, and the\n // names array will be too short (#5857).\n axis.max = Math.max(axis.max, series.xData.length - 1);\n series.processData();\n series.generatePoints();\n }\n series.data.forEach(function (point, i) {\n var x;\n if (point &&\n point.options &&\n typeof point.name !== 'undefined' // #9562\n ) {\n x = axis.nameToX(point);\n if (typeof x !== 'undefined' && x !== point.x) {\n point.x = x;\n series.xData[i] = x;\n }\n }\n });\n });\n }\n };\n /**\n * Update translation information.\n *\n * @private\n * @function Highcharts.Axis#setAxisTranslation\n *\n * @emits Highcharts.Axis#event:afterSetAxisTranslation\n */\n Axis.prototype.setAxisTranslation = function () {\n var axis = this,\n range = axis.max - axis.min,\n linkedParent = axis.linkedParent,\n hasCategories = !!axis.categories,\n isXAxis = axis.isXAxis;\n var pointRange = axis.axisPointRange || 0,\n closestPointRange,\n minPointOffset = 0,\n pointRangePadding = 0,\n ordinalCorrection,\n transA = axis.transA;\n // Adjust translation for padding. Y axis with categories need to go\n // through the same (#1784).\n if (isXAxis || hasCategories || pointRange) {\n // Get the closest points\n closestPointRange = axis.getClosest();\n if (linkedParent) {\n minPointOffset = linkedParent.minPointOffset;\n pointRangePadding = linkedParent.pointRangePadding;\n }\n else {\n axis.series.forEach(function (series) {\n var seriesPointRange = hasCategories ?\n 1 :\n (isXAxis ?\n pick(series.options.pointRange,\n closestPointRange, 0) :\n (axis.axisPointRange || 0)), // #2806\n pointPlacement = series.options.pointPlacement;\n pointRange = Math.max(pointRange, seriesPointRange);\n if (!axis.single || hasCategories) {\n // TODO: series should internally set x- and y-\n // pointPlacement to simplify this logic.\n var isPointPlacementAxis = series.is('xrange') ?\n !isXAxis :\n isXAxis;\n // minPointOffset is the value padding to the left of\n // the axis in order to make room for points with a\n // pointRange, typically columns. When the\n // pointPlacement option is 'between' or 'on', this\n // padding does not apply.\n minPointOffset = Math.max(minPointOffset, isPointPlacementAxis && isString(pointPlacement) ?\n 0 :\n seriesPointRange / 2);\n // Determine the total padding needed to the length of\n // the axis to make room for the pointRange. If the\n // series' pointPlacement is 'on', no padding is added.\n pointRangePadding = Math.max(pointRangePadding, isPointPlacementAxis && pointPlacement === 'on' ?\n 0 :\n seriesPointRange);\n }\n });\n }\n // Record minPointOffset and pointRangePadding\n ordinalCorrection = (axis.ordinal && axis.ordinal.slope && closestPointRange) ?\n axis.ordinal.slope / closestPointRange :\n 1; // #988, #1853\n axis.minPointOffset = minPointOffset =\n minPointOffset * ordinalCorrection;\n axis.pointRangePadding =\n pointRangePadding = pointRangePadding * ordinalCorrection;\n // pointRange means the width reserved for each point, like in a\n // column chart\n axis.pointRange = Math.min(pointRange, axis.single && hasCategories ? 1 : range);\n // closestPointRange means the closest distance between points. In\n // columns it is mostly equal to pointRange, but in lines pointRange\n // is 0 while closestPointRange is some other value\n if (isXAxis) {\n axis.closestPointRange = closestPointRange;\n }\n }\n // Secondary values\n axis.translationSlope = axis.transA = transA =\n axis.staticScale ||\n axis.len / ((range + pointRangePadding) || 1);\n // Translation addend\n axis.transB = axis.horiz ? axis.left : axis.bottom;\n axis.minPixelPadding = transA * minPointOffset;\n fireEvent(this, 'afterSetAxisTranslation');\n };\n /**\n * @private\n * @function Highcharts.Axis#minFromRange\n */\n Axis.prototype.minFromRange = function () {\n var axis = this;\n return axis.max - axis.range;\n };\n /**\n * Set the tick positions to round values and optionally extend the extremes\n * to the nearest tick.\n *\n * @private\n * @function Highcharts.Axis#setTickInterval\n *\n * @param {boolean} secondPass\n * TO-DO: parameter description\n *\n * @emits Highcharts.Axis#event:foundExtremes\n */\n Axis.prototype.setTickInterval = function (secondPass) {\n var axis = this,\n chart = axis.chart,\n log = axis.logarithmic,\n options = axis.options,\n isXAxis = axis.isXAxis,\n isLinked = axis.isLinked,\n tickPixelIntervalOption = options.tickPixelInterval,\n categories = axis.categories,\n softThreshold = axis.softThreshold;\n var maxPadding = options.maxPadding,\n minPadding = options.minPadding,\n length,\n linkedParentExtremes, \n // Only non-negative tickInterval is valid, #12961\n tickIntervalOption = isNumber(options.tickInterval) && options.tickInterval >= 0 ?\n options.tickInterval : void 0,\n threshold = isNumber(axis.threshold) ? axis.threshold : null,\n thresholdMin,\n thresholdMax,\n hardMin,\n hardMax;\n if (!axis.dateTime && !categories && !isLinked) {\n this.getTickAmount();\n }\n // Min or max set either by zooming/setExtremes or initial options\n hardMin = pick(axis.userMin, options.min);\n hardMax = pick(axis.userMax, options.max);\n // Linked axis gets the extremes from the parent axis\n if (isLinked) {\n axis.linkedParent = chart[axis.coll][options.linkedTo];\n linkedParentExtremes = axis.linkedParent.getExtremes();\n axis.min = pick(linkedParentExtremes.min, linkedParentExtremes.dataMin);\n axis.max = pick(linkedParentExtremes.max, linkedParentExtremes.dataMax);\n if (options.type !== axis.linkedParent.options.type) {\n // Can't link axes of different type\n error(11, 1, chart);\n }\n // Initial min and max from the extreme data values\n }\n else {\n // Adjust to hard threshold\n if (softThreshold && defined(threshold)) {\n if (axis.dataMin >= threshold) {\n thresholdMin = threshold;\n minPadding = 0;\n }\n else if (axis.dataMax <= threshold) {\n thresholdMax = threshold;\n maxPadding = 0;\n }\n }\n axis.min = pick(hardMin, thresholdMin, axis.dataMin);\n axis.max = pick(hardMax, thresholdMax, axis.dataMax);\n }\n if (log) {\n if (axis.positiveValuesOnly &&\n !secondPass &&\n Math.min(axis.min, pick(axis.dataMin, axis.min)) <= 0) { // #978\n // Can't plot negative values on log axis\n error(10, 1, chart);\n }\n // The correctFloat cures #934, float errors on full tens. But it\n // was too aggressive for #4360 because of conversion back to lin,\n // therefore use precision 15.\n axis.min = correctFloat(log.log2lin(axis.min), 16);\n axis.max = correctFloat(log.log2lin(axis.max), 16);\n }\n // handle zoomed range\n if (axis.range && defined(axis.max)) {\n // #618, #6773:\n axis.userMin = axis.min = hardMin =\n Math.max(axis.dataMin, axis.minFromRange());\n axis.userMax = hardMax = axis.max;\n axis.range = null; // don't use it when running setExtremes\n }\n // Hook for Highcharts Stock Scroller.\n // Consider combining with beforePadding.\n fireEvent(axis, 'foundExtremes');\n // Hook for adjusting this.min and this.max. Used by bubble series.\n if (axis.beforePadding) {\n axis.beforePadding();\n }\n // adjust min and max for the minimum range\n axis.adjustForMinRange();\n // Pad the values to get clear of the chart's edges. To avoid\n // tickInterval taking the padding into account, we do this after\n // computing tick interval (#1337).\n if (!categories &&\n !axis.axisPointRange &&\n !(axis.stacking && axis.stacking.usePercentage) &&\n !isLinked &&\n defined(axis.min) &&\n defined(axis.max)) {\n length = axis.max - axis.min;\n if (length) {\n if (!defined(hardMin) && minPadding) {\n axis.min -= length * minPadding;\n }\n if (!defined(hardMax) && maxPadding) {\n axis.max += length * maxPadding;\n }\n }\n }\n // Handle options for floor, ceiling, softMin and softMax (#6359)\n if (!isNumber(axis.userMin)) {\n if (isNumber(options.softMin) && options.softMin < axis.min) {\n axis.min = hardMin = options.softMin; // #6894\n }\n if (isNumber(options.floor)) {\n axis.min = Math.max(axis.min, options.floor);\n }\n }\n if (!isNumber(axis.userMax)) {\n if (isNumber(options.softMax) && options.softMax > axis.max) {\n axis.max = hardMax = options.softMax; // #6894\n }\n if (isNumber(options.ceiling)) {\n axis.max = Math.min(axis.max, options.ceiling);\n }\n }\n // When the threshold is soft, adjust the extreme value only if the data\n // extreme and the padded extreme land on either side of the threshold.\n // For example, a series of [0, 1, 2, 3] would make the yAxis add a tick\n // for -1 because of the default minPadding and startOnTick options.\n // This is prevented by the softThreshold option.\n if (softThreshold && defined(axis.dataMin)) {\n threshold = threshold || 0;\n if (!defined(hardMin) &&\n axis.min < threshold &&\n axis.dataMin >= threshold) {\n axis.min = axis.options.minRange ?\n Math.min(threshold, axis.max -\n axis.minRange) :\n threshold;\n }\n else if (!defined(hardMax) &&\n axis.max > threshold &&\n axis.dataMax <= threshold) {\n axis.max = axis.options.minRange ?\n Math.max(threshold, axis.min +\n axis.minRange) :\n threshold;\n }\n }\n // If min is bigger than highest, or if max less than lowest value, the\n // chart should not render points. (#14417)\n if (isNumber(axis.min) &&\n isNumber(axis.max) &&\n !this.chart.polar &&\n (axis.min > axis.max)) {\n if (defined(axis.options.min)) {\n axis.max = axis.min;\n }\n else if (defined(axis.options.max)) {\n axis.min = axis.max;\n }\n }\n // get tickInterval\n if (axis.min === axis.max ||\n typeof axis.min === 'undefined' ||\n typeof axis.max === 'undefined') {\n axis.tickInterval = 1;\n }\n else if (isLinked &&\n axis.linkedParent &&\n !tickIntervalOption &&\n tickPixelIntervalOption ===\n axis.linkedParent.options.tickPixelInterval) {\n axis.tickInterval = tickIntervalOption =\n axis.linkedParent.tickInterval;\n }\n else {\n axis.tickInterval = pick(tickIntervalOption, this.tickAmount ?\n ((axis.max - axis.min) /\n Math.max(this.tickAmount - 1, 1)) :\n void 0, \n // For categoried axis, 1 is default, for linear axis use\n // tickPix\n categories ?\n 1 :\n // don't let it be more than the data range\n (axis.max - axis.min) *\n tickPixelIntervalOption /\n Math.max(axis.len, tickPixelIntervalOption));\n }\n // Now we're finished detecting min and max, crop and group series data.\n // This is in turn needed in order to find tick positions in ordinal\n // axes.\n if (isXAxis && !secondPass) {\n var hasExtremesChanged_1 = axis.min !==\n (axis.old && axis.old.min) ||\n axis.max !== (axis.old && axis.old.max);\n // First process all series assigned to that axis.\n axis.series.forEach(function (series) {\n // Allows filtering out points outside the plot area.\n series.forceCrop = (series.forceCropping &&\n series.forceCropping());\n series.processData(hasExtremesChanged_1);\n });\n // Then apply grouping if needed. The hasExtremesChanged helps to\n // decide if the data grouping should be skipped in the further\n // calculations #16319.\n fireEvent(this, 'postProcessData', { hasExtremesChanged: hasExtremesChanged_1 });\n }\n // set the translation factor used in translate function\n axis.setAxisTranslation();\n // hook for ordinal axes and radial axes\n fireEvent(this, 'initialAxisTranslation');\n // In column-like charts, don't cramp in more ticks than there are\n // points (#1943, #4184)\n if (axis.pointRange && !tickIntervalOption) {\n axis.tickInterval = Math.max(axis.pointRange, axis.tickInterval);\n }\n // Before normalizing the tick interval, handle minimum tick interval.\n // This applies only if tickInterval is not defined.\n var minTickInterval = pick(options.minTickInterval, \n // In datetime axes, don't go below the data interval, except when\n // there are scatter-like series involved (#13369).\n axis.dateTime &&\n !axis.series.some(function (s) { return s.noSharedTooltip; }) ?\n axis.closestPointRange : 0);\n if (!tickIntervalOption && axis.tickInterval < minTickInterval) {\n axis.tickInterval = minTickInterval;\n }\n // For linear axes, normalize the interval\n if (!axis.dateTime && !axis.logarithmic && !tickIntervalOption) {\n axis.tickInterval = getNormalizedTickInterval(axis, axis.tickInterval);\n }\n // Prevent ticks from getting so close that we can't draw the labels\n if (!this.tickAmount) {\n axis.tickInterval = axis.unsquish();\n }\n this.setTickPositions();\n };\n /**\n * Now we have computed the normalized tickInterval, get the tick positions.\n *\n * @private\n * @function Highcharts.Axis#setTickPositions\n *\n * @emits Highcharts.Axis#event:afterSetTickPositions\n */\n Axis.prototype.setTickPositions = function () {\n var axis = this,\n options = this.options,\n tickPositionsOption = options.tickPositions,\n tickPositioner = options.tickPositioner,\n minorTickIntervalOption = this.getMinorTickInterval(),\n hasVerticalPanning = this.hasVerticalPanning(),\n isColorAxis = this.coll === 'colorAxis',\n startOnTick = ((isColorAxis || !hasVerticalPanning) && options.startOnTick),\n endOnTick = ((isColorAxis || !hasVerticalPanning) && options.endOnTick);\n var tickPositions = [],\n tickPositionerResult;\n // Set the tickmarkOffset\n this.tickmarkOffset = (this.categories &&\n options.tickmarkPlacement === 'between' &&\n this.tickInterval === 1) ? 0.5 : 0; // #3202\n // get minorTickInterval\n this.minorTickInterval =\n minorTickIntervalOption === 'auto' &&\n this.tickInterval ?\n this.tickInterval / 5 :\n minorTickIntervalOption;\n // When there is only one point, or all points have the same value on\n // this axis, then min and max are equal and tickPositions.length is 0\n // or 1. In this case, add some padding in order to center the point,\n // but leave it with one tick. #1337.\n this.single =\n this.min === this.max &&\n defined(this.min) &&\n !this.tickAmount &&\n (\n // Data is on integer (#6563)\n parseInt(this.min, 10) === this.min ||\n // Between integers and decimals are not allowed (#6274)\n options.allowDecimals !== false);\n /**\n * Contains the current positions that are laid out on the axis. The\n * positions are numbers in terms of axis values. In a category axis\n * they are integers, in a datetime axis they are also integers, but\n * designating milliseconds.\n *\n * This property is read only - for modifying the tick positions, use\n * the `tickPositioner` callback or [axis.tickPositions(\n * https://api.highcharts.com/highcharts/xAxis.tickPositions) option\n * instead.\n *\n * @name Highcharts.Axis#tickPositions\n * @type {Highcharts.AxisTickPositionsArray|undefined}\n */\n if (tickPositionsOption) {\n // Find the tick positions. Work on a copy (#1565)\n tickPositions = tickPositionsOption.slice();\n }\n else if (isNumber(this.min) && isNumber(this.max)) {\n // Too many ticks (#6405). Create a friendly warning and provide two\n // ticks so at least we can show the data series.\n if ((!axis.ordinal || !axis.ordinal.positions) &&\n ((this.max - this.min) /\n this.tickInterval >\n Math.max(2 * this.len, 200))) {\n tickPositions = [this.min, this.max];\n error(19, false, this.chart);\n }\n else if (axis.dateTime) {\n tickPositions = axis.getTimeTicks(axis.dateTime.normalizeTimeTickInterval(this.tickInterval, options.units), this.min, this.max, options.startOfWeek, axis.ordinal && axis.ordinal.positions, this.closestPointRange, true);\n }\n else if (axis.logarithmic) {\n tickPositions = axis.logarithmic.getLogTickPositions(this.tickInterval, this.min, this.max);\n }\n else {\n var startingTickInterval = this.tickInterval;\n var adjustedTickInterval = startingTickInterval;\n while (adjustedTickInterval <= startingTickInterval * 2) {\n tickPositions = this.getLinearTickPositions(this.tickInterval, this.min, this.max);\n // If there are more tick positions than the set tickAmount,\n // increase the tickInterval and continue until it fits.\n // (#17100)\n if (this.tickAmount &&\n tickPositions.length > this.tickAmount) {\n this.tickInterval = getNormalizedTickInterval(this, adjustedTickInterval *= 1.1);\n }\n else {\n break;\n }\n }\n }\n // Too dense ticks, keep only the first and last (#4477)\n if (tickPositions.length > this.len) {\n tickPositions = [\n tickPositions[0],\n tickPositions[tickPositions.length - 1]\n ];\n // Reduce doubled value (#7339)\n if (tickPositions[0] === tickPositions[1]) {\n tickPositions.length = 1;\n }\n }\n // Run the tick positioner callback, that allows modifying auto tick\n // positions.\n if (tickPositioner) {\n // Make it available to the positioner\n this.tickPositions = tickPositions;\n tickPositionerResult = tickPositioner.apply(axis, [this.min, this.max]);\n if (tickPositionerResult) {\n tickPositions = tickPositionerResult;\n }\n }\n }\n this.tickPositions = tickPositions;\n // Reset min/max or remove extremes based on start/end on tick\n this.paddedTicks = tickPositions.slice(0); // Used for logarithmic minor\n this.trimTicks(tickPositions, startOnTick, endOnTick);\n if (!this.isLinked && isNumber(this.min) && isNumber(this.max)) {\n // Substract half a unit (#2619, #2846, #2515, #3390), but not in\n // case of multiple ticks (#6897)\n if (this.single &&\n tickPositions.length < 2 &&\n !this.categories &&\n !this.series.some(function (s) {\n return (s.is('heatmap') && s.options.pointPlacement === 'between');\n })) {\n this.min -= 0.5;\n this.max += 0.5;\n }\n if (!tickPositionsOption && !tickPositionerResult) {\n this.adjustTickAmount();\n }\n }\n fireEvent(this, 'afterSetTickPositions');\n };\n /**\n * Handle startOnTick and endOnTick by either adapting to padding min/max or\n * rounded min/max. Also handle single data points.\n *\n * @private\n * @function Highcharts.Axis#trimTicks\n *\n * @param {Array} tickPositions\n * TO-DO: parameter description\n *\n * @param {boolean} [startOnTick]\n * TO-DO: parameter description\n *\n * @param {boolean} [endOnTick]\n * TO-DO: parameter description\n */\n Axis.prototype.trimTicks = function (tickPositions, startOnTick, endOnTick) {\n var roundedMin = tickPositions[0],\n roundedMax = tickPositions[tickPositions.length - 1],\n minPointOffset = (!this.isOrdinal && this.minPointOffset) || 0; // (#12716)\n fireEvent(this, 'trimTicks');\n if (!this.isLinked) {\n if (startOnTick && roundedMin !== -Infinity) { // #6502\n this.min = roundedMin;\n }\n else {\n while (this.min - minPointOffset > tickPositions[0]) {\n tickPositions.shift();\n }\n }\n if (endOnTick) {\n this.max = roundedMax;\n }\n else {\n while (this.max + minPointOffset <\n tickPositions[tickPositions.length - 1]) {\n tickPositions.pop();\n }\n }\n // If no tick are left, set one tick in the middle (#3195)\n if (tickPositions.length === 0 &&\n defined(roundedMin) &&\n !this.options.tickPositions) {\n tickPositions.push((roundedMax + roundedMin) / 2);\n }\n }\n };\n /**\n * Check if there are multiple axes in the same pane.\n *\n * @private\n * @function Highcharts.Axis#alignToOthers\n *\n * @return {boolean|undefined}\n * True if there are other axes.\n */\n Axis.prototype.alignToOthers = function () {\n var axis = this,\n alignedAxes = [this],\n options = axis.options,\n alignThresholds = (this.coll === 'yAxis' &&\n this.chart.options.chart.alignThresholds),\n thresholdAlignments = [];\n var hasOther;\n axis.thresholdAlignment = void 0;\n if ((\n // Only if alignTicks or alignThresholds is true\n (this.chart.options.chart.alignTicks !== false &&\n options.alignTicks) || (alignThresholds)) &&\n // Disabled when startOnTick or endOnTick are false (#7604)\n options.startOnTick !== false &&\n options.endOnTick !== false &&\n // Don't try to align ticks on a log axis, they are not evenly\n // spaced (#6021)\n !axis.logarithmic) {\n // Get a key identifying which pane the axis belongs to\n var getKey_1 = function (axis) {\n var horiz = axis.horiz,\n options = axis.options;\n return [\n horiz ? options.left : options.top,\n options.width,\n options.height,\n options.pane\n ].join(',');\n };\n var thisKey_1 = getKey_1(this);\n this.chart[this.coll].forEach(function (otherAxis) {\n var series = otherAxis.series;\n if (\n // #4442\n series.length &&\n series.some(function (s) { return s.visible; }) &&\n otherAxis !== axis &&\n getKey_1(otherAxis) === thisKey_1) {\n hasOther = true; // #4201\n alignedAxes.push(otherAxis);\n }\n });\n }\n if (hasOther && alignThresholds) {\n // Handle alignThresholds. The `thresholdAlignments` array keeps\n // records of where each axis in the group wants its threshold, from\n // 0 which is on `axis.min`, to 1 which is on `axis.max`.\n alignedAxes.forEach(function (otherAxis) {\n var threshAlign = otherAxis.getThresholdAlignment(axis);\n if (isNumber(threshAlign)) {\n thresholdAlignments.push(threshAlign);\n }\n });\n // For each of the axes in the group, record the average\n // `thresholdAlignment`.\n var thresholdAlignment_1 = thresholdAlignments.length > 1 ?\n thresholdAlignments.reduce(function (sum,\n n) { return (sum += n); }, 0) / thresholdAlignments.length :\n void 0;\n alignedAxes.forEach(function (axis) {\n axis.thresholdAlignment = thresholdAlignment_1;\n });\n }\n return hasOther;\n };\n /**\n * Where the axis wants its threshold, from 0 which is on `axis.min`, to 1 which\n * is on `axis.max`.\n *\n * @private\n * @function Highcharts.Axis#getThresholdAlignment\n */\n Axis.prototype.getThresholdAlignment = function (callerAxis) {\n if (!isNumber(this.dataMin) ||\n (this !== callerAxis &&\n this.series.some(function (s) { return (s.isDirty || s.isDirtyData); }))) {\n this.getSeriesExtremes();\n }\n if (isNumber(this.threshold)) {\n var thresholdAlignment = clamp(((this.threshold - (this.dataMin || 0)) /\n ((this.dataMax || 0) - (this.dataMin || 0))), 0, 1);\n if (this.options.reversed) {\n thresholdAlignment = 1 - thresholdAlignment;\n }\n return thresholdAlignment;\n }\n };\n /**\n * Find the max ticks of either the x and y axis collection, and record it\n * in `this.tickAmount`.\n *\n * @private\n * @function Highcharts.Axis#getTickAmount\n */\n Axis.prototype.getTickAmount = function () {\n var axis = this,\n options = this.options,\n tickPixelInterval = options.tickPixelInterval;\n var tickAmount = options.tickAmount;\n if (!defined(options.tickInterval) &&\n !tickAmount &&\n this.len < tickPixelInterval &&\n !this.isRadial &&\n !axis.logarithmic &&\n options.startOnTick &&\n options.endOnTick) {\n tickAmount = 2;\n }\n if (!tickAmount && this.alignToOthers()) {\n // Add 1 because 4 tick intervals require 5 ticks (including first\n // and last)\n tickAmount = Math.ceil(this.len / tickPixelInterval) + 1;\n }\n // For tick amounts of 2 and 3, compute five ticks and remove the\n // intermediate ones. This prevents the axis from adding ticks that are\n // too far away from the data extremes.\n if (tickAmount < 4) {\n this.finalTickAmt = tickAmount;\n tickAmount = 5;\n }\n this.tickAmount = tickAmount;\n };\n /**\n * When using multiple axes, adjust the number of ticks to match the highest\n * number of ticks in that group.\n *\n * @private\n * @function Highcharts.Axis#adjustTickAmount\n */\n Axis.prototype.adjustTickAmount = function () {\n var axis = this,\n finalTickAmt = axis.finalTickAmt,\n max = axis.max,\n min = axis.min,\n options = axis.options,\n tickPositions = axis.tickPositions,\n tickAmount = axis.tickAmount,\n thresholdAlignment = axis.thresholdAlignment,\n currentTickAmount = tickPositions && tickPositions.length,\n threshold = pick(axis.threshold,\n axis.softThreshold ? 0 : null);\n var len,\n i,\n tickInterval = axis.tickInterval,\n thresholdTickIndex;\n var \n // Extend the tickPositions by appending a position\n append = function () { return tickPositions.push(correctFloat(tickPositions[tickPositions.length - 1] +\n tickInterval)); }, \n // Extend the tickPositions by prepending a position\n prepend = function () { return tickPositions.unshift(correctFloat(tickPositions[0] - tickInterval)); };\n // If `thresholdAlignment` is a number, it means the `alignThresholds`\n // option is true. The `thresholdAlignment` is a scalar value between 0\n // and 1 for where the threshold should be relative to `axis.min` and\n // `axis.max`. Now that we know the tick amount, convert this to the\n // tick index. Unless `thresholdAlignment` is exactly 0 or 1, avoid the\n // first or last tick because that would lead to series being clipped.\n if (isNumber(thresholdAlignment)) {\n thresholdTickIndex = thresholdAlignment < 0.5 ?\n Math.ceil(thresholdAlignment * (tickAmount - 1)) :\n Math.floor(thresholdAlignment * (tickAmount - 1));\n if (options.reversed) {\n thresholdTickIndex = tickAmount - 1 - thresholdTickIndex;\n }\n }\n if (axis.hasData() && isNumber(min) && isNumber(max)) { // #14769\n // Adjust extremes and translation to the modified tick positions\n var adjustExtremes = function () {\n axis.transA *= (currentTickAmount - 1) / (tickAmount - 1);\n // Do not crop when ticks are not extremes (#9841)\n axis.min = options.startOnTick ?\n tickPositions[0] :\n Math.min(min, tickPositions[0]);\n axis.max = options.endOnTick ?\n tickPositions[tickPositions.length - 1] :\n Math.max(max, tickPositions[tickPositions.length - 1]);\n };\n // When the axis is subject to the alignThresholds option. Use\n // axis.threshold because the local threshold includes the\n // `softThreshold`.\n if (isNumber(thresholdTickIndex) && isNumber(axis.threshold)) {\n // Throw away the previously computed tickPositions and start\n // from scratch with only the threshold itself, then add ticks\n // below the threshold first, then fill up above the threshold.\n // If we are not able to fill up to axis.max, double the\n // tickInterval and run again.\n while (tickPositions[thresholdTickIndex] !== threshold ||\n tickPositions.length !== tickAmount ||\n tickPositions[0] > min ||\n tickPositions[tickPositions.length - 1] < max) {\n tickPositions.length = 0;\n tickPositions.push(axis.threshold);\n while (tickPositions.length < tickAmount) {\n if (\n // Start by prepending positions until the threshold\n // is at the required index...\n tickPositions[thresholdTickIndex] === void 0 ||\n tickPositions[thresholdTickIndex] > axis.threshold) {\n prepend();\n }\n else {\n // ... then append positions until we have the\n // required length\n append();\n }\n }\n // Safety vent\n if (tickInterval > axis.tickInterval * 8) {\n break;\n }\n tickInterval *= 2;\n }\n adjustExtremes();\n }\n else if (currentTickAmount < tickAmount) {\n while (tickPositions.length < tickAmount) {\n // Extend evenly for both sides unless we're on the\n // threshold (#3965)\n if (tickPositions.length % 2 || min === threshold) {\n append();\n }\n else {\n prepend();\n }\n }\n adjustExtremes();\n }\n // The finalTickAmt property is set in getTickAmount\n if (defined(finalTickAmt)) {\n i = len = tickPositions.length;\n while (i--) {\n if (\n // Remove every other tick\n (finalTickAmt === 3 && i % 2 === 1) ||\n // Remove all but first and last\n (finalTickAmt <= 2 && i > 0 && i < len - 1)) {\n tickPositions.splice(i, 1);\n }\n }\n axis.finalTickAmt = void 0;\n }\n }\n };\n /**\n * Set the scale based on data min and max, user set min and max or options.\n *\n * @private\n * @function Highcharts.Axis#setScale\n *\n * @emits Highcharts.Axis#event:afterSetScale\n */\n Axis.prototype.setScale = function () {\n var axis = this;\n var isDirtyData = false,\n isXAxisDirty = false;\n axis.series.forEach(function (series) {\n isDirtyData = isDirtyData || series.isDirtyData || series.isDirty;\n // When x axis is dirty, we need new data extremes for y as\n // well:\n isXAxisDirty = (isXAxisDirty ||\n (series.xAxis && series.xAxis.isDirty) ||\n false);\n });\n // set the new axisLength\n axis.setAxisSize();\n var isDirtyAxisLength = axis.len !== (axis.old && axis.old.len);\n // do we really need to go through all this?\n if (isDirtyAxisLength ||\n isDirtyData ||\n isXAxisDirty ||\n axis.isLinked ||\n axis.forceRedraw ||\n axis.userMin !== (axis.old && axis.old.userMin) ||\n axis.userMax !== (axis.old && axis.old.userMax) ||\n axis.alignToOthers()) {\n if (axis.stacking) {\n axis.stacking.resetStacks();\n }\n axis.forceRedraw = false;\n // get data extremes if needed\n axis.getSeriesExtremes();\n // get fixed positions based on tickInterval\n axis.setTickInterval();\n // Mark as dirty if it is not already set to dirty and extremes have\n // changed. #595.\n if (!axis.isDirty) {\n axis.isDirty =\n isDirtyAxisLength ||\n axis.min !== (axis.old && axis.old.min) ||\n axis.max !== (axis.old && axis.old.max);\n }\n }\n else if (axis.stacking) {\n axis.stacking.cleanStacks();\n }\n // Recalculate panning state object, when the data\n // has changed. It is required when vertical panning is enabled.\n if (isDirtyData && axis.panningState) {\n axis.panningState.isDirty = true;\n }\n fireEvent(this, 'afterSetScale');\n };\n /**\n * Set the minimum and maximum of the axes after render time. If the\n * `startOnTick` and `endOnTick` options are true, the minimum and maximum\n * values are rounded off to the nearest tick. To prevent this, these\n * options can be set to false before calling setExtremes. Also, setExtremes\n * will not allow a range lower than the `minRange` option, which by default\n * is the range of five points.\n *\n * @sample highcharts/members/axis-setextremes/\n * Set extremes from a button\n * @sample highcharts/members/axis-setextremes-datetime/\n * Set extremes on a datetime axis\n * @sample highcharts/members/axis-setextremes-off-ticks/\n * Set extremes off ticks\n * @sample stock/members/axis-setextremes/\n * Set extremes in Highcharts Stock\n *\n * @function Highcharts.Axis#setExtremes\n *\n * @param {number} [newMin]\n * The new minimum value.\n *\n * @param {number} [newMax]\n * The new maximum value.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or wait for an explicit call to\n * {@link Highcharts.Chart#redraw}\n *\n * @param {boolean|Partial} [animation=true]\n * Enable or modify animations.\n *\n * @param {*} [eventArguments]\n * Arguments to be accessed in event handler.\n *\n * @emits Highcharts.Axis#event:setExtremes\n */\n Axis.prototype.setExtremes = function (newMin, newMax, redraw, animation, eventArguments) {\n var axis = this,\n chart = axis.chart;\n redraw = pick(redraw, true); // defaults to true\n axis.series.forEach(function (serie) {\n delete serie.kdTree;\n });\n // Extend the arguments with min and max\n eventArguments = extend(eventArguments, {\n min: newMin,\n max: newMax\n });\n // Fire the event\n fireEvent(axis, 'setExtremes', eventArguments, function () {\n axis.userMin = newMin;\n axis.userMax = newMax;\n axis.eventArgs = eventArguments;\n if (redraw) {\n chart.redraw(animation);\n }\n });\n };\n /**\n * Overridable method for zooming chart. Pulled out in a separate method to\n * allow overriding in stock charts.\n *\n * @private\n * @function Highcharts.Axis#zoom\n */\n Axis.prototype.zoom = function (newMin, newMax) {\n var axis = this,\n dataMin = this.dataMin,\n dataMax = this.dataMax,\n options = this.options,\n min = Math.min(dataMin,\n pick(options.min,\n dataMin)),\n max = Math.max(dataMax,\n pick(options.max,\n dataMax)),\n evt = {\n newMin: newMin,\n newMax: newMax\n };\n fireEvent(this, 'zoom', evt, function (e) {\n // Use e.newMin and e.newMax - event handlers may have altered them\n var newMin = e.newMin,\n newMax = e.newMax;\n if (newMin !== axis.min || newMax !== axis.max) { // #5790\n // Prevent pinch zooming out of range. Check for defined is for\n // #1946. #1734.\n if (!axis.allowZoomOutside) {\n // #6014, sometimes newMax will be smaller than min (or\n // newMin will be larger than max).\n if (defined(dataMin)) {\n if (newMin < min) {\n newMin = min;\n }\n if (newMin > max) {\n newMin = max;\n }\n }\n if (defined(dataMax)) {\n if (newMax < min) {\n newMax = min;\n }\n if (newMax > max) {\n newMax = max;\n }\n }\n }\n // In full view, displaying the reset zoom button is not\n // required\n axis.displayBtn = (typeof newMin !== 'undefined' ||\n typeof newMax !== 'undefined');\n // Do it\n axis.setExtremes(newMin, newMax, false, void 0, { trigger: 'zoom' });\n }\n e.zoomed = true;\n });\n return evt.zoomed;\n };\n /**\n * Update the axis metrics.\n *\n * @private\n * @function Highcharts.Axis#setAxisSize\n */\n Axis.prototype.setAxisSize = function () {\n var chart = this.chart,\n options = this.options, \n // [top, right, bottom, left]\n offsets = options.offsets || [0, 0, 0, 0],\n horiz = this.horiz, \n // Check for percentage based input values. Rounding fixes problems\n // with column overflow and plot line filtering (#4898, #4899)\n width = this.width = Math.round(relativeLength(pick(options.width,\n chart.plotWidth - offsets[3] + offsets[1]),\n chart.plotWidth)),\n height = this.height = Math.round(relativeLength(pick(options.height,\n chart.plotHeight - offsets[0] + offsets[2]),\n chart.plotHeight)),\n top = this.top = Math.round(relativeLength(pick(options.top,\n chart.plotTop + offsets[0]),\n chart.plotHeight,\n chart.plotTop)),\n left = this.left = Math.round(relativeLength(pick(options.left,\n chart.plotLeft + offsets[3]),\n chart.plotWidth,\n chart.plotLeft));\n // Expose basic values to use in Series object and navigator\n this.bottom = chart.chartHeight - height - top;\n this.right = chart.chartWidth - width - left;\n // Direction agnostic properties\n this.len = Math.max(horiz ? width : height, 0); // Math.max fixes #905\n this.pos = horiz ? left : top; // distance from SVG origin\n };\n /**\n * Get the current extremes for the axis.\n *\n * @sample highcharts/members/axis-getextremes/\n * Report extremes by click on a button\n *\n * @function Highcharts.Axis#getExtremes\n *\n * @return {Highcharts.ExtremesObject}\n * An object containing extremes information.\n */\n Axis.prototype.getExtremes = function () {\n var axis = this,\n log = axis.logarithmic;\n return {\n min: log ?\n correctFloat(log.lin2log(axis.min)) :\n axis.min,\n max: log ?\n correctFloat(log.lin2log(axis.max)) :\n axis.max,\n dataMin: axis.dataMin,\n dataMax: axis.dataMax,\n userMin: axis.userMin,\n userMax: axis.userMax\n };\n };\n /**\n * Get the zero plane either based on zero or on the min or max value.\n * Used in bar and area plots.\n *\n * @function Highcharts.Axis#getThreshold\n *\n * @param {number} threshold\n * The threshold in axis values.\n *\n * @return {number}\n * The translated threshold position in terms of pixels, and corrected to\n * stay within the axis bounds.\n */\n Axis.prototype.getThreshold = function (threshold) {\n var axis = this,\n log = axis.logarithmic,\n realMin = log ? log.lin2log(axis.min) : axis.min,\n realMax = log ? log.lin2log(axis.max) : axis.max;\n if (threshold === null || threshold === -Infinity) {\n threshold = realMin;\n }\n else if (threshold === Infinity) {\n threshold = realMax;\n }\n else if (realMin > threshold) {\n threshold = realMin;\n }\n else if (realMax < threshold) {\n threshold = realMax;\n }\n return axis.translate(threshold, 0, 1, 0, 1);\n };\n /**\n * Compute auto alignment for the axis label based on which side the axis is\n * on and the given rotation for the label.\n *\n * @private\n * @function Highcharts.Axis#autoLabelAlign\n *\n * @param {number} rotation\n * The rotation in degrees as set by either the `rotation` or `autoRotation`\n * options.\n *\n * @return {Highcharts.AlignValue}\n * Can be `\"center\"`, `\"left\"` or `\"right\"`.\n */\n Axis.prototype.autoLabelAlign = function (rotation) {\n var angle = (pick(rotation, 0) - (this.side * 90) + 720) % 360,\n evt = { align: 'center' };\n fireEvent(this, 'autoLabelAlign', evt, function (e) {\n if (angle > 15 && angle < 165) {\n e.align = 'right';\n }\n else if (angle > 195 && angle < 345) {\n e.align = 'left';\n }\n });\n return evt.align;\n };\n /**\n * Get the tick length and width for the axis based on axis options.\n *\n * @private\n * @function Highcharts.Axis#tickSize\n *\n * @param {string} [prefix]\n * 'tick' or 'minorTick'\n *\n * @return {Array|undefined}\n * An array of tickLength and tickWidth\n */\n Axis.prototype.tickSize = function (prefix) {\n var options = this.options,\n tickWidth = pick(options[prefix === 'tick' ? 'tickWidth' : 'minorTickWidth'], \n // Default to 1 on linear and datetime X axes\n prefix === 'tick' && this.isXAxis && !this.categories ? 1 : 0);\n var tickLength = options[prefix === 'tick' ? 'tickLength' : 'minorTickLength'],\n tickSize;\n if (tickWidth && tickLength) {\n // Negate the length\n if (options[prefix + 'Position'] === 'inside') {\n tickLength = -tickLength;\n }\n tickSize = [tickLength, tickWidth];\n }\n var e = { tickSize: tickSize };\n fireEvent(this, 'afterTickSize', e);\n return e.tickSize;\n };\n /**\n * Return the size of the labels.\n *\n * @private\n * @function Highcharts.Axis#labelMetrics\n */\n Axis.prototype.labelMetrics = function () {\n var index = this.tickPositions && this.tickPositions[0] || 0;\n return this.chart.renderer.fontMetrics(this.options.labels.style.fontSize, this.ticks[index] && this.ticks[index].label);\n };\n /**\n * Prevent the ticks from getting so close we can't draw the labels. On a\n * horizontal axis, this is handled by rotating the labels, removing ticks\n * and adding ellipsis. On a vertical axis remove ticks and add ellipsis.\n *\n * @private\n * @function Highcharts.Axis#unsquish\n */\n Axis.prototype.unsquish = function () {\n var labelOptions = this.options.labels,\n horiz = this.horiz,\n tickInterval = this.tickInterval,\n slotSize = this.len / (((this.categories ? 1 : 0) +\n this.max -\n this.min) /\n tickInterval),\n rotationOption = labelOptions.rotation,\n labelMetrics = this.labelMetrics(),\n range = Math.max(this.max - this.min, 0), \n // Return the multiple of tickInterval that is needed to avoid\n // collision\n getStep = function (spaceNeeded) {\n var step = spaceNeeded / (slotSize || 1);\n step = step > 1 ? Math.ceil(step) : 1;\n // Guard for very small or negative angles (#9835)\n if (step * tickInterval > range &&\n spaceNeeded !== Infinity &&\n slotSize !== Infinity &&\n range) {\n step = Math.ceil(range / tickInterval);\n }\n return correctFloat(step * tickInterval);\n };\n var newTickInterval = tickInterval,\n rotation,\n bestScore = Number.MAX_VALUE,\n autoRotation;\n if (horiz) {\n if (!labelOptions.staggerLines) {\n if (isNumber(rotationOption)) {\n autoRotation = [rotationOption];\n }\n else if (slotSize < labelOptions.autoRotationLimit) {\n autoRotation = labelOptions.autoRotation;\n }\n }\n if (autoRotation) {\n var step = void 0,\n score = void 0;\n // Loop over the given autoRotation options, and determine which\n // gives the best score. The best score is that with the lowest\n // number of steps and a rotation closest to horizontal.\n for (var _i = 0, autoRotation_1 = autoRotation; _i < autoRotation_1.length; _i++) {\n var rot = autoRotation_1[_i];\n if (rot === rotationOption ||\n (rot && rot >= -90 && rot <= 90)) { // #3891\n step = getStep(Math.abs(labelMetrics.h / Math.sin(deg2rad * rot)));\n score = step + Math.abs(rot / 360);\n if (score < bestScore) {\n bestScore = score;\n rotation = rot;\n newTickInterval = step;\n }\n }\n }\n }\n }\n else { // #4411\n newTickInterval = getStep(labelMetrics.h);\n }\n this.autoRotation = autoRotation;\n this.labelRotation = pick(rotation, isNumber(rotationOption) ? rotationOption : 0);\n return labelOptions.step ? tickInterval : newTickInterval;\n };\n /**\n * Get the general slot width for labels/categories on this axis. This may\n * change between the pre-render (from Axis.getOffset) and the final tick\n * rendering and placement.\n *\n * @private\n * @function Highcharts.Axis#getSlotWidth\n *\n * @param {Highcharts.Tick} [tick] Optionally, calculate the slot width\n * basing on tick label. It is used in highcharts-3d module, where the slots\n * has different widths depending on perspective angles.\n *\n * @return {number}\n * The pixel width allocated to each axis label.\n */\n Axis.prototype.getSlotWidth = function (tick) {\n // #5086, #1580, #1931\n var chart = this.chart,\n horiz = this.horiz,\n labelOptions = this.options.labels,\n slotCount = Math.max(this.tickPositions.length - (this.categories ? 0 : 1), 1),\n marginLeft = chart.margin[3];\n // Used by grid axis\n if (tick && isNumber(tick.slotWidth)) { // #13221, can be 0\n return tick.slotWidth;\n }\n if (horiz && labelOptions.step < 2) {\n if (labelOptions.rotation) { // #4415\n return 0;\n }\n return ((this.staggerLines || 1) * this.len) / slotCount;\n }\n if (!horiz) {\n // #7028\n var cssWidth = labelOptions.style.width;\n if (cssWidth !== void 0) {\n return parseInt(String(cssWidth), 10);\n }\n if (marginLeft) {\n return marginLeft - chart.spacing[3];\n }\n }\n // Last resort, a fraction of the available size\n return chart.chartWidth * 0.33;\n };\n /**\n * Render the axis labels and determine whether ellipsis or rotation need to\n * be applied.\n *\n * @private\n * @function Highcharts.Axis#renderUnsquish\n */\n Axis.prototype.renderUnsquish = function () {\n var chart = this.chart,\n renderer = chart.renderer,\n tickPositions = this.tickPositions,\n ticks = this.ticks,\n labelOptions = this.options.labels,\n labelStyleOptions = labelOptions.style,\n horiz = this.horiz,\n slotWidth = this.getSlotWidth(),\n innerWidth = Math.max(1,\n Math.round(slotWidth - 2 * labelOptions.padding)),\n attr = {},\n labelMetrics = this.labelMetrics(),\n textOverflowOption = labelStyleOptions.textOverflow;\n var commonWidth,\n commonTextOverflow,\n maxLabelLength = 0,\n label,\n i,\n pos;\n // Set rotation option unless it is \"auto\", like in gauges\n if (!isString(labelOptions.rotation)) {\n // #4443\n attr.rotation = labelOptions.rotation || 0;\n }\n // Get the longest label length\n tickPositions.forEach(function (tickPosition) {\n var tick = ticks[tickPosition];\n // Replace label - sorting animation\n if (tick.movedLabel) {\n tick.replaceMovedLabel();\n }\n if (tick &&\n tick.label &&\n tick.label.textPxLength > maxLabelLength) {\n maxLabelLength = tick.label.textPxLength;\n }\n });\n this.maxLabelLength = maxLabelLength;\n // Handle auto rotation on horizontal axis\n if (this.autoRotation) {\n // Apply rotation only if the label is too wide for the slot, and\n // the label is wider than its height.\n if (maxLabelLength > innerWidth &&\n maxLabelLength > labelMetrics.h) {\n attr.rotation = this.labelRotation;\n }\n else {\n this.labelRotation = 0;\n }\n // Handle word-wrap or ellipsis on vertical axis\n }\n else if (slotWidth) {\n // For word-wrap or ellipsis\n commonWidth = innerWidth;\n if (!textOverflowOption) {\n commonTextOverflow = 'clip';\n // On vertical axis, only allow word wrap if there is room\n // for more lines.\n i = tickPositions.length;\n while (!horiz && i--) {\n pos = tickPositions[i];\n label = ticks[pos].label;\n if (label) {\n // Reset ellipsis in order to get the correct\n // bounding box (#4070)\n if (label.styles &&\n label.styles.textOverflow === 'ellipsis') {\n label.css({ textOverflow: 'clip' });\n // Set the correct width in order to read\n // the bounding box height (#4678, #5034)\n }\n else if (label.textPxLength > slotWidth) {\n label.css({ width: slotWidth + 'px' });\n }\n if (label.getBBox().height > (this.len / tickPositions.length -\n (labelMetrics.h - labelMetrics.f))) {\n label.specificTextOverflow = 'ellipsis';\n }\n }\n }\n }\n }\n // Add ellipsis if the label length is significantly longer than ideal\n if (attr.rotation) {\n commonWidth = (maxLabelLength > chart.chartHeight * 0.5 ?\n chart.chartHeight * 0.33 :\n maxLabelLength);\n if (!textOverflowOption) {\n commonTextOverflow = 'ellipsis';\n }\n }\n // Set the explicit or automatic label alignment\n this.labelAlign = labelOptions.align ||\n this.autoLabelAlign(this.labelRotation);\n if (this.labelAlign) {\n attr.align = this.labelAlign;\n }\n // Apply general and specific CSS\n tickPositions.forEach(function (pos) {\n var tick = ticks[pos],\n label = tick && tick.label,\n widthOption = labelStyleOptions.width,\n css = {};\n if (label) {\n // This needs to go before the CSS in old IE (#4502)\n label.attr(attr);\n if (tick.shortenLabel) {\n tick.shortenLabel();\n }\n else if (commonWidth &&\n !widthOption &&\n // Setting width in this case messes with the bounding box\n // (#7975)\n labelStyleOptions.whiteSpace !== 'nowrap' &&\n (\n // Speed optimizing, #7656\n commonWidth < label.textPxLength ||\n // Resetting CSS, #4928\n label.element.tagName === 'SPAN')) {\n css.width = commonWidth + 'px';\n if (!textOverflowOption) {\n css.textOverflow = (label.specificTextOverflow ||\n commonTextOverflow);\n }\n label.css(css);\n // Reset previously shortened label (#8210)\n }\n else if (label.styles &&\n label.styles.width &&\n !css.width &&\n !widthOption) {\n label.css({ width: null });\n }\n delete label.specificTextOverflow;\n tick.rotation = attr.rotation;\n }\n }, this);\n // Note: Why is this not part of getLabelPosition?\n this.tickRotCorr = renderer.rotCorr(labelMetrics.b, this.labelRotation || 0, this.side !== 0);\n };\n /**\n * Return true if the axis has associated data.\n *\n * @function Highcharts.Axis#hasData\n *\n * @return {boolean}\n * True if the axis has associated visible series and those series have\n * either valid data points or explicit `min` and `max` settings.\n */\n Axis.prototype.hasData = function () {\n return this.series.some(function (s) {\n return s.hasData();\n }) ||\n (this.options.showEmpty &&\n defined(this.min) &&\n defined(this.max));\n };\n /**\n * Adds the title defined in axis.options.title.\n *\n * @function Highcharts.Axis#addTitle\n *\n * @param {boolean} [display]\n * Whether or not to display the title.\n */\n Axis.prototype.addTitle = function (display) {\n var axis = this,\n renderer = axis.chart.renderer,\n horiz = axis.horiz,\n opposite = axis.opposite,\n options = axis.options,\n axisTitleOptions = options.title,\n styledMode = axis.chart.styledMode;\n var textAlign;\n if (!axis.axisTitle) {\n textAlign = axisTitleOptions.textAlign;\n if (!textAlign) {\n textAlign = (horiz ? {\n low: 'left',\n middle: 'center',\n high: 'right'\n } : {\n low: opposite ? 'right' : 'left',\n middle: 'center',\n high: opposite ? 'left' : 'right'\n })[axisTitleOptions.align];\n }\n axis.axisTitle = renderer\n .text(axisTitleOptions.text || '', 0, 0, axisTitleOptions.useHTML)\n .attr({\n zIndex: 7,\n rotation: axisTitleOptions.rotation,\n align: textAlign\n })\n .addClass('highcharts-axis-title');\n // #7814, don't mutate style option\n if (!styledMode) {\n axis.axisTitle.css(merge(axisTitleOptions.style));\n }\n axis.axisTitle.add(axis.axisGroup);\n axis.axisTitle.isNew = true;\n }\n // Max width defaults to the length of the axis\n if (!styledMode &&\n !axisTitleOptions.style.width &&\n !axis.isRadial) {\n axis.axisTitle.css({\n width: axis.len + 'px'\n });\n }\n // hide or show the title depending on whether showEmpty is set\n axis.axisTitle[display ? 'show' : 'hide'](display);\n };\n /**\n * Generates a tick for initial positioning.\n *\n * @private\n * @function Highcharts.Axis#generateTick\n *\n * @param {number} pos\n * The tick position in axis values.\n *\n * @param {number} [i]\n * The index of the tick in {@link Axis.tickPositions}.\n */\n Axis.prototype.generateTick = function (pos) {\n var axis = this,\n ticks = axis.ticks;\n if (!ticks[pos]) {\n ticks[pos] = new Tick(axis, pos);\n }\n else {\n ticks[pos].addLabel(); // update labels depending on tick interval\n }\n };\n /**\n * Render the tick labels to a preliminary position to get their sizes\n *\n * @private\n * @function Highcharts.Axis#getOffset\n *\n * @emits Highcharts.Axis#event:afterGetOffset\n */\n Axis.prototype.getOffset = function () {\n var _this = this;\n var axis = this,\n chart = axis.chart,\n horiz = axis.horiz,\n options = axis.options,\n side = axis.side,\n ticks = axis.ticks,\n tickPositions = axis.tickPositions,\n coll = axis.coll,\n axisParent = axis.axisParent // Used in color axis\n ,\n renderer = chart.renderer,\n invertedSide = (chart.inverted && !axis.isZAxis ?\n [1, 0, 3, 2][side] :\n side),\n hasData = axis.hasData(),\n axisTitleOptions = options.title,\n labelOptions = options.labels,\n axisOffset = chart.axisOffset,\n clipOffset = chart.clipOffset,\n directionFactor = [-1, 1, 1, -1][side],\n className = options.className;\n var showAxis,\n titleOffset = 0,\n titleOffsetOption,\n titleMargin = 0,\n labelOffset = 0, // reset\n labelOffsetPadded,\n lineHeightCorrection;\n // For reuse in Axis.render\n axis.showAxis = showAxis = hasData || options.showEmpty;\n // Set/reset staggerLines\n axis.staggerLines = (axis.horiz && labelOptions.staggerLines) || void 0;\n // Create the axisGroup and gridGroup elements on first iteration\n if (!axis.axisGroup) {\n var createGroup = function (name, suffix, zIndex) { return renderer.g(name)\n .attr({ zIndex: zIndex })\n .addClass(\"highcharts-\".concat(coll.toLowerCase()).concat(suffix, \" \") +\n (_this.isRadial ? \"highcharts-radial-axis\".concat(suffix, \" \") : '') +\n (className || ''))\n .add(axisParent); };\n axis.gridGroup = createGroup('grid', '-grid', options.gridZIndex);\n axis.axisGroup = createGroup('axis', '', options.zIndex);\n axis.labelGroup = createGroup('axis-labels', '-labels', labelOptions.zIndex);\n }\n if (hasData || axis.isLinked) {\n // Generate ticks\n tickPositions.forEach(function (pos) {\n // i is not used here, but may be used in overrides\n axis.generateTick(pos);\n });\n axis.renderUnsquish();\n // Left side must be align: right and right side must\n // have align: left for labels\n axis.reserveSpaceDefault = (side === 0 ||\n side === 2 ||\n { 1: 'left', 3: 'right' }[side] === axis.labelAlign);\n if (pick(labelOptions.reserveSpace, axis.labelAlign === 'center' ? true : null, axis.reserveSpaceDefault)) {\n tickPositions.forEach(function (pos) {\n // get the highest offset\n labelOffset = Math.max(ticks[pos].getLabelSize(), labelOffset);\n });\n }\n if (axis.staggerLines) {\n labelOffset *= axis.staggerLines;\n }\n axis.labelOffset = labelOffset * (axis.opposite ? -1 : 1);\n }\n else { // doesn't have data\n objectEach(ticks, function (tick, n) {\n tick.destroy();\n delete ticks[n];\n });\n }\n if (axisTitleOptions &&\n axisTitleOptions.text &&\n axisTitleOptions.enabled !== false) {\n axis.addTitle(showAxis);\n if (showAxis && axisTitleOptions.reserveSpace !== false) {\n axis.titleOffset = titleOffset =\n axis.axisTitle.getBBox()[horiz ? 'height' : 'width'];\n titleOffsetOption = axisTitleOptions.offset;\n titleMargin = defined(titleOffsetOption) ?\n 0 :\n pick(axisTitleOptions.margin, horiz ? 5 : 10);\n }\n }\n // Render the axis line\n axis.renderLine();\n // handle automatic or user set offset\n axis.offset = directionFactor * pick(options.offset, axisOffset[side] ? axisOffset[side] + (options.margin || 0) : 0);\n axis.tickRotCorr = axis.tickRotCorr || { x: 0, y: 0 }; // polar\n if (side === 0) {\n lineHeightCorrection = -axis.labelMetrics().h;\n }\n else if (side === 2) {\n lineHeightCorrection = axis.tickRotCorr.y;\n }\n else {\n lineHeightCorrection = 0;\n }\n // Find the padded label offset\n labelOffsetPadded = Math.abs(labelOffset) + titleMargin;\n if (labelOffset) {\n labelOffsetPadded -= lineHeightCorrection;\n labelOffsetPadded += directionFactor * (horiz ?\n pick(labelOptions.y, axis.tickRotCorr.y + directionFactor * 8) :\n labelOptions.x);\n }\n axis.axisTitleMargin = pick(titleOffsetOption, labelOffsetPadded);\n if (axis.getMaxLabelDimensions) {\n axis.maxLabelDimensions = axis.getMaxLabelDimensions(ticks, tickPositions);\n }\n // Due to GridAxis.tickSize, tickSize should be calculated after ticks\n // has rendered.\n if (coll !== 'colorAxis') {\n var tickSize = this.tickSize('tick');\n axisOffset[side] = Math.max(axisOffset[side], (axis.axisTitleMargin || 0) + titleOffset +\n directionFactor * axis.offset, labelOffsetPadded, // #3027\n tickPositions && tickPositions.length && tickSize ?\n tickSize[0] + directionFactor * axis.offset :\n 0 // #4866\n );\n // Decide the clipping needed to keep the graph inside\n // the plot area and axis lines\n var clip = !axis.axisLine || options.offset ?\n 0 :\n // #4308, #4371:\n Math.floor(axis.axisLine.strokeWidth() / 2) * 2;\n clipOffset[invertedSide] =\n Math.max(clipOffset[invertedSide], clip);\n }\n fireEvent(this, 'afterGetOffset');\n };\n /**\n * Internal function to get the path for the axis line. Extended for polar\n * charts.\n *\n * @function Highcharts.Axis#getLinePath\n *\n * @param {number} lineWidth\n * The line width in pixels.\n *\n * @return {Highcharts.SVGPathArray}\n * The SVG path definition in array form.\n */\n Axis.prototype.getLinePath = function (lineWidth) {\n var chart = this.chart,\n opposite = this.opposite,\n offset = this.offset,\n horiz = this.horiz,\n lineLeft = this.left + (opposite ? this.width : 0) + offset,\n lineTop = chart.chartHeight - this.bottom -\n (opposite ? this.height : 0) + offset;\n if (opposite) {\n lineWidth *= -1; // crispify the other way - #1480, #1687\n }\n return chart.renderer\n .crispLine([\n [\n 'M',\n horiz ?\n this.left :\n lineLeft,\n horiz ?\n lineTop :\n this.top\n ],\n [\n 'L',\n horiz ?\n chart.chartWidth - this.right :\n lineLeft,\n horiz ?\n lineTop :\n chart.chartHeight - this.bottom\n ]\n ], lineWidth);\n };\n /**\n * Render the axis line. Called internally when rendering and redrawing the\n * axis.\n *\n * @function Highcharts.Axis#renderLine\n */\n Axis.prototype.renderLine = function () {\n if (!this.axisLine) {\n this.axisLine = this.chart.renderer.path()\n .addClass('highcharts-axis-line')\n .add(this.axisGroup);\n if (!this.chart.styledMode) {\n this.axisLine.attr({\n stroke: this.options.lineColor,\n 'stroke-width': this.options.lineWidth,\n zIndex: 7\n });\n }\n }\n };\n /**\n * Position the axis title.\n *\n * @private\n * @function Highcharts.Axis#getTitlePosition\n *\n * @return {Highcharts.PositionObject}\n * X and Y positions for the title.\n */\n Axis.prototype.getTitlePosition = function () {\n // compute anchor points for each of the title align options\n var horiz = this.horiz,\n axisLeft = this.left,\n axisTop = this.top,\n axisLength = this.len,\n axisTitleOptions = this.options.title,\n margin = horiz ? axisLeft : axisTop,\n opposite = this.opposite,\n offset = this.offset,\n xOption = axisTitleOptions.x,\n yOption = axisTitleOptions.y,\n axisTitle = this.axisTitle,\n fontMetrics = this.chart.renderer.fontMetrics(axisTitleOptions.style.fontSize,\n axisTitle), \n // The part of a multiline text that is below the baseline of the\n // first line. Subtract 1 to preserve pixel-perfectness from the\n // old behaviour (v5.0.12), where only one line was allowed.\n textHeightOvershoot = axisTitle ? Math.max(axisTitle.getBBox(false, 0).height - fontMetrics.h - 1, 0) : 0, \n // the position in the length direction of the axis\n alongAxis = ({\n low: margin + (horiz ? 0 : axisLength),\n middle: margin + axisLength / 2,\n high: margin + (horiz ? axisLength : 0)\n })[axisTitleOptions.align], \n // the position in the perpendicular direction of the axis\n offAxis = (horiz ? axisTop + this.height : axisLeft) +\n (horiz ? 1 : -1) * // horizontal axis reverses the margin\n (opposite ? -1 : 1) * // so does opposite axes\n (this.axisTitleMargin || 0) +\n [\n -textHeightOvershoot,\n textHeightOvershoot,\n fontMetrics.f,\n -textHeightOvershoot // left\n ][this.side],\n titlePosition = {\n x: horiz ?\n alongAxis + xOption :\n offAxis + (opposite ? this.width : 0) + offset + xOption,\n y: horiz ?\n offAxis + yOption - (opposite ? this.height : 0) + offset :\n alongAxis + yOption\n };\n fireEvent(this, 'afterGetTitlePosition', { titlePosition: titlePosition });\n return titlePosition;\n };\n /**\n * Render a minor tick into the given position. If a minor tick already\n * exists in this position, move it.\n *\n * @function Highcharts.Axis#renderMinorTick\n *\n * @param {number} pos\n * The position in axis values.\n *\n * @param {boolean} slideIn\n * Whether the tick should animate in from last computed position\n */\n Axis.prototype.renderMinorTick = function (pos, slideIn) {\n var axis = this;\n var minorTicks = axis.minorTicks;\n if (!minorTicks[pos]) {\n minorTicks[pos] = new Tick(axis, pos, 'minor');\n }\n // Render new ticks in old position\n if (slideIn && minorTicks[pos].isNew) {\n minorTicks[pos].render(null, true);\n }\n minorTicks[pos].render(null, false, 1);\n };\n /**\n * Render a major tick into the given position. If a tick already exists\n * in this position, move it.\n *\n * @function Highcharts.Axis#renderTick\n *\n * @param {number} pos\n * The position in axis values.\n *\n * @param {number} i\n * The tick index.\n *\n * @param {boolean} slideIn\n * Whether the tick should animate in from last computed position\n */\n Axis.prototype.renderTick = function (pos, i, slideIn) {\n var axis = this,\n isLinked = axis.isLinked,\n ticks = axis.ticks;\n // Linked axes need an extra check to find out if\n if (!isLinked ||\n (pos >= axis.min && pos <= axis.max) ||\n (axis.grid && axis.grid.isColumn)) {\n if (!ticks[pos]) {\n ticks[pos] = new Tick(axis, pos);\n }\n // NOTE this seems like overkill. Could be handled in tick.render by\n // setting old position in attr, then set new position in animate.\n // render new ticks in old position\n if (slideIn && ticks[pos].isNew) {\n // Start with negative opacity so that it is visible from\n // halfway into the animation\n ticks[pos].render(i, true, -1);\n }\n ticks[pos].render(i);\n }\n };\n /**\n * Render the axis.\n *\n * @private\n * @function Highcharts.Axis#render\n *\n * @emits Highcharts.Axis#event:afterRender\n */\n Axis.prototype.render = function () {\n var axis = this,\n chart = axis.chart,\n log = axis.logarithmic,\n renderer = chart.renderer,\n options = axis.options,\n isLinked = axis.isLinked,\n tickPositions = axis.tickPositions,\n axisTitle = axis.axisTitle,\n ticks = axis.ticks,\n minorTicks = axis.minorTicks,\n alternateBands = axis.alternateBands,\n stackLabelOptions = options.stackLabels,\n alternateGridColor = options.alternateGridColor,\n tickmarkOffset = axis.tickmarkOffset,\n axisLine = axis.axisLine,\n showAxis = axis.showAxis,\n animation = animObject(renderer.globalAnimation);\n var from,\n to;\n // Reset\n axis.labelEdge.length = 0;\n axis.overlap = false;\n // Mark all elements inActive before we go over and mark the active ones\n [ticks, minorTicks, alternateBands].forEach(function (coll) {\n objectEach(coll, function (tick) {\n tick.isActive = false;\n });\n });\n // If the series has data draw the ticks. Else only the line and title\n if (axis.hasData() || isLinked) {\n var slideInTicks_1 = axis.chart.hasRendered &&\n axis.old && isNumber(axis.old.min);\n // minor ticks\n if (axis.minorTickInterval && !axis.categories) {\n axis.getMinorTickPositions().forEach(function (pos) {\n axis.renderMinorTick(pos, slideInTicks_1);\n });\n }\n // Major ticks. Pull out the first item and render it last so that\n // we can get the position of the neighbour label. #808.\n if (tickPositions.length) { // #1300\n tickPositions.forEach(function (pos, i) {\n axis.renderTick(pos, i, slideInTicks_1);\n });\n // In a categorized axis, the tick marks are displayed\n // between labels. So we need to add a tick mark and\n // grid line at the left edge of the X axis.\n if (tickmarkOffset && (axis.min === 0 || axis.single)) {\n if (!ticks[-1]) {\n ticks[-1] = new Tick(axis, -1, null, true);\n }\n ticks[-1].render(-1);\n }\n }\n // alternate grid color\n if (alternateGridColor) {\n tickPositions.forEach(function (pos, i) {\n to = typeof tickPositions[i + 1] !== 'undefined' ?\n tickPositions[i + 1] + tickmarkOffset :\n axis.max - tickmarkOffset;\n if (i % 2 === 0 &&\n pos < axis.max &&\n to <= axis.max + (chart.polar ?\n -tickmarkOffset :\n tickmarkOffset)) { // #2248, #4660\n if (!alternateBands[pos]) {\n // Should be imported from PlotLineOrBand.js, but\n // the dependency cycle with axis is a problem\n alternateBands[pos] = new H.PlotLineOrBand(axis);\n }\n from = pos + tickmarkOffset; // #949\n alternateBands[pos].options = {\n from: log ? log.lin2log(from) : from,\n to: log ? log.lin2log(to) : to,\n color: alternateGridColor,\n className: 'highcharts-alternate-grid'\n };\n alternateBands[pos].render();\n alternateBands[pos].isActive = true;\n }\n });\n }\n // custom plot lines and bands\n if (!axis._addedPlotLB) { // only first time\n axis._addedPlotLB = true;\n (options.plotLines || [])\n .concat(options.plotBands || [])\n .forEach(function (plotLineOptions) {\n axis\n .addPlotBandOrLine(plotLineOptions);\n });\n }\n } // end if hasData\n // Remove inactive ticks\n [ticks, minorTicks, alternateBands].forEach(function (coll) {\n var forDestruction = [],\n delay = animation.duration,\n destroyInactiveItems = function () {\n var i = forDestruction.length;\n while (i--) {\n // When resizing rapidly, the same items\n // may be destroyed in different timeouts,\n // or the may be reactivated\n if (coll[forDestruction[i]] &&\n !coll[forDestruction[i]].isActive) {\n coll[forDestruction[i]].destroy();\n delete coll[forDestruction[i]];\n }\n }\n };\n objectEach(coll, function (tick, pos) {\n if (!tick.isActive) {\n // Render to zero opacity\n tick.render(pos, false, 0);\n tick.isActive = false;\n forDestruction.push(pos);\n }\n });\n // When the objects are finished fading out, destroy them\n syncTimeout(destroyInactiveItems, coll === alternateBands ||\n !chart.hasRendered ||\n !delay ?\n 0 :\n delay);\n });\n // Set the axis line path\n if (axisLine) {\n axisLine[axisLine.isPlaced ? 'animate' : 'attr']({\n d: this.getLinePath(axisLine.strokeWidth())\n });\n axisLine.isPlaced = true;\n // Show or hide the line depending on options.showEmpty\n axisLine[showAxis ? 'show' : 'hide'](showAxis);\n }\n if (axisTitle && showAxis) {\n var titleXy = axis.getTitlePosition();\n axisTitle[axisTitle.isNew ? 'attr' : 'animate'](titleXy);\n axisTitle.isNew = false;\n }\n // Stacked totals:\n if (stackLabelOptions && stackLabelOptions.enabled && axis.stacking) {\n axis.stacking.renderStackTotals();\n }\n // End stacked totals\n // Record old scaling for updating/animation\n axis.old = {\n len: axis.len,\n max: axis.max,\n min: axis.min,\n transA: axis.transA,\n userMax: axis.userMax,\n userMin: axis.userMin\n };\n axis.isDirty = false;\n fireEvent(this, 'afterRender');\n };\n /**\n * Redraw the axis to reflect changes in the data or axis extremes. Called\n * internally from Highcharts.Chart#redraw.\n *\n * @private\n * @function Highcharts.Axis#redraw\n */\n Axis.prototype.redraw = function () {\n if (this.visible) {\n // render the axis\n this.render();\n // move plot lines and bands\n this.plotLinesAndBands.forEach(function (plotLine) {\n plotLine.render();\n });\n }\n // mark associated series as dirty and ready for redraw\n this.series.forEach(function (series) {\n series.isDirty = true;\n });\n };\n /**\n * Returns an array of axis properties, that should be untouched during\n * reinitialization.\n *\n * @private\n * @function Highcharts.Axis#getKeepProps\n */\n Axis.prototype.getKeepProps = function () {\n return (this.keepProps || Axis.keepProps);\n };\n /**\n * Destroys an Axis instance. See {@link Axis#remove} for the API endpoint\n * to fully remove the axis.\n *\n * @private\n * @function Highcharts.Axis#destroy\n *\n * @param {boolean} [keepEvents]\n * Whether to preserve events, used internally in Axis.update.\n */\n Axis.prototype.destroy = function (keepEvents) {\n var axis = this,\n plotLinesAndBands = axis.plotLinesAndBands,\n eventOptions = this.eventOptions;\n fireEvent(this, 'destroy', { keepEvents: keepEvents });\n // Remove the events\n if (!keepEvents) {\n removeEvent(axis);\n }\n // Destroy collections\n [axis.ticks, axis.minorTicks, axis.alternateBands].forEach(function (coll) {\n destroyObjectProperties(coll);\n });\n if (plotLinesAndBands) {\n var i = plotLinesAndBands.length;\n while (i--) { // #1975\n plotLinesAndBands[i].destroy();\n }\n }\n // Destroy elements\n ['axisLine', 'axisTitle', 'axisGroup',\n 'gridGroup', 'labelGroup', 'cross', 'scrollbar'].forEach(function (prop) {\n if (axis[prop]) {\n axis[prop] = axis[prop].destroy();\n }\n });\n // Destroy each generated group for plotlines and plotbands\n for (var plotGroup in axis.plotLinesAndBandsGroups) { // eslint-disable-line guard-for-in\n axis.plotLinesAndBandsGroups[plotGroup] =\n axis.plotLinesAndBandsGroups[plotGroup].destroy();\n }\n // Delete all properties and fall back to the prototype.\n objectEach(axis, function (val, key) {\n if (axis.getKeepProps().indexOf(key) === -1) {\n delete axis[key];\n }\n });\n this.eventOptions = eventOptions;\n };\n /**\n * Internal function to draw a crosshair.\n *\n * @function Highcharts.Axis#drawCrosshair\n *\n * @param {Highcharts.PointerEventObject} [e]\n * The event arguments from the modified pointer event, extended with\n * `chartX` and `chartY`\n *\n * @param {Highcharts.Point} [point]\n * The Point object if the crosshair snaps to points.\n *\n * @emits Highcharts.Axis#event:afterDrawCrosshair\n * @emits Highcharts.Axis#event:drawCrosshair\n */\n Axis.prototype.drawCrosshair = function (e, point) {\n var options = this.crosshair,\n snap = pick(options && options.snap,\n true),\n chart = this.chart;\n var path,\n pos,\n categorized,\n graphic = this.cross,\n crossOptions;\n fireEvent(this, 'drawCrosshair', { e: e, point: point });\n // Use last available event when updating non-snapped crosshairs without\n // mouse interaction (#5287)\n if (!e) {\n e = this.cross && this.cross.e;\n }\n if (\n // Disabled in options\n !options ||\n // Snap\n ((defined(point) || !snap) === false)) {\n this.hideCrosshair();\n }\n else {\n // Get the path\n if (!snap) {\n pos = e &&\n (this.horiz ?\n e.chartX - this.pos :\n this.len - e.chartY + this.pos);\n }\n else if (defined(point)) {\n // #3834\n pos = pick(this.coll !== 'colorAxis' ?\n point.crosshairPos : // 3D axis extension\n null, this.isXAxis ?\n point.plotX :\n this.len - point.plotY);\n }\n if (defined(pos)) {\n crossOptions = {\n // value, only used on radial\n value: point && (this.isXAxis ?\n point.x :\n pick(point.stackY, point.y)),\n translatedValue: pos\n };\n if (chart.polar) {\n // Additional information required for crosshairs in\n // polar chart\n extend(crossOptions, {\n isCrosshair: true,\n chartX: e && e.chartX,\n chartY: e && e.chartY,\n point: point\n });\n }\n path = this.getPlotLinePath(crossOptions) ||\n null; // #3189\n }\n if (!defined(path)) {\n this.hideCrosshair();\n return;\n }\n categorized = this.categories && !this.isRadial;\n // Draw the cross\n if (!graphic) {\n this.cross = graphic = chart.renderer\n .path()\n .addClass('highcharts-crosshair highcharts-crosshair-' +\n (categorized ? 'category ' : 'thin ') +\n (options.className || ''))\n .attr({\n zIndex: pick(options.zIndex, 2)\n })\n .add();\n // Presentational attributes\n if (!chart.styledMode) {\n graphic.attr({\n stroke: options.color ||\n (categorized ?\n Color\n .parse(\"#ccd6eb\" /* Palette.highlightColor20 */)\n .setOpacity(0.25)\n .get() :\n \"#cccccc\" /* Palette.neutralColor20 */),\n 'stroke-width': pick(options.width, 1)\n }).css({\n 'pointer-events': 'none'\n });\n if (options.dashStyle) {\n graphic.attr({\n dashstyle: options.dashStyle\n });\n }\n }\n }\n graphic.show().attr({\n d: path\n });\n if (categorized && !options.width) {\n graphic.attr({\n 'stroke-width': this.transA\n });\n }\n this.cross.e = e;\n }\n fireEvent(this, 'afterDrawCrosshair', { e: e, point: point });\n };\n /**\n * Hide the crosshair if visible.\n *\n * @function Highcharts.Axis#hideCrosshair\n */\n Axis.prototype.hideCrosshair = function () {\n if (this.cross) {\n this.cross.hide();\n }\n fireEvent(this, 'afterHideCrosshair');\n };\n /**\n * Check whether the chart has vertical panning ('y' or 'xy' type).\n *\n * @private\n * @function Highcharts.Axis#hasVerticalPanning\n */\n Axis.prototype.hasVerticalPanning = function () {\n var panningOptions = this.chart.options.chart.panning;\n return Boolean(panningOptions &&\n panningOptions.enabled && // #14624\n /y/.test(panningOptions.type));\n };\n /**\n * Check whether the given value is a positive valid axis value.\n *\n * @private\n * @function Highcharts.Axis#validatePositiveValue\n *\n * @param {unknown} value\n * The axis value\n */\n Axis.prototype.validatePositiveValue = function (value) {\n return isNumber(value) && value > 0;\n };\n /**\n * Update an axis object with a new set of options. The options are merged\n * with the existing options, so only new or altered options need to be\n * specified.\n *\n * @sample highcharts/members/axis-update/\n * Axis update demo\n *\n * @function Highcharts.Axis#update\n *\n * @param {Highcharts.AxisOptions} options\n * The new options that will be merged in with existing options on the axis.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the axis is altered. If doing more\n * operations on the chart, it is a good idea to set redraw to false and\n * call {@link Chart#redraw} after.\n */\n Axis.prototype.update = function (options, redraw) {\n var chart = this.chart;\n options = merge(this.userOptions, options);\n this.destroy(true);\n this.init(chart, options);\n chart.isDirtyBox = true;\n if (pick(redraw, true)) {\n chart.redraw();\n }\n };\n /**\n * Remove the axis from the chart.\n *\n * @sample highcharts/members/chart-addaxis/\n * Add and remove axes\n *\n * @function Highcharts.Axis#remove\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart following the remove.\n */\n Axis.prototype.remove = function (redraw) {\n var chart = this.chart,\n key = this.coll, // xAxis or yAxis\n axisSeries = this.series;\n var i = axisSeries.length;\n // Remove associated series (#2687)\n while (i--) {\n if (axisSeries[i]) {\n axisSeries[i].remove(false);\n }\n }\n // Remove the axis\n erase(chart.axes, this);\n erase(chart[key], this);\n chart[key].forEach(function (axis, i) {\n // Re-index, #1706, #8075\n axis.options.index = axis.userOptions.index = i;\n });\n this.destroy();\n chart.isDirtyBox = true;\n if (pick(redraw, true)) {\n chart.redraw();\n }\n };\n /**\n * Update the axis title by options after render time.\n *\n * @sample highcharts/members/axis-settitle/\n * Set a new Y axis title\n *\n * @function Highcharts.Axis#setTitle\n *\n * @param {Highcharts.AxisTitleOptions} titleOptions\n * The additional title options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after setting the title.\n */\n Axis.prototype.setTitle = function (titleOptions, redraw) {\n this.update({ title: titleOptions }, redraw);\n };\n /**\n * Set new axis categories and optionally redraw.\n *\n * @sample highcharts/members/axis-setcategories/\n * Set categories by click on a button\n *\n * @function Highcharts.Axis#setCategories\n *\n * @param {Array} categories\n * The new categories.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart.\n */\n Axis.prototype.setCategories = function (categories, redraw) {\n this.update({ categories: categories }, redraw);\n };\n /* *\n *\n * Static Properties\n *\n * */\n Axis.defaultOptions = AxisDefaults.defaultXAxisOptions;\n // Properties to survive after destroy, needed for Axis.update (#4317,\n // #5773, #5881).\n Axis.keepProps = [\n 'extKey',\n 'hcEvents',\n 'names',\n 'series',\n 'userMax',\n 'userMin'\n ];\n return Axis;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Options for the path on the Axis to be calculated.\n * @interface Highcharts.AxisPlotLinePathOptionsObject\n */ /**\n * Axis value.\n * @name Highcharts.AxisPlotLinePathOptionsObject#value\n * @type {number|undefined}\n */ /**\n * Line width used for calculation crisp line coordinates. Defaults to 1.\n * @name Highcharts.AxisPlotLinePathOptionsObject#lineWidth\n * @type {number|undefined}\n */ /**\n * If `false`, the function will return null when it falls outside the axis\n * bounds. If `true`, the function will return a path aligned to the plot area\n * sides if it falls outside. If `pass`, it will return a path outside.\n * @name Highcharts.AxisPlotLinePathOptionsObject#force\n * @type {string|boolean|undefined}\n */ /**\n * Used in Highcharts Stock. When `true`, plot paths\n * (crosshair, plotLines, gridLines)\n * will be rendered on all axes when defined on the first axis.\n * @name Highcharts.AxisPlotLinePathOptionsObject#acrossPanes\n * @type {boolean|undefined}\n */ /**\n * Use old coordinates (for resizing and rescaling).\n * If not set, defaults to `false`.\n * @name Highcharts.AxisPlotLinePathOptionsObject#old\n * @type {boolean|undefined}\n */ /**\n * If given, return the plot line path of a pixel position on the axis.\n * @name Highcharts.AxisPlotLinePathOptionsObject#translatedValue\n * @type {number|undefined}\n */ /**\n * Used in Polar axes. Reverse the positions for concatenation of polygonal\n * plot bands\n * @name Highcharts.AxisPlotLinePathOptionsObject#reverse\n * @type {boolean|undefined}\n */\n /**\n * Options for crosshairs on axes.\n *\n * @product highstock\n *\n * @typedef {Highcharts.XAxisCrosshairOptions|Highcharts.YAxisCrosshairOptions} Highcharts.AxisCrosshairOptions\n */\n /**\n * @typedef {\"navigator\"|\"pan\"|\"rangeSelectorButton\"|\"rangeSelectorInput\"|\"scrollbar\"|\"traverseUpButton\"|\"zoom\"} Highcharts.AxisExtremesTriggerValue\n */\n /**\n * @callback Highcharts.AxisEventCallbackFunction\n *\n * @param {Highcharts.Axis} this\n */\n /**\n * @callback Highcharts.AxisLabelsFormatterCallbackFunction\n *\n * @param {Highcharts.AxisLabelsFormatterContextObject} this\n *\n * @param {Highcharts.AxisLabelsFormatterContextObject} ctx\n *\n * @return {string}\n */\n /**\n * @interface Highcharts.AxisLabelsFormatterContextObject\n */ /**\n * The axis item of the label\n * @name Highcharts.AxisLabelsFormatterContextObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * The chart instance.\n * @name Highcharts.AxisLabelsFormatterContextObject#chart\n * @type {Highcharts.Chart}\n */ /**\n * Default formatting of date/time labels.\n * @name Highcharts.AxisLabelsFormatterContextObject#dateTimeLabelFormat\n * @type {string|undefined}\n */ /**\n * Whether the label belongs to the first tick on the axis.\n * @name Highcharts.AxisLabelsFormatterContextObject#isFirst\n * @type {boolean}\n */ /**\n * Whether the label belongs to the last tick on the axis.\n * @name Highcharts.AxisLabelsFormatterContextObject#isLast\n * @type {boolean}\n */ /**\n * The position on the axis in terms of axis values. For category axes, a\n * zero-based index. For datetime axes, the JavaScript time in milliseconds\n * since 1970.\n * @name Highcharts.AxisLabelsFormatterContextObject#pos\n * @type {number}\n */ /**\n * The preformatted text as the result of the default formatting. For example\n * dates will be formatted as strings, and numbers with language-specific comma\n * separators, thousands separators and numeric symbols like `k` or `M`.\n * @name Highcharts.AxisLabelsFormatterContextObject#text\n * @type {string|undefined}\n */ /**\n * The Tick instance.\n * @name Highcharts.AxisLabelsFormatterContextObject#tick\n * @type {Highcharts.Tick}\n */ /**\n * This can be either a numeric value or a category string.\n * @name Highcharts.AxisLabelsFormatterContextObject#value\n * @type {number|string}\n */\n /**\n * Options for axes.\n *\n * @typedef {Highcharts.XAxisOptions|Highcharts.YAxisOptions|Highcharts.ZAxisOptions} Highcharts.AxisOptions\n */\n /**\n * @callback Highcharts.AxisPointBreakEventCallbackFunction\n *\n * @param {Highcharts.Axis} this\n *\n * @param {Highcharts.AxisPointBreakEventObject} evt\n */\n /**\n * @interface Highcharts.AxisPointBreakEventObject\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#brk\n * @type {Highcharts.Dictionary}\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#point\n * @type {Highcharts.Point}\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#preventDefault\n * @type {Function}\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#target\n * @type {Highcharts.SVGElement}\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#type\n * @type {\"pointBreak\"|\"pointInBreak\"}\n */\n /**\n * @callback Highcharts.AxisSetExtremesEventCallbackFunction\n *\n * @param {Highcharts.Axis} this\n *\n * @param {Highcharts.AxisSetExtremesEventObject} evt\n */\n /**\n * @interface Highcharts.AxisSetExtremesEventObject\n * @extends Highcharts.ExtremesObject\n */ /**\n * @name Highcharts.AxisSetExtremesEventObject#preventDefault\n * @type {Function}\n */ /**\n * @name Highcharts.AxisSetExtremesEventObject#target\n * @type {Highcharts.SVGElement}\n */ /**\n * @name Highcharts.AxisSetExtremesEventObject#trigger\n * @type {Highcharts.AxisExtremesTriggerValue|string}\n */ /**\n * @name Highcharts.AxisSetExtremesEventObject#type\n * @type {\"setExtremes\"}\n */\n /**\n * @callback Highcharts.AxisTickPositionerCallbackFunction\n *\n * @param {Highcharts.Axis} this\n *\n * @return {Highcharts.AxisTickPositionsArray}\n */\n /**\n * @interface Highcharts.AxisTickPositionsArray\n * @augments Array\n */\n /**\n * @typedef {\"high\"|\"low\"|\"middle\"} Highcharts.AxisTitleAlignValue\n */\n /**\n * @typedef {Highcharts.XAxisTitleOptions|Highcharts.YAxisTitleOptions|Highcharts.ZAxisTitleOptions} Highcharts.AxisTitleOptions\n */\n /**\n * @typedef {\"linear\"|\"logarithmic\"|\"datetime\"|\"category\"|\"treegrid\"} Highcharts.AxisTypeValue\n */\n /**\n * The returned object literal from the {@link Highcharts.Axis#getExtremes}\n * function.\n *\n * @interface Highcharts.ExtremesObject\n */ /**\n * The maximum value of the axis' associated series.\n * @name Highcharts.ExtremesObject#dataMax\n * @type {number}\n */ /**\n * The minimum value of the axis' associated series.\n * @name Highcharts.ExtremesObject#dataMin\n * @type {number}\n */ /**\n * The maximum axis value, either automatic or set manually. If the `max` option\n * is not set, `maxPadding` is 0 and `endOnTick` is false, this value will be\n * the same as `dataMax`.\n * @name Highcharts.ExtremesObject#max\n * @type {number}\n */ /**\n * The minimum axis value, either automatic or set manually. If the `min` option\n * is not set, `minPadding` is 0 and `startOnTick` is false, this value will be\n * the same as `dataMin`.\n * @name Highcharts.ExtremesObject#min\n * @type {number}\n */ /**\n * The user defined maximum, either from the `max` option or from a zoom or\n * `setExtremes` action.\n * @name Highcharts.ExtremesObject#userMax\n * @type {number}\n */ /**\n * The user defined minimum, either from the `min` option or from a zoom or\n * `setExtremes` action.\n * @name Highcharts.ExtremesObject#userMin\n * @type {number}\n */\n /**\n * Formatter function for the text of a crosshair label.\n *\n * @callback Highcharts.XAxisCrosshairLabelFormatterCallbackFunction\n *\n * @param {Highcharts.Axis} this\n * Axis context\n *\n * @param {number} value\n * Y value of the data point\n *\n * @return {string}\n */\n ''; // keeps doclets above in JS file\n\n return Axis;\n });\n _registerModule(_modules, 'Core/Axis/DateTimeAxis.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var addEvent = U.addEvent,\n getMagnitude = U.getMagnitude,\n normalizeTickInterval = U.normalizeTickInterval,\n timeUnits = U.timeUnits;\n /* *\n *\n * Composition\n *\n * */\n /* eslint-disable valid-jsdoc */\n var DateTimeAxis;\n (function (DateTimeAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extends axis class with date and time support.\n * @private\n */\n function compose(AxisClass) {\n if (composedClasses.indexOf(AxisClass) === -1) {\n composedClasses.push(AxisClass);\n AxisClass.keepProps.push('dateTime');\n var axisProto = AxisClass.prototype;\n axisProto.getTimeTicks = getTimeTicks;\n addEvent(AxisClass, 'init', onInit);\n }\n return AxisClass;\n }\n DateTimeAxis.compose = compose;\n /**\n * Set the tick positions to a time unit that makes sense, for example\n * on the first of each month or on every Monday. Return an array with\n * the time positions. Used in datetime axes as well as for grouping\n * data on a datetime axis.\n *\n * @private\n * @function Highcharts.Axis#getTimeTicks\n * @param {Highcharts.TimeNormalizeObject} normalizedInterval\n * The interval in axis values (ms) and thecount.\n * @param {number} min\n * The minimum in axis values.\n * @param {number} max\n * The maximum in axis values.\n */\n function getTimeTicks() {\n return this.chart.time.getTimeTicks.apply(this.chart.time, arguments);\n }\n /**\n * @private\n */\n function onInit(e) {\n var axis = this;\n var options = e.userOptions;\n if (options.type !== 'datetime') {\n axis.dateTime = void 0;\n return;\n }\n if (!axis.dateTime) {\n axis.dateTime = new Additions(axis);\n }\n }\n /* *\n *\n * Classes\n *\n * */\n var Additions = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Additions(axis) {\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get a normalized tick interval for dates. Returns a configuration\n * object with unit range (interval), count and name. Used to prepare\n * data for `getTimeTicks`. Previously this logic was part of\n * getTimeTicks, but as `getTimeTicks` now runs of segments in stock\n * charts, the normalizing logic was extracted in order to prevent it\n * for running over again for each segment having the same interval.\n * #662, #697.\n * @private\n */\n Additions.prototype.normalizeTimeTickInterval = function (tickInterval, unitsOption) {\n var units = (unitsOption || [[\n // unit name\n 'millisecond',\n // allowed multiples\n [1, 2, 5, 10, 20, 25, 50, 100, 200, 500]\n ],\n [\n 'second',\n [1, 2, 5, 10, 15, 30]\n ],\n [\n 'minute',\n [1, 2, 5, 10, 15, 30]\n ],\n [\n 'hour',\n [1, 2, 3, 4, 6, 8, 12]\n ],\n [\n 'day',\n [1, 2]\n ],\n [\n 'week',\n [1, 2]\n ],\n [\n 'month',\n [1, 2, 3, 4, 6]\n ],\n [\n 'year',\n null\n ]]);\n var unit = units[units.length - 1], // default unit is years\n interval = timeUnits[unit[0]],\n multiples = unit[1],\n i;\n // loop through the units to find the one that best fits the\n // tickInterval\n for (i = 0; i < units.length; i++) {\n unit = units[i];\n interval = timeUnits[unit[0]];\n multiples = unit[1];\n if (units[i + 1]) {\n // lessThan is in the middle between the highest multiple\n // and the next unit.\n var lessThan = (interval *\n multiples[multiples.length - 1] +\n timeUnits[units[i + 1][0]]) / 2;\n // break and keep the current unit\n if (tickInterval <= lessThan) {\n break;\n }\n }\n }\n // prevent 2.5 years intervals, though 25, 250 etc. are allowed\n if (interval === timeUnits.year && tickInterval < 5 * interval) {\n multiples = [1, 2, 5];\n }\n // get the count\n var count = normalizeTickInterval(tickInterval / interval,\n multiples,\n unit[0] === 'year' ? // #1913, #2360\n Math.max(getMagnitude(tickInterval / interval), 1) :\n 1);\n return {\n unitRange: interval,\n count: count,\n unitName: unit[0]\n };\n };\n /**\n * Get the best date format for a specific X value based on the closest\n * point range on the axis.\n *\n * @private\n */\n Additions.prototype.getXDateFormat = function (x, dateTimeLabelFormats) {\n var axis = this.axis,\n time = axis.chart.time;\n return axis.closestPointRange ?\n time.getDateFormat(axis.closestPointRange, x, axis.options.startOfWeek, dateTimeLabelFormats) ||\n // #2546, 2581\n time.resolveDTLFormat(dateTimeLabelFormats.year).main :\n time.resolveDTLFormat(dateTimeLabelFormats.day).main;\n };\n return Additions;\n }());\n DateTimeAxis.Additions = Additions;\n })(DateTimeAxis || (DateTimeAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return DateTimeAxis;\n });\n _registerModule(_modules, 'Core/Axis/LogarithmicAxis.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var addEvent = U.addEvent,\n getMagnitude = U.getMagnitude,\n normalizeTickInterval = U.normalizeTickInterval,\n pick = U.pick;\n /* *\n *\n * Class\n *\n * */\n /**\n * @private\n */\n var LogarithmicAxis;\n (function (LogarithmicAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Provides logarithmic support for axes.\n * @private\n */\n function compose(AxisClass) {\n if (composedClasses.indexOf(AxisClass) === -1) {\n composedClasses.push(AxisClass);\n AxisClass.keepProps.push('logarithmic');\n addEvent(AxisClass, 'init', onInit);\n addEvent(AxisClass, 'afterInit', onAfterInit);\n }\n return AxisClass;\n }\n LogarithmicAxis.compose = compose;\n /**\n * @private\n */\n function onInit(e) {\n var axis = this;\n var options = e.userOptions;\n var logarithmic = axis.logarithmic;\n if (options.type !== 'logarithmic') {\n axis.logarithmic = void 0;\n }\n else {\n if (!logarithmic) {\n logarithmic = axis.logarithmic = new Additions(axis);\n }\n }\n }\n /**\n * @private\n */\n function onAfterInit() {\n var axis = this;\n var log = axis.logarithmic;\n // extend logarithmic axis\n if (log) {\n axis.lin2val = function (num) {\n return log.lin2log(num);\n };\n axis.val2lin = function (num) {\n return log.log2lin(num);\n };\n }\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * Provides logarithmic support for axes.\n * @private\n * @class\n */\n var Additions = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Additions(axis) {\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set the tick positions of a logarithmic axis.\n */\n Additions.prototype.getLogTickPositions = function (interval, min, max, minor) {\n var log = this;\n var axis = log.axis;\n var axisLength = axis.len;\n var options = axis.options;\n // Since we use this method for both major and minor ticks,\n // use a local variable and return the result\n var positions = [];\n // Reset\n if (!minor) {\n log.minorAutoInterval = void 0;\n }\n // First case: All ticks fall on whole logarithms: 1, 10, 100 etc.\n if (interval >= 0.5) {\n interval = Math.round(interval);\n positions = axis.getLinearTickPositions(interval, min, max);\n // Second case: We need intermediary ticks. For example\n // 1, 2, 4, 6, 8, 10, 20, 40 etc.\n }\n else if (interval >= 0.08) {\n var roundedMin = Math.floor(min);\n var intermediate = void 0,\n i = void 0,\n j = void 0,\n len = void 0,\n pos = void 0,\n lastPos = void 0,\n break2 = void 0;\n if (interval > 0.3) {\n intermediate = [1, 2, 4];\n // 0.2 equals five minor ticks per 1, 10, 100 etc\n }\n else if (interval > 0.15) {\n intermediate = [1, 2, 4, 6, 8];\n }\n else { // 0.1 equals ten minor ticks per 1, 10, 100 etc\n intermediate = [1, 2, 3, 4, 5, 6, 7, 8, 9];\n }\n for (i = roundedMin; i < max + 1 && !break2; i++) {\n len = intermediate.length;\n for (j = 0; j < len && !break2; j++) {\n pos = log.log2lin(log.lin2log(i) * intermediate[j]);\n // #1670, lastPos is #3113\n if (pos > min &&\n (!minor || lastPos <= max) &&\n typeof lastPos !== 'undefined') {\n positions.push(lastPos);\n }\n if (lastPos > max) {\n break2 = true;\n }\n lastPos = pos;\n }\n }\n // Third case: We are so deep in between whole logarithmic values,\n // that we might as well handle the tick positions like a linear\n // axis. For example 1.01, 1.02, 1.03, 1.04.\n }\n else {\n var realMin = log.lin2log(min),\n realMax = log.lin2log(max),\n tickIntervalOption = minor ?\n axis.getMinorTickInterval() :\n options.tickInterval,\n filteredTickIntervalOption = tickIntervalOption === 'auto' ?\n null :\n tickIntervalOption,\n tickPixelIntervalOption = options.tickPixelInterval / (minor ? 5 : 1),\n totalPixelLength = minor ?\n axisLength / axis.tickPositions.length :\n axisLength;\n interval = pick(filteredTickIntervalOption, log.minorAutoInterval, (realMax - realMin) *\n tickPixelIntervalOption / (totalPixelLength || 1));\n interval = normalizeTickInterval(interval);\n positions = axis.getLinearTickPositions(interval, realMin, realMax).map(log.log2lin);\n if (!minor) {\n log.minorAutoInterval = interval / 5;\n }\n }\n // Set the axis-level tickInterval variable\n if (!minor) {\n axis.tickInterval = interval;\n }\n return positions;\n };\n Additions.prototype.lin2log = function (num) {\n return Math.pow(10, num);\n };\n Additions.prototype.log2lin = function (num) {\n return Math.log(num) / Math.LN10;\n };\n return Additions;\n }());\n LogarithmicAxis.Additions = Additions;\n })(LogarithmicAxis || (LogarithmicAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return LogarithmicAxis;\n });\n _registerModule(_modules, 'Core/Axis/PlotLineOrBand/PlotLineOrBandAxis.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var erase = U.erase,\n extend = U.extend,\n isNumber = U.isNumber;\n /* *\n *\n * Composition\n *\n * */\n var PlotLineOrBandAxis;\n (function (PlotLineOrBandAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Variables\n *\n * */\n var PlotLineOrBandClass;\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * @private\n */\n function compose(PlotLineOrBandType, AxisClass) {\n if (!PlotLineOrBandClass) {\n PlotLineOrBandClass = PlotLineOrBandType;\n }\n if (composedClasses.indexOf(AxisClass) === -1) {\n composedClasses.push(AxisClass);\n extend(AxisClass.prototype, Additions.prototype);\n }\n return AxisClass;\n }\n PlotLineOrBandAxis.compose = compose;\n /* *\n *\n * Classes\n *\n * */\n /**\n * Object with members for extending the Axis prototype.\n * @private\n */\n var Additions = /** @class */ (function () {\n function Additions() {\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Internal function to create the SVG path definition for a plot band.\n *\n * @function Highcharts.Axis#getPlotBandPath\n *\n * @param {number} from\n * The axis value to start from.\n *\n * @param {number} to\n * The axis value to end on.\n *\n * @param {Highcharts.AxisPlotBandsOptions|Highcharts.AxisPlotLinesOptions} options\n * The plotBand or plotLine configuration object.\n *\n * @return {Highcharts.SVGPathArray}\n * The SVG path definition in array form.\n */\n Additions.prototype.getPlotBandPath = function (from, to, options) {\n if (options === void 0) { options = this.options; }\n var toPath = this.getPlotLinePath({\n value: to,\n force: true,\n acrossPanes: options.acrossPanes\n }), result = [], horiz = this.horiz, outside = !isNumber(this.min) ||\n !isNumber(this.max) ||\n (from < this.min && to < this.min) ||\n (from > this.max && to > this.max);\n var path = this.getPlotLinePath({\n value: from,\n force: true,\n acrossPanes: options.acrossPanes\n }),\n i, \n // #4964 check if chart is inverted or plotband is on yAxis\n plus = 1,\n isFlat;\n if (path && toPath) {\n // Flat paths don't need labels (#3836)\n if (outside) {\n isFlat = path.toString() === toPath.toString();\n plus = 0;\n }\n // Go over each subpath - for panes in Highcharts Stock\n for (i = 0; i < path.length; i += 2) {\n var pathStart = path[i],\n pathEnd = path[i + 1],\n toPathStart = toPath[i],\n toPathEnd = toPath[i + 1];\n // Type checking all affected path segments. Consider\n // something smarter.\n if ((pathStart[0] === 'M' || pathStart[0] === 'L') &&\n (pathEnd[0] === 'M' || pathEnd[0] === 'L') &&\n (toPathStart[0] === 'M' || toPathStart[0] === 'L') &&\n (toPathEnd[0] === 'M' || toPathEnd[0] === 'L')) {\n // Add 1 pixel when coordinates are the same\n if (horiz && toPathStart[1] === pathStart[1]) {\n toPathStart[1] += plus;\n toPathEnd[1] += plus;\n }\n else if (!horiz && toPathStart[2] === pathStart[2]) {\n toPathStart[2] += plus;\n toPathEnd[2] += plus;\n }\n result.push(['M', pathStart[1], pathStart[2]], ['L', pathEnd[1], pathEnd[2]], ['L', toPathEnd[1], toPathEnd[2]], ['L', toPathStart[1], toPathStart[2]], ['Z']);\n }\n result.isFlat = isFlat;\n }\n }\n else { // outside the axis area\n path = null;\n }\n return result;\n };\n /**\n * Add a plot band after render time.\n *\n * @sample highcharts/members/axis-addplotband/\n * Toggle the plot band from a button\n *\n * @function Highcharts.Axis#addPlotBand\n *\n * @param {Highcharts.AxisPlotBandsOptions} options\n * A configuration object for the plot band, as defined in\n * [xAxis.plotBands](https://api.highcharts.com/highcharts/xAxis.plotBands).\n *\n * @return {Highcharts.PlotLineOrBand|undefined}\n * The added plot band.\n */\n Additions.prototype.addPlotBand = function (options) {\n return this.addPlotBandOrLine(options, 'plotBands');\n };\n /**\n * Add a plot line after render time.\n *\n * @sample highcharts/members/axis-addplotline/\n * Toggle the plot line from a button\n *\n * @function Highcharts.Axis#addPlotLine\n *\n * @param {Highcharts.AxisPlotLinesOptions} options\n * A configuration object for the plot line, as defined in\n * [xAxis.plotLines](https://api.highcharts.com/highcharts/xAxis.plotLines).\n *\n * @return {Highcharts.PlotLineOrBand|undefined}\n * The added plot line.\n */\n Additions.prototype.addPlotLine = function (options) {\n return this.addPlotBandOrLine(options, 'plotLines');\n };\n /**\n * Add a plot band or plot line after render time. Called from\n * addPlotBand and addPlotLine internally.\n *\n * @private\n * @function Highcharts.Axis#addPlotBandOrLine\n * @param {Highcharts.AxisPlotBandsOptions|Highcharts.AxisPlotLinesOptions} options\n * The plotBand or plotLine configuration object.\n */\n Additions.prototype.addPlotBandOrLine = function (options, coll) {\n var _this = this;\n var userOptions = this.userOptions;\n var obj = new PlotLineOrBandClass(this,\n options);\n if (this.visible) {\n obj = obj.render();\n }\n if (obj) { // #2189\n if (!this._addedPlotLB) {\n this._addedPlotLB = true;\n (userOptions.plotLines || [])\n .concat(userOptions.plotBands || [])\n .forEach(function (plotLineOptions) {\n _this.addPlotBandOrLine(plotLineOptions);\n });\n }\n // Add it to the user options for exporting and Axis.update\n if (coll) {\n // Workaround Microsoft/TypeScript issue #32693\n var updatedOptions = (userOptions[coll] || []);\n updatedOptions.push(options);\n userOptions[coll] = updatedOptions;\n }\n this.plotLinesAndBands.push(obj);\n }\n return obj;\n };\n /**\n * Remove a plot band or plot line from the chart by id. Called\n * internally from `removePlotBand` and `removePlotLine`.\n * @private\n * @function Highcharts.Axis#removePlotBandOrLine\n */\n Additions.prototype.removePlotBandOrLine = function (id) {\n var plotLinesAndBands = this.plotLinesAndBands,\n options = this.options,\n userOptions = this.userOptions;\n if (plotLinesAndBands) { // #15639\n var i_1 = plotLinesAndBands.length;\n while (i_1--) {\n if (plotLinesAndBands[i_1].id === id) {\n plotLinesAndBands[i_1].destroy();\n }\n }\n ([\n options.plotLines || [],\n userOptions.plotLines || [],\n options.plotBands || [],\n userOptions.plotBands || []\n ]).forEach(function (arr) {\n i_1 = arr.length;\n while (i_1--) {\n if ((arr[i_1] || {}).id === id) {\n erase(arr, arr[i_1]);\n }\n }\n });\n }\n };\n /**\n * Remove a plot band by its id.\n *\n * @sample highcharts/members/axis-removeplotband/\n * Remove plot band by id\n * @sample highcharts/members/axis-addplotband/\n * Toggle the plot band from a button\n *\n * @function Highcharts.Axis#removePlotBand\n *\n * @param {string} id\n * The plot band's `id` as given in the original configuration\n * object or in the `addPlotBand` option.\n */\n Additions.prototype.removePlotBand = function (id) {\n this.removePlotBandOrLine(id);\n };\n /**\n * Remove a plot line by its id.\n *\n * @sample highcharts/xaxis/plotlines-id/\n * Remove plot line by id\n * @sample highcharts/members/axis-addplotline/\n * Toggle the plot line from a button\n *\n * @function Highcharts.Axis#removePlotLine\n *\n * @param {string} id\n * The plot line's `id` as given in the original configuration\n * object or in the `addPlotLine` option.\n */\n Additions.prototype.removePlotLine = function (id) {\n this.removePlotBandOrLine(id);\n };\n return Additions;\n }());\n })(PlotLineOrBandAxis || (PlotLineOrBandAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return PlotLineOrBandAxis;\n });\n _registerModule(_modules, 'Core/Axis/PlotLineOrBand/PlotLineOrBand.js', [_modules['Core/Axis/PlotLineOrBand/PlotLineOrBandAxis.js'], _modules['Core/Utilities.js']], function (PlotLineOrBandAxis, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var arrayMax = U.arrayMax,\n arrayMin = U.arrayMin,\n defined = U.defined,\n destroyObjectProperties = U.destroyObjectProperties,\n erase = U.erase,\n fireEvent = U.fireEvent,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick;\n /* *\n *\n * Class\n *\n * */\n /**\n * The object wrapper for plot lines and plot bands\n *\n * @class\n * @name Highcharts.PlotLineOrBand\n *\n * @param {Highcharts.Axis} axis\n * Related axis.\n *\n * @param {Highcharts.AxisPlotLinesOptions|Highcharts.AxisPlotBandsOptions} [options]\n * Options to use.\n */\n var PlotLineOrBand = /** @class */ (function () {\n /* *\n *\n * Constructor\n *\n * */\n function PlotLineOrBand(axis, options) {\n this.axis = axis;\n if (options) {\n this.options = options;\n this.id = options.id;\n }\n }\n /* *\n *\n * Static Functions\n *\n * */\n PlotLineOrBand.compose = function (AxisClass) {\n return PlotLineOrBandAxis.compose(PlotLineOrBand, AxisClass);\n };\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Render the plot line or plot band. If it is already existing,\n * move it.\n * @private\n * @function Highcharts.PlotLineOrBand#render\n */\n PlotLineOrBand.prototype.render = function () {\n fireEvent(this, 'render');\n var plotLine = this,\n axis = plotLine.axis,\n horiz = axis.horiz,\n log = axis.logarithmic,\n options = plotLine.options,\n color = options.color,\n zIndex = pick(options.zIndex, 0),\n events = options.events,\n groupAttribs = {},\n renderer = axis.chart.renderer;\n var optionsLabel = options.label,\n label = plotLine.label,\n to = options.to,\n from = options.from,\n value = options.value,\n svgElem = plotLine.svgElem,\n path = [],\n group;\n var isBand = defined(from) && defined(to),\n isLine = defined(value),\n isNew = !svgElem,\n attribs = {\n 'class': 'highcharts-plot-' + (isBand ? 'band ' : 'line ') +\n (options.className || '')\n };\n var groupName = isBand ? 'bands' : 'lines';\n // logarithmic conversion\n if (log) {\n from = log.log2lin(from);\n to = log.log2lin(to);\n value = log.log2lin(value);\n }\n // Set the presentational attributes\n if (!axis.chart.styledMode) {\n if (isLine) {\n attribs.stroke = color || \"#999999\" /* Palette.neutralColor40 */;\n attribs['stroke-width'] = pick(options.width, 1);\n if (options.dashStyle) {\n attribs.dashstyle =\n options.dashStyle;\n }\n }\n else if (isBand) { // plot band\n attribs.fill = color || \"#e6ebf5\" /* Palette.highlightColor10 */;\n if (options.borderWidth) {\n attribs.stroke = options.borderColor;\n attribs['stroke-width'] = options.borderWidth;\n }\n }\n }\n // Grouping and zIndex\n groupAttribs.zIndex = zIndex;\n groupName += '-' + zIndex;\n group = axis.plotLinesAndBandsGroups[groupName];\n if (!group) {\n axis.plotLinesAndBandsGroups[groupName] = group =\n renderer.g('plot-' + groupName)\n .attr(groupAttribs).add();\n }\n // Create the path\n if (isNew) {\n /**\n * SVG element of the plot line or band.\n *\n * @name Highcharts.PlotLineOrBand#svgElem\n * @type {Highcharts.SVGElement}\n */\n plotLine.svgElem = svgElem = renderer\n .path()\n .attr(attribs)\n .add(group);\n }\n // Set the path or return\n if (isLine) {\n path = axis.getPlotLinePath({\n value: value,\n lineWidth: svgElem.strokeWidth(),\n acrossPanes: options.acrossPanes\n });\n }\n else if (isBand) { // plot band\n path = axis.getPlotBandPath(from, to, options);\n }\n else {\n return;\n }\n // common for lines and bands\n // Add events only if they were not added before.\n if (!plotLine.eventsAdded && events) {\n objectEach(events, function (event, eventType) {\n svgElem.on(eventType, function (e) {\n events[eventType].apply(plotLine, [e]);\n });\n });\n plotLine.eventsAdded = true;\n }\n if ((isNew || !svgElem.d) && path && path.length) {\n svgElem.attr({ d: path });\n }\n else if (svgElem) {\n if (path) {\n svgElem.show();\n svgElem.animate({ d: path });\n }\n else if (svgElem.d) {\n svgElem.hide();\n if (label) {\n plotLine.label = label = label.destroy();\n }\n }\n }\n // the plot band/line label\n if (optionsLabel &&\n (defined(optionsLabel.text) || defined(optionsLabel.formatter)) &&\n path &&\n path.length &&\n axis.width > 0 &&\n axis.height > 0 &&\n !path.isFlat) {\n // apply defaults\n optionsLabel = merge({\n align: horiz && isBand && 'center',\n x: horiz ? !isBand && 4 : 10,\n verticalAlign: !horiz && isBand && 'middle',\n y: horiz ? isBand ? 16 : 10 : isBand ? 6 : -4,\n rotation: horiz && !isBand && 90\n }, optionsLabel);\n this.renderLabel(optionsLabel, path, isBand, zIndex);\n }\n else if (label) { // move out of sight\n label.hide();\n }\n // chainable\n return plotLine;\n };\n /**\n * Render and align label for plot line or band.\n * @private\n * @function Highcharts.PlotLineOrBand#renderLabel\n */\n PlotLineOrBand.prototype.renderLabel = function (optionsLabel, path, isBand, zIndex) {\n var plotLine = this,\n axis = plotLine.axis,\n renderer = axis.chart.renderer;\n var label = plotLine.label;\n // add the SVG element\n if (!label) {\n /**\n * SVG element of the label.\n *\n * @name Highcharts.PlotLineOrBand#label\n * @type {Highcharts.SVGElement}\n */\n plotLine.label = label = renderer\n .text(this.getLabelText(optionsLabel), 0, 0, optionsLabel.useHTML)\n .attr({\n align: optionsLabel.textAlign || optionsLabel.align,\n rotation: optionsLabel.rotation,\n 'class': 'highcharts-plot-' + (isBand ? 'band' : 'line') +\n '-label ' + (optionsLabel.className || ''),\n zIndex: zIndex\n })\n .add();\n if (!axis.chart.styledMode) {\n label.css(merge({\n textOverflow: 'ellipsis'\n }, optionsLabel.style));\n }\n }\n // get the bounding box and align the label\n // #3000 changed to better handle choice between plotband or plotline\n var xBounds = path.xBounds ||\n [path[0][1],\n path[1][1], (isBand ? path[2][1] : path[0][1])];\n var yBounds = path.yBounds ||\n [path[0][2],\n path[1][2], (isBand ? path[2][2] : path[0][2])];\n var x = arrayMin(xBounds);\n var y = arrayMin(yBounds);\n label.align(optionsLabel, false, {\n x: x,\n y: y,\n width: arrayMax(xBounds) - x,\n height: arrayMax(yBounds) - y\n });\n if (!label.alignValue || label.alignValue === 'left') {\n label.css({\n width: (label.rotation === 90 ?\n axis.height - (label.alignAttr.y - axis.top) :\n axis.width - (label.alignAttr.x - axis.left)) + 'px'\n });\n }\n label.show(true);\n };\n /**\n * Get label's text content.\n * @private\n * @function Highcharts.PlotLineOrBand#getLabelText\n */\n PlotLineOrBand.prototype.getLabelText = function (optionsLabel) {\n return defined(optionsLabel.formatter) ?\n optionsLabel.formatter\n .call(this) :\n optionsLabel.text;\n };\n /**\n * Remove the plot line or band.\n *\n * @function Highcharts.PlotLineOrBand#destroy\n */\n PlotLineOrBand.prototype.destroy = function () {\n // remove it from the lookup\n erase(this.axis.plotLinesAndBands, this);\n delete this.axis;\n destroyObjectProperties(this);\n };\n return PlotLineOrBand;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Options for plot bands on axes.\n *\n * @typedef {Highcharts.XAxisPlotBandsOptions|Highcharts.YAxisPlotBandsOptions|Highcharts.ZAxisPlotBandsOptions} Highcharts.AxisPlotBandsOptions\n */\n /**\n * Options for plot band labels on axes.\n *\n * @typedef {Highcharts.XAxisPlotBandsLabelOptions|Highcharts.YAxisPlotBandsLabelOptions|Highcharts.ZAxisPlotBandsLabelOptions} Highcharts.AxisPlotBandsLabelOptions\n */\n /**\n * Options for plot lines on axes.\n *\n * @typedef {Highcharts.XAxisPlotLinesOptions|Highcharts.YAxisPlotLinesOptions|Highcharts.ZAxisPlotLinesOptions} Highcharts.AxisPlotLinesOptions\n */\n /**\n * Options for plot line labels on axes.\n *\n * @typedef {Highcharts.XAxisPlotLinesLabelOptions|Highcharts.YAxisPlotLinesLabelOptions|Highcharts.ZAxisPlotLinesLabelOptions} Highcharts.AxisPlotLinesLabelOptions\n */\n ('');\n /* *\n *\n * API Options\n *\n * */\n /**\n * An array of colored bands stretching across the plot area marking an\n * interval on the axis.\n *\n * In styled mode, the plot bands are styled by the `.highcharts-plot-band`\n * class in addition to the `className` option.\n *\n * @productdesc {highcharts}\n * In a gauge, a plot band on the Y axis (value axis) will stretch along the\n * perimeter of the gauge.\n *\n * @type {Array<*>}\n * @product highcharts highstock gantt\n * @apioption xAxis.plotBands\n */\n /**\n * Flag to decide if plotBand should be rendered across all panes.\n *\n * @since 7.1.2\n * @product highstock\n * @type {boolean}\n * @default true\n * @apioption xAxis.plotBands.acrossPanes\n */\n /**\n * Border color for the plot band. Also requires `borderWidth` to be set.\n *\n * @type {Highcharts.ColorString}\n * @apioption xAxis.plotBands.borderColor\n */\n /**\n * Border width for the plot band. Also requires `borderColor` to be set.\n *\n * @type {number}\n * @default 0\n * @apioption xAxis.plotBands.borderWidth\n */\n /**\n * A custom class name, in addition to the default `highcharts-plot-band`,\n * to apply to each individual band.\n *\n * @type {string}\n * @since 5.0.0\n * @apioption xAxis.plotBands.className\n */\n /**\n * The color of the plot band.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-color/\n * Color band\n * @sample {highstock} stock/xaxis/plotbands/\n * Plot band on Y axis\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #e6ebf5\n * @apioption xAxis.plotBands.color\n */\n /**\n * An object defining mouse events for the plot band. Supported properties\n * are `click`, `mouseover`, `mouseout`, `mousemove`.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-events/\n * Mouse events demonstrated\n *\n * @since 1.2\n * @apioption xAxis.plotBands.events\n */\n /**\n * Click event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotBands.events.click\n */\n /**\n * Mouse move event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotBands.events.mousemove\n */\n /**\n * Mouse out event on the corner of a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotBands.events.mouseout\n */\n /**\n * Mouse over event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotBands.events.mouseover\n */\n /**\n * The start position of the plot band in axis units.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-color/\n * Datetime axis\n * @sample {highcharts} highcharts/xaxis/plotbands-from/\n * Categorized axis\n * @sample {highstock} stock/xaxis/plotbands/\n * Plot band on Y axis\n *\n * @type {number}\n * @apioption xAxis.plotBands.from\n */\n /**\n * An id used for identifying the plot band in Axis.removePlotBand.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-id/\n * Remove plot band by id\n * @sample {highstock} highcharts/xaxis/plotbands-id/\n * Remove plot band by id\n *\n * @type {string}\n * @apioption xAxis.plotBands.id\n */\n /**\n * The end position of the plot band in axis units.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-color/\n * Datetime axis\n * @sample {highcharts} highcharts/xaxis/plotbands-from/\n * Categorized axis\n * @sample {highstock} stock/xaxis/plotbands/\n * Plot band on Y axis\n *\n * @type {number}\n * @apioption xAxis.plotBands.to\n */\n /**\n * The z index of the plot band within the chart, relative to other\n * elements. Using the same z index as another element may give\n * unpredictable results, as the last rendered element will be on top.\n * Values from 0 to 20 make sense.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-color/\n * Behind plot lines by default\n * @sample {highcharts} highcharts/xaxis/plotbands-zindex/\n * Above plot lines\n * @sample {highcharts} highcharts/xaxis/plotbands-zindex-above-series/\n * Above plot lines and series\n *\n * @type {number}\n * @since 1.2\n * @apioption xAxis.plotBands.zIndex\n */\n /**\n * Text labels for the plot bands\n *\n * @product highcharts highstock gantt\n * @apioption xAxis.plotBands.label\n */\n /**\n * Horizontal alignment of the label. Can be one of \"left\", \"center\" or\n * \"right\".\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-align/\n * Aligned to the right\n * @sample {highstock} stock/xaxis/plotbands-label/\n * Plot band with labels\n *\n * @type {Highcharts.AlignValue}\n * @default center\n * @since 2.1\n * @apioption xAxis.plotBands.label.align\n */\n /**\n * Rotation of the text label in degrees .\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-rotation/\n * Vertical text\n *\n * @type {number}\n * @default 0\n * @since 2.1\n * @apioption xAxis.plotBands.label.rotation\n */\n /**\n * CSS styles for the text label.\n *\n * In styled mode, the labels are styled by the\n * `.highcharts-plot-band-label` class.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-style/\n * Blue and bold label\n *\n * @type {Highcharts.CSSObject}\n * @since 2.1\n * @apioption xAxis.plotBands.label.style\n */\n /**\n * The string text itself. A subset of HTML is supported.\n *\n * @type {string}\n * @since 2.1\n * @apioption xAxis.plotBands.label.text\n */\n /**\n * The text alignment for the label. While `align` determines where the\n * texts anchor point is placed within the plot band, `textAlign` determines\n * how the text is aligned against its anchor point. Possible values are\n * \"left\", \"center\" and \"right\". Defaults to the same as the `align` option.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-rotation/\n * Vertical text in center position but text-aligned left\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1\n * @apioption xAxis.plotBands.label.textAlign\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n *\n * @type {boolean}\n * @default false\n * @since 3.0.3\n * @apioption xAxis.plotBands.label.useHTML\n */\n /**\n * Vertical alignment of the label relative to the plot band. Can be one of\n * \"top\", \"middle\" or \"bottom\".\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-verticalalign/\n * Vertically centered label\n * @sample {highstock} stock/xaxis/plotbands-label/\n * Plot band with labels\n *\n * @type {Highcharts.VerticalAlignValue}\n * @default top\n * @since 2.1\n * @apioption xAxis.plotBands.label.verticalAlign\n */\n /**\n * Horizontal position relative the alignment. Default varies by\n * orientation.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-align/\n * Aligned 10px from the right edge\n * @sample {highstock} stock/xaxis/plotbands-label/\n * Plot band with labels\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotBands.label.x\n */\n /**\n * Vertical position of the text baseline relative to the alignment. Default\n * varies by orientation.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-y/\n * Label on x axis\n * @sample {highstock} stock/xaxis/plotbands-label/\n * Plot band with labels\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotBands.label.y\n */\n /**\n * An array of lines stretching across the plot area, marking a specific\n * value on one of the axes.\n *\n * In styled mode, the plot lines are styled by the\n * `.highcharts-plot-line` class in addition to the `className` option.\n *\n * @type {Array<*>}\n * @product highcharts highstock gantt\n * @sample {highcharts} highcharts/xaxis/plotlines-color/\n * Basic plot line\n * @sample {highcharts} highcharts/series-solidgauge/labels-auto-aligned/\n * Solid gauge plot line\n * @apioption xAxis.plotLines\n */\n /**\n * Flag to decide if plotLine should be rendered across all panes.\n *\n * @sample {highstock} stock/xaxis/plotlines-acrosspanes/\n * Plot lines on different panes\n *\n * @since 7.1.2\n * @product highstock\n * @type {boolean}\n * @default true\n * @apioption xAxis.plotLines.acrossPanes\n */\n /**\n * A custom class name, in addition to the default `highcharts-plot-line`,\n * to apply to each individual line.\n *\n * @type {string}\n * @since 5.0.0\n * @apioption xAxis.plotLines.className\n */\n /**\n * The color of the line.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-color/\n * A red line from X axis\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {Highcharts.ColorString}\n * @default #999999\n * @apioption xAxis.plotLines.color\n */\n /**\n * The dashing or dot style for the plot line. For possible values see\n * [this overview](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-dashstyle-all/).\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-dashstyle/\n * Dash and dot pattern\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {Highcharts.DashStyleValue}\n * @default Solid\n * @since 1.2\n * @apioption xAxis.plotLines.dashStyle\n */\n /**\n * An object defining mouse events for the plot line. Supported\n * properties are `click`, `mouseover`, `mouseout`, `mousemove`.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-events/\n * Mouse events demonstrated\n *\n * @since 1.2\n * @apioption xAxis.plotLines.events\n */\n /**\n * Click event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotLines.events.click\n */\n /**\n * Mouse move event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotLines.events.mousemove\n */\n /**\n * Mouse out event on the corner of a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotLines.events.mouseout\n */\n /**\n * Mouse over event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotLines.events.mouseover\n */\n /**\n * An id used for identifying the plot line in Axis.removePlotLine.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-id/\n * Remove plot line by id\n *\n * @type {string}\n * @apioption xAxis.plotLines.id\n */\n /**\n * The position of the line in axis units.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-color/\n * Between two categories on X axis\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {number}\n * @apioption xAxis.plotLines.value\n */\n /**\n * The width or thickness of the plot line.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-color/\n * 2px wide line from X axis\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {number}\n * @default 2\n * @apioption xAxis.plotLines.width\n */\n /**\n * The z index of the plot line within the chart.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-zindex-behind/\n * Behind plot lines by default\n * @sample {highcharts} highcharts/xaxis/plotlines-zindex-above/\n * Above plot lines\n * @sample {highcharts} highcharts/xaxis/plotlines-zindex-above-all/\n * Above plot lines and series\n *\n * @type {number}\n * @since 1.2\n * @apioption xAxis.plotLines.zIndex\n */\n /**\n * Text labels for the plot bands\n *\n * @apioption xAxis.plotLines.label\n */\n /**\n * Horizontal alignment of the label. Can be one of \"left\", \"center\" or\n * \"right\".\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-align-right/\n * Aligned to the right\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {Highcharts.AlignValue}\n * @default left\n * @since 2.1\n * @apioption xAxis.plotLines.label.align\n */\n /**\n * Callback JavaScript function to format the label. Useful properties like\n * the value of plot line or the range of plot band (`from` & `to`\n * properties) can be found in `this.options` object.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-plotbands-label-formatter\n * Label formatters for plot line and plot band.\n * @type {Highcharts.FormatterCallbackFunction}\n * @apioption xAxis.plotLines.label.formatter\n */\n /**\n * Rotation of the text label in degrees. Defaults to 0 for horizontal plot\n * lines and 90 for vertical lines.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-verticalalign-middle/\n * Slanted text\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotLines.label.rotation\n */\n /**\n * CSS styles for the text label.\n *\n * In styled mode, the labels are styled by the\n * `.highcharts-plot-line-label` class.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-style/\n * Blue and bold label\n *\n * @type {Highcharts.CSSObject}\n * @since 2.1\n * @apioption xAxis.plotLines.label.style\n */\n /**\n * The text itself. A subset of HTML is supported.\n *\n * @type {string}\n * @since 2.1\n * @apioption xAxis.plotLines.label.text\n */\n /**\n * The text alignment for the label. While `align` determines where the\n * texts anchor point is placed within the plot band, `textAlign` determines\n * how the text is aligned against its anchor point. Possible values are\n * \"left\", \"center\" and \"right\". Defaults to the same as the `align` option.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-textalign/\n * Text label in bottom position\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1\n * @apioption xAxis.plotLines.label.textAlign\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n *\n * @type {boolean}\n * @default false\n * @since 3.0.3\n * @apioption xAxis.plotLines.label.useHTML\n */\n /**\n * Vertical alignment of the label relative to the plot line. Can be\n * one of \"top\", \"middle\" or \"bottom\".\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-verticalalign-middle/\n * Vertically centered label\n *\n * @type {Highcharts.VerticalAlignValue}\n * @default {highcharts} top\n * @default {highstock} top\n * @since 2.1\n * @apioption xAxis.plotLines.label.verticalAlign\n */\n /**\n * Horizontal position relative the alignment. Default varies by\n * orientation.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-align-right/\n * Aligned 10px from the right edge\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotLines.label.x\n */\n /**\n * Vertical position of the text baseline relative to the alignment. Default\n * varies by orientation.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-y/\n * Label below the plot line\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotLines.label.y\n */\n /**\n * @type {Array<*>}\n * @extends xAxis.plotBands\n * @apioption yAxis.plotBands\n */\n /**\n * In a gauge chart, this option determines the inner radius of the\n * plot band that stretches along the perimeter. It can be given as\n * a percentage string, like `\"100%\"`, or as a pixel number, like `100`.\n * By default, the inner radius is controlled by the [thickness](\n * #yAxis.plotBands.thickness) option.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-gauge\n * Gauge plot band\n *\n * @type {number|string}\n * @since 2.3\n * @product highcharts\n * @apioption yAxis.plotBands.innerRadius\n */\n /**\n * In a gauge chart, this option determines the outer radius of the\n * plot band that stretches along the perimeter. It can be given as\n * a percentage string, like `\"100%\"`, or as a pixel number, like `100`.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-gauge\n * Gauge plot band\n *\n * @type {number|string}\n * @default 100%\n * @since 2.3\n * @product highcharts\n * @apioption yAxis.plotBands.outerRadius\n */\n /**\n * In a gauge chart, this option sets the width of the plot band\n * stretching along the perimeter. It can be given as a percentage\n * string, like `\"10%\"`, or as a pixel number, like `10`. The default\n * value 10 is the same as the default [tickLength](#yAxis.tickLength),\n * thus making the plot band act as a background for the tick markers.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-gauge\n * Gauge plot band\n *\n * @type {number|string}\n * @default 10\n * @since 2.3\n * @product highcharts\n * @apioption yAxis.plotBands.thickness\n */\n /**\n * @type {Array<*>}\n * @extends xAxis.plotLines\n * @apioption yAxis.plotLines\n */\n (''); // keeps doclets above in JS file\n\n return PlotLineOrBand;\n });\n _registerModule(_modules, 'Core/Tooltip.js', [_modules['Core/FormatUtilities.js'], _modules['Core/Globals.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Utilities.js']], function (F, H, R, RendererRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var format = F.format;\n var doc = H.doc;\n var distribute = R.distribute;\n var addEvent = U.addEvent,\n clamp = U.clamp,\n css = U.css,\n defined = U.defined,\n discardElement = U.discardElement,\n extend = U.extend,\n fireEvent = U.fireEvent,\n isArray = U.isArray,\n isNumber = U.isNumber,\n isString = U.isString,\n merge = U.merge,\n pick = U.pick,\n splat = U.splat,\n syncTimeout = U.syncTimeout;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Tooltip of a chart.\n *\n * @class\n * @name Highcharts.Tooltip\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.TooltipOptions} options\n * Tooltip options.\n */\n var Tooltip = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Tooltip(chart, options) {\n /* *\n *\n * Properties\n *\n * */\n this.allowShared = true;\n this.container = void 0;\n this.crosshairs = [];\n this.distance = 0;\n this.isHidden = true;\n this.isSticky = false;\n this.now = {};\n this.options = {};\n this.outside = false;\n this.chart = chart;\n this.init(chart, options);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * In styled mode, apply the default filter for the tooltip drop-shadow. It\n * needs to have an id specific to the chart, otherwise there will be issues\n * when one tooltip adopts the filter of a different chart, specifically one\n * where the container is hidden.\n *\n * @private\n * @function Highcharts.Tooltip#applyFilter\n */\n Tooltip.prototype.applyFilter = function () {\n var chart = this.chart;\n chart.renderer.definition({\n tagName: 'filter',\n attributes: {\n id: 'drop-shadow-' + chart.index,\n opacity: 0.5\n },\n children: [{\n tagName: 'feGaussianBlur',\n attributes: {\n 'in': 'SourceAlpha',\n stdDeviation: 1\n }\n }, {\n tagName: 'feOffset',\n attributes: {\n dx: 1,\n dy: 1\n }\n }, {\n tagName: 'feComponentTransfer',\n children: [{\n tagName: 'feFuncA',\n attributes: {\n type: 'linear',\n slope: 0.3\n }\n }]\n }, {\n tagName: 'feMerge',\n children: [{\n tagName: 'feMergeNode'\n }, {\n tagName: 'feMergeNode',\n attributes: {\n 'in': 'SourceGraphic'\n }\n }]\n }]\n });\n };\n /**\n * Build the body (lines) of the tooltip by iterating over the items and\n * returning one entry for each item, abstracting this functionality allows\n * to easily overwrite and extend it.\n *\n * @private\n * @function Highcharts.Tooltip#bodyFormatter\n */\n Tooltip.prototype.bodyFormatter = function (items) {\n return items.map(function (item) {\n var tooltipOptions = item.series.tooltipOptions;\n return (tooltipOptions[(item.point.formatPrefix || 'point') + 'Formatter'] ||\n item.point.tooltipFormatter).call(item.point, tooltipOptions[(item.point.formatPrefix || 'point') + 'Format'] || '');\n });\n };\n /**\n * Destroy the single tooltips in a split tooltip.\n * If the tooltip is active then it is not destroyed, unless forced to.\n *\n * @private\n * @function Highcharts.Tooltip#cleanSplit\n *\n * @param {boolean} [force]\n * Force destroy all tooltips.\n */\n Tooltip.prototype.cleanSplit = function (force) {\n this.chart.series.forEach(function (series) {\n var tt = series && series.tt;\n if (tt) {\n if (!tt.isActive || force) {\n series.tt = tt.destroy();\n }\n else {\n tt.isActive = false;\n }\n }\n });\n };\n /**\n * In case no user defined formatter is given, this will be used. Note that\n * the context here is an object holding point, series, x, y etc.\n *\n * @function Highcharts.Tooltip#defaultFormatter\n *\n * @param {Highcharts.Tooltip} tooltip\n *\n * @return {string|Array}\n * Returns a string (single tooltip and shared)\n * or an array of strings (split tooltip)\n */\n Tooltip.prototype.defaultFormatter = function (tooltip) {\n var items = this.points || splat(this);\n var s;\n // Build the header\n s = [tooltip.tooltipFooterHeaderFormatter(items[0])];\n // build the values\n s = s.concat(tooltip.bodyFormatter(items));\n // footer\n s.push(tooltip.tooltipFooterHeaderFormatter(items[0], true));\n return s;\n };\n /**\n * Removes and destroys the tooltip and its elements.\n *\n * @function Highcharts.Tooltip#destroy\n */\n Tooltip.prototype.destroy = function () {\n // Destroy and clear local variables\n if (this.label) {\n this.label = this.label.destroy();\n }\n if (this.split && this.tt) {\n this.cleanSplit(true);\n this.tt = this.tt.destroy();\n }\n if (this.renderer) {\n this.renderer = this.renderer.destroy();\n discardElement(this.container);\n }\n U.clearTimeout(this.hideTimer);\n U.clearTimeout(this.tooltipTimeout);\n };\n /**\n * Extendable method to get the anchor position of the tooltip\n * from a point or set of points\n *\n * @private\n * @function Highcharts.Tooltip#getAnchor\n */\n Tooltip.prototype.getAnchor = function (points, mouseEvent) {\n var chart = this.chart,\n pointer = chart.pointer,\n inverted = chart.inverted,\n plotTop = chart.plotTop,\n plotLeft = chart.plotLeft;\n var ret,\n yAxis,\n xAxis,\n plotX = 0,\n plotY = 0;\n points = splat(points);\n // When tooltip follows mouse, relate the position to the mouse\n if (this.followPointer && mouseEvent) {\n if (typeof mouseEvent.chartX === 'undefined') {\n mouseEvent = pointer.normalize(mouseEvent);\n }\n ret = [\n mouseEvent.chartX - plotLeft,\n mouseEvent.chartY - plotTop\n ];\n // Some series types use a specificly calculated tooltip position for\n // each point\n }\n else if (points[0].tooltipPos) {\n ret = points[0].tooltipPos;\n // Calculate the average position and adjust for axis positions\n }\n else {\n points.forEach(function (point) {\n yAxis = point.series.yAxis;\n xAxis = point.series.xAxis;\n plotX += point.plotX || 0;\n plotY += (point.plotLow ?\n (point.plotLow + (point.plotHigh || 0)) / 2 :\n (point.plotY || 0));\n // Adjust position for positioned axes (top/left settings)\n if (xAxis && yAxis) {\n if (!inverted) { // #1151\n plotX += xAxis.pos - plotLeft;\n plotY += yAxis.pos - plotTop;\n }\n else { // #14771\n plotX += (plotTop + chart.plotHeight - xAxis.len - xAxis.pos);\n plotY += (plotLeft + chart.plotWidth - yAxis.len - yAxis.pos);\n }\n }\n });\n plotX /= points.length;\n plotY /= points.length;\n // Use the average position for multiple points\n ret = [\n inverted ? chart.plotWidth - plotY : plotX,\n inverted ? chart.plotHeight - plotX : plotY\n ];\n // When shared, place the tooltip next to the mouse (#424)\n if (this.shared && points.length > 1 && mouseEvent) {\n if (inverted) {\n ret[0] = mouseEvent.chartX - plotLeft;\n }\n else {\n ret[1] = mouseEvent.chartY - plotTop;\n }\n }\n }\n return ret.map(Math.round);\n };\n /**\n * Creates the Tooltip label element if it does not exist, then returns it.\n *\n * @function Highcharts.Tooltip#getLabel\n *\n * @return {Highcharts.SVGElement}\n * Tooltip label\n */\n Tooltip.prototype.getLabel = function () {\n var tooltip = this,\n styledMode = this.chart.styledMode,\n options = this.options,\n doSplit = this.split && this.allowShared,\n className = ('tooltip' + (defined(options.className) ?\n ' ' + options.className :\n '')),\n pointerEvents = (options.style.pointerEvents ||\n (this.shouldStickOnContact() ? 'auto' : 'none'));\n var container,\n renderer = this.chart.renderer;\n // If changing from a split tooltip to a non-split tooltip, we must\n // destroy it in order to get the SVG right. #13868.\n if (tooltip.label) {\n var wasSplit = !tooltip.label.hasClass('highcharts-label');\n if ((doSplit && !wasSplit) || (!doSplit && wasSplit)) {\n tooltip.destroy();\n }\n }\n if (!this.label) {\n if (this.outside) {\n var chartStyle = this.chart.options.chart.style,\n Renderer = RendererRegistry.getRendererType();\n /**\n * Reference to the tooltip's container, when\n * [Highcharts.Tooltip#outside] is set to true, otherwise\n * it's undefined.\n *\n * @name Highcharts.Tooltip#container\n * @type {Highcharts.HTMLDOMElement|undefined}\n */\n this.container = container = H.doc.createElement('div');\n container.className = 'highcharts-tooltip-container';\n css(container, {\n position: 'absolute',\n top: '1px',\n pointerEvents: pointerEvents,\n zIndex: Math.max(this.options.style.zIndex || 0, (chartStyle && chartStyle.zIndex || 0) + 3)\n });\n H.doc.body.appendChild(container);\n /**\n * Reference to the tooltip's renderer, when\n * [Highcharts.Tooltip#outside] is set to true, otherwise\n * it's undefined.\n *\n * @name Highcharts.Tooltip#renderer\n * @type {Highcharts.SVGRenderer|undefined}\n */\n this.renderer = renderer = new Renderer(container, 0, 0, chartStyle, void 0, void 0, renderer.styledMode);\n }\n // Create the label\n if (doSplit) {\n this.label = renderer.g(className);\n }\n else {\n this.label = renderer\n .label('', 0, 0, options.shape, void 0, void 0, options.useHTML, void 0, className)\n .attr({\n padding: options.padding,\n r: options.borderRadius\n });\n if (!styledMode) {\n this.label\n .attr({\n fill: options.backgroundColor,\n 'stroke-width': options.borderWidth\n })\n // #2301, #2657\n .css(options.style)\n .css({ pointerEvents: pointerEvents })\n .shadow(options.shadow);\n }\n }\n if (styledMode && options.shadow) {\n // Apply the drop-shadow filter\n this.applyFilter();\n this.label.attr({\n filter: 'url(#drop-shadow-' + this.chart.index + ')'\n });\n }\n // Split tooltip use updateTooltipContainer to position the tooltip\n // container.\n if (tooltip.outside && !tooltip.split) {\n var label_1 = this.label;\n var xSetter_1 = label_1.xSetter,\n ySetter_1 = label_1.ySetter;\n label_1.xSetter = function (value) {\n xSetter_1.call(label_1, tooltip.distance);\n container.style.left = value + 'px';\n };\n label_1.ySetter = function (value) {\n ySetter_1.call(label_1, tooltip.distance);\n container.style.top = value + 'px';\n };\n }\n this.label\n .attr({ zIndex: 8 })\n .add();\n }\n return this.label;\n };\n /**\n * Place the tooltip in a chart without spilling over and not covering the\n * point itself.\n *\n * @function Highcharts.Tooltip#getPosition\n *\n * @param {number} boxWidth\n * Width of the tooltip box.\n *\n * @param {number} boxHeight\n * Height of the tooltip box.\n *\n * @param {Highcharts.Point} point\n * Tooltip related point.\n *\n * @return {Highcharts.PositionObject}\n * Recommended position of the tooltip.\n */\n Tooltip.prototype.getPosition = function (boxWidth, boxHeight, point) {\n var chart = this.chart,\n distance = this.distance,\n ret = {}, \n // Don't use h if chart isn't inverted (#7242) ???\n h = (chart.inverted && point.h) || 0, // #4117 ???\n outside = this.outside,\n outerWidth = outside ?\n // substract distance to prevent scrollbars\n doc.documentElement.clientWidth - 2 * distance :\n chart.chartWidth,\n outerHeight = outside ?\n Math.max(doc.body.scrollHeight,\n doc.documentElement.scrollHeight,\n doc.body.offsetHeight,\n doc.documentElement.offsetHeight,\n doc.documentElement.clientHeight) :\n chart.chartHeight,\n chartPosition = chart.pointer.getChartPosition(),\n scaleX = function (val) { return ( // eslint-disable-line no-confusing-arrow\n val * chartPosition.scaleX); },\n scaleY = function (val) { return ( // eslint-disable-line no-confusing-arrow\n val * chartPosition.scaleY); }, \n // Build parameter arrays for firstDimension()/secondDimension()\n buildDimensionArray = function (dim) {\n var isX = dim === 'x';\n return [\n dim,\n isX ? outerWidth : outerHeight,\n isX ? boxWidth : boxHeight\n ].concat(outside ? [\n // If we are using tooltip.outside, we need to scale the\n // position to match scaling of the container in case there\n // is a transform/zoom on the container. #11329\n isX ? scaleX(boxWidth) : scaleY(boxHeight),\n isX ? chartPosition.left - distance +\n scaleX(point.plotX + chart.plotLeft) :\n chartPosition.top - distance +\n scaleY(point.plotY + chart.plotTop),\n 0,\n isX ? outerWidth : outerHeight\n ] : [\n // Not outside, no scaling is needed\n isX ? boxWidth : boxHeight,\n isX ? point.plotX + chart.plotLeft :\n point.plotY + chart.plotTop,\n isX ? chart.plotLeft : chart.plotTop,\n isX ? chart.plotLeft + chart.plotWidth :\n chart.plotTop + chart.plotHeight\n ]);\n };\n var first = buildDimensionArray('y'), second = buildDimensionArray('x'), swapped;\n // Handle negative points or reversed axis (#13780)\n var flipped = !!point.negative;\n if (!chart.polar &&\n chart.hoverSeries &&\n chart.hoverSeries.yAxis &&\n chart.hoverSeries.yAxis.reversed) {\n flipped = !flipped;\n }\n // The far side is right or bottom\n var preferFarSide = !this.followPointer &&\n pick(point.ttBelow, !chart.inverted === flipped), // #4984\n /*\n * Handle the preferred dimension. When the preferred dimension is\n * tooltip on top or bottom of the point,\n it will look for space\n * there.\n *\n * @private\n */\n firstDimension = function (dim,\n outerSize,\n innerSize,\n scaledInnerSize, // #11329\n point,\n min,\n max) {\n var scaledDist = outside ?\n (dim === 'y' ? scaleY(distance) : scaleX(distance)) :\n distance,\n scaleDiff = (innerSize - scaledInnerSize) / 2,\n roomLeft = scaledInnerSize < point - distance,\n roomRight = point + distance + scaledInnerSize < outerSize,\n alignedLeft = point - scaledDist - innerSize + scaleDiff,\n alignedRight = point + scaledDist - scaleDiff;\n if (preferFarSide && roomRight) {\n ret[dim] = alignedRight;\n }\n else if (!preferFarSide && roomLeft) {\n ret[dim] = alignedLeft;\n }\n else if (roomLeft) {\n ret[dim] = Math.min(max - scaledInnerSize, alignedLeft - h < 0 ? alignedLeft : alignedLeft - h);\n }\n else if (roomRight) {\n ret[dim] = Math.max(min, alignedRight + h + innerSize > outerSize ?\n alignedRight :\n alignedRight + h);\n }\n else {\n return false;\n }\n }, \n /*\n * Handle the secondary dimension. If the preferred dimension is\n * tooltip on top or bottom of the point, the second dimension is to\n * align the tooltip above the point, trying to align center but\n * allowing left or right align within the chart box.\n *\n * @private\n */\n secondDimension = function (dim, outerSize, innerSize, scaledInnerSize, // #11329\n point) {\n var retVal;\n // Too close to the edge, return false and swap dimensions\n if (point < distance || point > outerSize - distance) {\n retVal = false;\n // Align left/top\n }\n else if (point < innerSize / 2) {\n ret[dim] = 1;\n // Align right/bottom\n }\n else if (point > outerSize - scaledInnerSize / 2) {\n ret[dim] = outerSize - scaledInnerSize - 2;\n // Align center\n }\n else {\n ret[dim] = point - innerSize / 2;\n }\n return retVal;\n }, \n /*\n * Swap the dimensions\n */\n swap = function (count) {\n var temp = first;\n first = second;\n second = temp;\n swapped = count;\n }, run = function () {\n if (firstDimension.apply(0, first) !== false) {\n if (secondDimension.apply(0, second) === false &&\n !swapped) {\n swap(true);\n run();\n }\n }\n else if (!swapped) {\n swap(true);\n run();\n }\n else {\n ret.x = ret.y = 0;\n }\n };\n // Under these conditions, prefer the tooltip on the side of the point\n if (chart.inverted || this.len > 1) {\n swap();\n }\n run();\n return ret;\n };\n /**\n * Hides the tooltip with a fade out animation.\n *\n * @function Highcharts.Tooltip#hide\n *\n * @param {number} [delay]\n * The fade out in milliseconds. If no value is provided the value\n * of the tooltip.hideDelay option is used. A value of 0 disables\n * the fade out animation.\n */\n Tooltip.prototype.hide = function (delay) {\n var tooltip = this;\n // disallow duplicate timers (#1728, #1766)\n U.clearTimeout(this.hideTimer);\n delay = pick(delay, this.options.hideDelay);\n if (!this.isHidden) {\n this.hideTimer = syncTimeout(function () {\n // If there is a delay, do fadeOut with the default duration. If\n // the hideDelay is 0, we assume no animation is wanted, so we\n // pass 0 duration. #12994.\n tooltip.getLabel().fadeOut(delay ? void 0 : delay);\n tooltip.isHidden = true;\n }, delay);\n }\n };\n /**\n * @private\n * @function Highcharts.Tooltip#init\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.TooltipOptions} options\n * Tooltip options.\n */\n Tooltip.prototype.init = function (chart, options) {\n /**\n * Chart of the tooltip.\n *\n * @readonly\n * @name Highcharts.Tooltip#chart\n * @type {Highcharts.Chart}\n */\n this.chart = chart;\n /**\n * Used tooltip options.\n *\n * @readonly\n * @name Highcharts.Tooltip#options\n * @type {Highcharts.TooltipOptions}\n */\n this.options = options;\n /**\n * List of crosshairs.\n *\n * @private\n * @readonly\n * @name Highcharts.Tooltip#crosshairs\n * @type {Array}\n */\n this.crosshairs = [];\n /**\n * Current values of x and y when animating.\n *\n * @private\n * @readonly\n * @name Highcharts.Tooltip#now\n * @type {Highcharts.PositionObject}\n */\n this.now = { x: 0, y: 0 };\n /**\n * Tooltips are initially hidden.\n *\n * @private\n * @readonly\n * @name Highcharts.Tooltip#isHidden\n * @type {boolean}\n */\n this.isHidden = true;\n /**\n * True, if the tooltip is split into one label per series, with the\n * header close to the axis.\n *\n * @readonly\n * @name Highcharts.Tooltip#split\n * @type {boolean|undefined}\n */\n this.split = options.split && !chart.inverted && !chart.polar;\n /**\n * When the tooltip is shared, the entire plot area will capture mouse\n * movement or touch events.\n *\n * @readonly\n * @name Highcharts.Tooltip#shared\n * @type {boolean|undefined}\n */\n this.shared = options.shared || this.split;\n /**\n * Whether to allow the tooltip to render outside the chart's SVG\n * element box. By default (false), the tooltip is rendered within the\n * chart's SVG element, which results in the tooltip being aligned\n * inside the chart area.\n *\n * @readonly\n * @name Highcharts.Tooltip#outside\n * @type {boolean}\n *\n * @todo\n * Split tooltip does not support outside in the first iteration. Should\n * not be too complicated to implement.\n */\n this.outside = pick(options.outside, Boolean(chart.scrollablePixelsX || chart.scrollablePixelsY));\n };\n Tooltip.prototype.shouldStickOnContact = function (pointerEvent) {\n return !!(!this.followPointer &&\n this.options.stickOnContact &&\n (!pointerEvent || this.chart.pointer.inClass(pointerEvent.target, 'highcharts-tooltip')));\n };\n /**\n * Moves the tooltip with a soft animation to a new position.\n *\n * @private\n * @function Highcharts.Tooltip#move\n *\n * @param {number} x\n *\n * @param {number} y\n *\n * @param {number} anchorX\n *\n * @param {number} anchorY\n */\n Tooltip.prototype.move = function (x, y, anchorX, anchorY) {\n var tooltip = this,\n now = tooltip.now,\n animate = tooltip.options.animation !== false &&\n !tooltip.isHidden &&\n // When we get close to the target position, abort animation and\n // land on the right place (#3056)\n (Math.abs(x - now.x) > 1 || Math.abs(y - now.y) > 1),\n skipAnchor = tooltip.followPointer || tooltip.len > 1;\n // Get intermediate values for animation\n extend(now, {\n x: animate ? (2 * now.x + x) / 3 : x,\n y: animate ? (now.y + y) / 2 : y,\n anchorX: skipAnchor ?\n void 0 :\n animate ? (2 * now.anchorX + anchorX) / 3 : anchorX,\n anchorY: skipAnchor ?\n void 0 :\n animate ? (now.anchorY + anchorY) / 2 : anchorY\n });\n // Move to the intermediate value\n tooltip.getLabel().attr(now);\n tooltip.drawTracker();\n // Run on next tick of the mouse tracker\n if (animate) {\n // Never allow two timeouts\n U.clearTimeout(this.tooltipTimeout);\n // Set the fixed interval ticking for the smooth tooltip\n this.tooltipTimeout = setTimeout(function () {\n // The interval function may still be running during destroy,\n // so check that the chart is really there before calling.\n if (tooltip) {\n tooltip.move(x, y, anchorX, anchorY);\n }\n }, 32);\n }\n };\n /**\n * Refresh the tooltip's text and position.\n *\n * @function Highcharts.Tooltip#refresh\n *\n * @param {Highcharts.Point|Array} pointOrPoints\n * Either a point or an array of points.\n *\n * @param {Highcharts.PointerEventObject} [mouseEvent]\n * Mouse event, that is responsible for the refresh and should be\n * used for the tooltip update.\n */\n Tooltip.prototype.refresh = function (pointOrPoints, mouseEvent) {\n var tooltip = this,\n chart = this.chart,\n options = tooltip.options,\n points = splat(pointOrPoints),\n point = points[0],\n pointConfig = [],\n formatter = options.formatter || tooltip.defaultFormatter,\n shared = tooltip.shared,\n styledMode = chart.styledMode;\n var textConfig = {};\n if (!options.enabled || !point.series) { // #16820\n return;\n }\n U.clearTimeout(this.hideTimer);\n // A switch saying if this specific tooltip configuration allows shared\n // or split modes\n tooltip.allowShared = !(!isArray(pointOrPoints) &&\n pointOrPoints.series &&\n pointOrPoints.series.noSharedTooltip);\n // get the reference point coordinates (pie charts use tooltipPos)\n tooltip.followPointer = (!tooltip.split && point.series.tooltipOptions.followPointer);\n var anchor = tooltip.getAnchor(pointOrPoints,\n mouseEvent),\n x = anchor[0],\n y = anchor[1];\n // shared tooltip, array is sent over\n if (shared && tooltip.allowShared) {\n chart.pointer.applyInactiveState(points);\n // Now set hover state for the choosen ones:\n points.forEach(function (item) {\n item.setState('hover');\n pointConfig.push(item.getLabelConfig());\n });\n textConfig = {\n x: point.category,\n y: point.y\n };\n textConfig.points = pointConfig;\n // single point tooltip\n }\n else {\n textConfig = point.getLabelConfig();\n }\n this.len = pointConfig.length; // #6128\n var text = formatter.call(textConfig,\n tooltip);\n // register the current series\n var currentSeries = point.series;\n this.distance = pick(currentSeries.tooltipOptions.distance, 16);\n // update the inner HTML\n if (text === false) {\n this.hide();\n }\n else {\n // update text\n if (tooltip.split && tooltip.allowShared) { // #13868\n this.renderSplit(text, points);\n }\n else {\n var checkX_1 = x;\n var checkY_1 = y;\n if (mouseEvent && chart.pointer.isDirectTouch) {\n checkX_1 = mouseEvent.chartX - chart.plotLeft;\n checkY_1 = mouseEvent.chartY - chart.plotTop;\n }\n // #11493, #13095\n if (chart.polar ||\n currentSeries.options.clip === false ||\n points.some(function (p) {\n return p.series.shouldShowTooltip(checkX_1, checkY_1);\n })) {\n var label = tooltip.getLabel();\n // Prevent the tooltip from flowing over the chart box\n // (#6659)\n if (!options.style.width || styledMode) {\n label.css({\n width: this.chart.spacingBox.width + 'px'\n });\n }\n label.attr({\n text: text && text.join ?\n text.join('') :\n text\n });\n // Set the stroke color of the box to reflect the point\n label.removeClass(/highcharts-color-[\\d]+/g)\n .addClass('highcharts-color-' +\n pick(point.colorIndex, currentSeries.colorIndex));\n if (!styledMode) {\n label.attr({\n stroke: (options.borderColor ||\n point.color ||\n currentSeries.color ||\n \"#666666\" /* Palette.neutralColor60 */)\n });\n }\n tooltip.updatePosition({\n plotX: x,\n plotY: y,\n negative: point.negative,\n ttBelow: point.ttBelow,\n h: anchor[2] || 0\n });\n }\n else {\n tooltip.hide();\n return;\n }\n }\n // show it\n if (tooltip.isHidden && tooltip.label) {\n tooltip.label.attr({\n opacity: 1\n }).show();\n }\n tooltip.isHidden = false;\n }\n fireEvent(this, 'refresh');\n };\n /**\n * Render the split tooltip. Loops over each point's text and adds\n * a label next to the point, then uses the distribute function to\n * find best non-overlapping positions.\n *\n * @private\n * @function Highcharts.Tooltip#renderSplit\n *\n * @param {string|Array<(boolean|string)>} labels\n *\n * @param {Array} points\n */\n Tooltip.prototype.renderSplit = function (labels, points) {\n var tooltip = this;\n var chart = tooltip.chart,\n _a = tooltip.chart,\n chartWidth = _a.chartWidth,\n chartHeight = _a.chartHeight,\n plotHeight = _a.plotHeight,\n plotLeft = _a.plotLeft,\n plotTop = _a.plotTop,\n pointer = _a.pointer,\n _b = _a.scrollablePixelsY,\n scrollablePixelsY = _b === void 0 ? 0 : _b,\n scrollablePixelsX = _a.scrollablePixelsX,\n _c = _a.scrollingContainer,\n _d = _c === void 0 ? { scrollLeft: 0,\n scrollTop: 0 } : _c,\n scrollLeft = _d.scrollLeft,\n scrollTop = _d.scrollTop,\n styledMode = _a.styledMode,\n distance = tooltip.distance,\n options = tooltip.options,\n positioner = tooltip.options.positioner;\n // The area which the tooltip should be limited to. Limit to scrollable\n // plot area if enabled, otherwise limit to the chart container. If\n // outside is true it should be the whole viewport\n var bounds = (tooltip.outside &&\n typeof scrollablePixelsX !== 'number') ?\n doc.documentElement.getBoundingClientRect() : {\n left: scrollLeft,\n right: scrollLeft + chartWidth,\n top: scrollTop,\n bottom: scrollTop + chartHeight\n };\n var tooltipLabel = tooltip.getLabel();\n var ren = this.renderer || chart.renderer;\n var headerTop = Boolean(chart.xAxis[0] && chart.xAxis[0].opposite);\n var _e = pointer.getChartPosition(),\n chartLeft = _e.left,\n chartTop = _e.top;\n var distributionBoxTop = plotTop + scrollTop;\n var headerHeight = 0;\n var adjustedPlotHeight = plotHeight - scrollablePixelsY;\n /**\n * Calculates the anchor position for the partial tooltip\n *\n * @private\n * @param {Highcharts.Point} point The point related to the tooltip\n * @return {Object} Returns an object with anchorX and anchorY\n */\n function getAnchor(point) {\n var isHeader = point.isHeader,\n _a = point.plotX,\n plotX = _a === void 0 ? 0 : _a,\n _b = point.plotY,\n plotY = _b === void 0 ? 0 : _b,\n series = point.series;\n var anchorX;\n var anchorY;\n if (isHeader) {\n // Set anchorX to plotX\n anchorX = plotLeft + plotX;\n // Set anchorY to center of visible plot area.\n anchorY = plotTop + plotHeight / 2;\n }\n else {\n var xAxis = series.xAxis,\n yAxis = series.yAxis;\n // Set anchorX to plotX. Limit to within xAxis.\n anchorX = xAxis.pos + clamp(plotX, -distance, xAxis.len + distance);\n // Set anchorY, limit to the scrollable plot area\n if (series.shouldShowTooltip(0, yAxis.pos - plotTop + plotY, {\n ignoreX: true\n })) {\n anchorY = yAxis.pos + plotY;\n }\n }\n // Limit values to plot area\n anchorX = clamp(anchorX, bounds.left - distance, bounds.right + distance);\n return { anchorX: anchorX, anchorY: anchorY };\n }\n /**\n * Calculates the position of the partial tooltip\n *\n * @private\n * @param {number} anchorX\n * The partial tooltip anchor x position\n *\n * @param {number} anchorY\n * The partial tooltip anchor y position\n *\n * @param {boolean|undefined} isHeader\n * Whether the partial tooltip is a header\n *\n * @param {number} boxWidth\n * Width of the partial tooltip\n *\n * @return {Highcharts.PositionObject}\n * Returns the partial tooltip x and y position\n */\n function defaultPositioner(anchorX, anchorY, isHeader, boxWidth, alignedLeft) {\n if (alignedLeft === void 0) { alignedLeft = true; }\n var y;\n var x;\n if (isHeader) {\n y = headerTop ? 0 : adjustedPlotHeight;\n x = clamp(anchorX - (boxWidth / 2), bounds.left, bounds.right - boxWidth - (tooltip.outside ? chartLeft : 0));\n }\n else {\n y = anchorY - distributionBoxTop;\n x = alignedLeft ?\n anchorX - boxWidth - distance :\n anchorX + distance;\n x = clamp(x, alignedLeft ? x : bounds.left, bounds.right);\n }\n // NOTE: y is relative to distributionBoxTop\n return { x: x, y: y };\n }\n /**\n * Updates the attributes and styling of the partial tooltip. Creates a\n * new partial tooltip if it does not exists.\n *\n * @private\n * @param {Highcharts.SVGElement|undefined} partialTooltip\n * The partial tooltip to update\n * @param {Highcharts.Point} point\n * The point related to the partial tooltip\n * @param {boolean|string} str The text for the partial tooltip\n * @return {Highcharts.SVGElement} Returns the updated partial tooltip\n */\n function updatePartialTooltip(partialTooltip, point, str) {\n var tt = partialTooltip;\n var isHeader = point.isHeader,\n series = point.series;\n var colorClass = 'highcharts-color-' + pick(point.colorIndex, series.colorIndex, 'none');\n if (!tt) {\n var attribs = {\n padding: options.padding,\n r: options.borderRadius\n };\n if (!styledMode) {\n attribs.fill = options.backgroundColor;\n attribs['stroke-width'] = options.borderWidth;\n }\n tt = ren\n .label('', 0, 0, (options[isHeader ? 'headerShape' : 'shape']), void 0, void 0, options.useHTML)\n .addClass((isHeader ? 'highcharts-tooltip-header ' : '') +\n 'highcharts-tooltip-box ' +\n colorClass)\n .attr(attribs)\n .add(tooltipLabel);\n }\n tt.isActive = true;\n tt.attr({\n text: str\n });\n if (!styledMode) {\n tt.css(options.style)\n .shadow(options.shadow)\n .attr({\n stroke: (options.borderColor ||\n point.color ||\n series.color ||\n \"#333333\" /* Palette.neutralColor80 */)\n });\n }\n return tt;\n }\n // Graceful degradation for legacy formatters\n if (isString(labels)) {\n labels = [false, labels];\n }\n // Create the individual labels for header and points, ignore footer\n var boxes = labels.slice(0,\n points.length + 1).reduce(function (boxes,\n str,\n i) {\n if (str !== false && str !== '') {\n var point = (points[i - 1] ||\n {\n // Item 0 is the header. Instead of this, we could also\n // use the crosshair label\n isHeader: true,\n plotX: points[0].plotX,\n plotY: plotHeight,\n series: {}\n });\n var isHeader = point.isHeader;\n // Store the tooltip label referance on the series\n var owner = isHeader ? tooltip : point.series;\n var tt = owner.tt = updatePartialTooltip(owner.tt,\n point,\n str.toString());\n // Get X position now, so we can move all to the other side in\n // case of overflow\n var bBox = tt.getBBox();\n var boxWidth = bBox.width + tt.strokeWidth();\n if (isHeader) {\n headerHeight = bBox.height;\n adjustedPlotHeight += headerHeight;\n if (headerTop) {\n distributionBoxTop -= headerHeight;\n }\n }\n var _a = getAnchor(point),\n anchorX = _a.anchorX,\n anchorY = _a.anchorY;\n if (typeof anchorY === 'number') {\n var size = bBox.height + 1;\n var boxPosition = (positioner ?\n positioner.call(tooltip,\n boxWidth,\n size,\n point) :\n defaultPositioner(anchorX,\n anchorY,\n isHeader,\n boxWidth));\n boxes.push({\n // 0-align to the top, 1-align to the bottom\n align: positioner ? 0 : void 0,\n anchorX: anchorX,\n anchorY: anchorY,\n boxWidth: boxWidth,\n point: point,\n rank: pick(boxPosition.rank, isHeader ? 1 : 0),\n size: size,\n target: boxPosition.y,\n tt: tt,\n x: boxPosition.x\n });\n }\n else {\n // Hide tooltips which anchorY is outside the visible plot\n // area\n tt.isActive = false;\n }\n }\n return boxes;\n }, []);\n // Realign the tooltips towards the right if there is not enough space\n // to the left and there is space to to the right\n if (!positioner && boxes.some(function (box) {\n // Always realign if the beginning of a label is outside bounds\n var outside = tooltip.outside;\n var boxStart = (outside ? chartLeft : 0) + box.anchorX;\n if (boxStart < bounds.left &&\n boxStart + box.boxWidth < bounds.right) {\n return true;\n }\n // Otherwise, check if there is more space available to the right\n return boxStart < (chartLeft - bounds.left) + box.boxWidth &&\n bounds.right - boxStart > boxStart;\n })) {\n boxes = boxes.map(function (box) {\n var _a = defaultPositioner(box.anchorX,\n box.anchorY,\n box.point.isHeader,\n box.boxWidth,\n false),\n x = _a.x,\n y = _a.y;\n return extend(box, {\n target: y,\n x: x\n });\n });\n }\n // Clean previous run (for missing points)\n tooltip.cleanSplit();\n // Distribute and put in place\n distribute(boxes, adjustedPlotHeight);\n var boxExtremes = {\n left: chartLeft,\n right: chartLeft\n };\n // Get the extremes from series tooltips\n boxes.forEach(function (box) {\n var x = box.x,\n boxWidth = box.boxWidth,\n isHeader = box.isHeader;\n if (!isHeader) {\n if (tooltip.outside && chartLeft + x < boxExtremes.left) {\n boxExtremes.left = chartLeft + x;\n }\n if (!isHeader &&\n tooltip.outside &&\n boxExtremes.left + boxWidth > boxExtremes.right) {\n boxExtremes.right = chartLeft + x;\n }\n }\n });\n boxes.forEach(function (box) {\n var x = box.x,\n anchorX = box.anchorX,\n anchorY = box.anchorY,\n pos = box.pos,\n isHeader = box.point.isHeader;\n var attributes = {\n visibility: typeof pos === 'undefined' ? 'hidden' : 'inherit',\n x: x,\n /* NOTE: y should equal pos to be consistent with !split\n * tooltip,\n but is currently relative to plotTop. Is left as is\n * to avoid breaking change. Remove distributionBoxTop to make\n * it consistent.\n */\n y: pos + distributionBoxTop,\n anchorX: anchorX,\n anchorY: anchorY\n };\n // Handle left-aligned tooltips overflowing the chart area\n if (tooltip.outside && x < anchorX) {\n var offset = chartLeft - boxExtremes.left;\n // Skip this if there is no overflow\n if (offset > 0) {\n if (!isHeader) {\n attributes.x = x + offset;\n attributes.anchorX = anchorX + offset;\n }\n if (isHeader) {\n attributes.x = (boxExtremes.right - boxExtremes.left) / 2;\n attributes.anchorX = anchorX + offset;\n }\n }\n }\n // Put the label in place\n box.tt.attr(attributes);\n });\n /* If we have a seperate tooltip container, then update the necessary\n * container properties.\n * Test that tooltip has its own container and renderer before executing\n * the operation.\n */\n var container = tooltip.container,\n outside = tooltip.outside,\n renderer = tooltip.renderer;\n if (outside && container && renderer) {\n // Set container size to fit the bounds\n var _f = tooltipLabel.getBBox(),\n width = _f.width,\n height = _f.height,\n x = _f.x,\n y = _f.y;\n renderer.setSize(width + x, height + y, false);\n // Position the tooltip container to the chart container\n container.style.left = boxExtremes.left + 'px';\n container.style.top = chartTop + 'px';\n }\n };\n /**\n * If the `stickOnContact` option is active, this will add a tracker shape.\n *\n * @private\n * @function Highcharts.Tooltip#drawTracker\n */\n Tooltip.prototype.drawTracker = function () {\n var tooltip = this;\n if (!this.shouldStickOnContact()) {\n if (tooltip.tracker) {\n tooltip.tracker.destroy();\n }\n return;\n }\n var chart = tooltip.chart;\n var label = tooltip.label;\n var points = tooltip.shared ? chart.hoverPoints : chart.hoverPoint;\n if (!label || !points) {\n return;\n }\n var box = {\n x: 0,\n y: 0,\n width: 0,\n height: 0\n };\n // Combine anchor and tooltip\n var anchorPos = this.getAnchor(points);\n var labelBBox = label.getBBox();\n anchorPos[0] += chart.plotLeft - label.translateX;\n anchorPos[1] += chart.plotTop - label.translateY;\n // When the mouse pointer is between the anchor point and the label,\n // the label should stick.\n box.x = Math.min(0, anchorPos[0]);\n box.y = Math.min(0, anchorPos[1]);\n box.width = (anchorPos[0] < 0 ?\n Math.max(Math.abs(anchorPos[0]), (labelBBox.width - anchorPos[0])) :\n Math.max(Math.abs(anchorPos[0]), labelBBox.width));\n box.height = (anchorPos[1] < 0 ?\n Math.max(Math.abs(anchorPos[1]), (labelBBox.height - Math.abs(anchorPos[1]))) :\n Math.max(Math.abs(anchorPos[1]), labelBBox.height));\n if (tooltip.tracker) {\n tooltip.tracker.attr(box);\n }\n else {\n tooltip.tracker = label.renderer\n .rect(box)\n .addClass('highcharts-tracker')\n .add(label);\n if (!chart.styledMode) {\n tooltip.tracker.attr({\n fill: 'rgba(0,0,0,0)'\n });\n }\n }\n };\n /**\n * @private\n */\n Tooltip.prototype.styledModeFormat = function (formatString) {\n return formatString\n .replace('style=\"font-size: 10px\"', 'class=\"highcharts-header\"')\n .replace(/style=\"color:{(point|series)\\.color}\"/g, 'class=\"highcharts-color-{$1.colorIndex}\"');\n };\n /**\n * Format the footer/header of the tooltip\n * #3397: abstraction to enable formatting of footer and header\n *\n * @private\n * @function Highcharts.Tooltip#tooltipFooterHeaderFormatter\n */\n Tooltip.prototype.tooltipFooterHeaderFormatter = function (labelConfig, isFooter) {\n var series = labelConfig.series,\n tooltipOptions = series.tooltipOptions,\n xAxis = series.xAxis,\n dateTime = xAxis && xAxis.dateTime,\n e = {\n isFooter: isFooter,\n labelConfig: labelConfig\n };\n var xDateFormat = tooltipOptions.xDateFormat,\n formatString = tooltipOptions[isFooter ? 'footerFormat' : 'headerFormat'];\n fireEvent(this, 'headerFormatter', e, function (e) {\n // Guess the best date format based on the closest point distance\n // (#568, #3418)\n if (dateTime && !xDateFormat && isNumber(labelConfig.key)) {\n xDateFormat = dateTime.getXDateFormat(labelConfig.key, tooltipOptions.dateTimeLabelFormats);\n }\n // Insert the footer date format if any\n if (dateTime && xDateFormat) {\n ((labelConfig.point && labelConfig.point.tooltipDateKeys) ||\n ['key']).forEach(function (key) {\n formatString = formatString.replace('{point.' + key + '}', '{point.' + key + ':' + xDateFormat + '}');\n });\n }\n // Replace default header style with class name\n if (series.chart.styledMode) {\n formatString = this.styledModeFormat(formatString);\n }\n e.text = format(formatString, {\n point: labelConfig,\n series: series\n }, this.chart);\n });\n return e.text;\n };\n /**\n * Updates the tooltip with the provided tooltip options.\n *\n * @function Highcharts.Tooltip#update\n *\n * @param {Highcharts.TooltipOptions} options\n * The tooltip options to update.\n */\n Tooltip.prototype.update = function (options) {\n this.destroy();\n // Update user options (#6218)\n merge(true, this.chart.options.tooltip.userOptions, options);\n this.init(this.chart, merge(true, this.options, options));\n };\n /**\n * Find the new position and perform the move\n *\n * @private\n * @function Highcharts.Tooltip#updatePosition\n *\n * @param {Highcharts.Point} point\n */\n Tooltip.prototype.updatePosition = function (point) {\n var chart = this.chart,\n options = this.options,\n pointer = chart.pointer,\n label = this.getLabel(), \n // Needed for outside: true (#11688)\n chartPosition = pointer.getChartPosition(),\n pos = (options.positioner || this.getPosition).call(this,\n label.width,\n label.height,\n point);\n var anchorX = point.plotX + chart.plotLeft,\n anchorY = point.plotY + chart.plotTop,\n pad;\n // Set the renderer size dynamically to prevent document size to change\n if (this.outside) {\n pad = options.borderWidth + 2 * this.distance;\n this.renderer.setSize(label.width + pad, label.height + pad, false);\n // Anchor and tooltip container need scaling if chart container has\n // scale transform/css zoom. #11329.\n if (chartPosition.scaleX !== 1 || chartPosition.scaleY !== 1) {\n css(this.container, {\n transform: \"scale(\".concat(chartPosition.scaleX, \", \").concat(chartPosition.scaleY, \")\")\n });\n anchorX *= chartPosition.scaleX;\n anchorY *= chartPosition.scaleY;\n }\n anchorX += chartPosition.left - pos.x;\n anchorY += chartPosition.top - pos.y;\n }\n // do the move\n this.move(Math.round(pos.x), Math.round(pos.y || 0), // can be undefined (#3977)\n anchorX, anchorY);\n };\n return Tooltip;\n }());\n /* *\n *\n * Default export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Callback function to format the text of the tooltip from scratch.\n *\n * In case of single or shared tooltips, a string should be be returned. In case\n * of splitted tooltips, it should return an array where the first item is the\n * header, and subsequent items are mapped to the points. Return `false` to\n * disable tooltip for a specific point on series.\n *\n * @callback Highcharts.TooltipFormatterCallbackFunction\n *\n * @param {Highcharts.TooltipFormatterContextObject} this\n * Context to format\n *\n * @param {Highcharts.Tooltip} tooltip\n * The tooltip instance\n *\n * @return {false|string|Array<(string|null|undefined)>|null|undefined}\n * Formatted text or false\n */\n /**\n * Configuration for the tooltip formatters.\n *\n * @interface Highcharts.TooltipFormatterContextObject\n * @extends Highcharts.PointLabelObject\n */ /**\n * Array of points in shared tooltips.\n * @name Highcharts.TooltipFormatterContextObject#points\n * @type {Array|undefined}\n */\n /**\n * A callback function to place the tooltip in a specific position.\n *\n * @callback Highcharts.TooltipPositionerCallbackFunction\n *\n * @param {Highcharts.Tooltip} this\n * Tooltip context of the callback.\n *\n * @param {number} labelWidth\n * Width of the tooltip.\n *\n * @param {number} labelHeight\n * Height of the tooltip.\n *\n * @param {Highcharts.TooltipPositionerPointObject} point\n * Point information for positioning a tooltip.\n *\n * @return {Highcharts.PositionObject}\n * New position for the tooltip.\n */\n /**\n * Point information for positioning a tooltip.\n *\n * @interface Highcharts.TooltipPositionerPointObject\n * @extends Highcharts.Point\n */ /**\n * If `tooltip.split` option is enabled and positioner is called for each of the\n * boxes separately, this property indicates the call on the xAxis header, which\n * is not a point itself.\n * @name Highcharts.TooltipPositionerPointObject#isHeader\n * @type {boolean}\n */ /**\n * The reference point relative to the plot area. Add chart.plotLeft to get the\n * full coordinates.\n * @name Highcharts.TooltipPositionerPointObject#plotX\n * @type {number}\n */ /**\n * The reference point relative to the plot area. Add chart.plotTop to get the\n * full coordinates.\n * @name Highcharts.TooltipPositionerPointObject#plotY\n * @type {number}\n */\n /**\n * @typedef {\"callout\"|\"circle\"|\"square\"} Highcharts.TooltipShapeValue\n */\n ''; // keeps doclets above in JS file\n\n return Tooltip;\n });\n _registerModule(_modules, 'Core/Series/Point.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Defaults.js'], _modules['Core/FormatUtilities.js'], _modules['Core/Utilities.js']], function (AST, A, D, F, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var animObject = A.animObject;\n var defaultOptions = D.defaultOptions;\n var format = F.format;\n var addEvent = U.addEvent,\n defined = U.defined,\n erase = U.erase,\n extend = U.extend,\n fireEvent = U.fireEvent,\n getNestedProperty = U.getNestedProperty,\n isArray = U.isArray,\n isFunction = U.isFunction,\n isNumber = U.isNumber,\n isObject = U.isObject,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick,\n syncTimeout = U.syncTimeout,\n removeEvent = U.removeEvent,\n uniqueKey = U.uniqueKey;\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /* *\n *\n * Class\n *\n * */\n /**\n * The Point object. The point objects are generated from the `series.data`\n * configuration objects or raw numbers. They can be accessed from the\n * `Series.points` array. Other ways to instantiate points are through {@link\n * Highcharts.Series#addPoint} or {@link Highcharts.Series#setData}.\n *\n * @class\n * @name Highcharts.Point\n */\n var Point = /** @class */ (function () {\n function Point() {\n /* *\n *\n * Properties\n *\n * */\n /**\n * For categorized axes this property holds the category name for the\n * point. For other axes it holds the X value.\n *\n * @name Highcharts.Point#category\n * @type {number|string}\n */\n this.category = void 0;\n /**\n * The point's current color index, used in styled mode instead of\n * `color`. The color index is inserted in class names used for styling.\n *\n * @name Highcharts.Point#colorIndex\n * @type {number}\n */\n this.colorIndex = void 0;\n this.formatPrefix = 'point';\n this.id = void 0;\n this.isNull = false;\n /**\n * The name of the point. The name can be given as the first position of the\n * point configuration array, or as a `name` property in the configuration:\n *\n * @example\n * // Array config\n * data: [\n * ['John', 1],\n * ['Jane', 2]\n * ]\n *\n * // Object config\n * data: [{\n * name: 'John',\n * y: 1\n * }, {\n * name: 'Jane',\n * y: 2\n * }]\n *\n * @name Highcharts.Point#name\n * @type {string}\n */\n this.name = void 0;\n /**\n * The point's options as applied in the initial configuration, or\n * extended through `Point.update`.\n *\n * In TypeScript you have to extend `PointOptionsObject` via an\n * additional interface to allow custom data options:\n *\n * ```\n * declare interface PointOptionsObject {\n * customProperty: string;\n * }\n * ```\n *\n * @name Highcharts.Point#options\n * @type {Highcharts.PointOptionsObject}\n */\n this.options = void 0;\n /**\n * The percentage for points in a stacked series or pies.\n *\n * @name Highcharts.Point#percentage\n * @type {number|undefined}\n */\n this.percentage = void 0;\n this.selected = false;\n /**\n * The series object associated with the point.\n *\n * @name Highcharts.Point#series\n * @type {Highcharts.Series}\n */\n this.series = void 0;\n /**\n * The attributes of the rendered SVG shape like in `column` or `pie`\n * series.\n *\n * @readonly\n * @name Highcharts.Point#shapeArgs\n * @type {Readonly|undefined}\n */\n this.shapeArgs = void 0;\n /**\n * The total of values in either a stack for stacked series, or a pie in a\n * pie series.\n *\n * @name Highcharts.Point#total\n * @type {number|undefined}\n */\n this.total = void 0;\n /**\n * For certain series types, like pie charts, where individual points can\n * be shown or hidden.\n *\n * @name Highcharts.Point#visible\n * @type {boolean}\n * @default true\n */\n this.visible = true;\n this.x = void 0;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Animate SVG elements associated with the point.\n *\n * @private\n * @function Highcharts.Point#animateBeforeDestroy\n */\n Point.prototype.animateBeforeDestroy = function () {\n var point = this,\n animateParams = { x: point.startXPos,\n opacity: 0 },\n graphicalProps = point.getGraphicalProps();\n graphicalProps.singular.forEach(function (prop) {\n var isDataLabel = prop === 'dataLabel';\n point[prop] = point[prop].animate(isDataLabel ? {\n x: point[prop].startXPos,\n y: point[prop].startYPos,\n opacity: 0\n } : animateParams);\n });\n graphicalProps.plural.forEach(function (plural) {\n point[plural].forEach(function (item) {\n if (item.element) {\n item.animate(extend({ x: point.startXPos }, (item.startYPos ? {\n x: item.startXPos,\n y: item.startYPos\n } : {})));\n }\n });\n });\n };\n /**\n * Apply the options containing the x and y data and possible some extra\n * properties. Called on point init or from point.update.\n *\n * @private\n * @function Highcharts.Point#applyOptions\n *\n * @param {Highcharts.PointOptionsType} options\n * The point options as defined in series.data.\n *\n * @param {number} [x]\n * Optionally, the x value.\n *\n * @return {Highcharts.Point}\n * The Point instance.\n */\n Point.prototype.applyOptions = function (options, x) {\n var point = this,\n series = point.series,\n pointValKey = series.options.pointValKey || series.pointValKey;\n options = Point.prototype.optionsToObject.call(this, options);\n // copy options directly to point\n extend(point, options);\n point.options = point.options ?\n extend(point.options, options) :\n options;\n // Since options are copied into the Point instance, some accidental\n // options must be shielded (#5681)\n if (options.group) {\n delete point.group;\n }\n if (options.dataLabels) {\n delete point.dataLabels;\n }\n /**\n * The y value of the point.\n * @name Highcharts.Point#y\n * @type {number|undefined}\n */\n // For higher dimension series types. For instance, for ranges, point.y\n // is mapped to point.low.\n if (pointValKey) {\n point.y = Point.prototype.getNestedProperty.call(point, pointValKey);\n }\n point.isNull = this.isValid && !this.isValid();\n point.formatPrefix = point.isNull ? 'null' : 'point'; // #9233, #10874\n // The point is initially selected by options (#5777)\n if (point.selected) {\n point.state = 'select';\n }\n /**\n * The x value of the point.\n * @name Highcharts.Point#x\n * @type {number}\n */\n // If no x is set by now, get auto incremented value. All points must\n // have an x value, however the y value can be null to create a gap in\n // the series\n if ('name' in point &&\n typeof x === 'undefined' &&\n series.xAxis &&\n series.xAxis.hasNames) {\n point.x = series.xAxis.nameToX(point);\n }\n if (typeof point.x === 'undefined' && series) {\n if (typeof x === 'undefined') {\n point.x = series.autoIncrement();\n }\n else {\n point.x = x;\n }\n }\n else if (isNumber(options.x) && series.options.relativeXValue) {\n point.x = series.autoIncrement(options.x);\n }\n return point;\n };\n /**\n * Destroy a point to clear memory. Its reference still stays in\n * `series.data`.\n *\n * @private\n * @function Highcharts.Point#destroy\n */\n Point.prototype.destroy = function () {\n var point = this,\n series = point.series,\n chart = series.chart,\n dataSorting = series.options.dataSorting,\n hoverPoints = chart.hoverPoints,\n globalAnimation = point.series.chart.renderer.globalAnimation,\n animation = animObject(globalAnimation);\n var prop;\n /**\n * Allow to call after animation.\n * @private\n */\n function destroyPoint() {\n // Remove all events and elements\n if (point.graphic ||\n point.graphics ||\n point.dataLabel ||\n point.dataLabels) {\n removeEvent(point);\n point.destroyElements();\n }\n for (prop in point) { // eslint-disable-line guard-for-in\n point[prop] = null;\n }\n }\n if (point.legendItem) {\n // pies have legend items\n chart.legend.destroyItem(point);\n }\n if (hoverPoints) {\n point.setState();\n erase(hoverPoints, point);\n if (!hoverPoints.length) {\n chart.hoverPoints = null;\n }\n }\n if (point === chart.hoverPoint) {\n point.onMouseOut();\n }\n // Remove properties after animation\n if (!dataSorting || !dataSorting.enabled) {\n destroyPoint();\n }\n else {\n this.animateBeforeDestroy();\n syncTimeout(destroyPoint, animation.duration);\n }\n chart.pointCount--;\n };\n /**\n * Destroy SVG elements associated with the point.\n *\n * @private\n * @function Highcharts.Point#destroyElements\n * @param {Highcharts.Dictionary} [kinds]\n */\n Point.prototype.destroyElements = function (kinds) {\n var point = this,\n props = point.getGraphicalProps(kinds);\n props.singular.forEach(function (prop) {\n point[prop] = point[prop].destroy();\n });\n props.plural.forEach(function (plural) {\n point[plural].forEach(function (item) {\n if (item.element) {\n item.destroy();\n }\n });\n delete point[plural];\n });\n };\n /**\n * Fire an event on the Point object.\n *\n * @private\n * @function Highcharts.Point#firePointEvent\n *\n * @param {string} eventType\n * Type of the event.\n *\n * @param {Highcharts.Dictionary|Event} [eventArgs]\n * Additional event arguments.\n *\n * @param {Highcharts.EventCallbackFunction|Function} [defaultFunction]\n * Default event handler.\n *\n * @emits Highcharts.Point#event:*\n */\n Point.prototype.firePointEvent = function (eventType, eventArgs, defaultFunction) {\n var point = this,\n series = this.series,\n seriesOptions = series.options;\n // load event handlers on demand to save time on mouseover/out\n if (seriesOptions.point.events[eventType] ||\n (point.options &&\n point.options.events &&\n point.options.events[eventType])) {\n point.importEvents();\n }\n // add default handler if in selection mode\n if (eventType === 'click' && seriesOptions.allowPointSelect) {\n defaultFunction = function (event) {\n // Control key is for Windows, meta (= Cmd key) for Mac, Shift\n // for Opera.\n if (point.select) { // #2911\n point.select(null, event.ctrlKey || event.metaKey || event.shiftKey);\n }\n };\n }\n fireEvent(point, eventType, eventArgs, defaultFunction);\n };\n /**\n * Get the CSS class names for individual points. Used internally where the\n * returned value is set on every point.\n *\n * @function Highcharts.Point#getClassName\n *\n * @return {string}\n * The class names.\n */\n Point.prototype.getClassName = function () {\n var point = this;\n return 'highcharts-point' +\n (point.selected ? ' highcharts-point-select' : '') +\n (point.negative ? ' highcharts-negative' : '') +\n (point.isNull ? ' highcharts-null-point' : '') +\n (typeof point.colorIndex !== 'undefined' ?\n ' highcharts-color-' + point.colorIndex : '') +\n (point.options.className ? ' ' + point.options.className : '') +\n (point.zone && point.zone.className ? ' ' +\n point.zone.className.replace('highcharts-negative', '') : '');\n };\n /**\n * Get props of all existing graphical point elements.\n *\n * @private\n * @function Highcharts.Point#getGraphicalProps\n */\n Point.prototype.getGraphicalProps = function (kinds) {\n var point = this,\n props = [],\n graphicalProps = { singular: [],\n plural: [] };\n var prop,\n i;\n kinds = kinds || { graphic: 1, dataLabel: 1 };\n if (kinds.graphic) {\n props.push('graphic', 'shadowGroup');\n }\n if (kinds.dataLabel) {\n props.push('dataLabel', 'dataLabelPath', 'dataLabelUpper', 'connector');\n }\n i = props.length;\n while (i--) {\n prop = props[i];\n if (point[prop]) {\n graphicalProps.singular.push(prop);\n }\n }\n [\n 'graphic',\n 'dataLabel',\n 'connector'\n ].forEach(function (prop) {\n var plural = prop + 's';\n if (kinds[prop] && point[plural]) {\n graphicalProps.plural.push(plural);\n }\n });\n return graphicalProps;\n };\n /**\n * Return the configuration hash needed for the data label and tooltip\n * formatters.\n *\n * @function Highcharts.Point#getLabelConfig\n *\n * @return {Highcharts.PointLabelObject}\n * Abstract object used in formatters and formats.\n */\n Point.prototype.getLabelConfig = function () {\n return {\n x: this.category,\n y: this.y,\n color: this.color,\n colorIndex: this.colorIndex,\n key: this.name || this.category,\n series: this.series,\n point: this,\n percentage: this.percentage,\n total: this.total || this.stackTotal\n };\n };\n /**\n * Returns the value of the point property for a given value.\n * @private\n */\n Point.prototype.getNestedProperty = function (key) {\n if (!key) {\n return;\n }\n if (key.indexOf('custom.') === 0) {\n return getNestedProperty(key, this.options);\n }\n return this[key];\n };\n /**\n * In a series with `zones`, return the zone that the point belongs to.\n *\n * @function Highcharts.Point#getZone\n *\n * @return {Highcharts.SeriesZonesOptionsObject}\n * The zone item.\n */\n Point.prototype.getZone = function () {\n var series = this.series,\n zones = series.zones,\n zoneAxis = series.zoneAxis || 'y';\n var zone,\n i = 0;\n zone = zones[i];\n while (this[zoneAxis] >= zone.value) {\n zone = zones[++i];\n }\n // For resetting or reusing the point (#8100)\n if (!this.nonZonedColor) {\n this.nonZonedColor = this.color;\n }\n if (zone && zone.color && !this.options.color) {\n this.color = zone.color;\n }\n else {\n this.color = this.nonZonedColor;\n }\n return zone;\n };\n /**\n * Utility to check if point has new shape type. Used in column series and\n * all others that are based on column series.\n * @private\n */\n Point.prototype.hasNewShapeType = function () {\n var point = this;\n var oldShapeType = point.graphic &&\n (point.graphic.symbolName || point.graphic.element.nodeName);\n return oldShapeType !== this.shapeType;\n };\n /**\n * Initialize the point. Called internally based on the `series.data`\n * option.\n *\n * @function Highcharts.Point#init\n *\n * @param {Highcharts.Series} series\n * The series object containing this point.\n *\n * @param {Highcharts.PointOptionsType} options\n * The data in either number, array or object format.\n *\n * @param {number} [x]\n * Optionally, the X value of the point.\n *\n * @return {Highcharts.Point}\n * The Point instance.\n *\n * @emits Highcharts.Point#event:afterInit\n */\n Point.prototype.init = function (series, options, x) {\n this.series = series;\n this.applyOptions(options, x);\n // Add a unique ID to the point if none is assigned\n this.id = defined(this.id) ? this.id : uniqueKey();\n this.resolveColor();\n series.chart.pointCount++;\n fireEvent(this, 'afterInit');\n return this;\n };\n /**\n * Determine if point is valid.\n * @private\n * @function Highcharts.Point#isValid\n */\n Point.prototype.isValid = function () {\n return this.x !== null && isNumber(this.y);\n };\n /**\n * Transform number or array configs into objects. Also called for object\n * configs. Used internally to unify the different configuration formats for\n * points. For example, a simple number `10` in a line series will be\n * transformed to `{ y: 10 }`, and an array config like `[1, 10]` in a\n * scatter series will be transformed to `{ x: 1, y: 10 }`.\n *\n * @deprecated\n * @function Highcharts.Point#optionsToObject\n *\n * @param {Highcharts.PointOptionsType} options\n * Series data options.\n *\n * @return {Highcharts.Dictionary<*>}\n * Transformed point options.\n */\n Point.prototype.optionsToObject = function (options) {\n var series = this.series,\n keys = series.options.keys,\n pointArrayMap = keys || series.pointArrayMap || ['y'],\n valueCount = pointArrayMap.length;\n var ret = {},\n firstItemType,\n i = 0,\n j = 0;\n if (isNumber(options) || options === null) {\n ret[pointArrayMap[0]] = options;\n }\n else if (isArray(options)) {\n // with leading x value\n if (!keys && options.length > valueCount) {\n firstItemType = typeof options[0];\n if (firstItemType === 'string') {\n ret.name = options[0];\n }\n else if (firstItemType === 'number') {\n ret.x = options[0];\n }\n i++;\n }\n while (j < valueCount) {\n // Skip undefined positions for keys\n if (!keys || typeof options[i] !== 'undefined') {\n if (pointArrayMap[j].indexOf('.') > 0) {\n // Handle nested keys, e.g. ['color.pattern.image']\n // Avoid function call unless necessary.\n Point.prototype.setNestedProperty(ret, options[i], pointArrayMap[j]);\n }\n else {\n ret[pointArrayMap[j]] = options[i];\n }\n }\n i++;\n j++;\n }\n }\n else if (typeof options === 'object') {\n ret = options;\n // This is the fastest way to detect if there are individual point\n // dataLabels that need to be considered in drawDataLabels. These\n // can only occur in object configs.\n if (options.dataLabels) {\n series._hasPointLabels = true;\n }\n // Same approach as above for markers\n if (options.marker) {\n series._hasPointMarkers = true;\n }\n }\n return ret;\n };\n /**\n * @private\n * @function Highcharts.Point#resolveColor\n */\n Point.prototype.resolveColor = function () {\n var series = this.series,\n optionsChart = series.chart.options.chart,\n styledMode = series.chart.styledMode;\n var color,\n colors,\n colorCount = optionsChart.colorCount,\n colorIndex;\n // remove points nonZonedColor for later recalculation\n delete this.nonZonedColor;\n if (series.options.colorByPoint) {\n if (!styledMode) {\n colors = series.options.colors || series.chart.options.colors;\n color = colors[series.colorCounter];\n colorCount = colors.length;\n }\n colorIndex = series.colorCounter;\n series.colorCounter++;\n // loop back to zero\n if (series.colorCounter === colorCount) {\n series.colorCounter = 0;\n }\n }\n else {\n if (!styledMode) {\n color = series.color;\n }\n colorIndex = series.colorIndex;\n }\n this.colorIndex = pick(this.options.colorIndex, colorIndex);\n /**\n * The point's current color.\n *\n * @name Highcharts.Point#color\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject|undefined}\n */\n this.color = pick(this.options.color, color);\n };\n /**\n * Set a value in an object, on the property defined by key. The key\n * supports nested properties using dot notation. The function modifies the\n * input object and does not make a copy.\n *\n * @function Highcharts.Point#setNestedProperty\n *\n * @param {T} object\n * The object to set the value on.\n *\n * @param {*} value\n * The value to set.\n *\n * @param {string} key\n * Key to the property to set.\n *\n * @return {T}\n * The modified object.\n */\n Point.prototype.setNestedProperty = function (object, value, key) {\n var nestedKeys = key.split('.');\n nestedKeys.reduce(function (result, key, i, arr) {\n var isLastKey = arr.length - 1 === i;\n result[key] = (isLastKey ?\n value :\n isObject(result[key], true) ?\n result[key] :\n {});\n return result[key];\n }, object);\n return object;\n };\n Point.prototype.shouldDraw = function () {\n return !this.isNull;\n };\n /**\n * Extendable method for formatting each point's tooltip line.\n *\n * @function Highcharts.Point#tooltipFormatter\n *\n * @param {string} pointFormat\n * The point format.\n *\n * @return {string}\n * A string to be concatenated in to the common tooltip text.\n */\n Point.prototype.tooltipFormatter = function (pointFormat) {\n // Insert options for valueDecimals, valuePrefix, and valueSuffix\n var series = this.series, seriesTooltipOptions = series.tooltipOptions, valueDecimals = pick(seriesTooltipOptions.valueDecimals, ''), valuePrefix = seriesTooltipOptions.valuePrefix || '', valueSuffix = seriesTooltipOptions.valueSuffix || '';\n // Replace default point style with class name\n if (series.chart.styledMode) {\n pointFormat =\n series.chart.tooltip.styledModeFormat(pointFormat);\n }\n // Loop over the point array map and replace unformatted values with\n // sprintf formatting markup\n (series.pointArrayMap || ['y']).forEach(function (key) {\n key = '{point.' + key; // without the closing bracket\n if (valuePrefix || valueSuffix) {\n pointFormat = pointFormat.replace(RegExp(key + '}', 'g'), valuePrefix + key + '}' + valueSuffix);\n }\n pointFormat = pointFormat.replace(RegExp(key + '}', 'g'), key + ':,.' + valueDecimals + 'f}');\n });\n return format(pointFormat, {\n point: this,\n series: this.series\n }, series.chart);\n };\n /**\n * Update point with new options (typically x/y data) and optionally redraw\n * the series.\n *\n * @sample highcharts/members/point-update-column/\n * Update column value\n * @sample highcharts/members/point-update-pie/\n * Update pie slice\n * @sample maps/members/point-update/\n * Update map area value in Highmaps\n *\n * @function Highcharts.Point#update\n *\n * @param {Highcharts.PointOptionsType} options\n * The point options. Point options are handled as described under\n * the `series.type.data` item for each series type. For example\n * for a line series, if options is a single number, the point will\n * be given that number as the marin y value. If it is an array, it\n * will be interpreted as x and y values respectively. If it is an\n * object, advanced options are applied.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the point is updated. If doing\n * more operations on the chart, it is best practice to set\n * `redraw` to false and call `chart.redraw()` after.\n *\n * @param {boolean|Partial} [animation=true]\n * Whether to apply animation, and optionally animation\n * configuration.\n *\n * @emits Highcharts.Point#event:update\n */\n Point.prototype.update = function (options, redraw, animation, runEvent) {\n var point = this,\n series = point.series,\n graphic = point.graphic,\n chart = series.chart,\n seriesOptions = series.options;\n var i;\n redraw = pick(redraw, true);\n /**\n * @private\n */\n function update() {\n point.applyOptions(options);\n // Update visuals, #4146\n // Handle mock graphic elements for a11y, #12718\n var hasMockGraphic = graphic && point.hasMockGraphic;\n var shouldDestroyGraphic = point.y === null ?\n !hasMockGraphic :\n hasMockGraphic;\n if (graphic && shouldDestroyGraphic) {\n point.graphic = graphic.destroy();\n delete point.hasMockGraphic;\n }\n if (isObject(options, true)) {\n // Destroy so we can get new elements\n if (graphic && graphic.element) {\n // \"null\" is also a valid symbol\n if (options &&\n options.marker &&\n typeof options.marker.symbol !== 'undefined') {\n point.graphic = graphic.destroy();\n }\n }\n if (options && options.dataLabels && point.dataLabel) {\n point.dataLabel = point.dataLabel.destroy(); // #2468\n }\n if (point.connector) {\n point.connector = point.connector.destroy(); // #7243\n }\n }\n // record changes in the parallel arrays\n i = point.index;\n series.updateParallelArrays(point, i);\n // Record the options to options.data. If the old or the new config\n // is an object, use point options, otherwise use raw options\n // (#4701, #4916).\n seriesOptions.data[i] = (isObject(seriesOptions.data[i], true) ||\n isObject(options, true)) ?\n point.options :\n pick(options, seriesOptions.data[i]);\n // redraw\n series.isDirty = series.isDirtyData = true;\n if (!series.fixedBox && series.hasCartesianSeries) { // #1906, #2320\n chart.isDirtyBox = true;\n }\n if (seriesOptions.legendType === 'point') { // #1831, #1885\n chart.isDirtyLegend = true;\n }\n if (redraw) {\n chart.redraw(animation);\n }\n }\n // Fire the event with a default handler of doing the update\n if (runEvent === false) { // When called from setData\n update();\n }\n else {\n point.firePointEvent('update', { options: options }, update);\n }\n };\n /**\n * Remove a point and optionally redraw the series and if necessary the axes\n *\n * @sample highcharts/plotoptions/series-point-events-remove/\n * Remove point and confirm\n * @sample highcharts/members/point-remove/\n * Remove pie slice\n * @sample maps/members/point-remove/\n * Remove selected points in Highmaps\n *\n * @function Highcharts.Point#remove\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or wait for an explicit call. When\n * doing more operations on the chart, for example running\n * `point.remove()` in a loop, it is best practice to set `redraw`\n * to false and call `chart.redraw()` after.\n *\n * @param {boolean|Partial} [animation=false]\n * Whether to apply animation, and optionally animation\n * configuration.\n */\n Point.prototype.remove = function (redraw, animation) {\n this.series.removePoint(this.series.data.indexOf(this), redraw, animation);\n };\n /**\n * Toggle the selection status of a point.\n *\n * @see Highcharts.Chart#getSelectedPoints\n *\n * @sample highcharts/members/point-select/\n * Select a point from a button\n * @sample highcharts/chart/events-selection-points/\n * Select a range of points through a drag selection\n * @sample maps/series/data-id/\n * Select a point in Highmaps\n *\n * @function Highcharts.Point#select\n *\n * @param {boolean} [selected]\n * When `true`, the point is selected. When `false`, the point is\n * unselected. When `null` or `undefined`, the selection state is toggled.\n *\n * @param {boolean} [accumulate=false]\n * When `true`, the selection is added to other selected points.\n * When `false`, other selected points are deselected. Internally in\n * Highcharts, when\n * [allowPointSelect](https://api.highcharts.com/highcharts/plotOptions.series.allowPointSelect)\n * is `true`, selected points are accumulated on Control, Shift or Cmd\n * clicking the point.\n *\n * @emits Highcharts.Point#event:select\n * @emits Highcharts.Point#event:unselect\n */\n Point.prototype.select = function (selected, accumulate) {\n var point = this,\n series = point.series,\n chart = series.chart;\n selected = pick(selected, !point.selected);\n this.selectedStaging = selected;\n // fire the event with the default handler\n point.firePointEvent(selected ? 'select' : 'unselect', { accumulate: accumulate }, function () {\n /**\n * Whether the point is selected or not.\n *\n * @see Point#select\n * @see Chart#getSelectedPoints\n *\n * @name Highcharts.Point#selected\n * @type {boolean}\n */\n point.selected = point.options.selected = selected;\n series.options.data[series.data.indexOf(point)] =\n point.options;\n point.setState(selected && 'select');\n // unselect all other points unless Ctrl or Cmd + click\n if (!accumulate) {\n chart.getSelectedPoints().forEach(function (loopPoint) {\n var loopSeries = loopPoint.series;\n if (loopPoint.selected && loopPoint !== point) {\n loopPoint.selected = loopPoint.options.selected =\n false;\n loopSeries.options.data[loopSeries.data.indexOf(loopPoint)] = loopPoint.options;\n // Programatically selecting a point should restore\n // normal state, but when click happened on other\n // point, set inactive state to match other points\n loopPoint.setState(chart.hoverPoints &&\n loopSeries.options.inactiveOtherPoints ?\n 'inactive' : '');\n loopPoint.firePointEvent('unselect');\n }\n });\n }\n });\n delete this.selectedStaging;\n };\n /**\n * Runs on mouse over the point. Called internally from mouse and touch\n * events.\n *\n * @function Highcharts.Point#onMouseOver\n *\n * @param {Highcharts.PointerEventObject} [e]\n * The event arguments.\n */\n Point.prototype.onMouseOver = function (e) {\n var point = this,\n series = point.series,\n chart = series.chart,\n pointer = chart.pointer;\n e = e ?\n pointer.normalize(e) :\n // In cases where onMouseOver is called directly without an event\n pointer.getChartCoordinatesFromPoint(point, chart.inverted);\n pointer.runPointActions(e, point);\n };\n /**\n * Runs on mouse out from the point. Called internally from mouse and touch\n * events.\n *\n * @function Highcharts.Point#onMouseOut\n * @emits Highcharts.Point#event:mouseOut\n */\n Point.prototype.onMouseOut = function () {\n var point = this,\n chart = point.series.chart;\n point.firePointEvent('mouseOut');\n if (!point.series.options.inactiveOtherPoints) {\n (chart.hoverPoints || []).forEach(function (p) {\n p.setState();\n });\n }\n chart.hoverPoints = chart.hoverPoint = null;\n };\n /**\n * Import events from the series' and point's options. Only do it on\n * demand, to save processing time on hovering.\n *\n * @private\n * @function Highcharts.Point#importEvents\n */\n Point.prototype.importEvents = function () {\n if (!this.hasImportedEvents) {\n var point_1 = this,\n options = merge(point_1.series.options.point,\n point_1.options),\n events = options.events;\n point_1.events = events;\n objectEach(events, function (event, eventType) {\n if (isFunction(event)) {\n addEvent(point_1, eventType, event);\n }\n });\n this.hasImportedEvents = true;\n }\n };\n /**\n * Set the point's state.\n *\n * @function Highcharts.Point#setState\n *\n * @param {Highcharts.PointStateValue|\"\"} [state]\n * The new state, can be one of `'hover'`, `'select'`, `'inactive'`,\n * or `''` (an empty string), `'normal'` or `undefined` to set to\n * normal state.\n * @param {boolean} [move]\n * State for animation.\n *\n * @emits Highcharts.Point#event:afterSetState\n */\n Point.prototype.setState = function (state, move) {\n var point = this,\n series = point.series,\n previousState = point.state,\n stateOptions = (series.options.states[state || 'normal'] ||\n {}),\n markerOptions = (defaultOptions.plotOptions[series.type].marker &&\n series.options.marker),\n normalDisabled = (markerOptions && markerOptions.enabled === false),\n markerStateOptions = ((markerOptions &&\n markerOptions.states &&\n markerOptions.states[state || 'normal']) || {}),\n stateDisabled = markerStateOptions.enabled === false,\n pointMarker = point.marker || {},\n chart = series.chart,\n hasMarkers = (markerOptions && series.markerAttribs);\n var halo = series.halo,\n markerAttribs,\n pointAttribs,\n pointAttribsAnimation,\n stateMarkerGraphic = series.stateMarkerGraphic,\n newSymbol;\n state = state || ''; // empty string\n if (\n // already has this state\n (state === point.state && !move) ||\n // selected points don't respond to hover\n (point.selected && state !== 'select') ||\n // series' state options is disabled\n (stateOptions.enabled === false) ||\n // general point marker's state options is disabled\n (state && (stateDisabled ||\n (normalDisabled &&\n markerStateOptions.enabled === false))) ||\n // individual point marker's state options is disabled\n (state &&\n pointMarker.states &&\n pointMarker.states[state] &&\n pointMarker.states[state].enabled === false) // #1610\n ) {\n return;\n }\n point.state = state;\n if (hasMarkers) {\n markerAttribs = series.markerAttribs(point, state);\n }\n // Apply hover styles to the existing point\n // Prevent from mocked null points (#14966)\n if (point.graphic && !point.hasMockGraphic) {\n if (previousState) {\n point.graphic.removeClass('highcharts-point-' + previousState);\n }\n if (state) {\n point.graphic.addClass('highcharts-point-' + state);\n }\n if (!chart.styledMode) {\n pointAttribs = series.pointAttribs(point, state);\n pointAttribsAnimation = pick(chart.options.chart.animation, stateOptions.animation);\n var opacity_1 = pointAttribs.opacity;\n // Some inactive points (e.g. slices in pie) should apply\n // opacity also for their labels\n if (isNumber(opacity_1)) {\n (point.dataLabels || []).forEach(function (label) {\n if (label &&\n !label.hasClass('highcharts-data-label-hidden')) {\n label.animate({ opacity: opacity_1 }, pointAttribsAnimation);\n }\n });\n if (point.connector) {\n point.connector.animate({ opacity: opacity_1 }, pointAttribsAnimation);\n }\n }\n point.graphic.animate(pointAttribs, pointAttribsAnimation);\n }\n if (markerAttribs) {\n point.graphic.animate(markerAttribs, pick(\n // Turn off globally:\n chart.options.chart.animation, markerStateOptions.animation, markerOptions.animation));\n }\n // Zooming in from a range with no markers to a range with markers\n if (stateMarkerGraphic) {\n stateMarkerGraphic.hide();\n }\n }\n else {\n // if a graphic is not applied to each point in the normal state,\n // create a shared graphic for the hover state\n if (state && markerStateOptions) {\n newSymbol = pointMarker.symbol || series.symbol;\n // If the point has another symbol than the previous one, throw\n // away the state marker graphic and force a new one (#1459)\n if (stateMarkerGraphic &&\n stateMarkerGraphic.currentSymbol !== newSymbol) {\n stateMarkerGraphic = stateMarkerGraphic.destroy();\n }\n // Add a new state marker graphic\n if (markerAttribs) {\n if (!stateMarkerGraphic) {\n if (newSymbol) {\n series.stateMarkerGraphic = stateMarkerGraphic =\n chart.renderer\n .symbol(newSymbol, markerAttribs.x, markerAttribs.y, markerAttribs.width, markerAttribs.height)\n .add(series.markerGroup);\n stateMarkerGraphic.currentSymbol = newSymbol;\n }\n // Move the existing graphic\n }\n else {\n stateMarkerGraphic[move ? 'animate' : 'attr']({\n x: markerAttribs.x,\n y: markerAttribs.y\n });\n }\n }\n if (!chart.styledMode && stateMarkerGraphic &&\n point.state !== 'inactive') {\n stateMarkerGraphic.attr(series.pointAttribs(point, state));\n }\n }\n if (stateMarkerGraphic) {\n stateMarkerGraphic[state && point.isInside ? 'show' : 'hide'](); // #2450\n stateMarkerGraphic.element.point = point; // #4310\n stateMarkerGraphic.addClass(point.getClassName(), true);\n }\n }\n // Show me your halo\n var haloOptions = stateOptions.halo;\n var markerGraphic = (point.graphic || stateMarkerGraphic);\n var markerVisibility = (markerGraphic && markerGraphic.visibility || 'inherit');\n if (haloOptions &&\n haloOptions.size &&\n markerGraphic &&\n markerVisibility !== 'hidden' &&\n !point.isCluster) {\n if (!halo) {\n series.halo = halo = chart.renderer.path()\n // #5818, #5903, #6705\n .add(markerGraphic.parentGroup);\n }\n halo.show()[move ? 'animate' : 'attr']({\n d: point.haloPath(haloOptions.size)\n });\n halo.attr({\n 'class': 'highcharts-halo highcharts-color-' +\n pick(point.colorIndex, series.colorIndex) +\n (point.className ? ' ' + point.className : ''),\n 'visibility': markerVisibility,\n 'zIndex': -1 // #4929, #8276\n });\n halo.point = point; // #6055\n if (!chart.styledMode) {\n halo.attr(extend({\n 'fill': point.color || series.color,\n 'fill-opacity': haloOptions.opacity\n }, AST.filterUserAttributes(haloOptions.attributes || {})));\n }\n }\n else if (halo && halo.point && halo.point.haloPath) {\n // Animate back to 0 on the current halo point (#6055)\n halo.animate({ d: halo.point.haloPath(0) }, null, \n // Hide after unhovering. The `complete` callback runs in the\n // halo's context (#7681).\n halo.hide);\n }\n fireEvent(point, 'afterSetState', { state: state });\n };\n /**\n * Get the path definition for the halo, which is usually a shadow-like\n * circle around the currently hovered point.\n *\n * @function Highcharts.Point#haloPath\n *\n * @param {number} size\n * The radius of the circular halo.\n *\n * @return {Highcharts.SVGPathArray}\n * The path definition.\n */\n Point.prototype.haloPath = function (size) {\n var series = this.series,\n chart = series.chart;\n return chart.renderer.symbols.circle(Math.floor(this.plotX) - size, this.plotY - size, size * 2, size * 2);\n };\n return Point;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Function callback when a series point is clicked. Return false to cancel the\n * action.\n *\n * @callback Highcharts.PointClickCallbackFunction\n *\n * @param {Highcharts.Point} this\n * The point where the event occured.\n *\n * @param {Highcharts.PointClickEventObject} event\n * Event arguments.\n */\n /**\n * Common information for a click event on a series point.\n *\n * @interface Highcharts.PointClickEventObject\n * @extends Highcharts.PointerEventObject\n */ /**\n * Clicked point.\n * @name Highcharts.PointClickEventObject#point\n * @type {Highcharts.Point}\n */\n /**\n * Configuration for the data label and tooltip formatters.\n *\n * @interface Highcharts.PointLabelObject\n */ /**\n * The point's current color.\n * @name Highcharts.PointLabelObject#color\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject|undefined}\n */ /**\n * The point's current color index, used in styled mode instead of `color`. The\n * color index is inserted in class names used for styling.\n * @name Highcharts.PointLabelObject#colorIndex\n * @type {number}\n */ /**\n * The name of the related point.\n * @name Highcharts.PointLabelObject#key\n * @type {string|undefined}\n */ /**\n * The percentage for related points in a stacked series or pies.\n * @name Highcharts.PointLabelObject#percentage\n * @type {number}\n */ /**\n * The related point. The point name, if defined, is available through\n * `this.point.name`.\n * @name Highcharts.PointLabelObject#point\n * @type {Highcharts.Point}\n */ /**\n * The related series. The series name is available through `this.series.name`.\n * @name Highcharts.PointLabelObject#series\n * @type {Highcharts.Series}\n */ /**\n * The total of values in either a stack for stacked series, or a pie in a pie\n * series.\n * @name Highcharts.PointLabelObject#total\n * @type {number|undefined}\n */ /**\n * For categorized axes this property holds the category name for the point. For\n * other axes it holds the X value.\n * @name Highcharts.PointLabelObject#x\n * @type {number|string|undefined}\n */ /**\n * The y value of the point.\n * @name Highcharts.PointLabelObject#y\n * @type {number|null|undefined}\n */\n /**\n * Gets fired when the mouse leaves the area close to the point.\n *\n * @callback Highcharts.PointMouseOutCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {global.PointerEvent} event\n * Event that occured.\n */\n /**\n * Gets fired when the mouse enters the area close to the point.\n *\n * @callback Highcharts.PointMouseOverCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {global.Event} event\n * Event that occured.\n */\n /**\n * The generic point options for all series.\n *\n * In TypeScript you have to extend `PointOptionsObject` with an additional\n * declaration to allow custom data options:\n *\n * ```\n * declare interface PointOptionsObject {\n * customProperty: string;\n * }\n * ```\n *\n * @interface Highcharts.PointOptionsObject\n */\n /**\n * Possible option types for a data point. Use `null` to indicate a gap.\n *\n * @typedef {number|string|Highcharts.PointOptionsObject|Array<(number|string|null)>|null} Highcharts.PointOptionsType\n */\n /**\n * Gets fired when the point is removed using the `.remove()` method.\n *\n * @callback Highcharts.PointRemoveCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {global.Event} event\n * Event that occured.\n */\n /**\n * Possible key values for the point state options.\n *\n * @typedef {\"hover\"|\"inactive\"|\"normal\"|\"select\"} Highcharts.PointStateValue\n */\n /**\n * Gets fired when the point is updated programmatically through the `.update()`\n * method.\n *\n * @callback Highcharts.PointUpdateCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {Highcharts.PointUpdateEventObject} event\n * Event that occured.\n */\n /**\n * Information about the update event.\n *\n * @interface Highcharts.PointUpdateEventObject\n * @extends global.Event\n */ /**\n * Options data of the update event.\n * @name Highcharts.PointUpdateEventObject#options\n * @type {Highcharts.PointOptionsType}\n */\n /**\n * @interface Highcharts.PointEventsOptionsObject\n */ /**\n * Fires when the point is selected either programmatically or following a click\n * on the point. One parameter, `event`, is passed to the function. Returning\n * `false` cancels the operation.\n * @name Highcharts.PointEventsOptionsObject#select\n * @type {Highcharts.PointSelectCallbackFunction|undefined}\n */ /**\n * Fires when the point is unselected either programmatically or following a\n * click on the point. One parameter, `event`, is passed to the function.\n * Returning `false` cancels the operation.\n * @name Highcharts.PointEventsOptionsObject#unselect\n * @type {Highcharts.PointUnselectCallbackFunction|undefined}\n */\n /**\n * Information about the select/unselect event.\n *\n * @interface Highcharts.PointInteractionEventObject\n * @extends global.Event\n */ /**\n * @name Highcharts.PointInteractionEventObject#accumulate\n * @type {boolean}\n */\n /**\n * Gets fired when the point is selected either programmatically or following a\n * click on the point.\n *\n * @callback Highcharts.PointSelectCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {Highcharts.PointInteractionEventObject} event\n * Event that occured.\n */\n /**\n * Fires when the point is unselected either programmatically or following a\n * click on the point.\n *\n * @callback Highcharts.PointUnselectCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {Highcharts.PointInteractionEventObject} event\n * Event that occured.\n */\n ''; // keeps doclets above in JS file.\n\n return Point;\n });\n _registerModule(_modules, 'Core/Pointer.js', [_modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Tooltip.js'], _modules['Core/Utilities.js']], function (Color, H, Tooltip, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var color = Color.parse;\n var charts = H.charts,\n noop = H.noop;\n var addEvent = U.addEvent,\n attr = U.attr,\n css = U.css,\n defined = U.defined,\n extend = U.extend,\n find = U.find,\n fireEvent = U.fireEvent,\n isNumber = U.isNumber,\n isObject = U.isObject,\n objectEach = U.objectEach,\n offset = U.offset,\n pick = U.pick,\n splat = U.splat;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The mouse and touch tracker object. Each {@link Chart} item has one\n * associated Pointer item that can be accessed from the {@link Chart.pointer}\n * property.\n *\n * @class\n * @name Highcharts.Pointer\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.Options} options\n * The root options object. The pointer uses options from the chart and tooltip\n * structures.\n */\n var Pointer = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Pointer(chart, options) {\n this.lastValidTouch = {};\n this.pinchDown = [];\n this.runChartClick = false;\n this.eventsToUnbind = [];\n this.chart = chart;\n this.hasDragged = false;\n this.options = options;\n this.init(chart, options);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set inactive state to all series that are not currently hovered,\n * or, if `inactiveOtherPoints` is set to true, set inactive state to\n * all points within that series.\n *\n * @private\n * @function Highcharts.Pointer#applyInactiveState\n *\n * @param {Array} points\n * Currently hovered points\n */\n Pointer.prototype.applyInactiveState = function (points) {\n var activeSeries = [],\n series;\n // Get all active series from the hovered points\n (points || []).forEach(function (item) {\n series = item.series;\n // Include itself\n activeSeries.push(series);\n // Include parent series\n if (series.linkedParent) {\n activeSeries.push(series.linkedParent);\n }\n // Include all child series\n if (series.linkedSeries) {\n activeSeries = activeSeries.concat(series.linkedSeries);\n }\n // Include navigator series\n if (series.navigatorSeries) {\n activeSeries.push(series.navigatorSeries);\n }\n });\n // Now loop over all series, filtering out active series\n this.chart.series.forEach(function (inactiveSeries) {\n if (activeSeries.indexOf(inactiveSeries) === -1) {\n // Inactive series\n inactiveSeries.setState('inactive', true);\n }\n else if (inactiveSeries.options.inactiveOtherPoints) {\n // Active series, but other points should be inactivated\n inactiveSeries.setAllPointsToState('inactive');\n }\n });\n };\n /**\n * Destroys the Pointer object and disconnects DOM events.\n *\n * @function Highcharts.Pointer#destroy\n */\n Pointer.prototype.destroy = function () {\n var pointer = this;\n this.eventsToUnbind.forEach(function (unbind) { return unbind(); });\n this.eventsToUnbind = [];\n if (!H.chartCount) {\n if (Pointer.unbindDocumentMouseUp) {\n Pointer.unbindDocumentMouseUp = Pointer.unbindDocumentMouseUp();\n }\n if (Pointer.unbindDocumentTouchEnd) {\n Pointer.unbindDocumentTouchEnd = (Pointer.unbindDocumentTouchEnd());\n }\n }\n // memory and CPU leak\n clearInterval(pointer.tooltipTimeout);\n objectEach(pointer, function (_val, prop) {\n pointer[prop] = void 0;\n });\n };\n /**\n * Calculate attrs for selection marker.\n * @private\n * @function Highcharts.Pointer#getSelectionMarkerAttrs\n * @emits getSelectionMarkerAttrs\n */\n Pointer.prototype.getSelectionMarkerAttrs = function (chartX, chartY) {\n var _this = this;\n var e = {\n args: { chartX: chartX,\n chartY: chartY },\n attrs: {},\n shapeType: 'rect'\n };\n fireEvent(this, 'getSelectionMarkerAttrs', e, function (e) {\n var _a = _this,\n chart = _a.chart,\n _b = _a.mouseDownX,\n mouseDownX = _b === void 0 ? 0 : _b,\n _c = _a.mouseDownY,\n mouseDownY = _c === void 0 ? 0 : _c,\n zoomHor = _a.zoomHor,\n zoomVert = _a.zoomVert,\n attrs = e.attrs;\n var size;\n attrs.x = chart.plotLeft;\n attrs.y = chart.plotTop;\n attrs.width = zoomHor ? 1 : chart.plotWidth;\n attrs.height = zoomVert ? 1 : chart.plotHeight;\n // Adjust the width of the selection marker\n if (zoomHor) {\n size = chartX - mouseDownX;\n attrs.width = Math.abs(size);\n attrs.x = (size > 0 ? 0 : size) + mouseDownX;\n }\n // Adjust the height of the selection marker\n if (zoomVert) {\n size = chartY - mouseDownY;\n attrs.height = Math.abs(size);\n attrs.y = (size > 0 ? 0 : size) + mouseDownY;\n }\n });\n return e;\n };\n /**\n * Perform a drag operation in response to a mousemove event while the mouse\n * is down.\n * @private\n * @function Highcharts.Pointer#drag\n */\n Pointer.prototype.drag = function (e) {\n var chart = this.chart,\n chartOptions = chart.options.chart,\n plotLeft = chart.plotLeft,\n plotTop = chart.plotTop,\n plotWidth = chart.plotWidth,\n plotHeight = chart.plotHeight,\n mouseDownX = (this.mouseDownX || 0),\n mouseDownY = (this.mouseDownY || 0),\n panningEnabled = isObject(chartOptions.panning) ?\n chartOptions.panning && chartOptions.panning.enabled :\n chartOptions.panning,\n panKey = (chartOptions.panKey && e[chartOptions.panKey + 'Key']);\n var chartX = e.chartX,\n chartY = e.chartY,\n clickedInside,\n selectionMarker = this.selectionMarker;\n // If the device supports both touch and mouse (like IE11), and we are\n // touch-dragging inside the plot area, don't handle the mouse event.\n // #4339.\n if (selectionMarker && selectionMarker.touch) {\n return;\n }\n // If the mouse is outside the plot area, adjust to coordinates\n // inside to prevent the selection marker from going outside\n if (chartX < plotLeft) {\n chartX = plotLeft;\n }\n else if (chartX > plotLeft + plotWidth) {\n chartX = plotLeft + plotWidth;\n }\n if (chartY < plotTop) {\n chartY = plotTop;\n }\n else if (chartY > plotTop + plotHeight) {\n chartY = plotTop + plotHeight;\n }\n // determine if the mouse has moved more than 10px\n this.hasDragged = Math.sqrt(Math.pow(mouseDownX - chartX, 2) +\n Math.pow(mouseDownY - chartY, 2));\n if (this.hasDragged > 10) {\n clickedInside = chart.isInsidePlot(mouseDownX - plotLeft, mouseDownY - plotTop, {\n visiblePlotOnly: true\n });\n var _a = this.getSelectionMarkerAttrs(chartX,\n chartY),\n shapeType = _a.shapeType,\n attrs = _a.attrs;\n // make a selection\n if ((chart.hasCartesianSeries || chart.mapView) &&\n (this.zoomX || this.zoomY) &&\n clickedInside &&\n !panKey) {\n if (!selectionMarker) {\n this.selectionMarker = selectionMarker =\n chart.renderer[shapeType]();\n selectionMarker\n .attr({\n 'class': 'highcharts-selection-marker',\n zIndex: 7\n })\n .add();\n if (!chart.styledMode) {\n selectionMarker.attr({\n fill: chartOptions.selectionMarkerFill ||\n color(\"#335cad\" /* Palette.highlightColor80 */)\n .setOpacity(0.25).get()\n });\n }\n }\n }\n if (selectionMarker) {\n selectionMarker.attr(attrs);\n }\n // panning\n if (clickedInside &&\n !selectionMarker &&\n panningEnabled) {\n chart.pan(e, chartOptions.panning);\n }\n }\n };\n /**\n * Start a drag operation.\n * @private\n * @function Highcharts.Pointer#dragStart\n */\n Pointer.prototype.dragStart = function (e) {\n var chart = this.chart;\n // Record the start position\n chart.mouseIsDown = e.type;\n chart.cancelClick = false;\n chart.mouseDownX = this.mouseDownX = e.chartX;\n chart.mouseDownY = this.mouseDownY = e.chartY;\n };\n /**\n * Get selection box to calculate extremes\n * @private\n * @function Highcharts.Pointer#getSelectionBox\n * @emits getSelectionBox\n */\n Pointer.prototype.getSelectionBox = function (marker) {\n var e = {\n args: { marker: marker },\n result: {}\n };\n fireEvent(this, 'getSelectionBox', e, function (e) {\n e.result = {\n x: marker.attr ? +marker.attr('x') : marker.x,\n y: marker.attr ? +marker.attr('y') : marker.y,\n width: marker.attr ? marker.attr('width') : marker.width,\n height: marker.attr ? marker.attr('height') : marker.height\n };\n });\n return e.result;\n };\n /**\n * On mouse up or touch end across the entire document, drop the selection.\n * @private\n * @function Highcharts.Pointer#drop\n */\n Pointer.prototype.drop = function (e) {\n var pointer = this,\n chart = this.chart,\n hasPinched = this.hasPinched;\n if (this.selectionMarker) {\n var _a = this.getSelectionBox(this.selectionMarker),\n x_1 = _a.x,\n y_1 = _a.y,\n width_1 = _a.width,\n height_1 = _a.height;\n var selectionData_1 = {\n originalEvent: e,\n xAxis: [],\n yAxis: [],\n x: x_1,\n y: y_1,\n width: width_1,\n height: height_1\n }, \n // Start by false runZoom, unless when we have a mapView, in\n // which case the zoom will be handled in the selection event.\n runZoom_1 = Boolean(chart.mapView);\n // a selection has been made\n if (this.hasDragged || hasPinched) {\n // record each axis' min and max\n chart.axes.forEach(function (axis) {\n if (axis.zoomEnabled &&\n defined(axis.min) &&\n (hasPinched ||\n pointer[{\n xAxis: 'zoomX',\n yAxis: 'zoomY'\n }[axis.coll]]) &&\n isNumber(x_1) &&\n isNumber(y_1) &&\n isNumber(width_1) &&\n isNumber(height_1)) { // #859, #3569\n var horiz = axis.horiz,\n minPixelPadding = e.type === 'touchend' ?\n axis.minPixelPadding :\n 0, // #1207, #3075\n selectionMin = axis.toValue((horiz ? x_1 : y_1) + minPixelPadding),\n selectionMax = axis.toValue((horiz ? x_1 + width_1 : y_1 + height_1) -\n minPixelPadding);\n selectionData_1[axis.coll].push({\n axis: axis,\n // Min/max for reversed axes\n min: Math.min(selectionMin, selectionMax),\n max: Math.max(selectionMin, selectionMax)\n });\n runZoom_1 = true;\n }\n });\n if (runZoom_1) {\n fireEvent(chart, 'selection', selectionData_1, function (args) {\n chart.zoom(extend(args, hasPinched ?\n { animation: false } :\n null));\n });\n }\n }\n if (isNumber(chart.index)) {\n this.selectionMarker = this.selectionMarker.destroy();\n }\n // Reset scaling preview\n if (hasPinched) {\n this.scaleGroups();\n }\n }\n // Reset all. Check isNumber because it may be destroyed on mouse up\n // (#877)\n if (chart && isNumber(chart.index)) {\n css(chart.container, { cursor: chart._cursor });\n chart.cancelClick = this.hasDragged > 10; // #370\n chart.mouseIsDown = this.hasDragged = this.hasPinched = false;\n this.pinchDown = [];\n }\n };\n /**\n * Finds the closest point to a set of coordinates, using the k-d-tree\n * algorithm.\n *\n * @function Highcharts.Pointer#findNearestKDPoint\n *\n * @param {Array} series\n * All the series to search in.\n *\n * @param {boolean|undefined} shared\n * Whether it is a shared tooltip or not.\n *\n * @param {Highcharts.PointerEventObject} e\n * The pointer event object, containing chart coordinates of the pointer.\n *\n * @return {Highcharts.Point|undefined}\n * The point closest to given coordinates.\n */\n Pointer.prototype.findNearestKDPoint = function (series, shared, e) {\n var closest;\n /** @private */\n function sort(p1, p2) {\n var isCloserX = p1.distX - p2.distX,\n isCloser = p1.dist - p2.dist,\n isAbove = ((p2.series.group && p2.series.group.zIndex) -\n (p1.series.group && p1.series.group.zIndex));\n var result;\n // We have two points which are not in the same place on xAxis\n // and shared tooltip:\n if (isCloserX !== 0 && shared) { // #5721\n result = isCloserX;\n // Points are not exactly in the same place on x/yAxis:\n }\n else if (isCloser !== 0) {\n result = isCloser;\n // The same xAxis and yAxis position, sort by z-index:\n }\n else if (isAbove !== 0) {\n result = isAbove;\n // The same zIndex, sort by array index:\n }\n else {\n result =\n p1.series.index > p2.series.index ?\n -1 :\n 1;\n }\n return result;\n }\n series.forEach(function (s) {\n var noSharedTooltip = s.noSharedTooltip && shared,\n compareX = (!noSharedTooltip &&\n s.options.findNearestPointBy.indexOf('y') < 0),\n point = s.searchPoint(e,\n compareX);\n if ( // Check that we actually found a point on the series.\n isObject(point, true) && point.series &&\n // Use the new point if it is closer.\n (!isObject(closest, true) ||\n (sort(closest, point) > 0))) {\n closest = point;\n }\n });\n return closest;\n };\n /**\n * @private\n * @function Highcharts.Pointer#getChartCoordinatesFromPoint\n */\n Pointer.prototype.getChartCoordinatesFromPoint = function (point, inverted) {\n var series = point.series,\n xAxis = series.xAxis,\n yAxis = series.yAxis,\n shapeArgs = point.shapeArgs;\n if (xAxis && yAxis) {\n var x = pick(point.clientX,\n point.plotX);\n var y = point.plotY || 0;\n if (point.isNode &&\n shapeArgs &&\n isNumber(shapeArgs.x) &&\n isNumber(shapeArgs.y)) {\n x = shapeArgs.x;\n y = shapeArgs.y;\n }\n return inverted ? {\n chartX: yAxis.len + yAxis.pos - y,\n chartY: xAxis.len + xAxis.pos - x\n } : {\n chartX: x + xAxis.pos,\n chartY: y + yAxis.pos\n };\n }\n if (shapeArgs && shapeArgs.x && shapeArgs.y) {\n // E.g. pies do not have axes\n return {\n chartX: shapeArgs.x,\n chartY: shapeArgs.y\n };\n }\n };\n /**\n * Return the cached chartPosition if it is available on the Pointer,\n * otherwise find it. Running offset is quite expensive, so it should be\n * avoided when we know the chart hasn't moved.\n *\n * @function Highcharts.Pointer#getChartPosition\n *\n * @return {Highcharts.ChartPositionObject}\n * The offset of the chart container within the page\n */\n Pointer.prototype.getChartPosition = function () {\n if (this.chartPosition) {\n return this.chartPosition;\n }\n var container = this.chart.container;\n var pos = offset(container);\n this.chartPosition = {\n left: pos.left,\n top: pos.top,\n scaleX: 1,\n scaleY: 1\n };\n var offsetWidth = container.offsetWidth;\n var offsetHeight = container.offsetHeight;\n // #13342 - tooltip was not visible in Chrome, when chart\n // updates height.\n if (offsetWidth > 2 && // #13342\n offsetHeight > 2 // #13342\n ) {\n this.chartPosition.scaleX = pos.width / offsetWidth;\n this.chartPosition.scaleY = pos.height / offsetHeight;\n }\n return this.chartPosition;\n };\n /**\n * Get the click position in terms of axis values.\n *\n * @function Highcharts.Pointer#getCoordinates\n *\n * @param {Highcharts.PointerEventObject} e\n * Pointer event, extended with `chartX` and `chartY` properties.\n *\n * @return {Highcharts.PointerAxisCoordinatesObject}\n * Axis coordinates.\n */\n Pointer.prototype.getCoordinates = function (e) {\n var coordinates = {\n xAxis: [],\n yAxis: []\n };\n this.chart.axes.forEach(function (axis) {\n coordinates[axis.isXAxis ? 'xAxis' : 'yAxis'].push({\n axis: axis,\n value: axis.toValue(e[axis.horiz ? 'chartX' : 'chartY'])\n });\n });\n return coordinates;\n };\n /**\n * Calculates what is the current hovered point/points and series.\n *\n * @private\n * @function Highcharts.Pointer#getHoverData\n *\n * @param {Highcharts.Point|undefined} existingHoverPoint\n * The point currently being hovered.\n *\n * @param {Highcharts.Series|undefined} existingHoverSeries\n * The series currently being hovered.\n *\n * @param {Array} series\n * All the series in the chart.\n *\n * @param {boolean} isDirectTouch\n * Is the pointer directly hovering the point.\n *\n * @param {boolean|undefined} shared\n * Whether it is a shared tooltip or not.\n *\n * @param {Highcharts.PointerEventObject} [e]\n * The triggering event, containing chart coordinates of the pointer.\n *\n * @return {Object}\n * Object containing resulting hover data: hoverPoint, hoverSeries, and\n * hoverPoints.\n */\n Pointer.prototype.getHoverData = function (existingHoverPoint, existingHoverSeries, series, isDirectTouch, shared, e) {\n var hoverPoints = [],\n useExisting = !!(isDirectTouch && existingHoverPoint),\n filter = function (s) {\n return (s.visible &&\n !(!shared && s.directTouch) && // #3821\n pick(s.options.enableMouseTracking,\n true));\n };\n var hoverSeries = existingHoverSeries, \n // Which series to look in for the hover point\n searchSeries, \n // Parameters needed for beforeGetHoverData event.\n eventArgs = {\n chartX: e ? e.chartX : void 0,\n chartY: e ? e.chartY : void 0,\n shared: shared\n };\n // Find chart.hoverPane and update filter method in polar.\n fireEvent(this, 'beforeGetHoverData', eventArgs);\n var notSticky = hoverSeries && !hoverSeries.stickyTracking;\n searchSeries = notSticky ?\n // Only search on hovered series if it has stickyTracking false\n [hoverSeries] :\n // Filter what series to look in.\n series.filter(function (s) { return s.stickyTracking &&\n (eventArgs.filter || filter)(s); });\n // Use existing hovered point or find the one closest to coordinates.\n var hoverPoint = useExisting || !e ?\n existingHoverPoint :\n this.findNearestKDPoint(searchSeries,\n shared,\n e);\n // Assign hover series\n hoverSeries = hoverPoint && hoverPoint.series;\n // If we have a hoverPoint, assign hoverPoints.\n if (hoverPoint) {\n // When tooltip is shared, it displays more than one point\n if (shared && !hoverSeries.noSharedTooltip) {\n searchSeries = series.filter(function (s) {\n return eventArgs.filter ?\n eventArgs.filter(s) : filter(s) && !s.noSharedTooltip;\n });\n // Get all points with the same x value as the hoverPoint\n searchSeries.forEach(function (s) {\n var point = find(s.points,\n function (p) {\n return p.x === hoverPoint.x && !p.isNull;\n });\n if (isObject(point)) {\n /*\n * Boost returns a minimal point. Convert it to a usable\n * point for tooltip and states.\n */\n if (s.boosted && s.boost) {\n point = s.boost.getPoint(point);\n }\n hoverPoints.push(point);\n }\n });\n }\n else {\n hoverPoints.push(hoverPoint);\n }\n }\n // Check whether the hoverPoint is inside pane we are hovering over.\n eventArgs = { hoverPoint: hoverPoint };\n fireEvent(this, 'afterGetHoverData', eventArgs);\n return {\n hoverPoint: eventArgs.hoverPoint,\n hoverSeries: hoverSeries,\n hoverPoints: hoverPoints\n };\n };\n /**\n * @private\n * @function Highcharts.Pointer#getPointFromEvent\n */\n Pointer.prototype.getPointFromEvent = function (e) {\n var target = e.target,\n point;\n while (target && !point) {\n point = target.point;\n target = target.parentNode;\n }\n return point;\n };\n /**\n * @private\n * @function Highcharts.Pointer#onTrackerMouseOut\n */\n Pointer.prototype.onTrackerMouseOut = function (e) {\n var chart = this.chart;\n var relatedTarget = e.relatedTarget || e.toElement;\n var series = chart.hoverSeries;\n this.isDirectTouch = false;\n if (series &&\n relatedTarget &&\n !series.stickyTracking &&\n !this.inClass(relatedTarget, 'highcharts-tooltip') &&\n (!this.inClass(relatedTarget, 'highcharts-series-' + series.index) || // #2499, #4465, #5553\n !this.inClass(relatedTarget, 'highcharts-tracker'))) {\n series.onMouseOut();\n }\n };\n /**\n * Utility to detect whether an element has, or has a parent with, a\n * specific class name. Used on detection of tracker objects and on deciding\n * whether hovering the tooltip should cause the active series to mouse out.\n *\n * @function Highcharts.Pointer#inClass\n *\n * @param {Highcharts.SVGDOMElement|Highcharts.HTMLDOMElement} element\n * The element to investigate.\n *\n * @param {string} className\n * The class name to look for.\n *\n * @return {boolean|undefined}\n * True if either the element or one of its parents has the given class\n * name.\n */\n Pointer.prototype.inClass = function (element, className) {\n var elem = element,\n elemClassName;\n while (elem) {\n elemClassName = attr(elem, 'class');\n if (elemClassName) {\n if (elemClassName.indexOf(className) !== -1) {\n return true;\n }\n if (elemClassName.indexOf('highcharts-container') !== -1) {\n return false;\n }\n }\n elem = elem.parentElement;\n }\n };\n /**\n * Initialize the Pointer.\n *\n * @private\n * @function Highcharts.Pointer#init\n *\n * @param {Highcharts.Chart} chart\n * The Chart instance.\n *\n * @param {Highcharts.Options} options\n * The root options object. The pointer uses options from the chart and\n * tooltip structures.\n */\n Pointer.prototype.init = function (chart, options) {\n // Store references\n this.options = options;\n this.chart = chart;\n // Do we need to handle click on a touch device?\n this.runChartClick = Boolean(options.chart.events && options.chart.events.click);\n this.pinchDown = [];\n this.lastValidTouch = {};\n if (Tooltip) {\n /**\n * Tooltip object for points of series.\n *\n * @name Highcharts.Chart#tooltip\n * @type {Highcharts.Tooltip}\n */\n chart.tooltip = new Tooltip(chart, options.tooltip);\n }\n this.setDOMEvents();\n };\n /**\n * Takes a browser event object and extends it with custom Highcharts\n * properties `chartX` and `chartY` in order to work on the internal\n * coordinate system.\n *\n * On map charts, the properties `lon` and `lat` are added to the event\n * object given that the chart has projection information.\n *\n * @function Highcharts.Pointer#normalize\n *\n * @param {global.MouseEvent|global.PointerEvent|global.TouchEvent} e\n * Event object in standard browsers.\n *\n * @param {Highcharts.OffsetObject} [chartPosition]\n * Additional chart offset.\n *\n * @return {Highcharts.PointerEventObject}\n * A browser event with extended properties `chartX` and `chartY`.\n */\n Pointer.prototype.normalize = function (e, chartPosition) {\n var touches = e.touches;\n // iOS (#2757)\n var ePos = (touches ?\n touches.length ?\n touches.item(0) :\n (pick(// #13534\n touches.changedTouches,\n e.changedTouches))[0] :\n e);\n // Get mouse position\n if (!chartPosition) {\n chartPosition = this.getChartPosition();\n }\n var chartX = ePos.pageX - chartPosition.left,\n chartY = ePos.pageY - chartPosition.top;\n // #11329 - when there is scaling on a parent element, we need to take\n // this into account\n chartX /= chartPosition.scaleX;\n chartY /= chartPosition.scaleY;\n return extend(e, {\n chartX: Math.round(chartX),\n chartY: Math.round(chartY)\n });\n };\n /**\n * @private\n * @function Highcharts.Pointer#onContainerClick\n */\n Pointer.prototype.onContainerClick = function (e) {\n var chart = this.chart;\n var hoverPoint = chart.hoverPoint;\n var pEvt = this.normalize(e);\n var plotLeft = chart.plotLeft;\n var plotTop = chart.plotTop;\n if (!chart.cancelClick) {\n // On tracker click, fire the series and point events. #783, #1583\n if (hoverPoint &&\n this.inClass(pEvt.target, 'highcharts-tracker')) {\n // the series click event\n fireEvent(hoverPoint.series, 'click', extend(pEvt, {\n point: hoverPoint\n }));\n // the point click event\n if (chart.hoverPoint) { // it may be destroyed (#1844)\n hoverPoint.firePointEvent('click', pEvt);\n }\n // When clicking outside a tracker, fire a chart event\n }\n else {\n extend(pEvt, this.getCoordinates(pEvt));\n // fire a click event in the chart\n if (chart.isInsidePlot(pEvt.chartX - plotLeft, pEvt.chartY - plotTop, {\n visiblePlotOnly: true\n })) {\n fireEvent(chart, 'click', pEvt);\n }\n }\n }\n };\n /**\n * @private\n * @function Highcharts.Pointer#onContainerMouseDown\n */\n Pointer.prototype.onContainerMouseDown = function (e) {\n var isPrimaryButton = ((e.buttons || e.button) & 1) === 1;\n // Normalize before the 'if' for the legacy IE (#7850)\n e = this.normalize(e);\n // #11635, Firefox does not reliable fire move event after click scroll\n if (H.isFirefox &&\n e.button !== 0) {\n this.onContainerMouseMove(e);\n }\n // #11635, limiting to primary button (incl. IE 8 support)\n if (typeof e.button === 'undefined' ||\n isPrimaryButton) {\n this.zoomOption(e);\n // #295, #13737 solve conflict between container drag and chart zoom\n if (isPrimaryButton &&\n e.preventDefault) {\n e.preventDefault();\n }\n this.dragStart(e);\n }\n };\n /**\n * When mouse leaves the container, hide the tooltip.\n * @private\n * @function Highcharts.Pointer#onContainerMouseLeave\n */\n Pointer.prototype.onContainerMouseLeave = function (e) {\n var chart = charts[pick(Pointer.hoverChartIndex, -1)];\n var tooltip = this.chart.tooltip;\n e = this.normalize(e);\n // #4886, MS Touch end fires mouseleave but with no related target\n if (chart &&\n (e.relatedTarget || e.toElement)) {\n chart.pointer.reset();\n // Also reset the chart position, used in #149 fix\n chart.pointer.chartPosition = void 0;\n }\n // #11635, Firefox wheel scroll does not fire out events consistently\n if (tooltip && !tooltip.isHidden) {\n this.reset();\n }\n };\n /**\n * When mouse enters the container, delete pointer's chartPosition.\n * @private\n * @function Highcharts.Pointer#onContainerMouseEnter\n */\n Pointer.prototype.onContainerMouseEnter = function (e) {\n delete this.chartPosition;\n };\n /**\n * The mousemove, touchmove and touchstart event handler\n * @private\n * @function Highcharts.Pointer#onContainerMouseMove\n */\n Pointer.prototype.onContainerMouseMove = function (e) {\n var chart = this.chart,\n tooltip = chart.tooltip,\n pEvt = this.normalize(e);\n this.setHoverChartIndex();\n // In IE8 we apparently need this returnValue set to false in order to\n // avoid text being selected. But in Chrome, e.returnValue is prevented,\n // plus we don't need to run e.preventDefault to prevent selected text\n // in modern browsers. So we set it conditionally. Remove it when IE8 is\n // no longer needed. #2251, #3224.\n if (!pEvt.preventDefault) {\n pEvt.returnValue = false;\n }\n if (chart.mouseIsDown === 'mousedown' || this.touchSelect(pEvt)) {\n this.drag(pEvt);\n }\n // Show the tooltip and run mouse over events (#977)\n if (!chart.openMenu &&\n (this.inClass(pEvt.target, 'highcharts-tracker') ||\n chart.isInsidePlot(pEvt.chartX - chart.plotLeft, pEvt.chartY - chart.plotTop, {\n visiblePlotOnly: true\n })) &&\n // If the tooltip has stickOnContact enabled, do nothing. This\n // applies regardless of any combinations of the `split` and\n // `useHTML` options.\n !(tooltip &&\n tooltip.shouldStickOnContact(pEvt))) {\n if (this.inClass(pEvt.target, 'highcharts-no-tooltip')) {\n this.reset(false, 0);\n }\n else {\n this.runPointActions(pEvt);\n }\n }\n };\n /**\n * @private\n * @function Highcharts.Pointer#onDocumentTouchEnd\n */\n Pointer.prototype.onDocumentTouchEnd = function (e) {\n var hoverChart = charts[pick(Pointer.hoverChartIndex, -1)];\n if (hoverChart) {\n hoverChart.pointer.drop(e);\n }\n };\n /**\n * @private\n * @function Highcharts.Pointer#onContainerTouchMove\n */\n Pointer.prototype.onContainerTouchMove = function (e) {\n if (this.touchSelect(e)) {\n this.onContainerMouseMove(e);\n }\n else {\n this.touch(e);\n }\n };\n /**\n * @private\n * @function Highcharts.Pointer#onContainerTouchStart\n */\n Pointer.prototype.onContainerTouchStart = function (e) {\n if (this.touchSelect(e)) {\n this.onContainerMouseDown(e);\n }\n else {\n this.zoomOption(e);\n this.touch(e, true);\n }\n };\n /**\n * Special handler for mouse move that will hide the tooltip when the mouse\n * leaves the plotarea. Issue #149 workaround. The mouseleave event does not\n * always fire.\n * @private\n * @function Highcharts.Pointer#onDocumentMouseMove\n */\n Pointer.prototype.onDocumentMouseMove = function (e) {\n var chart = this.chart;\n var tooltip = chart.tooltip;\n var chartPosition = this.chartPosition;\n var pEvt = this.normalize(e,\n chartPosition);\n // If we're outside, hide the tooltip\n if (chartPosition &&\n !chart.isInsidePlot(pEvt.chartX - chart.plotLeft, pEvt.chartY - chart.plotTop, {\n visiblePlotOnly: true\n }) &&\n !(tooltip &&\n tooltip.shouldStickOnContact(pEvt)) &&\n !this.inClass(pEvt.target, 'highcharts-tracker')) {\n this.reset();\n }\n };\n /**\n * @private\n * @function Highcharts.Pointer#onDocumentMouseUp\n */\n Pointer.prototype.onDocumentMouseUp = function (e) {\n var chart = charts[pick(Pointer.hoverChartIndex, -1)];\n if (chart) {\n chart.pointer.drop(e);\n }\n };\n /**\n * Handle touch events with two touches\n * @private\n * @function Highcharts.Pointer#pinch\n */\n Pointer.prototype.pinch = function (e) {\n var self = this,\n chart = self.chart,\n pinchDown = self.pinchDown,\n touches = (e.touches || []),\n touchesLength = touches.length,\n lastValidTouch = self.lastValidTouch,\n hasZoom = self.hasZoom,\n transform = {},\n fireClickEvent = touchesLength === 1 && ((self.inClass(e.target, 'highcharts-tracker') &&\n chart.runTrackerClick) ||\n self.runChartClick),\n clip = {},\n tooltip = self.chart.tooltip,\n followTouchMove = touchesLength === 1 &&\n pick((tooltip && tooltip.options.followTouchMove),\n true);\n var selectionMarker = self.selectionMarker;\n // Don't initiate panning until the user has pinched. This prevents us\n // from blocking page scrolling as users scroll down a long page\n // (#4210).\n if (touchesLength > 1) {\n self.initiated = true;\n }\n else if (followTouchMove) {\n // #16119: Prevent blocking scroll when single-finger panning is\n // not enabled\n self.initiated = false;\n }\n // On touch devices, only proceed to trigger click if a handler is\n // defined\n if (hasZoom &&\n self.initiated &&\n !fireClickEvent &&\n e.cancelable !== false) {\n e.preventDefault();\n }\n // Normalize each touch\n [].map.call(touches, function (e) {\n return self.normalize(e);\n });\n // Register the touch start position\n if (e.type === 'touchstart') {\n [].forEach.call(touches, function (e, i) {\n pinchDown[i] = { chartX: e.chartX, chartY: e.chartY };\n });\n lastValidTouch.x = [pinchDown[0].chartX, pinchDown[1] &&\n pinchDown[1].chartX];\n lastValidTouch.y = [pinchDown[0].chartY, pinchDown[1] &&\n pinchDown[1].chartY];\n // Identify the data bounds in pixels\n chart.axes.forEach(function (axis) {\n if (axis.zoomEnabled) {\n var bounds = chart.bounds[axis.horiz ? 'h' : 'v'],\n minPixelPadding = axis.minPixelPadding,\n min = axis.toPixels(Math.min(pick(axis.options.min,\n axis.dataMin),\n axis.dataMin)),\n max = axis.toPixels(Math.max(pick(axis.options.max,\n axis.dataMax),\n axis.dataMax)),\n absMin = Math.min(min,\n max),\n absMax = Math.max(min,\n max);\n // Store the bounds for use in the touchmove handler\n bounds.min = Math.min(axis.pos, absMin - minPixelPadding);\n bounds.max = Math.max(axis.pos + axis.len, absMax + minPixelPadding);\n }\n });\n self.res = true; // reset on next move\n // Optionally move the tooltip on touchmove\n }\n else if (followTouchMove) {\n this.runPointActions(self.normalize(e));\n // Event type is touchmove, handle panning and pinching\n }\n else if (pinchDown.length) { // can be 0 when releasing, if touchend\n // fires first\n fireEvent(chart, 'touchpan', { originalEvent: e }, function () {\n // Set the marker\n if (!selectionMarker) {\n // @todo It's a mock object, so maybe we need a separate\n // interface\n self.selectionMarker = selectionMarker = extend({\n destroy: noop,\n touch: true\n }, chart.plotBox);\n }\n self.pinchTranslate(pinchDown, touches, transform, selectionMarker, clip, lastValidTouch);\n self.hasPinched = hasZoom;\n // Scale and translate the groups to provide visual feedback\n // during pinching\n self.scaleGroups(transform, clip);\n });\n if (self.res) {\n self.res = false;\n this.reset(false, 0);\n }\n }\n };\n /**\n * Run translation operations\n * @private\n * @function Highcharts.Pointer#pinchTranslate\n */\n Pointer.prototype.pinchTranslate = function (pinchDown, touches, transform, selectionMarker, clip, lastValidTouch) {\n if (this.zoomHor) {\n this.pinchTranslateDirection(true, pinchDown, touches, transform, selectionMarker, clip, lastValidTouch);\n }\n if (this.zoomVert) {\n this.pinchTranslateDirection(false, pinchDown, touches, transform, selectionMarker, clip, lastValidTouch);\n }\n };\n /**\n * Run translation operations for each direction (horizontal and vertical)\n * independently.\n * @private\n * @function Highcharts.Pointer#pinchTranslateDirection\n */\n Pointer.prototype.pinchTranslateDirection = function (horiz, pinchDown, touches, transform, selectionMarker, clip, lastValidTouch, forcedScale) {\n var chart = this.chart, xy = horiz ? 'x' : 'y', XY = horiz ? 'X' : 'Y', sChartXY = ('chart' + XY), wh = horiz ? 'width' : 'height', plotLeftTop = chart['plot' + (horiz ? 'Left' : 'Top')], inverted = chart.inverted, bounds = chart.bounds[horiz ? 'h' : 'v'], singleTouch = pinchDown.length === 1, touch0Start = pinchDown[0][sChartXY], touch1Start = !singleTouch && pinchDown[1][sChartXY], setScale = function () {\n // Don't zoom if fingers are too close on this axis\n if (typeof touch1Now === 'number' &&\n Math.abs(touch0Start - touch1Start) > 20) {\n scale = forcedScale ||\n Math.abs(touch0Now - touch1Now) /\n Math.abs(touch0Start - touch1Start);\n }\n clipXY = ((plotLeftTop - touch0Now) / scale) + touch0Start;\n selectionWH = chart['plot' + (horiz ? 'Width' : 'Height')] / scale;\n };\n var selectionWH,\n selectionXY,\n clipXY,\n scale = forcedScale || 1,\n touch0Now = touches[0][sChartXY],\n touch1Now = !singleTouch && touches[1][sChartXY],\n outOfBounds;\n // Set the scale, first pass\n setScale();\n // The clip position (x or y) is altered if out of bounds, the selection\n // position is not\n selectionXY = clipXY;\n // Out of bounds\n if (selectionXY < bounds.min) {\n selectionXY = bounds.min;\n outOfBounds = true;\n }\n else if (selectionXY + selectionWH > bounds.max) {\n selectionXY = bounds.max - selectionWH;\n outOfBounds = true;\n }\n // Is the chart dragged off its bounds, determined by dataMin and\n // dataMax?\n if (outOfBounds) {\n // Modify the touchNow position in order to create an elastic drag\n // movement. This indicates to the user that the chart is responsive\n // but can't be dragged further.\n touch0Now -= 0.8 * (touch0Now - lastValidTouch[xy][0]);\n if (typeof touch1Now === 'number') {\n touch1Now -= 0.8 * (touch1Now - lastValidTouch[xy][1]);\n }\n // Set the scale, second pass to adapt to the modified touchNow\n // positions\n setScale();\n }\n else {\n lastValidTouch[xy] = [touch0Now, touch1Now];\n }\n // Set geometry for clipping, selection and transformation\n if (!inverted) {\n clip[xy] = clipXY - plotLeftTop;\n clip[wh] = selectionWH;\n }\n var scaleKey = inverted ?\n (horiz ? 'scaleY' : 'scaleX') : 'scale' + XY;\n var transformScale = inverted ? 1 / scale : scale;\n selectionMarker[wh] = selectionWH;\n selectionMarker[xy] = selectionXY;\n transform[scaleKey] = scale;\n transform['translate' + XY] = (transformScale * plotLeftTop) +\n (touch0Now - (transformScale * touch0Start));\n };\n /**\n * Reset the tracking by hiding the tooltip, the hover series state and the\n * hover point\n *\n * @function Highcharts.Pointer#reset\n *\n * @param {boolean} [allowMove]\n * Instead of destroying the tooltip altogether, allow moving it if\n * possible.\n *\n * @param {number} [delay]\n */\n Pointer.prototype.reset = function (allowMove, delay) {\n var pointer = this,\n chart = pointer.chart,\n hoverSeries = chart.hoverSeries,\n hoverPoint = chart.hoverPoint,\n hoverPoints = chart.hoverPoints,\n tooltip = chart.tooltip,\n tooltipPoints = tooltip && tooltip.shared ?\n hoverPoints :\n hoverPoint;\n // Check if the points have moved outside the plot area (#1003, #4736,\n // #5101)\n if (allowMove && tooltipPoints) {\n splat(tooltipPoints).forEach(function (point) {\n if (point.series.isCartesian &&\n typeof point.plotX === 'undefined') {\n allowMove = false;\n }\n });\n }\n // Just move the tooltip, #349\n if (allowMove) {\n if (tooltip && tooltipPoints && splat(tooltipPoints).length) {\n tooltip.refresh(tooltipPoints);\n if (tooltip.shared && hoverPoints) { // #8284\n hoverPoints.forEach(function (point) {\n point.setState(point.state, true);\n if (point.series.isCartesian) {\n if (point.series.xAxis.crosshair) {\n point.series.xAxis\n .drawCrosshair(null, point);\n }\n if (point.series.yAxis.crosshair) {\n point.series.yAxis\n .drawCrosshair(null, point);\n }\n }\n });\n }\n else if (hoverPoint) { // #2500\n hoverPoint.setState(hoverPoint.state, true);\n chart.axes.forEach(function (axis) {\n if (axis.crosshair &&\n hoverPoint.series[axis.coll] === axis) {\n axis.drawCrosshair(null, hoverPoint);\n }\n });\n }\n }\n // Full reset\n }\n else {\n if (hoverPoint) {\n hoverPoint.onMouseOut();\n }\n if (hoverPoints) {\n hoverPoints.forEach(function (point) {\n point.setState();\n });\n }\n if (hoverSeries) {\n hoverSeries.onMouseOut();\n }\n if (tooltip) {\n tooltip.hide(delay);\n }\n if (pointer.unDocMouseMove) {\n pointer.unDocMouseMove = pointer.unDocMouseMove();\n }\n // Remove crosshairs\n chart.axes.forEach(function (axis) {\n axis.hideCrosshair();\n });\n pointer.hoverX = chart.hoverPoints = chart.hoverPoint = null;\n }\n };\n /**\n * With line type charts with a single tracker, get the point closest to the\n * mouse. Run Point.onMouseOver and display tooltip for the point or points.\n *\n * @private\n * @function Highcharts.Pointer#runPointActions\n *\n * @emits Highcharts.Point#event:mouseOut\n * @emits Highcharts.Point#event:mouseOver\n */\n Pointer.prototype.runPointActions = function (e, p) {\n var pointer = this,\n chart = pointer.chart,\n series = chart.series,\n tooltip = (chart.tooltip && chart.tooltip.options.enabled ?\n chart.tooltip :\n void 0),\n shared = (tooltip ?\n tooltip.shared :\n false);\n var hoverPoint = p || chart.hoverPoint,\n hoverSeries = hoverPoint && hoverPoint.series || chart.hoverSeries;\n var // onMouseOver or already hovering a series with directTouch\n isDirectTouch = (!e || e.type !== 'touchmove') && (!!p || ((hoverSeries && hoverSeries.directTouch) &&\n pointer.isDirectTouch)),\n hoverData = this.getHoverData(hoverPoint,\n hoverSeries,\n series,\n isDirectTouch,\n shared,\n e);\n // Update variables from hoverData.\n hoverPoint = hoverData.hoverPoint;\n hoverSeries = hoverData.hoverSeries;\n var points = hoverData.hoverPoints,\n followPointer = hoverSeries &&\n hoverSeries.tooltipOptions.followPointer &&\n !hoverSeries.tooltipOptions.split,\n useSharedTooltip = (shared &&\n hoverSeries &&\n !hoverSeries.noSharedTooltip);\n // Refresh tooltip for kdpoint if new hover point or tooltip was hidden\n // #3926, #4200\n if (hoverPoint &&\n // !(hoverSeries && hoverSeries.directTouch) &&\n (hoverPoint !== chart.hoverPoint || (tooltip && tooltip.isHidden))) {\n (chart.hoverPoints || []).forEach(function (p) {\n if (points.indexOf(p) === -1) {\n p.setState();\n }\n });\n // Set normal state to previous series\n if (chart.hoverSeries !== hoverSeries) {\n hoverSeries.onMouseOver();\n }\n pointer.applyInactiveState(points);\n // Do mouseover on all points (#3919, #3985, #4410, #5622)\n (points || []).forEach(function (p) {\n p.setState('hover');\n });\n // If tracking is on series in stead of on each point,\n // fire mouseOver on hover point. // #4448\n if (chart.hoverPoint) {\n chart.hoverPoint.firePointEvent('mouseOut');\n }\n // Hover point may have been destroyed in the event handlers (#7127)\n if (!hoverPoint.series) {\n return;\n }\n /**\n * Contains all hovered points.\n *\n * @name Highcharts.Chart#hoverPoints\n * @type {Array|null}\n */\n chart.hoverPoints = points;\n /**\n * Contains the original hovered point.\n *\n * @name Highcharts.Chart#hoverPoint\n * @type {Highcharts.Point|null}\n */\n chart.hoverPoint = hoverPoint;\n /**\n * Hover state should not be lost when axis is updated (#12569)\n * Axis.update runs pointer.reset which uses chart.hoverPoint.state\n * to apply state which does not exist in hoverPoint yet.\n * The mouseOver event should be triggered when hoverPoint\n * is correct.\n */\n hoverPoint.firePointEvent('mouseOver', void 0, function () {\n // Draw tooltip if necessary\n if (tooltip && hoverPoint) {\n tooltip.refresh(useSharedTooltip ? points : hoverPoint, e);\n }\n });\n // Update positions (regardless of kdpoint or hoverPoint)\n }\n else if (followPointer && tooltip && !tooltip.isHidden) {\n var anchor = tooltip.getAnchor([{}],\n e);\n if (chart.isInsidePlot(anchor[0], anchor[1], {\n visiblePlotOnly: true\n })) {\n tooltip.updatePosition({ plotX: anchor[0], plotY: anchor[1] });\n }\n }\n // Start the event listener to pick up the tooltip and crosshairs\n if (!pointer.unDocMouseMove) {\n pointer.unDocMouseMove = addEvent(chart.container.ownerDocument, 'mousemove', function (e) {\n var chart = charts[Pointer.hoverChartIndex];\n if (chart) {\n chart.pointer.onDocumentMouseMove(e);\n }\n });\n pointer.eventsToUnbind.push(pointer.unDocMouseMove);\n }\n // Issues related to crosshair #4927, #5269 #5066, #5658\n chart.axes.forEach(function drawAxisCrosshair(axis) {\n var snap = pick((axis.crosshair || {}).snap,\n true);\n var point;\n if (snap) {\n point = chart.hoverPoint; // #13002\n if (!point || point.series[axis.coll] !== axis) {\n point = find(points, function (p) {\n return p.series && p.series[axis.coll] === axis;\n });\n }\n }\n // Axis has snapping crosshairs, and one of the hover points belongs\n // to axis. Always call drawCrosshair when it is not snap.\n if (point || !snap) {\n axis.drawCrosshair(e, point);\n // Axis has snapping crosshairs, but no hover point belongs to axis\n }\n else {\n axis.hideCrosshair();\n }\n });\n };\n /**\n * Scale series groups to a certain scale and translation.\n * @private\n * @function Highcharts.Pointer#scaleGroups\n */\n Pointer.prototype.scaleGroups = function (attribs, clip) {\n var chart = this.chart;\n // Scale each series\n chart.series.forEach(function (series) {\n var seriesAttribs = attribs || series.getPlotBox(); // #1701\n if (series.group &&\n ((series.xAxis && series.xAxis.zoomEnabled) ||\n chart.mapView)) {\n series.group.attr(seriesAttribs);\n if (series.markerGroup) {\n series.markerGroup.attr(seriesAttribs);\n series.markerGroup.clip(clip ? chart.clipRect : null);\n }\n if (series.dataLabelsGroup) {\n series.dataLabelsGroup.attr(seriesAttribs);\n }\n }\n });\n // Clip\n chart.clipRect.attr(clip || chart.clipBox);\n };\n /**\n * Set the JS DOM events on the container and document. This method should\n * contain a one-to-one assignment between methods and their handlers. Any\n * advanced logic should be moved to the handler reflecting the event's\n * name.\n * @private\n * @function Highcharts.Pointer#setDOMEvents\n */\n Pointer.prototype.setDOMEvents = function () {\n var _this = this;\n var container = this.chart.container,\n ownerDoc = container.ownerDocument;\n container.onmousedown = this.onContainerMouseDown.bind(this);\n container.onmousemove = this.onContainerMouseMove.bind(this);\n container.onclick = this.onContainerClick.bind(this);\n this.eventsToUnbind.push(addEvent(container, 'mouseenter', this.onContainerMouseEnter.bind(this)));\n this.eventsToUnbind.push(addEvent(container, 'mouseleave', this.onContainerMouseLeave.bind(this)));\n if (!Pointer.unbindDocumentMouseUp) {\n Pointer.unbindDocumentMouseUp = addEvent(ownerDoc, 'mouseup', this.onDocumentMouseUp.bind(this));\n }\n // In case we are dealing with overflow, reset the chart position when\n // scrolling parent elements\n var parent = this.chart.renderTo.parentElement;\n while (parent && parent.tagName !== 'BODY') {\n this.eventsToUnbind.push(addEvent(parent, 'scroll', function () {\n delete _this.chartPosition;\n }));\n parent = parent.parentElement;\n }\n if (H.hasTouch) {\n this.eventsToUnbind.push(addEvent(container, 'touchstart', this.onContainerTouchStart.bind(this), { passive: false }));\n this.eventsToUnbind.push(addEvent(container, 'touchmove', this.onContainerTouchMove.bind(this), { passive: false }));\n if (!Pointer.unbindDocumentTouchEnd) {\n Pointer.unbindDocumentTouchEnd = addEvent(ownerDoc, 'touchend', this.onDocumentTouchEnd.bind(this), { passive: false });\n }\n }\n };\n /**\n * Sets the index of the hovered chart and leaves the previous hovered\n * chart, to reset states like tooltip.\n * @private\n * @function Highcharts.Pointer#setHoverChartIndex\n */\n Pointer.prototype.setHoverChartIndex = function () {\n var chart = this.chart;\n var hoverChart = H.charts[pick(Pointer.hoverChartIndex, -1)];\n if (hoverChart &&\n hoverChart !== chart) {\n hoverChart.pointer.onContainerMouseLeave({ relatedTarget: chart.container });\n }\n if (!hoverChart ||\n !hoverChart.mouseIsDown) {\n Pointer.hoverChartIndex = chart.index;\n }\n };\n /**\n * General touch handler shared by touchstart and touchmove.\n * @private\n * @function Highcharts.Pointer#touch\n */\n Pointer.prototype.touch = function (e, start) {\n var chart = this.chart;\n var hasMoved,\n pinchDown,\n isInside;\n this.setHoverChartIndex();\n if (e.touches.length === 1) {\n e = this.normalize(e);\n isInside = chart.isInsidePlot(e.chartX - chart.plotLeft, e.chartY - chart.plotTop, {\n visiblePlotOnly: true\n });\n if (isInside && !chart.openMenu) {\n // Run mouse events and display tooltip etc\n if (start) {\n this.runPointActions(e);\n }\n // Android fires touchmove events after the touchstart even if\n // the finger hasn't moved, or moved only a pixel or two. In iOS\n // however, the touchmove doesn't fire unless the finger moves\n // more than ~4px. So we emulate this behaviour in Android by\n // checking how much it moved, and cancelling on small\n // distances. #3450.\n if (e.type === 'touchmove') {\n pinchDown = this.pinchDown;\n hasMoved = pinchDown[0] ? Math.sqrt(// #5266\n Math.pow(pinchDown[0].chartX - e.chartX, 2) +\n Math.pow(pinchDown[0].chartY - e.chartY, 2)) >= 4 : false;\n }\n if (pick(hasMoved, true)) {\n this.pinch(e);\n }\n }\n else if (start) {\n // Hide the tooltip on touching outside the plot area (#1203)\n this.reset();\n }\n }\n else if (e.touches.length === 2) {\n this.pinch(e);\n }\n };\n /**\n * Returns true if the chart is set up for zooming by single touch and the\n * event is capable\n * @private\n * @function Highcharts.Pointer#touchSelect\n */\n Pointer.prototype.touchSelect = function (e) {\n return Boolean(this.chart.options.chart.zooming.singleTouch &&\n e.touches &&\n e.touches.length === 1);\n };\n /**\n * Resolve the zoomType option, this is reset on all touch start and mouse\n * down events.\n * @private\n * @function Highcharts.Pointer#zoomOption\n */\n Pointer.prototype.zoomOption = function (e) {\n var chart = this.chart,\n options = chart.options.chart,\n inverted = chart.inverted;\n var zoomType = options.zooming.type || '',\n zoomX,\n zoomY;\n // Look for the pinchType option\n if (/touch/.test(e.type)) {\n zoomType = pick(options.zooming.pinchType, zoomType);\n }\n this.zoomX = zoomX = /x/.test(zoomType);\n this.zoomY = zoomY = /y/.test(zoomType);\n this.zoomHor = (zoomX && !inverted) || (zoomY && inverted);\n this.zoomVert = (zoomY && !inverted) || (zoomX && inverted);\n this.hasZoom = zoomX || zoomY;\n };\n return Pointer;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Chart position and scale.\n *\n * @interface Highcharts.ChartPositionObject\n */ /**\n * @name Highcharts.ChartPositionObject#left\n * @type {number}\n */ /**\n * @name Highcharts.ChartPositionObject#scaleX\n * @type {number}\n */ /**\n * @name Highcharts.ChartPositionObject#scaleY\n * @type {number}\n */ /**\n * @name Highcharts.ChartPositionObject#top\n * @type {number}\n */\n /**\n * One position in relation to an axis.\n *\n * @interface Highcharts.PointerAxisCoordinateObject\n */ /**\n * Related axis.\n *\n * @name Highcharts.PointerAxisCoordinateObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * Axis value.\n *\n * @name Highcharts.PointerAxisCoordinateObject#value\n * @type {number}\n */\n /**\n * Positions in terms of axis values.\n *\n * @interface Highcharts.PointerAxisCoordinatesObject\n */ /**\n * Positions on the x-axis.\n * @name Highcharts.PointerAxisCoordinatesObject#xAxis\n * @type {Array}\n */ /**\n * Positions on the y-axis.\n * @name Highcharts.PointerAxisCoordinatesObject#yAxis\n * @type {Array}\n */\n /**\n * Pointer coordinates.\n *\n * @interface Highcharts.PointerCoordinatesObject\n */ /**\n * @name Highcharts.PointerCoordinatesObject#chartX\n * @type {number}\n */ /**\n * @name Highcharts.PointerCoordinatesObject#chartY\n * @type {number}\n */\n /**\n * A native browser mouse or touch event, extended with position information\n * relative to the {@link Chart.container}.\n *\n * @interface Highcharts.PointerEventObject\n * @extends global.PointerEvent\n */ /**\n * The X coordinate of the pointer interaction relative to the chart.\n *\n * @name Highcharts.PointerEventObject#chartX\n * @type {number}\n */ /**\n * The Y coordinate of the pointer interaction relative to the chart.\n *\n * @name Highcharts.PointerEventObject#chartY\n * @type {number}\n */\n /**\n * Axis-specific data of a selection.\n *\n * @interface Highcharts.SelectDataObject\n */ /**\n * The selected Axis.\n * @name Highcharts.SelectDataObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * The maximum axis value, either automatic or set manually.\n * @name Highcharts.SelectDataObject#max\n * @type {number}\n */ /**\n * The minimum axis value, either automatic or set manually.\n * @name Highcharts.SelectDataObject#min\n * @type {number}\n */\n /**\n * Object for select events.\n * The primary axes are `xAxis[0]` and `yAxis[0]`. Remember the unit of a\n * datetime axis is milliseconds since 1970-01-01 00:00:00.\n *\n * @interface Highcharts.SelectEventObject\n */ /**\n * The related browser event.\n * @name Highcharts.SelectEventObject#originalEvent\n * @type {global.Event}\n */ /**\n * Indicates a reset event to restore default state.\n * @name Highcharts.SelectEventObject#resetSelection\n * @type {boolean|undefined}\n */ /**\n * Arrays containing the axes of each dimension and each axis' min and max\n * values.\n * @name Highcharts.SelectEventObject#xAxis\n * @type {Array}\n */ /**\n * Arrays containing the axes of each dimension and each axis' min and max\n * values.\n * @name Highcharts.SelectEventObject#yAxis\n * @type {Array}\n */\n ''; // keeps doclets above in JS file\n\n return Pointer;\n });\n _registerModule(_modules, 'Core/MSPointer.js', [_modules['Core/Globals.js'], _modules['Core/Pointer.js'], _modules['Core/Utilities.js']], function (H, Pointer, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var charts = H.charts,\n doc = H.doc,\n noop = H.noop,\n win = H.win;\n var addEvent = U.addEvent,\n css = U.css,\n objectEach = U.objectEach,\n pick = U.pick,\n removeEvent = U.removeEvent;\n /* *\n *\n * Constants\n *\n * */\n // The touches object keeps track of the points being touched at all times\n var touches = {};\n var hasPointerEvent = !!win.PointerEvent;\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /** @private */\n function getWebkitTouches() {\n var fake = [];\n fake.item = function (i) {\n return this[i];\n };\n objectEach(touches, function (touch) {\n fake.push({\n pageX: touch.pageX,\n pageY: touch.pageY,\n target: touch.target\n });\n });\n return fake;\n }\n /** @private */\n function translateMSPointer(e, method, wktype, func) {\n var chart = charts[Pointer.hoverChartIndex || NaN];\n if ((e.pointerType === 'touch' ||\n e.pointerType === e.MSPOINTER_TYPE_TOUCH) && chart) {\n var p = chart.pointer;\n func(e);\n p[method]({\n type: wktype,\n target: e.currentTarget,\n preventDefault: noop,\n touches: getWebkitTouches()\n });\n }\n }\n /* *\n *\n * Class\n *\n * */\n /** @private */\n var MSPointer = /** @class */ (function (_super) {\n __extends(MSPointer, _super);\n function MSPointer() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n /* *\n *\n * Static Functions\n *\n * */\n MSPointer.isRequired = function () {\n return !!(!H.hasTouch && (win.PointerEvent || win.MSPointerEvent));\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Add or remove the MS Pointer specific events\n * @private\n * @function Highcharts.Pointer#batchMSEvents\n */\n MSPointer.prototype.batchMSEvents = function (fn) {\n fn(this.chart.container, hasPointerEvent ? 'pointerdown' : 'MSPointerDown', this.onContainerPointerDown);\n fn(this.chart.container, hasPointerEvent ? 'pointermove' : 'MSPointerMove', this.onContainerPointerMove);\n fn(doc, hasPointerEvent ? 'pointerup' : 'MSPointerUp', this.onDocumentPointerUp);\n };\n // Destroy MS events also\n MSPointer.prototype.destroy = function () {\n this.batchMSEvents(removeEvent);\n _super.prototype.destroy.call(this);\n };\n // Disable default IE actions for pinch and such on chart element\n MSPointer.prototype.init = function (chart, options) {\n _super.prototype.init.call(this, chart, options);\n if (this.hasZoom) { // #4014\n css(chart.container, {\n '-ms-touch-action': 'none',\n 'touch-action': 'none'\n });\n }\n };\n /**\n * @private\n * @function Highcharts.Pointer#onContainerPointerDown\n */\n MSPointer.prototype.onContainerPointerDown = function (e) {\n translateMSPointer(e, 'onContainerTouchStart', 'touchstart', function (e) {\n touches[e.pointerId] = {\n pageX: e.pageX,\n pageY: e.pageY,\n target: e.currentTarget\n };\n });\n };\n /**\n * @private\n * @function Highcharts.Pointer#onContainerPointerMove\n */\n MSPointer.prototype.onContainerPointerMove = function (e) {\n translateMSPointer(e, 'onContainerTouchMove', 'touchmove', function (e) {\n touches[e.pointerId] = ({ pageX: e.pageX, pageY: e.pageY });\n if (!touches[e.pointerId].target) {\n touches[e.pointerId].target = e.currentTarget;\n }\n });\n };\n /**\n * @private\n * @function Highcharts.Pointer#onDocumentPointerUp\n */\n MSPointer.prototype.onDocumentPointerUp = function (e) {\n translateMSPointer(e, 'onDocumentTouchEnd', 'touchend', function (e) {\n delete touches[e.pointerId];\n });\n };\n // Add IE specific touch events to chart\n MSPointer.prototype.setDOMEvents = function () {\n var tooltip = this.chart.tooltip;\n _super.prototype.setDOMEvents.call(this);\n if (this.hasZoom ||\n pick((tooltip && tooltip.options.followTouchMove), true)) {\n this.batchMSEvents(addEvent);\n }\n };\n return MSPointer;\n }(Pointer));\n /* *\n *\n * Default Export\n *\n * */\n\n return MSPointer;\n });\n _registerModule(_modules, 'Core/Legend/Legend.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/FormatUtilities.js'], _modules['Core/Globals.js'], _modules['Core/Series/Point.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Utilities.js']], function (A, F, H, Point, R, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var animObject = A.animObject,\n setAnimation = A.setAnimation;\n var format = F.format;\n var isFirefox = H.isFirefox,\n marginNames = H.marginNames,\n win = H.win;\n var distribute = R.distribute;\n var addEvent = U.addEvent,\n createElement = U.createElement,\n css = U.css,\n defined = U.defined,\n discardElement = U.discardElement,\n find = U.find,\n fireEvent = U.fireEvent,\n isNumber = U.isNumber,\n merge = U.merge,\n pick = U.pick,\n relativeLength = U.relativeLength,\n stableSort = U.stableSort,\n syncTimeout = U.syncTimeout,\n wrap = U.wrap;\n /* *\n *\n * Class\n *\n * */\n /**\n * The overview of the chart's series. The legend object is instanciated\n * internally in the chart constructor, and is available from the `chart.legend`\n * property. Each chart has only one legend.\n *\n * @class\n * @name Highcharts.Legend\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.LegendOptions} options\n * Legend options.\n */\n var Legend = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Legend(chart, options) {\n /* *\n *\n * Properties\n *\n * */\n this.allItems = [];\n this.box = void 0;\n this.contentGroup = void 0;\n this.display = false;\n this.group = void 0;\n this.initialItemY = 0;\n this.itemHeight = 0;\n this.itemMarginBottom = 0;\n this.itemMarginTop = 0;\n this.itemX = 0;\n this.itemY = 0;\n this.lastItemY = 0;\n this.lastLineHeight = 0;\n this.legendHeight = 0;\n this.legendWidth = 0;\n this.maxItemWidth = 0;\n this.maxLegendWidth = 0;\n this.offsetWidth = 0;\n this.options = void 0;\n this.padding = 0;\n this.pages = [];\n this.proximate = false;\n this.scrollGroup = void 0;\n this.symbolHeight = 0;\n this.symbolWidth = 0;\n this.titleHeight = 0;\n this.totalItemWidth = 0;\n this.widthOption = 0;\n this.chart = chart;\n this.init(chart, options);\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Initialize the legend.\n *\n * @private\n * @function Highcharts.Legend#init\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.LegendOptions} options\n * Legend options.\n */\n Legend.prototype.init = function (chart, options) {\n /**\n * Chart of this legend.\n *\n * @readonly\n * @name Highcharts.Legend#chart\n * @type {Highcharts.Chart}\n */\n this.chart = chart;\n this.setOptions(options);\n if (options.enabled) {\n // Render it\n this.render();\n // move checkboxes\n addEvent(this.chart, 'endResize', function () {\n this.legend.positionCheckboxes();\n });\n if (this.proximate) {\n this.unchartrender = addEvent(this.chart, 'render', function () {\n this.legend.proximatePositions();\n this.legend.positionItems();\n });\n }\n else if (this.unchartrender) {\n this.unchartrender();\n }\n }\n };\n /**\n * @private\n * @function Highcharts.Legend#setOptions\n * @param {Highcharts.LegendOptions} options\n */\n Legend.prototype.setOptions = function (options) {\n var padding = pick(options.padding, 8);\n /**\n * Legend options.\n *\n * @readonly\n * @name Highcharts.Legend#options\n * @type {Highcharts.LegendOptions}\n */\n this.options = options;\n if (!this.chart.styledMode) {\n this.itemStyle = options.itemStyle;\n this.itemHiddenStyle = merge(this.itemStyle, options.itemHiddenStyle);\n }\n this.itemMarginTop = options.itemMarginTop || 0;\n this.itemMarginBottom = options.itemMarginBottom || 0;\n this.padding = padding;\n this.initialItemY = padding - 5; // 5 is pixels above the text\n this.symbolWidth = pick(options.symbolWidth, 16);\n this.pages = [];\n this.proximate = options.layout === 'proximate' && !this.chart.inverted;\n // #12705: baseline has to be reset on every update\n this.baseline = void 0;\n };\n /**\n * Update the legend with new options. Equivalent to running `chart.update`\n * with a legend configuration option.\n *\n * @sample highcharts/legend/legend-update/\n * Legend update\n *\n * @function Highcharts.Legend#update\n *\n * @param {Highcharts.LegendOptions} options\n * Legend options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the axis is altered. If doing more\n * operations on the chart, it is a good idea to set redraw to false and\n * call {@link Chart#redraw} after. Whether to redraw the chart.\n *\n * @emits Highcharts.Legends#event:afterUpdate\n */\n Legend.prototype.update = function (options, redraw) {\n var chart = this.chart;\n this.setOptions(merge(true, this.options, options));\n this.destroy();\n chart.isDirtyLegend = chart.isDirtyBox = true;\n if (pick(redraw, true)) {\n chart.redraw();\n }\n fireEvent(this, 'afterUpdate');\n };\n /**\n * Set the colors for the legend item.\n *\n * @private\n * @function Highcharts.Legend#colorizeItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n * A Series or Point instance\n * @param {boolean} [visible=false]\n * Dimmed or colored\n *\n * @todo\n * Make events official: Fires the event `afterColorizeItem`.\n */\n Legend.prototype.colorizeItem = function (item, visible) {\n var _a = item.legendItem || {},\n group = _a.group,\n label = _a.label,\n line = _a.line,\n symbol = _a.symbol;\n if (group) {\n group[visible ? 'removeClass' : 'addClass']('highcharts-legend-item-hidden');\n }\n if (!this.chart.styledMode) {\n var legend = this,\n options = legend.options,\n hiddenColor = legend.itemHiddenStyle.color,\n textColor = visible ?\n options.itemStyle.color :\n hiddenColor,\n symbolColor = visible ?\n (item.color || hiddenColor) :\n hiddenColor,\n markerOptions = item.options && item.options.marker;\n var symbolAttr = { fill: symbolColor };\n if (label) {\n label.css({\n fill: textColor,\n color: textColor // #1553, oldIE\n });\n }\n if (line) {\n line.attr({ stroke: symbolColor });\n }\n if (symbol) {\n // Apply marker options\n if (markerOptions && symbol.isMarker) { // #585\n symbolAttr = item.pointAttribs();\n if (!visible) {\n // #6769\n symbolAttr.stroke = symbolAttr.fill = hiddenColor;\n }\n }\n symbol.attr(symbolAttr);\n }\n }\n fireEvent(this, 'afterColorizeItem', { item: item, visible: visible });\n };\n /**\n * @private\n * @function Highcharts.Legend#positionItems\n */\n Legend.prototype.positionItems = function () {\n // Now that the legend width and height are established, put the items\n // in the final position\n this.allItems.forEach(this.positionItem, this);\n if (!this.chart.isResizing) {\n this.positionCheckboxes();\n }\n };\n /**\n * Position the legend item.\n *\n * @private\n * @function Highcharts.Legend#positionItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n * The item to position\n */\n Legend.prototype.positionItem = function (item) {\n var _this = this;\n var legend = this,\n _a = item.legendItem || {},\n group = _a.group,\n _b = _a.x,\n x = _b === void 0 ? 0 : _b,\n _c = _a.y,\n y = _c === void 0 ? 0 : _c,\n options = legend.options,\n symbolPadding = options.symbolPadding,\n ltr = !options.rtl,\n checkbox = item.checkbox;\n if (group && group.element) {\n var attribs = {\n translateX: ltr ?\n x :\n legend.legendWidth - x - 2 * symbolPadding - 4,\n translateY: y\n };\n var complete = function () {\n fireEvent(_this, 'afterPositionItem', { item: item });\n };\n group[defined(group.translateY) ? 'animate' : 'attr'](attribs, void 0, complete);\n }\n if (checkbox) {\n checkbox.x = x;\n checkbox.y = y;\n }\n };\n /**\n * Destroy a single legend item, used internally on removing series items.\n *\n * @private\n * @function Highcharts.Legend#destroyItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n * The item to remove\n */\n Legend.prototype.destroyItem = function (item) {\n var checkbox = item.checkbox,\n legendItem = item.legendItem || {};\n // destroy SVG elements\n for (var _i = 0, _a = ['group', 'label', 'line', 'symbol']; _i < _a.length; _i++) {\n var key = _a[_i];\n if (legendItem[key]) {\n legendItem[key] = legendItem[key].destroy();\n }\n }\n if (checkbox) {\n discardElement(checkbox);\n }\n item.legendItem = void 0;\n };\n /**\n * Destroy the legend. Used internally. To reflow objects, `chart.redraw`\n * must be called after destruction.\n *\n * @private\n * @function Highcharts.Legend#destroy\n */\n Legend.prototype.destroy = function () {\n var legend = this;\n // Destroy items\n for (var _i = 0, _a = this.getAllItems(); _i < _a.length; _i++) {\n var item = _a[_i];\n this.destroyItem(item);\n }\n // Destroy legend elements\n for (var _b = 0, _c = [\n 'clipRect',\n 'up',\n 'down',\n 'pager',\n 'nav',\n 'box',\n 'title',\n 'group'\n ]; _b < _c.length; _b++) {\n var key = _c[_b];\n if (legend[key]) {\n legend[key] = legend[key].destroy();\n }\n }\n this.display = null; // Reset in .render on update.\n };\n /**\n * Position the checkboxes after the width is determined.\n *\n * @private\n * @function Highcharts.Legend#positionCheckboxes\n */\n Legend.prototype.positionCheckboxes = function () {\n var alignAttr = this.group && this.group.alignAttr,\n clipHeight = this.clipHeight || this.legendHeight,\n titleHeight = this.titleHeight;\n var translateY;\n if (alignAttr) {\n translateY = alignAttr.translateY;\n this.allItems.forEach(function (item) {\n var checkbox = item.checkbox;\n var top;\n if (checkbox) {\n top = translateY + titleHeight + checkbox.y +\n (this.scrollOffset || 0) + 3;\n css(checkbox, {\n left: (alignAttr.translateX + item.checkboxOffset +\n checkbox.x - 20) + 'px',\n top: top + 'px',\n display: this.proximate || (top > translateY - 6 &&\n top < translateY + clipHeight - 6) ?\n '' :\n 'none'\n });\n }\n }, this);\n }\n };\n /**\n * Render the legend title on top of the legend.\n *\n * @private\n * @function Highcharts.Legend#renderTitle\n */\n Legend.prototype.renderTitle = function () {\n var options = this.options,\n padding = this.padding,\n titleOptions = options.title;\n var bBox,\n titleHeight = 0;\n if (titleOptions.text) {\n if (!this.title) {\n /**\n * SVG element of the legend title.\n *\n * @readonly\n * @name Highcharts.Legend#title\n * @type {Highcharts.SVGElement}\n */\n this.title = this.chart.renderer.label(titleOptions.text, padding - 3, padding - 4, void 0, void 0, void 0, options.useHTML, void 0, 'legend-title')\n .attr({ zIndex: 1 });\n if (!this.chart.styledMode) {\n this.title.css(titleOptions.style);\n }\n this.title.add(this.group);\n }\n // Set the max title width (#7253)\n if (!titleOptions.width) {\n this.title.css({\n width: this.maxLegendWidth + 'px'\n });\n }\n bBox = this.title.getBBox();\n titleHeight = bBox.height;\n this.offsetWidth = bBox.width; // #1717\n this.contentGroup.attr({ translateY: titleHeight });\n }\n this.titleHeight = titleHeight;\n };\n /**\n * Set the legend item text.\n *\n * @function Highcharts.Legend#setText\n * @param {Highcharts.Point|Highcharts.Series} item\n * The item for which to update the text in the legend.\n */\n Legend.prototype.setText = function (item) {\n var options = this.options;\n item.legendItem.label.attr({\n text: options.labelFormat ?\n format(options.labelFormat, item, this.chart) :\n options.labelFormatter.call(item)\n });\n };\n /**\n * Render a single specific legend item. Called internally from the `render`\n * function.\n *\n * @private\n * @function Highcharts.Legend#renderItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n * The item to render.\n */\n Legend.prototype.renderItem = function (item) {\n var legend = this,\n legendItem = item.legendItem = item.legendItem || {},\n chart = legend.chart,\n renderer = chart.renderer,\n options = legend.options,\n horizontal = options.layout === 'horizontal',\n symbolWidth = legend.symbolWidth,\n symbolPadding = options.symbolPadding || 0,\n itemStyle = legend.itemStyle,\n itemHiddenStyle = legend.itemHiddenStyle,\n itemDistance = horizontal ? pick(options.itemDistance, 20) : 0,\n ltr = !options.rtl,\n isSeries = !item.series,\n series = !isSeries && item.series.drawLegendSymbol ?\n item.series :\n item,\n seriesOptions = series.options,\n showCheckbox = (legend.createCheckboxForItem) &&\n seriesOptions &&\n seriesOptions.showCheckbox,\n useHTML = options.useHTML,\n itemClassName = item.options.className;\n var label = legendItem.label, \n // full width minus text width\n itemExtraWidth = symbolWidth + symbolPadding +\n itemDistance + (showCheckbox ? 20 : 0);\n if (!label) { // generate it once, later move it\n // Generate the group box, a group to hold the symbol and text. Text\n // is to be appended in Legend class.\n legendItem.group = renderer\n .g('legend-item')\n .addClass('highcharts-' + series.type + '-series ' +\n 'highcharts-color-' + item.colorIndex +\n (itemClassName ? ' ' + itemClassName : '') +\n (isSeries ?\n ' highcharts-series-' + item.index :\n ''))\n .attr({ zIndex: 1 })\n .add(legend.scrollGroup);\n // Generate the list item text and add it to the group\n legendItem.label = label = renderer.text('', ltr ?\n symbolWidth + symbolPadding :\n -symbolPadding, legend.baseline || 0, useHTML);\n if (!chart.styledMode) {\n // merge to prevent modifying original (#1021)\n label.css(merge(item.visible ?\n itemStyle :\n itemHiddenStyle));\n }\n label\n .attr({\n align: ltr ? 'left' : 'right',\n zIndex: 2\n })\n .add(legendItem.group);\n // Get the baseline for the first item - the font size is equal for\n // all\n if (!legend.baseline) {\n legend.fontMetrics = renderer.fontMetrics(chart.styledMode ? 12 : itemStyle.fontSize, label);\n legend.baseline =\n legend.fontMetrics.f + 3 + legend.itemMarginTop;\n label.attr('y', legend.baseline);\n legend.symbolHeight =\n options.symbolHeight || legend.fontMetrics.f;\n if (options.squareSymbol) {\n legend.symbolWidth = pick(options.symbolWidth, Math.max(legend.symbolHeight, 16));\n itemExtraWidth = legend.symbolWidth + symbolPadding +\n itemDistance + (showCheckbox ? 20 : 0);\n if (ltr) {\n label.attr('x', legend.symbolWidth + symbolPadding);\n }\n }\n }\n // Draw the legend symbol inside the group box\n series.drawLegendSymbol(legend, item);\n if (legend.setItemEvents) {\n legend.setItemEvents(item, label, useHTML);\n }\n }\n // Add the HTML checkbox on top\n if (showCheckbox && !item.checkbox && legend.createCheckboxForItem) {\n legend.createCheckboxForItem(item);\n }\n // Colorize the items\n legend.colorizeItem(item, item.visible);\n // Take care of max width and text overflow (#6659)\n if (chart.styledMode || !itemStyle.width) {\n label.css({\n width: ((options.itemWidth ||\n legend.widthOption ||\n chart.spacingBox.width) - itemExtraWidth) + 'px'\n });\n }\n // Always update the text\n legend.setText(item);\n // calculate the positions for the next line\n var bBox = label.getBBox();\n var fontMetricsH = (legend.fontMetrics && legend.fontMetrics.h) || 0;\n item.itemWidth = item.checkboxOffset =\n options.itemWidth ||\n legendItem.labelWidth ||\n bBox.width + itemExtraWidth;\n legend.maxItemWidth = Math.max(legend.maxItemWidth, item.itemWidth);\n legend.totalItemWidth += item.itemWidth;\n legend.itemHeight = item.itemHeight = Math.round(legendItem.labelHeight ||\n // use bBox for multiline (#16398)\n (bBox.height > fontMetricsH * 1.5 ? bBox.height : fontMetricsH));\n };\n /**\n * Get the position of the item in the layout. We now know the\n * maxItemWidth from the previous loop.\n *\n * @private\n * @function Highcharts.Legend#layoutItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n */\n Legend.prototype.layoutItem = function (item) {\n var options = this.options,\n padding = this.padding,\n horizontal = options.layout === 'horizontal',\n itemHeight = item.itemHeight,\n itemMarginBottom = this.itemMarginBottom,\n itemMarginTop = this.itemMarginTop,\n itemDistance = horizontal ? pick(options.itemDistance, 20) : 0,\n maxLegendWidth = this.maxLegendWidth,\n itemWidth = (options.alignColumns &&\n this.totalItemWidth > maxLegendWidth) ?\n this.maxItemWidth :\n item.itemWidth,\n legendItem = item.legendItem || {};\n // If the item exceeds the width, start a new line\n if (horizontal &&\n this.itemX - padding + itemWidth > maxLegendWidth) {\n this.itemX = padding;\n if (this.lastLineHeight) { // Not for the first line (#10167)\n this.itemY += (itemMarginTop +\n this.lastLineHeight +\n itemMarginBottom);\n }\n this.lastLineHeight = 0; // reset for next line (#915, #3976)\n }\n // Set the edge positions\n this.lastItemY = itemMarginTop + this.itemY + itemMarginBottom;\n this.lastLineHeight = Math.max(// #915\n itemHeight, this.lastLineHeight);\n // cache the position of the newly generated or reordered items\n legendItem.x = this.itemX;\n legendItem.y = this.itemY;\n // advance\n if (horizontal) {\n this.itemX += itemWidth;\n }\n else {\n this.itemY +=\n itemMarginTop + itemHeight + itemMarginBottom;\n this.lastLineHeight = itemHeight;\n }\n // the width of the widest item\n this.offsetWidth = this.widthOption || Math.max((horizontal ? this.itemX - padding - (item.checkbox ?\n // decrease by itemDistance only when no checkbox #4853\n 0 :\n itemDistance) : itemWidth) + padding, this.offsetWidth);\n };\n /**\n * Get all items, which is one item per series for most series and one\n * item per point for pie series and its derivatives. Fires the event\n * `afterGetAllItems`.\n *\n * @private\n * @function Highcharts.Legend#getAllItems\n * @return {Array<(Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series)>}\n * The current items in the legend.\n * @emits Highcharts.Legend#event:afterGetAllItems\n */\n Legend.prototype.getAllItems = function () {\n var allItems = [];\n this.chart.series.forEach(function (series) {\n var seriesOptions = series && series.options;\n // Handle showInLegend. If the series is linked to another series,\n // defaults to false.\n if (series && pick(seriesOptions.showInLegend, !defined(seriesOptions.linkedTo) ? void 0 : false, true)) {\n // Use points or series for the legend item depending on\n // legendType\n allItems = allItems.concat((series.legendItem || {}).labels ||\n (seriesOptions.legendType === 'point' ?\n series.data :\n series));\n }\n });\n fireEvent(this, 'afterGetAllItems', { allItems: allItems });\n return allItems;\n };\n /**\n * Get a short, three letter string reflecting the alignment and layout.\n *\n * @private\n * @function Highcharts.Legend#getAlignment\n * @return {string}\n * The alignment, empty string if floating\n */\n Legend.prototype.getAlignment = function () {\n var options = this.options;\n // Use the first letter of each alignment option in order to detect\n // the side. (#4189 - use charAt(x) notation instead of [x] for IE7)\n if (this.proximate) {\n return options.align.charAt(0) + 'tv';\n }\n return options.floating ? '' : (options.align.charAt(0) +\n options.verticalAlign.charAt(0) +\n options.layout.charAt(0));\n };\n /**\n * Adjust the chart margins by reserving space for the legend on only one\n * side of the chart. If the position is set to a corner, top or bottom is\n * reserved for horizontal legends and left or right for vertical ones.\n *\n * @private\n * @function Highcharts.Legend#adjustMargins\n * @param {Array} margin\n * @param {Array} spacing\n */\n Legend.prototype.adjustMargins = function (margin, spacing) {\n var chart = this.chart,\n options = this.options,\n alignment = this.getAlignment();\n if (alignment) {\n ([\n /(lth|ct|rth)/,\n /(rtv|rm|rbv)/,\n /(rbh|cb|lbh)/,\n /(lbv|lm|ltv)/\n ]).forEach(function (alignments, side) {\n if (alignments.test(alignment) && !defined(margin[side])) {\n // Now we have detected on which side of the chart we should\n // reserve space for the legend\n chart[marginNames[side]] = Math.max(chart[marginNames[side]], (chart.legend[(side + 1) % 2 ? 'legendHeight' : 'legendWidth'] +\n [1, -1, -1, 1][side] * options[(side % 2) ? 'x' : 'y'] +\n pick(options.margin, 12) +\n spacing[side] +\n (chart.titleOffset[side] || 0)));\n }\n });\n }\n };\n /**\n * @private\n * @function Highcharts.Legend#proximatePositions\n */\n Legend.prototype.proximatePositions = function () {\n var chart = this.chart,\n boxes = [],\n alignLeft = this.options.align === 'left';\n this.allItems.forEach(function (item) {\n var lastPoint,\n height,\n useFirstPoint = alignLeft,\n target,\n top;\n if (item.yAxis) {\n if (item.xAxis.options.reversed) {\n useFirstPoint = !useFirstPoint;\n }\n if (item.points) {\n lastPoint = find(useFirstPoint ?\n item.points :\n item.points.slice(0).reverse(), function (item) {\n return isNumber(item.plotY);\n });\n }\n height = this.itemMarginTop +\n item.legendItem.label.getBBox().height +\n this.itemMarginBottom;\n top = item.yAxis.top - chart.plotTop;\n if (item.visible) {\n target = lastPoint ?\n lastPoint.plotY :\n item.yAxis.height;\n target += top - 0.3 * height;\n }\n else {\n target = top + item.yAxis.height;\n }\n boxes.push({\n target: target,\n size: height,\n item: item\n });\n }\n }, this);\n var legendItem;\n for (var _i = 0, _a = distribute(boxes, chart.plotHeight); _i < _a.length; _i++) {\n var box = _a[_i];\n legendItem = box.item.legendItem || {};\n if (box.pos) {\n legendItem.y = chart.plotTop - chart.spacing[0] + box.pos;\n }\n }\n };\n /**\n * Render the legend. This method can be called both before and after\n * `chart.render`. If called after, it will only rearrange items instead\n * of creating new ones. Called internally on initial render and after\n * redraws.\n *\n * @private\n * @function Highcharts.Legend#render\n */\n Legend.prototype.render = function () {\n var legend = this,\n chart = legend.chart,\n renderer = chart.renderer,\n options = legend.options,\n padding = legend.padding, \n // add each series or point\n allItems = legend.getAllItems();\n var display,\n legendWidth,\n legendHeight,\n legendGroup = legend.group,\n allowedWidth,\n box = legend.box;\n legend.itemX = padding;\n legend.itemY = legend.initialItemY;\n legend.offsetWidth = 0;\n legend.lastItemY = 0;\n legend.widthOption = relativeLength(options.width, chart.spacingBox.width - padding);\n // Compute how wide the legend is allowed to be\n allowedWidth = chart.spacingBox.width - 2 * padding - options.x;\n if (['rm', 'lm'].indexOf(legend.getAlignment().substring(0, 2)) > -1) {\n allowedWidth /= 2;\n }\n legend.maxLegendWidth = legend.widthOption || allowedWidth;\n if (!legendGroup) {\n /**\n * SVG group of the legend.\n *\n * @readonly\n * @name Highcharts.Legend#group\n * @type {Highcharts.SVGElement}\n */\n legend.group = legendGroup = renderer\n .g('legend')\n .addClass(options.className || '')\n .attr({ zIndex: 7 })\n .add();\n legend.contentGroup = renderer\n .g()\n .attr({ zIndex: 1 }) // above background\n .add(legendGroup);\n legend.scrollGroup = renderer\n .g()\n .add(legend.contentGroup);\n }\n legend.renderTitle();\n // sort by legendIndex\n stableSort(allItems, function (a, b) {\n return ((a.options && a.options.legendIndex) || 0) -\n ((b.options && b.options.legendIndex) || 0);\n });\n // reversed legend\n if (options.reversed) {\n allItems.reverse();\n }\n /**\n * All items for the legend, which is an array of series for most series\n * and an array of points for pie series and its derivatives.\n *\n * @readonly\n * @name Highcharts.Legend#allItems\n * @type {Array<(Highcharts.Point|Highcharts.Series)>}\n */\n legend.allItems = allItems;\n legend.display = display = !!allItems.length;\n // Render the items. First we run a loop to set the text and properties\n // and read all the bounding boxes. The next loop computes the item\n // positions based on the bounding boxes.\n legend.lastLineHeight = 0;\n legend.maxItemWidth = 0;\n legend.totalItemWidth = 0;\n legend.itemHeight = 0;\n allItems.forEach(legend.renderItem, legend);\n allItems.forEach(legend.layoutItem, legend);\n // Get the box\n legendWidth = (legend.widthOption || legend.offsetWidth) + padding;\n legendHeight = legend.lastItemY + legend.lastLineHeight +\n legend.titleHeight;\n legendHeight = legend.handleOverflow(legendHeight);\n legendHeight += padding;\n // Draw the border and/or background\n if (!box) {\n /**\n * SVG element of the legend box.\n *\n * @readonly\n * @name Highcharts.Legend#box\n * @type {Highcharts.SVGElement}\n */\n legend.box = box = renderer.rect()\n .addClass('highcharts-legend-box')\n .attr({\n r: options.borderRadius\n })\n .add(legendGroup);\n }\n // Presentational\n if (!chart.styledMode) {\n box\n .attr({\n stroke: options.borderColor,\n 'stroke-width': options.borderWidth || 0,\n fill: options.backgroundColor || 'none'\n })\n .shadow(options.shadow);\n }\n if (legendWidth > 0 && legendHeight > 0) {\n box[box.placed ? 'animate' : 'attr'](box.crisp.call({}, {\n x: 0,\n y: 0,\n width: legendWidth,\n height: legendHeight\n }, box.strokeWidth()));\n }\n // hide the border if no items\n legendGroup[display ? 'show' : 'hide']();\n // Open for responsiveness\n if (chart.styledMode && legendGroup.getStyle('display') === 'none') {\n legendWidth = legendHeight = 0;\n }\n legend.legendWidth = legendWidth;\n legend.legendHeight = legendHeight;\n if (display) {\n legend.align();\n }\n if (!this.proximate) {\n this.positionItems();\n }\n fireEvent(this, 'afterRender');\n };\n /**\n * Align the legend to chart's box.\n *\n * @private\n * @function Highcharts.align\n * @param {Highcharts.BBoxObject} alignTo\n */\n Legend.prototype.align = function (alignTo) {\n if (alignTo === void 0) { alignTo = this.chart.spacingBox; }\n var chart = this.chart,\n options = this.options;\n // If aligning to the top and the layout is horizontal, adjust for\n // the title (#7428)\n var y = alignTo.y;\n if (/(lth|ct|rth)/.test(this.getAlignment()) &&\n chart.titleOffset[0] > 0) {\n y += chart.titleOffset[0];\n }\n else if (/(lbh|cb|rbh)/.test(this.getAlignment()) &&\n chart.titleOffset[2] > 0) {\n y -= chart.titleOffset[2];\n }\n if (y !== alignTo.y) {\n alignTo = merge(alignTo, { y: y });\n }\n if (!chart.hasRendered) {\n // Avoid animation when adjusting alignment for responsiveness and\n // colorAxis label layout\n this.group.placed = false;\n }\n this.group.align(merge(options, {\n width: this.legendWidth,\n height: this.legendHeight,\n verticalAlign: this.proximate ? 'top' : options.verticalAlign\n }), true, alignTo);\n };\n /**\n * Set up the overflow handling by adding navigation with up and down arrows\n * below the legend.\n *\n * @private\n * @function Highcharts.Legend#handleOverflow\n */\n Legend.prototype.handleOverflow = function (legendHeight) {\n var legend = this,\n chart = this.chart,\n renderer = chart.renderer,\n options = this.options,\n optionsY = options.y,\n alignTop = options.verticalAlign === 'top',\n padding = this.padding,\n maxHeight = options.maxHeight,\n navOptions = options.navigation,\n animation = pick(navOptions.animation,\n true),\n arrowSize = navOptions.arrowSize || 12,\n pages = this.pages,\n allItems = this.allItems,\n clipToHeight = function (height) {\n if (typeof height === 'number') {\n clipRect.attr({\n height: height\n });\n }\n else if (clipRect) { // Reset (#5912)\n legend.clipRect = clipRect.destroy();\n legend.contentGroup.clip();\n }\n // useHTML\n if (legend.contentGroup.div) {\n legend.contentGroup.div.style.clip = height ?\n 'rect(' + padding + 'px,9999px,' +\n (padding + height) + 'px,0)' :\n 'auto';\n }\n }, addTracker = function (key) {\n legend[key] = renderer\n .circle(0, 0, arrowSize * 1.3)\n .translate(arrowSize / 2, arrowSize / 2)\n .add(nav);\n if (!chart.styledMode) {\n legend[key].attr('fill', 'rgba(0,0,0,0.0001)');\n }\n return legend[key];\n };\n var clipHeight,\n lastY,\n legendItem,\n spaceHeight = (chart.spacingBox.height +\n (alignTop ? -optionsY : optionsY) - padding),\n nav = this.nav,\n clipRect = this.clipRect;\n // Adjust the height\n if (options.layout === 'horizontal' &&\n options.verticalAlign !== 'middle' &&\n !options.floating) {\n spaceHeight /= 2;\n }\n if (maxHeight) {\n spaceHeight = Math.min(spaceHeight, maxHeight);\n }\n // Reset the legend height and adjust the clipping rectangle\n pages.length = 0;\n if (legendHeight &&\n spaceHeight > 0 &&\n legendHeight > spaceHeight &&\n navOptions.enabled !== false) {\n this.clipHeight = clipHeight =\n Math.max(spaceHeight - 20 - this.titleHeight - padding, 0);\n this.currentPage = pick(this.currentPage, 1);\n this.fullHeight = legendHeight;\n // Fill pages with Y positions so that the top of each a legend item\n // defines the scroll top for each page (#2098)\n allItems.forEach(function (item, i) {\n legendItem = item.legendItem || {};\n var y = legendItem.y || 0,\n h = Math.round(legendItem.label.getBBox().height);\n var len = pages.length;\n if (!len || (y - pages[len - 1] > clipHeight &&\n (lastY || y) !== pages[len - 1])) {\n pages.push(lastY || y);\n len++;\n }\n // Keep track of which page each item is on\n legendItem.pageIx = len - 1;\n if (lastY) {\n (allItems[i - 1].legendItem || {}).pageIx = len - 1;\n }\n // add the last page if needed (#2617, #13683)\n if (\n // check the last item\n i === allItems.length - 1 &&\n // if adding next page is needed\n y + h - pages[len - 1] > clipHeight &&\n // and will fully fit inside a new page\n h <= clipHeight) {\n pages.push(y);\n legendItem.pageIx = len;\n }\n if (y !== lastY) {\n lastY = y;\n }\n });\n // Only apply clipping if needed. Clipping causes blurred legend in\n // PDF export (#1787)\n if (!clipRect) {\n clipRect = legend.clipRect =\n renderer.clipRect(0, padding, 9999, 0);\n legend.contentGroup.clip(clipRect);\n }\n clipToHeight(clipHeight);\n // Add navigation elements\n if (!nav) {\n this.nav = nav = renderer.g()\n .attr({ zIndex: 1 })\n .add(this.group);\n this.up = renderer\n .symbol('triangle', 0, 0, arrowSize, arrowSize)\n .add(nav);\n addTracker('upTracker')\n .on('click', function () {\n legend.scroll(-1, animation);\n });\n this.pager = renderer.text('', 15, 10)\n .addClass('highcharts-legend-navigation');\n if (!chart.styledMode && navOptions.style) {\n this.pager.css(navOptions.style);\n }\n this.pager.add(nav);\n this.down = renderer\n .symbol('triangle-down', 0, 0, arrowSize, arrowSize)\n .add(nav);\n addTracker('downTracker')\n .on('click', function () {\n legend.scroll(1, animation);\n });\n }\n // Set initial position\n legend.scroll(0);\n legendHeight = spaceHeight;\n // Reset\n }\n else if (nav) {\n clipToHeight();\n this.nav = nav.destroy(); // #6322\n this.scrollGroup.attr({\n translateY: 1\n });\n this.clipHeight = 0; // #1379\n }\n return legendHeight;\n };\n /**\n * Scroll the legend by a number of pages.\n *\n * @private\n * @function Highcharts.Legend#scroll\n *\n * @param {number} scrollBy\n * The number of pages to scroll.\n *\n * @param {boolean|Partial} [animation]\n * Whether and how to apply animation.\n *\n */\n Legend.prototype.scroll = function (scrollBy, animation) {\n var _this = this;\n var chart = this.chart,\n pages = this.pages,\n pageCount = pages.length,\n clipHeight = this.clipHeight,\n navOptions = this.options.navigation,\n pager = this.pager,\n padding = this.padding;\n var currentPage = this.currentPage + scrollBy;\n // When resizing while looking at the last page\n if (currentPage > pageCount) {\n currentPage = pageCount;\n }\n if (currentPage > 0) {\n if (typeof animation !== 'undefined') {\n setAnimation(animation, chart);\n }\n this.nav.attr({\n translateX: padding,\n translateY: clipHeight + this.padding + 7 + this.titleHeight,\n visibility: 'inherit'\n });\n [this.up, this.upTracker].forEach(function (elem) {\n elem.attr({\n 'class': currentPage === 1 ?\n 'highcharts-legend-nav-inactive' :\n 'highcharts-legend-nav-active'\n });\n });\n pager.attr({\n text: currentPage + '/' + pageCount\n });\n [this.down, this.downTracker].forEach(function (elem) {\n elem.attr({\n // adjust to text width\n x: 18 + this.pager.getBBox().width,\n 'class': currentPage === pageCount ?\n 'highcharts-legend-nav-inactive' :\n 'highcharts-legend-nav-active'\n });\n }, this);\n if (!chart.styledMode) {\n this.up\n .attr({\n fill: currentPage === 1 ?\n navOptions.inactiveColor :\n navOptions.activeColor\n });\n this.upTracker\n .css({\n cursor: currentPage === 1 ? 'default' : 'pointer'\n });\n this.down\n .attr({\n fill: currentPage === pageCount ?\n navOptions.inactiveColor :\n navOptions.activeColor\n });\n this.downTracker\n .css({\n cursor: currentPage === pageCount ?\n 'default' :\n 'pointer'\n });\n }\n this.scrollOffset = -pages[currentPage - 1] + this.initialItemY;\n this.scrollGroup.animate({\n translateY: this.scrollOffset\n });\n this.currentPage = currentPage;\n this.positionCheckboxes();\n // Fire event after scroll animation is complete\n var animOptions = animObject(pick(animation,\n chart.renderer.globalAnimation,\n true));\n syncTimeout(function () {\n fireEvent(_this, 'afterScroll', { currentPage: currentPage });\n }, animOptions.duration);\n }\n };\n /**\n * @private\n * @function Highcharts.Legend#setItemEvents\n * @param {Highcharts.BubbleLegendItem|Point|Highcharts.Series} item\n * @param {Highcharts.SVGElement} legendLabel\n * @param {boolean} [useHTML=false]\n * @emits Highcharts.Point#event:legendItemClick\n * @emits Highcharts.Series#event:legendItemClick\n */\n Legend.prototype.setItemEvents = function (item, legendLabel, useHTML) {\n var legend = this,\n legendItem = item.legendItem || {},\n boxWrapper = legend.chart.renderer.boxWrapper,\n isPoint = item instanceof Point,\n activeClass = 'highcharts-legend-' +\n (isPoint ? 'point' : 'series') + '-active',\n styledMode = legend.chart.styledMode, \n // When `useHTML`, the symbol is rendered in other group, so\n // we need to apply events listeners to both places\n legendElements = useHTML ?\n [legendLabel,\n legendItem.symbol] :\n [legendItem.group];\n var setOtherItemsState = function (state) {\n legend.allItems.forEach(function (otherItem) {\n if (item !== otherItem) {\n [otherItem]\n .concat(otherItem.linkedSeries || [])\n .forEach(function (otherItem) {\n otherItem.setState(state, !isPoint);\n });\n }\n });\n };\n // Set the events on the item group, or in case of useHTML, the item\n // itself (#1249)\n for (var _i = 0, legendElements_1 = legendElements; _i < legendElements_1.length; _i++) {\n var element = legendElements_1[_i];\n if (element) {\n element\n .on('mouseover', function () {\n if (item.visible) {\n setOtherItemsState('inactive');\n }\n item.setState('hover');\n // A CSS class to dim or hide other than the hovered\n // series.\n // Works only if hovered series is visible (#10071).\n if (item.visible) {\n boxWrapper.addClass(activeClass);\n }\n if (!styledMode) {\n legendLabel.css(legend.options.itemHoverStyle);\n }\n })\n .on('mouseout', function () {\n if (!legend.chart.styledMode) {\n legendLabel.css(merge(item.visible ?\n legend.itemStyle :\n legend.itemHiddenStyle));\n }\n setOtherItemsState('');\n // A CSS class to dim or hide other than the hovered\n // series.\n boxWrapper.removeClass(activeClass);\n item.setState();\n })\n .on('click', function (event) {\n var strLegendItemClick = 'legendItemClick',\n fnLegendItemClick = function () {\n if (item.setVisible) {\n item.setVisible();\n }\n // Reset inactive state\n setOtherItemsState(item.visible ? 'inactive' : '');\n };\n // A CSS class to dim or hide other than the hovered\n // series. Event handling in iOS causes the activeClass\n // to be added prior to click in some cases (#7418).\n boxWrapper.removeClass(activeClass);\n // Pass over the click/touch event. #4.\n event = {\n browserEvent: event\n };\n // click the name or symbol\n if (item.firePointEvent) { // point\n item.firePointEvent(strLegendItemClick, event, fnLegendItemClick);\n }\n else {\n fireEvent(item, strLegendItemClick, event, fnLegendItemClick);\n }\n });\n }\n }\n };\n /**\n * @private\n * @function Highcharts.Legend#createCheckboxForItem\n * @param {Highcharts.BubbleLegendItem|Point|Highcharts.Series} item\n * @emits Highcharts.Series#event:checkboxClick\n */\n Legend.prototype.createCheckboxForItem = function (item) {\n var legend = this;\n item.checkbox = createElement('input', {\n type: 'checkbox',\n className: 'highcharts-legend-checkbox',\n checked: item.selected,\n defaultChecked: item.selected // required by IE7\n }, legend.options.itemCheckboxStyle, legend.chart.container);\n addEvent(item.checkbox, 'click', function (event) {\n var target = event.target;\n fireEvent(item.series || item, 'checkboxClick', {\n checked: target.checked,\n item: item\n }, function () {\n item.select();\n });\n });\n };\n return Legend;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @interface Highcharts.LegendItemObject\n */ /**\n * @name Highcharts.LegendItemObject#item\n * @type {Highcharts.SVGElement|undefined}\n */ /**\n * @name Highcharts.LegendItemObject#line\n * @type {Highcharts.SVGElement|undefined}\n */ /**\n * @name Highcharts.LegendItemObject#symbol\n * @type {Highcharts.SVGElement|undefined}\n */\n /**\n * Gets fired when the legend item belonging to a point is clicked. The default\n * action is to toggle the visibility of the point. This can be prevented by\n * returning `false` or calling `event.preventDefault()`.\n *\n * @callback Highcharts.PointLegendItemClickCallbackFunction\n *\n * @param {Highcharts.Point} this\n * The point on which the event occured.\n *\n * @param {Highcharts.PointLegendItemClickEventObject} event\n * The event that occured.\n */\n /**\n * Information about the legend click event.\n *\n * @interface Highcharts.PointLegendItemClickEventObject\n */ /**\n * Related browser event.\n * @name Highcharts.PointLegendItemClickEventObject#browserEvent\n * @type {Highcharts.PointerEvent}\n */ /**\n * Prevent the default action of toggle the visibility of the point.\n * @name Highcharts.PointLegendItemClickEventObject#preventDefault\n * @type {Function}\n */ /**\n * Related point.\n * @name Highcharts.PointLegendItemClickEventObject#target\n * @type {Highcharts.Point}\n */ /**\n * Event type.\n * @name Highcharts.PointLegendItemClickEventObject#type\n * @type {\"legendItemClick\"}\n */\n /**\n * Series color as used by the legend and some series types.\n * @name Highcharts.Series#color\n * @type {Highcharts.ColorType|undefined}\n */ /**\n * Legend data for the series.\n * @name Highcharts.Series#legendItem\n * @type {Highcharts.LegendItemObject|undefined}\n * @since 10.3.0\n */\n /**\n * Gets fired when the legend item belonging to a series is clicked. The default\n * action is to toggle the visibility of the series. This can be prevented by\n * returning `false` or calling `event.preventDefault()`.\n *\n * @callback Highcharts.SeriesLegendItemClickCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesLegendItemClickEventObject} event\n * The event that occured.\n */\n /**\n * Information about the legend click event.\n *\n * @interface Highcharts.SeriesLegendItemClickEventObject\n */ /**\n * Related browser event.\n * @name Highcharts.SeriesLegendItemClickEventObject#browserEvent\n * @type {Highcharts.PointerEvent}\n */ /**\n * Prevent the default action of toggle the visibility of the series.\n * @name Highcharts.SeriesLegendItemClickEventObject#preventDefault\n * @type {Function}\n */ /**\n * Related series.\n * @name Highcharts.SeriesLegendItemClickEventObject#target\n * @type {Highcharts.Series}\n */ /**\n * Event type.\n * @name Highcharts.SeriesLegendItemClickEventObject#type\n * @type {\"legendItemClick\"}\n */\n (''); // keeps doclets above in JS file\n\n return Legend;\n });\n _registerModule(_modules, 'Core/Series/SeriesRegistry.js', [_modules['Core/Globals.js'], _modules['Core/Defaults.js'], _modules['Core/Series/Point.js'], _modules['Core/Utilities.js']], function (H, D, Point, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var defaultOptions = D.defaultOptions;\n var extendClass = U.extendClass,\n merge = U.merge;\n /* *\n *\n * Namespace\n *\n * */\n var SeriesRegistry;\n (function (SeriesRegistry) {\n /* *\n *\n * Properties\n *\n * */\n /**\n * @internal\n * @todo Move `Globals.seriesTypes` code to her.\n */\n SeriesRegistry.seriesTypes = H.seriesTypes;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Registers class pattern of a series.\n *\n * @private\n */\n function registerSeriesType(seriesType, SeriesClass) {\n var defaultPlotOptions = defaultOptions.plotOptions || {},\n seriesOptions = SeriesClass.defaultOptions,\n seriesProto = SeriesClass.prototype;\n seriesProto.type = seriesType;\n if (!seriesProto.pointClass) {\n seriesProto.pointClass = Point;\n }\n if (seriesOptions) {\n defaultPlotOptions[seriesType] = seriesOptions;\n }\n SeriesRegistry.seriesTypes[seriesType] = SeriesClass;\n }\n SeriesRegistry.registerSeriesType = registerSeriesType;\n /**\n * Old factory to create new series prototypes.\n *\n * @deprecated\n * @function Highcharts.seriesType\n *\n * @param {string} type\n * The series type name.\n *\n * @param {string} parent\n * The parent series type name. Use `line` to inherit from the basic\n * {@link Series} object.\n *\n * @param {Highcharts.SeriesOptionsType|Highcharts.Dictionary<*>} options\n * The additional default options that are merged with the parent's options.\n *\n * @param {Highcharts.Dictionary<*>} [props]\n * The properties (functions and primitives) to set on the new prototype.\n *\n * @param {Highcharts.Dictionary<*>} [pointProps]\n * Members for a series-specific extension of the {@link Point} prototype if\n * needed.\n *\n * @return {Highcharts.Series}\n * The newly created prototype as extended from {@link Series} or its\n * derivatives.\n */\n function seriesType(type, parent, options, seriesProto, pointProto) {\n var defaultPlotOptions = defaultOptions.plotOptions || {};\n parent = parent || '';\n // Merge the options\n defaultPlotOptions[type] = merge(defaultPlotOptions[parent], options);\n // Create the class\n registerSeriesType(type, extendClass(SeriesRegistry.seriesTypes[parent] || function () { }, seriesProto));\n SeriesRegistry.seriesTypes[type].prototype.type = type;\n // Create the point class if needed\n if (pointProto) {\n SeriesRegistry.seriesTypes[type].prototype.pointClass = extendClass(Point, pointProto);\n }\n return SeriesRegistry.seriesTypes[type];\n }\n SeriesRegistry.seriesType = seriesType;\n })(SeriesRegistry || (SeriesRegistry = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return SeriesRegistry;\n });\n _registerModule(_modules, 'Core/Chart/Chart.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Axis/Axis.js'], _modules['Core/Defaults.js'], _modules['Core/FormatUtilities.js'], _modules['Core/Foundation.js'], _modules['Core/Globals.js'], _modules['Core/Legend/Legend.js'], _modules['Core/MSPointer.js'], _modules['Core/Pointer.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Time.js'], _modules['Core/Utilities.js'], _modules['Core/Renderer/HTML/AST.js']], function (A, Axis, D, FormatUtilities, Foundation, H, Legend, MSPointer, Pointer, RendererRegistry, SeriesRegistry, SVGRenderer, Time, U, AST) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var animate = A.animate,\n animObject = A.animObject,\n setAnimation = A.setAnimation;\n var defaultOptions = D.defaultOptions,\n defaultTime = D.defaultTime;\n var numberFormat = FormatUtilities.numberFormat;\n var registerEventOptions = Foundation.registerEventOptions;\n var charts = H.charts,\n doc = H.doc,\n marginNames = H.marginNames,\n svg = H.svg,\n win = H.win;\n var seriesTypes = SeriesRegistry.seriesTypes;\n var addEvent = U.addEvent,\n attr = U.attr,\n cleanRecursively = U.cleanRecursively,\n createElement = U.createElement,\n css = U.css,\n defined = U.defined,\n discardElement = U.discardElement,\n erase = U.erase,\n error = U.error,\n extend = U.extend,\n find = U.find,\n fireEvent = U.fireEvent,\n getStyle = U.getStyle,\n isArray = U.isArray,\n isNumber = U.isNumber,\n isObject = U.isObject,\n isString = U.isString,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick,\n pInt = U.pInt,\n relativeLength = U.relativeLength,\n removeEvent = U.removeEvent,\n splat = U.splat,\n syncTimeout = U.syncTimeout,\n uniqueKey = U.uniqueKey;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The Chart class. The recommended constructor is {@link Highcharts#chart}.\n *\n * @example\n * let chart = Highcharts.chart('container', {\n * title: {\n * text: 'My chart'\n * },\n * series: [{\n * data: [1, 3, 2, 4]\n * }]\n * })\n *\n * @class\n * @name Highcharts.Chart\n *\n * @param {string|Highcharts.HTMLDOMElement} [renderTo]\n * The DOM element to render to, or its id.\n *\n * @param {Highcharts.Options} options\n * The chart options structure.\n *\n * @param {Highcharts.ChartCallbackFunction} [callback]\n * Function to run when the chart has loaded and and all external images\n * are loaded. Defining a\n * [chart.events.load](https://api.highcharts.com/highcharts/chart.events.load)\n * handler is equivalent.\n */\n var Chart = /** @class */ (function () {\n function Chart(a, b, c) {\n this.axes = void 0;\n this.axisOffset = void 0;\n this.bounds = void 0;\n this.chartHeight = void 0;\n this.chartWidth = void 0;\n this.clipBox = void 0;\n this.colorCounter = void 0;\n this.container = void 0;\n this.eventOptions = void 0;\n this.index = void 0;\n this.isResizing = void 0;\n this.labelCollectors = void 0;\n this.legend = void 0;\n this.margin = void 0;\n this.numberFormatter = void 0;\n this.options = void 0;\n this.plotBox = void 0;\n this.plotHeight = void 0;\n this.plotLeft = void 0;\n this.plotTop = void 0;\n this.plotWidth = void 0;\n this.pointCount = void 0;\n this.pointer = void 0;\n this.renderer = void 0;\n this.renderTo = void 0;\n this.series = void 0;\n this.sharedClips = {};\n this.spacing = void 0;\n this.spacingBox = void 0;\n this.symbolCounter = void 0;\n this.time = void 0;\n this.titleOffset = void 0;\n this.userOptions = void 0;\n this.xAxis = void 0;\n this.yAxis = void 0;\n this.getArgs(a, b, c);\n }\n /**\n * Factory function for basic charts.\n *\n * @example\n * // Render a chart in to div#container\n * let chart = Highcharts.chart('container', {\n * title: {\n * text: 'My chart'\n * },\n * series: [{\n * data: [1, 3, 2, 4]\n * }]\n * });\n *\n * @function Highcharts.chart\n *\n * @param {string|Highcharts.HTMLDOMElement} [renderTo]\n * The DOM element to render to, or its id.\n *\n * @param {Highcharts.Options} options\n * The chart options structure.\n *\n * @param {Highcharts.ChartCallbackFunction} [callback]\n * Function to run when the chart has loaded and and all external images are\n * loaded. Defining a\n * [chart.events.load](https://api.highcharts.com/highcharts/chart.events.load)\n * handler is equivalent.\n *\n * @return {Highcharts.Chart}\n * Returns the Chart object.\n */\n Chart.chart = function (a, b, c) {\n return new Chart(a, b, c);\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Handle the arguments passed to the constructor.\n *\n * @private\n * @function Highcharts.Chart#getArgs\n *\n * @param {...Array<*>} arguments\n * All arguments for the constructor.\n *\n * @emits Highcharts.Chart#event:init\n * @emits Highcharts.Chart#event:afterInit\n */\n Chart.prototype.getArgs = function (a, b, c) {\n // Remove the optional first argument, renderTo, and\n // set it on this.\n if (isString(a) || a.nodeName) {\n this.renderTo = a;\n this.init(b, c);\n }\n else {\n this.init(a, b);\n }\n };\n /**\n * Overridable function that initializes the chart. The constructor's\n * arguments are passed on directly.\n *\n * @function Highcharts.Chart#init\n *\n * @param {Highcharts.Options} userOptions\n * Custom options.\n *\n * @param {Function} [callback]\n * Function to run when the chart has loaded and and all external\n * images are loaded.\n *\n *\n * @emits Highcharts.Chart#event:init\n * @emits Highcharts.Chart#event:afterInit\n */\n Chart.prototype.init = function (userOptions, callback) {\n // Handle regular options\n var userPlotOptions = userOptions.plotOptions || {};\n // Fire the event with a default function\n fireEvent(this, 'init', { args: arguments }, function () {\n var options = merge(defaultOptions,\n userOptions); // do the merge\n var optionsChart = options.chart;\n // Override (by copy of user options) or clear tooltip options\n // in chart.options.plotOptions (#6218)\n objectEach(options.plotOptions, function (typeOptions, type) {\n if (isObject(typeOptions)) { // #8766\n typeOptions.tooltip = (userPlotOptions[type] && // override by copy:\n merge(userPlotOptions[type].tooltip)) || void 0; // or clear\n }\n });\n // User options have higher priority than default options\n // (#6218). In case of exporting: path is changed\n options.tooltip.userOptions = (userOptions.chart &&\n userOptions.chart.forExport &&\n userOptions.tooltip.userOptions) || userOptions.tooltip;\n /**\n * The original options given to the constructor or a chart factory\n * like {@link Highcharts.chart} and {@link Highcharts.stockChart}.\n *\n * @name Highcharts.Chart#userOptions\n * @type {Highcharts.Options}\n */\n this.userOptions = userOptions;\n this.margin = [];\n this.spacing = [];\n // Pixel data bounds for touch zoom\n this.bounds = { h: {}, v: {} };\n // An array of functions that returns labels that should be\n // considered for anti-collision\n this.labelCollectors = [];\n this.callback = callback;\n this.isResizing = 0;\n var zooming = optionsChart.zooming = optionsChart.zooming || {};\n // Other options have no default so just pick\n if (userOptions.chart && !userOptions.chart.zooming) {\n zooming.resetButton = optionsChart.resetZoomButton;\n }\n zooming.key = pick(zooming.key, optionsChart.zoomKey);\n zooming.pinchType = pick(zooming.pinchType, optionsChart.pinchType);\n zooming.singleTouch = pick(zooming.singleTouch, optionsChart.zoomBySingleTouch);\n zooming.type = pick(zooming.type, optionsChart.zoomType);\n /**\n * The options structure for the chart after merging\n * {@link #defaultOptions} and {@link #userOptions}. It contains\n * members for the sub elements like series, legend, tooltip etc.\n *\n * @name Highcharts.Chart#options\n * @type {Highcharts.Options}\n */\n this.options = options;\n /**\n * All the axes in the chart.\n *\n * @see Highcharts.Chart.xAxis\n * @see Highcharts.Chart.yAxis\n *\n * @name Highcharts.Chart#axes\n * @type {Array}\n */\n this.axes = [];\n /**\n * All the current series in the chart.\n *\n * @name Highcharts.Chart#series\n * @type {Array}\n */\n this.series = [];\n /**\n * The `Time` object associated with the chart. Since v6.0.5,\n * time settings can be applied individually for each chart. If\n * no individual settings apply, the `Time` object is shared by\n * all instances.\n *\n * @name Highcharts.Chart#time\n * @type {Highcharts.Time}\n */\n this.time =\n userOptions.time && Object.keys(userOptions.time).length ?\n new Time(userOptions.time) :\n H.time;\n /**\n * Callback function to override the default function that formats\n * all the numbers in the chart. Returns a string with the formatted\n * number.\n *\n * @name Highcharts.Chart#numberFormatter\n * @type {Highcharts.NumberFormatterCallbackFunction}\n */\n this.numberFormatter = optionsChart.numberFormatter || numberFormat;\n /**\n * Whether the chart is in styled mode, meaning all presentatinoal\n * attributes are avoided.\n *\n * @name Highcharts.Chart#styledMode\n * @type {boolean}\n */\n this.styledMode = optionsChart.styledMode;\n this.hasCartesianSeries = optionsChart.showAxes;\n var chart = this;\n /**\n * Index position of the chart in the {@link Highcharts#charts}\n * property.\n *\n * @name Highcharts.Chart#index\n * @type {number}\n * @readonly\n */\n chart.index = charts.length; // Add the chart to the global lookup\n charts.push(chart);\n H.chartCount++;\n // Chart event handlers\n registerEventOptions(this, optionsChart);\n /**\n * A collection of the X axes in the chart.\n *\n * @name Highcharts.Chart#xAxis\n * @type {Array}\n */\n chart.xAxis = [];\n /**\n * A collection of the Y axes in the chart.\n *\n * @name Highcharts.Chart#yAxis\n * @type {Array}\n *\n * @todo\n * Make events official: Fire the event `afterInit`.\n */\n chart.yAxis = [];\n chart.pointCount = chart.colorCounter = chart.symbolCounter = 0;\n // Fire after init but before first render, before axes and series\n // have been initialized.\n fireEvent(chart, 'afterInit');\n chart.firstRender();\n });\n };\n /**\n * Internal function to unitialize an individual series.\n *\n * @private\n * @function Highcharts.Chart#initSeries\n */\n Chart.prototype.initSeries = function (options) {\n var chart = this,\n optionsChart = chart.options.chart,\n type = (options.type ||\n optionsChart.type ||\n optionsChart.defaultSeriesType),\n SeriesClass = seriesTypes[type];\n // No such series type\n if (!SeriesClass) {\n error(17, true, chart, { missingModuleFor: type });\n }\n var series = new SeriesClass();\n if (typeof series.init === 'function') {\n series.init(chart, options);\n }\n return series;\n };\n /**\n * Internal function to set data for all series with enabled sorting.\n *\n * @private\n * @function Highcharts.Chart#setSeriesData\n */\n Chart.prototype.setSeriesData = function () {\n this.getSeriesOrderByLinks().forEach(function (series) {\n // We need to set data for series with sorting after series init\n if (!series.points && !series.data && series.enabledDataSorting) {\n series.setData(series.options.data, false);\n }\n });\n };\n /**\n * Sort and return chart series in order depending on the number of linked\n * series.\n *\n * @private\n * @function Highcharts.Series#getSeriesOrderByLinks\n */\n Chart.prototype.getSeriesOrderByLinks = function () {\n return this.series.concat().sort(function (a, b) {\n if (a.linkedSeries.length || b.linkedSeries.length) {\n return b.linkedSeries.length - a.linkedSeries.length;\n }\n return 0;\n });\n };\n /**\n * Order all series above a given index. When series are added and ordered\n * by configuration, only the last series is handled (#248, #1123, #2456,\n * #6112). This function is called on series initialization and destroy.\n *\n * @private\n * @function Highcharts.Series#orderSeries\n * @param {number} [fromIndex]\n * If this is given, only the series above this index are handled.\n */\n Chart.prototype.orderSeries = function (fromIndex) {\n var series = this.series;\n for (var i = (fromIndex || 0), iEnd = series.length; i < iEnd; ++i) {\n if (series[i]) {\n /**\n * Contains the series' index in the `Chart.series` array.\n *\n * @name Highcharts.Series#index\n * @type {number}\n * @readonly\n */\n series[i].index = i;\n series[i].name = series[i].getName();\n }\n }\n };\n /**\n * Check whether a given point is within the plot area.\n *\n * @function Highcharts.Chart#isInsidePlot\n *\n * @param {number} plotX\n * Pixel x relative to the plot area.\n *\n * @param {number} plotY\n * Pixel y relative to the plot area.\n *\n * @param {Highcharts.ChartIsInsideOptionsObject} [options]\n * Options object.\n *\n * @return {boolean}\n * Returns true if the given point is inside the plot area.\n */\n Chart.prototype.isInsidePlot = function (plotX, plotY, options) {\n var _a;\n if (options === void 0) { options = {}; }\n var _b = this,\n inverted = _b.inverted,\n plotBox = _b.plotBox,\n plotLeft = _b.plotLeft,\n plotTop = _b.plotTop,\n scrollablePlotBox = _b.scrollablePlotBox;\n var scrollLeft = 0,\n scrollTop = 0;\n if (options.visiblePlotOnly && this.scrollingContainer) {\n (_a = this.scrollingContainer, scrollLeft = _a.scrollLeft, scrollTop = _a.scrollTop);\n }\n var series = options.series,\n box = (options.visiblePlotOnly && scrollablePlotBox) || plotBox,\n x = options.inverted ? plotY : plotX,\n y = options.inverted ? plotX : plotY,\n e = {\n x: x,\n y: y,\n isInsidePlot: true,\n options: options\n };\n if (!options.ignoreX) {\n var xAxis = (series &&\n (inverted && !this.polar ? series.yAxis : series.xAxis)) || {\n pos: plotLeft,\n len: Infinity\n };\n var chartX = options.paneCoordinates ?\n xAxis.pos + x : plotLeft + x;\n if (!(chartX >= Math.max(scrollLeft + plotLeft, xAxis.pos) &&\n chartX <= Math.min(scrollLeft + plotLeft + box.width, xAxis.pos + xAxis.len))) {\n e.isInsidePlot = false;\n }\n }\n if (!options.ignoreY && e.isInsidePlot) {\n var yAxis = (options.axis && !options.axis.isXAxis && options.axis) || (series && (inverted ? series.xAxis : series.yAxis)) || {\n pos: plotTop,\n len: Infinity\n };\n var chartY = options.paneCoordinates ?\n yAxis.pos + y : plotTop + y;\n if (!(chartY >= Math.max(scrollTop + plotTop, yAxis.pos) &&\n chartY <= Math.min(scrollTop + plotTop + box.height, yAxis.pos + yAxis.len))) {\n e.isInsidePlot = false;\n }\n }\n fireEvent(this, 'afterIsInsidePlot', e);\n return e.isInsidePlot;\n };\n /**\n * Redraw the chart after changes have been done to the data, axis extremes\n * chart size or chart elements. All methods for updating axes, series or\n * points have a parameter for redrawing the chart. This is `true` by\n * default. But in many cases you want to do more than one operation on the\n * chart before redrawing, for example add a number of points. In those\n * cases it is a waste of resources to redraw the chart for each new point\n * added. So you add the points and call `chart.redraw()` after.\n *\n * @function Highcharts.Chart#redraw\n *\n * @param {boolean|Partial} [animation]\n * If or how to apply animation to the redraw.\n *\n * @emits Highcharts.Chart#event:afterSetExtremes\n * @emits Highcharts.Chart#event:beforeRedraw\n * @emits Highcharts.Chart#event:predraw\n * @emits Highcharts.Chart#event:redraw\n * @emits Highcharts.Chart#event:render\n * @emits Highcharts.Chart#event:updatedData\n */\n Chart.prototype.redraw = function (animation) {\n fireEvent(this, 'beforeRedraw');\n var chart = this,\n axes = chart.hasCartesianSeries ? chart.axes : chart.colorAxis || [],\n series = chart.series,\n pointer = chart.pointer,\n legend = chart.legend,\n legendUserOptions = chart.userOptions.legend,\n renderer = chart.renderer,\n isHiddenChart = renderer.isHidden(),\n afterRedraw = [];\n var hasDirtyStacks,\n hasStackedSeries,\n i,\n isDirtyBox = chart.isDirtyBox,\n redrawLegend = chart.isDirtyLegend,\n serie;\n // Handle responsive rules, not only on resize (#6130)\n if (chart.setResponsive) {\n chart.setResponsive(false);\n }\n // Set the global animation. When chart.hasRendered is not true, the\n // redraw call comes from a responsive rule and animation should not\n // occur.\n setAnimation(chart.hasRendered ? animation : false, chart);\n if (isHiddenChart) {\n chart.temporaryDisplay();\n }\n // Adjust title layout (reflow multiline text)\n chart.layOutTitles();\n // link stacked series\n i = series.length;\n while (i--) {\n serie = series[i];\n if (serie.options.stacking || serie.options.centerInCategory) {\n hasStackedSeries = true;\n if (serie.isDirty) {\n hasDirtyStacks = true;\n break;\n }\n }\n }\n if (hasDirtyStacks) { // mark others as dirty\n i = series.length;\n while (i--) {\n serie = series[i];\n if (serie.options.stacking) {\n serie.isDirty = true;\n }\n }\n }\n // Handle updated data in the series\n series.forEach(function (serie) {\n if (serie.isDirty) {\n if (serie.options.legendType === 'point') {\n if (typeof serie.updateTotals === 'function') {\n serie.updateTotals();\n }\n redrawLegend = true;\n }\n else if (legendUserOptions &&\n (legendUserOptions.labelFormatter ||\n legendUserOptions.labelFormat)) {\n redrawLegend = true; // #2165\n }\n }\n if (serie.isDirtyData) {\n fireEvent(serie, 'updatedData');\n }\n });\n // handle added or removed series\n if (redrawLegend && legend && legend.options.enabled) {\n // draw legend graphics\n legend.render();\n chart.isDirtyLegend = false;\n }\n // reset stacks\n if (hasStackedSeries) {\n chart.getStacks();\n }\n // set axes scales\n axes.forEach(function (axis) {\n axis.updateNames();\n axis.setScale();\n });\n chart.getMargins(); // #3098\n // If one axis is dirty, all axes must be redrawn (#792, #2169)\n axes.forEach(function (axis) {\n if (axis.isDirty) {\n isDirtyBox = true;\n }\n });\n // redraw axes\n axes.forEach(function (axis) {\n // Fire 'afterSetExtremes' only if extremes are set\n var key = axis.min + ',' + axis.max;\n if (axis.extKey !== key) { // #821, #4452\n axis.extKey = key;\n // prevent a recursive call to chart.redraw() (#1119)\n afterRedraw.push(function () {\n fireEvent(axis, 'afterSetExtremes', extend(axis.eventArgs, axis.getExtremes())); // #747, #751\n delete axis.eventArgs;\n });\n }\n if (isDirtyBox || hasStackedSeries) {\n axis.redraw();\n }\n });\n // the plot areas size has changed\n if (isDirtyBox) {\n chart.drawChartBox();\n }\n // Fire an event before redrawing series, used by the boost module to\n // clear previous series renderings.\n fireEvent(chart, 'predraw');\n // redraw affected series\n series.forEach(function (serie) {\n if ((isDirtyBox || serie.isDirty) && serie.visible) {\n serie.redraw();\n }\n // Set it here, otherwise we will have unlimited 'updatedData' calls\n // for a hidden series after setData(). Fixes #6012\n serie.isDirtyData = false;\n });\n // move tooltip or reset\n if (pointer) {\n pointer.reset(true);\n }\n // redraw if canvas\n renderer.draw();\n // Fire the events\n fireEvent(chart, 'redraw');\n fireEvent(chart, 'render');\n if (isHiddenChart) {\n chart.temporaryDisplay(true);\n }\n // Fire callbacks that are put on hold until after the redraw\n afterRedraw.forEach(function (callback) {\n callback.call();\n });\n };\n /**\n * Get an axis, series or point object by `id` as given in the configuration\n * options. Returns `undefined` if no item is found.\n *\n * @sample highcharts/plotoptions/series-id/\n * Get series by id\n *\n * @function Highcharts.Chart#get\n *\n * @param {string} id\n * The id as given in the configuration options.\n *\n * @return {Highcharts.Axis|Highcharts.Series|Highcharts.Point|undefined}\n * The retrieved item.\n */\n Chart.prototype.get = function (id) {\n var series = this.series;\n /**\n * @private\n */\n function itemById(item) {\n return (item.id === id ||\n (item.options && item.options.id === id));\n }\n var ret = \n // Search axes\n find(this.axes,\n itemById) ||\n // Search series\n find(this.series,\n itemById);\n // Search points\n for (var i = 0; !ret && i < series.length; i++) {\n ret = find(series[i].points || [], itemById);\n }\n return ret;\n };\n /**\n * Create the Axis instances based on the config options.\n *\n * @private\n * @function Highcharts.Chart#getAxes\n * @emits Highcharts.Chart#event:afterGetAxes\n * @emits Highcharts.Chart#event:getAxes\n */\n Chart.prototype.getAxes = function () {\n var chart = this,\n options = this.options,\n xAxisOptions = options.xAxis = splat(options.xAxis || {}),\n yAxisOptions = options.yAxis = splat(options.yAxis || {});\n fireEvent(this, 'getAxes');\n // make sure the options are arrays and add some members\n xAxisOptions.forEach(function (axis, i) {\n axis.index = i;\n axis.isX = true;\n });\n yAxisOptions.forEach(function (axis, i) {\n axis.index = i;\n });\n // concatenate all axis options into one array\n var optionsArray = xAxisOptions.concat(yAxisOptions);\n optionsArray.forEach(function (axisOptions) {\n new Axis(chart, axisOptions); // eslint-disable-line no-new\n });\n fireEvent(this, 'afterGetAxes');\n };\n /**\n * Returns an array of all currently selected points in the chart. Points\n * can be selected by clicking or programmatically by the\n * {@link Highcharts.Point#select}\n * function.\n *\n * @sample highcharts/plotoptions/series-allowpointselect-line/\n * Get selected points\n *\n * @function Highcharts.Chart#getSelectedPoints\n *\n * @return {Array}\n * The currently selected points.\n */\n Chart.prototype.getSelectedPoints = function () {\n return this.series.reduce(function (acc, series) {\n // For one-to-one points inspect series.data in order to retrieve\n // points outside the visible range (#6445). For grouped data,\n // inspect the generated series.points.\n series.getPointsCollection()\n .forEach(function (point) {\n if (pick(point.selectedStaging, point.selected)) {\n acc.push(point);\n }\n });\n return acc;\n }, []);\n };\n /**\n * Returns an array of all currently selected series in the chart. Series\n * can be selected either programmatically by the\n * {@link Highcharts.Series#select}\n * function or by checking the checkbox next to the legend item if\n * [series.showCheckBox](https://api.highcharts.com/highcharts/plotOptions.series.showCheckbox)\n * is true.\n *\n * @sample highcharts/members/chart-getselectedseries/\n * Get selected series\n *\n * @function Highcharts.Chart#getSelectedSeries\n *\n * @return {Array}\n * The currently selected series.\n */\n Chart.prototype.getSelectedSeries = function () {\n return this.series.filter(function (serie) {\n return serie.selected;\n });\n };\n /**\n * Set a new title or subtitle for the chart.\n *\n * @sample highcharts/members/chart-settitle/\n * Set title text and styles\n *\n * @function Highcharts.Chart#setTitle\n *\n * @param {Highcharts.TitleOptions} [titleOptions]\n * New title options. The title text itself is set by the\n * `titleOptions.text` property.\n *\n * @param {Highcharts.SubtitleOptions} [subtitleOptions]\n * New subtitle options. The subtitle text itself is set by the\n * `subtitleOptions.text` property.\n *\n * @param {boolean} [redraw]\n * Whether to redraw the chart or wait for a later call to\n * `chart.redraw()`.\n */\n Chart.prototype.setTitle = function (titleOptions, subtitleOptions, redraw) {\n this.applyDescription('title', titleOptions);\n this.applyDescription('subtitle', subtitleOptions);\n // The initial call also adds the caption. On update, chart.update will\n // relay to Chart.setCaption.\n this.applyDescription('caption', void 0);\n this.layOutTitles(redraw);\n };\n /**\n * Apply a title, subtitle or caption for the chart\n *\n * @private\n * @function Highcharts.Chart#applyDescription\n * @param name {string}\n * Either title, subtitle or caption\n * @param {Highcharts.TitleOptions|Highcharts.SubtitleOptions|Highcharts.CaptionOptions|undefined} explicitOptions\n * The options to set, will be merged with default options.\n */\n Chart.prototype.applyDescription = function (name, explicitOptions) {\n var chart = this;\n // Default style\n var style = name === 'title' ? {\n color: \"#333333\" /* Palette.neutralColor80 */,\n fontSize: this.options.isStock ? '16px' : '18px' // #2944\n } : {\n color: \"#666666\" /* Palette.neutralColor60 */\n };\n // Merge default options with explicit options\n var options = this.options[name] = merge(\n // Default styles\n (!this.styledMode && { style: style }),\n this.options[name],\n explicitOptions);\n var elem = this[name];\n if (elem && explicitOptions) {\n this[name] = elem = elem.destroy(); // remove old\n }\n if (options && !elem) {\n elem = this.renderer.text(options.text, 0, 0, options.useHTML)\n .attr({\n align: options.align,\n 'class': 'highcharts-' + name,\n zIndex: options.zIndex || 4\n })\n .add();\n // Update methods, shortcut to Chart.setTitle, Chart.setSubtitle and\n // Chart.setCaption\n elem.update = function (updateOptions) {\n var fn = {\n title: 'setTitle',\n subtitle: 'setSubtitle',\n caption: 'setCaption'\n }[name];\n chart[fn](updateOptions);\n };\n // Presentational\n if (!this.styledMode) {\n elem.css(options.style);\n }\n /**\n * The chart title. The title has an `update` method that allows\n * modifying the options directly or indirectly via\n * `chart.update`.\n *\n * @sample highcharts/members/title-update/\n * Updating titles\n *\n * @name Highcharts.Chart#title\n * @type {Highcharts.TitleObject}\n */\n /**\n * The chart subtitle. The subtitle has an `update` method that\n * allows modifying the options directly or indirectly via\n * `chart.update`.\n *\n * @name Highcharts.Chart#subtitle\n * @type {Highcharts.SubtitleObject}\n */\n this[name] = elem;\n }\n };\n /**\n * Internal function to lay out the chart title, subtitle and caption, and\n * cache the full offset height for use in `getMargins`. The result is\n * stored in `this.titleOffset`.\n *\n * @private\n * @function Highcharts.Chart#layOutTitles\n *\n * @param {boolean} [redraw=true]\n * @emits Highcharts.Chart#event:afterLayOutTitles\n */\n Chart.prototype.layOutTitles = function (redraw) {\n var titleOffset = [0, 0, 0],\n renderer = this.renderer,\n spacingBox = this.spacingBox;\n // Lay out the title and the subtitle respectively\n ['title', 'subtitle', 'caption'].forEach(function (key) {\n var title = this[key], titleOptions = (this.options[key]), verticalAlign = titleOptions.verticalAlign || 'top', offset = key === 'title' ?\n verticalAlign === 'top' ? -3 : 0 :\n // Floating subtitle (#6574)\n verticalAlign === 'top' ? titleOffset[0] + 2 : 0;\n var titleSize,\n height;\n if (title) {\n if (!this.styledMode) {\n titleSize = (titleOptions.style &&\n titleOptions.style.fontSize);\n }\n titleSize = renderer.fontMetrics(titleSize, title).b;\n title\n .css({\n width: (titleOptions.width ||\n spacingBox.width + (titleOptions.widthAdjust || 0)) + 'px'\n });\n // Skip the cache for HTML (#3481, #11666)\n height = Math.round(title.getBBox(titleOptions.useHTML).height);\n title.align(extend({\n y: verticalAlign === 'bottom' ?\n titleSize :\n offset + titleSize,\n height: height\n }, titleOptions), false, 'spacingBox');\n if (!titleOptions.floating) {\n if (verticalAlign === 'top') {\n titleOffset[0] = Math.ceil(titleOffset[0] +\n height);\n }\n else if (verticalAlign === 'bottom') {\n titleOffset[2] = Math.ceil(titleOffset[2] +\n height);\n }\n }\n }\n }, this);\n // Handle title.margin and caption.margin\n if (titleOffset[0] &&\n (this.options.title.verticalAlign || 'top') === 'top') {\n titleOffset[0] += this.options.title.margin;\n }\n if (titleOffset[2] &&\n this.options.caption.verticalAlign === 'bottom') {\n titleOffset[2] += this.options.caption.margin;\n }\n var requiresDirtyBox = (!this.titleOffset ||\n this.titleOffset.join(',') !== titleOffset.join(','));\n // Used in getMargins\n this.titleOffset = titleOffset;\n fireEvent(this, 'afterLayOutTitles');\n if (!this.isDirtyBox && requiresDirtyBox) {\n this.isDirtyBox = this.isDirtyLegend = requiresDirtyBox;\n // Redraw if necessary (#2719, #2744)\n if (this.hasRendered && pick(redraw, true) && this.isDirtyBox) {\n this.redraw();\n }\n }\n };\n /**\n * Internal function to get the chart width and height according to options\n * and container size. Sets {@link Chart.chartWidth} and\n * {@link Chart.chartHeight}.\n *\n * @private\n * @function Highcharts.Chart#getChartSize\n */\n Chart.prototype.getChartSize = function () {\n var chart = this,\n optionsChart = chart.options.chart,\n widthOption = optionsChart.width,\n heightOption = optionsChart.height,\n renderTo = chart.renderTo;\n // Get inner width and height\n if (!defined(widthOption)) {\n chart.containerWidth = getStyle(renderTo, 'width');\n }\n if (!defined(heightOption)) {\n chart.containerHeight = getStyle(renderTo, 'height');\n }\n /**\n * The current pixel width of the chart.\n *\n * @name Highcharts.Chart#chartWidth\n * @type {number}\n */\n chart.chartWidth = Math.max(// #1393\n 0, widthOption || chart.containerWidth || 600 // #1460\n );\n /**\n * The current pixel height of the chart.\n *\n * @name Highcharts.Chart#chartHeight\n * @type {number}\n */\n chart.chartHeight = Math.max(0, relativeLength(heightOption, chart.chartWidth) ||\n (chart.containerHeight > 1 ?\n chart.containerHeight :\n 400));\n };\n /**\n * If the renderTo element has no offsetWidth, most likely one or more of\n * its parents are hidden. Loop up the DOM tree to temporarily display the\n * parents, then save the original display properties, and when the true\n * size is retrieved, reset them. Used on first render and on redraws.\n *\n * @private\n * @function Highcharts.Chart#temporaryDisplay\n *\n * @param {boolean} [revert]\n * Revert to the saved original styles.\n */\n Chart.prototype.temporaryDisplay = function (revert) {\n var node = this.renderTo,\n tempStyle;\n if (!revert) {\n while (node && node.style) {\n // When rendering to a detached node, it needs to be temporarily\n // attached in order to read styling and bounding boxes (#5783,\n // #7024).\n if (!doc.body.contains(node) && !node.parentNode) {\n node.hcOrigDetached = true;\n doc.body.appendChild(node);\n }\n if (getStyle(node, 'display', false) === 'none' ||\n node.hcOricDetached) {\n node.hcOrigStyle = {\n display: node.style.display,\n height: node.style.height,\n overflow: node.style.overflow\n };\n tempStyle = {\n display: 'block',\n overflow: 'hidden'\n };\n if (node !== this.renderTo) {\n tempStyle.height = 0;\n }\n css(node, tempStyle);\n // If it still doesn't have an offset width after setting\n // display to block, it probably has an !important priority\n // #2631, 6803\n if (!node.offsetWidth) {\n node.style.setProperty('display', 'block', 'important');\n }\n }\n node = node.parentNode;\n if (node === doc.body) {\n break;\n }\n }\n }\n else {\n while (node && node.style) {\n if (node.hcOrigStyle) {\n css(node, node.hcOrigStyle);\n delete node.hcOrigStyle;\n }\n if (node.hcOrigDetached) {\n doc.body.removeChild(node);\n node.hcOrigDetached = false;\n }\n node = node.parentNode;\n }\n }\n };\n /**\n * Set the {@link Chart.container|chart container's} class name, in\n * addition to `highcharts-container`.\n *\n * @function Highcharts.Chart#setClassName\n *\n * @param {string} [className]\n * The additional class name.\n */\n Chart.prototype.setClassName = function (className) {\n this.container.className = 'highcharts-container ' + (className || '');\n };\n /**\n * Get the containing element, determine the size and create the inner\n * container div to hold the chart.\n *\n * @private\n * @function Highcharts.Chart#afterGetContainer\n * @emits Highcharts.Chart#event:afterGetContainer\n */\n Chart.prototype.getContainer = function () {\n var chart = this,\n options = chart.options,\n optionsChart = options.chart,\n indexAttrName = 'data-highcharts-chart',\n containerId = uniqueKey();\n var containerStyle,\n renderTo = chart.renderTo;\n if (!renderTo) {\n chart.renderTo = renderTo =\n optionsChart.renderTo;\n }\n if (isString(renderTo)) {\n chart.renderTo = renderTo =\n doc.getElementById(renderTo);\n }\n // Display an error if the renderTo is wrong\n if (!renderTo) {\n error(13, true, chart);\n }\n // If the container already holds a chart, destroy it. The check for\n // hasRendered is there because web pages that are saved to disk from\n // the browser, will preserve the data-highcharts-chart attribute and\n // the SVG contents, but not an interactive chart. So in this case,\n // charts[oldChartIndex] will point to the wrong chart if any (#2609).\n var oldChartIndex = pInt(attr(renderTo,\n indexAttrName));\n if (isNumber(oldChartIndex) &&\n charts[oldChartIndex] &&\n charts[oldChartIndex].hasRendered) {\n charts[oldChartIndex].destroy();\n }\n // Make a reference to the chart from the div\n attr(renderTo, indexAttrName, chart.index);\n // remove previous chart\n renderTo.innerHTML = AST.emptyHTML;\n // If the container doesn't have an offsetWidth, it has or is a child of\n // a node that has display:none. We need to temporarily move it out to a\n // visible state to determine the size, else the legend and tooltips\n // won't render properly. The skipClone option is used in sparklines as\n // a micro optimization, saving about 1-2 ms each chart.\n if (!optionsChart.skipClone && !renderTo.offsetWidth) {\n chart.temporaryDisplay();\n }\n // get the width and height\n chart.getChartSize();\n var chartWidth = chart.chartWidth;\n var chartHeight = chart.chartHeight;\n // Allow table cells and flex-boxes to shrink without the chart blocking\n // them out (#6427)\n css(renderTo, { overflow: 'hidden' });\n // Create the inner container\n if (!chart.styledMode) {\n containerStyle = extend({\n position: 'relative',\n // needed for context menu (avoidscrollbars) and content\n // overflow in IE\n overflow: 'hidden',\n width: chartWidth + 'px',\n height: chartHeight + 'px',\n textAlign: 'left',\n lineHeight: 'normal',\n zIndex: 0,\n '-webkit-tap-highlight-color': 'rgba(0,0,0,0)',\n userSelect: 'none',\n 'touch-action': 'manipulation',\n outline: 'none'\n }, optionsChart.style || {});\n }\n /**\n * The containing HTML element of the chart. The container is\n * dynamically inserted into the element given as the `renderTo`\n * parameter in the {@link Highcharts#chart} constructor.\n *\n * @name Highcharts.Chart#container\n * @type {Highcharts.HTMLDOMElement}\n */\n var container = createElement('div', {\n id: containerId\n },\n containerStyle,\n renderTo);\n chart.container = container;\n // cache the cursor (#1650)\n chart._cursor = container.style.cursor;\n // Initialize the renderer\n var Renderer = optionsChart.renderer || !svg ?\n RendererRegistry.getRendererType(optionsChart.renderer) :\n SVGRenderer;\n /**\n * The renderer instance of the chart. Each chart instance has only one\n * associated renderer.\n *\n * @name Highcharts.Chart#renderer\n * @type {Highcharts.SVGRenderer}\n */\n chart.renderer = new Renderer(container, chartWidth, chartHeight, void 0, optionsChart.forExport, options.exporting && options.exporting.allowHTML, chart.styledMode);\n // Set the initial animation from the options\n setAnimation(void 0, chart);\n chart.setClassName(optionsChart.className);\n if (!chart.styledMode) {\n chart.renderer.setStyle(optionsChart.style);\n }\n else {\n // Initialize definitions\n for (var key in options.defs) { // eslint-disable-line guard-for-in\n this.renderer.definition(options.defs[key]);\n }\n }\n // Add a reference to the charts index\n chart.renderer.chartIndex = chart.index;\n fireEvent(this, 'afterGetContainer');\n };\n /**\n * Calculate margins by rendering axis labels in a preliminary position.\n * Title, subtitle and legend have already been rendered at this stage, but\n * will be moved into their final positions.\n *\n * @private\n * @function Highcharts.Chart#getMargins\n * @emits Highcharts.Chart#event:getMargins\n */\n Chart.prototype.getMargins = function (skipAxes) {\n var _a = this,\n spacing = _a.spacing,\n margin = _a.margin,\n titleOffset = _a.titleOffset;\n this.resetMargins();\n // Adjust for title and subtitle\n if (titleOffset[0] && !defined(margin[0])) {\n this.plotTop = Math.max(this.plotTop, titleOffset[0] + spacing[0]);\n }\n if (titleOffset[2] && !defined(margin[2])) {\n this.marginBottom = Math.max(this.marginBottom, titleOffset[2] + spacing[2]);\n }\n // Adjust for legend\n if (this.legend && this.legend.display) {\n this.legend.adjustMargins(margin, spacing);\n }\n fireEvent(this, 'getMargins');\n if (!skipAxes) {\n this.getAxisMargins();\n }\n };\n /**\n * @private\n * @function Highcharts.Chart#getAxisMargins\n */\n Chart.prototype.getAxisMargins = function () {\n var chart = this, \n // [top, right, bottom, left]\n axisOffset = chart.axisOffset = [0, 0, 0, 0],\n colorAxis = chart.colorAxis,\n margin = chart.margin,\n getOffset = function (axes) {\n axes.forEach(function (axis) {\n if (axis.visible) {\n axis.getOffset();\n }\n });\n };\n // pre-render axes to get labels offset width\n if (chart.hasCartesianSeries) {\n getOffset(chart.axes);\n }\n else if (colorAxis && colorAxis.length) {\n getOffset(colorAxis);\n }\n // Add the axis offsets\n marginNames.forEach(function (m, side) {\n if (!defined(margin[side])) {\n chart[m] += axisOffset[side];\n }\n });\n chart.setChartSize();\n };\n /**\n * Reflows the chart to its container. By default, the chart reflows\n * automatically to its container following a `window.resize` event, as per\n * the [chart.reflow](https://api.highcharts.com/highcharts/chart.reflow)\n * option. However, there are no reliable events for div resize, so if the\n * container is resized without a window resize event, this must be called\n * explicitly.\n *\n * @sample highcharts/members/chart-reflow/\n * Resize div and reflow\n * @sample highcharts/chart/events-container/\n * Pop up and reflow\n *\n * @function Highcharts.Chart#reflow\n *\n * @param {global.Event} [e]\n * Event arguments. Used primarily when the function is called\n * internally as a response to window resize.\n */\n Chart.prototype.reflow = function (e) {\n var chart = this, optionsChart = chart.options.chart, renderTo = chart.renderTo, hasUserSize = (defined(optionsChart.width) &&\n defined(optionsChart.height)), width = optionsChart.width || getStyle(renderTo, 'width'), height = optionsChart.height || getStyle(renderTo, 'height'), target = e ? e.target : win;\n delete chart.pointer.chartPosition;\n // Width and height checks for display:none. Target is doc in IE8 and\n // Opera, win in Firefox, Chrome and IE9.\n if (!hasUserSize &&\n !chart.isPrinting &&\n width &&\n height &&\n (target === win || target === doc)) {\n if (width !== chart.containerWidth ||\n height !== chart.containerHeight) {\n U.clearTimeout(chart.reflowTimeout);\n // When called from window.resize, e is set, else it's called\n // directly (#2224)\n chart.reflowTimeout = syncTimeout(function () {\n // Set size, it may have been destroyed in the meantime\n // (#1257)\n if (chart.container) {\n chart.setSize(void 0, void 0, false);\n }\n }, e ? 100 : 0);\n }\n chart.containerWidth = width;\n chart.containerHeight = height;\n }\n };\n /**\n * Toggle the event handlers necessary for auto resizing, depending on the\n * `chart.reflow` option.\n *\n * @private\n * @function Highcharts.Chart#setReflow\n */\n Chart.prototype.setReflow = function (reflow) {\n var chart = this;\n if (reflow !== false && !this.unbindReflow) {\n this.unbindReflow = addEvent(win, 'resize', function (e) {\n // a removed event listener still runs in Edge and IE if the\n // listener was removed while the event runs, so check if the\n // chart is not destroyed (#11609)\n if (chart.options) {\n chart.reflow(e);\n }\n });\n addEvent(this, 'destroy', this.unbindReflow);\n }\n else if (reflow === false && this.unbindReflow) {\n // Unbind and unset\n this.unbindReflow = this.unbindReflow();\n }\n // The following will add listeners to re-fit the chart before and after\n // printing (#2284). However it only works in WebKit. Should have worked\n // in Firefox, but not supported in IE.\n /*\n if (win.matchMedia) {\n win.matchMedia('print').addListener(function reflow() {\n chart.reflow();\n });\n }\n //*/\n };\n /**\n * Resize the chart to a given width and height. In order to set the width\n * only, the height argument may be skipped. To set the height only, pass\n * `undefined` for the width.\n *\n * @sample highcharts/members/chart-setsize-button/\n * Test resizing from buttons\n * @sample highcharts/members/chart-setsize-jquery-resizable/\n * Add a jQuery UI resizable\n * @sample stock/members/chart-setsize/\n * Highcharts Stock with UI resizable\n *\n * @function Highcharts.Chart#setSize\n *\n * @param {number|null} [width]\n * The new pixel width of the chart. Since v4.2.6, the argument can\n * be `undefined` in order to preserve the current value (when\n * setting height only), or `null` to adapt to the width of the\n * containing element.\n *\n * @param {number|null} [height]\n * The new pixel height of the chart. Since v4.2.6, the argument can\n * be `undefined` in order to preserve the current value, or `null`\n * in order to adapt to the height of the containing element.\n *\n * @param {boolean|Partial} [animation=true]\n * Whether and how to apply animation.\n *\n *\n * @emits Highcharts.Chart#event:endResize\n * @emits Highcharts.Chart#event:resize\n */\n Chart.prototype.setSize = function (width, height, animation) {\n var chart = this,\n renderer = chart.renderer;\n // Handle the isResizing counter\n chart.isResizing += 1;\n // set the animation for the current process\n setAnimation(animation, chart);\n var globalAnimation = renderer.globalAnimation;\n chart.oldChartHeight = chart.chartHeight;\n chart.oldChartWidth = chart.chartWidth;\n if (typeof width !== 'undefined') {\n chart.options.chart.width = width;\n }\n if (typeof height !== 'undefined') {\n chart.options.chart.height = height;\n }\n chart.getChartSize();\n // Resize the container with the global animation applied if enabled\n // (#2503)\n if (!chart.styledMode) {\n (globalAnimation ? animate : css)(chart.container, {\n width: chart.chartWidth + 'px',\n height: chart.chartHeight + 'px'\n }, globalAnimation);\n }\n chart.setChartSize(true);\n renderer.setSize(chart.chartWidth, chart.chartHeight, globalAnimation);\n // handle axes\n chart.axes.forEach(function (axis) {\n axis.isDirty = true;\n axis.setScale();\n });\n chart.isDirtyLegend = true; // force legend redraw\n chart.isDirtyBox = true; // force redraw of plot and chart border\n chart.layOutTitles(); // #2857\n chart.getMargins();\n chart.redraw(globalAnimation);\n chart.oldChartHeight = null;\n fireEvent(chart, 'resize');\n // Fire endResize and set isResizing back. If animation is disabled,\n // fire without delay\n syncTimeout(function () {\n if (chart) {\n fireEvent(chart, 'endResize', null, function () {\n chart.isResizing -= 1;\n });\n }\n }, animObject(globalAnimation).duration);\n };\n /**\n * Set the public chart properties. This is done before and after the\n * pre-render to determine margin sizes.\n *\n * @private\n * @function Highcharts.Chart#setChartSize\n * @emits Highcharts.Chart#event:afterSetChartSize\n */\n Chart.prototype.setChartSize = function (skipAxes) {\n var chart = this,\n inverted = chart.inverted,\n renderer = chart.renderer,\n chartWidth = chart.chartWidth,\n chartHeight = chart.chartHeight,\n optionsChart = chart.options.chart,\n spacing = chart.spacing,\n clipOffset = chart.clipOffset;\n var plotLeft,\n plotTop,\n plotWidth,\n plotHeight;\n /**\n * The current left position of the plot area in pixels.\n *\n * @name Highcharts.Chart#plotLeft\n * @type {number}\n */\n chart.plotLeft = plotLeft = Math.round(chart.plotLeft);\n /**\n * The current top position of the plot area in pixels.\n *\n * @name Highcharts.Chart#plotTop\n * @type {number}\n */\n chart.plotTop = plotTop = Math.round(chart.plotTop);\n /**\n * The current width of the plot area in pixels.\n *\n * @name Highcharts.Chart#plotWidth\n * @type {number}\n */\n chart.plotWidth = plotWidth = Math.max(0, Math.round(chartWidth - plotLeft - chart.marginRight));\n /**\n * The current height of the plot area in pixels.\n *\n * @name Highcharts.Chart#plotHeight\n * @type {number}\n */\n chart.plotHeight = plotHeight = Math.max(0, Math.round(chartHeight - plotTop - chart.marginBottom));\n chart.plotSizeX = inverted ? plotHeight : plotWidth;\n chart.plotSizeY = inverted ? plotWidth : plotHeight;\n chart.plotBorderWidth = optionsChart.plotBorderWidth || 0;\n // Set boxes used for alignment\n chart.spacingBox = renderer.spacingBox = {\n x: spacing[3],\n y: spacing[0],\n width: chartWidth - spacing[3] - spacing[1],\n height: chartHeight - spacing[0] - spacing[2]\n };\n chart.plotBox = renderer.plotBox = {\n x: plotLeft,\n y: plotTop,\n width: plotWidth,\n height: plotHeight\n };\n var plotBorderWidth = 2 * Math.floor(chart.plotBorderWidth / 2),\n clipX = Math.ceil(Math.max(plotBorderWidth,\n clipOffset[3]) / 2),\n clipY = Math.ceil(Math.max(plotBorderWidth,\n clipOffset[0]) / 2);\n chart.clipBox = {\n x: clipX,\n y: clipY,\n width: Math.floor(chart.plotSizeX -\n Math.max(plotBorderWidth, clipOffset[1]) / 2 -\n clipX),\n height: Math.max(0, Math.floor(chart.plotSizeY -\n Math.max(plotBorderWidth, clipOffset[2]) / 2 -\n clipY))\n };\n if (!skipAxes) {\n chart.axes.forEach(function (axis) {\n axis.setAxisSize();\n axis.setAxisTranslation();\n });\n renderer.alignElements();\n }\n fireEvent(chart, 'afterSetChartSize', { skipAxes: skipAxes });\n };\n /**\n * Initial margins before auto size margins are applied.\n *\n * @private\n * @function Highcharts.Chart#resetMargins\n */\n Chart.prototype.resetMargins = function () {\n fireEvent(this, 'resetMargins');\n var chart = this,\n chartOptions = chart.options.chart;\n // Create margin and spacing array\n ['margin', 'spacing'].forEach(function splashArrays(target) {\n var value = chartOptions[target],\n values = isObject(value) ? value : [value,\n value,\n value,\n value];\n [\n 'Top',\n 'Right',\n 'Bottom',\n 'Left'\n ].forEach(function (sideName, side) {\n chart[target][side] = pick(chartOptions[target + sideName], values[side]);\n });\n });\n // Set margin names like chart.plotTop, chart.plotLeft,\n // chart.marginRight, chart.marginBottom.\n marginNames.forEach(function (m, side) {\n chart[m] = pick(chart.margin[side], chart.spacing[side]);\n });\n chart.axisOffset = [0, 0, 0, 0]; // top, right, bottom, left\n chart.clipOffset = [0, 0, 0, 0];\n };\n /**\n * Internal function to draw or redraw the borders and backgrounds for chart\n * and plot area.\n *\n * @private\n * @function Highcharts.Chart#drawChartBox\n * @emits Highcharts.Chart#event:afterDrawChartBox\n */\n Chart.prototype.drawChartBox = function () {\n var chart = this,\n optionsChart = chart.options.chart,\n renderer = chart.renderer,\n chartWidth = chart.chartWidth,\n chartHeight = chart.chartHeight,\n styledMode = chart.styledMode,\n plotBGImage = chart.plotBGImage,\n chartBackgroundColor = optionsChart.backgroundColor,\n plotBackgroundColor = optionsChart.plotBackgroundColor,\n plotBackgroundImage = optionsChart.plotBackgroundImage,\n plotLeft = chart.plotLeft,\n plotTop = chart.plotTop,\n plotWidth = chart.plotWidth,\n plotHeight = chart.plotHeight,\n plotBox = chart.plotBox,\n clipRect = chart.clipRect,\n clipBox = chart.clipBox;\n var chartBackground = chart.chartBackground,\n plotBackground = chart.plotBackground,\n plotBorder = chart.plotBorder,\n chartBorderWidth,\n mgn,\n bgAttr,\n verb = 'animate';\n // Chart area\n if (!chartBackground) {\n chart.chartBackground = chartBackground = renderer.rect()\n .addClass('highcharts-background')\n .add();\n verb = 'attr';\n }\n if (!styledMode) {\n // Presentational\n chartBorderWidth = optionsChart.borderWidth || 0;\n mgn = chartBorderWidth + (optionsChart.shadow ? 8 : 0);\n bgAttr = {\n fill: chartBackgroundColor || 'none'\n };\n if (chartBorderWidth || chartBackground['stroke-width']) { // #980\n bgAttr.stroke = optionsChart.borderColor;\n bgAttr['stroke-width'] = chartBorderWidth;\n }\n chartBackground\n .attr(bgAttr)\n .shadow(optionsChart.shadow);\n }\n else {\n chartBorderWidth = mgn = chartBackground.strokeWidth();\n }\n chartBackground[verb]({\n x: mgn / 2,\n y: mgn / 2,\n width: chartWidth - mgn - chartBorderWidth % 2,\n height: chartHeight - mgn - chartBorderWidth % 2,\n r: optionsChart.borderRadius\n });\n // Plot background\n verb = 'animate';\n if (!plotBackground) {\n verb = 'attr';\n chart.plotBackground = plotBackground = renderer.rect()\n .addClass('highcharts-plot-background')\n .add();\n }\n plotBackground[verb](plotBox);\n if (!styledMode) {\n // Presentational attributes for the background\n plotBackground\n .attr({\n fill: plotBackgroundColor || 'none'\n })\n .shadow(optionsChart.plotShadow);\n // Create the background image\n if (plotBackgroundImage) {\n if (!plotBGImage) {\n chart.plotBGImage = renderer.image(plotBackgroundImage, plotLeft, plotTop, plotWidth, plotHeight).add();\n }\n else {\n if (plotBackgroundImage !== plotBGImage.attr('href')) {\n plotBGImage.attr('href', plotBackgroundImage);\n }\n plotBGImage.animate(plotBox);\n }\n }\n }\n // Plot clip\n if (!clipRect) {\n chart.clipRect = renderer.clipRect(clipBox);\n }\n else {\n clipRect.animate({\n width: clipBox.width,\n height: clipBox.height\n });\n }\n // Plot area border\n verb = 'animate';\n if (!plotBorder) {\n verb = 'attr';\n chart.plotBorder = plotBorder = renderer.rect()\n .addClass('highcharts-plot-border')\n .attr({\n zIndex: 1 // Above the grid\n })\n .add();\n }\n if (!styledMode) {\n // Presentational\n plotBorder.attr({\n stroke: optionsChart.plotBorderColor,\n 'stroke-width': optionsChart.plotBorderWidth || 0,\n fill: 'none'\n });\n }\n plotBorder[verb](plotBorder.crisp({\n x: plotLeft,\n y: plotTop,\n width: plotWidth,\n height: plotHeight\n }, -plotBorder.strokeWidth())); // #3282 plotBorder should be negative;\n // reset\n chart.isDirtyBox = false;\n fireEvent(this, 'afterDrawChartBox');\n };\n /**\n * Detect whether a certain chart property is needed based on inspecting its\n * options and series. This mainly applies to the chart.inverted property,\n * and in extensions to the chart.angular and chart.polar properties.\n *\n * @private\n * @function Highcharts.Chart#propFromSeries\n */\n Chart.prototype.propFromSeries = function () {\n var chart = this,\n optionsChart = chart.options.chart,\n seriesOptions = chart.options.series;\n var i,\n klass,\n value;\n /**\n * The flag is set to `true` if a series of the chart is inverted.\n *\n * @name Highcharts.Chart#inverted\n * @type {boolean|undefined}\n */\n ['inverted', 'angular', 'polar'].forEach(function (key) {\n // The default series type's class\n klass = seriesTypes[(optionsChart.type || optionsChart.defaultSeriesType)];\n // Get the value from available chart-wide properties\n value =\n // It is set in the options:\n optionsChart[key] ||\n // The default series class:\n (klass && klass.prototype[key]);\n // requires it\n // 4. Check if any the chart's series require it\n i = seriesOptions && seriesOptions.length;\n while (!value && i--) {\n klass = seriesTypes[seriesOptions[i].type];\n if (klass && klass.prototype[key]) {\n value = true;\n }\n }\n // Set the chart property\n chart[key] = value;\n });\n };\n /**\n * Internal function to link two or more series together, based on the\n * `linkedTo` option. This is done from `Chart.render`, and after\n * `Chart.addSeries` and `Series.remove`.\n *\n * @private\n * @function Highcharts.Chart#linkSeries\n * @emits Highcharts.Chart#event:afterLinkSeries\n */\n Chart.prototype.linkSeries = function () {\n var chart = this,\n chartSeries = chart.series;\n // Reset links\n chartSeries.forEach(function (series) {\n series.linkedSeries.length = 0;\n });\n // Apply new links\n chartSeries.forEach(function (series) {\n var linkedTo = series.options.linkedTo;\n if (isString(linkedTo)) {\n if (linkedTo === ':previous') {\n linkedTo = chart.series[series.index - 1];\n }\n else {\n linkedTo = chart.get(linkedTo);\n }\n // #3341 avoid mutual linking\n if (linkedTo && linkedTo.linkedParent !== series) {\n linkedTo.linkedSeries.push(series);\n series.linkedParent = linkedTo;\n if (linkedTo.enabledDataSorting) {\n series.setDataSortingOptions();\n }\n series.visible = pick(series.options.visible, linkedTo.options.visible, series.visible); // #3879\n }\n }\n });\n fireEvent(this, 'afterLinkSeries');\n };\n /**\n * Render series for the chart.\n *\n * @private\n * @function Highcharts.Chart#renderSeries\n */\n Chart.prototype.renderSeries = function () {\n this.series.forEach(function (serie) {\n serie.translate();\n serie.render();\n });\n };\n /**\n * Render labels for the chart.\n *\n * @private\n * @function Highcharts.Chart#renderLabels\n */\n Chart.prototype.renderLabels = function () {\n var chart = this,\n labels = chart.options.labels;\n if (labels.items) {\n labels.items.forEach(function (label) {\n var style = extend(labels.style,\n label.style),\n x = pInt(style.left) + chart.plotLeft,\n y = pInt(style.top) + chart.plotTop + 12;\n // delete to prevent rewriting in IE\n delete style.left;\n delete style.top;\n chart.renderer.text(label.html, x, y)\n .attr({ zIndex: 2 })\n .css(style)\n .add();\n });\n }\n };\n /**\n * Render all graphics for the chart. Runs internally on initialization.\n *\n * @private\n * @function Highcharts.Chart#render\n */\n Chart.prototype.render = function () {\n var chart = this,\n axes = chart.axes,\n colorAxis = chart.colorAxis,\n renderer = chart.renderer,\n options = chart.options,\n renderAxes = function (axes) {\n axes.forEach(function (axis) {\n if (axis.visible) {\n axis.render();\n }\n });\n };\n var correction = 0; // correction for X axis labels\n // Title\n chart.setTitle();\n /**\n * The overview of the chart's series.\n *\n * @name Highcharts.Chart#legend\n * @type {Highcharts.Legend}\n */\n chart.legend = new Legend(chart, options.legend);\n // Get stacks\n if (chart.getStacks) {\n chart.getStacks();\n }\n // Get chart margins\n chart.getMargins(true);\n chart.setChartSize();\n // Record preliminary dimensions for later comparison\n var tempWidth = chart.plotWidth;\n axes.some(function (axis) {\n if (axis.horiz &&\n axis.visible &&\n axis.options.labels.enabled &&\n axis.series.length) {\n // 21 is the most common correction for X axis labels\n correction = 21;\n return true;\n }\n });\n // use Math.max to prevent negative plotHeight\n chart.plotHeight = Math.max(chart.plotHeight - correction, 0);\n var tempHeight = chart.plotHeight;\n // Get margins by pre-rendering axes\n axes.forEach(function (axis) {\n axis.setScale();\n });\n chart.getAxisMargins();\n // If the plot area size has changed significantly, calculate tick\n // positions again\n var redoHorizontal = tempWidth / chart.plotWidth > 1.1;\n // Height is more sensitive, use lower threshold\n var redoVertical = tempHeight / chart.plotHeight > 1.05;\n if (redoHorizontal || redoVertical) {\n axes.forEach(function (axis) {\n if ((axis.horiz && redoHorizontal) ||\n (!axis.horiz && redoVertical)) {\n // update to reflect the new margins\n axis.setTickInterval(true);\n }\n });\n chart.getMargins(); // second pass to check for new labels\n }\n // Draw the borders and backgrounds\n chart.drawChartBox();\n // Axes\n if (chart.hasCartesianSeries) {\n renderAxes(axes);\n }\n else if (colorAxis && colorAxis.length) {\n renderAxes(colorAxis);\n }\n // The series\n if (!chart.seriesGroup) {\n chart.seriesGroup = renderer.g('series-group')\n .attr({ zIndex: 3 })\n .add();\n }\n chart.renderSeries();\n // Labels\n chart.renderLabels();\n // Credits\n chart.addCredits();\n // Handle responsiveness\n if (chart.setResponsive) {\n chart.setResponsive();\n }\n // Set flag\n chart.hasRendered = true;\n };\n /**\n * Set a new credits label for the chart.\n *\n * @sample highcharts/credits/credits-update/\n * Add and update credits\n *\n * @function Highcharts.Chart#addCredits\n *\n * @param {Highcharts.CreditsOptions} [credits]\n * A configuration object for the new credits.\n */\n Chart.prototype.addCredits = function (credits) {\n var chart = this,\n creds = merge(true,\n this.options.credits,\n credits);\n if (creds.enabled && !this.credits) {\n /**\n * The chart's credits label. The label has an `update` method that\n * allows setting new options as per the\n * [credits options set](https://api.highcharts.com/highcharts/credits).\n *\n * @name Highcharts.Chart#credits\n * @type {Highcharts.SVGElement}\n */\n this.credits = this.renderer.text(creds.text + (this.mapCredits || ''), 0, 0)\n .addClass('highcharts-credits')\n .on('click', function () {\n if (creds.href) {\n win.location.href = creds.href;\n }\n })\n .attr({\n align: creds.position.align,\n zIndex: 8\n });\n if (!chart.styledMode) {\n this.credits.css(creds.style);\n }\n this.credits\n .add()\n .align(creds.position);\n // Dynamically update\n this.credits.update = function (options) {\n chart.credits = chart.credits.destroy();\n chart.addCredits(options);\n };\n }\n };\n /**\n * Remove the chart and purge memory. This method is called internally\n * before adding a second chart into the same container, as well as on\n * window unload to prevent leaks.\n *\n * @sample highcharts/members/chart-destroy/\n * Destroy the chart from a button\n * @sample stock/members/chart-destroy/\n * Destroy with Highcharts Stock\n *\n * @function Highcharts.Chart#destroy\n *\n * @emits Highcharts.Chart#event:destroy\n */\n Chart.prototype.destroy = function () {\n var chart = this,\n axes = chart.axes,\n series = chart.series,\n container = chart.container,\n parentNode = container && container.parentNode;\n var i;\n // fire the chart.destoy event\n fireEvent(chart, 'destroy');\n // Delete the chart from charts lookup array\n if (chart.renderer.forExport) {\n erase(charts, chart); // #6569\n }\n else {\n charts[chart.index] = void 0;\n }\n H.chartCount--;\n chart.renderTo.removeAttribute('data-highcharts-chart');\n // remove events\n removeEvent(chart);\n // ==== Destroy collections:\n // Destroy axes\n i = axes.length;\n while (i--) {\n axes[i] = axes[i].destroy();\n }\n // Destroy scroller & scroller series before destroying base series\n if (this.scroller && this.scroller.destroy) {\n this.scroller.destroy();\n }\n // Destroy each series\n i = series.length;\n while (i--) {\n series[i] = series[i].destroy();\n }\n // ==== Destroy chart properties:\n [\n 'title', 'subtitle', 'chartBackground', 'plotBackground',\n 'plotBGImage', 'plotBorder', 'seriesGroup', 'clipRect', 'credits',\n 'pointer', 'rangeSelector', 'legend', 'resetZoomButton', 'tooltip',\n 'renderer'\n ].forEach(function (name) {\n var prop = chart[name];\n if (prop && prop.destroy) {\n chart[name] = prop.destroy();\n }\n });\n // Remove container and all SVG, check container as it can break in IE\n // when destroyed before finished loading\n if (container) {\n container.innerHTML = AST.emptyHTML;\n removeEvent(container);\n if (parentNode) {\n discardElement(container);\n }\n }\n // clean it all up\n objectEach(chart, function (val, key) {\n delete chart[key];\n });\n };\n /**\n * Prepare for first rendering after all data are loaded.\n *\n * @private\n * @function Highcharts.Chart#firstRender\n * @emits Highcharts.Chart#event:beforeRender\n */\n Chart.prototype.firstRender = function () {\n var chart = this,\n options = chart.options;\n // Hook for oldIE to check whether the chart is ready to render\n if (chart.isReadyToRender && !chart.isReadyToRender()) {\n return;\n }\n // Create the container\n chart.getContainer();\n chart.resetMargins();\n chart.setChartSize();\n // Set the common chart properties (mainly invert) from the given series\n chart.propFromSeries();\n // get axes\n chart.getAxes();\n // Initialize the series\n (isArray(options.series) ? options.series : []).forEach(\n // #9680\n function (serieOptions) {\n chart.initSeries(serieOptions);\n });\n chart.linkSeries();\n chart.setSeriesData();\n // Run an event after axes and series are initialized, but before\n // render. At this stage, the series data is indexed and cached in the\n // xData and yData arrays, so we can access those before rendering. Used\n // in Highcharts Stock.\n fireEvent(chart, 'beforeRender');\n // depends on inverted and on margins being set\n if (Pointer) {\n if (MSPointer.isRequired()) {\n chart.pointer = new MSPointer(chart, options);\n }\n else {\n /**\n * The Pointer that keeps track of mouse and touch interaction.\n *\n * @memberof Highcharts.Chart\n * @name pointer\n * @type {Highcharts.Pointer}\n * @instance\n */\n chart.pointer = new Pointer(chart, options);\n }\n }\n chart.render();\n chart.pointer.getChartPosition(); // #14973\n // Fire the load event if there are no external images\n if (!chart.renderer.imgCount && !chart.hasLoaded) {\n chart.onload();\n }\n // If the chart was rendered outside the top container, put it back in\n // (#3679)\n chart.temporaryDisplay(true);\n };\n /**\n * Internal function that runs on chart load, async if any images are loaded\n * in the chart. Runs the callbacks and triggers the `load` and `render`\n * events.\n *\n * @private\n * @function Highcharts.Chart#onload\n * @emits Highcharts.Chart#event:load\n * @emits Highcharts.Chart#event:render\n */\n Chart.prototype.onload = function () {\n // Run callbacks, first the ones registered by modules, then user's one\n this.callbacks.concat([this.callback]).forEach(function (fn) {\n // Chart destroyed in its own callback (#3600)\n if (fn && typeof this.index !== 'undefined') {\n fn.apply(this, [this]);\n }\n }, this);\n fireEvent(this, 'load');\n fireEvent(this, 'render');\n // Set up auto resize, check for not destroyed (#6068)\n if (defined(this.index)) {\n this.setReflow(this.options.chart.reflow);\n }\n this.warnIfA11yModuleNotLoaded();\n // Don't run again\n this.hasLoaded = true;\n };\n /**\n * Emit console warning if the a11y module is not loaded.\n */\n Chart.prototype.warnIfA11yModuleNotLoaded = function () {\n var _a = this,\n options = _a.options,\n title = _a.title;\n if (options && !this.accessibility) {\n // Make chart behave as an image with the title as alt text\n this.renderer.boxWrapper.attr({\n role: 'img',\n 'aria-label': (title && title.element.textContent) || ''\n });\n if (!(options.accessibility && options.accessibility.enabled === false)) {\n error('Highcharts warning: Consider including the ' +\n '\"accessibility.js\" module to make your chart more ' +\n 'usable for people with disabilities. Set the ' +\n '\"accessibility.enabled\" option to false to remove this ' +\n 'warning. See https://www.highcharts.com/docs/accessibility/accessibility-module.', false, this);\n }\n }\n };\n /**\n * Add a series to the chart after render time. Note that this method should\n * never be used when adding data synchronously at chart render time, as it\n * adds expense to the calculations and rendering. When adding data at the\n * same time as the chart is initialized, add the series as a configuration\n * option instead. With multiple axes, the `offset` is dynamically adjusted.\n *\n * @sample highcharts/members/chart-addseries/\n * Add a series from a button\n * @sample stock/members/chart-addseries/\n * Add a series in Highcharts Stock\n *\n * @function Highcharts.Chart#addSeries\n *\n * @param {Highcharts.SeriesOptionsType} options\n * The config options for the series.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after adding.\n *\n * @param {boolean|Partial} [animation]\n * Whether to apply animation, and optionally animation\n * configuration.\n *\n * @return {Highcharts.Series}\n * The newly created series object.\n *\n * @emits Highcharts.Chart#event:addSeries\n * @emits Highcharts.Chart#event:afterAddSeries\n */\n Chart.prototype.addSeries = function (options, redraw, animation) {\n var chart = this;\n var series;\n if (options) { // <- not necessary\n redraw = pick(redraw, true); // defaults to true\n fireEvent(chart, 'addSeries', { options: options }, function () {\n series = chart.initSeries(options);\n chart.isDirtyLegend = true;\n chart.linkSeries();\n if (series.enabledDataSorting) {\n // We need to call `setData` after `linkSeries`\n series.setData(options.data, false);\n }\n fireEvent(chart, 'afterAddSeries', { series: series });\n if (redraw) {\n chart.redraw(animation);\n }\n });\n }\n return series;\n };\n /**\n * Add an axis to the chart after render time. Note that this method should\n * never be used when adding data synchronously at chart render time, as it\n * adds expense to the calculations and rendering. When adding data at the\n * same time as the chart is initialized, add the axis as a configuration\n * option instead.\n *\n * @sample highcharts/members/chart-addaxis/\n * Add and remove axes\n *\n * @function Highcharts.Chart#addAxis\n *\n * @param {Highcharts.AxisOptions} options\n * The axis options.\n *\n * @param {boolean} [isX=false]\n * Whether it is an X axis or a value axis.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after adding.\n *\n * @param {boolean|Partial} [animation=true]\n * Whether and how to apply animation in the redraw.\n *\n * @return {Highcharts.Axis}\n * The newly generated Axis object.\n */\n Chart.prototype.addAxis = function (options, isX, redraw, animation) {\n return this.createAxis(isX ? 'xAxis' : 'yAxis', { axis: options, redraw: redraw, animation: animation });\n };\n /**\n * Add a color axis to the chart after render time. Note that this method\n * should never be used when adding data synchronously at chart render time,\n * as it adds expense to the calculations and rendering. When adding data at\n * the same time as the chart is initialized, add the axis as a\n * configuration option instead.\n *\n * @sample highcharts/members/chart-addaxis/\n * Add and remove axes\n *\n * @function Highcharts.Chart#addColorAxis\n *\n * @param {Highcharts.ColorAxisOptions} options\n * The axis options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after adding.\n *\n * @param {boolean|Partial} [animation=true]\n * Whether and how to apply animation in the redraw.\n *\n * @return {Highcharts.ColorAxis}\n * The newly generated Axis object.\n */\n Chart.prototype.addColorAxis = function (options, redraw, animation) {\n return this.createAxis('colorAxis', { axis: options, redraw: redraw, animation: animation });\n };\n /**\n * Factory for creating different axis types.\n *\n * @private\n * @function Highcharts.Chart#createAxis\n *\n * @param {string} type\n * An axis type.\n *\n * @param {...Array<*>} arguments\n * All arguments for the constructor.\n *\n * @return {Highcharts.Axis | Highcharts.ColorAxis}\n * The newly generated Axis object.\n */\n Chart.prototype.createAxis = function (type, options) {\n var axis = new Axis(this,\n merge(options.axis, {\n index: this[type].length,\n isX: type === 'xAxis'\n }));\n if (pick(options.redraw, true)) {\n this.redraw(options.animation);\n }\n return axis;\n };\n /**\n * Dim the chart and show a loading text or symbol. Options for the loading\n * screen are defined in {@link\n * https://api.highcharts.com/highcharts/loading|the loading options}.\n *\n * @sample highcharts/members/chart-hideloading/\n * Show and hide loading from a button\n * @sample highcharts/members/chart-showloading/\n * Apply different text labels\n * @sample stock/members/chart-show-hide-loading/\n * Toggle loading in Highcharts Stock\n *\n * @function Highcharts.Chart#showLoading\n *\n * @param {string} [str]\n * An optional text to show in the loading label instead of the\n * default one. The default text is set in\n * [lang.loading](https://api.highcharts.com/highcharts/lang.loading).\n */\n Chart.prototype.showLoading = function (str) {\n var chart = this,\n options = chart.options,\n loadingOptions = options.loading,\n setLoadingSize = function () {\n if (loadingDiv) {\n css(loadingDiv, {\n left: chart.plotLeft + 'px',\n top: chart.plotTop + 'px',\n width: chart.plotWidth + 'px',\n height: chart.plotHeight + 'px'\n });\n }\n };\n var loadingDiv = chart.loadingDiv,\n loadingSpan = chart.loadingSpan;\n // create the layer at the first call\n if (!loadingDiv) {\n chart.loadingDiv = loadingDiv = createElement('div', {\n className: 'highcharts-loading highcharts-loading-hidden'\n }, null, chart.container);\n }\n if (!loadingSpan) {\n chart.loadingSpan = loadingSpan = createElement('span', { className: 'highcharts-loading-inner' }, null, loadingDiv);\n addEvent(chart, 'redraw', setLoadingSize); // #1080\n }\n loadingDiv.className = 'highcharts-loading';\n // Update text\n AST.setElementHTML(loadingSpan, pick(str, options.lang.loading, ''));\n if (!chart.styledMode) {\n // Update visuals\n css(loadingDiv, extend(loadingOptions.style, {\n zIndex: 10\n }));\n css(loadingSpan, loadingOptions.labelStyle);\n // Show it\n if (!chart.loadingShown) {\n css(loadingDiv, {\n opacity: 0,\n display: ''\n });\n animate(loadingDiv, {\n opacity: loadingOptions.style.opacity || 0.5\n }, {\n duration: loadingOptions.showDuration || 0\n });\n }\n }\n chart.loadingShown = true;\n setLoadingSize();\n };\n /**\n * Hide the loading layer.\n *\n * @see Highcharts.Chart#showLoading\n *\n * @sample highcharts/members/chart-hideloading/\n * Show and hide loading from a button\n * @sample stock/members/chart-show-hide-loading/\n * Toggle loading in Highcharts Stock\n *\n * @function Highcharts.Chart#hideLoading\n */\n Chart.prototype.hideLoading = function () {\n var options = this.options,\n loadingDiv = this.loadingDiv;\n if (loadingDiv) {\n loadingDiv.className =\n 'highcharts-loading highcharts-loading-hidden';\n if (!this.styledMode) {\n animate(loadingDiv, {\n opacity: 0\n }, {\n duration: options.loading.hideDuration || 100,\n complete: function () {\n css(loadingDiv, { display: 'none' });\n }\n });\n }\n }\n this.loadingShown = false;\n };\n /**\n * A generic function to update any element of the chart. Elements can be\n * enabled and disabled, moved, re-styled, re-formatted etc.\n *\n * A special case is configuration objects that take arrays, for example\n * [xAxis](https://api.highcharts.com/highcharts/xAxis),\n * [yAxis](https://api.highcharts.com/highcharts/yAxis) or\n * [series](https://api.highcharts.com/highcharts/series). For these\n * collections, an `id` option is used to map the new option set to an\n * existing object. If an existing object of the same id is not found, the\n * corresponding item is updated. So for example, running `chart.update`\n * with a series item without an id, will cause the existing chart's series\n * with the same index in the series array to be updated. When the\n * `oneToOne` parameter is true, `chart.update` will also take care of\n * adding and removing items from the collection. Read more under the\n * parameter description below.\n *\n * Note that when changing series data, `chart.update` may mutate the passed\n * data options.\n *\n * See also the\n * [responsive option set](https://api.highcharts.com/highcharts/responsive).\n * Switching between `responsive.rules` basically runs `chart.update` under\n * the hood.\n *\n * @sample highcharts/members/chart-update/\n * Update chart geometry\n *\n * @function Highcharts.Chart#update\n *\n * @param {Highcharts.Options} options\n * A configuration object for the new chart options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart.\n *\n * @param {boolean} [oneToOne=false]\n * When `true`, the `series`, `xAxis`, `yAxis` and `annotations`\n * collections will be updated one to one, and items will be either\n * added or removed to match the new updated options. For example,\n * if the chart has two series and we call `chart.update` with a\n * configuration containing three series, one will be added. If we\n * call `chart.update` with one series, one will be removed. Setting\n * an empty `series` array will remove all series, but leaving out\n * the`series` property will leave all series untouched. If the\n * series have id's, the new series options will be matched by id,\n * and the remaining ones removed.\n *\n * @param {boolean|Partial} [animation=true]\n * Whether to apply animation, and optionally animation\n * configuration.\n *\n * @emits Highcharts.Chart#event:update\n * @emits Highcharts.Chart#event:afterUpdate\n */\n Chart.prototype.update = function (options, redraw, oneToOne, animation) {\n var chart = this,\n adders = {\n credits: 'addCredits',\n title: 'setTitle',\n subtitle: 'setSubtitle',\n caption: 'setCaption'\n },\n isResponsiveOptions = options.isResponsiveOptions,\n itemsForRemoval = [];\n var updateAllAxes,\n updateAllSeries,\n runSetSize;\n fireEvent(chart, 'update', { options: options });\n // If there are responsive rules in action, undo the responsive rules\n // before we apply the updated options and replay the responsive rules\n // on top from the chart.redraw function (#9617).\n if (!isResponsiveOptions) {\n chart.setResponsive(false, true);\n }\n options = cleanRecursively(options, chart.options);\n chart.userOptions = merge(chart.userOptions, options);\n // If the top-level chart option is present, some special updates are\n // required\n var optionsChart = options.chart;\n if (optionsChart) {\n merge(true, chart.options.chart, optionsChart);\n // Setter function\n if ('className' in optionsChart) {\n chart.setClassName(optionsChart.className);\n }\n if ('reflow' in optionsChart) {\n chart.setReflow(optionsChart.reflow);\n }\n if ('inverted' in optionsChart ||\n 'polar' in optionsChart ||\n 'type' in optionsChart) {\n // Parse options.chart.inverted and options.chart.polar together\n // with the available series.\n chart.propFromSeries();\n updateAllAxes = true;\n }\n if ('alignTicks' in optionsChart) { // #6452\n updateAllAxes = true;\n }\n if ('events' in optionsChart) {\n // Chart event handlers\n registerEventOptions(this, optionsChart);\n }\n objectEach(optionsChart, function (val, key) {\n if (chart.propsRequireUpdateSeries.indexOf('chart.' + key) !==\n -1) {\n updateAllSeries = true;\n }\n // Only dirty box\n if (chart.propsRequireDirtyBox.indexOf(key) !== -1) {\n chart.isDirtyBox = true;\n }\n // Chart setSize\n if (chart.propsRequireReflow.indexOf(key) !== -1) {\n if (isResponsiveOptions) {\n chart.isDirtyBox = true;\n }\n else {\n runSetSize = true;\n }\n }\n });\n if (!chart.styledMode && optionsChart.style) {\n chart.renderer.setStyle(chart.options.chart.style || {});\n }\n }\n // Moved up, because tooltip needs updated plotOptions (#6218)\n if (!chart.styledMode && options.colors) {\n this.options.colors = options.colors;\n }\n if (options.time) {\n // Maintaining legacy global time. If the chart is instanciated\n // first with global time, then updated with time options, we need\n // to create a new Time instance to avoid mutating the global time\n // (#10536).\n if (this.time === defaultTime) {\n this.time = new Time(options.time);\n }\n // If we're updating, the time class is different from other chart\n // classes (chart.legend, chart.tooltip etc) in that it doesn't know\n // about the chart. The other chart[something].update functions also\n // set the chart.options[something]. For the time class however we\n // need to update the chart options separately. #14230.\n merge(true, chart.options.time, options.time);\n }\n // Some option stuctures correspond one-to-one to chart objects that\n // have update methods, for example\n // options.credits => chart.credits\n // options.legend => chart.legend\n // options.title => chart.title\n // options.tooltip => chart.tooltip\n // options.subtitle => chart.subtitle\n // options.mapNavigation => chart.mapNavigation\n // options.navigator => chart.navigator\n // options.scrollbar => chart.scrollbar\n objectEach(options, function (val, key) {\n if (chart[key] &&\n typeof chart[key].update === 'function') {\n chart[key].update(val, false);\n // If a one-to-one object does not exist, look for an adder function\n }\n else if (typeof chart[adders[key]] === 'function') {\n chart[adders[key]](val);\n // Else, just merge the options. For nodes like loading, noData,\n // plotOptions\n }\n else if (key !== 'colors' &&\n chart.collectionsWithUpdate.indexOf(key) === -1) {\n merge(true, chart.options[key], options[key]);\n }\n if (key !== 'chart' &&\n chart.propsRequireUpdateSeries.indexOf(key) !== -1) {\n updateAllSeries = true;\n }\n });\n // Setters for collections. For axes and series, each item is referred\n // by an id. If the id is not found, it defaults to the corresponding\n // item in the collection, so setting one series without an id, will\n // update the first series in the chart. Setting two series without\n // an id will update the first and the second respectively (#6019)\n // chart.update and responsive.\n this.collectionsWithUpdate.forEach(function (coll) {\n var indexMap;\n if (options[coll]) {\n // In stock charts, the navigator series are also part of the\n // chart.series array, but those series should not be handled\n // here (#8196) and neither should the navigator axis (#9671).\n indexMap = [];\n chart[coll].forEach(function (s, i) {\n if (!s.options.isInternal) {\n indexMap.push(pick(s.options.index, i));\n }\n });\n splat(options[coll]).forEach(function (newOptions, i) {\n var hasId = defined(newOptions.id);\n var item;\n // Match by id\n if (hasId) {\n item = chart.get(newOptions.id);\n }\n // No match by id found, match by index instead\n if (!item && chart[coll]) {\n item = chart[coll][indexMap ? indexMap[i] : i];\n // Check if we grabbed an item with an exising but\n // different id (#13541)\n if (item && hasId && defined(item.options.id)) {\n item = void 0;\n }\n }\n if (item && item.coll === coll) {\n item.update(newOptions, false);\n if (oneToOne) {\n item.touched = true;\n }\n }\n // If oneToOne and no matching item is found, add one\n if (!item && oneToOne && chart.collectionsWithInit[coll]) {\n chart.collectionsWithInit[coll][0].apply(chart, \n // [newOptions, ...extraArguments, redraw=false]\n [\n newOptions\n ].concat(\n // Not all initializers require extra args\n chart.collectionsWithInit[coll][1] || []).concat([\n false\n ])).touched = true;\n }\n });\n // Add items for removal\n if (oneToOne) {\n chart[coll].forEach(function (item) {\n if (!item.touched && !item.options.isInternal) {\n itemsForRemoval.push(item);\n }\n else {\n delete item.touched;\n }\n });\n }\n }\n });\n itemsForRemoval.forEach(function (item) {\n if (item.chart && item.remove) { // #9097, avoid removing twice\n item.remove(false);\n }\n });\n if (updateAllAxes) {\n chart.axes.forEach(function (axis) {\n axis.update({}, false);\n });\n }\n // Certain options require the whole series structure to be thrown away\n // and rebuilt\n if (updateAllSeries) {\n chart.getSeriesOrderByLinks().forEach(function (series) {\n // Avoid removed navigator series\n if (series.chart) {\n series.update({}, false);\n }\n }, this);\n }\n // Update size. Redraw is forced.\n var newWidth = optionsChart && optionsChart.width;\n var newHeight = optionsChart && (isString(optionsChart.height) ?\n relativeLength(optionsChart.height,\n newWidth || chart.chartWidth) :\n optionsChart.height);\n if (\n // In this case, run chart.setSize with newWidth and newHeight which\n // are undefined, only for reflowing chart elements because margin\n // or spacing has been set (#8190)\n runSetSize ||\n // In this case, the size is actually set\n (isNumber(newWidth) && newWidth !== chart.chartWidth) ||\n (isNumber(newHeight) && newHeight !== chart.chartHeight)) {\n chart.setSize(newWidth, newHeight, animation);\n }\n else if (pick(redraw, true)) {\n chart.redraw(animation);\n }\n fireEvent(chart, 'afterUpdate', {\n options: options,\n redraw: redraw,\n animation: animation\n });\n };\n /**\n * Shortcut to set the subtitle options. This can also be done from {@link\n * Chart#update} or {@link Chart#setTitle}.\n *\n * @function Highcharts.Chart#setSubtitle\n *\n * @param {Highcharts.SubtitleOptions} options\n * New subtitle options. The subtitle text itself is set by the\n * `options.text` property.\n */\n Chart.prototype.setSubtitle = function (options, redraw) {\n this.applyDescription('subtitle', options);\n this.layOutTitles(redraw);\n };\n /**\n * Set the caption options. This can also be done from {@link\n * Chart#update}.\n *\n * @function Highcharts.Chart#setCaption\n *\n * @param {Highcharts.CaptionOptions} options\n * New caption options. The caption text itself is set by the\n * `options.text` property.\n */\n Chart.prototype.setCaption = function (options, redraw) {\n this.applyDescription('caption', options);\n this.layOutTitles(redraw);\n };\n /**\n * Display the zoom button, so users can reset zoom to the default view\n * settings.\n *\n * @function Highcharts.Chart#showResetZoom\n *\n * @emits Highcharts.Chart#event:afterShowResetZoom\n * @emits Highcharts.Chart#event:beforeShowResetZoom\n */\n Chart.prototype.showResetZoom = function () {\n var chart = this,\n lang = defaultOptions.lang,\n btnOptions = chart.options.chart.zooming.resetButton,\n theme = btnOptions.theme,\n alignTo = (btnOptions.relativeTo === 'chart' ||\n btnOptions.relativeTo === 'spacingBox' ?\n null :\n 'scrollablePlotBox');\n /**\n * @private\n */\n function zoomOut() {\n chart.zoomOut();\n }\n fireEvent(this, 'beforeShowResetZoom', null, function () {\n chart.resetZoomButton = chart.renderer\n .button(lang.resetZoom, null, null, zoomOut, theme)\n .attr({\n align: btnOptions.position.align,\n title: lang.resetZoomTitle\n })\n .addClass('highcharts-reset-zoom')\n .add()\n .align(btnOptions.position, false, alignTo);\n });\n fireEvent(this, 'afterShowResetZoom');\n };\n /**\n * Zoom the chart out after a user has zoomed in. See also\n * [Axis.setExtremes](/class-reference/Highcharts.Axis#setExtremes).\n *\n * @function Highcharts.Chart#zoomOut\n *\n * @emits Highcharts.Chart#event:selection\n */\n Chart.prototype.zoomOut = function () {\n fireEvent(this, 'selection', { resetSelection: true }, this.zoom);\n };\n /**\n * Zoom into a given portion of the chart given by axis coordinates.\n *\n * @private\n * @function Highcharts.Chart#zoom\n * @param {Highcharts.SelectEventObject} event\n */\n Chart.prototype.zoom = function (event) {\n var chart = this,\n pointer = chart.pointer;\n var displayButton = false,\n hasZoomed;\n // If zoom is called with no arguments, reset the axes\n if (!event || event.resetSelection) {\n chart.axes.forEach(function (axis) {\n hasZoomed = axis.zoom();\n });\n pointer.initiated = false; // #6804\n }\n else { // else, zoom in on all axes\n event.xAxis.concat(event.yAxis).forEach(function (axisData) {\n var axis = axisData.axis,\n isXAxis = axis.isXAxis;\n // don't zoom more than minRange\n if (pointer[isXAxis ? 'zoomX' : 'zoomY'] &&\n (defined(pointer.mouseDownX) &&\n defined(pointer.mouseDownY) &&\n chart.isInsidePlot(pointer.mouseDownX - chart.plotLeft, pointer.mouseDownY - chart.plotTop, { axis: axis })) || !defined(chart.inverted ? pointer.mouseDownX : pointer.mouseDownY)) {\n hasZoomed = axis.zoom(axisData.min, axisData.max);\n if (axis.displayBtn) {\n displayButton = true;\n }\n }\n });\n }\n // Show or hide the Reset zoom button\n var resetZoomButton = chart.resetZoomButton;\n if (displayButton && !resetZoomButton) {\n chart.showResetZoom();\n }\n else if (!displayButton && isObject(resetZoomButton)) {\n chart.resetZoomButton = resetZoomButton.destroy();\n }\n // Redraw\n if (hasZoomed) {\n chart.redraw(pick(chart.options.chart.animation, event && event.animation, chart.pointCount < 100));\n }\n };\n /**\n * Pan the chart by dragging the mouse across the pane. This function is\n * called on mouse move, and the distance to pan is computed from chartX\n * compared to the first chartX position in the dragging operation.\n *\n * @private\n * @function Highcharts.Chart#pan\n * @param {Highcharts.PointerEventObject} e\n * @param {string} panning\n */\n Chart.prototype.pan = function (e, panning) {\n var chart = this,\n hoverPoints = chart.hoverPoints,\n panningOptions = (typeof panning === 'object' ?\n panning :\n {\n enabled: panning,\n type: 'x'\n }),\n chartOptions = chart.options.chart;\n if (chartOptions && chartOptions.panning) {\n chartOptions.panning = panningOptions;\n }\n var type = panningOptions.type;\n var doRedraw;\n fireEvent(this, 'pan', { originalEvent: e }, function () {\n // remove active points for shared tooltip\n if (hoverPoints) {\n hoverPoints.forEach(function (point) {\n point.setState();\n });\n }\n var axes = chart.xAxis;\n if (type === 'xy') {\n axes = axes.concat(chart.yAxis);\n }\n else if (type === 'y') {\n axes = chart.yAxis;\n }\n var nextMousePos = {};\n axes.forEach(function (axis) {\n if (!axis.options.panningEnabled || axis.options.isInternal) {\n return;\n }\n var horiz = axis.horiz, mousePos = e[horiz ? 'chartX' : 'chartY'], mouseDown = horiz ? 'mouseDownX' : 'mouseDownY', startPos = chart[mouseDown], halfPointRange = axis.minPointOffset || 0, pointRangeDirection = (axis.reversed && !chart.inverted) ||\n (!axis.reversed && chart.inverted) ?\n -1 :\n 1, extremes = axis.getExtremes(), panMin = axis.toValue(startPos - mousePos, true) +\n halfPointRange * pointRangeDirection, panMax = axis.toValue(startPos + axis.len - mousePos, true) -\n ((halfPointRange * pointRangeDirection) ||\n (axis.isXAxis && axis.pointRangePadding) ||\n 0), flipped = panMax < panMin, hasVerticalPanning = axis.hasVerticalPanning();\n var newMin = flipped ? panMax : panMin,\n newMax = flipped ? panMin : panMax,\n panningState = axis.panningState,\n spill;\n // General calculations of panning state.\n // This is related to using vertical panning. (#11315).\n if (hasVerticalPanning &&\n !axis.isXAxis && (!panningState || panningState.isDirty)) {\n axis.series.forEach(function (series) {\n var processedData = series.getProcessedData(true),\n dataExtremes = series.getExtremes(processedData.yData,\n true);\n if (!panningState) {\n panningState = {\n startMin: Number.MAX_VALUE,\n startMax: -Number.MAX_VALUE\n };\n }\n if (isNumber(dataExtremes.dataMin) &&\n isNumber(dataExtremes.dataMax)) {\n panningState.startMin = Math.min(pick(series.options.threshold, Infinity), dataExtremes.dataMin, panningState.startMin);\n panningState.startMax = Math.max(pick(series.options.threshold, -Infinity), dataExtremes.dataMax, panningState.startMax);\n }\n });\n }\n var paddedMin = Math.min(pick(panningState && panningState.startMin,\n extremes.dataMin),\n halfPointRange ?\n extremes.min :\n axis.toValue(axis.toPixels(extremes.min) -\n axis.minPixelPadding));\n var paddedMax = Math.max(pick(panningState && panningState.startMax,\n extremes.dataMax),\n halfPointRange ?\n extremes.max :\n axis.toValue(axis.toPixels(extremes.max) +\n axis.minPixelPadding));\n axis.panningState = panningState;\n // It is not necessary to calculate extremes on ordinal axis,\n // because they are already calculated, so we don't want to\n // override them.\n if (!axis.isOrdinal) {\n // If the new range spills over, either to the min or max,\n // adjust the new range.\n spill = paddedMin - newMin;\n if (spill > 0) {\n newMax += spill;\n newMin = paddedMin;\n }\n spill = newMax - paddedMax;\n if (spill > 0) {\n newMax = paddedMax;\n newMin -= spill;\n }\n // Set new extremes if they are actually new\n if (axis.series.length &&\n newMin !== extremes.min &&\n newMax !== extremes.max &&\n newMin >= paddedMin &&\n newMax <= paddedMax) {\n axis.setExtremes(newMin, newMax, false, false, { trigger: 'pan' });\n if (!chart.resetZoomButton &&\n // Show reset zoom button only when both newMin and\n // newMax values are between padded axis range.\n newMin !== paddedMin &&\n newMax !== paddedMax &&\n type.match('y')) {\n chart.showResetZoom();\n axis.displayBtn = false;\n }\n doRedraw = true;\n }\n // set new reference for next run:\n nextMousePos[mouseDown] = mousePos;\n }\n });\n objectEach(nextMousePos, function (pos, down) {\n chart[down] = pos;\n });\n if (doRedraw) {\n chart.redraw(false);\n }\n css(chart.container, { cursor: 'move' });\n });\n };\n return Chart;\n }());\n extend(Chart.prototype, {\n // Hook for adding callbacks in modules\n callbacks: [],\n /**\n * These collections (arrays) implement `Chart.addSomethig` method used in\n * chart.update() to create new object in the collection. Equivalent for\n * deleting is resolved by simple `Somethig.remove()`.\n *\n * Note: We need to define these references after initializers are bound to\n * chart's prototype.\n *\n * @private\n */\n collectionsWithInit: {\n // collectionName: [ initializingMethod, [extraArguments] ]\n xAxis: [Chart.prototype.addAxis, [true]],\n yAxis: [Chart.prototype.addAxis, [false]],\n series: [Chart.prototype.addSeries]\n },\n /**\n * These collections (arrays) implement update() methods with support for\n * one-to-one option.\n * @private\n */\n collectionsWithUpdate: [\n 'xAxis',\n 'yAxis',\n 'series'\n ],\n /**\n * These properties cause isDirtyBox to be set to true when updating. Can be\n * extended from plugins.\n * @private\n */\n propsRequireDirtyBox: [\n 'backgroundColor',\n 'borderColor',\n 'borderWidth',\n 'borderRadius',\n 'plotBackgroundColor',\n 'plotBackgroundImage',\n 'plotBorderColor',\n 'plotBorderWidth',\n 'plotShadow',\n 'shadow'\n ],\n /**\n * These properties require a full reflow of chart elements, best\n * implemented through running `Chart.setSize` internally (#8190).\n * @private\n */\n propsRequireReflow: [\n 'margin',\n 'marginTop',\n 'marginRight',\n 'marginBottom',\n 'marginLeft',\n 'spacing',\n 'spacingTop',\n 'spacingRight',\n 'spacingBottom',\n 'spacingLeft'\n ],\n /**\n * These properties cause all series to be updated when updating. Can be\n * extended from plugins.\n * @private\n */\n propsRequireUpdateSeries: [\n 'chart.inverted',\n 'chart.polar',\n 'chart.ignoreHiddenSeries',\n 'chart.type',\n 'colors',\n 'plotOptions',\n 'time',\n 'tooltip'\n ]\n });\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Callback for chart constructors.\n *\n * @callback Highcharts.ChartCallbackFunction\n *\n * @param {Highcharts.Chart} chart\n * Created chart.\n */\n /**\n * Format a number and return a string based on input settings.\n *\n * @callback Highcharts.NumberFormatterCallbackFunction\n *\n * @param {number} number\n * The input number to format.\n *\n * @param {number} decimals\n * The amount of decimals. A value of -1 preserves the amount in the\n * input number.\n *\n * @param {string} [decimalPoint]\n * The decimal point, defaults to the one given in the lang options, or\n * a dot.\n *\n * @param {string} [thousandsSep]\n * The thousands separator, defaults to the one given in the lang\n * options, or a space character.\n *\n * @return {string} The formatted number.\n */\n /**\n * The chart title. The title has an `update` method that allows modifying the\n * options directly or indirectly via `chart.update`.\n *\n * @interface Highcharts.TitleObject\n * @extends Highcharts.SVGElement\n */ /**\n * Modify options for the title.\n *\n * @function Highcharts.TitleObject#update\n *\n * @param {Highcharts.TitleOptions} titleOptions\n * Options to modify.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the title is altered. If doing more\n * operations on the chart, it is a good idea to set redraw to false and\n * call {@link Chart#redraw} after.\n */\n /**\n * The chart subtitle. The subtitle has an `update` method that\n * allows modifying the options directly or indirectly via\n * `chart.update`.\n *\n * @interface Highcharts.SubtitleObject\n * @extends Highcharts.SVGElement\n */ /**\n * Modify options for the subtitle.\n *\n * @function Highcharts.SubtitleObject#update\n *\n * @param {Highcharts.SubtitleOptions} subtitleOptions\n * Options to modify.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the subtitle is altered. If doing\n * more operations on the chart, it is a good idea to set redraw to false\n * and call {@link Chart#redraw} after.\n */\n /**\n * The chart caption. The caption has an `update` method that\n * allows modifying the options directly or indirectly via\n * `chart.update`.\n *\n * @interface Highcharts.CaptionObject\n * @extends Highcharts.SVGElement\n */ /**\n * Modify options for the caption.\n *\n * @function Highcharts.CaptionObject#update\n *\n * @param {Highcharts.CaptionOptions} captionOptions\n * Options to modify.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the caption is altered. If doing\n * more operations on the chart, it is a good idea to set redraw to false\n * and call {@link Chart#redraw} after.\n */\n /**\n * @interface Highcharts.ChartIsInsideOptionsObject\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#axis\n * @type {Highcharts.Axis|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#ignoreX\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#ignoreY\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#inverted\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#paneCoordinates\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#series\n * @type {Highcharts.Series|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#visiblePlotOnly\n * @type {boolean|undefined}\n */\n ''; // keeps doclets above in JS file\n\n return Chart;\n });\n _registerModule(_modules, 'Core/Legend/LegendSymbol.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var merge = U.merge,\n pick = U.pick;\n /* *\n *\n * Namespace\n *\n * */\n var LegendSymbol;\n (function (LegendSymbol) {\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Get the series' symbol in the legend.\n *\n * This method should be overridable to create custom symbols through\n * Highcharts.seriesTypes[type].prototype.drawLegendSymbol.\n *\n * @private\n * @function Highcharts.LegendSymbolMixin.drawLineMarker\n *\n * @param {Highcharts.Legend} legend\n * The legend object.\n */\n function drawLineMarker(legend) {\n var legendItem = this.legendItem = this.legendItem || {},\n options = this.options,\n symbolWidth = legend.symbolWidth,\n symbolHeight = legend.symbolHeight,\n generalRadius = symbolHeight / 2,\n renderer = this.chart.renderer,\n legendItemGroup = legendItem.group,\n verticalCenter = legend.baseline -\n Math.round(legend.fontMetrics.b * 0.3);\n var attr = {},\n legendSymbol,\n markerOptions = options.marker;\n // Draw the line\n if (!this.chart.styledMode) {\n attr = {\n 'stroke-width': options.lineWidth || 0\n };\n if (options.dashStyle) {\n attr.dashstyle = options.dashStyle;\n }\n }\n legendItem.line = renderer\n .path([\n ['M', 0, verticalCenter],\n ['L', symbolWidth, verticalCenter]\n ])\n .addClass('highcharts-graph')\n .attr(attr)\n .add(legendItemGroup);\n // Draw the marker\n if (markerOptions && markerOptions.enabled !== false && symbolWidth) {\n // Do not allow the marker to be larger than the symbolHeight\n var radius = Math.min(pick(markerOptions.radius,\n generalRadius),\n generalRadius);\n // Restrict symbol markers size\n if (this.symbol.indexOf('url') === 0) {\n markerOptions = merge(markerOptions, {\n width: symbolHeight,\n height: symbolHeight\n });\n radius = 0;\n }\n legendItem.symbol = legendSymbol = renderer\n .symbol(this.symbol, (symbolWidth / 2) - radius, verticalCenter - radius, 2 * radius, 2 * radius, markerOptions)\n .addClass('highcharts-point')\n .add(legendItemGroup);\n legendSymbol.isMarker = true;\n }\n }\n LegendSymbol.drawLineMarker = drawLineMarker;\n /**\n * Get the series' symbol in the legend.\n *\n * This method should be overridable to create custom symbols through\n * Highcharts.seriesTypes[type].prototype.drawLegendSymbol.\n *\n * @private\n * @function Highcharts.LegendSymbolMixin.drawRectangle\n *\n * @param {Highcharts.Legend} legend\n * The legend object\n *\n * @param {Highcharts.Point|Highcharts.Series} item\n * The series (this) or point\n */\n function drawRectangle(legend, item) {\n var legendItem = item.legendItem || {},\n options = legend.options,\n symbolHeight = legend.symbolHeight,\n square = options.squareSymbol,\n symbolWidth = square ? symbolHeight : legend.symbolWidth;\n legendItem.symbol = this.chart.renderer\n .rect(square ? (legend.symbolWidth - symbolHeight) / 2 : 0, legend.baseline - symbolHeight + 1, // #3988\n symbolWidth, symbolHeight, pick(legend.options.symbolRadius, symbolHeight / 2))\n .addClass('highcharts-point')\n .attr({\n zIndex: 3\n })\n .add(legendItem.group);\n }\n LegendSymbol.drawRectangle = drawRectangle;\n })(LegendSymbol || (LegendSymbol = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return LegendSymbol;\n });\n _registerModule(_modules, 'Core/Series/SeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * General options for all series types.\n *\n * @optionparent plotOptions.series\n */\n var seriesDefaults = {\n // base series options\n /**\n * The SVG value used for the `stroke-linecap` and `stroke-linejoin`\n * of a line graph. Round means that lines are rounded in the ends and\n * bends.\n *\n * @type {Highcharts.SeriesLinecapValue}\n * @default round\n * @since 3.0.7\n * @apioption plotOptions.line.linecap\n */\n /**\n * Pixel width of the graph line.\n *\n * @see In styled mode, the line stroke-width can be set with the\n * `.highcharts-graph` class name.\n *\n * @sample {highcharts} highcharts/plotoptions/series-linewidth-general/\n * On all series\n * @sample {highcharts} highcharts/plotoptions/series-linewidth-specific/\n * On one single series\n *\n * @product highcharts highstock\n *\n * @private\n */\n lineWidth: 2,\n /**\n * For some series, there is a limit that shuts down animation\n * by default when the total number of points in the chart is too high.\n * For example, for a column chart and its derivatives, animation does\n * not run if there is more than 250 points totally. To disable this\n * cap, set `animationLimit` to `Infinity`. This option works if animation\n * is fired on individual points, not on a group of points like e.g. during\n * the initial animation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-animationlimit/\n * Animation limit on updating individual points\n *\n * @type {number}\n * @apioption plotOptions.series.animationLimit\n */\n /**\n * Allow this series' points to be selected by clicking on the graphic\n * (columns, point markers, pie slices, map areas etc).\n *\n * The selected points can be handled by point select and unselect\n * events, or collectively by the [getSelectedPoints\n * ](/class-reference/Highcharts.Chart#getSelectedPoints) function.\n *\n * And alternative way of selecting points is through dragging.\n *\n * @sample {highcharts} highcharts/plotoptions/series-allowpointselect-line/\n * Line\n * @sample {highcharts} highcharts/plotoptions/series-allowpointselect-column/\n * Column\n * @sample {highcharts} highcharts/plotoptions/series-allowpointselect-pie/\n * Pie\n * @sample {highcharts} highcharts/chart/events-selection-points/\n * Select a range of points through a drag selection\n * @sample {highmaps} maps/plotoptions/series-allowpointselect/\n * Map area\n * @sample {highmaps} maps/plotoptions/mapbubble-allowpointselect/\n * Map bubble\n *\n * @since 1.2.0\n *\n * @private\n */\n allowPointSelect: false,\n /**\n * When true, each point or column edge is rounded to its nearest pixel\n * in order to render sharp on screen. In some cases, when there are a\n * lot of densely packed columns, this leads to visible difference\n * in column widths or distance between columns. In these cases,\n * setting `crisp` to `false` may look better, even though each column\n * is rendered blurry.\n *\n * @sample {highcharts} highcharts/plotoptions/column-crisp-false/\n * Crisp is false\n *\n * @since 5.0.10\n * @product highcharts highstock gantt\n *\n * @private\n */\n crisp: true,\n /**\n * If true, a checkbox is displayed next to the legend item to allow\n * selecting the series. The state of the checkbox is determined by\n * the `selected` option.\n *\n * @productdesc {highmaps}\n * Note that if a `colorAxis` is defined, the color axis is represented\n * in the legend, not the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-showcheckbox-true/\n * Show select box\n *\n * @since 1.2.0\n *\n * @private\n */\n showCheckbox: false,\n /**\n * Enable or disable the initial animation when a series is displayed.\n * The animation can also be set as a configuration object. Please\n * note that this option only applies to the initial animation of the\n * series itself. For other animations, see [chart.animation](\n * #chart.animation) and the animation parameter under the API methods.\n * The following properties are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * - `duration`: The duration of the animation in milliseconds. (Defaults to\n * `1000`)\n *\n * - `easing`: Can be a string reference to an easing function set on\n * the `Math` object or a function. See the _Custom easing function_\n * demo below. (Defaults to `easeInOutSine`)\n *\n * Due to poor performance, animation is disabled in old IE browsers\n * for several chart types.\n *\n * @sample {highcharts} highcharts/plotoptions/series-animation-disabled/\n * Animation disabled\n * @sample {highcharts} highcharts/plotoptions/series-animation-slower/\n * Slower animation\n * @sample {highcharts} highcharts/plotoptions/series-animation-easing/\n * Custom easing function\n * @sample {highstock} stock/plotoptions/animation-slower/\n * Slower animation\n * @sample {highstock} stock/plotoptions/animation-easing/\n * Custom easing function\n * @sample {highmaps} maps/plotoptions/series-animation-true/\n * Animation enabled on map series\n * @sample {highmaps} maps/plotoptions/mapbubble-animation-false/\n * Disabled on mapbubble series\n *\n * @type {boolean|Highcharts.AnimationOptionsObject}\n * @default {highcharts} true\n * @default {highstock} true\n * @default {highmaps} false\n *\n * @private\n */\n animation: {\n /** @ignore-option */\n duration: 1000\n },\n /**\n * An additional class name to apply to the series' graphical elements.\n * This option does not replace default class names of the graphical\n * element.\n *\n * @type {string}\n * @since 5.0.0\n * @apioption plotOptions.series.className\n */\n /**\n * Disable this option to allow series rendering in the whole plotting\n * area.\n *\n * **Note:** Clipping should be always enabled when\n * [chart.zoomType](#chart.zoomType) is set\n *\n * @sample {highcharts} highcharts/plotoptions/series-clip/\n * Disabled clipping\n *\n * @default true\n * @type {boolean}\n * @since 3.0.0\n * @apioption plotOptions.series.clip\n */\n /**\n * The main color of the series. In line type series it applies to the\n * line and the point markers unless otherwise specified. In bar type\n * series it applies to the bars unless a color is specified per point.\n * The default value is pulled from the `options.colors` array.\n *\n * In styled mode, the color can be defined by the\n * [colorIndex](#plotOptions.series.colorIndex) option. Also, the series\n * color can be set with the `.highcharts-series`,\n * `.highcharts-color-{n}`, `.highcharts-{type}-series` or\n * `.highcharts-series-{n}` class, or individual classes given by the\n * `className` option.\n *\n * @productdesc {highmaps}\n * In maps, the series color is rarely used, as most choropleth maps use\n * the color to denote the value of each point. The series color can\n * however be used in a map with multiple series holding categorized\n * data.\n *\n * @sample {highcharts} highcharts/plotoptions/series-color-general/\n * General plot option\n * @sample {highcharts} highcharts/plotoptions/series-color-specific/\n * One specific series\n * @sample {highcharts} highcharts/plotoptions/series-color-area/\n * Area color\n * @sample {highcharts} highcharts/series/infographic/\n * Pattern fill\n * @sample {highmaps} maps/demo/category-map/\n * Category map by multiple series\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption plotOptions.series.color\n */\n /**\n * Styled mode only. A specific color index to use for the series, so its\n * graphic representations are given the class name `highcharts-color-{n}`.\n *\n * @sample {highcharts} highcharts/css/colorindex/\n * Series and point color index\n *\n * @type {number}\n * @since 5.0.0\n * @apioption plotOptions.series.colorIndex\n */\n /**\n * Whether to connect a graph line across null points, or render a gap\n * between the two points on either side of the null.\n *\n * @sample {highcharts} highcharts/plotoptions/series-connectnulls-false/\n * False by default\n * @sample {highcharts} highcharts/plotoptions/series-connectnulls-true/\n * True\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock\n * @apioption plotOptions.series.connectNulls\n */\n /**\n * You can set the cursor to \"pointer\" if you have click events attached\n * to the series, to signal to the user that the points and lines can\n * be clicked.\n *\n * In styled mode, the series cursor can be set with the same classes\n * as listed under [series.color](#plotOptions.series.color).\n *\n * @sample {highcharts} highcharts/plotoptions/series-cursor-line/\n * On line graph\n * @sample {highcharts} highcharts/plotoptions/series-cursor-column/\n * On columns\n * @sample {highcharts} highcharts/plotoptions/series-cursor-scatter/\n * On scatter markers\n * @sample {highstock} stock/plotoptions/cursor/\n * Pointer on a line graph\n * @sample {highmaps} maps/plotoptions/series-allowpointselect/\n * Map area\n * @sample {highmaps} maps/plotoptions/mapbubble-allowpointselect/\n * Map bubble\n *\n * @type {string|Highcharts.CursorValue}\n * @apioption plotOptions.series.cursor\n */\n /**\n * A reserved subspace to store options and values for customized\n * functionality. Here you can add additional data for your own event\n * callbacks and formatter callbacks.\n *\n * @sample {highcharts} highcharts/point/custom/\n * Point and series with custom data\n *\n * @type {Highcharts.Dictionary<*>}\n * @apioption plotOptions.series.custom\n */\n /**\n * Name of the dash style to use for the graph, or for some series types\n * the outline of each shape.\n *\n * In styled mode, the\n * [stroke dash-array](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/css/series-dashstyle/)\n * can be set with the same classes as listed under\n * [series.color](#plotOptions.series.color).\n *\n * @sample {highcharts} highcharts/plotoptions/series-dashstyle-all/\n * Possible values demonstrated\n * @sample {highcharts} highcharts/plotoptions/series-dashstyle/\n * Chart suitable for printing in black and white\n * @sample {highstock} highcharts/plotoptions/series-dashstyle-all/\n * Possible values demonstrated\n * @sample {highmaps} highcharts/plotoptions/series-dashstyle-all/\n * Possible values demonstrated\n * @sample {highmaps} maps/plotoptions/series-dashstyle/\n * Dotted borders on a map\n *\n * @type {Highcharts.DashStyleValue}\n * @default Solid\n * @since 2.1\n * @apioption plotOptions.series.dashStyle\n */\n /**\n * A description of the series to add to the screen reader information\n * about the series.\n *\n * @type {string}\n * @since 5.0.0\n * @requires modules/accessibility\n * @apioption plotOptions.series.description\n */\n /**\n * Options for the series data sorting.\n *\n * @type {Highcharts.DataSortingOptionsObject}\n * @since 8.0.0\n * @product highcharts highstock\n * @apioption plotOptions.series.dataSorting\n */\n /**\n * Enable or disable data sorting for the series. Use [xAxis.reversed](\n * #xAxis.reversed) to change the sorting order.\n *\n * @sample {highcharts} highcharts/datasorting/animation/\n * Data sorting in scatter-3d\n * @sample {highcharts} highcharts/datasorting/labels-animation/\n * Axis labels animation\n * @sample {highcharts} highcharts/datasorting/dependent-sorting/\n * Dependent series sorting\n * @sample {highcharts} highcharts/datasorting/independent-sorting/\n * Independent series sorting\n *\n * @type {boolean}\n * @since 8.0.0\n * @apioption plotOptions.series.dataSorting.enabled\n */\n /**\n * Whether to allow matching points by name in an update. If this option\n * is disabled, points will be matched by order.\n *\n * @sample {highcharts} highcharts/datasorting/match-by-name/\n * Enabled match by name\n *\n * @type {boolean}\n * @since 8.0.0\n * @apioption plotOptions.series.dataSorting.matchByName\n */\n /**\n * Determines what data value should be used to sort by.\n *\n * @sample {highcharts} highcharts/datasorting/sort-key/\n * Sort key as `z` value\n *\n * @type {string}\n * @since 8.0.0\n * @default y\n * @apioption plotOptions.series.dataSorting.sortKey\n */\n /**\n * Enable or disable the mouse tracking for a specific series. This\n * includes point tooltips and click events on graphs and points. For\n * large datasets it improves performance.\n *\n * @sample {highcharts} highcharts/plotoptions/series-enablemousetracking-false/\n * No mouse tracking\n * @sample {highmaps} maps/plotoptions/series-enablemousetracking-false/\n * No mouse tracking\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.enableMouseTracking\n */\n /**\n * Whether to use the Y extremes of the total chart width or only the\n * zoomed area when zooming in on parts of the X axis. By default, the\n * Y axis adjusts to the min and max of the visible data. Cartesian\n * series only.\n *\n * @type {boolean}\n * @default false\n * @since 4.1.6\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.getExtremesFromAll\n */\n /**\n * An array specifying which option maps to which key in the data point\n * array. This makes it convenient to work with unstructured data arrays\n * from different sources.\n *\n * @see [series.data](#series.line.data)\n *\n * @sample {highcharts|highstock} highcharts/series/data-keys/\n * An extended data array with keys\n * @sample {highcharts|highstock} highcharts/series/data-nested-keys/\n * Nested keys used to access object properties\n *\n * @type {Array}\n * @since 4.1.6\n * @apioption plotOptions.series.keys\n */\n /**\n * The line cap used for line ends and line joins on the graph.\n *\n * @sample highcharts/series-line/linecap/\n * Line cap comparison\n *\n * @type {Highcharts.SeriesLinecapValue}\n * @default round\n * @product highcharts highstock\n * @apioption plotOptions.series.linecap\n */\n /**\n * The [id](#series.id) of another series to link to. Additionally,\n * the value can be \":previous\" to link to the previous series. When\n * two series are linked, only the first one appears in the legend.\n * Toggling the visibility of this also toggles the linked series.\n *\n * If master series uses data sorting and linked series does not have\n * its own sorting definition, the linked series will be sorted in the\n * same order as the master one.\n *\n * @sample {highcharts|highstock} highcharts/demo/arearange-line/\n * Linked series\n *\n * @type {string}\n * @since 3.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.linkedTo\n */\n /**\n * Options for the corresponding navigator series if `showInNavigator`\n * is `true` for this series. Available options are the same as any\n * series, documented at [plotOptions](#plotOptions.series) and\n * [series](#series).\n *\n * These options are merged with options in [navigator.series](\n * #navigator.series), and will take precedence if the same option is\n * defined both places.\n *\n * @see [navigator.series](#navigator.series)\n *\n * @type {Highcharts.PlotSeriesOptions}\n * @since 5.0.0\n * @product highstock\n * @apioption plotOptions.series.navigatorOptions\n */\n /**\n * The color for the parts of the graph or points that are below the\n * [threshold](#plotOptions.series.threshold). Note that `zones` takes\n * precedence over the negative color. Using `negativeColor` is\n * equivalent to applying a zone with value of 0.\n *\n * @see In styled mode, a negative color is applied by setting this option\n * to `true` combined with the `.highcharts-negative` class name.\n *\n * @sample {highcharts} highcharts/plotoptions/series-negative-color/\n * Spline, area and column\n * @sample {highcharts} highcharts/plotoptions/arearange-negativecolor/\n * Arearange\n * @sample {highcharts} highcharts/css/series-negative-color/\n * Styled mode\n * @sample {highstock} highcharts/plotoptions/series-negative-color/\n * Spline, area and column\n * @sample {highstock} highcharts/plotoptions/arearange-negativecolor/\n * Arearange\n * @sample {highmaps} highcharts/plotoptions/series-negative-color/\n * Spline, area and column\n * @sample {highmaps} highcharts/plotoptions/arearange-negativecolor/\n * Arearange\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 3.0\n * @apioption plotOptions.series.negativeColor\n */\n /**\n * Same as\n * [accessibility.series.descriptionFormatter](#accessibility.series.descriptionFormatter),\n * but for an individual series. Overrides the chart wide configuration.\n *\n * @type {Function}\n * @since 5.0.12\n * @apioption plotOptions.series.pointDescriptionFormatter\n */\n /**\n * If no x values are given for the points in a series, `pointInterval`\n * defines the interval of the x values. For example, if a series\n * contains one value every decade starting from year 0, set\n * `pointInterval` to `10`. In true `datetime` axes, the `pointInterval`\n * is set in milliseconds.\n *\n * It can be also be combined with `pointIntervalUnit` to draw irregular\n * time intervals.\n *\n * If combined with `relativeXValue`, an x value can be set on each\n * point, and the `pointInterval` is added x times to the `pointStart`\n * setting.\n *\n * Please note that this options applies to the _series data_, not the\n * interval of the axis ticks, which is independent.\n *\n * @sample {highcharts} highcharts/plotoptions/series-pointstart-datetime/\n * Datetime X axis\n * @sample {highcharts} highcharts/plotoptions/series-relativexvalue/\n * Relative x value\n * @sample {highstock} stock/plotoptions/pointinterval-pointstart/\n * Using pointStart and pointInterval\n * @sample {highstock} stock/plotoptions/relativexvalue/\n * Relative x value\n *\n * @type {number}\n * @default 1\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.pointInterval\n */\n /**\n * On datetime series, this allows for setting the\n * [pointInterval](#plotOptions.series.pointInterval) to irregular time\n * units, `day`, `month` and `year`. A day is usually the same as 24\n * hours, but `pointIntervalUnit` also takes the DST crossover into\n * consideration when dealing with local time. Combine this option with\n * `pointInterval` to draw weeks, quarters, 6 months, 10 years etc.\n *\n * Please note that this options applies to the _series data_, not the\n * interval of the axis ticks, which is independent.\n *\n * @sample {highcharts} highcharts/plotoptions/series-pointintervalunit/\n * One point a month\n * @sample {highstock} highcharts/plotoptions/series-pointintervalunit/\n * One point a month\n *\n * @type {string}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @validvalue [\"day\", \"month\", \"year\"]\n * @apioption plotOptions.series.pointIntervalUnit\n */\n /**\n * Possible values: `\"on\"`, `\"between\"`, `number`.\n *\n * In a column chart, when pointPlacement is `\"on\"`, the point will not\n * create any padding of the X axis. In a polar column chart this means\n * that the first column points directly north. If the pointPlacement is\n * `\"between\"`, the columns will be laid out between ticks. This is\n * useful for example for visualising an amount between two points in\n * time or in a certain sector of a polar chart.\n *\n * Since Highcharts 3.0.2, the point placement can also be numeric,\n * where 0 is on the axis value, -0.5 is between this value and the\n * previous, and 0.5 is between this value and the next. Unlike the\n * textual options, numeric point placement options won't affect axis\n * padding.\n *\n * Note that pointPlacement needs a [pointRange](\n * #plotOptions.series.pointRange) to work. For column series this is\n * computed, but for line-type series it needs to be set.\n *\n * For the `xrange` series type and gantt charts, if the Y axis is a\n * category axis, the `pointPlacement` applies to the Y axis rather than\n * the (typically datetime) X axis.\n *\n * Defaults to `undefined` in cartesian charts, `\"between\"` in polar\n * charts.\n *\n * @see [xAxis.tickmarkPlacement](#xAxis.tickmarkPlacement)\n *\n * @sample {highcharts|highstock} highcharts/plotoptions/series-pointplacement-between/\n * Between in a column chart\n * @sample {highcharts|highstock} highcharts/plotoptions/series-pointplacement-numeric/\n * Numeric placement for custom layout\n * @sample {highcharts|highstock} maps/plotoptions/heatmap-pointplacement/\n * Placement in heatmap\n *\n * @type {string|number}\n * @since 2.3.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.pointPlacement\n */\n /**\n * If no x values are given for the points in a series, pointStart\n * defines on what value to start. For example, if a series contains one\n * yearly value starting from 1945, set pointStart to 1945.\n *\n * If combined with `relativeXValue`, an x value can be set on each\n * point. The x value from the point options is multiplied by\n * `pointInterval` and added to `pointStart` to produce a modified x\n * value.\n *\n * @sample {highcharts} highcharts/plotoptions/series-pointstart-linear/\n * Linear\n * @sample {highcharts} highcharts/plotoptions/series-pointstart-datetime/\n * Datetime\n * @sample {highcharts} highcharts/plotoptions/series-relativexvalue/\n * Relative x value\n * @sample {highstock} stock/plotoptions/pointinterval-pointstart/\n * Using pointStart and pointInterval\n * @sample {highstock} stock/plotoptions/relativexvalue/\n * Relative x value\n *\n * @type {number}\n * @default 0\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.pointStart\n */\n /**\n * When true, X values in the data set are relative to the current\n * `pointStart`, `pointInterval` and `pointIntervalUnit` settings. This\n * allows compression of the data for datasets with irregular X values.\n *\n * The real X values are computed on the formula `f(x) = ax + b`, where\n * `a` is the `pointInterval` (optionally with a time unit given by\n * `pointIntervalUnit`), and `b` is the `pointStart`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-relativexvalue/\n * Relative X value\n * @sample {highstock} stock/plotoptions/relativexvalue/\n * Relative X value\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock\n * @apioption plotOptions.series.relativeXValue\n */\n /**\n * Whether to select the series initially. If `showCheckbox` is true,\n * the checkbox next to the series name in the legend will be checked\n * for a selected series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-selected/\n * One out of two series selected\n *\n * @type {boolean}\n * @default false\n * @since 1.2.0\n * @apioption plotOptions.series.selected\n */\n /**\n * Whether to apply a drop shadow to the graph line. Since 2.3 the\n * shadow can be an object configuration containing `color`, `offsetX`,\n * `offsetY`, `opacity` and `width`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-shadow/\n * Shadow enabled\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n * @default false\n * @apioption plotOptions.series.shadow\n */\n /**\n * Whether to display this particular series or series type in the\n * legend. Standalone series are shown in legend by default, and linked\n * series are not. Since v7.2.0 it is possible to show series that use\n * colorAxis by setting this option to `true`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-showinlegend/\n * One series in the legend, one hidden\n *\n * @type {boolean}\n * @apioption plotOptions.series.showInLegend\n */\n /**\n * Whether or not to show the series in the navigator. Takes precedence\n * over [navigator.baseSeries](#navigator.baseSeries) if defined.\n *\n * @type {boolean}\n * @since 5.0.0\n * @product highstock\n * @apioption plotOptions.series.showInNavigator\n */\n /**\n * If set to `true`, the accessibility module will skip past the points\n * in this series for keyboard navigation.\n *\n * @type {boolean}\n * @since 5.0.12\n * @apioption plotOptions.series.skipKeyboardNavigation\n */\n /**\n * Whether to stack the values of each series on top of each other.\n * Possible values are `undefined` to disable, `\"normal\"` to stack by\n * value or `\"percent\"`.\n *\n * When stacking is enabled, data must be sorted\n * in ascending X order.\n *\n * Some stacking options are related to specific series types. In the\n * streamgraph series type, the stacking option is set to `\"stream\"`.\n * The second one is `\"overlap\"`, which only applies to waterfall\n * series.\n *\n * @see [yAxis.reversedStacks](#yAxis.reversedStacks)\n *\n * @sample {highcharts} highcharts/plotoptions/series-stacking-line/\n * Line\n * @sample {highcharts} highcharts/plotoptions/series-stacking-column/\n * Column\n * @sample {highcharts} highcharts/plotoptions/series-stacking-bar/\n * Bar\n * @sample {highcharts} highcharts/plotoptions/series-stacking-area/\n * Area\n * @sample {highcharts} highcharts/plotoptions/series-stacking-percent-line/\n * Line\n * @sample {highcharts} highcharts/plotoptions/series-stacking-percent-column/\n * Column\n * @sample {highcharts} highcharts/plotoptions/series-stacking-percent-bar/\n * Bar\n * @sample {highcharts} highcharts/plotoptions/series-stacking-percent-area/\n * Area\n * @sample {highcharts} highcharts/plotoptions/series-waterfall-with-normal-stacking\n * Waterfall with normal stacking\n * @sample {highcharts} highcharts/plotoptions/series-waterfall-with-overlap-stacking\n * Waterfall with overlap stacking\n * @sample {highstock} stock/plotoptions/stacking/\n * Area\n *\n * @type {string}\n * @product highcharts highstock\n * @validvalue [\"normal\", \"overlap\", \"percent\", \"stream\"]\n * @apioption plotOptions.series.stacking\n */\n /**\n * Whether to apply steps to the line. Possible values are `left`,\n * `center` and `right`.\n *\n * @sample {highcharts} highcharts/plotoptions/line-step/\n * Different step line options\n * @sample {highcharts} highcharts/plotoptions/area-step/\n * Stepped, stacked area\n * @sample {highstock} stock/plotoptions/line-step/\n * Step line\n *\n * @type {string}\n * @since 1.2.5\n * @product highcharts highstock\n * @validvalue [\"left\", \"center\", \"right\"]\n * @apioption plotOptions.series.step\n */\n /**\n * The threshold, also called zero level or base level. For line type\n * series this is only used in conjunction with\n * [negativeColor](#plotOptions.series.negativeColor).\n *\n * @see [softThreshold](#plotOptions.series.softThreshold).\n *\n * @type {number|null}\n * @default 0\n * @since 3.0\n * @product highcharts highstock\n * @apioption plotOptions.series.threshold\n */\n /**\n * Set the initial visibility of the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-visible/\n * Two series, one hidden and one visible\n * @sample {highstock} stock/plotoptions/series-visibility/\n * Hidden series\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.visible\n */\n /**\n * Defines the Axis on which the zones are applied.\n *\n * @see [zones](#plotOptions.series.zones)\n *\n * @sample {highcharts} highcharts/series/color-zones-zoneaxis-x/\n * Zones on the X-Axis\n * @sample {highstock} highcharts/series/color-zones-zoneaxis-x/\n * Zones on the X-Axis\n *\n * @type {string}\n * @default y\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zoneAxis\n */\n /**\n * General event handlers for the series items. These event hooks can\n * also be attached to the series at run time using the\n * `Highcharts.addEvent` function.\n *\n * @declare Highcharts.SeriesEventsOptionsObject\n *\n * @private\n */\n events: {},\n /**\n * Fires after the series has finished its initial animation, or in case\n * animation is disabled, immediately as the series is displayed.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-afteranimate/\n * Show label after animate\n * @sample {highstock} highcharts/plotoptions/series-events-afteranimate/\n * Show label after animate\n *\n * @type {Highcharts.SeriesAfterAnimateCallbackFunction}\n * @since 4.0\n * @product highcharts highstock gantt\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.afterAnimate\n */\n /**\n * Fires when the checkbox next to the series' name in the legend is\n * clicked. One parameter, `event`, is passed to the function. The state\n * of the checkbox is found by `event.checked`. The checked item is\n * found by `event.item`. Return `false` to prevent the default action\n * which is to toggle the select state of the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-checkboxclick/\n * Alert checkbox status\n *\n * @type {Highcharts.SeriesCheckboxClickCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.checkboxClick\n */\n /**\n * Fires when the series is clicked. One parameter, `event`, is passed\n * to the function, containing common event information. Additionally,\n * `event.point` holds a pointer to the nearest point on the graph.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-click/\n * Alert click info\n * @sample {highstock} stock/plotoptions/series-events-click/\n * Alert click info\n * @sample {highmaps} maps/plotoptions/series-events-click/\n * Display click info in subtitle\n *\n * @type {Highcharts.SeriesClickCallbackFunction}\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.click\n */\n /**\n * Fires when the series is hidden after chart generation time, either\n * by clicking the legend item or by calling `.hide()`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-hide/\n * Alert when the series is hidden by clicking the legend item\n *\n * @type {Highcharts.SeriesHideCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.hide\n */\n /**\n * Fires when the legend item belonging to the series is clicked. One\n * parameter, `event`, is passed to the function. The default action\n * is to toggle the visibility of the series. This can be prevented\n * by returning `false` or calling `event.preventDefault()`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-legenditemclick/\n * Confirm hiding and showing\n *\n * @type {Highcharts.SeriesLegendItemClickCallbackFunction}\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.legendItemClick\n */\n /**\n * Fires when the mouse leaves the graph. One parameter, `event`, is\n * passed to the function, containing common event information. If the\n * [stickyTracking](#plotOptions.series) option is true, `mouseOut`\n * doesn't happen before the mouse enters another graph or leaves the\n * plot area.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-mouseover-sticky/\n * With sticky tracking by default\n * @sample {highcharts} highcharts/plotoptions/series-events-mouseover-no-sticky/\n * Without sticky tracking\n *\n * @type {Highcharts.SeriesMouseOutCallbackFunction}\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.mouseOut\n */\n /**\n * Fires when the mouse enters the graph. One parameter, `event`, is\n * passed to the function, containing common event information.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-mouseover-sticky/\n * With sticky tracking by default\n * @sample {highcharts} highcharts/plotoptions/series-events-mouseover-no-sticky/\n * Without sticky tracking\n *\n * @type {Highcharts.SeriesMouseOverCallbackFunction}\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.mouseOver\n */\n /**\n * Fires when the series is shown after chart generation time, either\n * by clicking the legend item or by calling `.show()`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-show/\n * Alert when the series is shown by clicking the legend item.\n *\n * @type {Highcharts.SeriesShowCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.show\n */\n /**\n * Options for the point markers of line-like series. Properties like\n * `fillColor`, `lineColor` and `lineWidth` define the visual appearance\n * of the markers. Other series types, like column series, don't have\n * markers, but have visual options on the series level instead.\n *\n * In styled mode, the markers can be styled with the\n * `.highcharts-point`, `.highcharts-point-hover` and\n * `.highcharts-point-select` class names.\n *\n * @declare Highcharts.PointMarkerOptionsObject\n *\n * @private\n */\n marker: {\n /**\n * Enable or disable the point marker. If `undefined`, the markers\n * are hidden when the data is dense, and shown for more widespread\n * data points.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-enabled/\n * Disabled markers\n * @sample {highcharts} highcharts/plotoptions/series-marker-enabled-false/\n * Disabled in normal state but enabled on hover\n * @sample {highstock} stock/plotoptions/series-marker/\n * Enabled markers\n *\n * @type {boolean}\n * @default {highcharts} undefined\n * @default {highstock} false\n * @apioption plotOptions.series.marker.enabled\n */\n /**\n * The threshold for how dense the point markers should be before\n * they are hidden, given that `enabled` is not defined. The number\n * indicates the horizontal distance between the two closest points\n * in the series, as multiples of the `marker.radius`. In other\n * words, the default value of 2 means points are hidden if\n * overlapping horizontally.\n *\n * @sample highcharts/plotoptions/series-marker-enabledthreshold\n * A higher threshold\n *\n * @since 6.0.5\n */\n enabledThreshold: 2,\n /**\n * The fill color of the point marker. When `undefined`, the series'\n * or point's color is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-fillcolor/\n * White fill\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption plotOptions.series.marker.fillColor\n */\n /**\n * Image markers only. Set the image width explicitly. When using\n * this option, a `width` must also be set.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-width-height/\n * Fixed width and height\n * @sample {highstock} highcharts/plotoptions/series-marker-width-height/\n * Fixed width and height\n *\n * @type {number}\n * @since 4.0.4\n * @apioption plotOptions.series.marker.height\n */\n /**\n * The color of the point marker's outline. When `undefined`, the\n * series' or point's color is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-fillcolor/\n * Inherit from series color (undefined)\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n lineColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The width of the point marker's outline.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-fillcolor/\n * 2px blue marker\n */\n lineWidth: 0,\n /**\n * The radius of the point marker.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-radius/\n * Bigger markers\n *\n * @default {highstock} 2\n * @default {highcharts} 4\n *\n */\n radius: 4,\n /**\n * A predefined shape or symbol for the marker. When undefined, the\n * symbol is pulled from options.symbols. Other possible values are\n * `'circle'`, `'square'`,`'diamond'`, `'triangle'` and\n * `'triangle-down'`.\n *\n * Additionally, the URL to a graphic can be given on this form:\n * `'url(graphic.png)'`. Note that for the image to be applied to\n * exported charts, its URL needs to be accessible by the export\n * server.\n *\n * Custom callbacks for symbol path generation can also be added to\n * `Highcharts.SVGRenderer.prototype.symbols`. The callback is then\n * used by its method name, as shown in the demo.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-symbol/\n * Predefined, graphic and custom markers\n * @sample {highstock} highcharts/plotoptions/series-marker-symbol/\n * Predefined, graphic and custom markers\n *\n * @type {string}\n * @apioption plotOptions.series.marker.symbol\n */\n /**\n * Image markers only. Set the image width explicitly. When using\n * this option, a `height` must also be set.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-width-height/\n * Fixed width and height\n * @sample {highstock} highcharts/plotoptions/series-marker-width-height/\n * Fixed width and height\n *\n * @type {number}\n * @since 4.0.4\n * @apioption plotOptions.series.marker.width\n */\n /**\n * States for a single point marker.\n *\n * @declare Highcharts.PointStatesOptionsObject\n */\n states: {\n /**\n * The normal state of a single point marker. Currently only\n * used for setting animation when returning to normal state\n * from hover.\n *\n * @declare Highcharts.PointStatesNormalOptionsObject\n */\n normal: {\n /**\n * Animation when returning to normal state after hovering.\n *\n * @type {boolean|Partial}\n */\n animation: true\n },\n /**\n * The hover state for a single point marker.\n *\n * @declare Highcharts.PointStatesHoverOptionsObject\n */\n hover: {\n /**\n * Animation when hovering over the marker.\n *\n * @type {boolean|Partial}\n */\n animation: {\n /** @internal */\n duration: 50\n },\n /**\n * Enable or disable the point marker.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-hover-enabled/\n * Disabled hover state\n */\n enabled: true,\n /**\n * The fill color of the marker in hover state. When\n * `undefined`, the series' or point's fillColor for normal\n * state is used.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption plotOptions.series.marker.states.hover.fillColor\n */\n /**\n * The color of the point marker's outline. When\n * `undefined`, the series' or point's lineColor for normal\n * state is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-hover-linecolor/\n * White fill color, black line color\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption plotOptions.series.marker.states.hover.lineColor\n */\n /**\n * The width of the point marker's outline. When\n * `undefined`, the series' or point's lineWidth for normal\n * state is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-hover-linewidth/\n * 3px line width\n *\n * @type {number}\n * @apioption plotOptions.series.marker.states.hover.lineWidth\n */\n /**\n * The radius of the point marker. In hover state, it\n * defaults to the normal state's radius + 2 as per the\n * [radiusPlus](#plotOptions.series.marker.states.hover.radiusPlus)\n * option.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-hover-radius/\n * 10px radius\n *\n * @type {number}\n * @apioption plotOptions.series.marker.states.hover.radius\n */\n /**\n * The number of pixels to increase the radius of the\n * hovered point.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 5 pixels greater radius on hover\n * @sample {highstock} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 5 pixels greater radius on hover\n *\n * @since 4.0.3\n */\n radiusPlus: 2,\n /**\n * The additional line width for a hovered point.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 2 pixels wider on hover\n * @sample {highstock} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 2 pixels wider on hover\n *\n * @since 4.0.3\n */\n lineWidthPlus: 1\n },\n /**\n * The appearance of the point marker when selected. In order to\n * allow a point to be selected, set the\n * `series.allowPointSelect` option to true.\n *\n * @declare Highcharts.PointStatesSelectOptionsObject\n */\n select: {\n /**\n * Enable or disable visible feedback for selection.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-enabled/\n * Disabled select state\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.marker.states.select.enabled\n */\n /**\n * The radius of the point marker. In hover state, it\n * defaults to the normal state's radius + 2.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-radius/\n * 10px radius for selected points\n *\n * @type {number}\n * @apioption plotOptions.series.marker.states.select.radius\n */\n /**\n * The fill color of the point marker.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-fillcolor/\n * Solid red discs for selected points\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n fillColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * The color of the point marker's outline. When\n * `undefined`, the series' or point's color is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-linecolor/\n * Red line color for selected points\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n lineColor: \"#000000\" /* Palette.neutralColor100 */,\n /**\n * The width of the point marker's outline.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-linewidth/\n * 3px line width for selected points\n */\n lineWidth: 2\n }\n }\n },\n /**\n * Properties for each single point.\n *\n * @declare Highcharts.PlotSeriesPointOptions\n *\n * @private\n */\n point: {\n /**\n * Fires when a point is clicked. One parameter, `event`, is passed\n * to the function, containing common event information.\n *\n * If the `series.allowPointSelect` option is true, the default\n * action for the point's click event is to toggle the point's\n * select state. Returning `false` cancels this action.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-click/\n * Click marker to alert values\n * @sample {highcharts} highcharts/plotoptions/series-point-events-click-column/\n * Click column\n * @sample {highcharts} highcharts/plotoptions/series-point-events-click-url/\n * Go to URL\n * @sample {highmaps} maps/plotoptions/series-point-events-click/\n * Click marker to display values\n * @sample {highmaps} maps/plotoptions/series-point-events-click-url/\n * Go to URL\n *\n * @type {Highcharts.PointClickCallbackFunction}\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.click\n */\n /**\n * Fires when the mouse leaves the area close to the point. One\n * parameter, `event`, is passed to the function, containing common\n * event information.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-mouseover/\n * Show values in the chart's corner on mouse over\n *\n * @type {Highcharts.PointMouseOutCallbackFunction}\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.mouseOut\n */\n /**\n * Fires when the mouse enters the area close to the point. One\n * parameter, `event`, is passed to the function, containing common\n * event information.\n *\n * Returning `false` cancels the default behavior, which is to show a\n * tooltip for the point.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-mouseover/\n * Show values in the chart's corner on mouse over\n *\n * @type {Highcharts.PointMouseOverCallbackFunction}\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.mouseOver\n */\n /**\n * Fires when the point is removed using the `.remove()` method. One\n * parameter, `event`, is passed to the function. Returning `false`\n * cancels the operation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-remove/\n * Remove point and confirm\n *\n * @type {Highcharts.PointRemoveCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.remove\n */\n /**\n * Fires when the point is selected either programmatically or\n * following a click on the point. One parameter, `event`, is passed\n * to the function. Returning `false` cancels the operation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-select/\n * Report the last selected point\n * @sample {highmaps} maps/plotoptions/series-allowpointselect/\n * Report select and unselect\n *\n * @type {Highcharts.PointSelectCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.select\n */\n /**\n * Fires when the point is unselected either programmatically or\n * following a click on the point. One parameter, `event`, is passed\n * to the function.\n * Returning `false` cancels the operation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-unselect/\n * Report the last unselected point\n * @sample {highmaps} maps/plotoptions/series-allowpointselect/\n * Report select and unselect\n *\n * @type {Highcharts.PointUnselectCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.unselect\n */\n /**\n * Fires when the point is updated programmatically through the\n * `.update()` method. One parameter, `event`, is passed to the\n * function. The new point options can be accessed through\n * `event.options`. Returning `false` cancels the operation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-update/\n * Confirm point updating\n *\n * @type {Highcharts.PointUpdateCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.update\n */\n /**\n * Events for each single point.\n *\n * @declare Highcharts.PointEventsOptionsObject\n */\n events: {}\n },\n /**\n * Options for the series data labels, appearing next to each data\n * point.\n *\n * Since v6.2.0, multiple data labels can be applied to each single\n * point by defining them as an array of configs.\n *\n * In styled mode, the data labels can be styled with the\n * `.highcharts-data-label-box` and `.highcharts-data-label` class names\n * ([see example](https://www.highcharts.com/samples/highcharts/css/series-datalabels)).\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-enabled\n * Data labels enabled\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-multiple\n * Multiple data labels on a bar series\n * @sample {highcharts} highcharts/css/series-datalabels\n * Style mode example\n *\n * @type {*|Array<*>}\n * @product highcharts highstock highmaps gantt\n *\n * @private\n */\n dataLabels: {\n /**\n * Enable or disable the initial animation when a series is\n * displayed for the `dataLabels`. The animation can also be set as\n * a configuration object. Please note that this option only\n * applies to the initial animation.\n * For other animations, see [chart.animation](#chart.animation)\n * and the animation parameter under the API methods.\n * The following properties are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * @sample {highcharts} highcharts/plotoptions/animation-defer/\n * Animation defer settings\n *\n * @type {boolean|Partial}\n * @since 8.2.0\n * @apioption plotOptions.series.dataLabels.animation\n */\n animation: {},\n /**\n * The animation delay time in milliseconds.\n * Set to `0` renders dataLabel immediately.\n * As `undefined` inherits defer time from the [series.animation.defer](#plotOptions.series.animation.defer).\n *\n * @type {number}\n * @since 8.2.0\n * @apioption plotOptions.series.dataLabels.animation.defer\n */\n /**\n * The alignment of the data label compared to the point. If\n * `right`, the right side of the label should be touching the\n * point. For points with an extent, like columns, the alignments\n * also dictates how to align it inside the box, as given with the\n * [inside](#plotOptions.column.dataLabels.inside)\n * option. Can be one of `left`, `center` or `right`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-align-left/\n * Left aligned\n * @sample {highcharts} highcharts/plotoptions/bar-datalabels-align-inside-bar/\n * Data labels inside the bar\n *\n * @type {Highcharts.AlignValue|null}\n */\n align: 'center',\n /**\n * Whether to allow data labels to overlap. To make the labels less\n * sensitive for overlapping, the\n * [dataLabels.padding](#plotOptions.series.dataLabels.padding)\n * can be set to 0.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-allowoverlap-false/\n * Don't allow overlap\n *\n * @type {boolean}\n * @default false\n * @since 4.1.0\n * @apioption plotOptions.series.dataLabels.allowOverlap\n */\n /**\n * The background color or gradient for the data label.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n * @sample {highmaps} maps/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.backgroundColor\n */\n /**\n * The border color for the data label. Defaults to `undefined`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.borderColor\n */\n /**\n * The border radius in pixels for the data label.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n * @sample {highmaps} maps/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {number}\n * @default 0\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.borderRadius\n */\n /**\n * The border width in pixels for the data label.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {number}\n * @default 0\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.borderWidth\n */\n /**\n * A class name for the data label. Particularly in styled mode,\n * this can be used to give each series' or point's data label\n * unique styling. In addition to this option, a default color class\n * name is added so that we can give the labels a contrast text\n * shadow.\n *\n * @sample {highcharts} highcharts/css/data-label-contrast/\n * Contrast text shadow\n * @sample {highcharts} highcharts/css/series-datalabels/\n * Styling by CSS\n *\n * @type {string}\n * @since 5.0.0\n * @apioption plotOptions.series.dataLabels.className\n */\n /**\n * This options is deprecated.\n * Use [style.color](#plotOptions.series.dataLabels.style) instead.\n *\n * The text color for the data labels. Defaults to `undefined`. For\n * certain series types, like column or map, the data labels can be\n * drawn inside the points. In this case the data label will be\n * drawn with maximum contrast by default. Additionally, it will be\n * given a `text-outline` style with the opposite color, to further\n * increase the contrast. This can be overridden by setting the\n * `text-outline` style to `none` in the `dataLabels.style` option.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-color/\n * Red data labels\n * @sample {highmaps} maps/demo/color-axis/\n * White data labels\n *\n * @see [style.color](#plotOptions.series.dataLabels.style)\n *\n * @type {Highcharts.ColorType}\n * @deprecated 10.3\n * @apioption plotOptions.series.dataLabels.color\n */\n /**\n * Whether to hide data labels that are outside the plot area. By\n * default, the data label is moved inside the plot area according\n * to the\n * [overflow](#plotOptions.series.dataLabels.overflow)\n * option.\n *\n * @type {boolean}\n * @default true\n * @since 2.3.3\n * @apioption plotOptions.series.dataLabels.crop\n */\n /**\n * Whether to defer displaying the data labels until the initial\n * series animation has finished. Setting to `false` renders the\n * data label immediately. If set to `true` inherits the defer\n * time set in [plotOptions.series.animation](#plotOptions.series.animation).\n * If set to a number, a defer time is specified in milliseconds.\n *\n * @sample highcharts/plotoptions/animation-defer\n * Set defer time\n *\n * @since 4.0.0\n * @type {boolean|number}\n * @product highcharts highstock gantt\n */\n defer: true,\n /**\n * Enable or disable the data labels.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-enabled/\n * Data labels enabled\n * @sample {highmaps} maps/demo/color-axis/\n * Data labels enabled\n *\n * @type {boolean}\n * @default false\n * @apioption plotOptions.series.dataLabels.enabled\n */\n /**\n * A declarative filter to control of which data labels to display.\n * The declarative filter is designed for use when callback\n * functions are not available, like when the chart options require\n * a pure JSON structure or for use with graphical editors. For\n * programmatic control, use the `formatter` instead, and return\n * `undefined` to disable a single data label.\n *\n * @example\n * filter: {\n * property: 'percentage',\n * operator: '>',\n * value: 4\n * }\n *\n * @sample {highcharts} highcharts/demo/pie-monochrome\n * Data labels filtered by percentage\n *\n * @declare Highcharts.DataLabelsFilterOptionsObject\n * @since 6.0.3\n * @apioption plotOptions.series.dataLabels.filter\n */\n /**\n * The operator to compare by. Can be one of `>`, `<`, `>=`, `<=`,\n * `==`, and `===`.\n *\n * @type {string}\n * @validvalue [\">\", \"<\", \">=\", \"<=\", \"==\", \"===\"]\n * @apioption plotOptions.series.dataLabels.filter.operator\n */\n /**\n * The point property to filter by. Point options are passed\n * directly to properties, additionally there are `y` value,\n * `percentage` and others listed under {@link Highcharts.Point}\n * members.\n *\n * @type {string}\n * @apioption plotOptions.series.dataLabels.filter.property\n */\n /**\n * The value to compare against.\n *\n * @type {number}\n * @apioption plotOptions.series.dataLabels.filter.value\n */\n /**\n * A\n * [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for the data label. Available variables are the same as for\n * `formatter`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-format/\n * Add a unit\n * @sample {highmaps} maps/plotoptions/series-datalabels-format/\n * Formatted value in the data label\n *\n * @type {string}\n * @default y\n * @default point.value\n * @since 3.0\n * @apioption plotOptions.series.dataLabels.format\n */\n // eslint-disable-next-line valid-jsdoc\n /**\n * Callback JavaScript function to format the data label. Note that if a\n * `format` is defined, the format takes precedence and the formatter is\n * ignored.\n *\n * @sample {highmaps} maps/plotoptions/series-datalabels-format/\n * Formatted value\n *\n * @type {Highcharts.DataLabelsFormatterCallbackFunction}\n */\n formatter: function () {\n var numberFormatter = this.series.chart.numberFormatter;\n return typeof this.y !== 'number' ?\n '' : numberFormatter(this.y, -1);\n },\n /**\n * For points with an extent, like columns or map areas, whether to\n * align the data label inside the box or to the actual value point.\n * Defaults to `false` in most cases, `true` in stacked columns.\n *\n * @type {boolean}\n * @since 3.0\n * @apioption plotOptions.series.dataLabels.inside\n */\n /**\n * Format for points with the value of null. Works analogously to\n * [format](#plotOptions.series.dataLabels.format). `nullFormat` can\n * be applied only to series which support displaying null points\n * i.e `heatmap` or `tilemap`. Does not work with series that don't\n * display null points, like `line`, `column`, `bar` or `pie`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-nullformat/\n * Format data label for null points in heat map\n *\n * @type {boolean|string}\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.nullFormat\n */\n /**\n * Callback JavaScript function that defines formatting for points\n * with the value of null. Works analogously to\n * [formatter](#plotOptions.series.dataLabels.formatter).\n * `nullFormatter` can be applied only to series which support\n * displaying null points i.e `heatmap` or `tilemap`. Does not work\n * with series that don't display null points, like `line`, `column`,\n * `bar` or `pie`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-nullformat/\n * Format data label for null points in heat map\n *\n * @type {Highcharts.DataLabelsFormatterCallbackFunction}\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.nullFormatter\n */\n /**\n * How to handle data labels that flow outside the plot area. The\n * default is `\"justify\"`, which aligns them inside the plot area.\n * For columns and bars, this means it will be moved inside the bar.\n * To display data labels outside the plot area, set `crop` to\n * `false` and `overflow` to `\"allow\"`.\n *\n * @type {Highcharts.DataLabelsOverflowValue}\n * @default justify\n * @since 3.0.6\n * @apioption plotOptions.series.dataLabels.overflow\n */\n /**\n * When either the `borderWidth` or the `backgroundColor` is set,\n * this is the padding within the box.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n * @sample {highmaps} maps/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @since 2.2.1\n */\n padding: 5,\n /**\n * Aligns data labels relative to points. If `center` alignment is\n * not possible, it defaults to `right`.\n *\n * @type {Highcharts.AlignValue}\n * @default center\n * @apioption plotOptions.series.dataLabels.position\n */\n /**\n * Text rotation in degrees. Note that due to a more complex\n * structure, backgrounds, borders and padding will be lost on a\n * rotated data label.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-rotation/\n * Vertical labels\n *\n * @type {number}\n * @default 0\n * @apioption plotOptions.series.dataLabels.rotation\n */\n /**\n * The shadow of the box. Works best with `borderWidth` or\n * `backgroundColor`. Since 2.3 the shadow can be an object\n * configuration containing `color`, `offsetX`, `offsetY`, `opacity`\n * and `width`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n * @default false\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.shadow\n */\n /**\n * The name of a symbol to use for the border around the label.\n * Symbols are predefined functions on the Renderer object.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-shape/\n * A callout for annotations\n *\n * @type {string}\n * @default square\n * @since 4.1.2\n * @apioption plotOptions.series.dataLabels.shape\n */\n /**\n * Styles for the label. The default `color` setting is\n * `\"contrast\"`, which is a pseudo color that Highcharts picks up\n * and applies the maximum contrast to the underlying point item,\n * for example the bar in a bar chart.\n *\n * The `textOutline` is a pseudo property that applies an outline of\n * the given width with the given color, which by default is the\n * maximum contrast to the text. So a bright text color will result\n * in a black text outline for maximum readability on a mixed\n * background. In some cases, especially with grayscale text, the\n * text outline doesn't work well, in which cases it can be disabled\n * by setting it to `\"none\"`. When `useHTML` is true, the\n * `textOutline` will not be picked up. In this, case, the same\n * effect can be acheived through the `text-shadow` CSS property.\n *\n * For some series types, where each point has an extent, like for\n * example tree maps, the data label may overflow the point. There\n * are two strategies for handling overflow. By default, the text\n * will wrap to multiple lines. The other strategy is to set\n * `style.textOverflow` to `ellipsis`, which will keep the text on\n * one line plus it will break inside long words.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-style/\n * Bold labels\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-overflow/\n * Long labels truncated with an ellipsis in a pie\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-overflow-wrap/\n * Long labels are wrapped in a pie\n * @sample {highmaps} maps/demo/color-axis/\n * Bold labels\n *\n * @type {Highcharts.CSSObject}\n * @since 4.1.0\n * @apioption plotOptions.series.dataLabels.style\n */\n style: {\n /** @internal */\n fontSize: '11px',\n /** @internal */\n fontWeight: 'bold',\n /** @internal */\n color: 'contrast',\n /** @internal */\n textOutline: '1px contrast'\n },\n /**\n * Options for a label text which should follow marker's shape.\n * Border and background are disabled for a label that follows a\n * path.\n *\n * **Note:** Only SVG-based renderer supports this option. Setting\n * `useHTML` to true will disable this option.\n *\n * @declare Highcharts.DataLabelsTextPathOptionsObject\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.textPath\n */\n /**\n * Presentation attributes for the text path.\n *\n * @type {Highcharts.SVGAttributes}\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.textPath.attributes\n */\n /**\n * Enable or disable `textPath` option for link's or marker's data\n * labels.\n *\n * @type {boolean}\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.textPath.enabled\n */\n /**\n * Whether to\n * [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n *\n * @type {boolean}\n * @default false\n * @apioption plotOptions.series.dataLabels.useHTML\n */\n /**\n * The vertical alignment of a data label. Can be one of `top`,\n * `middle` or `bottom`. The default value depends on the data, for\n * instance in a column chart, the label is above positive values\n * and below negative values.\n *\n * @type {Highcharts.VerticalAlignValue|null}\n * @since 2.3.3\n */\n verticalAlign: 'bottom',\n /**\n * The x position offset of the label relative to the point in\n * pixels.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-rotation/\n * Vertical and positioned\n * @sample {highcharts} highcharts/plotoptions/bar-datalabels-align-inside-bar/\n * Data labels inside the bar\n */\n x: 0,\n /**\n * The z index of the data labels. Use a `zIndex` of 6 to display it above\n * the series, or use a `zIndex` of 2 to display it behind the series.\n *\n * @type {number}\n * @default 6\n * @since 2.3.5\n * @apioption plotOptions.series.dataLabels.zIndex\n */\n /**\n * The y position offset of the label relative to the point in\n * pixels.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-rotation/\n * Vertical and positioned\n */\n y: 0\n },\n /**\n * When the series contains less points than the crop threshold, all\n * points are drawn, even if the points fall outside the visible plot\n * area at the current zoom. The advantage of drawing all points\n * (including markers and columns), is that animation is performed on\n * updates. On the other hand, when the series contains more points than\n * the crop threshold, the series data is cropped to only contain points\n * that fall within the plot area. The advantage of cropping away\n * invisible points is to increase performance on large series.\n *\n * @since 2.2\n * @product highcharts highstock\n *\n * @private\n */\n cropThreshold: 300,\n /**\n * Opacity of a series parts: line, fill (e.g. area) and dataLabels.\n *\n * @see [states.inactive.opacity](#plotOptions.series.states.inactive.opacity)\n *\n * @since 7.1.0\n *\n * @private\n */\n opacity: 1,\n /**\n * The width of each point on the x axis. For example in a column chart\n * with one value each day, the pointRange would be 1 day (= 24 * 3600\n * * 1000 milliseconds). This is normally computed automatically, but\n * this option can be used to override the automatic value.\n *\n * @product highstock\n *\n * @private\n */\n pointRange: 0,\n /**\n * When this is true, the series will not cause the Y axis to cross\n * the zero plane (or [threshold](#plotOptions.series.threshold) option)\n * unless the data actually crosses the plane.\n *\n * For example, if `softThreshold` is `false`, a series of 0, 1, 2,\n * 3 will make the Y axis show negative values according to the\n * `minPadding` option. If `softThreshold` is `true`, the Y axis starts\n * at 0.\n *\n * @since 4.1.9\n * @product highcharts highstock\n *\n * @private\n */\n softThreshold: true,\n /**\n * @declare Highcharts.SeriesStatesOptionsObject\n *\n * @private\n */\n states: {\n /**\n * The normal state of a series, or for point items in column, pie\n * and similar series. Currently only used for setting animation\n * when returning to normal state from hover.\n *\n * @declare Highcharts.SeriesStatesNormalOptionsObject\n */\n normal: {\n /**\n * Animation when returning to normal state after hovering.\n *\n * @type {boolean|Partial}\n */\n animation: true\n },\n /**\n * Options for the hovered series. These settings override the\n * normal state options when a series is moused over or touched.\n *\n * @declare Highcharts.SeriesStatesHoverOptionsObject\n */\n hover: {\n /**\n * Enable separate styles for the hovered series to visualize\n * that the user hovers either the series itself or the legend.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-enabled/\n * Line\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-enabled-column/\n * Column\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-enabled-pie/\n * Pie\n *\n * @type {boolean}\n * @default true\n * @since 1.2\n * @apioption plotOptions.series.states.hover.enabled\n */\n /**\n * Animation setting for hovering the graph in line-type series.\n *\n * @type {boolean|Partial}\n * @since 5.0.8\n * @product highcharts highstock\n */\n animation: {\n /**\n * The duration of the hover animation in milliseconds. By\n * default the hover state animates quickly in, and slowly\n * back to normal.\n *\n * @internal\n */\n duration: 50\n },\n /**\n * Pixel width of the graph line. By default this property is\n * undefined, and the `lineWidthPlus` property dictates how much\n * to increase the linewidth from normal state.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-linewidth/\n * 5px line on hover\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption plotOptions.series.states.hover.lineWidth\n */\n /**\n * The additional line width for the graph of a hovered series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 5 pixels wider\n * @sample {highstock} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 5 pixels wider\n *\n * @since 4.0.3\n * @product highcharts highstock\n */\n lineWidthPlus: 1,\n /**\n * In Highcharts 1.0, the appearance of all markers belonging\n * to the hovered series. For settings on the hover state of the\n * individual point, see\n * [marker.states.hover](#plotOptions.series.marker.states.hover).\n *\n * @deprecated\n *\n * @extends plotOptions.series.marker\n * @excluding states, symbol\n * @product highcharts highstock\n */\n marker: {\n // lineWidth: base + 1,\n // radius: base + 1\n },\n /**\n * Options for the halo appearing around the hovered point in\n * line-type series as well as outside the hovered slice in pie\n * charts. By default the halo is filled by the current point or\n * series color with an opacity of 0.25\\. The halo can be\n * disabled by setting the `halo` option to `null`.\n *\n * In styled mode, the halo is styled with the\n * `.highcharts-halo` class, with colors inherited from\n * `.highcharts-color-{n}`.\n *\n * @sample {highcharts} highcharts/plotoptions/halo/\n * Halo options\n * @sample {highstock} highcharts/plotoptions/halo/\n * Halo options\n *\n * @declare Highcharts.SeriesStatesHoverHaloOptionsObject\n * @type {null|*}\n * @since 4.0\n * @product highcharts highstock\n */\n halo: {\n /**\n * A collection of SVG attributes to override the appearance\n * of the halo, for example `fill`, `stroke` and\n * `stroke-width`.\n *\n * @type {Highcharts.SVGAttributes}\n * @since 4.0\n * @product highcharts highstock\n * @apioption plotOptions.series.states.hover.halo.attributes\n */\n /**\n * The pixel size of the halo. For point markers this is the\n * radius of the halo. For pie slices it is the width of the\n * halo outside the slice. For bubbles it defaults to 5 and\n * is the width of the halo outside the bubble.\n *\n * @since 4.0\n * @product highcharts highstock\n */\n size: 10,\n /**\n * Opacity for the halo unless a specific fill is overridden\n * using the `attributes` setting. Note that Highcharts is\n * only able to apply opacity to colors of hex or rgb(a)\n * formats.\n *\n * @since 4.0\n * @product highcharts highstock\n */\n opacity: 0.25\n }\n },\n /**\n * Specific options for point in selected states, after being\n * selected by\n * [allowPointSelect](#plotOptions.series.allowPointSelect)\n * or programmatically.\n *\n * @sample maps/plotoptions/series-allowpointselect/\n * Allow point select demo\n *\n * @declare Highcharts.SeriesStatesSelectOptionsObject\n * @extends plotOptions.series.states.hover\n * @excluding brightness\n */\n select: {\n animation: {\n /** @internal */\n duration: 0\n }\n },\n /**\n * The opposite state of a hover for series.\n *\n * @sample highcharts/plotoptions/series-states-inactive-disabled\n * Disabled inactive state\n *\n * @declare Highcharts.SeriesStatesInactiveOptionsObject\n */\n inactive: {\n /**\n * Enable or disable the inactive state for a series\n *\n * @sample highcharts/plotoptions/series-states-inactive-disabled\n * Disabled inactive state\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.states.inactive.enabled\n */\n /**\n * The animation for entering the inactive state.\n *\n * @type {boolean|Partial}\n */\n animation: {\n /** @internal */\n duration: 50\n },\n /**\n * Opacity of series elements (dataLabels, line, area).\n *\n * @type {number}\n */\n opacity: 0.2\n }\n },\n /**\n * Sticky tracking of mouse events. When true, the `mouseOut` event on a\n * series isn't triggered until the mouse moves over another series, or\n * out of the plot area. When false, the `mouseOut` event on a series is\n * triggered when the mouse leaves the area around the series' graph or\n * markers. This also implies the tooltip when not shared. When\n * `stickyTracking` is false and `tooltip.shared` is false, the tooltip\n * will be hidden when moving the mouse between series. Defaults to true\n * for line and area type series, but to false for columns, pies etc.\n *\n * **Note:** The boost module will force this option because of\n * technical limitations.\n *\n * @sample {highcharts} highcharts/plotoptions/series-stickytracking-true/\n * True by default\n * @sample {highcharts} highcharts/plotoptions/series-stickytracking-false/\n * False\n *\n * @default {highcharts} true\n * @default {highstock} true\n * @default {highmaps} false\n * @since 2.0\n *\n * @private\n */\n stickyTracking: true,\n /**\n * A configuration object for the tooltip rendering of each single\n * series. Properties are inherited from [tooltip](#tooltip), but only\n * the following properties can be defined on a series level.\n *\n * @declare Highcharts.SeriesTooltipOptionsObject\n * @since 2.3\n * @extends tooltip\n * @excluding animation, backgroundColor, borderColor, borderRadius,\n * borderWidth, className, crosshairs, enabled, formatter,\n * headerShape, hideDelay, outside, padding, positioner,\n * shadow, shape, shared, snap, split, stickOnContact,\n * style, useHTML\n * @apioption plotOptions.series.tooltip\n */\n /**\n * When a series contains a data array that is longer than this, only\n * one dimensional arrays of numbers, or two dimensional arrays with\n * x and y values are allowed. Also, only the first point is tested,\n * and the rest are assumed to be the same format. This saves expensive\n * data checking and indexing in long series. Set it to `0` disable.\n *\n * Note:\n * In boost mode turbo threshold is forced. Only array of numbers or\n * two dimensional arrays are allowed.\n *\n * @since 2.2\n * @product highcharts highstock gantt\n *\n * @private\n */\n turboThreshold: 1000,\n /**\n * An array defining zones within a series. Zones can be applied to the\n * X axis, Y axis or Z axis for bubbles, according to the `zoneAxis`\n * option. The zone definitions have to be in ascending order regarding\n * to the value.\n *\n * In styled mode, the color zones are styled with the\n * `.highcharts-zone-{n}` class, or custom classed from the `className`\n * option\n * ([view live demo](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/css/color-zones/)).\n *\n * @see [zoneAxis](#plotOptions.series.zoneAxis)\n *\n * @sample {highcharts} highcharts/series/color-zones-simple/\n * Color zones\n * @sample {highstock} highcharts/series/color-zones-simple/\n * Color zones\n *\n * @declare Highcharts.SeriesZonesOptionsObject\n * @type {Array<*>}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones\n */\n /**\n * Styled mode only. A custom class name for the zone.\n *\n * @sample highcharts/css/color-zones/\n * Zones styled by class name\n *\n * @type {string}\n * @since 5.0.0\n * @apioption plotOptions.series.zones.className\n */\n /**\n * Defines the color of the series.\n *\n * @see [series color](#plotOptions.series.color)\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones.color\n */\n /**\n * A name for the dash style to use for the graph.\n *\n * @see [plotOptions.series.dashStyle](#plotOptions.series.dashStyle)\n *\n * @sample {highcharts|highstock} highcharts/series/color-zones-dashstyle-dot/\n * Dashed line indicates prognosis\n *\n * @type {Highcharts.DashStyleValue}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones.dashStyle\n */\n /**\n * Defines the fill color for the series (in area type series)\n *\n * @see [fillColor](#plotOptions.area.fillColor)\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones.fillColor\n */\n /**\n * The value up to where the zone extends, if undefined the zones\n * stretches to the last value in the series.\n *\n * @type {number}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones.value\n */\n /**\n * When using dual or multiple color axes, this number defines which\n * colorAxis the particular series is connected to. It refers to\n * either the\n * {@link #colorAxis.id|axis id}\n * or the index of the axis in the colorAxis array, with 0 being the\n * first. Set this option to false to prevent a series from connecting\n * to the default color axis.\n *\n * Since v7.2.0 the option can also be an axis id or an axis index\n * instead of a boolean flag.\n *\n * @sample highcharts/coloraxis/coloraxis-with-pie/\n * Color axis with pie series\n * @sample highcharts/coloraxis/multiple-coloraxis/\n * Multiple color axis\n *\n * @type {number|string|boolean}\n * @default 0\n * @product highcharts highstock highmaps\n * @apioption plotOptions.series.colorAxis\n */\n /**\n * Determines what data value should be used to calculate point color\n * if `colorAxis` is used. Requires to set `min` and `max` if some\n * custom point property is used or if approximation for data grouping\n * is set to `'sum'`.\n *\n * @sample highcharts/coloraxis/custom-color-key/\n * Custom color key\n * @sample highcharts/coloraxis/color-key-with-stops/\n * Custom colorKey with color axis stops\n * @sample highcharts/coloraxis/changed-default-color-key/\n * Changed default color key\n *\n * @type {string}\n * @default y\n * @since 7.2.0\n * @product highcharts highstock highmaps\n * @apioption plotOptions.series.colorKey\n */\n /**\n * Determines whether the series should look for the nearest point\n * in both dimensions or just the x-dimension when hovering the series.\n * Defaults to `'xy'` for scatter series and `'x'` for most other\n * series. If the data has duplicate x-values, it is recommended to\n * set this to `'xy'` to allow hovering over all points.\n *\n * Applies only to series types using nearest neighbor search (not\n * direct hover) for tooltip.\n *\n * @sample {highcharts} highcharts/series/findnearestpointby/\n * Different hover behaviors\n * @sample {highstock} highcharts/series/findnearestpointby/\n * Different hover behaviors\n * @sample {highmaps} highcharts/series/findnearestpointby/\n * Different hover behaviors\n *\n * @since 5.0.10\n * @validvalue [\"x\", \"xy\"]\n *\n * @private\n */\n findNearestPointBy: 'x'\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return seriesDefaults;\n });\n _registerModule(_modules, 'Core/Series/Series.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Defaults.js'], _modules['Core/Foundation.js'], _modules['Core/Globals.js'], _modules['Core/Legend/LegendSymbol.js'], _modules['Core/Series/Point.js'], _modules['Core/Series/SeriesDefaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (A, D, F, H, LegendSymbol, Point, SeriesDefaults, SeriesRegistry, SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var animObject = A.animObject,\n setAnimation = A.setAnimation;\n var defaultOptions = D.defaultOptions;\n var registerEventOptions = F.registerEventOptions;\n var hasTouch = H.hasTouch,\n svg = H.svg,\n win = H.win;\n var seriesTypes = SeriesRegistry.seriesTypes;\n var addEvent = U.addEvent,\n arrayMax = U.arrayMax,\n arrayMin = U.arrayMin,\n clamp = U.clamp,\n cleanRecursively = U.cleanRecursively,\n correctFloat = U.correctFloat,\n defined = U.defined,\n erase = U.erase,\n error = U.error,\n extend = U.extend,\n find = U.find,\n fireEvent = U.fireEvent,\n getNestedProperty = U.getNestedProperty,\n isArray = U.isArray,\n isNumber = U.isNumber,\n isString = U.isString,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick,\n removeEvent = U.removeEvent,\n splat = U.splat,\n syncTimeout = U.syncTimeout;\n /* *\n *\n * Class\n *\n * */\n /**\n * This is the base series prototype that all other series types inherit from.\n * A new series is initialized either through the\n * [series](https://api.highcharts.com/highcharts/series)\n * option structure, or after the chart is initialized, through\n * {@link Highcharts.Chart#addSeries}.\n *\n * The object can be accessed in a number of ways. All series and point event\n * handlers give a reference to the `series` object. The chart object has a\n * {@link Highcharts.Chart#series|series} property that is a collection of all\n * the chart's series. The point objects and axis objects also have the same\n * reference.\n *\n * Another way to reference the series programmatically is by `id`. Add an id\n * in the series configuration options, and get the series object by\n * {@link Highcharts.Chart#get}.\n *\n * Configuration options for the series are given in three levels. Options for\n * all series in a chart are given in the\n * [plotOptions.series](https://api.highcharts.com/highcharts/plotOptions.series)\n * object. Then options for all series of a specific type\n * are given in the plotOptions of that type, for example `plotOptions.line`.\n * Next, options for one single series are given in the series array, or as\n * arguments to `chart.addSeries`.\n *\n * The data in the series is stored in various arrays.\n *\n * - First, `series.options.data` contains all the original config options for\n * each point whether added by options or methods like `series.addPoint`.\n *\n * - Next, `series.data` contains those values converted to points, but in case\n * the series data length exceeds the `cropThreshold`, or if the data is\n * grouped, `series.data` doesn't contain all the points. It only contains the\n * points that have been created on demand.\n *\n * - Then there's `series.points` that contains all currently visible point\n * objects. In case of cropping, the cropped-away points are not part of this\n * array. The `series.points` array starts at `series.cropStart` compared to\n * `series.data` and `series.options.data`. If however the series data is\n * grouped, these can't be correlated one to one.\n *\n * - `series.xData` and `series.processedXData` contain clean x values,\n * equivalent to `series.data` and `series.points`.\n *\n * - `series.yData` and `series.processedYData` contain clean y values,\n * equivalent to `series.data` and `series.points`.\n *\n * @class\n * @name Highcharts.Series\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.SeriesOptionsType|object} options\n * The series options.\n */\n var Series = /** @class */ (function () {\n function Series() {\n /* *\n *\n * Static Properties\n *\n * */\n this._i = void 0;\n this.chart = void 0;\n this.data = void 0;\n this.eventOptions = void 0;\n this.eventsToUnbind = void 0;\n this.index = void 0;\n this.linkedSeries = void 0;\n this.options = void 0;\n this.points = void 0;\n this.processedXData = void 0;\n this.processedYData = void 0;\n this.tooltipOptions = void 0;\n this.userOptions = void 0;\n this.xAxis = void 0;\n this.yAxis = void 0;\n this.zones = void 0;\n /** eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n Series.prototype.init = function (chart, userOptions) {\n fireEvent(this, 'init', { options: userOptions });\n var series = this,\n chartSeries = chart.series;\n // The 'eventsToUnbind' property moved from prototype into the\n // Series init to avoid reference to the same array between\n // the different series and charts. #12959, #13937\n this.eventsToUnbind = [];\n /**\n * Read only. The chart that the series belongs to.\n *\n * @name Highcharts.Series#chart\n * @type {Highcharts.Chart}\n */\n series.chart = chart;\n /**\n * Read only. The series' type, like \"line\", \"area\", \"column\" etc.\n * The type in the series options anc can be altered using\n * {@link Series#update}.\n *\n * @name Highcharts.Series#type\n * @type {string}\n */\n /**\n * Read only. The series' current options. To update, use\n * {@link Series#update}.\n *\n * @name Highcharts.Series#options\n * @type {Highcharts.SeriesOptionsType}\n */\n series.options = series.setOptions(userOptions);\n var options = series.options;\n series.linkedSeries = [];\n // bind the axes\n series.bindAxes();\n extend(series, {\n /**\n * The series name as given in the options. Defaults to\n * \"Series {n}\".\n *\n * @name Highcharts.Series#name\n * @type {string}\n */\n name: options.name,\n state: '',\n /**\n * Read only. The series' visibility state as set by {@link\n * Series#show}, {@link Series#hide}, or in the initial\n * configuration.\n *\n * @name Highcharts.Series#visible\n * @type {boolean}\n */\n visible: options.visible !== false,\n /**\n * Read only. The series' selected state as set by {@link\n * Highcharts.Series#select}.\n *\n * @name Highcharts.Series#selected\n * @type {boolean}\n */\n selected: options.selected === true // false by default\n });\n registerEventOptions(this, options);\n var events = options.events;\n if ((events && events.click) ||\n (options.point &&\n options.point.events &&\n options.point.events.click) ||\n options.allowPointSelect) {\n chart.runTrackerClick = true;\n }\n series.getColor();\n series.getSymbol();\n // Initialize the parallel data arrays\n series.parallelArrays.forEach(function (key) {\n if (!series[key + 'Data']) {\n series[key + 'Data'] = [];\n }\n });\n // Mark cartesian\n if (series.isCartesian) {\n chart.hasCartesianSeries = true;\n }\n // Get the index and register the series in the chart. The index is\n // one more than the current latest series index (#5960).\n var lastSeries;\n if (chartSeries.length) {\n lastSeries = chartSeries[chartSeries.length - 1];\n }\n series._i = pick(lastSeries && lastSeries._i, -1) + 1;\n series.opacity = series.options.opacity;\n // Insert the series and re-order all series above the insertion\n // point.\n chart.orderSeries(this.insert(chartSeries));\n // Set options for series with sorting and set data later.\n if (options.dataSorting && options.dataSorting.enabled) {\n series.setDataSortingOptions();\n }\n else if (!series.points && !series.data) {\n series.setData(options.data, false);\n }\n fireEvent(this, 'afterInit');\n };\n /**\n * Check whether the series item is itself or inherits from a certain\n * series type.\n *\n * @function Highcharts.Series#is\n * @param {string} type The type of series to check for, can be either\n * featured or custom series types. For example `column`, `pie`,\n * `ohlc` etc.\n *\n * @return {boolean}\n * True if this item is or inherits from the given type.\n */\n Series.prototype.is = function (type) {\n return seriesTypes[type] && this instanceof seriesTypes[type];\n };\n /**\n * Insert the series in a collection with other series, either the chart\n * series or yAxis series, in the correct order according to the index\n * option. Used internally when adding series.\n *\n * @private\n * @function Highcharts.Series#insert\n * @param {Array} collection\n * A collection of series, like `chart.series` or `xAxis.series`.\n * @return {number}\n * The index of the series in the collection.\n */\n Series.prototype.insert = function (collection) {\n var indexOption = this.options.index;\n var i;\n // Insert by index option\n if (isNumber(indexOption)) {\n i = collection.length;\n while (i--) {\n // Loop down until the interted element has higher index\n if (indexOption >=\n pick(collection[i].options.index, collection[i]._i)) {\n collection.splice(i + 1, 0, this);\n break;\n }\n }\n if (i === -1) {\n collection.unshift(this);\n }\n i = i + 1;\n // Or just push it to the end\n }\n else {\n collection.push(this);\n }\n return pick(i, collection.length - 1);\n };\n /**\n * Set the xAxis and yAxis properties of cartesian series, and register\n * the series in the `axis.series` array.\n *\n * @private\n * @function Highcharts.Series#bindAxes\n */\n Series.prototype.bindAxes = function () {\n var series = this,\n seriesOptions = series.options,\n chart = series.chart;\n var axisOptions;\n fireEvent(this, 'bindAxes', null, function () {\n // repeat for xAxis and yAxis\n (series.axisTypes || []).forEach(function (AXIS) {\n var index = 0;\n // loop through the chart's axis objects\n chart[AXIS].forEach(function (axis) {\n axisOptions = axis.options;\n // apply if the series xAxis or yAxis option mathches\n // the number of the axis, or if undefined, use the\n // first axis\n if ((seriesOptions[AXIS] === index &&\n !axisOptions.isInternal) ||\n (typeof seriesOptions[AXIS] !==\n 'undefined' &&\n seriesOptions[AXIS] === axisOptions.id) ||\n (typeof seriesOptions[AXIS] ===\n 'undefined' &&\n axisOptions.index === 0)) {\n // register this series in the axis.series lookup\n series.insert(axis.series);\n // set this series.xAxis or series.yAxis reference\n /**\n * Read only. The unique xAxis object associated\n * with the series.\n *\n * @name Highcharts.Series#xAxis\n * @type {Highcharts.Axis}\n */\n /**\n * Read only. The unique yAxis object associated\n * with the series.\n *\n * @name Highcharts.Series#yAxis\n * @type {Highcharts.Axis}\n */\n series[AXIS] = axis;\n // mark dirty for redraw\n axis.isDirty = true;\n }\n if (!axisOptions.isInternal) {\n index++;\n }\n });\n // The series needs an X and an Y axis\n if (!series[AXIS] &&\n series.optionalAxis !== AXIS) {\n error(18, true, chart);\n }\n });\n });\n fireEvent(this, 'afterBindAxes');\n };\n /**\n * For simple series types like line and column, the data values are\n * held in arrays like xData and yData for quick lookup to find extremes\n * and more. For multidimensional series like bubble and map, this can\n * be extended with arrays like zData and valueData by adding to the\n * `series.parallelArrays` array.\n *\n * @private\n * @function Highcharts.Series#updateParallelArrays\n */\n Series.prototype.updateParallelArrays = function (point, i) {\n var series = point.series,\n args = arguments,\n fn = isNumber(i) ?\n // Insert the value in the given position\n function (key) {\n var val = key === 'y' && series.toYData ?\n series.toYData(point) :\n point[key];\n series[key + 'Data'][i] = val;\n } :\n // Apply the method specified in i with the following\n // arguments as arguments\n function (key) {\n Array.prototype[i].apply(series[key + 'Data'], Array.prototype.slice.call(args, 2));\n };\n series.parallelArrays.forEach(fn);\n };\n /**\n * Define hasData functions for series. These return true if there\n * are data points on this series within the plot area.\n *\n * @private\n * @function Highcharts.Series#hasData\n */\n Series.prototype.hasData = function () {\n return ((this.visible &&\n typeof this.dataMax !== 'undefined' &&\n typeof this.dataMin !== 'undefined') || ( // #3703\n this.visible &&\n this.yData &&\n this.yData.length > 0) // #9758\n );\n };\n /**\n * Return an auto incremented x value based on the pointStart and\n * pointInterval options. This is only used if an x value is not given\n * for the point that calls autoIncrement.\n *\n * @private\n * @function Highcharts.Series#autoIncrement\n */\n Series.prototype.autoIncrement = function (x) {\n var options = this.options,\n pointIntervalUnit = options.pointIntervalUnit,\n relativeXValue = options.relativeXValue,\n time = this.chart.time;\n var xIncrement = this.xIncrement,\n date,\n pointInterval;\n xIncrement = pick(xIncrement, options.pointStart, 0);\n this.pointInterval = pointInterval = pick(this.pointInterval, options.pointInterval, 1);\n if (relativeXValue && isNumber(x)) {\n pointInterval *= x;\n }\n // Added code for pointInterval strings\n if (pointIntervalUnit) {\n date = new time.Date(xIncrement);\n if (pointIntervalUnit === 'day') {\n time.set('Date', date, time.get('Date', date) + pointInterval);\n }\n else if (pointIntervalUnit === 'month') {\n time.set('Month', date, time.get('Month', date) + pointInterval);\n }\n else if (pointIntervalUnit === 'year') {\n time.set('FullYear', date, time.get('FullYear', date) + pointInterval);\n }\n pointInterval = date.getTime() - xIncrement;\n }\n if (relativeXValue && isNumber(x)) {\n return xIncrement + pointInterval;\n }\n this.xIncrement = xIncrement + pointInterval;\n return xIncrement;\n };\n /**\n * Internal function to set properties for series if data sorting is\n * enabled.\n *\n * @private\n * @function Highcharts.Series#setDataSortingOptions\n */\n Series.prototype.setDataSortingOptions = function () {\n var options = this.options;\n extend(this, {\n requireSorting: false,\n sorted: false,\n enabledDataSorting: true,\n allowDG: false\n });\n // To allow unsorted data for column series.\n if (!defined(options.pointRange)) {\n options.pointRange = 1;\n }\n };\n /**\n * Set the series options by merging from the options tree. Called\n * internally on initializing and updating series. This function will\n * not redraw the series. For API usage, use {@link Series#update}.\n * @private\n * @function Highcharts.Series#setOptions\n * @param {Highcharts.SeriesOptionsType} itemOptions\n * The series options.\n * @emits Highcharts.Series#event:afterSetOptions\n */\n Series.prototype.setOptions = function (itemOptions) {\n var chart = this.chart,\n chartOptions = chart.options,\n plotOptions = chartOptions.plotOptions,\n userOptions = chart.userOptions || {},\n seriesUserOptions = merge(itemOptions),\n styledMode = chart.styledMode,\n e = {\n plotOptions: plotOptions,\n userOptions: seriesUserOptions\n };\n var zone;\n fireEvent(this, 'setOptions', e);\n // These may be modified by the event\n var typeOptions = e.plotOptions[this.type],\n userPlotOptions = (userOptions.plotOptions || {});\n // use copy to prevent undetected changes (#9762)\n /**\n * Contains series options by the user without defaults.\n * @name Highcharts.Series#userOptions\n * @type {Highcharts.SeriesOptionsType}\n */\n this.userOptions = e.userOptions;\n var options = merge(typeOptions,\n plotOptions.series, \n // #3881, chart instance plotOptions[type] should trump\n // plotOptions.series\n userOptions.plotOptions &&\n userOptions.plotOptions[this.type],\n seriesUserOptions);\n // The tooltip options are merged between global and series specific\n // options. Importance order asscendingly:\n // globals: (1)tooltip, (2)plotOptions.series,\n // (3)plotOptions[this.type]\n // init userOptions with possible later updates: 4-6 like 1-3 and\n // (7)this series options\n this.tooltipOptions = merge(defaultOptions.tooltip, // 1\n defaultOptions.plotOptions.series &&\n defaultOptions.plotOptions.series.tooltip, // 2\n defaultOptions.plotOptions[this.type].tooltip, // 3\n chartOptions.tooltip.userOptions, // 4\n plotOptions.series &&\n plotOptions.series.tooltip, // 5\n plotOptions[this.type].tooltip, // 6\n seriesUserOptions.tooltip // 7\n );\n // When shared tooltip, stickyTracking is true by default,\n // unless user says otherwise.\n this.stickyTracking = pick(seriesUserOptions.stickyTracking, userPlotOptions[this.type] &&\n userPlotOptions[this.type].stickyTracking, userPlotOptions.series && userPlotOptions.series.stickyTracking, (this.tooltipOptions.shared && !this.noSharedTooltip ?\n true :\n options.stickyTracking));\n // Delete marker object if not allowed (#1125)\n if (typeOptions.marker === null) {\n delete options.marker;\n }\n // Handle color zones\n this.zoneAxis = options.zoneAxis;\n var zones = this.zones = (options.zones || []).slice();\n if ((options.negativeColor || options.negativeFillColor) &&\n !options.zones) {\n zone = {\n value: options[this.zoneAxis + 'Threshold'] ||\n options.threshold ||\n 0,\n className: 'highcharts-negative'\n };\n if (!styledMode) {\n zone.color = options.negativeColor;\n zone.fillColor = options.negativeFillColor;\n }\n zones.push(zone);\n }\n if (zones.length) { // Push one extra zone for the rest\n if (defined(zones[zones.length - 1].value)) {\n zones.push(styledMode ? {} : {\n color: this.color,\n fillColor: this.fillColor\n });\n }\n }\n fireEvent(this, 'afterSetOptions', { options: options });\n return options;\n };\n /**\n * Return series name in \"Series {Number}\" format or the one defined by\n * a user. This method can be simply overridden as series name format\n * can vary (e.g. technical indicators).\n *\n * @function Highcharts.Series#getName\n *\n * @return {string}\n * The series name.\n */\n Series.prototype.getName = function () {\n // #4119\n return pick(this.options.name, 'Series ' + (this.index + 1));\n };\n /**\n * @private\n * @function Highcharts.Series#getCyclic\n */\n Series.prototype.getCyclic = function (prop, value, defaults) {\n var chart = this.chart, userOptions = this.userOptions, indexName = prop + 'Index', counterName = prop + 'Counter', len = defaults ? defaults.length : pick(chart.options.chart[prop + 'Count'], chart[prop + 'Count']);\n var i,\n setting;\n if (!value) {\n // Pick up either the colorIndex option, or the _colorIndex\n // after Series.update()\n setting = pick(userOptions[indexName], userOptions['_' + indexName]);\n if (defined(setting)) { // after Series.update()\n i = setting;\n }\n else {\n // #6138\n if (!chart.series.length) {\n chart[counterName] = 0;\n }\n userOptions['_' + indexName] = i =\n chart[counterName] % len;\n chart[counterName] += 1;\n }\n if (defaults) {\n value = defaults[i];\n }\n }\n // Set the colorIndex\n if (typeof i !== 'undefined') {\n this[indexName] = i;\n }\n this[prop] = value;\n };\n /**\n * Get the series' color based on either the options or pulled from\n * global options.\n *\n * @private\n * @function Highcharts.Series#getColor\n */\n Series.prototype.getColor = function () {\n if (this.chart.styledMode) {\n this.getCyclic('color');\n }\n else if (this.options.colorByPoint) {\n this.color = \"#cccccc\" /* Palette.neutralColor20 */;\n }\n else {\n this.getCyclic('color', this.options.color ||\n defaultOptions.plotOptions[this.type].color, this.chart.options.colors);\n }\n };\n /**\n * Get all points' instances created for this series.\n *\n * @private\n * @function Highcharts.Series#getPointsCollection\n */\n Series.prototype.getPointsCollection = function () {\n return (this.hasGroupedData ? this.points : this.data) || [];\n };\n /**\n * Get the series' symbol based on either the options or pulled from\n * global options.\n *\n * @private\n * @function Highcharts.Series#getSymbol\n */\n Series.prototype.getSymbol = function () {\n var seriesMarkerOption = this.options.marker;\n this.getCyclic('symbol', seriesMarkerOption.symbol, this.chart.options.symbols);\n };\n /**\n * Finds the index of an existing point that matches the given point\n * options.\n *\n * @private\n * @function Highcharts.Series#findPointIndex\n * @param {Highcharts.PointOptionsObject} optionsObject\n * The options of the point.\n * @param {number} fromIndex\n * The index to start searching from, used for optimizing series with\n * required sorting.\n * @return {number|undefined}\n * Returns the index of a matching point, or undefined if no match is found.\n */\n Series.prototype.findPointIndex = function (optionsObject, fromIndex) {\n var id = optionsObject.id,\n x = optionsObject.x,\n oldData = this.points,\n dataSorting = this.options.dataSorting;\n var matchingPoint,\n matchedById,\n pointIndex;\n if (id) {\n var item = this.chart.get(id);\n if (item instanceof Point) {\n matchingPoint = item;\n }\n }\n else if (this.linkedParent ||\n this.enabledDataSorting ||\n this.options.relativeXValue) {\n var matcher = function (oldPoint) { return !oldPoint.touched &&\n oldPoint.index === optionsObject.index; };\n if (dataSorting && dataSorting.matchByName) {\n matcher = function (oldPoint) { return !oldPoint.touched &&\n oldPoint.name === optionsObject.name; };\n }\n else if (this.options.relativeXValue) {\n matcher = function (oldPoint) { return !oldPoint.touched &&\n oldPoint.options.x === optionsObject.x; };\n }\n matchingPoint = find(oldData, matcher);\n // Add unmatched point as a new point\n if (!matchingPoint) {\n return void 0;\n }\n }\n if (matchingPoint) {\n pointIndex = matchingPoint && matchingPoint.index;\n if (typeof pointIndex !== 'undefined') {\n matchedById = true;\n }\n }\n // Search for the same X in the existing data set\n if (typeof pointIndex === 'undefined' && isNumber(x)) {\n pointIndex = this.xData.indexOf(x, fromIndex);\n }\n // Reduce pointIndex if data is cropped\n if (pointIndex !== -1 &&\n typeof pointIndex !== 'undefined' &&\n this.cropped) {\n pointIndex = (pointIndex >= this.cropStart) ?\n pointIndex - this.cropStart : pointIndex;\n }\n if (!matchedById &&\n isNumber(pointIndex) &&\n oldData[pointIndex] && oldData[pointIndex].touched) {\n pointIndex = void 0;\n }\n return pointIndex;\n };\n /**\n * Internal function called from setData. If the point count is the same\n * as it was, or if there are overlapping X values, just run\n * Point.update which is cheaper, allows animation, and keeps references\n * to points. This also allows adding or removing points if the X-es\n * don't match.\n *\n * @private\n * @function Highcharts.Series#updateData\n */\n Series.prototype.updateData = function (data, animation) {\n var options = this.options,\n dataSorting = options.dataSorting,\n oldData = this.points,\n pointsToAdd = [],\n requireSorting = this.requireSorting,\n equalLength = data.length === oldData.length;\n var hasUpdatedByKey,\n i,\n point,\n lastIndex,\n succeeded = true;\n this.xIncrement = null;\n // Iterate the new data\n data.forEach(function (pointOptions, i) {\n var optionsObject = (defined(pointOptions) &&\n this.pointClass.prototype.optionsToObject.call({ series: this },\n pointOptions)) || {};\n var pointIndex;\n // Get the x of the new data point\n var x = optionsObject.x,\n id = optionsObject.id;\n if (id || isNumber(x)) {\n pointIndex = this.findPointIndex(optionsObject, lastIndex);\n // Matching X not found\n // or used already due to ununique x values (#8995),\n // add point (but later)\n if (pointIndex === -1 ||\n typeof pointIndex === 'undefined') {\n pointsToAdd.push(pointOptions);\n // Matching X found, update\n }\n else if (oldData[pointIndex] &&\n pointOptions !== options.data[pointIndex]) {\n oldData[pointIndex].update(pointOptions, false, null, false);\n // Mark it touched, below we will remove all points that\n // are not touched.\n oldData[pointIndex].touched = true;\n // Speed optimize by only searching after last known\n // index. Performs ~20% bettor on large data sets.\n if (requireSorting) {\n lastIndex = pointIndex + 1;\n }\n // Point exists, no changes, don't remove it\n }\n else if (oldData[pointIndex]) {\n oldData[pointIndex].touched = true;\n }\n // If the length is equal and some of the nodes had a\n // match in the same position, we don't want to remove\n // non-matches.\n if (!equalLength ||\n i !== pointIndex ||\n (dataSorting && dataSorting.enabled) ||\n this.hasDerivedData) {\n hasUpdatedByKey = true;\n }\n }\n else {\n // Gather all points that are not matched\n pointsToAdd.push(pointOptions);\n }\n }, this);\n // Remove points that don't exist in the updated data set\n if (hasUpdatedByKey) {\n i = oldData.length;\n while (i--) {\n point = oldData[i];\n if (point && !point.touched && point.remove) {\n point.remove(false, animation);\n }\n }\n // If we did not find keys (ids or x-values), and the length is the\n // same, update one-to-one\n }\n else if (equalLength && (!dataSorting || !dataSorting.enabled)) {\n data.forEach(function (point, i) {\n // .update doesn't exist on a linked, hidden series (#3709)\n // (#10187)\n if (point !== oldData[i].y && (oldData[i].update)) {\n oldData[i].update(point, false, null, false);\n }\n });\n // Don't add new points since those configs are used above\n pointsToAdd.length = 0;\n // Did not succeed in updating data\n }\n else {\n succeeded = false;\n }\n oldData.forEach(function (point) {\n if (point) {\n point.touched = false;\n }\n });\n if (!succeeded) {\n return false;\n }\n // Add new points\n pointsToAdd.forEach(function (point) {\n this.addPoint(point, false, null, null, false);\n }, this);\n if (this.xIncrement === null &&\n this.xData &&\n this.xData.length) {\n this.xIncrement = arrayMax(this.xData);\n this.autoIncrement();\n }\n return true;\n };\n /**\n * Apply a new set of data to the series and optionally redraw it. The\n * new data array is passed by reference (except in case of\n * `updatePoints`), and may later be mutated when updating the chart\n * data.\n *\n * Note the difference in behaviour when setting the same amount of\n * points, or a different amount of points, as handled by the\n * `updatePoints` parameter.\n *\n * @sample highcharts/members/series-setdata/\n * Set new data from a button\n * @sample highcharts/members/series-setdata-pie/\n * Set data in a pie\n * @sample stock/members/series-setdata/\n * Set new data in Highcharts Stock\n * @sample maps/members/series-setdata/\n * Set new data in Highmaps\n *\n * @function Highcharts.Series#setData\n *\n * @param {Array} data\n * Takes an array of data in the same format as described under\n * `series.{type}.data` for the given series type, for example a\n * line series would take data in the form described under\n * [series.line.data](https://api.highcharts.com/highcharts/series.line.data).\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the series is altered. If\n * doing more operations on the chart, it is a good idea to set\n * redraw to false and call {@link Chart#redraw} after.\n *\n * @param {boolean|Partial} [animation]\n * When the updated data is the same length as the existing data,\n * points will be updated by default, and animation visualizes\n * how the points are changed. Set false to disable animation, or\n * a configuration object to set duration or easing.\n *\n * @param {boolean} [updatePoints=true]\n * When this is true, points will be updated instead of replaced\n * whenever possible. This occurs a) when the updated data is the\n * same length as the existing data, b) when points are matched\n * by their id's, or c) when points can be matched by X values.\n * This allows updating with animation and performs better. In\n * this case, the original array is not passed by reference. Set\n * `false` to prevent.\n */\n Series.prototype.setData = function (data, redraw, animation, updatePoints) {\n if (redraw === void 0) { redraw = true; }\n var series = this,\n oldData = series.points,\n oldDataLength = (oldData && oldData.length) || 0,\n options = series.options,\n chart = series.chart,\n dataSorting = options.dataSorting,\n xAxis = series.xAxis,\n turboThreshold = options.turboThreshold,\n xData = this.xData,\n yData = this.yData,\n pointArrayMap = series.pointArrayMap,\n valueCount = pointArrayMap && pointArrayMap.length,\n keys = options.keys;\n var i,\n pt,\n updatedData,\n indexOfX = 0,\n indexOfY = 1,\n firstPoint = null,\n copiedData;\n if (!chart.options.chart.allowMutatingData) { // #4259\n // Remove old reference\n if (options.data) {\n delete series.options.data;\n }\n if (series.userOptions.data) {\n delete series.userOptions.data;\n }\n copiedData = merge(true, data);\n }\n data = copiedData || data || [];\n var dataLength = data.length;\n if (dataSorting && dataSorting.enabled) {\n data = this.sortData(data);\n }\n // First try to run Point.update which is cheaper, allows animation,\n // and keeps references to points.\n if (chart.options.chart.allowMutatingData &&\n updatePoints !== false &&\n dataLength &&\n oldDataLength &&\n !series.cropped &&\n !series.hasGroupedData &&\n series.visible &&\n // Soft updating has no benefit in boost, and causes JS error\n // (#8355)\n !series.boosted) {\n updatedData = this.updateData(data, animation);\n }\n if (!updatedData) {\n // Reset properties\n series.xIncrement = null;\n series.colorCounter = 0; // for series with colorByPoint (#1547)\n // Update parallel arrays\n this.parallelArrays.forEach(function (key) {\n series[key + 'Data'].length = 0;\n });\n // In turbo mode, only one- or twodimensional arrays of numbers\n // are allowed. The first value is tested, and we assume that\n // all the rest are defined the same way. Although the 'for'\n // loops are similar, they are repeated inside each if-else\n // conditional for max performance.\n if (turboThreshold && dataLength > turboThreshold) {\n firstPoint = series.getFirstValidPoint(data);\n if (isNumber(firstPoint)) { // assume all points are numbers\n for (i = 0; i < dataLength; i++) {\n xData[i] = this.autoIncrement();\n yData[i] = data[i];\n }\n // Assume all points are arrays when first point is\n }\n else if (isArray(firstPoint)) {\n if (valueCount) { // [x, low, high] or [x, o, h, l, c]\n if (firstPoint.length === valueCount) {\n for (i = 0; i < dataLength; i++) {\n xData[i] = this.autoIncrement();\n yData[i] = data[i];\n }\n }\n else {\n for (i = 0; i < dataLength; i++) {\n pt = data[i];\n xData[i] = pt[0];\n yData[i] =\n pt.slice(1, valueCount + 1);\n }\n }\n }\n else { // [x, y]\n if (keys) {\n indexOfX = keys.indexOf('x');\n indexOfY = keys.indexOf('y');\n indexOfX = indexOfX >= 0 ? indexOfX : 0;\n indexOfY = indexOfY >= 0 ? indexOfY : 1;\n }\n if (firstPoint.length === 1) {\n indexOfY = 0;\n }\n if (indexOfX === indexOfY) {\n for (i = 0; i < dataLength; i++) {\n xData[i] = this.autoIncrement();\n yData[i] = data[i][indexOfY];\n }\n }\n else {\n for (i = 0; i < dataLength; i++) {\n pt = data[i];\n xData[i] = pt[indexOfX];\n yData[i] = pt[indexOfY];\n }\n }\n }\n }\n else {\n // Highcharts expects configs to be numbers or arrays in\n // turbo mode\n error(12, false, chart);\n }\n }\n else {\n for (i = 0; i < dataLength; i++) {\n // stray commas in oldIE:\n if (typeof data[i] !== 'undefined') {\n pt = { series: series };\n series.pointClass.prototype.applyOptions.apply(pt, [data[i]]);\n series.updateParallelArrays(pt, i);\n }\n }\n }\n // Forgetting to cast strings to numbers is a common caveat when\n // handling CSV or JSON\n if (yData && isString(yData[0])) {\n error(14, true, chart);\n }\n series.data = [];\n series.options.data = series.userOptions.data = data;\n // destroy old points\n i = oldDataLength;\n while (i--) {\n if (oldData[i] && (oldData[i].destroy)) {\n oldData[i].destroy();\n }\n }\n // reset minRange (#878)\n if (xAxis) {\n xAxis.minRange = xAxis.userMinRange;\n }\n // redraw\n series.isDirty = chart.isDirtyBox = true;\n series.isDirtyData = !!oldData;\n animation = false;\n }\n // Typically for pie series, points need to be processed and\n // generated prior to rendering the legend\n if (options.legendType === 'point') {\n this.processData();\n this.generatePoints();\n }\n if (redraw) {\n chart.redraw(animation);\n }\n };\n /**\n * Internal function to sort series data\n *\n * @private\n * @function Highcharts.Series#sortData\n * @param {Array} data\n * Force data grouping.\n */\n Series.prototype.sortData = function (data) {\n var series = this,\n options = series.options,\n dataSorting = options.dataSorting,\n sortKey = dataSorting.sortKey || 'y',\n getPointOptionsObject = function (series,\n pointOptions) {\n return (defined(pointOptions) &&\n series.pointClass.prototype.optionsToObject.call({\n series: series\n },\n pointOptions)) || {};\n };\n data.forEach(function (pointOptions, i) {\n data[i] = getPointOptionsObject(series, pointOptions);\n data[i].index = i;\n }, this);\n // Sorting\n var sortedData = data.concat().sort(function (a,\n b) {\n var aValue = getNestedProperty(sortKey,\n a);\n var bValue = getNestedProperty(sortKey,\n b);\n return bValue < aValue ? -1 : bValue > aValue ? 1 : 0;\n });\n // Set x value depending on the position in the array\n sortedData.forEach(function (point, i) {\n point.x = i;\n }, this);\n // Set the same x for linked series points if they don't have their\n // own sorting\n if (series.linkedSeries) {\n series.linkedSeries.forEach(function (linkedSeries) {\n var options = linkedSeries.options,\n seriesData = options.data;\n if ((!options.dataSorting ||\n !options.dataSorting.enabled) &&\n seriesData) {\n seriesData.forEach(function (pointOptions, i) {\n seriesData[i] = getPointOptionsObject(linkedSeries, pointOptions);\n if (data[i]) {\n seriesData[i].x = data[i].x;\n seriesData[i].index = i;\n }\n });\n linkedSeries.setData(seriesData, false);\n }\n });\n }\n return data;\n };\n /**\n * Internal function to process the data by cropping away unused data\n * points if the series is longer than the crop threshold. This saves\n * computing time for large series.\n *\n * @private\n * @function Highcharts.Series#getProcessedData\n * @param {boolean} [forceExtremesFromAll]\n * Force getting extremes of a total series data range.\n */\n Series.prototype.getProcessedData = function (forceExtremesFromAll) {\n var series = this,\n xAxis = series.xAxis,\n options = series.options,\n cropThreshold = options.cropThreshold,\n getExtremesFromAll = forceExtremesFromAll ||\n series.getExtremesFromAll ||\n options.getExtremesFromAll, // #4599\n isCartesian = series.isCartesian,\n val2lin = xAxis && xAxis.val2lin,\n isLog = !!(xAxis && xAxis.logarithmic);\n var croppedData,\n cropped,\n cropStart = 0,\n distance,\n closestPointRange,\n i, // loop variable\n xExtremes,\n min,\n max, \n // copied during slice operation:\n processedXData = series.xData,\n processedYData = series.yData,\n throwOnUnsorted = series.requireSorting,\n updatingNames = false;\n var dataLength = processedXData.length;\n if (xAxis) {\n // corrected for log axis (#3053)\n xExtremes = xAxis.getExtremes();\n min = xExtremes.min;\n max = xExtremes.max;\n updatingNames = !!(xAxis.categories && !xAxis.names.length);\n }\n // optionally filter out points outside the plot area\n if (isCartesian &&\n series.sorted &&\n !getExtremesFromAll &&\n (!cropThreshold ||\n dataLength > cropThreshold ||\n series.forceCrop)) {\n // it's outside current extremes\n if (processedXData[dataLength - 1] < min ||\n processedXData[0] > max) {\n processedXData = [];\n processedYData = [];\n // only crop if it's actually spilling out\n }\n else if (series.yData && (processedXData[0] < min ||\n processedXData[dataLength - 1] > max)) {\n croppedData = this.cropData(series.xData, series.yData, min, max);\n processedXData = croppedData.xData;\n processedYData = croppedData.yData;\n cropStart = croppedData.start;\n cropped = true;\n }\n }\n // Find the closest distance between processed points\n i = processedXData.length || 1;\n while (--i) {\n distance = (isLog ?\n (val2lin(processedXData[i]) -\n val2lin(processedXData[i - 1])) :\n (processedXData[i] -\n processedXData[i - 1]));\n if (distance > 0 &&\n (typeof closestPointRange === 'undefined' ||\n distance < closestPointRange)) {\n closestPointRange = distance;\n // Unsorted data is not supported by the line tooltip, as well\n // as data grouping and navigation in Stock charts (#725) and\n // width calculation of columns (#1900).\n // Avoid warning during the premature processing pass in\n // updateNames (#16104).\n }\n else if (distance < 0 && throwOnUnsorted && !updatingNames) {\n error(15, false, series.chart);\n throwOnUnsorted = false; // Only once\n }\n }\n return {\n xData: processedXData,\n yData: processedYData,\n cropped: cropped,\n cropStart: cropStart,\n closestPointRange: closestPointRange\n };\n };\n /**\n * Internal function to apply processed data.\n * In Highcharts Stock, this function is extended to provide data grouping.\n *\n * @private\n * @function Highcharts.Series#processData\n * @param {boolean} [force]\n * Force data grouping.\n */\n Series.prototype.processData = function (force) {\n var series = this,\n xAxis = series.xAxis;\n // If the series data or axes haven't changed, don't go through\n // this. Return false to pass the message on to override methods\n // like in data grouping.\n if (series.isCartesian &&\n !series.isDirty &&\n !xAxis.isDirty &&\n !series.yAxis.isDirty &&\n !force) {\n return false;\n }\n var processedData = series.getProcessedData();\n // Record the properties\n series.cropped = processedData.cropped; // undefined or true\n series.cropStart = processedData.cropStart;\n series.processedXData = processedData.xData;\n series.processedYData = processedData.yData;\n series.closestPointRange = (series.basePointRange = processedData.closestPointRange);\n fireEvent(series, 'afterProcessData');\n };\n /**\n * Iterate over xData and crop values between min and max. Returns\n * object containing crop start/end cropped xData with corresponding\n * part of yData, dataMin and dataMax within the cropped range.\n *\n * @private\n * @function Highcharts.Series#cropData\n */\n Series.prototype.cropData = function (xData, yData, min, max, cropShoulder) {\n var dataLength = xData.length;\n var i,\n j,\n cropStart = 0,\n cropEnd = dataLength;\n // line-type series need one point outside\n cropShoulder = pick(cropShoulder, this.cropShoulder);\n // iterate up to find slice start\n for (i = 0; i < dataLength; i++) {\n if (xData[i] >= min) {\n cropStart = Math.max(0, i - cropShoulder);\n break;\n }\n }\n // proceed to find slice end\n for (j = i; j < dataLength; j++) {\n if (xData[j] > max) {\n cropEnd = j + cropShoulder;\n break;\n }\n }\n return {\n xData: xData.slice(cropStart, cropEnd),\n yData: yData.slice(cropStart, cropEnd),\n start: cropStart,\n end: cropEnd\n };\n };\n /**\n * Generate the data point after the data has been processed by cropping\n * away unused points and optionally grouped in Highcharts Stock.\n *\n * @private\n * @function Highcharts.Series#generatePoints\n */\n Series.prototype.generatePoints = function () {\n var series = this,\n options = series.options,\n dataOptions = (series.processedData || options.data),\n processedXData = series.processedXData,\n processedYData = series.processedYData,\n PointClass = series.pointClass,\n processedDataLength = processedXData.length,\n cropStart = series.cropStart || 0,\n hasGroupedData = series.hasGroupedData,\n keys = options.keys,\n points = [],\n groupCropStartIndex = (options.dataGrouping &&\n options.dataGrouping.groupAll ?\n cropStart :\n 0);\n var dataLength,\n cursor,\n point,\n i,\n data = series.data;\n if (!data && !hasGroupedData) {\n var arr = [];\n arr.length = dataOptions.length;\n data = series.data = arr;\n }\n if (keys && hasGroupedData) {\n // grouped data has already applied keys (#6590)\n series.options.keys = false;\n }\n for (i = 0; i < processedDataLength; i++) {\n cursor = cropStart + i;\n if (!hasGroupedData) {\n point = data[cursor];\n // #970:\n if (!point &&\n typeof dataOptions[cursor] !== 'undefined') {\n data[cursor] = point = (new PointClass()).init(series, dataOptions[cursor], processedXData[i]);\n }\n }\n else {\n // splat the y data in case of ohlc data array\n point = (new PointClass()).init(series, [processedXData[i]].concat(splat(processedYData[i])));\n point.dataGroup = series.groupMap[groupCropStartIndex + i];\n if (point.dataGroup.options) {\n point.options = point.dataGroup.options;\n extend(point, point.dataGroup.options);\n // Collision of props and options (#9770)\n delete point.dataLabels;\n }\n }\n if (point) { // #6279\n /**\n * Contains the point's index in the `Series.points` array.\n *\n * @name Highcharts.Point#index\n * @type {number}\n * @readonly\n */\n // For faster access in Point.update\n point.index = hasGroupedData ?\n (groupCropStartIndex + i) : cursor;\n points[i] = point;\n }\n }\n // restore keys options (#6590)\n series.options.keys = keys;\n // Hide cropped-away points - this only runs when the number of\n // points is above cropThreshold, or when swithching view from\n // non-grouped data to grouped data (#637)\n if (data &&\n (processedDataLength !== (dataLength = data.length) ||\n hasGroupedData)) {\n for (i = 0; i < dataLength; i++) {\n // when has grouped data, clear all points\n if (i === cropStart && !hasGroupedData) {\n i += processedDataLength;\n }\n if (data[i]) {\n data[i].destroyElements();\n data[i].plotX = void 0; // #1003\n }\n }\n }\n /**\n * Read only. An array containing those values converted to points.\n * In case the series data length exceeds the `cropThreshold`, or if\n * the data is grouped, `series.data` doesn't contain all the\n * points. Also, in case a series is hidden, the `data` array may be\n * empty. To access raw values, `series.options.data` will always be\n * up to date. `Series.data` only contains the points that have been\n * created on demand. To modify the data, use\n * {@link Highcharts.Series#setData} or\n * {@link Highcharts.Point#update}.\n *\n * @see Series.points\n *\n * @name Highcharts.Series#data\n * @type {Array}\n */\n series.data = data;\n /**\n * An array containing all currently visible point objects. In case\n * of cropping, the cropped-away points are not part of this array.\n * The `series.points` array starts at `series.cropStart` compared\n * to `series.data` and `series.options.data`. If however the series\n * data is grouped, these can't be correlated one to one. To modify\n * the data, use {@link Highcharts.Series#setData} or\n * {@link Highcharts.Point#update}.\n *\n * @name Highcharts.Series#points\n * @type {Array}\n */\n series.points = points;\n fireEvent(this, 'afterGeneratePoints');\n };\n /**\n * Get current X extremes for the visible data.\n *\n * @private\n * @function Highcharts.Series#getXExtremes\n * @param {Array} xData\n * The data to inspect. Defaults to the current data within the visible\n * range.\n */\n Series.prototype.getXExtremes = function (xData) {\n return {\n min: arrayMin(xData),\n max: arrayMax(xData)\n };\n };\n /**\n * Calculate Y extremes for the visible data. The result is returned\n * as an object with `dataMin` and `dataMax` properties.\n *\n * @private\n * @function Highcharts.Series#getExtremes\n * @param {Array} [yData]\n * The data to inspect. Defaults to the current data within the visible\n * range.\n * @param {boolean} [forceExtremesFromAll]\n * Force getting extremes of a total series data range.\n */\n Series.prototype.getExtremes = function (yData, forceExtremesFromAll) {\n var xAxis = this.xAxis,\n yAxis = this.yAxis,\n xData = this.processedXData || this.xData,\n activeYData = [], \n // Handle X outside the viewed area. This does not work with\n // non-sorted data like scatter (#7639).\n shoulder = this.requireSorting ? this.cropShoulder : 0,\n positiveValuesOnly = yAxis ? yAxis.positiveValuesOnly : false;\n // #2117, need to compensate for log X axis\n var xExtremes,\n validValue,\n withinRange,\n x,\n y,\n i,\n j,\n xMin = 0,\n xMax = 0,\n activeCounter = 0;\n yData = yData || this.stackedYData || this.processedYData || [];\n var yDataLength = yData.length;\n if (xAxis) {\n xExtremes = xAxis.getExtremes();\n xMin = xExtremes.min;\n xMax = xExtremes.max;\n }\n for (i = 0; i < yDataLength; i++) {\n x = xData[i];\n y = yData[i];\n // For points within the visible range, including the first\n // point outside the visible range (#7061), consider y extremes.\n validValue = ((isNumber(y) || isArray(y)) &&\n ((y.length || y > 0) || !positiveValuesOnly));\n withinRange = (forceExtremesFromAll ||\n this.getExtremesFromAll ||\n this.options.getExtremesFromAll ||\n this.cropped ||\n !xAxis || // for colorAxis support\n ((xData[i + shoulder] || x) >= xMin &&\n (xData[i - shoulder] || x) <= xMax));\n if (validValue && withinRange) {\n j = y.length;\n if (j) { // array, like ohlc or range data\n while (j--) {\n if (isNumber(y[j])) { // #7380, #11513\n activeYData[activeCounter++] = y[j];\n }\n }\n }\n else {\n activeYData[activeCounter++] = y;\n }\n }\n }\n var dataExtremes = {\n activeYData: activeYData,\n dataMin: arrayMin(activeYData),\n dataMax: arrayMax(activeYData)\n };\n fireEvent(this, 'afterGetExtremes', { dataExtremes: dataExtremes });\n return dataExtremes;\n };\n /**\n * Set the current data extremes as `dataMin` and `dataMax` on the\n * Series item. Use this only when the series properties should be\n * updated.\n *\n * @private\n * @function Highcharts.Series#applyExtremes\n */\n Series.prototype.applyExtremes = function () {\n var dataExtremes = this.getExtremes();\n /**\n * Contains the minimum value of the series' data point. Some series\n * types like `networkgraph` do not support this property as they\n * lack a `y`-value.\n * @name Highcharts.Series#dataMin\n * @type {number|undefined}\n * @readonly\n */\n this.dataMin = dataExtremes.dataMin;\n /**\n * Contains the maximum value of the series' data point. Some series\n * types like `networkgraph` do not support this property as they\n * lack a `y`-value.\n * @name Highcharts.Series#dataMax\n * @type {number|undefined}\n * @readonly\n */\n this.dataMax = dataExtremes.dataMax;\n return dataExtremes;\n };\n /**\n * Find and return the first non null point in the data\n *\n * @private\n * @function Highcharts.Series.getFirstValidPoint\n * @param {Array} data\n * Array of options for points\n */\n Series.prototype.getFirstValidPoint = function (data) {\n var dataLength = data.length;\n var i = 0,\n firstPoint = null;\n while (firstPoint === null && i < dataLength) {\n firstPoint = data[i];\n i++;\n }\n return firstPoint;\n };\n /**\n * Translate data points from raw data values to chart specific\n * positioning data needed later in the `drawPoints` and `drawGraph`\n * functions. This function can be overridden in plugins and custom\n * series type implementations.\n *\n * @function Highcharts.Series#translate\n *\n * @emits Highcharts.Series#events:translate\n */\n Series.prototype.translate = function () {\n if (!this.processedXData) { // hidden series\n this.processData();\n }\n this.generatePoints();\n var series = this,\n options = series.options,\n stacking = options.stacking,\n xAxis = series.xAxis,\n categories = xAxis.categories,\n enabledDataSorting = series.enabledDataSorting,\n yAxis = series.yAxis,\n points = series.points,\n dataLength = points.length,\n pointPlacement = series.pointPlacementToXValue(), // #7860\n dynamicallyPlaced = Boolean(pointPlacement),\n threshold = options.threshold,\n stackThreshold = options.startFromThreshold ? threshold : 0,\n zoneAxis = this.zoneAxis || 'y';\n var i,\n plotX,\n lastPlotX,\n stackIndicator,\n closestPointRangePx = Number.MAX_VALUE;\n /**\n * Plotted coordinates need to be within a limited range. Drawing\n * too far outside the viewport causes various rendering issues\n * (#3201, #3923, #7555).\n * @private\n */\n function limitedRange(val) {\n return clamp(val, -1e5, 1e5);\n }\n // Translate each point\n for (i = 0; i < dataLength; i++) {\n var point = points[i],\n xValue = point.x;\n var pointStack = void 0,\n stackValues = void 0,\n yValue = point.y,\n yBottom = point.low;\n var stack = stacking && yAxis.stacking && yAxis.stacking.stacks[(series.negStacks &&\n yValue <\n (stackThreshold ? 0 : threshold) ?\n '-' :\n '') + series.stackKey];\n if (yAxis.positiveValuesOnly &&\n !yAxis.validatePositiveValue(yValue) ||\n xAxis.positiveValuesOnly &&\n !xAxis.validatePositiveValue(xValue)) {\n point.isNull = true;\n }\n /**\n * The translated X value for the point in terms of pixels. Relative\n * to the X axis position if the series has one, otherwise relative\n * to the plot area. Depending on the series type this value might\n * not be defined.\n * @name Highcharts.Point#plotX\n * @type {number|undefined}\n */\n point.plotX = plotX = correctFloat(// #5236\n // Get the plotX translation\n limitedRange(xAxis.translate(// #3923\n xValue, 0, 0, 0, 1, pointPlacement, this.type === 'flags')) // #3923\n );\n // Calculate the bottom y value for stacked series\n if (stacking &&\n series.visible &&\n stack &&\n stack[xValue]) {\n stackIndicator = series.getStackIndicator(stackIndicator, xValue, series.index);\n if (!point.isNull) {\n pointStack = stack[xValue];\n stackValues =\n pointStack.points[stackIndicator.key];\n }\n }\n if (isArray(stackValues)) {\n yBottom = stackValues[0];\n yValue = stackValues[1];\n if (yBottom === stackThreshold &&\n stackIndicator.key ===\n stack[xValue].base) {\n yBottom = pick((isNumber(threshold) && threshold), yAxis.min);\n }\n // #1200, #1232\n if (yAxis.positiveValuesOnly && yBottom <= 0) {\n yBottom = null;\n }\n point.total = point.stackTotal = pointStack.total;\n point.percentage =\n pointStack.total &&\n (point.y / pointStack.total * 100);\n point.stackY = yValue;\n // Place the stack label\n // in case of variwide series (where widths of points are\n // different in most cases), stack labels are positioned\n // wrongly, so the call of the setOffset is omited here and\n // labels are correctly positioned later, at the end of the\n // variwide's translate function (#10962)\n if (!series.irregularWidths) {\n pointStack.setOffset(series.pointXOffset || 0, series.barW || 0);\n }\n }\n // Set translated yBottom or remove it\n point.yBottom = defined(yBottom) ?\n limitedRange(yAxis.translate(yBottom, 0, 1, 0, 1)) :\n null;\n // General hook, used for Highcharts Stock compare and cumulative\n if (series.dataModify) {\n yValue = series.dataModify.modifyValue(yValue, i);\n }\n // Set the the plotY value, reset it for redraws\n // #3201\n point.plotY = void 0;\n if (isNumber(yValue)) {\n var translated = yAxis.translate(yValue,\n false,\n true,\n false,\n true);\n if (typeof translated !== 'undefined') {\n /**\n * The translated Y value for the point in terms of pixels.\n * Relative to the Y axis position if the series has one,\n * otherwise relative to the plot area. Depending on the\n * series type this value might not be defined.\n * @name Highcharts.Point#plotY\n * @type {number|undefined}\n */\n point.plotY = limitedRange(translated);\n }\n }\n point.isInside = this.isPointInside(point);\n // Set client related positions for mouse tracking\n point.clientX = dynamicallyPlaced ?\n correctFloat(xAxis.translate(xValue, 0, 0, 0, 1, pointPlacement)) :\n plotX; // #1514, #5383, #5518\n // Negative points. For bubble charts, this means negative z\n // values (#9728)\n point.negative = point[zoneAxis] < (options[zoneAxis + 'Threshold'] ||\n threshold ||\n 0);\n // some API data\n point.category = pick(categories && categories[point.x], point.x);\n // Determine auto enabling of markers (#3635, #5099)\n if (!point.isNull && point.visible !== false) {\n if (typeof lastPlotX !== 'undefined') {\n closestPointRangePx = Math.min(closestPointRangePx, Math.abs(plotX - lastPlotX));\n }\n lastPlotX = plotX;\n }\n // Find point zone\n point.zone = this.zones.length ? point.getZone() : void 0;\n // Animate new points with data sorting\n if (!point.graphic && series.group && enabledDataSorting) {\n point.isNew = true;\n }\n }\n series.closestPointRangePx = closestPointRangePx;\n fireEvent(this, 'afterTranslate');\n };\n /**\n * Return the series points with null points filtered out.\n *\n * @function Highcharts.Series#getValidPoints\n *\n * @param {Array} [points]\n * The points to inspect, defaults to {@link Series.points}.\n *\n * @param {boolean} [insideOnly=false]\n * Whether to inspect only the points that are inside the visible view.\n *\n * @param {boolean} [allowNull=false]\n * Whether to allow null points to pass as valid points.\n *\n * @return {Array}\n * The valid points.\n */\n Series.prototype.getValidPoints = function (points, insideOnly, allowNull) {\n var chart = this.chart;\n // #3916, #5029, #5085\n return (points || this.points || []).filter(function (point) {\n if (insideOnly && !chart.isInsidePlot(point.plotX, point.plotY, { inverted: chart.inverted })) {\n return false;\n }\n return point.visible !== false &&\n (allowNull || !point.isNull);\n });\n };\n /**\n * Get the clipping for the series. Could be called for a series to\n * initiate animating the clip or to set the final clip (only width\n * and x).\n *\n * @private\n * @function Highcharts.Series#getClip\n */\n Series.prototype.getClipBox = function () {\n var _a = this,\n chart = _a.chart,\n xAxis = _a.xAxis,\n yAxis = _a.yAxis;\n // If no axes on the series, use global clipBox\n var seriesBox = merge(chart.clipBox);\n // Otherwise, use clipBox.width which is corrected for plotBorderWidth\n // and clipOffset\n if (xAxis && xAxis.len !== chart.plotSizeX) {\n seriesBox.width = xAxis.len;\n }\n if (yAxis && yAxis.len !== chart.plotSizeY) {\n seriesBox.height = yAxis.len;\n }\n return seriesBox;\n };\n /**\n * Get the shared clip key, creating it if it doesn't exist.\n *\n * @private\n * @function Highcharts.Series#getSharedClipKey\n */\n Series.prototype.getSharedClipKey = function () {\n this.sharedClipKey = (this.options.xAxis || 0) + ',' +\n (this.options.yAxis || 0);\n return this.sharedClipKey;\n };\n /**\n * Set the clipping for the series. For animated series the clip is later\n * modified.\n *\n * @private\n * @function Highcharts.Series#setClip\n */\n Series.prototype.setClip = function () {\n var _a = this,\n chart = _a.chart,\n group = _a.group,\n markerGroup = _a.markerGroup,\n sharedClips = chart.sharedClips,\n renderer = chart.renderer,\n clipBox = this.getClipBox(),\n sharedClipKey = this.getSharedClipKey(); // #4526\n var clipRect = sharedClips[sharedClipKey];\n // If a clipping rectangle for the same set of axes does not exist,\n // create it\n if (!clipRect) {\n sharedClips[sharedClipKey] = clipRect = renderer.clipRect(clipBox);\n // When setting chart size, or when the series is rendered again before\n // starting animating, in compliance to a responsive rule\n }\n else {\n clipRect.animate(clipBox);\n }\n if (group) {\n // When clip is false, reset to no clip after animation\n group.clip(this.options.clip === false ? void 0 : clipRect);\n }\n // Unclip temporary animation clip\n if (markerGroup) {\n markerGroup.clip();\n }\n };\n /**\n * Animate in the series. Called internally twice. First with the `init`\n * parameter set to true, which sets up the initial state of the\n * animation. Then when ready, it is called with the `init` parameter\n * undefined, in order to perform the actual animation.\n *\n * @function Highcharts.Series#animate\n *\n * @param {boolean} [init]\n * Initialize the animation.\n */\n Series.prototype.animate = function (init) {\n var _a = this, chart = _a.chart, group = _a.group, markerGroup = _a.markerGroup, inverted = chart.inverted, animation = animObject(this.options.animation), \n // The key for temporary animation clips\n animationClipKey = [\n this.getSharedClipKey(),\n animation.duration,\n animation.easing,\n animation.defer\n ].join(',');\n var animationClipRect = chart.sharedClips[animationClipKey],\n markerAnimationClipRect = chart.sharedClips[animationClipKey + 'm'];\n // Initialize the animation. Set up the clipping rectangle.\n if (init && group) {\n var clipBox = this.getClipBox();\n // Create temporary animation clips\n if (!animationClipRect) {\n clipBox.width = 0;\n if (inverted) {\n clipBox.x = chart.plotHeight;\n }\n animationClipRect = chart.renderer.clipRect(clipBox);\n chart.sharedClips[animationClipKey] = animationClipRect;\n var markerClipBox = {\n // Include the width of the first marker\n x: inverted ? (chart.plotSizeX || 0) + 99 : -99,\n y: inverted ? -chart.plotLeft : -chart.plotTop,\n width: 99,\n height: inverted ? chart.chartWidth : chart.chartHeight\n };\n markerAnimationClipRect = chart.renderer.clipRect(markerClipBox);\n chart.sharedClips[animationClipKey + 'm'] = markerAnimationClipRect;\n }\n else {\n // When height changes during animation, typically due to\n // responsive settings\n animationClipRect.attr('height', clipBox.height);\n }\n group.clip(animationClipRect);\n if (markerGroup) {\n markerGroup.clip(markerAnimationClipRect);\n }\n // Run the animation\n }\n else if (animationClipRect &&\n // Only first series in this pane\n !animationClipRect.hasClass('highcharts-animating')) {\n var finalBox = this.getClipBox(),\n step_1 = animation.step;\n // Only do this when there are actually markers\n if (markerGroup && markerGroup.element.childNodes.length) {\n // To provide as smooth animation as possible, update the marker\n // group clipping in steps of the main group animation\n animation.step = function (val, fx) {\n if (step_1) {\n step_1.apply(fx, arguments);\n }\n if (markerAnimationClipRect &&\n markerAnimationClipRect.element) {\n markerAnimationClipRect.attr(fx.prop, fx.prop === 'width' ? val + 99 : val);\n }\n };\n }\n animationClipRect\n .addClass('highcharts-animating')\n .animate(finalBox, animation);\n }\n };\n /**\n * This runs after animation to land on the final plot clipping.\n *\n * @private\n * @function Highcharts.Series#afterAnimate\n *\n * @emits Highcharts.Series#event:afterAnimate\n */\n Series.prototype.afterAnimate = function () {\n var _this = this;\n this.setClip();\n // Destroy temporary clip rectangles that are no longer in use\n objectEach(this.chart.sharedClips, function (clip, key, sharedClips) {\n if (clip && !_this.chart.container.querySelector(\"[clip-path=\\\"url(#\".concat(clip.id, \")\\\"]\"))) {\n clip.destroy();\n delete sharedClips[key];\n }\n });\n this.finishedAnimating = true;\n fireEvent(this, 'afterAnimate');\n };\n /**\n * Draw the markers for line-like series types, and columns or other\n * graphical representation for {@link Point} objects for other series\n * types. The resulting element is typically stored as\n * {@link Point.graphic}, and is created on the first call and updated\n * and moved on subsequent calls.\n *\n * @function Highcharts.Series#drawPoints\n */\n Series.prototype.drawPoints = function (points) {\n if (points === void 0) { points = this.points; }\n var series = this,\n chart = series.chart,\n options = series.options,\n seriesMarkerOptions = options.marker,\n markerGroup = (series[series.specialGroup] ||\n series.markerGroup),\n xAxis = series.xAxis,\n globallyEnabled = pick(seriesMarkerOptions.enabled, !xAxis || xAxis.isRadial ? true : null, \n // Use larger or equal as radius is null in bubbles (#6321)\n series.closestPointRangePx >= (seriesMarkerOptions.enabledThreshold *\n seriesMarkerOptions.radius));\n var i,\n point,\n graphic,\n verb,\n pointMarkerOptions,\n hasPointMarker,\n markerAttribs;\n if (seriesMarkerOptions.enabled !== false ||\n series._hasPointMarkers) {\n for (i = 0; i < points.length; i++) {\n point = points[i];\n graphic = point.graphic;\n verb = graphic ? 'animate' : 'attr';\n pointMarkerOptions = point.marker || {};\n hasPointMarker = !!point.marker;\n var shouldDrawMarker = ((globallyEnabled &&\n typeof pointMarkerOptions.enabled === 'undefined') || pointMarkerOptions.enabled) && !point.isNull && point.visible !== false;\n // only draw the point if y is defined\n if (shouldDrawMarker) {\n // Shortcuts\n var symbol = pick(pointMarkerOptions.symbol,\n series.symbol, 'rect');\n markerAttribs = series.markerAttribs(point, (point.selected && 'select'));\n // Set starting position for point sliding animation.\n if (series.enabledDataSorting) {\n point.startXPos = xAxis.reversed ?\n -(markerAttribs.width || 0) :\n xAxis.width;\n }\n var isInside = point.isInside !== false;\n if (graphic) { // update\n // Since the marker group isn't clipped, each\n // individual marker must be toggled\n graphic[isInside ? 'show' : 'hide'](isInside)\n .animate(markerAttribs);\n }\n else if (isInside &&\n ((markerAttribs.width || 0) > 0 || point.hasImage)) {\n /**\n * The graphic representation of the point.\n * Typically this is a simple shape, like a `rect`\n * for column charts or `path` for line markers, but\n * for some complex series types like boxplot or 3D\n * charts, the graphic may be a `g` element\n * containing other shapes. The graphic is generated\n * the first time {@link Series#drawPoints} runs,\n * and updated and moved on subsequent runs.\n *\n * @name Point#graphic\n * @type {SVGElement}\n */\n point.graphic = graphic = chart.renderer\n .symbol(symbol, markerAttribs.x, markerAttribs.y, markerAttribs.width, markerAttribs.height, hasPointMarker ?\n pointMarkerOptions :\n seriesMarkerOptions)\n .add(markerGroup);\n // Sliding animation for new points\n if (series.enabledDataSorting &&\n chart.hasRendered) {\n graphic.attr({\n x: point.startXPos\n });\n verb = 'animate';\n }\n }\n if (graphic && verb === 'animate') { // update\n // Since the marker group isn't clipped, each\n // individual marker must be toggled\n graphic[isInside ? 'show' : 'hide'](isInside)\n .animate(markerAttribs);\n }\n // Presentational attributes\n if (graphic && !chart.styledMode) {\n graphic[verb](series.pointAttribs(point, (point.selected && 'select')));\n }\n if (graphic) {\n graphic.addClass(point.getClassName(), true);\n }\n }\n else if (graphic) {\n point.graphic = graphic.destroy(); // #1269\n }\n }\n }\n };\n /**\n * Get non-presentational attributes for a point. Used internally for\n * both styled mode and classic. Can be overridden for different series\n * types.\n *\n * @see Series#pointAttribs\n *\n * @function Highcharts.Series#markerAttribs\n *\n * @param {Highcharts.Point} point\n * The Point to inspect.\n *\n * @param {string} [state]\n * The state, can be either `hover`, `select` or undefined.\n *\n * @return {Highcharts.SVGAttributes}\n * A hash containing those attributes that are not settable from CSS.\n */\n Series.prototype.markerAttribs = function (point, state) {\n var seriesOptions = this.options,\n seriesMarkerOptions = seriesOptions.marker,\n pointMarkerOptions = point.marker || {},\n symbol = (pointMarkerOptions.symbol ||\n seriesMarkerOptions.symbol);\n var seriesStateOptions,\n pointStateOptions,\n radius = pick(pointMarkerOptions.radius,\n seriesMarkerOptions && seriesMarkerOptions.radius);\n // Handle hover and select states\n if (state) {\n seriesStateOptions = seriesMarkerOptions.states[state];\n pointStateOptions = pointMarkerOptions.states &&\n pointMarkerOptions.states[state];\n radius = pick(pointStateOptions && pointStateOptions.radius, seriesStateOptions && seriesStateOptions.radius, radius && radius + (seriesStateOptions && seriesStateOptions.radiusPlus ||\n 0));\n }\n point.hasImage = symbol && symbol.indexOf('url') === 0;\n if (point.hasImage) {\n radius = 0; // and subsequently width and height is not set\n }\n var attribs = isNumber(radius) ? {\n // Math.floor for #1843:\n x: seriesOptions.crisp ?\n Math.floor(point.plotX - radius) :\n point.plotX - radius,\n y: point.plotY - radius\n } : {};\n if (radius) {\n attribs.width = attribs.height = 2 * radius;\n }\n return attribs;\n };\n /**\n * Internal function to get presentational attributes for each point.\n * Unlike {@link Series#markerAttribs}, this function should return\n * those attributes that can also be set in CSS. In styled mode,\n * `pointAttribs` won't be called.\n *\n * @private\n * @function Highcharts.Series#pointAttribs\n *\n * @param {Highcharts.Point} [point]\n * The point instance to inspect.\n *\n * @param {string} [state]\n * The point state, can be either `hover`, `select` or 'normal'. If\n * undefined, normal state is assumed.\n *\n * @return {Highcharts.SVGAttributes}\n * The presentational attributes to be set on the point.\n */\n Series.prototype.pointAttribs = function (point, state) {\n var seriesMarkerOptions = this.options.marker,\n pointOptions = point && point.options,\n pointMarkerOptions = ((pointOptions && pointOptions.marker) || {}),\n pointColorOption = pointOptions && pointOptions.color,\n pointColor = point && point.color,\n zoneColor = point && point.zone && point.zone.color;\n var seriesStateOptions,\n pointStateOptions,\n color = this.color,\n fill,\n stroke,\n strokeWidth = pick(pointMarkerOptions.lineWidth,\n seriesMarkerOptions.lineWidth),\n opacity = 1;\n color = (pointColorOption ||\n zoneColor ||\n pointColor ||\n color);\n fill = (pointMarkerOptions.fillColor ||\n seriesMarkerOptions.fillColor ||\n color);\n stroke = (pointMarkerOptions.lineColor ||\n seriesMarkerOptions.lineColor ||\n color);\n // Handle hover and select states\n state = state || 'normal';\n if (state) {\n seriesStateOptions = (seriesMarkerOptions.states[state] || {});\n pointStateOptions = (pointMarkerOptions.states &&\n pointMarkerOptions.states[state]) || {};\n strokeWidth = pick(pointStateOptions.lineWidth, seriesStateOptions.lineWidth, strokeWidth + pick(pointStateOptions.lineWidthPlus, seriesStateOptions.lineWidthPlus, 0));\n fill = (pointStateOptions.fillColor ||\n seriesStateOptions.fillColor ||\n fill);\n stroke = (pointStateOptions.lineColor ||\n seriesStateOptions.lineColor ||\n stroke);\n opacity = pick(pointStateOptions.opacity, seriesStateOptions.opacity, opacity);\n }\n return {\n 'stroke': stroke,\n 'stroke-width': strokeWidth,\n 'fill': fill,\n 'opacity': opacity\n };\n };\n /**\n * Clear DOM objects and free up memory.\n *\n * @private\n * @function Highcharts.Series#destroy\n *\n * @emits Highcharts.Series#event:destroy\n */\n Series.prototype.destroy = function (keepEventsForUpdate) {\n var series = this,\n chart = series.chart,\n issue134 = /AppleWebKit\\/533/.test(win.navigator.userAgent),\n data = series.data || [];\n var destroy,\n i,\n point,\n axis;\n // add event hook\n fireEvent(series, 'destroy', { keepEventsForUpdate: keepEventsForUpdate });\n // remove events\n this.removeEvents(keepEventsForUpdate);\n // erase from axes\n (series.axisTypes || []).forEach(function (AXIS) {\n axis = series[AXIS];\n if (axis && axis.series) {\n erase(axis.series, series);\n axis.isDirty = axis.forceRedraw = true;\n }\n });\n // remove legend items\n if (series.legendItem) {\n series.chart.legend.destroyItem(series);\n }\n // destroy all points with their elements\n i = data.length;\n while (i--) {\n point = data[i];\n if (point && point.destroy) {\n point.destroy();\n }\n }\n if (series.clips) {\n series.clips.forEach(function (clip) { return clip.destroy(); });\n }\n // Clear the animation timeout if we are destroying the series\n // during initial animation\n U.clearTimeout(series.animationTimeout);\n // Destroy all SVGElements associated to the series\n objectEach(series, function (val, prop) {\n // Survive provides a hook for not destroying\n if (val instanceof SVGElement && !val.survive) {\n // issue 134 workaround\n destroy = issue134 && prop === 'group' ?\n 'hide' :\n 'destroy';\n val[destroy]();\n }\n });\n // remove from hoverSeries\n if (chart.hoverSeries === series) {\n chart.hoverSeries = void 0;\n }\n erase(chart.series, series);\n chart.orderSeries();\n // clear all members\n objectEach(series, function (val, prop) {\n if (!keepEventsForUpdate || prop !== 'hcEvents') {\n delete series[prop];\n }\n });\n };\n /**\n * Clip the graphs into zones for colors and styling.\n *\n * @private\n * @function Highcharts.Series#applyZones\n */\n Series.prototype.applyZones = function () {\n var series = this,\n chart = this.chart,\n renderer = chart.renderer,\n zones = this.zones,\n clips = (this.clips || []),\n graph = this.graph,\n area = this.area,\n plotSizeMax = Math.max(chart.plotWidth,\n chart.plotHeight),\n axis = this[(this.zoneAxis || 'y') + 'Axis'],\n inverted = chart.inverted;\n var translatedFrom,\n translatedTo,\n clipAttr,\n extremes,\n reversed,\n horiz,\n pxRange,\n pxPosMin,\n pxPosMax,\n zoneArea,\n zoneGraph,\n ignoreZones = false;\n if (zones.length &&\n (graph || area) &&\n axis &&\n typeof axis.min !== 'undefined') {\n reversed = axis.reversed;\n horiz = axis.horiz;\n // The use of the Color Threshold assumes there are no gaps\n // so it is safe to hide the original graph and area\n // unless it is not waterfall series, then use showLine property\n // to set lines between columns to be visible (#7862)\n if (graph && !this.showLine) {\n graph.hide();\n }\n if (area) {\n area.hide();\n }\n // Create the clips\n extremes = axis.getExtremes();\n zones.forEach(function (threshold, i) {\n translatedFrom = reversed ?\n (horiz ? chart.plotWidth : 0) :\n (horiz ? 0 : (axis.toPixels(extremes.min) || 0));\n translatedFrom = clamp(pick(translatedTo, translatedFrom), 0, plotSizeMax);\n translatedTo = clamp(Math.round(axis.toPixels(pick(threshold.value, extremes.max), true) || 0), 0, plotSizeMax);\n if (ignoreZones) {\n translatedFrom = translatedTo =\n axis.toPixels(extremes.max);\n }\n pxRange = Math.abs(translatedFrom - translatedTo);\n pxPosMin = Math.min(translatedFrom, translatedTo);\n pxPosMax = Math.max(translatedFrom, translatedTo);\n if (axis.isXAxis) {\n clipAttr = {\n x: inverted ? pxPosMax : pxPosMin,\n y: 0,\n width: pxRange,\n height: plotSizeMax\n };\n if (!horiz) {\n clipAttr.x = chart.plotHeight - clipAttr.x;\n }\n }\n else {\n clipAttr = {\n x: 0,\n y: inverted ? pxPosMax : pxPosMin,\n width: plotSizeMax,\n height: pxRange\n };\n if (horiz) {\n clipAttr.y = chart.plotWidth - clipAttr.y;\n }\n }\n // VML SUPPPORT\n if (inverted && renderer.isVML) {\n if (axis.isXAxis) {\n clipAttr = {\n x: 0,\n y: reversed ? pxPosMin : pxPosMax,\n height: clipAttr.width,\n width: chart.chartWidth\n };\n }\n else {\n clipAttr = {\n x: (clipAttr.y -\n chart.plotLeft -\n chart.spacingBox.x),\n y: 0,\n width: clipAttr.height,\n height: chart.chartHeight\n };\n }\n }\n // END OF VML SUPPORT\n if (clips[i]) {\n clips[i].animate(clipAttr);\n }\n else {\n clips[i] = renderer.clipRect(clipAttr);\n }\n // when no data, graph zone is not applied and after setData\n // clip was ignored. As a result, it should be applied each\n // time.\n zoneArea = series['zone-area-' + i];\n zoneGraph = series['zone-graph-' + i];\n if (graph && zoneGraph) {\n zoneGraph.clip(clips[i]);\n }\n if (area && zoneArea) {\n zoneArea.clip(clips[i]);\n }\n // if this zone extends out of the axis, ignore the others\n ignoreZones = threshold.value > extremes.max;\n // Clear translatedTo for indicators\n if (series.resetZones && translatedTo === 0) {\n translatedTo = void 0;\n }\n });\n this.clips = clips;\n }\n else if (series.visible) {\n // If zones were removed, restore graph and area\n if (graph) {\n graph.show();\n }\n if (area) {\n area.show();\n }\n }\n };\n /**\n * Initialize and perform group inversion on series.group and\n * series.markerGroup.\n *\n * @private\n * @function Highcharts.Series#invertGroups\n */\n Series.prototype.invertGroups = function (inverted) {\n var series = this,\n chart = series.chart;\n /**\n * @private\n */\n function setInvert() {\n ['group', 'markerGroup'].forEach(function (groupName) {\n if (series[groupName]) {\n // VML/HTML needs explicit attributes for flipping\n if (chart.renderer.isVML) {\n series[groupName].attr({\n width: series.yAxis.len,\n height: series.xAxis.len\n });\n }\n series[groupName].width = series.yAxis.len;\n series[groupName].height = series.xAxis.len;\n // If inverted polar, don't invert series group\n series[groupName].invert(series.isRadialSeries ? false : inverted);\n }\n });\n }\n // Pie, go away (#1736)\n if (!series.xAxis) {\n return;\n }\n // A fixed size is needed for inversion to work\n series.eventsToUnbind.push(addEvent(chart, 'resize', setInvert));\n // Do it now\n setInvert();\n // On subsequent render and redraw, just do setInvert without\n // setting up events again\n series.invertGroups = setInvert;\n };\n /**\n * General abstraction for creating plot groups like series.group,\n * series.dataLabelsGroup and series.markerGroup. On subsequent calls,\n * the group will only be adjusted to the updated plot size.\n *\n * @private\n * @function Highcharts.Series#plotGroup\n */\n Series.prototype.plotGroup = function (prop, name, visibility, zIndex, parent) {\n var group = this[prop];\n var isNew = !group,\n attrs = {\n visibility: visibility,\n zIndex: zIndex || 0.1 // IE8 and pointer logic use this\n };\n // Avoid setting undefined opacity, or in styled mode\n if (typeof this.opacity !== 'undefined' &&\n !this.chart.styledMode && this.state !== 'inactive' // #13719\n ) {\n attrs.opacity = this.opacity;\n }\n // Generate it on first call\n if (isNew) {\n this[prop] = group = this.chart.renderer\n .g()\n .add(parent);\n }\n // Add the class names, and replace existing ones as response to\n // Series.update (#6660)\n group.addClass(('highcharts-' + name +\n ' highcharts-series-' + this.index +\n ' highcharts-' + this.type + '-series ' +\n (defined(this.colorIndex) ?\n 'highcharts-color-' + this.colorIndex + ' ' :\n '') +\n (this.options.className || '') +\n (group.hasClass('highcharts-tracker') ?\n ' highcharts-tracker' :\n '')), true);\n // Place it on first and subsequent (redraw) calls\n group.attr(attrs)[isNew ? 'attr' : 'animate'](this.getPlotBox());\n return group;\n };\n /**\n * Get the translation and scale for the plot area of this series.\n *\n * @function Highcharts.Series#getPlotBox\n */\n Series.prototype.getPlotBox = function () {\n var chart = this.chart;\n var xAxis = this.xAxis,\n yAxis = this.yAxis;\n // Swap axes for inverted (#2339)\n if (chart.inverted) {\n xAxis = yAxis;\n yAxis = this.xAxis;\n }\n return {\n translateX: xAxis ? xAxis.left : chart.plotLeft,\n translateY: yAxis ? yAxis.top : chart.plotTop,\n scaleX: 1,\n scaleY: 1\n };\n };\n /**\n * Removes the event handlers attached previously with addEvents.\n * @private\n * @function Highcharts.Series#removeEvents\n */\n Series.prototype.removeEvents = function (keepEventsForUpdate) {\n var series = this;\n if (!keepEventsForUpdate) {\n // remove all events\n removeEvent(series);\n }\n if (series.eventsToUnbind.length) {\n // remove only internal events for proper update\n // #12355 - solves problem with multiple destroy events\n series.eventsToUnbind.forEach(function (unbind) {\n unbind();\n });\n series.eventsToUnbind.length = 0;\n }\n };\n /**\n * Render the graph and markers. Called internally when first rendering\n * and later when redrawing the chart. This function can be extended in\n * plugins, but normally shouldn't be called directly.\n *\n * @function Highcharts.Series#render\n *\n * @emits Highcharts.Series#event:afterRender\n */\n Series.prototype.render = function () {\n var series = this,\n chart = series.chart,\n options = series.options,\n animOptions = animObject(options.animation),\n visibility = series.visible ?\n 'inherit' : 'hidden', // #2597\n zIndex = options.zIndex,\n hasRendered = series.hasRendered,\n chartSeriesGroup = chart.seriesGroup,\n inverted = chart.inverted;\n // Animation doesn't work in IE8 quirks when the group div is\n // hidden, and looks bad in other oldIE\n var animDuration = (!series.finishedAnimating && chart.renderer.isSVG) ?\n animOptions.duration : 0;\n fireEvent(this, 'render');\n // the group\n var group = series.plotGroup('group', 'series', visibility, zIndex, chartSeriesGroup);\n series.markerGroup = series.plotGroup('markerGroup', 'markers', visibility, zIndex, chartSeriesGroup);\n // Initial clipping, applies to columns etc. (#3839).\n if (options.clip !== false) {\n series.setClip();\n }\n // Initialize the animation\n if (series.animate && animDuration) {\n series.animate(true);\n }\n // SVGRenderer needs to know this before drawing elements (#1089,\n // #1795)\n group.inverted = pick(series.invertible, series.isCartesian) ?\n inverted : false;\n // Draw the graph if any\n if (series.drawGraph) {\n series.drawGraph();\n series.applyZones();\n }\n // Draw the points\n if (series.visible) {\n series.drawPoints();\n }\n // Draw the data labels\n if (series.drawDataLabels) {\n series.drawDataLabels();\n }\n // In pie charts, slices are added to the DOM, but actual rendering\n // is postponed until labels reserved their space\n if (series.redrawPoints) {\n series.redrawPoints();\n }\n // draw the mouse tracking area\n if (series.drawTracker &&\n series.options.enableMouseTracking !== false) {\n series.drawTracker();\n }\n // Handle inverted series and tracker groups\n series.invertGroups(inverted);\n // Run the animation\n if (series.animate && animDuration) {\n series.animate();\n }\n // Call the afterAnimate function on animation complete (but don't\n // overwrite the animation.complete option which should be available\n // to the user).\n if (!hasRendered) {\n // Additional time if defer is defined before afterAnimate\n // will be triggered\n if (animDuration && animOptions.defer) {\n animDuration += animOptions.defer;\n }\n series.animationTimeout = syncTimeout(function () {\n series.afterAnimate();\n }, animDuration || 0);\n }\n // Means data is in accordance with what you see\n series.isDirty = false;\n // (See #322) series.isDirty = series.isDirtyData = false; // means\n // data is in accordance with what you see\n series.hasRendered = true;\n fireEvent(series, 'afterRender');\n };\n /**\n * Redraw the series. This function is called internally from\n * `chart.redraw` and normally shouldn't be called directly.\n * @private\n * @function Highcharts.Series#redraw\n */\n Series.prototype.redraw = function () {\n var series = this,\n chart = series.chart, \n // cache it here as it is set to false in render, but used after\n wasDirty = series.isDirty || series.isDirtyData,\n group = series.group,\n xAxis = series.xAxis,\n yAxis = series.yAxis;\n // reposition on resize\n if (group) {\n if (chart.inverted) {\n group.attr({\n width: chart.plotWidth,\n height: chart.plotHeight\n });\n }\n group.animate({\n translateX: pick(xAxis && xAxis.left, chart.plotLeft),\n translateY: pick(yAxis && yAxis.top, chart.plotTop)\n });\n }\n series.translate();\n series.render();\n if (wasDirty) { // #3868, #3945\n delete this.kdTree;\n }\n };\n /**\n * Find the nearest point from a pointer event. This applies to series that\n * use k-d-trees to get the nearest point. Native pointer events must be\n * normalized using `Pointer.normalize`, that adds `chartX` and `chartY`\n * properties.\n *\n * @sample highcharts/demo/synchronized-charts\n * Synchronized charts with tooltips\n *\n * @function Highcharts.Series#searchPoint\n *\n * @param {Highcharts.PointerEvent} e\n * The normalized pointer event\n * @param {boolean} [compareX=false]\n * Search only by the X value, not Y\n *\n * @return {Point|undefined}\n * The closest point to the pointer event\n */\n Series.prototype.searchPoint = function (e, compareX) {\n var series = this,\n xAxis = series.xAxis,\n yAxis = series.yAxis,\n inverted = series.chart.inverted;\n return this.searchKDTree({\n clientX: inverted ?\n xAxis.len - e.chartY + xAxis.pos :\n e.chartX - xAxis.pos,\n plotY: inverted ?\n yAxis.len - e.chartX + yAxis.pos :\n e.chartY - yAxis.pos\n }, compareX, e);\n };\n /**\n * Build the k-d-tree that is used by mouse and touch interaction to get\n * the closest point. Line-like series typically have a one-dimensional\n * tree where points are searched along the X axis, while scatter-like\n * series typically search in two dimensions, X and Y.\n *\n * @private\n * @function Highcharts.Series#buildKDTree\n */\n Series.prototype.buildKDTree = function (e) {\n // Prevent multiple k-d-trees from being built simultaneously\n // (#6235)\n this.buildingKdTree = true;\n var series = this,\n dimensions = series.options.findNearestPointBy\n .indexOf('y') > -1 ? 2 : 1;\n /**\n * Internal function\n * @private\n */\n function _kdtree(points, depth, dimensions) {\n var length = points && points.length;\n var axis,\n median;\n if (length) {\n // alternate between the axis\n axis = series.kdAxisArray[depth % dimensions];\n // sort point array\n points.sort(function (a, b) {\n return a[axis] - b[axis];\n });\n median = Math.floor(length / 2);\n // build and return nod\n return {\n point: points[median],\n left: _kdtree(points.slice(0, median), depth + 1, dimensions),\n right: _kdtree(points.slice(median + 1), depth + 1, dimensions)\n };\n }\n }\n /**\n * Start the recursive build process with a clone of the points\n * array and null points filtered out. (#3873)\n * @private\n */\n function startRecursive() {\n series.kdTree = _kdtree(series.getValidPoints(null, \n // For line-type series restrict to plot area, but\n // column-type series not (#3916, #4511)\n !series.directTouch), dimensions, dimensions);\n series.buildingKdTree = false;\n }\n delete series.kdTree;\n // For testing tooltips, don't build async. Also if touchstart, we\n // may be dealing with click events on mobile, so don't delay\n // (#6817).\n syncTimeout(startRecursive, series.options.kdNow || (e && e.type === 'touchstart') ? 0 : 1);\n };\n /**\n * @private\n * @function Highcharts.Series#searchKDTree\n */\n Series.prototype.searchKDTree = function (point, compareX, e) {\n var series = this,\n kdX = this.kdAxisArray[0],\n kdY = this.kdAxisArray[1],\n kdComparer = compareX ? 'distX' : 'dist',\n kdDimensions = series.options.findNearestPointBy\n .indexOf('y') > -1 ? 2 : 1;\n /**\n * Set the one and two dimensional distance on the point object.\n * @private\n */\n function setDistance(p1, p2) {\n var x = (defined(p1[kdX]) &&\n defined(p2[kdX])) ?\n Math.pow(p1[kdX] - p2[kdX], 2) :\n null,\n y = (defined(p1[kdY]) &&\n defined(p2[kdY])) ?\n Math.pow(p1[kdY] - p2[kdY], 2) :\n null,\n r = (x || 0) + (y || 0);\n p2.dist = defined(r) ? Math.sqrt(r) : Number.MAX_VALUE;\n p2.distX = defined(x) ? Math.sqrt(x) : Number.MAX_VALUE;\n }\n /**\n * @private\n */\n function _search(search, tree, depth, dimensions) {\n var point = tree.point,\n axis = series.kdAxisArray[depth % dimensions];\n var nPoint1,\n nPoint2,\n ret = point;\n setDistance(search, point);\n // Pick side based on distance to splitting point\n var tdist = search[axis] - point[axis], sideA = tdist < 0 ? 'left' : 'right', sideB = tdist < 0 ? 'right' : 'left';\n // End of tree\n if (tree[sideA]) {\n nPoint1 = _search(search, tree[sideA], depth + 1, dimensions);\n ret = (nPoint1[kdComparer] <\n ret[kdComparer] ?\n nPoint1 :\n point);\n }\n if (tree[sideB]) {\n // compare distance to current best to splitting point to\n // decide whether to check side B or not\n if (Math.sqrt(tdist * tdist) < ret[kdComparer]) {\n nPoint2 = _search(search, tree[sideB], depth + 1, dimensions);\n ret = (nPoint2[kdComparer] <\n ret[kdComparer] ?\n nPoint2 :\n ret);\n }\n }\n return ret;\n }\n if (!this.kdTree && !this.buildingKdTree) {\n this.buildKDTree(e);\n }\n if (this.kdTree) {\n return _search(point, this.kdTree, kdDimensions, kdDimensions);\n }\n };\n /**\n * @private\n * @function Highcharts.Series#pointPlacementToXValue\n */\n Series.prototype.pointPlacementToXValue = function () {\n var _a = this,\n _b = _a.options,\n pointPlacement = _b.pointPlacement,\n pointRange = _b.pointRange,\n axis = _a.xAxis;\n var factor = pointPlacement;\n // Point placement is relative to each series pointRange (#5889)\n if (factor === 'between') {\n factor = axis.reversed ? -0.5 : 0.5; // #11955\n }\n return isNumber(factor) ?\n factor * (pointRange || axis.pointRange) :\n 0;\n };\n /**\n * @private\n * @function Highcharts.Series#isPointInside\n */\n Series.prototype.isPointInside = function (point) {\n var _a = this,\n chart = _a.chart,\n xAxis = _a.xAxis,\n yAxis = _a.yAxis,\n isInside = (typeof point.plotY !== 'undefined' &&\n typeof point.plotX !== 'undefined' &&\n point.plotY >= 0 &&\n point.plotY <= (yAxis ? yAxis.len : chart.plotHeight) &&\n point.plotX >= 0 &&\n point.plotX <= (xAxis ? xAxis.len : chart.plotWidth));\n return isInside;\n };\n /**\n * Draw the tracker object that sits above all data labels and markers to\n * track mouse events on the graph or points. For the line type charts\n * the tracker uses the same graphPath, but with a greater stroke width\n * for better control.\n * @private\n */\n Series.prototype.drawTracker = function () {\n var series = this,\n options = series.options,\n trackByArea = options.trackByArea,\n trackerPath = [].concat(trackByArea ?\n series.areaPath :\n series.graphPath), \n // trackerPathLength = trackerPath.length,\n chart = series.chart,\n pointer = chart.pointer,\n renderer = chart.renderer,\n snap = chart.options.tooltip.snap,\n tracker = series.tracker,\n onMouseOver = function (e) {\n if (chart.hoverSeries !== series) {\n series.onMouseOver();\n }\n }, \n /*\n * Empirical lowest possible opacities for TRACKER_FILL for an\n * element to stay invisible but clickable\n * IE6: 0.002\n * IE7: 0.002\n * IE8: 0.002\n * IE9: 0.00000000001 (unlimited)\n * IE10: 0.0001 (exporting only)\n * FF: 0.00000000001 (unlimited)\n * Chrome: 0.000001\n * Safari: 0.000001\n * Opera: 0.00000000001 (unlimited)\n */\n TRACKER_FILL = 'rgba(192,192,192,' + (svg ? 0.0001 : 0.002) + ')';\n var i;\n // Draw the tracker\n if (tracker) {\n tracker.attr({ d: trackerPath });\n }\n else if (series.graph) { // create\n series.tracker = renderer.path(trackerPath)\n .attr({\n visibility: series.visible ? 'inherit' : 'hidden',\n zIndex: 2\n })\n .addClass(trackByArea ?\n 'highcharts-tracker-area' :\n 'highcharts-tracker-line')\n .add(series.group);\n if (!chart.styledMode) {\n series.tracker.attr({\n 'stroke-linecap': 'round',\n 'stroke-linejoin': 'round',\n stroke: TRACKER_FILL,\n fill: trackByArea ? TRACKER_FILL : 'none',\n 'stroke-width': series.graph.strokeWidth() +\n (trackByArea ? 0 : 2 * snap)\n });\n }\n // The tracker is added to the series group, which is clipped, but\n // is covered by the marker group. So the marker group also needs to\n // capture events.\n [\n series.tracker,\n series.markerGroup,\n series.dataLabelsGroup\n ].forEach(function (tracker) {\n if (tracker) {\n tracker.addClass('highcharts-tracker')\n .on('mouseover', onMouseOver)\n .on('mouseout', function (e) {\n pointer.onTrackerMouseOut(e);\n });\n if (options.cursor && !chart.styledMode) {\n tracker.css({ cursor: options.cursor });\n }\n if (hasTouch) {\n tracker.on('touchstart', onMouseOver);\n }\n }\n });\n }\n fireEvent(this, 'afterDrawTracker');\n };\n /**\n * Add a point to the series after render time. The point can be added at\n * the end, or by giving it an X value, to the start or in the middle of the\n * series.\n *\n * @sample highcharts/members/series-addpoint-append/\n * Append point\n * @sample highcharts/members/series-addpoint-append-and-shift/\n * Append and shift\n * @sample highcharts/members/series-addpoint-x-and-y/\n * Both X and Y values given\n * @sample highcharts/members/series-addpoint-pie/\n * Append pie slice\n * @sample stock/members/series-addpoint/\n * Append 100 points in Highcharts Stock\n * @sample stock/members/series-addpoint-shift/\n * Append and shift in Highcharts Stock\n * @sample maps/members/series-addpoint/\n * Add a point in Highmaps\n *\n * @function Highcharts.Series#addPoint\n *\n * @param {Highcharts.PointOptionsType} options\n * The point options. If options is a single number, a point with\n * that y value is appended to the series. If it is an array, it will\n * be interpreted as x and y values respectively. If it is an\n * object, advanced options as outlined under `series.data` are\n * applied.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the point is added. When adding\n * more than one point, it is highly recommended that the redraw\n * option be set to false, and instead {@link Chart#redraw} is\n * explicitly called after the adding of points is finished.\n * Otherwise, the chart will redraw after adding each point.\n *\n * @param {boolean} [shift=false]\n * If true, a point is shifted off the start of the series as one is\n * appended to the end.\n *\n * @param {boolean|Partial} [animation]\n * Whether to apply animation, and optionally animation\n * configuration.\n *\n * @param {boolean} [withEvent=true]\n * Used internally, whether to fire the series `addPoint` event.\n *\n * @emits Highcharts.Series#event:addPoint\n */\n Series.prototype.addPoint = function (options, redraw, shift, animation, withEvent) {\n var series = this,\n seriesOptions = series.options,\n data = series.data,\n chart = series.chart,\n xAxis = series.xAxis,\n names = xAxis && xAxis.hasNames && xAxis.names,\n dataOptions = seriesOptions.data,\n xData = series.xData;\n var isInTheMiddle,\n i;\n // Optional redraw, defaults to true\n redraw = pick(redraw, true);\n // Get options and push the point to xData, yData and series.options. In\n // series.generatePoints the Point instance will be created on demand\n // and pushed to the series.data array.\n var point = { series: series };\n series.pointClass.prototype.applyOptions.apply(point, [options]);\n var x = point.x;\n // Get the insertion point\n i = xData.length;\n if (series.requireSorting && x < xData[i - 1]) {\n isInTheMiddle = true;\n while (i && xData[i - 1] > x) {\n i--;\n }\n }\n // Insert undefined item\n series.updateParallelArrays(point, 'splice', i, 0, 0);\n // Update it\n series.updateParallelArrays(point, i);\n if (names && point.name) {\n names[x] = point.name;\n }\n dataOptions.splice(i, 0, options);\n if (isInTheMiddle ||\n // When processedData is present we need to splice an empty slot\n // into series.data, otherwise generatePoints won't pick it up.\n series.processedData) {\n series.data.splice(i, 0, null);\n series.processData();\n }\n // Generate points to be added to the legend (#1329)\n if (seriesOptions.legendType === 'point') {\n series.generatePoints();\n }\n // Shift the first point off the parallel arrays\n if (shift) {\n if (data[0] && (data[0].remove)) {\n data[0].remove(false);\n }\n else {\n data.shift();\n series.updateParallelArrays(point, 'shift');\n dataOptions.shift();\n }\n }\n // Fire event\n if (withEvent !== false) {\n fireEvent(series, 'addPoint', { point: point });\n }\n // redraw\n series.isDirty = true;\n series.isDirtyData = true;\n if (redraw) {\n chart.redraw(animation); // Animation is set anyway on redraw, #5665\n }\n };\n /**\n * Remove a point from the series. Unlike the\n * {@link Highcharts.Point#remove} method, this can also be done on a point\n * that is not instanciated because it is outside the view or subject to\n * Highcharts Stock data grouping.\n *\n * @sample highcharts/members/series-removepoint/\n * Remove cropped point\n *\n * @function Highcharts.Series#removePoint\n *\n * @param {number} i\n * The index of the point in the {@link Highcharts.Series.data|data}\n * array.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the point is added. When\n * removing more than one point, it is highly recommended that the\n * `redraw` option be set to `false`, and instead {@link\n * Highcharts.Chart#redraw} is explicitly called after the adding of\n * points is finished.\n *\n * @param {boolean|Partial} [animation]\n * Whether and optionally how the series should be animated.\n *\n * @emits Highcharts.Point#event:remove\n */\n Series.prototype.removePoint = function (i, redraw, animation) {\n var series = this,\n data = series.data,\n point = data[i],\n points = series.points,\n chart = series.chart,\n remove = function () {\n if (points && points.length === data.length) { // #4935\n points.splice(i, 1);\n }\n data.splice(i, 1);\n series.options.data.splice(i, 1);\n series.updateParallelArrays(point || { series: series }, 'splice', i, 1);\n if (point) {\n point.destroy();\n }\n // redraw\n series.isDirty = true;\n series.isDirtyData = true;\n if (redraw) {\n chart.redraw();\n }\n };\n setAnimation(animation, chart);\n redraw = pick(redraw, true);\n // Fire the event with a default handler of removing the point\n if (point) {\n point.firePointEvent('remove', null, remove);\n }\n else {\n remove();\n }\n };\n /**\n * Remove a series and optionally redraw the chart.\n *\n * @sample highcharts/members/series-remove/\n * Remove first series from a button\n *\n * @function Highcharts.Series#remove\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or wait for an explicit call to\n * {@link Highcharts.Chart#redraw}.\n *\n * @param {boolean|Partial} [animation]\n * Whether to apply animation, and optionally animation\n * configuration.\n *\n * @param {boolean} [withEvent=true]\n * Used internally, whether to fire the series `remove` event.\n *\n * @emits Highcharts.Series#event:remove\n */\n Series.prototype.remove = function (redraw, animation, withEvent, keepEvents) {\n var series = this,\n chart = series.chart;\n /**\n * @private\n */\n function remove() {\n // Destroy elements\n series.destroy(keepEvents);\n // Redraw\n chart.isDirtyLegend = chart.isDirtyBox = true;\n chart.linkSeries();\n if (pick(redraw, true)) {\n chart.redraw(animation);\n }\n }\n // Fire the event with a default handler of removing the point\n if (withEvent !== false) {\n fireEvent(series, 'remove', null, remove);\n }\n else {\n remove();\n }\n };\n /**\n * Update the series with a new set of options. For a clean and precise\n * handling of new options, all methods and elements from the series are\n * removed, and it is initialized from scratch. Therefore, this method is\n * more performance expensive than some other utility methods like {@link\n * Series#setData} or {@link Series#setVisible}.\n *\n * Note that `Series.update` may mutate the passed `data` options.\n *\n * @sample highcharts/members/series-update/\n * Updating series options\n * @sample maps/members/series-update/\n * Update series options in Highmaps\n *\n * @function Highcharts.Series#update\n *\n * @param {Highcharts.SeriesOptionsType} options\n * New options that will be merged with the series' existing options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the series is altered. If doing\n * more operations on the chart, it is a good idea to set redraw to\n * false and call {@link Chart#redraw} after.\n *\n * @emits Highcharts.Series#event:update\n * @emits Highcharts.Series#event:afterUpdate\n */\n Series.prototype.update = function (options, redraw) {\n options = cleanRecursively(options, this.userOptions);\n fireEvent(this, 'update', { options: options });\n var series = this,\n chart = series.chart, \n // must use user options when changing type because series.options\n // is merged in with type specific plotOptions\n oldOptions = series.userOptions,\n initialType = series.initialType || series.type,\n plotOptions = chart.options.plotOptions,\n initialSeriesProto = seriesTypes[initialType].prototype,\n groups = [\n 'group',\n 'markerGroup',\n 'dataLabelsGroup',\n 'transformGroup',\n 'shadowGroup'\n ], \n // Animation must be enabled when calling update before the initial\n // animation has first run. This happens when calling update\n // directly after chart initialization, or when applying responsive\n // rules (#6912).\n animation = series.finishedAnimating && { animation: false },\n kinds = {};\n var seriesOptions,\n n,\n preserve = [\n 'eventOptions',\n 'navigatorSeries',\n 'baseSeries'\n ],\n newType = (options.type ||\n oldOptions.type ||\n chart.options.chart.type);\n var keepPoints = !(\n // Indicators, histograms etc recalculate the data. It should be\n // possible to omit this.\n this.hasDerivedData ||\n // New type requires new point classes\n (newType && newType !== this.type) ||\n // New options affecting how the data points are built\n typeof options.pointStart !== 'undefined' ||\n typeof options.pointInterval !== 'undefined' ||\n typeof options.relativeXValue !== 'undefined' ||\n options.joinBy ||\n options.mapData || // #11636\n // Changes to data grouping requires new points in new group\n series.hasOptionChanged('dataGrouping') ||\n series.hasOptionChanged('pointStart') ||\n series.hasOptionChanged('pointInterval') ||\n series.hasOptionChanged('pointIntervalUnit') ||\n series.hasOptionChanged('keys'));\n newType = newType || initialType;\n if (keepPoints) {\n preserve.push('data', 'isDirtyData', 'points', 'processedData', // #17057\n 'processedXData', 'processedYData', 'xIncrement', 'cropped', '_hasPointMarkers', '_hasPointLabels', 'clips', // #15420\n // Networkgraph (#14397)\n 'nodes', 'layout', \n // Treemap\n 'level', \n // Map specific, consider moving it to series-specific preserve-\n // properties (#10617)\n 'mapMap', 'mapData', 'minY', 'maxY', 'minX', 'maxX');\n if (options.visible !== false) {\n preserve.push('area', 'graph');\n }\n series.parallelArrays.forEach(function (key) {\n preserve.push(key + 'Data');\n });\n if (options.data) {\n // setData uses dataSorting options so we need to update them\n // earlier\n if (options.dataSorting) {\n extend(series.options.dataSorting, options.dataSorting);\n }\n this.setData(options.data, false);\n }\n }\n // Do the merge, with some forced options\n options = merge(oldOptions, animation, {\n // When oldOptions.index is null it should't be cleared.\n // Otherwise navigator series will have wrong indexes (#10193).\n index: typeof oldOptions.index === 'undefined' ?\n series.index : oldOptions.index,\n pointStart: pick(\n // when updating from blank (#7933)\n (plotOptions &&\n plotOptions.series &&\n plotOptions.series.pointStart), oldOptions.pointStart, \n // when updating after addPoint\n series.xData[0])\n }, (!keepPoints && { data: series.options.data }), options);\n // Merge does not merge arrays, but replaces them. Since points were\n // updated, `series.options.data` has correct merged options, use it:\n if (keepPoints && options.data) {\n options.data = series.options.data;\n }\n // Make sure preserved properties are not destroyed (#3094)\n preserve = groups.concat(preserve);\n preserve.forEach(function (prop) {\n preserve[prop] = series[prop];\n delete series[prop];\n });\n var casting = false;\n if (seriesTypes[newType]) {\n casting = newType !== series.type;\n // Destroy the series and delete all properties, it will be\n // reinserted within the `init` call below\n series.remove(false, false, false, true);\n if (casting) {\n // Modern browsers including IE11\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(series, seriesTypes[newType].prototype);\n // Legacy (IE < 11)\n }\n else {\n var ownEvents = Object.hasOwnProperty.call(series, 'hcEvents') && series.hcEvents;\n for (n in initialSeriesProto) { // eslint-disable-line guard-for-in\n series[n] = void 0;\n }\n // Reinsert all methods and properties from the new type\n // prototype (#2270, #3719).\n extend(series, seriesTypes[newType].prototype);\n // The events are tied to the prototype chain, don't copy if\n // they're not the series' own\n if (ownEvents) {\n series.hcEvents = ownEvents;\n }\n else {\n delete series.hcEvents;\n }\n }\n }\n }\n else {\n error(17, true, chart, { missingModuleFor: newType });\n }\n // Re-register groups (#3094) and other preserved properties\n preserve.forEach(function (prop) {\n series[prop] = preserve[prop];\n });\n series.init(chart, options);\n // Remove particular elements of the points. Check `series.options`\n // because we need to consider the options being set on plotOptions as\n // well.\n if (keepPoints && this.points) {\n seriesOptions = series.options;\n // What kind of elements to destroy\n if (seriesOptions.visible === false) {\n kinds.graphic = 1;\n kinds.dataLabel = 1;\n }\n else if (!series._hasPointLabels) {\n var marker = seriesOptions.marker,\n dataLabels = seriesOptions.dataLabels;\n if (marker && (marker.enabled === false ||\n (oldOptions.marker && oldOptions.marker.symbol) !==\n marker.symbol // #10870, #15946\n )) {\n kinds.graphic = 1;\n }\n if (dataLabels &&\n dataLabels.enabled === false) {\n kinds.dataLabel = 1;\n }\n }\n for (var _a = 0, _b = this.points; _a < _b.length; _a++) {\n var point = _b[_a];\n if (point && point.series) {\n point.resolveColor();\n // Destroy elements in order to recreate based on updated\n // series options.\n if (Object.keys(kinds).length) {\n point.destroyElements(kinds);\n }\n if (seriesOptions.showInLegend === false &&\n point.legendItem) {\n chart.legend.destroyItem(point);\n }\n }\n }\n }\n series.initialType = initialType;\n chart.linkSeries(); // Links are lost in series.remove (#3028)\n // #15383: Fire updatedData if the type has changed to keep linked\n // series such as indicators updated\n if (casting && series.linkedSeries.length) {\n series.isDirtyData = true;\n }\n fireEvent(this, 'afterUpdate');\n if (pick(redraw, true)) {\n chart.redraw(keepPoints ? void 0 : false);\n }\n };\n /**\n * Used from within series.update\n * @private\n */\n Series.prototype.setName = function (name) {\n this.name = this.options.name = this.userOptions.name = name;\n this.chart.isDirtyLegend = true;\n };\n /**\n * Check if the option has changed.\n * @private\n */\n Series.prototype.hasOptionChanged = function (optionName) {\n var chart = this.chart,\n option = this.options[optionName],\n plotOptions = chart.options.plotOptions,\n oldOption = this.userOptions[optionName];\n if (oldOption) {\n return option !== oldOption;\n }\n return option !==\n pick(plotOptions &&\n plotOptions[this.type] &&\n plotOptions[this.type][optionName], plotOptions &&\n plotOptions.series &&\n plotOptions.series[optionName], option);\n };\n /**\n * Runs on mouse over the series graphical items.\n *\n * @function Highcharts.Series#onMouseOver\n * @emits Highcharts.Series#event:mouseOver\n */\n Series.prototype.onMouseOver = function () {\n var series = this,\n chart = series.chart,\n hoverSeries = chart.hoverSeries,\n pointer = chart.pointer;\n pointer.setHoverChartIndex();\n // set normal state to previous series\n if (hoverSeries && hoverSeries !== series) {\n hoverSeries.onMouseOut();\n }\n // trigger the event, but to save processing time,\n // only if defined\n if (series.options.events.mouseOver) {\n fireEvent(series, 'mouseOver');\n }\n // hover this\n series.setState('hover');\n /**\n * Contains the original hovered series.\n *\n * @name Highcharts.Chart#hoverSeries\n * @type {Highcharts.Series|null}\n */\n chart.hoverSeries = series;\n };\n /**\n * Runs on mouse out of the series graphical items.\n *\n * @function Highcharts.Series#onMouseOut\n *\n * @emits Highcharts.Series#event:mouseOut\n */\n Series.prototype.onMouseOut = function () {\n // trigger the event only if listeners exist\n var series = this,\n options = series.options,\n chart = series.chart,\n tooltip = chart.tooltip,\n hoverPoint = chart.hoverPoint;\n // #182, set to null before the mouseOut event fires\n chart.hoverSeries = null;\n // trigger mouse out on the point, which must be in this series\n if (hoverPoint) {\n hoverPoint.onMouseOut();\n }\n // fire the mouse out event\n if (series && options.events.mouseOut) {\n fireEvent(series, 'mouseOut');\n }\n // hide the tooltip\n if (tooltip &&\n !series.stickyTracking &&\n (!tooltip.shared || series.noSharedTooltip)) {\n tooltip.hide();\n }\n // Reset all inactive states\n chart.series.forEach(function (s) {\n s.setState('', true);\n });\n };\n /**\n * Set the state of the series. Called internally on mouse interaction\n * operations, but it can also be called directly to visually\n * highlight a series.\n *\n * @function Highcharts.Series#setState\n *\n * @param {Highcharts.SeriesStateValue|\"\"} [state]\n * The new state, can be either `'hover'`, `'inactive'`, `'select'`,\n * or `''` (an empty string), `'normal'` or `undefined` to set to\n * normal state.\n * @param {boolean} [inherit]\n * Determines if state should be inherited by points too.\n */\n Series.prototype.setState = function (state, inherit) {\n var series = this,\n options = series.options,\n graph = series.graph,\n inactiveOtherPoints = options.inactiveOtherPoints,\n stateOptions = options.states, \n // By default a quick animation to hover/inactive,\n // slower to un-hover\n stateAnimation = pick((stateOptions[state || 'normal'] &&\n stateOptions[state || 'normal'].animation),\n series.chart.options.chart.animation);\n var attribs,\n lineWidth = options.lineWidth,\n i = 0,\n opacity = options.opacity;\n state = state || '';\n if (series.state !== state) {\n // Toggle class names\n [\n series.group,\n series.markerGroup,\n series.dataLabelsGroup\n ].forEach(function (group) {\n if (group) {\n // Old state\n if (series.state) {\n group.removeClass('highcharts-series-' + series.state);\n }\n // New state\n if (state) {\n group.addClass('highcharts-series-' + state);\n }\n }\n });\n series.state = state;\n if (!series.chart.styledMode) {\n if (stateOptions[state] &&\n stateOptions[state].enabled === false) {\n return;\n }\n if (state) {\n lineWidth = (stateOptions[state].lineWidth ||\n lineWidth + (stateOptions[state].lineWidthPlus || 0)); // #4035\n opacity = pick(stateOptions[state].opacity, opacity);\n }\n if (graph && !graph.dashstyle) {\n attribs = {\n 'stroke-width': lineWidth\n };\n // Animate the graph stroke-width.\n graph.animate(attribs, stateAnimation);\n while (series['zone-graph-' + i]) {\n series['zone-graph-' + i].animate(attribs, stateAnimation);\n i = i + 1;\n }\n }\n // For some types (pie, networkgraph, sankey) opacity is\n // resolved on a point level\n if (!inactiveOtherPoints) {\n [\n series.group,\n series.markerGroup,\n series.dataLabelsGroup,\n series.labelBySeries\n ].forEach(function (group) {\n if (group) {\n group.animate({\n opacity: opacity\n }, stateAnimation);\n }\n });\n }\n }\n }\n // Don't loop over points on a series that doesn't apply inactive state\n // to siblings markers (e.g. line, column)\n if (inherit && inactiveOtherPoints && series.points) {\n series.setAllPointsToState(state || void 0);\n }\n };\n /**\n * Set the state for all points in the series.\n *\n * @function Highcharts.Series#setAllPointsToState\n *\n * @private\n *\n * @param {string} [state]\n * Can be either `hover` or undefined to set to normal state.\n */\n Series.prototype.setAllPointsToState = function (state) {\n this.points.forEach(function (point) {\n if (point.setState) {\n point.setState(state);\n }\n });\n };\n /**\n * Show or hide the series.\n *\n * @function Highcharts.Series#setVisible\n *\n * @param {boolean} [visible]\n * True to show the series, false to hide. If undefined, the visibility is\n * toggled.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the series is altered. If doing more\n * operations on the chart, it is a good idea to set redraw to false and\n * call {@link Chart#redraw|chart.redraw()} after.\n *\n * @emits Highcharts.Series#event:hide\n * @emits Highcharts.Series#event:show\n */\n Series.prototype.setVisible = function (vis, redraw) {\n var series = this,\n chart = series.chart,\n ignoreHiddenSeries = chart.options.chart.ignoreHiddenSeries,\n oldVisibility = series.visible;\n // if called without an argument, toggle visibility\n series.visible =\n vis =\n series.options.visible =\n series.userOptions.visible =\n typeof vis === 'undefined' ? !oldVisibility : vis; // #5618\n var showOrHide = vis ? 'show' : 'hide';\n // show or hide elements\n [\n 'group',\n 'dataLabelsGroup',\n 'markerGroup',\n 'tracker',\n 'tt'\n ].forEach(function (key) {\n if (series[key]) {\n series[key][showOrHide]();\n }\n });\n // hide tooltip (#1361)\n if (chart.hoverSeries === series ||\n (chart.hoverPoint && chart.hoverPoint.series) === series) {\n series.onMouseOut();\n }\n if (series.legendItem) {\n chart.legend.colorizeItem(series, vis);\n }\n // rescale or adapt to resized chart\n series.isDirty = true;\n // in a stack, all other series are affected\n if (series.options.stacking) {\n chart.series.forEach(function (otherSeries) {\n if (otherSeries.options.stacking && otherSeries.visible) {\n otherSeries.isDirty = true;\n }\n });\n }\n // show or hide linked series\n series.linkedSeries.forEach(function (otherSeries) {\n otherSeries.setVisible(vis, false);\n });\n if (ignoreHiddenSeries) {\n chart.isDirtyBox = true;\n }\n fireEvent(series, showOrHide);\n if (redraw !== false) {\n chart.redraw();\n }\n };\n /**\n * Show the series if hidden.\n *\n * @sample highcharts/members/series-hide/\n * Toggle visibility from a button\n *\n * @function Highcharts.Series#show\n * @emits Highcharts.Series#event:show\n */\n Series.prototype.show = function () {\n this.setVisible(true);\n };\n /**\n * Hide the series if visible. If the\n * [chart.ignoreHiddenSeries](https://api.highcharts.com/highcharts/chart.ignoreHiddenSeries)\n * option is true, the chart is redrawn without this series.\n *\n * @sample highcharts/members/series-hide/\n * Toggle visibility from a button\n *\n * @function Highcharts.Series#hide\n * @emits Highcharts.Series#event:hide\n */\n Series.prototype.hide = function () {\n this.setVisible(false);\n };\n /**\n * Select or unselect the series. This means its\n * {@link Highcharts.Series.selected|selected}\n * property is set, the checkbox in the legend is toggled and when selected,\n * the series is returned by the {@link Highcharts.Chart#getSelectedSeries}\n * function.\n *\n * @sample highcharts/members/series-select/\n * Select a series from a button\n *\n * @function Highcharts.Series#select\n *\n * @param {boolean} [selected]\n * True to select the series, false to unselect. If undefined, the selection\n * state is toggled.\n *\n * @emits Highcharts.Series#event:select\n * @emits Highcharts.Series#event:unselect\n */\n Series.prototype.select = function (selected) {\n var series = this;\n series.selected =\n selected =\n this.options.selected = (typeof selected === 'undefined' ?\n !series.selected :\n selected);\n if (series.checkbox) {\n series.checkbox.checked = selected;\n }\n fireEvent(series, selected ? 'select' : 'unselect');\n };\n /**\n * Checks if a tooltip should be shown for a given point.\n *\n * @private\n */\n Series.prototype.shouldShowTooltip = function (plotX, plotY, options) {\n if (options === void 0) { options = {}; }\n options.series = this;\n options.visiblePlotOnly = true;\n return this.chart.isInsidePlot(plotX, plotY, options);\n };\n Series.defaultOptions = SeriesDefaults;\n /**\n * Registry of all available series types.\n *\n * @name Highcharts.Series.types\n * @type {Highcharts.Dictionary}\n */\n Series.types = SeriesRegistry.seriesTypes;\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Registers a series class to be accessible via `Series.types`.\n *\n * @function Highcharts.Series.registerType\n *\n * @param {string} seriesType\n * The series type as an identifier string in lower case.\n *\n * @param {Function} SeriesClass\n * The series class as a class pattern or a constructor function with\n * prototype.\n */\n Series.registerType = SeriesRegistry.registerSeriesType;\n return Series;\n }());\n extend(Series.prototype, {\n axisTypes: ['xAxis', 'yAxis'],\n coll: 'series',\n colorCounter: 0,\n cropShoulder: 1,\n directTouch: false,\n drawLegendSymbol: LegendSymbol.drawLineMarker,\n isCartesian: true,\n kdAxisArray: ['clientX', 'plotY'],\n // each point's x and y values are stored in this.xData and this.yData:\n parallelArrays: ['x', 'y'],\n pointClass: Point,\n requireSorting: true,\n // requires the data to be sorted:\n sorted: true\n });\n /* *\n *\n * Registry\n *\n * */\n SeriesRegistry.series = Series;\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * This is a placeholder type of the possible series options for\n * [Highcharts](../highcharts/series), [Highcharts Stock](../highstock/series),\n * [Highmaps](../highmaps/series), and [Gantt](../gantt/series).\n *\n * In TypeScript is this dynamically generated to reference all possible types\n * of series options.\n *\n * @ignore-declaration\n * @typedef {Highcharts.SeriesOptions|Highcharts.Dictionary<*>} Highcharts.SeriesOptionsType\n */\n /**\n * Options for `dataSorting`.\n *\n * @interface Highcharts.DataSortingOptionsObject\n * @since 8.0.0\n */ /**\n * Enable or disable data sorting for the series.\n * @name Highcharts.DataSortingOptionsObject#enabled\n * @type {boolean|undefined}\n */ /**\n * Whether to allow matching points by name in an update.\n * @name Highcharts.DataSortingOptionsObject#matchByName\n * @type {boolean|undefined}\n */ /**\n * Determines what data value should be used to sort by.\n * @name Highcharts.DataSortingOptionsObject#sortKey\n * @type {string|undefined}\n */\n /**\n * Function callback when a series has been animated.\n *\n * @callback Highcharts.SeriesAfterAnimateCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesAfterAnimateEventObject} event\n * Event arguments.\n */\n /**\n * Event information regarding completed animation of a series.\n *\n * @interface Highcharts.SeriesAfterAnimateEventObject\n */ /**\n * Animated series.\n * @name Highcharts.SeriesAfterAnimateEventObject#target\n * @type {Highcharts.Series}\n */ /**\n * Event type.\n * @name Highcharts.SeriesAfterAnimateEventObject#type\n * @type {\"afterAnimate\"}\n */\n /**\n * Function callback when the checkbox next to the series' name in the legend is\n * clicked.\n *\n * @callback Highcharts.SeriesCheckboxClickCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesCheckboxClickEventObject} event\n * Event arguments.\n */\n /**\n * Event information regarding check of a series box.\n *\n * @interface Highcharts.SeriesCheckboxClickEventObject\n */ /**\n * Whether the box has been checked.\n * @name Highcharts.SeriesCheckboxClickEventObject#checked\n * @type {boolean}\n */ /**\n * Related series.\n * @name Highcharts.SeriesCheckboxClickEventObject#item\n * @type {Highcharts.Series}\n */ /**\n * Related series.\n * @name Highcharts.SeriesCheckboxClickEventObject#target\n * @type {Highcharts.Series}\n */ /**\n * Event type.\n * @name Highcharts.SeriesCheckboxClickEventObject#type\n * @type {\"checkboxClick\"}\n */\n /**\n * Function callback when a series is clicked. Return false to cancel toogle\n * actions.\n *\n * @callback Highcharts.SeriesClickCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesClickEventObject} event\n * Event arguments.\n */\n /**\n * Common information for a click event on a series.\n *\n * @interface Highcharts.SeriesClickEventObject\n * @extends global.Event\n */ /**\n * Nearest point on the graph.\n * @name Highcharts.SeriesClickEventObject#point\n * @type {Highcharts.Point}\n */\n /**\n * Gets fired when the series is hidden after chart generation time, either by\n * clicking the legend item or by calling `.hide()`.\n *\n * @callback Highcharts.SeriesHideCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * The SVG value used for the `stroke-linecap` and `stroke-linejoin` of a line\n * graph.\n *\n * @typedef {\"butt\"|\"round\"|\"square\"|string} Highcharts.SeriesLinecapValue\n */\n /**\n * Gets fired when the legend item belonging to the series is clicked. The\n * default action is to toggle the visibility of the series. This can be\n * prevented by returning `false` or calling `event.preventDefault()`.\n *\n * @callback Highcharts.SeriesLegendItemClickCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesLegendItemClickEventObject} event\n * The event that occured.\n */\n /**\n * Information about the event.\n *\n * @interface Highcharts.SeriesLegendItemClickEventObject\n */ /**\n * Related browser event.\n * @name Highcharts.SeriesLegendItemClickEventObject#browserEvent\n * @type {global.PointerEvent}\n */ /**\n * Prevent the default action of toggle the visibility of the series.\n * @name Highcharts.SeriesLegendItemClickEventObject#preventDefault\n * @type {Function}\n */ /**\n * Related series.\n * @name Highcharts.SeriesCheckboxClickEventObject#target\n * @type {Highcharts.Series}\n */ /**\n * Event type.\n * @name Highcharts.SeriesCheckboxClickEventObject#type\n * @type {\"checkboxClick\"}\n */\n /**\n * Gets fired when the mouse leaves the graph.\n *\n * @callback Highcharts.SeriesMouseOutCallbackFunction\n *\n * @param {Highcharts.Series} this\n * Series where the event occured.\n *\n * @param {global.PointerEvent} event\n * Event that occured.\n */\n /**\n * Gets fired when the mouse enters the graph.\n *\n * @callback Highcharts.SeriesMouseOverCallbackFunction\n *\n * @param {Highcharts.Series} this\n * Series where the event occured.\n *\n * @param {global.PointerEvent} event\n * Event that occured.\n */\n /**\n * Translation and scale for the plot area of a series.\n *\n * @interface Highcharts.SeriesPlotBoxObject\n */ /**\n * @name Highcharts.SeriesPlotBoxObject#scaleX\n * @type {number}\n */ /**\n * @name Highcharts.SeriesPlotBoxObject#scaleY\n * @type {number}\n */ /**\n * @name Highcharts.SeriesPlotBoxObject#translateX\n * @type {number}\n */ /**\n * @name Highcharts.SeriesPlotBoxObject#translateY\n * @type {number}\n */\n /**\n * Gets fired when the series is shown after chart generation time, either by\n * clicking the legend item or by calling `.show()`.\n *\n * @callback Highcharts.SeriesShowCallbackFunction\n *\n * @param {Highcharts.Series} this\n * Series where the event occured.\n *\n * @param {global.Event} event\n * Event that occured.\n */\n /**\n * Possible key values for the series state options.\n *\n * @typedef {\"hover\"|\"inactive\"|\"normal\"|\"select\"} Highcharts.SeriesStateValue\n */\n ''; // detach doclets above\n /* *\n *\n * API Options\n *\n * */\n /**\n * Series options for specific data and the data itself. In TypeScript you\n * have to cast the series options to specific series types, to get all\n * possible options for a series.\n *\n * @example\n * // TypeScript example\n * Highcharts.chart('container', {\n * series: [{\n * color: '#06C',\n * data: [[0, 1], [2, 3]]\n * } as Highcharts.SeriesLineOptions ]\n * });\n *\n * @type {Array<*>}\n * @apioption series\n */\n /**\n * An id for the series. This can be used after render time to get a pointer\n * to the series object through `chart.get()`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-id/\n * Get series by id\n *\n * @type {string}\n * @since 1.2.0\n * @apioption series.id\n */\n /**\n * The index of the series in the chart, affecting the internal index in the\n * `chart.series` array, the visible Z index as well as the order in the\n * legend.\n *\n * @type {number}\n * @since 2.3.0\n * @apioption series.index\n */\n /**\n * The sequential index of the series in the legend.\n *\n * @see [legend.reversed](#legend.reversed),\n * [yAxis.reversedStacks](#yAxis.reversedStacks)\n *\n * @sample {highcharts|highstock} highcharts/series/legendindex/\n * Legend in opposite order\n *\n * @type {number}\n * @apioption series.legendIndex\n */\n /**\n * The name of the series as shown in the legend, tooltip etc.\n *\n * @sample {highcharts} highcharts/series/name/\n * Series name\n * @sample {highmaps} maps/demo/category-map/\n * Series name\n *\n * @type {string}\n * @apioption series.name\n */\n /**\n * This option allows grouping series in a stacked chart. The stack option\n * can be a string or anything else, as long as the grouped series' stack\n * options match each other after conversion into a string.\n *\n * @sample {highcharts} highcharts/series/stack/\n * Stacked and grouped columns\n *\n * @type {number|string}\n * @since 2.1\n * @product highcharts highstock\n * @apioption series.stack\n */\n /**\n * The type of series, for example `line` or `column`. By default, the\n * series type is inherited from [chart.type](#chart.type), so unless the\n * chart is a combination of series types, there is no need to set it on the\n * series level.\n *\n * @sample {highcharts} highcharts/series/type/\n * Line and column in the same chart\n * @sample highcharts/series/type-dynamic/\n * Dynamic types with button selector\n * @sample {highmaps} maps/demo/mapline-mappoint/\n * Multiple types in the same map\n *\n * @type {string}\n * @apioption series.type\n */\n /**\n * When using dual or multiple x axes, this number defines which xAxis the\n * particular series is connected to. It refers to either the\n * {@link #xAxis.id|axis id}\n * or the index of the axis in the xAxis array, with 0 being the first.\n *\n * @type {number|string}\n * @default 0\n * @product highcharts highstock\n * @apioption series.xAxis\n */\n /**\n * When using dual or multiple y axes, this number defines which yAxis the\n * particular series is connected to. It refers to either the\n * {@link #yAxis.id|axis id}\n * or the index of the axis in the yAxis array, with 0 being the first.\n *\n * @sample {highcharts} highcharts/series/yaxis/\n * Apply the column series to the secondary Y axis\n *\n * @type {number|string}\n * @default 0\n * @product highcharts highstock\n * @apioption series.yAxis\n */\n /**\n * Define the visual z index of the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-zindex-default/\n * With no z index, the series defined last are on top\n * @sample {highcharts} highcharts/plotoptions/series-zindex/\n * With a z index, the series with the highest z index is on top\n * @sample {highstock} highcharts/plotoptions/series-zindex-default/\n * With no z index, the series defined last are on top\n * @sample {highstock} highcharts/plotoptions/series-zindex/\n * With a z index, the series with the highest z index is on top\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption series.zIndex\n */\n ''; // include precedent doclets in transpilat\n\n return Series;\n });\n _registerModule(_modules, 'Extensions/ScrollablePlotArea.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Axis/Axis.js'], _modules['Core/Chart/Chart.js'], _modules['Core/Series/Series.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Utilities.js']], function (A, Axis, Chart, Series, RendererRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * Highcharts feature to make the Y axis stay fixed when scrolling the chart\n * horizontally on mobile devices. Supports left and right side axes.\n */\n /*\n WIP on vertical scrollable plot area (#9378). To do:\n - Bottom axis positioning\n - Test with Gantt\n - Look for size optimizing the code\n - API and demos\n */\n var stop = A.stop;\n var addEvent = U.addEvent,\n createElement = U.createElement,\n defined = U.defined,\n merge = U.merge,\n pick = U.pick;\n /* eslint-disable no-invalid-this, valid-jsdoc */\n addEvent(Chart, 'afterSetChartSize', function (e) {\n var scrollablePlotArea = this.options.chart.scrollablePlotArea,\n scrollableMinWidth = scrollablePlotArea && scrollablePlotArea.minWidth,\n scrollableMinHeight = scrollablePlotArea && scrollablePlotArea.minHeight,\n scrollablePixelsX,\n scrollablePixelsY,\n corrections;\n if (!this.renderer.forExport) {\n // The amount of pixels to scroll, the difference between chart\n // width and scrollable width\n if (scrollableMinWidth) {\n this.scrollablePixelsX = scrollablePixelsX = Math.max(0, scrollableMinWidth - this.chartWidth);\n if (scrollablePixelsX) {\n this.scrollablePlotBox = (this.renderer.scrollablePlotBox = merge(this.plotBox));\n this.plotBox.width = this.plotWidth += scrollablePixelsX;\n if (this.inverted) {\n this.clipBox.height += scrollablePixelsX;\n }\n else {\n this.clipBox.width += scrollablePixelsX;\n }\n corrections = {\n // Corrections for right side\n 1: { name: 'right', value: scrollablePixelsX }\n };\n }\n // Currently we can only do either X or Y\n }\n else if (scrollableMinHeight) {\n this.scrollablePixelsY = scrollablePixelsY = Math.max(0, scrollableMinHeight - this.chartHeight);\n if (defined(scrollablePixelsY)) {\n this.scrollablePlotBox = (this.renderer.scrollablePlotBox = merge(this.plotBox));\n this.plotBox.height = this.plotHeight += scrollablePixelsY;\n if (this.inverted) {\n this.clipBox.width += scrollablePixelsY;\n }\n else {\n this.clipBox.height += scrollablePixelsY;\n }\n corrections = {\n 2: { name: 'bottom', value: scrollablePixelsY }\n };\n }\n }\n if (corrections && !e.skipAxes) {\n this.axes.forEach(function (axis) {\n // For right and bottom axes, only fix the plot line length\n if (corrections[axis.side]) {\n // Get the plot lines right in getPlotLinePath,\n // temporarily set it to the adjusted plot width.\n axis.getPlotLinePath = function () {\n var marginName = corrections[axis.side].name,\n correctionValue = corrections[axis.side].value, \n // axis.right or axis.bottom\n margin = this[marginName],\n path;\n // Temporarily adjust\n this[marginName] = margin - correctionValue;\n path = Axis.prototype.getPlotLinePath.apply(this, arguments);\n // Reset\n this[marginName] = margin;\n return path;\n };\n }\n else {\n // Apply the corrected plotWidth\n axis.setAxisSize();\n axis.setAxisTranslation();\n }\n });\n }\n }\n });\n addEvent(Chart, 'render', function () {\n if (this.scrollablePixelsX || this.scrollablePixelsY) {\n if (this.setUpScrolling) {\n this.setUpScrolling();\n }\n this.applyFixed();\n }\n else if (this.fixedDiv) { // Has been in scrollable mode\n this.applyFixed();\n }\n });\n /**\n * @private\n * @function Highcharts.Chart#setUpScrolling\n * @return {void}\n */\n Chart.prototype.setUpScrolling = function () {\n var _this = this;\n var css = {\n WebkitOverflowScrolling: 'touch',\n overflowX: 'hidden',\n overflowY: 'hidden'\n };\n if (this.scrollablePixelsX) {\n css.overflowX = 'auto';\n }\n if (this.scrollablePixelsY) {\n css.overflowY = 'auto';\n }\n // Insert a container with position relative\n // that scrolling and fixed container renders to (#10555)\n this.scrollingParent = createElement('div', {\n className: 'highcharts-scrolling-parent'\n }, {\n position: 'relative'\n }, this.renderTo);\n // Add the necessary divs to provide scrolling\n this.scrollingContainer = createElement('div', {\n 'className': 'highcharts-scrolling'\n }, css, this.scrollingParent);\n // On scroll, reset the chart position because it applies to the scrolled\n // container\n addEvent(this.scrollingContainer, 'scroll', function () {\n if (_this.pointer) {\n delete _this.pointer.chartPosition;\n }\n });\n this.innerContainer = createElement('div', {\n 'className': 'highcharts-inner-container'\n }, null, this.scrollingContainer);\n // Now move the container inside\n this.innerContainer.appendChild(this.container);\n // Don't run again\n this.setUpScrolling = null;\n };\n /**\n * These elements are moved over to the fixed renderer and stay fixed when the\n * user scrolls the chart\n * @private\n */\n Chart.prototype.moveFixedElements = function () {\n var container = this.container,\n fixedRenderer = this.fixedRenderer,\n fixedSelectors = [\n '.highcharts-contextbutton',\n '.highcharts-credits',\n '.highcharts-legend',\n '.highcharts-legend-checkbox',\n '.highcharts-navigator-series',\n '.highcharts-navigator-xaxis',\n '.highcharts-navigator-yaxis',\n '.highcharts-navigator',\n '.highcharts-reset-zoom',\n '.highcharts-drillup-button',\n '.highcharts-scrollbar',\n '.highcharts-subtitle',\n '.highcharts-title'\n ],\n axisClass;\n if (this.scrollablePixelsX && !this.inverted) {\n axisClass = '.highcharts-yaxis';\n }\n else if (this.scrollablePixelsX && this.inverted) {\n axisClass = '.highcharts-xaxis';\n }\n else if (this.scrollablePixelsY && !this.inverted) {\n axisClass = '.highcharts-xaxis';\n }\n else if (this.scrollablePixelsY && this.inverted) {\n axisClass = '.highcharts-yaxis';\n }\n if (axisClass) {\n fixedSelectors.push(\"\" + axisClass + \":not(.highcharts-radial-axis)\", \"\" + axisClass + \"-labels:not(.highcharts-radial-axis-labels)\");\n }\n fixedSelectors.forEach(function (className) {\n [].forEach.call(container.querySelectorAll(className), function (elem) {\n (elem.namespaceURI === fixedRenderer.SVG_NS ?\n fixedRenderer.box :\n fixedRenderer.box.parentNode).appendChild(elem);\n elem.style.pointerEvents = 'auto';\n });\n });\n };\n /**\n * @private\n * @function Highcharts.Chart#applyFixed\n * @return {void}\n */\n Chart.prototype.applyFixed = function () {\n var firstTime = !this.fixedDiv,\n chartOptions = this.options.chart,\n scrollableOptions = chartOptions.scrollablePlotArea,\n Renderer = RendererRegistry.getRendererType();\n var fixedRenderer,\n scrollableWidth,\n scrollableHeight;\n // First render\n if (firstTime) {\n this.fixedDiv = createElement('div', {\n className: 'highcharts-fixed'\n }, {\n position: 'absolute',\n overflow: 'hidden',\n pointerEvents: 'none',\n zIndex: (chartOptions.style && chartOptions.style.zIndex || 0) + 2,\n top: 0\n }, null, true);\n if (this.scrollingContainer) {\n this.scrollingContainer.parentNode.insertBefore(this.fixedDiv, this.scrollingContainer);\n }\n this.renderTo.style.overflow = 'visible';\n this.fixedRenderer = fixedRenderer = new Renderer(this.fixedDiv, this.chartWidth, this.chartHeight, this.options.chart.style);\n // Mask\n this.scrollableMask = fixedRenderer\n .path()\n .attr({\n fill: this.options.chart.backgroundColor || '#fff',\n 'fill-opacity': pick(scrollableOptions.opacity, 0.85),\n zIndex: -1\n })\n .addClass('highcharts-scrollable-mask')\n .add();\n addEvent(this, 'afterShowResetZoom', this.moveFixedElements);\n addEvent(this, 'afterApplyDrilldown', this.moveFixedElements);\n addEvent(this, 'afterLayOutTitles', this.moveFixedElements);\n }\n else {\n // Set the size of the fixed renderer to the visible width\n this.fixedRenderer.setSize(this.chartWidth, this.chartHeight);\n }\n if (this.scrollableDirty || firstTime) {\n this.scrollableDirty = false;\n this.moveFixedElements();\n }\n // Increase the size of the scrollable renderer and background\n scrollableWidth = this.chartWidth + (this.scrollablePixelsX || 0);\n scrollableHeight = this.chartHeight + (this.scrollablePixelsY || 0);\n stop(this.container);\n this.container.style.width = scrollableWidth + 'px';\n this.container.style.height = scrollableHeight + 'px';\n this.renderer.boxWrapper.attr({\n width: scrollableWidth,\n height: scrollableHeight,\n viewBox: [0, 0, scrollableWidth, scrollableHeight].join(' ')\n });\n this.chartBackground.attr({\n width: scrollableWidth,\n height: scrollableHeight\n });\n this.scrollingContainer.style.height = this.chartHeight + 'px';\n // Set scroll position\n if (firstTime) {\n if (scrollableOptions.scrollPositionX) {\n this.scrollingContainer.scrollLeft =\n this.scrollablePixelsX *\n scrollableOptions.scrollPositionX;\n }\n if (scrollableOptions.scrollPositionY) {\n this.scrollingContainer.scrollTop =\n this.scrollablePixelsY *\n scrollableOptions.scrollPositionY;\n }\n }\n // Mask behind the left and right side\n var axisOffset = this.axisOffset,\n maskTop = this.plotTop - axisOffset[0] - 1,\n maskLeft = this.plotLeft - axisOffset[3] - 1,\n maskBottom = this.plotTop + this.plotHeight + axisOffset[2] + 1,\n maskRight = this.plotLeft + this.plotWidth + axisOffset[1] + 1,\n maskPlotRight = this.plotLeft + this.plotWidth -\n (this.scrollablePixelsX || 0),\n maskPlotBottom = this.plotTop + this.plotHeight -\n (this.scrollablePixelsY || 0),\n d;\n if (this.scrollablePixelsX) {\n d = [\n // Left side\n ['M', 0, maskTop],\n ['L', this.plotLeft - 1, maskTop],\n ['L', this.plotLeft - 1, maskBottom],\n ['L', 0, maskBottom],\n ['Z'],\n // Right side\n ['M', maskPlotRight, maskTop],\n ['L', this.chartWidth, maskTop],\n ['L', this.chartWidth, maskBottom],\n ['L', maskPlotRight, maskBottom],\n ['Z']\n ];\n }\n else if (this.scrollablePixelsY) {\n d = [\n // Top side\n ['M', maskLeft, 0],\n ['L', maskLeft, this.plotTop - 1],\n ['L', maskRight, this.plotTop - 1],\n ['L', maskRight, 0],\n ['Z'],\n // Bottom side\n ['M', maskLeft, maskPlotBottom],\n ['L', maskLeft, this.chartHeight],\n ['L', maskRight, this.chartHeight],\n ['L', maskRight, maskPlotBottom],\n ['Z']\n ];\n }\n else {\n d = [['M', 0, 0]];\n }\n if (this.redrawTrigger !== 'adjustHeight') {\n this.scrollableMask.attr({ d: d });\n }\n };\n addEvent(Axis, 'afterInit', function () {\n this.chart.scrollableDirty = true;\n });\n addEvent(Series, 'show', function () {\n this.chart.scrollableDirty = true;\n });\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Options for a scrollable plot area. This feature provides a minimum size for\n * the plot area of the chart. If the size gets smaller than this, typically\n * on mobile devices, a native browser scrollbar is presented. This scrollbar\n * provides smooth scrolling for the contents of the plot area, whereas the\n * title, legend and unaffected axes are fixed.\n *\n * Since v7.1.2, a scrollable plot area can be defined for either horizontal or\n * vertical scrolling, depending on whether the `minWidth` or `minHeight`\n * option is set.\n *\n * @sample highcharts/chart/scrollable-plotarea\n * Scrollable plot area\n * @sample highcharts/chart/scrollable-plotarea-vertical\n * Vertically scrollable plot area\n * @sample {gantt} gantt/chart/scrollable-plotarea-vertical\n * Gantt chart with vertically scrollable plot area\n *\n * @since 6.1.0\n * @product highcharts gantt\n * @apioption chart.scrollablePlotArea\n */\n /**\n * The minimum height for the plot area. If it gets smaller than this, the plot\n * area will become scrollable.\n *\n * @type {number}\n * @since 7.1.2\n * @apioption chart.scrollablePlotArea.minHeight\n */\n /**\n * The minimum width for the plot area. If it gets smaller than this, the plot\n * area will become scrollable.\n *\n * @type {number}\n * @since 6.1.0\n * @apioption chart.scrollablePlotArea.minWidth\n */\n /**\n * The initial scrolling position of the scrollable plot area. Ranges from 0 to\n * 1, where 0 aligns the plot area to the left and 1 aligns it to the right.\n * Typically we would use 1 if the chart has right aligned Y axes.\n *\n * @type {number}\n * @since 6.1.0\n * @apioption chart.scrollablePlotArea.scrollPositionX\n */\n /**\n * The initial scrolling position of the scrollable plot area. Ranges from 0 to\n * 1, where 0 aligns the plot area to the top and 1 aligns it to the bottom.\n *\n * @type {number}\n * @since 7.1.2\n * @apioption chart.scrollablePlotArea.scrollPositionY\n */\n /**\n * The opacity of mask applied on one of the sides of the plot\n * area.\n *\n * @sample {highcharts} highcharts/chart/scrollable-plotarea-opacity\n * Disabled opacity for the mask\n *\n * @type {number}\n * @default 0.85\n * @since 7.1.1\n * @apioption chart.scrollablePlotArea.opacity\n */\n (''); // keep doclets above in transpiled file\n\n });\n _registerModule(_modules, 'Core/Axis/Stacking/StackItem.js', [_modules['Core/FormatUtilities.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (FU, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var format = FU.format;\n var Series = SeriesRegistry.series;\n var defined = U.defined,\n destroyObjectProperties = U.destroyObjectProperties,\n isNumber = U.isNumber,\n pick = U.pick;\n /* *\n *\n * Class\n *\n * */\n /**\n * The class for stacks. Each stack, on a specific X value and either negative\n * or positive, has its own stack item.\n * @private\n */\n var StackItem = /** @class */ (function () {\n /* *\n *\n * Constructor\n *\n * */\n function StackItem(axis, options, isNegative, x, stackOption) {\n var inverted = axis.chart.inverted;\n this.axis = axis;\n // Tells if the stack is negative\n this.isNegative = isNegative;\n // Save the options to be able to style the label\n this.options = options = options || {};\n // Save the x value to be able to position the label later\n this.x = x;\n // Initialize total value\n this.total = null;\n this.cumulative = null;\n // This will keep each points' extremes stored by series.index and point\n // index\n this.points = {};\n this.hasValidPoints = false;\n // Save the stack option on the series configuration object,\n // and whether to treat it as percent\n this.stack = stackOption;\n this.leftCliff = 0;\n this.rightCliff = 0;\n // The align options and text align varies on whether the stack is\n // negative and if the chart is inverted or not.\n // First test the user supplied value, then use the dynamic.\n this.alignOptions = {\n align: options.align ||\n (inverted ? (isNegative ? 'left' : 'right') : 'center'),\n verticalAlign: options.verticalAlign ||\n (inverted ? 'middle' : (isNegative ? 'bottom' : 'top')),\n y: options.y,\n x: options.x\n };\n this.textAlign = options.textAlign ||\n (inverted ? (isNegative ? 'right' : 'left') : 'center');\n }\n /**\n * @private\n */\n StackItem.prototype.destroy = function () {\n destroyObjectProperties(this, this.axis);\n };\n /**\n * Renders the stack total label and adds it to the stack label group.\n * @private\n */\n StackItem.prototype.render = function (group) {\n var chart = this.axis.chart,\n options = this.options,\n formatOption = options.format,\n str = formatOption ? // format the text in the label\n format(formatOption,\n this,\n chart) :\n options.formatter.call(this);\n // Change the text to reflect the new total and set visibility to hidden\n // in case the serie is hidden\n if (this.label) {\n this.label.attr({ text: str, visibility: 'hidden' });\n }\n else {\n // Create new label\n this.label = chart.renderer\n .label(str, null, null, options.shape, null, null, options.useHTML, false, 'stack-labels');\n var attr = {\n r: options.borderRadius || 0,\n text: str,\n rotation: options.rotation,\n // set default padding to 5 as it is in datalabels #12308\n padding: pick(options.padding, 5),\n visibility: 'hidden' // hidden until setOffset is called\n };\n if (!chart.styledMode) {\n attr.fill = options.backgroundColor;\n attr.stroke = options.borderColor;\n attr['stroke-width'] = options.borderWidth;\n this.label.css(options.style);\n }\n this.label.attr(attr);\n if (!this.label.added) {\n this.label.add(group); // add to the labels-group\n }\n }\n // Rank it higher than data labels (#8742)\n this.label.labelrank = chart.plotSizeY;\n };\n /**\n * Sets the offset that the stack has from the x value and repositions the\n * label.\n * @private\n */\n StackItem.prototype.setOffset = function (xOffset, xWidth, boxBottom, boxTop, defaultX) {\n var axis = this.axis,\n chart = axis.chart, \n // stack value translated mapped to chart coordinates\n y = axis.translate(axis.stacking.usePercentage ?\n 100 :\n (boxTop ?\n boxTop :\n this.total), 0, 0, 0, 1),\n yZero = axis.translate(boxBottom ? boxBottom : 0), // stack origin\n // x position:\n x = pick(defaultX,\n chart.xAxis[0].translate(this.x)) +\n xOffset,\n stackBox = defined(y) && this.getStackBox(chart,\n this,\n x,\n y,\n xWidth, \n // stack height:\n Math.abs(y - yZero),\n axis),\n label = this.label,\n isNegative = this.isNegative,\n textAlign = this.textAlign;\n if (label && stackBox) {\n var bBox = label.getBBox(),\n padding = label.padding;\n var boxOffsetX = void 0,\n isJustify = pick(this.options.overflow, 'justify') === 'justify',\n visible = void 0;\n if (textAlign === 'left') {\n boxOffsetX = chart.inverted ? -padding : padding;\n }\n else if (textAlign === 'right') {\n boxOffsetX = bBox.width;\n }\n else {\n if (chart.inverted && textAlign === 'center') {\n boxOffsetX = bBox.width / 2;\n }\n else {\n boxOffsetX = chart.inverted ?\n (isNegative ? bBox.width + padding : -padding) :\n bBox.width / 2;\n }\n }\n var boxOffsetY = chart.inverted ?\n bBox.height / 2 : (isNegative ? -padding : bBox.height);\n // Reset alignOptions property after justify #12337\n this.alignOptions.x = pick(this.options.x, 0);\n this.alignOptions.y = pick(this.options.y, 0);\n // Set the stackBox position\n stackBox.x -= boxOffsetX;\n stackBox.y -= boxOffsetY;\n // Align the label to the box\n label.align(this.alignOptions, null, stackBox);\n // Check if label is inside the plotArea #12294\n if (chart.isInsidePlot(label.alignAttr.x + boxOffsetX - this.alignOptions.x, label.alignAttr.y + boxOffsetY - this.alignOptions.y)) {\n label.show();\n }\n else {\n // Move label away to avoid the overlapping issues\n label.hide();\n isJustify = false;\n }\n if (isJustify) {\n // Justify stackLabel into the stackBox\n Series.prototype.justifyDataLabel.call(this.axis, label, this.alignOptions, label.alignAttr, bBox, stackBox);\n }\n label.attr({\n x: label.alignAttr.x,\n y: label.alignAttr.y\n });\n if (pick(!isJustify && this.options.crop, true)) {\n visible =\n isNumber(label.x) &&\n isNumber(label.y) &&\n chart.isInsidePlot(label.x - padding + label.width, label.y) &&\n chart.isInsidePlot(label.x + padding, label.y);\n if (!visible) {\n label.hide();\n }\n }\n }\n };\n /**\n * @private\n * @function Highcharts.StackItem#getStackBox\n */\n StackItem.prototype.getStackBox = function (chart, stackItem, x, y, xWidth, h, axis) {\n var reversed = stackItem.axis.reversed,\n inverted = chart.inverted,\n axisPos = axis.height + axis.pos -\n (inverted ? chart.plotLeft : chart.plotTop),\n neg = (stackItem.isNegative && !reversed) ||\n (!stackItem.isNegative && reversed); // #4056\n return {\n x: inverted ?\n (neg ? y - axis.right : y - h + axis.pos - chart.plotLeft) :\n x + chart.xAxis[0].transB - chart.plotLeft,\n y: inverted ?\n axis.height - x - xWidth :\n (neg ?\n (axisPos - y - h) :\n axisPos - y),\n width: inverted ? h : xWidth,\n height: inverted ? xWidth : h\n };\n };\n return StackItem;\n }());\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Stack of data points\n *\n * @product highcharts\n *\n * @interface Highcharts.StackItemObject\n */ /**\n * Alignment settings\n * @name Highcharts.StackItemObject#alignOptions\n * @type {Highcharts.AlignObject}\n */ /**\n * Related axis\n * @name Highcharts.StackItemObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * Cumulative value of the stacked data points\n * @name Highcharts.StackItemObject#cumulative\n * @type {number}\n */ /**\n * True if on the negative side\n * @name Highcharts.StackItemObject#isNegative\n * @type {boolean}\n */ /**\n * Related SVG element\n * @name Highcharts.StackItemObject#label\n * @type {Highcharts.SVGElement}\n */ /**\n * Related stack options\n * @name Highcharts.StackItemObject#options\n * @type {Highcharts.YAxisStackLabelsOptions}\n */ /**\n * Total value of the stacked data points\n * @name Highcharts.StackItemObject#total\n * @type {number}\n */ /**\n * Shared x value of the stack\n * @name Highcharts.StackItemObject#x\n * @type {number}\n */\n ''; // keeps doclets above in JS file\n\n return StackItem;\n });\n _registerModule(_modules, 'Core/Axis/Stacking/StackingAxis.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Axis/Axis.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Axis/Stacking/StackItem.js'], _modules['Core/Utilities.js']], function (A, Axis, SeriesRegistry, StackItem, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var getDeferredAnimation = A.getDeferredAnimation;\n var seriesProto = SeriesRegistry.series.prototype;\n var addEvent = U.addEvent,\n correctFloat = U.correctFloat,\n defined = U.defined,\n destroyObjectProperties = U.destroyObjectProperties,\n fireEvent = U.fireEvent,\n isArray = U.isArray,\n isNumber = U.isNumber,\n objectEach = U.objectEach,\n pick = U.pick;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Generate stacks for each series and calculate stacks total values\n *\n * @private\n * @function Highcharts.Chart#getStacks\n */\n function chartGetStacks() {\n var chart = this,\n inverted = chart.inverted;\n // reset stacks for each yAxis\n chart.yAxis.forEach(function (axis) {\n if (axis.stacking && axis.stacking.stacks && axis.hasVisibleSeries) {\n axis.stacking.oldStacks = axis.stacking.stacks;\n }\n });\n chart.series.forEach(function (series) {\n var xAxisOptions = series.xAxis && series.xAxis.options || {};\n if (series.options.stacking &&\n (series.visible === true ||\n chart.options.chart.ignoreHiddenSeries === false)) {\n series.stackKey = [\n series.type,\n pick(series.options.stack, ''),\n inverted ? xAxisOptions.top : xAxisOptions.left,\n inverted ? xAxisOptions.height : xAxisOptions.width\n ].join(',');\n }\n });\n }\n /**\n * @private\n */\n function onAxisDestroy() {\n var stacking = this.stacking;\n if (!stacking) {\n return;\n }\n var stacks = stacking.stacks;\n // Destroy each stack total\n objectEach(stacks, function (stack, stackKey) {\n destroyObjectProperties(stack);\n stacks[stackKey] = null;\n });\n if (stacking &&\n stacking.stackTotalGroup) {\n stacking.stackTotalGroup.destroy();\n }\n }\n /**\n * @private\n */\n function onAxisInit() {\n var axis = this;\n if (!axis.stacking) {\n axis.stacking = new AxisAdditions(axis);\n }\n }\n /**\n * Get stack indicator, according to it's x-value, to determine points with the\n * same x-value\n *\n * @private\n * @function Highcharts.Series#getStackIndicator\n */\n function seriesGetStackIndicator(stackIndicator, x, index, key) {\n // Update stack indicator, when:\n // first point in a stack || x changed || stack type (negative vs positive)\n // changed:\n if (!defined(stackIndicator) ||\n stackIndicator.x !== x ||\n (key && stackIndicator.stackKey !== key)) {\n stackIndicator = {\n x: x,\n index: 0,\n key: key,\n stackKey: key\n };\n }\n else {\n (stackIndicator).index++;\n }\n stackIndicator.key =\n [index, x, stackIndicator.index].join(',');\n return stackIndicator;\n }\n /**\n * Iterate over all stacks and compute the absolute values to percent\n *\n * @private\n * @function Highcharts.Series#modifyStacks\n */\n function seriesModifyStacks() {\n var series = this,\n yAxis = series.yAxis,\n stackKey = series.stackKey,\n stacks = yAxis.stacking.stacks,\n processedXData = series.processedXData,\n stacking = series.options.stacking,\n stacker = series[stacking + 'Stacker'];\n var stackIndicator;\n if (stacker) { // Modifier function exists (Series.percentStacker etc.)\n [stackKey, '-' + stackKey].forEach(function (key) {\n var i = processedXData.length,\n x,\n stack,\n pointExtremes;\n while (i--) {\n x = processedXData[i];\n stackIndicator = series.getStackIndicator(stackIndicator, x, series.index, key);\n stack = stacks[key] && stacks[key][x];\n pointExtremes =\n stack && stack.points[stackIndicator.key];\n if (pointExtremes) {\n stacker.call(series, pointExtremes, stack, i);\n }\n }\n });\n }\n }\n /**\n * Modifier function for percent stacks. Blows up the stack to 100%.\n *\n * @private\n * @function Highcharts.Series#percentStacker\n */\n function seriesPercentStacker(pointExtremes, stack, i) {\n var totalFactor = stack.total ? 100 / stack.total : 0;\n // Y bottom value\n pointExtremes[0] = correctFloat(pointExtremes[0] * totalFactor);\n // Y value\n pointExtremes[1] = correctFloat(pointExtremes[1] * totalFactor);\n this.stackedYData[i] = pointExtremes[1];\n }\n /**\n * Set grouped points in a stack-like object. When `centerInCategory` is true,\n * and `stacking` is not enabled, we need a pseudo (horizontal) stack in order\n * to handle grouping of points within the same category.\n *\n * @private\n * @function Highcharts.Series#setStackedPoints\n * @return {void}\n */\n function seriesSetGroupedPoints() {\n var stacking = this.yAxis.stacking;\n if (this.options.centerInCategory &&\n (this.is('column') || this.is('columnrange')) &&\n // With stacking enabled, we already have stacks that we can compute\n // from\n !this.options.stacking &&\n // With only one series, we don't need to consider centerInCategory\n this.chart.series.length > 1) {\n seriesProto.setStackedPoints.call(this, 'group');\n // After updating, if we now have proper stacks, we must delete the group\n // pseudo stacks (#14986)\n }\n else if (stacking) {\n objectEach(stacking.stacks, function (type, key) {\n if (key.slice(-5) === 'group') {\n objectEach(type, function (stack) { return stack.destroy(); });\n delete stacking.stacks[key];\n }\n });\n }\n }\n /**\n * Adds series' points value to corresponding stack\n *\n * @private\n * @function Highcharts.Series#setStackedPoints\n */\n function seriesSetStackedPoints(stackingParam) {\n var stacking = stackingParam || this.options.stacking;\n if (!stacking || (this.visible !== true &&\n this.chart.options.chart.ignoreHiddenSeries !== false)) {\n return;\n }\n var series = this, xData = series.processedXData, yData = series.processedYData, stackedYData = [], yDataLength = yData.length, seriesOptions = series.options, threshold = seriesOptions.threshold, stackThreshold = pick(seriesOptions.startFromThreshold && threshold, 0), stackOption = seriesOptions.stack, stackKey = stackingParam ? \"\" + series.type + \",\".concat(stacking) : series.stackKey, negKey = '-' + stackKey, negStacks = series.negStacks, yAxis = series.yAxis, stacks = yAxis.stacking.stacks, oldStacks = yAxis.stacking.oldStacks;\n var stackIndicator,\n isNegative,\n stack,\n other,\n key,\n pointKey,\n i,\n x,\n y;\n yAxis.stacking.stacksTouched += 1;\n // loop over the non-null y values and read them into a local array\n for (i = 0; i < yDataLength; i++) {\n x = xData[i];\n y = yData[i];\n stackIndicator = series.getStackIndicator(stackIndicator, x, series.index);\n pointKey = stackIndicator.key;\n // Read stacked values into a stack based on the x value,\n // the sign of y and the stack key. Stacking is also handled for null\n // values (#739)\n isNegative = negStacks && y < (stackThreshold ? 0 : threshold);\n key = isNegative ? negKey : stackKey;\n // Create empty object for this stack if it doesn't exist yet\n if (!stacks[key]) {\n stacks[key] = {};\n }\n // Initialize StackItem for this x\n if (!stacks[key][x]) {\n if (oldStacks[key] &&\n oldStacks[key][x]) {\n stacks[key][x] = oldStacks[key][x];\n stacks[key][x].total = null;\n }\n else {\n stacks[key][x] = new StackItem(yAxis, yAxis.options.stackLabels, !!isNegative, x, stackOption);\n }\n }\n // If the StackItem doesn't exist, create it first\n stack = stacks[key][x];\n if (y !== null) {\n stack.points[pointKey] = stack.points[series.index] =\n [pick(stack.cumulative, stackThreshold)];\n // Record the base of the stack\n if (!defined(stack.cumulative)) {\n stack.base = pointKey;\n }\n stack.touched = yAxis.stacking.stacksTouched;\n // In area charts, if there are multiple points on the same X value,\n // let the area fill the full span of those points\n if (stackIndicator.index > 0 && series.singleStacks === false) {\n stack.points[pointKey][0] =\n stack.points[series.index + ',' + x + ',0'][0];\n }\n // When updating to null, reset the point stack (#7493)\n }\n else {\n stack.points[pointKey] = stack.points[series.index] =\n null;\n }\n // Add value to the stack total\n if (stacking === 'percent') {\n // Percent stacked column, totals are the same for the positive and\n // negative stacks\n other = isNegative ? stackKey : negKey;\n if (negStacks && stacks[other] && stacks[other][x]) {\n other = stacks[other][x];\n stack.total = other.total =\n Math.max(other.total, stack.total) +\n Math.abs(y) ||\n 0;\n // Percent stacked areas\n }\n else {\n stack.total =\n correctFloat(stack.total + (Math.abs(y) || 0));\n }\n }\n else if (stacking === 'group') {\n if (isArray(y)) {\n y = y[0];\n }\n // In this stack, the total is the number of valid points\n if (y !== null) {\n stack.total = (stack.total || 0) + 1;\n }\n }\n else {\n stack.total = correctFloat(stack.total + (y || 0));\n }\n if (stacking === 'group') {\n // This point's index within the stack, pushed to stack.points[1]\n stack.cumulative = (stack.total || 1) - 1;\n }\n else {\n stack.cumulative =\n pick(stack.cumulative, stackThreshold) + (y || 0);\n }\n if (y !== null) {\n stack.points[pointKey].push(stack.cumulative);\n stackedYData[i] = stack.cumulative;\n stack.hasValidPoints = true;\n }\n }\n if (stacking === 'percent') {\n yAxis.stacking.usePercentage = true;\n }\n if (stacking !== 'group') {\n this.stackedYData = stackedYData; // To be used in getExtremes\n }\n // Reset old stacks\n yAxis.stacking.oldStacks = {};\n }\n /* *\n *\n * Classes\n *\n * */\n /**\n * Adds stacking support to axes.\n * @private\n * @class\n */\n var AxisAdditions = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function AxisAdditions(axis) {\n this.oldStacks = {};\n this.stacks = {};\n this.stacksTouched = 0;\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Build the stacks from top down\n * @private\n */\n AxisAdditions.prototype.buildStacks = function () {\n var stacking = this;\n var axis = stacking.axis;\n var axisSeries = axis.series;\n var reversedStacks = axis.options.reversedStacks;\n var len = axisSeries.length;\n var actualSeries,\n i;\n if (!axis.isXAxis) {\n stacking.usePercentage = false;\n i = len;\n while (i--) {\n actualSeries = axisSeries[reversedStacks ? i : len - i - 1];\n actualSeries.setStackedPoints();\n actualSeries.setGroupedPoints();\n }\n // Loop up again to compute percent and stream stack\n for (i = 0; i < len; i++) {\n axisSeries[i].modifyStacks();\n }\n fireEvent(axis, 'afterBuildStacks');\n }\n };\n /**\n * @private\n */\n AxisAdditions.prototype.cleanStacks = function () {\n var stacking = this,\n axis = stacking.axis;\n var stacks;\n if (!axis.isXAxis) {\n if (stacking.oldStacks) {\n stacks = stacking.stacks = stacking.oldStacks;\n }\n // reset stacks\n objectEach(stacks, function (type) {\n objectEach(type, function (stack) {\n stack.cumulative = stack.total;\n });\n });\n }\n };\n /**\n * Set all the stacks to initial states and destroy unused ones.\n * @private\n */\n AxisAdditions.prototype.resetStacks = function () {\n var stacking = this,\n axis = stacking.axis,\n stacks = stacking.stacks;\n if (!axis.isXAxis) {\n objectEach(stacks, function (type) {\n objectEach(type, function (stack, x) {\n // Clean up memory after point deletion (#1044, #4320)\n if (isNumber(stack.touched) &&\n stack.touched < stacking.stacksTouched) {\n stack.destroy();\n delete type[x];\n // Reset stacks\n }\n else {\n stack.total = null;\n stack.cumulative = null;\n }\n });\n });\n }\n };\n /**\n * @private\n */\n AxisAdditions.prototype.renderStackTotals = function () {\n var stacking = this,\n axis = stacking.axis,\n chart = axis.chart,\n renderer = chart.renderer,\n stacks = stacking.stacks,\n stackLabelsAnim = axis.options.stackLabels &&\n axis.options.stackLabels.animation,\n animationConfig = getDeferredAnimation(chart,\n stackLabelsAnim || false),\n stackTotalGroup = stacking.stackTotalGroup = (stacking.stackTotalGroup ||\n renderer\n .g('stack-labels')\n .attr({\n zIndex: 6,\n opacity: 0\n })\n .add());\n // plotLeft/Top will change when y axis gets wider so we need to\n // translate the stackTotalGroup at every render call. See bug #506\n // and #516\n stackTotalGroup.translate(chart.plotLeft, chart.plotTop);\n // Render each stack total\n objectEach(stacks, function (type) {\n objectEach(type, function (stack) {\n stack.render(stackTotalGroup);\n });\n });\n stackTotalGroup.animate({\n opacity: 1\n }, animationConfig);\n };\n return AxisAdditions;\n }());\n /* *\n *\n * Composition\n *\n * */\n var StackingAxis;\n (function (StackingAxis) {\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extends axis with stacking support.\n * @private\n */\n function compose(AxisClass, ChartClass, SeriesClass) {\n if (composedClasses.indexOf(AxisClass) === -1) {\n composedClasses.push(AxisClass);\n addEvent(AxisClass, 'init', onAxisInit);\n addEvent(AxisClass, 'destroy', onAxisDestroy);\n }\n if (composedClasses.indexOf(ChartClass) === -1) {\n composedClasses.push(ChartClass);\n var chartProto = ChartClass.prototype;\n chartProto.getStacks = chartGetStacks;\n }\n if (composedClasses.indexOf(SeriesClass) === -1) {\n composedClasses.push(SeriesClass);\n var seriesProto_1 = SeriesClass.prototype;\n seriesProto_1.getStackIndicator = seriesGetStackIndicator;\n seriesProto_1.modifyStacks = seriesModifyStacks;\n seriesProto_1.percentStacker = seriesPercentStacker;\n seriesProto_1.setGroupedPoints = seriesSetGroupedPoints;\n seriesProto_1.setStackedPoints = seriesSetStackedPoints;\n }\n }\n StackingAxis.compose = compose;\n })(StackingAxis || (StackingAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return StackingAxis;\n });\n _registerModule(_modules, 'Series/Line/LineSeries.js', [_modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (Series, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var defined = U.defined,\n merge = U.merge;\n /* *\n *\n * Class\n *\n * */\n /**\n * The line series is the base type and is therefor the series base prototype.\n *\n * @private\n */\n var LineSeries = /** @class */ (function (_super) {\n __extends(LineSeries, _super);\n function LineSeries() {\n /* *\n *\n * Static Functions\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.data = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Draw the graph. Called internally when rendering line-like series\n * types. The first time it generates the `series.graph` item and\n * optionally other series-wide items like `series.area` for area\n * charts. On subsequent calls these items are updated with new\n * positions and attributes.\n *\n * @function Highcharts.Series#drawGraph\n */\n LineSeries.prototype.drawGraph = function () {\n var series = this,\n options = this.options,\n graphPath = (this.gappedPath || this.getGraphPath).call(this),\n styledMode = this.chart.styledMode;\n var props = [[\n 'graph',\n 'highcharts-graph'\n ]];\n // Presentational properties\n if (!styledMode) {\n props[0].push((options.lineColor ||\n this.color ||\n \"#cccccc\" /* Palette.neutralColor20 */ // when colorByPoint = true\n ), options.dashStyle);\n }\n props = series.getZonesGraphs(props);\n // Draw the graph\n props.forEach(function (prop, i) {\n var graphKey = prop[0];\n var attribs,\n graph = series[graphKey];\n var verb = graph ? 'animate' : 'attr';\n if (graph) {\n graph.endX = series.preventGraphAnimation ?\n null :\n graphPath.xMap;\n graph.animate({ d: graphPath });\n }\n else if (graphPath.length) { // #1487\n /**\n * SVG element of area-based charts. Can be used for styling\n * purposes. If zones are configured, this element will be\n * hidden and replaced by multiple zone areas, accessible\n * via `series['zone-area-x']` (where x is a number,\n * starting with 0).\n *\n * @name Highcharts.Series#area\n * @type {Highcharts.SVGElement|undefined}\n */\n /**\n * SVG element of line-based charts. Can be used for styling\n * purposes. If zones are configured, this element will be\n * hidden and replaced by multiple zone lines, accessible\n * via `series['zone-graph-x']` (where x is a number,\n * starting with 0).\n *\n * @name Highcharts.Series#graph\n * @type {Highcharts.SVGElement|undefined}\n */\n series[graphKey] = graph = series.chart.renderer\n .path(graphPath)\n .addClass(prop[1])\n .attr({ zIndex: 1 }) // #1069\n .add(series.group);\n }\n if (graph && !styledMode) {\n attribs = {\n 'stroke': prop[2],\n 'stroke-width': options.lineWidth,\n // Polygon series use filled graph\n 'fill': (series.fillGraph && series.color) || 'none'\n };\n if (prop[3]) {\n attribs.dashstyle = prop[3];\n }\n else if (options.linecap !== 'square') {\n attribs['stroke-linecap'] =\n attribs['stroke-linejoin'] = 'round';\n }\n graph[verb](attribs)\n // Add shadow to normal series (0) or to first\n // zone (1) #3932\n .shadow((i < 2) && options.shadow);\n }\n // Helpers for animation\n if (graph) {\n graph.startX = graphPath.xMap;\n graph.isArea = graphPath.isArea; // For arearange animation\n }\n });\n };\n // eslint-disable-next-line valid-jsdoc\n /**\n * Get the graph path.\n *\n * @private\n */\n LineSeries.prototype.getGraphPath = function (points, nullsAsZeroes, connectCliffs) {\n var series = this,\n options = series.options,\n graphPath = [],\n xMap = [];\n var gap,\n step = options.step;\n points = points || series.points;\n // Bottom of a stack is reversed\n var reversed = points.reversed;\n if (reversed) {\n points.reverse();\n }\n // Reverse the steps (#5004)\n step = {\n right: 1,\n center: 2\n }[step] || (step && 3);\n if (step && reversed) {\n step = 4 - step;\n }\n // Remove invalid points, especially in spline (#5015)\n points = this.getValidPoints(points, false, !(options.connectNulls && !nullsAsZeroes && !connectCliffs));\n // Build the line\n points.forEach(function (point, i) {\n var plotX = point.plotX,\n plotY = point.plotY,\n lastPoint = points[i - 1];\n // the path to this point from the previous\n var pathToPoint;\n if ((point.leftCliff || (lastPoint && lastPoint.rightCliff)) &&\n !connectCliffs) {\n gap = true; // ... and continue\n }\n // Line series, nullsAsZeroes is not handled\n if (point.isNull && !defined(nullsAsZeroes) && i > 0) {\n gap = !options.connectNulls;\n // Area series, nullsAsZeroes is set\n }\n else if (point.isNull && !nullsAsZeroes) {\n gap = true;\n }\n else {\n if (i === 0 || gap) {\n pathToPoint = [[\n 'M',\n point.plotX,\n point.plotY\n ]];\n // Generate the spline as defined in the SplineSeries object\n }\n else if (series.getPointSpline) {\n pathToPoint = [series.getPointSpline(points, point, i)];\n }\n else if (step) {\n if (step === 1) { // right\n pathToPoint = [[\n 'L',\n lastPoint.plotX,\n plotY\n ]];\n }\n else if (step === 2) { // center\n pathToPoint = [[\n 'L',\n (lastPoint.plotX + plotX) / 2,\n lastPoint.plotY\n ], [\n 'L',\n (lastPoint.plotX + plotX) / 2,\n plotY\n ]];\n }\n else {\n pathToPoint = [[\n 'L',\n plotX,\n lastPoint.plotY\n ]];\n }\n pathToPoint.push([\n 'L',\n plotX,\n plotY\n ]);\n }\n else {\n // normal line to next point\n pathToPoint = [[\n 'L',\n plotX,\n plotY\n ]];\n }\n // Prepare for animation. When step is enabled, there are\n // two path nodes for each x value.\n xMap.push(point.x);\n if (step) {\n xMap.push(point.x);\n if (step === 2) { // step = center (#8073)\n xMap.push(point.x);\n }\n }\n graphPath.push.apply(graphPath, pathToPoint);\n gap = false;\n }\n });\n graphPath.xMap = xMap;\n series.graphPath = graphPath;\n return graphPath;\n };\n // eslint-disable-next-line valid-jsdoc\n /**\n * Get zones properties for building graphs. Extendable by series with\n * multiple lines within one series.\n *\n * @private\n */\n LineSeries.prototype.getZonesGraphs = function (props) {\n // Add the zone properties if any\n this.zones.forEach(function (zone, i) {\n var propset = [\n 'zone-graph-' + i,\n 'highcharts-graph highcharts-zone-graph-' + i + ' ' +\n (zone.className || '')\n ];\n if (!this.chart.styledMode) {\n propset.push((zone.color || this.color), (zone.dashStyle || this.options.dashStyle));\n }\n props.push(propset);\n }, this);\n return props;\n };\n LineSeries.defaultOptions = merge(Series.defaultOptions, \n /**\n * General options for all series types.\n *\n * @optionparent plotOptions.series\n */\n {\n // nothing here yet\n });\n return LineSeries;\n }(Series));\n SeriesRegistry.registerSeriesType('line', LineSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A line series displays information as a series of data points connected by\n * straight line segments.\n *\n * @sample {highcharts} highcharts/demo/line-basic/\n * Line chart\n * @sample {highstock} stock/demo/basic-line/\n * Line chart\n *\n * @extends plotOptions.series\n * @product highcharts highstock\n * @apioption plotOptions.line\n */\n /**\n * The SVG value used for the `stroke-linecap` and `stroke-linejoin`\n * of a line graph. Round means that lines are rounded in the ends and\n * bends.\n *\n * @type {Highcharts.SeriesLinecapValue}\n * @default round\n * @since 3.0.7\n * @apioption plotOptions.line.linecap\n */\n /**\n * A `line` series. If the [type](#series.line.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.line\n * @excluding dataParser,dataURL\n * @product highcharts highstock\n * @apioption series.line\n */\n /**\n * An array of data points for the series. For the `line` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 1],\n * [1, 2],\n * [2, 8]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.line.turboThreshold),\n * this option is not available.\n * ```js\n * data: [{\n * x: 1,\n * y: 9,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 6,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * **Note:** In TypeScript you have to extend `PointOptionsObject` with an\n * additional declaration to allow custom data types:\n * ```ts\n * declare module `highcharts` {\n * interface PointOptionsObject {\n * custom: Record;\n * }\n * }\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @declare Highcharts.PointOptionsObject\n * @type {Array|null|*>}\n * @apioption series.line.data\n */\n /**\n * An additional, individual class name for the data point's graphic\n * representation.\n *\n * @type {string}\n * @since 5.0.0\n * @product highcharts gantt\n * @apioption series.line.data.className\n */\n /**\n * Individual color for the point. By default the color is pulled from\n * the global `colors` array.\n *\n * In styled mode, the `color` option doesn't take effect. Instead, use\n * `colorIndex`.\n *\n * @sample {highcharts} highcharts/point/color/\n * Mark the highest point\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts highstock gantt\n * @apioption series.line.data.color\n */\n /**\n * A specific color index to use for the point, so its graphic representations\n * are given the class name `highcharts-color-{n}`. In styled mode this will\n * change the color of the graphic. In non-styled mode, the color is set by the\n * `fill` attribute, so the change in class name won't have a visual effect by\n * default.\n *\n * @sample {highcharts} highcharts/css/colorindex/\n * Series and point color index\n *\n * @type {number}\n * @since 5.0.0\n * @product highcharts gantt\n * @apioption series.line.data.colorIndex\n */\n /**\n * A reserved subspace to store options and values for customized functionality.\n * Here you can add additional data for your own event callbacks and formatter\n * callbacks.\n *\n * @sample {highcharts} highcharts/point/custom/\n * Point and series with custom data\n *\n * @type {Highcharts.Dictionary<*>}\n * @apioption series.line.data.custom\n */\n /**\n * Individual data label for each point. The options are the same as\n * the ones for [plotOptions.series.dataLabels](\n * #plotOptions.series.dataLabels).\n *\n * @sample highcharts/point/datalabels/\n * Show a label for the last value\n *\n * @declare Highcharts.DataLabelsOptions\n * @extends plotOptions.line.dataLabels\n * @product highcharts highstock gantt\n * @apioption series.line.data.dataLabels\n */\n /**\n * A description of the point to add to the screen reader information\n * about the point.\n *\n * @type {string}\n * @since 5.0.0\n * @requires modules/accessibility\n * @apioption series.line.data.description\n */\n /**\n * An id for the point. This can be used after render time to get a\n * pointer to the point object through `chart.get()`.\n *\n * @sample {highcharts} highcharts/point/id/\n * Remove an id'd point\n *\n * @type {string}\n * @since 1.2.0\n * @product highcharts highstock gantt\n * @apioption series.line.data.id\n */\n /**\n * The rank for this point's data label in case of collision. If two\n * data labels are about to overlap, only the one with the highest `labelrank`\n * will be drawn.\n *\n * @type {number}\n * @apioption series.line.data.labelrank\n */\n /**\n * The name of the point as shown in the legend, tooltip, dataLabels, etc.\n *\n * @see [xAxis.uniqueNames](#xAxis.uniqueNames)\n *\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Point names\n *\n * @type {string}\n * @apioption series.line.data.name\n */\n /**\n * Whether the data point is selected initially.\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock gantt\n * @apioption series.line.data.selected\n */\n /**\n * The x value of the point. For datetime axes, the X value is the timestamp\n * in milliseconds since 1970.\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption series.line.data.x\n */\n /**\n * The y value of the point.\n *\n * @type {number|null}\n * @product highcharts highstock\n * @apioption series.line.data.y\n */\n /**\n * The individual point events.\n *\n * @extends plotOptions.series.point.events\n * @product highcharts highstock gantt\n * @apioption series.line.data.events\n */\n /**\n * Options for the point markers of line-like series.\n *\n * @declare Highcharts.PointMarkerOptionsObject\n * @extends plotOptions.series.marker\n * @product highcharts highstock\n * @apioption series.line.data.marker\n */\n ''; // include precedent doclets in transpilat\n\n return LineSeries;\n });\n _registerModule(_modules, 'Series/Area/AreaSeries.js', [_modules['Core/Color/Color.js'], _modules['Core/Legend/LegendSymbol.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (Color, LegendSymbol, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var color = Color.parse;\n var LineSeries = SeriesRegistry.seriesTypes.line;\n var extend = U.extend,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick;\n /* *\n *\n * Class\n *\n * */\n /**\n * Area series type.\n *\n * @private\n * @class\n * @name AreaSeries\n *\n * @augments LineSeries\n */\n var AreaSeries = /** @class */ (function (_super) {\n __extends(AreaSeries, _super);\n function AreaSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n _this.data = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Draw the graph and the underlying area. This method calls the Series\n * base function and adds the area. The areaPath is calculated in the\n * getSegmentPath method called from Series.prototype.drawGraph.\n * @private\n */\n AreaSeries.prototype.drawGraph = function () {\n // Define or reset areaPath\n this.areaPath = [];\n // Call the base method\n _super.prototype.drawGraph.apply(this);\n // Define local variables\n var series = this,\n areaPath = this.areaPath,\n options = this.options,\n zones = this.zones,\n props = [[\n 'area',\n 'highcharts-area',\n this.color,\n options.fillColor\n ]]; // area name, main color, fill color\n zones.forEach(function (zone,\n i) {\n props.push([\n 'zone-area-' + i,\n 'highcharts-area highcharts-zone-area-' + i + ' ' +\n zone.className,\n zone.color || series.color,\n zone.fillColor || options.fillColor\n ]);\n });\n props.forEach(function (prop) {\n var areaKey = prop[0],\n attribs = {};\n var area = series[areaKey];\n var verb = area ? 'animate' : 'attr';\n // Create or update the area\n if (area) { // update\n area.endX = series.preventGraphAnimation ?\n null :\n areaPath.xMap;\n area.animate({ d: areaPath });\n }\n else { // create\n attribs.zIndex = 0; // #1069\n area = series[areaKey] = series.chart.renderer\n .path(areaPath)\n .addClass(prop[1])\n .add(series.group);\n area.isArea = true;\n }\n if (!series.chart.styledMode) {\n attribs.fill = pick(prop[3], color(prop[2])\n .setOpacity(pick(options.fillOpacity, 0.75))\n .get());\n }\n area[verb](attribs);\n area.startX = areaPath.xMap;\n area.shiftUnit = options.step ? 2 : 1;\n });\n };\n /**\n * @private\n */\n AreaSeries.prototype.getGraphPath = function (points) {\n var getGraphPath = LineSeries.prototype.getGraphPath, options = this.options, stacking = options.stacking, yAxis = this.yAxis, bottomPoints = [], graphPoints = [], seriesIndex = this.index, stacks = yAxis.stacking.stacks[this.stackKey], threshold = options.threshold, translatedThreshold = Math.round(// #10909\n yAxis.getThreshold(options.threshold)), connectNulls = pick(// #10574\n options.connectNulls, stacking === 'percent'), \n // To display null points in underlying stacked series, this\n // series graph must be broken, and the area also fall down to\n // fill the gap left by the null point. #2069\n addDummyPoints = function (i, otherI, side) {\n var point = points[i], stackedValues = stacking &&\n stacks[point.x].points[seriesIndex], nullVal = point[side + 'Null'] || 0, cliffVal = point[side + 'Cliff'] || 0;\n var top,\n bottom,\n isNull = true;\n if (cliffVal || nullVal) {\n top = (nullVal ?\n stackedValues[0] :\n stackedValues[1]) + cliffVal;\n bottom = stackedValues[0] + cliffVal;\n isNull = !!nullVal;\n }\n else if (!stacking &&\n points[otherI] &&\n points[otherI].isNull) {\n top = bottom = threshold;\n }\n // Add to the top and bottom line of the area\n if (typeof top !== 'undefined') {\n graphPoints.push({\n plotX: plotX,\n plotY: top === null ?\n translatedThreshold :\n yAxis.getThreshold(top),\n isNull: isNull,\n isCliff: true\n });\n bottomPoints.push({\n plotX: plotX,\n plotY: bottom === null ?\n translatedThreshold :\n yAxis.getThreshold(bottom),\n doCurve: false // #1041, gaps in areaspline areas\n });\n }\n };\n var plotX,\n isNull,\n yBottom;\n // Find what points to use\n points = points || this.points;\n // Fill in missing points\n if (stacking) {\n points = this.getStackPoints(points);\n }\n for (var i = 0, iEnd = points.length; i < iEnd; ++i) {\n // Reset after series.update of stacking property (#12033)\n if (!stacking) {\n points[i].leftCliff = points[i].rightCliff =\n points[i].leftNull = points[i].rightNull = void 0;\n }\n isNull = points[i].isNull;\n plotX = pick(points[i].rectPlotX, points[i].plotX);\n yBottom = stacking ?\n pick(points[i].yBottom, translatedThreshold) :\n translatedThreshold;\n if (!isNull || connectNulls) {\n if (!connectNulls) {\n addDummyPoints(i, i - 1, 'left');\n }\n // Skip null point when stacking is false and connectNulls\n // true\n if (!(isNull && !stacking && connectNulls)) {\n graphPoints.push(points[i]);\n bottomPoints.push({\n x: i,\n plotX: plotX,\n plotY: yBottom\n });\n }\n if (!connectNulls) {\n addDummyPoints(i, i + 1, 'right');\n }\n }\n }\n var topPath = getGraphPath.call(this,\n graphPoints,\n true,\n true);\n bottomPoints.reversed = true;\n var bottomPath = getGraphPath.call(this,\n bottomPoints,\n true,\n true);\n var firstBottomPoint = bottomPath[0];\n if (firstBottomPoint && firstBottomPoint[0] === 'M') {\n bottomPath[0] = ['L', firstBottomPoint[1], firstBottomPoint[2]];\n }\n var areaPath = topPath.concat(bottomPath);\n if (areaPath.length) {\n areaPath.push(['Z']);\n }\n // TODO: don't set leftCliff and rightCliff when connectNulls?\n var graphPath = getGraphPath\n .call(this,\n graphPoints,\n false,\n connectNulls);\n areaPath.xMap = topPath.xMap;\n this.areaPath = areaPath;\n return graphPath;\n };\n /**\n * Return an array of stacked points, where null and missing points are\n * replaced by dummy points in order for gaps to be drawn correctly in\n * stacks.\n * @private\n */\n AreaSeries.prototype.getStackPoints = function (points) {\n var series = this,\n segment = [],\n keys = [],\n xAxis = this.xAxis,\n yAxis = this.yAxis,\n stack = yAxis.stacking.stacks[this.stackKey],\n pointMap = {},\n yAxisSeries = yAxis.series,\n seriesLength = yAxisSeries.length,\n upOrDown = yAxis.options.reversedStacks ? 1 : -1,\n seriesIndex = yAxisSeries.indexOf(series);\n points = points || this.points;\n if (this.options.stacking) {\n for (var i = 0; i < points.length; i++) {\n // Reset after point update (#7326)\n points[i].leftNull = points[i].rightNull = void 0;\n // Create a map where we can quickly look up the points by\n // their X values.\n pointMap[points[i].x] = points[i];\n }\n // Sort the keys (#1651)\n objectEach(stack, function (stackX, x) {\n // nulled after switching between\n // grouping and not (#1651, #2336)\n if (stackX.total !== null) {\n keys.push(x);\n }\n });\n keys.sort(function (a, b) {\n return a - b;\n });\n var visibleSeries_1 = yAxisSeries.map(function (s) { return s.visible; });\n keys.forEach(function (x, idx) {\n var y = 0,\n stackPoint,\n stackedValues;\n if (pointMap[x] && !pointMap[x].isNull) {\n segment.push(pointMap[x]);\n // Find left and right cliff. -1 goes left, 1 goes\n // right.\n [-1, 1].forEach(function (direction) {\n var nullName = direction === 1 ?\n 'rightNull' :\n 'leftNull',\n cliffName = direction === 1 ?\n 'rightCliff' :\n 'leftCliff',\n otherStack = stack[keys[idx + direction]];\n var cliff = 0;\n // If there is a stack next to this one,\n // to the left or to the right...\n if (otherStack) {\n var i = seriesIndex;\n // Can go either up or down,\n // depending on reversedStacks\n while (i >= 0 && i < seriesLength) {\n var si = yAxisSeries[i].index;\n stackPoint = otherStack.points[si];\n if (!stackPoint) {\n // If the next point in this series is\n // missing, mark the point with\n // point.leftNull or point.rightNull = true.\n if (si === series.index) {\n pointMap[x][nullName] = true;\n // If there are missing points in the next\n // stack in any of the series below this\n // one, we need to substract the missing\n // values and add a hiatus to the left or\n // right.\n }\n else if (visibleSeries_1[i]) {\n stackedValues = stack[x].points[si];\n if (stackedValues) {\n cliff -= (stackedValues[1] -\n stackedValues[0]);\n }\n }\n }\n // When reversedStacks is true, loop up,\n // else loop down\n i += upOrDown;\n }\n }\n pointMap[x][cliffName] = cliff;\n });\n // There is no point for this X value in this series, so we\n // insert a dummy point in order for the areas to be drawn\n // correctly.\n }\n else {\n // Loop down the stack to find the series below this\n // one that has a value (#1991)\n var i = seriesIndex;\n while (i >= 0 && i < seriesLength) {\n var si = yAxisSeries[i].index;\n stackPoint = stack[x].points[si];\n if (stackPoint) {\n y = stackPoint[1];\n break;\n }\n // When reversedStacks is true, loop up, else loop\n // down\n i += upOrDown;\n }\n y = pick(y, 0);\n y = yAxis.translate(// #6272\n y, 0, 1, 0, 1);\n segment.push({\n isNull: true,\n plotX: xAxis.translate(// #6272\n x, 0, 0, 0, 1),\n x: x,\n plotY: y,\n yBottom: y\n });\n }\n });\n }\n return segment;\n };\n /**\n * The area series type.\n *\n * @sample {highcharts} highcharts/demo/area-basic/\n * Area chart\n * @sample {highstock} stock/demo/area/\n * Area chart\n *\n * @extends plotOptions.line\n * @excluding useOhlcData\n * @product highcharts highstock\n * @optionparent plotOptions.area\n */\n AreaSeries.defaultOptions = merge(LineSeries.defaultOptions, {\n /**\n * @see [fillColor](#plotOptions.area.fillColor)\n * @see [fillOpacity](#plotOptions.area.fillOpacity)\n *\n * @apioption plotOptions.area.color\n */\n /**\n * Fill color or gradient for the area. When `null`, the series' `color`\n * is used with the series' `fillOpacity`.\n *\n * In styled mode, the fill color can be set with the `.highcharts-area`\n * class name.\n *\n * @see [color](#plotOptions.area.color)\n * @see [fillOpacity](#plotOptions.area.fillOpacity)\n *\n * @sample {highcharts} highcharts/plotoptions/area-fillcolor-default/\n * Null by default\n * @sample {highcharts} highcharts/plotoptions/area-fillcolor-gradient/\n * Gradient\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts highstock\n * @apioption plotOptions.area.fillColor\n */\n /**\n * Fill opacity for the area. When you set an explicit `fillColor`,\n * the `fillOpacity` is not applied. Instead, you should define the\n * opacity in the `fillColor` with an rgba color definition. The\n * `fillOpacity` setting, also the default setting, overrides the alpha\n * component of the `color` setting.\n *\n * In styled mode, the fill opacity can be set with the\n * `.highcharts-area` class name.\n *\n * @see [color](#plotOptions.area.color)\n * @see [fillColor](#plotOptions.area.fillColor)\n *\n * @sample {highcharts} highcharts/plotoptions/area-fillopacity/\n * Automatic fill color and fill opacity of 0.1\n *\n * @type {number}\n * @default {highcharts} 0.75\n * @default {highstock} 0.75\n * @product highcharts highstock\n * @apioption plotOptions.area.fillOpacity\n */\n /**\n * A separate color for the graph line. By default the line takes the\n * `color` of the series, but the lineColor setting allows setting a\n * separate color for the line without altering the `fillColor`.\n *\n * In styled mode, the line stroke can be set with the\n * `.highcharts-graph` class name.\n *\n * @sample {highcharts} highcharts/plotoptions/area-linecolor/\n * Dark gray line\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts highstock\n * @apioption plotOptions.area.lineColor\n */\n /**\n * A separate color for the negative part of the area.\n *\n * In styled mode, a negative color is set with the\n * `.highcharts-negative` class name.\n *\n * @see [negativeColor](#plotOptions.area.negativeColor)\n *\n * @sample {highcharts} highcharts/css/series-negative-color/\n * Negative color in styled mode\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 3.0\n * @product highcharts\n * @apioption plotOptions.area.negativeFillColor\n */\n /**\n * Whether the whole area or just the line should respond to mouseover\n * tooltips and other mouse or touch events.\n *\n * @sample {highcharts|highstock} highcharts/plotoptions/area-trackbyarea/\n * Display the tooltip when the area is hovered\n *\n * @type {boolean}\n * @default false\n * @since 1.1.6\n * @product highcharts highstock\n * @apioption plotOptions.area.trackByArea\n */\n /**\n * The Y axis value to serve as the base for the area, for\n * distinguishing between values above and below a threshold. The area\n * between the graph and the threshold is filled.\n *\n * * If a number is given, the Y axis will scale to the threshold.\n * * If `null`, the scaling behaves like a line series with fill between\n * the graph and the Y axis minimum.\n * * If `Infinity` or `-Infinity`, the area between the graph and the\n * corresponding Y axis extreme is filled (since v6.1.0).\n *\n * @sample {highcharts} highcharts/plotoptions/area-threshold/\n * A threshold of 100\n * @sample {highcharts} highcharts/plotoptions/area-threshold-infinity/\n * A threshold of Infinity\n *\n * @type {number|null}\n * @since 2.0\n * @product highcharts highstock\n */\n threshold: 0\n });\n return AreaSeries;\n }(LineSeries));\n extend(AreaSeries.prototype, {\n singleStacks: false,\n drawLegendSymbol: LegendSymbol.drawRectangle\n });\n SeriesRegistry.registerSeriesType('area', AreaSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A `area` series. If the [type](#series.area.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.area\n * @excluding dataParser, dataURL, useOhlcData\n * @product highcharts highstock\n * @apioption series.area\n */\n /**\n * @see [fillColor](#series.area.fillColor)\n * @see [fillOpacity](#series.area.fillOpacity)\n *\n * @apioption series.area.color\n */\n /**\n * An array of data points for the series. For the `area` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` * and `pointInterval` given in the series options. If the\n * axis has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 9],\n * [1, 7],\n * [2, 6]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.area.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 9,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 6,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @product highcharts highstock\n * @apioption series.area.data\n */\n /**\n * @see [color](#series.area.color)\n * @see [fillOpacity](#series.area.fillOpacity)\n *\n * @apioption series.area.fillColor\n */\n /**\n * @see [color](#series.area.color)\n * @see [fillColor](#series.area.fillColor)\n *\n * @default {highcharts} 0.75\n * @default {highstock} 0.75\n * @apioption series.area.fillOpacity\n */\n ''; // adds doclets above to transpilat\n\n return AreaSeries;\n });\n _registerModule(_modules, 'Series/Spline/SplineSeries.js', [_modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var LineSeries = SeriesRegistry.seriesTypes.line;\n var merge = U.merge,\n pick = U.pick;\n /* *\n *\n * Class\n *\n * */\n /**\n * Spline series type.\n *\n * @private\n */\n var SplineSeries = /** @class */ (function (_super) {\n __extends(SplineSeries, _super);\n function SplineSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.data = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Get the spline segment from a given point's previous neighbour to the\n * given point.\n *\n * @private\n * @function Highcharts.seriesTypes.spline#getPointSpline\n */\n SplineSeries.prototype.getPointSpline = function (points, point, i) {\n var \n // 1 means control points midway between points, 2 means 1/3\n // from the point, 3 is 1/4 etc\n smoothing = 1.5,\n denom = smoothing + 1,\n plotX = point.plotX || 0,\n plotY = point.plotY || 0,\n lastPoint = points[i - 1],\n nextPoint = points[i + 1];\n var leftContX,\n leftContY,\n rightContX,\n rightContY;\n /**\n * @private\n */\n function doCurve(otherPoint) {\n return otherPoint &&\n !otherPoint.isNull &&\n otherPoint.doCurve !== false &&\n // #6387, area splines next to null:\n !point.isCliff;\n }\n // Find control points\n if (doCurve(lastPoint) && doCurve(nextPoint)) {\n var lastX = lastPoint.plotX || 0,\n lastY = lastPoint.plotY || 0,\n nextX = nextPoint.plotX || 0,\n nextY = nextPoint.plotY || 0;\n var correction = 0;\n leftContX = (smoothing * plotX + lastX) / denom;\n leftContY = (smoothing * plotY + lastY) / denom;\n rightContX = (smoothing * plotX + nextX) / denom;\n rightContY = (smoothing * plotY + nextY) / denom;\n // Have the two control points make a straight line through main\n // point\n if (rightContX !== leftContX) { // #5016, division by zero\n correction = (((rightContY - leftContY) *\n (rightContX - plotX)) /\n (rightContX - leftContX) + plotY - rightContY);\n }\n leftContY += correction;\n rightContY += correction;\n // to prevent false extremes, check that control points are\n // between neighbouring points' y values\n if (leftContY > lastY && leftContY > plotY) {\n leftContY = Math.max(lastY, plotY);\n // mirror of left control point\n rightContY = 2 * plotY - leftContY;\n }\n else if (leftContY < lastY && leftContY < plotY) {\n leftContY = Math.min(lastY, plotY);\n rightContY = 2 * plotY - leftContY;\n }\n if (rightContY > nextY && rightContY > plotY) {\n rightContY = Math.max(nextY, plotY);\n leftContY = 2 * plotY - rightContY;\n }\n else if (rightContY < nextY && rightContY < plotY) {\n rightContY = Math.min(nextY, plotY);\n leftContY = 2 * plotY - rightContY;\n }\n // record for drawing in next point\n point.rightContX = rightContX;\n point.rightContY = rightContY;\n }\n // Visualize control points for debugging\n /*\n if (leftContX) {\n this.chart.renderer.circle(\n leftContX + this.chart.plotLeft,\n leftContY + this.chart.plotTop,\n 2\n )\n .attr({\n stroke: 'red',\n 'stroke-width': 2,\n fill: 'none',\n zIndex: 9\n })\n .add();\n this.chart.renderer.path(['M', leftContX + this.chart.plotLeft,\n leftContY + this.chart.plotTop,\n 'L', plotX + this.chart.plotLeft, plotY + this.chart.plotTop])\n .attr({\n stroke: 'red',\n 'stroke-width': 2,\n zIndex: 9\n })\n .add();\n }\n if (rightContX) {\n this.chart.renderer.circle(\n rightContX + this.chart.plotLeft,\n rightContY + this.chart.plotTop,\n 2\n )\n .attr({\n stroke: 'green',\n 'stroke-width': 2,\n fill: 'none',\n zIndex: 9\n })\n .add();\n this.chart.renderer.path(['M', rightContX + this.chart.plotLeft,\n rightContY + this.chart.plotTop,\n 'L', plotX + this.chart.plotLeft, plotY + this.chart.plotTop])\n .attr({\n stroke: 'green',\n 'stroke-width': 2,\n zIndex: 9\n })\n .add();\n }\n // */\n var ret = [\n 'C',\n pick(lastPoint.rightContX,\n lastPoint.plotX, 0),\n pick(lastPoint.rightContY,\n lastPoint.plotY, 0),\n pick(leftContX,\n plotX, 0),\n pick(leftContY,\n plotY, 0),\n plotX,\n plotY\n ];\n // reset for updating series later\n lastPoint.rightContX = lastPoint.rightContY = void 0;\n return ret;\n };\n /**\n * A spline series is a special type of line series, where the segments\n * between the data points are smoothed.\n *\n * @sample {highcharts} highcharts/demo/spline-irregular-time/\n * Spline chart\n * @sample {highstock} stock/demo/spline/\n * Spline chart\n *\n * @extends plotOptions.series\n * @excluding step, boostThreshold, boostBlending\n * @product highcharts highstock\n * @optionparent plotOptions.spline\n */\n SplineSeries.defaultOptions = merge(LineSeries.defaultOptions);\n return SplineSeries;\n }(LineSeries));\n SeriesRegistry.registerSeriesType('spline', SplineSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A `spline` series. If the [type](#series.spline.type) option is\n * not specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.spline\n * @excluding dataParser, dataURL, step, boostThreshold, boostBlending\n * @product highcharts highstock\n * @apioption series.spline\n */\n /**\n * An array of data points for the series. For the `spline` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 9],\n * [1, 2],\n * [2, 8]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.spline.turboThreshold),\n * this option is not available.\n * ```js\n * data: [{\n * x: 1,\n * y: 9,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 0,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @product highcharts highstock\n * @apioption series.spline.data\n */\n ''; // adds doclets above intro transpilat\n\n return SplineSeries;\n });\n _registerModule(_modules, 'Series/AreaSpline/AreaSplineSeries.js', [_modules['Series/Spline/SplineSeries.js'], _modules['Core/Legend/LegendSymbol.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (SplineSeries, LegendSymbol, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var _a = SeriesRegistry.seriesTypes,\n AreaSeries = _a.area,\n areaProto = _a.area.prototype;\n var extend = U.extend,\n merge = U.merge;\n /* *\n *\n * Class\n *\n * */\n /**\n * AreaSpline series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.areaspline\n *\n * @augments Highcharts.Series\n */\n var AreaSplineSeries = /** @class */ (function (_super) {\n __extends(AreaSplineSeries, _super);\n function AreaSplineSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.data = void 0;\n _this.points = void 0;\n _this.options = void 0;\n return _this;\n }\n AreaSplineSeries.defaultOptions = merge(SplineSeries.defaultOptions, AreaSeries.defaultOptions);\n return AreaSplineSeries;\n }(SplineSeries));\n extend(AreaSplineSeries.prototype, {\n getGraphPath: areaProto.getGraphPath,\n getStackPoints: areaProto.getStackPoints,\n drawGraph: areaProto.drawGraph,\n drawLegendSymbol: LegendSymbol.drawRectangle\n });\n SeriesRegistry.registerSeriesType('areaspline', AreaSplineSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * The area spline series is an area series where the graph between the\n * points is smoothed into a spline.\n *\n * @sample {highcharts} highcharts/demo/areaspline/\n * Area spline chart\n * @sample {highstock} stock/demo/areaspline/\n * Area spline chart\n *\n * @extends plotOptions.area\n * @excluding step, boostThreshold, boostBlending\n * @product highcharts highstock\n * @apioption plotOptions.areaspline\n */\n /**\n * @see [fillColor](#plotOptions.areaspline.fillColor)\n * @see [fillOpacity](#plotOptions.areaspline.fillOpacity)\n *\n * @apioption plotOptions.areaspline.color\n */\n /**\n * @see [color](#plotOptions.areaspline.color)\n * @see [fillOpacity](#plotOptions.areaspline.fillOpacity)\n *\n * @apioption plotOptions.areaspline.fillColor\n */\n /**\n * @see [color](#plotOptions.areaspline.color)\n * @see [fillColor](#plotOptions.areaspline.fillColor)\n *\n * @default 0.75\n * @apioption plotOptions.areaspline.fillOpacity\n */\n /**\n * A `areaspline` series. If the [type](#series.areaspline.type) option\n * is not specified, it is inherited from [chart.type](#chart.type).\n *\n *\n * @extends series,plotOptions.areaspline\n * @excluding dataParser, dataURL, step, boostThreshold, boostBlending\n * @product highcharts highstock\n * @apioption series.areaspline\n */\n /**\n * @see [fillColor](#series.areaspline.fillColor)\n * @see [fillOpacity](#series.areaspline.fillOpacity)\n *\n * @apioption series.areaspline.color\n */\n /**\n * An array of data points for the series. For the `areaspline` series\n * type, points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 10],\n * [1, 9],\n * [2, 3]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.areaspline.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 4,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 4,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @product highcharts highstock\n * @apioption series.areaspline.data\n */\n /**\n * @see [color](#series.areaspline.color)\n * @see [fillOpacity](#series.areaspline.fillOpacity)\n *\n * @apioption series.areaspline.fillColor\n */\n /**\n * @see [color](#series.areaspline.color)\n * @see [fillColor](#series.areaspline.fillColor)\n *\n * @default 0.75\n * @apioption series.areaspline.fillOpacity\n */\n ''; // adds doclets above into transpilat\n\n return AreaSplineSeries;\n });\n _registerModule(_modules, 'Series/Column/ColumnSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Column series display one column per value along an X axis.\n *\n * @sample {highcharts} highcharts/demo/column-basic/\n * Column chart\n * @sample {highstock} stock/demo/column/\n * Column chart\n *\n * @extends plotOptions.line\n * @excluding connectEnds, connectNulls, gapSize, gapUnit, linecap,\n * lineWidth, marker, step, useOhlcData\n * @product highcharts highstock\n * @optionparent plotOptions.column\n */\n var ColumnSeriesDefaults = {\n /**\n * The corner radius of the border surrounding each column or bar.\n *\n * @sample {highcharts} highcharts/plotoptions/column-borderradius/\n * Rounded columns\n *\n * @product highcharts highstock gantt\n */\n borderRadius: 0,\n /**\n * When using automatic point colors pulled from the global\n * [colors](colors) or series-specific\n * [plotOptions.column.colors](series.colors) collections,\n this option\n * determines whether the chart should receive one color per series or\n * one color per point.\n *\n * In styled mode,\n the `colors` or `series.colors` arrays are not\n * supported,\n and instead this option gives the points individual color\n * class names on the form `highcharts-color-{n}`.\n *\n * @see [series colors](#plotOptions.column.colors)\n *\n * @sample {highcharts} highcharts/plotoptions/column-colorbypoint-false/\n * False by default\n * @sample {highcharts} highcharts/plotoptions/column-colorbypoint-true/\n * True\n *\n * @type {boolean}\n * @default false\n * @since 2.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.colorByPoint\n */\n /**\n * A series specific or series type specific color set to apply instead\n * of the global [colors](#colors) when [colorByPoint](\n * #plotOptions.column.colorByPoint) is true.\n *\n * @type {Array}\n * @since 3.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.colors\n */\n /**\n * When `true`,\n the columns will center in the category,\n ignoring null\n * or missing points. When `false`,\n space will be reserved for null or\n * missing points.\n *\n * @sample {highcharts} highcharts/series-column/centerincategory/\n * Center in category\n *\n * @since 8.0.1\n * @product highcharts highstock gantt\n */\n centerInCategory: false,\n /**\n * Padding between each value groups,\n in x axis units.\n *\n * @sample {highcharts} highcharts/plotoptions/column-grouppadding-default/\n * 0.2 by default\n * @sample {highcharts} highcharts/plotoptions/column-grouppadding-none/\n * No group padding - all columns are evenly spaced\n *\n * @product highcharts highstock gantt\n */\n groupPadding: 0.2,\n /**\n * Whether to group non-stacked columns or to let them render\n * independent of each other. Non-grouped columns will be laid out\n * individually and overlap each other.\n *\n * @sample {highcharts} highcharts/plotoptions/column-grouping-false/\n * Grouping disabled\n * @sample {highstock} highcharts/plotoptions/column-grouping-false/\n * Grouping disabled\n *\n * @type {boolean}\n * @default true\n * @since 2.3.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.grouping\n */\n /** @ignore-option */\n marker: null,\n /**\n * The maximum allowed pixel width for a column,\n translated to the\n * height of a bar in a bar chart. This prevents the columns from\n * becoming too wide when there is a small number of points in the\n * chart.\n *\n * @see [pointWidth](#plotOptions.column.pointWidth)\n *\n * @sample {highcharts} highcharts/plotoptions/column-maxpointwidth-20/\n * Limited to 50\n * @sample {highstock} highcharts/plotoptions/column-maxpointwidth-20/\n * Limited to 50\n *\n * @type {number}\n * @since 4.1.8\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.maxPointWidth\n */\n /**\n * Padding between each column or bar,\n in x axis units.\n *\n * @sample {highcharts} highcharts/plotoptions/column-pointpadding-default/\n * 0.1 by default\n * @sample {highcharts} highcharts/plotoptions/column-pointpadding-025/\n * 0.25\n * @sample {highcharts} highcharts/plotoptions/column-pointpadding-none/\n * 0 for tightly packed columns\n *\n * @product highcharts highstock gantt\n */\n pointPadding: 0.1,\n /**\n * A pixel value specifying a fixed width for each column or bar point.\n * When set to `undefined`,\n the width is calculated from the\n * `pointPadding` and `groupPadding`. The width effects the dimension\n * that is not based on the point value. For column series it is the\n * hoizontal length and for bar series it is the vertical length.\n *\n * @see [maxPointWidth](#plotOptions.column.maxPointWidth)\n *\n * @sample {highcharts} highcharts/plotoptions/column-pointwidth-20/\n * 20px wide columns regardless of chart width or the amount of\n * data points\n *\n * @type {number}\n * @since 1.2.5\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.pointWidth\n */\n /**\n * A pixel value specifying a fixed width for the column or bar.\n * Overrides pointWidth on the series.\n *\n * @see [series.pointWidth](#plotOptions.column.pointWidth)\n *\n * @type {number}\n * @default undefined\n * @since 7.0.0\n * @product highcharts highstock gantt\n * @apioption series.column.data.pointWidth\n */\n /**\n * The minimal height for a column or width for a bar. By default,\n * 0 values are not shown. To visualize a 0 (or close to zero) point,\n * set the minimal point length to a pixel value like 3\\. In stacked\n * column charts,\n minPointLength might not be respected for tightly\n * packed values.\n *\n * @sample {highcharts} highcharts/plotoptions/column-minpointlength/\n * Zero base value\n * @sample {highcharts} highcharts/plotoptions/column-minpointlength-pos-and-neg/\n * Positive and negative close to zero values\n *\n * @product highcharts highstock gantt\n */\n minPointLength: 0,\n /**\n * When the series contains less points than the crop threshold,\n all\n * points are drawn,\n event if the points fall outside the visible plot\n * area at the current zoom. The advantage of drawing all points\n * (including markers and columns),\n is that animation is performed on\n * updates. On the other hand,\n when the series contains more points than\n * the crop threshold,\n the series data is cropped to only contain points\n * that fall within the plot area. The advantage of cropping away\n * invisible points is to increase performance on large series.\n *\n * @product highcharts highstock gantt\n */\n cropThreshold: 50,\n /**\n * The X axis range that each point is valid for. This determines the\n * width of the column. On a categorized axis,\n the range will be 1\n * by default (one category unit). On linear and datetime axes,\n the\n * range will be computed as the distance between the two closest data\n * points.\n *\n * The default `null` means it is computed automatically,\n but this\n * option can be used to override the automatic value.\n *\n * This option is set by default to 1 if data sorting is enabled.\n *\n * @sample {highcharts} highcharts/plotoptions/column-pointrange/\n * Set the point range to one day on a data set with one week\n * between the points\n *\n * @type {number|null}\n * @since 2.3\n * @product highcharts highstock gantt\n */\n pointRange: null,\n states: {\n /**\n * Options for the hovered point. These settings override the normal\n * state options when a point is moused over or touched.\n *\n * @extends plotOptions.series.states.hover\n * @excluding halo,\n lineWidth,\n lineWidthPlus,\n marker\n * @product highcharts highstock gantt\n */\n hover: {\n /** @ignore-option */\n halo: false,\n /**\n * A specific border color for the hovered point. Defaults to\n * inherit the normal state border color.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts gantt\n * @apioption plotOptions.column.states.hover.borderColor\n */\n /**\n * A specific color for the hovered point.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts gantt\n * @apioption plotOptions.column.states.hover.color\n */\n /**\n * How much to brighten the point on interaction. Requires the\n * main color to be defined in hex or rgb(a) format.\n *\n * In styled mode,\n the hover brightening is by default replaced\n * with a fill-opacity set in the `.highcharts-point:hover`\n * rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-states-hover-brightness/\n * Brighten by 0.5\n *\n * @product highcharts highstock gantt\n */\n brightness: 0.1\n },\n /**\n * Options for the selected point. These settings override the\n * normal state options when a point is selected.\n *\n * @extends plotOptions.series.states.select\n * @excluding halo,\n lineWidth,\n lineWidthPlus,\n marker\n * @product highcharts highstock gantt\n */\n select: {\n /**\n * A specific color for the selected point.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #cccccc\n * @product highcharts highstock gantt\n */\n color: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * A specific border color for the selected point.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #000000\n * @product highcharts highstock gantt\n */\n borderColor: \"#000000\" /* Palette.neutralColor100 */\n }\n },\n dataLabels: {\n align: void 0,\n verticalAlign: void 0,\n /**\n * The y position offset of the label relative to the point in\n * pixels.\n *\n * @type {number}\n */\n y: void 0\n },\n // false doesn't work well: https://jsfiddle.net/highcharts/hz8fopan/14/\n /** @ignore-option */\n startFromThreshold: true,\n stickyTracking: false,\n tooltip: {\n distance: 6\n },\n /**\n * The Y axis value to serve as the base for the columns,\n for\n * distinguishing between values above and below a threshold. If `null`,\n * the columns extend from the padding Y axis minimum.\n *\n * @type {number|null}\n * @since 2.0\n * @product highcharts\n */\n threshold: 0,\n /**\n * The width of the border surrounding each column or bar. Defaults to\n * `1` when there is room for a border,\n but to `0` when the columns are\n * so dense that a border would cover the next column.\n *\n * In styled mode,\n the stroke width can be set with the\n * `.highcharts-point` rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-borderwidth/\n * 2px black border\n *\n * @type {number}\n * @default undefined\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.borderWidth\n */\n /**\n * The color of the border surrounding each column or bar.\n *\n * In styled mode,\n the border stroke can be set with the\n * `.highcharts-point` rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-bordercolor/\n * Dark gray border\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #ffffff\n * @product highcharts highstock gantt\n */\n borderColor: \"#ffffff\" /* Palette.backgroundColor */\n };\n /**\n * A `column` series. If the [type](#series.column.type) option is\n * not specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.column\n * @excluding connectNulls, dataParser, dataURL, gapSize, gapUnit, linecap,\n * lineWidth, marker, connectEnds, step\n * @product highcharts highstock\n * @apioption series.column\n */\n /**\n * An array of data points for the series. For the `column` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 6],\n * [1, 2],\n * [2, 6]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.column.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 9,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 6,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @excluding marker\n * @product highcharts highstock\n * @apioption series.column.data\n */\n /**\n * The color of the border surrounding the column or bar.\n *\n * In styled mode, the border stroke can be set with the `.highcharts-point`\n * rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-bordercolor/\n * Dark gray border\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts highstock\n * @apioption series.column.data.borderColor\n */\n /**\n * The width of the border surrounding the column or bar.\n *\n * In styled mode, the stroke width can be set with the `.highcharts-point`\n * rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-borderwidth/\n * 2px black border\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption series.column.data.borderWidth\n */\n /**\n * A name for the dash style to use for the column or bar. Overrides\n * dashStyle on the series.\n *\n * In styled mode, the stroke dash-array can be set with the same classes as\n * listed under [data.color](#series.column.data.color).\n *\n * @see [series.pointWidth](#plotOptions.column.dashStyle)\n *\n * @type {Highcharts.DashStyleValue}\n * @apioption series.column.data.dashStyle\n */\n /**\n * A pixel value specifying a fixed width for the column or bar. Overrides\n * pointWidth on the series. The width effects the dimension that is not based\n * on the point value.\n *\n * @see [series.pointWidth](#plotOptions.column.pointWidth)\n *\n * @type {number}\n * @apioption series.column.data.pointWidth\n */\n /**\n * @excluding halo, lineWidth, lineWidthPlus, marker\n * @product highcharts highstock\n * @apioption series.column.states.hover\n */\n /**\n * @excluding halo, lineWidth, lineWidthPlus, marker\n * @product highcharts highstock\n * @apioption series.column.states.select\n */\n ''; // keeps doclets above in JS file\n /* *\n *\n * Default Export\n *\n * */\n\n return ColumnSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Column/ColumnSeries.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Color/Color.js'], _modules['Series/Column/ColumnSeriesDefaults.js'], _modules['Core/Globals.js'], _modules['Core/Legend/LegendSymbol.js'], _modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (A, Color, ColumnSeriesDefaults, H, LegendSymbol, Series, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var animObject = A.animObject;\n var color = Color.parse;\n var hasTouch = H.hasTouch,\n noop = H.noop;\n var clamp = U.clamp,\n css = U.css,\n defined = U.defined,\n extend = U.extend,\n fireEvent = U.fireEvent,\n isArray = U.isArray,\n isNumber = U.isNumber,\n merge = U.merge,\n pick = U.pick,\n objectEach = U.objectEach;\n /* *\n *\n * Class\n *\n * */\n /**\n * The column series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.column\n *\n * @augments Highcharts.Series\n */\n var ColumnSeries = /** @class */ (function (_super) {\n __extends(ColumnSeries, _super);\n function ColumnSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.borderWidth = void 0;\n _this.data = void 0;\n _this.group = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Animate the column heights one by one from zero.\n *\n * @private\n * @function Highcharts.seriesTypes.column#animate\n *\n * @param {boolean} init\n * Whether to initialize the animation or run it\n */\n ColumnSeries.prototype.animate = function (init) {\n var series = this,\n yAxis = this.yAxis,\n options = series.options,\n inverted = this.chart.inverted,\n attr = {},\n translateProp = inverted ?\n 'translateX' :\n 'translateY';\n var translateStart,\n translatedThreshold;\n if (init) {\n attr.scaleY = 0.001;\n translatedThreshold = clamp(yAxis.toPixels(options.threshold), yAxis.pos, yAxis.pos + yAxis.len);\n if (inverted) {\n attr.translateX = translatedThreshold - yAxis.len;\n }\n else {\n attr.translateY = translatedThreshold;\n }\n // apply finnal clipping (used in Highcharts Stock) (#7083)\n // animation is done by scaleY, so cliping is for panes\n if (series.clipBox) {\n series.setClip();\n }\n series.group.attr(attr);\n }\n else { // run the animation\n translateStart = Number(series.group.attr(translateProp));\n series.group.animate({ scaleY: 1 }, extend(animObject(series.options.animation), {\n // Do the scale synchronously to ensure smooth\n // updating (#5030, #7228)\n step: function (val, fx) {\n if (series.group) {\n attr[translateProp] = translateStart +\n fx.pos * (yAxis.pos - translateStart);\n series.group.attr(attr);\n }\n }\n }));\n }\n };\n /**\n * Initialize the series. Extends the basic Series.init method by\n * marking other series of the same type as dirty.\n *\n * @private\n * @function Highcharts.seriesTypes.column#init\n */\n ColumnSeries.prototype.init = function (chart, options) {\n _super.prototype.init.apply(this, arguments);\n var series = this;\n chart = series.chart;\n // if the series is added dynamically, force redraw of other\n // series affected by a new column\n if (chart.hasRendered) {\n chart.series.forEach(function (otherSeries) {\n if (otherSeries.type === series.type) {\n otherSeries.isDirty = true;\n }\n });\n }\n };\n /**\n * Return the width and x offset of the columns adjusted for grouping,\n * groupPadding, pointPadding, pointWidth etc.\n *\n * @private\n * @function Highcharts.seriesTypes.column#getColumnMetrics\n */\n ColumnSeries.prototype.getColumnMetrics = function () {\n var series = this,\n options = series.options,\n xAxis = series.xAxis,\n yAxis = series.yAxis,\n reversedStacks = xAxis.options.reversedStacks, \n // Keep backward compatibility: reversed xAxis had reversed\n // stacks\n reverseStacks = (xAxis.reversed && !reversedStacks) ||\n (!xAxis.reversed && reversedStacks),\n stackGroups = {};\n var stackKey,\n columnCount = 0;\n // Get the total number of column type series. This is called on\n // every series. Consider moving this logic to a chart.orderStacks()\n // function and call it on init, addSeries and removeSeries\n if (options.grouping === false) {\n columnCount = 1;\n }\n else {\n series.chart.series.forEach(function (otherSeries) {\n var otherYAxis = otherSeries.yAxis,\n otherOptions = otherSeries.options;\n var columnIndex;\n if (otherSeries.type === series.type &&\n (otherSeries.visible ||\n !series.chart.options.chart.ignoreHiddenSeries) &&\n yAxis.len === otherYAxis.len &&\n yAxis.pos === otherYAxis.pos) { // #642, #2086\n if (otherOptions.stacking &&\n otherOptions.stacking !== 'group') {\n stackKey = otherSeries.stackKey;\n if (typeof stackGroups[stackKey] ===\n 'undefined') {\n stackGroups[stackKey] = columnCount++;\n }\n columnIndex = stackGroups[stackKey];\n }\n else if (otherOptions.grouping !== false) { // #1162\n columnIndex = columnCount++;\n }\n otherSeries.columnIndex = columnIndex;\n }\n });\n }\n var categoryWidth = Math.min(Math.abs(xAxis.transA) * ((xAxis.ordinal && xAxis.ordinal.slope) ||\n options.pointRange ||\n xAxis.closestPointRange ||\n xAxis.tickInterval ||\n 1), // #2610\n xAxis.len // #1535\n ),\n groupPadding = categoryWidth * options.groupPadding,\n groupWidth = categoryWidth - 2 * groupPadding,\n pointOffsetWidth = groupWidth / (columnCount || 1),\n pointWidth = Math.min(options.maxPointWidth || xAxis.len,\n pick(options.pointWidth,\n pointOffsetWidth * (1 - 2 * options.pointPadding))),\n pointPadding = (pointOffsetWidth - pointWidth) / 2, \n // #1251, #3737\n colIndex = (series.columnIndex || 0) + (reverseStacks ? 1 : 0),\n pointXOffset = pointPadding +\n (groupPadding +\n colIndex * pointOffsetWidth -\n (categoryWidth / 2)) * (reverseStacks ? -1 : 1);\n // Save it for reading in linked series (Error bars particularly)\n series.columnMetrics = {\n width: pointWidth,\n offset: pointXOffset,\n paddedWidth: pointOffsetWidth,\n columnCount: columnCount\n };\n return series.columnMetrics;\n };\n /**\n * Make the columns crisp. The edges are rounded to the nearest full\n * pixel.\n *\n * @private\n * @function Highcharts.seriesTypes.column#crispCol\n */\n ColumnSeries.prototype.crispCol = function (x, y, w, h) {\n var chart = this.chart,\n borderWidth = this.borderWidth,\n xCrisp = -(borderWidth % 2 ? 0.5 : 0);\n var right,\n yCrisp = borderWidth % 2 ? 0.5 : 1;\n if (chart.inverted && chart.renderer.isVML) {\n yCrisp += 1;\n }\n // Horizontal. We need to first compute the exact right edge, then\n // round it and compute the width from there.\n if (this.options.crisp) {\n right = Math.round(x + w) + xCrisp;\n x = Math.round(x) + xCrisp;\n w = right - x;\n }\n // Vertical\n var bottom = Math.round(y + h) + yCrisp,\n fromTop = Math.abs(y) <= 0.5 && bottom > 0.5; // #4504, #4656\n y = Math.round(y) + yCrisp;\n h = bottom - y;\n // Top edges are exceptions\n if (fromTop && h) { // #5146\n y -= 1;\n h += 1;\n }\n return {\n x: x,\n y: y,\n width: w,\n height: h\n };\n };\n /**\n * Adjust for missing columns, according to the `centerInCategory`\n * option. Missing columns are either single points or stacks where the\n * point or points are either missing or null.\n *\n * @private\n * @function Highcharts.seriesTypes.column#adjustForMissingColumns\n * @param {number} x\n * The x coordinate of the column, left side\n *\n * @param {number} pointWidth\n * The pointWidth, already computed upstream\n *\n * @param {Highcharts.ColumnPoint} point\n * The point instance\n *\n * @param {Highcharts.ColumnMetricsObject} metrics\n * The series-wide column metrics\n *\n * @return {number}\n * The adjusted x position, or the original if not adjusted\n */\n ColumnSeries.prototype.adjustForMissingColumns = function (x, pointWidth, point, metrics) {\n var _this = this;\n var stacking = this.options.stacking;\n if (!point.isNull && metrics.columnCount > 1) {\n var reversedStacks_1 = this.yAxis.options.reversedStacks;\n var indexInCategory_1 = 0,\n totalInCategory_1 = reversedStacks_1 ? 0 : -metrics.columnCount;\n // Loop over all the stacks on the Y axis. When stacking is enabled,\n // these are real point stacks. When stacking is not enabled, but\n // `centerInCategory` is true, there is one stack handling the\n // grouping of points in each category. This is done in the\n // `setGroupedPoints` function.\n objectEach(this.yAxis.stacking && this.yAxis.stacking.stacks, function (stack) {\n if (typeof point.x === 'number') {\n var stackItem_1 = stack[point.x.toString()];\n if (stackItem_1) {\n var pointValues = stackItem_1.points[_this.index];\n // If true `stacking` is enabled, count the total\n // number of non-null stacks in the category, and\n // note which index this point is within those\n // stacks.\n if (stacking) {\n if (pointValues) {\n indexInCategory_1 = totalInCategory_1;\n }\n if (stackItem_1.hasValidPoints) {\n reversedStacks_1 ? // #16169\n totalInCategory_1++ : totalInCategory_1--;\n }\n // If `stacking` is not enabled, look for the index\n }\n else if (isArray(pointValues)) {\n // If there are multiple points with the same X\n // then gather all series in category, and\n // assign index\n var seriesIndexes = Object\n .keys(stackItem_1.points)\n .filter(function (pointKey) {\n // Filter out duplicate X's\n return !pointKey.match(',') &&\n // Filter out null points\n stackItem_1.points[pointKey] &&\n stackItem_1.points[pointKey].length > 1;\n })\n .map(parseFloat)\n .sort(function (a, b) { return b - a; });\n indexInCategory_1 = seriesIndexes.indexOf(_this.index);\n totalInCategory_1 = seriesIndexes.length;\n }\n }\n }\n });\n // Compute the adjusted x position\n var boxWidth = (totalInCategory_1 - 1) * metrics.paddedWidth +\n pointWidth;\n x = (point.plotX || 0) + boxWidth / 2 - pointWidth -\n indexInCategory_1 * metrics.paddedWidth;\n }\n return x;\n };\n /**\n * Translate each point to the plot area coordinate system and find\n * shape positions\n *\n * @private\n * @function Highcharts.seriesTypes.column#translate\n */\n ColumnSeries.prototype.translate = function () {\n var series = this,\n chart = series.chart,\n options = series.options,\n dense = series.dense =\n series.closestPointRange * series.xAxis.transA < 2,\n borderWidth = series.borderWidth = pick(options.borderWidth,\n dense ? 0 : 1 // #3635\n ),\n xAxis = series.xAxis,\n yAxis = series.yAxis,\n threshold = options.threshold,\n translatedThreshold = series.translatedThreshold =\n yAxis.getThreshold(threshold),\n minPointLength = pick(options.minPointLength, 5),\n metrics = series.getColumnMetrics(),\n seriesPointWidth = metrics.width,\n seriesXOffset = series.pointXOffset = metrics.offset,\n dataMin = series.dataMin,\n dataMax = series.dataMax;\n // postprocessed for border width\n var seriesBarW = series.barW =\n Math.max(seriesPointWidth, 1 + 2 * borderWidth);\n if (chart.inverted) {\n translatedThreshold -= 0.5; // #3355\n }\n // When the pointPadding is 0, we want the columns to be packed\n // tightly, so we allow individual columns to have individual sizes.\n // When pointPadding is greater, we strive for equal-width columns\n // (#2694).\n if (options.pointPadding) {\n seriesBarW = Math.ceil(seriesBarW);\n }\n Series.prototype.translate.apply(series);\n // Record the new values\n series.points.forEach(function (point) {\n var yBottom = pick(point.yBottom,\n translatedThreshold),\n safeDistance = 999 + Math.abs(yBottom),\n plotX = point.plotX || 0, \n // Don't draw too far outside plot area (#1303, #2241,\n // #4264)\n plotY = clamp(point.plotY, -safeDistance,\n yAxis.len + safeDistance);\n var up,\n barY = Math.min(plotY,\n yBottom),\n barH = Math.max(plotY,\n yBottom) - barY,\n pointWidth = seriesPointWidth,\n barX = plotX + seriesXOffset,\n barW = seriesBarW;\n // Handle options.minPointLength\n if (minPointLength && Math.abs(barH) < minPointLength) {\n barH = minPointLength;\n up = (!yAxis.reversed && !point.negative) ||\n (yAxis.reversed && point.negative);\n // Reverse zeros if there's no positive value in the series\n // in visible range (#7046)\n if (isNumber(threshold) &&\n isNumber(dataMax) &&\n point.y === threshold &&\n dataMax <= threshold &&\n // and if there's room for it (#7311)\n (yAxis.min || 0) < threshold &&\n // if all points are the same value (i.e zero) not draw\n // as negative points (#10646), but only if there's room\n // for it (#14876)\n (dataMin !== dataMax || (yAxis.max || 0) <= threshold)) {\n up = !up;\n }\n // If stacked...\n barY = (Math.abs(barY - translatedThreshold) > minPointLength ?\n // ...keep position\n yBottom - minPointLength :\n // #1485, #4051\n translatedThreshold -\n (up ? minPointLength : 0));\n }\n // Handle point.options.pointWidth\n // @todo Handle grouping/stacking too. Calculate offset properly\n if (defined(point.options.pointWidth)) {\n pointWidth = barW =\n Math.ceil(point.options.pointWidth);\n barX -= Math.round((pointWidth - seriesPointWidth) / 2);\n }\n // Adjust for null or missing points\n if (options.centerInCategory) {\n barX = series.adjustForMissingColumns(barX, pointWidth, point, metrics);\n }\n // Cache for access in polar\n point.barX = barX;\n point.pointWidth = pointWidth;\n // Fix the tooltip on center of grouped columns (#1216, #424,\n // #3648)\n point.tooltipPos = chart.inverted ?\n [\n clamp(yAxis.len + yAxis.pos - chart.plotLeft - plotY, yAxis.pos - chart.plotLeft, yAxis.len + yAxis.pos - chart.plotLeft),\n xAxis.len + xAxis.pos - chart.plotTop - barX - barW / 2,\n barH\n ] :\n [\n xAxis.left - chart.plotLeft + barX + barW / 2,\n clamp(plotY + yAxis.pos -\n chart.plotTop, yAxis.pos - chart.plotTop, yAxis.len + yAxis.pos - chart.plotTop),\n barH\n ];\n // Register shape type and arguments to be used in drawPoints\n // Allow shapeType defined on pointClass level\n point.shapeType = series.pointClass.prototype.shapeType || 'rect';\n point.shapeArgs = series.crispCol.apply(series, point.isNull ?\n // #3169, drilldown from null must have a position to work\n // from #6585, dataLabel should be placed on xAxis, not\n // floating in the middle of the chart\n [barX, translatedThreshold, barW, 0] :\n [barX, barY, barW, barH]);\n });\n };\n /**\n * Columns have no graph\n *\n * @private\n * @function Highcharts.seriesTypes.column#drawGraph\n */\n ColumnSeries.prototype.drawGraph = function () {\n this.group[this.dense ? 'addClass' : 'removeClass']('highcharts-dense-data');\n };\n /**\n * Get presentational attributes\n *\n * @private\n * @function Highcharts.seriesTypes.column#pointAttribs\n */\n ColumnSeries.prototype.pointAttribs = function (point, state) {\n var options = this.options, p2o = this.pointAttrToOptions || {}, strokeOption = p2o.stroke || 'borderColor', strokeWidthOption = p2o['stroke-width'] || 'borderWidth';\n var stateOptions,\n zone,\n brightness,\n fill = (point && point.color) || this.color, \n // set to fill when borderColor null:\n stroke = ((point && point[strokeOption]) ||\n options[strokeOption] ||\n fill),\n dashstyle = (point && point.options.dashStyle) || options.dashStyle,\n strokeWidth = (point && point[strokeWidthOption]) ||\n options[strokeWidthOption] ||\n this[strokeWidthOption] || 0,\n opacity = pick(point && point.opacity,\n options.opacity, 1);\n // Handle zone colors\n if (point && this.zones.length) {\n zone = point.getZone();\n // When zones are present, don't use point.color (#4267).\n // Changed order (#6527), added support for colorAxis (#10670)\n fill = (point.options.color ||\n (zone && (zone.color || point.nonZonedColor)) ||\n this.color);\n if (zone) {\n stroke = zone.borderColor || stroke;\n dashstyle = zone.dashStyle || dashstyle;\n strokeWidth = zone.borderWidth || strokeWidth;\n }\n }\n // Select or hover states\n if (state && point) {\n stateOptions = merge(options.states[state], \n // #6401\n point.options.states &&\n point.options.states[state] ||\n {});\n brightness = stateOptions.brightness;\n fill =\n stateOptions.color || (typeof brightness !== 'undefined' &&\n color(fill)\n .brighten(stateOptions.brightness)\n .get()) || fill;\n stroke = stateOptions[strokeOption] || stroke;\n strokeWidth =\n stateOptions[strokeWidthOption] || strokeWidth;\n dashstyle = stateOptions.dashStyle || dashstyle;\n opacity = pick(stateOptions.opacity, opacity);\n }\n var ret = {\n fill: fill,\n stroke: stroke,\n 'stroke-width': strokeWidth,\n opacity: opacity\n };\n if (dashstyle) {\n ret.dashstyle = dashstyle;\n }\n return ret;\n };\n /**\n * Draw the columns. For bars, the series.group is rotated, so the same\n * coordinates apply for columns and bars. This method is inherited by\n * scatter series.\n *\n * @private\n * @function Highcharts.seriesTypes.column#drawPoints\n */\n ColumnSeries.prototype.drawPoints = function (points) {\n if (points === void 0) { points = this.points; }\n var series = this,\n chart = this.chart,\n options = series.options,\n renderer = chart.renderer,\n animationLimit = options.animationLimit || 250;\n var shapeArgs;\n // draw the columns\n points.forEach(function (point) {\n var plotY = point.plotY;\n var graphic = point.graphic,\n hasGraphic = !!graphic,\n verb = graphic && chart.pointCount < animationLimit ?\n 'animate' : 'attr';\n if (isNumber(plotY) && point.y !== null) {\n shapeArgs = point.shapeArgs;\n // When updating a series between 2d and 3d or cartesian and\n // polar, the shape type changes.\n if (graphic && point.hasNewShapeType()) {\n graphic = graphic.destroy();\n }\n // Set starting position for point sliding animation.\n if (series.enabledDataSorting) {\n point.startXPos = series.xAxis.reversed ?\n -(shapeArgs ? (shapeArgs.width || 0) : 0) :\n series.xAxis.width;\n }\n if (!graphic) {\n point.graphic = graphic =\n renderer[point.shapeType](shapeArgs)\n .add(point.group || series.group);\n if (graphic &&\n series.enabledDataSorting &&\n chart.hasRendered &&\n chart.pointCount < animationLimit) {\n graphic.attr({\n x: point.startXPos\n });\n hasGraphic = true;\n verb = 'animate';\n }\n }\n if (graphic && hasGraphic) { // update\n graphic[verb](merge(shapeArgs));\n }\n // Border radius is not stylable (#6900)\n if (options.borderRadius) {\n graphic[verb]({\n r: options.borderRadius\n });\n }\n // Presentational\n if (!chart.styledMode) {\n graphic[verb](series.pointAttribs(point, (point.selected && 'select')))\n .shadow(point.allowShadow !== false && options.shadow, null, options.stacking && !options.borderRadius);\n }\n if (graphic) {\n graphic.addClass(point.getClassName(), true);\n graphic.attr({\n visibility: point.visible ? 'inherit' : 'hidden'\n });\n }\n }\n else if (graphic) {\n point.graphic = graphic.destroy(); // #1269\n }\n });\n };\n /**\n * Draw the tracker for a point.\n * @private\n */\n ColumnSeries.prototype.drawTracker = function () {\n var series = this,\n chart = series.chart,\n pointer = chart.pointer,\n onMouseOver = function (e) {\n var point = pointer.getPointFromEvent(e);\n // undefined on graph in scatterchart\n if (typeof point !== 'undefined') {\n pointer.isDirectTouch = true;\n point.onMouseOver(e);\n }\n };\n var dataLabels;\n // Add reference to the point\n series.points.forEach(function (point) {\n dataLabels = (isArray(point.dataLabels) ?\n point.dataLabels :\n (point.dataLabel ? [point.dataLabel] : []));\n if (point.graphic) {\n point.graphic.element.point = point;\n }\n dataLabels.forEach(function (dataLabel) {\n if (dataLabel.div) {\n dataLabel.div.point = point;\n }\n else {\n dataLabel.element.point = point;\n }\n });\n });\n // Add the event listeners, we need to do this only once\n if (!series._hasTracking) {\n series.trackerGroups.forEach(function (key) {\n if (series[key]) {\n // we don't always have dataLabelsGroup\n series[key]\n .addClass('highcharts-tracker')\n .on('mouseover', onMouseOver)\n .on('mouseout', function (e) {\n pointer.onTrackerMouseOut(e);\n });\n if (hasTouch) {\n series[key].on('touchstart', onMouseOver);\n }\n if (!chart.styledMode && series.options.cursor) {\n series[key]\n .css(css)\n .css({ cursor: series.options.cursor });\n }\n }\n });\n series._hasTracking = true;\n }\n fireEvent(this, 'afterDrawTracker');\n };\n /**\n * Remove this series from the chart\n *\n * @private\n * @function Highcharts.seriesTypes.column#remove\n */\n ColumnSeries.prototype.remove = function () {\n var series = this,\n chart = series.chart;\n // column and bar series affects other series of the same type\n // as they are either stacked or grouped\n if (chart.hasRendered) {\n chart.series.forEach(function (otherSeries) {\n if (otherSeries.type === series.type) {\n otherSeries.isDirty = true;\n }\n });\n }\n Series.prototype.remove.apply(series, arguments);\n };\n ColumnSeries.defaultOptions = merge(Series.defaultOptions, ColumnSeriesDefaults);\n return ColumnSeries;\n }(Series));\n extend(ColumnSeries.prototype, {\n cropShoulder: 0,\n // When tooltip is not shared, this series (and derivatives) requires\n // direct touch/hover. KD-tree does not apply.\n directTouch: true,\n /**\n * Use a solid rectangle like the area series types\n *\n * @private\n * @function Highcharts.seriesTypes.column#drawLegendSymbol\n *\n * @param {Highcharts.Legend} legend\n * The legend object\n *\n * @param {Highcharts.Series|Highcharts.Point} item\n * The series (this) or point\n */\n drawLegendSymbol: LegendSymbol.drawRectangle,\n getSymbol: noop,\n // use separate negative stacks, unlike area stacks where a negative\n // point is substracted from previous (#1910)\n negStacks: true,\n trackerGroups: ['group', 'dataLabelsGroup']\n });\n SeriesRegistry.registerSeriesType('column', ColumnSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Adjusted width and x offset of the columns for grouping.\n *\n * @private\n * @interface Highcharts.ColumnMetricsObject\n */ /**\n * Width of the columns.\n * @name Highcharts.ColumnMetricsObject#width\n * @type {number}\n */ /**\n * Offset of the columns.\n * @name Highcharts.ColumnMetricsObject#offset\n * @type {number}\n */\n ''; // detach doclets above\n\n return ColumnSeries;\n });\n _registerModule(_modules, 'Core/Series/DataLabel.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/FormatUtilities.js'], _modules['Core/Utilities.js']], function (A, F, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var getDeferredAnimation = A.getDeferredAnimation;\n var format = F.format;\n var defined = U.defined,\n extend = U.extend,\n fireEvent = U.fireEvent,\n isArray = U.isArray,\n isString = U.isString,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick,\n splat = U.splat;\n /* *\n *\n * Composition\n *\n * */\n /* eslint-disable valid-jsdoc */\n var DataLabel;\n (function (DataLabel) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Align each individual data label.\n * @private\n */\n function alignDataLabel(point, dataLabel, options, alignTo, isNew) {\n var series = this,\n chart = this.chart,\n inverted = this.isCartesian && chart.inverted,\n enabledDataSorting = this.enabledDataSorting,\n plotX = pick(point.dlBox && point.dlBox.centerX,\n point.plotX),\n plotY = point.plotY,\n rotation = options.rotation,\n align = options.align,\n isInsidePlot = defined(plotX) &&\n defined(plotY) &&\n chart.isInsidePlot(plotX,\n Math.round(plotY), {\n inverted: inverted,\n paneCoordinates: true,\n series: series\n }),\n setStartPos = function (alignOptions) {\n if (enabledDataSorting && series.xAxis && !justify) {\n series.setDataLabelStartPos(point,\n dataLabel,\n isNew,\n isInsidePlot,\n alignOptions);\n }\n };\n var baseline,\n rotCorr, // rotation correction\n // Math.round for rounding errors (#2683), alignTo to allow column\n // labels (#2700)\n alignAttr, // the final position;\n justify = pick(options.overflow, (enabledDataSorting ? 'none' : 'justify')) === 'justify', visible = this.visible &&\n point.visible !== false &&\n (point.series.forceDL ||\n (enabledDataSorting && !justify) ||\n isInsidePlot ||\n (\n // If the data label is inside the align box, it is\n // enough that parts of the align box is inside the\n // plot area (#12370). When stacking, it is always\n // inside regardless of the option (#15148).\n pick(options.inside, !!this.options.stacking) &&\n alignTo &&\n chart.isInsidePlot(plotX, inverted ?\n alignTo.x + 1 :\n alignTo.y + alignTo.height - 1, {\n inverted: inverted,\n paneCoordinates: true,\n series: series\n })));\n if (visible && defined(plotX) && defined(plotY)) {\n if (rotation) {\n dataLabel.attr({ align: align });\n }\n var bBox = dataLabel.getBBox(true),\n bBoxCorrection = [0, 0];\n baseline = chart.renderer.fontMetrics(chart.styledMode ? void 0 : options.style.fontSize, dataLabel).b;\n // The alignment box is a singular point\n alignTo = extend({\n x: inverted ? this.yAxis.len - plotY : plotX,\n y: Math.round(inverted ? this.xAxis.len - plotX : plotY),\n width: 0,\n height: 0\n }, alignTo);\n // Add the text size for alignment calculation\n extend(options, {\n width: bBox.width,\n height: bBox.height\n });\n // Allow a hook for changing alignment in the last moment, then do\n // the alignment\n if (rotation) {\n justify = false; // Not supported for rotated text\n rotCorr = chart.renderer.rotCorr(baseline, rotation); // #3723\n alignAttr = {\n x: (alignTo.x +\n (options.x || 0) +\n alignTo.width / 2 +\n rotCorr.x),\n y: (alignTo.y +\n (options.y || 0) +\n { top: 0, middle: 0.5, bottom: 1 }[options.verticalAlign] *\n alignTo.height)\n };\n bBoxCorrection = [\n bBox.x - Number(dataLabel.attr('x')),\n bBox.y - Number(dataLabel.attr('y'))\n ];\n setStartPos(alignAttr); // data sorting\n dataLabel[isNew ? 'attr' : 'animate'](alignAttr);\n }\n else {\n setStartPos(alignTo); // data sorting\n dataLabel.align(options, void 0, alignTo);\n alignAttr = dataLabel.alignAttr;\n }\n // Handle justify or crop\n if (justify && alignTo.height >= 0) { // #8830\n this.justifyDataLabel(dataLabel, options, alignAttr, bBox, alignTo, isNew);\n // Now check that the data label is within the plot area\n }\n else if (pick(options.crop, true)) {\n var x = alignAttr.x,\n y = alignAttr.y;\n x += bBoxCorrection[0];\n y += bBoxCorrection[1];\n // Uncomment this block to visualize the bounding boxes used for\n // determining visibility\n /*\n chart.renderer.rect(\n chart.plotLeft + alignAttr.x + bBox.x,\n chart.plotTop + alignAttr.y + bBox.y + 9999,\n bBox.width,\n bBox.height\n ).attr({\n stroke: 'rgba(0, 0, 0, 0.3)',\n 'stroke-width': 0.5\n }).add();\n chart.renderer.circle(\n chart.plotLeft + alignAttr.x,\n chart.plotTop + alignAttr.y,\n 2\n ).attr({\n fill: 'red',\n zIndex: 20\n }).add();\n // */\n visible =\n chart.isInsidePlot(x, y, {\n paneCoordinates: true,\n series: series\n }) &&\n chart.isInsidePlot(x + bBox.width, y + bBox.height, {\n paneCoordinates: true,\n series: series\n });\n }\n // When we're using a shape, make it possible with a connector or an\n // arrow pointing to thie point\n if (options.shape && !rotation) {\n dataLabel[isNew ? 'attr' : 'animate']({\n anchorX: inverted ?\n chart.plotWidth - point.plotY :\n point.plotX,\n anchorY: inverted ?\n chart.plotHeight - point.plotX :\n point.plotY\n });\n }\n }\n // To use alignAttr property in hideOverlappingLabels\n if (isNew && enabledDataSorting) {\n dataLabel.placed = false;\n }\n // Show or hide based on the final aligned position\n if (!visible && (!enabledDataSorting || justify)) {\n dataLabel.hide();\n dataLabel.placed = false; // don't animate back in\n }\n else {\n dataLabel.show();\n }\n }\n /**\n * Handle the dataLabels.filter option.\n * @private\n */\n function applyFilter(point, options) {\n var filter = options.filter;\n if (filter) {\n var op = filter.operator;\n var prop = point[filter.property];\n var val = filter.value;\n if ((op === '>' && prop > val) ||\n (op === '<' && prop < val) ||\n (op === '>=' && prop >= val) ||\n (op === '<=' && prop <= val) ||\n (op === '==' && prop == val) || // eslint-disable-line eqeqeq\n (op === '===' && prop === val)) {\n return true;\n }\n return false;\n }\n return true;\n }\n /**\n * @private\n */\n function compose(SeriesClass) {\n if (composedClasses.indexOf(SeriesClass) === -1) {\n var seriesProto = SeriesClass.prototype;\n composedClasses.push(SeriesClass);\n seriesProto.alignDataLabel = alignDataLabel;\n seriesProto.drawDataLabels = drawDataLabels;\n seriesProto.justifyDataLabel = justifyDataLabel;\n seriesProto.setDataLabelStartPos = setDataLabelStartPos;\n }\n }\n DataLabel.compose = compose;\n /**\n * Draw the data labels\n * @private\n */\n function drawDataLabels(points) {\n if (points === void 0) { points = this.points; }\n var series = this,\n chart = series.chart,\n seriesOptions = series.options,\n hasRendered = series.hasRendered || 0,\n renderer = chart.renderer,\n _a = chart.options.chart,\n backgroundColor = _a.backgroundColor,\n plotBackgroundColor = _a.plotBackgroundColor,\n contrastColor = renderer.getContrast((isString(plotBackgroundColor) && plotBackgroundColor) ||\n (isString(backgroundColor) && backgroundColor) ||\n \"#000000\" /* Palette.neutralColor100 */);\n var seriesDlOptions = seriesOptions.dataLabels,\n pointOptions,\n dataLabelsGroup;\n var dataLabelAnim = seriesDlOptions.animation,\n animationConfig = seriesDlOptions.defer ?\n getDeferredAnimation(chart,\n dataLabelAnim,\n series) :\n { defer: 0,\n duration: 0 };\n // Merge in plotOptions.dataLabels for series\n seriesDlOptions = mergeArrays(mergeArrays(chart.options.plotOptions &&\n chart.options.plotOptions.series &&\n chart.options.plotOptions.series.dataLabels, chart.options.plotOptions &&\n chart.options.plotOptions[series.type] &&\n chart.options.plotOptions[series.type].dataLabels), seriesDlOptions);\n fireEvent(this, 'drawDataLabels');\n if (isArray(seriesDlOptions) ||\n seriesDlOptions.enabled ||\n series._hasPointLabels) {\n // Create a separate group for the data labels to avoid rotation\n dataLabelsGroup = series.plotGroup('dataLabelsGroup', 'data-labels', !hasRendered ? 'hidden' : 'inherit', // #5133, #10220\n seriesDlOptions.zIndex || 6);\n dataLabelsGroup.attr({ opacity: +hasRendered }); // #3300\n if (!hasRendered) {\n var group = series.dataLabelsGroup;\n if (group) {\n if (series.visible) { // #2597, #3023, #3024\n dataLabelsGroup.show();\n }\n group[seriesOptions.animation ? 'animate' : 'attr']({ opacity: 1 }, animationConfig);\n }\n }\n // Make the labels for each point\n points.forEach(function (point) {\n // Merge in series options for the point.\n // @note dataLabelAttribs (like pointAttribs) would eradicate\n // the need for dlOptions, and simplify the section below.\n pointOptions = splat(mergeArrays(seriesDlOptions, \n // dlOptions is used in treemaps\n (point.dlOptions ||\n (point.options && point.options.dataLabels))));\n // Handle each individual data label for this point\n pointOptions.forEach(function (labelOptions, i) {\n // Options for one datalabel\n var labelEnabled = (labelOptions.enabled &&\n // #2282, #4641, #7112, #10049\n (!point.isNull || point.dataLabelOnNull) &&\n applyFilter(point,\n labelOptions)),\n connector = point.connectors ?\n point.connectors[i] :\n point.connector;\n var labelConfig,\n formatString,\n labelText,\n style,\n rotation,\n attr,\n dataLabel = point.dataLabels ?\n point.dataLabels[i] : point.dataLabel,\n isNew = !dataLabel;\n var labelDistance = pick(labelOptions.distance,\n point.labelDistance);\n if (labelEnabled) {\n // Create individual options structure that can be\n // extended without affecting others\n labelConfig = point.getLabelConfig();\n formatString = pick(labelOptions[point.formatPrefix + 'Format'], labelOptions.format);\n labelText = defined(formatString) ?\n format(formatString, labelConfig, chart) :\n (labelOptions[point.formatPrefix + 'Formatter'] ||\n labelOptions.formatter).call(labelConfig, labelOptions);\n style = labelOptions.style;\n rotation = labelOptions.rotation;\n if (!chart.styledMode) {\n // Determine the color\n style.color = pick(labelOptions.color, style.color, series.color, \"#000000\" /* Palette.neutralColor100 */);\n // Get automated contrast color\n if (style.color === 'contrast') {\n point.contrastColor = renderer.getContrast((point.color || series.color));\n style.color = (!defined(labelDistance) &&\n labelOptions.inside) ||\n labelDistance < 0 ||\n !!seriesOptions.stacking ?\n point.contrastColor :\n contrastColor;\n }\n else {\n delete point.contrastColor;\n }\n if (seriesOptions.cursor) {\n style.cursor = seriesOptions.cursor;\n }\n }\n attr = {\n r: labelOptions.borderRadius || 0,\n rotation: rotation,\n padding: labelOptions.padding,\n zIndex: 1\n };\n if (!chart.styledMode) {\n attr.fill = labelOptions.backgroundColor;\n attr.stroke = labelOptions.borderColor;\n attr['stroke-width'] = labelOptions.borderWidth;\n }\n // Remove unused attributes (#947)\n objectEach(attr, function (val, name) {\n if (typeof val === 'undefined') {\n delete attr[name];\n }\n });\n }\n // If the point is outside the plot area, destroy it. #678,\n // #820\n if (dataLabel && (!labelEnabled ||\n !defined(labelText) ||\n !!dataLabel.div !== !!labelOptions.useHTML ||\n (\n // Change from no rotation to rotation and\n // vice versa. Don't use defined() because\n // rotation = 0 means also rotation = undefined\n (!dataLabel.rotation ||\n !labelOptions.rotation) &&\n dataLabel.rotation !== labelOptions.rotation))) {\n isNew = true;\n point.dataLabel = dataLabel =\n point.dataLabel && point.dataLabel.destroy();\n if (point.dataLabels) {\n // Remove point.dataLabels if this was the last one\n if (point.dataLabels.length === 1) {\n delete point.dataLabels;\n }\n else {\n delete point.dataLabels[i];\n }\n }\n if (!i) {\n delete point.dataLabel;\n }\n if (connector) {\n point.connector = point.connector.destroy();\n if (point.connectors) {\n // Remove point.connectors if this was the last\n // one\n if (point.connectors.length === 1) {\n delete point.connectors;\n }\n else {\n delete point.connectors[i];\n }\n }\n }\n }\n // Individual labels are disabled if the are explicitly\n // disabled in the point options, or if they fall outside\n // the plot area.\n if (labelEnabled && defined(labelText)) {\n if (!dataLabel) {\n // Create new label element\n point.dataLabels = point.dataLabels || [];\n dataLabel = point.dataLabels[i] = rotation ?\n // Labels don't rotate, use text element\n renderer.text(labelText, 0, 0, labelOptions.useHTML)\n .addClass('highcharts-data-label') :\n // We can use label\n renderer.label(labelText, 0, 0, labelOptions.shape, null, null, labelOptions.useHTML, null, 'data-label');\n // Store for backwards compatibility\n if (!i) {\n point.dataLabel = dataLabel;\n }\n dataLabel.addClass(' highcharts-data-label-color-' +\n point.colorIndex +\n ' ' + (labelOptions.className || '') +\n ( // #3398\n labelOptions.useHTML ?\n ' highcharts-tracker' :\n ''));\n }\n else {\n // Use old element and just update text\n attr.text = labelText;\n }\n // Store data label options for later access\n dataLabel.options = labelOptions;\n dataLabel.attr(attr);\n if (!chart.styledMode) {\n // Styles must be applied before add in order to\n // read text bounding box\n dataLabel.css(style).shadow(labelOptions.shadow);\n }\n var textPathOptions = labelOptions[point.formatPrefix + 'TextPath'] ||\n labelOptions.textPath;\n if (textPathOptions && !labelOptions.useHTML) {\n dataLabel.setTextPath((point.getDataLabelPath &&\n point.getDataLabelPath(dataLabel)) || point.graphic, textPathOptions);\n if (point.dataLabelPath &&\n !textPathOptions.enabled) {\n // clean the DOM\n point.dataLabelPath = (point.dataLabelPath.destroy());\n }\n }\n if (!dataLabel.added) {\n dataLabel.add(dataLabelsGroup);\n }\n // Now the data label is created and placed at 0,0, so\n // we need to align it\n series.alignDataLabel(point, dataLabel, labelOptions, null, isNew);\n }\n else if (dataLabel) {\n dataLabel.hide();\n }\n });\n });\n }\n fireEvent(this, 'afterDrawDataLabels');\n }\n /**\n * If data labels fall partly outside the plot area, align them back in, in\n * a way that doesn't hide the point.\n * @private\n */\n function justifyDataLabel(dataLabel, options, alignAttr, bBox, alignTo, isNew) {\n var chart = this.chart,\n align = options.align,\n verticalAlign = options.verticalAlign,\n padding = dataLabel.box ? 0 : (dataLabel.padding || 0);\n var _a = options.x,\n x = _a === void 0 ? 0 : _a,\n _b = options.y,\n y = _b === void 0 ? 0 : _b,\n off,\n justified;\n // Off left\n off = (alignAttr.x || 0) + padding;\n if (off < 0) {\n if (align === 'right' && x >= 0) {\n options.align = 'left';\n options.inside = true;\n }\n else {\n x -= off;\n }\n justified = true;\n }\n // Off right\n off = (alignAttr.x || 0) + bBox.width - padding;\n if (off > chart.plotWidth) {\n if (align === 'left' && x <= 0) {\n options.align = 'right';\n options.inside = true;\n }\n else {\n x += chart.plotWidth - off;\n }\n justified = true;\n }\n // Off top\n off = alignAttr.y + padding;\n if (off < 0) {\n if (verticalAlign === 'bottom' && y >= 0) {\n options.verticalAlign = 'top';\n options.inside = true;\n }\n else {\n y -= off;\n }\n justified = true;\n }\n // Off bottom\n off = (alignAttr.y || 0) + bBox.height - padding;\n if (off > chart.plotHeight) {\n if (verticalAlign === 'top' && y <= 0) {\n options.verticalAlign = 'bottom';\n options.inside = true;\n }\n else {\n y += chart.plotHeight - off;\n }\n justified = true;\n }\n if (justified) {\n options.x = x;\n options.y = y;\n dataLabel.placed = !isNew;\n dataLabel.align(options, void 0, alignTo);\n }\n return justified;\n }\n /**\n * Merge two objects that can be arrays. If one of them is an array, the\n * other is merged into each element. If both are arrays, each element is\n * merged by index. If neither are arrays, we use normal merge.\n * @private\n */\n function mergeArrays(one, two) {\n var res = [],\n i;\n if (isArray(one) && !isArray(two)) {\n res = one.map(function (el) {\n return merge(el, two);\n });\n }\n else if (isArray(two) && !isArray(one)) {\n res = two.map(function (el) {\n return merge(one, el);\n });\n }\n else if (!isArray(one) && !isArray(two)) {\n res = merge(one, two);\n }\n else {\n i = Math.max(one.length, two.length);\n while (i--) {\n res[i] = merge(one[i], two[i]);\n }\n }\n return res;\n }\n /**\n * Set starting position for data label sorting animation.\n * @private\n */\n function setDataLabelStartPos(point, dataLabel, isNew, isInside, alignOptions) {\n var chart = this.chart,\n inverted = chart.inverted,\n xAxis = this.xAxis,\n reversed = xAxis.reversed,\n labelCenter = inverted ? dataLabel.height / 2 : dataLabel.width / 2,\n pointWidth = point.pointWidth,\n halfWidth = pointWidth ? pointWidth / 2 : 0;\n dataLabel.startXPos = inverted ?\n alignOptions.x :\n (reversed ?\n -labelCenter - halfWidth :\n xAxis.width - labelCenter + halfWidth);\n dataLabel.startYPos = inverted ?\n (reversed ?\n this.yAxis.height - labelCenter + halfWidth :\n -labelCenter - halfWidth) : alignOptions.y;\n // We need to handle visibility in case of sorting point outside plot\n // area\n if (!isInside) {\n dataLabel\n .attr({ opacity: 1 })\n .animate({ opacity: 0 }, void 0, dataLabel.hide);\n }\n else if (dataLabel.visibility === 'hidden') {\n dataLabel.show();\n dataLabel\n .attr({ opacity: 0 })\n .animate({ opacity: 1 });\n }\n // Save start position on first render, but do not change position\n if (!chart.hasRendered) {\n return;\n }\n // Set start position\n if (isNew) {\n dataLabel.attr({ x: dataLabel.startXPos, y: dataLabel.startYPos });\n }\n dataLabel.placed = true;\n }\n })(DataLabel || (DataLabel = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Callback JavaScript function to format the data label as a string. Note that\n * if a `format` is defined, the format takes precedence and the formatter is\n * ignored.\n *\n * @callback Highcharts.DataLabelsFormatterCallbackFunction\n *\n * @param {Highcharts.PointLabelObject} this\n * Data label context to format\n *\n * @param {Highcharts.DataLabelsOptions} options\n * [API options](/highcharts/plotOptions.series.dataLabels) of the data label\n *\n * @return {number|string|null|undefined}\n * Formatted data label text\n */\n /**\n * Values for handling data labels that flow outside the plot area.\n *\n * @typedef {\"allow\"|\"justify\"} Highcharts.DataLabelsOverflowValue\n */\n ''; // keeps doclets above in JS file\n\n return DataLabel;\n });\n _registerModule(_modules, 'Series/Column/ColumnDataLabel.js', [_modules['Core/Series/DataLabel.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (DataLabel, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var Series = SeriesRegistry.series;\n var merge = U.merge,\n pick = U.pick;\n /* *\n *\n * Composition\n *\n * */\n var ColumnDataLabel;\n (function (ColumnDataLabel) {\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Override the basic data label alignment by adjusting for the position of\n * the column.\n * @private\n */\n function alignDataLabel(point, dataLabel, options, alignTo, isNew) {\n var inverted = this.chart.inverted,\n series = point.series,\n xLen = (series.xAxis ? series.xAxis.len : this.chart.plotSizeX) || 0,\n yLen = (series.yAxis ? series.yAxis.len : this.chart.plotSizeY) || 0, \n // data label box for alignment\n dlBox = point.dlBox || point.shapeArgs,\n below = pick(point.below, // range series\n point.plotY >\n pick(this.translatedThreshold,\n yLen)), \n // draw it inside the box?\n inside = pick(options.inside, !!this.options.stacking),\n overshoot;\n // Align to the column itself, or the top of it\n if (dlBox) { // Area range uses this method but not alignTo\n alignTo = merge(dlBox);\n if (alignTo.y < 0) {\n alignTo.height += alignTo.y;\n alignTo.y = 0;\n }\n // If parts of the box overshoots outside the plot area, modify the\n // box to center the label inside\n overshoot = alignTo.y + alignTo.height - yLen;\n if (overshoot > 0 && overshoot < alignTo.height) {\n alignTo.height -= overshoot;\n }\n if (inverted) {\n alignTo = {\n x: yLen - alignTo.y - alignTo.height,\n y: xLen - alignTo.x - alignTo.width,\n width: alignTo.height,\n height: alignTo.width\n };\n }\n // Compute the alignment box\n if (!inside) {\n if (inverted) {\n alignTo.x += below ? 0 : alignTo.width;\n alignTo.width = 0;\n }\n else {\n alignTo.y += below ? alignTo.height : 0;\n alignTo.height = 0;\n }\n }\n }\n // When alignment is undefined (typically columns and bars), display the\n // individual point below or above the point depending on the threshold\n options.align = pick(options.align, !inverted || inside ? 'center' : below ? 'right' : 'left');\n options.verticalAlign = pick(options.verticalAlign, inverted || inside ? 'middle' : below ? 'top' : 'bottom');\n // Call the parent method\n Series.prototype.alignDataLabel.call(this, point, dataLabel, options, alignTo, isNew);\n // If label was justified and we have contrast, set it:\n if (options.inside && point.contrastColor) {\n dataLabel.css({\n color: point.contrastColor\n });\n }\n }\n /** @private */\n function compose(ColumnSeriesClass) {\n DataLabel.compose(Series);\n if (composedClasses.indexOf(ColumnSeriesClass) === -1) {\n composedClasses.push(ColumnSeriesClass);\n ColumnSeriesClass.prototype.alignDataLabel = alignDataLabel;\n }\n }\n ColumnDataLabel.compose = compose;\n })(ColumnDataLabel || (ColumnDataLabel = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return ColumnDataLabel;\n });\n _registerModule(_modules, 'Series/Bar/BarSeries.js', [_modules['Series/Column/ColumnSeries.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (ColumnSeries, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var extend = U.extend,\n merge = U.merge;\n /* *\n *\n * Class\n *\n * */\n /**\n * Bar series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.bar\n *\n * @augments Highcharts.Series\n */\n var BarSeries = /** @class */ (function (_super) {\n __extends(BarSeries, _super);\n function BarSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.data = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n }\n /**\n * A bar series is a special type of column series where the columns are\n * horizontal.\n *\n * @sample highcharts/demo/bar-basic/\n * Bar chart\n *\n * @extends plotOptions.column\n * @product highcharts\n * @optionparent plotOptions.bar\n */\n BarSeries.defaultOptions = merge(ColumnSeries.defaultOptions, {\n // nothing here yet\n });\n return BarSeries;\n }(ColumnSeries));\n extend(BarSeries.prototype, {\n inverted: true\n });\n SeriesRegistry.registerSeriesType('bar', BarSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A `bar` series. If the [type](#series.bar.type) option is not specified,\n * it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.bar\n * @excluding connectNulls, dashStyle, dataParser, dataURL, gapSize, gapUnit,\n * linecap, lineWidth, marker, connectEnds, step\n * @product highcharts\n * @apioption series.bar\n */\n /**\n * An array of data points for the series. For the `bar` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 5],\n * [1, 10],\n * [2, 3]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.bar.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 1,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 10,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.column.data\n * @product highcharts\n * @apioption series.bar.data\n */\n /**\n * @excluding halo,lineWidth,lineWidthPlus,marker\n * @product highcharts highstock\n * @apioption series.bar.states.hover\n */\n /**\n * @excluding halo,lineWidth,lineWidthPlus,marker\n * @product highcharts highstock\n * @apioption series.bar.states.select\n */\n ''; // gets doclets above into transpilat\n\n return BarSeries;\n });\n _registerModule(_modules, 'Series/Scatter/ScatterSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A scatter plot uses cartesian coordinates to display values for two\n * variables for a set of data.\n *\n * @sample {highcharts} highcharts/demo/scatter/\n * Scatter plot\n *\n * @extends plotOptions.line\n * @excluding cropThreshold, pointPlacement, shadow, useOhlcData\n * @product highcharts highstock\n * @optionparent plotOptions.scatter\n */\n var ScatterSeriesDefaults = {\n /**\n * The width of the line connecting the data points.\n *\n * @sample {highcharts} highcharts/plotoptions/scatter-linewidth-none/\n * 0 by default\n * @sample {highcharts} highcharts/plotoptions/scatter-linewidth-1/\n * 1px\n *\n * @product highcharts highstock\n */\n lineWidth: 0,\n findNearestPointBy: 'xy',\n /**\n * Apply a jitter effect for the rendered markers. When plotting\n * discrete values,\n a little random noise may help telling the points\n * apart. The jitter setting applies a random displacement of up to `n`\n * axis units in either direction. So for example on a horizontal X\n * axis,\n setting the `jitter.x` to 0.24 will render the point in a\n * random position between 0.24 units to the left and 0.24 units to the\n * right of the true axis position. On a category axis,\n setting it to\n * 0.5 will fill up the bin and make the data appear continuous.\n *\n * When rendered on top of a box plot or a column series,\n a jitter value\n * of 0.24 will correspond to the underlying series' default\n * [groupPadding](\n * https://api.highcharts.com/highcharts/plotOptions.column.groupPadding)\n * and [pointPadding](\n * https://api.highcharts.com/highcharts/plotOptions.column.pointPadding)\n * settings.\n *\n * @sample {highcharts} highcharts/series-scatter/jitter\n * Jitter on a scatter plot\n *\n * @sample {highcharts} highcharts/series-scatter/jitter-boxplot\n * Jittered scatter plot on top of a box plot\n *\n * @product highcharts highstock\n * @since 7.0.2\n */\n jitter: {\n /**\n * The maximal X offset for the random jitter effect.\n */\n x: 0,\n /**\n * The maximal Y offset for the random jitter effect.\n */\n y: 0\n },\n marker: {\n enabled: true // Overrides auto-enabling in line series (#3647)\n },\n /**\n * Sticky tracking of mouse events. When true,\n the `mouseOut` event\n * on a series isn't triggered until the mouse moves over another\n * series,\n or out of the plot area. When false,\n the `mouseOut` event on\n * a series is triggered when the mouse leaves the area around the\n * series' graph or markers. This also implies the tooltip. When\n * `stickyTracking` is false and `tooltip.shared` is false,\n the tooltip\n * will be hidden when moving the mouse between series.\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock highmaps\n * @apioption plotOptions.scatter.stickyTracking\n */\n /**\n * A configuration object for the tooltip rendering of each single\n * series. Properties are inherited from [tooltip](#tooltip).\n * Overridable properties are `headerFormat`,\n `pointFormat`,\n * `yDecimals`,\n `xDateFormat`,\n `yPrefix` and `ySuffix`. Unlike other\n * series,\n in a scatter plot the series.name by default shows in the\n * headerFormat and point.x and point.y in the pointFormat.\n *\n * @product highcharts highstock highmaps\n */\n tooltip: {\n /**\n * @product highcharts highstock\n */\n headerFormat: '\\u25CF ' +\n ' {series.name}
',\n pointFormat: 'x: {point.x}
y: {point.y}
'\n }\n };\n /**\n * A `scatter` series. If the [type](#series.scatter.type) option is\n * not specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.scatter\n * @excluding cropThreshold, dataParser, dataURL, useOhlcData\n * @product highcharts highstock\n * @apioption series.scatter\n */\n /**\n * An array of data points for the series. For the `scatter` series\n * type, points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 0],\n * [1, 8],\n * [2, 9]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.scatter.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 2,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 4,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @product highcharts highstock\n * @apioption series.scatter.data\n */\n ''; // keeps doclets above in JS file\n /* *\n *\n * Default Export\n *\n * */\n\n return ScatterSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Scatter/ScatterSeries.js', [_modules['Series/Scatter/ScatterSeriesDefaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (ScatterSeriesDefaults, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var _a = SeriesRegistry.seriesTypes,\n ColumnSeries = _a.column,\n LineSeries = _a.line;\n var addEvent = U.addEvent,\n extend = U.extend,\n merge = U.merge;\n /* *\n *\n * Class\n *\n * */\n /**\n * Scatter series type.\n *\n * @private\n */\n var ScatterSeries = /** @class */ (function (_super) {\n __extends(ScatterSeries, _super);\n function ScatterSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.data = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Optionally add the jitter effect.\n * @private\n */\n ScatterSeries.prototype.applyJitter = function () {\n var series = this,\n jitter = this.options.jitter,\n len = this.points.length;\n /**\n * Return a repeatable, pseudo-random number based on an integer\n * seed.\n * @private\n */\n function unrandom(seed) {\n var rand = Math.sin(seed) * 10000;\n return rand - Math.floor(rand);\n }\n if (jitter) {\n this.points.forEach(function (point, i) {\n ['x', 'y'].forEach(function (dim, j) {\n var axis,\n plotProp = 'plot' + dim.toUpperCase(),\n min,\n max,\n translatedJitter;\n if (jitter[dim] && !point.isNull) {\n axis = series[dim + 'Axis'];\n translatedJitter =\n jitter[dim] * axis.transA;\n if (axis && !axis.isLog) {\n // Identify the outer bounds of the jitter range\n min = Math.max(0, point[plotProp] - translatedJitter);\n max = Math.min(axis.len, point[plotProp] + translatedJitter);\n // Find a random position within this range\n point[plotProp] = min +\n (max - min) * unrandom(i + j * len);\n // Update clientX for the tooltip k-d-tree\n if (dim === 'x') {\n point.clientX = point.plotX;\n }\n }\n }\n });\n });\n }\n };\n /**\n * @private\n */\n ScatterSeries.prototype.drawGraph = function () {\n if (this.options.lineWidth) {\n _super.prototype.drawGraph.call(this);\n }\n else if (this.graph) {\n this.graph = this.graph.destroy();\n }\n };\n ScatterSeries.defaultOptions = merge(LineSeries.defaultOptions, ScatterSeriesDefaults);\n return ScatterSeries;\n }(LineSeries));\n extend(ScatterSeries.prototype, {\n drawTracker: ColumnSeries.prototype.drawTracker,\n sorted: false,\n requireSorting: false,\n noSharedTooltip: true,\n trackerGroups: ['group', 'markerGroup', 'dataLabelsGroup'],\n takeOrdinalPosition: false // #2342\n });\n /* *\n *\n * Events\n *\n * */\n /* eslint-disable no-invalid-this */\n addEvent(ScatterSeries, 'afterTranslate', function () {\n this.applyJitter();\n });\n SeriesRegistry.registerSeriesType('scatter', ScatterSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return ScatterSeries;\n });\n _registerModule(_modules, 'Series/CenteredUtilities.js', [_modules['Core/Globals.js'], _modules['Core/Series/Series.js'], _modules['Core/Utilities.js']], function (H, Series, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var deg2rad = H.deg2rad;\n var fireEvent = U.fireEvent,\n isNumber = U.isNumber,\n pick = U.pick,\n relativeLength = U.relativeLength;\n /**\n * @private\n */\n var CenteredUtilities;\n (function (CenteredUtilities) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Get the center of the pie based on the size and center options relative\n * to the plot area. Borrowed by the polar and gauge series types.\n *\n * @private\n * @function Highcharts.CenteredSeriesMixin.getCenter\n */\n function getCenter() {\n var options = this.options,\n chart = this.chart,\n slicingRoom = 2 * (options.slicedOffset || 0),\n plotWidth = chart.plotWidth - 2 * slicingRoom,\n plotHeight = chart.plotHeight - 2 * slicingRoom,\n centerOption = options.center,\n smallestSize = Math.min(plotWidth,\n plotHeight),\n thickness = options.thickness;\n var handleSlicingRoom,\n size = options.size,\n innerSize = options.innerSize || 0,\n i,\n value;\n if (typeof size === 'string') {\n size = parseFloat(size);\n }\n if (typeof innerSize === 'string') {\n innerSize = parseFloat(innerSize);\n }\n var positions = [\n pick(centerOption[0], '50%'),\n pick(centerOption[1], '50%'),\n // Prevent from negative values\n pick(size && size < 0 ? void 0 : options.size, '100%'),\n pick(innerSize && innerSize < 0 ? void 0 : options.innerSize || 0, '0%')\n ];\n // No need for inner size in angular (gauges) series but still required\n // for pie series\n if (chart.angular && !(this instanceof Series)) {\n positions[3] = 0;\n }\n for (i = 0; i < 4; ++i) {\n value = positions[i];\n handleSlicingRoom = i < 2 || (i === 2 && /%$/.test(value));\n // i == 0: centerX, relative to width\n // i == 1: centerY, relative to height\n // i == 2: size, relative to smallestSize\n // i == 3: innerSize, relative to size\n positions[i] = relativeLength(value, [plotWidth, plotHeight, smallestSize, positions[2]][i]) + (handleSlicingRoom ? slicingRoom : 0);\n }\n // innerSize cannot be larger than size (#3632)\n if (positions[3] > positions[2]) {\n positions[3] = positions[2];\n }\n // thickness overrides innerSize, need to be less than pie size (#6647)\n if (isNumber(thickness) &&\n thickness * 2 < positions[2] && thickness > 0) {\n positions[3] = positions[2] - thickness * 2;\n }\n fireEvent(this, 'afterGetCenter', { positions: positions });\n return positions;\n }\n CenteredUtilities.getCenter = getCenter;\n /**\n * getStartAndEndRadians - Calculates start and end angles in radians.\n * Used in series types such as pie and sunburst.\n *\n * @private\n * @function Highcharts.CenteredSeriesMixin.getStartAndEndRadians\n *\n * @param {number} [start]\n * Start angle in degrees.\n *\n * @param {number} [end]\n * Start angle in degrees.\n *\n * @return {Highcharts.RadianAngles}\n * Returns an object containing start and end angles as radians.\n */\n function getStartAndEndRadians(start, end) {\n var startAngle = isNumber(start) ? start : 0, // must be a number\n endAngle = ((isNumber(end) && // must be a number\n end > startAngle && // must be larger than the start angle\n // difference must be less than 360 degrees\n (end - startAngle) < 360) ?\n end :\n startAngle + 360),\n correction = -90;\n return {\n start: deg2rad * (startAngle + correction),\n end: deg2rad * (endAngle + correction)\n };\n }\n CenteredUtilities.getStartAndEndRadians = getStartAndEndRadians;\n })(CenteredUtilities || (CenteredUtilities = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @private\n * @interface Highcharts.RadianAngles\n */ /**\n * @name Highcharts.RadianAngles#end\n * @type {number}\n */ /**\n * @name Highcharts.RadianAngles#start\n * @type {number}\n */\n ''; // keeps doclets above in JS file\n\n return CenteredUtilities;\n });\n _registerModule(_modules, 'Series/Pie/PiePoint.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Series/Point.js'], _modules['Core/Utilities.js']], function (A, Point, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var setAnimation = A.setAnimation;\n var addEvent = U.addEvent,\n defined = U.defined,\n extend = U.extend,\n isNumber = U.isNumber,\n pick = U.pick,\n relativeLength = U.relativeLength;\n /* *\n *\n * Class\n *\n * */\n var PiePoint = /** @class */ (function (_super) {\n __extends(PiePoint, _super);\n function PiePoint() {\n /* *\n *\n * Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n _this.labelDistance = void 0;\n _this.options = void 0;\n _this.series = void 0;\n return _this;\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Extendable method for getting the path of the connector between the\n * data label and the pie slice.\n * @private\n */\n PiePoint.prototype.getConnectorPath = function () {\n var labelPosition = this.labelPosition,\n options = this.series.options.dataLabels,\n predefinedShapes = this.connectorShapes;\n var connectorShape = options.connectorShape;\n // find out whether to use the predefined shape\n if (predefinedShapes[connectorShape]) {\n connectorShape = predefinedShapes[connectorShape];\n }\n return connectorShape.call(this, {\n // pass simplified label position object for user's convenience\n x: labelPosition.final.x,\n y: labelPosition.final.y,\n alignment: labelPosition.alignment\n }, labelPosition.connectorPosition, options);\n };\n /**\n * @private\n */\n PiePoint.prototype.getTranslate = function () {\n return this.sliced ? this.slicedTranslation : {\n translateX: 0,\n translateY: 0\n };\n };\n /**\n * @private\n */\n PiePoint.prototype.haloPath = function (size) {\n var shapeArgs = this.shapeArgs;\n return this.sliced || !this.visible ?\n [] :\n this.series.chart.renderer.symbols.arc(shapeArgs.x, shapeArgs.y, shapeArgs.r + size, shapeArgs.r + size, {\n // Substract 1px to ensure the background is not bleeding\n // through between the halo and the slice (#7495).\n innerR: shapeArgs.r - 1,\n start: shapeArgs.start,\n end: shapeArgs.end\n });\n };\n /**\n * Initialize the pie slice.\n * @private\n */\n PiePoint.prototype.init = function () {\n var _this = this;\n _super.prototype.init.apply(this, arguments);\n this.name = pick(this.name, 'Slice');\n // add event listener for select\n var toggleSlice = function (e) {\n _this.slice(e.type === 'select');\n };\n addEvent(this, 'select', toggleSlice);\n addEvent(this, 'unselect', toggleSlice);\n return this;\n };\n /**\n * Negative points are not valid (#1530, #3623, #5322)\n * @private\n */\n PiePoint.prototype.isValid = function () {\n return isNumber(this.y) && this.y >= 0;\n };\n /**\n * Toggle the visibility of a pie slice or other data point. Note that this\n * method is available only for some series, like pie, treemap and sunburst.\n *\n * @function Highcharts.Point#setVisible\n *\n * @param {boolean} [vis]\n * True to show the pie slice or other data point, false to hide. If\n * undefined, the visibility is toggled.\n *\n * @param {boolean} [redraw] Whether to redraw the chart after the point is\n * altered. If doing more operations on the chart, it is a good idea to set\n * redraw to false and call {@link Chart#redraw|chart.redraw()} after.\n *\n */\n PiePoint.prototype.setVisible = function (vis, redraw) {\n var _this = this;\n var series = this.series,\n chart = series.chart,\n ignoreHiddenPoint = series.options.ignoreHiddenPoint;\n redraw = pick(redraw, ignoreHiddenPoint);\n if (vis !== this.visible) {\n // If called without an argument, toggle visibility\n this.visible = this.options.visible = vis =\n typeof vis === 'undefined' ? !this.visible : vis;\n // update userOptions.data\n series.options.data[series.data.indexOf(this)] =\n this.options;\n // Show and hide associated elements. This is performed\n // regardless of redraw or not, because chart.redraw only\n // handles full series.\n ['graphic', 'dataLabel', 'connector', 'shadowGroup'].forEach(function (key) {\n if (_this[key]) {\n _this[key][vis ? 'show' : 'hide'](vis);\n }\n });\n if (this.legendItem) {\n chart.legend.colorizeItem(this, vis);\n }\n // #4170, hide halo after hiding point\n if (!vis && this.state === 'hover') {\n this.setState('');\n }\n // Handle ignore hidden slices\n if (ignoreHiddenPoint) {\n series.isDirty = true;\n }\n if (redraw) {\n chart.redraw();\n }\n }\n };\n /**\n * Set or toggle whether the slice is cut out from the pie.\n * @private\n *\n * @param {boolean} sliced\n * When undefined, the slice state is toggled.\n *\n * @param {boolean} [redraw]\n * Whether to redraw the chart. True by default.\n *\n * @param {boolean|Partial} [animation]\n * Animation options.\n */\n PiePoint.prototype.slice = function (sliced, redraw, animation) {\n var series = this.series,\n chart = series.chart;\n setAnimation(animation, chart);\n // redraw is true by default\n redraw = pick(redraw, true);\n /**\n * Pie series only. Whether to display a slice offset from the\n * center.\n * @name Highcharts.Point#sliced\n * @type {boolean|undefined}\n */\n // if called without an argument, toggle\n this.sliced = this.options.sliced = sliced =\n defined(sliced) ? sliced : !this.sliced;\n // update userOptions.data\n series.options.data[series.data.indexOf(this)] =\n this.options;\n if (this.graphic) {\n this.graphic.animate(this.getTranslate());\n }\n if (this.shadowGroup) {\n this.shadowGroup.animate(this.getTranslate());\n }\n };\n return PiePoint;\n }(Point));\n extend(PiePoint.prototype, {\n connectorShapes: {\n // only one available before v7.0.0\n fixedOffset: function (labelPosition, connectorPosition, options) {\n var breakAt = connectorPosition.breakAt,\n touchingSliceAt = connectorPosition.touchingSliceAt,\n lineSegment = options.softConnector ? [\n 'C',\n // 1st control point (of the curve)\n labelPosition.x +\n // 5 gives the connector a little horizontal bend\n (labelPosition.alignment === 'left' ? -5 : 5),\n labelPosition.y,\n 2 * breakAt.x - touchingSliceAt.x,\n 2 * breakAt.y - touchingSliceAt.y,\n breakAt.x,\n breakAt.y //\n ] : [\n 'L',\n breakAt.x,\n breakAt.y\n ];\n // assemble the path\n return ([\n ['M', labelPosition.x, labelPosition.y],\n lineSegment,\n ['L', touchingSliceAt.x, touchingSliceAt.y]\n ]);\n },\n straight: function (labelPosition, connectorPosition) {\n var touchingSliceAt = connectorPosition.touchingSliceAt;\n // direct line to the slice\n return [\n ['M', labelPosition.x, labelPosition.y],\n ['L', touchingSliceAt.x, touchingSliceAt.y]\n ];\n },\n crookedLine: function (labelPosition, connectorPosition, options) {\n var touchingSliceAt = connectorPosition.touchingSliceAt,\n series = this.series,\n pieCenterX = series.center[0],\n plotWidth = series.chart.plotWidth,\n plotLeft = series.chart.plotLeft,\n alignment = labelPosition.alignment,\n radius = this.shapeArgs.r,\n crookDistance = relativeLength(// % to fraction\n options.crookDistance, 1),\n crookX = alignment === 'left' ?\n pieCenterX + radius + (plotWidth + plotLeft -\n pieCenterX - radius) * (1 - crookDistance) :\n plotLeft + (pieCenterX - radius) * crookDistance,\n segmentWithCrook = [\n 'L',\n crookX,\n labelPosition.y\n ];\n var useCrook = true;\n // crookedLine formula doesn't make sense if the path overlaps\n // the label - use straight line instead in that case\n if (alignment === 'left' ?\n (crookX > labelPosition.x || crookX < touchingSliceAt.x) :\n (crookX < labelPosition.x || crookX > touchingSliceAt.x)) {\n useCrook = false;\n }\n // assemble the path\n var path = [['M',\n labelPosition.x,\n labelPosition.y]];\n if (useCrook) {\n path.push(segmentWithCrook);\n }\n path.push(['L', touchingSliceAt.x, touchingSliceAt.y]);\n return path;\n }\n }\n });\n /* *\n *\n * Default Export\n *\n * */\n\n return PiePoint;\n });\n _registerModule(_modules, 'Series/Pie/PieSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A pie chart is a circular graphic which is divided into slices to\n * illustrate numerical proportion.\n *\n * @sample highcharts/demo/pie-basic/\n * Pie chart\n *\n * @extends plotOptions.line\n * @excluding animationLimit, boostThreshold, connectEnds, connectNulls,\n * cropThreshold, dashStyle, dataSorting, dragDrop,\n * findNearestPointBy, getExtremesFromAll, label, lineWidth,\n * linkedTo, marker, negativeColor, pointInterval,\n * pointIntervalUnit, pointPlacement, pointStart,\n * softThreshold, stacking, step, threshold, turboThreshold,\n * zoneAxis, zones, dataSorting, boostBlending\n * @product highcharts highmaps\n * @optionparent plotOptions.pie\n *\n * @private\n */\n var PieSeriesDefaults = {\n /**\n * @excluding legendItemClick\n * @apioption plotOptions.pie.events\n */\n /**\n * Fires when the checkbox next to the point name in the legend is\n * clicked. One parameter, event, is passed to the function. The state\n * of the checkbox is found by event.checked. The checked item is found\n * by event.item. Return false to prevent the default action which is to\n * toggle the select state of the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-checkboxclick/\n * Alert checkbox status\n *\n * @type {Function}\n * @since 1.2.0\n * @product highcharts highmaps\n * @context Highcharts.Point\n * @apioption plotOptions.pie.events.checkboxClick\n */\n /**\n * Fires when the legend item belonging to the pie point (slice) is\n * clicked. The `this` keyword refers to the point itself. One\n * parameter, `event`, is passed to the function, containing common\n * event information. The default action is to toggle the visibility of\n * the point. This can be prevented by calling `event.preventDefault()`.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-point-events-legenditemclick/\n * Confirm toggle visibility\n *\n * @type {Highcharts.PointLegendItemClickCallbackFunction}\n * @since 1.2.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.point.events.legendItemClick\n */\n /**\n * The center of the pie chart relative to the plot area. Can be\n * percentages or pixel values. The default behaviour (as of 3.0) is to\n * center the pie so that all slices and data labels are within the plot\n * area. As a consequence, the pie may actually jump around in a chart\n * with dynamic values, as the data labels move. In that case, the\n * center should be explicitly set, for example to `[\"50%\", \"50%\"]`.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-center/\n * Centered at 100, 100\n *\n * @type {Array<(number|string|null),(number|string|null)>}\n * @default [null, null]\n * @product highcharts highmaps\n *\n * @private\n */\n center: [null, null],\n /**\n * The color of the pie series. A pie series is represented as an empty\n * circle if the total sum of its values is 0. Use this property to\n * define the color of its border.\n *\n * In styled mode, the color can be defined by the\n * [colorIndex](#plotOptions.series.colorIndex) option. Also, the series\n * color can be set with the `.highcharts-series`,\n * `.highcharts-color-{n}`, `.highcharts-{type}-series` or\n * `.highcharts-series-{n}` class, or individual classes given by the\n * `className` option.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-emptyseries/\n * Empty pie series\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #cccccc\n * @apioption plotOptions.pie.color\n */\n /**\n * @product highcharts\n *\n * @private\n */\n clip: false,\n /**\n * @ignore-option\n *\n * @private\n */\n colorByPoint: true,\n /**\n * A series specific or series type specific color set to use instead\n * of the global [colors](#colors).\n *\n * @sample {highcharts} highcharts/demo/pie-monochrome/\n * Set default colors for all pies\n *\n * @type {Array}\n * @since 3.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.colors\n */\n /**\n * @declare Highcharts.SeriesPieDataLabelsOptionsObject\n * @extends plotOptions.series.dataLabels\n * @excluding align, allowOverlap, inside, staggerLines, step\n * @private\n */\n dataLabels: {\n /**\n * Alignment method for data labels. Possible values are:\n *\n * - `plotEdges`: Each label touches the nearest vertical edge of\n * the plot area.\n *\n * - `connectors`: Connectors have the same x position and the\n * widest label of each half (left & right) touches the nearest\n * vertical edge of the plot area.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-alignto-connectors/\n * alignTo: connectors\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-alignto-plotedges/\n * alignTo: plotEdges\n *\n * @type {string}\n * @since 7.0.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.dataLabels.alignTo\n */\n allowOverlap: true,\n /**\n * The color of the line connecting the data label to the pie slice.\n * The default color is the same as the point's color.\n *\n * In styled mode, the connector stroke is given in the\n * `.highcharts-data-label-connector` class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-connectorcolor/\n * Blue connectors\n * @sample {highcharts} highcharts/css/pie-point/\n * Styled connectors\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.1\n * @product highcharts highmaps\n * @apioption plotOptions.pie.dataLabels.connectorColor\n */\n /**\n * The distance from the data label to the connector. Note that\n * data labels also have a default `padding`, so in order for the\n * connector to touch the text, the `padding` must also be 0.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-connectorpadding/\n * No padding\n *\n * @since 2.1\n * @product highcharts highmaps\n */\n connectorPadding: 5,\n /**\n * Specifies the method that is used to generate the connector path.\n * Highcharts provides 3 built-in connector shapes: `'fixedOffset'`\n * (default), `'straight'` and `'crookedLine'`. Using\n * `'crookedLine'` has the most sense (in most of the cases) when\n * `'alignTo'` is set.\n *\n * Users can provide their own method by passing a function instead\n * of a String. 3 arguments are passed to the callback:\n *\n * - Object that holds the information about the coordinates of the\n * label (`x` & `y` properties) and how the label is located in\n * relation to the pie (`alignment` property). `alignment` can by\n * one of the following:\n * `'left'` (pie on the left side of the data label),\n * `'right'` (pie on the right side of the data label) or\n * `'center'` (data label overlaps the pie).\n *\n * - Object that holds the information about the position of the\n * connector. Its `touchingSliceAt` porperty tells the position\n * of the place where the connector touches the slice.\n *\n * - Data label options\n *\n * The function has to return an SVG path definition in array form\n * (see the example).\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-connectorshape-string/\n * connectorShape is a String\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-connectorshape-function/\n * connectorShape is a function\n *\n * @type {string|Function}\n * @since 7.0.0\n * @product highcharts highmaps\n */\n connectorShape: 'fixedOffset',\n /**\n * The width of the line connecting the data label to the pie slice.\n *\n * In styled mode, the connector stroke width is given in the\n * `.highcharts-data-label-connector` class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-connectorwidth-disabled/\n * Disable the connector\n * @sample {highcharts} highcharts/css/pie-point/\n * Styled connectors\n *\n * @type {number}\n * @default 1\n * @since 2.1\n * @product highcharts highmaps\n * @apioption plotOptions.pie.dataLabels.connectorWidth\n */\n /**\n * Works only if `connectorShape` is `'crookedLine'`. It defines how\n * far from the vertical plot edge the coonnector path should be\n * crooked.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-crookdistance/\n * crookDistance set to 90%\n *\n * @since 7.0.0\n * @product highcharts highmaps\n */\n crookDistance: '70%',\n /**\n * The distance of the data label from the pie's edge. Negative\n * numbers put the data label on top of the pie slices. Can also be\n * defined as a percentage of pie's radius. Connectors are only\n * shown for data labels outside the pie.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-distance/\n * Data labels on top of the pie\n *\n * @type {number|string}\n * @since 2.1\n * @product highcharts highmaps\n */\n distance: 30,\n enabled: true,\n /**\n * A\n * [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for the data label. Available variables are the same as for\n * `formatter`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-format/\n * Add a unit\n *\n * @type {string}\n * @default undefined\n * @since 3.0\n * @apioption plotOptions.pie.dataLabels.format\n */\n // eslint-disable-next-line valid-jsdoc\n /**\n * Callback JavaScript function to format the data label. Note that\n * if a `format` is defined, the format takes precedence and the\n * formatter is ignored.\n *\n * @type {Highcharts.DataLabelsFormatterCallbackFunction}\n * @default function () { return this.point.isNull ? void 0 : this.point.name; }\n */\n formatter: function () {\n return this.point.isNull ? void 0 : this.point.name;\n },\n /**\n * Whether to render the connector as a soft arc or a line with\n * sharp break. Works only if `connectorShape` equals to\n * `fixedOffset`.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-softconnector-true/\n * Soft\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-softconnector-false/\n * Non soft\n *\n * @since 2.1.7\n * @product highcharts highmaps\n */\n softConnector: true,\n /**\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-overflow\n * Long labels truncated with an ellipsis\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-overflow-wrap\n * Long labels are wrapped\n *\n * @type {Highcharts.CSSObject}\n * @apioption plotOptions.pie.dataLabels.style\n */\n x: 0\n },\n /**\n * If the total sum of the pie's values is 0, the series is represented\n * as an empty circle . The `fillColor` option defines the color of that\n * circle. Use [pie.borderWidth](#plotOptions.pie.borderWidth) to set\n * the border thickness.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-emptyseries/\n * Empty pie series\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @private\n */\n fillColor: void 0,\n /**\n * The end angle of the pie in degrees where 0 is top and 90 is right.\n * Defaults to `startAngle` plus 360.\n *\n * @sample {highcharts} highcharts/demo/pie-semi-circle/\n * Semi-circle donut\n *\n * @type {number}\n * @since 1.3.6\n * @product highcharts highmaps\n * @apioption plotOptions.pie.endAngle\n */\n /**\n * Thickness describing the ring size for a donut type chart,\n * overriding [innerSize](#plotOptions.pie.innerSize).\n *\n * @type {number}\n * @default undefined\n * @product highcharts\n * @since 10.1.0\n * @apioption plotOptions.pie.thickness\n * @private\n */\n /**\n * Equivalent to [chart.ignoreHiddenSeries](#chart.ignoreHiddenSeries),\n * this option tells whether the series shall be redrawn as if the\n * hidden point were `null`.\n *\n * The default value changed from `false` to `true` with Highcharts\n * 3.0.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-ignorehiddenpoint/\n * True, the hiddden point is ignored\n *\n * @since 2.3.0\n * @product highcharts highmaps\n *\n * @private\n */\n ignoreHiddenPoint: true,\n /**\n * @ignore-option\n *\n * @private\n */\n inactiveOtherPoints: true,\n /**\n * The size of the inner diameter for the pie. A size greater than 0\n * renders a donut chart. Can be a percentage or pixel value.\n * Percentages are relative to the pie size. Pixel values are given as\n * integers. Setting overridden by thickness.\n *\n *\n * Note: in Highcharts < 4.1.2, the percentage was relative to the plot\n * area, not the pie size.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-innersize-80px/\n * 80px inner size\n * @sample {highcharts} highcharts/plotoptions/pie-innersize-50percent/\n * 50% of the plot area\n * @sample {highcharts} highcharts/demo/3d-pie-donut/\n * 3D donut\n *\n * @type {number|string}\n * @default 0\n * @since 2.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.innerSize\n */\n /**\n * @ignore-option\n *\n * @private\n */\n legendType: 'point',\n /**\n * @ignore-option\n *\n * @private\n */\n marker: null,\n /**\n * The minimum size for a pie in response to auto margins. The pie will\n * try to shrink to make room for data labels in side the plot area,\n * but only to this size.\n *\n * @type {number|string}\n * @default 80\n * @since 3.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.minSize\n */\n /**\n * The diameter of the pie relative to the plot area. Can be a\n * percentage or pixel value. Pixel values are given as integers. The\n * default behaviour (as of 3.0) is to scale to the plot area and give\n * room for data labels within the plot area.\n * [slicedOffset](#plotOptions.pie.slicedOffset) is also included in the\n * default size calculation. As a consequence, the size of the pie may\n * vary when points are updated and data labels more around. In that\n * case it is best to set a fixed value, for example `\"75%\"`.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-size/\n * Smaller pie\n *\n * @type {number|string|null}\n * @product highcharts highmaps\n *\n * @private\n */\n size: null,\n /**\n * Whether to display this particular series or series type in the\n * legend. Since 2.1, pies are not shown in the legend by default.\n *\n * @sample {highcharts} highcharts/plotoptions/series-showinlegend/\n * One series in the legend, one hidden\n *\n * @product highcharts highmaps\n *\n * @private\n */\n showInLegend: false,\n /**\n * If a point is sliced, moved out from the center, how many pixels\n * should it be moved?.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-slicedoffset-20/\n * 20px offset\n *\n * @product highcharts highmaps\n *\n * @private\n */\n slicedOffset: 10,\n /**\n * The start angle of the pie slices in degrees where 0 is top and 90\n * right.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-startangle-90/\n * Start from right\n *\n * @type {number}\n * @default 0\n * @since 2.3.4\n * @product highcharts highmaps\n * @apioption plotOptions.pie.startAngle\n */\n /**\n * Sticky tracking of mouse events. When true, the `mouseOut` event\n * on a series isn't triggered until the mouse moves over another\n * series, or out of the plot area. When false, the `mouseOut` event on\n * a series is triggered when the mouse leaves the area around the\n * series' graph or markers. This also implies the tooltip. When\n * `stickyTracking` is false and `tooltip.shared` is false, the tooltip\n * will be hidden when moving the mouse between series.\n *\n * @product highcharts highmaps\n *\n * @private\n */\n stickyTracking: false,\n tooltip: {\n followPointer: true\n },\n /**\n * The color of the border surrounding each slice. When `null`, the\n * border takes the same color as the slice fill. This can be used\n * together with a `borderWidth` to fill drawing gaps created by\n * antialiazing artefacts in borderless pies.\n *\n * In styled mode, the border stroke is given in the `.highcharts-point`\n * class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-bordercolor-black/\n * Black border\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #ffffff\n * @product highcharts highmaps\n *\n * @private\n */\n borderColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The width of the border surrounding each slice.\n *\n * When setting the border width to 0, there may be small gaps between\n * the slices due to SVG antialiasing artefacts. To work around this,\n * keep the border width at 0.5 or 1, but set the `borderColor` to\n * `null` instead.\n *\n * In styled mode, the border stroke width is given in the\n * `.highcharts-point` class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-borderwidth/\n * 3px border\n *\n * @product highcharts highmaps\n *\n * @private\n */\n borderWidth: 1,\n /**\n * @ignore-option\n * @private\n */\n lineWidth: void 0,\n states: {\n /**\n * @extends plotOptions.series.states.hover\n * @excluding marker, lineWidth, lineWidthPlus\n * @product highcharts highmaps\n */\n hover: {\n /**\n * How much to brighten the point on interaction. Requires the\n * main color to be defined in hex or rgb(a) format.\n *\n * In styled mode, the hover brightness is by default replaced\n * by a fill-opacity given in the `.highcharts-point-hover`\n * class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-states-hover-brightness/\n * Brightened by 0.5\n *\n * @product highcharts highmaps\n */\n brightness: 0.1\n }\n }\n };\n /**\n * A `pie` series. If the [type](#series.pie.type) option is not specified,\n * it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.pie\n * @excluding cropThreshold, dataParser, dataURL, linkedTo, stack, xAxis, yAxis,\n * dataSorting, step, boostThreshold, boostBlending\n * @product highcharts highmaps\n * @apioption series.pie\n */\n /**\n * An array of data points for the series. For the `pie` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.pie.turboThreshold),\n * this option is not available.\n * ```js\n * data: [{\n * y: 1,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * y: 7,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @excluding marker, x\n * @product highcharts highmaps\n * @apioption series.pie.data\n */\n /**\n * @type {Highcharts.SeriesPieDataLabelsOptionsObject}\n * @product highcharts highmaps\n * @apioption series.pie.data.dataLabels\n */\n /**\n * The sequential index of the data point in the legend.\n *\n * @type {number}\n * @product highcharts highmaps\n * @apioption series.pie.data.legendIndex\n */\n /**\n * Whether to display a slice offset from the center.\n *\n * @sample {highcharts} highcharts/point/sliced/\n * One sliced point\n *\n * @type {boolean}\n * @product highcharts highmaps\n * @apioption series.pie.data.sliced\n */\n /**\n * @extends plotOptions.pie.dataLabels\n * @excluding align, allowOverlap, inside, staggerLines, step\n * @product highcharts highmaps\n * @apioption series.pie.dataLabels\n */\n /**\n * @excluding legendItemClick\n * @product highcharts highmaps\n * @apioption series.pie.events\n */\n ''; // placeholder for transpiled doclets above\n /* *\n *\n * Default Export\n *\n * */\n\n return PieSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Pie/PieSeries.js', [_modules['Series/CenteredUtilities.js'], _modules['Series/Column/ColumnSeries.js'], _modules['Core/Globals.js'], _modules['Core/Legend/LegendSymbol.js'], _modules['Series/Pie/PiePoint.js'], _modules['Series/Pie/PieSeriesDefaults.js'], _modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/Symbols.js'], _modules['Core/Utilities.js']], function (CU, ColumnSeries, H, LegendSymbol, PiePoint, PieSeriesDefaults, Series, SeriesRegistry, Symbols, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var getStartAndEndRadians = CU.getStartAndEndRadians;\n var noop = H.noop;\n var clamp = U.clamp,\n extend = U.extend,\n fireEvent = U.fireEvent,\n merge = U.merge,\n pick = U.pick,\n relativeLength = U.relativeLength;\n /* *\n *\n * Class\n *\n * */\n /**\n * Pie series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.pie\n *\n * @augments Highcharts.Series\n */\n var PieSeries = /** @class */ (function (_super) {\n __extends(PieSeries, _super);\n function PieSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.center = void 0;\n _this.data = void 0;\n _this.maxLabelDistance = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Animates the pies in.\n * @private\n */\n PieSeries.prototype.animate = function (init) {\n var series = this,\n points = series.points,\n startAngleRad = series.startAngleRad;\n if (!init) {\n points.forEach(function (point) {\n var graphic = point.graphic,\n args = point.shapeArgs;\n if (graphic && args) {\n // start values\n graphic.attr({\n // animate from inner radius (#779)\n r: pick(point.startR, (series.center && series.center[3] / 2)),\n start: startAngleRad,\n end: startAngleRad\n });\n // animate\n graphic.animate({\n r: args.r,\n start: args.start,\n end: args.end\n }, series.options.animation);\n }\n });\n }\n };\n /**\n * Called internally to draw auxiliary graph in pie-like series in\n * situtation when the default graph is not sufficient enough to present\n * the data well. Auxiliary graph is saved in the same object as\n * regular graph.\n * @private\n */\n PieSeries.prototype.drawEmpty = function () {\n var start = this.startAngleRad,\n end = this.endAngleRad,\n options = this.options;\n var centerX,\n centerY;\n // Draw auxiliary graph if there're no visible points.\n if (this.total === 0 && this.center) {\n centerX = this.center[0];\n centerY = this.center[1];\n if (!this.graph) {\n this.graph = this.chart.renderer\n .arc(centerX, centerY, this.center[1] / 2, 0, start, end)\n .addClass('highcharts-empty-series')\n .add(this.group);\n }\n this.graph.attr({\n d: Symbols.arc(centerX, centerY, this.center[2] / 2, 0, {\n start: start,\n end: end,\n innerR: this.center[3] / 2\n })\n });\n if (!this.chart.styledMode) {\n this.graph.attr({\n 'stroke-width': options.borderWidth,\n fill: options.fillColor || 'none',\n stroke: options.color || \"#cccccc\" /* Palette.neutralColor20 */\n });\n }\n }\n else if (this.graph) { // Destroy the graph object.\n this.graph = this.graph.destroy();\n }\n };\n /**\n * Slices in pie chart are initialized in DOM, but it's shapes and\n * animations are normally run in `drawPoints()`.\n * @private\n */\n PieSeries.prototype.drawPoints = function () {\n var renderer = this.chart.renderer;\n this.points.forEach(function (point) {\n // When updating a series between 2d and 3d or cartesian and\n // polar, the shape type changes.\n if (point.graphic && point.hasNewShapeType()) {\n point.graphic = point.graphic.destroy();\n }\n if (!point.graphic) {\n point.graphic = renderer[point.shapeType](point.shapeArgs)\n .add(point.series.group);\n point.delayedRendering = true;\n }\n });\n };\n /**\n * Extend the generatePoints method by adding total and percentage\n * properties to each point\n * @private\n */\n PieSeries.prototype.generatePoints = function () {\n _super.prototype.generatePoints.call(this);\n this.updateTotals();\n };\n /**\n * Utility for getting the x value from a given y, used for\n * anticollision logic in data labels. Added point for using specific\n * points' label distance.\n * @private\n */\n PieSeries.prototype.getX = function (y, left, point) {\n var center = this.center, \n // Variable pie has individual radius\n radius = this.radii ?\n this.radii[point.index] || 0 :\n center[2] / 2;\n var angle = Math.asin(clamp((y - center[1]) / (radius + point.labelDistance), -1, 1));\n var x = center[0] +\n (left ? -1 : 1) *\n (Math.cos(angle) * (radius + point.labelDistance)) +\n (point.labelDistance > 0 ?\n (left ? -1 : 1) * this.options.dataLabels.padding :\n 0);\n return x;\n };\n /**\n * Define hasData function for non-cartesian series. Returns true if the\n * series has points at all.\n * @private\n */\n PieSeries.prototype.hasData = function () {\n return !!this.processedXData.length; // != 0\n };\n /**\n * Draw the data points\n * @private\n */\n PieSeries.prototype.redrawPoints = function () {\n var series = this,\n chart = series.chart,\n renderer = chart.renderer,\n shadow = series.options.shadow;\n var groupTranslation,\n graphic,\n pointAttr,\n shapeArgs;\n this.drawEmpty();\n if (shadow && !series.shadowGroup && !chart.styledMode) {\n series.shadowGroup = renderer\n .g('shadow')\n .attr({ zIndex: -1 })\n .add(series.group);\n }\n // draw the slices\n series.points.forEach(function (point) {\n var animateTo = {};\n graphic = point.graphic;\n if (!point.isNull && graphic) {\n var shadowGroup = void 0;\n shapeArgs = point.shapeArgs;\n // If the point is sliced, use special translation, else use\n // plot area translation\n groupTranslation = point.getTranslate();\n if (!chart.styledMode) {\n // Put the shadow behind all points\n shadowGroup = point.shadowGroup;\n if (shadow && !shadowGroup) {\n shadowGroup = point.shadowGroup = renderer\n .g('shadow')\n .add(series.shadowGroup);\n }\n if (shadowGroup) {\n shadowGroup.attr(groupTranslation);\n }\n pointAttr = series.pointAttribs(point, (point.selected && 'select'));\n }\n // Draw the slice\n if (!point.delayedRendering) {\n graphic\n .setRadialReference(series.center);\n if (!chart.styledMode) {\n merge(true, animateTo, pointAttr);\n }\n merge(true, animateTo, shapeArgs, groupTranslation);\n graphic.animate(animateTo);\n }\n else {\n graphic\n .setRadialReference(series.center)\n .attr(shapeArgs)\n .attr(groupTranslation);\n if (!chart.styledMode) {\n graphic\n .attr(pointAttr)\n .attr({ 'stroke-linejoin': 'round' })\n .shadow(shadow, shadowGroup);\n }\n point.delayedRendering = false;\n }\n graphic.attr({\n visibility: point.visible ? 'inherit' : 'hidden'\n });\n graphic.addClass(point.getClassName(), true);\n }\n else if (graphic) {\n point.graphic = graphic.destroy();\n }\n });\n };\n /**\n * Utility for sorting data labels.\n * @private\n */\n PieSeries.prototype.sortByAngle = function (points, sign) {\n points.sort(function (a, b) {\n return ((typeof a.angle !== 'undefined') &&\n (b.angle - a.angle) * sign);\n });\n };\n /**\n * Do translation for pie slices\n * @private\n */\n PieSeries.prototype.translate = function (positions) {\n fireEvent(this, 'translate');\n this.generatePoints();\n var series = this,\n precision = 1000, // issue #172\n options = series.options,\n slicedOffset = options.slicedOffset,\n connectorOffset = slicedOffset + (options.borderWidth || 0),\n radians = getStartAndEndRadians(options.startAngle,\n options.endAngle),\n startAngleRad = series.startAngleRad = radians.start,\n endAngleRad = series.endAngleRad = radians.end,\n circ = endAngleRad - startAngleRad, // 2 * Math.PI,\n points = series.points,\n labelDistance = options.dataLabels.distance,\n ignoreHiddenPoint = options.ignoreHiddenPoint,\n len = points.length;\n var finalConnectorOffset,\n start,\n end,\n angle, \n // the x component of the radius vector for a given point\n radiusX,\n radiusY,\n i,\n point,\n cumulative = 0;\n // Get positions - either an integer or a percentage string must be\n // given. If positions are passed as a parameter, we're in a\n // recursive loop for adjusting space for data labels.\n if (!positions) {\n series.center = positions = series.getCenter();\n }\n // Calculate the geometry for each point\n for (i = 0; i < len; i++) {\n point = points[i];\n // set start and end angle\n start = startAngleRad + (cumulative * circ);\n if (point.isValid() &&\n (!ignoreHiddenPoint || point.visible)) {\n cumulative += point.percentage / 100;\n }\n end = startAngleRad + (cumulative * circ);\n // set the shape\n var shapeArgs = {\n x: positions[0],\n y: positions[1],\n r: positions[2] / 2,\n innerR: positions[3] / 2,\n start: Math.round(start * precision) / precision,\n end: Math.round(end * precision) / precision\n };\n point.shapeType = 'arc';\n point.shapeArgs = shapeArgs;\n // Used for distance calculation for specific point.\n point.labelDistance = pick((point.options.dataLabels &&\n point.options.dataLabels.distance), labelDistance);\n // Compute point.labelDistance if it's defined as percentage\n // of slice radius (#8854)\n point.labelDistance = relativeLength(point.labelDistance, shapeArgs.r);\n // Saved for later dataLabels distance calculation.\n series.maxLabelDistance = Math.max(series.maxLabelDistance || 0, point.labelDistance);\n // The angle must stay within -90 and 270 (#2645)\n angle = (end + start) / 2;\n if (angle > 1.5 * Math.PI) {\n angle -= 2 * Math.PI;\n }\n else if (angle < -Math.PI / 2) {\n angle += 2 * Math.PI;\n }\n // Center for the sliced out slice\n point.slicedTranslation = {\n translateX: Math.round(Math.cos(angle) * slicedOffset),\n translateY: Math.round(Math.sin(angle) * slicedOffset)\n };\n // set the anchor point for tooltips\n radiusX = Math.cos(angle) * positions[2] / 2;\n radiusY = Math.sin(angle) * positions[2] / 2;\n point.tooltipPos = [\n positions[0] + radiusX * 0.7,\n positions[1] + radiusY * 0.7\n ];\n point.half = angle < -Math.PI / 2 || angle > Math.PI / 2 ?\n 1 :\n 0;\n point.angle = angle;\n // Set the anchor point for data labels. Use point.labelDistance\n // instead of labelDistance // #1174\n // finalConnectorOffset - not override connectorOffset value.\n finalConnectorOffset = Math.min(connectorOffset, point.labelDistance / 5); // #1678\n point.labelPosition = {\n natural: {\n // initial position of the data label - it's utilized for\n // finding the final position for the label\n x: positions[0] + radiusX + Math.cos(angle) *\n point.labelDistance,\n y: positions[1] + radiusY + Math.sin(angle) *\n point.labelDistance\n },\n 'final': {\n // used for generating connector path -\n // initialized later in drawDataLabels function\n // x: undefined,\n // y: undefined\n },\n // left - pie on the left side of the data label\n // right - pie on the right side of the data label\n // center - data label overlaps the pie\n alignment: point.labelDistance < 0 ?\n 'center' : point.half ? 'right' : 'left',\n connectorPosition: {\n breakAt: {\n x: positions[0] + radiusX + Math.cos(angle) *\n finalConnectorOffset,\n y: positions[1] + radiusY + Math.sin(angle) *\n finalConnectorOffset\n },\n touchingSliceAt: {\n x: positions[0] + radiusX,\n y: positions[1] + radiusY\n }\n }\n };\n }\n fireEvent(series, 'afterTranslate');\n };\n /**\n * Recompute total chart sum and update percentages of points.\n * @private\n */\n PieSeries.prototype.updateTotals = function () {\n var points = this.points,\n len = points.length,\n ignoreHiddenPoint = this.options.ignoreHiddenPoint;\n var i,\n point,\n total = 0;\n // Get the total sum\n for (i = 0; i < len; i++) {\n point = points[i];\n if (point.isValid() &&\n (!ignoreHiddenPoint || point.visible)) {\n total += point.y;\n }\n }\n this.total = total;\n // Set each point's properties\n for (i = 0; i < len; i++) {\n point = points[i];\n point.percentage =\n (total > 0 && (point.visible || !ignoreHiddenPoint)) ?\n point.y / total * 100 :\n 0;\n point.total = total;\n }\n };\n PieSeries.defaultOptions = merge(Series.defaultOptions, PieSeriesDefaults);\n return PieSeries;\n }(Series));\n extend(PieSeries.prototype, {\n axisTypes: [],\n directTouch: true,\n drawGraph: void 0,\n drawLegendSymbol: LegendSymbol.drawRectangle,\n drawTracker: ColumnSeries.prototype.drawTracker,\n getCenter: CU.getCenter,\n getSymbol: noop,\n isCartesian: false,\n noSharedTooltip: true,\n pointAttribs: ColumnSeries.prototype.pointAttribs,\n pointClass: PiePoint,\n requireSorting: false,\n searchPoint: noop,\n trackerGroups: ['group', 'dataLabelsGroup']\n });\n SeriesRegistry.registerSeriesType('pie', PieSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return PieSeries;\n });\n _registerModule(_modules, 'Series/Pie/PieDataLabel.js', [_modules['Core/Series/DataLabel.js'], _modules['Core/Globals.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (DataLabel, H, R, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var noop = H.noop;\n var distribute = R.distribute;\n var Series = SeriesRegistry.series;\n var arrayMax = U.arrayMax,\n clamp = U.clamp,\n defined = U.defined,\n merge = U.merge,\n pick = U.pick,\n relativeLength = U.relativeLength;\n /* *\n *\n * Composition\n *\n * */\n var ColumnDataLabel;\n (function (ColumnDataLabel) {\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n var dataLabelPositioners = {\n // Based on the value computed in Highcharts' distribute algorithm.\n radialDistributionY: function (point) {\n return point.top + point.distributeBox.pos;\n },\n // get the x - use the natural x position for labels near the\n // top and bottom, to prevent the top and botton slice\n // connectors from touching each other on either side\n // Based on the value computed in Highcharts' distribute algorithm.\n radialDistributionX: function (series, point, y, naturalY) {\n return series.getX(y < point.top + 2 || y > point.bottom - 2 ?\n naturalY :\n y, point.half, point);\n },\n // dataLabels.distance determines the x position of the label\n justify: function (point, radius, seriesCenter) {\n return seriesCenter[0] + (point.half ? -1 : 1) *\n (radius + point.labelDistance);\n },\n // Left edges of the left-half labels touch the left edge of the plot\n // area. Right edges of the right-half labels touch the right edge of\n // the plot area.\n alignToPlotEdges: function (dataLabel, half, plotWidth, plotLeft) {\n var dataLabelWidth = dataLabel.getBBox().width;\n return half ? dataLabelWidth + plotLeft :\n plotWidth - dataLabelWidth - plotLeft;\n },\n // Connectors of each side end in the same x position. Labels are\n // aligned to them. Left edge of the widest left-half label touches the\n // left edge of the plot area. Right edge of the widest right-half label\n // touches the right edge of the plot area.\n alignToConnectors: function (points, half, plotWidth, plotLeft) {\n var maxDataLabelWidth = 0,\n dataLabelWidth;\n // find widest data label\n points.forEach(function (point) {\n dataLabelWidth = point.dataLabel.getBBox().width;\n if (dataLabelWidth > maxDataLabelWidth) {\n maxDataLabelWidth = dataLabelWidth;\n }\n });\n return half ? maxDataLabelWidth + plotLeft :\n plotWidth - maxDataLabelWidth - plotLeft;\n }\n };\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /** @private */\n function compose(PieSeriesClass) {\n DataLabel.compose(Series);\n if (composedClasses.indexOf(PieSeriesClass) === -1) {\n composedClasses.push(PieSeriesClass);\n var pieProto = PieSeriesClass.prototype;\n pieProto.dataLabelPositioners = dataLabelPositioners;\n pieProto.alignDataLabel = noop;\n pieProto.drawDataLabels = drawDataLabels;\n pieProto.placeDataLabels = placeDataLabels;\n pieProto.verifyDataLabelOverflow = verifyDataLabelOverflow;\n }\n }\n ColumnDataLabel.compose = compose;\n /**\n * Override the base drawDataLabels method by pie specific functionality\n * @private\n */\n function drawDataLabels() {\n var series = this,\n data = series.data,\n chart = series.chart,\n options = series.options.dataLabels || {},\n connectorPadding = options.connectorPadding,\n plotWidth = chart.plotWidth,\n plotHeight = chart.plotHeight,\n plotLeft = chart.plotLeft,\n maxWidth = Math.round(chart.chartWidth / 3),\n seriesCenter = series.center,\n radius = seriesCenter[2] / 2,\n centerY = seriesCenter[1],\n halves = [\n [],\n [] // left\n ],\n overflow = [0, 0, 0, 0], // top, right, bottom, left\n dataLabelPositioners = series.dataLabelPositioners;\n var point,\n connectorWidth,\n connector,\n dataLabel,\n dataLabelWidth, \n // labelPos,\n labelPosition,\n labelHeight, \n // divide the points into right and left halves for anti collision\n x,\n y,\n visibility,\n j,\n pointDataLabelsOptions;\n // get out if not enabled\n if (!series.visible ||\n (!options.enabled &&\n !series._hasPointLabels)) {\n return;\n }\n // Reset all labels that have been shortened\n data.forEach(function (point) {\n if (point.dataLabel && point.visible && point.dataLabel.shortened) {\n point.dataLabel\n .attr({\n width: 'auto'\n }).css({\n width: 'auto',\n textOverflow: 'clip'\n });\n point.dataLabel.shortened = false;\n }\n });\n // run parent method\n Series.prototype.drawDataLabels.apply(series);\n data.forEach(function (point) {\n if (point.dataLabel) {\n if (point.visible) { // #407, #2510\n // Arrange points for detection collision\n halves[point.half].push(point);\n // Reset positions (#4905)\n point.dataLabel._pos = null;\n // Avoid long labels squeezing the pie size too far down\n if (!defined(options.style.width) &&\n !defined(point.options.dataLabels &&\n point.options.dataLabels.style &&\n point.options.dataLabels.style.width)) {\n if (point.dataLabel.getBBox().width > maxWidth) {\n point.dataLabel.css({\n // Use a fraction of the maxWidth to avoid\n // wrapping close to the end of the string.\n width: Math.round(maxWidth * 0.7) + 'px'\n });\n point.dataLabel.shortened = true;\n }\n }\n }\n else {\n point.dataLabel = point.dataLabel.destroy();\n // Workaround to make pies destroy multiple datalabels\n // correctly. This logic needs rewriting to support multiple\n // datalabels fully.\n if (point.dataLabels && point.dataLabels.length === 1) {\n delete point.dataLabels;\n }\n }\n }\n });\n /* Loop over the points in each half, starting from the top and bottom\n * of the pie to detect overlapping labels.\n */\n halves.forEach(function (points, i) {\n var length = points.length,\n positions = [];\n var top,\n bottom,\n naturalY,\n sideOverflow,\n size,\n distributionLength;\n if (!length) {\n return;\n }\n // Sort by angle\n series.sortByAngle(points, i - 0.5);\n // Only do anti-collision when we have dataLabels outside the pie\n // and have connectors. (#856)\n if (series.maxLabelDistance > 0) {\n top = Math.max(0, centerY - radius - series.maxLabelDistance);\n bottom = Math.min(centerY + radius + series.maxLabelDistance, chart.plotHeight);\n points.forEach(function (point) {\n // check if specific points' label is outside the pie\n if (point.labelDistance > 0 && point.dataLabel) {\n // point.top depends on point.labelDistance value\n // Used for calculation of y value in getX method\n point.top = Math.max(0, centerY - radius - point.labelDistance);\n point.bottom = Math.min(centerY + radius + point.labelDistance, chart.plotHeight);\n size = point.dataLabel.getBBox().height || 21;\n // point.positionsIndex is needed for getting index of\n // parameter related to specific point inside positions\n // array - not every point is in positions array.\n point.distributeBox = {\n target: point.labelPosition.natural.y -\n point.top + size / 2,\n size: size,\n rank: point.y\n };\n positions.push(point.distributeBox);\n }\n });\n distributionLength = bottom + size - top;\n distribute(positions, distributionLength, distributionLength / 5);\n }\n // Now the used slots are sorted, fill them up sequentially\n for (j = 0; j < length; j++) {\n point = points[j];\n // labelPos = point.labelPos;\n labelPosition = point.labelPosition;\n dataLabel = point.dataLabel;\n visibility = point.visible === false ? 'hidden' : 'inherit';\n naturalY = labelPosition.natural.y;\n y = naturalY;\n if (positions && defined(point.distributeBox)) {\n if (typeof point.distributeBox.pos === 'undefined') {\n visibility = 'hidden';\n }\n else {\n labelHeight = point.distributeBox.size;\n // Find label's y position\n y = dataLabelPositioners\n .radialDistributionY(point);\n }\n }\n // It is needed to delete point.positionIndex for\n // dynamically added points etc.\n delete point.positionIndex; // @todo unused\n // Find label's x position\n // justify is undocumented in the API - preserve support for it\n if (options.justify) {\n x = dataLabelPositioners.justify(point, radius, seriesCenter);\n }\n else {\n switch (options.alignTo) {\n case 'connectors':\n x = dataLabelPositioners.alignToConnectors(points, i, plotWidth, plotLeft);\n break;\n case 'plotEdges':\n x = dataLabelPositioners.alignToPlotEdges(dataLabel, i, plotWidth, plotLeft);\n break;\n default:\n x = dataLabelPositioners.radialDistributionX(series, point, y, naturalY);\n }\n }\n // Record the placement and visibility\n dataLabel._attr = {\n visibility: visibility,\n align: labelPosition.alignment\n };\n pointDataLabelsOptions = point.options.dataLabels || {};\n dataLabel._pos = {\n x: (x +\n pick(pointDataLabelsOptions.x, options.x) + // (#12985)\n ({\n left: connectorPadding,\n right: -connectorPadding\n }[labelPosition.alignment] || 0)),\n // 10 is for the baseline (label vs text)\n y: (y +\n pick(pointDataLabelsOptions.y, options.y) - // (#12985)\n 10)\n };\n // labelPos.x = x;\n // labelPos.y = y;\n labelPosition.final.x = x;\n labelPosition.final.y = y;\n // Detect overflowing data labels\n if (pick(options.crop, true)) {\n dataLabelWidth = dataLabel.getBBox().width;\n sideOverflow = null;\n // Overflow left\n if (x - dataLabelWidth < connectorPadding &&\n i === 1 // left half\n ) {\n sideOverflow = Math.round(dataLabelWidth - x + connectorPadding);\n overflow[3] = Math.max(sideOverflow, overflow[3]);\n // Overflow right\n }\n else if (x + dataLabelWidth > plotWidth - connectorPadding &&\n i === 0 // right half\n ) {\n sideOverflow = Math.round(x + dataLabelWidth - plotWidth + connectorPadding);\n overflow[1] = Math.max(sideOverflow, overflow[1]);\n }\n // Overflow top\n if (y - labelHeight / 2 < 0) {\n overflow[0] = Math.max(Math.round(-y + labelHeight / 2), overflow[0]);\n // Overflow left\n }\n else if (y + labelHeight / 2 > plotHeight) {\n overflow[2] = Math.max(Math.round(y + labelHeight / 2 - plotHeight), overflow[2]);\n }\n dataLabel.sideOverflow = sideOverflow;\n }\n } // for each point\n }); // for each half\n // Do not apply the final placement and draw the connectors until we\n // have verified that labels are not spilling over.\n if (arrayMax(overflow) === 0 ||\n this.verifyDataLabelOverflow(overflow)) {\n // Place the labels in the final position\n this.placeDataLabels();\n this.points.forEach(function (point) {\n // #8864: every connector can have individual options\n pointDataLabelsOptions =\n merge(options, point.options.dataLabels);\n connectorWidth =\n pick(pointDataLabelsOptions.connectorWidth, 1);\n // Draw the connector\n if (connectorWidth) {\n var isNew = void 0;\n connector = point.connector;\n dataLabel = point.dataLabel;\n if (dataLabel &&\n dataLabel._pos &&\n point.visible &&\n point.labelDistance > 0) {\n visibility = dataLabel._attr.visibility;\n isNew = !connector;\n if (isNew) {\n point.connector = connector = chart.renderer\n .path()\n .addClass('highcharts-data-label-connector ' +\n ' highcharts-color-' + point.colorIndex +\n (point.className ?\n ' ' + point.className :\n ''))\n .add(series.dataLabelsGroup);\n if (!chart.styledMode) {\n connector.attr({\n 'stroke-width': connectorWidth,\n 'stroke': (pointDataLabelsOptions.connectorColor ||\n point.color ||\n \"#666666\" /* Palette.neutralColor60 */)\n });\n }\n }\n connector[isNew ? 'attr' : 'animate']({\n d: point.getConnectorPath()\n });\n connector.attr('visibility', visibility);\n }\n else if (connector) {\n point.connector = connector.destroy();\n }\n }\n });\n }\n }\n /**\n * Perform the final placement of the data labels after we have verified\n * that they fall within the plot area.\n * @private\n */\n function placeDataLabels() {\n this.points.forEach(function (point) {\n var dataLabel = point.dataLabel,\n _pos;\n if (dataLabel && point.visible) {\n _pos = dataLabel._pos;\n if (_pos) {\n // Shorten data labels with ellipsis if they still overflow\n // after the pie has reached minSize (#223).\n if (dataLabel.sideOverflow) {\n dataLabel._attr.width =\n Math.max(dataLabel.getBBox().width -\n dataLabel.sideOverflow, 0);\n dataLabel.css({\n width: dataLabel._attr.width + 'px',\n textOverflow: ((this.options.dataLabels.style || {})\n .textOverflow ||\n 'ellipsis')\n });\n dataLabel.shortened = true;\n }\n dataLabel.attr(dataLabel._attr);\n dataLabel[dataLabel.moved ? 'animate' : 'attr'](_pos);\n dataLabel.moved = true;\n }\n else if (dataLabel) {\n dataLabel.attr({ y: -9999 });\n }\n }\n // Clear for update\n delete point.distributeBox;\n }, this);\n }\n /**\n * Verify whether the data labels are allowed to draw, or we should run more\n * translation and data label positioning to keep them inside the plot area.\n * Returns true when data labels are ready to draw.\n * @private\n */\n function verifyDataLabelOverflow(overflow) {\n var center = this.center,\n options = this.options,\n centerOption = options.center,\n minSize = options.minSize || 80,\n newSize = minSize, \n // If a size is set, return true and don't try to shrink the pie\n // to fit the labels.\n ret = options.size !== null;\n if (!ret) {\n // Handle horizontal size and center\n if (centerOption[0] !== null) { // Fixed center\n newSize = Math.max(center[2] -\n Math.max(overflow[1], overflow[3]), minSize);\n }\n else { // Auto center\n newSize = Math.max(\n // horizontal overflow\n center[2] - overflow[1] - overflow[3], minSize);\n // horizontal center\n center[0] += (overflow[3] - overflow[1]) / 2;\n }\n // Handle vertical size and center\n if (centerOption[1] !== null) { // Fixed center\n newSize = clamp(newSize, minSize, center[2] - Math.max(overflow[0], overflow[2]));\n }\n else { // Auto center\n newSize = clamp(newSize, minSize, \n // vertical overflow\n center[2] - overflow[0] - overflow[2]);\n // vertical center\n center[1] += (overflow[0] - overflow[2]) / 2;\n }\n // If the size must be decreased, we need to run translate and\n // drawDataLabels again\n if (newSize < center[2]) {\n center[2] = newSize;\n center[3] = Math.min(// #3632\n options.thickness ?\n Math.max(0, newSize - options.thickness * 2) :\n Math.max(0, relativeLength(options.innerSize || 0, newSize)), newSize); // #6647\n this.translate(center);\n if (this.drawDataLabels) {\n this.drawDataLabels();\n }\n // Else, return true to indicate that the pie and its labels is\n // within the plot area\n }\n else {\n ret = true;\n }\n }\n return ret;\n }\n })(ColumnDataLabel || (ColumnDataLabel = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return ColumnDataLabel;\n });\n _registerModule(_modules, 'Extensions/OverlappingDataLabels.js', [_modules['Core/Chart/Chart.js'], _modules['Core/Utilities.js']], function (Chart, U) {\n /* *\n *\n * Highcharts module to hide overlapping data labels.\n * This module is included in Highcharts.\n *\n * (c) 2009-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var addEvent = U.addEvent,\n fireEvent = U.fireEvent,\n isArray = U.isArray,\n isNumber = U.isNumber,\n objectEach = U.objectEach,\n pick = U.pick;\n /**\n * Internal type\n * @private\n */\n /* eslint-disable no-invalid-this */\n // Collect potensial overlapping data labels. Stack labels probably don't need\n // to be considered because they are usually accompanied by data labels that lie\n // inside the columns.\n addEvent(Chart, 'render', function collectAndHide() {\n var chart = this,\n labels = [];\n // Consider external label collectors\n (this.labelCollectors || []).forEach(function (collector) {\n labels = labels.concat(collector());\n });\n (this.yAxis || []).forEach(function (yAxis) {\n if (yAxis.stacking &&\n yAxis.options.stackLabels &&\n !yAxis.options.stackLabels.allowOverlap) {\n objectEach(yAxis.stacking.stacks, function (stack) {\n objectEach(stack, function (stackItem) {\n if (stackItem.label) {\n labels.push(stackItem.label);\n }\n });\n });\n }\n });\n (this.series || []).forEach(function (series) {\n var dlOptions = series.options.dataLabels;\n if (series.visible &&\n !(dlOptions.enabled === false && !series._hasPointLabels)) { // #3866\n var push = function (points) {\n return points.forEach(function (point) {\n if (point.visible) {\n var dataLabels = (isArray(point.dataLabels) ?\n point.dataLabels :\n (point.dataLabel ? [point.dataLabel] : []));\n dataLabels.forEach(function (label) {\n var options = label.options;\n label.labelrank = pick(options.labelrank, point.labelrank, point.shapeArgs && point.shapeArgs.height); // #4118\n if (!options.allowOverlap) {\n labels.push(label);\n }\n else { // #13449\n label.oldOpacity = label.opacity;\n label.newOpacity = 1;\n hideOrShow(label, chart);\n }\n });\n }\n });\n };\n push(series.nodes || []);\n push(series.points);\n }\n });\n this.hideOverlappingLabels(labels);\n });\n /**\n * Hide overlapping labels. Labels are moved and faded in and out on zoom to\n * provide a smooth visual imression.\n *\n * @private\n * @function Highcharts.Chart#hideOverlappingLabels\n * @param {Array} labels\n * Rendered data labels\n * @requires modules/overlapping-datalabels\n */\n Chart.prototype.hideOverlappingLabels = function (labels) {\n var chart = this,\n len = labels.length,\n ren = chart.renderer,\n label,\n i,\n j,\n label1,\n label2,\n box1,\n box2,\n isLabelAffected = false,\n isIntersectRect = function (box1,\n box2) {\n return !(box2.x >= box1.x + box1.width ||\n box2.x + box2.width <= box1.x ||\n box2.y >= box1.y + box1.height ||\n box2.y + box2.height <= box1.y);\n }, \n // Get the box with its position inside the chart, as opposed to getBBox\n // that only reports the position relative to the parent.\n getAbsoluteBox = function (label) {\n var pos,\n parent,\n bBox, \n // Substract the padding if no background or border (#4333)\n padding = label.box ? 0 : (label.padding || 0),\n lineHeightCorrection = 0,\n xOffset = 0,\n boxWidth,\n alignValue;\n if (label &&\n (!label.alignAttr || label.placed)) {\n pos = label.alignAttr || {\n x: label.attr('x'),\n y: label.attr('y')\n };\n parent = label.parentGroup;\n // Get width and height if pure text nodes (stack labels)\n if (!label.width) {\n bBox = label.getBBox();\n label.width = bBox.width;\n label.height = bBox.height;\n // Labels positions are computed from top left corner, so\n // we need to substract the text height from text nodes too.\n lineHeightCorrection = ren\n .fontMetrics(null, label.element).h;\n }\n boxWidth = label.width - 2 * padding;\n alignValue = {\n left: '0',\n center: '0.5',\n right: '1'\n }[label.alignValue];\n if (alignValue) {\n xOffset = +alignValue * boxWidth;\n }\n else if (isNumber(label.x) &&\n Math.round(label.x) !== label.translateX) {\n xOffset = label.x - label.translateX;\n }\n return {\n x: pos.x + (parent.translateX || 0) + padding -\n (xOffset || 0),\n y: pos.y + (parent.translateY || 0) + padding -\n lineHeightCorrection,\n width: label.width - 2 * padding,\n height: label.height - 2 * padding\n };\n }\n };\n for (i = 0; i < len; i++) {\n label = labels[i];\n if (label) {\n // Mark with initial opacity\n label.oldOpacity = label.opacity;\n label.newOpacity = 1;\n label.absoluteBox = getAbsoluteBox(label);\n }\n }\n // Prevent a situation in a gradually rising slope, that each label will\n // hide the previous one because the previous one always has lower rank.\n labels.sort(function (a, b) {\n return (b.labelrank || 0) - (a.labelrank || 0);\n });\n // Detect overlapping labels\n for (i = 0; i < len; i++) {\n label1 = labels[i];\n box1 = label1 && label1.absoluteBox;\n for (j = i + 1; j < len; ++j) {\n label2 = labels[j];\n box2 = label2 && label2.absoluteBox;\n if (box1 &&\n box2 &&\n label1 !== label2 && // #6465, polar chart with connectEnds\n label1.newOpacity !== 0 &&\n label2.newOpacity !== 0 &&\n // #15863 dataLabels are no longer hidden by translation\n label1.visibility !== 'hidden' &&\n label2.visibility !== 'hidden') {\n if (isIntersectRect(box1, box2)) {\n (label1.labelrank < label2.labelrank ? label1 : label2)\n .newOpacity = 0;\n }\n }\n }\n }\n // Hide or show\n labels.forEach(function (label) {\n if (hideOrShow(label, chart)) {\n isLabelAffected = true;\n }\n });\n if (isLabelAffected) {\n fireEvent(chart, 'afterHideAllOverlappingLabels');\n }\n };\n /**\n * Hide or show labels based on opacity.\n *\n * @private\n * @function hideOrShow\n * @param {Highcharts.SVGElement} label\n * The label.\n * @param {Highcharts.Chart} chart\n * The chart that contains the label.\n * @return {boolean}\n * Whether label is affected\n */\n function hideOrShow(label, chart) {\n var complete,\n newOpacity,\n isLabelAffected = false;\n if (label) {\n newOpacity = label.newOpacity;\n if (label.oldOpacity !== newOpacity) {\n // Make sure the label is completely hidden to avoid catching clicks\n // (#4362)\n if (label.alignAttr && label.placed) { // data labels\n label[newOpacity ? 'removeClass' : 'addClass']('highcharts-data-label-hidden');\n complete = function () {\n if (!chart.styledMode) {\n label.css({\n pointerEvents: newOpacity ? 'auto' : 'none'\n });\n }\n };\n isLabelAffected = true;\n // Animate or set the opacity\n label.alignAttr.opacity = newOpacity;\n label[label.isOld ? 'animate' : 'attr'](label.alignAttr, null, complete);\n fireEvent(chart, 'afterHideOverlappingLabel');\n }\n else { // other labels, tick labels\n label.attr({\n opacity: newOpacity\n });\n }\n }\n label.isOld = true;\n }\n return isLabelAffected;\n }\n\n });\n _registerModule(_modules, 'Core/Responsive.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var extend = U.extend,\n find = U.find,\n isArray = U.isArray,\n isObject = U.isObject,\n merge = U.merge,\n objectEach = U.objectEach,\n pick = U.pick,\n splat = U.splat,\n uniqueKey = U.uniqueKey;\n /* *\n *\n * Composition\n *\n * */\n var Responsive;\n (function (Responsive) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * @private\n */\n function compose(ChartClass) {\n if (composedClasses.indexOf(ChartClass) === -1) {\n composedClasses.push(ChartClass);\n extend(ChartClass.prototype, Additions.prototype);\n }\n return ChartClass;\n }\n Responsive.compose = compose;\n /* *\n *\n * Class\n *\n * */\n var Additions = /** @class */ (function () {\n function Additions() {\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get the current values for a given set of options. Used before we\n * update the chart with a new responsiveness rule.\n *\n * @todo Restore axis options (by id?). The matching of items in\n * collections bears resemblance to the oneToOne matching in\n * Chart.update. Probably we can refactor out that matching and reuse it\n * in both functions.\n *\n * @private\n * @function Highcharts.Chart#currentOptions\n */\n Additions.prototype.currentOptions = function (options) {\n var chart = this, ret = {};\n /**\n * Recurse over a set of options and its current values,\n * and store the current values in the ret object.\n */\n function getCurrent(options, curr, ret, depth) {\n var i;\n objectEach(options, function (val, key) {\n if (!depth &&\n chart.collectionsWithUpdate.indexOf(key) > -1 &&\n curr[key]) {\n val = splat(val);\n ret[key] = [];\n // Iterate over collections like series, xAxis or yAxis\n // and map the items by index.\n for (i = 0; i < Math.max(val.length, curr[key].length); i++) {\n // Item exists in current data (#6347)\n if (curr[key][i]) {\n // If the item is missing from the new data, we\n // need to save the whole config structure. Like\n // when responsively updating from a dual axis\n // layout to a single axis and back (#13544).\n if (val[i] === void 0) {\n ret[key][i] = curr[key][i];\n // Otherwise, proceed\n }\n else {\n ret[key][i] = {};\n getCurrent(val[i], curr[key][i], ret[key][i], depth + 1);\n }\n }\n }\n }\n else if (isObject(val)) {\n ret[key] = isArray(val) ? [] : {};\n getCurrent(val, curr[key] || {}, ret[key], depth + 1);\n }\n else if (typeof curr[key] === 'undefined') { // #10286\n ret[key] = null;\n }\n else {\n ret[key] = curr[key];\n }\n });\n }\n getCurrent(options, this.options, ret, 0);\n return ret;\n };\n /**\n * Handle a single responsiveness rule.\n *\n * @private\n * @function Highcharts.Chart#matchResponsiveRule\n * @param {Highcharts.ResponsiveRulesOptions} rule\n * @param {Array} matches\n */\n Additions.prototype.matchResponsiveRule = function (rule, matches) {\n var condition = rule.condition,\n fn = condition.callback || function () {\n return (this.chartWidth <= pick(condition.maxWidth,\n Number.MAX_VALUE) &&\n this.chartHeight <= pick(condition.maxHeight,\n Number.MAX_VALUE) &&\n this.chartWidth >= pick(condition.minWidth, 0) &&\n this.chartHeight >= pick(condition.minHeight, 0));\n };\n if (fn.call(this)) {\n matches.push(rule._id);\n }\n };\n /**\n * Update the chart based on the current chart/document size and options\n * for responsiveness.\n *\n * @private\n * @function Highcharts.Chart#setResponsive\n * @param {boolean} [redraw=true]\n * @param {boolean} [reset=false]\n * Reset by un-applying all rules. Chart.update resets all rules before\n * applying updated options.\n */\n Additions.prototype.setResponsive = function (redraw, reset) {\n var _this = this;\n var options = this.options.responsive,\n currentResponsive = this.currentResponsive;\n var ruleIds = [],\n undoOptions;\n if (!reset && options && options.rules) {\n options.rules.forEach(function (rule) {\n if (typeof rule._id === 'undefined') {\n rule._id = uniqueKey();\n }\n _this.matchResponsiveRule(rule, ruleIds /* , redraw */);\n }, this);\n }\n // Merge matching rules\n var mergedOptions = merge.apply(void 0,\n ruleIds\n .map(function (ruleId) { return find((options || {}).rules || [],\n function (rule) { return (rule._id === ruleId); }); })\n .map(function (rule) { return (rule && rule.chartOptions); }));\n mergedOptions.isResponsiveOptions = true;\n // Stringified key for the rules that currently apply.\n ruleIds = (ruleIds.toString() || void 0);\n var currentRuleIds = (currentResponsive && currentResponsive.ruleIds);\n // Changes in what rules apply\n if (ruleIds !== currentRuleIds) {\n // Undo previous rules. Before we apply a new set of rules, we\n // need to roll back completely to base options (#6291).\n if (currentResponsive) {\n this.update(currentResponsive.undoOptions, redraw, true);\n }\n if (ruleIds) {\n // Get undo-options for matching rules\n undoOptions = this.currentOptions(mergedOptions);\n undoOptions.isResponsiveOptions = true;\n this.currentResponsive = {\n ruleIds: ruleIds,\n mergedOptions: mergedOptions,\n undoOptions: undoOptions\n };\n this.update(mergedOptions, redraw, true);\n }\n else {\n this.currentResponsive = void 0;\n }\n }\n };\n return Additions;\n }());\n })(Responsive || (Responsive = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * A callback function to gain complete control on when the responsive rule\n * applies.\n *\n * @callback Highcharts.ResponsiveCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * Chart context.\n *\n * @return {boolean}\n * Return `true` if it applies.\n */\n (''); // keeps doclets above in JS file\n /* *\n *\n * API Options\n *\n * */\n /**\n * Allows setting a set of rules to apply for different screen or chart\n * sizes. Each rule specifies additional chart options.\n *\n * @sample {highstock} stock/demo/responsive/\n * Stock chart\n * @sample highcharts/responsive/axis/\n * Axis\n * @sample highcharts/responsive/legend/\n * Legend\n * @sample highcharts/responsive/classname/\n * Class name\n *\n * @since 5.0.0\n * @apioption responsive\n */\n /**\n * A set of rules for responsive settings. The rules are executed from\n * the top down.\n *\n * @sample {highcharts} highcharts/responsive/axis/\n * Axis changes\n * @sample {highstock} highcharts/responsive/axis/\n * Axis changes\n * @sample {highmaps} highcharts/responsive/axis/\n * Axis changes\n *\n * @type {Array<*>}\n * @since 5.0.0\n * @apioption responsive.rules\n */\n /**\n * A full set of chart options to apply as overrides to the general\n * chart options. The chart options are applied when the given rule\n * is active.\n *\n * A special case is configuration objects that take arrays, for example\n * [xAxis](#xAxis), [yAxis](#yAxis) or [series](#series). For these\n * collections, an `id` option is used to map the new option set to\n * an existing object. If an existing object of the same id is not found,\n * the item of the same indexupdated. So for example, setting `chartOptions`\n * with two series items without an `id`, will cause the existing chart's\n * two series to be updated with respective options.\n *\n * @sample {highstock} stock/demo/responsive/\n * Stock chart\n * @sample highcharts/responsive/axis/\n * Axis\n * @sample highcharts/responsive/legend/\n * Legend\n * @sample highcharts/responsive/classname/\n * Class name\n *\n * @type {Highcharts.Options}\n * @since 5.0.0\n * @apioption responsive.rules.chartOptions\n */\n /**\n * Under which conditions the rule applies.\n *\n * @since 5.0.0\n * @apioption responsive.rules.condition\n */\n /**\n * A callback function to gain complete control on when the responsive\n * rule applies. Return `true` if it applies. This opens for checking\n * against other metrics than the chart size, for example the document\n * size or other elements.\n *\n * @type {Highcharts.ResponsiveCallbackFunction}\n * @since 5.0.0\n * @context Highcharts.Chart\n * @apioption responsive.rules.condition.callback\n */\n /**\n * The responsive rule applies if the chart height is less than this.\n *\n * @type {number}\n * @since 5.0.0\n * @apioption responsive.rules.condition.maxHeight\n */\n /**\n * The responsive rule applies if the chart width is less than this.\n *\n * @sample highcharts/responsive/axis/\n * Max width is 500\n *\n * @type {number}\n * @since 5.0.0\n * @apioption responsive.rules.condition.maxWidth\n */\n /**\n * The responsive rule applies if the chart height is greater than this.\n *\n * @type {number}\n * @default 0\n * @since 5.0.0\n * @apioption responsive.rules.condition.minHeight\n */\n /**\n * The responsive rule applies if the chart width is greater than this.\n *\n * @type {number}\n * @default 0\n * @since 5.0.0\n * @apioption responsive.rules.condition.minWidth\n */\n (''); // keeps doclets above in JS file\n\n return Responsive;\n });\n _registerModule(_modules, 'masters/highcharts.src.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js'], _modules['Core/Defaults.js'], _modules['Core/Animation/Fx.js'], _modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Renderer/HTML/AST.js'], _modules['Core/FormatUtilities.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Renderer/HTML/HTMLElement.js'], _modules['Core/Renderer/HTML/HTMLRenderer.js'], _modules['Core/Axis/Axis.js'], _modules['Core/Axis/DateTimeAxis.js'], _modules['Core/Axis/LogarithmicAxis.js'], _modules['Core/Axis/PlotLineOrBand/PlotLineOrBand.js'], _modules['Core/Axis/Tick.js'], _modules['Core/Tooltip.js'], _modules['Core/Series/Point.js'], _modules['Core/Pointer.js'], _modules['Core/MSPointer.js'], _modules['Core/Legend/Legend.js'], _modules['Core/Chart/Chart.js'], _modules['Core/Axis/Stacking/StackingAxis.js'], _modules['Core/Axis/Stacking/StackItem.js'], _modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Series/Column/ColumnSeries.js'], _modules['Series/Column/ColumnDataLabel.js'], _modules['Series/Pie/PieSeries.js'], _modules['Series/Pie/PieDataLabel.js'], _modules['Core/Series/DataLabel.js'], _modules['Core/Responsive.js'], _modules['Core/Color/Color.js'], _modules['Core/Time.js']], function (Highcharts, Utilities, Defaults, Fx, Animation, AST, FormatUtilities, RendererUtilities, SVGElement, SVGRenderer, HTMLElement, HTMLRenderer, Axis, DateTimeAxis, LogarithmicAxis, PlotLineOrBand, Tick, Tooltip, Point, Pointer, MSPointer, Legend, Chart, StackingAxis, StackItem, Series, SeriesRegistry, ColumnSeries, ColumnDataLabel, PieSeries, PieDataLabel, DataLabel, Responsive, Color, Time) {\n\n var G = Highcharts;\n // Animation\n G.animate = Animation.animate;\n G.animObject = Animation.animObject;\n G.getDeferredAnimation = Animation.getDeferredAnimation;\n G.setAnimation = Animation.setAnimation;\n G.stop = Animation.stop;\n G.timers = Fx.timers;\n // Classes\n G.AST = AST;\n G.Axis = Axis;\n G.Chart = Chart;\n G.chart = Chart.chart;\n G.Fx = Fx;\n G.Legend = Legend;\n G.PlotLineOrBand = PlotLineOrBand;\n G.Point = Point;\n G.Pointer = (MSPointer.isRequired() ? MSPointer : Pointer);\n G.Series = Series;\n G.StackItem = StackItem;\n G.SVGElement = SVGElement;\n G.SVGRenderer = SVGRenderer;\n G.Tick = Tick;\n G.Time = Time;\n G.Tooltip = Tooltip;\n // Color\n G.Color = Color;\n G.color = Color.parse;\n // Compositions\n HTMLRenderer.compose(SVGRenderer);\n HTMLElement.compose(SVGElement);\n // DefaultOptions\n G.defaultOptions = Defaults.defaultOptions;\n G.getOptions = Defaults.getOptions;\n G.time = Defaults.defaultTime;\n G.setOptions = Defaults.setOptions;\n // Format Utilities\n G.dateFormat = FormatUtilities.dateFormat;\n G.format = FormatUtilities.format;\n G.numberFormat = FormatUtilities.numberFormat;\n // Utilities\n G.addEvent = Utilities.addEvent;\n G.arrayMax = Utilities.arrayMax;\n G.arrayMin = Utilities.arrayMin;\n G.attr = Utilities.attr;\n G.clearTimeout = Utilities.clearTimeout;\n G.correctFloat = Utilities.correctFloat;\n G.createElement = Utilities.createElement;\n G.css = Utilities.css;\n G.defined = Utilities.defined;\n G.destroyObjectProperties = Utilities.destroyObjectProperties;\n G.discardElement = Utilities.discardElement;\n G.distribute = RendererUtilities.distribute;\n G.erase = Utilities.erase;\n G.error = Utilities.error;\n G.extend = Utilities.extend;\n G.extendClass = Utilities.extendClass;\n G.find = Utilities.find;\n G.fireEvent = Utilities.fireEvent;\n G.getMagnitude = Utilities.getMagnitude;\n G.getStyle = Utilities.getStyle;\n G.inArray = Utilities.inArray;\n G.isArray = Utilities.isArray;\n G.isClass = Utilities.isClass;\n G.isDOMElement = Utilities.isDOMElement;\n G.isFunction = Utilities.isFunction;\n G.isNumber = Utilities.isNumber;\n G.isObject = Utilities.isObject;\n G.isString = Utilities.isString;\n G.keys = Utilities.keys;\n G.merge = Utilities.merge;\n G.normalizeTickInterval = Utilities.normalizeTickInterval;\n G.objectEach = Utilities.objectEach;\n G.offset = Utilities.offset;\n G.pad = Utilities.pad;\n G.pick = Utilities.pick;\n G.pInt = Utilities.pInt;\n G.relativeLength = Utilities.relativeLength;\n G.removeEvent = Utilities.removeEvent;\n G.seriesType = SeriesRegistry.seriesType;\n G.splat = Utilities.splat;\n G.stableSort = Utilities.stableSort;\n G.syncTimeout = Utilities.syncTimeout;\n G.timeUnits = Utilities.timeUnits;\n G.uniqueKey = Utilities.uniqueKey;\n G.useSerialIds = Utilities.useSerialIds;\n G.wrap = Utilities.wrap;\n // Compositions\n ColumnDataLabel.compose(ColumnSeries);\n DataLabel.compose(Series);\n DateTimeAxis.compose(Axis);\n LogarithmicAxis.compose(Axis);\n PieDataLabel.compose(PieSeries);\n PlotLineOrBand.compose(Axis);\n Responsive.compose(Chart);\n StackingAxis.compose(Axis, Chart, Series);\n // Default Export\n\n return G;\n });\n _registerModule(_modules, 'Core/Axis/BrokenAxis.js', [_modules['Core/Axis/Stacking/StackItem.js'], _modules['Core/Utilities.js']], function (StackItem, U) {\n /* *\n *\n * (c) 2009-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var addEvent = U.addEvent,\n find = U.find,\n fireEvent = U.fireEvent,\n isArray = U.isArray,\n isNumber = U.isNumber,\n pick = U.pick;\n /* *\n *\n * Composition\n *\n * */\n /**\n * Axis with support of broken data rows.\n * @private\n */\n var BrokenAxis;\n (function (BrokenAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Adds support for broken axes.\n * @private\n */\n function compose(AxisClass, SeriesClass) {\n if (composedClasses.indexOf(AxisClass) === -1) {\n composedClasses.push(AxisClass);\n AxisClass.keepProps.push('brokenAxis');\n addEvent(AxisClass, 'init', onAxisInit);\n addEvent(AxisClass, 'afterInit', onAxisAfterInit);\n addEvent(AxisClass, 'afterSetTickPositions', onAxisAfterSetTickPositions);\n addEvent(AxisClass, 'afterSetOptions', onAxisAfterSetOptions);\n }\n if (composedClasses.indexOf(SeriesClass) === -1) {\n composedClasses.push(SeriesClass);\n var seriesProto = SeriesClass.prototype;\n seriesProto.drawBreaks = seriesDrawBreaks;\n seriesProto.gappedPath = seriesGappedPath;\n addEvent(SeriesClass, 'afterGeneratePoints', onSeriesAfterGeneratePoints);\n addEvent(SeriesClass, 'afterRender', onSeriesAfterRender);\n }\n return AxisClass;\n }\n BrokenAxis.compose = compose;\n /**\n * @private\n */\n function onAxisAfterInit() {\n if (typeof this.brokenAxis !== 'undefined') {\n this.brokenAxis.setBreaks(this.options.breaks, false);\n }\n }\n /**\n * Force Axis to be not-ordinal when breaks are defined.\n * @private\n */\n function onAxisAfterSetOptions() {\n var axis = this;\n if (axis.brokenAxis && axis.brokenAxis.hasBreaks) {\n axis.options.ordinal = false;\n }\n }\n /**\n * @private\n */\n function onAxisAfterSetTickPositions() {\n var axis = this,\n brokenAxis = axis.brokenAxis;\n if (brokenAxis &&\n brokenAxis.hasBreaks) {\n var tickPositions = axis.tickPositions,\n info = axis.tickPositions.info,\n newPositions = [];\n for (var i = 0; i < tickPositions.length; i++) {\n if (!brokenAxis.isInAnyBreak(tickPositions[i])) {\n newPositions.push(tickPositions[i]);\n }\n }\n axis.tickPositions = newPositions;\n axis.tickPositions.info = info;\n }\n }\n /**\n * @private\n */\n function onAxisInit() {\n var axis = this;\n if (!axis.brokenAxis) {\n axis.brokenAxis = new Additions(axis);\n }\n }\n /**\n * @private\n */\n function onSeriesAfterGeneratePoints() {\n var _a = this,\n isDirty = _a.isDirty,\n connectNulls = _a.options.connectNulls,\n points = _a.points,\n xAxis = _a.xAxis,\n yAxis = _a.yAxis;\n // Set, or reset visibility of the points. Axis.setBreaks marks\n // the series as isDirty\n if (isDirty) {\n var i = points.length;\n while (i--) {\n var point = points[i];\n // Respect nulls inside the break (#4275)\n var nullGap = point.y === null && connectNulls === false;\n var isPointInBreak = (!nullGap && ((xAxis &&\n xAxis.brokenAxis &&\n xAxis.brokenAxis.isInAnyBreak(point.x,\n true)) || (yAxis &&\n yAxis.brokenAxis &&\n yAxis.brokenAxis.isInAnyBreak(point.y,\n true))));\n // Set point.visible if in any break.\n // If not in break, reset visible to original value.\n point.visible = isPointInBreak ?\n false :\n point.options.visible !== false;\n }\n }\n }\n /**\n * @private\n */\n function onSeriesAfterRender() {\n this.drawBreaks(this.xAxis, ['x']);\n this.drawBreaks(this.yAxis, pick(this.pointArrayMap, ['y']));\n }\n /**\n * @private\n */\n function seriesDrawBreaks(axis, keys) {\n var series = this,\n points = series.points;\n var breaks,\n threshold,\n eventName,\n y;\n if (axis && // #5950\n axis.brokenAxis &&\n axis.brokenAxis.hasBreaks) {\n var brokenAxis_1 = axis.brokenAxis;\n keys.forEach(function (key) {\n breaks = brokenAxis_1 && brokenAxis_1.breakArray || [];\n threshold = axis.isXAxis ?\n axis.min :\n pick(series.options.threshold, axis.min);\n points.forEach(function (point) {\n y = pick(point['stack' + key.toUpperCase()], point[key]);\n breaks.forEach(function (brk) {\n if (isNumber(threshold) && isNumber(y)) {\n eventName = false;\n if ((threshold < brk.from && y > brk.to) ||\n (threshold > brk.from && y < brk.from)) {\n eventName = 'pointBreak';\n }\n else if ((threshold < brk.from &&\n y > brk.from &&\n y < brk.to) || (threshold > brk.from &&\n y > brk.to &&\n y < brk.from)) {\n eventName = 'pointInBreak';\n }\n if (eventName) {\n fireEvent(axis, eventName, { point: point, brk: brk });\n }\n }\n });\n });\n });\n }\n }\n /**\n * Extend getGraphPath by identifying gaps in the data so that we\n * can draw a gap in the line or area. This was moved from ordinal\n * axis module to broken axis module as of #5045.\n *\n * @private\n * @function Highcharts.Series#gappedPath\n *\n * @return {Highcharts.SVGPathArray}\n * Gapped path\n */\n function seriesGappedPath() {\n var currentDataGrouping = this.currentDataGrouping,\n groupingSize = currentDataGrouping && currentDataGrouping.gapSize,\n points = this.points.slice(),\n yAxis = this.yAxis;\n var gapSize = this.options.gapSize,\n i = points.length - 1,\n stack;\n /**\n * Defines when to display a gap in the graph, together with the\n * [gapUnit](plotOptions.series.gapUnit) option.\n *\n * In case when `dataGrouping` is enabled, points can be grouped\n * into a larger time span. This can make the grouped points to\n * have a greater distance than the absolute value of `gapSize`\n * property, which will result in disappearing graph completely.\n * To prevent this situation the mentioned distance between\n * grouped points is used instead of previously defined\n * `gapSize`.\n *\n * In practice, this option is most often used to visualize gaps\n * in time series. In a stock chart, intraday data is available\n * for daytime hours, while gaps will appear in nights and\n * weekends.\n *\n * @see [gapUnit](plotOptions.series.gapUnit)\n * @see [xAxis.breaks](#xAxis.breaks)\n *\n * @sample {highstock} stock/plotoptions/series-gapsize/\n * Setting the gap size to 2 introduces gaps for weekends in\n * daily datasets.\n *\n * @type {number}\n * @default 0\n * @product highstock\n * @requires modules/broken-axis\n * @apioption plotOptions.series.gapSize\n */\n /**\n * Together with [gapSize](plotOptions.series.gapSize), this\n * option defines where to draw gaps in the graph.\n *\n * When the `gapUnit` is `\"relative\"` (default), a gap size of 5\n * means that if the distance between two points is greater than\n * 5 times that of the two closest points, the graph will be\n * broken.\n *\n * When the `gapUnit` is `\"value\"`, the gap is based on absolute\n * axis values, which on a datetime axis is milliseconds. This\n * also applies to the navigator series that inherits gap\n * options from the base series.\n *\n * @see [gapSize](plotOptions.series.gapSize)\n *\n * @type {string}\n * @default relative\n * @since 5.0.13\n * @product highstock\n * @validvalue [\"relative\", \"value\"]\n * @requires modules/broken-axis\n * @apioption plotOptions.series.gapUnit\n */\n if (gapSize && i > 0) { // #5008\n // Gap unit is relative\n if (this.options.gapUnit !== 'value') {\n gapSize *= this.basePointRange;\n }\n // Setting a new gapSize in case dataGrouping is enabled\n // (#7686)\n if (groupingSize &&\n groupingSize > gapSize &&\n // Except when DG is forced (e.g. from other series)\n // and has lower granularity than actual points (#11351)\n groupingSize >= this.basePointRange) {\n gapSize = groupingSize;\n }\n // extension for ordinal breaks\n var current = void 0,\n next = void 0;\n while (i--) {\n // Reassign next if it is not visible\n if (!(next && next.visible !== false)) {\n next = points[i + 1];\n }\n current = points[i];\n // Skip iteration if one of the points is not visible\n if (next.visible === false || current.visible === false) {\n continue;\n }\n if (next.x - current.x > gapSize) {\n var xRange = (current.x + next.x) / 2;\n points.splice(// insert after this one\n i + 1, 0, {\n isNull: true,\n x: xRange\n });\n // For stacked chart generate empty stack items, #6546\n if (yAxis.stacking && this.options.stacking) {\n stack = yAxis.stacking.stacks[this.stackKey][xRange] = new StackItem(yAxis, yAxis.options.stackLabels, false, xRange, this.stack);\n stack.total = 0;\n }\n }\n // Assign current to next for the upcoming iteration\n next = current;\n }\n }\n // Call base method\n return this.getGraphPath(points);\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * Provides support for broken axes.\n * @private\n * @class\n */\n var Additions = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Additions(axis) {\n this.hasBreaks = false;\n this.axis = axis;\n }\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * @private\n */\n Additions.isInBreak = function (brk, val) {\n var repeat = brk.repeat || Infinity,\n from = brk.from,\n length = brk.to - brk.from,\n test = (val >= from ?\n (val - from) % repeat :\n repeat - ((from - val) % repeat));\n var ret;\n if (!brk.inclusive) {\n ret = test < length && test !== 0;\n }\n else {\n ret = test <= length;\n }\n return ret;\n };\n /**\n * @private\n */\n Additions.lin2Val = function (val) {\n var axis = this;\n var brokenAxis = axis.brokenAxis;\n var breakArray = brokenAxis && brokenAxis.breakArray;\n if (!breakArray || !isNumber(val)) {\n return val;\n }\n var nval = val,\n brk,\n i;\n for (i = 0; i < breakArray.length; i++) {\n brk = breakArray[i];\n if (brk.from >= nval) {\n break;\n }\n else if (brk.to < nval) {\n nval += brk.len;\n }\n else if (Additions.isInBreak(brk, nval)) {\n nval += brk.len;\n }\n }\n return nval;\n };\n /**\n * @private\n */\n Additions.val2Lin = function (val) {\n var axis = this;\n var brokenAxis = axis.brokenAxis;\n var breakArray = brokenAxis && brokenAxis.breakArray;\n if (!breakArray || !isNumber(val)) {\n return val;\n }\n var nval = val,\n brk,\n i;\n for (i = 0; i < breakArray.length; i++) {\n brk = breakArray[i];\n if (brk.to <= val) {\n nval -= brk.len;\n }\n else if (brk.from >= val) {\n break;\n }\n else if (Additions.isInBreak(brk, val)) {\n nval -= (val - brk.from);\n break;\n }\n }\n return nval;\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Returns the first break found where the x is larger then break.from\n * and smaller then break.to.\n *\n * @param {number} x\n * The number which should be within a break.\n *\n * @param {Array} breaks\n * The array of breaks to search within.\n *\n * @return {Highcharts.XAxisBreaksOptions|undefined}\n * Returns the first break found that matches, returns false if no break\n * is found.\n */\n Additions.prototype.findBreakAt = function (x, breaks) {\n return find(breaks, function (b) {\n return b.from < x && x < b.to;\n });\n };\n /**\n * @private\n */\n Additions.prototype.isInAnyBreak = function (val, testKeep) {\n var brokenAxis = this,\n axis = brokenAxis.axis,\n breaks = axis.options.breaks || [];\n var i = breaks.length,\n inbrk,\n keep,\n ret;\n if (i && isNumber(val)) {\n while (i--) {\n if (Additions.isInBreak(breaks[i], val)) {\n inbrk = true;\n if (!keep) {\n keep = pick(breaks[i].showPoints, !axis.isXAxis);\n }\n }\n }\n if (inbrk && testKeep) {\n ret = inbrk && !keep;\n }\n else {\n ret = inbrk;\n }\n }\n return ret;\n };\n /**\n * Dynamically set or unset breaks in an axis. This function in lighter\n * than usin Axis.update, and it also preserves animation.\n *\n * @private\n * @function Highcharts.Axis#setBreaks\n *\n * @param {Array} [breaks]\n * The breaks to add. When `undefined` it removes existing breaks.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart immediately.\n */\n Additions.prototype.setBreaks = function (breaks, redraw) {\n var brokenAxis = this;\n var axis = brokenAxis.axis;\n var hasBreaks = (isArray(breaks) && !!breaks.length);\n axis.isDirty = brokenAxis.hasBreaks !== hasBreaks;\n brokenAxis.hasBreaks = hasBreaks;\n axis.options.breaks = axis.userOptions.breaks = breaks;\n axis.forceRedraw = true; // Force recalculation in setScale\n // Recalculate series related to the axis.\n axis.series.forEach(function (series) {\n series.isDirty = true;\n });\n if (!hasBreaks && axis.val2lin === Additions.val2Lin) {\n // Revert to prototype functions\n delete axis.val2lin;\n delete axis.lin2val;\n }\n if (hasBreaks) {\n axis.userOptions.ordinal = false;\n axis.lin2val = Additions.lin2Val;\n axis.val2lin = Additions.val2Lin;\n axis.setExtremes = function (newMin, newMax, redraw, animation, eventArguments) {\n // If trying to set extremes inside a break, extend min to\n // after, and max to before the break ( #3857 )\n if (brokenAxis.hasBreaks) {\n var breaks_1 = (this.options.breaks || []);\n var axisBreak = void 0;\n while ((axisBreak = brokenAxis.findBreakAt(newMin, breaks_1))) {\n newMin = axisBreak.to;\n }\n while ((axisBreak = brokenAxis.findBreakAt(newMax, breaks_1))) {\n newMax = axisBreak.from;\n }\n // If both min and max is within the same break.\n if (newMax < newMin) {\n newMax = newMin;\n }\n }\n axis.constructor.prototype.setExtremes.call(this, newMin, newMax, redraw, animation, eventArguments);\n };\n axis.setAxisTranslation = function () {\n axis.constructor.prototype.setAxisTranslation.call(this);\n brokenAxis.unitLength = void 0;\n if (brokenAxis.hasBreaks) {\n var breaks_2 = axis.options.breaks || [], \n // Temporary one:\n breakArrayT_1 = [],\n breakArray_1 = [],\n pointRangePadding = pick(axis.pointRangePadding, 0);\n var length_1 = 0,\n inBrk_1,\n repeat_1,\n min_1 = axis.userMin || axis.min,\n max_1 = axis.userMax || axis.max,\n start_1,\n i_1;\n // Min & max check (#4247)\n breaks_2.forEach(function (brk) {\n repeat_1 = brk.repeat || Infinity;\n if (isNumber(min_1) && isNumber(max_1)) {\n if (Additions.isInBreak(brk, min_1)) {\n min_1 += ((brk.to % repeat_1) -\n (min_1 % repeat_1));\n }\n if (Additions.isInBreak(brk, max_1)) {\n max_1 -= ((max_1 % repeat_1) -\n (brk.from % repeat_1));\n }\n }\n });\n // Construct an array holding all breaks in the axis\n breaks_2.forEach(function (brk) {\n start_1 = brk.from;\n repeat_1 = brk.repeat || Infinity;\n if (isNumber(min_1) && isNumber(max_1)) {\n while (start_1 - repeat_1 > min_1) {\n start_1 -= repeat_1;\n }\n while (start_1 < min_1) {\n start_1 += repeat_1;\n }\n for (i_1 = start_1; i_1 < max_1; i_1 += repeat_1) {\n breakArrayT_1.push({\n value: i_1,\n move: 'in'\n });\n breakArrayT_1.push({\n value: i_1 + brk.to - brk.from,\n move: 'out',\n size: brk.breakSize\n });\n }\n }\n });\n breakArrayT_1.sort(function (a, b) {\n return ((a.value === b.value) ?\n ((a.move === 'in' ? 0 : 1) -\n (b.move === 'in' ? 0 : 1)) :\n a.value - b.value);\n });\n // Simplify the breaks\n inBrk_1 = 0;\n start_1 = min_1;\n breakArrayT_1.forEach(function (brk) {\n inBrk_1 += (brk.move === 'in' ? 1 : -1);\n if (inBrk_1 === 1 && brk.move === 'in') {\n start_1 = brk.value;\n }\n if (inBrk_1 === 0 && isNumber(start_1)) {\n breakArray_1.push({\n from: start_1,\n to: brk.value,\n len: brk.value - start_1 - (brk.size || 0)\n });\n length_1 += (brk.value -\n start_1 -\n (brk.size || 0));\n }\n });\n brokenAxis.breakArray = breakArray_1;\n // Used with staticScale, and below the actual axis\n // length, when breaks are substracted.\n if (isNumber(min_1) &&\n isNumber(max_1) &&\n isNumber(axis.min)) {\n brokenAxis.unitLength = max_1 - min_1 - length_1 +\n pointRangePadding;\n fireEvent(axis, 'afterBreaks');\n if (axis.staticScale) {\n axis.transA = axis.staticScale;\n }\n else if (brokenAxis.unitLength) {\n axis.transA *=\n (max_1 - axis.min + pointRangePadding) /\n brokenAxis.unitLength;\n }\n if (pointRangePadding) {\n axis.minPixelPadding =\n axis.transA * (axis.minPointOffset || 0);\n }\n axis.min = min_1;\n axis.max = max_1;\n }\n }\n };\n }\n if (pick(redraw, true)) {\n axis.chart.redraw();\n }\n };\n return Additions;\n }());\n BrokenAxis.Additions = Additions;\n })(BrokenAxis || (BrokenAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return BrokenAxis;\n });\n _registerModule(_modules, 'masters/modules/broken-axis.src.js', [_modules['Core/Globals.js'], _modules['Core/Axis/BrokenAxis.js']], function (Highcharts, BrokenAxis) {\n\n var G = Highcharts;\n // Compositions\n BrokenAxis.compose(G.Axis, G.Series);\n\n });\n _registerModule(_modules, 'Extensions/DataGrouping/ApproximationRegistry.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n /**\n * Define the available approximation types. The data grouping\n * approximations takes an array or numbers as the first parameter. In case\n * of ohlc, four arrays are sent in as four parameters. Each array consists\n * only of numbers. In case null values belong to the group, the property\n * .hasNulls will be set to true on the array.\n *\n * @product highstock\n *\n * @private\n */\n var ApproximationRegistry = {\n // approximations added programmatically\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return ApproximationRegistry;\n });\n _registerModule(_modules, 'Extensions/DataGrouping/ApproximationDefaults.js', [_modules['Extensions/DataGrouping/ApproximationRegistry.js'], _modules['Core/Utilities.js']], function (ApproximationRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var arrayMax = U.arrayMax,\n arrayMin = U.arrayMin,\n correctFloat = U.correctFloat,\n extend = U.extend,\n isNumber = U.isNumber;\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function average(arr) {\n var len = arr.length;\n var ret = sum(arr);\n // If we have a number, return it divided by the length. If not,\n // return null or undefined based on what the sum method finds.\n if (isNumber(ret) && len) {\n ret = correctFloat(ret / len);\n }\n return ret;\n }\n /**\n * The same as average, but for series with multiple values, like area ranges.\n * @private\n */\n function averages() {\n var ret = [];\n [].forEach.call(arguments, function (arr) {\n ret.push(average(arr));\n });\n // Return undefined when first elem. is undefined and let\n // sum method handle null (#7377)\n return typeof ret[0] === 'undefined' ? void 0 : ret;\n }\n /**\n * @private\n */\n function close(arr) {\n return arr.length ?\n arr[arr.length - 1] :\n (arr.hasNulls ? null : void 0);\n }\n /**\n * @private\n */\n function high(arr) {\n return arr.length ?\n arrayMax(arr) :\n (arr.hasNulls ? null : void 0);\n }\n /**\n * HLC, OHLC and range are special cases where a multidimensional array is input\n * and an array is output.\n * @private\n */\n function hlc(high, low, close) {\n high = ApproximationRegistry.high(high);\n low = ApproximationRegistry.low(low);\n close = ApproximationRegistry.close(close);\n if (isNumber(high) ||\n isNumber(low) ||\n isNumber(close)) {\n return [high, low, close];\n }\n }\n /**\n * @private\n */\n function low(arr) {\n return arr.length ?\n arrayMin(arr) :\n (arr.hasNulls ? null : void 0);\n }\n /**\n * @private\n */\n function ohlc(open, high, low, close) {\n open = ApproximationRegistry.open(open);\n high = ApproximationRegistry.high(high);\n low = ApproximationRegistry.low(low);\n close = ApproximationRegistry.close(close);\n if (isNumber(open) ||\n isNumber(high) ||\n isNumber(low) ||\n isNumber(close)) {\n return [open, high, low, close];\n }\n }\n /**\n * @private\n */\n function open(arr) {\n return arr.length ? arr[0] : (arr.hasNulls ? null : void 0);\n }\n /**\n * @private\n */\n function range(low, high) {\n low = ApproximationRegistry.low(low);\n high = ApproximationRegistry.high(high);\n if (isNumber(low) || isNumber(high)) {\n return [low, high];\n }\n if (low === null && high === null) {\n return null;\n }\n // else, return is undefined\n }\n /**\n * @private\n */\n function sum(arr) {\n var len = arr.length,\n ret;\n // 1. it consists of nulls exclusive\n if (!len && arr.hasNulls) {\n ret = null;\n // 2. it has a length and real values\n }\n else if (len) {\n ret = 0;\n while (len--) {\n ret += arr[len];\n }\n }\n // 3. it has zero length, so just return undefined\n // => doNothing()\n return ret;\n }\n /* *\n *\n * Default Export\n *\n * */\n var ApproximationDefaults = {\n average: average,\n averages: averages,\n close: close,\n high: high,\n hlc: hlc,\n low: low,\n ohlc: ohlc,\n open: open,\n range: range,\n sum: sum\n };\n extend(ApproximationRegistry, ApproximationDefaults);\n\n return ApproximationDefaults;\n });\n _registerModule(_modules, 'Extensions/DataGrouping/DataGroupingDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n /**\n * Common options\n * @private\n */\n var common = {\n // enabled: null, // (true for stock charts, false for basic),\n // forced: undefined,\n groupPixelWidth: 2,\n // the first one is the point or start value, the second is the start\n // value if we're dealing with range, the third one is the end value if\n // dealing with a range\n dateTimeLabelFormats: {\n millisecond: [\n '%A, %b %e, %H:%M:%S.%L',\n '%A, %b %e, %H:%M:%S.%L',\n '-%H:%M:%S.%L'\n ],\n second: [\n '%A, %b %e, %H:%M:%S',\n '%A, %b %e, %H:%M:%S',\n '-%H:%M:%S'\n ],\n minute: [\n '%A, %b %e, %H:%M',\n '%A, %b %e, %H:%M',\n '-%H:%M'\n ],\n hour: [\n '%A, %b %e, %H:%M',\n '%A, %b %e, %H:%M',\n '-%H:%M'\n ],\n day: [\n '%A, %b %e, %Y',\n '%A, %b %e',\n '-%A, %b %e, %Y'\n ],\n week: [\n 'Week from %A, %b %e, %Y',\n '%A, %b %e',\n '-%A, %b %e, %Y'\n ],\n month: [\n '%B %Y',\n '%B',\n '-%B %Y'\n ],\n year: [\n '%Y',\n '%Y',\n '-%Y'\n ]\n }\n // smoothed = false, // enable this for navigator series only\n };\n /**\n * Extends common options\n * @private\n */\n var seriesSpecific = {\n line: {},\n spline: {},\n area: {},\n areaspline: {},\n arearange: {},\n column: {\n groupPixelWidth: 10\n },\n columnrange: {\n groupPixelWidth: 10\n },\n candlestick: {\n groupPixelWidth: 10\n },\n ohlc: {\n groupPixelWidth: 5\n },\n hlc: {\n groupPixelWidth: 5\n // Move to HeikinAshiSeries.ts aftre refactoring data grouping.\n },\n heikinashi: {\n groupPixelWidth: 10\n }\n };\n /**\n * Units are defined in a separate array to allow complete overriding in\n * case of a user option.\n * @private\n */\n var units = [\n [\n 'millisecond',\n [1, 2, 5, 10, 20, 25, 50, 100, 200, 500] // allowed multiples\n ],\n [\n 'second',\n [1, 2, 5, 10, 15, 30]\n ],\n [\n 'minute',\n [1, 2, 5, 10, 15, 30]\n ],\n [\n 'hour',\n [1, 2, 3, 4, 6, 8, 12]\n ],\n [\n 'day',\n [1]\n ],\n [\n 'week',\n [1]\n ],\n [\n 'month',\n [1, 3, 6]\n ],\n [\n 'year',\n null\n ]\n ];\n /* *\n *\n * Default Export\n *\n * */\n var DataGroupingDefaults = {\n common: common,\n seriesSpecific: seriesSpecific,\n units: units\n };\n\n return DataGroupingDefaults;\n });\n _registerModule(_modules, 'Extensions/DataGrouping/DataGroupingAxisComposition.js', [_modules['Extensions/DataGrouping/DataGroupingDefaults.js'], _modules['Core/Utilities.js']], function (DataGroupingDefaults, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var addEvent = U.addEvent,\n extend = U.extend,\n merge = U.merge,\n pick = U.pick;\n /* *\n *\n * Constants\n *\n * */\n var composedMembers = [];\n /* *\n *\n * Variables\n *\n * */\n var AxisConstructor;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Check the groupPixelWidth and apply the grouping if needed.\n * Fired only after processing the data.\n *\n * @product highstock\n *\n * @function Highcharts.Axis#applyGrouping\n */\n function applyGrouping(e) {\n var axis = this,\n series = axis.series;\n // Reset the groupPixelWidth for all series, #17141.\n series.forEach(function (series) {\n series.groupPixelWidth = void 0; // #2110\n });\n series.forEach(function (series) {\n series.groupPixelWidth = (axis.getGroupPixelWidth &&\n axis.getGroupPixelWidth());\n if (series.groupPixelWidth) {\n series.hasProcessed = true; // #2692\n }\n // Fire independing on series.groupPixelWidth to always set a proper\n // dataGrouping state, (#16238)\n series.applyGrouping(!!e.hasExtremesChanged);\n });\n }\n /**\n * @private\n */\n function compose(AxisClass) {\n AxisConstructor = AxisClass;\n if (composedMembers.indexOf(AxisClass) === -1) {\n composedMembers.push(AxisClass);\n addEvent(AxisClass, 'afterSetScale', onAfterSetScale);\n // When all series are processed, calculate the group pixel width and\n // then if this value is different than zero apply groupings.\n addEvent(AxisClass, 'postProcessData', applyGrouping);\n extend(AxisClass.prototype, {\n applyGrouping: applyGrouping,\n getGroupPixelWidth: getGroupPixelWidth,\n setDataGrouping: setDataGrouping\n });\n }\n }\n /**\n * Get the data grouping pixel width based on the greatest defined individual\n * width of the axis' series, and if whether one of the axes need grouping.\n * @private\n */\n function getGroupPixelWidth() {\n var series = this.series;\n var i = series.length,\n groupPixelWidth = 0,\n doGrouping = false,\n dataLength,\n dgOptions;\n // If one of the series needs grouping, apply it to all (#1634)\n while (i--) {\n dgOptions = series[i].options.dataGrouping;\n if (dgOptions) { // #2692\n // If multiple series are compared on the same x axis, give them the\n // same group pixel width (#334)\n groupPixelWidth = Math.max(groupPixelWidth, \n // Fallback to commonOptions (#9693)\n pick(dgOptions.groupPixelWidth, DataGroupingDefaults.common.groupPixelWidth));\n dataLength = (series[i].processedXData || series[i].data).length;\n // Execute grouping if the amount of points is greater than the\n // limit defined in groupPixelWidth\n if (series[i].groupPixelWidth ||\n (dataLength >\n (this.chart.plotSizeX / groupPixelWidth)) ||\n (dataLength && dgOptions.forced)) {\n doGrouping = true;\n }\n }\n }\n return doGrouping ? groupPixelWidth : 0;\n }\n /**\n * When resetting the scale reset the hasProccessed flag to avoid taking\n * previous data grouping of neighbour series into accound when determining\n * group pixel width (#2692).\n * @private\n */\n function onAfterSetScale() {\n this.series.forEach(function (series) {\n series.hasProcessed = false;\n });\n }\n /**\n * Highcharts Stock only. Force data grouping on all the axis' series.\n *\n * @product highstock\n *\n * @function Highcharts.Axis#setDataGrouping\n *\n * @param {boolean|Highcharts.DataGroupingOptionsObject} [dataGrouping]\n * A `dataGrouping` configuration. Use `false` to disable data grouping\n * dynamically.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or wait for a later call to\n * {@link Chart#redraw}.\n */\n function setDataGrouping(dataGrouping, redraw) {\n var axis = this;\n var i;\n redraw = pick(redraw, true);\n if (!dataGrouping) {\n dataGrouping = {\n forced: false,\n units: null\n };\n }\n // Axis is instantiated, update all series\n if (this instanceof AxisConstructor) {\n i = this.series.length;\n while (i--) {\n this.series[i].update({\n dataGrouping: dataGrouping\n }, false);\n }\n // Axis not yet instanciated, alter series options\n }\n else {\n this.chart.options.series.forEach(function (seriesOptions) {\n // Merging dataGrouping options with already defined options #16759\n seriesOptions.dataGrouping = typeof dataGrouping === 'boolean' ?\n dataGrouping :\n merge(dataGrouping, seriesOptions.dataGrouping);\n });\n }\n // Clear ordinal slope, so we won't accidentaly use the old one (#7827)\n if (axis.ordinal) {\n axis.ordinal.slope = void 0;\n }\n if (redraw) {\n this.chart.redraw();\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n var DataGroupingAxisComposition = {\n compose: compose\n };\n\n return DataGroupingAxisComposition;\n });\n _registerModule(_modules, 'Extensions/DataGrouping/DataGroupingSeriesComposition.js', [_modules['Extensions/DataGrouping/ApproximationRegistry.js'], _modules['Extensions/DataGrouping/DataGroupingDefaults.js'], _modules['Core/Axis/DateTimeAxis.js'], _modules['Core/Defaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (ApproximationRegistry, DataGroupingDefaults, DateTimeAxis, D, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var seriesProto = SeriesRegistry.series.prototype;\n var addEvent = U.addEvent,\n defined = U.defined,\n error = U.error,\n extend = U.extend,\n isNumber = U.isNumber,\n merge = U.merge,\n pick = U.pick;\n /* *\n *\n * Constants\n *\n * */\n var baseGeneratePoints = seriesProto.generatePoints;\n var composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function adjustExtremes(xAxis, groupedXData) {\n // Make sure the X axis extends to show the first group (#2533)\n // But only for visible series (#5493, #6393)\n if (defined(groupedXData[0]) &&\n isNumber(xAxis.min) &&\n isNumber(xAxis.dataMin) &&\n groupedXData[0] < xAxis.min) {\n if ((!defined(xAxis.options.min) &&\n xAxis.min <= xAxis.dataMin) ||\n xAxis.min === xAxis.dataMin) {\n xAxis.min = Math.min(groupedXData[0], xAxis.min);\n }\n xAxis.dataMin = Math.min(groupedXData[0], xAxis.dataMin);\n }\n // When the last anchor set, change the extremes that\n // the last point is visible (#12455).\n if (defined(groupedXData[groupedXData.length - 1]) &&\n isNumber(xAxis.max) &&\n isNumber(xAxis.dataMax) &&\n groupedXData[groupedXData.length - 1] > xAxis.max) {\n if ((!defined(xAxis.options.max) &&\n isNumber(xAxis.dataMax) &&\n xAxis.max >= xAxis.dataMax) || xAxis.max === xAxis.dataMax) {\n xAxis.max = Math.max(groupedXData[groupedXData.length - 1], xAxis.max);\n }\n xAxis.dataMax = Math.max(groupedXData[groupedXData.length - 1], xAxis.dataMax);\n }\n }\n /**\n * @private\n */\n function anchorPoints(series, groupedXData, xMax) {\n var options = series.options,\n dataGroupingOptions = options.dataGrouping,\n totalRange = (series.currentDataGrouping && series.currentDataGrouping.gapSize);\n var i;\n // DataGrouping x-coordinates.\n if (dataGroupingOptions && series.xData && totalRange && series.groupMap) {\n var groupedDataLength = groupedXData.length - 1,\n anchor = dataGroupingOptions.anchor,\n firstAnchor = pick(dataGroupingOptions.firstAnchor,\n anchor),\n lastAnchor = pick(dataGroupingOptions.lastAnchor,\n anchor);\n // Anchor points that are not extremes.\n if (anchor && anchor !== 'start') {\n var shiftInterval = (totalRange *\n { middle: 0.5,\n end: 1 }[anchor]);\n i = groupedXData.length - 1;\n while (i-- && i > 0) {\n groupedXData[i] += shiftInterval;\n }\n }\n // Change the first point position, but only when it is\n // the first point in the data set not in the current zoom.\n if (firstAnchor &&\n firstAnchor !== 'start' &&\n series.xData[0] >= groupedXData[0]) {\n var groupStart = series.groupMap[0].start,\n groupLength = series.groupMap[0].length;\n var firstGroupstEnd = void 0;\n if (isNumber(groupStart) && isNumber(groupLength)) {\n firstGroupstEnd = groupStart + (groupLength - 1);\n }\n groupedXData[0] = {\n middle: groupedXData[0] + 0.5 * totalRange,\n end: groupedXData[0] + totalRange,\n firstPoint: series.xData[0],\n lastPoint: firstGroupstEnd && series.xData[firstGroupstEnd]\n }[firstAnchor];\n }\n // Change the last point position but only when it is\n // the last point in the data set not in the current zoom.\n if (lastAnchor &&\n lastAnchor !== 'start' &&\n totalRange &&\n groupedXData[groupedDataLength] >= xMax - totalRange) {\n var lastGroupStart = series.groupMap[series.groupMap.length - 1].start;\n groupedXData[groupedDataLength] = {\n middle: groupedXData[groupedDataLength] + 0.5 * totalRange,\n end: groupedXData[groupedDataLength] + totalRange,\n firstPoint: lastGroupStart && series.xData[lastGroupStart],\n lastPoint: series.xData[series.xData.length - 1]\n }[lastAnchor];\n }\n }\n }\n /**\n * For the processed data, calculate the grouped data if needed.\n *\n * @private\n * @function Highcharts.Series#applyGrouping\n */\n function applyGrouping(hasExtremesChanged) {\n var series = this,\n chart = series.chart,\n options = series.options,\n dataGroupingOptions = options.dataGrouping,\n groupingEnabled = series.allowDG !== false && dataGroupingOptions &&\n pick(dataGroupingOptions.enabled,\n chart.options.isStock),\n visible = (series.visible || !chart.options.chart.ignoreHiddenSeries),\n lastDataGrouping = this.currentDataGrouping;\n var currentDataGrouping,\n croppedData,\n revertRequireSorting = false;\n // Data needs to be sorted for dataGrouping\n if (groupingEnabled && !series.requireSorting) {\n series.requireSorting = revertRequireSorting = true;\n }\n // Skip if skipDataGrouping method returns false or if grouping is disabled\n // (in that order).\n var skip = skipDataGrouping(series,\n hasExtremesChanged) === false || !groupingEnabled;\n // Revert original requireSorting value if changed\n if (revertRequireSorting) {\n series.requireSorting = false;\n }\n if (!skip) {\n series.destroyGroupedData();\n var processedXData = dataGroupingOptions.groupAll ?\n series.xData :\n series.processedXData,\n processedYData = dataGroupingOptions.groupAll ?\n series.yData :\n series.processedYData,\n plotSizeX = chart.plotSizeX,\n xAxis = series.xAxis,\n ordinal = xAxis.options.ordinal,\n groupPixelWidth = series.groupPixelWidth;\n var i = void 0,\n hasGroupedData = void 0;\n // Execute grouping if the amount of points is greater than the limit\n // defined in groupPixelWidth\n if (groupPixelWidth &&\n processedXData &&\n processedXData.length) {\n hasGroupedData = true;\n // Force recreation of point instances in series.translate, #5699\n series.isDirty = true;\n series.points = null; // #6709\n var extremes = xAxis.getExtremes(),\n xMin = extremes.min,\n xMax = extremes.max,\n groupIntervalFactor = (ordinal &&\n xAxis.ordinal &&\n xAxis.ordinal.getGroupIntervalFactor(xMin,\n xMax,\n series)) || 1,\n interval = (groupPixelWidth * (xMax - xMin) / plotSizeX) *\n groupIntervalFactor,\n groupPositions = xAxis.getTimeTicks(DateTimeAxis.Additions.prototype.normalizeTimeTickInterval(interval,\n dataGroupingOptions.units ||\n DataGroupingDefaults.units), \n // Processed data may extend beyond axis (#4907)\n Math.min(xMin,\n processedXData[0]),\n Math.max(xMax,\n processedXData[processedXData.length - 1]),\n xAxis.options.startOfWeek,\n processedXData,\n series.closestPointRange),\n groupedData = seriesProto.groupData.apply(series,\n [\n processedXData,\n processedYData,\n groupPositions,\n dataGroupingOptions.approximation\n ]);\n var groupedXData = groupedData.groupedXData,\n groupedYData = groupedData.groupedYData,\n gapSize = 0;\n // The smoothed option is deprecated, instead, there is a fallback\n // to the new anchoring mechanism. #12455.\n if (dataGroupingOptions &&\n dataGroupingOptions.smoothed &&\n groupedXData.length) {\n dataGroupingOptions.firstAnchor = 'firstPoint';\n dataGroupingOptions.anchor = 'middle';\n dataGroupingOptions.lastAnchor = 'lastPoint';\n error(32, false, chart, {\n 'dataGrouping.smoothed': 'use dataGrouping.anchor'\n });\n }\n anchorPoints(series, groupedXData, xMax);\n // Record what data grouping values were used\n for (i = 1; i < groupPositions.length; i++) {\n // The grouped gapSize needs to be the largest distance between\n // the group to capture varying group sizes like months or DST\n // crossing (#10000). Also check that the gap is not at the\n // start of a segment.\n if (!groupPositions.info.segmentStarts ||\n groupPositions.info.segmentStarts.indexOf(i) === -1) {\n gapSize = Math.max(groupPositions[i] - groupPositions[i - 1], gapSize);\n }\n }\n currentDataGrouping = groupPositions.info;\n currentDataGrouping.gapSize = gapSize;\n series.closestPointRange = groupPositions.info.totalRange;\n series.groupMap = groupedData.groupMap;\n if (visible) {\n adjustExtremes(xAxis, groupedXData);\n }\n // We calculated all group positions but we should render\n // only the ones within the visible range\n if (dataGroupingOptions.groupAll) {\n // Keep the reference to all grouped points\n // for further calculation (eg. heikinashi).\n series.allGroupedData = groupedYData;\n croppedData = series.cropData(groupedXData, groupedYData, xAxis.min, xAxis.max, 1 // Ordinal xAxis will remove left-most points otherwise\n );\n groupedXData = croppedData.xData;\n groupedYData = croppedData.yData;\n series.cropStart = croppedData.start; // #15005\n }\n // Set series props\n series.processedXData = groupedXData;\n series.processedYData = groupedYData;\n }\n else {\n series.groupMap = null;\n }\n series.hasGroupedData = hasGroupedData;\n series.currentDataGrouping = currentDataGrouping;\n series.preventGraphAnimation =\n (lastDataGrouping && lastDataGrouping.totalRange) !==\n (currentDataGrouping && currentDataGrouping.totalRange);\n }\n }\n /**\n * @private\n */\n function compose(SeriesClass) {\n var PointClass = SeriesClass.prototype.pointClass;\n if (composedMembers.indexOf(PointClass) === -1) {\n composedMembers.push(PointClass);\n // Override point prototype to throw a warning when trying to update\n // grouped points.\n addEvent(PointClass, 'update', function () {\n if (this.dataGroup) {\n error(24, false, this.series.chart);\n return false;\n }\n });\n }\n if (composedMembers.indexOf(SeriesClass) === -1) {\n composedMembers.push(SeriesClass);\n addEvent(SeriesClass, 'afterSetOptions', onAfterSetOptions);\n addEvent(SeriesClass, 'destroy', destroyGroupedData);\n extend(SeriesClass.prototype, {\n applyGrouping: applyGrouping,\n destroyGroupedData: destroyGroupedData,\n generatePoints: generatePoints,\n getDGApproximation: getDGApproximation,\n groupData: groupData\n });\n }\n }\n /**\n * Destroy the grouped data points. #622, #740\n * @private\n */\n function destroyGroupedData() {\n // Clear previous groups\n if (this.groupedData) {\n this.groupedData.forEach(function (point, i) {\n if (point) {\n this.groupedData[i] = point.destroy ?\n point.destroy() : null;\n }\n }, this);\n // Clears all:\n // - `this.groupedData`\n // - `this.points`\n // - `preserve` object in series.update()\n this.groupedData.length = 0;\n }\n }\n /**\n * Override the generatePoints method by adding a reference to grouped data\n * @private\n */\n function generatePoints() {\n baseGeneratePoints.apply(this);\n // Record grouped data in order to let it be destroyed the next time\n // processData runs\n this.destroyGroupedData(); // #622\n this.groupedData = this.hasGroupedData ? this.points : null;\n }\n /**\n * Set default approximations to the prototypes if present. Properties are\n * inherited down. Can be overridden for individual series types.\n * @private\n */\n function getDGApproximation() {\n if (this.is('arearange')) {\n return 'range';\n }\n if (this.is('ohlc')) {\n return 'ohlc';\n }\n if (this.is('hlc')) {\n return 'hlc';\n }\n if (this.is('column')) {\n return 'sum';\n }\n return 'average';\n }\n /**\n * Highcharts Stock only. Takes parallel arrays of x and y data and groups the\n * data into intervals defined by groupPositions, a collection of starting x\n * values for each group.\n *\n * @product highstock\n *\n * @function Highcharts.Series#groupData\n * @param {Array} xData\n * Parallel array of x data.\n * @param {Array<(number|null|undefined)>|Array>} yData\n * Parallel array of y data.\n * @param {Array} groupPositions\n * Group positions.\n * @param {string|Function} [approximation]\n * Approximation to use.\n * @return {Highcharts.DataGroupingResultObject}\n * Mapped groups.\n */\n function groupData(xData, yData, groupPositions, approximation) {\n var series = this,\n data = series.data,\n dataOptions = series.options && series.options.data,\n groupedXData = [],\n groupedYData = [],\n groupMap = [],\n dataLength = xData.length, \n // when grouping the fake extended axis for panning,\n // we don't need to consider y\n handleYData = !!yData,\n values = [],\n pointArrayMap = series.pointArrayMap,\n pointArrayMapLength = pointArrayMap && pointArrayMap.length,\n extendedPointArrayMap = ['x'].concat(pointArrayMap || ['y']),\n groupAll = (this.options.dataGrouping &&\n this.options.dataGrouping.groupAll);\n var pointX,\n pointY,\n groupedY,\n pos = 0,\n start = 0;\n var approximationFn = (typeof approximation === 'function' ?\n approximation :\n approximation && ApproximationRegistry[approximation] ?\n ApproximationRegistry[approximation] :\n ApproximationRegistry[(series.getDGApproximation && series.getDGApproximation() ||\n 'average')]);\n // Calculate values array size from pointArrayMap length\n if (pointArrayMapLength) {\n var len = pointArrayMap.length;\n while (len--) {\n values.push([]);\n }\n }\n else {\n values.push([]);\n }\n var valuesLen = pointArrayMapLength || 1;\n for (var i = 0; i <= dataLength; i++) {\n // Start with the first point within the X axis range (#2696)\n if (xData[i] < groupPositions[0]) {\n continue; // with next point\n }\n // when a new group is entered, summarize and initialize\n // the previous group\n while ((typeof groupPositions[pos + 1] !== 'undefined' &&\n xData[i] >= groupPositions[pos + 1]) ||\n i === dataLength) { // get the last group\n // get group x and y\n pointX = groupPositions[pos];\n series.dataGroupInfo = {\n start: groupAll ? start : (series.cropStart + start),\n length: values[0].length\n };\n groupedY = approximationFn.apply(series, values);\n // By default, let options of the first grouped point be passed over\n // to the grouped point. This allows preserving properties like\n // `name` and `color` or custom properties. Implementers can\n // override this from the approximation function, where they can\n // write custom options to `this.dataGroupInfo.options`.\n if (series.pointClass && !defined(series.dataGroupInfo.options)) {\n // Convert numbers and arrays into objects\n series.dataGroupInfo.options = merge(series.pointClass.prototype\n .optionsToObject.call({ series: series }, series.options.data[series.cropStart + start]));\n // Make sure the raw data (x, y, open, high etc) is not copied\n // over and overwriting approximated data.\n extendedPointArrayMap.forEach(function (key) {\n delete series.dataGroupInfo.options[key];\n });\n }\n // push the grouped data\n if (typeof groupedY !== 'undefined') {\n groupedXData.push(pointX);\n groupedYData.push(groupedY);\n groupMap.push(series.dataGroupInfo);\n }\n // reset the aggregate arrays\n start = i;\n for (var j = 0; j < valuesLen; j++) {\n values[j].length = 0; // faster than values[j] = []\n values[j].hasNulls = false;\n }\n // Advance on the group positions\n pos += 1;\n // don't loop beyond the last group\n if (i === dataLength) {\n break;\n }\n }\n // break out\n if (i === dataLength) {\n break;\n }\n // for each raw data point, push it to an array that contains all values\n // for this specific group\n if (pointArrayMap) {\n var index = (series.options.dataGrouping &&\n series.options.dataGrouping.groupAll ?\n i : series.cropStart + i),\n point = (data && data[index]) ||\n series.pointClass.prototype.applyOptions.apply({\n series: series\n },\n [dataOptions[index]]);\n var val = void 0;\n for (var j = 0; j < pointArrayMapLength; j++) {\n val = point[pointArrayMap[j]];\n if (isNumber(val)) {\n values[j].push(val);\n }\n else if (val === null) {\n values[j].hasNulls = true;\n }\n }\n }\n else {\n pointY = handleYData ? yData[i] : null;\n if (isNumber(pointY)) {\n values[0].push(pointY);\n }\n else if (pointY === null) {\n values[0].hasNulls = true;\n }\n }\n }\n return {\n groupedXData: groupedXData,\n groupedYData: groupedYData,\n groupMap: groupMap\n };\n }\n /**\n * Handle default options for data grouping. This must be set at runtime because\n * some series types are defined after this.\n * @private\n */\n function onAfterSetOptions(e) {\n var options = e.options,\n type = this.type,\n plotOptions = this.chart.options.plotOptions, \n // External series, for example technical indicators should also inherit\n // commonOptions which are not available outside this module\n baseOptions = (this.useCommonDataGrouping &&\n DataGroupingDefaults.common),\n seriesSpecific = DataGroupingDefaults.seriesSpecific;\n var defaultOptions = D.defaultOptions.plotOptions[type].dataGrouping;\n if (plotOptions && (seriesSpecific[type] || baseOptions)) { // #1284\n var rangeSelector = this.chart.rangeSelector;\n if (!defaultOptions) {\n defaultOptions = merge(DataGroupingDefaults.common, seriesSpecific[type]);\n }\n options.dataGrouping = merge(baseOptions, defaultOptions, plotOptions.series && plotOptions.series.dataGrouping, // #1228\n // Set by the StockChart constructor:\n plotOptions[type].dataGrouping, this.userOptions.dataGrouping, !options.isInternal &&\n rangeSelector &&\n isNumber(rangeSelector.selected) &&\n rangeSelector.buttonOptions[rangeSelector.selected].dataGrouping);\n }\n }\n /**\n * @private\n */\n function skipDataGrouping(series, force) {\n return !(series.isCartesian &&\n !series.isDirty &&\n !series.xAxis.isDirty &&\n !series.yAxis.isDirty &&\n !force);\n }\n /* *\n *\n * Default Export\n *\n * */\n var DataGroupingSeriesComposition = {\n compose: compose,\n groupData: groupData\n };\n\n return DataGroupingSeriesComposition;\n });\n _registerModule(_modules, 'Extensions/DataGrouping/DataGrouping.js', [_modules['Extensions/DataGrouping/DataGroupingAxisComposition.js'], _modules['Extensions/DataGrouping/DataGroupingDefaults.js'], _modules['Extensions/DataGrouping/DataGroupingSeriesComposition.js'], _modules['Core/FormatUtilities.js'], _modules['Core/Utilities.js']], function (DataGroupingAxisComposition, DataGroupingDefaults, DataGroupingSeriesComposition, F, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var format = F.format;\n var addEvent = U.addEvent,\n extend = U.extend,\n isNumber = U.isNumber;\n /* *\n *\n * Constants\n *\n * */\n var composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(AxisClass, SeriesClass, TooltipClass) {\n DataGroupingAxisComposition.compose(AxisClass);\n DataGroupingSeriesComposition.compose(SeriesClass);\n if (composedMembers.indexOf(TooltipClass) === -1) {\n composedMembers.push(TooltipClass);\n addEvent(TooltipClass, 'headerFormatter', onTooltipHeaderFormatter);\n }\n }\n /**\n * Extend the original method, make the tooltip's header reflect the grouped\n * range.\n * @private\n */\n function onTooltipHeaderFormatter(e) {\n var chart = this.chart,\n time = chart.time,\n labelConfig = e.labelConfig,\n series = labelConfig.series,\n options = series.options,\n tooltipOptions = series.tooltipOptions,\n dataGroupingOptions = options.dataGrouping,\n xAxis = series.xAxis;\n var xDateFormat = tooltipOptions.xDateFormat,\n xDateFormatEnd,\n currentDataGrouping,\n dateTimeLabelFormats,\n labelFormats,\n formattedKey,\n formatString = tooltipOptions[e.isFooter ? 'footerFormat' : 'headerFormat'];\n // apply only to grouped series\n if (xAxis &&\n xAxis.options.type === 'datetime' &&\n dataGroupingOptions &&\n isNumber(labelConfig.key)) {\n // set variables\n currentDataGrouping = series.currentDataGrouping;\n dateTimeLabelFormats = dataGroupingOptions.dateTimeLabelFormats ||\n // Fallback to commonOptions (#9693)\n DataGroupingDefaults.common.dateTimeLabelFormats;\n // if we have grouped data, use the grouping information to get the\n // right format\n if (currentDataGrouping) {\n labelFormats =\n dateTimeLabelFormats[currentDataGrouping.unitName];\n if (currentDataGrouping.count === 1) {\n xDateFormat = labelFormats[0];\n }\n else {\n xDateFormat = labelFormats[1];\n xDateFormatEnd = labelFormats[2];\n }\n // if not grouped, and we don't have set the xDateFormat option, get the\n // best fit, so if the least distance between points is one minute, show\n // it, but if the least distance is one day, skip hours and minutes etc.\n }\n else if (!xDateFormat && dateTimeLabelFormats && xAxis.dateTime) {\n xDateFormat = xAxis.dateTime.getXDateFormat(labelConfig.x, tooltipOptions.dateTimeLabelFormats);\n }\n // now format the key\n formattedKey = time.dateFormat(xDateFormat, labelConfig.key);\n if (xDateFormatEnd) {\n formattedKey += time.dateFormat(xDateFormatEnd, labelConfig.key + currentDataGrouping.totalRange - 1);\n }\n // Replace default header style with class name\n if (series.chart.styledMode) {\n formatString = this.styledModeFormat(formatString);\n }\n // return the replaced format\n e.text = format(formatString, {\n point: extend(labelConfig.point, { key: formattedKey }),\n series: series\n }, chart);\n e.preventDefault();\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n var DataGroupingComposition = {\n compose: compose,\n groupData: DataGroupingSeriesComposition.groupData\n };\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @typedef {\"average\"|\"averages\"|\"open\"|\"high\"|\"low\"|\"close\"|\"sum\"} Highcharts.DataGroupingApproximationValue\n */\n /**\n * The position of the point inside the group.\n *\n * @typedef {\"start\"|\"middle\"|\"end\"} Highcharts.DataGroupingAnchor\n */\n /**\n * The position of the first or last point in the series inside the group.\n *\n * @typedef {\"start\"|\"middle\"|\"end\"|\"firstPoint\"|\"lastPoint\"} Highcharts.DataGroupingAnchorExtremes\n */\n /**\n * Highcharts Stock only.\n *\n * @product highstock\n * @interface Highcharts.DataGroupingInfoObject\n */ /**\n * @name Highcharts.DataGroupingInfoObject#length\n * @type {number}\n */ /**\n * @name Highcharts.DataGroupingInfoObject#options\n * @type {Highcharts.SeriesOptionsType|undefined}\n */ /**\n * @name Highcharts.DataGroupingInfoObject#start\n * @type {number}\n */\n /**\n * Highcharts Stock only.\n *\n * @product highstock\n * @interface Highcharts.DataGroupingResultObject\n */ /**\n * @name Highcharts.DataGroupingResultObject#groupedXData\n * @type {Array}\n */ /**\n * @name Highcharts.DataGroupingResultObject#groupedYData\n * @type {Array<(number|null|undefined)>|Array>}\n */ /**\n * @name Highcharts.DataGroupingResultObject#groupMap\n * @type {Array}\n */\n /**\n * Highcharts Stock only. If a point object is created by data\n * grouping, it doesn't reflect actual points in the raw\n * data. In this case, the `dataGroup` property holds\n * information that points back to the raw data.\n *\n * - `dataGroup.start` is the index of the first raw data\n * point in the group.\n *\n * - `dataGroup.length` is the amount of points in the\n * group.\n *\n * @sample stock/members/point-datagroup\n * Click to inspect raw data points\n *\n * @product highstock\n *\n * @name Highcharts.Point#dataGroup\n * @type {Highcharts.DataGroupingInfoObject|undefined}\n */\n (''); // detach doclets above\n /* *\n *\n * API Options\n *\n * */\n /**\n * Data grouping is the concept of sampling the data values into larger\n * blocks in order to ease readability and increase performance of the\n * JavaScript charts. Highcharts Stock by default applies data grouping when\n * the points become closer than a certain pixel value, determined by\n * the `groupPixelWidth` option.\n *\n * If data grouping is applied, the grouping information of grouped\n * points can be read from the [Point.dataGroup](\n * /class-reference/Highcharts.Point#dataGroup). If point options other than\n * the data itself are set, for example `name` or `color` or custom properties,\n * the grouping logic doesn't know how to group it. In this case the options of\n * the first point instance are copied over to the group point. This can be\n * altered through a custom `approximation` callback function.\n *\n * @declare Highcharts.DataGroupingOptionsObject\n * @product highstock\n * @requires product:highstock\n * @requires module:modules/datagrouping\n * @apioption plotOptions.series.dataGrouping\n */\n /**\n * Specifies how the points should be located on the X axis inside the group.\n * Points that are extremes can be set separately. Available options:\n *\n * - `start` places the point at the beginning of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 00:00:00)\n *\n * - `middle` places the point in the middle of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 12:00:00)\n *\n * - `end` places the point at the end of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 23:59:59)\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-anchor\n * Changing the point x-coordinate inside the group.\n *\n * @see [dataGrouping.firstAnchor](#plotOptions.series.dataGrouping.firstAnchor)\n * @see [dataGrouping.lastAnchor](#plotOptions.series.dataGrouping.lastAnchor)\n *\n * @type {Highcharts.DataGroupingAnchor}\n * @since 9.1.0\n * @default start\n * @apioption plotOptions.series.dataGrouping.anchor\n */\n /**\n * The method of approximation inside a group. When for example 30 days\n * are grouped into one month, this determines what value should represent\n * the group. Possible values are \"average\", \"averages\", \"open\", \"high\",\n * \"low\", \"close\" and \"sum\". For OHLC and candlestick series the approximation\n * is \"ohlc\" by default, which finds the open, high, low and close values\n * within all the grouped data. For ranges, the approximation is \"range\",\n * which finds the low and high values. For multi-dimensional data,\n * like ranges and OHLC, \"averages\" will compute the average for each\n * dimension.\n *\n * Custom aggregate methods can be added by assigning a callback function\n * as the approximation. This function takes a numeric array as the\n * argument and should return a single numeric value or `null`. Note\n * that the numeric array will never contain null values, only true\n * numbers. Instead, if null values are present in the raw data, the\n * numeric array will have an `.hasNulls` property set to `true`. For\n * single-value data sets the data is available in the first argument\n * of the callback function. For OHLC data sets, all the open values\n * are in the first argument, all high values in the second etc.\n *\n * Since v4.2.7, grouping meta data is available in the approximation\n * callback from `this.dataGroupInfo`. It can be used to extract information\n * from the raw data.\n *\n * Defaults to `average` for line-type series, `sum` for columns, `range`\n * for range series, `hlc` for HLC, and `ohlc` for OHLC and candlestick.\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-approximation\n * Approximation callback with custom data\n * @sample {highstock} stock/plotoptions/series-datagrouping-simple-approximation\n * Simple approximation demo\n *\n * @type {Highcharts.DataGroupingApproximationValue|Function}\n * @apioption plotOptions.series.dataGrouping.approximation\n */\n /**\n * Datetime formats for the header of the tooltip in a stock chart.\n * The format can vary within a chart depending on the currently selected\n * time range and the current data grouping.\n *\n * The default formats are:\n * ```js\n * {\n * millisecond: [\n * '%A, %b %e, %H:%M:%S.%L', '%A, %b %e, %H:%M:%S.%L', '-%H:%M:%S.%L'\n * ],\n * second: ['%A, %b %e, %H:%M:%S', '%A, %b %e, %H:%M:%S', '-%H:%M:%S'],\n * minute: ['%A, %b %e, %H:%M', '%A, %b %e, %H:%M', '-%H:%M'],\n * hour: ['%A, %b %e, %H:%M', '%A, %b %e, %H:%M', '-%H:%M'],\n * day: ['%A, %b %e, %Y', '%A, %b %e', '-%A, %b %e, %Y'],\n * week: ['Week from %A, %b %e, %Y', '%A, %b %e', '-%A, %b %e, %Y'],\n * month: ['%B %Y', '%B', '-%B %Y'],\n * year: ['%Y', '%Y', '-%Y']\n * }\n * ```\n *\n * For each of these array definitions, the first item is the format\n * used when the active time span is one unit. For instance, if the\n * current data applies to one week, the first item of the week array\n * is used. The second and third items are used when the active time\n * span is more than two units. For instance, if the current data applies\n * to two weeks, the second and third item of the week array are used,\n * and applied to the start and end date of the time span.\n *\n * @type {Object}\n * @apioption plotOptions.series.dataGrouping.dateTimeLabelFormats\n */\n /**\n * Enable or disable data grouping.\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.dataGrouping.enabled\n */\n /**\n * Specifies how the first grouped point is positioned on the xAxis.\n * If firstAnchor and/or lastAnchor are defined, then those options take\n * precedence over anchor for the first and/or last grouped points.\n * Available options:\n *\n * -`start` places the point at the beginning of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 00:00:00)\n *\n * -`middle` places the point in the middle of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 12:00:00)\n *\n * -`end` places the point at the end of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 23:59:59)\n *\n * -`firstPoint` the first point in the group\n * (e.g. points at 00:13, 00:35, 00:59 -> 00:13)\n *\n * -`lastPoint` the last point in the group\n * (e.g. points at 00:13, 00:35, 00:59 -> 00:59)\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-first-anchor\n * Applying first and last anchor.\n *\n * @see [dataGrouping.anchor](#plotOptions.series.dataGrouping.anchor)\n *\n * @type {Highcharts.DataGroupingAnchorExtremes}\n * @since 9.1.0\n * @default start\n * @apioption plotOptions.series.dataGrouping.firstAnchor\n */\n /**\n * When data grouping is forced, it runs no matter how small the intervals\n * are. This can be handy for example when the sum should be calculated\n * for values appearing at random times within each hour.\n *\n * @type {boolean}\n * @default false\n * @apioption plotOptions.series.dataGrouping.forced\n */\n /**\n * The approximate pixel width of each group. If for example a series\n * with 30 points is displayed over a 600 pixel wide plot area, no grouping\n * is performed. If however the series contains so many points that\n * the spacing is less than the groupPixelWidth, Highcharts will try\n * to group it into appropriate groups so that each is more or less\n * two pixels wide. If multiple series with different group pixel widths\n * are drawn on the same x axis, all series will take the greatest width.\n * For example, line series have 2px default group width, while column\n * series have 10px. If combined, both the line and the column will\n * have 10px by default.\n *\n * @type {number}\n * @default 2\n * @apioption plotOptions.series.dataGrouping.groupPixelWidth\n */\n /**\n * By default only points within the visible range are grouped. Enabling this\n * option will force data grouping to calculate all grouped points for a given\n * dataset. That option prevents for example a column series from calculating\n * a grouped point partially. The effect is similar to\n * [Series.getExtremesFromAll](#plotOptions.series.getExtremesFromAll) but does\n * not affect yAxis extremes.\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-groupall/\n * Two series with the same data but different groupAll setting\n *\n * @type {boolean}\n * @default false\n * @since 6.1.0\n * @apioption plotOptions.series.dataGrouping.groupAll\n */\n /**\n * Specifies how the last grouped point is positioned on the xAxis.\n * If firstAnchor and/or lastAnchor are defined, then those options take\n * precedence over anchor for the first and/or last grouped points.\n * Available options:\n *\n * -`start` places the point at the beginning of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 00:00:00)\n *\n * -`middle` places the point in the middle of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 12:00:00)\n *\n * -`end` places the point at the end of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 23:59:59)\n *\n * -`firstPoint` the first point in the group\n * (e.g. points at 00:13, 00:35, 00:59 -> 00:13)\n *\n * -`lastPoint` the last point in the group\n * (e.g. points at 00:13, 00:35, 00:59 -> 00:59)\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-first-anchor\n * Applying first and last anchor.\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-last-anchor\n * Applying the last anchor in the chart with live data.\n *\n * @see [dataGrouping.anchor](#plotOptions.series.dataGrouping.anchor)\n *\n * @type {Highcharts.DataGroupingAnchorExtremes}\n * @since 9.1.0\n * @default start\n * @apioption plotOptions.series.dataGrouping.lastAnchor\n */\n /**\n * Normally, a group is indexed by the start of that group, so for example\n * when 30 daily values are grouped into one month, that month's x value\n * will be the 1st of the month. This apparently shifts the data to\n * the left. When the smoothed option is true, this is compensated for.\n * The data is shifted to the middle of the group, and min and max\n * values are preserved. Internally, this is used in the Navigator series.\n *\n * @type {boolean}\n * @default false\n * @deprecated\n * @apioption plotOptions.series.dataGrouping.smoothed\n */\n /**\n * An array determining what time intervals the data is allowed to be\n * grouped to. Each array item is an array where the first value is\n * the time unit and the second value another array of allowed multiples.\n *\n * Defaults to:\n * ```js\n * units: [[\n * 'millisecond', // unit name\n * [1, 2, 5, 10, 20, 25, 50, 100, 200, 500] // allowed multiples\n * ], [\n * 'second',\n * [1, 2, 5, 10, 15, 30]\n * ], [\n * 'minute',\n * [1, 2, 5, 10, 15, 30]\n * ], [\n * 'hour',\n * [1, 2, 3, 4, 6, 8, 12]\n * ], [\n * 'day',\n * [1]\n * ], [\n * 'week',\n * [1]\n * ], [\n * 'month',\n * [1, 3, 6]\n * ], [\n * 'year',\n * null\n * ]]\n * ```\n *\n * @type {Array|null)>>}\n * @apioption plotOptions.series.dataGrouping.units\n */\n /**\n * The approximate pixel width of each group. If for example a series\n * with 30 points is displayed over a 600 pixel wide plot area, no grouping\n * is performed. If however the series contains so many points that\n * the spacing is less than the groupPixelWidth, Highcharts will try\n * to group it into appropriate groups so that each is more or less\n * two pixels wide. Defaults to `10`.\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-grouppixelwidth/\n * Two series with the same data density but different groupPixelWidth\n *\n * @type {number}\n * @default 10\n * @apioption plotOptions.column.dataGrouping.groupPixelWidth\n */\n ''; // required by JSDoc parsing\n\n return DataGroupingComposition;\n });\n _registerModule(_modules, 'masters/modules/datagrouping.src.js', [_modules['Core/Globals.js'], _modules['Extensions/DataGrouping/ApproximationDefaults.js'], _modules['Extensions/DataGrouping/ApproximationRegistry.js'], _modules['Extensions/DataGrouping/DataGrouping.js']], function (Highcharts, ApproximationDefaults, ApproximationRegistry, DataGrouping) {\n\n var G = Highcharts;\n G.dataGrouping = {\n approximationDefaults: ApproximationDefaults,\n approximations: ApproximationRegistry\n };\n DataGrouping.compose(G.Axis, G.Series, G.Tooltip);\n\n });\n _registerModule(_modules, 'Series/DataModifyComposition.js', [_modules['Core/Axis/Axis.js'], _modules['Core/Series/Point.js'], _modules['Core/Series/Series.js'], _modules['Core/Utilities.js']], function (Axis, Point, Series, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var pointTooltipFormatter = Point.prototype.tooltipFormatter;\n var addEvent = U.addEvent,\n arrayMax = U.arrayMax,\n arrayMin = U.arrayMin,\n correctFloat = U.correctFloat,\n defined = U.defined,\n isArray = U.isArray,\n isNumber = U.isNumber,\n isString = U.isString,\n pick = U.pick;\n /* *\n *\n * Composition\n *\n * */\n var DataModifyComposition;\n (function (DataModifyComposition) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Extends the series, axis and point classes with\n * compare and cumulative support.\n *\n * @private\n *\n * @param SeriesClass\n * Series class to use.\n *\n * @param AxisClass\n * Axis class to extend.\n *\n * @param PointClass\n * Point class to use.\n */\n function compose(SeriesClass, AxisClass, PointClass) {\n if (composedClasses.indexOf(SeriesClass) === -1) {\n composedClasses.push(SeriesClass);\n var seriesProto = SeriesClass.prototype;\n seriesProto.setCompare = seriesSetCompare;\n seriesProto.setCumulative = seriesSetCumulative;\n addEvent(SeriesClass, 'afterInit', afterInit);\n addEvent(SeriesClass, 'afterGetExtremes', afterGetExtremes);\n addEvent(SeriesClass, 'afterProcessData', afterProcessData);\n }\n if (composedClasses.indexOf(AxisClass) === -1) {\n composedClasses.push(AxisClass);\n var axisProto = AxisClass.prototype;\n axisProto.setCompare = axisSetCompare;\n axisProto.setModifier = setModifier;\n axisProto.setCumulative = axisSetCumulative;\n }\n if (composedClasses.indexOf(PointClass) === -1) {\n composedClasses.push(PointClass);\n var pointProto = PointClass.prototype;\n pointProto.tooltipFormatter = tooltipFormatter;\n }\n return SeriesClass;\n }\n DataModifyComposition.compose = compose;\n /* ********************************************************************** *\n * Start shared compare and cumulative logic *\n * ********************************************************************** */\n /**\n * Shared code for the axis.setCompare() and the axis.setCumulative()\n * methods. Inits the 'compare' or the 'cumulative' mode.\n * @private\n */\n function setModifier(mode, modeState, redraw) {\n if (!this.isXAxis) {\n this.series.forEach(function (series) {\n if (mode === 'compare' &&\n typeof modeState !== 'boolean') {\n series.setCompare(modeState, false);\n }\n else if (mode === 'cumulative' &&\n !isString(modeState)) {\n series.setCumulative(modeState, false);\n }\n });\n if (pick(redraw, true)) {\n this.chart.redraw();\n }\n }\n }\n /**\n * Extend the tooltip formatter by adding support for the point.change\n * variable as well as the changeDecimals option.\n *\n * @ignore\n * @function Highcharts.Point#tooltipFormatter\n *\n * @param {string} pointFormat\n */\n function tooltipFormatter(pointFormat) {\n var point = this, numberFormatter = point.series.chart.numberFormatter, replace = function (value) {\n pointFormat = pointFormat.replace('{point.' + value + '}', (point[value] > 0 && value === 'change' ? '+' : '') +\n numberFormatter(point[value], pick(point.series.tooltipOptions.changeDecimals, 2)));\n };\n if (defined(point.change)) {\n replace('change');\n }\n if (defined(point.cumulativeSum)) {\n replace('cumulativeSum');\n }\n return pointTooltipFormatter.apply(this, [pointFormat]);\n }\n /**\n * Extend series.init by adding a methods to modify the y values used\n * for plotting on the y axis. For compare mode, this method is called both\n * from the axis when finding dataMin and dataMax,\n * and from the series.translate method.\n *\n * @ignore\n * @function Highcharts.Series#init\n */\n function afterInit() {\n var compare = this.options.compare;\n var dataModify;\n if (compare === 'percent' ||\n compare === 'value' ||\n this.options.cumulative) {\n dataModify = new Additions(this);\n if (compare === 'percent' || compare === 'value') {\n // Set comparison mode\n dataModify.initCompare(compare);\n }\n else {\n // Set Cumulative Sum mode\n dataModify.initCumulative();\n }\n }\n this.dataModify = dataModify;\n }\n /**\n * Adjust the extremes (compare and cumulative modify the data).\n * @private\n */\n function afterGetExtremes(e) {\n var dataExtremes = e.dataExtremes,\n activeYData = dataExtremes.activeYData;\n if (this.dataModify && dataExtremes) {\n var extremes = void 0;\n if (this.options.compare) {\n extremes = [\n this.dataModify.modifyValue(dataExtremes.dataMin),\n this.dataModify.modifyValue(dataExtremes.dataMax)\n ];\n }\n else if (this.options.cumulative &&\n isArray(activeYData) &&\n // If only one y visible, sum doesn't change\n // so no need to change extremes\n activeYData.length >= 2) {\n extremes = Additions.getCumulativeExtremes(activeYData);\n }\n if (extremes) {\n dataExtremes.dataMin = arrayMin(extremes);\n dataExtremes.dataMax = arrayMax(extremes);\n }\n }\n }\n /* ********************************************************************** *\n * End shared compare and cumulative logic *\n * ********************************************************************** */\n /* ********************************************************************** *\n * Start value compare logic *\n * ********************************************************************** */\n /**\n * Highcharts Stock only. Set the\n * [compare](https://api.highcharts.com/highstock/plotOptions.series.compare)\n * mode of the series after render time.\n * In most cases it is more useful running\n * {@link Axis#setCompare} on the X axis to update all its series.\n *\n * @function Highcharts.Series#setCompare\n *\n * @param {string|null} [compare]\n * Can be one of `undefined` (default), `null`, `\"percent\"`\n * or `\"value\"`.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or to wait for a later call to\n * {@link Chart#redraw}.\n */\n function seriesSetCompare(compare, redraw) {\n // Survive to export, #5485 (and for options generally)\n this.options.compare = this.userOptions.compare = compare;\n // Fire series.init() that will set or delete series.dataModify\n this.update({}, pick(redraw, true));\n if (this.dataModify && (compare === 'value' || compare === 'percent')) {\n this.dataModify.initCompare(compare);\n }\n else {\n // When disabling, clear the points\n this.points.forEach(function (point) {\n delete point.change;\n });\n }\n }\n /**\n * Extend series.processData by finding the first y value in the plot area,\n * used for comparing the following values\n *\n * @ignore\n * @function Highcharts.Series#processData\n */\n function afterProcessData() {\n var series = this;\n if (series.xAxis && // not pies\n series.processedYData &&\n series.dataModify) {\n var processedXData = series.processedXData,\n processedYData = series.processedYData,\n length_1 = processedYData.length,\n compareStart = series.options.compareStart === true ? 0 : 1;\n var keyIndex = -1,\n i = void 0;\n // For series with more than one value (range, OHLC etc), compare\n // against close or the pointValKey (#4922, #3112, #9854)\n if (series.pointArrayMap) {\n keyIndex = series.pointArrayMap.indexOf(series.options.pointValKey || series.pointValKey || 'y');\n }\n // find the first value for comparison\n for (i = 0; i < length_1 - compareStart; i++) {\n var compareValue = processedYData[i] && keyIndex > -1 ?\n processedYData[i][keyIndex] : processedYData[i];\n if (isNumber(compareValue) &&\n compareValue !== 0 &&\n processedXData[i + compareStart] >= (series.xAxis.min || 0)) {\n series.dataModify.compareValue = compareValue;\n break;\n }\n }\n }\n }\n /**\n * Highcharts Stock only. Set the compare mode on all series\n * belonging to a Y axis.\n *\n * @see [plotOptions.series.compare](https://api.highcharts.com/highstock/plotOptions.series.compare)\n *\n * @sample stock/members/axis-setcompare/\n * Set compare\n *\n * @function Highcharts.Axis#setCompare\n *\n * @param {string|null} [compare]\n * The compare mode. Can be one of `undefined` (default), `null`,\n * `\"value\"` or `\"percent\"`.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or to wait for a later call to\n * {@link Chart#redraw}.\n */\n function axisSetCompare(compare, redraw) {\n this.setModifier('compare', compare, redraw);\n }\n /* ********************************************************************** *\n * End value compare logic *\n * ********************************************************************** */\n /* ********************************************************************** *\n * Start Cumulative Sum logic, author: Rafal Sebestjanski *\n * ********************************************************************** */\n /**\n * Highcharts Stock only. Set the\n * [cumulative](https://api.highcharts.com/highstock/plotOptions.series.cumulative)\n * mode of the series after render time.\n * In most cases it is more useful running\n * {@link Axis#setCumulative} on the Y axis to update all its series.\n *\n * @function Highcharts.Series#setCumulative\n *\n * @param {boolean} [cumulative=false]\n * Either enable or disable Cumulative Sum mode.\n * Can be one of `false` (default) or `true`.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or to wait for a later call to\n * {@link Chart#redraw}.\n */\n function seriesSetCumulative(cumulative, redraw) {\n // Set default value to false\n cumulative = pick(cumulative, false);\n // Survive to export, #5485 (and for options generally)\n this.options.cumulative = this.userOptions.cumulative = cumulative;\n // Fire series.init() that will set or delete series.dataModify\n this.update({}, pick(redraw, true));\n // If should, turn on the Cumulative Sum mode\n if (this.dataModify) {\n this.dataModify.initCumulative();\n }\n else {\n // When disabling, clear the points\n this.points.forEach(function (point) {\n delete point.cumulativeSum;\n });\n }\n }\n /**\n * Highcharts Stock only. Set the cumulative mode on all series\n * belonging to a Y axis.\n *\n * @see [plotOptions.series.cumulative](https://api.highcharts.com/highstock/plotOptions.series.cumulative)\n *\n * @sample stock/members/axis-setcumulative/\n * Set cumulative\n *\n * @function Highcharts.Axis#setCumulative\n *\n * @param {boolean} [cumulative]\n * Whether to disable or enable the cumulative mode.\n * Can be one of `undefined` (default, treated as `false`),\n * `false` or `true`.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or to wait for a later call to\n * {@link Chart#redraw}.\n */\n function axisSetCumulative(cumulative, redraw) {\n this.setModifier('cumulative', cumulative, redraw);\n }\n /* *\n *\n * Classes\n *\n * */\n /**\n * @private\n */\n var Additions = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n /**\n * @private\n */\n function Additions(series) {\n this.series = series;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n Additions.prototype.modifyValue = function () {\n return 0;\n };\n /**\n * @ignore\n * @function Highcharts.Series#getCumulativeExtremes\n *\n * @param {Array} [activeYData]\n * An array cointaining all the points' y values\n * in a visible range.\n */\n Additions.getCumulativeExtremes = function (activeYData) {\n var cumulativeDataMin = Infinity,\n cumulativeDataMax = -Infinity;\n activeYData.reduce(function (prev, cur) {\n var sum = prev + cur;\n cumulativeDataMin = Math.min(cumulativeDataMin, sum, prev);\n cumulativeDataMax = Math.max(cumulativeDataMax, sum, prev);\n return sum;\n });\n return [cumulativeDataMin, cumulativeDataMax];\n };\n /**\n * @ignore\n * @function Highcharts.Series#initCompare\n *\n * @param {string} [compare]\n * Can be one of `\"percent\"` or `\"value\"`.\n */\n Additions.prototype.initCompare = function (compare) {\n // Set the modifyValue method\n this.modifyValue = function (value, index) {\n if (value === null) {\n value = 0;\n }\n var compareValue = this.compareValue;\n if (typeof value !== 'undefined' &&\n typeof compareValue !== 'undefined') { // #2601, #5814\n // Get the modified value\n if (compare === 'value') {\n value -= compareValue;\n // Compare percent\n }\n else {\n var compareBase = this.series.options.compareBase;\n value = 100 * (value / compareValue) -\n (compareBase === 100 ? 0 : 100);\n }\n // record for tooltip etc.\n if (typeof index !== 'undefined') {\n var point = this.series.points[index];\n if (point) {\n point.change = value;\n }\n }\n return value;\n }\n return 0;\n };\n };\n /**\n * @ignore\n * @function Highcharts.Series#initCumulative\n */\n Additions.prototype.initCumulative = function () {\n // Set the modifyValue method\n this.modifyValue = function (value, index) {\n if (value === null) {\n value = 0;\n }\n if (value !== void 0 && index !== void 0) {\n var prevPoint = index > 0 ?\n this.series.points[index - 1] : null;\n // Get the modified value\n if (prevPoint && prevPoint.cumulativeSum) {\n value = correctFloat(prevPoint.cumulativeSum + value);\n }\n // Record for tooltip etc.\n var point = this.series.points[index];\n if (point) {\n point.cumulativeSum = value;\n }\n return value;\n }\n return 0;\n };\n };\n return Additions;\n }());\n DataModifyComposition.Additions = Additions;\n })(DataModifyComposition || (DataModifyComposition = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Compare the values of the series against the first non-null, non-\n * zero value in the visible range. The y axis will show percentage\n * or absolute change depending on whether `compare` is set to `\"percent\"`\n * or `\"value\"`. When this is applied to multiple series, it allows\n * comparing the development of the series against each other. Adds\n * a `change` field to every point object.\n *\n * @see [compareBase](#plotOptions.series.compareBase)\n * @see [Axis.setCompare()](/class-reference/Highcharts.Axis#setCompare)\n * @see [Series.setCompare()](/class-reference/Highcharts.Series#setCompare)\n *\n * @sample {highstock} stock/plotoptions/series-compare-percent/\n * Percent\n * @sample {highstock} stock/plotoptions/series-compare-value/\n * Value\n *\n * @type {string}\n * @since 1.0.1\n * @product highstock\n * @validvalue [\"percent\", \"value\"]\n * @apioption plotOptions.series.compare\n */\n /**\n * Defines if comparison should start from the first point within the visible\n * range or should start from the first point **before** the range.\n *\n * In other words, this flag determines if first point within the visible range\n * will have 0% (`compareStart=true`) or should have been already calculated\n * according to the previous point (`compareStart=false`).\n *\n * @sample {highstock} stock/plotoptions/series-comparestart/\n * Calculate compare within visible range\n *\n * @type {boolean}\n * @default false\n * @since 6.0.0\n * @product highstock\n * @apioption plotOptions.series.compareStart\n */\n /**\n * When [compare](#plotOptions.series.compare) is `percent`, this option\n * dictates whether to use 0 or 100 as the base of comparison.\n *\n * @sample {highstock} stock/plotoptions/series-comparebase/\n * Compare base is 100\n *\n * @type {number}\n * @default 0\n * @since 5.0.6\n * @product highstock\n * @validvalue [0, 100]\n * @apioption plotOptions.series.compareBase\n */\n /**\n * Cumulative Sum feature replaces points' values with the following formula:\n * `sum of all previous points' values + current point's value`.\n * Works only for points in a visible range.\n * Adds the `cumulativeSum` field to each point object that can be accessed\n * e.g. in the [tooltip.pointFormat](https://api.highcharts.com/highstock/tooltip.pointFormat).\n *\n * @see [Axis.setCumulative()](/class-reference/Highcharts.Axis#setCumulative)\n * @see [Series.setCumulative()](/class-reference/Highcharts.Series#setCumulative)\n *\n * @sample {highstock} stock/plotoptions/series-cumulative-sum/\n * Cumulative Sum\n *\n * @type {boolean}\n * @default false\n * @since 9.3.0\n * @product highstock\n * @apioption plotOptions.series.cumulative\n */\n ''; // keeps doclets above in transpiled file\n\n return DataModifyComposition;\n });\n _registerModule(_modules, 'Core/Axis/NavigatorAxisComposition.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var isTouchDevice = H.isTouchDevice;\n var addEvent = U.addEvent,\n correctFloat = U.correctFloat,\n defined = U.defined,\n isNumber = U.isNumber,\n pick = U.pick;\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function onAxisInit() {\n var axis = this;\n if (!axis.navigatorAxis) {\n axis.navigatorAxis = new NavigatorAxisAdditions(axis);\n }\n }\n /**\n * For Stock charts, override selection zooming with some special features\n * because X axis zooming is already allowed by the Navigator and Range\n * selector.\n * @private\n */\n function onAxisZoom(e) {\n var axis = this,\n chart = axis.chart,\n chartOptions = chart.options,\n navigator = chartOptions.navigator,\n navigatorAxis = axis.navigatorAxis,\n pinchType = chartOptions.chart.zooming.pinchType,\n rangeSelector = chartOptions.rangeSelector,\n zoomType = chartOptions.chart.zooming.type;\n if (axis.isXAxis && ((navigator && navigator.enabled) ||\n (rangeSelector && rangeSelector.enabled))) {\n // For y only zooming, ignore the X axis completely\n if (zoomType === 'y') {\n e.zoomed = false;\n // For xy zooming, record the state of the zoom before zoom\n // selection, then when the reset button is pressed, revert to\n // this state. This should apply only if the chart is\n // initialized with a range (#6612), otherwise zoom all the way\n // out.\n }\n else if (((!isTouchDevice && zoomType === 'xy') ||\n (isTouchDevice && pinchType === 'xy')) &&\n axis.options.range) {\n var previousZoom = navigatorAxis.previousZoom;\n if (defined(e.newMin)) {\n navigatorAxis.previousZoom = [axis.min, axis.max];\n }\n else if (previousZoom) {\n e.newMin = previousZoom[0];\n e.newMax = previousZoom[1];\n navigatorAxis.previousZoom = void 0;\n }\n }\n }\n if (typeof e.zoomed !== 'undefined') {\n e.preventDefault();\n }\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * @private\n * @class\n */\n var NavigatorAxisAdditions = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function NavigatorAxisAdditions(axis) {\n this.axis = axis;\n }\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * @private\n */\n NavigatorAxisAdditions.compose = function (AxisClass) {\n if (composedClasses.indexOf(AxisClass) === -1) {\n composedClasses.push(AxisClass);\n AxisClass.keepProps.push('navigatorAxis');\n addEvent(AxisClass, 'init', onAxisInit);\n addEvent(AxisClass, 'zoom', onAxisZoom);\n }\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n NavigatorAxisAdditions.prototype.destroy = function () {\n this.axis = void 0;\n };\n /**\n * Add logic to normalize the zoomed range in order to preserve the pressed\n * state of range selector buttons\n *\n * @private\n * @function Highcharts.Axis#toFixedRange\n */\n NavigatorAxisAdditions.prototype.toFixedRange = function (pxMin, pxMax, fixedMin, fixedMax) {\n var axis = this.axis,\n chart = axis.chart;\n var newMin = pick(fixedMin,\n axis.translate(pxMin,\n true, !axis.horiz)),\n newMax = pick(fixedMax,\n axis.translate(pxMax,\n true, !axis.horiz));\n var fixedRange = chart && chart.fixedRange,\n halfPointRange = (axis.pointRange || 0) / 2,\n changeRatio = fixedRange && (newMax - newMin) / fixedRange;\n // Add/remove half point range to/from the extremes (#1172)\n if (!defined(fixedMin)) {\n newMin = correctFloat(newMin + halfPointRange);\n }\n if (!defined(fixedMax)) {\n newMax = correctFloat(newMax - halfPointRange);\n }\n // If the difference between the fixed range and the actual requested\n // range is too great, the user is dragging across an ordinal gap, and\n // we need to release the range selector button.\n if (changeRatio > 0.7 && changeRatio < 1.3) {\n if (fixedMax) {\n newMin = newMax - fixedRange;\n }\n else {\n newMax = newMin + fixedRange;\n }\n }\n if (!isNumber(newMin) || !isNumber(newMax)) { // #1195, #7411\n newMin = newMax = void 0;\n }\n return {\n min: newMin,\n max: newMax\n };\n };\n return NavigatorAxisAdditions;\n }());\n /* *\n *\n * Default Export\n *\n * */\n\n return NavigatorAxisAdditions;\n });\n _registerModule(_modules, 'Stock/Navigator/NavigatorDefaults.js', [_modules['Core/Color/Color.js'], _modules['Core/Series/SeriesRegistry.js']], function (Color, SeriesRegistry) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var color = Color.parse;\n var seriesTypes = SeriesRegistry.seriesTypes;\n /* *\n *\n * Constants\n *\n * */\n /**\n * The navigator is a small series below the main series, displaying\n * a view of the entire data set. It provides tools to zoom in and\n * out on parts of the data as well as panning across the dataset.\n *\n * @product highstock gantt\n * @optionparent navigator\n */\n var NavigatorDefaults = {\n /**\n * Whether the navigator and scrollbar should adapt to updated data\n * in the base X axis. When loading data async, as in the demo below,\n * this should be `false`. Otherwise new data will trigger navigator\n * redraw, which will cause unwanted looping. In the demo below, the\n * data in the navigator is set only once. On navigating, only the main\n * chart content is updated.\n *\n * @sample {highstock} stock/demo/lazy-loading/\n * Set to false with async data loading\n *\n * @type {boolean}\n * @default true\n * @apioption navigator.adaptToUpdatedData\n */\n /**\n * An integer identifying the index to use for the base series, or a\n * string representing the id of the series.\n *\n * **Note**: As of Highcharts 5.0, this is now a deprecated option.\n * Prefer [series.showInNavigator](#plotOptions.series.showInNavigator).\n *\n * @see [series.showInNavigator](#plotOptions.series.showInNavigator)\n *\n * @deprecated\n * @type {number|string}\n * @default 0\n * @apioption navigator.baseSeries\n */\n /**\n * Enable or disable the navigator.\n *\n * @sample {highstock} stock/navigator/enabled/\n * Disable the navigator\n *\n * @type {boolean}\n * @default true\n * @apioption navigator.enabled\n */\n /**\n * When the chart is inverted, whether to draw the navigator on the\n * opposite side.\n *\n * @type {boolean}\n * @default false\n * @since 5.0.8\n * @apioption navigator.opposite\n */\n /**\n * The height of the navigator.\n *\n * @sample {highstock} stock/navigator/height/\n * A higher navigator\n */\n height: 40,\n /**\n * The distance from the nearest element, the X axis or X axis labels.\n *\n * @sample {highstock} stock/navigator/margin/\n * A margin of 2 draws the navigator closer to the X axis labels\n */\n margin: 25,\n /**\n * Whether the mask should be inside the range marking the zoomed\n * range, or outside. In Highcharts Stock 1.x it was always `false`.\n *\n * @sample {highstock} stock/navigator/maskinside-false/\n * False, mask outside\n *\n * @since 2.0\n */\n maskInside: true,\n /**\n * Options for the handles for dragging the zoomed area.\n *\n * @sample {highstock} stock/navigator/handles/\n * Colored handles\n */\n handles: {\n /**\n * Width for handles.\n *\n * @sample {highstock} stock/navigator/styled-handles/\n * Styled handles\n *\n * @since 6.0.0\n */\n width: 7,\n /**\n * Height for handles.\n *\n * @sample {highstock} stock/navigator/styled-handles/\n * Styled handles\n *\n * @since 6.0.0\n */\n height: 15,\n /**\n * Array to define shapes of handles. 0-index for left, 1-index for\n * right.\n *\n * Additionally, the URL to a graphic can be given on this form:\n * `url(graphic.png)`. Note that for the image to be applied to\n * exported charts, its URL needs to be accessible by the export\n * server.\n *\n * Custom callbacks for symbol path generation can also be added to\n * `Highcharts.SVGRenderer.prototype.symbols`. The callback is then\n * used by its method name, as shown in the demo.\n *\n * @sample {highstock} stock/navigator/styled-handles/\n * Styled handles\n *\n * @type {Array}\n * @default [\"navigator-handle\", \"navigator-handle\"]\n * @since 6.0.0\n */\n symbols: ['navigator-handle', 'navigator-handle'],\n /**\n * Allows to enable/disable handles.\n *\n * @since 6.0.0\n */\n enabled: true,\n /**\n * The width for the handle border and the stripes inside.\n *\n * @sample {highstock} stock/navigator/styled-handles/\n * Styled handles\n *\n * @since 6.0.0\n * @apioption navigator.handles.lineWidth\n */\n lineWidth: 1,\n /**\n * The fill for the handle.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n backgroundColor: \"#f2f2f2\" /* Palette.neutralColor5 */,\n /**\n * The stroke for the handle border and the stripes inside.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n borderColor: \"#999999\" /* Palette.neutralColor40 */\n },\n /**\n * The color of the mask covering the areas of the navigator series\n * that are currently not visible in the main series. The default\n * color is bluish with an opacity of 0.3 to see the series below.\n *\n * @see In styled mode, the mask is styled with the\n * `.highcharts-navigator-mask` and\n * `.highcharts-navigator-mask-inside` classes.\n *\n * @sample {highstock} stock/navigator/maskfill/\n * Blue, semi transparent mask\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default rgba(102,133,194,0.3)\n */\n maskFill: color(\"#6685c2\" /* Palette.highlightColor60 */).setOpacity(0.3).get(),\n /**\n * The color of the line marking the currently zoomed area in the\n * navigator.\n *\n * @sample {highstock} stock/navigator/outline/\n * 2px blue outline\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #cccccc\n */\n outlineColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * The width of the line marking the currently zoomed area in the\n * navigator.\n *\n * @see In styled mode, the outline stroke width is set with the\n * `.highcharts-navigator-outline` class.\n *\n * @sample {highstock} stock/navigator/outline/\n * 2px blue outline\n *\n * @type {number}\n */\n outlineWidth: 1,\n /**\n * Options for the navigator series. Available options are the same\n * as any series, documented at [plotOptions](#plotOptions.series)\n * and [series](#series).\n *\n * Unless data is explicitly defined on navigator.series, the data\n * is borrowed from the first series in the chart.\n *\n * Default series options for the navigator series are:\n * ```js\n * series: {\n * type: 'areaspline',\n * fillOpacity: 0.05,\n * dataGrouping: {\n * smoothed: true\n * },\n * lineWidth: 1,\n * marker: {\n * enabled: false\n * }\n * }\n * ```\n *\n * @see In styled mode, the navigator series is styled with the\n * `.highcharts-navigator-series` class.\n *\n * @sample {highstock} stock/navigator/series-data/\n * Using a separate data set for the navigator\n * @sample {highstock} stock/navigator/series/\n * A green navigator series\n *\n * @type {*|Array<*>|Highcharts.SeriesOptionsType|Array}\n */\n series: {\n /**\n * The type of the navigator series.\n *\n * Heads up:\n * In column-type navigator, zooming is limited to at least one\n * point with its `pointRange`.\n *\n * @sample {highstock} stock/navigator/column/\n * Column type navigator\n *\n * @type {string}\n * @default {highstock} `areaspline` if defined, otherwise `line`\n * @default {gantt} gantt\n */\n type: (typeof seriesTypes.areaspline === 'undefined' ?\n 'line' :\n 'areaspline'),\n /**\n * The fill opacity of the navigator series.\n */\n fillOpacity: 0.05,\n /**\n * The pixel line width of the navigator series.\n */\n lineWidth: 1,\n /**\n * @ignore-option\n */\n compare: null,\n /**\n * Unless data is explicitly defined, the data is borrowed from the\n * first series in the chart.\n *\n * @type {Array|object|null>}\n * @product highstock\n * @apioption navigator.series.data\n */\n /**\n * Data grouping options for the navigator series.\n *\n * @extends plotOptions.series.dataGrouping\n */\n dataGrouping: {\n approximation: 'average',\n enabled: true,\n groupPixelWidth: 2,\n // Replace smoothed property by anchors, #12455.\n firstAnchor: 'firstPoint',\n anchor: 'middle',\n lastAnchor: 'lastPoint',\n // Day and week differs from plotOptions.series.dataGrouping\n units: [\n ['millisecond', [1, 2, 5, 10, 20, 25, 50, 100, 200, 500]],\n ['second', [1, 2, 5, 10, 15, 30]],\n ['minute', [1, 2, 5, 10, 15, 30]],\n ['hour', [1, 2, 3, 4, 6, 8, 12]],\n ['day', [1, 2, 3, 4]],\n ['week', [1, 2, 3]],\n ['month', [1, 3, 6]],\n ['year', null]\n ]\n },\n /**\n * Data label options for the navigator series. Data labels are\n * disabled by default on the navigator series.\n *\n * @extends plotOptions.series.dataLabels\n */\n dataLabels: {\n enabled: false,\n zIndex: 2 // #1839\n },\n id: 'highcharts-navigator-series',\n className: 'highcharts-navigator-series',\n /**\n * Sets the fill color of the navigator series.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption navigator.series.color\n */\n /**\n * Line color for the navigator series. Allows setting the color\n * while disallowing the default candlestick setting.\n *\n * @type {Highcharts.ColorString|null}\n */\n lineColor: null,\n marker: {\n enabled: false\n },\n /**\n * Since Highcharts Stock v8, default value is the same as default\n * `pointRange` defined for a specific type (e.g. `null` for\n * column type).\n *\n * In Highcharts Stock version < 8, defaults to 0.\n *\n * @extends plotOptions.series.pointRange\n * @type {number|null}\n * @apioption navigator.series.pointRange\n */\n /**\n * The threshold option. Setting it to 0 will make the default\n * navigator area series draw its area from the 0 value and up.\n *\n * @type {number|null}\n */\n threshold: null\n },\n /**\n * Enable or disable navigator sticking to right, while adding new\n * points. If `undefined`, the navigator sticks to the axis maximum only\n * if it was already at the maximum prior to adding points.\n *\n * @type {boolean}\n * @default undefined\n * @since 10.2.1\n * @sample {highstock} stock/navigator/sticktomax-false/\n * stickToMax set to false\n * @apioption navigator.stickToMax\n */\n /**\n * Options for the navigator X axis. Default series options for the\n * navigator xAxis are:\n * ```js\n * xAxis: {\n * tickWidth: 0,\n * lineWidth: 0,\n * gridLineWidth: 1,\n * tickPixelInterval: 200,\n * labels: {\n * align: 'left',\n * style: {\n * color: '#888'\n * },\n * x: 3,\n * y: -4\n * }\n * }\n * ```\n *\n * @extends xAxis\n * @excluding linkedTo, maxZoom, minRange, opposite, range, scrollbar,\n * showEmpty, maxRange\n */\n xAxis: {\n /**\n * Additional range on the right side of the xAxis. Works similar to\n * xAxis.maxPadding, but value is set in milliseconds.\n * Can be set for both, main xAxis and navigator's xAxis.\n *\n * @since 6.0.0\n */\n overscroll: 0,\n className: 'highcharts-navigator-xaxis',\n tickLength: 0,\n lineWidth: 0,\n gridLineColor: \"#e6e6e6\" /* Palette.neutralColor10 */,\n gridLineWidth: 1,\n tickPixelInterval: 200,\n labels: {\n align: 'left',\n /**\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @ignore */\n color: \"#999999\" /* Palette.neutralColor40 */\n },\n x: 3,\n y: -4\n },\n crosshair: false\n },\n /**\n * Options for the navigator Y axis. Default series options for the\n * navigator yAxis are:\n * ```js\n * yAxis: {\n * gridLineWidth: 0,\n * startOnTick: false,\n * endOnTick: false,\n * minPadding: 0.1,\n * maxPadding: 0.1,\n * labels: {\n * enabled: false\n * },\n * title: {\n * text: null\n * },\n * tickWidth: 0\n * }\n * ```\n *\n * @extends yAxis\n * @excluding height, linkedTo, maxZoom, minRange, ordinal, range,\n * showEmpty, scrollbar, top, units, maxRange, minLength,\n * maxLength, resize\n */\n yAxis: {\n className: 'highcharts-navigator-yaxis',\n gridLineWidth: 0,\n startOnTick: false,\n endOnTick: false,\n minPadding: 0.1,\n maxPadding: 0.1,\n labels: {\n enabled: false\n },\n crosshair: false,\n title: {\n text: null\n },\n tickLength: 0,\n tickWidth: 0\n }\n };\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Maximum range which can be set using the navigator's handles.\n * Opposite of [xAxis.minRange](#xAxis.minRange).\n *\n * @sample {highstock} stock/navigator/maxrange/\n * Defined max and min range\n *\n * @type {number}\n * @since 6.0.0\n * @product highstock gantt\n * @apioption xAxis.maxRange\n */\n (''); // keeps doclets above in JS file\n\n return NavigatorDefaults;\n });\n _registerModule(_modules, 'Stock/Navigator/NavigatorSymbols.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n /**\n * Draw one of the handles on the side of the zoomed range in the navigator.\n * @private\n */\n function navigatorHandle(_x, _y, width, height, options) {\n if (options === void 0) { options = {}; }\n var halfWidth = options.width ? options.width / 2 : width,\n markerPosition = Math.round(halfWidth / 3) + 0.5;\n height = options.height || height;\n return [\n ['M', -halfWidth - 1, 0.5],\n ['L', halfWidth, 0.5],\n ['L', halfWidth, height + 0.5],\n ['L', -halfWidth - 1, height + 0.5],\n ['L', -halfWidth - 1, 0.5],\n ['M', -markerPosition, 4],\n ['L', -markerPosition, height - 3],\n ['M', markerPosition - 1, 4],\n ['L', markerPosition - 1, height - 3]\n ];\n }\n /* *\n *\n * Default Export\n *\n * */\n var NavigatorSymbols = {\n 'navigator-handle': navigatorHandle\n };\n\n return NavigatorSymbols;\n });\n _registerModule(_modules, 'Stock/Navigator/NavigatorComposition.js', [_modules['Core/Defaults.js'], _modules['Core/Globals.js'], _modules['Core/Axis/NavigatorAxisComposition.js'], _modules['Stock/Navigator/NavigatorDefaults.js'], _modules['Stock/Navigator/NavigatorSymbols.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Utilities.js']], function (D, H, NavigatorAxisAdditions, NavigatorDefaults, NavigatorSymbols, RendererRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var defaultOptions = D.defaultOptions,\n setOptions = D.setOptions;\n var isTouchDevice = H.isTouchDevice;\n var getRendererType = RendererRegistry.getRendererType;\n var addEvent = U.addEvent,\n extend = U.extend,\n merge = U.merge,\n pick = U.pick;\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Variables\n *\n * */\n var NavigatorConstructor;\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(AxisClass, ChartClass, NavigatorClass, SeriesClass) {\n NavigatorAxisAdditions.compose(AxisClass);\n NavigatorConstructor = NavigatorClass;\n if (composedClasses.indexOf(ChartClass) === -1) {\n composedClasses.push(ChartClass);\n var chartProto = ChartClass.prototype;\n chartProto.callbacks.push(onChartCallback);\n addEvent(ChartClass, 'afterAddSeries', onChartAfterAddSeries);\n addEvent(ChartClass, 'afterSetChartSize', onChartAfterSetChartSize);\n addEvent(ChartClass, 'afterUpdate', onChartAfterUpdate);\n addEvent(ChartClass, 'beforeRender', onChartBeforeRender);\n addEvent(ChartClass, 'beforeShowResetZoom', onChartBeforeShowResetZoom);\n addEvent(ChartClass, 'update', onChartUpdate);\n }\n if (composedClasses.indexOf(SeriesClass) === -1) {\n composedClasses.push(SeriesClass);\n addEvent(SeriesClass, 'afterUpdate', onSeriesAfterUpdate);\n }\n if (composedClasses.indexOf(getRendererType) === -1) {\n composedClasses.push(getRendererType);\n extend(getRendererType().prototype.symbols, NavigatorSymbols);\n }\n if (composedClasses.indexOf(setOptions) === -1) {\n composedClasses.push(setOptions);\n extend(defaultOptions, { navigator: NavigatorDefaults });\n }\n }\n /**\n * Handle adding new series.\n * @private\n */\n function onChartAfterAddSeries() {\n if (this.navigator) {\n // Recompute which series should be shown in navigator, and add them\n this.navigator.setBaseSeries(null, false);\n }\n }\n /**\n * For stock charts, extend the Chart.setChartSize method so that we can set the\n * final top position of the navigator once the height of the chart, including\n * the legend, is determined. #367. We can't use Chart.getMargins, because\n * labels offsets are not calculated yet.\n * @private\n */\n function onChartAfterSetChartSize() {\n var legend = this.legend,\n navigator = this.navigator;\n var scrollbarHeight,\n legendOptions,\n xAxis,\n yAxis;\n if (navigator) {\n legendOptions = legend && legend.options;\n xAxis = navigator.xAxis;\n yAxis = navigator.yAxis;\n scrollbarHeight = navigator.scrollbarHeight;\n // Compute the top position\n if (this.inverted) {\n navigator.left = navigator.opposite ?\n this.chartWidth - scrollbarHeight -\n navigator.height :\n this.spacing[3] + scrollbarHeight;\n navigator.top = this.plotTop + scrollbarHeight;\n }\n else {\n navigator.left = pick(xAxis.left, this.plotLeft + scrollbarHeight);\n navigator.top = navigator.navigatorOptions.top ||\n this.chartHeight -\n navigator.height -\n scrollbarHeight -\n this.spacing[2] -\n (this.rangeSelector && this.extraBottomMargin ?\n this.rangeSelector.getHeight() :\n 0) -\n ((legendOptions &&\n legendOptions.verticalAlign === 'bottom' &&\n legendOptions.layout !== 'proximate' && // #13392\n legendOptions.enabled &&\n !legendOptions.floating) ?\n legend.legendHeight +\n pick(legendOptions.margin, 10) :\n 0) -\n (this.titleOffset ? this.titleOffset[2] : 0);\n }\n if (xAxis && yAxis) { // false if navigator is disabled (#904)\n if (this.inverted) {\n xAxis.options.left = yAxis.options.left = navigator.left;\n }\n else {\n xAxis.options.top = yAxis.options.top = navigator.top;\n }\n xAxis.setAxisSize();\n yAxis.setAxisSize();\n }\n }\n }\n /**\n * Initialize navigator, if no scrolling exists yet.\n * @private\n */\n function onChartAfterUpdate(event) {\n if (!this.navigator && !this.scroller &&\n (this.options.navigator.enabled ||\n this.options.scrollbar.enabled)) {\n this.scroller = this.navigator = new NavigatorConstructor(this);\n if (pick(event.redraw, true)) {\n this.redraw(event.animation); // #7067\n }\n }\n }\n /**\n * Initialize navigator for stock charts\n * @private\n */\n function onChartBeforeRender() {\n var options = this.options;\n if (options.navigator.enabled ||\n options.scrollbar.enabled) {\n this.scroller = this.navigator = new NavigatorConstructor(this);\n }\n }\n /**\n * For Stock charts. For x only zooming, do not to create the zoom button\n * because X axis zooming is already allowed by the Navigator and Range\n * selector. (#9285)\n * @private\n */\n function onChartBeforeShowResetZoom() {\n var chartOptions = this.options,\n navigator = chartOptions.navigator,\n rangeSelector = chartOptions.rangeSelector;\n if (((navigator && navigator.enabled) ||\n (rangeSelector && rangeSelector.enabled)) &&\n ((!isTouchDevice &&\n chartOptions.chart.zooming.type === 'x') ||\n (isTouchDevice &&\n chartOptions.chart.zooming.pinchType === 'x'))) {\n return false;\n }\n }\n /**\n * @private\n */\n function onChartCallback(chart) {\n var navigator = chart.navigator;\n // Initialize the navigator\n if (navigator && chart.xAxis[0]) {\n var extremes = chart.xAxis[0].getExtremes();\n navigator.render(extremes.min, extremes.max);\n }\n }\n /**\n * Merge options, if no scrolling exists yet\n * @private\n */\n function onChartUpdate(e) {\n var navigatorOptions = (e.options.navigator || {}),\n scrollbarOptions = (e.options.scrollbar || {});\n if (!this.navigator && !this.scroller &&\n (navigatorOptions.enabled || scrollbarOptions.enabled)) {\n merge(true, this.options.navigator, navigatorOptions);\n merge(true, this.options.scrollbar, scrollbarOptions);\n delete e.options.navigator;\n delete e.options.scrollbar;\n }\n }\n /**\n * Handle updating series\n * @private\n */\n function onSeriesAfterUpdate() {\n if (this.chart.navigator && !this.options.isInternal) {\n this.chart.navigator.setBaseSeries(null, false);\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n var NavigatorComposition = {\n compose: compose\n };\n\n return NavigatorComposition;\n });\n _registerModule(_modules, 'Core/Axis/ScrollbarAxis.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var addEvent = U.addEvent,\n defined = U.defined,\n pick = U.pick;\n /* *\n *\n * Composition\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Creates scrollbars if enabled.\n * @private\n */\n var ScrollbarAxis = /** @class */ (function () {\n function ScrollbarAxis() {\n }\n /**\n * Attaches to axis events to create scrollbars if enabled.\n *\n * @private\n *\n * @param AxisClass\n * Axis class to extend.\n *\n * @param ScrollbarClass\n * Scrollbar class to use.\n */\n ScrollbarAxis.compose = function (AxisClass, ScrollbarClass) {\n if (ScrollbarAxis.composed.indexOf(AxisClass) === -1) {\n ScrollbarAxis.composed.push(AxisClass);\n }\n else {\n return AxisClass;\n }\n var getExtremes = function (axis) {\n var axisMin = pick(axis.options && axis.options.min,\n axis.min);\n var axisMax = pick(axis.options && axis.options.max,\n axis.max);\n return {\n axisMin: axisMin,\n axisMax: axisMax,\n scrollMin: defined(axis.dataMin) ?\n Math.min(axisMin, axis.min, axis.dataMin, pick(axis.threshold, Infinity)) : axisMin,\n scrollMax: defined(axis.dataMax) ?\n Math.max(axisMax, axis.max, axis.dataMax, pick(axis.threshold, -Infinity)) : axisMax\n };\n };\n // Wrap axis initialization and create scrollbar if enabled:\n addEvent(AxisClass, 'afterInit', function () {\n var axis = this;\n if (axis.options &&\n axis.options.scrollbar &&\n axis.options.scrollbar.enabled) {\n // Predefined options:\n axis.options.scrollbar.vertical = !axis.horiz;\n axis.options.startOnTick = axis.options.endOnTick = false;\n axis.scrollbar = new ScrollbarClass(axis.chart.renderer, axis.options.scrollbar, axis.chart);\n addEvent(axis.scrollbar, 'changed', function (e) {\n var _a = getExtremes(axis),\n axisMin = _a.axisMin,\n axisMax = _a.axisMax,\n unitedMin = _a.scrollMin,\n unitedMax = _a.scrollMax,\n range = unitedMax - unitedMin,\n to,\n from;\n // #12834, scroll when show/hide series, wrong extremes\n if (!defined(axisMin) || !defined(axisMax)) {\n return;\n }\n if ((axis.horiz && !axis.reversed) ||\n (!axis.horiz && axis.reversed)) {\n to = unitedMin + range * this.to;\n from = unitedMin + range * this.from;\n }\n else {\n // y-values in browser are reversed, but this also\n // applies for reversed horizontal axis:\n to = unitedMin + range * (1 - this.from);\n from = unitedMin + range * (1 - this.to);\n }\n if (this.shouldUpdateExtremes(e.DOMType)) {\n axis.setExtremes(from, to, true, (e.DOMType !== 'mousemove' &&\n e.DOMType !== 'touchmove'), e);\n }\n else {\n // When live redraw is disabled, don't change extremes\n // Only change the position of the scollbar thumb\n this.setRange(this.from, this.to);\n }\n });\n }\n });\n // Wrap rendering axis, and update scrollbar if one is created:\n addEvent(AxisClass, 'afterRender', function () {\n var axis = this,\n _a = getExtremes(axis),\n scrollMin = _a.scrollMin,\n scrollMax = _a.scrollMax,\n scrollbar = axis.scrollbar,\n offset = (axis.axisTitleMargin + (axis.titleOffset || 0)),\n scrollbarsOffsets = axis.chart.scrollbarsOffsets,\n axisMargin = axis.options.margin || 0,\n offsetsIndex,\n from,\n to;\n if (scrollbar) {\n if (axis.horiz) {\n // Reserve space for labels/title\n if (!axis.opposite) {\n scrollbarsOffsets[1] += offset;\n }\n scrollbar.position(axis.left, (axis.top +\n axis.height +\n 2 +\n scrollbarsOffsets[1] -\n (axis.opposite ? axisMargin : 0)), axis.width, axis.height);\n // Next scrollbar should reserve space for margin (if set)\n if (!axis.opposite) {\n scrollbarsOffsets[1] += axisMargin;\n }\n offsetsIndex = 1;\n }\n else {\n // Reserve space for labels/title\n if (axis.opposite) {\n scrollbarsOffsets[0] += offset;\n }\n var xPosition = void 0;\n if (!scrollbar.options.opposite) {\n xPosition = axis.opposite ? 0 : axisMargin;\n }\n else {\n xPosition = axis.left +\n axis.width +\n 2 +\n scrollbarsOffsets[0] -\n (axis.opposite ? 0 : axisMargin);\n }\n scrollbar.position(xPosition, axis.top, axis.width, axis.height);\n // Next scrollbar should reserve space for margin (if set)\n if (axis.opposite) {\n scrollbarsOffsets[0] += axisMargin;\n }\n offsetsIndex = 0;\n }\n scrollbarsOffsets[offsetsIndex] += scrollbar.size +\n scrollbar.options.margin;\n if (isNaN(scrollMin) ||\n isNaN(scrollMax) ||\n !defined(axis.min) ||\n !defined(axis.max) ||\n axis.min === axis.max // #10733\n ) {\n // default action: when extremes are the same or there is\n // not extremes on the axis, but scrollbar exists, make it\n // full size\n scrollbar.setRange(0, 1);\n }\n else {\n from = ((axis.min - scrollMin) /\n (scrollMax - scrollMin));\n to = ((axis.max - scrollMin) /\n (scrollMax - scrollMin));\n if ((axis.horiz && !axis.reversed) ||\n (!axis.horiz && axis.reversed)) {\n scrollbar.setRange(from, to);\n }\n else {\n // inverse vertical axis\n scrollbar.setRange(1 - to, 1 - from);\n }\n }\n }\n });\n // Make space for a scrollbar:\n addEvent(AxisClass, 'afterGetOffset', function () {\n var axis = this,\n opposite = axis.scrollbar && !axis.scrollbar.options.opposite,\n index = axis.horiz ? 2 : opposite ? 3 : 1,\n scrollbar = axis.scrollbar;\n if (scrollbar) {\n // reset scrollbars offsets\n axis.chart.scrollbarsOffsets = [0, 0];\n axis.chart.axisOffset[index] +=\n scrollbar.size + scrollbar.options.margin;\n }\n });\n return AxisClass;\n };\n ScrollbarAxis.composed = [];\n return ScrollbarAxis;\n }());\n\n return ScrollbarAxis;\n });\n _registerModule(_modules, 'Stock/Scrollbar/ScrollbarDefaults.js', [_modules['Core/Globals.js']], function (H) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var isTouchDevice = H.isTouchDevice;\n /* *\n *\n * Constant\n *\n * */\n /**\n *\n * The scrollbar is a means of panning over the X axis of a stock chart.\n * Scrollbars can also be applied to other types of axes.\n *\n * Another approach to scrollable charts is the [chart.scrollablePlotArea](\n * https://api.highcharts.com/highcharts/chart.scrollablePlotArea) option that\n * is especially suitable for simpler cartesian charts on mobile.\n *\n * In styled mode, all the presentational options for the\n * scrollbar are replaced by the classes `.highcharts-scrollbar-thumb`,\n * `.highcharts-scrollbar-arrow`, `.highcharts-scrollbar-button`,\n * `.highcharts-scrollbar-rifles` and `.highcharts-scrollbar-track`.\n *\n * @sample stock/yaxis/inverted-bar-scrollbar/\n * A scrollbar on a simple bar chart\n *\n * @product highstock gantt\n * @optionparent scrollbar\n *\n * @private\n */\n var ScrollbarDefaults = {\n /**\n * The height of the scrollbar. The height also applies to the width\n * of the scroll arrows so that they are always squares. Defaults to\n * 20 for touch devices and 14 for mouse devices.\n *\n * @sample stock/scrollbar/height/\n * A 30px scrollbar\n *\n * @type {number}\n * @default 20/14\n */\n height: isTouchDevice ? 20 : 14,\n /**\n * The border rounding radius of the bar.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n barBorderRadius: 0,\n /**\n * The corner radius of the scrollbar buttons.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n buttonBorderRadius: 0,\n /**\n * Enable or disable the scrollbar.\n *\n * @sample stock/scrollbar/enabled/\n * Disable the scrollbar,\n only use navigator\n *\n * @type {boolean}\n * @default true\n * @apioption scrollbar.enabled\n */\n /**\n * Whether to redraw the main chart as the scrollbar or the navigator\n * zoomed window is moved. Defaults to `true` for modern browsers and\n * `false` for legacy IE browsers as well as mobile devices.\n *\n * @sample stock/scrollbar/liveredraw\n * Setting live redraw to false\n *\n * @type {boolean}\n * @since 1.3\n */\n liveRedraw: void 0,\n /**\n * The margin between the scrollbar and its axis when the scrollbar is\n * applied directly to an axis.\n */\n margin: 10,\n /**\n * The minimum width of the scrollbar.\n *\n * @since 1.2.5\n */\n minWidth: 6,\n /** @ignore-option */\n opposite: true,\n /**\n * Whether to show or hide the scrollbar when the scrolled content is\n * zoomed out to it full extent.\n *\n * @type {boolean}\n * @default true\n * @apioption scrollbar.showFull\n */\n step: 0.2,\n /**\n * The z index of the scrollbar group.\n */\n zIndex: 3,\n /**\n * The background color of the scrollbar itself.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n barBackgroundColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * The width of the bar's border.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n barBorderWidth: 1,\n /**\n * The color of the scrollbar's border.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n barBorderColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * The color of the small arrow inside the scrollbar buttons.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n buttonArrowColor: \"#333333\" /* Palette.neutralColor80 */,\n /**\n * The color of scrollbar buttons.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n buttonBackgroundColor: \"#e6e6e6\" /* Palette.neutralColor10 */,\n /**\n * The color of the border of the scrollbar buttons.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n buttonBorderColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * The border width of the scrollbar buttons.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n buttonBorderWidth: 1,\n /**\n * The color of the small rifles in the middle of the scrollbar.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n rifleColor: \"#333333\" /* Palette.neutralColor80 */,\n /**\n * The color of the track background.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n trackBackgroundColor: \"#f2f2f2\" /* Palette.neutralColor5 */,\n /**\n * The color of the border of the scrollbar track.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n trackBorderColor: \"#f2f2f2\" /* Palette.neutralColor5 */,\n /**\n * The corner radius of the border of the scrollbar track.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {number}\n * @default 0\n * @apioption scrollbar.trackBorderRadius\n */\n /**\n * The width of the border of the scrollbar track.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n trackBorderWidth: 1\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return ScrollbarDefaults;\n });\n _registerModule(_modules, 'Stock/Scrollbar/Scrollbar.js', [_modules['Core/Defaults.js'], _modules['Core/Globals.js'], _modules['Core/Axis/ScrollbarAxis.js'], _modules['Stock/Scrollbar/ScrollbarDefaults.js'], _modules['Core/Utilities.js']], function (D, H, ScrollbarAxis, ScrollbarDefaults, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var defaultOptions = D.defaultOptions;\n var addEvent = U.addEvent,\n correctFloat = U.correctFloat,\n defined = U.defined,\n destroyObjectProperties = U.destroyObjectProperties,\n fireEvent = U.fireEvent,\n merge = U.merge,\n pick = U.pick,\n removeEvent = U.removeEvent;\n /* *\n *\n * Constants\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * A reusable scrollbar, internally used in Highcharts Stock's\n * navigator and optionally on individual axes.\n *\n * @private\n * @class\n * @name Highcharts.Scrollbar\n * @param {Highcharts.SVGRenderer} renderer\n * @param {Highcharts.ScrollbarOptions} options\n * @param {Highcharts.Chart} chart\n */\n var Scrollbar = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n function Scrollbar(renderer, options, chart) {\n /* *\n *\n * Properties\n *\n * */\n this._events = [];\n this.chart = void 0;\n this.chartX = 0;\n this.chartY = 0;\n this.from = 0;\n this.group = void 0;\n this.options = void 0;\n this.renderer = void 0;\n this.scrollbar = void 0;\n this.scrollbarButtons = [];\n this.scrollbarGroup = void 0;\n this.scrollbarLeft = 0;\n this.scrollbarRifles = void 0;\n this.scrollbarStrokeWidth = 1;\n this.scrollbarTop = 0;\n this.size = 0;\n this.to = 0;\n this.track = void 0;\n this.trackBorderWidth = 1;\n this.userOptions = void 0;\n this.x = 0;\n this.y = 0;\n this.init(renderer, options, chart);\n }\n /* *\n *\n * Static Functions\n *\n * */\n Scrollbar.compose = function (AxisClass) {\n ScrollbarAxis.compose(AxisClass, Scrollbar);\n };\n /**\n * When we have vertical scrollbar, rifles and arrow in buttons should be\n * rotated. The same method is used in Navigator's handles, to rotate them.\n *\n * @function Highcharts.swapXY\n *\n * @param {Highcharts.SVGPathArray} path\n * Path to be rotated.\n *\n * @param {boolean} [vertical]\n * If vertical scrollbar, swap x-y values.\n *\n * @return {Highcharts.SVGPathArray}\n * Rotated path.\n *\n * @requires modules/stock\n */\n Scrollbar.swapXY = function (path, vertical) {\n if (vertical) {\n path.forEach(function (seg) {\n var len = seg.length;\n var temp;\n for (var i = 0; i < len; i += 2) {\n temp = seg[i + 1];\n if (typeof temp === 'number') {\n seg[i + 1] = seg[i + 2];\n seg[i + 2] = temp;\n }\n }\n });\n }\n return path;\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set up the mouse and touch events for the Scrollbar\n *\n * @private\n * @function Highcharts.Scrollbar#addEvents\n */\n Scrollbar.prototype.addEvents = function () {\n var buttonsOrder = this.options.inverted ? [1, 0] : [0, 1],\n buttons = this.scrollbarButtons,\n bar = this.scrollbarGroup.element,\n track = this.track.element,\n mouseDownHandler = this.mouseDownHandler.bind(this),\n mouseMoveHandler = this.mouseMoveHandler.bind(this),\n mouseUpHandler = this.mouseUpHandler.bind(this);\n // Mouse events\n var _events = [\n [\n buttons[buttonsOrder[0]].element,\n 'click',\n this.buttonToMinClick.bind(this)\n ],\n [\n buttons[buttonsOrder[1]].element,\n 'click',\n this.buttonToMaxClick.bind(this)\n ],\n [track, 'click',\n this.trackClick.bind(this)],\n [bar, 'mousedown',\n mouseDownHandler],\n [bar.ownerDocument, 'mousemove',\n mouseMoveHandler],\n [bar.ownerDocument, 'mouseup',\n mouseUpHandler]\n ];\n // Touch events\n if (H.hasTouch) {\n _events.push([bar, 'touchstart', mouseDownHandler], [bar.ownerDocument, 'touchmove', mouseMoveHandler], [bar.ownerDocument, 'touchend', mouseUpHandler]);\n }\n // Add them all\n _events.forEach(function (args) {\n addEvent.apply(null, args);\n });\n this._events = _events;\n };\n Scrollbar.prototype.buttonToMaxClick = function (e) {\n var scroller = this;\n var range = ((scroller.to - scroller.from) *\n pick(scroller.options.step, 0.2));\n scroller.updatePosition(scroller.from + range, scroller.to + range);\n fireEvent(scroller, 'changed', {\n from: scroller.from,\n to: scroller.to,\n trigger: 'scrollbar',\n DOMEvent: e\n });\n };\n Scrollbar.prototype.buttonToMinClick = function (e) {\n var scroller = this;\n var range = correctFloat(scroller.to - scroller.from) *\n pick(scroller.options.step, 0.2);\n scroller.updatePosition(correctFloat(scroller.from - range), correctFloat(scroller.to - range));\n fireEvent(scroller, 'changed', {\n from: scroller.from,\n to: scroller.to,\n trigger: 'scrollbar',\n DOMEvent: e\n });\n };\n /**\n * Get normalized (0-1) cursor position over the scrollbar\n *\n * @private\n * @function Highcharts.Scrollbar#cursorToScrollbarPosition\n *\n * @param {*} normalizedEvent\n * normalized event, with chartX and chartY values\n *\n * @return {Highcharts.Dictionary}\n * Local position {chartX, chartY}\n */\n Scrollbar.prototype.cursorToScrollbarPosition = function (normalizedEvent) {\n var scroller = this,\n options = scroller.options,\n minWidthDifference = options.minWidth > scroller.calculatedWidth ?\n options.minWidth :\n 0; // minWidth distorts translation\n return {\n chartX: (normalizedEvent.chartX - scroller.x -\n scroller.xOffset) /\n (scroller.barWidth - minWidthDifference),\n chartY: (normalizedEvent.chartY - scroller.y -\n scroller.yOffset) /\n (scroller.barWidth - minWidthDifference)\n };\n };\n /**\n * Destroys allocated elements.\n *\n * @private\n * @function Highcharts.Scrollbar#destroy\n */\n Scrollbar.prototype.destroy = function () {\n var scroller = this,\n navigator = scroller.chart.scroller;\n // Disconnect events added in addEvents\n scroller.removeEvents();\n // Destroy properties\n [\n 'track',\n 'scrollbarRifles',\n 'scrollbar',\n 'scrollbarGroup',\n 'group'\n ].forEach(function (prop) {\n if (scroller[prop] && scroller[prop].destroy) {\n scroller[prop] = scroller[prop].destroy();\n }\n });\n // #6421, chart may have more scrollbars\n if (navigator && scroller === navigator.scrollbar) {\n navigator.scrollbar = null;\n // Destroy elements in collection\n destroyObjectProperties(navigator.scrollbarButtons);\n }\n };\n /**\n * Draw the scrollbar buttons with arrows\n *\n * @private\n * @function Highcharts.Scrollbar#drawScrollbarButton\n * @param {number} index\n * 0 is left, 1 is right\n */\n Scrollbar.prototype.drawScrollbarButton = function (index) {\n var scroller = this,\n renderer = scroller.renderer,\n scrollbarButtons = scroller.scrollbarButtons,\n options = scroller.options,\n size = scroller.size,\n group = renderer.g().add(scroller.group);\n var tempElem;\n scrollbarButtons.push(group);\n // Create a rectangle for the scrollbar button\n tempElem = renderer.rect()\n .addClass('highcharts-scrollbar-button')\n .add(group);\n // Presentational attributes\n if (!scroller.chart.styledMode) {\n tempElem.attr({\n stroke: options.buttonBorderColor,\n 'stroke-width': options.buttonBorderWidth,\n fill: options.buttonBackgroundColor\n });\n }\n // Place the rectangle based on the rendered stroke width\n tempElem.attr(tempElem.crisp({\n x: -0.5,\n y: -0.5,\n width: size + 1,\n height: size + 1,\n r: options.buttonBorderRadius\n }, tempElem.strokeWidth()));\n // Button arrow\n tempElem = renderer\n .path(Scrollbar.swapXY([[\n 'M',\n size / 2 + (index ? -1 : 1),\n size / 2 - 3\n ], [\n 'L',\n size / 2 + (index ? -1 : 1),\n size / 2 + 3\n ], [\n 'L',\n size / 2 + (index ? 2 : -2),\n size / 2\n ]], options.vertical))\n .addClass('highcharts-scrollbar-arrow')\n .add(scrollbarButtons[index]);\n if (!scroller.chart.styledMode) {\n tempElem.attr({\n fill: options.buttonArrowColor\n });\n }\n };\n /**\n * @private\n * @function Highcharts.Scrollbar#init\n * @param {Highcharts.SVGRenderer} renderer\n * @param {Highcharts.ScrollbarOptions} options\n * @param {Highcharts.Chart} chart\n */\n Scrollbar.prototype.init = function (renderer, options, chart) {\n var scroller = this;\n scroller.scrollbarButtons = [];\n scroller.renderer = renderer;\n scroller.userOptions = options;\n scroller.options = merge(ScrollbarDefaults, defaultOptions.scrollbar, options);\n scroller.chart = chart;\n // backward compatibility\n scroller.size = pick(scroller.options.size, scroller.options.height);\n // Init\n if (options.enabled) {\n scroller.render();\n scroller.addEvents();\n }\n };\n Scrollbar.prototype.mouseDownHandler = function (e) {\n var scroller = this,\n normalizedEvent = scroller.chart.pointer.normalize(e),\n mousePosition = scroller.cursorToScrollbarPosition(normalizedEvent);\n scroller.chartX = mousePosition.chartX;\n scroller.chartY = mousePosition.chartY;\n scroller.initPositions = [scroller.from, scroller.to];\n scroller.grabbedCenter = true;\n };\n /**\n * Event handler for the mouse move event.\n * @private\n */\n Scrollbar.prototype.mouseMoveHandler = function (e) {\n var scroller = this,\n normalizedEvent = scroller.chart.pointer.normalize(e),\n options = scroller.options,\n direction = options.vertical ?\n 'chartY' : 'chartX',\n initPositions = scroller.initPositions || [];\n var scrollPosition,\n chartPosition,\n change;\n // In iOS, a mousemove event with e.pageX === 0 is fired when\n // holding the finger down in the center of the scrollbar. This\n // should be ignored.\n if (scroller.grabbedCenter &&\n // #4696, scrollbar failed on Android\n (!e.touches || e.touches[0][direction] !== 0)) {\n chartPosition = scroller.cursorToScrollbarPosition(normalizedEvent)[direction];\n scrollPosition = scroller[direction];\n change = chartPosition - scrollPosition;\n scroller.hasDragged = true;\n scroller.updatePosition(initPositions[0] + change, initPositions[1] + change);\n if (scroller.hasDragged) {\n fireEvent(scroller, 'changed', {\n from: scroller.from,\n to: scroller.to,\n trigger: 'scrollbar',\n DOMType: e.type,\n DOMEvent: e\n });\n }\n }\n };\n /**\n * Event handler for the mouse up event.\n * @private\n */\n Scrollbar.prototype.mouseUpHandler = function (e) {\n var scroller = this;\n if (scroller.hasDragged) {\n fireEvent(scroller, 'changed', {\n from: scroller.from,\n to: scroller.to,\n trigger: 'scrollbar',\n DOMType: e.type,\n DOMEvent: e\n });\n }\n scroller.grabbedCenter =\n scroller.hasDragged =\n scroller.chartX =\n scroller.chartY = null;\n };\n /**\n * Position the scrollbar, method called from a parent with defined\n * dimensions.\n *\n * @private\n * @function Highcharts.Scrollbar#position\n * @param {number} x\n * x-position on the chart\n * @param {number} y\n * y-position on the chart\n * @param {number} width\n * width of the scrollbar\n * @param {number} height\n * height of the scorllbar\n */\n Scrollbar.prototype.position = function (x, y, width, height) {\n var scroller = this,\n options = scroller.options,\n vertical = options.vertical,\n method = scroller.rendered ? 'animate' : 'attr';\n var xOffset = height,\n yOffset = 0;\n // Make the scrollbar visible when it is repositioned, #15763.\n scroller.group.show();\n scroller.x = x;\n scroller.y = y + this.trackBorderWidth;\n scroller.width = width; // width with buttons\n scroller.height = height;\n scroller.xOffset = xOffset;\n scroller.yOffset = yOffset;\n // If Scrollbar is a vertical type, swap options:\n if (vertical) {\n scroller.width = scroller.yOffset = width = yOffset = scroller.size;\n scroller.xOffset = xOffset = 0;\n scroller.barWidth = height - width * 2; // width without buttons\n scroller.x = x = x + scroller.options.margin;\n }\n else {\n scroller.height = scroller.xOffset = height = xOffset =\n scroller.size;\n scroller.barWidth = width - height * 2; // width without buttons\n scroller.y = scroller.y + scroller.options.margin;\n }\n // Set general position for a group:\n scroller.group[method]({\n translateX: x,\n translateY: scroller.y\n });\n // Resize background/track:\n scroller.track[method]({\n width: width,\n height: height\n });\n // Move right/bottom button ot it's place:\n scroller.scrollbarButtons[1][method]({\n translateX: vertical ? 0 : width - xOffset,\n translateY: vertical ? height - yOffset : 0\n });\n };\n /**\n * Removes the event handlers attached previously with addEvents.\n *\n * @private\n * @function Highcharts.Scrollbar#removeEvents\n */\n Scrollbar.prototype.removeEvents = function () {\n this._events.forEach(function (args) {\n removeEvent.apply(null, args);\n });\n this._events.length = 0;\n };\n /**\n * Render scrollbar with all required items.\n *\n * @private\n * @function Highcharts.Scrollbar#render\n */\n Scrollbar.prototype.render = function () {\n var scroller = this,\n renderer = scroller.renderer,\n options = scroller.options,\n size = scroller.size,\n styledMode = scroller.chart.styledMode,\n group = renderer.g('scrollbar')\n .attr({\n zIndex: options.zIndex\n })\n .hide() // initially hide the scrollbar #15863\n .add();\n // Draw the scrollbar group\n scroller.group = group;\n // Draw the scrollbar track:\n scroller.track = renderer.rect()\n .addClass('highcharts-scrollbar-track')\n .attr({\n x: 0,\n r: options.trackBorderRadius || 0,\n height: size,\n width: size\n }).add(group);\n if (!styledMode) {\n scroller.track.attr({\n fill: options.trackBackgroundColor,\n stroke: options.trackBorderColor,\n 'stroke-width': options.trackBorderWidth\n });\n }\n scroller.trackBorderWidth = scroller.track.strokeWidth();\n scroller.track.attr({\n y: -this.trackBorderWidth % 2 / 2\n });\n // Draw the scrollbar itself\n scroller.scrollbarGroup = renderer.g().add(group);\n scroller.scrollbar = renderer.rect()\n .addClass('highcharts-scrollbar-thumb')\n .attr({\n height: size,\n width: size,\n r: options.barBorderRadius || 0\n }).add(scroller.scrollbarGroup);\n scroller.scrollbarRifles = renderer\n .path(Scrollbar.swapXY([\n ['M', -3, size / 4],\n ['L', -3, 2 * size / 3],\n ['M', 0, size / 4],\n ['L', 0, 2 * size / 3],\n ['M', 3, size / 4],\n ['L', 3, 2 * size / 3]\n ], options.vertical))\n .addClass('highcharts-scrollbar-rifles')\n .add(scroller.scrollbarGroup);\n if (!styledMode) {\n scroller.scrollbar.attr({\n fill: options.barBackgroundColor,\n stroke: options.barBorderColor,\n 'stroke-width': options.barBorderWidth\n });\n scroller.scrollbarRifles.attr({\n stroke: options.rifleColor,\n 'stroke-width': 1\n });\n }\n scroller.scrollbarStrokeWidth = scroller.scrollbar.strokeWidth();\n scroller.scrollbarGroup.translate(-scroller.scrollbarStrokeWidth % 2 / 2, -scroller.scrollbarStrokeWidth % 2 / 2);\n // Draw the buttons:\n scroller.drawScrollbarButton(0);\n scroller.drawScrollbarButton(1);\n };\n /**\n * Set scrollbar size, with a given scale.\n *\n * @private\n * @function Highcharts.Scrollbar#setRange\n * @param {number} from\n * scale (0-1) where bar should start\n * @param {number} to\n * scale (0-1) where bar should end\n */\n Scrollbar.prototype.setRange = function (from, to) {\n var scroller = this,\n options = scroller.options,\n vertical = options.vertical,\n minWidth = options.minWidth,\n fullWidth = scroller.barWidth,\n method = (this.rendered &&\n !this.hasDragged &&\n !(this.chart.navigator && this.chart.navigator.hasDragged)) ? 'animate' : 'attr';\n if (!defined(fullWidth)) {\n return;\n }\n var toPX = fullWidth * Math.min(to, 1);\n var fromPX,\n newSize;\n from = Math.max(from, 0);\n fromPX = Math.ceil(fullWidth * from);\n scroller.calculatedWidth = newSize = correctFloat(toPX - fromPX);\n // We need to recalculate position, if minWidth is used\n if (newSize < minWidth) {\n fromPX = (fullWidth - minWidth + newSize) * from;\n newSize = minWidth;\n }\n var newPos = Math.floor(fromPX + scroller.xOffset + scroller.yOffset);\n var newRiflesPos = newSize / 2 - 0.5; // -0.5 -> rifle line width / 2\n // Store current position:\n scroller.from = from;\n scroller.to = to;\n if (!vertical) {\n scroller.scrollbarGroup[method]({\n translateX: newPos\n });\n scroller.scrollbar[method]({\n width: newSize\n });\n scroller.scrollbarRifles[method]({\n translateX: newRiflesPos\n });\n scroller.scrollbarLeft = newPos;\n scroller.scrollbarTop = 0;\n }\n else {\n scroller.scrollbarGroup[method]({\n translateY: newPos\n });\n scroller.scrollbar[method]({\n height: newSize\n });\n scroller.scrollbarRifles[method]({\n translateY: newRiflesPos\n });\n scroller.scrollbarTop = newPos;\n scroller.scrollbarLeft = 0;\n }\n if (newSize <= 12) {\n scroller.scrollbarRifles.hide();\n }\n else {\n scroller.scrollbarRifles.show();\n }\n // Show or hide the scrollbar based on the showFull setting\n if (options.showFull === false) {\n if (from <= 0 && to >= 1) {\n scroller.group.hide();\n }\n else {\n scroller.group.show();\n }\n }\n scroller.rendered = true;\n };\n /**\n * Checks if the extremes should be updated in response to a scrollbar\n * change event.\n *\n * @private\n * @function Highcharts.Scrollbar#shouldUpdateExtremes\n */\n Scrollbar.prototype.shouldUpdateExtremes = function (eventType) {\n return (pick(this.options.liveRedraw, H.svg &&\n !H.isTouchDevice &&\n !this.chart.boosted) ||\n // Mouseup always should change extremes\n eventType === 'mouseup' ||\n eventType === 'touchend' ||\n // Internal events\n !defined(eventType));\n };\n Scrollbar.prototype.trackClick = function (e) {\n var scroller = this;\n var normalizedEvent = scroller.chart.pointer.normalize(e),\n range = scroller.to - scroller.from,\n top = scroller.y + scroller.scrollbarTop,\n left = scroller.x + scroller.scrollbarLeft;\n if ((scroller.options.vertical && normalizedEvent.chartY > top) ||\n (!scroller.options.vertical && normalizedEvent.chartX > left)) {\n // On the top or on the left side of the track:\n scroller.updatePosition(scroller.from + range, scroller.to + range);\n }\n else {\n // On the bottom or the right side of the track:\n scroller.updatePosition(scroller.from - range, scroller.to - range);\n }\n fireEvent(scroller, 'changed', {\n from: scroller.from,\n to: scroller.to,\n trigger: 'scrollbar',\n DOMEvent: e\n });\n };\n /**\n * Update the scrollbar with new options\n *\n * @private\n * @function Highcharts.Scrollbar#update\n * @param {Highcharts.ScrollbarOptions} options\n */\n Scrollbar.prototype.update = function (options) {\n this.destroy();\n this.init(this.chart.renderer, merge(true, this.options, options), this.chart);\n };\n /**\n * Update position option in the Scrollbar, with normalized 0-1 scale\n *\n * @private\n * @function Highcharts.Scrollbar#updatePosition\n * @param {number} from\n * @param {number} to\n */\n Scrollbar.prototype.updatePosition = function (from, to) {\n if (to > 1) {\n from = correctFloat(1 - correctFloat(to - from));\n to = 1;\n }\n if (from < 0) {\n to = correctFloat(to - from);\n from = 0;\n }\n this.from = from;\n this.to = to;\n };\n /* *\n *\n * Static Properties\n *\n * */\n Scrollbar.defaultOptions = ScrollbarDefaults;\n return Scrollbar;\n }());\n /* *\n *\n * Registry\n *\n * */\n defaultOptions.scrollbar = merge(true, Scrollbar.defaultOptions, defaultOptions.scrollbar);\n /* *\n *\n * Default Export\n *\n * */\n\n return Scrollbar;\n });\n _registerModule(_modules, 'Stock/Navigator/Navigator.js', [_modules['Core/Axis/Axis.js'], _modules['Core/Defaults.js'], _modules['Core/Globals.js'], _modules['Core/Axis/NavigatorAxisComposition.js'], _modules['Stock/Navigator/NavigatorComposition.js'], _modules['Stock/Scrollbar/Scrollbar.js'], _modules['Core/Utilities.js']], function (Axis, D, H, NavigatorAxisAdditions, NavigatorComposition, Scrollbar, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var defaultOptions = D.defaultOptions;\n var hasTouch = H.hasTouch,\n isTouchDevice = H.isTouchDevice;\n var addEvent = U.addEvent,\n clamp = U.clamp,\n correctFloat = U.correctFloat,\n defined = U.defined,\n destroyObjectProperties = U.destroyObjectProperties,\n erase = U.erase,\n extend = U.extend,\n find = U.find,\n isArray = U.isArray,\n isNumber = U.isNumber,\n merge = U.merge,\n pick = U.pick,\n removeEvent = U.removeEvent,\n splat = U.splat;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Finding the min or max of a set of variables where we don't know if they are\n * defined, is a pattern that is repeated several places in Highcharts. Consider\n * making this a global utility method.\n * @private\n */\n function numExt(extreme) {\n var args = [];\n for (var _i = 1; _i < arguments.length; _i++) {\n args[_i - 1] = arguments[_i];\n }\n var numbers = [].filter.call(args,\n isNumber);\n if (numbers.length) {\n return Math[extreme].apply(0, numbers);\n }\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * The Navigator class\n *\n * @private\n * @class\n * @name Highcharts.Navigator\n *\n * @param {Highcharts.Chart} chart\n * Chart object\n */\n var Navigator = /** @class */ (function () {\n /* *\n *\n * Constructor\n *\n * */\n function Navigator(chart) {\n /* *\n *\n * Properties\n *\n * */\n this.baseSeries = void 0;\n this.chart = void 0;\n this.handles = void 0;\n this.height = void 0;\n this.left = void 0;\n this.navigatorEnabled = void 0;\n this.navigatorGroup = void 0;\n this.navigatorOptions = void 0;\n this.navigatorSeries = void 0;\n this.navigatorSize = void 0;\n this.opposite = void 0;\n this.outline = void 0;\n this.outlineHeight = void 0;\n this.range = void 0;\n this.rendered = void 0;\n this.shades = void 0;\n this.size = void 0;\n this.top = void 0;\n this.xAxis = void 0;\n this.yAxis = void 0;\n this.zoomedMax = void 0;\n this.zoomedMin = void 0;\n this.init(chart);\n }\n /* *\n *\n * Static Functions\n *\n * */\n Navigator.compose = function (AxisClass, ChartClass, SeriesClass) {\n NavigatorComposition.compose(AxisClass, ChartClass, Navigator, SeriesClass);\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Draw one of the handles on the side of the zoomed range in the navigator.\n *\n * @private\n * @function Highcharts.Navigator#drawHandle\n *\n * @param {number} x\n * The x center for the handle\n *\n * @param {number} index\n * 0 for left and 1 for right\n *\n * @param {boolean|undefined} inverted\n * Flag for chart.inverted\n *\n * @param {string} verb\n * Use 'animate' or 'attr'\n */\n Navigator.prototype.drawHandle = function (x, index, inverted, verb) {\n var navigator = this,\n height = navigator.navigatorOptions.handles.height;\n // Place it\n navigator.handles[index][verb](inverted ? {\n translateX: Math.round(navigator.left + navigator.height / 2),\n translateY: Math.round(navigator.top + parseInt(x, 10) + 0.5 - height)\n } : {\n translateX: Math.round(navigator.left + parseInt(x, 10)),\n translateY: Math.round(navigator.top + navigator.height / 2 - height / 2 - 1)\n });\n };\n /**\n * Render outline around the zoomed range\n *\n * @private\n * @function Highcharts.Navigator#drawOutline\n *\n * @param {number} zoomedMin\n * in pixels position where zoomed range starts\n *\n * @param {number} zoomedMax\n * in pixels position where zoomed range ends\n *\n * @param {boolean|undefined} inverted\n * flag if chart is inverted\n *\n * @param {string} verb\n * use 'animate' or 'attr'\n */\n Navigator.prototype.drawOutline = function (zoomedMin, zoomedMax, inverted, verb) {\n var navigator = this,\n maskInside = navigator.navigatorOptions.maskInside,\n outlineWidth = navigator.outline.strokeWidth(),\n halfOutline = outlineWidth / 2,\n outlineCorrection = (outlineWidth % 2) / 2, // #5800\n outlineHeight = navigator.outlineHeight,\n scrollbarHeight = navigator.scrollbarHeight || 0,\n navigatorSize = navigator.size;\n var left = navigator.left - scrollbarHeight,\n navigatorTop = navigator.top,\n verticalMin,\n path;\n if (inverted) {\n left -= halfOutline;\n verticalMin = navigatorTop + zoomedMax + outlineCorrection;\n zoomedMax = navigatorTop + zoomedMin + outlineCorrection;\n path = [\n [\n 'M',\n left + outlineHeight,\n navigatorTop - scrollbarHeight - outlineCorrection\n ],\n // top right of zoomed range\n ['L', left + outlineHeight, verticalMin],\n ['L', left, verticalMin],\n ['L', left, zoomedMax],\n ['L', left + outlineHeight, zoomedMax],\n [\n 'L',\n left + outlineHeight,\n navigatorTop + navigatorSize + scrollbarHeight\n ]\n ];\n if (maskInside) {\n path.push(\n // upper left of zoomed range\n ['M', left + outlineHeight, verticalMin - halfOutline], \n // upper right of z.r.\n [\n 'L',\n left + outlineHeight,\n zoomedMax + halfOutline\n ]);\n }\n }\n else {\n zoomedMin += left + scrollbarHeight - outlineCorrection;\n zoomedMax += left + scrollbarHeight - outlineCorrection;\n navigatorTop += halfOutline;\n path = [\n // left\n ['M', left, navigatorTop],\n // upper left of zoomed range\n ['L', zoomedMin, navigatorTop],\n // lower left of z.r.\n ['L', zoomedMin, navigatorTop + outlineHeight],\n // lower right of z.r.\n ['L', zoomedMax, navigatorTop + outlineHeight],\n // upper right of z.r.\n ['L', zoomedMax, navigatorTop],\n // right\n ['L', left + navigatorSize + scrollbarHeight * 2, navigatorTop]\n ];\n if (maskInside) {\n path.push(\n // upper left of zoomed range\n ['M', zoomedMin - halfOutline, navigatorTop], \n // upper right of z.r.\n ['L', zoomedMax + halfOutline, navigatorTop]);\n }\n }\n navigator.outline[verb]({\n d: path\n });\n };\n /**\n * Render outline around the zoomed range\n *\n * @private\n * @function Highcharts.Navigator#drawMasks\n *\n * @param {number} zoomedMin\n * in pixels position where zoomed range starts\n *\n * @param {number} zoomedMax\n * in pixels position where zoomed range ends\n *\n * @param {boolean|undefined} inverted\n * flag if chart is inverted\n *\n * @param {string} verb\n * use 'animate' or 'attr'\n */\n Navigator.prototype.drawMasks = function (zoomedMin, zoomedMax, inverted, verb) {\n var navigator = this,\n left = navigator.left,\n top = navigator.top,\n navigatorHeight = navigator.height;\n var height,\n width,\n x,\n y;\n // Determine rectangle position & size\n // According to (non)inverted position:\n if (inverted) {\n x = [left, left, left];\n y = [top, top + zoomedMin, top + zoomedMax];\n width = [navigatorHeight, navigatorHeight, navigatorHeight];\n height = [\n zoomedMin,\n zoomedMax - zoomedMin,\n navigator.size - zoomedMax\n ];\n }\n else {\n x = [left, left + zoomedMin, left + zoomedMax];\n y = [top, top, top];\n width = [\n zoomedMin,\n zoomedMax - zoomedMin,\n navigator.size - zoomedMax\n ];\n height = [navigatorHeight, navigatorHeight, navigatorHeight];\n }\n navigator.shades.forEach(function (shade, i) {\n shade[verb]({\n x: x[i],\n y: y[i],\n width: width[i],\n height: height[i]\n });\n });\n };\n /**\n * Generate DOM elements for a navigator:\n *\n * - main navigator group\n *\n * - all shades\n *\n * - outline\n *\n * - handles\n *\n * @private\n * @function Highcharts.Navigator#renderElements\n */\n Navigator.prototype.renderElements = function () {\n var navigator = this,\n navigatorOptions = navigator.navigatorOptions,\n maskInside = navigatorOptions.maskInside,\n chart = navigator.chart,\n inverted = chart.inverted,\n renderer = chart.renderer,\n mouseCursor = {\n cursor: inverted ? 'ns-resize' : 'ew-resize'\n }, \n // Create the main navigator group\n navigatorGroup = navigator.navigatorGroup = renderer\n .g('navigator')\n .attr({\n zIndex: 8,\n visibility: 'hidden'\n })\n .add();\n // Create masks, each mask will get events and fill:\n [\n !maskInside,\n maskInside,\n !maskInside\n ].forEach(function (hasMask, index) {\n var shade = renderer.rect()\n .addClass('highcharts-navigator-mask' +\n (index === 1 ? '-inside' : '-outside'))\n .add(navigatorGroup);\n if (!chart.styledMode) {\n shade.attr({\n fill: hasMask ?\n navigatorOptions.maskFill :\n 'rgba(0,0,0,0)'\n });\n if (index === 1) {\n shade.css(mouseCursor);\n }\n }\n navigator.shades[index] = shade;\n });\n // Create the outline:\n navigator.outline = renderer.path()\n .addClass('highcharts-navigator-outline')\n .add(navigatorGroup);\n if (!chart.styledMode) {\n navigator.outline.attr({\n 'stroke-width': navigatorOptions.outlineWidth,\n stroke: navigatorOptions.outlineColor\n });\n }\n // Create the handlers:\n if (navigatorOptions.handles && navigatorOptions.handles.enabled) {\n var handlesOptions_1 = navigatorOptions.handles;\n [0, 1].forEach(function (index) {\n handlesOptions_1.inverted = !!chart.inverted;\n navigator.handles[index] = renderer.symbol(handlesOptions_1.symbols[index], -handlesOptions_1.width / 2 - 1, 0, handlesOptions_1.width, handlesOptions_1.height, navigatorOptions.handles);\n // zIndex = 6 for right handle, 7 for left.\n // Can't be 10, because of the tooltip in inverted chart #2908\n navigator.handles[index].attr({ zIndex: 7 - index })\n .addClass('highcharts-navigator-handle ' +\n 'highcharts-navigator-handle-' +\n ['left', 'right'][index]).add(navigatorGroup);\n if (!chart.styledMode) {\n navigator.handles[index]\n .attr({\n fill: handlesOptions_1.backgroundColor,\n stroke: handlesOptions_1.borderColor,\n 'stroke-width': handlesOptions_1.lineWidth\n })\n .css(mouseCursor);\n }\n });\n }\n };\n /**\n * Update navigator\n *\n * @private\n * @function Highcharts.Navigator#update\n *\n * @param {Highcharts.NavigatorOptions} options\n * Options to merge in when updating navigator\n */\n Navigator.prototype.update = function (options) {\n // Remove references to old navigator series in base series\n (this.series || []).forEach(function (series) {\n if (series.baseSeries) {\n delete series.baseSeries.navigatorSeries;\n }\n });\n // Destroy and rebuild navigator\n this.destroy();\n var chartOptions = this.chart.options;\n merge(true, chartOptions.navigator, options);\n this.init(this.chart);\n };\n /**\n * Render the navigator\n *\n * @private\n * @function Highcharts.Navigator#render\n * @param {number} min\n * X axis value minimum\n * @param {number} max\n * X axis value maximum\n * @param {number} [pxMin]\n * Pixel value minimum\n * @param {number} [pxMax]\n * Pixel value maximum\n */\n Navigator.prototype.render = function (min, max, pxMin, pxMax) {\n var navigator = this,\n chart = navigator.chart,\n xAxis = navigator.xAxis,\n pointRange = xAxis.pointRange || 0,\n scrollbarXAxis = xAxis.navigatorAxis.fake ? chart.xAxis[0] : xAxis,\n navigatorEnabled = navigator.navigatorEnabled,\n rendered = navigator.rendered,\n inverted = chart.inverted,\n minRange = chart.xAxis[0].minRange,\n maxRange = chart.xAxis[0].options.maxRange;\n var navigatorWidth,\n scrollbarLeft,\n scrollbarTop,\n scrollbarHeight = navigator.scrollbarHeight,\n navigatorSize,\n verb;\n // Don't redraw while moving the handles (#4703).\n if (this.hasDragged && !defined(pxMin)) {\n return;\n }\n min = correctFloat(min - pointRange / 2);\n max = correctFloat(max + pointRange / 2);\n // Don't render the navigator until we have data (#486, #4202, #5172).\n if (!isNumber(min) || !isNumber(max)) {\n // However, if navigator was already rendered, we may need to resize\n // it. For example hidden series, but visible navigator (#6022).\n if (rendered) {\n pxMin = 0;\n pxMax = pick(xAxis.width, scrollbarXAxis.width);\n }\n else {\n return;\n }\n }\n navigator.left = pick(xAxis.left, \n // in case of scrollbar only, without navigator\n chart.plotLeft + scrollbarHeight +\n (inverted ? chart.plotWidth : 0));\n var zoomedMax = navigator.size = navigatorSize = pick(xAxis.len, (inverted ? chart.plotHeight : chart.plotWidth) -\n 2 * scrollbarHeight);\n if (inverted) {\n navigatorWidth = scrollbarHeight;\n }\n else {\n navigatorWidth = navigatorSize + 2 * scrollbarHeight;\n }\n // Get the pixel position of the handles\n pxMin = pick(pxMin, xAxis.toPixels(min, true));\n pxMax = pick(pxMax, xAxis.toPixels(max, true));\n // Verify (#1851, #2238)\n if (!isNumber(pxMin) || Math.abs(pxMin) === Infinity) {\n pxMin = 0;\n pxMax = navigatorWidth;\n }\n // Are we below the minRange? (#2618, #6191)\n var newMin = xAxis.toValue(pxMin,\n true),\n newMax = xAxis.toValue(pxMax,\n true),\n currentRange = Math.abs(correctFloat(newMax - newMin));\n if (currentRange < minRange) {\n if (this.grabbedLeft) {\n pxMin = xAxis.toPixels(newMax - minRange - pointRange, true);\n }\n else if (this.grabbedRight) {\n pxMax = xAxis.toPixels(newMin + minRange + pointRange, true);\n }\n }\n else if (defined(maxRange) &&\n correctFloat(currentRange - pointRange) > maxRange) {\n if (this.grabbedLeft) {\n pxMin = xAxis.toPixels(newMax - maxRange - pointRange, true);\n }\n else if (this.grabbedRight) {\n pxMax = xAxis.toPixels(newMin + maxRange + pointRange, true);\n }\n }\n // Handles are allowed to cross, but never exceed the plot area\n navigator.zoomedMax = clamp(Math.max(pxMin, pxMax), 0, zoomedMax);\n navigator.zoomedMin = clamp(navigator.fixedWidth ?\n navigator.zoomedMax - navigator.fixedWidth :\n Math.min(pxMin, pxMax), 0, zoomedMax);\n navigator.range = navigator.zoomedMax - navigator.zoomedMin;\n zoomedMax = Math.round(navigator.zoomedMax);\n var zoomedMin = Math.round(navigator.zoomedMin);\n if (navigatorEnabled) {\n navigator.navigatorGroup.attr({\n visibility: 'inherit'\n });\n // Place elements\n verb = rendered && !navigator.hasDragged ? 'animate' : 'attr';\n navigator.drawMasks(zoomedMin, zoomedMax, inverted, verb);\n navigator.drawOutline(zoomedMin, zoomedMax, inverted, verb);\n if (navigator.navigatorOptions.handles.enabled) {\n navigator.drawHandle(zoomedMin, 0, inverted, verb);\n navigator.drawHandle(zoomedMax, 1, inverted, verb);\n }\n }\n if (navigator.scrollbar) {\n if (inverted) {\n scrollbarTop = navigator.top - scrollbarHeight;\n scrollbarLeft = navigator.left - scrollbarHeight +\n (navigatorEnabled || !scrollbarXAxis.opposite ? 0 :\n // Multiple axes has offsets:\n (scrollbarXAxis.titleOffset || 0) +\n // Self margin from the axis.title\n scrollbarXAxis.axisTitleMargin);\n scrollbarHeight = navigatorSize + 2 * scrollbarHeight;\n }\n else {\n scrollbarTop = navigator.top + (navigatorEnabled ?\n navigator.height :\n -scrollbarHeight);\n scrollbarLeft = navigator.left - scrollbarHeight;\n }\n // Reposition scrollbar\n navigator.scrollbar.position(scrollbarLeft, scrollbarTop, navigatorWidth, scrollbarHeight);\n // Keep scale 0-1\n navigator.scrollbar.setRange(\n // Use real value, not rounded because range can be very small\n // (#1716)\n navigator.zoomedMin / (navigatorSize || 1), navigator.zoomedMax / (navigatorSize || 1));\n }\n navigator.rendered = true;\n };\n /**\n * Set up the mouse and touch events for the navigator\n *\n * @private\n * @function Highcharts.Navigator#addMouseEvents\n */\n Navigator.prototype.addMouseEvents = function () {\n var navigator = this,\n chart = navigator.chart,\n container = chart.container;\n var eventsToUnbind = [],\n mouseMoveHandler,\n mouseUpHandler;\n /**\n * Create mouse events' handlers.\n * Make them as separate functions to enable wrapping them:\n */\n navigator.mouseMoveHandler = mouseMoveHandler = function (e) {\n navigator.onMouseMove(e);\n };\n navigator.mouseUpHandler = mouseUpHandler = function (e) {\n navigator.onMouseUp(e);\n };\n // Add shades and handles mousedown events\n eventsToUnbind = navigator.getPartsEvents('mousedown');\n // Add mouse move and mouseup events. These are bind to doc/container,\n // because Navigator.grabbedSomething flags are stored in mousedown\n // events\n eventsToUnbind.push(addEvent(chart.renderTo, 'mousemove', mouseMoveHandler), addEvent(container.ownerDocument, 'mouseup', mouseUpHandler));\n // Touch events\n if (hasTouch) {\n eventsToUnbind.push(addEvent(chart.renderTo, 'touchmove', mouseMoveHandler), addEvent(container.ownerDocument, 'touchend', mouseUpHandler));\n eventsToUnbind.concat(navigator.getPartsEvents('touchstart'));\n }\n navigator.eventsToUnbind = eventsToUnbind;\n // Data events\n if (navigator.series && navigator.series[0]) {\n eventsToUnbind.push(addEvent(navigator.series[0].xAxis, 'foundExtremes', function () {\n chart.navigator.modifyNavigatorAxisExtremes();\n }));\n }\n };\n /**\n * Generate events for handles and masks\n *\n * @private\n * @function Highcharts.Navigator#getPartsEvents\n *\n * @param {string} eventName\n * Event name handler, 'mousedown' or 'touchstart'\n *\n * @return {Array}\n * An array of functions to remove navigator functions from the\n * events again.\n */\n Navigator.prototype.getPartsEvents = function (eventName) {\n var navigator = this,\n events = [];\n ['shades', 'handles'].forEach(function (name) {\n navigator[name].forEach(function (navigatorItem, index) {\n events.push(addEvent(navigatorItem.element, eventName, function (e) {\n navigator[name + 'Mousedown'](e, index);\n }));\n });\n });\n return events;\n };\n /**\n * Mousedown on a shaded mask, either:\n *\n * - will be stored for future drag&drop\n *\n * - will directly shift to a new range\n *\n * @private\n * @function Highcharts.Navigator#shadesMousedown\n *\n * @param {Highcharts.PointerEventObject} e\n * Mouse event\n *\n * @param {number} index\n * Index of a mask in Navigator.shades array\n */\n Navigator.prototype.shadesMousedown = function (e, index) {\n e = this.chart.pointer.normalize(e);\n var navigator = this,\n chart = navigator.chart,\n xAxis = navigator.xAxis,\n zoomedMin = navigator.zoomedMin,\n navigatorSize = navigator.size,\n range = navigator.range;\n var navigatorPosition = navigator.left,\n chartX = e.chartX,\n fixedMax,\n fixedMin,\n ext,\n left;\n // For inverted chart, swap some options:\n if (chart.inverted) {\n chartX = e.chartY;\n navigatorPosition = navigator.top;\n }\n if (index === 1) {\n // Store information for drag&drop\n navigator.grabbedCenter = chartX;\n navigator.fixedWidth = range;\n navigator.dragOffset = chartX - zoomedMin;\n }\n else {\n // Shift the range by clicking on shaded areas\n left = chartX - navigatorPosition - range / 2;\n if (index === 0) {\n left = Math.max(0, left);\n }\n else if (index === 2 && left + range >= navigatorSize) {\n left = navigatorSize - range;\n if (navigator.reversedExtremes) {\n // #7713\n left -= range;\n fixedMin = navigator.getUnionExtremes().dataMin;\n }\n else {\n // #2293, #3543\n fixedMax = navigator.getUnionExtremes().dataMax;\n }\n }\n if (left !== zoomedMin) { // it has actually moved\n navigator.fixedWidth = range; // #1370\n ext = xAxis.navigatorAxis.toFixedRange(left, left + range, fixedMin, fixedMax);\n if (defined(ext.min)) { // #7411\n chart.xAxis[0].setExtremes(Math.min(ext.min, ext.max), Math.max(ext.min, ext.max), true, null, // auto animation\n { trigger: 'navigator' });\n }\n }\n }\n };\n /**\n * Mousedown on a handle mask.\n * Will store necessary information for drag&drop.\n *\n * @private\n * @function Highcharts.Navigator#handlesMousedown\n * @param {Highcharts.PointerEventObject} e\n * Mouse event\n * @param {number} index\n * Index of a handle in Navigator.handles array\n */\n Navigator.prototype.handlesMousedown = function (e, index) {\n e = this.chart.pointer.normalize(e);\n var navigator = this,\n chart = navigator.chart,\n baseXAxis = chart.xAxis[0], \n // For reversed axes, min and max are changed,\n // so the other extreme should be stored\n reverse = navigator.reversedExtremes;\n if (index === 0) {\n // Grab the left handle\n navigator.grabbedLeft = true;\n navigator.otherHandlePos = navigator.zoomedMax;\n navigator.fixedExtreme = reverse ? baseXAxis.min : baseXAxis.max;\n }\n else {\n // Grab the right handle\n navigator.grabbedRight = true;\n navigator.otherHandlePos = navigator.zoomedMin;\n navigator.fixedExtreme = reverse ? baseXAxis.max : baseXAxis.min;\n }\n chart.fixedRange = null;\n };\n /**\n * Mouse move event based on x/y mouse position.\n *\n * @private\n * @function Highcharts.Navigator#onMouseMove\n *\n * @param {Highcharts.PointerEventObject} e\n * Mouse event\n */\n Navigator.prototype.onMouseMove = function (e) {\n var navigator = this,\n chart = navigator.chart,\n navigatorSize = navigator.navigatorSize,\n range = navigator.range,\n dragOffset = navigator.dragOffset,\n inverted = chart.inverted;\n var left = navigator.left,\n chartX;\n // In iOS, a mousemove event with e.pageX === 0 is fired when holding\n // the finger down in the center of the scrollbar. This should be\n // ignored.\n if (!e.touches || e.touches[0].pageX !== 0) { // #4696\n e = chart.pointer.normalize(e);\n chartX = e.chartX;\n // Swap some options for inverted chart\n if (inverted) {\n left = navigator.top;\n chartX = e.chartY;\n }\n // Drag left handle or top handle\n if (navigator.grabbedLeft) {\n navigator.hasDragged = true;\n navigator.render(0, 0, chartX - left, navigator.otherHandlePos);\n // Drag right handle or bottom handle\n }\n else if (navigator.grabbedRight) {\n navigator.hasDragged = true;\n navigator.render(0, 0, navigator.otherHandlePos, chartX - left);\n // Drag scrollbar or open area in navigator\n }\n else if (navigator.grabbedCenter) {\n navigator.hasDragged = true;\n if (chartX < dragOffset) { // outside left\n chartX = dragOffset;\n // outside right\n }\n else if (chartX >\n navigatorSize + dragOffset - range) {\n chartX = navigatorSize + dragOffset - range;\n }\n navigator.render(0, 0, chartX - dragOffset, chartX - dragOffset + range);\n }\n if (navigator.hasDragged &&\n navigator.scrollbar &&\n pick(navigator.scrollbar.options.liveRedraw, \n // By default, don't run live redraw on VML, on touch\n // devices or if the chart is in boost.\n H.svg &&\n !isTouchDevice &&\n !this.chart.boosted)) {\n e.DOMType = e.type; // DOMType is for IE8\n setTimeout(function () {\n navigator.onMouseUp(e);\n }, 0);\n }\n }\n };\n /**\n * Mouse up event based on x/y mouse position.\n *\n * @private\n * @function Highcharts.Navigator#onMouseUp\n * @param {Highcharts.PointerEventObject} e\n * Mouse event\n */\n Navigator.prototype.onMouseUp = function (e) {\n var navigator = this,\n chart = navigator.chart,\n xAxis = navigator.xAxis,\n scrollbar = navigator.scrollbar,\n DOMEvent = e.DOMEvent || e,\n inverted = chart.inverted,\n verb = navigator.rendered && !navigator.hasDragged ?\n 'animate' : 'attr';\n var zoomedMax,\n zoomedMin,\n unionExtremes,\n fixedMin,\n fixedMax,\n ext;\n if (\n // MouseUp is called for both, navigator and scrollbar (that order),\n // which causes calling afterSetExtremes twice. Prevent first call\n // by checking if scrollbar is going to set new extremes (#6334)\n (navigator.hasDragged && (!scrollbar || !scrollbar.hasDragged)) ||\n e.trigger === 'scrollbar') {\n unionExtremes = navigator.getUnionExtremes();\n // When dragging one handle, make sure the other one doesn't change\n if (navigator.zoomedMin === navigator.otherHandlePos) {\n fixedMin = navigator.fixedExtreme;\n }\n else if (navigator.zoomedMax === navigator.otherHandlePos) {\n fixedMax = navigator.fixedExtreme;\n }\n // Snap to right edge (#4076)\n if (navigator.zoomedMax === navigator.size) {\n fixedMax = navigator.reversedExtremes ?\n unionExtremes.dataMin :\n unionExtremes.dataMax;\n }\n // Snap to left edge (#7576)\n if (navigator.zoomedMin === 0) {\n fixedMin = navigator.reversedExtremes ?\n unionExtremes.dataMax :\n unionExtremes.dataMin;\n }\n ext = xAxis.navigatorAxis.toFixedRange(navigator.zoomedMin, navigator.zoomedMax, fixedMin, fixedMax);\n if (defined(ext.min)) {\n chart.xAxis[0].setExtremes(Math.min(ext.min, ext.max), Math.max(ext.min, ext.max), true, \n // Run animation when clicking buttons, scrollbar track etc,\n // but not when dragging handles or scrollbar\n navigator.hasDragged ? false : null, {\n trigger: 'navigator',\n triggerOp: 'navigator-drag',\n DOMEvent: DOMEvent // #1838\n });\n }\n }\n if (e.DOMType !== 'mousemove' &&\n e.DOMType !== 'touchmove') {\n navigator.grabbedLeft = navigator.grabbedRight =\n navigator.grabbedCenter = navigator.fixedWidth =\n navigator.fixedExtreme = navigator.otherHandlePos =\n navigator.hasDragged = navigator.dragOffset = null;\n }\n // Update position of navigator shades, outline and handles (#12573)\n if (navigator.navigatorEnabled &&\n isNumber(navigator.zoomedMin) &&\n isNumber(navigator.zoomedMax)) {\n zoomedMin = Math.round(navigator.zoomedMin);\n zoomedMax = Math.round(navigator.zoomedMax);\n if (navigator.shades) {\n navigator.drawMasks(zoomedMin, zoomedMax, inverted, verb);\n }\n if (navigator.outline) {\n navigator.drawOutline(zoomedMin, zoomedMax, inverted, verb);\n }\n if (navigator.navigatorOptions.handles.enabled &&\n Object.keys(navigator.handles).length ===\n navigator.handles.length) {\n navigator.drawHandle(zoomedMin, 0, inverted, verb);\n navigator.drawHandle(zoomedMax, 1, inverted, verb);\n }\n }\n };\n /**\n * Removes the event handlers attached previously with addEvents.\n *\n * @private\n * @function Highcharts.Navigator#removeEvents\n */\n Navigator.prototype.removeEvents = function () {\n if (this.eventsToUnbind) {\n this.eventsToUnbind.forEach(function (unbind) {\n unbind();\n });\n this.eventsToUnbind = void 0;\n }\n this.removeBaseSeriesEvents();\n };\n /**\n * Remove data events.\n *\n * @private\n * @function Highcharts.Navigator#removeBaseSeriesEvents\n */\n Navigator.prototype.removeBaseSeriesEvents = function () {\n var baseSeries = this.baseSeries || [];\n if (this.navigatorEnabled && baseSeries[0]) {\n if (this.navigatorOptions.adaptToUpdatedData !== false) {\n baseSeries.forEach(function (series) {\n removeEvent(series, 'updatedData', this.updatedDataHandler);\n }, this);\n }\n // We only listen for extremes-events on the first baseSeries\n if (baseSeries[0].xAxis) {\n removeEvent(baseSeries[0].xAxis, 'foundExtremes', this.modifyBaseAxisExtremes);\n }\n }\n };\n /**\n * Initialize the Navigator object\n *\n * @private\n * @function Highcharts.Navigator#init\n */\n Navigator.prototype.init = function (chart) {\n var chartOptions = chart.options,\n navigatorOptions = chartOptions.navigator || {},\n navigatorEnabled = navigatorOptions.enabled,\n scrollbarOptions = chartOptions.scrollbar || {},\n scrollbarEnabled = scrollbarOptions.enabled,\n height = navigatorEnabled && navigatorOptions.height || 0,\n scrollbarHeight = scrollbarEnabled && scrollbarOptions.height || 0;\n this.handles = [];\n this.shades = [];\n this.chart = chart;\n this.setBaseSeries();\n this.height = height;\n this.scrollbarHeight = scrollbarHeight;\n this.scrollbarEnabled = scrollbarEnabled;\n this.navigatorEnabled = navigatorEnabled;\n this.navigatorOptions = navigatorOptions;\n this.scrollbarOptions = scrollbarOptions;\n this.outlineHeight = height + scrollbarHeight;\n this.opposite = pick(navigatorOptions.opposite, Boolean(!navigatorEnabled && chart.inverted)); // #6262\n var navigator = this,\n baseSeries = navigator.baseSeries,\n xAxisIndex = chart.xAxis.length,\n yAxisIndex = chart.yAxis.length,\n baseXaxis = baseSeries && baseSeries[0] && baseSeries[0].xAxis ||\n chart.xAxis[0] || { options: {} };\n chart.isDirtyBox = true;\n if (navigator.navigatorEnabled) {\n // an x axis is required for scrollbar also\n navigator.xAxis = new Axis(chart, merge({\n // inherit base xAxis' break and ordinal options\n breaks: baseXaxis.options.breaks,\n ordinal: baseXaxis.options.ordinal\n }, navigatorOptions.xAxis, {\n id: 'navigator-x-axis',\n yAxis: 'navigator-y-axis',\n isX: true,\n type: 'datetime',\n index: xAxisIndex,\n isInternal: true,\n offset: 0,\n keepOrdinalPadding: true,\n startOnTick: false,\n endOnTick: false,\n minPadding: 0,\n maxPadding: 0,\n zoomEnabled: false\n }, chart.inverted ? {\n offsets: [scrollbarHeight, 0, -scrollbarHeight, 0],\n width: height\n } : {\n offsets: [0, -scrollbarHeight, 0, scrollbarHeight],\n height: height\n }));\n navigator.yAxis = new Axis(chart, merge(navigatorOptions.yAxis, {\n id: 'navigator-y-axis',\n alignTicks: false,\n offset: 0,\n index: yAxisIndex,\n isInternal: true,\n reversed: pick((navigatorOptions.yAxis &&\n navigatorOptions.yAxis.reversed), (chart.yAxis[0] && chart.yAxis[0].reversed), false),\n zoomEnabled: false\n }, chart.inverted ? {\n width: height\n } : {\n height: height\n }));\n // If we have a base series, initialize the navigator series\n if (baseSeries || navigatorOptions.series.data) {\n navigator.updateNavigatorSeries(false);\n // If not, set up an event to listen for added series\n }\n else if (chart.series.length === 0) {\n navigator.unbindRedraw = addEvent(chart, 'beforeRedraw', function () {\n // We've got one, now add it as base\n if (chart.series.length > 0 && !navigator.series) {\n navigator.setBaseSeries();\n navigator.unbindRedraw(); // reset\n }\n });\n }\n navigator.reversedExtremes = (chart.inverted && !navigator.xAxis.reversed) || (!chart.inverted && navigator.xAxis.reversed);\n // Render items, so we can bind events to them:\n navigator.renderElements();\n // Add mouse events\n navigator.addMouseEvents();\n // in case of scrollbar only, fake an x axis to get translation\n }\n else {\n navigator.xAxis = {\n chart: chart,\n navigatorAxis: {\n fake: true\n },\n translate: function (value, reverse) {\n var axis = chart.xAxis[0], ext = axis.getExtremes(), scrollTrackWidth = axis.len - 2 * scrollbarHeight, min = numExt('min', axis.options.min, ext.dataMin), valueRange = numExt('max', axis.options.max, ext.dataMax) - min;\n return reverse ?\n // from pixel to value\n (value * valueRange / scrollTrackWidth) + min :\n // from value to pixel\n scrollTrackWidth * (value - min) / valueRange;\n },\n toPixels: function (value) {\n return this.translate(value);\n },\n toValue: function (value) {\n return this.translate(value, true);\n }\n };\n navigator.xAxis.navigatorAxis.axis = navigator.xAxis;\n navigator.xAxis.navigatorAxis.toFixedRange = (NavigatorAxisAdditions.prototype.toFixedRange.bind(navigator.xAxis.navigatorAxis));\n }\n // Initialize the scrollbar\n if (chart.options.scrollbar.enabled) {\n chart.scrollbar = navigator.scrollbar = new Scrollbar(chart.renderer, merge(chart.options.scrollbar, {\n margin: navigator.navigatorEnabled ? 0 : 10,\n vertical: chart.inverted\n }), chart);\n addEvent(navigator.scrollbar, 'changed', function (e) {\n var range = navigator.size,\n to = range * this.to,\n from = range * this.from;\n navigator.hasDragged = navigator.scrollbar.hasDragged;\n navigator.render(0, 0, from, to);\n if (this.shouldUpdateExtremes(e.DOMType)) {\n setTimeout(function () {\n navigator.onMouseUp(e);\n });\n }\n });\n }\n // Add data events\n navigator.addBaseSeriesEvents();\n // Add redraw events\n navigator.addChartEvents();\n };\n /**\n * Get the union data extremes of the chart - the outer data extremes of the\n * base X axis and the navigator axis.\n *\n * @private\n * @function Highcharts.Navigator#getUnionExtremes\n */\n Navigator.prototype.getUnionExtremes = function (returnFalseOnNoBaseSeries) {\n var baseAxis = this.chart.xAxis[0],\n navAxis = this.xAxis,\n navAxisOptions = navAxis.options,\n baseAxisOptions = baseAxis.options;\n var ret;\n if (!returnFalseOnNoBaseSeries || baseAxis.dataMin !== null) {\n ret = {\n dataMin: pick(// #4053\n navAxisOptions && navAxisOptions.min, numExt('min', baseAxisOptions.min, baseAxis.dataMin, navAxis.dataMin, navAxis.min)),\n dataMax: pick(navAxisOptions && navAxisOptions.max, numExt('max', baseAxisOptions.max, baseAxis.dataMax, navAxis.dataMax, navAxis.max))\n };\n }\n return ret;\n };\n /**\n * Set the base series and update the navigator series from this. With a bit\n * of modification we should be able to make this an API method to be called\n * from the outside\n *\n * @private\n * @function Highcharts.Navigator#setBaseSeries\n * @param {Highcharts.SeriesOptionsType} [baseSeriesOptions]\n * Additional series options for a navigator\n * @param {boolean} [redraw]\n * Whether to redraw after update.\n */\n Navigator.prototype.setBaseSeries = function (baseSeriesOptions, redraw) {\n var chart = this.chart,\n baseSeries = this.baseSeries = [];\n baseSeriesOptions = (baseSeriesOptions ||\n chart.options && chart.options.navigator.baseSeries ||\n (chart.series.length ?\n // Find the first non-navigator series (#8430)\n find(chart.series, function (s) { return (!s.options.isInternal); }).index :\n 0));\n // Iterate through series and add the ones that should be shown in\n // navigator.\n (chart.series || []).forEach(function (series, i) {\n if (\n // Don't include existing nav series\n !series.options.isInternal &&\n (series.options.showInNavigator ||\n (i === baseSeriesOptions ||\n series.options.id === baseSeriesOptions) &&\n series.options.showInNavigator !== false)) {\n baseSeries.push(series);\n }\n });\n // When run after render, this.xAxis already exists\n if (this.xAxis && !this.xAxis.navigatorAxis.fake) {\n this.updateNavigatorSeries(true, redraw);\n }\n };\n /**\n * Update series in the navigator from baseSeries, adding new if does not\n * exist.\n *\n * @private\n * @function Highcharts.Navigator.updateNavigatorSeries\n */\n Navigator.prototype.updateNavigatorSeries = function (addEvents, redraw) {\n var navigator = this,\n chart = navigator.chart,\n baseSeries = navigator.baseSeries,\n navSeriesMixin = {\n enableMouseTracking: false,\n index: null,\n linkedTo: null,\n group: 'nav',\n padXAxis: false,\n xAxis: 'navigator-x-axis',\n yAxis: 'navigator-y-axis',\n showInLegend: false,\n stacking: void 0,\n isInternal: true,\n states: {\n inactive: {\n opacity: 1\n }\n }\n }, \n // Remove navigator series that are no longer in the baseSeries\n navigatorSeries = navigator.series =\n (navigator.series || []).filter(function (navSeries) {\n var base = navSeries.baseSeries;\n if (baseSeries.indexOf(base) < 0) { // Not in array\n // If there is still a base series connected to this\n // series, remove event handler and reference.\n if (base) {\n removeEvent(base, 'updatedData', navigator.updatedDataHandler);\n delete base.navigatorSeries;\n }\n // Kill the nav series. It may already have been\n // destroyed (#8715).\n if (navSeries.chart) {\n navSeries.destroy();\n }\n return false;\n }\n return true;\n });\n var baseOptions,\n mergedNavSeriesOptions,\n chartNavigatorSeriesOptions = navigator.navigatorOptions.series,\n baseNavigatorOptions;\n // Go through each base series and merge the options to create new\n // series\n if (baseSeries && baseSeries.length) {\n baseSeries.forEach(function (base) {\n var linkedNavSeries = base.navigatorSeries,\n userNavOptions = extend(\n // Grab color and visibility from base as default\n {\n color: base.color,\n visible: base.visible\n }, !isArray(chartNavigatorSeriesOptions) ?\n chartNavigatorSeriesOptions :\n defaultOptions.navigator.series);\n // Don't update if the series exists in nav and we have disabled\n // adaptToUpdatedData.\n if (linkedNavSeries &&\n navigator.navigatorOptions.adaptToUpdatedData === false) {\n return;\n }\n navSeriesMixin.name = 'Navigator ' + baseSeries.length;\n baseOptions = base.options || {};\n baseNavigatorOptions = baseOptions.navigatorOptions || {};\n // The dataLabels options are not merged correctly\n // if the settings are an array, #13847.\n userNavOptions.dataLabels = splat(userNavOptions.dataLabels);\n mergedNavSeriesOptions = merge(baseOptions, navSeriesMixin, userNavOptions, baseNavigatorOptions);\n // Once nav series type is resolved, pick correct pointRange\n mergedNavSeriesOptions.pointRange = pick(\n // Stricte set pointRange in options\n userNavOptions.pointRange, baseNavigatorOptions.pointRange, \n // Fallback to default values, e.g. `null` for column\n defaultOptions.plotOptions[mergedNavSeriesOptions.type || 'line'].pointRange);\n // Merge data separately. Do a slice to avoid mutating the\n // navigator options from base series (#4923).\n var navigatorSeriesData = baseNavigatorOptions.data || userNavOptions.data;\n navigator.hasNavigatorData =\n navigator.hasNavigatorData || !!navigatorSeriesData;\n mergedNavSeriesOptions.data =\n navigatorSeriesData ||\n baseOptions.data && baseOptions.data.slice(0);\n // Update or add the series\n if (linkedNavSeries && linkedNavSeries.options) {\n linkedNavSeries.update(mergedNavSeriesOptions, redraw);\n }\n else {\n base.navigatorSeries = chart.initSeries(mergedNavSeriesOptions);\n base.navigatorSeries.baseSeries = base; // Store ref\n navigatorSeries.push(base.navigatorSeries);\n }\n });\n }\n // If user has defined data (and no base series) or explicitly defined\n // navigator.series as an array, we create these series on top of any\n // base series.\n if (chartNavigatorSeriesOptions.data &&\n !(baseSeries && baseSeries.length) ||\n isArray(chartNavigatorSeriesOptions)) {\n navigator.hasNavigatorData = false;\n // Allow navigator.series to be an array\n chartNavigatorSeriesOptions =\n splat(chartNavigatorSeriesOptions);\n chartNavigatorSeriesOptions.forEach(function (userSeriesOptions, i) {\n navSeriesMixin.name =\n 'Navigator ' + (navigatorSeries.length + 1);\n mergedNavSeriesOptions = merge(defaultOptions.navigator.series, {\n // Since we don't have a base series to pull color from,\n // try to fake it by using color from series with same\n // index. Otherwise pull from the colors array. We need\n // an explicit color as otherwise updates will increment\n // color counter and we'll get a new color for each\n // update of the nav series.\n color: chart.series[i] &&\n !chart.series[i].options.isInternal &&\n chart.series[i].color ||\n chart.options.colors[i] ||\n chart.options.colors[0]\n }, navSeriesMixin, userSeriesOptions);\n mergedNavSeriesOptions.data = userSeriesOptions.data;\n if (mergedNavSeriesOptions.data) {\n navigator.hasNavigatorData = true;\n navigatorSeries.push(chart.initSeries(mergedNavSeriesOptions));\n }\n });\n }\n if (addEvents) {\n this.addBaseSeriesEvents();\n }\n };\n /**\n * Add data events.\n * For example when main series is updated we need to recalculate extremes\n *\n * @private\n * @function Highcharts.Navigator#addBaseSeriesEvent\n */\n Navigator.prototype.addBaseSeriesEvents = function () {\n var _this = this;\n var navigator = this,\n baseSeries = navigator.baseSeries || [];\n // Bind modified extremes event to first base's xAxis only.\n // In event of > 1 base-xAxes, the navigator will ignore those.\n // Adding this multiple times to the same axis is no problem, as\n // duplicates should be discarded by the browser.\n if (baseSeries[0] && baseSeries[0].xAxis) {\n baseSeries[0].eventsToUnbind.push(addEvent(baseSeries[0].xAxis, 'foundExtremes', this.modifyBaseAxisExtremes));\n }\n baseSeries.forEach(function (base) {\n // Link base series show/hide to navigator series visibility\n base.eventsToUnbind.push(addEvent(base, 'show', function () {\n if (this.navigatorSeries) {\n this.navigatorSeries.setVisible(true, false);\n }\n }));\n base.eventsToUnbind.push(addEvent(base, 'hide', function () {\n if (this.navigatorSeries) {\n this.navigatorSeries.setVisible(false, false);\n }\n }));\n // Respond to updated data in the base series, unless explicitily\n // not adapting to data changes.\n if (_this.navigatorOptions.adaptToUpdatedData !== false) {\n if (base.xAxis) {\n base.eventsToUnbind.push(addEvent(base, 'updatedData', _this.updatedDataHandler));\n }\n }\n // Handle series removal\n base.eventsToUnbind.push(addEvent(base, 'remove', function () {\n if (this.navigatorSeries) {\n erase(navigator.series, this.navigatorSeries);\n if (defined(this.navigatorSeries.options)) {\n this.navigatorSeries.remove(false);\n }\n delete this.navigatorSeries;\n }\n }));\n });\n };\n /**\n * Get minimum from all base series connected to the navigator\n * @private\n * @param {number} currentSeriesMin\n * Minium from the current series\n * @return {number}\n * Minimum from all series\n */\n Navigator.prototype.getBaseSeriesMin = function (currentSeriesMin) {\n return this.baseSeries.reduce(function (min, series) {\n // (#10193)\n return Math.min(min, series.xData && series.xData.length ?\n series.xData[0] : min);\n }, currentSeriesMin);\n };\n /**\n * Set the navigator x axis extremes to reflect the total. The navigator\n * extremes should always be the extremes of the union of all series in the\n * chart as well as the navigator series.\n *\n * @private\n * @function Highcharts.Navigator#modifyNavigatorAxisExtremes\n */\n Navigator.prototype.modifyNavigatorAxisExtremes = function () {\n var xAxis = this.xAxis;\n if (typeof xAxis.getExtremes !== 'undefined') {\n var unionExtremes = this.getUnionExtremes(true);\n if (unionExtremes &&\n (unionExtremes.dataMin !== xAxis.min ||\n unionExtremes.dataMax !== xAxis.max)) {\n xAxis.min = unionExtremes.dataMin;\n xAxis.max = unionExtremes.dataMax;\n }\n }\n };\n /**\n * Hook to modify the base axis extremes with information from the Navigator\n *\n * @private\n * @function Highcharts.Navigator#modifyBaseAxisExtremes\n */\n Navigator.prototype.modifyBaseAxisExtremes = function () {\n var baseXAxis = this,\n navigator = baseXAxis.chart.navigator,\n baseExtremes = baseXAxis.getExtremes(),\n baseMin = baseExtremes.min,\n baseMax = baseExtremes.max,\n baseDataMin = baseExtremes.dataMin,\n baseDataMax = baseExtremes.dataMax,\n range = baseMax - baseMin,\n stickToMin = navigator.stickToMin,\n stickToMax = navigator.stickToMax,\n overscroll = pick(baseXAxis.options.overscroll, 0),\n navigatorSeries = navigator.series && navigator.series[0],\n hasSetExtremes = !!baseXAxis.setExtremes, \n // When the extremes have been set by range selector button, don't\n // stick to min or max. The range selector buttons will handle the\n // extremes. (#5489)\n unmutable = baseXAxis.eventArgs &&\n baseXAxis.eventArgs.trigger === 'rangeSelectorButton';\n var newMax,\n newMin;\n if (!unmutable) {\n // If the zoomed range is already at the min, move it to the right\n // as new data comes in\n if (stickToMin) {\n newMin = baseDataMin;\n newMax = newMin + range;\n }\n // If the zoomed range is already at the max, move it to the right\n // as new data comes in\n if (stickToMax) {\n newMax = baseDataMax + overscroll;\n // If stickToMin is true, the new min value is set above\n if (!stickToMin) {\n newMin = Math.max(baseDataMin, // don't go below data extremes (#13184)\n newMax - range, navigator.getBaseSeriesMin(navigatorSeries && navigatorSeries.xData ?\n navigatorSeries.xData[0] :\n -Number.MAX_VALUE));\n }\n }\n // Update the extremes\n if (hasSetExtremes && (stickToMin || stickToMax)) {\n if (isNumber(newMin)) {\n baseXAxis.min = baseXAxis.userMin = newMin;\n baseXAxis.max = baseXAxis.userMax = newMax;\n }\n }\n }\n // Reset\n navigator.stickToMin =\n navigator.stickToMax = null;\n };\n /**\n * Handler for updated data on the base series. When data is modified, the\n * navigator series must reflect it. This is called from the Chart.redraw\n * function before axis and series extremes are computed.\n *\n * @private\n * @function Highcharts.Navigator#updateDataHandler\n */\n Navigator.prototype.updatedDataHandler = function () {\n var navigator = this.chart.navigator,\n baseSeries = this,\n navigatorSeries = this.navigatorSeries,\n shouldStickToMax = navigator.reversedExtremes ?\n Math.round(navigator.zoomedMin) === 0 :\n Math.round(navigator.zoomedMax) >= Math.round(navigator.size);\n // If the scrollbar is scrolled all the way to the right, keep right as\n // new data comes in, unless user set navigator.stickToMax to false.\n navigator.stickToMax = pick(this.chart.options.navigator &&\n this.chart.options.navigator.stickToMax, shouldStickToMax);\n navigator.stickToMin = navigator.shouldStickToMin(baseSeries, navigator);\n // Set the navigator series data to the new data of the base series\n if (navigatorSeries && !navigator.hasNavigatorData) {\n navigatorSeries.options.pointStart = baseSeries.xData[0];\n navigatorSeries.setData(baseSeries.options.data, false, null, false); // #5414\n }\n };\n /**\n * Detect if the zoomed area should stick to the minimum, #14742.\n *\n * @private\n * @function Highcharts.Navigator#shouldStickToMin\n */\n Navigator.prototype.shouldStickToMin = function (baseSeries, navigator) {\n var xDataMin = navigator.getBaseSeriesMin(baseSeries.xData[0]),\n xAxis = baseSeries.xAxis,\n max = xAxis.max,\n min = xAxis.min,\n range = xAxis.options.range;\n var stickToMin = true;\n if (isNumber(max) && isNumber(min)) {\n // If range declared, stick to the minimum only if the range\n // is smaller than the data set range.\n if (range && max - xDataMin > 0) {\n stickToMin = max - xDataMin < range;\n }\n else {\n // If the current axis minimum falls outside the new\n // updated dataset, we must adjust.\n stickToMin = min <= xDataMin;\n }\n }\n else {\n stickToMin = false; // #15864\n }\n return stickToMin;\n };\n /**\n * Add chart events, like redrawing navigator, when chart requires that.\n *\n * @private\n * @function Highcharts.Navigator#addChartEvents\n */\n Navigator.prototype.addChartEvents = function () {\n if (!this.eventsToUnbind) {\n this.eventsToUnbind = [];\n }\n this.eventsToUnbind.push(\n // Move the scrollbar after redraw, like after data updata even if\n // axes don't redraw\n addEvent(this.chart, 'redraw', function () {\n var navigator = this.navigator,\n xAxis = navigator && (navigator.baseSeries &&\n navigator.baseSeries[0] &&\n navigator.baseSeries[0].xAxis ||\n this.xAxis[0]); // #5709, #13114\n if (xAxis) {\n navigator.render(xAxis.min,\n xAxis.max);\n }\n }), \n // Make room for the navigator, can be placed around the chart:\n addEvent(this.chart, 'getMargins', function () {\n var chart = this,\n navigator = chart.navigator,\n marginName = navigator.opposite ?\n 'plotTop' : 'marginBottom';\n if (chart.inverted) {\n marginName = navigator.opposite ?\n 'marginRight' : 'plotLeft';\n }\n chart[marginName] =\n (chart[marginName] || 0) + (navigator.navigatorEnabled || !chart.inverted ?\n navigator.outlineHeight :\n 0) + navigator.navigatorOptions.margin;\n }));\n };\n /**\n * Destroys allocated elements.\n *\n * @private\n * @function Highcharts.Navigator#destroy\n */\n Navigator.prototype.destroy = function () {\n var _this = this;\n // Disconnect events added in addEvents\n this.removeEvents();\n if (this.xAxis) {\n erase(this.chart.xAxis, this.xAxis);\n erase(this.chart.axes, this.xAxis);\n }\n if (this.yAxis) {\n erase(this.chart.yAxis, this.yAxis);\n erase(this.chart.axes, this.yAxis);\n }\n // Destroy series\n (this.series || []).forEach(function (s) {\n if (s.destroy) {\n s.destroy();\n }\n });\n // Destroy properties\n [\n 'series', 'xAxis', 'yAxis', 'shades', 'outline', 'scrollbarTrack',\n 'scrollbarRifles', 'scrollbarGroup', 'scrollbar', 'navigatorGroup',\n 'rendered'\n ].forEach(function (prop) {\n if (_this[prop] && _this[prop].destroy) {\n _this[prop].destroy();\n }\n _this[prop] = null;\n });\n // Destroy elements in collection\n [this.handles].forEach(function (coll) {\n destroyObjectProperties(coll);\n });\n };\n return Navigator;\n }());\n /* *\n *\n * Default Export\n *\n * */\n\n return Navigator;\n });\n _registerModule(_modules, 'Stock/RangeSelector/RangeSelectorDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Declarations\n *\n * */\n /**\n * Language object. The language object is global and it can't be set\n * on each chart initialization. Instead, use `Highcharts.setOptions` to\n * set it before any chart is initialized.\n *\n * ```js\n * Highcharts.setOptions({\n * lang: {\n * months: [\n * 'Janvier', 'Février', 'Mars', 'Avril',\n * 'Mai', 'Juin', 'Juillet', 'Août',\n * 'Septembre', 'Octobre', 'Novembre', 'Décembre'\n * ],\n * weekdays: [\n * 'Dimanche', 'Lundi', 'Mardi', 'Mercredi',\n * 'Jeudi', 'Vendredi', 'Samedi'\n * ]\n * }\n * });\n * ```\n *\n * @optionparent lang\n */\n var lang = {\n /**\n * The text for the label for the range selector buttons.\n *\n * @product highstock gantt\n */\n rangeSelectorZoom: 'Zoom',\n /**\n * The text for the label for the \"from\" input box in the range\n * selector. Since v9.0,\n this string is empty as the label is not\n * rendered by default.\n *\n * @product highstock gantt\n */\n rangeSelectorFrom: '',\n /**\n * The text for the label for the \"to\" input box in the range selector.\n *\n * @product highstock gantt\n */\n rangeSelectorTo: '→'\n };\n /**\n * The range selector is a tool for selecting ranges to display within\n * the chart. It provides buttons to select preconfigured ranges in\n * the chart, like 1 day, 1 week, 1 month etc. It also provides input\n * boxes where min and max dates can be manually input.\n *\n * @product highstock gantt\n * @optionparent rangeSelector\n */\n var rangeSelector = {\n /**\n * Whether to enable all buttons from the start. By default buttons are\n * only enabled if the corresponding time range exists on the X axis,\n * but enabling all buttons allows for dynamically loading different\n * time ranges.\n *\n * @sample {highstock} stock/rangeselector/allbuttonsenabled-true/\n * All buttons enabled\n *\n * @since 2.0.3\n */\n allButtonsEnabled: false,\n /**\n * An array of configuration objects for the buttons.\n *\n * Defaults to:\n * ```js\n * buttons: [{\n * type: 'month',\n * count: 1,\n * text: '1m',\n * title: 'View 1 month'\n * }, {\n * type: 'month',\n * count: 3,\n * text: '3m',\n * title: 'View 3 months'\n * }, {\n * type: 'month',\n * count: 6,\n * text: '6m',\n * title: 'View 6 months'\n * }, {\n * type: 'ytd',\n * text: 'YTD',\n * title: 'View year to date'\n * }, {\n * type: 'year',\n * count: 1,\n * text: '1y',\n * title: 'View 1 year'\n * }, {\n * type: 'all',\n * text: 'All',\n * title: 'View all'\n * }]\n * ```\n *\n * @sample {highstock} stock/rangeselector/datagrouping/\n * Data grouping by buttons\n *\n * @type {Array<*>}\n */\n buttons: void 0,\n /**\n * How many units of the defined type the button should span. If `type`\n * is \"month\" and `count` is 3,\n the button spans three months.\n *\n * @type {number}\n * @default 1\n * @apioption rangeSelector.buttons.count\n */\n /**\n * Fires when clicking on the rangeSelector button. One parameter,\n * event,\n is passed to the function,\n containing common event\n * information.\n *\n * ```js\n * click: function(e) {\n * console.log(this);\n * }\n * ```\n *\n * Return false to stop default button's click action.\n *\n * @sample {highstock} stock/rangeselector/button-click/\n * Click event on the button\n *\n * @type {Highcharts.RangeSelectorClickCallbackFunction}\n * @apioption rangeSelector.buttons.events.click\n */\n /**\n * Additional range (in milliseconds) added to the end of the calculated\n * time span.\n *\n * @sample {highstock} stock/rangeselector/min-max-offsets/\n * Button offsets\n *\n * @type {number}\n * @default 0\n * @since 6.0.0\n * @apioption rangeSelector.buttons.offsetMax\n */\n /**\n * Additional range (in milliseconds) added to the start of the\n * calculated time span.\n *\n * @sample {highstock} stock/rangeselector/min-max-offsets/\n * Button offsets\n *\n * @type {number}\n * @default 0\n * @since 6.0.0\n * @apioption rangeSelector.buttons.offsetMin\n */\n /**\n * When buttons apply dataGrouping on a series, by default zooming\n * in/out will deselect buttons and unset dataGrouping. Enable this\n * option to keep buttons selected when extremes change.\n *\n * @sample {highstock} stock/rangeselector/preserve-datagrouping/\n * Different preserveDataGrouping settings\n *\n * @type {boolean}\n * @default false\n * @since 6.1.2\n * @apioption rangeSelector.buttons.preserveDataGrouping\n */\n /**\n * A custom data grouping object for each button.\n *\n * @see [series.dataGrouping](#plotOptions.series.dataGrouping)\n *\n * @sample {highstock} stock/rangeselector/datagrouping/\n * Data grouping by range selector buttons\n *\n * @type {*}\n * @extends plotOptions.series.dataGrouping\n * @apioption rangeSelector.buttons.dataGrouping\n */\n /**\n * The text for the button itself.\n *\n * @type {string}\n * @apioption rangeSelector.buttons.text\n */\n /**\n * Explanation for the button, shown as a tooltip on hover, and used by\n * assistive technology.\n *\n * @type {string}\n * @apioption rangeSelector.buttons.title\n */\n /**\n * Defined the time span for the button. Can be one of `millisecond`,\n * `second`, `minute`, `hour`, `day`, `week`, `month`, `year`, `ytd`,\n * and `all`.\n *\n * @type {Highcharts.RangeSelectorButtonTypeValue}\n * @apioption rangeSelector.buttons.type\n */\n /**\n * The space in pixels between the buttons in the range selector.\n */\n buttonSpacing: 5,\n /**\n * Whether to collapse the range selector buttons into a dropdown when\n * there is not enough room to show everything in a single row, instead\n * of dividing the range selector into multiple rows.\n * Can be one of the following:\n * - `always`: Always collapse\n * - `responsive`: Only collapse when there is not enough room\n * - `never`: Never collapse\n *\n * @sample {highstock} stock/rangeselector/dropdown/\n * Dropdown option\n *\n * @validvalue [\"always\", \"responsive\", \"never\"]\n * @since 9.0.0\n */\n dropdown: 'responsive',\n /**\n * Enable or disable the range selector. Default to `true` for stock\n * charts, using the `stockChart` factory.\n *\n * @sample {highstock} stock/rangeselector/enabled/\n * Disable the range selector\n *\n * @type {boolean|undefined}\n * @default {highstock} true\n */\n enabled: void 0,\n /**\n * The vertical alignment of the rangeselector box. Allowed properties\n * are `top`, `middle`, `bottom`.\n *\n * @sample {highstock} stock/rangeselector/vertical-align-middle/\n * Middle\n * @sample {highstock} stock/rangeselector/vertical-align-bottom/\n * Bottom\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 6.0.0\n */\n verticalAlign: 'top',\n /**\n * A collection of attributes for the buttons. The object takes SVG\n * attributes like `fill`, `stroke`, `stroke-width`, as well as `style`,\n * a collection of CSS properties for the text.\n *\n * The object can also be extended with states, so you can set\n * presentational options for `hover`, `select` or `disabled` button\n * states.\n *\n * CSS styles for the text label.\n *\n * In styled mode, the buttons are styled by the\n * `.highcharts-range-selector-buttons .highcharts-button` rule with its\n * different states.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @type {Highcharts.SVGAttributes}\n */\n buttonTheme: {\n /** @ignore */\n width: 28,\n /** @ignore */\n height: 18,\n /** @ignore */\n padding: 2,\n /** @ignore */\n zIndex: 7 // #484, #852\n },\n /**\n * When the rangeselector is floating, the plot area does not reserve\n * space for it. This opens for positioning anywhere on the chart.\n *\n * @sample {highstock} stock/rangeselector/floating/\n * Placing the range selector between the plot area and the\n * navigator\n *\n * @since 6.0.0\n */\n floating: false,\n /**\n * The x offset of the range selector relative to its horizontal\n * alignment within `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @since 6.0.0\n */\n x: 0,\n /**\n * The y offset of the range selector relative to its horizontal\n * alignment within `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @since 6.0.0\n */\n y: 0,\n /**\n * Deprecated. The height of the range selector. Currently it is\n * calculated dynamically.\n *\n * @deprecated\n * @type {number|undefined}\n * @since 2.1.9\n */\n height: void 0,\n /**\n * The border color of the date input boxes.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @type {Highcharts.ColorString}\n * @since 1.3.7\n */\n inputBoxBorderColor: 'none',\n /**\n * The pixel height of the date input boxes.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @since 1.3.7\n */\n inputBoxHeight: 17,\n /**\n * The pixel width of the date input boxes. When `undefined`, the width\n * is fitted to the rendered content.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @type {number|undefined}\n * @since 1.3.7\n */\n inputBoxWidth: void 0,\n /**\n * The date format in the input boxes when not selected for editing.\n * Defaults to `%b %e, %Y`.\n *\n * This is used to determine which type of input to show,\n * `datetime-local`, `date` or `time` and falling back to `text` when\n * the browser does not support the input type or the format contains\n * milliseconds.\n *\n * @sample {highstock} stock/rangeselector/input-type/\n * Input types\n * @sample {highstock} stock/rangeselector/input-format/\n * Milliseconds in the range selector\n *\n */\n inputDateFormat: '%b %e, %Y',\n /**\n * A custom callback function to parse values entered in the input boxes\n * and return a valid JavaScript time as milliseconds since 1970.\n * The first argument passed is a value to parse,\n * second is a boolean indicating use of the UTC time.\n *\n * This will only get called for inputs of type `text`. Since v8.2.3,\n * the input type is dynamically determined based on the granularity\n * of the `inputDateFormat` and the browser support.\n *\n * @sample {highstock} stock/rangeselector/input-format/\n * Milliseconds in the range selector\n *\n * @type {Highcharts.RangeSelectorParseCallbackFunction}\n * @since 1.3.3\n */\n inputDateParser: void 0,\n /**\n * The date format in the input boxes when they are selected for\n * editing. This must be a format that is recognized by JavaScript\n * Date.parse.\n *\n * This will only be used for inputs of type `text`. Since v8.2.3,\n * the input type is dynamically determined based on the granularity\n * of the `inputDateFormat` and the browser support.\n *\n * @sample {highstock} stock/rangeselector/input-format/\n * Milliseconds in the range selector\n *\n */\n inputEditDateFormat: '%Y-%m-%d',\n /**\n * Enable or disable the date input boxes.\n */\n inputEnabled: true,\n /**\n * Positioning for the input boxes. Allowed properties are `align`,\n * `x` and `y`.\n *\n * @since 1.2.4\n */\n inputPosition: {\n /**\n * The alignment of the input box. Allowed properties are `left`,\n * `center`, `right`.\n *\n * @sample {highstock} stock/rangeselector/input-button-position/\n * Alignment\n *\n * @type {Highcharts.AlignValue}\n * @since 6.0.0\n */\n align: 'right',\n /**\n * X offset of the input row.\n */\n x: 0,\n /**\n * Y offset of the input row.\n */\n y: 0\n },\n /**\n * The space in pixels between the labels and the date input boxes in\n * the range selector.\n *\n * @since 9.0.0\n */\n inputSpacing: 5,\n /**\n * The index of the button to appear pre-selected.\n *\n * @type {number}\n */\n selected: void 0,\n /**\n * Positioning for the button row.\n *\n * @since 1.2.4\n */\n buttonPosition: {\n /**\n * The alignment of the input box. Allowed properties are `left`,\n * `center`, `right`.\n *\n * @sample {highstock} stock/rangeselector/input-button-position/\n * Alignment\n *\n * @type {Highcharts.AlignValue}\n * @since 6.0.0\n */\n align: 'left',\n /**\n * X offset of the button row.\n */\n x: 0,\n /**\n * Y offset of the button row.\n */\n y: 0\n },\n /**\n * CSS for the HTML inputs in the range selector.\n *\n * In styled mode, the inputs are styled by the\n * `.highcharts-range-input text` rule in SVG mode, and\n * `input.highcharts-range-selector` when active.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @type {Highcharts.CSSObject}\n * @apioption rangeSelector.inputStyle\n */\n inputStyle: {\n /** @ignore */\n color: \"#335cad\" /* Palette.highlightColor80 */,\n /** @ignore */\n cursor: 'pointer'\n },\n /**\n * CSS styles for the labels - the Zoom, From and To texts.\n *\n * In styled mode, the labels are styled by the\n * `.highcharts-range-label` class.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @type {Highcharts.CSSObject}\n */\n labelStyle: {\n /** @ignore */\n color: \"#666666\" /* Palette.neutralColor60 */\n }\n };\n /* *\n *\n * Default Export\n *\n * */\n var RangeSelectorDefaults = {\n lang: lang,\n rangeSelector: rangeSelector\n };\n\n return RangeSelectorDefaults;\n });\n _registerModule(_modules, 'Stock/RangeSelector/RangeSelectorComposition.js', [_modules['Core/Defaults.js'], _modules['Stock/RangeSelector/RangeSelectorDefaults.js'], _modules['Core/Utilities.js']], function (D, RangeSelectorDefaults, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var defaultOptions = D.defaultOptions,\n setOptions = D.setOptions;\n var addEvent = U.addEvent,\n defined = U.defined,\n extend = U.extend,\n find = U.find,\n isNumber = U.isNumber,\n merge = U.merge,\n pick = U.pick;\n /* *\n *\n * Constants\n *\n * */\n var chartDestroyEvents = [];\n var composedMembers = [];\n /* *\n *\n * Variables\n *\n * */\n var RangeSelectorConstructor;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get the axis min value based on the range option and the current max. For\n * stock charts this is extended via the {@link RangeSelector} so that if the\n * selected range is a multiple of months or years, it is compensated for\n * various month lengths.\n *\n * @private\n * @function Highcharts.Axis#minFromRange\n * @return {number|undefined}\n * The new minimum value.\n */\n function axisMinFromRange() {\n var rangeOptions = this.range,\n type = rangeOptions.type,\n max = this.max,\n time = this.chart.time, \n // Get the true range from a start date\n getTrueRange = function (base,\n count) {\n var timeName = type === 'year' ?\n 'FullYear' : 'Month';\n var date = new time.Date(base);\n var basePeriod = time.get(timeName,\n date);\n time.set(timeName, date, basePeriod + count);\n if (basePeriod === time.get(timeName, date)) {\n time.set('Date', date, 0); // #6537\n }\n return date.getTime() - base;\n };\n var min,\n range;\n if (isNumber(rangeOptions)) {\n min = max - rangeOptions;\n range = rangeOptions;\n }\n else if (rangeOptions) {\n min = max + getTrueRange(max, -(rangeOptions.count || 1));\n // Let the fixedRange reflect initial settings (#5930)\n if (this.chart) {\n this.chart.fixedRange = max - min;\n }\n }\n var dataMin = pick(this.dataMin,\n Number.MIN_VALUE);\n if (!isNumber(min)) {\n min = dataMin;\n }\n if (min <= dataMin) {\n min = dataMin;\n if (typeof range === 'undefined') { // #4501\n range = getTrueRange(min, rangeOptions.count);\n }\n this.newMax = Math.min(min + range, pick(this.dataMax, Number.MAX_VALUE));\n }\n if (!isNumber(max)) {\n min = void 0;\n }\n else if (!isNumber(rangeOptions) &&\n rangeOptions &&\n rangeOptions._offsetMin) {\n min += rangeOptions._offsetMin;\n }\n return min;\n }\n /**\n * @private\n */\n function compose(AxisClass, ChartClass, RangeSelectorClass) {\n RangeSelectorConstructor = RangeSelectorClass;\n if (composedMembers.indexOf(AxisClass) === -1) {\n composedMembers.push(AxisClass);\n AxisClass.prototype.minFromRange = axisMinFromRange;\n }\n if (composedMembers.indexOf(ChartClass) === -1) {\n composedMembers.push(ChartClass);\n addEvent(ChartClass, 'afterGetContainer', onChartAfterGetContainer);\n addEvent(ChartClass, 'beforeRender', onChartBeforeRender);\n addEvent(ChartClass, 'destroy', onChartDestroy);\n addEvent(ChartClass, 'getMargins', onChartGetMargins);\n addEvent(ChartClass, 'render', onChartRender);\n addEvent(ChartClass, 'update', onChartUpdate);\n var chartProto = ChartClass.prototype;\n chartProto.callbacks.push(onChartCallback);\n }\n if (composedMembers.indexOf(setOptions) === -1) {\n extend(defaultOptions, { rangeSelector: RangeSelectorDefaults.rangeSelector });\n extend(defaultOptions.lang, RangeSelectorDefaults.lang);\n }\n }\n /**\n * Initialize rangeselector for stock charts\n * @private\n */\n function onChartAfterGetContainer() {\n if (this.options.rangeSelector &&\n this.options.rangeSelector.enabled) {\n this.rangeSelector = new RangeSelectorConstructor(this);\n }\n }\n /**\n * @private\n */\n function onChartBeforeRender() {\n var chart = this,\n axes = chart.axes,\n rangeSelector = chart.rangeSelector;\n if (rangeSelector) {\n if (isNumber(rangeSelector.deferredYTDClick)) {\n rangeSelector.clickButton(rangeSelector.deferredYTDClick);\n delete rangeSelector.deferredYTDClick;\n }\n axes.forEach(function (axis) {\n axis.updateNames();\n axis.setScale();\n });\n chart.getAxisMargins();\n rangeSelector.render();\n var verticalAlign = rangeSelector.options.verticalAlign;\n if (!rangeSelector.options.floating) {\n if (verticalAlign === 'bottom') {\n this.extraBottomMargin = true;\n }\n else if (verticalAlign !== 'middle') {\n this.extraTopMargin = true;\n }\n }\n }\n }\n /**\n * @private\n */\n function onChartCallback(chart) {\n var extremes,\n legend,\n alignTo,\n verticalAlign;\n var rangeSelector = chart.rangeSelector,\n redraw = function () {\n if (rangeSelector) {\n extremes = chart.xAxis[0].getExtremes();\n legend = chart.legend;\n verticalAlign = (rangeSelector &&\n rangeSelector.options.verticalAlign);\n if (isNumber(extremes.min)) {\n rangeSelector.render(extremes.min, extremes.max);\n }\n // Re-align the legend so that it's below the rangeselector\n if (legend.display &&\n verticalAlign === 'top' &&\n verticalAlign === legend.options.verticalAlign) {\n // Create a new alignment box for the legend.\n alignTo = merge(chart.spacingBox);\n if (legend.options.layout === 'vertical') {\n alignTo.y = chart.plotTop;\n }\n else {\n alignTo.y += rangeSelector.getHeight();\n }\n legend.group.placed = false; // Don't animate the alignment.\n legend.align(alignTo);\n }\n }\n };\n if (rangeSelector) {\n var events = find(chartDestroyEvents,\n function (e) { return e[0] === chart; });\n if (!events) {\n chartDestroyEvents.push([chart, [\n // redraw the scroller on setExtremes\n addEvent(chart.xAxis[0], 'afterSetExtremes', function (e) {\n if (rangeSelector) {\n rangeSelector.render(e.min, e.max);\n }\n }),\n // redraw the scroller chart resize\n addEvent(chart, 'redraw', redraw)\n ]]);\n }\n // do it now\n redraw();\n }\n }\n /**\n * Remove resize/afterSetExtremes at chart destroy.\n * @private\n */\n function onChartDestroy() {\n for (var i = 0, iEnd = chartDestroyEvents.length; i < iEnd; ++i) {\n var events = chartDestroyEvents[i];\n if (events[0] === this) {\n events[1].forEach(function (unbind) { return unbind(); });\n chartDestroyEvents.splice(i, 1);\n return;\n }\n }\n }\n function onChartGetMargins() {\n var rangeSelector = this.rangeSelector;\n if (rangeSelector) {\n var rangeSelectorHeight = rangeSelector.getHeight();\n if (this.extraTopMargin) {\n this.plotTop += rangeSelectorHeight;\n }\n if (this.extraBottomMargin) {\n this.marginBottom += rangeSelectorHeight;\n }\n }\n }\n /**\n * @private\n */\n function onChartRender() {\n var chart = this,\n rangeSelector = chart.rangeSelector;\n if (rangeSelector && !rangeSelector.options.floating) {\n rangeSelector.render();\n var verticalAlign = rangeSelector.options.verticalAlign;\n if (verticalAlign === 'bottom') {\n this.extraBottomMargin = true;\n }\n else if (verticalAlign !== 'middle') {\n this.extraTopMargin = true;\n }\n }\n }\n /**\n * @private\n */\n function onChartUpdate(e) {\n var chart = this,\n options = e.options,\n optionsRangeSelector = options.rangeSelector,\n extraBottomMarginWas = this.extraBottomMargin,\n extraTopMarginWas = this.extraTopMargin;\n var rangeSelector = chart.rangeSelector;\n if (optionsRangeSelector &&\n optionsRangeSelector.enabled &&\n !defined(rangeSelector) &&\n this.options.rangeSelector) {\n this.options.rangeSelector.enabled = true;\n this.rangeSelector = rangeSelector = new RangeSelectorConstructor(this);\n }\n this.extraBottomMargin = false;\n this.extraTopMargin = false;\n if (rangeSelector) {\n onChartCallback(this);\n var verticalAlign = (optionsRangeSelector &&\n optionsRangeSelector.verticalAlign) || (rangeSelector.options && rangeSelector.options.verticalAlign);\n if (!rangeSelector.options.floating) {\n if (verticalAlign === 'bottom') {\n this.extraBottomMargin = true;\n }\n else if (verticalAlign !== 'middle') {\n this.extraTopMargin = true;\n }\n }\n if (this.extraBottomMargin !== extraBottomMarginWas ||\n this.extraTopMargin !== extraTopMarginWas) {\n this.isDirtyBox = true;\n }\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n var RangeSelectorComposition = {\n compose: compose\n };\n\n return RangeSelectorComposition;\n });\n _registerModule(_modules, 'Stock/RangeSelector/RangeSelector.js', [_modules['Core/Axis/Axis.js'], _modules['Core/Defaults.js'], _modules['Core/Globals.js'], _modules['Stock/RangeSelector/RangeSelectorComposition.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (Axis, D, H, RangeSelectorComposition, SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var defaultOptions = D.defaultOptions;\n var addEvent = U.addEvent,\n createElement = U.createElement,\n css = U.css,\n defined = U.defined,\n destroyObjectProperties = U.destroyObjectProperties,\n discardElement = U.discardElement,\n extend = U.extend,\n fireEvent = U.fireEvent,\n isNumber = U.isNumber,\n merge = U.merge,\n objectEach = U.objectEach,\n pad = U.pad,\n pick = U.pick,\n pInt = U.pInt,\n splat = U.splat;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get the preferred input type based on a date format string.\n *\n * @private\n * @function preferredInputType\n */\n function preferredInputType(format) {\n var ms = format.indexOf('%L') !== -1;\n if (ms) {\n return 'text';\n }\n var date = ['a', 'A', 'd', 'e', 'w', 'b', 'B', 'm', 'o', 'y', 'Y']\n .some(function (char) { return format.indexOf('%' + char) !== -1; });\n var time = ['H', 'k', 'I', 'l', 'M', 'S']\n .some(function (char) { return format.indexOf('%' + char) !== -1; });\n if (date && time) {\n return 'datetime-local';\n }\n if (date) {\n return 'date';\n }\n if (time) {\n return 'time';\n }\n return 'text';\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * The range selector.\n *\n * @private\n * @class\n * @name Highcharts.RangeSelector\n * @param {Highcharts.Chart} chart\n */\n var RangeSelector = /** @class */ (function () {\n /* *\n *\n * Constructor\n *\n * */\n function RangeSelector(chart) {\n /* *\n *\n * Properties\n *\n * */\n this.buttons = void 0;\n this.buttonOptions = RangeSelector.prototype.defaultButtons;\n this.initialButtonGroupWidth = 0;\n this.options = void 0;\n this.chart = chart;\n this.init(chart);\n }\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * @private\n */\n RangeSelector.compose = function (AxisClass, ChartClass) {\n RangeSelectorComposition.compose(AxisClass, ChartClass, RangeSelector);\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * The method to run when one of the buttons in the range selectors is\n * clicked\n *\n * @private\n * @function Highcharts.RangeSelector#clickButton\n * @param {number} i\n * The index of the button\n * @param {boolean} [redraw]\n */\n RangeSelector.prototype.clickButton = function (i, redraw) {\n var rangeSelector = this,\n chart = rangeSelector.chart,\n rangeOptions = rangeSelector.buttonOptions[i],\n baseAxis = chart.xAxis[0],\n unionExtremes = (chart.scroller && chart.scroller.getUnionExtremes()) || baseAxis || {},\n type = rangeOptions.type,\n dataGrouping = rangeOptions.dataGrouping;\n var dataMin = unionExtremes.dataMin,\n dataMax = unionExtremes.dataMax,\n newMin,\n newMax = baseAxis && Math.round(Math.min(baseAxis.max,\n pick(dataMax,\n baseAxis.max))), // #1568\n baseXAxisOptions,\n range = rangeOptions._range,\n rangeMin,\n minSetting,\n rangeSetting,\n ctx,\n ytdExtremes,\n addOffsetMin = true;\n // chart has no data, base series is removed\n if (dataMin === null || dataMax === null) {\n return;\n }\n // Set the fixed range before range is altered\n chart.fixedRange = range;\n rangeSelector.setSelected(i);\n // Apply dataGrouping associated to button\n if (dataGrouping) {\n this.forcedDataGrouping = true;\n Axis.prototype.setDataGrouping.call(baseAxis || { chart: this.chart }, dataGrouping, false);\n this.frozenStates = rangeOptions.preserveDataGrouping;\n }\n // Apply range\n if (type === 'month' || type === 'year') {\n if (!baseAxis) {\n // This is set to the user options and picked up later when the\n // axis is instantiated so that we know the min and max.\n range = rangeOptions;\n }\n else {\n ctx = {\n range: rangeOptions,\n max: newMax,\n chart: chart,\n dataMin: dataMin,\n dataMax: dataMax\n };\n newMin = baseAxis.minFromRange.call(ctx);\n if (isNumber(ctx.newMax)) {\n newMax = ctx.newMax;\n }\n // #15799: offsetMin is added in minFromRange so that it works\n // with pre-selected buttons as well\n addOffsetMin = false;\n }\n // Fixed times like minutes, hours, days\n }\n else if (range) {\n newMin = Math.max(newMax - range, dataMin);\n newMax = Math.min(newMin + range, dataMax);\n addOffsetMin = false;\n }\n else if (type === 'ytd') {\n // On user clicks on the buttons, or a delayed action running from\n // the beforeRender event (below), the baseAxis is defined.\n if (baseAxis) {\n // When \"ytd\" is the pre-selected button for the initial view,\n // its calculation is delayed and rerun in the beforeRender\n // event (below). When the series are initialized, but before\n // the chart is rendered, we have access to the xData array\n // (#942).\n if (typeof dataMax === 'undefined' ||\n typeof dataMin === 'undefined') {\n dataMin = Number.MAX_VALUE;\n dataMax = Number.MIN_VALUE;\n chart.series.forEach(function (series) {\n // reassign it to the last item\n var xData = series.xData;\n if (xData) {\n dataMin = Math.min(xData[0], dataMin);\n dataMax = Math.max(xData[xData.length - 1], dataMax);\n }\n });\n redraw = false;\n }\n ytdExtremes = rangeSelector.getYTDExtremes(dataMax, dataMin, chart.time.useUTC);\n newMin = rangeMin = ytdExtremes.min;\n newMax = ytdExtremes.max;\n // \"ytd\" is pre-selected. We don't yet have access to processed\n // point and extremes data (things like pointStart and pointInterval\n // are missing), so we delay the process (#942)\n }\n else {\n rangeSelector.deferredYTDClick = i;\n return;\n }\n }\n else if (type === 'all' && baseAxis) {\n // If the navigator exist and the axis range is declared reset that\n // range and from now on only use the range set by a user, #14742.\n if (chart.navigator && chart.navigator.baseSeries[0]) {\n chart.navigator.baseSeries[0].xAxis.options.range = void 0;\n }\n newMin = dataMin;\n newMax = dataMax;\n }\n if (addOffsetMin && rangeOptions._offsetMin && defined(newMin)) {\n newMin += rangeOptions._offsetMin;\n }\n if (rangeOptions._offsetMax && defined(newMax)) {\n newMax += rangeOptions._offsetMax;\n }\n if (this.dropdown) {\n this.dropdown.selectedIndex = i + 1;\n }\n // Update the chart\n if (!baseAxis) {\n // Axis not yet instanciated. Temporarily set min and range\n // options and remove them on chart load (#4317).\n baseXAxisOptions = splat(chart.options.xAxis)[0];\n rangeSetting = baseXAxisOptions.range;\n baseXAxisOptions.range = range;\n minSetting = baseXAxisOptions.min;\n baseXAxisOptions.min = rangeMin;\n addEvent(chart, 'load', function resetMinAndRange() {\n baseXAxisOptions.range = rangeSetting;\n baseXAxisOptions.min = minSetting;\n });\n }\n else {\n // Existing axis object. Set extremes after render time.\n baseAxis.setExtremes(newMin, newMax, pick(redraw, true), void 0, // auto animation\n {\n trigger: 'rangeSelectorButton',\n rangeSelectorButton: rangeOptions\n });\n }\n fireEvent(this, 'afterBtnClick');\n };\n /**\n * Set the selected option. This method only sets the internal flag, it\n * doesn't update the buttons or the actual zoomed range.\n *\n * @private\n * @function Highcharts.RangeSelector#setSelected\n * @param {number} [selected]\n */\n RangeSelector.prototype.setSelected = function (selected) {\n this.selected = this.options.selected = selected;\n };\n /**\n * Initialize the range selector\n *\n * @private\n * @function Highcharts.RangeSelector#init\n * @param {Highcharts.Chart} chart\n */\n RangeSelector.prototype.init = function (chart) {\n var rangeSelector = this,\n options = chart.options.rangeSelector,\n buttonOptions = (options.buttons || rangeSelector.defaultButtons.slice()),\n selectedOption = options.selected,\n blurInputs = function () {\n var minInput = rangeSelector.minInput,\n maxInput = rangeSelector.maxInput;\n // #3274 in some case blur is not defined\n if (minInput && (minInput.blur)) {\n fireEvent(minInput, 'blur');\n }\n if (maxInput && (maxInput.blur)) {\n fireEvent(maxInput, 'blur');\n }\n };\n rangeSelector.chart = chart;\n rangeSelector.options = options;\n rangeSelector.buttons = [];\n rangeSelector.buttonOptions = buttonOptions;\n this.eventsToUnbind = [];\n this.eventsToUnbind.push(addEvent(chart.container, 'mousedown', blurInputs));\n this.eventsToUnbind.push(addEvent(chart, 'resize', blurInputs));\n // Extend the buttonOptions with actual range\n buttonOptions.forEach(rangeSelector.computeButtonRange);\n // zoomed range based on a pre-selected button index\n if (typeof selectedOption !== 'undefined' &&\n buttonOptions[selectedOption]) {\n this.clickButton(selectedOption, false);\n }\n this.eventsToUnbind.push(addEvent(chart, 'load', function () {\n // If a data grouping is applied to the current button, release it\n // when extremes change\n if (chart.xAxis && chart.xAxis[0]) {\n addEvent(chart.xAxis[0], 'setExtremes', function (e) {\n if (this.max - this.min !==\n chart.fixedRange &&\n e.trigger !== 'rangeSelectorButton' &&\n e.trigger !== 'updatedData' &&\n rangeSelector.forcedDataGrouping &&\n !rangeSelector.frozenStates) {\n this.setDataGrouping(false, false);\n }\n });\n }\n }));\n };\n /**\n * Dynamically update the range selector buttons after a new range has been\n * set\n *\n * @private\n * @function Highcharts.RangeSelector#updateButtonStates\n */\n RangeSelector.prototype.updateButtonStates = function () {\n var rangeSelector = this,\n chart = this.chart,\n dropdown = this.dropdown,\n baseAxis = chart.xAxis[0],\n actualRange = Math.round(baseAxis.max - baseAxis.min),\n hasNoData = !baseAxis.hasVisibleSeries,\n day = 24 * 36e5, // A single day in milliseconds\n unionExtremes = (chart.scroller &&\n chart.scroller.getUnionExtremes()) || baseAxis,\n dataMin = unionExtremes.dataMin,\n dataMax = unionExtremes.dataMax,\n ytdExtremes = rangeSelector.getYTDExtremes(dataMax,\n dataMin,\n chart.time.useUTC),\n ytdMin = ytdExtremes.min,\n ytdMax = ytdExtremes.max,\n selected = rangeSelector.selected,\n allButtonsEnabled = rangeSelector.options.allButtonsEnabled,\n buttons = rangeSelector.buttons;\n var selectedExists = isNumber(selected);\n rangeSelector.buttonOptions.forEach(function (rangeOptions, i) {\n var range = rangeOptions._range,\n type = rangeOptions.type,\n count = rangeOptions.count || 1,\n button = buttons[i],\n offsetRange = rangeOptions._offsetMax -\n rangeOptions._offsetMin,\n isSelected = i === selected, \n // Disable buttons where the range exceeds what is allowed in\n // the current view\n isTooGreatRange = range >\n dataMax - dataMin, \n // Disable buttons where the range is smaller than the minimum\n // range\n isTooSmallRange = range < baseAxis.minRange;\n var state = 0, \n // Do not select the YTD button if not explicitly told so\n isYTDButNotSelected = false, \n // Disable the All button if we're already showing all\n isAllButAlreadyShowingAll = false,\n isSameRange = range === actualRange;\n // Months and years have a variable range so we check the extremes\n if ((type === 'month' || type === 'year') &&\n (actualRange + 36e5 >=\n { month: 28, year: 365 }[type] * day * count - offsetRange) &&\n (actualRange - 36e5 <=\n { month: 31, year: 366 }[type] * day * count + offsetRange)) {\n isSameRange = true;\n }\n else if (type === 'ytd') {\n isSameRange = (ytdMax - ytdMin + offsetRange) === actualRange;\n isYTDButNotSelected = !isSelected;\n }\n else if (type === 'all') {\n isSameRange = (baseAxis.max - baseAxis.min >=\n dataMax - dataMin);\n isAllButAlreadyShowingAll = (!isSelected &&\n selectedExists &&\n isSameRange);\n }\n // The new zoom area happens to match the range for a button - mark\n // it selected. This happens when scrolling across an ordinal gap.\n // It can be seen in the intraday demos when selecting 1h and scroll\n // across the night gap.\n var disable = (!allButtonsEnabled &&\n (isTooGreatRange ||\n isTooSmallRange ||\n isAllButAlreadyShowingAll ||\n hasNoData));\n var select = ((isSelected && isSameRange) ||\n (isSameRange && !selectedExists && !isYTDButNotSelected) ||\n (isSelected && rangeSelector.frozenStates));\n if (disable) {\n state = 3;\n }\n else if (select) {\n selectedExists = true; // Only one button can be selected\n state = 2;\n }\n // If state has changed, update the button\n if (button.state !== state) {\n button.setState(state);\n if (dropdown) {\n dropdown.options[i + 1].disabled = disable;\n if (state === 2) {\n dropdown.selectedIndex = i + 1;\n }\n }\n // Reset (#9209)\n if (state === 0 && selected === i) {\n rangeSelector.setSelected();\n }\n }\n });\n };\n /**\n * Compute and cache the range for an individual button\n *\n * @private\n * @function Highcharts.RangeSelector#computeButtonRange\n * @param {Highcharts.RangeSelectorButtonsOptions} rangeOptions\n */\n RangeSelector.prototype.computeButtonRange = function (rangeOptions) {\n var type = rangeOptions.type,\n count = rangeOptions.count || 1, \n // these time intervals have a fixed number of milliseconds, as\n // opposed to month, ytd and year\n fixedTimes = {\n millisecond: 1,\n second: 1000,\n minute: 60 * 1000,\n hour: 3600 * 1000,\n day: 24 * 3600 * 1000,\n week: 7 * 24 * 3600 * 1000\n };\n // Store the range on the button object\n if (fixedTimes[type]) {\n rangeOptions._range = fixedTimes[type] * count;\n }\n else if (type === 'month' || type === 'year') {\n rangeOptions._range = {\n month: 30,\n year: 365\n }[type] * 24 * 36e5 * count;\n }\n rangeOptions._offsetMin = pick(rangeOptions.offsetMin, 0);\n rangeOptions._offsetMax = pick(rangeOptions.offsetMax, 0);\n rangeOptions._range +=\n rangeOptions._offsetMax - rangeOptions._offsetMin;\n };\n /**\n * Get the unix timestamp of a HTML input for the dates\n *\n * @private\n * @function Highcharts.RangeSelector#getInputValue\n */\n RangeSelector.prototype.getInputValue = function (name) {\n var input = name === 'min' ? this.minInput : this.maxInput;\n var options = this.chart.options\n .rangeSelector;\n var time = this.chart.time;\n if (input) {\n return ((input.type === 'text' && options.inputDateParser) ||\n this.defaultInputDateParser)(input.value, time.useUTC, time);\n }\n return 0;\n };\n /**\n * Set the internal and displayed value of a HTML input for the dates\n *\n * @private\n * @function Highcharts.RangeSelector#setInputValue\n */\n RangeSelector.prototype.setInputValue = function (name, inputTime) {\n var options = this.options, time = this.chart.time, input = name === 'min' ? this.minInput : this.maxInput, dateBox = name === 'min' ? this.minDateBox : this.maxDateBox;\n if (input) {\n var hcTimeAttr = input.getAttribute('data-hc-time');\n var updatedTime = defined(hcTimeAttr) ? Number(hcTimeAttr) : void 0;\n if (defined(inputTime)) {\n var previousTime = updatedTime;\n if (defined(previousTime)) {\n input.setAttribute('data-hc-time-previous', previousTime);\n }\n input.setAttribute('data-hc-time', inputTime);\n updatedTime = inputTime;\n }\n input.value = time.dateFormat((this.inputTypeFormats[input.type] ||\n options.inputEditDateFormat), updatedTime);\n if (dateBox) {\n dateBox.attr({\n text: time.dateFormat(options.inputDateFormat, updatedTime)\n });\n }\n }\n };\n /**\n * Set the min and max value of a HTML input for the dates\n *\n * @private\n * @function Highcharts.RangeSelector#setInputExtremes\n */\n RangeSelector.prototype.setInputExtremes = function (name, min, max) {\n var input = name === 'min' ? this.minInput : this.maxInput;\n if (input) {\n var format = this.inputTypeFormats[input.type];\n var time = this.chart.time;\n if (format) {\n var newMin = time.dateFormat(format,\n min);\n if (input.min !== newMin) {\n input.min = newMin;\n }\n var newMax = time.dateFormat(format,\n max);\n if (input.max !== newMax) {\n input.max = newMax;\n }\n }\n }\n };\n /**\n * @private\n * @function Highcharts.RangeSelector#showInput\n * @param {string} name\n */\n RangeSelector.prototype.showInput = function (name) {\n var dateBox = name === 'min' ? this.minDateBox : this.maxDateBox;\n var input = name === 'min' ? this.minInput : this.maxInput;\n if (input && dateBox && this.inputGroup) {\n var isTextInput = input.type === 'text';\n var _a = this.inputGroup,\n translateX = _a.translateX,\n translateY = _a.translateY;\n var inputBoxWidth = this.options.inputBoxWidth;\n css(input, {\n width: isTextInput ?\n ((dateBox.width + (inputBoxWidth ? -2 : 20)) + 'px') :\n 'auto',\n height: isTextInput ? ((dateBox.height - 2) + 'px') : 'auto',\n border: '2px solid silver'\n });\n if (isTextInput && inputBoxWidth) {\n css(input, {\n left: (translateX + dateBox.x) + 'px',\n top: translateY + 'px'\n });\n // Inputs of types date, time or datetime-local should be centered\n // on top of the dateBox\n }\n else {\n css(input, {\n left: Math.min(Math.round(dateBox.x +\n translateX -\n (input.offsetWidth - dateBox.width) / 2), this.chart.chartWidth - input.offsetWidth) + 'px',\n top: (translateY - (input.offsetHeight - dateBox.height) / 2) + 'px'\n });\n }\n }\n };\n /**\n * @private\n * @function Highcharts.RangeSelector#hideInput\n * @param {string} name\n */\n RangeSelector.prototype.hideInput = function (name) {\n var input = name === 'min' ? this.minInput : this.maxInput;\n if (input) {\n css(input, {\n top: '-9999em',\n border: 0,\n width: '1px',\n height: '1px'\n });\n }\n };\n /**\n * @private\n * @function Highcharts.RangeSelector#defaultInputDateParser\n */\n RangeSelector.prototype.defaultInputDateParser = function (inputDate, useUTC, time) {\n var hasTimezone = function (str) {\n return str.length > 6 &&\n (str.lastIndexOf('-') === str.length - 6 ||\n str.lastIndexOf('+') === str.length - 6);\n };\n var input = inputDate.split('/').join('-').split(' ').join('T');\n if (input.indexOf('T') === -1) {\n input += 'T00:00';\n }\n if (useUTC) {\n input += 'Z';\n }\n else if (H.isSafari && !hasTimezone(input)) {\n var offset = new Date(input).getTimezoneOffset() / 60;\n input += offset <= 0 ? \"+\".concat(pad(-offset), \":00\") : \"-\".concat(pad(offset), \":00\");\n }\n var date = Date.parse(input);\n // If the value isn't parsed directly to a value by the\n // browser's Date.parse method, like YYYY-MM-DD in IE8, try\n // parsing it a different way\n if (!isNumber(date)) {\n var parts = inputDate.split('-');\n date = Date.UTC(pInt(parts[0]), pInt(parts[1]) - 1, pInt(parts[2]));\n }\n if (time && useUTC && isNumber(date)) {\n date += time.getTimezoneOffset(date);\n }\n return date;\n };\n /**\n * Draw either the 'from' or the 'to' HTML input box of the range selector\n *\n * @private\n * @function Highcharts.RangeSelector#drawInput\n */\n RangeSelector.prototype.drawInput = function (name) {\n var _a = this,\n chart = _a.chart,\n div = _a.div,\n inputGroup = _a.inputGroup;\n var rangeSelector = this,\n chartStyle = chart.renderer.style || {},\n renderer = chart.renderer,\n options = chart.options.rangeSelector,\n lang = defaultOptions.lang,\n isMin = name === 'min';\n /**\n * @private\n */\n function updateExtremes() {\n var maxInput = rangeSelector.maxInput,\n minInput = rangeSelector.minInput,\n chartAxis = chart.xAxis[0],\n dataAxis = chart.scroller && chart.scroller.xAxis ?\n chart.scroller.xAxis :\n chartAxis,\n dataMin = dataAxis.dataMin,\n dataMax = dataAxis.dataMax;\n var value = rangeSelector.getInputValue(name);\n if (value !== Number(input.getAttribute('data-hc-time-previous')) &&\n isNumber(value)) {\n input.setAttribute('data-hc-time-previous', value);\n // Validate the extremes. If it goes beyound the data min or\n // max, use the actual data extreme (#2438).\n if (isMin && maxInput && isNumber(dataMin)) {\n if (value > Number(maxInput.getAttribute('data-hc-time'))) {\n value = void 0;\n }\n else if (value < dataMin) {\n value = dataMin;\n }\n }\n else if (minInput && isNumber(dataMax)) {\n if (value < Number(minInput.getAttribute('data-hc-time'))) {\n value = void 0;\n }\n else if (value > dataMax) {\n value = dataMax;\n }\n }\n // Set the extremes\n if (typeof value !== 'undefined') { // @todo typof undefined\n chartAxis.setExtremes(isMin ? value : chartAxis.min, isMin ? chartAxis.max : value, void 0, void 0, { trigger: 'rangeSelectorInput' });\n }\n }\n }\n // Create the text label\n var text = lang[isMin ? 'rangeSelectorFrom' : 'rangeSelectorTo'] || '';\n var label = renderer\n .label(text, 0)\n .addClass('highcharts-range-label')\n .attr({\n padding: text ? 2 : 0,\n height: text ? options.inputBoxHeight : 0\n })\n .add(inputGroup);\n // Create an SVG label that shows updated date ranges and and records\n // click events that bring in the HTML input.\n var dateBox = renderer\n .label('', 0)\n .addClass('highcharts-range-input')\n .attr({\n padding: 2,\n width: options.inputBoxWidth,\n height: options.inputBoxHeight,\n 'text-align': 'center'\n })\n .on('click',\n function () {\n // If it is already focused, the onfocus event doesn't fire\n // (#3713)\n rangeSelector.showInput(name);\n rangeSelector[name + 'Input'].focus();\n });\n if (!chart.styledMode) {\n dateBox.attr({\n stroke: options.inputBoxBorderColor,\n 'stroke-width': 1\n });\n }\n dateBox.add(inputGroup);\n // Create the HTML input element. This is rendered as 1x1 pixel then set\n // to the right size when focused.\n var input = createElement('input', {\n name: name,\n className: 'highcharts-range-selector'\n },\n void 0,\n div);\n // #14788: Setting input.type to an unsupported type throws in IE, so\n // we need to use setAttribute instead\n input.setAttribute('type', preferredInputType(options.inputDateFormat || '%b %e, %Y'));\n if (!chart.styledMode) {\n // Styles\n label.css(merge(chartStyle, options.labelStyle));\n dateBox.css(merge({\n color: \"#333333\" /* Palette.neutralColor80 */\n }, chartStyle, options.inputStyle));\n css(input, extend({\n position: 'absolute',\n border: 0,\n boxShadow: '0 0 15px rgba(0,0,0,0.3)',\n width: '1px',\n height: '1px',\n padding: 0,\n textAlign: 'center',\n fontSize: chartStyle.fontSize,\n fontFamily: chartStyle.fontFamily,\n top: '-9999em' // #4798\n }, options.inputStyle));\n }\n // Blow up the input box\n input.onfocus = function () {\n rangeSelector.showInput(name);\n };\n // Hide away the input box\n input.onblur = function () {\n // update extermes only when inputs are active\n if (input === H.doc.activeElement) { // Only when focused\n // Update also when no `change` event is triggered, like when\n // clicking inside the SVG (#4710)\n updateExtremes();\n }\n // #10404 - move hide and blur outside focus\n rangeSelector.hideInput(name);\n rangeSelector.setInputValue(name);\n input.blur(); // #4606\n };\n var keyDown = false;\n // handle changes in the input boxes\n input.onchange = function () {\n // Update extremes and blur input when clicking date input calendar\n if (!keyDown) {\n updateExtremes();\n rangeSelector.hideInput(name);\n input.blur();\n }\n };\n input.onkeypress = function (event) {\n // IE does not fire onchange on enter\n if (event.keyCode === 13) {\n updateExtremes();\n }\n };\n input.onkeydown = function (event) {\n keyDown = true;\n // Arrow keys\n if (event.keyCode === 38 || event.keyCode === 40) {\n updateExtremes();\n }\n };\n input.onkeyup = function () {\n keyDown = false;\n };\n return { dateBox: dateBox, input: input, label: label };\n };\n /**\n * Get the position of the range selector buttons and inputs. This can be\n * overridden from outside for custom positioning.\n *\n * @private\n * @function Highcharts.RangeSelector#getPosition\n */\n RangeSelector.prototype.getPosition = function () {\n var chart = this.chart,\n options = chart.options.rangeSelector,\n top = options.verticalAlign === 'top' ?\n chart.plotTop - chart.axisOffset[0] :\n 0; // set offset only for varticalAlign top\n return {\n buttonTop: top + options.buttonPosition.y,\n inputTop: top + options.inputPosition.y - 10\n };\n };\n /**\n * Get the extremes of YTD. Will choose dataMax if its value is lower than\n * the current timestamp. Will choose dataMin if its value is higher than\n * the timestamp for the start of current year.\n *\n * @private\n * @function Highcharts.RangeSelector#getYTDExtremes\n * @return {*}\n * Returns min and max for the YTD\n */\n RangeSelector.prototype.getYTDExtremes = function (dataMax, dataMin, useUTC) {\n var time = this.chart.time,\n now = new time.Date(dataMax),\n year = time.get('FullYear',\n now),\n startOfYear = useUTC ?\n time.Date.UTC(year, 0, 1) : // eslint-disable-line new-cap\n +new time.Date(year, 0, 1),\n min = Math.max(dataMin,\n startOfYear),\n ts = now.getTime();\n return {\n max: Math.min(dataMax || ts, ts),\n min: min\n };\n };\n /**\n * Render the range selector including the buttons and the inputs. The first\n * time render is called, the elements are created and positioned. On\n * subsequent calls, they are moved and updated.\n *\n * @private\n * @function Highcharts.RangeSelector#render\n * @param {number} [min]\n * X axis minimum\n * @param {number} [max]\n * X axis maximum\n */\n RangeSelector.prototype.render = function (min, max) {\n var chart = this.chart,\n renderer = chart.renderer,\n container = chart.container,\n chartOptions = chart.options,\n options = chartOptions.rangeSelector, \n // Place inputs above the container\n inputsZIndex = pick(chartOptions.chart.style &&\n chartOptions.chart.style.zIndex, 0) + 1,\n inputEnabled = options.inputEnabled,\n rendered = this.rendered;\n if (options.enabled === false) {\n return;\n }\n // create the elements\n if (!rendered) {\n this.group = renderer.g('range-selector-group')\n .attr({\n zIndex: 7\n })\n .add();\n this.div = createElement('div', void 0, {\n position: 'relative',\n height: 0,\n zIndex: inputsZIndex\n });\n if (this.buttonOptions.length) {\n this.renderButtons();\n }\n // First create a wrapper outside the container in order to make\n // the inputs work and make export correct\n if (container.parentNode) {\n container.parentNode.insertBefore(this.div, container);\n }\n if (inputEnabled) {\n // Create the group to keep the inputs\n this.inputGroup = renderer.g('input-group').add(this.group);\n var minElems = this.drawInput('min');\n this.minDateBox = minElems.dateBox;\n this.minLabel = minElems.label;\n this.minInput = minElems.input;\n var maxElems = this.drawInput('max');\n this.maxDateBox = maxElems.dateBox;\n this.maxLabel = maxElems.label;\n this.maxInput = maxElems.input;\n }\n }\n if (inputEnabled) {\n // Set or reset the input values\n this.setInputValue('min', min);\n this.setInputValue('max', max);\n var unionExtremes = (chart.scroller && chart.scroller.getUnionExtremes()) || chart.xAxis[0] || {};\n if (defined(unionExtremes.dataMin) &&\n defined(unionExtremes.dataMax)) {\n var minRange = chart.xAxis[0].minRange || 0;\n this.setInputExtremes('min', unionExtremes.dataMin, Math.min(unionExtremes.dataMax, this.getInputValue('max')) - minRange);\n this.setInputExtremes('max', Math.max(unionExtremes.dataMin, this.getInputValue('min')) + minRange, unionExtremes.dataMax);\n }\n // Reflow\n if (this.inputGroup) {\n var x_1 = 0;\n [\n this.minLabel,\n this.minDateBox,\n this.maxLabel,\n this.maxDateBox\n ].forEach(function (label) {\n if (label) {\n var width = label.getBBox().width;\n if (width) {\n label.attr({ x: x_1 });\n x_1 += width + options.inputSpacing;\n }\n }\n });\n }\n }\n this.alignElements();\n this.rendered = true;\n };\n /**\n * Render the range buttons. This only runs the first time, later the\n * positioning is laid out in alignElements.\n *\n * @private\n * @function Highcharts.RangeSelector#renderButtons\n */\n RangeSelector.prototype.renderButtons = function () {\n var _this = this;\n var _a = this,\n buttons = _a.buttons,\n chart = _a.chart,\n options = _a.options;\n var lang = defaultOptions.lang;\n var renderer = chart.renderer;\n var buttonTheme = merge(options.buttonTheme);\n var states = buttonTheme && buttonTheme.states;\n // Prevent the button from resetting the width when the button state\n // changes since we need more control over the width when collapsing\n // the buttons\n var width = buttonTheme.width || 28;\n delete buttonTheme.width;\n delete buttonTheme.states;\n this.buttonGroup = renderer.g('range-selector-buttons').add(this.group);\n var dropdown = this.dropdown = createElement('select',\n void 0, {\n position: 'absolute',\n width: '1px',\n height: '1px',\n padding: 0,\n border: 0,\n top: '-9999em',\n cursor: 'pointer',\n opacity: 0.0001\n },\n this.div);\n // Prevent page zoom on iPhone\n addEvent(dropdown, 'touchstart', function () {\n dropdown.style.fontSize = '16px';\n });\n // Forward events from select to button\n [\n [H.isMS ? 'mouseover' : 'mouseenter'],\n [H.isMS ? 'mouseout' : 'mouseleave'],\n ['change', 'click']\n ].forEach(function (_a) {\n var from = _a[0],\n to = _a[1];\n addEvent(dropdown, from, function () {\n var button = buttons[_this.currentButtonIndex()];\n if (button) {\n fireEvent(button.element, to || from);\n }\n });\n });\n this.zoomText = renderer\n .label((lang && lang.rangeSelectorZoom) || '', 0)\n .attr({\n padding: options.buttonTheme.padding,\n height: options.buttonTheme.height,\n paddingLeft: 0,\n paddingRight: 0\n })\n .add(this.buttonGroup);\n if (!this.chart.styledMode) {\n this.zoomText.css(options.labelStyle);\n buttonTheme['stroke-width'] = pick(buttonTheme['stroke-width'], 0);\n }\n createElement('option', {\n textContent: this.zoomText.textStr,\n disabled: true\n }, void 0, dropdown);\n this.buttonOptions.forEach(function (rangeOptions, i) {\n createElement('option', {\n textContent: rangeOptions.title || rangeOptions.text\n }, void 0, dropdown);\n buttons[i] = renderer\n .button(rangeOptions.text, 0, 0, function (e) {\n // extract events from button object and call\n var buttonEvents = (rangeOptions.events && rangeOptions.events.click);\n var callDefaultEvent;\n if (buttonEvents) {\n callDefaultEvent =\n buttonEvents.call(rangeOptions, e);\n }\n if (callDefaultEvent !== false) {\n _this.clickButton(i);\n }\n _this.isActive = true;\n }, buttonTheme, states && states.hover, states && states.select, states && states.disabled)\n .attr({\n 'text-align': 'center',\n width: width\n })\n .add(_this.buttonGroup);\n if (rangeOptions.title) {\n buttons[i].attr('title', rangeOptions.title);\n }\n });\n };\n /**\n * Align the elements horizontally and vertically.\n *\n * @private\n * @function Highcharts.RangeSelector#alignElements\n */\n RangeSelector.prototype.alignElements = function () {\n var _this = this;\n var _a = this,\n buttonGroup = _a.buttonGroup,\n buttons = _a.buttons,\n chart = _a.chart,\n group = _a.group,\n inputGroup = _a.inputGroup,\n options = _a.options,\n zoomText = _a.zoomText;\n var chartOptions = chart.options;\n var navButtonOptions = (chartOptions.exporting &&\n chartOptions.exporting.enabled !== false &&\n chartOptions.navigation &&\n chartOptions.navigation.buttonOptions);\n var buttonPosition = options.buttonPosition,\n inputPosition = options.inputPosition,\n verticalAlign = options.verticalAlign;\n // Get the X offset required to avoid overlapping with the exporting\n // button. This is is used both by the buttonGroup and the inputGroup.\n var getXOffsetForExportButton = function (group,\n position) {\n if (navButtonOptions &&\n _this.titleCollision(chart) &&\n verticalAlign === 'top' &&\n position.align === 'right' && ((position.y -\n group.getBBox().height - 12) <\n ((navButtonOptions.y || 0) +\n (navButtonOptions.height || 0) +\n chart.spacing[0]))) {\n return -40;\n }\n return 0;\n };\n var plotLeft = chart.plotLeft;\n if (group && buttonPosition && inputPosition) {\n var translateX = buttonPosition.x - chart.spacing[3];\n if (buttonGroup) {\n this.positionButtons();\n if (!this.initialButtonGroupWidth) {\n var width_1 = 0;\n if (zoomText) {\n width_1 += zoomText.getBBox().width + 5;\n }\n buttons.forEach(function (button, i) {\n width_1 += button.width;\n if (i !== buttons.length - 1) {\n width_1 += options.buttonSpacing;\n }\n });\n this.initialButtonGroupWidth = width_1;\n }\n plotLeft -= chart.spacing[3];\n this.updateButtonStates();\n // Detect collision between button group and exporting\n var xOffsetForExportButton_1 = getXOffsetForExportButton(buttonGroup,\n buttonPosition);\n this.alignButtonGroup(xOffsetForExportButton_1);\n // Skip animation\n group.placed = buttonGroup.placed = chart.hasLoaded;\n }\n var xOffsetForExportButton = 0;\n if (inputGroup) {\n // Detect collision between the input group and exporting button\n xOffsetForExportButton = getXOffsetForExportButton(inputGroup, inputPosition);\n if (inputPosition.align === 'left') {\n translateX = plotLeft;\n }\n else if (inputPosition.align === 'right') {\n translateX = -Math.max(chart.axisOffset[1], -xOffsetForExportButton);\n }\n // Update the alignment to the updated spacing box\n inputGroup.align({\n y: inputPosition.y,\n width: inputGroup.getBBox().width,\n align: inputPosition.align,\n // fix wrong getBBox() value on right align\n x: inputPosition.x + translateX - 2\n }, true, chart.spacingBox);\n // Skip animation\n inputGroup.placed = chart.hasLoaded;\n }\n this.handleCollision(xOffsetForExportButton);\n // Vertical align\n group.align({\n verticalAlign: verticalAlign\n }, true, chart.spacingBox);\n var alignTranslateY = group.alignAttr.translateY;\n // Set position\n var groupHeight = group.getBBox().height + 20; // # 20 padding\n var translateY = 0;\n // Calculate bottom position\n if (verticalAlign === 'bottom') {\n var legendOptions = chart.legend && chart.legend.options;\n var legendHeight = (legendOptions &&\n legendOptions.verticalAlign === 'bottom' &&\n legendOptions.enabled &&\n !legendOptions.floating ?\n (chart.legend.legendHeight +\n pick(legendOptions.margin, 10)) :\n 0);\n groupHeight = groupHeight + legendHeight - 20;\n translateY = (alignTranslateY -\n groupHeight -\n (options.floating ? 0 : options.y) -\n (chart.titleOffset ? chart.titleOffset[2] : 0) -\n 10 // 10 spacing\n );\n }\n if (verticalAlign === 'top') {\n if (options.floating) {\n translateY = 0;\n }\n if (chart.titleOffset && chart.titleOffset[0]) {\n translateY = chart.titleOffset[0];\n }\n translateY += ((chart.margin[0] - chart.spacing[0]) || 0);\n }\n else if (verticalAlign === 'middle') {\n if (inputPosition.y === buttonPosition.y) {\n translateY = alignTranslateY;\n }\n else if (inputPosition.y || buttonPosition.y) {\n if (inputPosition.y < 0 ||\n buttonPosition.y < 0) {\n translateY -= Math.min(inputPosition.y, buttonPosition.y);\n }\n else {\n translateY = alignTranslateY - groupHeight;\n }\n }\n }\n group.translate(options.x, options.y + Math.floor(translateY));\n // Translate HTML inputs\n var _b = this,\n minInput = _b.minInput,\n maxInput = _b.maxInput,\n dropdown = _b.dropdown;\n if (options.inputEnabled && minInput && maxInput) {\n minInput.style.marginTop = group.translateY + 'px';\n maxInput.style.marginTop = group.translateY + 'px';\n }\n if (dropdown) {\n dropdown.style.marginTop = group.translateY + 'px';\n }\n }\n };\n /**\n * Align the button group horizontally and vertically.\n *\n * @private\n * @function Highcharts.RangeSelector#alignButtonGroup\n * @param {number} xOffsetForExportButton\n * @param {number} [width]\n */\n RangeSelector.prototype.alignButtonGroup = function (xOffsetForExportButton, width) {\n var _a = this,\n chart = _a.chart,\n options = _a.options,\n buttonGroup = _a.buttonGroup,\n buttons = _a.buttons;\n var buttonPosition = options.buttonPosition;\n var plotLeft = chart.plotLeft - chart.spacing[3];\n var translateX = buttonPosition.x - chart.spacing[3];\n if (buttonPosition.align === 'right') {\n translateX += xOffsetForExportButton - plotLeft; // #13014\n }\n else if (buttonPosition.align === 'center') {\n translateX -= plotLeft / 2;\n }\n if (buttonGroup) {\n // Align button group\n buttonGroup.align({\n y: buttonPosition.y,\n width: pick(width, this.initialButtonGroupWidth),\n align: buttonPosition.align,\n x: translateX\n }, true, chart.spacingBox);\n }\n };\n /**\n * @private\n * @function Highcharts.RangeSelector#positionButtons\n */\n RangeSelector.prototype.positionButtons = function () {\n var _a = this,\n buttons = _a.buttons,\n chart = _a.chart,\n options = _a.options,\n zoomText = _a.zoomText;\n var verb = chart.hasLoaded ? 'animate' : 'attr';\n var buttonPosition = options.buttonPosition;\n var plotLeft = chart.plotLeft;\n var buttonLeft = plotLeft;\n if (zoomText && zoomText.visibility !== 'hidden') {\n // #8769, allow dynamically updating margins\n zoomText[verb]({\n x: pick(plotLeft + buttonPosition.x, plotLeft)\n });\n // Button start position\n buttonLeft += buttonPosition.x +\n zoomText.getBBox().width + 5;\n }\n for (var i = 0, iEnd = this.buttonOptions.length; i < iEnd; ++i) {\n if (buttons[i].visibility !== 'hidden') {\n buttons[i][verb]({ x: buttonLeft });\n // increase button position for the next button\n buttonLeft += buttons[i].width + options.buttonSpacing;\n }\n else {\n buttons[i][verb]({ x: plotLeft });\n }\n }\n };\n /**\n * Handle collision between the button group and the input group\n *\n * @private\n * @function Highcharts.RangeSelector#handleCollision\n *\n * @param {number} xOffsetForExportButton\n * The X offset of the group required to make room for the\n * exporting button\n */\n RangeSelector.prototype.handleCollision = function (xOffsetForExportButton) {\n var _this = this;\n var _a = this,\n chart = _a.chart,\n buttonGroup = _a.buttonGroup,\n inputGroup = _a.inputGroup;\n var _b = this.options,\n buttonPosition = _b.buttonPosition,\n dropdown = _b.dropdown,\n inputPosition = _b.inputPosition;\n var maxButtonWidth = function () {\n var buttonWidth = 0;\n _this.buttons.forEach(function (button) {\n var bBox = button.getBBox();\n if (bBox.width > buttonWidth) {\n buttonWidth = bBox.width;\n }\n });\n return buttonWidth;\n };\n var groupsOverlap = function (buttonGroupWidth) {\n if (inputGroup && buttonGroup) {\n var inputGroupX = (inputGroup.alignAttr.translateX +\n inputGroup.alignOptions.x -\n xOffsetForExportButton +\n // getBBox for detecing left margin\n inputGroup.getBBox().x +\n // 2px padding to not overlap input and label\n 2);\n var inputGroupWidth = inputGroup.alignOptions.width;\n var buttonGroupX = buttonGroup.alignAttr.translateX +\n buttonGroup.getBBox().x;\n return (buttonGroupX + buttonGroupWidth > inputGroupX) &&\n (inputGroupX + inputGroupWidth > buttonGroupX) &&\n (buttonPosition.y <\n (inputPosition.y +\n inputGroup.getBBox().height));\n }\n return false;\n };\n var moveInputsDown = function () {\n if (inputGroup && buttonGroup) {\n inputGroup.attr({\n translateX: inputGroup.alignAttr.translateX + (chart.axisOffset[1] >= -xOffsetForExportButton ?\n 0 :\n -xOffsetForExportButton),\n translateY: inputGroup.alignAttr.translateY +\n buttonGroup.getBBox().height + 10\n });\n }\n };\n if (buttonGroup) {\n if (dropdown === 'always') {\n this.collapseButtons(xOffsetForExportButton);\n if (groupsOverlap(maxButtonWidth())) {\n // Move the inputs down if there is still a collision\n // after collapsing the buttons\n moveInputsDown();\n }\n return;\n }\n if (dropdown === 'never') {\n this.expandButtons();\n }\n }\n // Detect collision\n if (inputGroup && buttonGroup) {\n if ((inputPosition.align === buttonPosition.align) ||\n // 20 is minimal spacing between elements\n groupsOverlap(this.initialButtonGroupWidth + 20)) {\n if (dropdown === 'responsive') {\n this.collapseButtons(xOffsetForExportButton);\n if (groupsOverlap(maxButtonWidth())) {\n moveInputsDown();\n }\n }\n else {\n moveInputsDown();\n }\n }\n else if (dropdown === 'responsive') {\n this.expandButtons();\n }\n }\n else if (buttonGroup && dropdown === 'responsive') {\n if (this.initialButtonGroupWidth > chart.plotWidth) {\n this.collapseButtons(xOffsetForExportButton);\n }\n else {\n this.expandButtons();\n }\n }\n };\n /**\n * Collapse the buttons and put the select element on top.\n *\n * @private\n * @function Highcharts.RangeSelector#collapseButtons\n * @param {number} xOffsetForExportButton\n */\n RangeSelector.prototype.collapseButtons = function (xOffsetForExportButton) {\n var _a = this,\n buttons = _a.buttons,\n buttonOptions = _a.buttonOptions,\n chart = _a.chart,\n dropdown = _a.dropdown,\n options = _a.options,\n zoomText = _a.zoomText;\n var userButtonTheme = (chart.userOptions.rangeSelector &&\n chart.userOptions.rangeSelector.buttonTheme) || {};\n var getAttribs = function (text) { return ({\n text: text ? \"\" + text + \" \\u25BE\" : '▾',\n width: 'auto',\n paddingLeft: pick(options.buttonTheme.paddingLeft,\n userButtonTheme.padding, 8),\n paddingRight: pick(options.buttonTheme.paddingRight,\n userButtonTheme.padding, 8)\n }); };\n if (zoomText) {\n zoomText.hide();\n }\n var hasActiveButton = false;\n buttonOptions.forEach(function (rangeOptions, i) {\n var button = buttons[i];\n if (button.state !== 2) {\n button.hide();\n }\n else {\n button.show();\n button.attr(getAttribs(rangeOptions.text));\n hasActiveButton = true;\n }\n });\n if (!hasActiveButton) {\n if (dropdown) {\n dropdown.selectedIndex = 0;\n }\n buttons[0].show();\n buttons[0].attr(getAttribs(this.zoomText && this.zoomText.textStr));\n }\n var align = options.buttonPosition.align;\n this.positionButtons();\n if (align === 'right' || align === 'center') {\n this.alignButtonGroup(xOffsetForExportButton, buttons[this.currentButtonIndex()].getBBox().width);\n }\n this.showDropdown();\n };\n /**\n * Show all the buttons and hide the select element.\n *\n * @private\n * @function Highcharts.RangeSelector#expandButtons\n */\n RangeSelector.prototype.expandButtons = function () {\n var _a = this,\n buttons = _a.buttons,\n buttonOptions = _a.buttonOptions,\n options = _a.options,\n zoomText = _a.zoomText;\n this.hideDropdown();\n if (zoomText) {\n zoomText.show();\n }\n buttonOptions.forEach(function (rangeOptions, i) {\n var button = buttons[i];\n button.show();\n button.attr({\n text: rangeOptions.text,\n width: options.buttonTheme.width || 28,\n paddingLeft: pick(options.buttonTheme.paddingLeft, 'unset'),\n paddingRight: pick(options.buttonTheme.paddingRight, 'unset')\n });\n if (button.state < 2) {\n button.setState(0);\n }\n });\n this.positionButtons();\n };\n /**\n * Get the index of the visible button when the buttons are collapsed.\n *\n * @private\n * @function Highcharts.RangeSelector#currentButtonIndex\n */\n RangeSelector.prototype.currentButtonIndex = function () {\n var dropdown = this.dropdown;\n if (dropdown && dropdown.selectedIndex > 0) {\n return dropdown.selectedIndex - 1;\n }\n return 0;\n };\n /**\n * Position the select element on top of the button.\n *\n * @private\n * @function Highcharts.RangeSelector#showDropdown\n */\n RangeSelector.prototype.showDropdown = function () {\n var _a = this,\n buttonGroup = _a.buttonGroup,\n buttons = _a.buttons,\n chart = _a.chart,\n dropdown = _a.dropdown;\n if (buttonGroup && dropdown) {\n var translateX = buttonGroup.translateX,\n translateY = buttonGroup.translateY;\n var bBox = buttons[this.currentButtonIndex()].getBBox();\n css(dropdown, {\n left: (chart.plotLeft + translateX) + 'px',\n top: (translateY + 0.5) + 'px',\n width: bBox.width + 'px',\n height: bBox.height + 'px'\n });\n this.hasVisibleDropdown = true;\n }\n };\n /**\n * @private\n * @function Highcharts.RangeSelector#hideDropdown\n */\n RangeSelector.prototype.hideDropdown = function () {\n var dropdown = this.dropdown;\n if (dropdown) {\n css(dropdown, {\n top: '-9999em',\n width: '1px',\n height: '1px'\n });\n this.hasVisibleDropdown = false;\n }\n };\n /**\n * Extracts height of range selector\n *\n * @private\n * @function Highcharts.RangeSelector#getHeight\n * @return {number}\n * Returns rangeSelector height\n */\n RangeSelector.prototype.getHeight = function () {\n var rangeSelector = this,\n options = rangeSelector.options,\n rangeSelectorGroup = rangeSelector.group,\n inputPosition = options.inputPosition,\n buttonPosition = options.buttonPosition,\n yPosition = options.y,\n buttonPositionY = buttonPosition.y,\n inputPositionY = inputPosition.y;\n var rangeSelectorHeight = 0;\n if (options.height) {\n return options.height;\n }\n // Align the elements before we read the height in case we're switching\n // between wrapped and non-wrapped layout\n this.alignElements();\n rangeSelectorHeight = rangeSelectorGroup ?\n // 13px to keep back compatibility\n (rangeSelectorGroup.getBBox(true).height) + 13 +\n yPosition :\n 0;\n var minPosition = Math.min(inputPositionY,\n buttonPositionY);\n if ((inputPositionY < 0 && buttonPositionY < 0) ||\n (inputPositionY > 0 && buttonPositionY > 0)) {\n rangeSelectorHeight += Math.abs(minPosition);\n }\n return rangeSelectorHeight;\n };\n /**\n * Detect collision with title or subtitle\n *\n * @private\n * @function Highcharts.RangeSelector#titleCollision\n * @return {boolean}\n * Returns collision status\n */\n RangeSelector.prototype.titleCollision = function (chart) {\n return !(chart.options.title.text ||\n chart.options.subtitle.text);\n };\n /**\n * Update the range selector with new options\n *\n * @private\n * @function Highcharts.RangeSelector#update\n * @param {Highcharts.RangeSelectorOptions} options\n */\n RangeSelector.prototype.update = function (options) {\n var chart = this.chart;\n merge(true, chart.options.rangeSelector, options);\n this.destroy();\n this.init(chart);\n this.render();\n };\n /**\n * Destroys allocated elements.\n *\n * @private\n * @function Highcharts.RangeSelector#destroy\n */\n RangeSelector.prototype.destroy = function () {\n var rSelector = this,\n minInput = rSelector.minInput,\n maxInput = rSelector.maxInput;\n if (rSelector.eventsToUnbind) {\n rSelector.eventsToUnbind.forEach(function (unbind) { return unbind(); });\n rSelector.eventsToUnbind = void 0;\n }\n // Destroy elements in collections\n destroyObjectProperties(rSelector.buttons);\n // Clear input element events\n if (minInput) {\n minInput.onfocus = minInput.onblur = minInput.onchange = null;\n }\n if (maxInput) {\n maxInput.onfocus = maxInput.onblur = maxInput.onchange = null;\n }\n // Destroy HTML and SVG elements\n objectEach(rSelector, function (val, key) {\n if (val && key !== 'chart') {\n if (val instanceof SVGElement) {\n // SVGElement\n val.destroy();\n }\n else if (val instanceof window.HTMLElement) {\n // HTML element\n discardElement(val);\n }\n }\n if (val !== RangeSelector.prototype[key]) {\n rSelector[key] = null;\n }\n }, this);\n };\n return RangeSelector;\n }());\n extend(RangeSelector.prototype, {\n /**\n * The default buttons for pre-selecting time frames.\n * @private\n */\n defaultButtons: [{\n type: 'month',\n count: 1,\n text: '1m',\n title: 'View 1 month'\n }, {\n type: 'month',\n count: 3,\n text: '3m',\n title: 'View 3 months'\n }, {\n type: 'month',\n count: 6,\n text: '6m',\n title: 'View 6 months'\n }, {\n type: 'ytd',\n text: 'YTD',\n title: 'View year to date'\n }, {\n type: 'year',\n count: 1,\n text: '1y',\n title: 'View 1 year'\n }, {\n type: 'all',\n text: 'All',\n title: 'View all'\n }],\n /**\n * The date formats to use when setting min, max and value on date inputs.\n * @private\n */\n inputTypeFormats: {\n 'datetime-local': '%Y-%m-%dT%H:%M:%S',\n 'date': '%Y-%m-%d',\n 'time': '%H:%M:%S'\n }\n });\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Define the time span for the button\n *\n * @typedef {\"all\"|\"day\"|\"hour\"|\"millisecond\"|\"minute\"|\"month\"|\"second\"|\"week\"|\"year\"|\"ytd\"} Highcharts.RangeSelectorButtonTypeValue\n */\n /**\n * Callback function to react on button clicks.\n *\n * @callback Highcharts.RangeSelectorClickCallbackFunction\n *\n * @param {global.Event} e\n * Event arguments.\n *\n * @param {boolean|undefined}\n * Return false to cancel the default button event.\n */\n /**\n * Callback function to parse values entered in the input boxes and return a\n * valid JavaScript time as milliseconds since 1970.\n *\n * @callback Highcharts.RangeSelectorParseCallbackFunction\n *\n * @param {string} value\n * Input value to parse.\n *\n * @return {number}\n * Parsed JavaScript time value.\n */\n (''); // keeps doclets above in JS file\n\n return RangeSelector;\n });\n _registerModule(_modules, 'Core/Axis/OrdinalAxis.js', [_modules['Core/Axis/Axis.js'], _modules['Core/Globals.js'], _modules['Core/Series/Series.js'], _modules['Core/Utilities.js']], function (Axis, H, Series, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var addEvent = U.addEvent,\n correctFloat = U.correctFloat,\n css = U.css,\n defined = U.defined,\n error = U.error,\n pick = U.pick,\n timeUnits = U.timeUnits;\n /* *\n *\n * Constants\n *\n * */\n var composedClasses = [];\n /* eslint-disable valid-jsdoc */\n /* *\n *\n * Composition\n *\n * */\n /**\n * Extends the axis with ordinal support.\n * @private\n */\n var OrdinalAxis;\n (function (OrdinalAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extends the axis with ordinal support.\n *\n * @private\n *\n * @param AxisClass\n * Axis class to extend.\n *\n * @param ChartClass\n * Chart class to use.\n *\n * @param SeriesClass\n * Series class to use.\n */\n function compose(AxisClass, SeriesClass, ChartClass) {\n if (composedClasses.indexOf(AxisClass) === -1) {\n composedClasses.push(AxisClass);\n var axisProto = AxisClass.prototype;\n axisProto.getTimeTicks = getTimeTicks;\n axisProto.index2val = index2val;\n axisProto.lin2val = lin2val;\n axisProto.val2lin = val2lin;\n // Record this to prevent overwriting by broken-axis module (#5979)\n axisProto.ordinal2lin = axisProto.val2lin;\n addEvent(AxisClass, 'afterInit', onAxisAfterInit);\n addEvent(AxisClass, 'foundExtremes', onAxisFoundExtremes);\n addEvent(AxisClass, 'afterSetScale', onAxisAfterSetScale);\n addEvent(AxisClass, 'initialAxisTranslation', onAxisInitialAxisTranslation);\n }\n if (composedClasses.indexOf(ChartClass) === -1) {\n composedClasses.push(ChartClass);\n addEvent(ChartClass, 'pan', onChartPan);\n }\n if (composedClasses.indexOf(SeriesClass) === -1) {\n composedClasses.push(SeriesClass);\n addEvent(SeriesClass, 'updatedData', onSeriesUpdatedData);\n }\n /* eslint-enable no-invalid-this */\n return AxisClass;\n }\n OrdinalAxis.compose = compose;\n /**\n * In an ordinal axis, there might be areas with dense consentrations of\n * points, then large gaps between some. Creating equally distributed\n * ticks over this entire range may lead to a huge number of ticks that\n * will later be removed. So instead, break the positions up in\n * segments, find the tick positions for each segment then concatenize\n * them. This method is used from both data grouping logic and X axis\n * tick position logic.\n * @private\n */\n function getTimeTicks(normalizedInterval, min, max, startOfWeek, positions, closestDistance, findHigherRanks) {\n if (positions === void 0) { positions = []; }\n if (closestDistance === void 0) { closestDistance = 0; }\n var higherRanks = {},\n tickPixelIntervalOption = this.options.tickPixelInterval,\n time = this.chart.time, \n // Record all the start positions of a segment, to use when\n // deciding what's a gap in the data.\n segmentStarts = [];\n var end,\n segmentPositions,\n hasCrossedHigherRank,\n info,\n outsideMax,\n start = 0,\n groupPositions = [],\n lastGroupPosition = -Number.MAX_VALUE;\n // The positions are not always defined, for example for ordinal\n // positions when data has regular interval (#1557, #2090)\n if ((!this.options.ordinal && !this.options.breaks) ||\n !positions ||\n positions.length < 3 ||\n typeof min === 'undefined') {\n return time.getTimeTicks.apply(time, arguments);\n }\n // Analyze the positions array to split it into segments on gaps\n // larger than 5 times the closest distance. The closest distance is\n // already found at this point, so we reuse that instead of\n // computing it again.\n var posLength = positions.length;\n for (end = 0; end < posLength; end++) {\n outsideMax = end && positions[end - 1] > max;\n if (positions[end] < min) { // Set the last position before min\n start = end;\n }\n if (end === posLength - 1 ||\n positions[end + 1] - positions[end] > closestDistance * 5 ||\n outsideMax) {\n // For each segment, calculate the tick positions from the\n // getTimeTicks utility function. The interval will be the\n // same regardless of how long the segment is.\n if (positions[end] > lastGroupPosition) { // #1475\n segmentPositions = time.getTimeTicks(normalizedInterval, positions[start], positions[end], startOfWeek);\n // Prevent duplicate groups, for example for multiple\n // segments within one larger time frame (#1475)\n while (segmentPositions.length &&\n segmentPositions[0] <= lastGroupPosition) {\n segmentPositions.shift();\n }\n if (segmentPositions.length) {\n lastGroupPosition =\n segmentPositions[segmentPositions.length - 1];\n }\n segmentStarts.push(groupPositions.length);\n groupPositions = groupPositions.concat(segmentPositions);\n }\n // Set start of next segment\n start = end + 1;\n }\n if (outsideMax) {\n break;\n }\n }\n // Get the grouping info from the last of the segments. The info is\n // the same for all segments.\n if (segmentPositions) {\n info = segmentPositions.info;\n // Optionally identify ticks with higher rank, for example\n // when the ticks have crossed midnight.\n if (findHigherRanks && info.unitRange <= timeUnits.hour) {\n end = groupPositions.length - 1;\n // Compare points two by two\n for (start = 1; start < end; start++) {\n if (time.dateFormat('%d', groupPositions[start]) !==\n time.dateFormat('%d', groupPositions[start - 1])) {\n higherRanks[groupPositions[start]] = 'day';\n hasCrossedHigherRank = true;\n }\n }\n // If the complete array has crossed midnight, we want\n // to mark the first positions also as higher rank\n if (hasCrossedHigherRank) {\n higherRanks[groupPositions[0]] = 'day';\n }\n info.higherRanks = higherRanks;\n }\n // Save the info\n info.segmentStarts = segmentStarts;\n groupPositions.info = info;\n }\n else {\n error(12, false, this.chart);\n }\n // Don't show ticks within a gap in the ordinal axis, where the\n // space between two points is greater than a portion of the tick\n // pixel interval\n if (findHigherRanks && defined(tickPixelIntervalOption)) {\n var length_1 = groupPositions.length,\n translatedArr = [],\n distances = [];\n var itemToRemove = void 0,\n translated = void 0,\n lastTranslated = void 0,\n medianDistance = void 0,\n distance = void 0,\n i = length_1;\n // Find median pixel distance in order to keep a reasonably even\n // distance between ticks (#748)\n while (i--) {\n translated = this.translate(groupPositions[i]);\n if (lastTranslated) {\n distances[i] = lastTranslated - translated;\n }\n translatedArr[i] = lastTranslated = translated;\n }\n distances.sort();\n medianDistance = distances[Math.floor(distances.length / 2)];\n if (medianDistance < tickPixelIntervalOption * 0.6) {\n medianDistance = null;\n }\n // Now loop over again and remove ticks where needed\n i = groupPositions[length_1 - 1] > max ? length_1 - 1 : length_1; // #817\n lastTranslated = void 0;\n while (i--) {\n translated = translatedArr[i];\n distance = Math.abs(lastTranslated - translated);\n // #4175 - when axis is reversed, the distance, is negative but\n // tickPixelIntervalOption positive, so we need to compare the\n // same values\n // Remove ticks that are closer than 0.6 times the pixel\n // interval from the one to the right, but not if it is close to\n // the median distance (#748).\n if (lastTranslated &&\n distance < tickPixelIntervalOption * 0.8 &&\n (medianDistance === null || distance < medianDistance * 0.8)) {\n // Is this a higher ranked position with a normal\n // position to the right?\n if (higherRanks[groupPositions[i]] &&\n !higherRanks[groupPositions[i + 1]]) {\n // Yes: remove the lower ranked neighbour to the\n // right\n itemToRemove = i + 1;\n lastTranslated = translated; // #709\n }\n else {\n // No: remove this one\n itemToRemove = i;\n }\n groupPositions.splice(itemToRemove, 1);\n }\n else {\n lastTranslated = translated;\n }\n }\n }\n return groupPositions;\n }\n /**\n * Get axis position of given index of the extended ordinal positions.\n * Used only when panning an ordinal axis.\n *\n * @private\n * @function Highcharts.Axis#index2val\n * @param {number} index\n * The index value of searched point\n */\n function index2val(index) {\n var axis = this,\n ordinal = axis.ordinal, \n // Context could be changed to extendedOrdinalPositions.\n ordinalPositions = ordinal.positions;\n // The visible range contains only equally spaced values.\n if (!ordinalPositions) {\n return index;\n }\n var i = ordinalPositions.length - 1,\n distance;\n if (index < 0) { // out of range, in effect panning to the left\n index = ordinalPositions[0];\n }\n else if (index > i) { // out of range, panning to the right\n index = ordinalPositions[i];\n }\n else { // split it up\n i = Math.floor(index);\n distance = index - i; // the decimal\n }\n if (typeof distance !== 'undefined' &&\n typeof ordinalPositions[i] !== 'undefined') {\n return ordinalPositions[i] + (distance ?\n distance *\n (ordinalPositions[i + 1] - ordinalPositions[i]) :\n 0);\n }\n return index;\n }\n /**\n * Translate from linear (internal) to axis value.\n *\n * @private\n * @function Highcharts.Axis#lin2val\n * @param {number} val\n * The linear abstracted value.\n */\n function lin2val(val) {\n var axis = this,\n ordinal = axis.ordinal,\n localMin = axis.old ? axis.old.min : axis.min,\n localA = axis.old ? axis.old.transA : axis.transA;\n var positions = ordinal.positions; // for the current visible range\n // The visible range contains only equally spaced values.\n if (!positions) {\n return val;\n }\n // Convert back from modivied value to pixels. // #15970\n var pixelVal = (val - localMin) * localA +\n axis.minPixelPadding,\n isInside = pixelVal > 0 && pixelVal < axis.left + axis.len;\n // If the value is not inside the plot area, use the extended positions.\n // (array contains also points that are outside of the plotArea).\n if (!isInside) {\n // When iterating for the first time,\n // get the extended ordinal positional and assign them.\n if (!ordinal.extendedOrdinalPositions) {\n ordinal.extendedOrdinalPositions = (ordinal.getExtendedPositions());\n }\n positions = ordinal.extendedOrdinalPositions;\n }\n // In some cases (especially in early stages of the chart creation) the\n // getExtendedPositions might return undefined.\n if (positions && positions.length) {\n var index = ordinal.getIndexOfPoint(pixelVal,\n positions),\n mantissa = correctFloat(index % 1);\n // Check if the index is inside position array. If true,\n // read/approximate value for that exact index.\n if (index >= 0 && index < positions.length - 1) {\n var leftNeighbour = positions[Math.floor(index)],\n rightNeighbour = positions[Math.ceil(index)],\n distance = rightNeighbour - leftNeighbour;\n return positions[Math.floor(index)] + mantissa * distance;\n }\n // For cases when the index is not in the extended ordinal position\n // array, like when the value we are looking for exceed the\n // available data, approximate that value based on the calculated\n // slope.\n var positionsLength = positions.length,\n firstPositionsValue = positions[0],\n lastPositionsValue = positions[positionsLength - 1],\n slope = (lastPositionsValue - firstPositionsValue) / (positionsLength - 1);\n if (index < 0) {\n return firstPositionsValue + slope * index;\n }\n return lastPositionsValue + slope * (index - positionsLength);\n }\n return val;\n }\n /**\n * Internal function to calculate the precise index in ordinalPositions\n * array.\n * @private\n */\n function getIndexInArray(ordinalPositions, val) {\n var index = OrdinalAxis.Additions.findIndexOf(ordinalPositions,\n val,\n true);\n if (ordinalPositions[index] === val) {\n return index;\n }\n var percent = (val - ordinalPositions[index]) /\n (ordinalPositions[index + 1] - ordinalPositions[index]);\n return index + percent;\n }\n /**\n * @private\n */\n function onAxisAfterInit() {\n var axis = this;\n if (!axis.ordinal) {\n axis.ordinal = new OrdinalAxis.Additions(axis);\n }\n }\n /**\n * @private\n */\n function onAxisFoundExtremes() {\n var axis = this;\n if (axis.isXAxis &&\n defined(axis.options.overscroll) &&\n axis.max === axis.dataMax &&\n (\n // Panning is an execption. We don't want to apply\n // overscroll when panning over the dataMax\n !axis.chart.mouseIsDown ||\n axis.isInternal) && (\n // Scrollbar buttons are the other execption:\n !axis.eventArgs ||\n axis.eventArgs && axis.eventArgs.trigger !== 'navigator')) {\n axis.max += axis.options.overscroll;\n // Live data and buttons require translation for the min:\n if (!axis.isInternal && defined(axis.userMin)) {\n axis.min += axis.options.overscroll;\n }\n }\n }\n /**\n * For ordinal axis, that loads data async, redraw axis after data is\n * loaded. If we don't do that, axis will have the same extremes as\n * previously, but ordinal positions won't be calculated. See #10290\n * @private\n */\n function onAxisAfterSetScale() {\n var axis = this;\n if (axis.horiz && !axis.isDirty) {\n axis.isDirty = axis.isOrdinal &&\n axis.chart.navigator &&\n !axis.chart.navigator.adaptToUpdatedData;\n }\n }\n /**\n * @private\n */\n function onAxisInitialAxisTranslation() {\n var axis = this;\n if (axis.ordinal) {\n axis.ordinal.beforeSetTickPositions();\n axis.tickInterval = axis.ordinal.postProcessTickInterval(axis.tickInterval);\n }\n }\n /**\n * Extending the Chart.pan method for ordinal axes\n * @private\n */\n function onChartPan(e) {\n var chart = this,\n xAxis = chart.xAxis[0],\n overscroll = xAxis.options.overscroll,\n chartX = e.originalEvent.chartX,\n panning = chart.options.chart.panning;\n var runBase = false;\n if (panning &&\n panning.type !== 'y' &&\n xAxis.options.ordinal &&\n xAxis.series.length) {\n var mouseDownX = chart.mouseDownX,\n extremes = xAxis.getExtremes(),\n dataMax = extremes.dataMax,\n min = extremes.min,\n max = extremes.max,\n hoverPoints = chart.hoverPoints,\n closestPointRange = (xAxis.closestPointRange ||\n (xAxis.ordinal && xAxis.ordinal.overscrollPointsRange)),\n pointPixelWidth = (xAxis.translationSlope *\n (xAxis.ordinal.slope || closestPointRange)), \n // how many ordinal units did we move?\n movedUnits = (mouseDownX - chartX) / pointPixelWidth, \n // get index of all the chart's points\n extendedOrdinalPositions = xAxis.ordinal.getExtendedPositions(),\n extendedAxis = {\n ordinal: {\n positions: extendedOrdinalPositions,\n extendedOrdinalPositions: extendedOrdinalPositions\n }\n },\n index2val_1 = xAxis.index2val,\n val2lin_1 = xAxis.val2lin;\n var trimmedRange = void 0,\n ordinalPositions = void 0,\n searchAxisLeft = void 0,\n searchAxisRight = void 0;\n // we have an ordinal axis, but the data is equally spaced\n if (!extendedAxis.ordinal.positions) {\n runBase = true;\n }\n else if (Math.abs(movedUnits) > 1) {\n // Remove active points for shared tooltip\n if (hoverPoints) {\n hoverPoints.forEach(function (point) {\n point.setState();\n });\n }\n if (movedUnits < 0) {\n searchAxisLeft = extendedAxis;\n searchAxisRight = xAxis.ordinal.positions ?\n xAxis : extendedAxis;\n }\n else {\n searchAxisLeft = xAxis.ordinal.positions ?\n xAxis : extendedAxis;\n searchAxisRight = extendedAxis;\n }\n // In grouped data series, the last ordinal position represents\n // the grouped data, which is to the left of the real data max.\n // If we don't compensate for this, we will be allowed to pan\n // grouped data series passed the right of the plot area.\n ordinalPositions = searchAxisRight.ordinal.positions;\n if (dataMax >\n ordinalPositions[ordinalPositions.length - 1]) {\n ordinalPositions.push(dataMax);\n }\n // Get the new min and max values by getting the ordinal index\n // for the current extreme, then add the moved units and\n // translate back to values. This happens on the extended\n // ordinal positions if the new position is out of range, else\n // it happens on the current x axis which is smaller and faster.\n chart.fixedRange = max - min;\n trimmedRange = xAxis.navigatorAxis\n .toFixedRange(void 0, void 0, index2val_1.apply(searchAxisLeft, [\n val2lin_1.apply(searchAxisLeft, [min, true]) +\n movedUnits\n ]), index2val_1.apply(searchAxisRight, [\n val2lin_1.apply(searchAxisRight, [max, true]) +\n movedUnits\n ]));\n // Apply it if it is within the available data range\n if (trimmedRange.min >= Math.min(extremes.dataMin, min) &&\n trimmedRange.max <= Math.max(dataMax, max) +\n overscroll) {\n xAxis.setExtremes(trimmedRange.min, trimmedRange.max, true, false, { trigger: 'pan' });\n }\n chart.mouseDownX = chartX; // set new reference for next run\n css(chart.container, { cursor: 'move' });\n }\n }\n else {\n runBase = true;\n }\n // revert to the linear chart.pan version\n if (runBase || (panning && /y/.test(panning.type))) {\n if (overscroll) {\n xAxis.max = xAxis.dataMax + overscroll;\n }\n }\n else {\n e.preventDefault();\n }\n }\n /**\n * @private\n */\n function onSeriesUpdatedData() {\n var xAxis = this.xAxis;\n // Destroy the extended ordinal index on updated data\n // and destroy extendedOrdinalPositions, #16055.\n if (xAxis && xAxis.options.ordinal) {\n delete xAxis.ordinal.index;\n delete xAxis.ordinal.extendedOrdinalPositions;\n }\n }\n /**\n * Translate from a linear axis value to the corresponding ordinal axis\n * position. If there are no gaps in the ordinal axis this will be the\n * same. The translated value is the value that the point would have if\n * the axis was linear, using the same min and max.\n *\n * @private\n * @function Highcharts.Axis#val2lin\n * @param {number} val\n * The axis value.\n * @param {boolean} [toIndex]\n * Whether to return the index in the ordinalPositions or the new value.\n */\n function val2lin(val, toIndex) {\n var axis = this,\n ordinal = axis.ordinal,\n ordinalPositions = ordinal.positions;\n var slope = ordinal.slope,\n extendedOrdinalPositions = ordinal.extendedOrdinalPositions;\n if (!ordinalPositions) {\n return val;\n }\n var ordinalLength = ordinalPositions.length;\n var ordinalIndex;\n // If the searched value is inside visible plotArea, ivastigate the\n // value basing on ordinalPositions.\n if (ordinalPositions[0] <= val &&\n ordinalPositions[ordinalLength - 1] >= val) {\n ordinalIndex = getIndexInArray(ordinalPositions, val);\n // final return value is based on ordinalIndex\n }\n else {\n if (!extendedOrdinalPositions) {\n extendedOrdinalPositions =\n ordinal.getExtendedPositions &&\n ordinal.getExtendedPositions();\n ordinal.extendedOrdinalPositions = extendedOrdinalPositions;\n }\n if (!(extendedOrdinalPositions && extendedOrdinalPositions.length)) {\n return val;\n }\n var length_2 = extendedOrdinalPositions.length;\n if (!slope) {\n slope =\n (extendedOrdinalPositions[length_2 - 1] -\n extendedOrdinalPositions[0]) /\n length_2;\n }\n // OriginalPointReference is equal to the index of\n // first point of ordinalPositions in extendedOrdinalPositions.\n var originalPositionsReference = getIndexInArray(extendedOrdinalPositions,\n ordinalPositions[0]);\n // If the searched value is outside the visiblePlotArea,\n // check if it is inside extendedOrdinalPositions.\n if (val >= extendedOrdinalPositions[0] &&\n val <=\n extendedOrdinalPositions[length_2 - 1]) {\n // Return Value\n ordinalIndex = getIndexInArray(extendedOrdinalPositions, val) -\n originalPositionsReference;\n }\n else {\n // Since ordinal.slope is the average distance between 2\n // points on visible plotArea, this can be used to calculete\n // the approximate position of the point, which is outside\n // the extededOrdinalPositions.\n if (val < extendedOrdinalPositions[0]) {\n var diff = extendedOrdinalPositions[0] - val,\n approximateIndexOffset = diff / slope;\n ordinalIndex =\n -originalPositionsReference -\n approximateIndexOffset;\n }\n else {\n var diff = val -\n extendedOrdinalPositions[length_2 - 1],\n approximateIndexOffset = diff / slope;\n ordinalIndex =\n approximateIndexOffset +\n length_2 -\n originalPositionsReference;\n }\n }\n }\n return toIndex ? ordinalIndex : slope * (ordinalIndex || 0) +\n ordinal.offset;\n }\n /* *\n *\n * Classes\n *\n * */\n /**\n * @private\n */\n var Additions = /** @class */ (function () {\n /* *\n *\n * Constructors\n *\n * */\n /**\n * @private\n */\n function Additions(axis) {\n this.index = {};\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Calculate the ordinal positions before tick positions are calculated.\n * @private\n */\n Additions.prototype.beforeSetTickPositions = function () {\n var axis = this.axis,\n ordinal = axis.ordinal,\n extremes = axis.getExtremes(),\n min = extremes.min,\n max = extremes.max,\n hasBreaks = axis.isXAxis && !!axis.options.breaks,\n isOrdinal = axis.options.ordinal,\n ignoreHiddenSeries = axis.chart.options.chart.ignoreHiddenSeries;\n var len,\n uniqueOrdinalPositions,\n dist,\n minIndex,\n maxIndex,\n slope,\n i,\n ordinalPositions = [],\n overscrollPointsRange = Number.MAX_VALUE,\n useOrdinal = false,\n adjustOrdinalExtremesPoints = false,\n isBoosted = false;\n // Apply the ordinal logic\n if (isOrdinal || hasBreaks) { // #4167 YAxis is never ordinal ?\n var distanceBetweenPoint_1 = 0;\n axis.series.forEach(function (series, i) {\n uniqueOrdinalPositions = [];\n // For an axis with multiple series, check if the distance\n // between points is identical throughout all series.\n if (i > 0 &&\n series.options.id !== 'highcharts-navigator-series' &&\n series.processedXData.length > 1) {\n adjustOrdinalExtremesPoints =\n distanceBetweenPoint_1 !== series.processedXData[1] -\n series.processedXData[0];\n }\n distanceBetweenPoint_1 =\n series.processedXData[1] - series.processedXData[0];\n if (series.boosted) {\n isBoosted = series.boosted;\n }\n if ((!ignoreHiddenSeries || series.visible !== false) &&\n (series\n .takeOrdinalPosition !== false ||\n hasBreaks)) {\n // concatenate the processed X data into the existing\n // positions, or the empty array\n ordinalPositions = ordinalPositions.concat(series.processedXData);\n len = ordinalPositions.length;\n // remove duplicates (#1588)\n ordinalPositions.sort(function (a, b) {\n // without a custom function it is sorted as strings\n return a - b;\n });\n overscrollPointsRange = Math.min(overscrollPointsRange, pick(\n // Check for a single-point series:\n series.closestPointRange, overscrollPointsRange));\n if (len) {\n i = 0;\n while (i < len - 1) {\n if (ordinalPositions[i] !==\n ordinalPositions[i + 1]) {\n uniqueOrdinalPositions.push(ordinalPositions[i + 1]);\n }\n i++;\n }\n // Check first item:\n if (uniqueOrdinalPositions[0] !==\n ordinalPositions[0]) {\n uniqueOrdinalPositions.unshift(ordinalPositions[0]);\n }\n ordinalPositions = uniqueOrdinalPositions;\n }\n }\n });\n // If the distance between points is not identical throughout\n // all series, remove the first and last ordinal position to\n // avoid enabling ordinal logic when it is not needed, #17405.\n // Only for boosted series because changes are negligible.\n if (adjustOrdinalExtremesPoints && isBoosted) {\n ordinalPositions.pop();\n ordinalPositions.shift();\n }\n // cache the length\n len = ordinalPositions.length;\n // Check if we really need the overhead of mapping axis data\n // against the ordinal positions. If the series consist of\n // evenly spaced data any way, we don't need any ordinal logic.\n if (len > 2) { // two points have equal distance by default\n dist = ordinalPositions[1] - ordinalPositions[0];\n i = len - 1;\n while (i-- && !useOrdinal) {\n if (ordinalPositions[i + 1] - ordinalPositions[i] !==\n dist) {\n useOrdinal = true;\n }\n }\n // When zooming in on a week, prevent axis padding for\n // weekends even though the data within the week is evenly\n // spaced.\n if (!axis.options.keepOrdinalPadding &&\n (ordinalPositions[0] - min > dist ||\n (max -\n ordinalPositions[ordinalPositions.length - 1]) > dist)) {\n useOrdinal = true;\n }\n }\n else if (axis.options.overscroll) {\n if (len === 2) {\n // Exactly two points, distance for overscroll is fixed:\n overscrollPointsRange =\n ordinalPositions[1] - ordinalPositions[0];\n }\n else if (len === 1) {\n // We have just one point, closest distance is unknown.\n // Assume then it is last point and overscrolled range:\n overscrollPointsRange = axis.options.overscroll;\n ordinalPositions = [\n ordinalPositions[0],\n ordinalPositions[0] + overscrollPointsRange\n ];\n }\n else {\n // In case of zooming in on overscrolled range, stick to\n // the old range:\n overscrollPointsRange = ordinal.overscrollPointsRange;\n }\n }\n // Record the slope and offset to compute the linear values from\n // the array index. Since the ordinal positions may exceed the\n // current range, get the start and end positions within it\n // (#719, #665b)\n if (useOrdinal || axis.forceOrdinal) {\n if (axis.options.overscroll) {\n ordinal.overscrollPointsRange = overscrollPointsRange;\n ordinalPositions = ordinalPositions.concat(ordinal.getOverscrollPositions());\n }\n // Register\n ordinal.positions = ordinalPositions;\n // This relies on the ordinalPositions being set. Use\n // Math.max and Math.min to prevent padding on either sides\n // of the data.\n minIndex = axis.ordinal2lin(// #5979\n Math.max(min, ordinalPositions[0]), true);\n maxIndex = Math.max(axis.ordinal2lin(Math.min(max, ordinalPositions[ordinalPositions.length - 1]), true), 1); // #3339\n // Set the slope and offset of the values compared to the\n // indices in the ordinal positions\n ordinal.slope = slope = (max - min) / (maxIndex - minIndex);\n ordinal.offset = min - (minIndex * slope);\n }\n else {\n ordinal.overscrollPointsRange = pick(axis.closestPointRange, ordinal.overscrollPointsRange);\n ordinal.positions = axis.ordinal.slope = ordinal.offset =\n void 0;\n }\n }\n axis.isOrdinal = isOrdinal && useOrdinal; // #3818, #4196, #4926\n ordinal.groupIntervalFactor = null; // reset for next run\n };\n /**\n * Faster way of using the Array.indexOf method.\n * Works for sorted arrays only with unique values.\n *\n * @param {Array} sortedArray\n * The sorted array inside which we are looking for.\n * @param {number} key\n * The key to being found.\n * @param {boolean} indirectSearch\n * In case of lack of the point in the array, should return\n * value be equal to -1 or the closest smaller index.\n * @private\n */\n Additions.findIndexOf = function (sortedArray, key, indirectSearch) {\n var start = 0,\n end = sortedArray.length - 1,\n middle;\n while (start < end) {\n middle = Math.ceil((start + end) / 2);\n // Key found as the middle element.\n if (sortedArray[middle] <= key) {\n // Continue searching to the right.\n start = middle;\n }\n else {\n // Continue searching to the left.\n end = middle - 1;\n }\n }\n if (sortedArray[start] === key) {\n return start;\n }\n // Key could not be found.\n return !indirectSearch ? -1 : start;\n };\n /**\n * Get the ordinal positions for the entire data set. This is necessary\n * in chart panning because we need to find out what points or data\n * groups are available outside the visible range. When a panning\n * operation starts, if an index for the given grouping does not exists,\n * it is created and cached. This index is deleted on updated data, so\n * it will be regenerated the next time a panning operation starts.\n * @private\n */\n Additions.prototype.getExtendedPositions = function () {\n var ordinal = this,\n axis = ordinal.axis,\n axisProto = axis.constructor.prototype,\n chart = axis.chart,\n grouping = axis.series[0].currentDataGrouping,\n key = grouping ?\n grouping.count + grouping.unitName :\n 'raw',\n overscroll = axis.options.overscroll,\n extremes = axis.getExtremes();\n var fakeAxis,\n fakeSeries = void 0,\n ordinalIndex = ordinal.index;\n // If this is the first time, or the ordinal index is deleted by\n // updatedData,\n // create it.\n if (!ordinalIndex) {\n ordinalIndex = ordinal.index = {};\n }\n if (!ordinalIndex[key]) {\n // Create a fake axis object where the extended ordinal\n // positions are emulated\n fakeAxis = {\n series: [],\n chart: chart,\n forceOrdinal: false,\n getExtremes: function () {\n return {\n min: extremes.dataMin,\n max: extremes.dataMax + overscroll\n };\n },\n getGroupPixelWidth: axisProto.getGroupPixelWidth,\n getTimeTicks: axisProto.getTimeTicks,\n options: {\n ordinal: true\n },\n ordinal: {\n getGroupIntervalFactor: this.getGroupIntervalFactor\n },\n ordinal2lin: axisProto.ordinal2lin,\n getIndexOfPoint: axisProto.getIndexOfPoint,\n val2lin: axisProto.val2lin // #2590\n };\n fakeAxis.ordinal.axis = fakeAxis;\n // Add the fake series to hold the full data, then apply\n // processData to it\n axis.series.forEach(function (series) {\n fakeSeries = {\n xAxis: fakeAxis,\n xData: series.xData.slice(),\n chart: chart,\n destroyGroupedData: H.noop,\n getProcessedData: Series.prototype.getProcessedData,\n applyGrouping: Series.prototype.applyGrouping\n };\n fakeSeries.xData = fakeSeries.xData.concat(ordinal.getOverscrollPositions());\n fakeSeries.options = {\n dataGrouping: grouping ? {\n firstAnchor: 'firstPoint',\n anchor: 'middle',\n lastAnchor: 'lastPoint',\n enabled: true,\n forced: true,\n // doesn't matter which, use the fastest\n approximation: 'open',\n units: [[\n grouping.unitName,\n [grouping.count]\n ]]\n } : {\n enabled: false\n }\n };\n fakeAxis.series.push(fakeSeries);\n series.processData.apply(fakeSeries);\n });\n // Force to use the ordinal when points are evenly spaced (e.g.\n // weeks), #3825.\n if ((fakeSeries.closestPointRange !==\n fakeSeries.basePointRange) &&\n fakeSeries.currentDataGrouping) {\n fakeAxis.forceOrdinal = true;\n }\n // Run beforeSetTickPositions to compute the ordinalPositions\n axis.ordinal.beforeSetTickPositions.apply({ axis: fakeAxis });\n // Cache it\n ordinalIndex[key] = fakeAxis.ordinal.positions;\n }\n return ordinalIndex[key];\n };\n /**\n * Find the factor to estimate how wide the plot area would have been if\n * ordinal gaps were included. This value is used to compute an imagined\n * plot width in order to establish the data grouping interval.\n *\n * A real world case is the intraday-candlestick example. Without this\n * logic, it would show the correct data grouping when viewing a range\n * within each day, but once moving the range to include the gap between\n * two days, the interval would include the cut-away night hours and the\n * data grouping would be wrong. So the below method tries to compensate\n * by identifying the most common point interval, in this case days.\n *\n * An opposite case is presented in issue #718. We have a long array of\n * daily data, then one point is appended one hour after the last point.\n * We expect the data grouping not to change.\n *\n * In the future, if we find cases where this estimation doesn't work\n * optimally, we might need to add a second pass to the data grouping\n * logic, where we do another run with a greater interval if the number\n * of data groups is more than a certain fraction of the desired group\n * count.\n * @private\n */\n Additions.prototype.getGroupIntervalFactor = function (xMin, xMax, series) {\n var ordinal = this,\n axis = ordinal.axis,\n processedXData = series.processedXData,\n len = processedXData.length,\n distances = [];\n var median,\n i,\n groupIntervalFactor = ordinal.groupIntervalFactor;\n // Only do this computation for the first series, let the other\n // inherit it (#2416)\n if (!groupIntervalFactor) {\n // Register all the distances in an array\n for (i = 0; i < len - 1; i++) {\n distances[i] = (processedXData[i + 1] -\n processedXData[i]);\n }\n // Sort them and find the median\n distances.sort(function (a, b) {\n return a - b;\n });\n median = distances[Math.floor(len / 2)];\n // Compensate for series that don't extend through the entire\n // axis extent. #1675.\n xMin = Math.max(xMin, processedXData[0]);\n xMax = Math.min(xMax, processedXData[len - 1]);\n ordinal.groupIntervalFactor = groupIntervalFactor =\n (len * median) / (xMax - xMin);\n }\n // Return the factor needed for data grouping\n return groupIntervalFactor;\n };\n /**\n * Get index of point inside the ordinal positions array.\n *\n * @private\n * @param {number} val\n * The pixel value of a point.\n *\n * @param {Array} [ordinallArray]\n * An array of all points available on the axis for the given data set.\n * Either ordinalPositions if the value is inside the plotArea or\n * extendedOrdinalPositions if not.\n */\n Additions.prototype.getIndexOfPoint = function (val, ordinalArray) {\n var ordinal = this,\n axis = ordinal.axis,\n firstPointVal = ordinal.positions ? ordinal.positions[0] : 0;\n var firstPointX = axis.series[0].points &&\n axis.series[0].points[0] &&\n axis.series[0].points[0].plotX ||\n axis.minPixelPadding; // #15987\n // When more series assign to axis, find the smallest one, #15987.\n if (axis.series.length > 1) {\n axis.series.forEach(function (series) {\n if (series.points &&\n defined(series.points[0]) &&\n defined(series.points[0].plotX) &&\n series.points[0].plotX < firstPointX) {\n firstPointX = series.points[0].plotX;\n }\n });\n }\n // Distance in pixels between two points on the ordinal axis in the\n // current zoom.\n var ordinalPointPixelInterval = axis.translationSlope * (ordinal.slope ||\n axis.closestPointRange ||\n ordinal.overscrollPointsRange), \n // toValue for the first point.\n shiftIndex = (val - firstPointX) / ordinalPointPixelInterval;\n return Additions.findIndexOf(ordinalArray, firstPointVal) + shiftIndex;\n };\n /**\n * Get ticks for an ordinal axis within a range where points don't\n * exist. It is required when overscroll is enabled. We can't base on\n * points, because we may not have any, so we use approximated\n * pointRange and generate these ticks between Axis.dataMax,\n * Axis.dataMax + Axis.overscroll evenly spaced. Used in panning and\n * navigator scrolling.\n * @private\n */\n Additions.prototype.getOverscrollPositions = function () {\n var ordinal = this,\n axis = ordinal.axis,\n extraRange = axis.options.overscroll,\n distance = ordinal.overscrollPointsRange,\n positions = [],\n max = axis.dataMax;\n if (defined(distance)) {\n // Max + pointRange because we need to scroll to the last\n while (max <= axis.dataMax + extraRange) {\n max += distance;\n positions.push(max);\n }\n }\n return positions;\n };\n /**\n * Make the tick intervals closer because the ordinal gaps make the\n * ticks spread out or cluster.\n * @private\n */\n Additions.prototype.postProcessTickInterval = function (tickInterval) {\n // Problem: https://jsfiddle.net/highcharts/FQm4E/1/. This is a case\n // where this algorithm doesn't work optimally. In this case, the\n // tick labels are spread out per week, but all the gaps reside\n // within weeks. So we have a situation where the labels are courser\n // than the ordinal gaps, and thus the tick interval should not be\n // altered.\n var ordinal = this,\n axis = ordinal.axis,\n ordinalSlope = ordinal.slope;\n var ret;\n if (ordinalSlope) {\n if (!axis.options.breaks) {\n ret = (tickInterval /\n (ordinalSlope / axis.closestPointRange));\n }\n else {\n ret = axis.closestPointRange || tickInterval; // #7275\n }\n }\n else {\n ret = tickInterval;\n }\n return ret;\n };\n return Additions;\n }());\n OrdinalAxis.Additions = Additions;\n })(OrdinalAxis || (OrdinalAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return OrdinalAxis;\n });\n _registerModule(_modules, 'Series/HLC/HLCPoint.js', [_modules['Core/Series/SeriesRegistry.js']], function (SeriesRegistry) {\n /* *\n *\n * (c) 2010-2021 Pawel Lysy\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var ColumnPoint = SeriesRegistry.seriesTypes.column.prototype.pointClass;\n /* *\n *\n * Class\n *\n * */\n var HLCPoint = /** @class */ (function (_super) {\n __extends(HLCPoint, _super);\n function HLCPoint() {\n /* *\n *\n * Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n _this.close = void 0;\n _this.high = void 0;\n _this.low = void 0;\n _this.options = void 0;\n _this.plotClose = void 0;\n _this.series = void 0;\n return _this;\n }\n return HLCPoint;\n }(ColumnPoint));\n /* *\n *\n * Default Export\n *\n * */\n\n return HLCPoint;\n });\n _registerModule(_modules, 'Series/HLC/HLCSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Pawel Lysy\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * An HLC chart is a style of financial chart used to describe price\n * movements over time. It displays high, low and close values per\n * data point.\n *\n * @sample stock/demo/hlc/\n * HLC chart\n *\n * @extends plotOptions.column\n * @excluding borderColor, borderRadius, borderWidth, crisp, stacking,\n * stack\n * @product highstock\n * @optionparent plotOptions.hlc\n */\n var HLCSeriesDefaults = {\n /**\n * The approximate pixel width of each group. If for example a series\n * with 30 points is displayed over a 600 pixel wide plot area, no\n * grouping is performed. If however the series contains so many points\n * that the spacing is less than the groupPixelWidth, Highcharts will\n * try to group it into appropriate groups so that each is more or less\n * two pixels wide. Defaults to `5`.\n *\n * @type {number}\n * @default 5\n * @product highstock\n * @apioption plotOptions.hlc.dataGrouping.groupPixelWidth\n */\n /**\n * @type {Highcharts.DataGroupingApproximationValue|Function}\n * @default hlc\n * @product highstock\n * @apioption plotOptions.hlc.dataGrouping.approximation\n */\n /**\n * @default close\n * @apioption plotOptions.hlc.colorKey\n */\n /**\n * The pixel width of the line/border. Defaults to `1`.\n *\n * @sample {highstock} stock/plotoptions/hlc-linewidth/\n * A greater line width\n *\n * @type {number}\n * @default 1\n * @product highstock\n *\n * @public\n */\n lineWidth: 1,\n tooltip: {\n pointFormat: '\\u25CF ' +\n ' {series.name}
' +\n 'High: {point.high}
' +\n 'Low: {point.low}
' +\n 'Close: {point.close}
'\n },\n /**\n * @type {number|null}\n */\n threshold: null,\n states: {\n /**\n * @extends plotOptions.column.states.hover\n * @product highstock\n */\n hover: {\n /**\n * The pixel width of the line representing the HLC point.\n *\n * @type {number}\n * @default 3\n * @product highstock\n */\n lineWidth: 3\n }\n },\n /**\n * Determines which one of `high`, `low`, `close` values should\n * be represented as `point.y`, which is later used to set dataLabel\n * position and [compare](#plotOptions.series.compare).\n *\n * @sample {highstock} stock/plotoptions/hlc-pointvalkey/\n * Possible values\n *\n * @type {string}\n * @default close\n * @validvalue [\"high\", \"low\", \"close\"]\n * @product highstock\n * @apioption plotOptions.hlc.pointValKey\n */\n /**\n * @default close\n * @apioption plotOptions.hlc.colorKey\n */\n stickyTracking: true\n };\n /**\n * A `hlc` series. If the [type](#series.hlc.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.hlc\n * @excluding dataParser, dataURL\n * @product highstock\n * @apioption series.hlc\n */\n /**\n * An array of data points for the series. For the `hlc` series type,\n * points can be given in the following ways:\n *\n * 1. An array of arrays with 4 or 3 values. In this case, the values correspond\n * to `x,high,low,close`. If the first value is a string, it is applied\n * as the name of the point, and the `x` value is inferred. The `x` value can\n * also be omitted, in which case the inner arrays should be of length of 3\\.\n * Then the `x` value is automatically calculated, either starting at 0 and\n * incremented by 1, or from `pointStart` and `pointInterval` given in the\n * series options.\n * ```js\n * data: [\n * [0, 5, 6, 7],\n * [1, 4, 8, 2],\n * [2, 3, 4, 10]\n * ]\n * ```\n *\n * 2. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.hlc.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * high: 4,\n * low: 5,\n * close: 2,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * high: 3,\n * low: 6,\n * close: 7,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @type {Array|Array<(number|string),number,number,number>|*>}\n * @extends series.arearange.data\n * @excluding y, marker\n * @product highstock\n * @apioption series.hlc.data\n */\n /**\n * The closing value of each data point.\n *\n * @type {number}\n * @product highstock\n * @apioption series.hlc.data.close\n */\n (''); // keeps doclets above in JS file\n /* *\n *\n * Default Export\n *\n * */\n\n return HLCSeriesDefaults;\n });\n _registerModule(_modules, 'Series/HLC/HLCSeries.js', [_modules['Series/HLC/HLCPoint.js'], _modules['Series/HLC/HLCSeriesDefaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (HLCPoint, HLCSeriesDefaults, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Pawel Lysy\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var ColumnSeries = SeriesRegistry.seriesTypes.column;\n var extend = U.extend,\n merge = U.merge;\n /* *\n *\n * Class\n *\n * */\n /**\n * The hlc series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.hlc\n *\n * @augments Highcharts.Series\n */\n var HLCSeries = /** @class */ (function (_super) {\n __extends(HLCSeries, _super);\n function HLCSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.data = void 0;\n _this.options = void 0;\n _this.points = void 0;\n _this.yData = void 0;\n return _this;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extend the path if close is not between high and low.\n *\n * @param {SVGPath} path the path array of the point\n * @param {number} halfStrokeWidth\n * @param {number} value value of the point to which the stem should be extended\n */\n HLCSeries.prototype.extendStem = function (path, halfStrokeWidth, value) {\n var start = path[0];\n var end = path[1];\n // We don't need to worry about crisp - close value\n // is already crisped and halfStrokeWidth should remove it.\n if (typeof start[2] === 'number') {\n start[2] = Math.max(value + halfStrokeWidth, start[2]);\n }\n if (typeof end[2] === 'number') {\n end[2] = Math.min(value - halfStrokeWidth, end[2]);\n }\n };\n /**\n * Function to create SVGPath of the point based on the\n * plot positions of this point.\n * @private\n */\n HLCSeries.prototype.getPointPath = function (point, graphic) {\n // crisp vector coordinates\n var strokeWidth = graphic.strokeWidth(),\n series = point.series,\n crispCorr = (strokeWidth % 2) / 2, \n // #2596:\n crispX = Math.round(point.plotX) - crispCorr,\n halfWidth = Math.round(point.shapeArgs.width / 2);\n var plotClose = point.plotClose;\n // the vertical stem\n var path = [\n ['M',\n crispX,\n Math.round(point.yBottom)],\n ['L',\n crispX,\n Math.round(point.plotHigh)]\n ];\n // close\n if (point.close !== null) {\n plotClose = Math.round(point.plotClose) + crispCorr;\n path.push(['M', crispX, plotClose], ['L', crispX + halfWidth, plotClose]);\n series.extendStem(path, strokeWidth / 2, plotClose);\n }\n return path;\n };\n /**\n * Draw single point\n * @private\n */\n HLCSeries.prototype.drawSinglePoint = function (point) {\n var series = point.series,\n chart = series.chart;\n var path,\n graphic = point.graphic;\n if (typeof point.plotY !== 'undefined') {\n // Create and/or update the graphic\n if (!graphic) {\n point.graphic = graphic = chart.renderer.path()\n .add(series.group);\n }\n if (!chart.styledMode) {\n graphic.attr(series.pointAttribs(point, (point.selected && 'select'))); // #3897\n }\n // crisp vector coordinates\n path = series.getPointPath(point, graphic);\n graphic[!graphic ? 'attr' : 'animate']({ d: path })\n .addClass(point.getClassName(), true);\n }\n };\n /**\n * Draw the data points\n * @private\n */\n HLCSeries.prototype.drawPoints = function () {\n this.points.forEach(this.drawSinglePoint);\n };\n /**\n * @private\n * @function Highcharts.seriesTypes.hlc#init\n */\n HLCSeries.prototype.init = function () {\n _super.prototype.init.apply(this, arguments);\n this.options.stacking = void 0; // #8817\n };\n /**\n * Postprocess mapping between options and SVG attributes\n * @private\n */\n HLCSeries.prototype.pointAttribs = function (point, state) {\n var attribs = _super.prototype.pointAttribs.call(this,\n point,\n state);\n delete attribs.fill;\n return attribs;\n };\n HLCSeries.prototype.toYData = function (point) {\n // return a plain array for speedy calculation\n return [point.high, point.low, point.close];\n };\n /**\n * Translate data points from raw values x and y to plotX and plotY\n *\n * @private\n * @function Highcharts.seriesTypes.hlc#translate\n */\n HLCSeries.prototype.translate = function () {\n var series = this,\n yAxis = series.yAxis,\n names = (this.pointArrayMap && this.pointArrayMap.slice()) || [],\n translated = names.map(function (name) {\n return \"plot\".concat(name.charAt(0).toUpperCase() + name.slice(1));\n });\n translated.push('yBottom');\n names.push('low');\n _super.prototype.translate.apply(series);\n // Do the translation\n series.points.forEach(function (point) {\n names.forEach(function (name, i) {\n var value = point[name];\n if (value !== null) {\n if (series.dataModify) {\n value = series.dataModify.modifyValue(value);\n }\n point[translated[i]] =\n yAxis.toPixels(value, true);\n }\n });\n // Align the tooltip to the high value to avoid covering the\n // point\n point.tooltipPos[1] =\n point.plotHigh + yAxis.pos - series.chart.plotTop;\n });\n };\n HLCSeries.defaultOptions = merge(ColumnSeries.defaultOptions, HLCSeriesDefaults);\n return HLCSeries;\n }(ColumnSeries));\n extend(HLCSeries.prototype, {\n pointClass: HLCPoint,\n animate: null,\n directTouch: false,\n pointArrayMap: ['high', 'low', 'close'],\n pointAttrToOptions: {\n stroke: 'color',\n 'stroke-width': 'lineWidth'\n },\n pointValKey: 'close'\n });\n SeriesRegistry.registerSeriesType('hlc', HLCSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return HLCSeries;\n });\n _registerModule(_modules, 'Series/OHLC/OHLCPoint.js', [_modules['Core/Series/SeriesRegistry.js']], function (SeriesRegistry) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var HLCSeries = SeriesRegistry.seriesTypes.hlc;\n /* *\n *\n * Class\n *\n * */\n var OHLCPoint = /** @class */ (function (_super) {\n __extends(OHLCPoint, _super);\n function OHLCPoint() {\n /* *\n *\n * Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n _this.open = void 0;\n _this.options = void 0;\n _this.plotOpen = void 0;\n _this.series = void 0;\n return _this;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extend the parent method by adding up or down to the class name.\n * @private\n * @function Highcharts.seriesTypes.ohlc#getClassName\n */\n OHLCPoint.prototype.getClassName = function () {\n return _super.prototype.getClassName.call(this) +\n (this.open < this.close ?\n ' highcharts-point-up' :\n ' highcharts-point-down');\n };\n /**\n * Save upColor as point color (#14826).\n * @private\n * @function Highcharts.seriesTypes.ohlc#resolveUpColor\n */\n OHLCPoint.prototype.resolveUpColor = function () {\n if (this.open < this.close &&\n !this.options.color &&\n this.series.options.upColor) {\n this.color = this.series.options.upColor;\n }\n };\n /**\n * Extend the parent method by saving upColor.\n * @private\n * @function Highcharts.seriesTypes.ohlc#resolveColor\n */\n OHLCPoint.prototype.resolveColor = function () {\n _super.prototype.resolveColor.call(this);\n this.resolveUpColor();\n };\n /**\n * Extend the parent method by saving upColor.\n * @private\n * @function Highcharts.seriesTypes.ohlc#getZone\n *\n * @return {Highcharts.SeriesZonesOptionsObject}\n * The zone item.\n */\n OHLCPoint.prototype.getZone = function () {\n var zone = _super.prototype.getZone.call(this);\n this.resolveUpColor();\n return zone;\n };\n /**\n * Extend the parent method by resolving up/down colors (#15849)\n * @private\n **/\n OHLCPoint.prototype.applyOptions = function () {\n _super.prototype.applyOptions.apply(this, arguments);\n if (this.resolveColor) {\n this.resolveColor();\n }\n return this;\n };\n return OHLCPoint;\n }(HLCSeries.prototype.pointClass));\n /* *\n *\n * Default Export\n *\n * */\n\n return OHLCPoint;\n });\n _registerModule(_modules, 'Series/OHLC/OHLCSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * An OHLC chart is a style of financial chart used to describe price\n * movements over time. It displays open, high, low and close values per\n * data point.\n *\n * @sample stock/demo/ohlc\n * OHLC chart\n *\n * @extends plotOptions.hlc\n * @product highstock\n * @optionparent plotOptions.ohlc\n */\n var OHLCSeriesDefaults = {\n /**\n * @type {Highcharts.DataGroupingApproximationValue|Function}\n * @default ohlc\n * @product highstock\n * @apioption plotOptions.ohlc.dataGrouping.approximation\n */\n /**\n * Determines which one of `open`, `high`, `low`, `close` values should\n * be represented as `point.y`, which is later used to set dataLabel\n * position and [compare](#plotOptions.series.compare).\n *\n * @default close\n * @validvalue [\"open\", \"high\", \"low\", \"close\"]\n * @product highstock\n * @apioption plotOptions.ohlc.pointValKey\n */\n /**\n * Line color for up points.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highstock\n * @apioption plotOptions.ohlc.upColor\n */\n tooltip: {\n pointFormat: '\\u25CF ' +\n ' {series.name}
' +\n 'Open: {point.open}
' +\n 'High: {point.high}
' +\n 'Low: {point.low}
' +\n 'Close: {point.close}
'\n }\n };\n /**\n * The parameter allows setting line series type and use OHLC indicators.\n * Data in OHLC format is required.\n *\n * @sample {highstock} stock/indicators/use-ohlc-data\n * Use OHLC data format to plot line chart\n *\n * @type {boolean}\n * @product highstock\n * @apioption plotOptions.line.useOhlcData\n */\n /**\n * A `ohlc` series. If the [type](#series.ohlc.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.ohlc\n * @excluding dataParser, dataURL\n * @product highstock\n * @apioption series.ohlc\n */\n /**\n * An array of data points for the series. For the `ohlc` series type,\n * points can be given in the following ways:\n *\n * 1. An array of arrays with 5 or 4 values. In this case, the values correspond\n * to `x,open,high,low,close`. If the first value is a string, it is applied\n * as the name of the point, and the `x` value is inferred. The `x` value can\n * also be omitted, in which case the inner arrays should be of length 4\\.\n * Then the `x` value is automatically calculated, either starting at 0 and\n * incremented by 1, or from `pointStart` and `pointInterval` given in the\n * series options.\n * ```js\n * data: [\n * [0, 6, 5, 6, 7],\n * [1, 9, 4, 8, 2],\n * [2, 6, 3, 4, 10]\n * ]\n * ```\n *\n * 2. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.ohlc.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * open: 3,\n * high: 4,\n * low: 5,\n * close: 2,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * open: 4,\n * high: 3,\n * low: 6,\n * close: 7,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @type {Array|Array<(number|string),number,number,number,number>|*>}\n * @extends series.arearange.data\n * @excluding y, marker\n * @product highstock\n * @apioption series.ohlc.data\n */\n /**\n * The closing value of each data point.\n *\n * @type {number}\n * @product highstock\n * @apioption series.ohlc.data.close\n */\n /**\n * The opening value of each data point.\n *\n * @type {number}\n * @product highstock\n * @apioption series.ohlc.data.open\n */\n ''; // adds doclets above to transpilat\n /* *\n *\n * Default Export\n *\n * */\n\n return OHLCSeriesDefaults;\n });\n _registerModule(_modules, 'Series/OHLC/OHLCSeries.js', [_modules['Series/OHLC/OHLCPoint.js'], _modules['Series/OHLC/OHLCSeriesDefaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (OHLCPoint, OHLCSeriesDefaults, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var HLCSeries = SeriesRegistry.seriesTypes.hlc;\n var addEvent = U.addEvent,\n extend = U.extend,\n merge = U.merge;\n /* *\n *\n * Constants\n *\n * */\n var composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function onSeriesAfterSetOptions(e) {\n var options = e.options,\n dataGrouping = options.dataGrouping;\n if (dataGrouping &&\n options.useOhlcData &&\n options.id !== 'highcharts-navigator-series') {\n dataGrouping.approximation = 'ohlc';\n }\n }\n /**\n * Add useOhlcData option\n * @private\n */\n function onSeriesInit(eventOptions) {\n // eslint-disable-next-line no-invalid-this\n var series = this,\n options = eventOptions.options;\n if (options.useOhlcData &&\n options.id !== 'highcharts-navigator-series') {\n extend(series, {\n pointValKey: OHLCSeries.prototype.pointValKey,\n // keys: ohlcProto.keys, // @todo potentially nonsense\n pointArrayMap: OHLCSeries.prototype.pointArrayMap,\n toYData: OHLCSeries.prototype.toYData\n });\n }\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * The ohlc series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.ohlc\n *\n * @augments Highcharts.Series\n */\n var OHLCSeries = /** @class */ (function (_super) {\n __extends(OHLCSeries, _super);\n function OHLCSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.data = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n }\n /* *\n *\n * Static Functions\n *\n * */\n OHLCSeries.compose = function (SeriesClass) {\n var _args = [];\n for (var _i = 1; _i < arguments.length; _i++) {\n _args[_i - 1] = arguments[_i];\n }\n if (composedMembers.indexOf(SeriesClass) === -1) {\n composedMembers.push(SeriesClass);\n addEvent(SeriesClass, 'afterSetOptions', onSeriesAfterSetOptions);\n addEvent(SeriesClass, 'init', onSeriesInit);\n }\n };\n /* *\n *\n * Functions\n *\n * */\n OHLCSeries.prototype.getPointPath = function (point, graphic) {\n var path = _super.prototype.getPointPath.call(this,\n point,\n graphic),\n strokeWidth = graphic.strokeWidth(),\n crispCorr = (strokeWidth % 2) / 2,\n crispX = Math.round(point.plotX) - crispCorr,\n halfWidth = Math.round(point.shapeArgs.width / 2);\n var plotOpen = point.plotOpen;\n // crisp vector coordinates\n if (point.open !== null) {\n plotOpen = Math.round(point.plotOpen) + crispCorr;\n path.push(['M', crispX, plotOpen], ['L', crispX - halfWidth, plotOpen]);\n _super.prototype.extendStem.call(this, path, strokeWidth / 2, plotOpen);\n }\n return path;\n };\n /**\n * Postprocess mapping between options and SVG attributes\n * @private\n */\n OHLCSeries.prototype.pointAttribs = function (point, state) {\n var attribs = _super.prototype.pointAttribs.call(this,\n point,\n state),\n options = this.options;\n delete attribs.fill;\n if (!point.options.color &&\n options.upColor &&\n point.open < point.close) {\n attribs.stroke = options.upColor;\n }\n return attribs;\n };\n OHLCSeries.prototype.toYData = function (point) {\n // return a plain array for speedy calculation\n return [point.open, point.high, point.low, point.close];\n };\n OHLCSeries.defaultOptions = merge(HLCSeries.defaultOptions, OHLCSeriesDefaults);\n return OHLCSeries;\n }(HLCSeries));\n extend(OHLCSeries.prototype, {\n pointClass: OHLCPoint,\n pointArrayMap: ['open', 'high', 'low', 'close']\n });\n SeriesRegistry.registerSeriesType('ohlc', OHLCSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return OHLCSeries;\n });\n _registerModule(_modules, 'Series/Candlestick/CandlestickSeriesDefaults.js', [_modules['Core/Defaults.js'], _modules['Core/Utilities.js']], function (D, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var defaultOptions = D.defaultOptions;\n var merge = U.merge;\n /* *\n *\n * API Options\n *\n * */\n /**\n * A candlestick chart is a style of financial chart used to describe\n * price movements over time.\n *\n * @sample stock/demo/candlestick/\n * Candlestick chart\n *\n * @extends plotOptions.ohlc\n * @excluding borderColor,borderRadius,borderWidth\n * @product highstock\n * @optionparent plotOptions.candlestick\n */\n var CandlestickSeriesDefaults = {\n /**\n * The specific line color for up candle sticks. The default is to\n * inherit the general `lineColor` setting.\n *\n * @sample {highstock} stock/plotoptions/candlestick-linecolor/\n * Candlestick line colors\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 1.3.6\n * @product highstock\n * @apioption plotOptions.candlestick.upLineColor\n */\n states: {\n /**\n * @extends plotOptions.column.states.hover\n * @product highstock\n */\n hover: {\n /**\n * The pixel width of the line/border around the\n * candlestick.\n *\n * @product highstock\n */\n lineWidth: 2\n }\n },\n /**\n * @type {number|null}\n * @product highstock\n */\n threshold: null,\n /**\n * The color of the line/border of the candlestick.\n *\n * In styled mode,\n the line stroke can be set with the\n * `.highcharts-candlestick-series .highcahrts-point` rule.\n *\n * @see [upLineColor](#plotOptions.candlestick.upLineColor)\n *\n * @sample {highstock} stock/plotoptions/candlestick-linecolor/\n * Candlestick line colors\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #000000\n * @product highstock\n */\n lineColor: \"#000000\" /* Palette.neutralColor100 */,\n /**\n * The pixel width of the candlestick line/border. Defaults to `1`.\n *\n *\n * In styled mode,\n the line stroke width can be set with the\n * `.highcharts-candlestick-series .highcahrts-point` rule.\n *\n * @product highstock\n */\n lineWidth: 1,\n /**\n * The fill color of the candlestick when values are rising.\n *\n * In styled mode,\n the up color can be set with the\n * `.highcharts-candlestick-series .highcharts-point-up` rule.\n *\n * @sample {highstock} stock/plotoptions/candlestick-color/\n * Custom colors\n * @sample {highstock} highcharts/css/candlestick/\n * Colors in styled mode\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #ffffff\n * @product highstock\n */\n upColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * @product highstock\n */\n stickyTracking: true\n };\n /**\n * A `candlestick` series. If the [type](#series.candlestick.type)\n * option is not specified, it is inherited from [chart.type](\n * #chart.type).\n *\n * @type {*}\n * @extends series,plotOptions.candlestick\n * @excluding dataParser, dataURL, marker\n * @product highstock\n * @apioption series.candlestick\n */\n /**\n * An array of data points for the series. For the `candlestick` series\n * type, points can be given in the following ways:\n *\n * 1. An array of arrays with 5 or 4 values. In this case, the values correspond\n * to `x,open,high,low,close`. If the first value is a string, it is applied\n * as the name of the point, and the `x` value is inferred. The `x` value can\n * also be omitted, in which case the inner arrays should be of length 4.\n * Then the `x` value is automatically calculated, either starting at 0 and\n * incremented by 1, or from `pointStart` and `pointInterval` given in the\n * series options.\n * ```js\n * data: [\n * [0, 7, 2, 0, 4],\n * [1, 1, 4, 2, 8],\n * [2, 3, 3, 9, 3]\n * ]\n * ```\n *\n * 2. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.candlestick.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * open: 9,\n * high: 2,\n * low: 4,\n * close: 6,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * open: 1,\n * high: 4,\n * low: 7,\n * close: 7,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @type {Array|Array<(number|string),number,number,number,number>|*>}\n * @extends series.ohlc.data\n * @excluding y\n * @product highstock\n * @apioption series.candlestick.data\n */\n ''; // adds doclets above to transpilat\n /* *\n *\n * Default Export\n *\n * */\n\n return CandlestickSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Candlestick/CandlestickSeries.js', [_modules['Series/Candlestick/CandlestickSeriesDefaults.js'], _modules['Core/Defaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (CandlestickSeriesDefaults, D, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var defaultOptions = D.defaultOptions;\n var _a = SeriesRegistry.seriesTypes,\n ColumnSeries = _a.column,\n OHLCSeries = _a.ohlc;\n var merge = U.merge;\n /* *\n *\n * Class\n *\n * */\n /**\n * The candlestick series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.candlestick\n *\n * @augments Highcharts.seriesTypes.ohlc\n */\n var CandlestickSeries = /** @class */ (function (_super) {\n __extends(CandlestickSeries, _super);\n function CandlestickSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.data = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Postprocess mapping between options and SVG attributes\n *\n * @private\n * @function Highcharts.seriesTypes.candlestick#pointAttribs\n */\n CandlestickSeries.prototype.pointAttribs = function (point, state) {\n var attribs = ColumnSeries.prototype.pointAttribs.call(this,\n point,\n state),\n options = this.options,\n isUp = point.open < point.close,\n stroke = options.lineColor || this.color,\n color = point.color || this.color; // (#14826)\n attribs['stroke-width'] = options.lineWidth;\n attribs.fill = point.options.color ||\n (isUp ? (options.upColor || color) : color);\n attribs.stroke = point.options.lineColor ||\n (isUp ? (options.upLineColor || stroke) : stroke);\n // Select or hover states\n if (state) {\n var stateOptions = options.states[state];\n attribs.fill = stateOptions.color || attribs.fill;\n attribs.stroke = stateOptions.lineColor || attribs.stroke;\n attribs['stroke-width'] =\n stateOptions.lineWidth || attribs['stroke-width'];\n }\n return attribs;\n };\n /**\n * Draw the data points.\n *\n * @private\n * @function Highcharts.seriesTypes.candlestick#drawPoints\n */\n CandlestickSeries.prototype.drawPoints = function () {\n var series = this,\n points = series.points,\n chart = series.chart,\n reversedYAxis = series.yAxis.reversed;\n for (var _i = 0, points_1 = points; _i < points_1.length; _i++) {\n var point = points_1[_i];\n var graphic = point.graphic,\n plotOpen = void 0,\n plotClose = void 0,\n topBox = void 0,\n bottomBox = void 0,\n hasTopWhisker = void 0,\n hasBottomWhisker = void 0,\n crispCorr = void 0,\n crispX = void 0,\n path = void 0,\n halfWidth = void 0;\n var isNew = !graphic;\n if (typeof point.plotY !== 'undefined') {\n if (!graphic) {\n point.graphic = graphic = chart.renderer.path()\n .add(series.group);\n }\n if (!series.chart.styledMode) {\n graphic\n .attr(series.pointAttribs(point, (point.selected && 'select'))) // #3897\n .shadow(series.options.shadow);\n }\n // Crisp vector coordinates\n crispCorr = (graphic.strokeWidth() % 2) / 2;\n // #2596:\n crispX = Math.round(point.plotX) - crispCorr;\n plotOpen = point.plotOpen;\n plotClose = point.plotClose;\n topBox = Math.min(plotOpen, plotClose);\n bottomBox = Math.max(plotOpen, plotClose);\n halfWidth = Math.round(point.shapeArgs.width / 2);\n hasTopWhisker = reversedYAxis ?\n bottomBox !== point.yBottom :\n Math.round(topBox) !==\n Math.round(point.plotHigh);\n hasBottomWhisker = reversedYAxis ?\n Math.round(topBox) !==\n Math.round(point.plotHigh) :\n bottomBox !== point.yBottom;\n topBox = Math.round(topBox) + crispCorr;\n bottomBox = Math.round(bottomBox) + crispCorr;\n // Create the path. Due to a bug in Chrome 49, the path is\n // first instanciated with no values, then the values\n // pushed. For unknown reasons, instanciating the path array\n // with all the values would lead to a crash when updating\n // frequently (#5193).\n path = [];\n path.push(['M', crispX - halfWidth, bottomBox], ['L', crispX - halfWidth, topBox], ['L', crispX + halfWidth, topBox], ['L', crispX + halfWidth, bottomBox], ['Z'], // Ensure a nice rectangle #2602\n ['M', crispX, topBox], [\n 'L',\n // #460, #2094\n crispX,\n hasTopWhisker ?\n Math.round(reversedYAxis ?\n point.yBottom :\n point.plotHigh) :\n topBox\n ], ['M', crispX, bottomBox], [\n 'L',\n // #460, #2094\n crispX,\n hasBottomWhisker ?\n Math.round(reversedYAxis ?\n point.plotHigh :\n point.yBottom) :\n bottomBox\n ]);\n graphic[isNew ? 'attr' : 'animate']({ d: path })\n .addClass(point.getClassName(), true);\n }\n }\n };\n CandlestickSeries.defaultOptions = merge(OHLCSeries.defaultOptions, defaultOptions.plotOptions, { tooltip: OHLCSeries.defaultOptions.tooltip }, CandlestickSeriesDefaults);\n return CandlestickSeries;\n }(OHLCSeries));\n SeriesRegistry.registerSeriesType('candlestick', CandlestickSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return CandlestickSeries;\n });\n _registerModule(_modules, 'Series/Flags/FlagsPoint.js', [_modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var ColumnPoint = SeriesRegistry.seriesTypes.column.prototype.pointClass;\n var isNumber = U.isNumber;\n /* *\n *\n * Class\n *\n * */\n var FlagsPoint = /** @class */ (function (_super) {\n __extends(FlagsPoint, _super);\n function FlagsPoint() {\n /* *\n *\n * Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n _this.options = void 0;\n _this.series = void 0;\n _this.ttBelow = false;\n return _this;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n FlagsPoint.prototype.isValid = function () {\n // #9233 - Prevent from treating flags as null points (even if\n // they have no y values defined).\n return isNumber(this.y) || typeof this.y === 'undefined';\n };\n /**\n * @private\n */\n FlagsPoint.prototype.hasNewShapeType = function () {\n var shape = this.options.shape || this.series.options.shape;\n return this.graphic && shape && shape !== this.graphic.symbolKey;\n };\n return FlagsPoint;\n }(ColumnPoint));\n /* *\n *\n * Default Export\n *\n * */\n\n return FlagsPoint;\n });\n _registerModule(_modules, 'Series/Flags/FlagsSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Flags are used to mark events in stock charts. They can be added on the\n * timeline, or attached to a specific series.\n *\n * @sample stock/demo/flags-general/\n * Flags on a line series\n *\n * @extends plotOptions.column\n * @excluding animation, borderColor, borderRadius, borderWidth,\n * colorByPoint, cropThreshold, dataGrouping, pointPadding,\n * pointWidth, turboThreshold\n * @product highstock\n * @optionparent plotOptions.flags\n */\n var FlagsSeriesDefaults = {\n /**\n * In case the flag is placed on a series, on what point key to place\n * it. Line and columns have one key, `y`. In range or OHLC-type series,\n * however, the flag can optionally be placed on the `open`, `high`,\n * `low` or `close` key.\n *\n * @sample {highstock} stock/plotoptions/flags-onkey/\n * Range series, flag on high\n *\n * @type {string}\n * @default y\n * @since 4.2.2\n * @product highstock\n * @validvalue [\"y\", \"open\", \"high\", \"low\", \"close\"]\n * @apioption plotOptions.flags.onKey\n */\n /**\n * The id of the series that the flags should be drawn on. If no id\n * is given, the flags are drawn on the x axis.\n *\n * @sample {highstock} stock/plotoptions/flags/\n * Flags on series and on x axis\n *\n * @type {string}\n * @product highstock\n * @apioption plotOptions.flags.onSeries\n */\n pointRange: 0,\n /**\n * Whether the flags are allowed to overlap sideways. If `false`, the\n * flags are moved sideways using an algorithm that seeks to place every\n * flag as close as possible to its original position.\n *\n * @sample {highstock} stock/plotoptions/flags-allowoverlapx\n * Allow sideways overlap\n *\n * @since 6.0.4\n */\n allowOverlapX: false,\n /**\n * The shape of the marker. Can be one of \"flag\", \"circlepin\",\n * \"squarepin\", or an image of the format `url(/path-to-image.jpg)`.\n * Individual shapes can also be set for each point.\n *\n * @sample {highstock} stock/plotoptions/flags/\n * Different shapes\n *\n * @type {Highcharts.FlagsShapeValue}\n * @product highstock\n */\n shape: 'flag',\n /**\n * When multiple flags in the same series fall on the same value, this\n * number determines the vertical offset between them.\n *\n * @sample {highstock} stock/plotoptions/flags-stackdistance/\n * A greater stack distance\n *\n * @product highstock\n */\n stackDistance: 12,\n /**\n * Text alignment for the text inside the flag.\n *\n * @since 5.0.0\n * @product highstock\n * @validvalue [\"left\", \"center\", \"right\"]\n */\n textAlign: 'center',\n /**\n * Specific tooltip options for flag series. Flag series tooltips are\n * different from most other types in that a flag doesn't have a data\n * value, so the tooltip rather displays the `text` option for each\n * point.\n *\n * @extends plotOptions.series.tooltip\n * @excluding changeDecimals, valueDecimals, valuePrefix, valueSuffix\n * @product highstock\n */\n tooltip: {\n pointFormat: '{point.text}'\n },\n /**\n * @type {number|null}\n */\n threshold: null,\n /**\n * The text to display on each flag. This can be defined on series\n * level, or individually for each point. Defaults to `\"A\"`.\n *\n * @type {string}\n * @default A\n * @product highstock\n * @apioption plotOptions.flags.title\n */\n /**\n * The y position of the top left corner of the flag relative to either\n * the series (if onSeries is defined), or the x axis. Defaults to\n * `-30`.\n *\n * @product highstock\n */\n y: -30,\n /**\n * Whether to use HTML to render the flag texts. Using HTML allows for\n * advanced formatting, images and reliable bi-directional text\n * rendering. Note that exported images won't respect the HTML, and that\n * HTML won't respect Z-index settings.\n *\n * @type {boolean}\n * @default false\n * @since 1.3\n * @product highstock\n * @apioption plotOptions.flags.useHTML\n */\n /**\n * Fixed width of the flag's shape. By default, width is autocalculated\n * according to the flag's title.\n *\n * @sample {highstock} stock/demo/flags-shapes/\n * Flags with fixed width\n *\n * @type {number}\n * @product highstock\n * @apioption plotOptions.flags.width\n */\n /**\n * Fixed height of the flag's shape. By default, height is\n * autocalculated according to the flag's title.\n *\n * @type {number}\n * @product highstock\n * @apioption plotOptions.flags.height\n */\n /**\n * The fill color for the flags.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highstock\n */\n fillColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The color of the line/border of the flag.\n *\n * In styled mode, the stroke is set in the\n * `.highcharts-flag-series.highcharts-point` rule.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #000000\n * @product highstock\n * @apioption plotOptions.flags.lineColor\n */\n /**\n * The pixel width of the flag's line/border.\n *\n * @product highstock\n */\n lineWidth: 1,\n states: {\n /**\n * @extends plotOptions.column.states.hover\n * @product highstock\n */\n hover: {\n /**\n * The color of the line/border of the flag.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highstock\n */\n lineColor: \"#000000\" /* Palette.neutralColor100 */,\n /**\n * The fill or background color of the flag.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highstock\n */\n fillColor: \"#ccd6eb\" /* Palette.highlightColor20 */\n }\n },\n /**\n * The text styles of the flag.\n *\n * In styled mode, the styles are set in the\n * `.highcharts-flag-series .highcharts-point` rule.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"fontSize\": \"11px\", \"fontWeight\": \"bold\"}\n * @product highstock\n */\n style: {\n /** @ignore-option */\n fontSize: '11px',\n /** @ignore-option */\n fontWeight: 'bold'\n }\n };\n /**\n * A `flags` series. If the [type](#series.flags.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.flags\n * @excluding animation, borderColor, borderRadius, borderWidth, colorByPoint,\n * connectNulls, cropThreshold, dashStyle, dataGrouping, dataParser,\n * dataURL, gapSize, gapUnit, linecap, lineWidth, marker,\n * pointPadding, pointWidth, step, turboThreshold, useOhlcData\n * @product highstock\n * @apioption series.flags\n */\n /**\n * An array of data points for the series. For the `flags` series type,\n * points can be given in the following ways:\n *\n * 1. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.flags.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * title: \"A\",\n * text: \"First event\"\n * }, {\n * x: 1,\n * title: \"B\",\n * text: \"Second event\"\n * }]\n * ```\n *\n * @type {Array<*>}\n * @extends series.line.data\n * @excluding dataLabels, marker, name, y\n * @product highstock\n * @apioption series.flags.data\n */\n /**\n * The fill color of an individual flag. By default it inherits from\n * the series color.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highstock\n * @apioption series.flags.data.fillColor\n */\n /**\n * The longer text to be shown in the flag's tooltip.\n *\n * @type {string}\n * @product highstock\n * @apioption series.flags.data.text\n */\n /**\n * The short text to be shown on the flag.\n *\n * @type {string}\n * @product highstock\n * @apioption series.flags.data.title\n */\n ''; // keeps doclets above in transpiled file\n /* *\n *\n * Default Export\n *\n * */\n\n return FlagsSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Flags/FlagsSymbols.js', [_modules['Core/Renderer/RendererRegistry.js']], function (RendererRegistry) {\n /* *\n *\n * Imports\n *\n * */\n /* *\n *\n * Composition\n *\n * */\n var FlagsSymbols;\n (function (FlagsSymbols) {\n /* *\n *\n * Constants\n *\n * */\n var modifiedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * @private\n */\n function compose(SVGRendererClass) {\n if (modifiedMembers.indexOf(SVGRendererClass) === -1) {\n modifiedMembers.push(SVGRendererClass);\n var symbols = SVGRendererClass.prototype.symbols;\n symbols.flag = flag;\n createPinSymbol(symbols, 'circle');\n createPinSymbol(symbols, 'square');\n }\n var RendererClass = RendererRegistry.getRendererType();\n // The symbol callbacks are generated on the SVGRenderer object in all\n // browsers. Even VML browsers need this in order to generate shapes in\n // export. Now share them with the VMLRenderer.\n if (modifiedMembers.indexOf(RendererClass)) {\n modifiedMembers.push(RendererClass);\n var symbols = SVGRendererClass.prototype.symbols,\n vmlSymbols = RendererClass.prototype.symbols;\n vmlSymbols.circlepin = symbols.circlepin;\n vmlSymbols.flag = symbols.flag.bind(symbols);\n vmlSymbols.squarepin = symbols.squarepin;\n }\n }\n FlagsSymbols.compose = compose;\n /**\n * Create the flag icon with anchor.\n * @private\n */\n function flag(x, y, w, h, options) {\n var anchorX = (options && options.anchorX) || x,\n anchorY = (options && options.anchorY) || y;\n // To do: unwanted any cast because symbols.circle has wrong type, it\n // actually returns an SVGPathArray\n var path = this.circle(anchorX - 1,\n anchorY - 1, 2, 2);\n path.push(['M', anchorX, anchorY], ['L', x, y + h], ['L', x, y], ['L', x + w, y], ['L', x + w, y + h], ['L', x, y + h], ['Z']);\n return path;\n }\n /**\n * Create the circlepin and squarepin icons with anchor.\n * @private\n */\n function createPinSymbol(symbols, shape) {\n symbols[(shape + 'pin')] = function (x, y, w, h, options) {\n var anchorX = options && options.anchorX,\n anchorY = options && options.anchorY;\n var path;\n // For single-letter flags, make sure circular flags are not taller\n // than their width\n if (shape === 'circle' && h > w) {\n x -= Math.round((h - w) / 2);\n w = h;\n }\n path = (symbols[shape])(x, y, w, h);\n if (anchorX && anchorY) {\n /**\n * If the label is below the anchor, draw the connecting line\n * from the top edge of the label, otherwise start drawing from\n * the bottom edge\n */\n var labelX = anchorX;\n if (shape === 'circle') {\n labelX = x + w / 2;\n }\n else {\n var startSeg = path[0];\n var endSeg = path[1];\n if (startSeg[0] === 'M' && endSeg[0] === 'L') {\n labelX = (startSeg[1] + endSeg[1]) / 2;\n }\n }\n var labelY = (y > anchorY) ? y : y + h;\n path.push([\n 'M',\n labelX,\n labelY\n ], [\n 'L',\n anchorX,\n anchorY\n ]);\n path = path.concat(symbols.circle(anchorX - 1, anchorY - 1, 2, 2));\n }\n return path;\n };\n }\n })(FlagsSymbols || (FlagsSymbols = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return FlagsSymbols;\n });\n _registerModule(_modules, 'Series/OnSeriesComposition.js', [_modules['Series/Column/ColumnSeries.js'], _modules['Core/Series/Series.js'], _modules['Core/Utilities.js']], function (ColumnSeries, Series, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var columnProto = ColumnSeries.prototype;\n var seriesProto = Series.prototype;\n var defined = U.defined,\n stableSort = U.stableSort;\n /* *\n *\n * Composition\n *\n * */\n var OnSeriesComposition;\n (function (OnSeriesComposition) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Properties\n *\n * */\n var composedClasses = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * @private\n */\n function compose(SeriesClass) {\n if (composedClasses.indexOf(SeriesClass) === -1) {\n composedClasses.push(SeriesClass);\n var seriesProto_1 = SeriesClass.prototype;\n seriesProto_1.getPlotBox = getPlotBox;\n seriesProto_1.translate = translate;\n }\n return SeriesClass;\n }\n OnSeriesComposition.compose = compose;\n /**\n * Override getPlotBox. If the onSeries option is valid, return the plot box\n * of the onSeries, otherwise proceed as usual.\n *\n * @private\n */\n function getPlotBox() {\n return seriesProto.getPlotBox.call((this.options.onSeries &&\n this.chart.get(this.options.onSeries)) || this);\n }\n OnSeriesComposition.getPlotBox = getPlotBox;\n /**\n * Extend the translate method by placing the point on the related series\n *\n * @private\n */\n function translate() {\n columnProto.translate.apply(this);\n var series = this,\n options = series.options,\n chart = series.chart,\n points = series.points,\n optionsOnSeries = options.onSeries,\n onSeries = (optionsOnSeries &&\n chart.get(optionsOnSeries)),\n step = onSeries && onSeries.options.step,\n onData = (onSeries && onSeries.points),\n inverted = chart.inverted,\n xAxis = series.xAxis,\n yAxis = series.yAxis;\n var cursor = points.length - 1,\n point,\n lastPoint,\n onKey = options.onKey || 'y',\n i = onData && onData.length,\n xOffset = 0,\n leftPoint,\n lastX,\n rightPoint,\n currentDataGrouping,\n distanceRatio;\n // relate to a master series\n if (onSeries && onSeries.visible && i) {\n xOffset = (onSeries.pointXOffset || 0) + (onSeries.barW || 0) / 2;\n currentDataGrouping = onSeries.currentDataGrouping;\n lastX = (onData[i - 1].x +\n (currentDataGrouping ? currentDataGrouping.totalRange : 0)); // #2374\n // sort the data points\n stableSort(points, function (a, b) { return (a.x - b.x); });\n onKey = 'plot' + onKey[0].toUpperCase() + onKey.substr(1);\n while (i-- && points[cursor]) {\n leftPoint = onData[i];\n point = points[cursor];\n point.y = leftPoint.y;\n if (leftPoint.x <= point.x &&\n typeof leftPoint[onKey] !== 'undefined') {\n if (point.x <= lastX) { // #803\n point.plotY = leftPoint[onKey];\n // interpolate between points, #666\n if (leftPoint.x < point.x &&\n !step) {\n rightPoint = onData[i + 1];\n if (rightPoint &&\n typeof rightPoint[onKey] !== 'undefined') {\n // the distance ratio, between 0 and 1\n distanceRatio =\n (point.x - leftPoint.x) /\n (rightPoint.x - leftPoint.x);\n point.plotY +=\n distanceRatio *\n // the plotY distance\n (rightPoint[onKey] - leftPoint[onKey]);\n point.y +=\n distanceRatio *\n (rightPoint.y - leftPoint.y);\n }\n }\n }\n cursor--;\n i++; // check again for points in the same x position\n if (cursor < 0) {\n break;\n }\n }\n }\n }\n // Add plotY position and handle stacking\n points.forEach(function (point, i) {\n var stackIndex;\n point.plotX += xOffset; // #2049\n // Undefined plotY means the point is either on axis, outside series\n // range or hidden series. If the series is outside the range of the\n // x axis it should fall through with an undefined plotY, but then\n // we must remove the shapeArgs (#847). For inverted charts, we need\n // to calculate position anyway, because series.invertGroups is not\n // defined\n if (typeof point.plotY === 'undefined' || inverted) {\n if (point.plotX >= 0 &&\n point.plotX <= xAxis.len) {\n // We're inside xAxis range\n if (inverted) {\n point.plotY = xAxis.translate(point.x, 0, 1, 0, 1);\n point.plotX = defined(point.y) ?\n yAxis.translate(point.y, 0, 0, 0, 1) :\n 0;\n }\n else {\n point.plotY = (xAxis.opposite ? 0 : series.yAxis.len) +\n xAxis.offset; // For the windbarb demo\n }\n }\n else {\n point.shapeArgs = {}; // 847\n }\n }\n // if multiple flags appear at the same x, order them into a stack\n lastPoint = points[i - 1];\n if (lastPoint && lastPoint.plotX === point.plotX) {\n if (typeof lastPoint.stackIndex === 'undefined') {\n lastPoint.stackIndex = 0;\n }\n stackIndex = lastPoint.stackIndex + 1;\n }\n point.stackIndex = stackIndex; // #3639\n });\n this.onSeries = onSeries;\n }\n OnSeriesComposition.translate = translate;\n })(OnSeriesComposition || (OnSeriesComposition = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return OnSeriesComposition;\n });\n _registerModule(_modules, 'Series/Flags/FlagsSeries.js', [_modules['Series/Flags/FlagsPoint.js'], _modules['Series/Flags/FlagsSeriesDefaults.js'], _modules['Series/Flags/FlagsSymbols.js'], _modules['Core/Globals.js'], _modules['Series/OnSeriesComposition.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (FlagsPoint, FlagsSeriesDefaults, FlagsSymbols, H, OnSeriesComposition, R, SeriesRegistry, SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var noop = H.noop;\n var distribute = R.distribute;\n var Series = SeriesRegistry.series,\n ColumnSeries = SeriesRegistry.seriesTypes.column;\n var addEvent = U.addEvent,\n defined = U.defined,\n extend = U.extend,\n merge = U.merge,\n objectEach = U.objectEach,\n wrap = U.wrap;\n /* *\n *\n * Classes\n *\n * */\n /**\n * The Flags series.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.flags\n *\n * @augments Highcharts.Series\n */\n var FlagsSeries = /** @class */ (function (_super) {\n __extends(FlagsSeries, _super);\n function FlagsSeries() {\n /* *\n *\n * Static Properties\n *\n * */\n var _this = _super !== null && _super.apply(this,\n arguments) || this;\n /* *\n *\n * Properties\n *\n * */\n _this.data = void 0;\n _this.options = void 0;\n _this.points = void 0;\n return _this;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Disable animation, but keep clipping (#8546).\n * @private\n */\n FlagsSeries.prototype.animate = function (init) {\n if (init) {\n this.setClip();\n }\n };\n /**\n * Draw the markers.\n * @private\n */\n FlagsSeries.prototype.drawPoints = function () {\n var series = this,\n points = series.points,\n chart = series.chart,\n renderer = chart.renderer,\n inverted = chart.inverted,\n options = series.options,\n optionsY = options.y,\n yAxis = series.yAxis,\n boxesMap = {},\n boxes = [];\n var plotX,\n plotY,\n shape,\n i,\n point,\n graphic,\n stackIndex,\n anchorY,\n attribs,\n outsideRight,\n centered;\n i = points.length;\n while (i--) {\n point = points[i];\n outsideRight =\n (inverted ? point.plotY : point.plotX) >\n series.xAxis.len;\n plotX = point.plotX;\n stackIndex = point.stackIndex;\n shape = point.options.shape || options.shape;\n plotY = point.plotY;\n if (typeof plotY !== 'undefined') {\n plotY = point.plotY + optionsY -\n (typeof stackIndex !== 'undefined' &&\n (stackIndex * options.stackDistance));\n }\n // skip connectors for higher level stacked points\n point.anchorX = stackIndex ? void 0 : point.plotX;\n anchorY = stackIndex ? void 0 : point.plotY;\n centered = shape !== 'flag';\n graphic = point.graphic;\n // Only draw the point if y is defined and the flag is within\n // the visible area\n if (typeof plotY !== 'undefined' &&\n plotX >= 0 &&\n !outsideRight) {\n // #15384\n if (graphic && point.hasNewShapeType()) {\n graphic = graphic.destroy();\n }\n // Create the flag\n if (!graphic) {\n graphic = point.graphic = renderer.label('', null, null, shape, null, null, options.useHTML)\n .addClass('highcharts-point')\n .add(series.markerGroup);\n // Add reference to the point for tracker (#6303)\n if (point.graphic.div) {\n point.graphic.div.point = point;\n }\n graphic.isNew = true;\n }\n graphic.attr({\n align: centered ? 'center' : 'left',\n width: options.width,\n height: options.height,\n 'text-align': options.textAlign\n });\n if (!chart.styledMode) {\n graphic\n .attr(series.pointAttribs(point))\n .css(merge(options.style, point.style))\n .shadow(options.shadow);\n }\n if (plotX > 0) { // #3119\n plotX -= graphic.strokeWidth() % 2; // #4285\n }\n // Plant the flag\n attribs = {\n y: plotY,\n anchorY: anchorY\n };\n if (options.allowOverlapX) {\n attribs.x = plotX;\n attribs.anchorX = point.anchorX;\n }\n graphic.attr({\n text: point.options.title || options.title || 'A'\n })[graphic.isNew ? 'attr' : 'animate'](attribs);\n // Rig for the distribute function\n if (!options.allowOverlapX) {\n if (!boxesMap[point.plotX]) {\n boxesMap[point.plotX] = {\n align: centered ? 0.5 : 0,\n size: graphic.width,\n target: plotX,\n anchorX: plotX\n };\n }\n else {\n boxesMap[point.plotX].size = Math.max(boxesMap[point.plotX].size, graphic.width);\n }\n }\n // Set the tooltip anchor position\n point.tooltipPos = [\n plotX,\n plotY + yAxis.pos - chart.plotTop\n ]; // #6327\n }\n else if (graphic) {\n point.graphic = graphic.destroy();\n }\n }\n // Handle X-dimension overlapping\n if (!options.allowOverlapX) {\n var maxDistance_1 = 100;\n objectEach(boxesMap, function (box) {\n box.plotX = box.anchorX;\n boxes.push(box);\n maxDistance_1 = Math.max(box.size, maxDistance_1);\n });\n // If necessary (for overlapping or long labels) distribute it\n // depending on the label width or a hardcoded value, #16041.\n distribute(boxes, inverted ? yAxis.len : this.xAxis.len, maxDistance_1);\n for (var _i = 0, points_1 = points; _i < points_1.length; _i++) {\n var point_1 = points_1[_i];\n var plotX_1 = point_1.plotX,\n graphic_1 = point_1.graphic,\n box = graphic_1 && boxesMap[plotX_1];\n if (box && graphic_1) {\n // Hide flag when its box position is not specified\n // (#8573, #9299)\n if (!defined(box.pos)) {\n graphic_1.hide().isNew = true;\n }\n else {\n graphic_1[graphic_1.isNew ? 'attr' : 'animate']({\n x: box.pos + (box.align || 0) * box.size,\n anchorX: point_1.anchorX\n }).show().isNew = false;\n }\n }\n }\n }\n // Can be a mix of SVG and HTML and we need events for both (#6303)\n if (options.useHTML && series.markerGroup) {\n wrap(series.markerGroup, 'on', function (proceed) {\n return SVGElement.prototype.on.apply(\n // for HTML\n // eslint-disable-next-line no-invalid-this\n proceed.apply(this, [].slice.call(arguments, 1)), \n // and for SVG\n [].slice.call(arguments, 1));\n });\n }\n };\n /**\n * Extend the column trackers with listeners to expand and contract\n * stacks.\n * @private\n */\n FlagsSeries.prototype.drawTracker = function () {\n var series = this,\n points = series.points;\n _super.prototype.drawTracker.call(this);\n var _loop_1 = function (point) {\n var graphic = point.graphic;\n if (graphic) {\n if (point.unbindMouseOver) {\n point.unbindMouseOver();\n }\n point.unbindMouseOver = addEvent(graphic.element, 'mouseover', function () {\n // Raise this point\n if (point.stackIndex > 0 &&\n !point.raised) {\n point._y = graphic.y;\n graphic.attr({\n y: point._y - 8\n });\n point.raised = true;\n }\n // Revert other raised points\n for (var _i = 0, points_3 = points; _i < points_3.length; _i++) {\n var otherPoint = points_3[_i];\n if (otherPoint !== point &&\n otherPoint.raised &&\n otherPoint.graphic) {\n otherPoint.graphic.attr({\n y: otherPoint._y\n });\n otherPoint.raised = false;\n }\n }\n });\n }\n };\n /* *\n * Bring each stacked flag up on mouse over, this allows readability\n * of vertically stacked elements as well as tight points on the x\n * axis. #1924.\n */\n for (var _i = 0, points_2 = points; _i < points_2.length; _i++) {\n var point = points_2[_i];\n _loop_1(point);\n }\n };\n /**\n * Get presentational attributes\n * @private\n */\n FlagsSeries.prototype.pointAttribs = function (point, state) {\n var options = this.options,\n color = (point && point.color) || this.color;\n var lineColor = options.lineColor,\n lineWidth = (point && point.lineWidth),\n fill = (point && point.fillColor) || options.fillColor;\n if (state) {\n fill = options.states[state].fillColor;\n lineColor = options.states[state].lineColor;\n lineWidth = options.states[state].lineWidth;\n }\n return {\n fill: fill || color,\n stroke: lineColor || color,\n 'stroke-width': lineWidth || options.lineWidth || 0\n };\n };\n /**\n * @private\n */\n FlagsSeries.prototype.setClip = function () {\n Series.prototype.setClip.apply(this, arguments);\n if (this.options.clip !== false &&\n this.sharedClipKey &&\n this.markerGroup) {\n this.markerGroup.clip(this.chart.sharedClips[this.sharedClipKey]);\n }\n };\n FlagsSeries.compose = FlagsSymbols.compose;\n FlagsSeries.defaultOptions = merge(ColumnSeries.defaultOptions, FlagsSeriesDefaults);\n return FlagsSeries;\n }(ColumnSeries));\n OnSeriesComposition.compose(FlagsSeries);\n extend(FlagsSeries.prototype, {\n allowDG: false,\n forceCrop: true,\n invertible: false,\n noSharedTooltip: true,\n pointClass: FlagsPoint,\n sorted: false,\n takeOrdinalPosition: false,\n trackerGroups: ['markerGroup'],\n buildKDTree: noop,\n /**\n * Inherit the initialization from base Series.\n * @private\n */\n init: Series.prototype.init,\n /**\n * Don't invert the flag marker group (#4960).\n * @private\n */\n invertGroups: noop\n });\n SeriesRegistry.registerSeriesType('flags', FlagsSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @typedef {\"circlepin\"|\"flag\"|\"squarepin\"} Highcharts.FlagsShapeValue\n */\n ''; // detach doclets above\n\n return FlagsSeries;\n });\n _registerModule(_modules, 'Core/Chart/StockChart.js', [_modules['Core/Axis/Axis.js'], _modules['Core/Chart/Chart.js'], _modules['Core/FormatUtilities.js'], _modules['Core/Defaults.js'], _modules['Stock/Navigator/NavigatorDefaults.js'], _modules['Stock/RangeSelector/RangeSelectorDefaults.js'], _modules['Stock/Scrollbar/ScrollbarDefaults.js'], _modules['Core/Series/Series.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Utilities.js']], function (Axis, Chart, F, D, NavigatorDefaults, RangeSelectorDefaults, ScrollbarDefaults, Series, SVGRenderer, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d,\n b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d,\n b) { d.__proto__ = b; }) ||\n function (d,\n 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 })();\n var format = F.format;\n var getOptions = D.getOptions;\n var addEvent = U.addEvent,\n clamp = U.clamp,\n defined = U.defined,\n extend = U.extend,\n find = U.find,\n isNumber = U.isNumber,\n isString = U.isString,\n merge = U.merge,\n pick = U.pick,\n splat = U.splat;\n /* *\n *\n * Class\n *\n * */\n /**\n * Stock-optimized chart. Use {@link Highcharts.Chart|Chart} for common charts.\n *\n * @requires modules/stock\n *\n * @class\n * @name Highcharts.StockChart\n * @extends Highcharts.Chart\n */\n var StockChart = /** @class */ (function (_super) {\n __extends(StockChart, _super);\n function StockChart() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n /**\n * Initializes the chart. The constructor's arguments are passed on\n * directly.\n *\n * @function Highcharts.StockChart#init\n *\n * @param {Highcharts.Options} userOptions\n * Custom options.\n *\n * @param {Function} [callback]\n * Function to run when the chart has loaded and and all external\n * images are loaded.\n *\n *\n * @emits Highcharts.StockChart#event:init\n * @emits Highcharts.StockChart#event:afterInit\n */\n StockChart.prototype.init = function (userOptions, callback) {\n var defaultOptions = getOptions(),\n xAxisOptions = userOptions.xAxis,\n yAxisOptions = userOptions.yAxis, \n // Always disable startOnTick:true on the main axis when the\n // navigator is enabled (#1090)\n navigatorEnabled = pick(userOptions.navigator && userOptions.navigator.enabled,\n NavigatorDefaults.enabled,\n true);\n // Avoid doing these twice\n userOptions.xAxis = userOptions.yAxis = void 0;\n var options = merge({\n chart: {\n panning: {\n enabled: true,\n type: 'x'\n },\n zooming: {\n pinchType: 'x'\n }\n },\n navigator: {\n enabled: navigatorEnabled\n },\n scrollbar: {\n // #4988 - check if setOptions was called\n enabled: pick(ScrollbarDefaults.enabled,\n true)\n },\n rangeSelector: {\n // #4988 - check if setOptions was called\n enabled: pick(RangeSelectorDefaults.rangeSelector.enabled,\n true)\n },\n title: {\n text: null\n },\n tooltip: {\n split: pick(defaultOptions.tooltip.split,\n true),\n crosshairs: true\n },\n legend: {\n enabled: false\n }\n },\n userOptions, // user's options\n {\n isStock: true // internal flag\n });\n userOptions.xAxis = xAxisOptions;\n userOptions.yAxis = yAxisOptions;\n // apply X axis options to both single and multi y axes\n options.xAxis = splat(userOptions.xAxis || {}).map(function (xAxisOptions, i) {\n return merge(getDefaultAxisOptions('xAxis', xAxisOptions), defaultOptions.xAxis, // #3802\n // #7690\n defaultOptions.xAxis && defaultOptions.xAxis[i], xAxisOptions, // user options\n getForcedAxisOptions('xAxis', userOptions));\n });\n // apply Y axis options to both single and multi y axes\n options.yAxis = splat(userOptions.yAxis || {}).map(function (yAxisOptions, i) {\n return merge(getDefaultAxisOptions('yAxis', yAxisOptions), defaultOptions.yAxis, // #3802\n // #7690\n defaultOptions.yAxis && defaultOptions.yAxis[i], yAxisOptions // user options\n );\n });\n _super.prototype.init.call(this, options, callback);\n };\n /**\n * Factory for creating different axis types.\n * Extended to add stock defaults.\n *\n * @private\n * @function Highcharts.StockChart#createAxis\n * @param {string} type\n * An axis type.\n * @param {Chart.CreateAxisOptionsObject} options\n * The axis creation options.\n */\n StockChart.prototype.createAxis = function (type, options) {\n options.axis = merge(getDefaultAxisOptions(type, options.axis), options.axis, getForcedAxisOptions(type, this.userOptions));\n return _super.prototype.createAxis.call(this, type, options);\n };\n return StockChart;\n }(Chart));\n /* eslint-disable no-invalid-this, valid-jsdoc */\n (function (StockChart) {\n /**\n * Factory function for creating new stock charts. Creates a new\n * {@link Highcharts.StockChart|StockChart} object with different default\n * options than the basic Chart.\n *\n * @example\n * let chart = Highcharts.stockChart('container', {\n * series: [{\n * data: [1, 2, 3, 4, 5, 6, 7, 8, 9],\n * pointInterval: 24 * 60 * 60 * 1000\n * }]\n * });\n *\n * @function Highcharts.stockChart\n *\n * @param {string|Highcharts.HTMLDOMElement} [renderTo]\n * The DOM element to render to, or its id.\n *\n * @param {Highcharts.Options} options\n * The chart options structure as described in the\n * [options reference](https://api.highcharts.com/highstock).\n *\n * @param {Highcharts.ChartCallbackFunction} [callback]\n * A function to execute when the chart object is finished loading\n * and rendering. In most cases the chart is built in one thread,\n * but in Internet Explorer version 8 or less the chart is sometimes\n * initialized before the document is ready, and in these cases the\n * chart object will not be finished synchronously. As a\n * consequence, code that relies on the newly built Chart object\n * should always run in the callback. Defining a\n * [chart.events.load](https://api.highcharts.com/highstock/chart.events.load)\n * handler is equivalent.\n *\n * @return {Highcharts.StockChart}\n * The chart object.\n */\n function stockChart(a, b, c) {\n return new StockChart(a, b, c);\n }\n StockChart.stockChart = stockChart;\n })(StockChart || (StockChart = {}));\n /**\n * Get stock-specific default axis options.\n *\n * @private\n * @function getDefaultAxisOptions\n */\n function getDefaultAxisOptions(type, options) {\n if (type === 'xAxis') {\n return {\n minPadding: 0,\n maxPadding: 0,\n overscroll: 0,\n ordinal: true,\n title: {\n text: null\n },\n labels: {\n overflow: 'justify'\n },\n showLastLabel: true\n };\n }\n if (type === 'yAxis') {\n return {\n labels: {\n y: -2\n },\n opposite: pick(options.opposite, true),\n showLastLabel: !!(\n // #6104, show last label by default for category axes\n options.categories ||\n options.type === 'category'),\n title: {\n text: null\n }\n };\n }\n return {};\n }\n /**\n * Get stock-specific forced axis options.\n *\n * @private\n * @function getForcedAxisOptions\n */\n function getForcedAxisOptions(type, chartOptions) {\n if (type === 'xAxis') {\n // Always disable startOnTick:true on the main axis when the navigator\n // is enabled (#1090)\n var navigatorEnabled = pick(chartOptions.navigator && chartOptions.navigator.enabled,\n NavigatorDefaults.enabled,\n true);\n var axisOptions = {\n type: 'datetime',\n categories: void 0\n };\n if (navigatorEnabled) {\n axisOptions.startOnTick = false;\n axisOptions.endOnTick = false;\n }\n return axisOptions;\n }\n return {};\n }\n /* *\n *\n * Compositions\n *\n * */\n // Handle som Stock-specific series defaults, override the plotOptions before\n // series options are handled.\n addEvent(Series, 'setOptions', function (e) {\n var overrides;\n if (this.chart.options.isStock) {\n if (this.is('column') || this.is('columnrange')) {\n overrides = {\n borderWidth: 0,\n shadow: false\n };\n }\n else if (!this.is('scatter') && !this.is('sma')) {\n overrides = {\n marker: {\n enabled: false,\n radius: 2\n }\n };\n }\n if (overrides) {\n e.plotOptions[this.type] = merge(e.plotOptions[this.type], overrides);\n }\n }\n });\n // Override the automatic label alignment so that the first Y axis' labels\n // are drawn on top of the grid line, and subsequent axes are drawn outside\n addEvent(Axis, 'autoLabelAlign', function (e) {\n var chart = this.chart,\n options = this.options,\n panes = chart._labelPanes = chart._labelPanes || {},\n key,\n labelOptions = this.options.labels;\n if (this.chart.options.isStock && this.coll === 'yAxis') {\n key = options.top + ',' + options.height;\n // do it only for the first Y axis of each pane\n if (!panes[key] && labelOptions.enabled) {\n if (labelOptions.x === 15) { // default\n labelOptions.x = 0;\n }\n if (typeof labelOptions.align === 'undefined') {\n labelOptions.align = 'right';\n }\n panes[key] = this;\n e.align = 'right';\n e.preventDefault();\n }\n }\n });\n // Clear axis from label panes (#6071)\n addEvent(Axis, 'destroy', function () {\n var chart = this.chart, key = this.options && (this.options.top + ',' + this.options.height);\n if (key && chart._labelPanes && chart._labelPanes[key] === this) {\n delete chart._labelPanes[key];\n }\n });\n // Override getPlotLinePath to allow for multipane charts\n addEvent(Axis, 'getPlotLinePath', function (e) {\n var axis = this,\n series = (this.isLinked && !this.series ?\n this.linkedParent.series :\n this.series),\n chart = axis.chart,\n renderer = chart.renderer,\n axisLeft = axis.left,\n axisTop = axis.top,\n x1,\n y1,\n x2,\n y2,\n result = [],\n axes = [], // #3416 need a default array\n axes2,\n uniqueAxes,\n translatedValue = e.translatedValue,\n value = e.value,\n force = e.force,\n transVal;\n /**\n * Return the other axis based on either the axis option or on related\n * series.\n * @private\n */\n function getAxis(coll) {\n var otherColl = coll === 'xAxis' ? 'yAxis' : 'xAxis',\n opt = axis.options[otherColl];\n // Other axis indexed by number\n if (isNumber(opt)) {\n return [chart[otherColl][opt]];\n }\n // Other axis indexed by id (like navigator)\n if (isString(opt)) {\n return [chart.get(opt)];\n }\n // Auto detect based on existing series\n return series.map(function (s) {\n return s[otherColl];\n });\n }\n if ( // For stock chart, by default render paths across the panes\n // except the case when `acrossPanes` is disabled by user (#6644)\n (chart.options.isStock && e.acrossPanes !== false) &&\n // Ignore in case of colorAxis or zAxis. #3360, #3524, #6720\n axis.coll === 'xAxis' || axis.coll === 'yAxis') {\n e.preventDefault();\n // Get the related axes based on series\n axes = getAxis(axis.coll);\n // Get the related axes based options.*Axis setting #2810\n axes2 = (axis.isXAxis ? chart.yAxis : chart.xAxis);\n axes2.forEach(function (A) {\n if (defined(A.options.id) ?\n A.options.id.indexOf('navigator') === -1 :\n true) {\n var a = (A.isXAxis ? 'yAxis' : 'xAxis'),\n rax = (defined(A.options[a]) ?\n chart[a][A.options[a]] :\n chart[a][0]);\n if (axis === rax) {\n axes.push(A);\n }\n }\n });\n // Remove duplicates in the axes array. If there are no axes in the axes\n // array, we are adding an axis without data, so we need to populate\n // this with grid lines (#2796).\n uniqueAxes = axes.length ?\n [] :\n [axis.isXAxis ? chart.yAxis[0] : chart.xAxis[0]]; // #3742\n axes.forEach(function (axis2) {\n if (uniqueAxes.indexOf(axis2) === -1 &&\n // Do not draw on axis which overlap completely. #5424\n !find(uniqueAxes, function (unique) {\n return unique.pos === axis2.pos && unique.len === axis2.len;\n })) {\n uniqueAxes.push(axis2);\n }\n });\n transVal = pick(translatedValue, axis.translate(value, void 0, void 0, e.old));\n if (isNumber(transVal)) {\n if (axis.horiz) {\n uniqueAxes.forEach(function (axis2) {\n var skip;\n y1 = axis2.pos;\n y2 = y1 + axis2.len;\n x1 = x2 = Math.round(transVal + axis.transB);\n // outside plot area\n if (force !== 'pass' &&\n (x1 < axisLeft || x1 > axisLeft + axis.width)) {\n if (force) {\n x1 = x2 = clamp(x1, axisLeft, axisLeft + axis.width);\n }\n else {\n skip = true;\n }\n }\n if (!skip) {\n result.push(['M', x1, y1], ['L', x2, y2]);\n }\n });\n }\n else {\n uniqueAxes.forEach(function (axis2) {\n var skip;\n x1 = axis2.pos;\n x2 = x1 + axis2.len;\n y1 = y2 = Math.round(axisTop + axis.height - transVal);\n // outside plot area\n if (force !== 'pass' &&\n (y1 < axisTop || y1 > axisTop + axis.height)) {\n if (force) {\n y1 = y2 = clamp(y1, axisTop, axisTop + axis.height);\n }\n else {\n skip = true;\n }\n }\n if (!skip) {\n result.push(['M', x1, y1], ['L', x2, y2]);\n }\n });\n }\n }\n e.path = result.length > 0 ?\n renderer.crispPolyLine(result, e.lineWidth || 1) :\n // #3557 getPlotLinePath in regular Highcharts also returns null\n null;\n }\n });\n /**\n * Function to crisp a line with multiple segments\n *\n * @private\n * @function Highcharts.SVGRenderer#crispPolyLine\n */\n SVGRenderer.prototype.crispPolyLine = function (points, width) {\n // points format: [['M', 0, 0], ['L', 100, 0]]\n // normalize to a crisp line\n for (var i = 0; i < points.length; i = i + 2) {\n var start = points[i],\n end = points[i + 1];\n if (start[1] === end[1]) {\n // Substract due to #1129. Now bottom and left axis gridlines behave\n // the same.\n start[1] = end[1] =\n Math.round(start[1]) - (width % 2 / 2);\n }\n if (start[2] === end[2]) {\n start[2] = end[2] =\n Math.round(start[2]) + (width % 2 / 2);\n }\n }\n return points;\n };\n // Wrapper to hide the label\n addEvent(Axis, 'afterHideCrosshair', function () {\n if (this.crossLabel) {\n this.crossLabel = this.crossLabel.hide();\n }\n });\n // Extend crosshairs to also draw the label\n addEvent(Axis, 'afterDrawCrosshair', function (event) {\n // Check if the label has to be drawn\n if (!this.crosshair ||\n !this.crosshair.label ||\n !this.crosshair.label.enabled ||\n !this.cross ||\n !isNumber(this.min) ||\n !isNumber(this.max)) {\n return;\n }\n var chart = this.chart, log = this.logarithmic, options = this.crosshair.label, // the label's options\n horiz = this.horiz, // axis orientation\n opposite = this.opposite, // axis position\n left = this.left, // left position\n top = this.top, // top position\n crossLabel = this.crossLabel, // the svgElement\n posx, posy, crossBox, formatOption = options.format, formatFormat = '', limit, align, tickInside = this.options.tickPosition === 'inside', snap = this.crosshair.snap !== false, offset = 0, \n // Use last available event (#5287)\n e = event.e || (this.cross && this.cross.e), point = event.point, min = this.min, max = this.max;\n if (log) {\n min = log.lin2log(min);\n max = log.lin2log(max);\n }\n align = (horiz ? 'center' : opposite ?\n (this.labelAlign === 'right' ? 'right' : 'left') :\n (this.labelAlign === 'left' ? 'left' : 'center'));\n // If the label does not exist yet, create it.\n if (!crossLabel) {\n crossLabel = this.crossLabel = chart.renderer\n .label('', 0, void 0, options.shape || 'callout')\n .addClass('highcharts-crosshair-label highcharts-color-' + (point && point.series ?\n point.series.colorIndex :\n this.series[0] && this.series[0].colorIndex))\n .attr({\n align: options.align || align,\n padding: pick(options.padding, 8),\n r: pick(options.borderRadius, 3),\n zIndex: 2\n })\n .add(this.labelGroup);\n // Presentational\n if (!chart.styledMode) {\n crossLabel\n .attr({\n fill: options.backgroundColor ||\n point && point.series && point.series.color || // #14888\n \"#666666\" /* Palette.neutralColor60 */,\n stroke: options.borderColor || '',\n 'stroke-width': options.borderWidth || 0\n })\n .css(extend({\n color: \"#ffffff\" /* Palette.backgroundColor */,\n fontWeight: 'normal',\n fontSize: '11px',\n textAlign: 'center'\n }, options.style || {}));\n }\n }\n if (horiz) {\n posx = snap ? (point.plotX || 0) + left : e.chartX;\n posy = top + (opposite ? 0 : this.height);\n }\n else {\n posx = opposite ? this.width + left : 0;\n posy = snap ? (point.plotY || 0) + top : e.chartY;\n }\n if (!formatOption && !options.formatter) {\n if (this.dateTime) {\n formatFormat = '%b %d, %Y';\n }\n formatOption =\n '{value' + (formatFormat ? ':' + formatFormat : '') + '}';\n }\n // Show the label\n var value = snap ?\n (this.isXAxis ? point.x : point.y) :\n this.toValue(horiz ? e.chartX : e.chartY);\n // Crosshair should be rendered within Axis range (#7219). Also, the point\n // of currentPriceIndicator should be inside the plot area, #14879.\n var isInside = point && point.series ?\n point.series.isPointInside(point) :\n (isNumber(value) && value > min && value < max);\n var text = '';\n if (formatOption) {\n text = format(formatOption, { value: value }, chart);\n }\n else if (options.formatter && isNumber(value)) {\n text = options.formatter.call(this, value);\n }\n crossLabel.attr({\n text: text,\n x: posx,\n y: posy,\n visibility: isInside ? 'inherit' : 'hidden'\n });\n crossBox = crossLabel.getBBox();\n // now it is placed we can correct its position\n if (isNumber(crossLabel.y)) {\n if (horiz) {\n if ((tickInside && !opposite) || (!tickInside && opposite)) {\n posy = crossLabel.y - crossBox.height;\n }\n }\n else {\n posy = crossLabel.y - (crossBox.height / 2);\n }\n }\n // check the edges\n if (horiz) {\n limit = {\n left: left - crossBox.x,\n right: left + this.width - crossBox.x\n };\n }\n else {\n limit = {\n left: this.labelAlign === 'left' ? left : 0,\n right: this.labelAlign === 'right' ?\n left + this.width :\n chart.chartWidth\n };\n }\n // left edge\n if (crossLabel.translateX < limit.left) {\n offset = limit.left - crossLabel.translateX;\n }\n // right edge\n if (crossLabel.translateX + crossBox.width >= limit.right) {\n offset = -(crossLabel.translateX + crossBox.width - limit.right);\n }\n // show the crosslabel\n crossLabel.attr({\n x: posx + offset,\n y: posy,\n // First set x and y, then anchorX and anchorY, when box is actually\n // calculated, #5702\n anchorX: horiz ?\n posx :\n (this.opposite ? 0 : chart.chartWidth),\n anchorY: horiz ?\n (this.opposite ? chart.chartHeight : 0) :\n posy + crossBox.height / 2\n });\n });\n /**\n * Based on the data grouping options decides whether\n * the data should be cropped while processing.\n *\n * @ignore\n * @function Highcharts.Series#forceCropping\n */\n Series.prototype.forceCropping = function () {\n var chart = this.chart,\n options = this.options,\n dataGroupingOptions = options.dataGrouping,\n groupingEnabled = this.allowDG !== false && dataGroupingOptions &&\n pick(dataGroupingOptions.enabled,\n chart.options.isStock);\n return groupingEnabled;\n };\n addEvent(Chart, 'update', function (e) {\n var options = e.options;\n // Use case: enabling scrollbar from a disabled state.\n // Scrollbar needs to be initialized from a controller, Navigator in this\n // case (#6615)\n if ('scrollbar' in options && this.navigator) {\n merge(true, this.options.scrollbar, options.scrollbar);\n this.navigator.update({});\n delete options.scrollbar;\n }\n });\n /* *\n *\n * Default Export\n *\n * */\n\n return StockChart;\n });\n _registerModule(_modules, 'masters/modules/stock.src.js', [_modules['Core/Globals.js'], _modules['Series/DataModifyComposition.js'], _modules['Stock/Navigator/Navigator.js'], _modules['Stock/RangeSelector/RangeSelector.js'], _modules['Stock/Scrollbar/Scrollbar.js'], _modules['Core/Axis/OrdinalAxis.js'], _modules['Series/OHLC/OHLCSeries.js'], _modules['Series/Flags/FlagsSeries.js'], _modules['Core/Chart/StockChart.js']], function (Highcharts, DataModifyComposition, Navigator, RangeSelector, Scrollbar, OrdinalAxis, OHLCSeries, FlagsSeries, StockChart) {\n\n var G = Highcharts;\n // Classes\n G.Navigator = Navigator;\n G.RangeSelector = RangeSelector;\n G.Scrollbar = Scrollbar;\n G.StockChart = G.stockChart = StockChart.stockChart;\n // Compositions\n DataModifyComposition.compose(G.Series, G.Axis, G.Point);\n FlagsSeries.compose(G.Renderer);\n Navigator.compose(G.Axis, G.Chart, G.Series);\n OHLCSeries.compose(G.Series);\n OrdinalAxis.compose(G.Axis, G.Series, G.Chart);\n RangeSelector.compose(G.Axis, G.Chart);\n Scrollbar.compose(G.Axis);\n\n });\n _registerModule(_modules, 'masters/highstock.src.js', [_modules['masters/highcharts.src.js']], function (Highcharts) {\n\n Highcharts.product = 'Highstock';\n\n return Highcharts;\n });\n _modules['masters/highstock.src.js']._modules = _modules;\n return _modules['masters/highstock.src.js'];\n}));","//! moment.js\n//! version : 2.29.4\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 if (m._isValid == null) {\n var flags = getParsingFlags(m),\n parsedParts = some.call(flags.parsedDateParts, function (i) {\n return i != null;\n }),\n isNowValid =\n !isNaN(m._d.getTime()) &&\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\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 }\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\n function addUnitAlias(unit, shorthand) {\n var lowerCase = unit.toLowerCase();\n aliases[lowerCase] = aliases[lowerCase + 's'] = aliases[shorthand] = unit;\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\n function addUnitPriority(unit, priority) {\n priorities[unit] = priority;\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 function isLeapYear(year) {\n return (year % 4 === 0 && year % 100 !== 0) || year % 400 === 0;\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 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 return mom.isValid()\n ? mom._d['get' + (mom._isUTC ? 'UTC' : '') + unit]()\n : NaN;\n }\n\n function set$1(mom, unit, value) {\n if (mom.isValid() && !isNaN(value)) {\n if (\n unit === 'FullYear' &&\n isLeapYear(mom.year()) &&\n mom.month() === 1 &&\n mom.date() === 29\n ) {\n value = toInt(value);\n mom._d['set' + (mom._isUTC ? 'UTC' : '') + unit](\n value,\n mom.month(),\n daysInMonth(value, mom.month())\n );\n } else {\n mom._d['set' + (mom._isUTC ? 'UTC' : '') + unit](value);\n }\n }\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 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 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 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 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 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 // ALIASES\n\n addUnitAlias('month', 'M');\n\n // PRIORITY\n\n addUnitPriority('month', 8);\n\n // PARSING\n\n addRegexToken('M', match1to2);\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 var dayOfMonth;\n\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 dayOfMonth = Math.min(mom.date(), daysInMonth(mom.year(), value));\n mom._d['set' + (mom._isUTC ? 'UTC' : '') + 'Month'](value, dayOfMonth);\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 for (i = 0; i < 12; i++) {\n // make the regex if we don't have it already\n mom = createUTC([2000, i]);\n shortPieces.push(this.monthsShort(mom, ''));\n longPieces.push(this.months(mom, ''));\n mixedPieces.push(this.months(mom, ''));\n mixedPieces.push(this.monthsShort(mom, ''));\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 for (i = 0; i < 12; i++) {\n shortPieces[i] = regexEscape(shortPieces[i]);\n longPieces[i] = regexEscape(longPieces[i]);\n }\n for (i = 0; i < 24; i++) {\n mixedPieces[i] = regexEscape(mixedPieces[i]);\n }\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 // 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 // ALIASES\n\n addUnitAlias('year', 'y');\n\n // PRIORITIES\n\n addUnitPriority('year', 1);\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 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 // ALIASES\n\n addUnitAlias('week', 'w');\n addUnitAlias('isoWeek', 'W');\n\n // PRIORITIES\n\n addUnitPriority('week', 5);\n addUnitPriority('isoWeek', 5);\n\n // PARSING\n\n addRegexToken('w', match1to2);\n addRegexToken('ww', match1to2, match2);\n addRegexToken('W', match1to2);\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 // ALIASES\n\n addUnitAlias('day', 'd');\n addUnitAlias('weekday', 'e');\n addUnitAlias('isoWeekday', 'E');\n\n // PRIORITY\n addUnitPriority('day', 11);\n addUnitPriority('weekday', 11);\n addUnitPriority('isoWeekday', 11);\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 var day = this._isUTC ? this._d.getUTCDay() : this._d.getDay();\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 // ALIASES\n\n addUnitAlias('hour', 'h');\n\n // PRIORITY\n addUnitPriority('hour', 13);\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);\n addRegexToken('h', match1to2);\n addRegexToken('k', match1to2);\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 return name.match('^[^/\\\\\\\\]*$') != null;\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 eras = this.eras();\n\n for (i = 0, l = eras.length; i < l; ++i) {\n namePieces.push(regexEscape(eras[i].name));\n abbrPieces.push(regexEscape(eras[i].abbr));\n narrowPieces.push(regexEscape(eras[i].narrow));\n\n mixedPieces.push(regexEscape(eras[i].name));\n mixedPieces.push(regexEscape(eras[i].abbr));\n mixedPieces.push(regexEscape(eras[i].narrow));\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 addUnitAlias('weekYear', 'gg');\n addUnitAlias('isoWeekYear', 'GG');\n\n // PRIORITY\n\n addUnitPriority('weekYear', 1);\n addUnitPriority('isoWeekYear', 1);\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(),\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 // ALIASES\n\n addUnitAlias('quarter', 'Q');\n\n // PRIORITY\n\n addUnitPriority('quarter', 7);\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 // ALIASES\n\n addUnitAlias('date', 'D');\n\n // PRIORITY\n addUnitPriority('date', 9);\n\n // PARSING\n\n addRegexToken('D', match1to2);\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 // ALIASES\n\n addUnitAlias('dayOfYear', 'DDD');\n\n // PRIORITY\n addUnitPriority('dayOfYear', 4);\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 // ALIASES\n\n addUnitAlias('minute', 'm');\n\n // PRIORITY\n\n addUnitPriority('minute', 14);\n\n // PARSING\n\n addRegexToken('m', match1to2);\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 // ALIASES\n\n addUnitAlias('second', 's');\n\n // PRIORITY\n\n addUnitPriority('second', 15);\n\n // PARSING\n\n addRegexToken('s', match1to2);\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 // ALIASES\n\n addUnitAlias('millisecond', 'ms');\n\n // PRIORITY\n\n addUnitPriority('millisecond', 16);\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 // TODO: Use this.as('ms')?\n function valueOf$1() {\n if (!this.isValid()) {\n return NaN;\n }\n return (\n this._milliseconds +\n this._days * 864e5 +\n (this._months % 12) * 2592e6 +\n toInt(this._months / 12) * 31536e6\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\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.29.4';\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","/**\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","/**\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= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\n\tfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n\tfunction _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\n\tfunction _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\n\tvar KEYCODE_UP = 38;\n\tvar KEYCODE_DOWN = 40;\n\tvar IS_BROWSER = typeof document != 'undefined';\n\tvar RE_NUMBER = /^[+-]?((\\.\\d+)|(\\d+(\\.\\d+)?))$/;\n\tvar RE_INCOMPLETE_NUMBER = /^([+-]|\\.0*|[+-]\\.0*|[+-]?\\d+\\.)?$/;\n\n\tfunction addClass(element, className) {\n\t if (element.classList) {\n\t return element.classList.add(className);\n\t }\n\t if (!element.className.search(new RegExp(\"\\\\b\" + className + \"\\\\b\"))) {\n\t element.className = \" \" + className;\n\t }\n\t}\n\n\tfunction removeClass(element, className) {\n\t if (element.className) {\n\t if (element.classList) {\n\t return element.classList.remove(className);\n\t }\n\n\t element.className = element.className.replace(new RegExp(\"\\\\b\" + className + \"\\\\b\", \"g\"), \"\");\n\t }\n\t}\n\n\tfunction access(object, prop, defaultValue) {\n\t var result = object[prop];\n\t if (typeof result == \"function\") {\n\t for (var _len = arguments.length, args = Array(_len > 3 ? _len - 3 : 0), _key = 3; _key < _len; _key++) {\n\t args[_key - 3] = arguments[_key];\n\t }\n\n\t result = result.apply(undefined, args);\n\t }\n\t return result === undefined ? defaultValue : result;\n\t}\n\n\tvar NumericInput = function (_Component) {\n\t _inherits(NumericInput, _Component);\n\n\t function NumericInput() {\n\t var _ref;\n\n\t _classCallCheck(this, NumericInput);\n\n\t for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n\t args[_key2] = arguments[_key2];\n\t }\n\n\t var _this = _possibleConstructorReturn(this, (_ref = NumericInput.__proto__ || Object.getPrototypeOf(NumericInput)).call.apply(_ref, [this].concat(args)));\n\n\t _this._isStrict = !!_this.props.strict;\n\n\t _this.state = _extends({\n\t btnDownHover: false,\n\t btnDownActive: false,\n\t btnUpHover: false,\n\t btnUpActive: false,\n\t stringValue: \"\"\n\t }, _this._propsToState(_this.props));\n\t _this.stop = _this.stop.bind(_this);\n\t _this.onTouchEnd = _this.onTouchEnd.bind(_this);\n\t _this.refsInput = {};\n\t _this.refsWrapper = {};\n\t return _this;\n\t }\n\n\t _createClass(NumericInput, [{\n\t key: '_propsToState',\n\t value: function _propsToState(props) {\n\t var out = {};\n\n\t if (props.hasOwnProperty(\"value\")) {\n\t out.stringValue = String(props.value || props.value === 0 ? props.value : '').trim();\n\n\t out.value = out.stringValue !== '' ? this._parse(props.value) : null;\n\t } else if (!this._isMounted && props.hasOwnProperty(\"defaultValue\")) {\n\t out.stringValue = String(props.defaultValue || props.defaultValue === 0 ? props.defaultValue : '').trim();\n\n\t out.value = props.defaultValue !== '' ? this._parse(props.defaultValue) : null;\n\t }\n\n\t return out;\n\t }\n\t }, {\n\t key: 'componentWillReceiveProps',\n\t value: function componentWillReceiveProps(props) {\n\t var _this2 = this;\n\n\t this._isStrict = !!props.strict;\n\t var nextState = this._propsToState(props);\n\t if (Object.keys(nextState).length) {\n\t this._ignoreValueChange = true;\n\t this.setState(nextState, function () {\n\t _this2._ignoreValueChange = false;\n\t });\n\t }\n\t }\n\t }, {\n\t key: 'componentWillUpdate',\n\t value: function componentWillUpdate() {\n\t this.saveSelection();\n\t }\n\t }, {\n\t key: 'componentDidUpdate',\n\t value: function componentDidUpdate(prevProps, prevState) {\n\t if (!this._ignoreValueChange && prevState.value !== this.state.value && (!isNaN(this.state.value) || this.state.value === null)) {\n\t this._invokeEventCallback(\"onChange\", this.state.value, this.refsInput.value, this.refsInput);\n\t }\n\n\t if (this._inputFocus) {\n\t this.refsInput.focus();\n\n\t if (this.state.selectionStart || this.state.selectionStart === 0) {\n\t this.refsInput.selectionStart = this.state.selectionStart;\n\t }\n\n\t if (this.state.selectionEnd || this.state.selectionEnd === 0) {\n\t this.refsInput.selectionEnd = this.state.selectionEnd;\n\t }\n\t }\n\n\t this.checkValidity();\n\t }\n\t }, {\n\t key: 'componentWillUnmount',\n\t value: function componentWillUnmount() {\n\t this._isMounted = false;\n\t this.stop();\n\t }\n\t }, {\n\t key: 'componentDidMount',\n\t value: function componentDidMount() {\n\t var _this3 = this;\n\n\t this._isMounted = true;\n\t this.refsInput.getValueAsNumber = function () {\n\t return _this3.state.value || 0;\n\t };\n\n\t this.refsInput.setValue = function (value) {\n\t _this3.setState({\n\t value: _this3._parse(value),\n\t stringValue: value\n\t });\n\t };\n\n\t if (!this._inputFocus && IS_BROWSER && document.activeElement === this.refsInput) {\n\t this._inputFocus = true;\n\t this.refsInput.focus();\n\t this._invokeEventCallback(\"onFocus\", {\n\t target: this.refsInput,\n\t type: \"focus\"\n\t });\n\t }\n\n\t this.checkValidity();\n\t }\n\t }, {\n\t key: 'saveSelection',\n\t value: function saveSelection() {\n\t this.state.selectionStart = this.refsInput.selectionStart;\n\t this.state.selectionEnd = this.refsInput.selectionEnd;\n\t }\n\t }, {\n\t key: 'checkValidity',\n\t value: function checkValidity() {\n\t var valid = void 0,\n\t validationError = \"\";\n\n\t var supportsValidation = !!this.refsInput.checkValidity;\n\n\t var noValidate = !!(this.props.noValidate && this.props.noValidate != \"false\");\n\n\t this.refsInput.noValidate = noValidate;\n\n\t valid = noValidate || !supportsValidation;\n\n\t if (valid) {\n\t validationError = \"\";\n\t } else {\n\t if (this.refsInput.pattern === \"\") {\n\t this.refsInput.pattern = this.props.required ? \".+\" : \".*\";\n\t }\n\n\t if (supportsValidation) {\n\t this.refsInput.checkValidity();\n\t valid = this.refsInput.validity.valid;\n\n\t if (!valid) {\n\t validationError = this.refsInput.validationMessage;\n\t }\n\t }\n\n\t if (valid && supportsValidation && this.props.maxLength) {\n\t if (this.refsInput.value.length > this.props.maxLength) {\n\t validationError = \"This value is too long\";\n\t }\n\t }\n\t }\n\n\t validationError = validationError || (valid ? \"\" : this.refsInput.validationMessage || \"Unknown Error\");\n\n\t var validStateChanged = this._valid !== validationError;\n\t this._valid = validationError;\n\t if (validationError) {\n\t addClass(this.refsWrapper, \"has-error\");\n\t if (validStateChanged) {\n\t this._invokeEventCallback(\"onInvalid\", validationError, this.state.value, this.refsInput.value);\n\t }\n\t } else {\n\t removeClass(this.refsWrapper, \"has-error\");\n\t if (validStateChanged) {\n\t this._invokeEventCallback(\"onValid\", this.state.value, this.refsInput.value);\n\t }\n\t }\n\t }\n\t }, {\n\t key: '_toNumber',\n\t value: function _toNumber(x) {\n\t var n = parseFloat(x);\n\t if (isNaN(n) || !isFinite(n)) {\n\t n = 0;\n\t }\n\n\t if (this._isStrict) {\n\t var precision = access(this.props, \"precision\", null, this);\n\t var q = Math.pow(10, precision === null ? 10 : precision);\n\t var _min = +access(this.props, \"min\", NumericInput.defaultProps.min, this);\n\t var _max = +access(this.props, \"max\", NumericInput.defaultProps.max, this);\n\t n = Math.min(Math.max(n, _min), _max);\n\t n = Math.round(n * q) / q;\n\t }\n\n\t return n;\n\t }\n\t }, {\n\t key: '_parse',\n\t value: function _parse(x) {\n\t x = String(x);\n\t if (typeof this.props.parse == 'function') {\n\t return parseFloat(this.props.parse(x));\n\t }\n\t return parseFloat(x);\n\t }\n\t }, {\n\t key: '_format',\n\t value: function _format(n) {\n\t var _n = this._toNumber(n);\n\t var precision = access(this.props, \"precision\", null, this);\n\t if (precision !== null) {\n\t _n = n.toFixed(precision);\n\t }\n\n\t _n += \"\";\n\n\t if (this.props.format) {\n\t return this.props.format(_n);\n\t }\n\n\t return _n;\n\t }\n\t }, {\n\t key: '_step',\n\t value: function _step(n, callback) {\n\t var _isStrict = this._isStrict;\n\t this._isStrict = true;\n\n\t var _step = +access(this.props, \"step\", NumericInput.defaultProps.step, this, n > 0 ? NumericInput.DIRECTION_UP : NumericInput.DIRECTION_DOWN);\n\n\t var _n = this._toNumber((this.state.value || 0) + _step * n);\n\n\t if (this.props.snap) {\n\t _n = Math.round(_n / _step) * _step;\n\t }\n\n\t this._isStrict = _isStrict;\n\n\t if (_n !== this.state.value) {\n\t this.setState({ value: _n, stringValue: _n + \"\" }, callback);\n\t return true;\n\t }\n\n\t return false;\n\t }\n\t }, {\n\t key: '_onKeyDown',\n\t value: function _onKeyDown() {\n\t for (var _len3 = arguments.length, args = Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {\n\t args[_key3] = arguments[_key3];\n\t }\n\n\t args[0].persist();\n\t this._invokeEventCallback.apply(this, [\"onKeyDown\"].concat(args));\n\t var e = args[0];\n\t if (!e.isDefaultPrevented()) {\n\t if (e.keyCode === KEYCODE_UP) {\n\t e.preventDefault();\n\t this._step(e.ctrlKey || e.metaKey ? 0.1 : e.shiftKey ? 10 : 1);\n\t } else if (e.keyCode === KEYCODE_DOWN) {\n\t e.preventDefault();\n\t this._step(e.ctrlKey || e.metaKey ? -0.1 : e.shiftKey ? -10 : -1);\n\t } else {\n\t var _value = this.refsInput.value,\n\t length = _value.length;\n\t if (e.keyCode === 8) {\n\t if (this.refsInput.selectionStart == this.refsInput.selectionEnd && this.refsInput.selectionEnd > 0 && _value.length && _value.charAt(this.refsInput.selectionEnd - 1) === \".\") {\n\t e.preventDefault();\n\t this.refsInput.selectionStart = this.refsInput.selectionEnd = this.refsInput.selectionEnd - 1;\n\t }\n\t } else if (e.keyCode === 46) {\n\t if (this.refsInput.selectionStart == this.refsInput.selectionEnd && this.refsInput.selectionEnd < length + 1 && _value.length && _value.charAt(this.refsInput.selectionEnd) === \".\") {\n\t e.preventDefault();\n\t this.refsInput.selectionStart = this.refsInput.selectionEnd = this.refsInput.selectionEnd + 1;\n\t }\n\t }\n\t }\n\t }\n\t }\n\t }, {\n\t key: 'stop',\n\t value: function stop() {\n\t if (this._timer) {\n\t clearTimeout(this._timer);\n\t }\n\t }\n\t }, {\n\t key: 'increase',\n\t value: function increase() {\n\t var _this4 = this;\n\n\t var _recursive = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n\n\t var callback = arguments[1];\n\n\t this.stop();\n\t this._step(1, callback);\n\t var _max = +access(this.props, \"max\", NumericInput.defaultProps.max, this);\n\t if (isNaN(this.state.value) || +this.state.value < _max) {\n\t this._timer = setTimeout(function () {\n\t _this4.increase(true);\n\t }, _recursive ? NumericInput.SPEED : NumericInput.DELAY);\n\t }\n\t }\n\t }, {\n\t key: 'decrease',\n\t value: function decrease() {\n\t var _this5 = this;\n\n\t var _recursive = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n\n\t var callback = arguments[1];\n\n\t this.stop();\n\t this._step(-1, callback);\n\t var _min = +access(this.props, \"min\", NumericInput.defaultProps.min, this);\n\t if (isNaN(this.state.value) || +this.state.value > _min) {\n\t this._timer = setTimeout(function () {\n\t _this5.decrease(true);\n\t }, _recursive ? NumericInput.SPEED : NumericInput.DELAY);\n\t }\n\t }\n\t }, {\n\t key: 'onMouseDown',\n\t value: function onMouseDown(dir, callback) {\n\t if (dir == 'down') {\n\t this.decrease(false, callback);\n\t } else if (dir == 'up') {\n\t this.increase(false, callback);\n\t }\n\t }\n\t }, {\n\t key: 'onTouchStart',\n\t value: function onTouchStart(dir, e) {\n\t e.preventDefault();\n\t if (dir == 'down') {\n\t this.decrease();\n\t } else if (dir == 'up') {\n\t this.increase();\n\t }\n\t }\n\t }, {\n\t key: 'onTouchEnd',\n\t value: function onTouchEnd(e) {\n\t e.preventDefault();\n\t this.stop();\n\t }\n\t }, {\n\t key: '_invokeEventCallback',\n\t value: function _invokeEventCallback(callbackName) {\n\t if (typeof this.props[callbackName] == \"function\") {\n\t var _props$callbackName;\n\n\t for (var _len4 = arguments.length, args = Array(_len4 > 1 ? _len4 - 1 : 0), _key4 = 1; _key4 < _len4; _key4++) {\n\t args[_key4 - 1] = arguments[_key4];\n\t }\n\n\t (_props$callbackName = this.props[callbackName]).call.apply(_props$callbackName, [null].concat(args));\n\t }\n\t }\n\t }, {\n\t key: 'render',\n\t value: function render() {\n\t var _this6 = this;\n\n\t var props = this.props;\n\t var state = this.state;\n\t var css = {};\n\n\t var _props = this.props,\n\t step = _props.step,\n\t min = _props.min,\n\t max = _props.max,\n\t precision = _props.precision,\n\t parse = _props.parse,\n\t format = _props.format,\n\t mobile = _props.mobile,\n\t snap = _props.snap,\n\t componentClass = _props.componentClass,\n\t value = _props.value,\n\t type = _props.type,\n\t style = _props.style,\n\t defaultValue = _props.defaultValue,\n\t onInvalid = _props.onInvalid,\n\t onValid = _props.onValid,\n\t strict = _props.strict,\n\t noStyle = _props.noStyle,\n\t rest = _objectWithoutProperties(_props, ['step', 'min', 'max', 'precision', 'parse', 'format', 'mobile', 'snap', 'componentClass', 'value', 'type', 'style', 'defaultValue', 'onInvalid', 'onValid', 'strict', 'noStyle']);\n\n\t noStyle = noStyle || style === false;\n\n\t for (var x in NumericInput.style) {\n\t css[x] = _extends({}, NumericInput.style[x], style ? style[x] || {} : {});\n\t }\n\n\t var hasFormControl = props.className && /\\bform-control\\b/.test(props.className);\n\n\t if (mobile == 'auto') {\n\t mobile = IS_BROWSER && 'ontouchstart' in document;\n\t }\n\n\t if (typeof mobile == \"function\") {\n\t mobile = mobile.call(this);\n\t }\n\t mobile = !!mobile;\n\n\t var attrs = {\n\t wrap: {\n\t style: noStyle ? null : css.wrap,\n\t className: 'react-numeric-input',\n\t ref: function ref(e) {\n\t if (e != null && e != undefined) {\n\t _this6.refsWrapper = e;\n\t }\n\t },\n\t onMouseUp: undefined,\n\t onMouseLeave: undefined\n\t },\n\t input: _extends({\n\t ref: function ref(e) {\n\t if (e != null && e != undefined) {\n\t _this6.refsInput = e;\n\t }\n\t },\n\t type: 'text',\n\t style: noStyle ? null : _extends({}, css.input, !hasFormControl ? css['input:not(.form-control)'] : {}, this._inputFocus ? css['input:focus'] : {})\n\t }, rest),\n\t btnUp: {\n\t onMouseEnter: undefined,\n\t onMouseDown: undefined,\n\t onMouseUp: undefined,\n\t onMouseLeave: undefined,\n\t onTouchStart: undefined,\n\t onTouchEnd: undefined,\n\t style: noStyle ? null : _extends({}, css.btn, css.btnUp, props.disabled || props.readOnly ? css['btn:disabled'] : state.btnUpActive ? css['btn:active'] : state.btnUpHover ? css['btn:hover'] : {})\n\t },\n\t btnDown: {\n\t onMouseEnter: undefined,\n\t onMouseDown: undefined,\n\t onMouseUp: undefined,\n\t onMouseLeave: undefined,\n\t onTouchStart: undefined,\n\t onTouchEnd: undefined,\n\t style: noStyle ? null : _extends({}, css.btn, css.btnDown, props.disabled || props.readOnly ? css['btn:disabled'] : state.btnDownActive ? css['btn:active'] : state.btnDownHover ? css['btn:hover'] : {})\n\t }\n\t };\n\n\t var stringValue = String(state.stringValue || (state.value || state.value === 0 ? state.value : \"\") || \"\");\n\n\t var loose = !this._isStrict && (this._inputFocus || !this._isMounted);\n\n\t if (loose && RE_INCOMPLETE_NUMBER.test(stringValue)) {\n\t attrs.input.value = stringValue;\n\t } else if (loose && stringValue && !RE_NUMBER.test(stringValue)) {\n\t attrs.input.value = stringValue;\n\t } else if (state.value || state.value === 0) {\n\t attrs.input.value = this._format(state.value);\n\t } else {\n\t attrs.input.value = \"\";\n\t }\n\n\t if (hasFormControl && !noStyle) {\n\t _extends(attrs.wrap.style, css['wrap.hasFormControl']);\n\t }\n\n\t if (mobile && !noStyle) {\n\t _extends(attrs.input.style, css['input.mobile']);\n\t _extends(attrs.btnUp.style, css['btnUp.mobile']);\n\t _extends(attrs.btnDown.style, css['btnDown.mobile']);\n\t }\n\n\t if (!props.disabled && !props.readOnly) {\n\t _extends(attrs.wrap, {\n\t onMouseUp: this.stop,\n\t onMouseLeave: this.stop\n\t });\n\n\t _extends(attrs.btnUp, {\n\t onTouchStart: this.onTouchStart.bind(this, 'up'),\n\t onTouchEnd: this.onTouchEnd,\n\t onMouseEnter: function onMouseEnter() {\n\t _this6.setState({\n\t btnUpHover: true\n\t });\n\t },\n\t onMouseLeave: function onMouseLeave() {\n\t _this6.stop();\n\t _this6.setState({\n\t btnUpHover: false,\n\t btnUpActive: false\n\t });\n\t },\n\t onMouseUp: function onMouseUp() {\n\t _this6.setState({\n\t btnUpHover: true,\n\t btnUpActive: false\n\t });\n\t },\n\t onMouseDown: function onMouseDown() {\n\t for (var _len5 = arguments.length, args = Array(_len5), _key5 = 0; _key5 < _len5; _key5++) {\n\t args[_key5] = arguments[_key5];\n\t }\n\n\t args[0].preventDefault();\n\t args[0].persist();\n\t _this6._inputFocus = true;\n\t _this6.setState({\n\t btnUpHover: true,\n\t btnUpActive: true\n\t }, function () {\n\t _this6._invokeEventCallback.apply(_this6, [\"onFocus\"].concat(args));\n\t _this6.onMouseDown('up');\n\t });\n\t }\n\t });\n\n\t _extends(attrs.btnDown, {\n\t onTouchStart: this.onTouchStart.bind(this, 'down'),\n\t onTouchEnd: this.onTouchEnd,\n\t onMouseEnter: function onMouseEnter() {\n\t _this6.setState({\n\t btnDownHover: true\n\t });\n\t },\n\t onMouseLeave: function onMouseLeave() {\n\t _this6.stop();\n\t _this6.setState({\n\t btnDownHover: false,\n\t btnDownActive: false\n\t });\n\t },\n\t onMouseUp: function onMouseUp() {\n\t _this6.setState({\n\t btnDownHover: true,\n\t btnDownActive: false\n\t });\n\t },\n\t onMouseDown: function onMouseDown() {\n\t for (var _len6 = arguments.length, args = Array(_len6), _key6 = 0; _key6 < _len6; _key6++) {\n\t args[_key6] = arguments[_key6];\n\t }\n\n\t args[0].preventDefault();\n\t args[0].persist();\n\t _this6._inputFocus = true;\n\t _this6.setState({\n\t btnDownHover: true,\n\t btnDownActive: true\n\t }, function () {\n\t _this6._invokeEventCallback.apply(_this6, [\"onFocus\"].concat(args));\n\t _this6.onMouseDown('down');\n\t });\n\t }\n\t });\n\n\t _extends(attrs.input, {\n\t onChange: function onChange(e) {\n\t var original = e.target.value;\n\t var val = _this6._parse(original);\n\t if (isNaN(val)) {\n\t val = null;\n\t }\n\t _this6.setState({\n\t value: _this6._isStrict ? _this6._toNumber(val) : val,\n\t stringValue: original\n\t });\n\t },\n\t onKeyDown: this._onKeyDown.bind(this),\n\t onInput: function onInput() {\n\t for (var _len7 = arguments.length, args = Array(_len7), _key7 = 0; _key7 < _len7; _key7++) {\n\t args[_key7] = arguments[_key7];\n\t }\n\n\t _this6.saveSelection();\n\t _this6._invokeEventCallback.apply(_this6, [\"onInput\"].concat(args));\n\t },\n\t onSelect: function onSelect() {\n\t for (var _len8 = arguments.length, args = Array(_len8), _key8 = 0; _key8 < _len8; _key8++) {\n\t args[_key8] = arguments[_key8];\n\t }\n\n\t _this6.saveSelection();\n\t _this6._invokeEventCallback.apply(_this6, [\"onSelect\"].concat(args));\n\t },\n\t onFocus: function onFocus() {\n\t for (var _len9 = arguments.length, args = Array(_len9), _key9 = 0; _key9 < _len9; _key9++) {\n\t args[_key9] = arguments[_key9];\n\t }\n\n\t args[0].persist();\n\t _this6._inputFocus = true;\n\t var val = _this6._parse(args[0].target.value);\n\t _this6.setState({\n\t value: val,\n\t stringValue: val || val === 0 ? val + \"\" : \"\"\n\t }, function () {\n\t _this6._invokeEventCallback.apply(_this6, [\"onFocus\"].concat(args));\n\t });\n\t },\n\t onBlur: function onBlur() {\n\t for (var _len10 = arguments.length, args = Array(_len10), _key10 = 0; _key10 < _len10; _key10++) {\n\t args[_key10] = arguments[_key10];\n\t }\n\n\t var _isStrict = _this6._isStrict;\n\t _this6._isStrict = true;\n\t args[0].persist();\n\t _this6._inputFocus = false;\n\t var val = _this6._parse(args[0].target.value);\n\t _this6.setState({\n\t value: val\n\t }, function () {\n\t _this6._invokeEventCallback.apply(_this6, [\"onBlur\"].concat(args));\n\t _this6._isStrict = _isStrict;\n\t });\n\t }\n\t });\n\t } else {\n\t if (!noStyle && props.disabled) {\n\t _extends(attrs.input.style, css['input:disabled']);\n\t }\n\t }\n\n\t var InputTag = componentClass || 'input';\n\n\t if (mobile) {\n\t return _react2.default.createElement(\n\t 'span',\n\t attrs.wrap,\n\t _react2.default.createElement(InputTag, attrs.input),\n\t _react2.default.createElement(\n\t 'b',\n\t attrs.btnUp,\n\t _react2.default.createElement('i', { style: noStyle ? null : css.minus }),\n\t _react2.default.createElement('i', { style: noStyle ? null : css.plus })\n\t ),\n\t _react2.default.createElement(\n\t 'b',\n\t attrs.btnDown,\n\t _react2.default.createElement('i', { style: noStyle ? null : css.minus })\n\t )\n\t );\n\t }\n\n\t return _react2.default.createElement(\n\t 'span',\n\t attrs.wrap,\n\t _react2.default.createElement(InputTag, attrs.input),\n\t _react2.default.createElement(\n\t 'b',\n\t attrs.btnUp,\n\t _react2.default.createElement('i', { style: noStyle ? null : css.arrowUp })\n\t ),\n\t _react2.default.createElement(\n\t 'b',\n\t attrs.btnDown,\n\t _react2.default.createElement('i', { style: noStyle ? null : css.arrowDown })\n\t )\n\t );\n\t }\n\t }]);\n\n\t return NumericInput;\n\t}(_react.Component);\n\n\tNumericInput.propTypes = {\n\t step: _propTypes2.default.oneOfType([_propTypes2.default.number, _propTypes2.default.func]),\n\t min: _propTypes2.default.oneOfType([_propTypes2.default.number, _propTypes2.default.func]),\n\t max: _propTypes2.default.oneOfType([_propTypes2.default.number, _propTypes2.default.func]),\n\t precision: _propTypes2.default.oneOfType([_propTypes2.default.number, _propTypes2.default.func]),\n\t maxLength: _propTypes2.default.number,\n\t parse: _propTypes2.default.func,\n\t format: _propTypes2.default.func,\n\t className: _propTypes2.default.string,\n\t disabled: _propTypes2.default.bool,\n\t readOnly: _propTypes2.default.bool,\n\t required: _propTypes2.default.bool,\n\t snap: _propTypes2.default.bool,\n\t noValidate: _propTypes2.default.oneOfType([_propTypes2.default.bool, _propTypes2.default.string]),\n\t style: _propTypes2.default.oneOfType([_propTypes2.default.object, _propTypes2.default.bool]),\n\t noStyle: _propTypes2.default.bool,\n\t type: _propTypes2.default.string,\n\t pattern: _propTypes2.default.string,\n\t onFocus: _propTypes2.default.func,\n\t onBlur: _propTypes2.default.func,\n\t onKeyDown: _propTypes2.default.func,\n\t onChange: _propTypes2.default.func,\n\t onInvalid: _propTypes2.default.func,\n\t onValid: _propTypes2.default.func,\n\t onInput: _propTypes2.default.func,\n\t onSelect: _propTypes2.default.func,\n\t size: _propTypes2.default.oneOfType([_propTypes2.default.number, _propTypes2.default.string]),\n\t value: _propTypes2.default.oneOfType([_propTypes2.default.number, _propTypes2.default.string]),\n\t defaultValue: _propTypes2.default.oneOfType([_propTypes2.default.number, _propTypes2.default.string]),\n\t strict: _propTypes2.default.bool,\n\t componentClass: _propTypes2.default.string,\n\t mobile: function mobile(props, propName) {\n\t var prop = props[propName];\n\t if (prop !== true && prop !== false && prop !== 'auto' && typeof prop != 'function') {\n\t return new Error('The \"mobile\" prop must be true, false, \"auto\" or a function');\n\t }\n\t }\n\t};\n\tNumericInput.defaultProps = {\n\t step: 1,\n\t min: Number.MIN_SAFE_INTEGER || -9007199254740991,\n\t max: Number.MAX_SAFE_INTEGER || 9007199254740991,\n\t precision: null,\n\t parse: null,\n\t format: null,\n\t mobile: 'auto',\n\t strict: false,\n\t componentClass: \"input\",\n\t style: {}\n\t};\n\tNumericInput.style = {\n\t wrap: {\n\t position: 'relative',\n\t display: 'inline-block'\n\t },\n\n\t 'wrap.hasFormControl': {\n\t display: 'block'\n\t },\n\n\t arrowUp: {\n\t position: 'absolute',\n\t top: '50%',\n\t left: '50%',\n\t width: 0,\n\t height: 0,\n\t borderWidth: '0 0.6ex 0.6ex 0.6ex',\n\t borderColor: 'transparent transparent rgba(0, 0, 0, 0.7)',\n\t borderStyle: 'solid',\n\t margin: '-0.3ex 0 0 -0.56ex'\n\t },\n\n\t arrowDown: {\n\t position: 'absolute',\n\t top: '50%',\n\t left: '50%',\n\t width: 0,\n\t height: 0,\n\t borderWidth: '0.6ex 0.6ex 0 0.6ex',\n\t borderColor: 'rgba(0, 0, 0, 0.7) transparent transparent',\n\t borderStyle: 'solid',\n\t margin: '-0.3ex 0 0 -0.56ex'\n\t },\n\n\t plus: {\n\t position: 'absolute',\n\t top: '50%',\n\t left: '50%',\n\t width: 2,\n\t height: 10,\n\t background: 'rgba(0,0,0,.7)',\n\t margin: '-5px 0 0 -1px'\n\t },\n\n\t minus: {\n\t position: 'absolute',\n\t top: '50%',\n\t left: '50%',\n\t width: 10,\n\t height: 2,\n\t background: 'rgba(0,0,0,.7)',\n\t margin: '-1px 0 0 -5px'\n\t },\n\n\t btn: {\n\t position: 'absolute',\n\t right: 2,\n\t width: '2.26ex',\n\t borderColor: 'rgba(0,0,0,.1)',\n\t borderStyle: 'solid',\n\t textAlign: 'center',\n\t cursor: 'default',\n\t transition: 'all 0.1s',\n\t background: 'rgba(0,0,0,.1)',\n\t boxShadow: '-1px -1px 3px rgba(0,0,0,.1) inset,' + '1px 1px 3px rgba(255,255,255,.7) inset'\n\t },\n\n\t btnUp: {\n\t top: 2,\n\t bottom: '50%',\n\t borderRadius: '2px 2px 0 0',\n\t borderWidth: '1px 1px 0 1px'\n\t },\n\n\t 'btnUp.mobile': {\n\t width: '3.3ex',\n\t bottom: 2,\n\t boxShadow: 'none',\n\t borderRadius: 2,\n\t borderWidth: 1\n\t },\n\n\t btnDown: {\n\t top: '50%',\n\t bottom: 2,\n\t borderRadius: '0 0 2px 2px',\n\t borderWidth: '0 1px 1px 1px'\n\t },\n\n\t 'btnDown.mobile': {\n\t width: '3.3ex',\n\t bottom: 2,\n\t left: 2,\n\t top: 2,\n\t right: 'auto',\n\t boxShadow: 'none',\n\t borderRadius: 2,\n\t borderWidth: 1\n\t },\n\n\t 'btn:hover': {\n\t background: 'rgba(0,0,0,.2)'\n\t },\n\n\t 'btn:active': {\n\t background: 'rgba(0,0,0,.3)',\n\t boxShadow: '0 1px 3px rgba(0,0,0,.2) inset,' + '-1px -1px 4px rgba(255,255,255,.5) inset'\n\t },\n\n\t 'btn:disabled': {\n\t opacity: 0.5,\n\t boxShadow: 'none',\n\t cursor: 'not-allowed'\n\t },\n\n\t input: {\n\t paddingRight: '3ex',\n\t boxSizing: 'border-box',\n\t fontSize: 'inherit'\n\t },\n\n\t 'input:not(.form-control)': {\n\t border: '1px solid #ccc',\n\t borderRadius: 2,\n\t paddingLeft: 4,\n\t display: 'block',\n\t WebkitAppearance: 'none',\n\t lineHeight: 'normal'\n\t },\n\n\t 'input.mobile': {\n\t paddingLeft: ' 3.4ex',\n\t paddingRight: '3.4ex',\n\t textAlign: 'center'\n\t },\n\n\t 'input:focus': {},\n\n\t 'input:disabled': {\n\t color: 'rgba(0, 0, 0, 0.3)',\n\t textShadow: '0 1px 0 rgba(255, 255, 255, 0.8)'\n\t }\n\t};\n\tNumericInput.SPEED = 50;\n\tNumericInput.DELAY = 500;\n\tNumericInput.DIRECTION_UP = \"up\";\n\tNumericInput.DIRECTION_DOWN = \"down\";\n\n\n\tmodule.exports = NumericInput;\n\n/***/ }),\n/* 1 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = require(\"react\");\n\n/***/ }),\n/* 2 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = require(\"prop-types\");\n\n/***/ })\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,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","// 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","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = function(module) {\n\tvar getter = module && module.__esModule ?\n\t\tfunction() { return module['default']; } :\n\t\tfunction() { return module; };\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","var getProto = Object.getPrototypeOf ? function(obj) { return Object.getPrototypeOf(obj); } : function(obj) { return 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(function(key) { def[key] = function() { return value[key]; }; });\n\t}\n\tdef['default'] = function() { return value; };\n\t__webpack_require__.d(ns, def);\n\treturn ns;\n};","// define getter functions for harmony exports\n__webpack_require__.d = function(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 = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// define __esModule on exports\n__webpack_require__.r = function(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 = function(module) {\n\tmodule.paths = [];\n\tif (!module.children) module.children = [];\n\treturn module;\n};","__webpack_require__.p = \"/\";","////////////////////////////////////////////////////////////////////////////////\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/**\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: any;\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/**\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`. May be either a URL or the pieces of a\n * 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 * Encode a location the same way window.history would do (no-op for memory\n * history) so we ensure our PUSH/REPLAC e navigations for data routers\n * behave the same as POP\n *\n * @param location The incoming location from router.navigate()\n */\n encodeLocation(location: Location): Location;\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};\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 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(to) {\n return typeof to === \"string\" ? to : createPath(to);\n },\n encodeLocation(location) {\n return location;\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 });\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 });\n }\n },\n go(delta) {\n action = Action.Pop;\n index = clampIndex(index + delta);\n if (listener) {\n listener({ action, location: getCurrentLocation() });\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 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\nfunction 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): HistoryState {\n return {\n usr: location.state,\n key: location.key,\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 function createURL(location: Location | string): 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 typeof window !== \"undefined\" &&\n typeof window.location !== \"undefined\" &&\n window.location.origin !== \"null\"\n ? window.location.origin\n : \"unknown://unknown\";\n let href = typeof location === \"string\" ? location : createPath(location);\n return new URL(href, base);\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 function handlePop() {\n action = Action.Pop;\n if (listener) {\n listener({ action, location: history.location });\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 let historyState = getHistoryState(location);\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 // 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 });\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 let historyState = getHistoryState(location);\n let url = history.createHref(location);\n globalHistory.replaceState(historyState, \"\", url);\n\n if (v5Compat && listener) {\n listener({ action, location: history.location });\n }\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 encodeLocation(location) {\n // Encode a Location the same way window.location would\n let url = createURL(createPath(location));\n return {\n ...location,\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","export default function _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++) {\n arr2[i] = arr[i];\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}","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 _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}","export default function _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n var _s, _e;\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\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 return _arr;\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}","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 _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\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 _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\nexport default function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}","export default function _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n return _setPrototypeOf(o, p);\n}","import setPrototypeOf from \"./setPrototypeOf.js\";\nexport default function _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}","export default function _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}","export default function _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}","export default 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}","import _typeof from \"./typeof.js\";\nimport assertThisInitialized from \"./assertThisInitialized.js\";\nexport default function _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n return assertThisInitialized(self);\n}","export default function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return self;\n}","import getPrototypeOf from \"./getPrototypeOf.js\";\nimport isNativeReflectConstruct from \"./isNativeReflectConstruct.js\";\nimport possibleConstructorReturn from \"./possibleConstructorReturn.js\";\nexport default function _createSuper(Derived) {\n var hasNativeReflectConstruct = isNativeReflectConstruct();\n return function _createSuperInternal() {\n var Super = getPrototypeOf(Derived),\n result;\n if (hasNativeReflectConstruct) {\n var NewTarget = getPrototypeOf(this).constructor;\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n return possibleConstructorReturn(this, result);\n };\n}","import setPrototypeOf from \"./setPrototypeOf.js\";\nimport isNativeReflectConstruct from \"./isNativeReflectConstruct.js\";\nexport default function _construct(Parent, args, Class) {\n if (isNativeReflectConstruct()) {\n _construct = Reflect.construct.bind();\n } else {\n _construct = function _construct(Parent, args, Class) {\n var a = [null];\n a.push.apply(a, args);\n var Constructor = Function.bind.apply(Parent, a);\n var instance = new Constructor();\n if (Class) setPrototypeOf(instance, Class.prototype);\n return instance;\n };\n }\n return _construct.apply(null, arguments);\n}","import getPrototypeOf from \"./getPrototypeOf.js\";\nimport setPrototypeOf from \"./setPrototypeOf.js\";\nimport isNativeFunction from \"./isNativeFunction.js\";\nimport construct from \"./construct.js\";\nexport default function _wrapNativeSuper(Class) {\n var _cache = typeof Map === \"function\" ? new Map() : undefined;\n _wrapNativeSuper = function _wrapNativeSuper(Class) {\n if (Class === null || !isNativeFunction(Class)) return Class;\n if (typeof Class !== \"function\") {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n if (typeof _cache !== \"undefined\") {\n if (_cache.has(Class)) return _cache.get(Class);\n _cache.set(Class, Wrapper);\n }\n function Wrapper() {\n return construct(Class, arguments, getPrototypeOf(this).constructor);\n }\n Wrapper.prototype = Object.create(Class.prototype, {\n constructor: {\n value: Wrapper,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n return setPrototypeOf(Wrapper, Class);\n };\n return _wrapNativeSuper(Class);\n}","export default function _isNativeFunction(fn) {\n return Function.toString.call(fn).indexOf(\"[native code]\") !== -1;\n}","import type { Location, Path, To } from \"./history\";\nimport { parsePath } 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: any;\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}\n\n/**\n * Redirect result from a loader or action\n */\nexport interface RedirectResult {\n type: ResultType.redirect;\n status: number;\n location: string;\n revalidate: boolean;\n}\n\n/**\n * Unsuccessful result from a loader or action\n */\nexport interface ErrorResult {\n type: ResultType.error;\n error: any;\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\nexport type FormMethod = \"get\" | \"post\" | \"put\" | \"patch\" | \"delete\";\nexport type FormEncType =\n | \"application/x-www-form-urlencoded\"\n | \"multipart/form-data\";\n\n/**\n * @private\n * Internal interface to pass around for action submissions, not intended for\n * external consumption\n */\nexport interface Submission {\n formMethod: Exclude;\n formAction: string;\n formEncType: FormEncType;\n formData: FormData;\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}\n\n/**\n * Arguments passed to loader functions\n */\nexport interface LoaderFunctionArgs extends DataFunctionArgs {}\n\n/**\n * Arguments passed to action functions\n */\nexport interface ActionFunctionArgs extends DataFunctionArgs {}\n\n/**\n * Route loader function signature\n */\nexport interface LoaderFunction {\n (args: LoaderFunctionArgs): Promise | Response | Promise | any;\n}\n\n/**\n * Route action function signature\n */\nexport interface ActionFunction {\n (args: ActionFunctionArgs): Promise | Response | Promise | any;\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: {\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 formData?: Submission[\"formData\"];\n actionResult?: DataResult;\n defaultShouldRevalidate: boolean;\n }): boolean;\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;\n action?: ActionFunction;\n hasErrorBoundary?: boolean;\n shouldRevalidate?: ShouldRevalidateFunction;\n handle?: any;\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\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 `${string}:${infer Param}`\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 */\ntype 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 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 parentPath: number[] = [],\n allIds: Set = new Set()\n): AgnosticDataRouteObject[] {\n return routes.map((route, index) => {\n let treePath = [...parentPath, 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 !allIds.has(id),\n `Found a route id collision on id \"${id}\". Route ` +\n \"id's must be globally unique within Data Router usages\"\n );\n allIds.add(id);\n\n if (isIndexRoute(route)) {\n let indexRoute: AgnosticDataIndexRouteObject = { ...route, id };\n return indexRoute;\n } else {\n let pathOrLayoutRoute: AgnosticDataNonIndexRouteObject = {\n ...route,\n id,\n children: route.children\n ? convertRoutesToDataRoutes(route.children, treePath, allIds)\n : undefined,\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/docs/en/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 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 matches = matchRouteBranch(\n branches[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 safelyDecodeURI(pathname)\n );\n }\n\n return matches;\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 routes.forEach((route, index) => {\n let meta: RouteMeta = {\n relativePath: route.path || \"\",\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\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({ path, score: computeScore(path, route.index), routesMeta });\n });\n\n return branches;\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): 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 if (!match) return null;\n\n Object.assign(matchedParams, match.params);\n\n let route = meta.route;\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/docs/en/v6/utils/generate-path\n */\nexport function generatePath(\n path: Path,\n params: {\n [key in PathParam]: string;\n } = {} as any\n): string {\n return path\n .replace(/:(\\w+)/g, (_, key: PathParam) => {\n invariant(params[key] != null, `Missing \":${key}\" param`);\n return params[key]!;\n })\n .replace(/(\\/?)\\*/, (_, prefix, __, str) => {\n const star = \"*\" as PathParam;\n\n if (params[star] == null) {\n // If no splat was provided, trim the trailing slash _unless_ it's\n // the entire path\n return str === \"/*\" ? \"/\" : \"\";\n }\n\n // Apply the splat\n return `${prefix}${params[star]}`;\n });\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/docs/en/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, paramNames] = 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 = paramNames.reduce>(\n (memo, paramName, 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 memo[paramName] = safelyDecodeURIComponent(\n captureGroups[index] || \"\",\n paramName\n );\n return memo;\n },\n {}\n );\n\n return {\n params,\n pathname: matchedPathname,\n pathnameBase,\n pattern,\n };\n}\n\nfunction compilePath(\n path: string,\n caseSensitive = false,\n end = true\n): [RegExp, string[]] {\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 paramNames: string[] = [];\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(/:(\\w+)/g, (_: string, paramName: string) => {\n paramNames.push(paramName);\n return \"([^\\\\/]+)\";\n });\n\n if (path.endsWith(\"*\")) {\n paramNames.push(\"*\");\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, paramNames];\n}\n\nfunction safelyDecodeURI(value: string) {\n try {\n return decodeURI(value);\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\nfunction safelyDecodeURIComponent(value: string, paramName: string) {\n try {\n return decodeURIComponent(value);\n } catch (error) {\n warning(\n false,\n `The value for the URL param \"${paramName}\" will not be decoded because` +\n ` the string \"${value}\" is a malformed URL segment. This is probably` +\n ` due to a bad percent 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 * @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\n/**\n * @private\n */\nexport function warning(cond: any, message: string): void {\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 React Router!\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\n/**\n * Returns a resolved path object relative to the given pathname.\n *\n * @see https://reactrouter.com/docs/en/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/**\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 (isPathRelative || toPathname == null) {\n from = locationPathname;\n } else {\n let routePathnameIndex = routePathnames.length - 1;\n\n if (toPathname.startsWith(\"..\")) {\n let toSegments = toPathname.split(\"/\");\n\n // Each leading .. segment means \"go up one route\" instead of \"go up one\n // URL segment\". This is a key difference from how works and a\n // major reason we call this a \"to\" value instead of a \"href\".\n while (toSegments[0] === \"..\") {\n toSegments.shift();\n routePathnameIndex -= 1;\n }\n\n to.pathname = toSegments.join(\"/\");\n }\n\n // If there are more \"..\" segments than parent routes, resolve relative to\n // the root / URL.\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 */\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 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 pendingKeys: Set = new Set();\n private controller: AbortController;\n private abortPromise: Promise;\n private unlistenAbortSignal: () => void;\n private subscriber?: (aborted: boolean) => void = undefined;\n data: Record;\n\n constructor(data: Record) {\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\n private trackPromise(\n key: string | number,\n value: Promise | unknown\n ): TrackedPromise | unknown {\n if (!(value instanceof Promise)) {\n return value;\n }\n\n this.pendingKeys.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, null, 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 | number,\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.pendingKeys.delete(key);\n\n if (this.done) {\n // Nothing left to abort!\n this.unlistenAbortSignal();\n }\n\n const subscriber = this.subscriber;\n if (error) {\n Object.defineProperty(promise, \"_error\", { get: () => error });\n subscriber && subscriber(false);\n return Promise.reject(error);\n }\n\n Object.defineProperty(promise, \"_data\", { get: () => data });\n subscriber && subscriber(false);\n return data;\n }\n\n subscribe(fn: (aborted: boolean) => void) {\n this.subscriber = fn;\n }\n\n cancel() {\n this.controller.abort();\n this.pendingKeys.forEach((v, k) => this.pendingKeys.delete(k));\n let subscriber = this.subscriber;\n subscriber && subscriber(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.pendingKeys.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\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 function defer(data: Record) {\n return new DeferredData(data);\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 * @private\n * Utility class we use to hold auto-unwrapped 4xx/5xx Response bodies\n */\nexport class ErrorResponse {\n status: number;\n statusText: string;\n data: any;\n\n constructor(status: number, statusText: string | undefined, data: any) {\n this.status = status;\n this.statusText = statusText || \"\";\n this.data = data;\n }\n}\n\n/**\n * Check if the given error is an ErrorResponse generated from a 4xx/5xx\n * Response throw from an action/loader\n */\nexport function isRouteErrorResponse(e: any): e is ErrorResponse {\n return e instanceof ErrorResponse;\n}\n","import type { History, Location, To } from \"./history\";\nimport {\n Action as HistoryAction,\n createLocation,\n createPath,\n createURL,\n parsePath,\n} from \"./history\";\nimport type {\n DataResult,\n AgnosticDataRouteMatch,\n AgnosticDataRouteObject,\n DeferredResult,\n ErrorResult,\n FormEncType,\n FormMethod,\n RedirectResult,\n RouteData,\n AgnosticRouteObject,\n Submission,\n SuccessResult,\n AgnosticRouteMatch,\n} from \"./utils\";\nimport {\n DeferredData,\n ErrorResponse,\n ResultType,\n convertRoutesToDataRoutes,\n getPathContributingMatches,\n invariant,\n isRouteErrorResponse,\n joinPaths,\n matchRoutes,\n resolveTo,\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 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 * 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): void;\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, opts?: RouterNavigateOptions): void;\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,\n opts?: RouterNavigateOptions\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 * 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 * 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/**\n * Data that can be passed into hydrate a Router from SSR\n */\nexport type HydrationState = Partial<\n Pick\n>;\n\n/**\n * Initialization options for createRouter\n */\nexport interface RouterInit {\n basename?: string;\n routes: AgnosticRouteObject[];\n history: History;\n hydrationData?: HydrationState;\n}\n\n/**\n * State returned from a server-side query() call\n */\nexport interface StaticHandlerContext {\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 _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(request: Request): Promise;\n queryRoute(request: Request, routeId?: string): Promise;\n}\n\n/**\n * Subscriber function signature for changes to router state\n */\nexport interface RouterSubscriber {\n (state: RouterState): void;\n}\n\ninterface UseMatchesMatch {\n id: string;\n pathname: string;\n params: AgnosticRouteMatch[\"params\"];\n data: unknown;\n handle: unknown;\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: UseMatchesMatch[]): string | null;\n}\n\n/**\n * Function signature for determining the current scroll position\n */\nexport interface GetScrollPositionFunction {\n (): number;\n}\n\n/**\n * Options for a navigate() call for a Link navigation\n */\ntype LinkNavigateOptions = {\n replace?: boolean;\n state?: any;\n preventScrollReset?: boolean;\n};\n\n/**\n * Options for a navigate() call for a Form navigation\n */\ntype SubmissionNavigateOptions = {\n replace?: boolean;\n state?: any;\n formMethod?: FormMethod;\n formEncType?: FormEncType;\n formData: FormData;\n};\n\n/**\n * Options to pass to navigate() for either a Link or Form navigation\n */\nexport type RouterNavigateOptions =\n | LinkNavigateOptions\n | SubmissionNavigateOptions;\n\n/**\n * Options to pass to fetch()\n */\nexport type RouterFetchOptions =\n | Omit\n | Omit;\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 };\n Loading: {\n state: \"loading\";\n location: Location;\n formMethod: FormMethod | undefined;\n formAction: string | undefined;\n formEncType: FormEncType | undefined;\n formData: FormData | undefined;\n };\n Submitting: {\n state: \"submitting\";\n location: Location;\n formMethod: FormMethod;\n formAction: string;\n formEncType: FormEncType;\n formData: FormData;\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 formData: undefined;\n data: TData | undefined;\n };\n Loading: {\n state: \"loading\";\n formMethod: FormMethod | undefined;\n formAction: string | undefined;\n formEncType: FormEncType | undefined;\n formData: FormData | undefined;\n data: TData | undefined;\n };\n Submitting: {\n state: \"submitting\";\n formMethod: FormMethod;\n formAction: string;\n formEncType: FormEncType;\n formData: FormData;\n data: TData | undefined;\n };\n};\n\nexport type Fetcher =\n FetcherStates[keyof FetcherStates];\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\ninterface HandleActionResult extends ShortCircuitable {\n /**\n * Error thrown from the current action, keyed by the route containing the\n * error boundary to render the error. To be committed to the state after\n * loaders have completed\n */\n pendingActionError?: RouteData;\n /**\n * Data returned from the current action, keyed by the route owning the action.\n * To be committed to the state after loaders have completed\n */\n pendingActionData?: RouteData;\n}\n\ninterface HandleLoadersResult extends ShortCircuitable {\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 * Tuple of [key, href, DataRouteMatch, DataRouteMatch[]] for a revalidating\n * fetcher.load()\n */\ntype RevalidatingFetcher = [\n string,\n string,\n AgnosticDataRouteMatch,\n AgnosticDataRouteMatch[]\n];\n\n/**\n * Tuple of [href, DataRouteMatch, DataRouteMatch[]] for an active\n * fetcher.load()\n */\ntype FetchLoadMatch = [\n string,\n AgnosticDataRouteMatch,\n AgnosticDataRouteMatch[]\n];\n\n/**\n * Wrapper object to allow us to throw any response out from callLoaderOrAction\n * for queryRouter while preserving whether or not it was thrown or returned\n * from the loader/action\n */\ninterface QueryRouteResponse {\n type: ResultType.data | ResultType.error;\n response: Response;\n}\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};\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};\n\nconst isBrowser =\n typeof window !== \"undefined\" &&\n typeof window.document !== \"undefined\" &&\n typeof window.document.createElement !== \"undefined\";\nconst isServer = !isBrowser;\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 invariant(\n init.routes.length > 0,\n \"You must provide a non-empty routes array to createRouter\"\n );\n\n let dataRoutes = convertRoutesToDataRoutes(init.routes);\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 let initialScrollRestored = false;\n\n let initialMatches = matchRoutes(\n dataRoutes,\n init.history.location,\n init.basename\n );\n let initialErrors: RouteData | null = null;\n\n if (initialMatches == null) {\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 { matches, route, error } = getNotFoundMatches(dataRoutes);\n initialMatches = matches;\n initialErrors = { [route.id]: error };\n }\n\n let initialized =\n !initialMatches.some((m) => m.route.loader) || init.hydrationData != null;\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 restoreScrollPosition: 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 };\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 // Should the current navigation prevent the scroll reset if scroll cannot\n // be restored?\n let pendingPreventScrollReset = false;\n // AbortController for the active navigation\n let pendingNavigationController: AbortController | null;\n // We use this to avoid touching history in completeNavigation if a\n // revalidation is entirely uninterrupted\n let isUninterruptedRevalidation = false;\n // Use this internal flag to force revalidation of all loaders:\n // - submissions (completed or interrupted)\n // - useRevalidate()\n // - X-Remix-Revalidate (from redirect)\n let isRevalidationRequired = false;\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 // Use this internal array to capture fetcher loads that were cancelled by an\n // action navigation and require revalidation\n let cancelledFetcherLoads: string[] = [];\n // AbortControllers for any in-flight fetchers\n let fetchControllers = new Map();\n // Track loads based on the order in which they started\n let incrementingLoadId = 0;\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 // Fetchers that triggered data reloads as a result of their actions\n let fetchReloadIds = new Map();\n // Fetchers that triggered redirect navigations from their actions\n let fetchRedirectIds = new Set();\n // Most recent href/match for fetcher.load calls for fetchers\n let fetchLoadMatches = new Map();\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 // 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 }) =>\n startNavigation(historyAction, location)\n );\n\n // Kick off initial data load if needed. Use Pop to avoid modifying history\n if (!state.initialized) {\n startNavigation(HistoryAction.Pop, state.location);\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 subscribers.clear();\n pendingNavigationController && pendingNavigationController.abort();\n state.fetchers.forEach((_, key) => deleteFetcher(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(newState: Partial): void {\n state = {\n ...state,\n ...newState,\n };\n subscribers.forEach((subscriber) => subscriber(state));\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 ): 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 submission\n // - We're past the submitting state and into the loading state\n // - The location we've finished loading is different from the submission\n // location, indicating we redirected from the action (avoids false\n // positives for loading/submissionRedirect when actionData returned\n // on a prior submission)\n let isActionReload =\n state.actionData != null &&\n state.navigation.formMethod != null &&\n state.navigation.state === \"loading\" &&\n state.navigation.formAction?.split(\"?\")[0] === location.pathname;\n\n // Always preserve any existing loaderData from re-used routes\n let newLoaderData = newState.loaderData\n ? {\n loaderData: mergeLoaderData(\n state.loaderData,\n newState.loaderData,\n newState.matches || []\n ),\n }\n : {};\n\n updateState({\n // Clear existing actionData on any completed navigation beyond the original\n // action, unless we're currently finishing the loading/actionReload state.\n // Do this prior to spreading in newState in case we got back to back actions\n ...(isActionReload ? {} : { actionData: null }),\n ...newState,\n ...newLoaderData,\n historyAction: pendingAction,\n location,\n initialized: true,\n navigation: IDLE_NAVIGATION,\n revalidation: \"idle\",\n // Don't restore on submission navigations\n restoreScrollPosition: state.navigation.formData\n ? false\n : getSavedScrollPosition(location, newState.matches || state.matches),\n preventScrollReset: pendingPreventScrollReset,\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 // Reset stateful navigation vars\n pendingAction = HistoryAction.Pop;\n pendingPreventScrollReset = false;\n isUninterruptedRevalidation = false;\n isRevalidationRequired = false;\n cancelledDeferredRoutes = [];\n cancelledFetcherLoads = [];\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,\n opts?: RouterNavigateOptions\n ): Promise {\n if (typeof to === \"number\") {\n init.history.go(to);\n return;\n }\n\n let { path, submission, error } = normalizeNavigateOptions(to, opts);\n\n let location = 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 location = init.history.encodeLocation(location);\n\n let historyAction =\n (opts && opts.replace) === true || submission != null\n ? HistoryAction.Replace\n : HistoryAction.Push;\n let preventScrollReset =\n opts && \"preventScrollReset\" in opts\n ? opts.preventScrollReset === true\n : undefined;\n\n return await startNavigation(historyAction, location, {\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 });\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 { overrideNavigation: state.navigation }\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 submission?: Submission;\n overrideNavigation?: Navigation;\n pendingError?: ErrorResponse;\n startUninterruptedRevalidation?: boolean;\n preventScrollReset?: boolean;\n replace?: 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 let loadingNavigation = opts && opts.overrideNavigation;\n let matches = matchRoutes(dataRoutes, location, init.basename);\n\n // Short circuit with a 404 on the root error boundary if we match nothing\n if (!matches) {\n let {\n matches: notFoundMatches,\n route,\n error,\n } = getNotFoundMatches(dataRoutes);\n // Cancel all pending deferred on 404s since we don't keep any routes\n cancelActiveDeferreds();\n completeNavigation(location, {\n matches: notFoundMatches,\n loaderData: {},\n errors: {\n [route.id]: error,\n },\n });\n return;\n }\n\n // Short circuit if it's only a hash change\n if (isHashChangeOnly(state.location, location)) {\n completeNavigation(location, { matches });\n return;\n }\n\n // Create a controller/Request for this navigation\n pendingNavigationController = new AbortController();\n let request = createRequest(\n location,\n pendingNavigationController.signal,\n opts && opts.submission\n );\n let pendingActionData: RouteData | undefined;\n let pendingError: RouteData | 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 pendingError = {\n [findNearestBoundary(matches).route.id]: opts.pendingError,\n };\n } else if (opts && opts.submission) {\n // Call action if we received an action submission\n let actionOutput = await handleAction(\n request,\n location,\n opts.submission,\n matches,\n { replace: opts.replace }\n );\n\n if (actionOutput.shortCircuited) {\n return;\n }\n\n pendingActionData = actionOutput.pendingActionData;\n pendingError = actionOutput.pendingActionError;\n\n let navigation: NavigationStates[\"Loading\"] = {\n state: \"loading\",\n location,\n ...opts.submission,\n };\n loadingNavigation = navigation;\n }\n\n // Call loaders\n let { shortCircuited, loaderData, errors } = await handleLoaders(\n request,\n location,\n matches,\n loadingNavigation,\n opts && opts.submission,\n opts && opts.replace,\n pendingActionData,\n pendingError\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,\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 opts?: { replace?: boolean }\n ): Promise {\n interruptActiveLoads();\n\n // Put us in a submitting state\n let navigation: NavigationStates[\"Submitting\"] = {\n state: \"submitting\",\n location,\n ...submission,\n };\n updateState({ navigation });\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) {\n result = getMethodNotAllowedResult(location);\n } else {\n result = await callLoaderOrAction(\n \"action\",\n request,\n actionMatch,\n matches,\n router.basename\n );\n\n if (request.signal.aborted) {\n return { shortCircuited: true };\n }\n }\n\n if (isRedirectResult(result)) {\n let redirectNavigation: NavigationStates[\"Loading\"] = {\n state: \"loading\",\n location: createLocation(state.location, result.location),\n ...submission,\n };\n await startRedirectNavigation(\n result,\n redirectNavigation,\n opts && opts.replace\n );\n return { shortCircuited: true };\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 are REPLACE navigations, but if the\n // action threw an error that'll be rendered in an errorElement, we fall\n // back to PUSH so that the user can use the back button to get back to\n // the pre-submission form location to try again\n if ((opts && opts.replace) !== true) {\n pendingAction = HistoryAction.Push;\n }\n\n return {\n pendingActionError: { [boundaryMatch.route.id]: result.error },\n };\n }\n\n if (isDeferredResult(result)) {\n throw new Error(\"defer() is not supported in actions\");\n }\n\n return {\n pendingActionData: { [actionMatch.route.id]: result.data },\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 overrideNavigation?: Navigation,\n submission?: Submission,\n replace?: boolean,\n pendingActionData?: RouteData,\n pendingError?: RouteData\n ): Promise {\n // Figure out the right navigation we want to use for data loading\n let loadingNavigation = overrideNavigation;\n if (!loadingNavigation) {\n let navigation: NavigationStates[\"Loading\"] = {\n state: \"loading\",\n location,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n };\n loadingNavigation = navigation;\n }\n\n let [matchesToLoad, revalidatingFetchers] = getMatchesToLoad(\n state,\n matches,\n submission,\n location,\n isRevalidationRequired,\n cancelledDeferredRoutes,\n cancelledFetcherLoads,\n pendingActionData,\n pendingError,\n fetchLoadMatches\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 // Short circuit if we have no loaders to run\n if (matchesToLoad.length === 0 && revalidatingFetchers.length === 0) {\n completeNavigation(location, {\n matches,\n loaderData: mergeLoaderData(state.loaderData, {}, matches),\n // Commit pending error if we're short circuiting\n errors: pendingError || null,\n actionData: pendingActionData || null,\n });\n return { shortCircuited: true };\n }\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 (!isUninterruptedRevalidation) {\n revalidatingFetchers.forEach(([key]) => {\n let fetcher = state.fetchers.get(key);\n let revalidatingFetcher: FetcherStates[\"Loading\"] = {\n state: \"loading\",\n data: fetcher && fetcher.data,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n };\n state.fetchers.set(key, revalidatingFetcher);\n });\n updateState({\n navigation: loadingNavigation,\n actionData: pendingActionData || state.actionData || null,\n ...(revalidatingFetchers.length > 0\n ? { fetchers: new Map(state.fetchers) }\n : {}),\n });\n }\n\n pendingNavigationLoadId = ++incrementingLoadId;\n revalidatingFetchers.forEach(([key]) =>\n fetchControllers.set(key, pendingNavigationController!)\n );\n\n let { results, loaderResults, fetcherResults } =\n await callLoadersAndMaybeResolveData(\n state.matches,\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 revalidatingFetchers.forEach(([key]) => fetchControllers.delete(key));\n\n // If any loaders returned a redirect Response, start a new REPLACE navigation\n let redirect = findRedirect(results);\n if (redirect) {\n let redirectNavigation = getLoaderRedirect(state, redirect);\n await startRedirectNavigation(redirect, redirectNavigation, replace);\n return { shortCircuited: true };\n }\n\n // Process and commit output from loaders\n let { loaderData, errors } = processLoaderData(\n state,\n matches,\n matchesToLoad,\n loaderResults,\n pendingError,\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 markFetchRedirectsDone();\n let didAbortFetchLoads = abortStaleFetchLoads(pendingNavigationLoadId);\n\n return {\n loaderData,\n errors,\n ...(didAbortFetchLoads || revalidatingFetchers.length > 0\n ? { fetchers: new Map(state.fetchers) }\n : {}),\n };\n }\n\n function getFetcher(key: string): Fetcher {\n return state.fetchers.get(key) || IDLE_FETCHER;\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,\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 if (fetchControllers.has(key)) abortFetcher(key);\n\n let matches = matchRoutes(dataRoutes, href, init.basename);\n if (!matches) {\n setFetcherError(key, routeId, new ErrorResponse(404, \"Not Found\", null));\n return;\n }\n\n let { path, submission } = normalizeNavigateOptions(href, opts, true);\n let match = getTargetMatch(matches, path);\n\n if (submission) {\n handleFetcherAction(key, routeId, path, match, matches, submission);\n return;\n }\n\n // Store off the match so we can call it's shouldRevalidate on subsequent\n // revalidations\n fetchLoadMatches.set(key, [path, match, matches]);\n handleFetcherLoader(key, routeId, path, match, matches);\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 submission: Submission\n ) {\n interruptActiveLoads();\n fetchLoadMatches.delete(key);\n\n if (!match.route.action) {\n let { error } = getMethodNotAllowedResult(path);\n setFetcherError(key, routeId, error);\n return;\n }\n\n // Put this fetcher into it's submitting state\n let existingFetcher = state.fetchers.get(key);\n let fetcher: FetcherStates[\"Submitting\"] = {\n state: \"submitting\",\n ...submission,\n data: existingFetcher && existingFetcher.data,\n };\n state.fetchers.set(key, fetcher);\n updateState({ fetchers: new Map(state.fetchers) });\n\n // Call the action for the fetcher\n let abortController = new AbortController();\n let fetchRequest = createRequest(path, abortController.signal, submission);\n fetchControllers.set(key, abortController);\n\n let actionResult = await callLoaderOrAction(\n \"action\",\n fetchRequest,\n match,\n requestMatches,\n router.basename\n );\n\n if (fetchRequest.signal.aborted) {\n // We can delete this so long as we weren't aborted by ou 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 if (isRedirectResult(actionResult)) {\n fetchControllers.delete(key);\n fetchRedirectIds.add(key);\n let loadingFetcher: FetcherStates[\"Loading\"] = {\n state: \"loading\",\n ...submission,\n data: undefined,\n };\n state.fetchers.set(key, loadingFetcher);\n updateState({ fetchers: new Map(state.fetchers) });\n\n let redirectNavigation: NavigationStates[\"Loading\"] = {\n state: \"loading\",\n location: createLocation(state.location, actionResult.location),\n ...submission,\n };\n await startRedirectNavigation(actionResult, redirectNavigation);\n return;\n }\n\n // Process any non-redirect errors thrown\n if (isErrorResult(actionResult)) {\n setFetcherError(key, routeId, actionResult.error);\n return;\n }\n\n if (isDeferredResult(actionResult)) {\n invariant(false, \"defer() is not supported in actions\");\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 = createRequest(\n nextLocation,\n abortController.signal\n );\n let matches =\n state.navigation.state !== \"idle\"\n ? matchRoutes(dataRoutes, state.navigation.location, init.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: FetcherStates[\"Loading\"] = {\n state: \"loading\",\n data: actionResult.data,\n ...submission,\n };\n state.fetchers.set(key, loadFetcher);\n\n let [matchesToLoad, revalidatingFetchers] = getMatchesToLoad(\n state,\n matches,\n submission,\n nextLocation,\n isRevalidationRequired,\n cancelledDeferredRoutes,\n cancelledFetcherLoads,\n { [match.route.id]: actionResult.data },\n undefined, // No need to send through errors since we short circuit above\n fetchLoadMatches\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(([staleKey]) => staleKey !== key)\n .forEach(([staleKey]) => {\n let existingFetcher = state.fetchers.get(staleKey);\n let revalidatingFetcher: FetcherStates[\"Loading\"] = {\n state: \"loading\",\n data: existingFetcher && existingFetcher.data,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n };\n state.fetchers.set(staleKey, revalidatingFetcher);\n fetchControllers.set(staleKey, abortController);\n });\n\n updateState({ fetchers: new Map(state.fetchers) });\n\n let { results, loaderResults, fetcherResults } =\n await callLoadersAndMaybeResolveData(\n state.matches,\n matches,\n matchesToLoad,\n revalidatingFetchers,\n revalidationRequest\n );\n\n if (abortController.signal.aborted) {\n return;\n }\n\n fetchReloadIds.delete(key);\n fetchControllers.delete(key);\n revalidatingFetchers.forEach(([staleKey]) =>\n fetchControllers.delete(staleKey)\n );\n\n let redirect = findRedirect(results);\n if (redirect) {\n let redirectNavigation = getLoaderRedirect(state, redirect);\n await startRedirectNavigation(redirect, redirectNavigation);\n return;\n }\n\n // Process and commit output from loaders\n let { loaderData, errors } = processLoaderData(\n state,\n state.matches,\n matchesToLoad,\n loaderResults,\n undefined,\n revalidatingFetchers,\n fetcherResults,\n activeDeferreds\n );\n\n let doneFetcher: FetcherStates[\"Idle\"] = {\n state: \"idle\",\n data: actionResult.data,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n };\n state.fetchers.set(key, doneFetcher);\n\n let didAbortFetchLoads = 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(state.loaderData, loaderData, matches),\n ...(didAbortFetchLoads ? { 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 ) {\n let existingFetcher = state.fetchers.get(key);\n // Put this fetcher into it's loading state\n let loadingFetcher: FetcherStates[\"Loading\"] = {\n state: \"loading\",\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n data: existingFetcher && existingFetcher.data,\n };\n state.fetchers.set(key, loadingFetcher);\n updateState({ fetchers: new Map(state.fetchers) });\n\n // Call the loader for this fetcher route match\n let abortController = new AbortController();\n let fetchRequest = createRequest(path, abortController.signal);\n fetchControllers.set(key, abortController);\n let result: DataResult = await callLoaderOrAction(\n \"loader\",\n fetchRequest,\n match,\n matches,\n router.basename\n );\n\n // Deferred isn't supported or 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 ou 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 // If the loader threw a redirect Response, start a new REPLACE navigation\n if (isRedirectResult(result)) {\n let redirectNavigation = getLoaderRedirect(state, result);\n await startRedirectNavigation(result, redirectNavigation);\n return;\n }\n\n // Process any non-redirect errors thrown\n if (isErrorResult(result)) {\n let boundaryMatch = findNearestBoundary(state.matches, routeId);\n state.fetchers.delete(key);\n // TODO: In remix, this would reset to IDLE_NAVIGATION if it was a catch -\n // do we need to behave any differently with our non-redirect errors?\n // What if it was a non-redirect Response?\n updateState({\n fetchers: new Map(state.fetchers),\n errors: {\n [boundaryMatch.route.id]: result.error,\n },\n });\n return;\n }\n\n invariant(!isDeferredResult(result), \"Unhandled fetcher deferred data\");\n\n // Put the fetcher back into an idle state\n let doneFetcher: FetcherStates[\"Idle\"] = {\n state: \"idle\",\n data: result.data,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n };\n state.fetchers.set(key, doneFetcher);\n updateState({ fetchers: new Map(state.fetchers) });\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 redirect: RedirectResult,\n navigation: Navigation,\n replace?: boolean\n ) {\n if (redirect.revalidate) {\n isRevalidationRequired = true;\n }\n invariant(\n navigation.location,\n \"Expected a location on the redirect navigation\"\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 ? HistoryAction.Replace : HistoryAction.Push;\n\n await startNavigation(redirectHistoryAction, navigation.location, {\n overrideNavigation: navigation,\n });\n }\n\n async function callLoadersAndMaybeResolveData(\n currentMatches: AgnosticDataRouteMatch[],\n matches: AgnosticDataRouteMatch[],\n matchesToLoad: AgnosticDataRouteMatch[],\n fetchersToLoad: RevalidatingFetcher[],\n request: Request\n ) {\n // Call all navigation loaders and revalidating fetcher loaders in parallel,\n // then slice off the results into separate arrays so we can handle them\n // accordingly\n let results = await Promise.all([\n ...matchesToLoad.map((match) =>\n callLoaderOrAction(\"loader\", request, match, matches, router.basename)\n ),\n ...fetchersToLoad.map(([, href, match, fetchMatches]) =>\n callLoaderOrAction(\n \"loader\",\n createRequest(href, request.signal),\n match,\n fetchMatches,\n router.basename\n )\n ),\n ]);\n let loaderResults = results.slice(0, matchesToLoad.length);\n let fetcherResults = results.slice(matchesToLoad.length);\n\n await Promise.all([\n resolveDeferredResults(\n currentMatches,\n matchesToLoad,\n loaderResults,\n request.signal,\n false,\n state.loaderData\n ),\n resolveDeferredResults(\n currentMatches,\n fetchersToLoad.map(([, , match]) => match),\n fetcherResults,\n request.signal,\n true\n ),\n ]);\n\n return { results, loaderResults, fetcherResults };\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.push(key);\n abortFetcher(key);\n }\n });\n }\n\n function setFetcherError(key: string, routeId: string, error: any) {\n let boundaryMatch = findNearestBoundary(state.matches, routeId);\n deleteFetcher(key);\n updateState({\n errors: {\n [boundaryMatch.route.id]: error,\n },\n fetchers: new Map(state.fetchers),\n });\n }\n\n function deleteFetcher(key: string): void {\n if (fetchControllers.has(key)) abortFetcher(key);\n fetchLoadMatches.delete(key);\n fetchReloadIds.delete(key);\n fetchRedirectIds.delete(key);\n state.fetchers.delete(key);\n }\n\n function abortFetcher(key: string) {\n let controller = fetchControllers.get(key);\n invariant(controller, `Expected fetch controller: ${key}`);\n controller.abort();\n fetchControllers.delete(key);\n }\n\n function markFetchersDone(keys: string[]) {\n for (let key of keys) {\n let fetcher = getFetcher(key);\n let doneFetcher: FetcherStates[\"Idle\"] = {\n state: \"idle\",\n data: fetcher.data,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n };\n state.fetchers.set(key, doneFetcher);\n }\n }\n\n function markFetchRedirectsDone(): void {\n let doneKeys = [];\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 }\n }\n markFetchersDone(doneKeys);\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 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 || ((location) => location.key);\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 saveScrollPosition(\n location: Location,\n matches: AgnosticDataRouteMatch[]\n ): void {\n if (savedScrollPositions && getScrollRestorationKey && getScrollPosition) {\n let userMatches = matches.map((m) =>\n createUseMatchesMatch(m, state.loaderData)\n );\n let key = getScrollRestorationKey(location, userMatches) || location.key;\n savedScrollPositions[key] = getScrollPosition();\n }\n }\n\n function getSavedScrollPosition(\n location: Location,\n matches: AgnosticDataRouteMatch[]\n ): number | null {\n if (savedScrollPositions && getScrollRestorationKey && getScrollPosition) {\n let userMatches = matches.map((m) =>\n createUseMatchesMatch(m, state.loaderData)\n );\n let key = getScrollRestorationKey(location, userMatches) || location.key;\n let y = savedScrollPositions[key];\n if (typeof y === \"number\") {\n return y;\n }\n }\n return null;\n }\n\n router = {\n get basename() {\n return init.basename;\n },\n get state() {\n return state;\n },\n get routes() {\n return dataRoutes;\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 getFetcher,\n deleteFetcher,\n dispose,\n _internalFetchControllers: fetchControllers,\n _internalActiveDeferreds: activeDeferreds,\n };\n\n return router;\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region createStaticHandler\n////////////////////////////////////////////////////////////////////////////////\n\nconst validActionMethods = new Set([\"POST\", \"PUT\", \"PATCH\", \"DELETE\"]);\nconst validRequestMethods = new Set([\"GET\", \"HEAD\", ...validActionMethods]);\n\nexport function unstable_createStaticHandler(\n routes: AgnosticRouteObject[]\n): StaticHandler {\n invariant(\n routes.length > 0,\n \"You must provide a non-empty routes array to unstable_createStaticHandler\"\n );\n\n let dataRoutes = convertRoutesToDataRoutes(routes);\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 async function query(\n request: Request\n ): Promise {\n let url = new URL(request.url);\n let location = createLocation(\"\", createPath(url), null, \"default\");\n let matches = matchRoutes(dataRoutes, location);\n\n if (!validRequestMethods.has(request.method)) {\n let {\n matches: methodNotAllowedMatches,\n route,\n error,\n } = getMethodNotAllowedMatches(dataRoutes);\n return {\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 };\n } else if (!matches) {\n let {\n matches: notFoundMatches,\n route,\n error,\n } = getNotFoundMatches(dataRoutes);\n return {\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 };\n }\n\n let result = await queryImpl(request, location, matches);\n if (result instanceof Response) {\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, ...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 thrown Response (such as a\n * 404 or 405) will have a custom X-Remix-Router-Error: \"yes\" header on it\n * in order to differentiate from responses thrown from user actions/loaders.\n */\n async function queryRoute(request: Request, routeId?: string): Promise {\n let url = new URL(request.url);\n let location = createLocation(\"\", createPath(url), null, \"default\");\n let matches = matchRoutes(dataRoutes, location);\n\n if (!validRequestMethods.has(request.method)) {\n throw createRouterErrorResponse(null, {\n status: 405,\n statusText: \"Method Not Allowed\",\n });\n } else if (!matches) {\n throw createRouterErrorResponse(null, {\n status: 404,\n statusText: \"Not Found\",\n });\n }\n\n let match = routeId\n ? matches.find((m) => m.route.id === routeId)\n : getTargetMatch(matches, location);\n\n if (!match) {\n throw createRouterErrorResponse(null, {\n status: 404,\n statusText: \"Not Found\",\n });\n }\n\n let result = await queryImpl(request, location, matches, match);\n if (result instanceof Response) {\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 let routeData = [result.actionData, result.loaderData].find((v) => v);\n return Object.values(routeData || {})[0];\n }\n\n async function queryImpl(\n request: Request,\n location: Location,\n matches: AgnosticDataRouteMatch[],\n routeMatch?: AgnosticDataRouteMatch\n ): Promise | Response> {\n invariant(\n request.signal,\n \"query()/queryRoute() requests must contain an AbortController signal\"\n );\n\n try {\n if (validActionMethods.has(request.method)) {\n let result = await submit(\n request,\n matches,\n routeMatch || getTargetMatch(matches, location),\n routeMatch != null\n );\n return result;\n }\n\n let result = await loadRouteData(request, matches, routeMatch);\n return result instanceof Response\n ? result\n : {\n ...result,\n actionData: null,\n actionHeaders: {},\n };\n } catch (e) {\n // If the user threw/returned a Response in callLoaderOrAction, we throw\n // it to bail out and then return or throw here based on whether the user\n // returned or threw\n if (isQueryRouteResponse(e)) {\n if (e.type === ResultType.error && !isRedirectResponse(e.response)) {\n throw e.response;\n }\n return e.response;\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 isRouteRequest: boolean\n ): Promise | Response> {\n let result: DataResult;\n if (!actionMatch.route.action) {\n if (isRouteRequest) {\n throw createRouterErrorResponse(null, {\n status: 405,\n statusText: \"Method Not Allowed\",\n });\n }\n result = getMethodNotAllowedResult(request.url);\n } else {\n result = await callLoaderOrAction(\n \"action\",\n request,\n actionMatch,\n matches,\n undefined, // Basename not currently supported in static handlers\n true,\n isRouteRequest\n );\n\n if (request.signal.aborted) {\n let method = isRouteRequest ? \"queryRoute\" : \"query\";\n throw new Error(`${method}() call aborted`);\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.status,\n headers: {\n Location: result.location,\n },\n });\n }\n\n if (isDeferredResult(result)) {\n throw new Error(\"defer() is not supported in actions\");\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 let boundaryMatch = findNearestBoundary(matches, actionMatch.route.id);\n return {\n matches: [actionMatch],\n loaderData: {},\n actionData: null,\n errors: {\n [boundaryMatch.route.id]: result.error,\n },\n // Note: statusCode + headers are unused here since queryRoute will\n // return the raw Response or value\n statusCode: 500,\n loaderHeaders: {},\n actionHeaders: {},\n };\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 };\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 let context = await loadRouteData(request, matches, undefined, {\n [boundaryMatch.route.id]: result.error,\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 : 500,\n actionData: null,\n actionHeaders: {\n ...(result.headers ? { [actionMatch.route.id]: result.headers } : {}),\n },\n };\n }\n\n let context = await loadRouteData(request, matches);\n\n return {\n ...context,\n // action status codes take precedence over loader status codes\n ...(result.statusCode ? { statusCode: result.statusCode } : {}),\n actionData: {\n [actionMatch.route.id]: result.data,\n },\n actionHeaders: {\n ...(result.headers ? { [actionMatch.route.id]: result.headers } : {}),\n },\n };\n }\n\n async function loadRouteData(\n request: Request,\n matches: AgnosticDataRouteMatch[],\n routeMatch?: AgnosticDataRouteMatch,\n pendingActionError?: RouteData\n ): Promise<\n | Omit\n | Response\n > {\n let isRouteRequest = routeMatch != null;\n let requestMatches = routeMatch\n ? [routeMatch]\n : getLoaderMatchesUntilBoundary(\n matches,\n Object.keys(pendingActionError || {})[0]\n );\n let matchesToLoad = requestMatches.filter((m) => m.route.loader);\n\n // Short circuit if we have no loaders to run\n if (matchesToLoad.length === 0) {\n return {\n matches,\n loaderData: {},\n errors: pendingActionError || null,\n statusCode: 200,\n loaderHeaders: {},\n };\n }\n\n let results = await Promise.all([\n ...matchesToLoad.map((match) =>\n callLoaderOrAction(\n \"loader\",\n request,\n match,\n matches,\n undefined, // Basename not currently supported in static handlers\n true,\n isRouteRequest\n )\n ),\n ]);\n\n if (request.signal.aborted) {\n let method = isRouteRequest ? \"queryRoute\" : \"query\";\n throw new Error(`${method}() call aborted`);\n }\n\n // Can't do anything with these without the Remix side of things, so just\n // cancel them for now\n results.forEach((result) => {\n if (isDeferredResult(result)) {\n result.deferredData.cancel();\n }\n });\n\n // Process and commit output from loaders\n let context = processRouteLoaderData(\n matches,\n matchesToLoad,\n results,\n pendingActionError\n );\n\n return {\n ...context,\n matches,\n };\n }\n\n function createRouterErrorResponse(\n body: BodyInit | null | undefined,\n init: ResponseInit\n ) {\n return new Response(body, {\n ...init,\n headers: {\n ...init.headers,\n \"X-Remix-Router-Error\": \"yes\",\n },\n });\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: 500,\n errors: {\n [context._deepestRenderedBoundaryId || routes[0].id]: error,\n },\n };\n return newContext;\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 to: To,\n opts?: RouterNavigateOptions,\n isFetcher = false\n): {\n path: string;\n submission?: Submission;\n error?: ErrorResponse;\n} {\n let path = typeof to === \"string\" ? to : createPath(to);\n\n // Return location verbatim on non-submission navigations\n if (!opts || (!(\"formMethod\" in opts) && !(\"formData\" in opts))) {\n return { path };\n }\n\n // Create a Submission on non-GET navigations\n if (opts.formMethod != null && opts.formMethod !== \"get\") {\n return {\n path,\n submission: {\n formMethod: opts.formMethod,\n formAction: stripHashFromPath(path),\n formEncType:\n (opts && opts.formEncType) || \"application/x-www-form-urlencoded\",\n formData: opts.formData,\n },\n };\n }\n\n // No formData to flatten for GET submission\n if (!opts.formData) {\n return { path };\n }\n\n // Flatten submission onto URLSearchParams for GET submissions\n let parsedPath = parsePath(path);\n try {\n let searchParams = convertFormDataToSearchParams(opts.formData);\n // Since fetcher GET submissions only run a single loader (as opposed to\n // navigation GET submissions which run all loaders), we need to preserve\n // any incoming ?index params\n if (\n isFetcher &&\n parsedPath.search &&\n hasNakedIndexQuery(parsedPath.search)\n ) {\n searchParams.append(\"index\", \"\");\n }\n parsedPath.search = `?${searchParams}`;\n } catch (e) {\n return {\n path,\n error: new ErrorResponse(\n 400,\n \"Bad Request\",\n \"Cannot submit binary form data using GET\"\n ),\n };\n }\n\n return { path: createPath(parsedPath) };\n}\n\nfunction getLoaderRedirect(\n state: RouterState,\n redirect: RedirectResult\n): Navigation {\n let { formMethod, formAction, formEncType, formData } = state.navigation;\n let navigation: NavigationStates[\"Loading\"] = {\n state: \"loading\",\n location: createLocation(state.location, redirect.location),\n formMethod: formMethod || undefined,\n formAction: formAction || undefined,\n formEncType: formEncType || undefined,\n formData: formData || undefined,\n };\n return navigation;\n}\n\n// Filter out all routes 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) {\n let boundaryMatches = matches;\n if (boundaryId) {\n let index = matches.findIndex((m) => m.route.id === boundaryId);\n if (index >= 0) {\n boundaryMatches = matches.slice(0, index);\n }\n }\n return boundaryMatches;\n}\n\nfunction getMatchesToLoad(\n state: RouterState,\n matches: AgnosticDataRouteMatch[],\n submission: Submission | undefined,\n location: Location,\n isRevalidationRequired: boolean,\n cancelledDeferredRoutes: string[],\n cancelledFetcherLoads: string[],\n pendingActionData?: RouteData,\n pendingError?: RouteData,\n fetchLoadMatches?: Map\n): [AgnosticDataRouteMatch[], RevalidatingFetcher[]] {\n let actionResult = pendingError\n ? Object.values(pendingError)[0]\n : pendingActionData\n ? Object.values(pendingActionData)[0]\n : null;\n\n // Pick navigation matches that are net-new or qualify for revalidation\n let boundaryId = pendingError ? Object.keys(pendingError)[0] : undefined;\n let boundaryMatches = getLoaderMatchesUntilBoundary(matches, boundaryId);\n let navigationMatches = boundaryMatches.filter(\n (match, index) =>\n match.route.loader != null &&\n (isNewLoader(state.loaderData, state.matches[index], match) ||\n // If this route had a pending deferred cancelled it must be revalidated\n cancelledDeferredRoutes.some((id) => id === match.route.id) ||\n shouldRevalidateLoader(\n state.location,\n state.matches[index],\n submission,\n location,\n match,\n isRevalidationRequired,\n actionResult\n ))\n );\n\n // Pick fetcher.loads that need to be revalidated\n let revalidatingFetchers: RevalidatingFetcher[] = [];\n fetchLoadMatches &&\n fetchLoadMatches.forEach(([href, match, fetchMatches], key) => {\n // This fetcher was cancelled from a prior action submission - force reload\n if (cancelledFetcherLoads.includes(key)) {\n revalidatingFetchers.push([key, href, match, fetchMatches]);\n } else if (isRevalidationRequired) {\n let shouldRevalidate = shouldRevalidateLoader(\n href,\n match,\n submission,\n href,\n match,\n isRevalidationRequired,\n actionResult\n );\n if (shouldRevalidate) {\n revalidatingFetchers.push([key, href, match, fetchMatches]);\n }\n }\n });\n\n return [navigationMatches, revalidatingFetchers];\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 &&\n currentPath.endsWith(\"*\") &&\n currentMatch.params[\"*\"] !== match.params[\"*\"])\n );\n}\n\nfunction shouldRevalidateLoader(\n currentLocation: string | Location,\n currentMatch: AgnosticDataRouteMatch,\n submission: Submission | undefined,\n location: string | Location,\n match: AgnosticDataRouteMatch,\n isRevalidationRequired: boolean,\n actionResult: DataResult | undefined\n) {\n let currentUrl = createURL(currentLocation);\n let currentParams = currentMatch.params;\n let nextUrl = createURL(location);\n let nextParams = match.params;\n\n // This is the default implementation as to 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 // Note that fetchers always provide the same current/next locations so the\n // URL-based checks here don't apply to fetcher shouldRevalidate calls\n let defaultShouldRevalidate =\n isNewRouteInstance(currentMatch, match) ||\n // Clicked the same link, resubmitted a GET form\n currentUrl.toString() === nextUrl.toString() ||\n // Search params affect all loaders\n currentUrl.search !== nextUrl.search ||\n // Forced revalidation due to submission, useRevalidate, or X-Remix-Revalidate\n isRevalidationRequired;\n\n if (match.route.shouldRevalidate) {\n let routeChoice = match.route.shouldRevalidate({\n currentUrl,\n currentParams,\n nextUrl,\n nextParams,\n ...submission,\n actionResult,\n defaultShouldRevalidate,\n });\n if (typeof routeChoice === \"boolean\") {\n return routeChoice;\n }\n }\n\n return defaultShouldRevalidate;\n}\n\nasync function callLoaderOrAction(\n type: \"loader\" | \"action\",\n request: Request,\n match: AgnosticDataRouteMatch,\n matches: AgnosticDataRouteMatch[],\n basename: string | undefined,\n isStaticRequest: boolean = false,\n isRouteRequest: boolean = false\n): Promise {\n let resultType;\n let result;\n\n // Setup a promise we can race against so that abort signals short circuit\n let reject: () => void;\n let abortPromise = new Promise((_, r) => (reject = r));\n let onReject = () => reject();\n request.signal.addEventListener(\"abort\", onReject);\n\n try {\n let handler = match.route[type];\n invariant(\n handler,\n `Could not find the ${type} to run on the \"${match.route.id}\" route`\n );\n\n result = await Promise.race([\n handler({ request, params: match.params }),\n abortPromise,\n ]);\n } catch (e) {\n resultType = ResultType.error;\n result = e;\n } finally {\n request.signal.removeEventListener(\"abort\", onReject);\n }\n\n if (result instanceof Response) {\n let status = result.status;\n\n // Process redirects\n if (status >= 300 && status <= 399) {\n let location = result.headers.get(\"Location\");\n invariant(\n location,\n \"Redirects returned/thrown from loaders/actions must have a Location header\"\n );\n\n // Support relative routing in redirects\n let activeMatches = matches.slice(0, matches.indexOf(match) + 1);\n let routePathnames = getPathContributingMatches(activeMatches).map(\n (match) => match.pathnameBase\n );\n let requestPath = createURL(request.url).pathname;\n let resolvedLocation = resolveTo(location, routePathnames, requestPath);\n invariant(\n createPath(resolvedLocation),\n `Unable to resolve redirect location: ${result.headers.get(\"Location\")}`\n );\n\n // Prepend the basename to the redirect location if we have one\n if (basename) {\n let path = resolvedLocation.pathname;\n resolvedLocation.pathname =\n path === \"/\" ? basename : joinPaths([basename, path]);\n }\n\n location = createPath(resolvedLocation);\n\n // Don't process redirects in the router during static requests requests.\n // Instead, throw the Response and let the server handle it with an HTTP\n // redirect. We also update the Location header in place in this flow so\n // basename and relative routing is taken into account\n if (isStaticRequest) {\n result.headers.set(\"Location\", location);\n throw result;\n }\n\n return {\n type: ResultType.redirect,\n status,\n location,\n revalidate: result.headers.get(\"X-Remix-Revalidate\") !== null,\n };\n }\n\n // For SSR single-route requests, we want to hand Responses back directly\n // without unwrapping. We do this with the QueryRouteResponse wrapper\n // interface so we can know whether it was returned or thrown\n if (isRouteRequest) {\n // eslint-disable-next-line no-throw-literal\n throw {\n type: resultType || ResultType.data,\n response: result,\n };\n }\n\n let data: any;\n let contentType = result.headers.get(\"Content-Type\");\n if (contentType && contentType.startsWith(\"application/json\")) {\n data = await result.json();\n } else {\n data = await result.text();\n }\n\n if (resultType === ResultType.error) {\n return {\n type: resultType,\n error: new ErrorResponse(status, result.statusText, data),\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 (resultType === ResultType.error) {\n return { type: resultType, error: result };\n }\n\n if (result instanceof DeferredData) {\n return { type: ResultType.deferred, deferredData: result };\n }\n\n return { type: ResultType.data, data: result };\n}\n\nfunction createRequest(\n location: string | Location,\n signal: AbortSignal,\n submission?: Submission\n): Request {\n let url = createURL(stripHashFromPath(location)).toString();\n let init: RequestInit = { signal };\n\n if (submission) {\n let { formMethod, formEncType, formData } = submission;\n init.method = formMethod.toUpperCase();\n init.body =\n formEncType === \"application/x-www-form-urlencoded\"\n ? convertFormDataToSearchParams(formData)\n : formData;\n }\n\n // Content-Type is inferred (https://fetch.spec.whatwg.org/#dom-request)\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 invariant(\n typeof value === \"string\",\n 'File inputs are not supported with encType \"application/x-www-form-urlencoded\", ' +\n 'please use \"multipart/form-data\" instead.'\n );\n searchParams.append(key, value);\n }\n\n return searchParams;\n}\n\nfunction processRouteLoaderData(\n matches: AgnosticDataRouteMatch[],\n matchesToLoad: AgnosticDataRouteMatch[],\n results: DataResult[],\n pendingError: RouteData | undefined,\n activeDeferreds?: Map\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\n // Process loader results into state.loaderData/state.errors\n results.forEach((result, index) => {\n let id = matchesToLoad[index].route.id;\n invariant(\n !isRedirectResult(result),\n \"Cannot handle redirect results in processLoaderData\"\n );\n if (isErrorResult(result)) {\n // Look upwards from the matched route for the closest ancestor\n // error boundary, defaulting to the root match\n let boundaryMatch = findNearestBoundary(matches, id);\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) {\n error = Object.values(pendingError)[0];\n pendingError = undefined;\n }\n errors = Object.assign(errors || {}, {\n [boundaryMatch.route.id]: error,\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 if (isDeferredResult(result)) {\n activeDeferreds && activeDeferreds.set(id, result.deferredData);\n loaderData[id] = result.deferredData.data;\n // TODO: Add statusCode/headers once we wire up streaming in Remix\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 (\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 }\n });\n\n // If we didn't consume the pending action error (i.e., all loaders\n // resolved), then consume it here\n if (pendingError) {\n errors = pendingError;\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 matchesToLoad: AgnosticDataRouteMatch[],\n results: DataResult[],\n pendingError: RouteData | undefined,\n revalidatingFetchers: RevalidatingFetcher[],\n fetcherResults: DataResult[],\n activeDeferreds: Map\n): {\n loaderData: RouterState[\"loaderData\"];\n errors?: RouterState[\"errors\"];\n} {\n let { loaderData, errors } = processRouteLoaderData(\n matches,\n matchesToLoad,\n results,\n pendingError,\n activeDeferreds\n );\n\n // Process results from our revalidating fetchers\n for (let index = 0; index < revalidatingFetchers.length; index++) {\n let [key, , match] = revalidatingFetchers[index];\n invariant(\n fetcherResults !== undefined && fetcherResults[index] !== undefined,\n \"Did not find corresponding fetcher result\"\n );\n let result = fetcherResults[index];\n\n // Process fetcher non-redirect errors\n 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 throw new Error(\"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 throw new Error(\"Unhandled fetcher deferred data\");\n } else {\n let doneFetcher: FetcherStates[\"Idle\"] = {\n state: \"idle\",\n data: result.data,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n };\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): RouteData {\n let mergedLoaderData = { ...newLoaderData };\n matches.forEach((match) => {\n let id = match.route.id;\n if (newLoaderData[id] === undefined && loaderData[id] !== undefined) {\n mergedLoaderData[id] = loaderData[id];\n }\n });\n return mergedLoaderData;\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(\n routes: AgnosticDataRouteObject[],\n status: number,\n statusText: string\n): {\n matches: AgnosticDataRouteMatch[];\n route: AgnosticDataRouteObject;\n error: ErrorResponse;\n} {\n // Prefer a root layout route if present, otherwise shim in a route object\n let route = routes.find((r) => r.index || !r.path || r.path === \"/\") || {\n id: `__shim-${status}-route__`,\n };\n\n return {\n matches: [\n {\n params: {},\n pathname: \"\",\n pathnameBase: \"\",\n route,\n },\n ],\n route,\n error: new ErrorResponse(status, statusText, null),\n };\n}\n\nfunction getNotFoundMatches(routes: AgnosticDataRouteObject[]) {\n return getShortCircuitMatches(routes, 404, \"Not Found\");\n}\n\nfunction getMethodNotAllowedMatches(routes: AgnosticDataRouteObject[]) {\n return getShortCircuitMatches(routes, 405, \"Method Not Allowed\");\n}\n\nfunction getMethodNotAllowedResult(path: Location | string): ErrorResult {\n let href = typeof path === \"string\" ? path : createPath(path);\n console.warn(\n \"You're trying to submit to a route that does not have an action. To \" +\n \"fix this, please add an `action` function to the route for \" +\n `[${href}]`\n );\n return {\n type: ResultType.error,\n error: new ErrorResponse(405, \"Method Not Allowed\", \"\"),\n };\n}\n\n// Find any returned redirect errors, starting from the lowest match\nfunction findRedirect(results: DataResult[]): RedirectResult | undefined {\n for (let i = results.length - 1; i >= 0; i--) {\n let result = results[i];\n if (isRedirectResult(result)) {\n return 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 return (\n a.pathname === b.pathname && a.search === b.search && a.hash !== b.hash\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\nfunction isRedirectResponse(result: any): result is Response {\n if (!(result instanceof Response)) {\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 isQueryRouteResponse(obj: any): obj is QueryRouteResponse {\n return (\n obj &&\n obj.response instanceof Response &&\n (obj.type === ResultType.data || ResultType.error)\n );\n}\n\nasync function resolveDeferredResults(\n currentMatches: AgnosticDataRouteMatch[],\n matchesToLoad: AgnosticDataRouteMatch[],\n results: DataResult[],\n signal: AbortSignal,\n isFetcher: boolean,\n currentLoaderData?: RouteData\n) {\n for (let index = 0; index < results.length; index++) {\n let result = results[index];\n let match = matchesToLoad[index];\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) && (isFetcher || 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, isFetcher).then((result) => {\n if (result) {\n results[index] = result || results[index];\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\n// Note: This should match the format exported by useMatches, so if you change\n// this please also change that :) Eventually we'll DRY this up\nfunction createUseMatchesMatch(\n match: AgnosticDataRouteMatch,\n loaderData: RouteData\n): UseMatchesMatch {\n let { route, pathname, params } = match;\n return {\n id: route.id,\n pathname,\n params,\n data: loaderData[route.id] as unknown,\n handle: route.handle as unknown,\n };\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//#endregion\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\nimport * as React from \"react\";\n\n/**\n * inlined Object.is polyfill to avoid requiring consumers ship their own\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is\n */\nfunction isPolyfill(x: any, y: any) {\n return (\n (x === y && (x !== 0 || 1 / x === 1 / y)) || (x !== x && y !== y) // eslint-disable-line no-self-compare\n );\n}\n\nconst is: (x: any, y: any) => boolean =\n typeof Object.is === \"function\" ? Object.is : isPolyfill;\n\n// Intentionally not using named imports because Rollup uses dynamic\n// dispatch for CommonJS interop named imports.\nconst { useState, useEffect, useLayoutEffect, useDebugValue } = React;\n\nlet didWarnOld18Alpha = false;\nlet didWarnUncachedGetSnapshot = false;\n\n// Disclaimer: This shim breaks many of the rules of React, and only works\n// because of a very particular set of implementation details and assumptions\n// -- change any one of them and it will break. The most important assumption\n// is that updates are always synchronous, because concurrent rendering is\n// only available in versions of React that also have a built-in\n// useSyncExternalStore API. And we only use this shim when the built-in API\n// does not exist.\n//\n// Do not assume that the clever hacks used by this hook also work in general.\n// The point of this shim is to replace the need for hacks by other libraries.\nexport function useSyncExternalStore(\n subscribe: (fn: () => void) => () => void,\n getSnapshot: () => T,\n // Note: The shim does not use getServerSnapshot, because pre-18 versions of\n // React do not expose a way to check if we're hydrating. So users of the shim\n // will need to track that themselves and return the correct value\n // from `getSnapshot`.\n getServerSnapshot?: () => T\n): T {\n if (__DEV__) {\n if (!didWarnOld18Alpha) {\n if (\"startTransition\" in React) {\n didWarnOld18Alpha = true;\n console.error(\n \"You are using an outdated, pre-release alpha of React 18 that \" +\n \"does not support useSyncExternalStore. The \" +\n \"use-sync-external-store shim will not work correctly. Upgrade \" +\n \"to a newer pre-release.\"\n );\n }\n }\n }\n\n // Read the current snapshot from the store on every render. Again, this\n // breaks the rules of React, and only works here because of specific\n // implementation details, most importantly that updates are\n // always synchronous.\n const value = getSnapshot();\n if (__DEV__) {\n if (!didWarnUncachedGetSnapshot) {\n const cachedValue = getSnapshot();\n if (!is(value, cachedValue)) {\n console.error(\n \"The result of getSnapshot should be cached to avoid an infinite loop\"\n );\n didWarnUncachedGetSnapshot = true;\n }\n }\n }\n\n // Because updates are synchronous, we don't queue them. Instead we force a\n // re-render whenever the subscribed state changes by updating an some\n // arbitrary useState hook. Then, during render, we call getSnapshot to read\n // the current value.\n //\n // Because we don't actually use the state returned by the useState hook, we\n // can save a bit of memory by storing other stuff in that slot.\n //\n // To implement the early bailout, we need to track some things on a mutable\n // object. Usually, we would put that in a useRef hook, but we can stash it in\n // our useState hook instead.\n //\n // To force a re-render, we call forceUpdate({inst}). That works because the\n // new object always fails an equality check.\n const [{ inst }, forceUpdate] = useState({ inst: { value, getSnapshot } });\n\n // Track the latest getSnapshot function with a ref. This needs to be updated\n // in the layout phase so we can access it during the tearing check that\n // happens on subscribe.\n useLayoutEffect(() => {\n inst.value = value;\n inst.getSnapshot = getSnapshot;\n\n // Whenever getSnapshot or subscribe changes, we need to check in the\n // commit phase if there was an interleaved mutation. In concurrent mode\n // this can happen all the time, but even in synchronous mode, an earlier\n // effect may have mutated the store.\n if (checkIfSnapshotChanged(inst)) {\n // Force a re-render.\n forceUpdate({ inst });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [subscribe, value, getSnapshot]);\n\n useEffect(() => {\n // Check for changes right before subscribing. Subsequent changes will be\n // detected in the subscription handler.\n if (checkIfSnapshotChanged(inst)) {\n // Force a re-render.\n forceUpdate({ inst });\n }\n const handleStoreChange = () => {\n // TODO: Because there is no cross-renderer API for batching updates, it's\n // up to the consumer of this library to wrap their subscription event\n // with unstable_batchedUpdates. Should we try to detect when this isn't\n // the case and print a warning in development?\n\n // The store changed. Check if the snapshot changed since the last time we\n // read from the store.\n if (checkIfSnapshotChanged(inst)) {\n // Force a re-render.\n forceUpdate({ inst });\n }\n };\n // Subscribe to the store and return a clean-up function.\n return subscribe(handleStoreChange);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [subscribe]);\n\n useDebugValue(value);\n return value;\n}\n\nfunction checkIfSnapshotChanged(inst: any) {\n const latestGetSnapshot = inst.getSnapshot;\n const prevValue = inst.value;\n try {\n const nextValue = latestGetSnapshot();\n return !is(prevValue, nextValue);\n } catch (error) {\n return true;\n }\n}\n","/**\n * Inlined into the react-router repo since use-sync-external-store does not\n * provide a UMD-compatible package, so we need this to be able to distribute\n * UMD react-router bundles\n */\n\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 * @flow\n */\n\nimport * as React from \"react\";\n\nimport { useSyncExternalStore as client } from \"./useSyncExternalStoreShimClient\";\nimport { useSyncExternalStore as server } from \"./useSyncExternalStoreShimServer\";\n\nconst canUseDOM: boolean = !!(\n typeof window !== \"undefined\" &&\n typeof window.document !== \"undefined\" &&\n typeof window.document.createElement !== \"undefined\"\n);\nconst isServerEnvironment = !canUseDOM;\nconst shim = isServerEnvironment ? server : client;\n\nexport const useSyncExternalStore =\n \"useSyncExternalStore\" in React\n ? ((module) => module.useSyncExternalStore)(React)\n : shim;\n","import * as React from \"react\";\nimport type {\n AgnosticRouteMatch,\n AgnosticIndexRouteObject,\n AgnosticNonIndexRouteObject,\n History,\n Location,\n Router,\n StaticHandlerContext,\n To,\n TrackedPromise,\n} from \"@remix-run/router\";\nimport type { Action as NavigationType } 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 errorElement?: React.ReactNode | null;\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 errorElement?: React.ReactNode | null;\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\n// Contexts for data routers\nexport const DataStaticRouterContext =\n React.createContext(null);\nif (__DEV__) {\n DataStaticRouterContext.displayName = \"DataStaticRouterContext\";\n}\n\nexport interface DataRouterContextObject extends NavigationContextObject {\n router: Router;\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 type RelativeRoutingType = \"route\" | \"path\";\n\nexport interface NavigateOptions {\n replace?: boolean;\n state?: any;\n preventScrollReset?: boolean;\n relative?: RelativeRoutingType;\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 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}\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}\n\nexport const RouteContext = React.createContext({\n outlet: null,\n matches: [],\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 Location,\n ParamParseKey,\n Params,\n Path,\n PathMatch,\n PathPattern,\n Router as RemixRouter,\n To,\n} from \"@remix-run/router\";\nimport {\n Action as NavigationType,\n invariant,\n isRouteErrorResponse,\n joinPaths,\n matchPath,\n matchRoutes,\n parsePath,\n resolveTo,\n warning,\n UNSAFE_getPathContributingMatches as getPathContributingMatches,\n} from \"@remix-run/router\";\n\nimport type {\n NavigateOptions,\n RouteContextObject,\n RouteMatch,\n RouteObject,\n DataRouteMatch,\n RelativeRoutingType,\n} from \"./context\";\nimport {\n DataRouterContext,\n DataRouterStateContext,\n LocationContext,\n NavigationContext,\n RouteContext,\n RouteErrorContext,\n AwaitContext,\n DataStaticRouterContext,\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/docs/en/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/docs/en/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/docs/en/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/docs/en/v6/hooks/use-navigation-type\n */\nexport function useNavigationType(): NavigationType {\n return React.useContext(LocationContext).navigationType;\n}\n\n/**\n * Returns true if the URL for the given \"to\" value 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/docs/en/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, 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\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/docs/en/v6/hooks/use-navigate\n */\nexport function useNavigate(): 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 { basename, navigator } = React.useContext(NavigationContext);\n let { matches } = React.useContext(RouteContext);\n let { pathname: locationPathname } = useLocation();\n\n let routePathnamesJson = JSON.stringify(\n getPathContributingMatches(matches).map((match) => match.pathnameBase)\n );\n\n let activeRef = React.useRef(false);\n React.useEffect(() => {\n activeRef.current = true;\n });\n\n let navigate: NavigateFunction = React.useCallback(\n (to: To | number, options: NavigateOptions = {}) => {\n warning(\n activeRef.current,\n `You should call navigate() in a React.useEffect(), not when ` +\n `your component is first rendered.`\n );\n\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. If this is a root navigation, then we\n // navigate to the raw basename which allows the basename to have full\n // control over the presence of a trailing slash on root links\n if (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 [basename, navigator, routePathnamesJson, locationPathname]\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/docs/en/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/docs/en/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/docs/en/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/docs/en/v6/hooks/use-resolved-path\n */\nexport function useResolvedPath(\n to: To,\n { relative }: { relative?: RelativeRoutingType } = {}\n): Path {\n let { matches } = React.useContext(RouteContext);\n let { pathname: locationPathname } = useLocation();\n\n let routePathnamesJson = JSON.stringify(\n getPathContributingMatches(matches).map((match) => match.pathnameBase)\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/docs/en/v6/hooks/use-routes\n */\nexport function useRoutes(\n routes: RouteObject[],\n locationArg?: Partial | string\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 dataRouterStateContext = React.useContext(DataRouterStateContext);\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 let remainingPathname =\n parentPathnameBase === \"/\"\n ? pathname\n : pathname.slice(parentPathnameBase.length) || \"/\";\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 `Matched leaf route at location \"${location.pathname}${location.search}${location.hash}\" does not have an element. ` +\n `This means it will render an with a 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([parentPathnameBase, match.pathname]),\n pathnameBase:\n match.pathnameBase === \"/\"\n ? parentPathnameBase\n : joinPaths([parentPathnameBase, match.pathnameBase]),\n })\n ),\n parentMatches,\n dataRouterStateContext || undefined\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 DefaultErrorElement() {\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 return (\n <>\n

Unhandled Thrown Error!

\n

{message}

\n {stack ?
{stack}
: null}\n

💿 Hey developer 👋

\n

\n You can provide a way better UX than this when your app throws errors by\n providing your own \n errorElement props on \n <Route>\n

\n \n );\n}\n\ntype RenderErrorBoundaryProps = React.PropsWithChildren<{\n location: Location;\n error: any;\n component: React.ReactNode;\n}>;\n\ntype RenderErrorBoundaryState = {\n location: Location;\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 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 (state.location !== props.location) {\n return {\n error: props.error,\n location: props.location,\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 || state.error,\n location: state.location,\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 ? (\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 dataStaticRouterContext = React.useContext(DataStaticRouterContext);\n\n // Track how deep we got in our render pass to emulate SSR componentDidCatch\n // in a DataStaticRouter\n if (dataStaticRouterContext && match.route.errorElement) {\n dataStaticRouterContext._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\"]\n): React.ReactElement | null {\n if (matches == null) {\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 {\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]\n );\n invariant(\n errorIndex >= 0,\n `Could not find a matching route for the current errors: ${errors}`\n );\n renderedMatches = renderedMatches.slice(\n 0,\n Math.min(renderedMatches.length, errorIndex + 1)\n );\n }\n\n return renderedMatches.reduceRight((outlet, match, index) => {\n let error = match.route.id ? errors?.[match.route.id] : null;\n // Only data routers handle errors\n let errorElement = dataRouterState\n ? match.route.errorElement || \n : null;\n let getChildren = () => (\n \n {error\n ? errorElement\n : match.route.element !== undefined\n ? match.route.element\n : outlet}\n \n );\n // Only wrap in an error boundary within data router usages when we have an\n // errorElement on this route. Otherwise let it bubble up to an ancestor\n // errorElement\n return dataRouterState && (match.route.errorElement || index === 0) ? (\n \n ) : (\n getChildren()\n );\n }, null as React.ReactElement | null);\n}\n\nenum DataRouterHook {\n UseRevalidator = \"useRevalidator\",\n}\n\nenum DataRouterStateHook {\n UseLoaderData = \"useLoaderData\",\n UseActionData = \"useActionData\",\n UseRouteError = \"useRouteError\",\n UseNavigation = \"useNavigation\",\n UseRouteLoaderData = \"useRouteLoaderData\",\n UseMatches = \"useMatches\",\n UseRevalidator = \"useRevalidator\",\n}\n\nfunction getDataRouterConsoleError(\n hookName: DataRouterHook | DataRouterStateHook\n) {\n return `${hookName} must be used within a data router. See https://reactrouter.com/en/main/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\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 {\n revalidate: dataRouterContext.router.revalidate,\n state: 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() {\n let { matches, loaderData } = useDataRouterState(\n DataRouterStateHook.UseMatches\n );\n return React.useMemo(\n () =>\n matches.map((match) => {\n let { pathname, params } = match;\n // Note: This structure matches that created by createUseMatchesMatch\n // in the @remix-run/router , so if you change this please also change\n // that :) Eventually we'll DRY this up\n return {\n id: match.route.id,\n pathname,\n params,\n data: loaderData[match.route.id] as unknown,\n handle: match.route.handle as unknown,\n };\n }),\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\n let route = React.useContext(RouteContext);\n invariant(route, `useLoaderData must be used inside a RouteContext`);\n\n let thisRoute = route.matches[route.matches.length - 1];\n invariant(\n thisRoute.route.id,\n `useLoaderData can only be used on routes that contain a unique \"id\"`\n );\n\n return state.loaderData[thisRoute.route.id];\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\n let route = React.useContext(RouteContext);\n invariant(route, `useActionData must be used inside a RouteContext`);\n\n return Object.values(state?.actionData || {})[0];\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 * 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 route = React.useContext(RouteContext);\n let thisRoute = route.matches[route.matches.length - 1];\n\n // If this was a render error, we put it in a RouteError context inside\n // of RenderErrorBoundary\n if (error) {\n return error;\n }\n\n invariant(route, `useRouteError must be used inside a RouteContext`);\n invariant(\n thisRoute.route.id,\n `useRouteError can only be used on routes that contain a unique \"id\"`\n );\n\n // Otherwise look for errors from our data router state\n return state.errors?.[thisRoute.route.id];\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\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 * as React from \"react\";\nimport type {\n TrackedPromise,\n InitialEntry,\n Location,\n MemoryHistory,\n Router as RemixRouter,\n RouterState,\n To,\n} from \"@remix-run/router\";\nimport {\n Action as NavigationType,\n AbortedDeferredError,\n createMemoryHistory,\n invariant,\n parsePath,\n stripBasename,\n warning,\n} from \"@remix-run/router\";\nimport { useSyncExternalStore as useSyncExternalStoreShim } from \"./use-sync-external-store-shim\";\n\nimport type {\n DataRouteObject,\n IndexRouteObject,\n RouteMatch,\n RouteObject,\n Navigator,\n NonIndexRouteObject,\n RelativeRoutingType,\n} from \"./context\";\nimport {\n LocationContext,\n NavigationContext,\n DataRouterContext,\n DataRouterStateContext,\n AwaitContext,\n} from \"./context\";\nimport {\n useAsyncValue,\n useInRouterContext,\n useNavigate,\n useOutlet,\n useRoutes,\n _renderMatches,\n} from \"./hooks\";\n\nexport interface RouterProviderProps {\n fallbackElement?: React.ReactNode;\n router: RemixRouter;\n}\n\n/**\n * Given a Remix Router instance, render the appropriate UI\n */\nexport function RouterProvider({\n fallbackElement,\n router,\n}: RouterProviderProps): React.ReactElement {\n // Sync router state to our component state to force re-renders\n let state: RouterState = useSyncExternalStoreShim(\n router.subscribe,\n () => router.state,\n // We have to provide this so React@18 doesn't complain during hydration,\n // but we pass our serialized hydration data into the router so state here\n // is already synced with what the server saw\n () => router.state\n );\n\n let navigator = React.useMemo((): Navigator => {\n return {\n createHref: router.createHref,\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 return (\n \n \n \n {router.state.initialized ? : fallbackElement}\n
\n \n \n );\n}\n\nexport interface MemoryRouterProps {\n basename?: string;\n children?: React.ReactNode;\n initialEntries?: InitialEntry[];\n initialIndex?: number;\n}\n\n/**\n * A that stores all entries in memory.\n *\n * @see https://reactrouter.com/docs/en/v6/routers/memory-router\n */\nexport function MemoryRouter({\n basename,\n children,\n initialEntries,\n initialIndex,\n}: MemoryRouterProps): React.ReactElement {\n let historyRef = React.useRef();\n if (historyRef.current == null) {\n historyRef.current = createMemoryHistory({\n initialEntries,\n initialIndex,\n v5Compat: true,\n });\n }\n\n let history = historyRef.current;\n let [state, setState] = React.useState({\n action: history.action,\n location: history.location,\n });\n\n React.useLayoutEffect(() => history.listen(setState), [history]);\n\n return (\n \n );\n}\n\nexport interface NavigateProps {\n to: To;\n replace?: boolean;\n state?: any;\n relative?: RelativeRoutingType;\n}\n\n/**\n * Changes the current location.\n *\n * Note: This API is mostly useful in React.Component subclasses that are not\n * able to use hooks. In functional components, we recommend you use the\n * `useNavigate` hook instead.\n *\n * @see https://reactrouter.com/docs/en/v6/components/navigate\n */\nexport function Navigate({\n to,\n replace,\n state,\n relative,\n}: NavigateProps): null {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of\n // the router loaded. We can help them understand how to avoid that.\n ` may be used only in the context of a component.`\n );\n\n warning(\n !React.useContext(NavigationContext).static,\n ` must not be used on the initial render in a . ` +\n `This is a no-op, but you should modify your code so the is ` +\n `only ever rendered in response to some user interaction or state change.`\n );\n\n let dataRouterState = React.useContext(DataRouterStateContext);\n let navigate = useNavigate();\n\n React.useEffect(() => {\n // Avoid kicking off multiple navigations if we're in the middle of a\n // data-router navigation, since components get re-rendered when we enter\n // a submitting/loading state\n if (dataRouterState && dataRouterState.navigation.state !== \"idle\") {\n return;\n }\n navigate(to, { replace, state, relative });\n });\n\n return null;\n}\n\nexport interface OutletProps {\n context?: unknown;\n}\n\n/**\n * Renders the child route's element, if there is one.\n *\n * @see https://reactrouter.com/docs/en/v6/components/outlet\n */\nexport function Outlet(props: OutletProps): React.ReactElement | null {\n return useOutlet(props.context);\n}\n\nexport interface PathRouteProps {\n caseSensitive?: NonIndexRouteObject[\"caseSensitive\"];\n path?: NonIndexRouteObject[\"path\"];\n id?: NonIndexRouteObject[\"id\"];\n loader?: NonIndexRouteObject[\"loader\"];\n action?: NonIndexRouteObject[\"action\"];\n hasErrorBoundary?: NonIndexRouteObject[\"hasErrorBoundary\"];\n shouldRevalidate?: NonIndexRouteObject[\"shouldRevalidate\"];\n handle?: NonIndexRouteObject[\"handle\"];\n index?: false;\n children?: React.ReactNode;\n element?: React.ReactNode | null;\n errorElement?: React.ReactNode | null;\n}\n\nexport interface LayoutRouteProps extends PathRouteProps {}\n\nexport interface IndexRouteProps {\n caseSensitive?: IndexRouteObject[\"caseSensitive\"];\n path?: IndexRouteObject[\"path\"];\n id?: IndexRouteObject[\"id\"];\n loader?: IndexRouteObject[\"loader\"];\n action?: IndexRouteObject[\"action\"];\n hasErrorBoundary?: IndexRouteObject[\"hasErrorBoundary\"];\n shouldRevalidate?: IndexRouteObject[\"shouldRevalidate\"];\n handle?: IndexRouteObject[\"handle\"];\n index: true;\n children?: undefined;\n element?: React.ReactNode | null;\n errorElement?: React.ReactNode | null;\n}\n\nexport type RouteProps = PathRouteProps | LayoutRouteProps | IndexRouteProps;\n\n/**\n * Declares an element that should be rendered at a certain URL path.\n *\n * @see https://reactrouter.com/docs/en/v6/components/route\n */\nexport function Route(_props: RouteProps): React.ReactElement | null {\n invariant(\n false,\n `A is only ever to be used as the child of element, ` +\n `never rendered directly. Please wrap your in a .`\n );\n}\n\nexport interface RouterProps {\n basename?: string;\n children?: React.ReactNode;\n location: Partial | string;\n navigationType?: NavigationType;\n navigator: Navigator;\n static?: boolean;\n}\n\n/**\n * Provides location context for the rest of the app.\n *\n * Note: You usually won't render a directly. Instead, you'll render a\n * router that is more specific to your environment such as a \n * in web browsers or a for server rendering.\n *\n * @see https://reactrouter.com/docs/en/v6/routers/router\n */\nexport function Router({\n basename: basenameProp = \"/\",\n children = null,\n location: locationProp,\n navigationType = NavigationType.Pop,\n navigator,\n static: staticProp = false,\n}: RouterProps): React.ReactElement | null {\n invariant(\n !useInRouterContext(),\n `You cannot render a inside another .` +\n ` You should never have more than one in your app.`\n );\n\n // Preserve trailing slashes on basename, so we can let the user control\n // the enforcement of trailing slashes throughout the app\n let basename = basenameProp.replace(/^\\/*/, \"/\");\n let navigationContext = React.useMemo(\n () => ({ basename, navigator, static: staticProp }),\n [basename, navigator, staticProp]\n );\n\n if (typeof locationProp === \"string\") {\n locationProp = parsePath(locationProp);\n }\n\n let {\n pathname = \"/\",\n search = \"\",\n hash = \"\",\n state = null,\n key = \"default\",\n } = locationProp;\n\n let location = React.useMemo(() => {\n let trailingPathname = stripBasename(pathname, basename);\n\n if (trailingPathname == null) {\n return null;\n }\n\n return {\n pathname: trailingPathname,\n search,\n hash,\n state,\n key,\n };\n }, [basename, pathname, search, hash, state, key]);\n\n warning(\n location != null,\n ` is not able to match the URL ` +\n `\"${pathname}${search}${hash}\" because it does not start with the ` +\n `basename, so the won't render anything.`\n );\n\n if (location == null) {\n return null;\n }\n\n return (\n \n \n \n );\n}\n\nexport interface RoutesProps {\n children?: React.ReactNode;\n location?: Partial | string;\n}\n\n/**\n * A container for a nested tree of elements that renders the branch\n * that best matches the current location.\n *\n * @see https://reactrouter.com/docs/en/v6/components/routes\n */\nexport function Routes({\n children,\n location,\n}: RoutesProps): React.ReactElement | null {\n let dataRouterContext = React.useContext(DataRouterContext);\n // When in a DataRouterContext _without_ children, we use the router routes\n // directly. If we have children, then we're in a descendant tree and we\n // need to use child routes.\n let routes =\n dataRouterContext && !children\n ? (dataRouterContext.router.routes as DataRouteObject[])\n : createRoutesFromChildren(children);\n return useRoutes(routes, location);\n}\n\nexport interface AwaitResolveRenderFunction {\n (data: Awaited): React.ReactElement;\n}\n\nexport interface AwaitProps {\n children: React.ReactNode | AwaitResolveRenderFunction;\n errorElement?: React.ReactNode;\n resolve: TrackedPromise | any;\n}\n\n/**\n * Component to use for rendering lazily loaded data from returning defer()\n * in a loader function\n */\nexport function Await({ children, errorElement, resolve }: AwaitProps) {\n return (\n \n {children}\n \n );\n}\n\ntype AwaitErrorBoundaryProps = React.PropsWithChildren<{\n errorElement?: React.ReactNode;\n resolve: TrackedPromise | any;\n}>;\n\ntype AwaitErrorBoundaryState = {\n error: any;\n};\n\nenum AwaitRenderStatus {\n pending,\n success,\n error,\n}\n\nconst neverSettledPromise = new Promise(() => {});\n\nclass AwaitErrorBoundary extends React.Component<\n AwaitErrorBoundaryProps,\n AwaitErrorBoundaryState\n> {\n constructor(props: AwaitErrorBoundaryProps) {\n super(props);\n this.state = { error: null };\n }\n\n static getDerivedStateFromError(error: any) {\n return { error };\n }\n\n componentDidCatch(error: any, errorInfo: any) {\n console.error(\n \" caught the following error during render\",\n error,\n errorInfo\n );\n }\n\n render() {\n let { children, errorElement, resolve } = this.props;\n\n let promise: TrackedPromise | null = null;\n let status: AwaitRenderStatus = AwaitRenderStatus.pending;\n\n if (!(resolve instanceof Promise)) {\n // Didn't get a promise - provide as a resolved promise\n status = AwaitRenderStatus.success;\n promise = Promise.resolve();\n Object.defineProperty(promise, \"_tracked\", { get: () => true });\n Object.defineProperty(promise, \"_data\", { get: () => resolve });\n } else if (this.state.error) {\n // Caught a render error, provide it as a rejected promise\n status = AwaitRenderStatus.error;\n let renderError = this.state.error;\n promise = Promise.reject().catch(() => {}); // Avoid unhandled rejection warnings\n Object.defineProperty(promise, \"_tracked\", { get: () => true });\n Object.defineProperty(promise, \"_error\", { get: () => renderError });\n } else if ((resolve as TrackedPromise)._tracked) {\n // Already tracked promise - check contents\n promise = resolve;\n status =\n promise._error !== undefined\n ? AwaitRenderStatus.error\n : promise._data !== undefined\n ? AwaitRenderStatus.success\n : AwaitRenderStatus.pending;\n } else {\n // Raw (untracked) promise - track it\n status = AwaitRenderStatus.pending;\n Object.defineProperty(resolve, \"_tracked\", { get: () => true });\n promise = resolve.then(\n (data: any) =>\n Object.defineProperty(resolve, \"_data\", { get: () => data }),\n (error: any) =>\n Object.defineProperty(resolve, \"_error\", { get: () => error })\n );\n }\n\n if (\n status === AwaitRenderStatus.error &&\n promise._error instanceof AbortedDeferredError\n ) {\n // Freeze the UI by throwing a never resolved promise\n throw neverSettledPromise;\n }\n\n if (status === AwaitRenderStatus.error && !errorElement) {\n // No errorElement, throw to the nearest route-level error boundary\n throw promise._error;\n }\n\n if (status === AwaitRenderStatus.error) {\n // Render via our errorElement\n return ;\n }\n\n if (status === AwaitRenderStatus.success) {\n // Render children with resolved value\n return ;\n }\n\n // Throw to the suspense boundary\n throw promise;\n }\n}\n\n/**\n * @private\n * Indirection to leverage useAsyncValue for a render-prop API on \n */\nfunction ResolveAwait({\n children,\n}: {\n children: React.ReactNode | AwaitResolveRenderFunction;\n}) {\n let data = useAsyncValue();\n if (typeof children === \"function\") {\n return children(data);\n }\n return <>{children};\n}\n\n///////////////////////////////////////////////////////////////////////////////\n// UTILS\n///////////////////////////////////////////////////////////////////////////////\n\n/**\n * Creates a route config from a React \"children\" object, which is usually\n * either a `` element or an array of them. Used internally by\n * `` to create a route config from its children.\n *\n * @see https://reactrouter.com/docs/en/v6/utils/create-routes-from-children\n */\nexport function createRoutesFromChildren(\n children: React.ReactNode,\n parentPath: number[] = []\n): RouteObject[] {\n let routes: RouteObject[] = [];\n\n React.Children.forEach(children, (element, index) => {\n if (!React.isValidElement(element)) {\n // Ignore non-elements. This allows people to more easily inline\n // conditionals in their route config.\n return;\n }\n\n if (element.type === React.Fragment) {\n // Transparently support React.Fragment and its children.\n routes.push.apply(\n routes,\n createRoutesFromChildren(element.props.children, parentPath)\n );\n return;\n }\n\n invariant(\n element.type === Route,\n `[${\n typeof element.type === \"string\" ? element.type : element.type.name\n }] is not a component. All component children of must be a or `\n );\n\n invariant(\n !element.props.index || !element.props.children,\n \"An index route cannot have child routes.\"\n );\n\n let treePath = [...parentPath, index];\n let route: RouteObject = {\n id: element.props.id || treePath.join(\"-\"),\n caseSensitive: element.props.caseSensitive,\n element: element.props.element,\n index: element.props.index,\n path: element.props.path,\n loader: element.props.loader,\n action: element.props.action,\n errorElement: element.props.errorElement,\n hasErrorBoundary: element.props.errorElement != null,\n shouldRevalidate: element.props.shouldRevalidate,\n handle: element.props.handle,\n };\n\n if (element.props.children) {\n route.children = createRoutesFromChildren(\n element.props.children,\n treePath\n );\n }\n\n routes.push(route);\n });\n\n return routes;\n}\n\n/**\n * Renders the result of `matchRoutes()` into a React element.\n */\nexport function renderMatches(\n matches: RouteMatch[] | null\n): React.ReactElement | null {\n return _renderMatches(matches);\n}\n\n/**\n * @private\n * Walk the route tree and add hasErrorBoundary if it's not provided, so that\n * users providing manual route arrays can just specify errorElement\n */\nexport function enhanceManualRouteObjects(\n routes: RouteObject[]\n): RouteObject[] {\n return routes.map((route) => {\n let routeClone = { ...route };\n if (routeClone.hasErrorBoundary == null) {\n routeClone.hasErrorBoundary = routeClone.errorElement != null;\n }\n if (routeClone.children) {\n routeClone.children = enhanceManualRouteObjects(routeClone.children);\n }\n return routeClone;\n });\n}\n","/**\n * NOTE: If you refactor this to split up the modules into separate files,\n * you'll need to update the rollup config for react-router-dom-v5-compat.\n */\nimport * as React from \"react\";\nimport type {\n NavigateOptions,\n RelativeRoutingType,\n RouteObject,\n To,\n} from \"react-router\";\nimport {\n Router,\n createPath,\n useHref,\n useLocation,\n useMatch,\n useMatches,\n useNavigate,\n useNavigation,\n useResolvedPath,\n UNSAFE_DataRouterContext as DataRouterContext,\n UNSAFE_DataRouterStateContext as DataRouterStateContext,\n UNSAFE_NavigationContext as NavigationContext,\n UNSAFE_RouteContext as RouteContext,\n UNSAFE_enhanceManualRouteObjects as enhanceManualRouteObjects,\n} from \"react-router\";\nimport type {\n BrowserHistory,\n Fetcher,\n FormEncType,\n FormMethod,\n GetScrollRestorationKeyFunction,\n HashHistory,\n History,\n HydrationState,\n Router as RemixRouter,\n} from \"@remix-run/router\";\nimport {\n createRouter,\n createBrowserHistory,\n createHashHistory,\n invariant,\n joinPaths,\n matchPath,\n} from \"@remix-run/router\";\n\nimport type {\n SubmitOptions,\n ParamKeyValuePair,\n URLSearchParamsInit,\n} from \"./dom\";\nimport {\n createSearchParams,\n defaultMethod,\n getFormSubmissionInfo,\n getSearchParamsForLocation,\n shouldProcessLinkClick,\n} from \"./dom\";\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Re-exports\n////////////////////////////////////////////////////////////////////////////////\n\nexport type {\n FormEncType,\n FormMethod,\n ParamKeyValuePair,\n SubmitOptions,\n URLSearchParamsInit,\n};\nexport { createSearchParams };\n\n// Note: Keep in sync with react-router exports!\nexport type {\n ActionFunction,\n ActionFunctionArgs,\n AwaitProps,\n DataRouteMatch,\n DataRouteObject,\n Fetcher,\n Hash,\n IndexRouteObject,\n IndexRouteProps,\n JsonFunction,\n LayoutRouteProps,\n LoaderFunction,\n LoaderFunctionArgs,\n Location,\n MemoryRouterProps,\n NavigateFunction,\n NavigateOptions,\n NavigateProps,\n Navigation,\n Navigator,\n NonIndexRouteObject,\n OutletProps,\n Params,\n ParamParseKey,\n Path,\n PathMatch,\n Pathname,\n PathPattern,\n PathRouteProps,\n RedirectFunction,\n RelativeRoutingType,\n RouteMatch,\n RouteObject,\n RouteProps,\n RouterProps,\n RouterProviderProps,\n RoutesProps,\n Search,\n ShouldRevalidateFunction,\n To,\n} from \"react-router\";\nexport {\n AbortedDeferredError,\n Await,\n MemoryRouter,\n Navigate,\n NavigationType,\n Outlet,\n Route,\n Router,\n RouterProvider,\n Routes,\n createMemoryRouter,\n createPath,\n createRoutesFromChildren,\n createRoutesFromElements,\n defer,\n isRouteErrorResponse,\n generatePath,\n json,\n matchPath,\n matchRoutes,\n parsePath,\n redirect,\n renderMatches,\n resolvePath,\n useActionData,\n useAsyncError,\n useAsyncValue,\n useHref,\n useInRouterContext,\n useLoaderData,\n useLocation,\n useMatch,\n useMatches,\n useNavigate,\n useNavigation,\n useNavigationType,\n useOutlet,\n useOutletContext,\n useParams,\n useResolvedPath,\n useRevalidator,\n useRouteError,\n useRouteLoaderData,\n useRoutes,\n} from \"react-router\";\n\n///////////////////////////////////////////////////////////////////////////////\n// DANGER! PLEASE READ ME!\n// We provide these exports as an escape hatch in the event that you need any\n// routing data that we don't provide an explicit API for. With that said, we\n// want to cover your use case if we can, so if you feel the need to use these\n// we want to hear from you. Let us know what you're building and we'll do our\n// best to make sure we can support you!\n//\n// We consider these exports an implementation detail and do not guarantee\n// against any breaking changes, regardless of the semver release. Use with\n// extreme caution and only if you understand the consequences. Godspeed.\n///////////////////////////////////////////////////////////////////////////////\n\n/** @internal */\nexport {\n UNSAFE_DataRouterContext,\n UNSAFE_DataRouterStateContext,\n UNSAFE_DataStaticRouterContext,\n UNSAFE_NavigationContext,\n UNSAFE_LocationContext,\n UNSAFE_RouteContext,\n UNSAFE_enhanceManualRouteObjects,\n} from \"react-router\";\n//#endregion\n\ndeclare global {\n var __staticRouterHydrationData: HydrationState | undefined;\n}\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Routers\n////////////////////////////////////////////////////////////////////////////////\n\nexport function createBrowserRouter(\n routes: RouteObject[],\n opts?: {\n basename?: string;\n hydrationData?: HydrationState;\n window?: Window;\n }\n): RemixRouter {\n return createRouter({\n basename: opts?.basename,\n history: createBrowserHistory({ window: opts?.window }),\n hydrationData: opts?.hydrationData || window?.__staticRouterHydrationData,\n routes: enhanceManualRouteObjects(routes),\n }).initialize();\n}\n\nexport function createHashRouter(\n routes: RouteObject[],\n opts?: {\n basename?: string;\n hydrationData?: HydrationState;\n window?: Window;\n }\n): RemixRouter {\n return createRouter({\n basename: opts?.basename,\n history: createHashHistory({ window: opts?.window }),\n hydrationData: opts?.hydrationData || window?.__staticRouterHydrationData,\n routes: enhanceManualRouteObjects(routes),\n }).initialize();\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Components\n////////////////////////////////////////////////////////////////////////////////\n\nexport interface BrowserRouterProps {\n basename?: string;\n children?: React.ReactNode;\n window?: Window;\n}\n\n/**\n * A `` for use in web browsers. Provides the cleanest URLs.\n */\nexport function BrowserRouter({\n basename,\n children,\n window,\n}: BrowserRouterProps) {\n let historyRef = React.useRef();\n if (historyRef.current == null) {\n historyRef.current = createBrowserHistory({ window, v5Compat: true });\n }\n\n let history = historyRef.current;\n let [state, setState] = React.useState({\n action: history.action,\n location: history.location,\n });\n\n React.useLayoutEffect(() => history.listen(setState), [history]);\n\n return (\n \n );\n}\n\nexport interface HashRouterProps {\n basename?: string;\n children?: React.ReactNode;\n window?: Window;\n}\n\n/**\n * A `` for use in web browsers. Stores the location in the hash\n * portion of the URL so it is not sent to the server.\n */\nexport function HashRouter({ basename, children, window }: HashRouterProps) {\n let historyRef = React.useRef();\n if (historyRef.current == null) {\n historyRef.current = createHashHistory({ window, v5Compat: true });\n }\n\n let history = historyRef.current;\n let [state, setState] = React.useState({\n action: history.action,\n location: history.location,\n });\n\n React.useLayoutEffect(() => history.listen(setState), [history]);\n\n return (\n \n );\n}\n\nexport interface HistoryRouterProps {\n basename?: string;\n children?: React.ReactNode;\n history: History;\n}\n\n/**\n * A `` that accepts a pre-instantiated history object. It's important\n * to note that using your own history object is highly discouraged and may add\n * two versions of the history library to your bundles unless you use the same\n * version of the history library that React Router uses internally.\n */\nfunction HistoryRouter({ basename, children, history }: HistoryRouterProps) {\n const [state, setState] = React.useState({\n action: history.action,\n location: history.location,\n });\n\n React.useLayoutEffect(() => history.listen(setState), [history]);\n\n return (\n \n );\n}\n\nif (__DEV__) {\n HistoryRouter.displayName = \"unstable_HistoryRouter\";\n}\n\nexport { HistoryRouter as unstable_HistoryRouter };\n\nexport interface LinkProps\n extends Omit, \"href\"> {\n reloadDocument?: boolean;\n replace?: boolean;\n state?: any;\n preventScrollReset?: boolean;\n relative?: RelativeRoutingType;\n to: To;\n}\n\n/**\n * The public API for rendering a history-aware
.\n */\nexport const Link = React.forwardRef(\n function LinkWithRef(\n {\n onClick,\n relative,\n reloadDocument,\n replace,\n state,\n target,\n to,\n preventScrollReset,\n ...rest\n },\n ref\n ) {\n let href = useHref(to, { relative });\n let internalOnClick = useLinkClickHandler(to, {\n replace,\n state,\n target,\n preventScrollReset,\n relative,\n });\n function handleClick(\n event: React.MouseEvent\n ) {\n if (onClick) onClick(event);\n if (!event.defaultPrevented) {\n internalOnClick(event);\n }\n }\n\n return (\n // eslint-disable-next-line jsx-a11y/anchor-has-content\n \n );\n }\n);\n\nif (__DEV__) {\n Link.displayName = \"Link\";\n}\n\nexport interface NavLinkProps\n extends Omit {\n children?:\n | React.ReactNode\n | ((props: { isActive: boolean; isPending: boolean }) => React.ReactNode);\n caseSensitive?: boolean;\n className?:\n | string\n | ((props: {\n isActive: boolean;\n isPending: boolean;\n }) => string | undefined);\n end?: boolean;\n style?:\n | React.CSSProperties\n | ((props: {\n isActive: boolean;\n isPending: boolean;\n }) => React.CSSProperties | undefined);\n}\n\n/**\n * A wrapper that knows if it's \"active\" or not.\n */\nexport const NavLink = React.forwardRef(\n function NavLinkWithRef(\n {\n \"aria-current\": ariaCurrentProp = \"page\",\n caseSensitive = false,\n className: classNameProp = \"\",\n end = false,\n style: styleProp,\n to,\n children,\n ...rest\n },\n ref\n ) {\n let path = useResolvedPath(to, { relative: rest.relative });\n let location = useLocation();\n let routerState = React.useContext(DataRouterStateContext);\n\n let toPathname = path.pathname;\n let locationPathname = location.pathname;\n let nextLocationPathname =\n routerState && routerState.navigation && routerState.navigation.location\n ? routerState.navigation.location.pathname\n : null;\n\n if (!caseSensitive) {\n locationPathname = locationPathname.toLowerCase();\n nextLocationPathname = nextLocationPathname\n ? nextLocationPathname.toLowerCase()\n : null;\n toPathname = toPathname.toLowerCase();\n }\n\n let isActive =\n locationPathname === toPathname ||\n (!end &&\n locationPathname.startsWith(toPathname) &&\n locationPathname.charAt(toPathname.length) === \"/\");\n\n let isPending =\n nextLocationPathname != null &&\n (nextLocationPathname === toPathname ||\n (!end &&\n nextLocationPathname.startsWith(toPathname) &&\n nextLocationPathname.charAt(toPathname.length) === \"/\"));\n\n let ariaCurrent = isActive ? ariaCurrentProp : undefined;\n\n let className: string | undefined;\n if (typeof classNameProp === \"function\") {\n className = classNameProp({ isActive, isPending });\n } else {\n // If the className prop is not a function, we use a default `active`\n // class for s that are active. In v5 `active` was the default\n // value for `activeClassName`, but we are removing that API and can still\n // use the old default behavior for a cleaner upgrade path and keep the\n // simple styling rules working as they currently do.\n className = [\n classNameProp,\n isActive ? \"active\" : null,\n isPending ? \"pending\" : null,\n ]\n .filter(Boolean)\n .join(\" \");\n }\n\n let style =\n typeof styleProp === \"function\"\n ? styleProp({ isActive, isPending })\n : styleProp;\n\n return (\n \n {typeof children === \"function\"\n ? children({ isActive, isPending })\n : children}\n \n );\n }\n);\n\nif (__DEV__) {\n NavLink.displayName = \"NavLink\";\n}\n\nexport interface FormProps extends React.FormHTMLAttributes {\n /**\n * The HTTP verb to use when the form is submit. Supports \"get\", \"post\",\n * \"put\", \"delete\", \"patch\".\n */\n method?: FormMethod;\n\n /**\n * Normal `
` but supports React Router's relative paths.\n */\n action?: string;\n\n /**\n * Forces a full document navigation instead of a fetch.\n */\n reloadDocument?: boolean;\n\n /**\n * Replaces the current entry in the browser history stack when the form\n * navigates. Use this if you don't want the user to be able to click \"back\"\n * to the page with the form on it.\n */\n replace?: boolean;\n\n /**\n * Determines whether the form action is relative to the route hierarchy or\n * the pathname. Use this if you want to opt out of navigating the route\n * hierarchy and want to instead route based on /-delimited URL segments\n */\n relative?: RelativeRoutingType;\n\n /**\n * A function to call when the form is submitted. If you call\n * `event.preventDefault()` then this form will not do anything.\n */\n onSubmit?: React.FormEventHandler;\n}\n\n/**\n * A `@remix-run/router`-aware ``. It behaves like a normal form except\n * that the interaction with the server is with `fetch` instead of new document\n * requests, allowing components to add nicer UX to the page as the form is\n * submitted and returns with data.\n */\nexport const Form = React.forwardRef(\n (props, ref) => {\n return ;\n }\n);\n\nif (__DEV__) {\n Form.displayName = \"Form\";\n}\n\ntype HTMLSubmitEvent = React.BaseSyntheticEvent<\n SubmitEvent,\n Event,\n HTMLFormElement\n>;\n\ntype HTMLFormSubmitter = HTMLButtonElement | HTMLInputElement;\n\ninterface FormImplProps extends FormProps {\n fetcherKey?: string;\n routeId?: string;\n}\n\nconst FormImpl = React.forwardRef(\n (\n {\n reloadDocument,\n replace,\n method = defaultMethod,\n action,\n onSubmit,\n fetcherKey,\n routeId,\n relative,\n ...props\n },\n forwardedRef\n ) => {\n let submit = useSubmitImpl(fetcherKey, routeId);\n let formMethod: FormMethod =\n method.toLowerCase() === \"get\" ? \"get\" : \"post\";\n let formAction = useFormAction(action, { relative });\n let submitHandler: React.FormEventHandler = (event) => {\n onSubmit && onSubmit(event);\n if (event.defaultPrevented) return;\n event.preventDefault();\n\n let submitter = (event as unknown as HTMLSubmitEvent).nativeEvent\n .submitter as HTMLFormSubmitter | null;\n\n submit(submitter || event.currentTarget, { method, replace, relative });\n };\n\n return (\n \n );\n }\n);\n\nif (__DEV__) {\n Form.displayName = \"Form\";\n}\n\ninterface ScrollRestorationProps {\n getKey?: GetScrollRestorationKeyFunction;\n storageKey?: string;\n}\n\n/**\n * This component will emulate the browser's scroll restoration on location\n * changes.\n */\nexport function ScrollRestoration({\n getKey,\n storageKey,\n}: ScrollRestorationProps) {\n useScrollRestoration({ getKey, storageKey });\n return null;\n}\n\nif (__DEV__) {\n ScrollRestoration.displayName = \"ScrollRestoration\";\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Hooks\n////////////////////////////////////////////////////////////////////////////////\n\nenum DataRouterHook {\n UseScrollRestoration = \"useScrollRestoration\",\n UseSubmitImpl = \"useSubmitImpl\",\n UseFetcher = \"useFetcher\",\n}\n\nenum DataRouterStateHook {\n UseFetchers = \"useFetchers\",\n UseScrollRestoration = \"useScrollRestoration\",\n}\n\nfunction getDataRouterConsoleError(\n hookName: DataRouterHook | DataRouterStateHook\n) {\n return `${hookName} must be used within a data router. See https://reactrouter.com/en/main/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\n/**\n * Handles the click behavior for router `` components. This is useful if\n * you need to create custom `` components with the same click behavior we\n * use in our exported ``.\n */\nexport function useLinkClickHandler(\n to: To,\n {\n target,\n replace: replaceProp,\n state,\n preventScrollReset,\n relative,\n }: {\n target?: React.HTMLAttributeAnchorTarget;\n replace?: boolean;\n state?: any;\n preventScrollReset?: boolean;\n relative?: RelativeRoutingType;\n } = {}\n): (event: React.MouseEvent) => void {\n let navigate = useNavigate();\n let location = useLocation();\n let path = useResolvedPath(to, { relative });\n\n return React.useCallback(\n (event: React.MouseEvent) => {\n if (shouldProcessLinkClick(event, target)) {\n event.preventDefault();\n\n // If the URL hasn't changed, a regular will do a replace instead of\n // a push, so do the same here unless the replace prop is explicitly set\n let replace =\n replaceProp !== undefined\n ? replaceProp\n : createPath(location) === createPath(path);\n\n navigate(to, { replace, state, preventScrollReset, relative });\n }\n },\n [\n location,\n navigate,\n path,\n replaceProp,\n state,\n target,\n to,\n preventScrollReset,\n relative,\n ]\n );\n}\n\n/**\n * A convenient wrapper for reading and writing search parameters via the\n * URLSearchParams interface.\n */\nexport function useSearchParams(\n defaultInit?: URLSearchParamsInit\n): [URLSearchParams, SetURLSearchParams] {\n warning(\n typeof URLSearchParams !== \"undefined\",\n `You cannot use the \\`useSearchParams\\` hook in a browser that does not ` +\n `support the URLSearchParams API. If you need to support Internet ` +\n `Explorer 11, we recommend you load a polyfill such as ` +\n `https://github.com/ungap/url-search-params\\n\\n` +\n `If you're unsure how to load polyfills, we recommend you check out ` +\n `https://polyfill.io/v3/ which provides some recommendations about how ` +\n `to load polyfills only for users that need them, instead of for every ` +\n `user.`\n );\n\n let defaultSearchParamsRef = React.useRef(createSearchParams(defaultInit));\n\n let location = useLocation();\n let searchParams = React.useMemo(\n () =>\n getSearchParamsForLocation(\n location.search,\n defaultSearchParamsRef.current\n ),\n [location.search]\n );\n\n let navigate = useNavigate();\n let setSearchParams = React.useCallback(\n (nextInit, navigateOptions) => {\n const newSearchParams = createSearchParams(\n typeof nextInit === \"function\" ? nextInit(searchParams) : nextInit\n );\n navigate(\"?\" + newSearchParams, navigateOptions);\n },\n [navigate, searchParams]\n );\n\n return [searchParams, setSearchParams];\n}\n\ntype SetURLSearchParams = (\n nextInit?:\n | URLSearchParamsInit\n | ((prev: URLSearchParams) => URLSearchParamsInit),\n navigateOpts?: NavigateOptions\n) => void;\n\ntype SubmitTarget =\n | HTMLFormElement\n | HTMLButtonElement\n | HTMLInputElement\n | FormData\n | URLSearchParams\n | { [name: string]: string }\n | null;\n\n/**\n * Submits a HTML `` to the server without reloading the page.\n */\nexport interface SubmitFunction {\n (\n /**\n * Specifies the `` to be submitted to the server, a specific\n * `\r\n )\r\n}\r\n","import React from 'react'\r\n\r\nexport default function LoadingBar() {\r\n return (\r\n
\r\n \r\n \r\n \r\n
\r\n )\r\n}\r\n","import React, { useContext, useState } from 'react';\r\nimport {NavLink} from 'react-router-dom'\r\n\r\n// context & hooks import\r\nimport UserContext from '../context/UserContext'\r\nimport useContexts from '../hooks/useContextCommunicator'\r\n\r\n// component import\r\nimport Button from '../components/Button';\r\nimport LoadingBar from '../components/LoadingBar'\r\n\r\nconst Login = () => {\r\n // context def\r\n const { loading } = useContext(UserContext)\r\n const {loginCommand} = useContexts()\r\n\r\n // state def\r\n const [email, setEmail] = useState('')\r\n const [password, setPassword] = useState('')\r\n const [errorMessage, setError] = useState('')\r\n\r\n // handler def\r\n const formSubmit = async (e) => {\r\n e.preventDefault()\r\n try {\r\n setError('')\r\n await loginCommand(email, password)\r\n } catch (e) {\r\n if (e.message === 'Error: 400') {\r\n setError('Unable to Log In, please try again')\r\n } else {\r\n setError(e.message)\r\n }\r\n }\r\n }\r\n\r\n // pre-render\r\n let loadingDiv = null\r\n if (loading) {\r\n loadingDiv = \r\n }\r\n\r\n return (\r\n
\r\n );\r\n}\r\n\r\nexport default Login;","import React, { useRef, useEffect} from 'react'\r\n\r\n// export default function Dialog({open, type, outsideClick, children }) {\r\nexport default function Dialog({open, type, closeClicked, children }) {\r\n const wrapperRef = useRef(null)\r\n\r\n useEffect(() => {\r\n const handleClickOutside = (event) => {\r\n if (wrapperRef.current && !wrapperRef.current.contains(event.target)) {\r\n closeClicked()\r\n }\r\n }\r\n\r\n document.addEventListener(\"mousedown\", handleClickOutside);\r\n return () => {\r\n document.removeEventListener(\"mousedown\", handleClickOutside);\r\n }\r\n }, [wrapperRef, closeClicked])\r\n\r\n if (!open) {\r\n return null\r\n }\r\n\r\n let dtype = \"dialog__box\"\r\n\r\n if (type) {\r\n dtype = \"dialog__\"+type\r\n }\r\n\r\n return (\r\n
\r\n
\r\n {children}\r\n
\r\n
\r\n )\r\n}\r\n","import {useContext} from 'react'\r\nimport dataServer from '../api/dataServer'\r\nimport authServer from '../api/authServer'\r\nimport DataContext from '../context/DataContext'\r\nimport UserContext from '../context/UserContext'\r\n// import {Redirect} from 'react-router-dom'\r\n\r\n// FOR TESTING IMPORT ONLY\r\nimport axios from 'axios'\r\n\r\nexport default () => {\r\n const {instrumentShown, updateStockChartData} = useContext(DataContext)\r\n const {portfolios, updateUserPortfolios} = useContext(UserContext)\r\n\r\n const getModelParams = async (modelIndex, stockType) => {\r\n const NodeRequest = {\r\n symbol: instrumentShown,\r\n chartkind: stockType,\r\n model_index: modelIndex\r\n }\r\n try {\r\n const response = await dataServer.post('/getModelData', NodeRequest)\r\n return response.data\r\n } catch (err) {\r\n return ({error: err.message})\r\n }\r\n }\r\n \r\n const qSpecDelete = async (stock, modelIndex, stockType) => {\r\n const NodeRequest = {\r\n stock,\r\n modelIndex,\r\n chartkind: stockType\r\n }\r\n try {\r\n await dataServer.post('/deleteModel', NodeRequest)\r\n return true\r\n } catch (err) {\r\n return {error: err.message}\r\n }\r\n }\r\n\r\n const qSpecAdd = async (stock, stockType) => {\r\n const NodeRequest = {\r\n stock: stock,\r\n chartkind: stockType,\r\n line_color: \"#000\",\r\n Kind: \"4\"\r\n }\r\n try {\r\n const response = await dataServer.post('/addqspectrum', NodeRequest)\r\n return response.data\r\n } catch (err) {\r\n return {error: err.message}\r\n }\r\n\r\n }\r\n\r\n const qSpecCalculatePeriodogram = async (object) => {\r\n try {\r\n const response = await dataServer.post('/calculatePeriodogram', object)\r\n return response.data\r\n } catch (err) {\r\n return {error: err.message}\r\n }\r\n }\r\n\r\n const qSpecCalculateProjLine = async (object) => {\r\n try {\r\n const response = await dataServer.post('/calculateSpectrumProjLine', object)\r\n return response.data\r\n } catch (err) {\r\n return {error: err.message}\r\n }\r\n }\r\n\r\n const getPeriodogram = async (modelIndex, stockType) => {\r\n const NodeRequest = {\r\n symbol: instrumentShown,\r\n chartkind: stockType,\r\n model_index: modelIndex\r\n }\r\n try {\r\n const response = await dataServer.post('/getPeriodogram', NodeRequest)\r\n return response.data\r\n } catch (err) {\r\n return ({error: err.message})\r\n }\r\n }\r\n\r\n const getPortfolioCommand = async (name) => {\r\n try {\r\n const response = await dataServer.post('/getPortfolio', {name})\r\n return response.data\r\n } catch (err) {\r\n throw new Error(err.response.status)\r\n }\r\n }\r\n\r\n const removeStockFromPortfolioCommand = async (portfolio, stock) => {\r\n let newPortfolios = [...portfolios]\r\n const index = newPortfolios.findIndex(item => item.name === portfolio)\r\n const stockIndex = newPortfolios[index].stocks.findIndex(item => item === stock)\r\n if (stockIndex > -1) {\r\n newPortfolios[index].stocks.splice(stockIndex, 1)\r\n }\r\n try {\r\n const response = await dataServer.patch('/editPortfolio', newPortfolios[index])\r\n updateUserPortfolios(newPortfolios)\r\n return response.data\r\n } catch (err) {\r\n throw new Error(err.response.status)\r\n }\r\n }\r\n\r\n const deletePortfolioCommand = async (portfolio) => {\r\n try {\r\n const response = await dataServer.delete('/deletePortfolio', {data:{name: portfolio}})\r\n updateUserPortfolios(response.data)\r\n return response.data\r\n } catch (err) {\r\n throw new Error (err.response.status)\r\n }\r\n }\r\n\r\n const addStockToPortfolio = async (portfolio, stock) => {\r\n let newPortfolios = [...portfolios]\r\n const index = newPortfolios.findIndex(item => item.name === portfolio)\r\n const stockIndex = newPortfolios[index].stocks.findIndex(item => item === stock)\r\n if (stockIndex > -1) {\r\n return ({error: 'Stock already included in portfolio'})\r\n }\r\n newPortfolios[index].stocks.push(stock)\r\n try {\r\n const response = await dataServer.patch('/editPortfolio', newPortfolios[index])\r\n updateUserPortfolios(newPortfolios)\r\n return response.data\r\n } catch (err) {\r\n newPortfolios[index].stocks.pop()\r\n throw new Error(err.response.status)\r\n }\r\n }\r\n\r\n const getUserInfo = async () => {\r\n try {\r\n const userInfo = await authServer.post('/me')\r\n return {name: userInfo.data.name, email: userInfo.data.email, stocks: userInfo.data.stocks, portfolios: userInfo.data.portfolios}\r\n } catch (err) {\r\n throw new Error (err.response.status)\r\n }\r\n }\r\n\r\n const updateUserInfoCommand = async (name, email) => {\r\n try {\r\n const NodeRequest = {\r\n name,\r\n email\r\n }\r\n const response = await authServer.patch('/me', NodeRequest)\r\n return response.data\r\n } catch (err) {\r\n throw new Error(err.response.status)\r\n }\r\n }\r\n\r\n const changePasswordCommand = async (oldPass, newPass) => {\r\n try {\r\n const NodeRequest = {\r\n oldPassword: oldPass,\r\n newPassword: newPass\r\n }\r\n const response = await authServer.post('/changePassword', NodeRequest)\r\n alert(response.data)\r\n return response.data\r\n } catch (err) {\r\n throw new Error(err.response.status)\r\n }\r\n }\r\n\r\n const removeSplitsCommand = async (stock) => {\r\n const request = {\r\n stock\r\n }\r\n const response = await dataServer.post('/splitRemove', request)\r\n return response.data\r\n }\r\n\r\n const updateInstrumentCommand = (instrument) => {\r\n updateStockChartData(instrument)\r\n }\r\n\r\n return {getModelParams, qSpecDelete, qSpecAdd, qSpecCalculatePeriodogram, qSpecCalculateProjLine, getPeriodogram, getPortfolioCommand, removeStockFromPortfolioCommand, deletePortfolioCommand, addStockToPortfolio, getUserInfo, updateUserInfoCommand, changePasswordCommand, removeSplitsCommand, updateInstrumentCommand}\r\n}","import React, { useState } from 'react'\r\nimport Button from '../components/Button';\r\nimport useInstrument from '../hooks/useInstrument';\r\nimport NumericInput from 'react-numeric-input';\r\n\r\nexport default function AstroDialog({type, deleteVisible, submitClicked, deleteClicked, closeClicked, modelIndex, loading}) {\r\n // context defs\r\n const {getModelParams} = useInstrument()\r\n\r\n // state defs\r\n const [loadComplete, setLoadComplete] = useState(false)\r\n\r\n const [astroModelOptions, setAstroModelOptions] = useState({\r\n astro_model_kind: 'Annual',\r\n astro_model_overtones: '12',\r\n astro_model_sm: 'All price',\r\n astro_color: '#000',\r\n Planet1: 'None',\r\n Planet2: 'None',\r\n zod: 'None'\r\n })\r\n\r\n // init\r\n React.useEffect(() => {\r\n const getModelInfo = async (modelIndex) => {\r\n const modelData = await getModelParams(modelIndex)\r\n let newState = {...astroModelOptions}\r\n newState.astro_model_kind = modelData.astro_model_kind\r\n newState.astro_model_overtones = modelData.astro_model_overtones\r\n newState.astro_model_sm = modelData.astro_model_sm\r\n if (modelData.astro_model_kind === 'Custom') {\r\n newState.Planet1 = modelData.Planet1\r\n newState.Planet2 = modelData.Planet2\r\n newState.zod = modelData.Zod\r\n }\r\n setAstroModelOptions(newState)\r\n setLoadComplete(true)\r\n }\r\n \r\n if (type==='Edit' && !loadComplete) {\r\n getModelInfo(modelIndex)\r\n }\r\n }, [loadComplete, astroModelOptions, modelIndex, type, getModelParams])\r\n\r\n const astroModelChange = (event) => {\r\n let newState = {...astroModelOptions}\r\n newState.astro_model_kind = event.target.value\r\n newState.Planet1 = 'None'\r\n newState.Planet2 = 'None'\r\n newState.zod = 'None'\r\n setAstroModelOptions(newState)\r\n }\r\n \r\n const astroSMChange = (event) => {\r\n let newState = {...astroModelOptions}\r\n newState.astro_model_sm = event.target.value\r\n setAstroModelOptions(newState)\r\n }\r\n \r\n const astroOvertonesChange = (value) => {\r\n let newState = {...astroModelOptions}\r\n newState.astro_model_overtones = value\r\n setAstroModelOptions(newState)\r\n }\r\n\r\n const customPlanetOneChange = (event) => {\r\n let newState = {...astroModelOptions}\r\n if (newState.astro_model_kind !== 'Custom') {\r\n newState.astro_model_kind = 'Custom'\r\n }\r\n newState.Planet1 = event.target.value\r\n setAstroModelOptions(newState)\r\n }\r\n\r\n const customPlanetTwoChange = (event) => {\r\n let newState = {...astroModelOptions}\r\n if (newState.astro_model_kind !== 'Custom') {\r\n newState.astro_model_kind = 'Custom'\r\n }\r\n newState.Planet2 = event.target.value\r\n setAstroModelOptions(newState)\r\n }\r\n\r\n const customZodiacChange = (event) => {\r\n let newState = {...astroModelOptions}\r\n if (newState.astro_model_kind !== 'Custom') {\r\n newState.astro_model_kind = 'Custom'\r\n }\r\n newState.zod = event.target.value\r\n setAstroModelOptions(newState)\r\n }\r\n\r\n const submitClickedHandler = () => {\r\n // Validate custom cycle proper submission\r\n if (astroModelOptions.astro_model_kind === 'Custom') {\r\n if (astroModelOptions.Planet1 === 'None') {\r\n return alert('For Custom Cycle need Two Planet entries and zodiac')\r\n } else if (astroModelOptions.Planet2 === 'None') {\r\n return alert('For Custom Cycle need Two Planet entries and zodiac')\r\n } else if (astroModelOptions.zod === 'None') {\r\n return alert('For Custom Cycle need Two Planet entries and zodiac')\r\n } else {\r\n const submitObject = {...astroModelOptions, type: 'astro'}\r\n submitClicked(submitObject)\r\n }\r\n } else {\r\n const submitObject = {...astroModelOptions, type: 'astro'}\r\n submitClicked(submitObject)\r\n }\r\n }\r\n\r\n // pre-render\r\n let customCycleClass = \"astro__content-disabled\"\r\n let customCycleOption = true\r\n if (astroModelOptions.astro_model_kind === 'Custom') {\r\n customCycleClass = \"astro__content\"\r\n customCycleOption = false\r\n }\r\n\r\n // Delete Button Visibility\r\n let deleteButton = deleteVisible ? : null\r\n\r\n return (\r\n \r\n
Natural Cycles Module
\r\n
\r\n
\r\n Model Type\r\n {/* */}\r\n {/*
*/}\r\n \r\n
\r\n Stock Memory\r\n \r\n
\r\n Overtones:\r\n \r\n
\r\n
\r\n
\r\n

Custom Natural Cycle

\r\n Planet #1: \r\n \r\n
\r\n Planet #2: \r\n \r\n
\r\n Zodiac: \r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n {deleteButton}\r\n \r\n \r\n
\r\n
\r\n )\r\n}\r\n","import React from 'react'\r\n\r\nexport default function Spinner() {\r\n return (\r\n
\r\n Loading...\r\n
\r\n )\r\n}\r\n","import React, {useContext, useState} from 'react'\r\nimport Highcharts from 'highcharts/highcharts';\r\nimport HighchartsReact from 'highcharts-react-official';\r\nimport Spinner from '../components/Spinner';\r\nimport Button from '../components/Button';\r\nimport NumericInput from 'react-numeric-input';\r\nimport useInstrument from '../hooks/useInstrument';\r\nimport UserContext from '../context/UserContext'\r\n\r\n\r\nexport default function AstroDialog({modelIndex, type, deleteVisible, stockName, stockType, closeClicked, submitClicked, deleteClicked, loading}) {\r\n const {email} = useContext(UserContext)\r\n const {qSpecDelete, qSpecAdd, qSpecCalculatePeriodogram, getModelParams, getPeriodogram} = useInstrument()\r\n\r\n\r\n // state definition\r\n const [qSpectrumModelOptions, setQSpectrumModelOptions] = React.useState({\r\n qSpec_model_sm: '12',\r\n qSpec_model_overtones: '4',\r\n qSpec_model_sz: 50,\r\n qSpec_model_fsm: '12',\r\n qSpec_model_kind: '4',\r\n loading: false,\r\n submitDisabled: false,\r\n model_index: modelIndex,\r\n qSpec_color: \"#000000\",\r\n chosen_cycles: null,\r\n customCycles: '',\r\n options: {\r\n title: {\r\n text: ''\r\n },\r\n chart: {\r\n height: '200px'\r\n },\r\n xAxis: {\r\n type: 'logarithmic'\r\n },\r\n yAxis: [{\r\n title: false,\r\n labels: {\r\n enabled: false\r\n }\r\n }],\r\n series: [{\r\n type: 'line',\r\n data: []\r\n }],\r\n legend: {\r\n enabled: false\r\n },\r\n responsive: {\r\n rules: [{\r\n condition: {\r\n maxWidth: 500\r\n },\r\n chartOptions: {\r\n chart: {\r\n height: '200px'\r\n },\r\n line: {\r\n states: {\r\n hover: {\r\n lineWidthPlus: 0\r\n },\r\n }\r\n },\r\n states: {\r\n hover: {\r\n enabled: false\r\n }\r\n },\r\n plotLines: {\r\n label: {\r\n text: '',\r\n y: 0\r\n }\r\n }\r\n }\r\n }]\r\n }\r\n }\r\n })\r\n \r\n\r\n // initial\r\n React.useEffect(() => {\r\n // function def\r\n const addQSpectrumModel = async () => {\r\n const data = await qSpecAdd(stockName, stockType)\r\n let newState = {...qSpectrumModelOptions}\r\n newState.model_index = data.model_index\r\n newState.options.series[0].data = data.data\r\n newState.chosen_cycles = data.chosen_cycles\r\n newState.chosen_cycles.forEach(element => {\r\n if (element[1]==='true') {\r\n element[1] = true\r\n } else {\r\n element[1] = false\r\n }\r\n })\r\n newState.options.xAxis.plotLines = data.chosen_cycles.map(element => ({\r\n value: element[0],\r\n width: 0.5,\r\n label: {\r\n text: element[0],\r\n align: 'right',\r\n y: 150\r\n }\r\n }))\r\n newState.loading = false\r\n newState.submitDisabled = false\r\n setQSpectrumModelOptions(newState)\r\n }\r\n const getQSpecData = async () => {\r\n const modelParams = await getModelParams(modelIndex, stockType) \r\n const periodogram = await getPeriodogram(modelIndex, stockType)\r\n let newState = {...qSpectrumModelOptions}\r\n newState.qSpec_model_sm = modelParams.SM\r\n newState.qSpec_model_fsm = modelParams.FSM\r\n newState.qSpec_model_sz = modelParams.SZ\r\n newState.qSpec_model_kind = modelParams.Kind\r\n newState.qSpec_model_overtones = modelParams.Overtones\r\n newState.options.series[0].data = periodogram.data\r\n newState.chosen_cycles = periodogram.chosen_cycles\r\n newState.customCycles = periodogram.customCycles\r\n newState.chosen_cycles.forEach(element => {\r\n if (element[1]==='true') {\r\n element[1] = true\r\n } else {\r\n element[1] = false\r\n }\r\n })\r\n newState.options.xAxis.plotLines = periodogram.chosen_cycles.map(element => ({\r\n value: element[0],\r\n width: 0.5,\r\n label: {\r\n text: element[0],\r\n align: 'right',\r\n y: 150\r\n }\r\n }))\r\n newState.loading = false\r\n setQSpectrumModelOptions(newState)\r\n }\r\n\r\n // ops\r\n if (type===\"New\") {\r\n let newState = {...qSpectrumModelOptions}\r\n newState.loading = true\r\n setQSpectrumModelOptions(newState)\r\n addQSpectrumModel()\r\n } else if (type===\"Edit\") {\r\n let newState = {...qSpectrumModelOptions}\r\n newState.loading = true\r\n setQSpectrumModelOptions(newState)\r\n getQSpecData()\r\n } else {\r\n }\r\n \r\n // return () => {\r\n // // cleanup\r\n // }\r\n }, [])\r\n\r\n // *********** OPERATIONS **************\r\n const qSpecSMChange = (value) => {\r\n const newState={...qSpectrumModelOptions}\r\n newState.qSpec_model_sm = value\r\n newState.submitDisabled = true\r\n setQSpectrumModelOptions(newState)\r\n }\r\n \r\n const qSpecSZChange = (value) => {\r\n const newState={...qSpectrumModelOptions}\r\n newState.qSpec_model_sz = parseInt(value)\r\n newState.submitDisabled = true\r\n setQSpectrumModelOptions(newState)\r\n }\r\n \r\n const qSpecOvertonesChange = (value) => {\r\n let newState={...qSpectrumModelOptions}\r\n newState.qSpec_model_overtones = value\r\n setQSpectrumModelOptions(newState)\r\n }\r\n\r\n const qSpecFSMChange = (value) => {\r\n const newState={...qSpectrumModelOptions}\r\n newState.qSpec_model_fsm = value\r\n setQSpectrumModelOptions(newState)\r\n }\r\n\r\n const qSpecKindChange = (event) => {\r\n const newState={...qSpectrumModelOptions}\r\n newState.qSpec_model_kind = event.target.value\r\n newState.submitDisabled = true\r\n setQSpectrumModelOptions(newState)\r\n }\r\n\r\n const cancelModelHandler = async () => {\r\n if (type===\"New\") {\r\n await qSpecDelete(stockName, qSpectrumModelOptions.model_index, stockType)\r\n closeClicked()\r\n } else if (type===\"Edit\") {\r\n closeClicked()\r\n }\r\n }\r\n\r\n const submitClickedHandler = () => {\r\n let chosen_cyclesString = ''\r\n qSpectrumModelOptions.chosen_cycles.forEach((element, index) => {\r\n chosen_cyclesString = chosen_cyclesString + element[1]\r\n if (qSpectrumModelOptions.chosen_cycles[index+1]) {\r\n chosen_cyclesString = chosen_cyclesString + \"@\"\r\n }\r\n });\r\n const submitObject = {\r\n symbol: stockName,\r\n chartkind: stockType?stockType:'standard',\r\n model_index: qSpectrumModelOptions.model_index,\r\n Kind: qSpectrumModelOptions.qSpec_model_kind,\r\n SM: qSpectrumModelOptions.qSpec_model_sm,\r\n FSM: qSpectrumModelOptions.qSpec_model_fsm,\r\n SZ: qSpectrumModelOptions.qSpec_model_sz,\r\n Overtones: qSpectrumModelOptions.qSpec_model_overtones,\r\n color: '#000',\r\n Target: '50',\r\n customCycles: qSpectrumModelOptions.customCycles,\r\n chosen_cycles: chosen_cyclesString,\r\n type: 'qspec'\r\n }\r\n submitClicked(submitObject)\r\n }\r\n\r\n const generatePeriodogramHandler = async () => {\r\n // Set Loading\r\n let newState = {...qSpectrumModelOptions}\r\n newState.loading = true\r\n setQSpectrumModelOptions(newState)\r\n\r\n const SecondRequest = {\r\n stock: stockName,\r\n chartkind: stockType?stockType:'standard',\r\n model_index: qSpectrumModelOptions.model_index,\r\n Kind: qSpectrumModelOptions.qSpec_model_kind,\r\n SM: qSpectrumModelOptions.qSpec_model_sm,\r\n SZ: qSpectrumModelOptions.qSpec_model_sz,\r\n Overtones: qSpectrumModelOptions.qSpec_model_overtones,\r\n FSM: qSpectrumModelOptions.qSpec_model_fsm\r\n }\r\n\r\n const data = await qSpecCalculatePeriodogram(SecondRequest)\r\n if (!data.error) {\r\n newState = {...qSpectrumModelOptions}\r\n newState.options.series[0].data = data.data\r\n newState.chosen_cycles = data.chosen_cycles\r\n newState.chosen_cycles.forEach(element => {\r\n if (element[1]==='true') {\r\n element[1] = true\r\n } else {\r\n element[1] = false\r\n }\r\n });\r\n newState.loading = false\r\n newState.submitDisabled = false\r\n newState.options.xAxis.plotLines = data.chosen_cycles.map(element => ({\r\n value: element[0],\r\n width: 1,\r\n label: {\r\n text: element[0],\r\n align: 'right'\r\n }\r\n }))\r\n setQSpectrumModelOptions(newState)\r\n } else {\r\n alert(data.error)\r\n newState = {...qSpectrumModelOptions}\r\n newState.loading = false\r\n setQSpectrumModelOptions(newState)\r\n }\r\n }\r\n\r\n const cycleCheckboxChangeHandler = (index) => {\r\n let newState = {...qSpectrumModelOptions}\r\n newState.chosen_cycles[index][1] = !newState.chosen_cycles[index][1]\r\n setQSpectrumModelOptions(newState)\r\n }\r\n\r\n const customCyclesChangeHandler = (event) => {\r\n const newState = {...qSpectrumModelOptions}\r\n newState.customCycles = event.target.value\r\n setQSpectrumModelOptions(newState)\r\n }\r\n\r\n // Pre-Render Code\r\n // Delete Button Visibility\r\n let deleteButton = null\r\n if (deleteVisible) {\r\n deleteButton = \r\n }\r\n\r\n let QSpecDialog = null\r\n\r\n if (qSpectrumModelOptions.loading) {\r\n QSpecDialog =
\r\n \r\n

Loading Data, please wait...

\r\n
\r\n } else {\r\n QSpecDialog =\r\n }\r\n\r\n let QSpecCycles = \r\n if (qSpectrumModelOptions.chosen_cycles) {\r\n QSpecCycles = qSpectrumModelOptions.chosen_cycles.map((item, index) => (\r\n
\r\n cycleCheckboxChangeHandler(index)} />\r\n
\r\n
\r\n ))\r\n }\r\n\r\n // \r\n let title\r\n if (type===\"New\") {\r\n title = \"Add Spectrum Module\"\r\n } else {\r\n title = \"Edit Spectrum Module\"\r\n }\r\n\r\n // Submit button disabled\r\n let submitButtonDisabled = false\r\n if (loading || qSpectrumModelOptions.submitDisabled) {\r\n submitButtonDisabled = true\r\n }\r\n\r\n return (\r\n \r\n
{title}
\r\n
\r\n
\r\n {QSpecDialog}\r\n
\r\n
\r\n Spectrum Settings:\r\n
\r\n Kind:\r\n \r\n Stock Memory:\r\n \r\n Sample Size:\r\n \r\n
\r\n \r\n
\r\n
\r\n Overtones:\r\n \r\n
\r\n FSM:\r\n \r\n {/* Custom Cycles: \r\n */}\r\n
\r\n
\r\n
\r\n Cycles:\r\n {QSpecCycles}\r\n
\r\n
\r\n
\r\n {deleteButton}\r\n \r\n \r\n
\r\n
\r\n )\r\n}","import React, { useState, useEffect, useContext } from 'react';\r\nimport HighchartsReact from 'highcharts-react-official';\r\nimport Highcharts from 'highcharts/highstock';\r\nimport Button from '../components/Button';\r\nimport Spinner from '../components/Spinner';\r\nimport DataContext from '../context/DataContext';\r\nimport moment from 'moment';\r\n\r\nexport default function IxDialog({closeClicked, instrument, ixData, instrData, stockIsFavorite, ixSelected}) {\r\n // context defs\r\n const { getIxData, showIxOnMain, addIxDataToModels, removeIxFromMain } = useContext(DataContext)\r\n\r\n // state defs\r\n const [shownIndex, setShownIndex] = useState(0)\r\n const [ixGraphData, setIxGraphData] = useState([])\r\n const [showingOnChart, setShowOnChart] = useState(false)\r\n\r\n const minTime = (moment(new Date()).valueOf()) - (1000*3600*24*180)\r\n\r\n const chartOptions = {\r\n tooltip: {\r\n formatter: function() {\r\n return 'Date: '+moment(this.x).format('L')\r\n }\r\n },\r\n rangeSelector: {\r\n // zoom buttons for 1m 3m YTD etc. disabled, change later if needed\r\n buttonTheme: {\r\n visibility: 'hidden'\r\n },\r\n },\r\n boost: {\r\n enabled: true,\r\n useGPUTranslations: true,\r\n },\r\n plotOptions: {\r\n series: {\r\n dataGrouping: {\r\n units: [[\r\n 'day', // unit name\r\n [1] // allowed multiples\r\n ], [\r\n 'month',\r\n [1, 2, 3, 4, 6]\r\n ]]\r\n },\r\n // general options for all series\r\n turboThreshold: 1000,\r\n // compare: 'percent',\r\n showInNavigator: true,\r\n }\r\n },\r\n // rangeSelector: {\r\n // selected: 0\r\n // },\r\n xAxis: {\r\n min: minTime,\r\n // max: maxTime\r\n },\r\n yAxis: [{\r\n\r\n }, {\r\n height: '100%',\r\n // floor: -1,\r\n // ceiling: 1,\r\n // visible: true\r\n }],\r\n series: [instrData[0], {\r\n name: \"Comparison\",\r\n color: \"#FF0000\",\r\n yAxis: 1,\r\n visible: true,\r\n data: ixGraphData\r\n }]\r\n // }, projLine]\r\n }\r\n\r\n // useEffect\r\n useEffect(() => {\r\n const ixContextRequest = async () => {\r\n setIxGraphData([])\r\n\r\n if (ixData.length) {\r\n const requestObj = {\r\n le: ixData[shownIndex][0],\r\n lag: parseInt(ixData[shownIndex][2].split('=')[1]),\r\n status: ixData[shownIndex][4].split('=')[1]\r\n }\r\n const contextResponse = await getIxData(requestObj)\r\n \r\n if (contextResponse.length) {\r\n setIxGraphData(contextResponse)\r\n } else {\r\n alert('No data')\r\n }\r\n \r\n const leIndex = instrData.findIndex(item => item.name === 'I-'+ixData[shownIndex][0])\r\n if (leIndex > -1) {\r\n setShowOnChart(true)\r\n } else {\r\n setShowOnChart(false)\r\n }\r\n }\r\n }\r\n\r\n ixContextRequest()\r\n\r\n return () => {\r\n // cleanup\r\n }\r\n }, [shownIndex])\r\n\r\n\r\n // handlers\r\n const showLeadingCheckedHandler = async () => {\r\n if (!showingOnChart) {\r\n const addSuccess = await showIxOnMain(instrument, ixData[shownIndex][0])\r\n if (addSuccess) {\r\n const ixDataObject = {\r\n name: \"I-\"+ixData[shownIndex][0],\r\n data: ixGraphData,\r\n header: \"LE - \"+ixData[shownIndex][0]+\" | R - \"+ixData[shownIndex][3].split('=')[1],\r\n lineWidth: \"1\",\r\n color: \"#000\",\r\n opacity: \"0.5\",\r\n yAxis: 1,\r\n visible: true\r\n }\r\n await addIxDataToModels(ixDataObject)\r\n setShowOnChart(true)\r\n ixSelected()\r\n } else {\r\n setShowOnChart(true)\r\n ixSelected()\r\n }\r\n } else {\r\n await removeIxFromMain(instrument, ixData[shownIndex][0])\r\n setShowOnChart(false)\r\n ixSelected()\r\n }\r\n }\r\n\r\n // pre-render\r\n // navigation\r\n const ixList = ixData.map((item, index) => {\r\n const isInverted = item[4].split('=')[1][0]\r\n return (\r\n
  • setShownIndex(index)}>\r\n {item[0]}, Lag: {Math.abs(parseInt(item[2].split('=')[1]))}d{isInverted === 'I'? ', Inv' : null}\r\n
  • \r\n )\r\n })\r\n\r\n // show on main chart checkbox\r\n let showIxOnChart\r\n\r\n if (stockIsFavorite) {\r\n showIxOnChart = ( Show on main chart)\r\n } else {\r\n showIxOnChart =
    Add to Favorite to Display Intermarket on Main Chart
    \r\n }\r\n\r\n // chart display\r\n let ixDisplay\r\n \r\n if (ixData.length) {\r\n ixDisplay =\r\n
    \r\n

    {ixData[shownIndex][0]} - {ixData[shownIndex][1]}

    \r\n

    {ixData[shownIndex][2]}, {ixData[shownIndex][4]}, {ixData[shownIndex][5]}

    \r\n
    \r\n

    Similarity: {ixData[shownIndex][3].split('=')[1]}

    \r\n {showIxOnChart}\r\n
    \r\n } else {\r\n ixDisplay =
    No Intermarket Instruments
    \r\n }\r\n\r\n let chartElement = \r\n \r\n if (ixGraphData.length) {\r\n chartElement = \r\n } else if (!ixData.length) {\r\n chartElement = \r\n }\r\n\r\n return (\r\n
    \r\n
    \r\n Intermarket Analysis for {instrument}. {ixData.length} Leading Indicators found\r\n \r\n
    \r\n
    \r\n
    \r\n
      \r\n {ixList}\r\n
    \r\n
    \r\n
    \r\n {ixDisplay}\r\n {chartElement}\r\n
    \r\n
    \r\n {/*
    \r\n \r\n
    */}\r\n
    \r\n )\r\n}","import { useContext } from 'react'\r\nimport UserContext from '../context/UserContext'\r\nimport DataContext from '../context/DataContext'\r\nimport {Navigate} from 'react-router-dom'\r\n\r\nexport default () => {\r\n const {removeUser} = useContext(UserContext)\r\n const {removeData} = useContext(DataContext)\r\n\r\n const errorHandler = (error) => {\r\n const errCode = error.message\r\n\r\n switch (errCode) {\r\n case '401':\r\n removeUser()\r\n removeData()\r\n localStorage.removeItem('token')\r\n return ()\r\n case '400':\r\n return '400'\r\n default:\r\n return errCode\r\n }\r\n }\r\n\r\n return {errorHandler}\r\n}","import React from \"react\";\nexport var DefaultContext = {\n color: undefined,\n size: undefined,\n className: undefined,\n style: undefined,\n attr: undefined\n};\nexport var IconContext = React.createContext && React.createContext(DefaultContext);","var __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)) t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\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) t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\") 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])) t[p[i]] = s[p[i]];\n }\n return t;\n};\nimport React from \"react\";\nimport { IconContext, DefaultContext } from \"./iconContext\";\nfunction Tree2Element(tree) {\n return tree && tree.map(function (node, i) {\n return React.createElement(node.tag, __assign({\n key: i\n }, node.attr), Tree2Element(node.child));\n });\n}\nexport function GenIcon(data) {\n // eslint-disable-next-line react/display-name\n return function (props) {\n return React.createElement(IconBase, __assign({\n attr: __assign({}, data.attr)\n }, props), Tree2Element(data.child));\n };\n}\nexport function IconBase(props) {\n var elem = function (conf) {\n var attr = props.attr,\n size = props.size,\n title = props.title,\n svgProps = __rest(props, [\"attr\", \"size\", \"title\"]);\n var computedSize = size || conf.size || \"1em\";\n var className;\n if (conf.className) className = conf.className;\n if (props.className) className = (className ? className + \" \" : \"\") + props.className;\n return React.createElement(\"svg\", __assign({\n stroke: \"currentColor\",\n fill: \"currentColor\",\n strokeWidth: \"0\"\n }, conf.attr, attr, svgProps, {\n className: className,\n style: __assign(__assign({\n color: props.color || conf.color\n }, conf.style), props.style),\n height: computedSize,\n width: computedSize,\n xmlns: \"http://www.w3.org/2000/svg\"\n }), title && React.createElement(\"title\", null, title), props.children);\n };\n return IconContext !== undefined ? React.createElement(IconContext.Consumer, null, function (conf) {\n return elem(conf);\n }) : elem(DefaultContext);\n}","// THIS FILE IS AUTO GENERATED\nimport { GenIcon } from '../lib';\nexport function AiFillAccountBook (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 184H712v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H384v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H144c-17.7 0-32 14.3-32 32v664c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V216c0-17.7-14.3-32-32-32zM648.3 426.8l-87.7 161.1h45.7c5.5 0 10 4.5 10 10v21.3c0 5.5-4.5 10-10 10h-63.4v29.7h63.4c5.5 0 10 4.5 10 10v21.3c0 5.5-4.5 10-10 10h-63.4V752c0 5.5-4.5 10-10 10h-41.3c-5.5 0-10-4.5-10-10v-51.8h-63.1c-5.5 0-10-4.5-10-10v-21.3c0-5.5 4.5-10 10-10h63.1v-29.7h-63.1c-5.5 0-10-4.5-10-10v-21.3c0-5.5 4.5-10 10-10h45.2l-88-161.1c-2.6-4.8-.9-10.9 4-13.6 1.5-.8 3.1-1.2 4.8-1.2h46c3.8 0 7.2 2.1 8.9 5.5l72.9 144.3 73.2-144.3a10 10 0 0 1 8.9-5.5h45c5.5 0 10 4.5 10 10 .1 1.7-.3 3.3-1.1 4.8z\"}}]})(props);\n};\nexport function AiFillAlert (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 244c176.18 0 319 142.82 319 319v233a32 32 0 0 1-32 32H225a32 32 0 0 1-32-32V563c0-176.18 142.82-319 319-319zM484 68h56a8 8 0 0 1 8 8v96a8 8 0 0 1-8 8h-56a8 8 0 0 1-8-8V76a8 8 0 0 1 8-8zM177.25 191.66a8 8 0 0 1 11.32 0l67.88 67.88a8 8 0 0 1 0 11.31l-39.6 39.6a8 8 0 0 1-11.31 0l-67.88-67.88a8 8 0 0 1 0-11.31l39.6-39.6zm669.6 0l39.6 39.6a8 8 0 0 1 0 11.3l-67.88 67.9a8 8 0 0 1-11.32 0l-39.6-39.6a8 8 0 0 1 0-11.32l67.89-67.88a8 8 0 0 1 11.31 0zM192 892h640a32 32 0 0 1 32 32v24a8 8 0 0 1-8 8H168a8 8 0 0 1-8-8v-24a32 32 0 0 1 32-32zm148-317v253h64V575h-64z\"}}]})(props);\n};\nexport function AiFillAlipayCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M308.6 545.7c-19.8 2-57.1 10.7-77.4 28.6-61 53-24.5 150 99 150 71.8 0 143.5-45.7 199.8-119-80.2-38.9-148.1-66.8-221.4-59.6zm460.5 67c100.1 33.4 154.7 43 166.7 44.8A445.9 445.9 0 0 0 960 512c0-247.4-200.6-448-448-448S64 264.6 64 512s200.6 448 448 448c155.9 0 293.2-79.7 373.5-200.5-75.6-29.8-213.6-85-286.8-120.1-69.9 85.7-160.1 137.8-253.7 137.8-158.4 0-212.1-138.1-137.2-229 16.3-19.8 44.2-38.7 87.3-49.4 67.5-16.5 175 10.3 275.7 43.4 18.1-33.3 33.4-69.9 44.7-108.9H305.1V402h160v-56.2H271.3v-31.3h193.8v-80.1s0-13.5 13.7-13.5H557v93.6h191.7v31.3H557.1V402h156.4c-15 61.1-37.7 117.4-66.2 166.8 47.5 17.1 90.1 33.3 121.8 43.9z\"}}]})(props);\n};\nexport function AiFillAlipaySquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M308.6 545.7c-19.8 2-57.1 10.7-77.4 28.6-61 53-24.5 150 99 150 71.8 0 143.5-45.7 199.8-119-80.2-38.9-148.1-66.8-221.4-59.6zM880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm29.4 663.2S703 689.4 598.7 639.5C528.8 725.2 438.6 777.3 345 777.3c-158.4 0-212.1-138.1-137.2-229 16.3-19.8 44.2-38.7 87.3-49.4 67.5-16.5 175 10.3 275.7 43.4 18.1-33.3 33.4-69.9 44.7-108.9H305.1V402h160v-56.2H271.3v-31.3h193.8v-80.1s0-13.5 13.7-13.5H557v93.6h191.7v31.3H557.1V402h156.4c-15 61.1-37.7 117.4-66.2 166.8 47.5 17.1 90.1 33.3 121.8 43.9 114.3 38.2 140.2 40.2 140.2 40.2v122.3z\"}}]})(props);\n};\nexport function AiFillAliwangwang (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M868.2 377.4c-18.9-45.1-46.3-85.6-81.2-120.6a377.26 377.26 0 0 0-120.5-81.2A375.65 375.65 0 0 0 519 145.8c-41.9 0-82.9 6.7-121.9 20C306 123.3 200.8 120 170.6 120c-2.2 0-7.4 0-9.4.2-11.9.4-22.8 6.5-29.2 16.4-6.5 9.9-7.7 22.4-3.4 33.5l64.3 161.6a378.59 378.59 0 0 0-52.8 193.2c0 51.4 10 101 29.8 147.6 18.9 45 46.2 85.6 81.2 120.5 34.7 34.8 75.4 62.1 120.5 81.2C418.3 894 467.9 904 519 904c51.3 0 100.9-10 147.7-29.8 44.9-18.9 85.5-46.3 120.4-81.2 34.7-34.8 62.1-75.4 81.2-120.6a376.5 376.5 0 0 0 29.8-147.6c-.2-51.2-10.1-100.8-29.9-147.4zm-325.2 79c0 20.4-16.6 37.1-37.1 37.1-20.4 0-37.1-16.7-37.1-37.1v-55.1c0-20.4 16.6-37.1 37.1-37.1 20.4 0 37.1 16.6 37.1 37.1v55.1zm175.2 0c0 20.4-16.6 37.1-37.1 37.1S644 476.8 644 456.4v-55.1c0-20.4 16.7-37.1 37.1-37.1 20.4 0 37.1 16.6 37.1 37.1v55.1z\"}}]})(props);\n};\nexport function AiFillAmazonCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M485 467.5c-11.6 4.9-20.9 12.2-27.8 22-6.9 9.8-10.4 21.6-10.4 35.5 0 17.8 7.5 31.5 22.4 41.2 14.1 9.1 28.9 11.4 44.4 6.8 17.9-5.2 30-17.9 36.4-38.1 3-9.3 4.5-19.7 4.5-31.3v-50.2c-12.6.4-24.4 1.6-35.5 3.7-11.1 2.1-22.4 5.6-34 10.4zM512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm35.8 262.7c-7.2-10.9-20.1-16.4-38.7-16.4-1.3 0-3 .1-5.3.3-2.2.2-6.6 1.5-12.9 3.7a79.4 79.4 0 0 0-17.9 9.1c-5.5 3.8-11.5 10-18 18.4-6.4 8.5-11.5 18.4-15.3 29.8l-94-8.4c0-12.4 2.4-24.7 7-36.9 4.7-12.2 11.8-23.9 21.4-35 9.6-11.2 21.1-21 34.5-29.4 13.4-8.5 29.6-15.2 48.4-20.3 18.9-5.1 39.1-7.6 60.9-7.6 21.3 0 40.6 2.6 57.8 7.7 17.2 5.2 31.1 11.5 41.4 19.1a117 117 0 0 1 25.9 25.7c6.9 9.6 11.7 18.5 14.4 26.7 2.7 8.2 4 15.7 4 22.8v182.5c0 6.4 1.4 13 4.3 19.8 2.9 6.8 6.3 12.8 10.2 18 3.9 5.2 7.9 9.9 12 14.3 4.1 4.3 7.6 7.7 10.6 9.9l4.1 3.4-72.5 69.4c-8.5-7.7-16.9-15.4-25.2-23.4-8.3-8-14.5-14-18.5-18.1l-6.1-6.2c-2.4-2.3-5-5.7-8-10.2-8.1 12.2-18.5 22.8-31.1 31.8-12.7 9-26.3 15.6-40.7 19.7-14.5 4.1-29.4 6.5-44.7 7.1-15.3.6-30-1.5-43.9-6.5-13.9-5-26.5-11.7-37.6-20.3-11.1-8.6-19.9-20.2-26.5-35-6.6-14.8-9.9-31.5-9.9-50.4 0-17.4 3-33.3 8.9-47.7 6-14.5 13.6-26.5 23-36.1 9.4-9.6 20.7-18.2 34-25.7s26.4-13.4 39.2-17.7c12.8-4.2 26.6-7.8 41.5-10.7 14.9-2.9 27.6-4.8 38.2-5.7 10.6-.9 21.2-1.6 31.8-2v-39.4c0-13.5-2.3-23.5-6.7-30.1zm180.5 379.6c-2.8 3.3-7.5 7.8-14.1 13.5s-16.8 12.7-30.5 21.1c-13.7 8.4-28.8 16-45 22.9-16.3 6.9-36.3 12.9-60.1 18-23.7 5.1-48.2 7.6-73.3 7.6-25.4 0-50.7-3.2-76.1-9.6-25.4-6.4-47.6-14.3-66.8-23.7-19.1-9.4-37.6-20.2-55.1-32.2-17.6-12.1-31.7-22.9-42.4-32.5-10.6-9.6-19.6-18.7-26.8-27.1-1.7-1.9-2.8-3.6-3.2-5.1-.4-1.5-.3-2.8.3-3.7.6-.9 1.5-1.6 2.6-2.2a7.42 7.42 0 0 1 7.4.8c40.9 24.2 72.9 41.3 95.9 51.4 82.9 36.4 168 45.7 255.3 27.9 40.5-8.3 82.1-22.2 124.9-41.8 3.2-1.2 6-1.5 8.3-.9 2.3.6 3.5 2.4 3.5 5.4 0 2.8-1.6 6.3-4.8 10.2zm59.9-29c-1.8 11.1-4.9 21.6-9.1 31.8-7.2 17.1-16.3 30-27.1 38.4-3.6 2.9-6.4 3.8-8.3 2.8-1.9-1-1.9-3.5 0-7.4 4.5-9.3 9.2-21.8 14.2-37.7 5-15.8 5.7-26 2.1-30.5-1.1-1.5-2.7-2.6-5-3.6-2.2-.9-5.1-1.5-8.6-1.9s-6.7-.6-9.4-.8c-2.8-.2-6.5-.2-11.2 0-4.7.2-8 .4-10.1.6a874.4 874.4 0 0 1-17.1 1.5c-1.3.2-2.7.4-4.1.5-1.5.1-2.7.2-3.5.3l-2.7.3c-1 .1-1.7.2-2.2.2h-3.2l-1-.2-.6-.5-.5-.9c-1.3-3.3 3.7-7.4 15-12.4s22.3-8.1 32.9-9.3c9.8-1.5 21.3-1.5 34.5-.3s21.3 3.7 24.3 7.4c2.3 3.5 2.5 10.7.7 21.7z\"}}]})(props);\n};\nexport function AiFillAmazonSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM547.8 326.7c-7.2-10.9-20.1-16.4-38.7-16.4-1.3 0-3 .1-5.3.3-2.2.2-6.6 1.5-12.9 3.7a79.4 79.4 0 0 0-17.9 9.1c-5.5 3.8-11.5 10-18 18.4-6.4 8.5-11.5 18.4-15.3 29.8l-94-8.4c0-12.4 2.4-24.7 7-36.9s11.8-23.9 21.4-35c9.6-11.2 21.1-21 34.5-29.4 13.4-8.5 29.6-15.2 48.4-20.3 18.9-5.1 39.1-7.6 60.9-7.6 21.3 0 40.6 2.6 57.8 7.7 17.2 5.2 31.1 11.5 41.4 19.1a117 117 0 0 1 25.9 25.7c6.9 9.6 11.7 18.5 14.4 26.7 2.7 8.2 4 15.7 4 22.8v182.5c0 6.4 1.4 13 4.3 19.8 2.9 6.8 6.3 12.8 10.2 18 3.9 5.2 7.9 9.9 12 14.3 4.1 4.3 7.6 7.7 10.6 9.9l4.1 3.4-72.5 69.4c-8.5-7.7-16.9-15.4-25.2-23.4-8.3-8-14.5-14-18.5-18.1l-6.1-6.2c-2.4-2.3-5-5.7-8-10.2-8.1 12.2-18.5 22.8-31.1 31.8-12.7 9-26.3 15.6-40.7 19.7-14.5 4.1-29.4 6.5-44.7 7.1-15.3.6-30-1.5-43.9-6.5-13.9-5-26.5-11.7-37.6-20.3-11.1-8.6-19.9-20.2-26.5-35-6.6-14.8-9.9-31.5-9.9-50.4 0-17.4 3-33.3 8.9-47.7 6-14.5 13.6-26.5 23-36.1 9.4-9.6 20.7-18.2 34-25.7s26.4-13.4 39.2-17.7c12.8-4.2 26.6-7.8 41.5-10.7 14.9-2.9 27.6-4.8 38.2-5.7 10.6-.9 21.2-1.6 31.8-2v-39.4c0-13.5-2.3-23.5-6.7-30.1zm180.5 379.6c-2.8 3.3-7.5 7.8-14.1 13.5s-16.8 12.7-30.5 21.1c-13.7 8.4-28.8 16-45 22.9-16.3 6.9-36.3 12.9-60.1 18-23.7 5.1-48.2 7.6-73.3 7.6-25.4 0-50.7-3.2-76.1-9.6-25.4-6.4-47.6-14.3-66.8-23.7-19.1-9.4-37.6-20.2-55.1-32.2-17.6-12.1-31.7-22.9-42.4-32.5-10.6-9.6-19.6-18.7-26.8-27.1-1.7-1.9-2.8-3.6-3.2-5.1-.4-1.5-.3-2.8.3-3.7.6-.9 1.5-1.6 2.6-2.2a7.42 7.42 0 0 1 7.4.8c40.9 24.2 72.9 41.3 95.9 51.4 82.9 36.4 168 45.7 255.3 27.9 40.5-8.3 82.1-22.2 124.9-41.8 3.2-1.2 6-1.5 8.3-.9 2.3.6 3.5 2.4 3.5 5.4 0 2.8-1.6 6.3-4.8 10.2zm59.9-29c-1.8 11.1-4.9 21.6-9.1 31.8-7.2 17.1-16.3 30-27.1 38.4-3.6 2.9-6.4 3.8-8.3 2.8-1.9-1-1.9-3.5 0-7.4 4.5-9.3 9.2-21.8 14.2-37.7 5-15.8 5.7-26 2.1-30.5-1.1-1.5-2.7-2.6-5-3.6-2.2-.9-5.1-1.5-8.6-1.9s-6.7-.6-9.4-.8c-2.8-.2-6.5-.2-11.2 0-4.7.2-8 .4-10.1.6a874.4 874.4 0 0 1-17.1 1.5c-1.3.2-2.7.4-4.1.5-1.5.1-2.7.2-3.5.3l-2.7.3c-1 .1-1.7.2-2.2.2h-3.2l-1-.2-.6-.5-.5-.9c-1.3-3.3 3.7-7.4 15-12.4s22.3-8.1 32.9-9.3c9.8-1.5 21.3-1.5 34.5-.3s21.3 3.7 24.3 7.4c2.3 3.5 2.5 10.7.7 21.7zM485 467.5c-11.6 4.9-20.9 12.2-27.8 22-6.9 9.8-10.4 21.6-10.4 35.5 0 17.8 7.5 31.5 22.4 41.2 14.1 9.1 28.9 11.4 44.4 6.8 17.9-5.2 30-17.9 36.4-38.1 3-9.3 4.5-19.7 4.5-31.3v-50.2c-12.6.4-24.4 1.6-35.5 3.7-11.1 2.1-22.4 5.6-34 10.4z\"}}]})(props);\n};\nexport function AiFillAndroid (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M270.1 741.7c0 23.4 19.1 42.5 42.6 42.5h48.7v120.4c0 30.5 24.5 55.4 54.6 55.4 30.2 0 54.6-24.8 54.6-55.4V784.1h85v120.4c0 30.5 24.5 55.4 54.6 55.4 30.2 0 54.6-24.8 54.6-55.4V784.1h48.7c23.5 0 42.6-19.1 42.6-42.5V346.4h-486v395.3zm357.1-600.1l44.9-65c2.6-3.8 2-8.9-1.5-11.4-3.5-2.4-8.5-1.2-11.1 2.6l-46.6 67.6c-30.7-12.1-64.9-18.8-100.8-18.8-35.9 0-70.1 6.7-100.8 18.8l-46.6-67.5c-2.6-3.8-7.6-5.1-11.1-2.6-3.5 2.4-4.1 7.4-1.5 11.4l44.9 65c-71.4 33.2-121.4 96.1-127.8 169.6h486c-6.6-73.6-56.7-136.5-128-169.7zM409.5 244.1a26.9 26.9 0 1 1 26.9-26.9 26.97 26.97 0 0 1-26.9 26.9zm208.4 0a26.9 26.9 0 1 1 26.9-26.9 26.97 26.97 0 0 1-26.9 26.9zm223.4 100.7c-30.2 0-54.6 24.8-54.6 55.4v216.4c0 30.5 24.5 55.4 54.6 55.4 30.2 0 54.6-24.8 54.6-55.4V400.1c.1-30.6-24.3-55.3-54.6-55.3zm-658.6 0c-30.2 0-54.6 24.8-54.6 55.4v216.4c0 30.5 24.5 55.4 54.6 55.4 30.2 0 54.6-24.8 54.6-55.4V400.1c0-30.6-24.5-55.3-54.6-55.3z\"}}]})(props);\n};\nexport function AiFillApi (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M917.7 148.8l-42.4-42.4c-1.6-1.6-3.6-2.3-5.7-2.3s-4.1.8-5.7 2.3l-76.1 76.1a199.27 199.27 0 0 0-112.1-34.3c-51.2 0-102.4 19.5-141.5 58.6L432.3 308.7a8.03 8.03 0 0 0 0 11.3L704 591.7c1.6 1.6 3.6 2.3 5.7 2.3 2 0 4.1-.8 5.7-2.3l101.9-101.9c68.9-69 77-175.7 24.3-253.5l76.1-76.1c3.1-3.2 3.1-8.3 0-11.4zM578.9 546.7a8.03 8.03 0 0 0-11.3 0L501 613.3 410.7 523l66.7-66.7c3.1-3.1 3.1-8.2 0-11.3L441 408.6a8.03 8.03 0 0 0-11.3 0L363 475.3l-43-43a7.85 7.85 0 0 0-5.7-2.3c-2 0-4.1.8-5.7 2.3L206.8 534.2c-68.9 68.9-77 175.7-24.3 253.5l-76.1 76.1a8.03 8.03 0 0 0 0 11.3l42.4 42.4c1.6 1.6 3.6 2.3 5.7 2.3s4.1-.8 5.7-2.3l76.1-76.1c33.7 22.9 72.9 34.3 112.1 34.3 51.2 0 102.4-19.5 141.5-58.6l101.9-101.9c3.1-3.1 3.1-8.2 0-11.3l-43-43 66.7-66.7c3.1-3.1 3.1-8.2 0-11.3l-36.6-36.2z\"}}]})(props);\n};\nexport function AiFillApple (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M747.4 535.7c-.4-68.2 30.5-119.6 92.9-157.5-34.9-50-87.7-77.5-157.3-82.8-65.9-5.2-138 38.4-164.4 38.4-27.9 0-91.7-36.6-141.9-36.6C273.1 298.8 163 379.8 163 544.6c0 48.7 8.9 99 26.7 150.8 23.8 68.2 109.6 235.3 199.1 232.6 46.8-1.1 79.9-33.2 140.8-33.2 59.1 0 89.7 33.2 141.9 33.2 90.3-1.3 167.9-153.2 190.5-221.6-121.1-57.1-114.6-167.2-114.6-170.7zm-105.1-305c50.7-60.2 46.1-115 44.6-134.7-44.8 2.6-96.6 30.5-126.1 64.8-32.5 36.8-51.6 82.3-47.5 133.6 48.4 3.7 92.6-21.2 129-63.7z\"}}]})(props);\n};\nexport function AiFillAppstore (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M864 144H560c-8.8 0-16 7.2-16 16v304c0 8.8 7.2 16 16 16h304c8.8 0 16-7.2 16-16V160c0-8.8-7.2-16-16-16zm0 400H560c-8.8 0-16 7.2-16 16v304c0 8.8 7.2 16 16 16h304c8.8 0 16-7.2 16-16V560c0-8.8-7.2-16-16-16zM464 144H160c-8.8 0-16 7.2-16 16v304c0 8.8 7.2 16 16 16h304c8.8 0 16-7.2 16-16V160c0-8.8-7.2-16-16-16zm0 400H160c-8.8 0-16 7.2-16 16v304c0 8.8 7.2 16 16 16h304c8.8 0 16-7.2 16-16V560c0-8.8-7.2-16-16-16z\"}}]})(props);\n};\nexport function AiFillAudio (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 624c93.9 0 170-75.2 170-168V232c0-92.8-76.1-168-170-168s-170 75.2-170 168v224c0 92.8 76.1 168 170 168zm330-170c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8 0 140.3-113.7 254-254 254S258 594.3 258 454c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8 0 168.7 126.6 307.9 290 327.6V884H326.7c-13.7 0-24.7 14.3-24.7 32v36c0 4.4 2.8 8 6.2 8h407.6c3.4 0 6.2-3.6 6.2-8v-36c0-17.7-11-32-24.7-32H548V782.1c165.3-18 294-158 294-328.1z\"}}]})(props);\n};\nexport function AiFillBackward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M485.6 249.9L198.2 498c-8.3 7.1-8.3 20.8 0 27.9l287.4 248.2c10.7 9.2 26.4.9 26.4-14V263.8c0-14.8-15.7-23.2-26.4-13.9zm320 0L518.2 498a18.6 18.6 0 0 0-6.2 14c0 5.2 2.1 10.4 6.2 14l287.4 248.2c10.7 9.2 26.4.9 26.4-14V263.8c0-14.8-15.7-23.2-26.4-13.9z\"}}]})(props);\n};\nexport function AiFillBank (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M894 462c30.9 0 43.8-39.7 18.7-58L530.8 126.2a31.81 31.81 0 0 0-37.6 0L111.3 404c-25.1 18.2-12.2 58 18.8 58H192v374h-72c-4.4 0-8 3.6-8 8v52c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-52c0-4.4-3.6-8-8-8h-72V462h62zM381 836H264V462h117v374zm189 0H453V462h117v374zm190 0H642V462h118v374z\"}}]})(props);\n};\nexport function AiFillBehanceCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M420.3 470.3c8.7-6.3 12.9-16.7 12.9-31 .3-6.8-1.1-13.5-4.1-19.6-2.7-4.9-6.7-9-11.6-11.9a44.8 44.8 0 0 0-16.6-6c-6.4-1.2-12.9-1.8-19.3-1.7h-70.3v79.7h76.1c13.1.1 24.2-3.1 32.9-9.5zm11.8 72c-9.8-7.5-22.9-11.2-39.2-11.2h-81.8v94h80.2c7.5 0 14.4-.7 21.1-2.1a50.5 50.5 0 0 0 17.8-7.2c5.1-3.3 9.2-7.8 12.3-13.6 3-5.8 4.5-13.2 4.5-22.1 0-17.7-5-30.2-14.9-37.8zM512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm86.5 286.9h138.4v33.7H598.5v-33.7zM512 628.8a89.52 89.52 0 0 1-27 31c-11.8 8.2-24.9 14.2-38.8 17.7a167.4 167.4 0 0 1-44.6 5.7H236V342.1h161c16.3 0 31.1 1.5 44.6 4.3 13.4 2.8 24.8 7.6 34.4 14.1 9.5 6.5 17 15.2 22.3 26 5.2 10.7 7.9 24.1 7.9 40 0 17.2-3.9 31.4-11.7 42.9-7.9 11.5-19.3 20.8-34.8 28.1 21.1 6 36.6 16.7 46.8 31.7 10.4 15.2 15.5 33.4 15.5 54.8 0 17.4-3.3 32.3-10 44.8zM790.8 576H612.4c0 19.4 6.7 38 16.8 48 10.2 9.9 24.8 14.9 43.9 14.9 13.8 0 25.5-3.5 35.5-10.4 9.9-6.9 15.9-14.2 18.1-21.8h59.8c-9.6 29.7-24.2 50.9-44 63.7-19.6 12.8-43.6 19.2-71.5 19.2-19.5 0-37-3.2-52.7-9.3-15.1-5.9-28.7-14.9-39.9-26.5a121.2 121.2 0 0 1-25.1-41.2c-6.1-16.9-9.1-34.7-8.9-52.6 0-18.5 3.1-35.7 9.1-51.7 11.5-31.1 35.4-56 65.9-68.9 16.3-6.8 33.8-10.2 51.5-10 21 0 39.2 4 55 12.2a111.6 111.6 0 0 1 38.6 32.8c10.1 13.7 17.2 29.3 21.7 46.9 4.3 17.3 5.8 35.5 4.6 54.7zm-122-95.6c-10.8 0-19.9 1.9-26.9 5.6-7 3.7-12.8 8.3-17.2 13.6a48.4 48.4 0 0 0-9.1 17.4c-1.6 5.3-2.7 10.7-3.1 16.2H723c-1.6-17.3-7.6-30.1-15.6-39.1-8.4-8.9-21.9-13.7-38.6-13.7z\"}}]})(props);\n};\nexport function AiFillBehanceSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM598.5 350.9h138.4v33.7H598.5v-33.7zM512 628.8a89.52 89.52 0 0 1-27 31c-11.8 8.2-24.9 14.2-38.8 17.7a167.4 167.4 0 0 1-44.6 5.7H236V342.1h161c16.3 0 31.1 1.5 44.6 4.3 13.4 2.8 24.8 7.6 34.4 14.1 9.5 6.5 17 15.2 22.3 26 5.2 10.7 7.9 24.1 7.9 40 0 17.2-3.9 31.4-11.7 42.9-7.9 11.5-19.3 20.8-34.8 28.1 21.1 6 36.6 16.7 46.8 31.7 10.4 15.2 15.5 33.4 15.5 54.8 0 17.4-3.3 32.3-10 44.8zM790.8 576H612.4c0 19.4 6.7 38 16.8 48 10.2 9.9 24.8 14.9 43.9 14.9 13.8 0 25.5-3.5 35.5-10.4 9.9-6.9 15.9-14.2 18.1-21.8h59.8c-9.6 29.7-24.2 50.9-44 63.7-19.6 12.8-43.6 19.2-71.5 19.2-19.5 0-37-3.2-52.7-9.3-15.1-5.9-28.7-14.9-39.9-26.5a121.2 121.2 0 0 1-25.1-41.2c-6.1-16.9-9.1-34.7-8.9-52.6 0-18.5 3.1-35.7 9.1-51.7 11.5-31.1 35.4-56 65.9-68.9 16.3-6.8 33.8-10.2 51.5-10 21 0 39.2 4 55 12.2a111.6 111.6 0 0 1 38.6 32.8c10.1 13.7 17.2 29.3 21.7 46.9 4.3 17.3 5.8 35.5 4.6 54.7zm-122-95.6c-10.8 0-19.9 1.9-26.9 5.6-7 3.7-12.8 8.3-17.2 13.6a48.4 48.4 0 0 0-9.1 17.4c-1.6 5.3-2.7 10.7-3.1 16.2H723c-1.6-17.3-7.6-30.1-15.6-39.1-8.4-8.9-21.9-13.7-38.6-13.7zm-248.5-10.1c8.7-6.3 12.9-16.7 12.9-31 .3-6.8-1.1-13.5-4.1-19.6-2.7-4.9-6.7-9-11.6-11.9a44.8 44.8 0 0 0-16.6-6c-6.4-1.2-12.9-1.8-19.3-1.7h-70.3v79.7h76.1c13.1.1 24.2-3.1 32.9-9.5zm11.8 72c-9.8-7.5-22.9-11.2-39.2-11.2h-81.8v94h80.2c7.5 0 14.4-.7 21.1-2.1s12.7-3.8 17.8-7.2c5.1-3.3 9.2-7.8 12.3-13.6 3-5.8 4.5-13.2 4.5-22.1 0-17.7-5-30.2-14.9-37.8z\"}}]})(props);\n};\nexport function AiFillBell (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M816 768h-24V428c0-141.1-104.3-257.8-240-277.2V112c0-22.1-17.9-40-40-40s-40 17.9-40 40v38.8C336.3 170.2 232 286.9 232 428v340h-24c-17.7 0-32 14.3-32 32v32c0 4.4 3.6 8 8 8h216c0 61.8 50.2 112 112 112s112-50.2 112-112h216c4.4 0 8-3.6 8-8v-32c0-17.7-14.3-32-32-32zM512 888c-26.5 0-48-21.5-48-48h96c0 26.5-21.5 48-48 48z\"}}]})(props);\n};\nexport function AiFillBook (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V96c0-17.7-14.3-32-32-32zM668 345.9L621.5 312 572 347.4V124h96v221.9z\"}}]})(props);\n};\nexport function AiFillBoxPlot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M952 224h-52c-4.4 0-8 3.6-8 8v248h-92V304c0-4.4-3.6-8-8-8H448v432h344c4.4 0 8-3.6 8-8V548h92v244c0 4.4 3.6 8 8 8h52c4.4 0 8-3.6 8-8V232c0-4.4-3.6-8-8-8zm-728 80v176h-92V232c0-4.4-3.6-8-8-8H72c-4.4 0-8 3.6-8 8v560c0 4.4 3.6 8 8 8h52c4.4 0 8-3.6 8-8V548h92v172c0 4.4 3.6 8 8 8h152V296H232c-4.4 0-8 3.6-8 8z\"}}]})(props);\n};\nexport function AiFillBug (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M304 280h416c4.4 0 8-3.6 8-8 0-40-8.8-76.7-25.9-108.1-17.2-31.5-42.5-56.8-74-74C596.7 72.8 560 64 520 64h-16c-40 0-76.7 8.8-108.1 25.9-31.5 17.2-56.8 42.5-74 74C304.8 195.3 296 232 296 272c0 4.4 3.6 8 8 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M940 512H792V412c76.8 0 139-62.2 139-139 0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8 0 34.8-28.2 63-63 63H232c-34.8 0-63-28.2-63-63 0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8 0 76.8 62.2 139 139 139v100H84c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h148v96c0 6.5.2 13 .7 19.3C164.1 728.6 116 796.7 116 876c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8 0-44.2 23.9-82.9 59.6-103.7 6 17.2 13.6 33.6 22.7 49 24.3 41.5 59 76.2 100.5 100.5 28.9 16.9 61 28.8 95.3 34.5 4.4 0 8-3.6 8-8V484c0-4.4 3.6-8 8-8h60c4.4 0 8 3.6 8 8v464.2c0 4.4 3.6 8 8 8 34.3-5.7 66.4-17.6 95.3-34.5 41.5-24.3 76.2-59 100.5-100.5 9.1-15.5 16.7-31.9 22.7-49C812.1 793.1 836 831.8 836 876c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8 0-79.3-48.1-147.4-116.7-176.7.4-6.4.7-12.8.7-19.3v-96h148c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiFillBuild (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M916 210H376c-17.7 0-32 14.3-32 32v236H108c-17.7 0-32 14.3-32 32v272c0 17.7 14.3 32 32 32h540c17.7 0 32-14.3 32-32V546h236c17.7 0 32-14.3 32-32V242c0-17.7-14.3-32-32-32zM612 746H412V546h200v200zm268-268H680V278h200v200z\"}}]})(props);\n};\nexport function AiFillBulb (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M348 676.1C250 619.4 184 513.4 184 392c0-181.1 146.9-328 328-328s328 146.9 328 328c0 121.4-66 227.4-164 284.1V792c0 17.7-14.3 32-32 32H380c-17.7 0-32-14.3-32-32V676.1zM392 888h240c4.4 0 8 3.6 8 8v32c0 17.7-14.3 32-32 32H416c-17.7 0-32-14.3-32-32v-32c0-4.4 3.6-8 8-8z\"}}]})(props);\n};\nexport function AiFillCalculator (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM440.2 765h-50.8c-2.2 0-4.5-1.1-5.9-2.9L348 718.6l-35.5 43.5a7.38 7.38 0 0 1-5.9 2.9h-50.8c-6.6 0-10.2-7.9-5.8-13.1l62.7-76.8-61.2-74.9c-4.3-5.2-.7-13.1 5.9-13.1h50.9c2.2 0 4.5 1.1 5.9 2.9l34 41.6 34-41.6c1.5-1.9 3.6-2.9 5.9-2.9h50.8c6.6 0 10.2 7.9 5.9 13.1L383.5 675l62.7 76.8c4.2 5.3.6 13.2-6 13.2zm7.8-382c0 2.2-1.4 4-3.2 4H376v68.7c0 1.9-1.8 3.3-4 3.3h-48c-2.2 0-4-1.4-4-3.2V387h-68.8c-1.8 0-3.2-1.8-3.2-4v-48c0-2.2 1.4-4 3.2-4H320v-68.8c0-1.8 1.8-3.2 4-3.2h48c2.2 0 4 1.4 4 3.2V331h68.7c1.9 0 3.3 1.8 3.3 4v48zm328 369c0 2.2-1.4 4-3.2 4H579.2c-1.8 0-3.2-1.8-3.2-4v-48c0-2.2 1.4-4 3.2-4h193.5c1.9 0 3.3 1.8 3.3 4v48zm0-104c0 2.2-1.4 4-3.2 4H579.2c-1.8 0-3.2-1.8-3.2-4v-48c0-2.2 1.4-4 3.2-4h193.5c1.9 0 3.3 1.8 3.3 4v48zm0-265c0 2.2-1.4 4-3.2 4H579.2c-1.8 0-3.2-1.8-3.2-4v-48c0-2.2 1.4-4 3.2-4h193.5c1.9 0 3.3 1.8 3.3 4v48z\"}}]})(props);\n};\nexport function AiFillCalendar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M112 880c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V460H112v420zm768-696H712v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H384v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H144c-17.7 0-32 14.3-32 32v176h800V216c0-17.7-14.3-32-32-32z\"}}]})(props);\n};\nexport function AiFillCamera (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M864 260H728l-32.4-90.8a32.07 32.07 0 0 0-30.2-21.2H358.6c-13.5 0-25.6 8.5-30.1 21.2L296 260H160c-44.2 0-80 35.8-80 80v456c0 44.2 35.8 80 80 80h704c44.2 0 80-35.8 80-80V340c0-44.2-35.8-80-80-80zM512 716c-88.4 0-160-71.6-160-160s71.6-160 160-160 160 71.6 160 160-71.6 160-160 160zm-96-160a96 96 0 1 0 192 0 96 96 0 1 0-192 0z\"}}]})(props);\n};\nexport function AiFillCar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M959 413.4L935.3 372a8 8 0 0 0-10.9-2.9l-50.7 29.6-78.3-216.2a63.9 63.9 0 0 0-60.9-44.4H301.2c-34.7 0-65.5 22.4-76.2 55.5l-74.6 205.2-50.8-29.6a8 8 0 0 0-10.9 2.9L65 413.4c-2.2 3.8-.9 8.6 2.9 10.8l60.4 35.2-14.5 40c-1.2 3.2-1.8 6.6-1.8 10v348.2c0 15.7 11.8 28.4 26.3 28.4h67.6c12.3 0 23-9.3 25.6-22.3l7.7-37.7h545.6l7.7 37.7c2.7 13 13.3 22.3 25.6 22.3h67.6c14.5 0 26.3-12.7 26.3-28.4V509.4c0-3.4-.6-6.8-1.8-10l-14.5-40 60.3-35.2a8 8 0 0 0 3-10.8zM264 621c-22.1 0-40-17.9-40-40s17.9-40 40-40 40 17.9 40 40-17.9 40-40 40zm388 75c0 4.4-3.6 8-8 8H380c-4.4 0-8-3.6-8-8v-84c0-4.4 3.6-8 8-8h40c4.4 0 8 3.6 8 8v36h168v-36c0-4.4 3.6-8 8-8h40c4.4 0 8 3.6 8 8v84zm108-75c-22.1 0-40-17.9-40-40s17.9-40 40-40 40 17.9 40 40-17.9 40-40 40zM220 418l72.7-199.9.5-1.3.4-1.3c1.1-3.3 4.1-5.5 7.6-5.5h427.6l75.4 208H220z\"}}]})(props);\n};\nexport function AiFillCaretDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M840.4 300H183.6c-19.7 0-30.7 20.8-18.5 35l328.4 380.8c9.4 10.9 27.5 10.9 37 0L858.9 335c12.2-14.2 1.2-35-18.5-35z\"}}]})(props);\n};\nexport function AiFillCaretLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M689 165.1L308.2 493.5c-10.9 9.4-10.9 27.5 0 37L689 858.9c14.2 12.2 35 1.2 35-18.5V183.6c0-19.7-20.8-30.7-35-18.5z\"}}]})(props);\n};\nexport function AiFillCaretRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M715.8 493.5L335 165.1c-14.2-12.2-35-1.2-35 18.5v656.8c0 19.7 20.8 30.7 35 18.5l380.8-328.4c10.9-9.4 10.9-27.6 0-37z\"}}]})(props);\n};\nexport function AiFillCaretUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M858.9 689L530.5 308.2c-9.4-10.9-27.5-10.9-37 0L165.1 689c-12.2 14.2-1.2 35 18.5 35h656.8c19.7 0 30.7-20.8 18.5-35z\"}}]})(props);\n};\nexport function AiFillCarryOut (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 184H712v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H384v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H144c-17.7 0-32 14.3-32 32v664c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V216c0-17.7-14.3-32-32-32zM694.5 432.7L481.9 725.4a16.1 16.1 0 0 1-26 0l-126.4-174c-3.8-5.3 0-12.7 6.5-12.7h55.2c5.1 0 10 2.5 13 6.6l64.7 89 150.9-207.8c3-4.1 7.8-6.6 13-6.6H688c6.5.1 10.3 7.5 6.5 12.8z\"}}]})(props);\n};\nexport function AiFillCheckCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm193.5 301.7l-210.6 292a31.8 31.8 0 0 1-51.7 0L318.5 484.9c-3.8-5.3 0-12.7 6.5-12.7h46.9c10.2 0 19.9 4.9 25.9 13.3l71.2 98.8 157.2-218c6-8.3 15.6-13.3 25.9-13.3H699c6.5 0 10.3 7.4 6.5 12.7z\"}}]})(props);\n};\nexport function AiFillCheckSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM695.5 365.7l-210.6 292a31.8 31.8 0 0 1-51.7 0L308.5 484.9c-3.8-5.3 0-12.7 6.5-12.7h46.9c10.2 0 19.9 4.9 25.9 13.3l71.2 98.8 157.2-218c6-8.3 15.6-13.3 25.9-13.3H689c6.5 0 10.3 7.4 6.5 12.7z\"}}]})(props);\n};\nexport function AiFillChrome (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M371.8 512c0 77.5 62.7 140.2 140.2 140.2S652.2 589.5 652.2 512 589.5 371.8 512 371.8 371.8 434.4 371.8 512zM900 362.4l-234.3 12.1c63.6 74.3 64.6 181.5 11.1 263.7l-188 289.2c78 4.2 158.4-12.9 231.2-55.2 180-104 253-322.1 180-509.8zM320.3 591.9L163.8 284.1A415.35 415.35 0 0 0 96 512c0 208 152.3 380.3 351.4 410.8l106.9-209.4c-96.6 18.2-189.9-34.8-234-121.5zm218.5-285.5l344.4 18.1C848 254.7 792.6 194 719.8 151.7 653.9 113.6 581.5 95.5 510.5 96c-122.5.5-242.2 55.2-322.1 154.5l128.2 196.9c32-91.9 124.8-146.7 222.2-141z\"}}]})(props);\n};\nexport function AiFillCiCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm-63.6 656c-103 0-162.4-68.6-162.4-182.6v-49C286 373.5 345.4 304 448.3 304c88.3 0 152.3 56.9 152.3 138.1 0 2.4-2 4.4-4.4 4.4h-52.6c-4.2 0-7.6-3.2-8-7.4-4-46.1-37.6-77.6-87-77.6-61.1 0-95.6 45.4-95.6 126.9v49.3c0 80.3 34.5 125.1 95.6 125.1 49.3 0 82.8-29.5 87-72.4.4-4.1 3.8-7.3 8-7.3h52.7c2.4 0 4.4 2 4.4 4.4 0 77.4-64.3 132.5-152.3 132.5zM738 704.1c0 4.4-3.6 8-8 8h-50.4c-4.4 0-8-3.6-8-8V319.9c0-4.4 3.6-8 8-8H730c4.4 0 8 3.6 8 8v384.2z\"}}]})(props);\n};\nexport function AiFillClockCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm176.5 585.7l-28.6 39a7.99 7.99 0 0 1-11.2 1.7L483.3 569.8a7.92 7.92 0 0 1-3.3-6.5V288c0-4.4 3.6-8 8-8h48.1c4.4 0 8 3.6 8 8v247.5l142.6 103.1c3.6 2.5 4.4 7.5 1.8 11.1z\"}}]})(props);\n};\nexport function AiFillCloseCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm165.4 618.2l-66-.3L512 563.4l-99.3 118.4-66.1.3c-4.4 0-8-3.5-8-8 0-1.9.7-3.7 1.9-5.2l130.1-155L340.5 359a8.32 8.32 0 0 1-1.9-5.2c0-4.4 3.6-8 8-8l66.1.3L512 464.6l99.3-118.4 66-.3c4.4 0 8 3.5 8 8 0 1.9-.7 3.7-1.9 5.2L553.5 514l130 155c1.2 1.5 1.9 3.3 1.9 5.2 0 4.4-3.6 8-8 8z\"}}]})(props);\n};\nexport function AiFillCloseSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM676.1 657.9c4.4 5.2.7 13.1-6.1 13.1h-58.9c-4.7 0-9.2-2.1-12.3-5.7L512 561.8l-86.8 103.5c-3 3.6-7.5 5.7-12.3 5.7H354c-6.8 0-10.5-7.9-6.1-13.1L470.2 512 347.9 366.1A7.95 7.95 0 0 1 354 353h58.9c4.7 0 9.2 2.1 12.3 5.7L512 462.2l86.8-103.5c3-3.6 7.5-5.7 12.3-5.7H670c6.8 0 10.5 7.9 6.1 13.1L553.8 512l122.3 145.9z\"}}]})(props);\n};\nexport function AiFillCloud (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M811.4 418.7C765.6 297.9 648.9 212 512.2 212S258.8 297.8 213 418.6C127.3 441.1 64 519.1 64 612c0 110.5 89.5 200 199.9 200h496.2C870.5 812 960 722.5 960 612c0-92.7-63.1-170.7-148.6-193.3z\"}}]})(props);\n};\nexport function AiFillCodeSandboxCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm243.7 589.2L512 794 268.3 653.2V371.8l110-63.6-.4-.2h.2L512 231l134 77h-.2l-.3.2 110.1 63.6v281.4zM307.9 536.7l87.6 49.9V681l96.7 55.9V524.8L307.9 418.4zm203.9-151.8L418 331l-91.1 52.6 185.2 107 185.2-106.9-91.4-52.8zm20 352l97.3-56.2v-94.1l87-49.5V418.5L531.8 525z\"}}]})(props);\n};\nexport function AiFillCodeSandboxSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M307.9 536.7l87.6 49.9V681l96.7 55.9V524.8L307.9 418.4zM880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM755.7 653.2L512 794 268.3 653.2V371.8l110-63.6-.4-.2h.2L512 231l134 77h-.2l-.3.2 110.1 63.6v281.4zm-223.9 83.7l97.3-56.2v-94.1l87-49.5V418.5L531.8 525zm-20-352L418 331l-91.1 52.6 185.2 107 185.2-106.9-91.4-52.8z\"}}]})(props);\n};\nexport function AiFillCode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM513.1 518.1l-192 161c-5.2 4.4-13.1.7-13.1-6.1v-62.7c0-2.3 1.1-4.6 2.9-6.1L420.7 512l-109.8-92.2a7.63 7.63 0 0 1-2.9-6.1V351c0-6.8 7.9-10.5 13.1-6.1l192 160.9c3.9 3.2 3.9 9.1 0 12.3zM716 673c0 4.4-3.4 8-7.5 8h-185c-4.1 0-7.5-3.6-7.5-8v-48c0-4.4 3.4-8 7.5-8h185c4.1 0 7.5 3.6 7.5 8v48z\"}}]})(props);\n};\nexport function AiFillCodepenCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M488.1 414.7V303.4L300.9 428l83.6 55.8zm254.1 137.7v-79.8l-59.8 39.9zM512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm278 533c0 1.1-.1 2.1-.2 3.1 0 .4-.1.7-.2 1a14.16 14.16 0 0 1-.8 3.2c-.2.6-.4 1.2-.6 1.7-.2.4-.4.8-.5 1.2-.3.5-.5 1.1-.8 1.6-.2.4-.4.7-.7 1.1-.3.5-.7 1-1 1.5-.3.4-.5.7-.8 1-.4.4-.8.9-1.2 1.3-.3.3-.6.6-1 .9-.4.4-.9.8-1.4 1.1-.4.3-.7.6-1.1.8-.1.1-.3.2-.4.3L525.2 786c-4 2.7-8.6 4-13.2 4-4.7 0-9.3-1.4-13.3-4L244.6 616.9c-.1-.1-.3-.2-.4-.3l-1.1-.8c-.5-.4-.9-.7-1.3-1.1-.3-.3-.6-.6-1-.9-.4-.4-.8-.8-1.2-1.3a7 7 0 0 1-.8-1c-.4-.5-.7-1-1-1.5-.2-.4-.5-.7-.7-1.1-.3-.5-.6-1.1-.8-1.6-.2-.4-.4-.8-.5-1.2-.2-.6-.4-1.2-.6-1.7-.1-.4-.3-.8-.4-1.2-.2-.7-.3-1.3-.4-2-.1-.3-.1-.7-.2-1-.1-1-.2-2.1-.2-3.1V427.9c0-1 .1-2.1.2-3.1.1-.3.1-.7.2-1a14.16 14.16 0 0 1 .8-3.2c.2-.6.4-1.2.6-1.7.2-.4.4-.8.5-1.2.2-.5.5-1.1.8-1.6.2-.4.4-.7.7-1.1.6-.9 1.2-1.7 1.8-2.5.4-.4.8-.9 1.2-1.3.3-.3.6-.6 1-.9.4-.4.9-.8 1.3-1.1.4-.3.7-.6 1.1-.8.1-.1.3-.2.4-.3L498.7 239c8-5.3 18.5-5.3 26.5 0l254.1 169.1c.1.1.3.2.4.3l1.1.8 1.4 1.1c.3.3.6.6 1 .9.4.4.8.8 1.2 1.3.7.8 1.3 1.6 1.8 2.5.2.4.5.7.7 1.1.3.5.6 1 .8 1.6.2.4.4.8.5 1.2.2.6.4 1.2.6 1.7.1.4.3.8.4 1.2.2.7.3 1.3.4 2 .1.3.1.7.2 1 .1 1 .2 2.1.2 3.1V597zm-254.1 13.3v111.3L723.1 597l-83.6-55.8zM281.8 472.6v79.8l59.8-39.9zM512 456.1l-84.5 56.4 84.5 56.4 84.5-56.4zM723.1 428L535.9 303.4v111.3l103.6 69.1zM384.5 541.2L300.9 597l187.2 124.6V610.3l-103.6-69.1z\"}}]})(props);\n};\nexport function AiFillCodepenSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M723.1 428L535.9 303.4v111.3l103.6 69.1zM512 456.1l-84.5 56.4 84.5 56.4 84.5-56.4zm23.9 154.2v111.3L723.1 597l-83.6-55.8zm-151.4-69.1L300.9 597l187.2 124.6V610.3l-103.6-69.1zM880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-90 485c0 1.1-.1 2.1-.2 3.1 0 .4-.1.7-.2 1a14.16 14.16 0 0 1-.8 3.2c-.2.6-.4 1.2-.6 1.7-.2.4-.4.8-.5 1.2-.3.5-.5 1.1-.8 1.6-.2.4-.4.7-.7 1.1-.3.5-.7 1-1 1.5-.3.4-.5.7-.8 1-.4.4-.8.9-1.2 1.3-.3.3-.6.6-1 .9-.4.4-.9.8-1.4 1.1-.4.3-.7.6-1.1.8-.1.1-.3.2-.4.3L525.2 786c-4 2.7-8.6 4-13.2 4-4.7 0-9.3-1.4-13.3-4L244.6 616.9c-.1-.1-.3-.2-.4-.3l-1.1-.8c-.5-.4-.9-.7-1.3-1.1-.3-.3-.6-.6-1-.9-.4-.4-.8-.8-1.2-1.3a7 7 0 0 1-.8-1c-.4-.5-.7-1-1-1.5-.2-.4-.5-.7-.7-1.1-.3-.5-.6-1.1-.8-1.6-.2-.4-.4-.8-.5-1.2-.2-.6-.4-1.2-.6-1.7-.1-.4-.3-.8-.4-1.2-.2-.7-.3-1.3-.4-2-.1-.3-.1-.7-.2-1-.1-1-.2-2.1-.2-3.1V427.9c0-1 .1-2.1.2-3.1.1-.3.1-.7.2-1a14.16 14.16 0 0 1 .8-3.2c.2-.6.4-1.2.6-1.7.2-.4.4-.8.5-1.2.2-.5.5-1.1.8-1.6.2-.4.4-.7.7-1.1.6-.9 1.2-1.7 1.8-2.5.4-.4.8-.9 1.2-1.3.3-.3.6-.6 1-.9.4-.4.9-.8 1.3-1.1.4-.3.7-.6 1.1-.8.1-.1.3-.2.4-.3L498.7 239c8-5.3 18.5-5.3 26.5 0l254.1 169.1c.1.1.3.2.4.3l1.1.8 1.4 1.1c.3.3.6.6 1 .9.4.4.8.8 1.2 1.3.7.8 1.3 1.6 1.8 2.5.2.4.5.7.7 1.1.3.5.6 1 .8 1.6.2.4.4.8.5 1.2.2.6.4 1.2.6 1.7.1.4.3.8.4 1.2.2.7.3 1.3.4 2 .1.3.1.7.2 1 .1 1 .2 2.1.2 3.1V597zm-47.8-44.6v-79.8l-59.8 39.9zm-460.4-79.8v79.8l59.8-39.9zm206.3-57.9V303.4L300.9 428l83.6 55.8z\"}}]})(props);\n};\nexport function AiFillCompass (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zM327.3 702.4c-2 .9-4.4 0-5.3-2.1-.4-1-.4-2.2 0-3.2l98.7-225.5 132.1 132.1-225.5 98.7zm375.1-375.1l-98.7 225.5-132.1-132.1L697.1 322c2-.9 4.4 0 5.3 2.1.4 1 .4 2.1 0 3.2z\"}}]})(props);\n};\nexport function AiFillContacts (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 224H768v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H548v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H328v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H96c-17.7 0-32 14.3-32 32v576c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V256c0-17.7-14.3-32-32-32zM661 736h-43.9c-4.2 0-7.6-3.3-7.9-7.5-3.8-50.6-46-90.5-97.2-90.5s-93.4 40-97.2 90.5c-.3 4.2-3.7 7.5-7.9 7.5H363a8 8 0 0 1-8-8.4c2.8-53.3 32-99.7 74.6-126.1a111.8 111.8 0 0 1-29.1-75.5c0-61.9 49.9-112 111.4-112 61.5 0 111.4 50.1 111.4 112 0 29.1-11 55.5-29.1 75.5 42.7 26.5 71.8 72.8 74.6 126.1.4 4.6-3.2 8.4-7.8 8.4zM512 474c-28.5 0-51.7 23.3-51.7 52s23.2 52 51.7 52c28.5 0 51.7-23.3 51.7-52s-23.2-52-51.7-52z\"}}]})(props);\n};\nexport function AiFillContainer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H192c-17.7 0-32 14.3-32 32v529c0-.6.4-1 1-1h219.3l5.2 24.7C397.6 708.5 450.8 752 512 752s114.4-43.5 126.4-103.3l5.2-24.7H863c.6 0 1 .4 1 1V96c0-17.7-14.3-32-32-32zM712 493c0 4.4-3.6 8-8 8H320c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h384c4.4 0 8 3.6 8 8v48zm0-160c0 4.4-3.6 8-8 8H320c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h384c4.4 0 8 3.6 8 8v48zm151 354H694.1c-11.6 32.8-32 62.3-59.1 84.7-34.5 28.6-78.2 44.3-123 44.3s-88.5-15.8-123-44.3a194.02 194.02 0 0 1-59.1-84.7H161c-.6 0-1-.4-1-1v242c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V686c0 .6-.4 1-1 1z\"}}]})(props);\n};\nexport function AiFillControl (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM404 683v77c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8v-77c-41.7-13.6-72-52.8-72-99s30.3-85.5 72-99V264c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v221c41.7 13.6 72 52.8 72 99s-30.3 85.5-72 99zm279.6-143.9c.2 0 .3-.1.4-.1v221c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V539c.2 0 .3.1.4.1-42-13.4-72.4-52.7-72.4-99.1 0-46.4 30.4-85.7 72.4-99.1-.2 0-.3.1-.4.1v-77c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v77c-.2 0-.3-.1-.4-.1 42 13.4 72.4 52.7 72.4 99.1 0 46.4-30.4 85.7-72.4 99.1zM616 440a36 36 0 1 0 72 0 36 36 0 1 0-72 0zM403.4 566.5l-1.5-2.4c0-.1-.1-.1-.1-.2l-.9-1.2c-.1-.1-.2-.2-.2-.3-1-1.3-2-2.5-3.2-3.6l-.2-.2c-.4-.4-.8-.8-1.2-1.1-.8-.8-1.7-1.5-2.6-2.1h-.1l-1.2-.9c-.1-.1-.3-.2-.4-.3-1.2-.8-2.5-1.6-3.9-2.2-.2-.1-.5-.2-.7-.4-.4-.2-.7-.3-1.1-.5-.3-.1-.7-.3-1-.4-.5-.2-1-.4-1.5-.5-.4-.1-.9-.3-1.3-.4l-.9-.3-1.4-.3c-.2-.1-.5-.1-.7-.2-.7-.1-1.4-.3-2.1-.4-.2 0-.4 0-.6-.1-.6-.1-1.1-.1-1.7-.2-.2 0-.4 0-.7-.1-.8 0-1.5-.1-2.3-.1s-1.5 0-2.3.1c-.2 0-.4 0-.7.1-.6 0-1.2.1-1.7.2-.2 0-.4 0-.6.1-.7.1-1.4.2-2.1.4-.2.1-.5.1-.7.2l-1.4.3-.9.3c-.4.1-.9.3-1.3.4-.5.2-1 .4-1.5.5-.3.1-.7.3-1 .4-.4.2-.7.3-1.1.5-.2.1-.5.2-.7.4-1.3.7-2.6 1.4-3.9 2.2-.1.1-.3.2-.4.3l-1.2.9h-.1c-.9.7-1.8 1.4-2.6 2.1-.4.4-.8.7-1.2 1.1l-.2.2a54.8 54.8 0 0 0-3.2 3.6c-.1.1-.2.2-.2.3l-.9 1.2c0 .1-.1.1-.1.2l-1.5 2.4c-.1.2-.2.3-.3.5-2.7 5.1-4.3 10.9-4.3 17s1.6 12 4.3 17c.1.2.2.3.3.5l1.5 2.4c0 .1.1.1.1.2l.9 1.2c.1.1.2.2.2.3 1 1.3 2 2.5 3.2 3.6l.2.2c.4.4.8.8 1.2 1.1.8.8 1.7 1.5 2.6 2.1h.1l1.2.9c.1.1.3.2.4.3 1.2.8 2.5 1.6 3.9 2.2.2.1.5.2.7.4.4.2.7.3 1.1.5.3.1.7.3 1 .4.5.2 1 .4 1.5.5.4.1.9.3 1.3.4l.9.3 1.4.3c.2.1.5.1.7.2.7.1 1.4.3 2.1.4.2 0 .4 0 .6.1.6.1 1.1.1 1.7.2.2 0 .4 0 .7.1.8 0 1.5.1 2.3.1s1.5 0 2.3-.1c.2 0 .4 0 .7-.1.6 0 1.2-.1 1.7-.2.2 0 .4 0 .6-.1.7-.1 1.4-.2 2.1-.4.2-.1.5-.1.7-.2l1.4-.3.9-.3c.4-.1.9-.3 1.3-.4.5-.2 1-.4 1.5-.5.3-.1.7-.3 1-.4.4-.2.7-.3 1.1-.5.2-.1.5-.2.7-.4 1.3-.7 2.6-1.4 3.9-2.2.1-.1.3-.2.4-.3l1.2-.9h.1c.9-.7 1.8-1.4 2.6-2.1.4-.4.8-.7 1.2-1.1l.2-.2c1.1-1.1 2.2-2.4 3.2-3.6.1-.1.2-.2.2-.3l.9-1.2c0-.1.1-.1.1-.2l1.5-2.4c.1-.2.2-.3.3-.5 2.7-5.1 4.3-10.9 4.3-17s-1.6-12-4.3-17c-.1-.2-.2-.4-.3-.5z\"}}]})(props);\n};\nexport function AiFillCopy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H296c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h496v688c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V96c0-17.7-14.3-32-32-32zM704 192H192c-17.7 0-32 14.3-32 32v530.7c0 8.5 3.4 16.6 9.4 22.6l173.3 173.3c2.2 2.2 4.7 4 7.4 5.5v1.9h4.2c3.5 1.3 7.2 2 11 2H704c17.7 0 32-14.3 32-32V224c0-17.7-14.3-32-32-32zM382 896h-.2L232 746.2v-.2h150v150z\"}}]})(props);\n};\nexport function AiFillCopyrightCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm5.4 670c-110 0-173.4-73.2-173.4-194.9v-52.3C344 364.2 407.4 290 517.3 290c94.3 0 162.7 60.7 162.7 147.4 0 2.6-2.1 4.7-4.7 4.7h-56.7c-4.2 0-7.6-3.2-8-7.4-4-49.5-40-83.4-93-83.4-65.3 0-102.1 48.5-102.1 135.5v52.6c0 85.7 36.9 133.6 102.1 133.6 52.8 0 88.7-31.7 93-77.8.4-4.1 3.8-7.3 8-7.3h56.8c2.6 0 4.7 2.1 4.7 4.7 0 82.6-68.7 141.4-162.7 141.4z\"}}]})(props);\n};\nexport function AiFillCreditCard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 160H96c-17.7 0-32 14.3-32 32v160h896V192c0-17.7-14.3-32-32-32zM64 832c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V440H64v392zm579-184c0-4.4 3.6-8 8-8h165c4.4 0 8 3.6 8 8v72c0 4.4-3.6 8-8 8H651c-4.4 0-8-3.6-8-8v-72z\"}}]})(props);\n};\nexport function AiFillCrown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M899.6 276.5L705 396.4 518.4 147.5a8.06 8.06 0 0 0-12.9 0L319 396.4 124.3 276.5c-5.7-3.5-13.1 1.2-12.2 7.9L188.5 865c1.1 7.9 7.9 14 16 14h615.1c8 0 14.9-6 15.9-14l76.4-580.6c.8-6.7-6.5-11.4-12.3-7.9zM512 734.2c-62.1 0-112.6-50.5-112.6-112.6S449.9 509 512 509s112.6 50.5 112.6 112.6S574.1 734.2 512 734.2zm0-160.9c-26.6 0-48.2 21.6-48.2 48.3 0 26.6 21.6 48.3 48.2 48.3s48.2-21.6 48.2-48.3c0-26.6-21.6-48.3-48.2-48.3z\"}}]})(props);\n};\nexport function AiFillCustomerService (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 128c-212.1 0-384 171.9-384 384v360c0 13.3 10.7 24 24 24h184c35.3 0 64-28.7 64-64V624c0-35.3-28.7-64-64-64H200v-48c0-172.3 139.7-312 312-312s312 139.7 312 312v48H688c-35.3 0-64 28.7-64 64v208c0 35.3 28.7 64 64 64h184c13.3 0 24-10.7 24-24V512c0-212.1-171.9-384-384-384z\"}}]})(props);\n};\nexport function AiFillDashboard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M924.8 385.6a446.7 446.7 0 0 0-96-142.4 446.7 446.7 0 0 0-142.4-96C631.1 123.8 572.5 112 512 112s-119.1 11.8-174.4 35.2a446.7 446.7 0 0 0-142.4 96 446.7 446.7 0 0 0-96 142.4C75.8 440.9 64 499.5 64 560c0 132.7 58.3 257.7 159.9 343.1l1.7 1.4c5.8 4.8 13.1 7.5 20.6 7.5h531.7c7.5 0 14.8-2.7 20.6-7.5l1.7-1.4C901.7 817.7 960 692.7 960 560c0-60.5-11.9-119.1-35.2-174.4zM482 232c0-4.4 3.6-8 8-8h44c4.4 0 8 3.6 8 8v80c0 4.4-3.6 8-8 8h-44c-4.4 0-8-3.6-8-8v-80zM270 582c0 4.4-3.6 8-8 8h-80c-4.4 0-8-3.6-8-8v-44c0-4.4 3.6-8 8-8h80c4.4 0 8 3.6 8 8v44zm90.7-204.5l-31.1 31.1a8.03 8.03 0 0 1-11.3 0L261.7 352a8.03 8.03 0 0 1 0-11.3l31.1-31.1c3.1-3.1 8.2-3.1 11.3 0l56.6 56.6c3.1 3.1 3.1 8.2 0 11.3zm291.1 83.6l-84.5 84.5c5 18.7.2 39.4-14.5 54.1a55.95 55.95 0 0 1-79.2 0 55.95 55.95 0 0 1 0-79.2 55.87 55.87 0 0 1 54.1-14.5l84.5-84.5c3.1-3.1 8.2-3.1 11.3 0l28.3 28.3c3.1 3.1 3.1 8.1 0 11.3zm43-52.4l-31.1-31.1a8.03 8.03 0 0 1 0-11.3l56.6-56.6c3.1-3.1 8.2-3.1 11.3 0l31.1 31.1c3.1 3.1 3.1 8.2 0 11.3l-56.6 56.6a8.03 8.03 0 0 1-11.3 0zM846 582c0 4.4-3.6 8-8 8h-80c-4.4 0-8-3.6-8-8v-44c0-4.4 3.6-8 8-8h80c4.4 0 8 3.6 8 8v44z\"}}]})(props);\n};\nexport function AiFillDatabase (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H192c-17.7 0-32 14.3-32 32v224h704V96c0-17.7-14.3-32-32-32zM288 232c-22.1 0-40-17.9-40-40s17.9-40 40-40 40 17.9 40 40-17.9 40-40 40zM160 928c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V704H160v224zm128-136c22.1 0 40 17.9 40 40s-17.9 40-40 40-40-17.9-40-40 17.9-40 40-40zM160 640h704V384H160v256zm128-168c22.1 0 40 17.9 40 40s-17.9 40-40 40-40-17.9-40-40 17.9-40 40-40z\"}}]})(props);\n};\nexport function AiFillDelete (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M864 256H736v-80c0-35.3-28.7-64-64-64H352c-35.3 0-64 28.7-64 64v80H160c-17.7 0-32 14.3-32 32v32c0 4.4 3.6 8 8 8h60.4l24.7 523c1.6 34.1 29.8 61 63.9 61h454c34.2 0 62.3-26.8 63.9-61l24.7-523H888c4.4 0 8-3.6 8-8v-32c0-17.7-14.3-32-32-32zm-200 0H360v-72h304v72z\"}}]})(props);\n};\nexport function AiFillDiff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.2 306.6L611.3 72.9c-6-5.7-13.9-8.9-22.2-8.9H296c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h277l219 210.6V824c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V329.6c0-8.7-3.5-17-9.8-23zM553.4 201.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v704c0 17.7 14.3 32 32 32h512c17.7 0 32-14.3 32-32V397.3c0-8.5-3.4-16.6-9.4-22.6L553.4 201.4zM568 753c0 3.8-3.4 7-7.5 7h-225c-4.1 0-7.5-3.2-7.5-7v-42c0-3.8 3.4-7 7.5-7h225c4.1 0 7.5 3.2 7.5 7v42zm0-220c0 3.8-3.4 7-7.5 7H476v84.9c0 3.9-3.1 7.1-7 7.1h-42c-3.8 0-7-3.2-7-7.1V540h-84.5c-4.1 0-7.5-3.2-7.5-7v-42c0-3.9 3.4-7 7.5-7H420v-84.9c0-3.9 3.2-7.1 7-7.1h42c3.9 0 7 3.2 7 7.1V484h84.5c4.1 0 7.5 3.1 7.5 7v42z\"}}]})(props);\n};\nexport function AiFillDingtalkCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm227 385.3c-1 4.2-3.5 10.4-7 17.8h.1l-.4.7c-20.3 43.1-73.1 127.7-73.1 127.7s-.1-.2-.3-.5l-15.5 26.8h74.5L575.1 810l32.3-128h-58.6l20.4-84.7c-16.5 3.9-35.9 9.4-59 16.8 0 0-31.2 18.2-89.9-35 0 0-39.6-34.7-16.6-43.4 9.8-3.7 47.4-8.4 77-12.3 40-5.4 64.6-8.2 64.6-8.2S422 517 392.7 512.5c-29.3-4.6-66.4-53.1-74.3-95.8 0 0-12.2-23.4 26.3-12.3 38.5 11.1 197.9 43.2 197.9 43.2s-207.4-63.3-221.2-78.7c-13.8-15.4-40.6-84.2-37.1-126.5 0 0 1.5-10.5 12.4-7.7 0 0 153.3 69.7 258.1 107.9 104.8 37.9 195.9 57.3 184.2 106.7z\"}}]})(props);\n};\nexport function AiFillDingtalkSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM739 449.3c-1 4.2-3.5 10.4-7 17.8h.1l-.4.7c-20.3 43.1-73.1 127.7-73.1 127.7s-.1-.2-.3-.5l-15.5 26.8h74.5L575.1 810l32.3-128h-58.6l20.4-84.7c-16.5 3.9-35.9 9.4-59 16.8 0 0-31.2 18.2-89.9-35 0 0-39.6-34.7-16.6-43.4 9.8-3.7 47.4-8.4 77-12.3 40-5.4 64.6-8.2 64.6-8.2S422 517 392.7 512.5c-29.3-4.6-66.4-53.1-74.3-95.8 0 0-12.2-23.4 26.3-12.3 38.5 11.1 197.9 43.2 197.9 43.2s-207.4-63.3-221.2-78.7c-13.8-15.4-40.6-84.2-37.1-126.5 0 0 1.5-10.5 12.4-7.7 0 0 153.3 69.7 258.1 107.9 104.8 37.9 195.9 57.3 184.2 106.7z\"}}]})(props);\n};\nexport function AiFillDislike (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M885.9 490.3c3.6-12 5.4-24.4 5.4-37 0-28.3-9.3-55.5-26.1-77.7 3.6-12 5.4-24.4 5.4-37 0-28.3-9.3-55.5-26.1-77.7 3.6-12 5.4-24.4 5.4-37 0-51.6-30.7-98.1-78.3-118.4a66.1 66.1 0 0 0-26.5-5.4H273v428h.3l85.8 310.8C372.9 889 418.9 924 470.9 924c29.7 0 57.4-11.8 77.9-33.4 20.5-21.5 31-49.7 29.5-79.4l-6-122.9h239.9c12.1 0 23.9-3.2 34.3-9.3 40.4-23.5 65.5-66.1 65.5-111 0-28.3-9.3-55.5-26.1-77.7zM112 132v364c0 17.7 14.3 32 32 32h65V100h-65c-17.7 0-32 14.3-32 32z\"}}]})(props);\n};\nexport function AiFillDollarCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm22.3 665.2l.2 31.7c0 4.4-3.6 8.1-8 8.1h-28.4c-4.4 0-8-3.6-8-8v-31.4C401.3 723 359.5 672.4 355 617.4c-.4-4.7 3.3-8.7 8-8.7h46.2c3.9 0 7.3 2.8 7.9 6.6 5.1 31.7 29.8 55.4 74.1 61.3V533.9l-24.7-6.3c-52.3-12.5-102.1-45.1-102.1-112.7 0-72.9 55.4-112.1 126.2-119v-33c0-4.4 3.6-8 8-8h28.1c4.4 0 8 3.6 8 8v32.7c68.5 6.9 119.9 46.9 125.9 109.2.5 4.7-3.2 8.8-8 8.8h-44.9c-4 0-7.4-3-7.9-6.9-4-29.2-27.4-53-65.5-58.2v134.3l25.4 5.9c64.8 16 108.9 47 108.9 116.4 0 75.3-56 117.3-134.3 124.1zM426.6 410.3c0 25.4 15.7 45.1 49.5 57.3 4.7 1.9 9.4 3.4 15 5v-124c-36.9 4.7-64.5 25.4-64.5 61.7zm116.5 135.2c-2.8-.6-5.6-1.3-8.8-2.2V677c42.6-3.8 72-27.2 72-66.4 0-30.7-15.9-50.7-63.2-65.1z\"}}]})(props);\n};\nexport function AiFillDownCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm184.5 353.7l-178 246a7.95 7.95 0 0 1-12.9 0l-178-246c-3.8-5.3 0-12.7 6.5-12.7H381c10.2 0 19.9 4.9 25.9 13.2L512 563.6l105.2-145.4c6-8.3 15.6-13.2 25.9-13.2H690c6.5 0 10.3 7.4 6.5 12.7z\"}}]})(props);\n};\nexport function AiFillDownSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM696.5 412.7l-178 246a7.95 7.95 0 0 1-12.9 0l-178-246c-3.8-5.3 0-12.7 6.5-12.7H381c10.2 0 19.9 4.9 25.9 13.2L512 558.6l105.2-145.4c6-8.3 15.6-13.2 25.9-13.2H690c6.5 0 10.3 7.4 6.5 12.7z\"}}]})(props);\n};\nexport function AiFillDribbbleCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M675.1 328.3a245.2 245.2 0 0 0-220.8-55.1c6.8 9.1 51.5 69.9 91.8 144 87.5-32.8 124.5-82.6 129-88.9zM554 552.8c-138.7 48.3-188.6 144.6-193 153.6 41.7 32.5 94.1 51.9 151 51.9 34.1 0 66.6-6.9 96.1-19.5-3.7-21.6-17.9-96.8-52.5-186.6l-1.6.6zm47.7-11.9c32.2 88.4 45.3 160.4 47.8 175.4 55.2-37.3 94.5-96.4 105.4-164.9-8.4-2.6-76.1-22.8-153.2-10.5zM512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 736c-158.8 0-288-129.2-288-288s129.2-288 288-288 288 129.2 288 288-129.2 288-288 288zm53.1-346.2c5.7 11.7 11.2 23.6 16.3 35.6 1.8 4.2 3.6 8.4 5.3 12.7 81.8-10.3 163.2 6.2 171.3 7.9-.5-58.1-21.3-111.4-55.5-153.3-5.3 7.1-46.5 60-137.4 97.1zM498.6 432c-40.8-72.5-84.7-133.4-91.2-142.3-68.8 32.5-120.3 95.9-136.2 172.2 11 .2 112.4.7 227.4-29.9zm30.6 82.5c3.2-1 6.4-2 9.7-2.9-6.2-14-12.9-28-19.9-41.7-122.8 36.8-242.1 35.2-252.8 35-.1 2.5-.1 5-.1 7.5 0 63.2 23.9 120.9 63.2 164.5 5.5-9.6 73-121.4 199.9-162.4z\"}}]})(props);\n};\nexport function AiFillDribbbleSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M498.6 432c-40.8-72.5-84.7-133.4-91.2-142.3-68.8 32.5-120.3 95.9-136.2 172.2 11 .2 112.4.7 227.4-29.9zm66.5 21.8c5.7 11.7 11.2 23.6 16.3 35.6 1.8 4.2 3.6 8.4 5.3 12.7 81.8-10.3 163.2 6.2 171.3 7.9-.5-58.1-21.3-111.4-55.5-153.3-5.3 7.1-46.5 60-137.4 97.1zM880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM512 800c-158.8 0-288-129.2-288-288s129.2-288 288-288 288 129.2 288 288-129.2 288-288 288zm89.7-259.1c32.2 88.4 45.3 160.4 47.8 175.4 55.2-37.3 94.5-96.4 105.4-164.9-8.4-2.6-76.1-22.8-153.2-10.5zm-72.5-26.4c3.2-1 6.4-2 9.7-2.9-6.2-14-12.9-28-19.9-41.7-122.8 36.8-242.1 35.2-252.8 35-.1 2.5-.1 5-.1 7.5 0 63.2 23.9 120.9 63.2 164.5 5.5-9.6 73-121.4 199.9-162.4zm145.9-186.2a245.2 245.2 0 0 0-220.8-55.1c6.8 9.1 51.5 69.9 91.8 144 87.5-32.8 124.5-82.6 129-88.9zM554 552.8c-138.7 48.3-188.6 144.6-193 153.6 41.7 32.5 94.1 51.9 151 51.9 34.1 0 66.6-6.9 96.1-19.5-3.7-21.6-17.9-96.8-52.5-186.6l-1.6.6z\"}}]})(props);\n};\nexport function AiFillDropboxCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M663.8 455.5zm-151.5-93.8l-151.8 93.8 151.8 93.9 151.5-93.9zM512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm151.2 595.5L512.6 750l-151-90.5v-33.1l45.4 29.4 105.6-87.7 105.6 87.7 45.1-29.4v33.1zm-45.6-22.4l-105.3-87.7L407 637.1l-151-99.2 104.5-82.4L256 371.2 407 274l105.3 87.7L617.6 274 768 372.1l-104.2 83.5L768 539l-150.4 98.1z\"}}]})(props);\n};\nexport function AiFillDropboxSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM663.2 659.5L512.6 750l-151-90.5v-33.1l45.4 29.4 105.6-87.7 105.6 87.7 45.1-29.4v33.1zm-45.6-22.4l-105.3-87.7L407 637.1l-151-99.2 104.5-82.4L256 371.2 407 274l105.3 87.7L617.6 274 768 372.1l-104.2 83.5L768 539l-150.4 98.1zM512.3 361.7l-151.8 93.8 151.8 93.9 151.5-93.9zm151.5 93.8z\"}}]})(props);\n};\nexport function AiFillEdit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 836H144c-17.7 0-32 14.3-32 32v36c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-36c0-17.7-14.3-32-32-32zm-622.3-84c2 0 4-.2 6-.5L431.9 722c2-.4 3.9-1.3 5.3-2.8l423.9-423.9a9.96 9.96 0 0 0 0-14.1L694.9 114.9c-1.9-1.9-4.4-2.9-7.1-2.9s-5.2 1-7.1 2.9L256.8 538.8c-1.5 1.5-2.4 3.3-2.8 5.3l-29.5 168.2a33.5 33.5 0 0 0 9.4 29.8c6.6 6.4 14.9 9.9 23.8 9.9z\"}}]})(props);\n};\nexport function AiFillEnvironment (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 327c-29.9 0-58 11.6-79.2 32.8A111.6 111.6 0 0 0 400 439c0 29.9 11.7 58 32.8 79.2A111.6 111.6 0 0 0 512 551c29.9 0 58-11.7 79.2-32.8C612.4 497 624 468.9 624 439c0-29.9-11.6-58-32.8-79.2S541.9 327 512 327zm342.6-37.9a362.49 362.49 0 0 0-79.9-115.7 370.83 370.83 0 0 0-118.2-77.8C610.7 76.6 562.1 67 512 67c-50.1 0-98.7 9.6-144.5 28.5-44.3 18.3-84 44.5-118.2 77.8A363.6 363.6 0 0 0 169.4 289c-19.5 45-29.4 92.8-29.4 142 0 70.6 16.9 140.9 50.1 208.7 26.7 54.5 64 107.6 111 158.1 80.3 86.2 164.5 138.9 188.4 153a43.9 43.9 0 0 0 22.4 6.1c7.8 0 15.5-2 22.4-6.1 23.9-14.1 108.1-66.8 188.4-153 47-50.4 84.3-103.6 111-158.1C867.1 572 884 501.8 884 431.1c0-49.2-9.9-97-29.4-142zM512 615c-97.2 0-176-78.8-176-176s78.8-176 176-176 176 78.8 176 176-78.8 176-176 176z\"}}]})(props);\n};\nexport function AiFillEuroCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm63.5 375.8c4.4 0 8 3.6 8 8V475c0 4.4-3.6 8-8 8h-136c-.3 4.4-.3 9.1-.3 13.8v36h136.2c4.4 0 8 3.6 8 8V568c0 4.4-3.6 8-8 8H444.9c15.3 62 61.3 98.6 129.8 98.6 19.9 0 37.1-1.2 51.8-4.1 4.9-1 9.5 2.8 9.5 7.8v42.8c0 3.8-2.7 7-6.4 7.8-15.9 3.4-34.3 5.1-55.3 5.1-109.8 0-183-58.8-200.2-158H344c-4.4 0-8-3.6-8-8v-27.2c0-4.4 3.6-8 8-8h26.1v-36.9c0-4.4 0-8.8.3-12.8H344c-4.4 0-8-3.6-8-8v-27.2c0-4.4 3.6-8 8-8h31.7c19.7-94.2 92-149.9 198.6-149.9 20.9 0 39.4 1.9 55.3 5.4 3.7.8 6.3 4 6.3 7.8V346h.1c0 5.1-4.6 8.8-9.6 7.8-14.7-2.9-31.8-4.4-51.7-4.4-65.4 0-110.4 33.5-127.6 90.4h128.4z\"}}]})(props);\n};\nexport function AiFillExclamationCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm-32 232c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v272c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V296zm32 440a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96z\"}}]})(props);\n};\nexport function AiFillExperiment (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M218.9 636.3l42.6 26.6c.1.1.3.2.4.3l12.7 8 .3.3a186.9 186.9 0 0 0 94.1 25.1c44.9 0 87.2-15.7 121-43.8a256.27 256.27 0 0 1 164.9-59.9c52.3 0 102.2 15.7 144.6 44.5l7.9 5-111.6-289V179.8h63.5c4.4 0 8-3.6 8-8V120c0-4.4-3.6-8-8-8H264.7c-4.4 0-8 3.6-8 8v51.9c0 4.4 3.6 8 8 8h63.5v173.6L218.9 636.3zm333-203.1c22 0 39.9 17.9 39.9 39.9S573.9 513 551.9 513 512 495.1 512 473.1s17.9-39.9 39.9-39.9zM878 825.1l-29.9-77.4-85.7-53.5-.1.1c-.7-.5-1.5-1-2.2-1.5l-8.1-5-.3-.3c-29-17.5-62.3-26.8-97-26.8-44.9 0-87.2 15.7-121 43.8a256.27 256.27 0 0 1-164.9 59.9c-53 0-103.5-16.1-146.2-45.6l-28.9-18.1L146 825.1c-2.8 7.4-4.3 15.2-4.3 23 0 35.2 28.6 63.8 63.8 63.8h612.9c7.9 0 15.7-1.5 23-4.3a63.6 63.6 0 0 0 36.6-82.5z\"}}]})(props);\n};\nexport function AiFillEyeInvisible (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[{\"tag\":\"clipPath\",\"attr\":{},\"child\":[{\"tag\":\"path\",\"attr\":{\"fill\":\"none\",\"d\":\"M124-288l388-672 388 672H124z\",\"clipRule\":\"evenodd\"}}]}]},{\"tag\":\"path\",\"attr\":{\"d\":\"M508 624a112 112 0 0 0 112-112c0-3.28-.15-6.53-.43-9.74L498.26 623.57c3.21.28 6.45.43 9.74.43zm370.72-458.44L836 122.88a8 8 0 0 0-11.31 0L715.37 232.23Q624.91 186 512 186q-288.3 0-430.2 300.3a60.3 60.3 0 0 0 0 51.5q56.7 119.43 136.55 191.45L112.56 835a8 8 0 0 0 0 11.31L155.25 889a8 8 0 0 0 11.31 0l712.16-712.12a8 8 0 0 0 0-11.32zM332 512a176 176 0 0 1 258.88-155.28l-48.62 48.62a112.08 112.08 0 0 0-140.92 140.92l-48.62 48.62A175.09 175.09 0 0 1 332 512z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M942.2 486.2Q889.4 375 816.51 304.85L672.37 449A176.08 176.08 0 0 1 445 676.37L322.74 798.63Q407.82 838 512 838q288.3 0 430.2-300.3a60.29 60.29 0 0 0 0-51.5z\"}}]})(props);\n};\nexport function AiFillEye (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M396 512a112 112 0 1 0 224 0 112 112 0 1 0-224 0zm546.2-25.8C847.4 286.5 704.1 186 512 186c-192.2 0-335.4 100.5-430.2 300.3a60.3 60.3 0 0 0 0 51.5C176.6 737.5 319.9 838 512 838c192.2 0 335.4-100.5 430.2-300.3 7.7-16.2 7.7-35 0-51.5zM508 688c-97.2 0-176-78.8-176-176s78.8-176 176-176 176 78.8 176 176-78.8 176-176 176z\"}}]})(props);\n};\nexport function AiFillFacebook (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-92.4 233.5h-63.9c-50.1 0-59.8 23.8-59.8 58.8v77.1h119.6l-15.6 120.7h-104V912H539.2V602.2H434.9V481.4h104.3v-89c0-103.3 63.1-159.6 155.3-159.6 44.2 0 82.1 3.3 93.2 4.8v107.9z\"}}]})(props);\n};\nexport function AiFillFastBackward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M517.6 273.5L230.2 499.3a16.14 16.14 0 0 0 0 25.4l287.4 225.8c10.7 8.4 26.4.8 26.4-12.7V286.2c0-13.5-15.7-21.1-26.4-12.7zm320 0L550.2 499.3a16.14 16.14 0 0 0 0 25.4l287.4 225.8c10.7 8.4 26.4.8 26.4-12.7V286.2c0-13.5-15.7-21.1-26.4-12.7zm-620-25.5h-51.2c-3.5 0-6.4 2.7-6.4 6v516c0 3.3 2.9 6 6.4 6h51.2c3.5 0 6.4-2.7 6.4-6V254c0-3.3-2.9-6-6.4-6z\"}}]})(props);\n};\nexport function AiFillFastForward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M793.8 499.3L506.4 273.5c-10.7-8.4-26.4-.8-26.4 12.7v451.6c0 13.5 15.7 21.1 26.4 12.7l287.4-225.8a16.14 16.14 0 0 0 0-25.4zm-320 0L186.4 273.5c-10.7-8.4-26.4-.8-26.4 12.7v451.5c0 13.5 15.7 21.1 26.4 12.7l287.4-225.8c4.1-3.2 6.2-8 6.2-12.7 0-4.6-2.1-9.4-6.2-12.6zM857.6 248h-51.2c-3.5 0-6.4 2.7-6.4 6v516c0 3.3 2.9 6 6.4 6h51.2c3.5 0 6.4-2.7 6.4-6V254c0-3.3-2.9-6-6.4-6z\"}}]})(props);\n};\nexport function AiFillFileAdd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M480 580H372a8 8 0 0 0-8 8v48a8 8 0 0 0 8 8h108v108a8 8 0 0 0 8 8h48a8 8 0 0 0 8-8V644h108a8 8 0 0 0 8-8v-48a8 8 0 0 0-8-8H544V472a8 8 0 0 0-8-8h-48a8 8 0 0 0-8 8v108zm374.6-291.3c6 6 9.4 14.1 9.4 22.6V928c0 17.7-14.3 32-32 32H192c-17.7 0-32-14.3-32-32V96c0-17.7 14.3-32 32-32h424.7c8.5 0 16.7 3.4 22.7 9.4l215.2 215.3zM790.2 326L602 137.8V326h188.2z\"}}]})(props);\n};\nexport function AiFillFileExcel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.7c6 6 9.4 14.1 9.4 22.6V928c0 17.7-14.3 32-32 32H192c-17.7 0-32-14.3-32-32V96c0-17.7 14.3-32 32-32h424.7c8.5 0 16.7 3.4 22.7 9.4l215.2 215.3zM790.2 326L602 137.8V326h188.2zM575.34 477.84l-61.22 102.3L452.3 477.8a12 12 0 0 0-10.27-5.79h-38.44a12 12 0 0 0-6.4 1.85 12 12 0 0 0-3.75 16.56l82.34 130.42-83.45 132.78a12 12 0 0 0-1.84 6.39 12 12 0 0 0 12 12h34.46a12 12 0 0 0 10.21-5.7l62.7-101.47 62.3 101.45a12 12 0 0 0 10.23 5.72h37.48a12 12 0 0 0 6.48-1.9 12 12 0 0 0 3.62-16.58l-83.83-130.55 85.3-132.47a12 12 0 0 0 1.9-6.5 12 12 0 0 0-12-12h-35.7a12 12 0 0 0-10.29 5.84z\"}}]})(props);\n};\nexport function AiFillFileExclamation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.7c6 6 9.4 14.1 9.4 22.6V928c0 17.7-14.3 32-32 32H192c-17.7 0-32-14.3-32-32V96c0-17.7 14.3-32 32-32h424.7c8.5 0 16.7 3.4 22.7 9.4l215.2 215.3zM790.2 326L602 137.8V326h188.2zM512 784a40 40 0 1 0 0-80 40 40 0 0 0 0 80zm32-152V448a8 8 0 0 0-8-8h-48a8 8 0 0 0-8 8v184a8 8 0 0 0 8 8h48a8 8 0 0 0 8-8z\"}}]})(props);\n};\nexport function AiFillFileImage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.7L639.4 73.4c-6-6-14.2-9.4-22.7-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.6-9.4-22.6zM400 402c22.1 0 40 17.9 40 40s-17.9 40-40 40-40-17.9-40-40 17.9-40 40-40zm296 294H328c-6.7 0-10.4-7.7-6.3-12.9l99.8-127.2a8 8 0 0 1 12.6 0l41.1 52.4 77.8-99.2a8 8 0 0 1 12.6 0l136.5 174c4.3 5.2.5 12.9-6.1 12.9zm-94-370V137.8L790.2 326H602z\"}}]})(props);\n};\nexport function AiFillFileMarkdown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.7c6 6 9.4 14.1 9.4 22.6V928c0 17.7-14.3 32-32 32H192c-17.7 0-32-14.3-32-32V96c0-17.7 14.3-32 32-32h424.7c8.5 0 16.7 3.4 22.7 9.4l215.2 215.3zM790.2 326L602 137.8V326h188.2zM426.13 600.93l59.11 132.97a16 16 0 0 0 14.62 9.5h24.06a16 16 0 0 0 14.63-9.51l59.1-133.35V758a16 16 0 0 0 16.01 16H641a16 16 0 0 0 16-16V486a16 16 0 0 0-16-16h-34.75a16 16 0 0 0-14.67 9.62L512.1 662.2l-79.48-182.59a16 16 0 0 0-14.67-9.61H383a16 16 0 0 0-16 16v272a16 16 0 0 0 16 16h27.13a16 16 0 0 0 16-16V600.93z\"}}]})(props);\n};\nexport function AiFillFilePdf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.7c6 6 9.4 14.1 9.4 22.6V928c0 17.7-14.3 32-32 32H192c-17.7 0-32-14.3-32-32V96c0-17.7 14.3-32 32-32h424.7c8.5 0 16.7 3.4 22.7 9.4l215.2 215.3zM790.2 326L602 137.8V326h188.2zM633.22 637.26c-15.18-.5-31.32.67-49.65 2.96-24.3-14.99-40.66-35.58-52.28-65.83l1.07-4.38 1.24-5.18c4.3-18.13 6.61-31.36 7.3-44.7.52-10.07-.04-19.36-1.83-27.97-3.3-18.59-16.45-29.46-33.02-30.13-15.45-.63-29.65 8-33.28 21.37-5.91 21.62-2.45 50.07 10.08 98.59-15.96 38.05-37.05 82.66-51.2 107.54-18.89 9.74-33.6 18.6-45.96 28.42-16.3 12.97-26.48 26.3-29.28 40.3-1.36 6.49.69 14.97 5.36 21.92 5.3 7.88 13.28 13 22.85 13.74 24.15 1.87 53.83-23.03 86.6-79.26 3.29-1.1 6.77-2.26 11.02-3.7l11.9-4.02c7.53-2.54 12.99-4.36 18.39-6.11 23.4-7.62 41.1-12.43 57.2-15.17 27.98 14.98 60.32 24.8 82.1 24.8 17.98 0 30.13-9.32 34.52-23.99 3.85-12.88.8-27.82-7.48-36.08-8.56-8.41-24.3-12.43-45.65-13.12zM385.23 765.68v-.36l.13-.34a54.86 54.86 0 0 1 5.6-10.76c4.28-6.58 10.17-13.5 17.47-20.87 3.92-3.95 8-7.8 12.79-12.12 1.07-.96 7.91-7.05 9.19-8.25l11.17-10.4-8.12 12.93c-12.32 19.64-23.46 33.78-33 43-3.51 3.4-6.6 5.9-9.1 7.51a16.43 16.43 0 0 1-2.61 1.42c-.41.17-.77.27-1.13.3a2.2 2.2 0 0 1-1.12-.15 2.07 2.07 0 0 1-1.27-1.91zM511.17 547.4l-2.26 4-1.4-4.38c-3.1-9.83-5.38-24.64-6.01-38-.72-15.2.49-24.32 5.29-24.32 6.74 0 9.83 10.8 10.07 27.05.22 14.28-2.03 29.14-5.7 35.65zm-5.81 58.46l1.53-4.05 2.09 3.8c11.69 21.24 26.86 38.96 43.54 51.31l3.6 2.66-4.39.9c-16.33 3.38-31.54 8.46-52.34 16.85 2.17-.88-21.62 8.86-27.64 11.17l-5.25 2.01 2.8-4.88c12.35-21.5 23.76-47.32 36.05-79.77zm157.62 76.26c-7.86 3.1-24.78.33-54.57-12.39l-7.56-3.22 8.2-.6c23.3-1.73 39.8-.45 49.42 3.07 4.1 1.5 6.83 3.39 8.04 5.55a4.64 4.64 0 0 1-1.36 6.31 6.7 6.7 0 0 1-2.17 1.28z\"}}]})(props);\n};\nexport function AiFillFilePpt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.7c6 6 9.4 14.1 9.4 22.6V928c0 17.7-14.3 32-32 32H192c-17.7 0-32-14.3-32-32V96c0-17.7 14.3-32 32-32h424.7c8.5 0 16.7 3.4 22.7 9.4l215.2 215.3zM790.2 326L602 137.8V326h188.2zM468.53 760v-91.54h59.27c60.57 0 100.2-39.65 100.2-98.12 0-58.22-39.58-98.34-99.98-98.34H424a12 12 0 0 0-12 12v276a12 12 0 0 0 12 12h32.53a12 12 0 0 0 12-12zm0-139.33h34.9c47.82 0 67.19-12.93 67.19-50.33 0-32.05-18.12-50.12-49.87-50.12h-52.22v100.45z\"}}]})(props);\n};\nexport function AiFillFileText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.7c6 6 9.4 14.1 9.4 22.6V928c0 17.7-14.3 32-32 32H192c-17.7 0-32-14.3-32-32V96c0-17.7 14.3-32 32-32h424.7c8.5 0 16.7 3.4 22.7 9.4l215.2 215.3zM790.2 326L602 137.8V326h188.2zM320 482a8 8 0 0 0-8 8v48a8 8 0 0 0 8 8h384a8 8 0 0 0 8-8v-48a8 8 0 0 0-8-8H320zm0 136a8 8 0 0 0-8 8v48a8 8 0 0 0 8 8h184a8 8 0 0 0 8-8v-48a8 8 0 0 0-8-8H320z\"}}]})(props);\n};\nexport function AiFillFileUnknown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.7c6 6 9.4 14.1 9.4 22.6V928c0 17.7-14.3 32-32 32H192c-17.7 0-32-14.3-32-32V96c0-17.7 14.3-32 32-32h424.7c8.5 0 16.7 3.4 22.7 9.4l215.2 215.3zM790.2 326L602 137.8V326h188.2zM402 549c0 5.4 4.4 9.5 9.8 9.5h32.4c5.4 0 9.8-4.2 9.8-9.4 0-28.2 25.8-51.6 58-51.6s58 23.4 58 51.5c0 25.3-21 47.2-49.3 50.9-19.3 2.8-34.5 20.3-34.7 40.1v32c0 5.5 4.5 10 10 10h32c5.5 0 10-4.5 10-10v-12.2c0-6 4-11.5 9.7-13.3 44.6-14.4 75-54 74.3-98.9-.8-55.5-49.2-100.8-108.5-101.6-61.4-.7-111.5 45.6-111.5 103zm110 227a32 32 0 1 0 0-64 32 32 0 0 0 0 64z\"}}]})(props);\n};\nexport function AiFillFileWord (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.7c6 6 9.4 14.1 9.4 22.6V928c0 17.7-14.3 32-32 32H192c-17.7 0-32-14.3-32-32V96c0-17.7 14.3-32 32-32h424.7c8.5 0 16.7 3.4 22.7 9.4l215.2 215.3zM790.2 326L602 137.8V326h188.2zM512 566.1l52.81 197a12 12 0 0 0 11.6 8.9h31.77a12 12 0 0 0 11.6-8.88l74.37-276a12 12 0 0 0 .4-3.12 12 12 0 0 0-12-12h-35.57a12 12 0 0 0-11.7 9.31l-45.78 199.1-49.76-199.32A12 12 0 0 0 528.1 472h-32.2a12 12 0 0 0-11.64 9.1L434.6 680.01 388.5 481.3a12 12 0 0 0-11.68-9.29h-35.39a12 12 0 0 0-3.11.41 12 12 0 0 0-8.47 14.7l74.17 276A12 12 0 0 0 415.6 772h31.99a12 12 0 0 0 11.59-8.9l52.81-197z\"}}]})(props);\n};\nexport function AiFillFileZip (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.7c6 6 9.4 14.1 9.4 22.6V928c0 17.7-14.3 32-32 32H192c-17.7 0-32-14.3-32-32V96c0-17.7 14.3-32 32-32h424.7c8.5 0 16.7 3.4 22.7 9.4l215.2 215.3zM790.2 326L602 137.8V326h188.2zM296 136v64h64v-64h-64zm64 64v64h64v-64h-64zm-64 64v64h64v-64h-64zm64 64v64h64v-64h-64zm-64 64v64h64v-64h-64zm64 64v64h64v-64h-64zm-64 64v64h64v-64h-64zm0 64v160h128V584H296zm48 48h32v64h-32v-64z\"}}]})(props);\n};\nexport function AiFillFile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.7c6 6 9.4 14.1 9.4 22.6V928c0 17.7-14.3 32-32 32H192c-17.7 0-32-14.3-32-32V96c0-17.7 14.3-32 32-32h424.7c8.5 0 16.7 3.4 22.7 9.4l215.2 215.3zM790.2 326L602 137.8V326h188.2z\"}}]})(props);\n};\nexport function AiFillFilter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M349 838c0 17.7 14.2 32 31.8 32h262.4c17.6 0 31.8-14.3 31.8-32V642H349v196zm531.1-684H143.9c-24.5 0-39.8 26.7-27.5 48l221.3 376h348.8l221.3-376c12.1-21.3-3.2-48-27.7-48z\"}}]})(props);\n};\nexport function AiFillFire (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M834.1 469.2A347.49 347.49 0 0 0 751.2 354l-29.1-26.7a8.09 8.09 0 0 0-13 3.3l-13 37.3c-8.1 23.4-23 47.3-44.1 70.8-1.4 1.5-3 1.9-4.1 2-1.1.1-2.8-.1-4.3-1.5-1.4-1.2-2.1-3-2-4.8 3.7-60.2-14.3-128.1-53.7-202C555.3 171 510 123.1 453.4 89.7l-41.3-24.3c-5.4-3.2-12.3 1-12 7.3l2.2 48c1.5 32.8-2.3 61.8-11.3 85.9-11 29.5-26.8 56.9-47 81.5a295.64 295.64 0 0 1-47.5 46.1 352.6 352.6 0 0 0-100.3 121.5A347.75 347.75 0 0 0 160 610c0 47.2 9.3 92.9 27.7 136a349.4 349.4 0 0 0 75.5 110.9c32.4 32 70 57.2 111.9 74.7C418.5 949.8 464.5 959 512 959s93.5-9.2 136.9-27.3A348.6 348.6 0 0 0 760.8 857c32.4-32 57.8-69.4 75.5-110.9a344.2 344.2 0 0 0 27.7-136c0-48.8-10-96.2-29.9-140.9z\"}}]})(props);\n};\nexport function AiFillFlag (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 305H624V192c0-17.7-14.3-32-32-32H184v-40c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v784c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V640h248v113c0 17.7 14.3 32 32 32h416c17.7 0 32-14.3 32-32V337c0-17.7-14.3-32-32-32z\"}}]})(props);\n};\nexport function AiFillFolderAdd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 298.4H521L403.7 186.2a8.15 8.15 0 0 0-5.5-2.2H144c-17.7 0-32 14.3-32 32v592c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V330.4c0-17.7-14.3-32-32-32zM632 577c0 3.8-3.4 7-7.5 7H540v84.9c0 3.9-3.2 7.1-7 7.1h-42c-3.8 0-7-3.2-7-7.1V584h-84.5c-4.1 0-7.5-3.2-7.5-7v-42c0-3.8 3.4-7 7.5-7H484v-84.9c0-3.9 3.2-7.1 7-7.1h42c3.8 0 7 3.2 7 7.1V528h84.5c4.1 0 7.5 3.2 7.5 7v42z\"}}]})(props);\n};\nexport function AiFillFolderOpen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 444H820V330.4c0-17.7-14.3-32-32-32H473L355.7 186.2a8.15 8.15 0 0 0-5.5-2.2H96c-17.7 0-32 14.3-32 32v592c0 17.7 14.3 32 32 32h698c13 0 24.8-7.9 29.7-20l134-332c1.5-3.8 2.3-7.9 2.3-12 0-17.7-14.3-32-32-32zm-180 0H238c-13 0-24.8 7.9-29.7 20L136 643.2V256h188.5l119.6 114.4H748V444z\"}}]})(props);\n};\nexport function AiFillFolder (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 298.4H521L403.7 186.2a8.15 8.15 0 0 0-5.5-2.2H144c-17.7 0-32 14.3-32 32v592c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V330.4c0-17.7-14.3-32-32-32z\"}}]})(props);\n};\nexport function AiFillFormatPainter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683558243\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M840 192h-56v-72c0-13.3-10.7-24-24-24H168c-13.3 0-24 10.7-24 24v272c0 13.3 10.7 24 24 24h592c13.3 0 24-10.7 24-24V256h32v200H465c-22.1 0-40 17.9-40 40v136h-44c-4.4 0-8 3.6-8 8v228c0 1.1 0.2 2.2 0.6 3.1-0.4 1.6-0.6 3.2-0.6 4.9 0 46.4 37.6 84 84 84s84-37.6 84-84c0-1.7-0.2-3.3-0.6-4.9 0.4-1 0.6-2 0.6-3.1V640c0-4.4-3.6-8-8-8h-44V520h351c22.1 0 40-17.9 40-40V232c0-22.1-17.9-40-40-40z\"}}]})(props);\n};\nexport function AiFillForward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M825.8 498L538.4 249.9c-10.7-9.2-26.4-.9-26.4 14v496.3c0 14.9 15.7 23.2 26.4 14L825.8 526c8.3-7.2 8.3-20.8 0-28zm-320 0L218.4 249.9c-10.7-9.2-26.4-.9-26.4 14v496.3c0 14.9 15.7 23.2 26.4 14L505.8 526c4.1-3.6 6.2-8.8 6.2-14 0-5.2-2.1-10.4-6.2-14z\"}}]})(props);\n};\nexport function AiFillFrown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zM288 421a48.01 48.01 0 0 1 96 0 48.01 48.01 0 0 1-96 0zm376 272h-48.1c-4.2 0-7.8-3.2-8.1-7.4C604 636.1 562.5 597 512 597s-92.1 39.1-95.8 88.6c-.3 4.2-3.9 7.4-8.1 7.4H360a8 8 0 0 1-8-8.4c4.4-84.3 74.5-151.6 160-151.6s155.6 67.3 160 151.6a8 8 0 0 1-8 8.4zm24-224a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96z\"}}]})(props);\n};\nexport function AiFillFund (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M926 164H94c-17.7 0-32 14.3-32 32v640c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V196c0-17.7-14.3-32-32-32zm-92.3 194.4l-297 297.2a8.03 8.03 0 0 1-11.3 0L410.9 541.1 238.4 713.7a8.03 8.03 0 0 1-11.3 0l-36.8-36.8a8.03 8.03 0 0 1 0-11.3l214.9-215c3.1-3.1 8.2-3.1 11.3 0L531 565l254.5-254.6c3.1-3.1 8.2-3.1 11.3 0l36.8 36.8c3.2 3 3.2 8.1.1 11.2z\"}}]})(props);\n};\nexport function AiFillFunnelPlot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M336.7 586h350.6l84.9-148H251.8zm543.4-432H143.9c-24.5 0-39.8 26.7-27.5 48L215 374h594l98.7-172c12.2-21.3-3.1-48-27.6-48zM349 838c0 17.7 14.2 32 31.8 32h262.4c17.6 0 31.8-14.3 31.8-32V650H349v188z\"}}]})(props);\n};\nexport function AiFillGift (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M160 894c0 17.7 14.3 32 32 32h286V550H160v344zm386 32h286c17.7 0 32-14.3 32-32V550H546v376zm334-616H732.4c13.6-21.4 21.6-46.8 21.6-74 0-76.1-61.9-138-138-138-41.4 0-78.7 18.4-104 47.4-25.3-29-62.6-47.4-104-47.4-76.1 0-138 61.9-138 138 0 27.2 7.9 52.6 21.6 74H144c-17.7 0-32 14.3-32 32v140h366V310h68v172h366V342c0-17.7-14.3-32-32-32zm-402-4h-70c-38.6 0-70-31.4-70-70s31.4-70 70-70 70 31.4 70 70v70zm138 0h-70v-70c0-38.6 31.4-70 70-70s70 31.4 70 70-31.4 70-70 70z\"}}]})(props);\n};\nexport function AiFillGithub (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M511.6 76.3C264.3 76.2 64 276.4 64 523.5 64 718.9 189.3 885 363.8 946c23.5 5.9 19.9-10.8 19.9-22.2v-77.5c-135.7 15.9-141.2-73.9-150.3-88.9C215 726 171.5 718 184.5 703c30.9-15.9 62.4 4 98.9 57.9 26.4 39.1 77.9 32.5 104 26 5.7-23.5 17.9-44.5 34.7-60.8-140.6-25.2-199.2-111-199.2-213 0-49.5 16.3-95 48.3-131.7-20.4-60.5 1.9-112.3 4.9-120 58.1-5.2 118.5 41.6 123.2 45.3 33-8.9 70.7-13.6 112.9-13.6 42.4 0 80.2 4.9 113.5 13.9 11.3-8.6 67.3-48.8 121.3-43.9 2.9 7.7 24.7 58.3 5.5 118 32.4 36.8 48.9 82.7 48.9 132.3 0 102.2-59 188.1-200 212.9a127.5 127.5 0 0 1 38.1 91v112.5c.8 9 0 17.9 15 17.9 177.1-59.7 304.6-227 304.6-424.1 0-247.2-200.4-447.3-447.5-447.3z\"}}]})(props);\n};\nexport function AiFillGitlab (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M910.5 553.2l-109-370.8c-6.8-20.4-23.1-34.1-44.9-34.1s-39.5 12.3-46.3 32.7l-72.2 215.4H386.2L314 181.1c-6.8-20.4-24.5-32.7-46.3-32.7s-39.5 13.6-44.9 34.1L113.9 553.2c-4.1 13.6 1.4 28.6 12.3 36.8l385.4 289 386.7-289c10.8-8.1 16.3-23.1 12.2-36.8z\"}}]})(props);\n};\nexport function AiFillGold (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M905.9 806.7l-40.2-248c-.6-3.9-4-6.7-7.9-6.7H596.2c-3.9 0-7.3 2.8-7.9 6.7l-40.2 248c-.1.4-.1.9-.1 1.3 0 4.4 3.6 8 8 8h342c.4 0 .9 0 1.3-.1 4.3-.7 7.3-4.8 6.6-9.2zm-470.2-248c-.6-3.9-4-6.7-7.9-6.7H166.2c-3.9 0-7.3 2.8-7.9 6.7l-40.2 248c-.1.4-.1.9-.1 1.3 0 4.4 3.6 8 8 8h342c.4 0 .9 0 1.3-.1 4.4-.7 7.3-4.8 6.6-9.2l-40.2-248zM342 472h342c.4 0 .9 0 1.3-.1 4.4-.7 7.3-4.8 6.6-9.2l-40.2-248c-.6-3.9-4-6.7-7.9-6.7H382.2c-3.9 0-7.3 2.8-7.9 6.7l-40.2 248c-.1.4-.1.9-.1 1.3 0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiFillGolden (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M905.9 806.7l-40.2-248c-.6-3.9-4-6.7-7.9-6.7H596.2c-3.9 0-7.3 2.8-7.9 6.7l-40.2 248c-.1.4-.1.9-.1 1.3 0 4.4 3.6 8 8 8h342c.4 0 .9 0 1.3-.1 4.3-.7 7.3-4.8 6.6-9.2zm-470.2-248c-.6-3.9-4-6.7-7.9-6.7H166.2c-3.9 0-7.3 2.8-7.9 6.7l-40.2 248c-.1.4-.1.9-.1 1.3 0 4.4 3.6 8 8 8h342c.4 0 .9 0 1.3-.1 4.4-.7 7.3-4.8 6.6-9.2l-40.2-248zM342 472h342c.4 0 .9 0 1.3-.1 4.4-.7 7.3-4.8 6.6-9.2l-40.2-248c-.6-3.9-4-6.7-7.9-6.7H382.2c-3.9 0-7.3 2.8-7.9 6.7l-40.2 248c-.1.4-.1.9-.1 1.3 0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiFillGoogleCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm167 633.6C638.4 735 583 757 516.9 757c-95.7 0-178.5-54.9-218.8-134.9C281.5 589 272 551.6 272 512s9.5-77 26.1-110.1c40.3-80.1 123.1-135 218.8-135 66 0 121.4 24.3 163.9 63.8L610.6 401c-25.4-24.3-57.7-36.6-93.6-36.6-63.8 0-117.8 43.1-137.1 101-4.9 14.7-7.7 30.4-7.7 46.6s2.8 31.9 7.7 46.6c19.3 57.9 73.3 101 137 101 33 0 61-8.7 82.9-23.4 26-17.4 43.2-43.3 48.9-74H516.9v-94.8h230.7c2.9 16.1 4.4 32.8 4.4 50.1 0 74.7-26.7 137.4-73 180.1z\"}}]})(props);\n};\nexport function AiFillGooglePlusCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm36.5 558.8c-43.9 61.8-132.1 79.8-200.9 53.3-69-26.3-118-99.2-112.1-173.5 1.5-90.9 85.2-170.6 176.1-167.5 43.6-2 84.6 16.9 118 43.6-14.3 16.2-29 31.8-44.8 46.3-40.1-27.7-97.2-35.6-137.3-3.6-57.4 39.7-60 133.4-4.8 176.1 53.7 48.7 155.2 24.5 170.1-50.1-33.6-.5-67.4 0-101-1.1-.1-20.1-.2-40.1-.1-60.2 56.2-.2 112.5-.3 168.8.2 3.3 47.3-3 97.5-32 136.5zM791 536.5c-16.8.2-33.6.3-50.4.4-.2 16.8-.3 33.6-.3 50.4H690c-.2-16.8-.2-33.5-.3-50.3-16.8-.2-33.6-.3-50.4-.5v-50.1c16.8-.2 33.6-.3 50.4-.3.1-16.8.3-33.6.4-50.4h50.2l.3 50.4c16.8.2 33.6.2 50.4.3v50.1z\"}}]})(props);\n};\nexport function AiFillGooglePlusSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM548.5 622.8c-43.9 61.8-132.1 79.8-200.9 53.3-69-26.3-118-99.2-112.1-173.5 1.5-90.9 85.2-170.6 176.1-167.5 43.6-2 84.6 16.9 118 43.6-14.3 16.2-29 31.8-44.8 46.3-40.1-27.7-97.2-35.6-137.3-3.6-57.4 39.7-60 133.4-4.8 176.1 53.7 48.7 155.2 24.5 170.1-50.1-33.6-.5-67.4 0-101-1.1-.1-20.1-.2-40.1-.1-60.2 56.2-.2 112.5-.3 168.8.2 3.3 47.3-3 97.5-32 136.5zM791 536.5c-16.8.2-33.6.3-50.4.4-.2 16.8-.3 33.6-.3 50.4H690c-.2-16.8-.2-33.5-.3-50.3-16.8-.2-33.6-.3-50.4-.5v-50.1c16.8-.2 33.6-.3 50.4-.3.1-16.8.3-33.6.4-50.4h50.2l.3 50.4c16.8.2 33.6.2 50.4.3v50.1z\"}}]})(props);\n};\nexport function AiFillGoogleSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM679 697.6C638.4 735 583 757 516.9 757c-95.7 0-178.5-54.9-218.8-134.9A245.02 245.02 0 0 1 272 512c0-39.6 9.5-77 26.1-110.1 40.3-80.1 123.1-135 218.8-135 66 0 121.4 24.3 163.9 63.8L610.6 401c-25.4-24.3-57.7-36.6-93.6-36.6-63.8 0-117.8 43.1-137.1 101-4.9 14.7-7.7 30.4-7.7 46.6s2.8 31.9 7.7 46.6c19.3 57.9 73.3 101 137 101 33 0 61-8.7 82.9-23.4 26-17.4 43.2-43.3 48.9-74H516.9v-94.8h230.7c2.9 16.1 4.4 32.8 4.4 50.1 0 74.7-26.7 137.4-73 180.1z\"}}]})(props);\n};\nexport function AiFillHdd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H192c-17.7 0-32 14.3-32 32v224h704V96c0-17.7-14.3-32-32-32zM456 216c0 4.4-3.6 8-8 8H264c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h184c4.4 0 8 3.6 8 8v48zM160 928c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V704H160v224zm576-136c22.1 0 40 17.9 40 40s-17.9 40-40 40-40-17.9-40-40 17.9-40 40-40zM160 640h704V384H160v256zm96-152c0-4.4 3.6-8 8-8h184c4.4 0 8 3.6 8 8v48c0 4.4-3.6 8-8 8H264c-4.4 0-8-3.6-8-8v-48z\"}}]})(props);\n};\nexport function AiFillHeart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M923 283.6a260.04 260.04 0 0 0-56.9-82.8 264.4 264.4 0 0 0-84-55.5A265.34 265.34 0 0 0 679.7 125c-49.3 0-97.4 13.5-139.2 39-10 6.1-19.5 12.8-28.5 20.1-9-7.3-18.5-14-28.5-20.1-41.8-25.5-89.9-39-139.2-39-35.5 0-69.9 6.8-102.4 20.3-31.4 13-59.7 31.7-84 55.5a258.44 258.44 0 0 0-56.9 82.8c-13.9 32.3-21 66.6-21 101.9 0 33.3 6.8 68 20.3 103.3 11.3 29.5 27.5 60.1 48.2 91 32.8 48.9 77.9 99.9 133.9 151.6 92.8 85.7 184.7 144.9 188.6 147.3l23.7 15.2c10.5 6.7 24 6.7 34.5 0l23.7-15.2c3.9-2.5 95.7-61.6 188.6-147.3 56-51.7 101.1-102.7 133.9-151.6 20.7-30.9 37-61.5 48.2-91 13.5-35.3 20.3-70 20.3-103.3.1-35.3-7-69.6-20.9-101.9z\"}}]})(props);\n};\nexport function AiFillHighlight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M957.6 507.4L603.2 158.2a7.9 7.9 0 0 0-11.2 0L353.3 393.4a8.03 8.03 0 0 0-.1 11.3l.1.1 40 39.4-117.2 115.3a8.03 8.03 0 0 0-.1 11.3l.1.1 39.5 38.9-189.1 187H72.1c-4.4 0-8.1 3.6-8.1 8V860c0 4.4 3.6 8 8 8h344.9c2.1 0 4.1-.8 5.6-2.3l76.1-75.6 40.4 39.8a7.9 7.9 0 0 0 11.2 0l117.1-115.6 40.1 39.5a7.9 7.9 0 0 0 11.2 0l238.7-235.2c3.4-3 3.4-8 .3-11.2z\"}}]})(props);\n};\nexport function AiFillHome (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M946.5 505L534.6 93.4a31.93 31.93 0 0 0-45.2 0L77.5 505c-12 12-18.8 28.3-18.8 45.3 0 35.3 28.7 64 64 64h43.4V908c0 17.7 14.3 32 32 32H448V716h112v224h265.9c17.7 0 32-14.3 32-32V614.3h43.4c17 0 33.3-6.7 45.3-18.8 24.9-25 24.9-65.5-.1-90.5z\"}}]})(props);\n};\nexport function AiFillHourglass (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M742 318V184h86c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H196c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h86v134c0 81.5 42.4 153.2 106.4 194-64 40.8-106.4 112.5-106.4 194v134h-86c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h632c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-86V706c0-81.5-42.4-153.2-106.4-194 64-40.8 106.4-112.5 106.4-194z\"}}]})(props);\n};\nexport function AiFillHtml5 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M145.2 96l66 746.6L512 928l299.6-85.4L878.9 96H145.2zm595 177.1l-4.8 47.2-1.7 19.5H382.3l8.2 94.2h335.1l-3.3 24.3-21.2 242.2-1.7 16.2-187 51.6v.3h-1.2l-.3.1v-.1h-.1l-188.6-52L310.8 572h91.1l6.5 73.2 102.4 27.7h.4l102-27.6 11.4-118.6H510.9v-.1H306l-22.8-253.5-1.7-24.3h460.3l-1.6 24.3z\"}}]})(props);\n};\nexport function AiFillIdcard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M373 411c-28.5 0-51.7 23.3-51.7 52s23.2 52 51.7 52 51.7-23.3 51.7-52-23.2-52-51.7-52zm555-251H96c-17.7 0-32 14.3-32 32v640c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V192c0-17.7-14.3-32-32-32zM608 420c0-4.4 1-8 2.3-8h123.4c1.3 0 2.3 3.6 2.3 8v48c0 4.4-1 8-2.3 8H610.3c-1.3 0-2.3-3.6-2.3-8v-48zm-86 253h-43.9c-4.2 0-7.6-3.3-7.9-7.5-3.8-50.5-46-90.5-97.2-90.5s-93.4 40-97.2 90.5c-.3 4.2-3.7 7.5-7.9 7.5H224a8 8 0 0 1-8-8.4c2.8-53.3 32-99.7 74.6-126.1a111.8 111.8 0 0 1-29.1-75.5c0-61.9 49.9-112 111.4-112s111.4 50.1 111.4 112c0 29.1-11 55.5-29.1 75.5 42.7 26.5 71.8 72.8 74.6 126.1.4 4.6-3.2 8.4-7.8 8.4zm278.9-53H615.1c-3.9 0-7.1-3.6-7.1-8v-48c0-4.4 3.2-8 7.1-8h185.7c3.9 0 7.1 3.6 7.1 8v48h.1c0 4.4-3.2 8-7.1 8z\"}}]})(props);\n};\nexport function AiFillIeCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M693.6 284.4c-24 0-51.1 11.7-72.6 22 46.3 18 86 57.3 112.3 99.6 7.1-18.9 14.6-47.9 14.6-67.9 0-32-22.8-53.7-54.3-53.7zM512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm253.9 492.9H437.1c0 100.4 144.3 136 196.8 47.4h120.8c-32.6 91.7-119.7 146-216.8 146-35.1 0-70.3-.1-101.7-15.6-87.4 44.5-180.3 56.6-180.3-42 0-45.8 23.2-107.1 44-145C335 484 381.3 422.8 435.6 374.5c-43.7 18.9-91.1 66.3-122 101.2 25.9-112.8 129.5-193.6 237.1-186.5 130-59.8 209.7-34.1 209.7 38.6 0 27.4-10.6 63.3-21.4 87.9 25.2 45.5 33.3 97.6 26.9 141.2zM540.5 399.1c-53.7 0-102 39.7-104 94.9h208c-2-55.1-50.6-94.9-104-94.9zM320.6 602.9c-73 152.4 11.5 172.2 100.3 123.3-46.6-27.5-82.6-72.2-100.3-123.3z\"}}]})(props);\n};\nexport function AiFillIeSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM765.9 556.9H437.1c0 100.4 144.3 136 196.8 47.4h120.8c-32.6 91.7-119.7 146-216.8 146-35.1 0-70.3-.1-101.7-15.6-87.4 44.5-180.3 56.6-180.3-42 0-45.8 23.2-107.1 44-145C335 484 381.3 422.8 435.6 374.5c-43.7 18.9-91.1 66.3-122 101.2 25.9-112.8 129.5-193.6 237.1-186.5 130-59.8 209.7-34.1 209.7 38.6 0 27.4-10.6 63.3-21.4 87.9 25.2 45.5 33.3 97.6 26.9 141.2zm-72.3-272.5c-24 0-51.1 11.7-72.6 22 46.3 18 86 57.3 112.3 99.6 7.1-18.9 14.6-47.9 14.6-67.9 0-32-22.8-53.7-54.3-53.7zM540.5 399.1c-53.7 0-102 39.7-104 94.9h208c-2-55.1-50.6-94.9-104-94.9zM320.6 602.9c-73 152.4 11.5 172.2 100.3 123.3-46.6-27.5-82.6-72.2-100.3-123.3z\"}}]})(props);\n};\nexport function AiFillInfoCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm32 664c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V456c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v272zm-32-344a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96z\"}}]})(props);\n};\nexport function AiFillInstagram (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 378.7c-73.4 0-133.3 59.9-133.3 133.3S438.6 645.3 512 645.3 645.3 585.4 645.3 512 585.4 378.7 512 378.7zM911.8 512c0-55.2.5-109.9-2.6-165-3.1-64-17.7-120.8-64.5-167.6-46.9-46.9-103.6-61.4-167.6-64.5-55.2-3.1-109.9-2.6-165-2.6-55.2 0-109.9-.5-165 2.6-64 3.1-120.8 17.7-167.6 64.5C132.6 226.3 118.1 283 115 347c-3.1 55.2-2.6 109.9-2.6 165s-.5 109.9 2.6 165c3.1 64 17.7 120.8 64.5 167.6 46.9 46.9 103.6 61.4 167.6 64.5 55.2 3.1 109.9 2.6 165 2.6 55.2 0 109.9.5 165-2.6 64-3.1 120.8-17.7 167.6-64.5 46.9-46.9 61.4-103.6 64.5-167.6 3.2-55.1 2.6-109.8 2.6-165zM512 717.1c-113.5 0-205.1-91.6-205.1-205.1S398.5 306.9 512 306.9 717.1 398.5 717.1 512 625.5 717.1 512 717.1zm213.5-370.7c-26.5 0-47.9-21.4-47.9-47.9s21.4-47.9 47.9-47.9 47.9 21.4 47.9 47.9a47.84 47.84 0 0 1-47.9 47.9z\"}}]})(props);\n};\nexport function AiFillInsurance (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M519.9 358.8h97.9v41.6h-97.9zm347-188.9L527.1 54.1C523 52.7 517.5 52 512 52s-11 .7-15.1 2.1L157.1 169.9c-8.3 2.8-15.1 12.4-15.1 21.2v482.4c0 8.8 5.7 20.4 12.6 25.9L499.3 968c3.5 2.7 8 4.1 12.6 4.1s9.2-1.4 12.6-4.1l344.7-268.6c6.9-5.4 12.6-17 12.6-25.9V191.1c.2-8.8-6.6-18.3-14.9-21.2zM411.3 656h-.2c0 4.4-3.6 8-8 8h-37.3c-4.4 0-8-3.6-8-8V471.4c-7.7 9.2-15.4 17.9-23.1 26a6.04 6.04 0 0 1-10.2-2.4l-13.2-43.5c-.6-2-.2-4.1 1.2-5.6 37-43.4 64.7-95.1 82.2-153.6 1.1-3.5 5-5.3 8.4-3.7l38.6 18.3c2.7 1.3 4.1 4.4 3.2 7.2a429.2 429.2 0 0 1-33.6 79V656zm296.5-49.2l-26.3 35.3a5.92 5.92 0 0 1-8.9.7c-30.6-29.3-56.8-65.2-78.1-106.9V656c0 4.4-3.6 8-8 8h-36.2c-4.4 0-8-3.6-8-8V536c-22 44.7-49 80.8-80.6 107.6a5.9 5.9 0 0 1-8.9-1.4L430 605.7a6 6 0 0 1 1.6-8.1c28.6-20.3 51.9-45.2 71-76h-55.1c-4.4 0-8-3.6-8-8V478c0-4.4 3.6-8 8-8h94.9v-18.6h-65.9c-4.4 0-8-3.6-8-8V316c0-4.4 3.6-8 8-8h184.7c4.4 0 8 3.6 8 8v127.2c0 4.4-3.6 8-8 8h-66.7v18.6h98.8c4.4 0 8 3.6 8 8v35.6c0 4.4-3.6 8-8 8h-59c18.1 29.1 41.8 54.3 72.3 76.9 2.6 2.1 3.2 5.9 1.2 8.5z\"}}]})(props);\n};\nexport function AiFillInteraction (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM726 585.7c0 55.3-44.7 100.1-99.7 100.1H420.6v53.4c0 5.7-6.5 8.8-10.9 5.3l-109.1-85.7c-3.5-2.7-3.5-8 0-10.7l109.1-85.7c4.4-3.5 10.9-.3 10.9 5.3v53.4h205.7c19.6 0 35.5-16 35.5-35.6v-78.9c0-3.7 3-6.8 6.8-6.8h50.7c3.7 0 6.8 3 6.8 6.8v79.1zm-2.6-209.9l-109.1 85.7c-4.4 3.5-10.9.3-10.9-5.3v-53.4H397.7c-19.6 0-35.5 16-35.5 35.6v78.9c0 3.7-3 6.8-6.8 6.8h-50.7c-3.7 0-6.8-3-6.8-6.8v-78.9c0-55.3 44.7-100.1 99.7-100.1h205.7v-53.4c0-5.7 6.5-8.8 10.9-5.3l109.1 85.7c3.6 2.5 3.6 7.8.1 10.5z\"}}]})(props);\n};\nexport function AiFillLayout (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M384 912h496c17.7 0 32-14.3 32-32V340H384v572zm496-800H384v164h528V144c0-17.7-14.3-32-32-32zm-768 32v736c0 17.7 14.3 32 32 32h176V112H144c-17.7 0-32 14.3-32 32z\"}}]})(props);\n};\nexport function AiFillLeftCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm104 316.9c0 10.2-4.9 19.9-13.2 25.9L457.4 512l145.4 105.2c8.3 6 13.2 15.6 13.2 25.9V690c0 6.5-7.4 10.3-12.7 6.5l-246-178a7.95 7.95 0 0 1 0-12.9l246-178a8 8 0 0 1 12.7 6.5v46.8z\"}}]})(props);\n};\nexport function AiFillLeftSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM624 380.9c0 10.2-4.9 19.9-13.2 25.9L465.4 512l145.4 105.2c8.3 6 13.2 15.6 13.2 25.9V690c0 6.5-7.4 10.3-12.7 6.5l-246-178a7.95 7.95 0 0 1 0-12.9l246-178c5.3-3.8 12.7 0 12.7 6.5v46.8z\"}}]})(props);\n};\nexport function AiFillLike (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M885.9 533.7c16.8-22.2 26.1-49.4 26.1-77.7 0-44.9-25.1-87.4-65.5-111.1a67.67 67.67 0 0 0-34.3-9.3H572.4l6-122.9c1.4-29.7-9.1-57.9-29.5-79.4A106.62 106.62 0 0 0 471 99.9c-52 0-98 35-111.8 85.1l-85.9 311h-.3v428h472.3c9.2 0 18.2-1.8 26.5-5.4 47.6-20.3 78.3-66.8 78.3-118.4 0-12.6-1.8-25-5.4-37 16.8-22.2 26.1-49.4 26.1-77.7 0-12.6-1.8-25-5.4-37 16.8-22.2 26.1-49.4 26.1-77.7-.2-12.6-2-25.1-5.6-37.1zM112 528v364c0 17.7 14.3 32 32 32h65V496h-65c-17.7 0-32 14.3-32 32z\"}}]})(props);\n};\nexport function AiFillLinkedin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM349.3 793.7H230.6V411.9h118.7v381.8zm-59.3-434a68.8 68.8 0 1 1 68.8-68.8c-.1 38-30.9 68.8-68.8 68.8zm503.7 434H675.1V608c0-44.3-.8-101.2-61.7-101.2-61.7 0-71.2 48.2-71.2 98v188.9H423.7V411.9h113.8v52.2h1.6c15.8-30 54.5-61.7 112.3-61.7 120.2 0 142.3 79.1 142.3 181.9v209.4z\"}}]})(props);\n};\nexport function AiFillLock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 464h-68V240c0-70.7-57.3-128-128-128H388c-70.7 0-128 57.3-128 128v224h-68c-17.7 0-32 14.3-32 32v384c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V496c0-17.7-14.3-32-32-32zM540 701v53c0 4.4-3.6 8-8 8h-40c-4.4 0-8-3.6-8-8v-53a48.01 48.01 0 1 1 56 0zm152-237H332V240c0-30.9 25.1-56 56-56h248c30.9 0 56 25.1 56 56v224z\"}}]})(props);\n};\nexport function AiFillMacCommand (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569747879816\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M624 672c0 26.5 21.5 48 48 48s48-21.5 48-48-21.5-48-48-48h-48v48zM720 352c0-26.5-21.5-48-48-48s-48 21.5-48 48v48h48c26.5 0 48-21.5 48-48z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M928 64H96c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V96c0-17.7-14.3-32-32-32zM672 560c61.9 0 112 50.1 112 112s-50.1 112-112 112-112-50.1-112-112v-48h-96v48c0 61.9-50.1 112-112 112s-112-50.1-112-112 50.1-112 112-112h48v-96h-48c-61.9 0-112-50.1-112-112s50.1-112 112-112 112 50.1 112 112v48h96v-48c0-61.9 50.1-112 112-112s112 50.1 112 112-50.1 112-112 112h-48v96h48z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M464 464h96v96h-96zM352 304c-26.5 0-48 21.5-48 48s21.5 48 48 48h48v-48c0-26.5-21.5-48-48-48zM304 672c0 26.5 21.5 48 48 48s48-21.5 48-48v-48h-48c-26.5 0-48 21.5-48 48z\"}}]})(props);\n};\nexport function AiFillMail (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 160H96c-17.7 0-32 14.3-32 32v640c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V192c0-17.7-14.3-32-32-32zm-80.8 108.9L531.7 514.4c-7.8 6.1-18.7 6.1-26.5 0L189.6 268.9A7.2 7.2 0 0 1 194 256h648.8a7.2 7.2 0 0 1 4.4 12.9z\"}}]})(props);\n};\nexport function AiFillMedicineBox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M839.2 278.1a32 32 0 0 0-30.4-22.1H736V144c0-17.7-14.3-32-32-32H320c-17.7 0-32 14.3-32 32v112h-72.8a31.9 31.9 0 0 0-30.4 22.1L112 502v378c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V502l-72.8-223.9zM660 628c0 4.4-3.6 8-8 8H544v108c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V636H372c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h108V464c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v108h108c4.4 0 8 3.6 8 8v48zm4-372H360v-72h304v72z\"}}]})(props);\n};\nexport function AiFillMediumCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm256 253.7l-40.8 39.1c-3.6 2.7-5.3 7.1-4.6 11.4v287.7c-.7 4.4 1 8.8 4.6 11.4l40 39.1v8.7H566.4v-8.3l41.3-40.1c4.1-4.1 4.1-5.3 4.1-11.4V422.5l-115 291.6h-15.5L347.5 422.5V618c-1.2 8.2 1.7 16.5 7.5 22.4l53.8 65.1v8.7H256v-8.7l53.8-65.1a26.1 26.1 0 0 0 7-22.4V392c.7-6.3-1.7-12.4-6.5-16.7l-47.8-57.6V309H411l114.6 251.5 100.9-251.3H768v8.5z\"}}]})(props);\n};\nexport function AiFillMediumSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM768 317.7l-40.8 39.1c-3.6 2.7-5.3 7.1-4.6 11.4v287.7c-.7 4.4 1 8.8 4.6 11.4l40 39.1v8.7H566.4v-8.3l41.3-40.1c4.1-4.1 4.1-5.3 4.1-11.4V422.5l-115 291.6h-15.5L347.5 422.5V618c-1.2 8.2 1.7 16.5 7.5 22.4l53.8 65.1v8.7H256v-8.7l53.8-65.1a26.1 26.1 0 0 0 7-22.4V392c.7-6.3-1.7-12.4-6.5-16.7l-47.8-57.6V309H411l114.6 251.5 100.9-251.3H768v8.5z\"}}]})(props);\n};\nexport function AiFillMeh (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zM288 421a48.01 48.01 0 0 1 96 0 48.01 48.01 0 0 1-96 0zm384 200c0 4.4-3.6 8-8 8H360c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h304c4.4 0 8 3.6 8 8v48zm16-152a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96z\"}}]})(props);\n};\nexport function AiFillMessage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M924.3 338.4a447.57 447.57 0 0 0-96.1-143.3 443.09 443.09 0 0 0-143-96.3A443.91 443.91 0 0 0 512 64h-2c-60.5.3-119 12.3-174.1 35.9a444.08 444.08 0 0 0-141.7 96.5 445 445 0 0 0-95 142.8A449.89 449.89 0 0 0 65 514.1c.3 69.4 16.9 138.3 47.9 199.9v152c0 25.4 20.6 46 45.9 46h151.8a447.72 447.72 0 0 0 199.5 48h2.1c59.8 0 117.7-11.6 172.3-34.3A443.2 443.2 0 0 0 827 830.5c41.2-40.9 73.6-88.7 96.3-142 23.5-55.2 35.5-113.9 35.8-174.5.2-60.9-11.6-120-34.8-175.6zM312.4 560c-26.4 0-47.9-21.5-47.9-48s21.5-48 47.9-48 47.9 21.5 47.9 48-21.4 48-47.9 48zm199.6 0c-26.4 0-47.9-21.5-47.9-48s21.5-48 47.9-48 47.9 21.5 47.9 48-21.5 48-47.9 48zm199.6 0c-26.4 0-47.9-21.5-47.9-48s21.5-48 47.9-48 47.9 21.5 47.9 48-21.5 48-47.9 48z\"}}]})(props);\n};\nexport function AiFillMinusCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm192 472c0 4.4-3.6 8-8 8H328c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h368c4.4 0 8 3.6 8 8v48z\"}}]})(props);\n};\nexport function AiFillMinusSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM704 536c0 4.4-3.6 8-8 8H328c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h368c4.4 0 8 3.6 8 8v48z\"}}]})(props);\n};\nexport function AiFillMobile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M744 62H280c-35.3 0-64 28.7-64 64v768c0 35.3 28.7 64 64 64h464c35.3 0 64-28.7 64-64V126c0-35.3-28.7-64-64-64zM512 824c-22.1 0-40-17.9-40-40s17.9-40 40-40 40 17.9 40 40-17.9 40-40 40z\"}}]})(props);\n};\nexport function AiFillMoneyCollect (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M911.5 699.7a8 8 0 0 0-10.3-4.8L840 717.2V179c0-37.6-30.4-68-68-68H252c-37.6 0-68 30.4-68 68v538.2l-61.3-22.3c-.9-.3-1.8-.5-2.7-.5-4.4 0-8 3.6-8 8V762c0 3.3 2.1 6.3 5.3 7.5L501 909.1c7.1 2.6 14.8 2.6 21.9 0l383.8-139.5c3.2-1.2 5.3-4.2 5.3-7.5v-59.6c0-1-.2-1.9-.5-2.8zm-243.8-377L564 514.3h57.6c4.4 0 8 3.6 8 8v27.1c0 4.4-3.6 8-8 8h-76.3v39h76.3c4.4 0 8 3.6 8 8v27.1c0 4.4-3.6 8-8 8h-76.3V703c0 4.4-3.6 8-8 8h-49.9c-4.4 0-8-3.6-8-8v-63.4h-76c-4.4 0-8-3.6-8-8v-27.1c0-4.4 3.6-8 8-8h76v-39h-76c-4.4 0-8-3.6-8-8v-27.1c0-4.4 3.6-8 8-8h57L356.5 322.8c-2.1-3.8-.7-8.7 3.2-10.8 1.2-.7 2.5-1 3.8-1h55.7a8 8 0 0 1 7.1 4.4L511 484.2h3.3L599 315.4c1.3-2.7 4.1-4.4 7.1-4.4h54.5c4.4 0 8 3.6 8.1 7.9 0 1.3-.4 2.6-1 3.8z\"}}]})(props);\n};\nexport function AiFillNotification (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112c-3.8 0-7.7.7-11.6 2.3L292 345.9H128c-8.8 0-16 7.4-16 16.6v299c0 9.2 7.2 16.6 16 16.6h101.6c-3.7 11.6-5.6 23.9-5.6 36.4 0 65.9 53.8 119.5 120 119.5 55.4 0 102.1-37.6 115.9-88.4l408.6 164.2c3.9 1.5 7.8 2.3 11.6 2.3 16.9 0 32-14.2 32-33.2V145.2C912 126.2 897 112 880 112zM344 762.3c-26.5 0-48-21.4-48-47.8 0-11.2 3.9-21.9 11-30.4l84.9 34.1c-2 24.6-22.7 44.1-47.9 44.1z\"}}]})(props);\n};\nexport function AiFillPauseCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm-80 600c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V360c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v304zm224 0c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V360c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v304z\"}}]})(props);\n};\nexport function AiFillPayCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm166.6 246.8L567.5 515.6h62c4.4 0 8 3.6 8 8v29.9c0 4.4-3.6 8-8 8h-82V603h82c4.4 0 8 3.6 8 8v29.9c0 4.4-3.6 8-8 8h-82V717c0 4.4-3.6 8-8 8h-54.3c-4.4 0-8-3.6-8-8v-68.1h-81.7c-4.4 0-8-3.6-8-8V611c0-4.4 3.6-8 8-8h81.7v-41.5h-81.7c-4.4 0-8-3.6-8-8v-29.9c0-4.4 3.6-8 8-8h61.4L345.4 310.8a8.07 8.07 0 0 1 7-11.9h60.7c3 0 5.8 1.7 7.1 4.4l90.6 180h3.4l90.6-180a8 8 0 0 1 7.1-4.4h59.5c4.4 0 8 3.6 8 8 .2 1.4-.2 2.7-.8 3.9z\"}}]})(props);\n};\nexport function AiFillPhone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M885.6 230.2L779.1 123.8a80.83 80.83 0 0 0-57.3-23.8c-21.7 0-42.1 8.5-57.4 23.8L549.8 238.4a80.83 80.83 0 0 0-23.8 57.3c0 21.7 8.5 42.1 23.8 57.4l83.8 83.8A393.82 393.82 0 0 1 553.1 553 395.34 395.34 0 0 1 437 633.8L353.2 550a80.83 80.83 0 0 0-57.3-23.8c-21.7 0-42.1 8.5-57.4 23.8L123.8 664.5a80.89 80.89 0 0 0-23.8 57.4c0 21.7 8.5 42.1 23.8 57.4l106.3 106.3c24.4 24.5 58.1 38.4 92.7 38.4 7.3 0 14.3-.6 21.2-1.8 134.8-22.2 268.5-93.9 376.4-201.7C828.2 612.8 899.8 479.2 922.3 344c6.8-41.3-6.9-83.8-36.7-113.8z\"}}]})(props);\n};\nexport function AiFillPicture (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 160H96c-17.7 0-32 14.3-32 32v640c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V192c0-17.7-14.3-32-32-32zM338 304c35.3 0 64 28.7 64 64s-28.7 64-64 64-64-28.7-64-64 28.7-64 64-64zm513.9 437.1a8.11 8.11 0 0 1-5.2 1.9H177.2c-4.4 0-8-3.6-8-8 0-1.9.7-3.7 1.9-5.2l170.3-202c2.8-3.4 7.9-3.8 11.3-1 .3.3.7.6 1 1l99.4 118 158.1-187.5c2.8-3.4 7.9-3.8 11.3-1 .3.3.7.6 1 1l229.6 271.6c2.6 3.3 2.2 8.4-1.2 11.2z\"}}]})(props);\n};\nexport function AiFillPieChart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M863.1 518.5H505.5V160.9c0-4.4-3.6-8-8-8h-26a398.57 398.57 0 0 0-282.5 117 397.47 397.47 0 0 0-85.6 127C82.6 446.2 72 498.5 72 552.5S82.6 658.7 103.4 708c20.1 47.5 48.9 90.3 85.6 127 36.7 36.7 79.4 65.5 127 85.6a396.64 396.64 0 0 0 155.6 31.5 398.57 398.57 0 0 0 282.5-117c36.7-36.7 65.5-79.4 85.6-127a396.64 396.64 0 0 0 31.5-155.6v-26c-.1-4.4-3.7-8-8.1-8zM951 463l-2.6-28.2c-8.5-92-49.3-178.8-115.1-244.3A398.5 398.5 0 0 0 588.4 75.6L560.1 73c-4.7-.4-8.7 3.2-8.7 7.9v383.7c0 4.4 3.6 8 8 8l383.6-1c4.7-.1 8.4-4 8-8.6z\"}}]})(props);\n};\nexport function AiFillPlayCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm144.1 454.9L437.7 677.8a8.02 8.02 0 0 1-12.7-6.5V353.7a8 8 0 0 1 12.7-6.5L656.1 506a7.9 7.9 0 0 1 0 12.9z\"}}]})(props);\n};\nexport function AiFillPlaySquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM641.7 520.8L442.3 677.6c-7.4 5.8-18.3.6-18.3-8.8V355.3c0-9.4 10.9-14.7 18.3-8.8l199.4 156.7a11.2 11.2 0 0 1 0 17.6z\"}}]})(props);\n};\nexport function AiFillPlusCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm192 472c0 4.4-3.6 8-8 8H544v152c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V544H328c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h152V328c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v152h152c4.4 0 8 3.6 8 8v48z\"}}]})(props);\n};\nexport function AiFillPlusSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM704 536c0 4.4-3.6 8-8 8H544v152c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V544H328c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h152V328c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v152h152c4.4 0 8 3.6 8 8v48z\"}}]})(props);\n};\nexport function AiFillPoundCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm146 658c0 4.4-3.6 8-8 8H376.2c-4.4 0-8-3.6-8-8v-38.5c0-3.7 2.5-6.9 6.1-7.8 44-10.9 72.8-49 72.8-94.2 0-14.7-2.5-29.4-5.9-44.2H374c-4.4 0-8-3.6-8-8v-30c0-4.4 3.6-8 8-8h53.7c-7.8-25.1-14.6-50.7-14.6-77.1 0-75.8 58.6-120.3 151.5-120.3 26.5 0 51.4 5.5 70.3 12.7 3.1 1.2 5.2 4.2 5.2 7.5v39.5a8 8 0 0 1-10.6 7.6c-17.9-6.4-39-10.5-60.4-10.5-53.3 0-87.3 26.6-87.3 70.2 0 24.7 6.2 47.9 13.4 70.5h112c4.4 0 8 3.6 8 8v30c0 4.4-3.6 8-8 8h-98.6c3.1 13.2 5.3 26.9 5.3 41 0 40.7-16.5 73.9-43.9 91.1v4.7h180c4.4 0 8 3.6 8 8V722z\"}}]})(props);\n};\nexport function AiFillPrinter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M732 120c0-4.4-3.6-8-8-8H300c-4.4 0-8 3.6-8 8v148h440V120zm120 212H172c-44.2 0-80 35.8-80 80v328c0 17.7 14.3 32 32 32h168v132c0 4.4 3.6 8 8 8h424c4.4 0 8-3.6 8-8V772h168c17.7 0 32-14.3 32-32V412c0-44.2-35.8-80-80-80zM664 844H360V568h304v276zm164-360c0 4.4-3.6 8-8 8h-40c-4.4 0-8-3.6-8-8v-40c0-4.4 3.6-8 8-8h40c4.4 0 8 3.6 8 8v40z\"}}]})(props);\n};\nexport function AiFillProfile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM380 696c-22.1 0-40-17.9-40-40s17.9-40 40-40 40 17.9 40 40-17.9 40-40 40zm0-144c-22.1 0-40-17.9-40-40s17.9-40 40-40 40 17.9 40 40-17.9 40-40 40zm0-144c-22.1 0-40-17.9-40-40s17.9-40 40-40 40 17.9 40 40-17.9 40-40 40zm304 272c0 4.4-3.6 8-8 8H492c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h184c4.4 0 8 3.6 8 8v48zm0-144c0 4.4-3.6 8-8 8H492c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h184c4.4 0 8 3.6 8 8v48zm0-144c0 4.4-3.6 8-8 8H492c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h184c4.4 0 8 3.6 8 8v48z\"}}]})(props);\n};\nexport function AiFillProject (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM368 744c0 4.4-3.6 8-8 8h-80c-4.4 0-8-3.6-8-8V280c0-4.4 3.6-8 8-8h80c4.4 0 8 3.6 8 8v464zm192-280c0 4.4-3.6 8-8 8h-80c-4.4 0-8-3.6-8-8V280c0-4.4 3.6-8 8-8h80c4.4 0 8 3.6 8 8v184zm192 72c0 4.4-3.6 8-8 8h-80c-4.4 0-8-3.6-8-8V280c0-4.4 3.6-8 8-8h80c4.4 0 8 3.6 8 8v256z\"}}]})(props);\n};\nexport function AiFillPropertySafety (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M866.9 169.9L527.1 54.1C523 52.7 517.5 52 512 52s-11 .7-15.1 2.1L157.1 169.9c-8.3 2.8-15.1 12.4-15.1 21.2v482.4c0 8.8 5.7 20.4 12.6 25.9L499.3 968c3.5 2.7 8 4.1 12.6 4.1s9.2-1.4 12.6-4.1l344.7-268.6c6.9-5.4 12.6-17 12.6-25.9V191.1c.2-8.8-6.6-18.3-14.9-21.2zM648.3 332.8l-87.7 161.1h45.7c5.5 0 10 4.5 10 10v21.3c0 5.5-4.5 10-10 10h-63.4v29.7h63.4c5.5 0 10 4.5 10 10v21.3c0 5.5-4.5 10-10 10h-63.4V658c0 5.5-4.5 10-10 10h-41.3c-5.5 0-10-4.5-10-10v-51.8h-63.1c-5.5 0-10-4.5-10-10v-21.3c0-5.5 4.5-10 10-10h63.1v-29.7h-63.1c-5.5 0-10-4.5-10-10v-21.3c0-5.5 4.5-10 10-10h45.2l-88-161.1c-2.6-4.8-.9-10.9 4-13.6 1.5-.8 3.1-1.2 4.8-1.2h46c3.8 0 7.2 2.1 8.9 5.5l72.9 144.3 73.2-144.3a10 10 0 0 1 8.9-5.5h45c5.5 0 10 4.5 10 10 .1 1.7-.3 3.3-1.1 4.8z\"}}]})(props);\n};\nexport function AiFillPushpin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M878.3 392.1L631.9 145.7c-6.5-6.5-15-9.7-23.5-9.7s-17 3.2-23.5 9.7L423.8 306.9c-12.2-1.4-24.5-2-36.8-2-73.2 0-146.4 24.1-206.5 72.3-15.4 12.3-16.6 35.4-2.7 49.4l181.7 181.7-215.4 215.2a15.8 15.8 0 0 0-4.6 9.8l-3.4 37.2c-.9 9.4 6.6 17.4 15.9 17.4.5 0 1 0 1.5-.1l37.2-3.4c3.7-.3 7.2-2 9.8-4.6l215.4-215.4 181.7 181.7c6.5 6.5 15 9.7 23.5 9.7 9.7 0 19.3-4.2 25.9-12.4 56.3-70.3 79.7-158.3 70.2-243.4l161.1-161.1c12.9-12.8 12.9-33.8 0-46.8z\"}}]})(props);\n};\nexport function AiFillQqCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm210.5 612.4c-11.5 1.4-44.9-52.7-44.9-52.7 0 31.3-16.2 72.2-51.1 101.8 16.9 5.2 54.9 19.2 45.9 34.4-7.3 12.3-125.6 7.9-159.8 4-34.2 3.8-152.5 8.3-159.8-4-9.1-15.2 28.9-29.2 45.8-34.4-35-29.5-51.1-70.4-51.1-101.8 0 0-33.4 54.1-44.9 52.7-5.4-.7-12.4-29.6 9.4-99.7 10.3-33 22-60.5 40.2-105.8-3.1-116.9 45.3-215 160.4-215 113.9 0 163.3 96.1 160.4 215 18.1 45.2 29.9 72.8 40.2 105.8 21.7 70.1 14.6 99.1 9.3 99.7z\"}}]})(props);\n};\nexport function AiFillQqSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM722.5 676.4c-11.5 1.4-44.9-52.7-44.9-52.7 0 31.3-16.2 72.2-51.1 101.8 16.9 5.2 54.9 19.2 45.9 34.4-7.3 12.3-125.6 7.9-159.8 4-34.2 3.8-152.5 8.3-159.8-4-9.1-15.2 28.9-29.2 45.8-34.4-35-29.5-51.1-70.4-51.1-101.8 0 0-33.4 54.1-44.9 52.7-5.4-.7-12.4-29.6 9.4-99.7 10.3-33 22-60.5 40.2-105.8-3.1-116.9 45.3-215 160.4-215 113.9 0 163.3 96.1 160.4 215 18.1 45.2 29.9 72.8 40.2 105.8 21.7 70.1 14.6 99.1 9.3 99.7z\"}}]})(props);\n};\nexport function AiFillQuestionCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 708c-22.1 0-40-17.9-40-40s17.9-40 40-40 40 17.9 40 40-17.9 40-40 40zm62.9-219.5a48.3 48.3 0 0 0-30.9 44.8V620c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8v-21.5c0-23.1 6.7-45.9 19.9-64.9 12.9-18.6 30.9-32.8 52.1-40.9 34-13.1 56-41.6 56-72.7 0-44.1-43.1-80-96-80s-96 35.9-96 80v7.6c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V420c0-39.3 17.2-76 48.4-103.3C430.4 290.4 470 276 512 276s81.6 14.5 111.6 40.7C654.8 344 672 380.7 672 420c0 57.8-38.1 109.8-97.1 132.5z\"}}]})(props);\n};\nexport function AiFillRead (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 161H699.2c-49.1 0-97.1 14.1-138.4 40.7L512 233l-48.8-31.3A255.2 255.2 0 0 0 324.8 161H96c-17.7 0-32 14.3-32 32v568c0 17.7 14.3 32 32 32h228.8c49.1 0 97.1 14.1 138.4 40.7l44.4 28.6c1.3.8 2.8 1.3 4.3 1.3s3-.4 4.3-1.3l44.4-28.6C602 807.1 650.1 793 699.2 793H928c17.7 0 32-14.3 32-32V193c0-17.7-14.3-32-32-32zM404 553.5c0 4.1-3.2 7.5-7.1 7.5H211.1c-3.9 0-7.1-3.4-7.1-7.5v-45c0-4.1 3.2-7.5 7.1-7.5h185.7c3.9 0 7.1 3.4 7.1 7.5v45zm0-140c0 4.1-3.2 7.5-7.1 7.5H211.1c-3.9 0-7.1-3.4-7.1-7.5v-45c0-4.1 3.2-7.5 7.1-7.5h185.7c3.9 0 7.1 3.4 7.1 7.5v45zm416 140c0 4.1-3.2 7.5-7.1 7.5H627.1c-3.9 0-7.1-3.4-7.1-7.5v-45c0-4.1 3.2-7.5 7.1-7.5h185.7c3.9 0 7.1 3.4 7.1 7.5v45zm0-140c0 4.1-3.2 7.5-7.1 7.5H627.1c-3.9 0-7.1-3.4-7.1-7.5v-45c0-4.1 3.2-7.5 7.1-7.5h185.7c3.9 0 7.1 3.4 7.1 7.5v45z\"}}]})(props);\n};\nexport function AiFillReconciliation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M676 623c-18.8 0-34 15.2-34 34s15.2 34 34 34 34-15.2 34-34-15.2-34-34-34zm204-455H668c0-30.9-25.1-56-56-56h-80c-30.9 0-56 25.1-56 56H264c-17.7 0-32 14.3-32 32v200h-88c-17.7 0-32 14.3-32 32v448c0 17.7 14.3 32 32 32h336c17.7 0 32-14.3 32-32v-16h368c17.7 0 32-14.3 32-32V200c0-17.7-14.3-32-32-32zM448 848H176V616h272v232zm0-296H176v-88h272v88zm20-272v-48h72v-56h64v56h72v48H468zm180 168v56c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8v-56c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8zm28 301c-50.8 0-92-41.2-92-92s41.2-92 92-92 92 41.2 92 92-41.2 92-92 92zm92-245c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8v-96c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v96zm-92 61c-50.8 0-92 41.2-92 92s41.2 92 92 92 92-41.2 92-92-41.2-92-92-92zm0 126c-18.8 0-34-15.2-34-34s15.2-34 34-34 34 15.2 34 34-15.2 34-34 34z\"}}]})(props);\n};\nexport function AiFillRedEnvelope (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V96c0-17.7-14.3-32-32-32zM647 470.4l-87.2 161h45.9c4.6 0 8.4 3.8 8.4 8.4v25.1c0 4.6-3.8 8.4-8.4 8.4h-63.3v28.6h63.3c4.6 0 8.4 3.8 8.4 8.4v25c.2 4.6-3.6 8.5-8.2 8.5h-63.3v49.9c0 4.6-3.8 8.4-8.4 8.4h-43.7c-4.6 0-8.4-3.8-8.4-8.4v-49.9h-63c-4.6 0-8.4-3.8-8.4-8.4v-25.1c0-4.6 3.8-8.4 8.4-8.4h63v-28.6h-63c-4.6 0-8.4-3.8-8.4-8.4v-25.1c0-4.6 3.8-8.4 8.4-8.4h45.4l-87.5-161c-2.2-4.1-.7-9.1 3.4-11.4 1.3-.6 2.6-1 3.9-1h48.8c3.2 0 6.1 1.8 7.5 4.6l71.9 141.8 71.9-141.9a8.5 8.5 0 0 1 7.5-4.6h47.8c4.6 0 8.4 3.8 8.4 8.4-.1 1.5-.5 2.9-1.1 4.1zM512.6 323L289 148h446L512.6 323z\"}}]})(props);\n};\nexport function AiFillRedditCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M584 548a36 36 0 1 0 72 0 36 36 0 1 0-72 0zm144-108a35.9 35.9 0 0 0-32.5 20.6c18.8 14.3 34.4 30.7 45.9 48.8A35.98 35.98 0 0 0 728 440zM512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm245 477.9c4.6 13.5 7 27.6 7 42.1 0 99.4-112.8 180-252 180s-252-80.6-252-180c0-14.5 2.4-28.6 7-42.1A72.01 72.01 0 0 1 296 404c27.1 0 50.6 14.9 62.9 37 36.2-19.8 80.2-32.8 128.1-36.1l58.4-131.1c4.3-9.8 15.2-14.8 25.5-11.8l91.6 26.5a54.03 54.03 0 0 1 101.6 25.6c0 29.8-24.2 54-54 54-23.5 0-43.5-15.1-50.9-36.1L577 308.3l-43 96.5c49.1 3 94.2 16.1 131.2 36.3 12.3-22.1 35.8-37 62.9-37 39.8 0 72 32.2 72 72-.1 29.3-17.8 54.6-43.1 65.8zm-171.3 83c-14.9 11.7-44.3 24.3-73.7 24.3s-58.9-12.6-73.7-24.3c-9.3-7.3-22.7-5.7-30 3.6-7.3 9.3-5.7 22.7 3.6 30 25.7 20.4 65 33.5 100.1 33.5 35.1 0 74.4-13.1 100.2-33.5 9.3-7.3 10.9-20.8 3.6-30a21.46 21.46 0 0 0-30.1-3.6zM296 440a35.98 35.98 0 0 0-13.4 69.4c11.5-18.1 27.1-34.5 45.9-48.8A35.9 35.9 0 0 0 296 440zm72 108a36 36 0 1 0 72 0 36 36 0 1 0-72 0z\"}}]})(props);\n};\nexport function AiFillRedditSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M296 440a35.98 35.98 0 0 0-13.4 69.4c11.5-18.1 27.1-34.5 45.9-48.8A35.9 35.9 0 0 0 296 440zm289.7 184.9c-14.9 11.7-44.3 24.3-73.7 24.3s-58.9-12.6-73.7-24.3c-9.3-7.3-22.7-5.7-30 3.6-7.3 9.3-5.7 22.7 3.6 30 25.7 20.4 65 33.5 100.1 33.5 35.1 0 74.4-13.1 100.2-33.5 9.3-7.3 10.9-20.8 3.6-30a21.46 21.46 0 0 0-30.1-3.6zM880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM757 541.9c4.6 13.5 7 27.6 7 42.1 0 99.4-112.8 180-252 180s-252-80.6-252-180c0-14.5 2.4-28.6 7-42.1A72.01 72.01 0 0 1 296 404c27.1 0 50.6 14.9 62.9 37 36.2-19.8 80.2-32.8 128.1-36.1l58.4-131.1c4.3-9.8 15.2-14.8 25.5-11.8l91.6 26.5a54.03 54.03 0 0 1 101.6 25.6c0 29.8-24.2 54-54 54-23.5 0-43.5-15.1-50.9-36.1L577 308.3l-43 96.5c49.1 3 94.2 16.1 131.2 36.3 12.3-22.1 35.8-37 62.9-37 39.8 0 72 32.2 72 72-.1 29.3-17.8 54.6-43.1 65.8zM584 548a36 36 0 1 0 72 0 36 36 0 1 0-72 0zm144-108a35.9 35.9 0 0 0-32.5 20.6c18.8 14.3 34.4 30.7 45.9 48.8A35.98 35.98 0 0 0 728 440zM368 548a36 36 0 1 0 72 0 36 36 0 1 0-72 0z\"}}]})(props);\n};\nexport function AiFillRest (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 256h-28.1l-35.7-120.9c-4-13.7-16.5-23.1-30.7-23.1h-451c-14.3 0-26.8 9.4-30.7 23.1L220.1 256H192c-17.7 0-32 14.3-32 32v28c0 4.4 3.6 8 8 8h45.8l47.7 558.7a32 32 0 0 0 31.9 29.3h429.2a32 32 0 0 0 31.9-29.3L802.2 324H856c4.4 0 8-3.6 8-8v-28c0-17.7-14.3-32-32-32zM508 704c-79.5 0-144-64.5-144-144s64.5-144 144-144 144 64.5 144 144-64.5 144-144 144zM291 256l22.4-76h397.2l22.4 76H291zm137 304a80 80 0 1 0 160 0 80 80 0 1 0-160 0z\"}}]})(props);\n};\nexport function AiFillRightCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm154.7 454.5l-246 178c-5.3 3.8-12.7 0-12.7-6.5v-46.9c0-10.2 4.9-19.9 13.2-25.9L566.6 512 421.2 406.8c-8.3-6-13.2-15.6-13.2-25.9V334c0-6.5 7.4-10.3 12.7-6.5l246 178c4.4 3.2 4.4 9.8 0 13z\"}}]})(props);\n};\nexport function AiFillRightSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM658.7 518.5l-246 178c-5.3 3.8-12.7 0-12.7-6.5v-46.9c0-10.2 4.9-19.9 13.2-25.9L558.6 512 413.2 406.8c-8.3-6-13.2-15.6-13.2-25.9V334c0-6.5 7.4-10.3 12.7-6.5l246 178c4.4 3.2 4.4 9.8 0 13z\"}}]})(props);\n};\nexport function AiFillRobot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569682613478\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M852 64H172c-17.7 0-32 14.3-32 32v660c0 17.7 14.3 32 32 32h680c17.7 0 32-14.3 32-32V96c0-17.7-14.3-32-32-32zM300 328c0-33.1 26.9-60 60-60s60 26.9 60 60-26.9 60-60 60-60-26.9-60-60z m372 248c0 4.4-3.6 8-8 8H360c-4.4 0-8-3.6-8-8v-60c0-4.4 3.6-8 8-8h304c4.4 0 8 3.6 8 8v60z m-8-188c-33.1 0-60-26.9-60-60s26.9-60 60-60 60 26.9 60 60-26.9 60-60 60zM799 864H225c-13.8 0-25 14.3-25 32v56c0 4.4 2.8 8 6.2 8h611.5c3.4 0 6.2-3.6 6.2-8v-56c0.1-17.7-11.1-32-24.9-32z\"}}]})(props);\n};\nexport function AiFillRocket (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M864 736c0-111.6-65.4-208-160-252.9V317.3c0-15.1-5.3-29.7-15.1-41.2L536.5 95.4C530.1 87.8 521 84 512 84s-18.1 3.8-24.5 11.4L335.1 276.1a63.97 63.97 0 0 0-15.1 41.2v165.8C225.4 528 160 624.4 160 736h156.5c-2.3 7.2-3.5 15-3.5 23.8 0 22.1 7.6 43.7 21.4 60.8a97.2 97.2 0 0 0 43.1 30.6c23.1 54 75.6 88.8 134.5 88.8 29.1 0 57.3-8.6 81.4-24.8 23.6-15.8 41.9-37.9 53-64a97 97 0 0 0 43.1-30.5 97.52 97.52 0 0 0 21.4-60.8c0-8.4-1.1-16.4-3.1-23.8L864 736zM512 352a48.01 48.01 0 0 1 0 96 48.01 48.01 0 0 1 0-96zm116.1 432.2c-5.2 3-11.2 4.2-17.1 3.4l-19.5-2.4-2.8 19.4c-5.4 37.9-38.4 66.5-76.7 66.5s-71.3-28.6-76.7-66.5l-2.8-19.5-19.5 2.5a27.7 27.7 0 0 1-17.1-3.5c-8.7-5-14.1-14.3-14.1-24.4 0-10.6 5.9-19.4 14.6-23.8h231.3c8.8 4.5 14.6 13.3 14.6 23.8-.1 10.2-5.5 19.6-14.2 24.5z\"}}]})(props);\n};\nexport function AiFillSafetyCertificate (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M866.9 169.9L527.1 54.1C523 52.7 517.5 52 512 52s-11 .7-15.1 2.1L157.1 169.9c-8.3 2.8-15.1 12.4-15.1 21.2v482.4c0 8.8 5.7 20.4 12.6 25.9L499.3 968c3.5 2.7 8 4.1 12.6 4.1s9.2-1.4 12.6-4.1l344.7-268.6c6.9-5.4 12.6-17 12.6-25.9V191.1c.2-8.8-6.6-18.3-14.9-21.2zM694.5 340.7L481.9 633.4a16.1 16.1 0 0 1-26 0l-126.4-174c-3.8-5.3 0-12.7 6.5-12.7h55.2c5.1 0 10 2.5 13 6.6l64.7 89 150.9-207.8c3-4.1 7.8-6.6 13-6.6H688c6.5.1 10.3 7.5 6.5 12.8z\"}}]})(props);\n};\nexport function AiFillSave (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M893.3 293.3L730.7 130.7c-12-12-28.3-18.7-45.3-18.7H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V338.5c0-17-6.7-33.2-18.7-45.2zM384 176h256v112H384V176zm128 554c-79.5 0-144-64.5-144-144s64.5-144 144-144 144 64.5 144 144-64.5 144-144 144zm0-224c-44.2 0-80 35.8-80 80s35.8 80 80 80 80-35.8 80-80-35.8-80-80-80z\"}}]})(props);\n};\nexport function AiFillSchedule (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 224H768v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H548v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H328v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H96c-17.7 0-32 14.3-32 32v576c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V256c0-17.7-14.3-32-32-32zM424 688c0 4.4-3.6 8-8 8H232c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h184c4.4 0 8 3.6 8 8v48zm0-136c0 4.4-3.6 8-8 8H232c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h184c4.4 0 8 3.6 8 8v48zm374.5-91.3l-165 228.7a15.9 15.9 0 0 1-25.8 0L493.5 531.2c-3.8-5.3 0-12.7 6.5-12.7h54.9c5.1 0 9.9 2.5 12.9 6.6l52.8 73.1 103.7-143.7c3-4.2 7.8-6.6 12.9-6.6H792c6.5.1 10.3 7.5 6.5 12.8z\"}}]})(props);\n};\nexport function AiFillSecurityScan (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M866.9 169.9L527.1 54.1C523 52.7 517.5 52 512 52s-11 .7-15.1 2.1L157.1 169.9c-8.3 2.8-15.1 12.4-15.1 21.2v482.4c0 8.8 5.7 20.4 12.6 25.9L499.3 968c3.5 2.7 8 4.1 12.6 4.1s9.2-1.4 12.6-4.1l344.7-268.6c6.9-5.4 12.6-17 12.6-25.9V191.1c.2-8.8-6.6-18.3-14.9-21.2zM626.8 554c-48.5 48.5-123 55.2-178.6 20.1l-77.5 77.5a8.03 8.03 0 0 1-11.3 0l-34-34a8.03 8.03 0 0 1 0-11.3l77.5-77.5c-35.1-55.7-28.4-130.1 20.1-178.6 56.3-56.3 147.5-56.3 203.8 0 56.3 56.3 56.3 147.5 0 203.8zm-158.54-45.27a80.1 80.1 0 1 0 113.27-113.28 80.1 80.1 0 1 0-113.27 113.28z\"}}]})(props);\n};\nexport function AiFillSetting (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512.5 390.6c-29.9 0-57.9 11.6-79.1 32.8-21.1 21.2-32.8 49.2-32.8 79.1 0 29.9 11.7 57.9 32.8 79.1 21.2 21.1 49.2 32.8 79.1 32.8 29.9 0 57.9-11.7 79.1-32.8 21.1-21.2 32.8-49.2 32.8-79.1 0-29.9-11.7-57.9-32.8-79.1a110.96 110.96 0 0 0-79.1-32.8zm412.3 235.5l-65.4-55.9c3.1-19 4.7-38.4 4.7-57.7s-1.6-38.8-4.7-57.7l65.4-55.9a32.03 32.03 0 0 0 9.3-35.2l-.9-2.6a442.5 442.5 0 0 0-79.6-137.7l-1.8-2.1a32.12 32.12 0 0 0-35.1-9.5l-81.2 28.9c-30-24.6-63.4-44-99.6-57.5l-15.7-84.9a32.05 32.05 0 0 0-25.8-25.7l-2.7-.5c-52-9.4-106.8-9.4-158.8 0l-2.7.5a32.05 32.05 0 0 0-25.8 25.7l-15.8 85.3a353.44 353.44 0 0 0-98.9 57.3l-81.8-29.1a32 32 0 0 0-35.1 9.5l-1.8 2.1a445.93 445.93 0 0 0-79.6 137.7l-.9 2.6c-4.5 12.5-.8 26.5 9.3 35.2l66.2 56.5c-3.1 18.8-4.6 38-4.6 57 0 19.2 1.5 38.4 4.6 57l-66 56.5a32.03 32.03 0 0 0-9.3 35.2l.9 2.6c18.1 50.3 44.8 96.8 79.6 137.7l1.8 2.1a32.12 32.12 0 0 0 35.1 9.5l81.8-29.1c29.8 24.5 63 43.9 98.9 57.3l15.8 85.3a32.05 32.05 0 0 0 25.8 25.7l2.7.5a448.27 448.27 0 0 0 158.8 0l2.7-.5a32.05 32.05 0 0 0 25.8-25.7l15.7-84.9c36.2-13.6 69.6-32.9 99.6-57.5l81.2 28.9a32 32 0 0 0 35.1-9.5l1.8-2.1c34.8-41.1 61.5-87.4 79.6-137.7l.9-2.6c4.3-12.4.6-26.3-9.5-35zm-412.3 52.2c-97.1 0-175.8-78.7-175.8-175.8s78.7-175.8 175.8-175.8 175.8 78.7 175.8 175.8-78.7 175.8-175.8 175.8z\"}}]})(props);\n};\nexport function AiFillShop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M882 272.1V144c0-17.7-14.3-32-32-32H174c-17.7 0-32 14.3-32 32v128.1c-16.7 1-30 14.9-30 31.9v131.7a177 177 0 0 0 14.4 70.4c4.3 10.2 9.6 19.8 15.6 28.9v345c0 17.6 14.3 32 32 32h274V736h128v176h274c17.7 0 32-14.3 32-32V535a175 175 0 0 0 15.6-28.9c9.5-22.3 14.4-46 14.4-70.4V304c0-17-13.3-30.9-30-31.9zm-72 568H640V704c0-17.7-14.3-32-32-32H416c-17.7 0-32 14.3-32 32v136.1H214V597.9c2.9 1.4 5.9 2.8 9 4 22.3 9.4 46 14.1 70.4 14.1s48-4.7 70.4-14.1c13.8-5.8 26.8-13.2 38.7-22.1.2-.1.4-.1.6 0a180.4 180.4 0 0 0 38.7 22.1c22.3 9.4 46 14.1 70.4 14.1 24.4 0 48-4.7 70.4-14.1 13.8-5.8 26.8-13.2 38.7-22.1.2-.1.4-.1.6 0a180.4 180.4 0 0 0 38.7 22.1c22.3 9.4 46 14.1 70.4 14.1 24.4 0 48-4.7 70.4-14.1 3-1.3 6-2.6 9-4v242.2zm0-568.1H214v-88h596v88z\"}}]})(props);\n};\nexport function AiFillShopping (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 312H696v-16c0-101.6-82.4-184-184-184s-184 82.4-184 184v16H192c-17.7 0-32 14.3-32 32v536c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V344c0-17.7-14.3-32-32-32zm-208 0H400v-16c0-61.9 50.1-112 112-112s112 50.1 112 112v16z\"}}]})(props);\n};\nexport function AiFillSignal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569682885975\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M584 352H440c-17.7 0-32 14.3-32 32v544c0 17.7 14.3 32 32 32h144c17.7 0 32-14.3 32-32V384c0-17.7-14.3-32-32-32zM892 64H748c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h144c17.7 0 32-14.3 32-32V96c0-17.7-14.3-32-32-32zM276 640H132c-17.7 0-32 14.3-32 32v256c0 17.7 14.3 32 32 32h144c17.7 0 32-14.3 32-32V672c0-17.7-14.3-32-32-32z\"}}]})(props);\n};\nexport function AiFillSketchCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M582.3 625.6l147.9-166.3h-63.4zm90-202.3h62.5l-92.1-115.1zm-274.7 36L512 684.5l114.4-225.2zM512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm286.7 380.2L515.8 762.3c-1 1.1-2.4 1.7-3.8 1.7s-2.8-.6-3.8-1.7L225.3 444.2a5.14 5.14 0 0 1-.2-6.6L365.6 262c1-1.2 2.4-1.9 4-1.9h284.6c1.6 0 3 .7 4 1.9l140.5 175.6a4.9 4.9 0 0 1 0 6.6zm-190.5-20.9L512 326.1l-96.2 97.2zM420.3 301.1l-23.1 89.8 88.8-89.8zm183.4 0H538l88.8 89.8zm-222.4 7.1l-92.1 115.1h62.5zm-87.5 151.1l147.9 166.3-84.5-166.3z\"}}]})(props);\n};\nexport function AiFillSketchSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M608.2 423.3L512 326.1l-96.2 97.2zm-25.9 202.3l147.9-166.3h-63.4zm90-202.3h62.5l-92.1-115.1zM880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-81.3 332.2L515.8 762.3c-1 1.1-2.4 1.7-3.8 1.7s-2.8-.6-3.8-1.7L225.3 444.2a5.14 5.14 0 0 1-.2-6.6L365.6 262c1-1.2 2.4-1.9 4-1.9h284.6c1.6 0 3 .7 4 1.9l140.5 175.6a4.9 4.9 0 0 1 0 6.6zm-401.1 15.1L512 684.5l114.4-225.2zm-16.3-151.1l-92.1 115.1h62.5zm-87.5 151.1l147.9 166.3-84.5-166.3zm126.5-158.2l-23.1 89.8 88.8-89.8zm183.4 0H538l88.8 89.8z\"}}]})(props);\n};\nexport function AiFillSkin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M870 126H663.8c-17.4 0-32.9 11.9-37 29.3C614.3 208.1 567 246 512 246s-102.3-37.9-114.8-90.7a37.93 37.93 0 0 0-37-29.3H154a44 44 0 0 0-44 44v252a44 44 0 0 0 44 44h75v388a44 44 0 0 0 44 44h478a44 44 0 0 0 44-44V466h75a44 44 0 0 0 44-44V170a44 44 0 0 0-44-44z\"}}]})(props);\n};\nexport function AiFillSkype (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M883.7 578.6c4.1-22.5 6.3-45.5 6.3-68.5 0-51-10-100.5-29.7-147-19-45-46.3-85.4-81-120.1a375.79 375.79 0 0 0-120.1-80.9c-46.6-19.7-96-29.7-147-29.7-24 0-48.1 2.3-71.5 6.8A225.1 225.1 0 0 0 335.6 113c-59.7 0-115.9 23.3-158.1 65.5A222.25 222.25 0 0 0 112 336.6c0 38 9.8 75.4 28.1 108.4-3.7 21.4-5.7 43.3-5.7 65.1 0 51 10 100.5 29.7 147 19 45 46.2 85.4 80.9 120.1 34.7 34.7 75.1 61.9 120.1 80.9 46.6 19.7 96 29.7 147 29.7 22.2 0 44.4-2 66.2-5.9 33.5 18.9 71.3 29 110 29 59.7 0 115.9-23.2 158.1-65.5 42.3-42.2 65.5-98.4 65.5-158.1.1-38-9.7-75.5-28.2-108.7zm-370 162.9c-134.2 0-194.2-66-194.2-115.4 0-25.4 18.7-43.1 44.5-43.1 57.4 0 42.6 82.5 149.7 82.5 54.9 0 85.2-29.8 85.2-60.3 0-18.3-9-38.7-45.2-47.6l-119.4-29.8c-96.1-24.1-113.6-76.1-113.6-124.9 0-101.4 95.5-139.5 185.2-139.5 82.6 0 180 45.7 180 106.5 0 26.1-22.6 41.2-48.4 41.2-49 0-40-67.8-138.7-67.8-49 0-76.1 22.2-76.1 53.9s38.7 41.8 72.3 49.5l88.4 19.6c96.8 21.6 121.3 78.1 121.3 131.3 0 82.3-63.3 143.9-191 143.9z\"}}]})(props);\n};\nexport function AiFillSlackCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zM361.5 580.2c0 27.8-22.5 50.4-50.3 50.4-13.3 0-26.1-5.3-35.6-14.8-9.4-9.5-14.7-22.3-14.7-35.6 0-27.8 22.5-50.4 50.3-50.4h50.3v50.4zm134 134.4c0 27.8-22.5 50.4-50.3 50.4-27.8 0-50.3-22.6-50.3-50.4V580.2c0-27.8 22.5-50.4 50.3-50.4 13.3 0 26.1 5.3 35.6 14.8s14.7 22.3 14.7 35.6v134.4zm-50.2-218.4h-134c-27.8 0-50.3-22.6-50.3-50.4 0-27.8 22.5-50.4 50.3-50.4h134c27.8 0 50.3 22.6 50.3 50.4-.1 27.9-22.6 50.4-50.3 50.4zm0-134.4c-13.3 0-26.1-5.3-35.6-14.8S395 324.8 395 311.4c0-27.8 22.5-50.4 50.3-50.4 27.8 0 50.3 22.6 50.3 50.4v50.4h-50.3zm83.7-50.4c0-27.8 22.5-50.4 50.3-50.4 27.8 0 50.3 22.6 50.3 50.4v134.4c0 27.8-22.5 50.4-50.3 50.4-27.8 0-50.3-22.6-50.3-50.4V311.4zM579.3 765c-27.8 0-50.3-22.6-50.3-50.4v-50.4h50.3c27.8 0 50.3 22.6 50.3 50.4 0 27.8-22.5 50.4-50.3 50.4zm134-134.4h-134c-13.3 0-26.1-5.3-35.6-14.8S529 593.6 529 580.2c0-27.8 22.5-50.4 50.3-50.4h134c27.8 0 50.3 22.6 50.3 50.4 0 27.8-22.5 50.4-50.3 50.4zm0-134.4H663v-50.4c0-27.8 22.5-50.4 50.3-50.4s50.3 22.6 50.3 50.4c0 27.8-22.5 50.4-50.3 50.4z\"}}]})(props);\n};\nexport function AiFillSlackSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM529 311.4c0-27.8 22.5-50.4 50.3-50.4 27.8 0 50.3 22.6 50.3 50.4v134.4c0 27.8-22.5 50.4-50.3 50.4-27.8 0-50.3-22.6-50.3-50.4V311.4zM361.5 580.2c0 27.8-22.5 50.4-50.3 50.4-13.3 0-26.1-5.3-35.6-14.8-9.4-9.5-14.7-22.3-14.7-35.6 0-27.8 22.5-50.4 50.3-50.4h50.3v50.4zm134 134.4c0 27.8-22.5 50.4-50.3 50.4-27.8 0-50.3-22.6-50.3-50.4V580.2c0-27.8 22.5-50.4 50.3-50.4 13.3 0 26.1 5.3 35.6 14.8s14.7 22.3 14.7 35.6v134.4zm-50.2-218.4h-134c-27.8 0-50.3-22.6-50.3-50.4 0-27.8 22.5-50.4 50.3-50.4h134c27.8 0 50.3 22.6 50.3 50.4-.1 27.9-22.6 50.4-50.3 50.4zm0-134.4c-13.3 0-26.1-5.3-35.6-14.8S395 324.8 395 311.4c0-27.8 22.5-50.4 50.3-50.4 27.8 0 50.3 22.6 50.3 50.4v50.4h-50.3zm134 403.2c-27.8 0-50.3-22.6-50.3-50.4v-50.4h50.3c27.8 0 50.3 22.6 50.3 50.4 0 27.8-22.5 50.4-50.3 50.4zm134-134.4h-134c-13.3 0-26.1-5.3-35.6-14.8-9.4-9.5-14.7-22.3-14.7-35.6 0-27.8 22.5-50.4 50.3-50.4h134c27.8 0 50.3 22.6 50.3 50.4 0 27.8-22.5 50.4-50.3 50.4zm0-134.4H663v-50.4c0-27.8 22.5-50.4 50.3-50.4s50.3 22.6 50.3 50.4c0 27.8-22.5 50.4-50.3 50.4z\"}}]})(props);\n};\nexport function AiFillSliders (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M904 296h-66v-96c0-4.4-3.6-8-8-8h-52c-4.4 0-8 3.6-8 8v96h-66c-4.4 0-8 3.6-8 8v416c0 4.4 3.6 8 8 8h66v96c0 4.4 3.6 8 8 8h52c4.4 0 8-3.6 8-8v-96h66c4.4 0 8-3.6 8-8V304c0-4.4-3.6-8-8-8zm-584-72h-66v-56c0-4.4-3.6-8-8-8h-52c-4.4 0-8 3.6-8 8v56h-66c-4.4 0-8 3.6-8 8v560c0 4.4 3.6 8 8 8h66v56c0 4.4 3.6 8 8 8h52c4.4 0 8-3.6 8-8v-56h66c4.4 0 8-3.6 8-8V232c0-4.4-3.6-8-8-8zm292 180h-66V232c0-4.4-3.6-8-8-8h-52c-4.4 0-8 3.6-8 8v172h-66c-4.4 0-8 3.6-8 8v200c0 4.4 3.6 8 8 8h66v172c0 4.4 3.6 8 8 8h52c4.4 0 8-3.6 8-8V620h66c4.4 0 8-3.6 8-8V412c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiFillSmile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zM288 421a48.01 48.01 0 0 1 96 0 48.01 48.01 0 0 1-96 0zm224 272c-85.5 0-155.6-67.3-160-151.6a8 8 0 0 1 8-8.4h48.1c4.2 0 7.8 3.2 8.1 7.4C420 589.9 461.5 629 512 629s92.1-39.1 95.8-88.6c.3-4.2 3.9-7.4 8.1-7.4H664a8 8 0 0 1 8 8.4C667.6 625.7 597.5 693 512 693zm176-224a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96z\"}}]})(props);\n};\nexport function AiFillSnippets (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 112H724V72c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v40H500V72c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v40H320c-17.7 0-32 14.3-32 32v120h-96c-17.7 0-32 14.3-32 32v632c0 17.7 14.3 32 32 32h512c17.7 0 32-14.3 32-32v-96h96c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM664 486H514V336h.2L664 485.8v.2zm128 274h-56V456L544 264H360v-80h68v32c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-32h152v32c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-32h68v576z\"}}]})(props);\n};\nexport function AiFillSound (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M892.1 737.8l-110.3-63.7a15.9 15.9 0 0 0-21.7 5.9l-19.9 34.5c-4.4 7.6-1.8 17.4 5.8 21.8L856.3 800a15.9 15.9 0 0 0 21.7-5.9l19.9-34.5c4.4-7.6 1.7-17.4-5.8-21.8zM760 344a15.9 15.9 0 0 0 21.7 5.9L892 286.2c7.6-4.4 10.2-14.2 5.8-21.8L878 230a15.9 15.9 0 0 0-21.7-5.9L746 287.8a15.99 15.99 0 0 0-5.8 21.8L760 344zm174 132H806c-8.8 0-16 7.2-16 16v40c0 8.8 7.2 16 16 16h128c8.8 0 16-7.2 16-16v-40c0-8.8-7.2-16-16-16zM625.9 115c-5.9 0-11.9 1.6-17.4 5.3L254 352H90c-8.8 0-16 7.2-16 16v288c0 8.8 7.2 16 16 16h164l354.5 231.7c5.5 3.6 11.6 5.3 17.4 5.3 16.7 0 32.1-13.3 32.1-32.1V147.1c0-18.8-15.4-32.1-32.1-32.1z\"}}]})(props);\n};\nexport function AiFillStar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M908.1 353.1l-253.9-36.9L540.7 86.1c-3.1-6.3-8.2-11.4-14.5-14.5-15.8-7.8-35-1.3-42.9 14.5L369.8 316.2l-253.9 36.9c-7 1-13.4 4.3-18.3 9.3a32.05 32.05 0 0 0 .6 45.3l183.7 179.1-43.4 252.9a31.95 31.95 0 0 0 46.4 33.7L512 754l227.1 119.4c6.2 3.3 13.4 4.4 20.3 3.2 17.4-3 29.1-19.5 26.1-36.9l-43.4-252.9 183.7-179.1c5-4.9 8.3-11.3 9.3-18.3 2.7-17.5-9.5-33.7-27-36.3z\"}}]})(props);\n};\nexport function AiFillStepBackward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M347.6 528.95l383.2 301.02c14.25 11.2 35.2 1.1 35.2-16.95V210.97c0-18.05-20.95-28.14-35.2-16.94L347.6 495.05a21.53 21.53 0 0 0 0 33.9M330 864h-64a8 8 0 0 1-8-8V168a8 8 0 0 1 8-8h64a8 8 0 0 1 8 8v688a8 8 0 0 1-8 8\"}}]})(props);\n};\nexport function AiFillStepForward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M676.4 528.95L293.2 829.97c-14.25 11.2-35.2 1.1-35.2-16.95V210.97c0-18.05 20.95-28.14 35.2-16.94l383.2 301.02a21.53 21.53 0 0 1 0 33.9M694 864h64a8 8 0 0 0 8-8V168a8 8 0 0 0-8-8h-64a8 8 0 0 0-8 8v688a8 8 0 0 0 8 8\"}}]})(props);\n};\nexport function AiFillStop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm234.8 736.5L223.5 277.2c16-19.7 34-37.7 53.7-53.7l523.3 523.3c-16 19.6-34 37.7-53.7 53.7z\"}}]})(props);\n};\nexport function AiFillSwitcher (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M752 240H144c-17.7 0-32 14.3-32 32v608c0 17.7 14.3 32 32 32h608c17.7 0 32-14.3 32-32V272c0-17.7-14.3-32-32-32zM596 606c0 4.4-3.6 8-8 8H308c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h280c4.4 0 8 3.6 8 8v48zm284-494H264c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h576v576c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V144c0-17.7-14.3-32-32-32z\"}}]})(props);\n};\nexport function AiFillTablet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M800 64H224c-35.3 0-64 28.7-64 64v768c0 35.3 28.7 64 64 64h576c35.3 0 64-28.7 64-64V128c0-35.3-28.7-64-64-64zM512 824c-22.1 0-40-17.9-40-40s17.9-40 40-40 40 17.9 40 40-17.9 40-40 40z\"}}]})(props);\n};\nexport function AiFillTag (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M938 458.8l-29.6-312.6c-1.5-16.2-14.4-29-30.6-30.6L565.2 86h-.4c-3.2 0-5.7 1-7.6 2.9L88.9 557.2a9.96 9.96 0 0 0 0 14.1l363.8 363.8c1.9 1.9 4.4 2.9 7.1 2.9s5.2-1 7.1-2.9l468.3-468.3c2-2.1 3-5 2.8-8zM699 387c-35.3 0-64-28.7-64-64s28.7-64 64-64 64 28.7 64 64-28.7 64-64 64z\"}}]})(props);\n};\nexport function AiFillTags (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M483.2 790.3L861.4 412c1.7-1.7 2.5-4 2.3-6.3l-25.5-301.4c-.7-7.8-6.8-13.9-14.6-14.6L522.2 64.3c-2.3-.2-4.7.6-6.3 2.3L137.7 444.8a8.03 8.03 0 0 0 0 11.3l334.2 334.2c3.1 3.2 8.2 3.2 11.3 0zm122.7-533.4c18.7-18.7 49.1-18.7 67.9 0 18.7 18.7 18.7 49.1 0 67.9-18.7 18.7-49.1 18.7-67.9 0-18.7-18.7-18.7-49.1 0-67.9zm283.8 282.9l-39.6-39.5a8.03 8.03 0 0 0-11.3 0l-362 361.3-237.6-237a8.03 8.03 0 0 0-11.3 0l-39.6 39.5a8.03 8.03 0 0 0 0 11.3l243.2 242.8 39.6 39.5c3.1 3.1 8.2 3.1 11.3 0l407.3-406.6c3.1-3.1 3.1-8.2 0-11.3z\"}}]})(props);\n};\nexport function AiFillTaobaoCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zM315.7 291.5c27.3 0 49.5 22.1 49.5 49.4s-22.1 49.4-49.5 49.4a49.4 49.4 0 1 1 0-98.8zM366.9 578c-13.6 42.3-10.2 26.7-64.4 144.5l-78.5-49s87.7-79.8 105.6-116.2c19.2-38.4-21.1-58.9-21.1-58.9l-60.2-37.5 32.7-50.2c45.4 33.7 48.7 36.6 79.2 67.2 23.8 23.9 20.7 56.8 6.7 100.1zm427.2 55c-15.3 143.8-202.4 90.3-202.4 90.3l10.2-41.1 43.3 9.3c80 5 72.3-64.9 72.3-64.9V423c.6-77.3-72.6-85.4-204.2-38.3l30.6 8.3c-2.5 9-12.5 23.2-25.2 38.6h176v35.6h-99.1v44.5h98.7v35.7h-98.7V622c14.9-4.8 28.6-11.5 40.5-20.5l-8.7-32.5 46.5-14.4 38.8 94.9-57.3 23.9-10.2-37.8c-25.6 19.5-78.8 48-171.8 45.4-99.2 2.6-73.7-112-73.7-112l2.5-1.3H472c-.5 14.7-6.6 38.7 1.7 51.8 6.8 10.8 24.2 12.6 35.3 13.1 1.3.1 2.6.1 3.9.1v-85.3h-101v-35.7h101v-44.5H487c-22.7 24.1-43.5 44.1-43.5 44.1l-30.6-26.7c21.7-22.9 43.3-59.1 56.8-83.2-10.9 4.4-22 9.2-33.6 14.2-11.2 14.3-24.2 29-38.7 43.5.5.8-50-28.4-50-28.4 52.2-44.4 81.4-139.9 81.4-139.9l72.5 20.4s-5.9 14-18.4 35.6c290.3-82.3 307.4 50.5 307.4 50.5s19.1 91.8 3.8 235.7z\"}}]})(props);\n};\nexport function AiFillTaobaoSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM315.7 291.5c27.3 0 49.5 22.1 49.5 49.4s-22.1 49.4-49.5 49.4a49.4 49.4 0 1 1 0-98.8zM366.9 578c-13.6 42.3-10.2 26.7-64.4 144.5l-78.5-49s87.7-79.8 105.6-116.2c19.2-38.4-21.1-58.9-21.1-58.9l-60.2-37.5 32.7-50.2c45.4 33.7 48.7 36.6 79.2 67.2 23.8 23.9 20.7 56.8 6.7 100.1zm427.2 55c-15.3 143.8-202.4 90.3-202.4 90.3l10.2-41.1 43.3 9.3c80 5 72.3-64.9 72.3-64.9V423c.6-77.3-72.6-85.4-204.2-38.3l30.6 8.3c-2.5 9-12.5 23.2-25.2 38.6h176v35.6h-99.1v44.5h98.7v35.7h-98.7V622c14.9-4.8 28.6-11.5 40.5-20.5l-8.7-32.5 46.5-14.4 38.8 94.9-57.3 23.9-10.2-37.8c-25.6 19.5-78.8 48-171.8 45.4-99.2 2.6-73.7-112-73.7-112l2.5-1.3H472c-.5 14.7-6.6 38.7 1.7 51.8 6.8 10.8 24.2 12.6 35.3 13.1 1.3.1 2.6.1 3.9.1v-85.3h-101v-35.7h101v-44.5H487c-22.7 24.1-43.5 44.1-43.5 44.1l-30.6-26.7c21.7-22.9 43.3-59.1 56.8-83.2-10.9 4.4-22 9.2-33.6 14.2-11.2 14.3-24.2 29-38.7 43.5.5.8-50-28.4-50-28.4 52.2-44.4 81.4-139.9 81.4-139.9l72.5 20.4s-5.9 14-18.4 35.6c290.3-82.3 307.4 50.5 307.4 50.5s19.1 91.8 3.8 235.7z\"}}]})(props);\n};\nexport function AiFillThunderbolt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M848 359.3H627.7L825.8 109c4.1-5.3.4-13-6.3-13H436c-2.8 0-5.5 1.5-6.9 4L170 547.5c-3.1 5.3.7 12 6.9 12h174.4l-89.4 357.6c-1.9 7.8 7.5 13.3 13.3 7.7L853.5 373c5.2-4.9 1.7-13.7-5.5-13.7z\"}}]})(props);\n};\nexport function AiFillTool (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M865.3 244.7c-.3-.3-61.1 59.8-182.1 180.6l-84.9-84.9 180.9-180.9c-95.2-57.3-217.5-42.6-296.8 36.7A244.42 244.42 0 0 0 419 432l1.8 6.7-283.5 283.4c-6.2 6.2-6.2 16.4 0 22.6l141.4 141.4c6.2 6.2 16.4 6.2 22.6 0l283.3-283.3 6.7 1.8c83.7 22.3 173.6-.9 236-63.3 79.4-79.3 94.1-201.6 38-296.6z\"}}]})(props);\n};\nexport function AiFillTrademarkCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm164.7 660.2c-1.1.5-2.3.8-3.5.8h-62c-3.1 0-5.9-1.8-7.2-4.6l-74.6-159.2h-88.7V717c0 4.4-3.6 8-8 8H378c-4.4 0-8-3.6-8-8V307c0-4.4 3.6-8 8-8h155.6c98.8 0 144.2 59.9 144.2 131.1 0 70.2-43.6 106.4-78.4 119.2l80.8 164.2c2.1 3.9.4 8.7-3.5 10.7zM523.9 357h-83.4v148H522c53 0 82.8-25.6 82.8-72.4 0-50.3-32.9-75.6-80.9-75.6z\"}}]})(props);\n};\nexport function AiFillTrophy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M868 160h-92v-40c0-4.4-3.6-8-8-8H256c-4.4 0-8 3.6-8 8v40h-92a44 44 0 0 0-44 44v148c0 81.7 60 149.6 138.2 162C265.6 630.2 359 721.8 476 734.5v105.2H280c-17.7 0-32 14.3-32 32V904c0 4.4 3.6 8 8 8h512c4.4 0 8-3.6 8-8v-32.3c0-17.7-14.3-32-32-32H548V734.5C665 721.8 758.4 630.2 773.8 514 852 501.6 912 433.7 912 352V204a44 44 0 0 0-44-44zM248 439.6c-37.1-11.9-64-46.7-64-87.6V232h64v207.6zM840 352c0 41-26.9 75.8-64 87.6V232h64v120z\"}}]})(props);\n};\nexport function AiFillTwitterCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm215.3 337.7c.3 4.7.3 9.6.3 14.4 0 146.8-111.8 315.9-316.1 315.9-63 0-121.4-18.3-170.6-49.8 9 1 17.6 1.4 26.8 1.4 52 0 99.8-17.6 137.9-47.4-48.8-1-89.8-33-103.8-77 17.1 2.5 32.5 2.5 50.1-2a111 111 0 0 1-88.9-109v-1.4c14.7 8.3 32 13.4 50.1 14.1a111.13 111.13 0 0 1-49.5-92.4c0-20.7 5.4-39.6 15.1-56a315.28 315.28 0 0 0 229 116.1C492 353.1 548.4 292 616.2 292c32 0 60.8 13.4 81.1 35 25.1-4.7 49.1-14.1 70.5-26.7-8.3 25.7-25.7 47.4-48.8 61.1 22.4-2.4 44-8.6 64-17.3-15.1 22.2-34 41.9-55.7 57.6z\"}}]})(props);\n};\nexport function AiFillTwitterSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM727.3 401.7c.3 4.7.3 9.6.3 14.4 0 146.8-111.8 315.9-316.1 315.9-63 0-121.4-18.3-170.6-49.8 9 1 17.6 1.4 26.8 1.4 52 0 99.8-17.6 137.9-47.4-48.8-1-89.8-33-103.8-77 17.1 2.5 32.5 2.5 50.1-2a111 111 0 0 1-88.9-109v-1.4c14.7 8.3 32 13.4 50.1 14.1a111.13 111.13 0 0 1-49.5-92.4c0-20.7 5.4-39.6 15.1-56a315.28 315.28 0 0 0 229 116.1C492 353.1 548.4 292 616.2 292c32 0 60.8 13.4 81.1 35 25.1-4.7 49.1-14.1 70.5-26.7-8.3 25.7-25.7 47.4-48.8 61.1 22.4-2.4 44-8.6 64-17.3-15.1 22.2-34 41.9-55.7 57.6z\"}}]})(props);\n};\nexport function AiFillUnlock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 464H332V240c0-30.9 25.1-56 56-56h248c30.9 0 56 25.1 56 56v68c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-68c0-70.7-57.3-128-128-128H388c-70.7 0-128 57.3-128 128v224h-68c-17.7 0-32 14.3-32 32v384c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V496c0-17.7-14.3-32-32-32zM540 701v53c0 4.4-3.6 8-8 8h-40c-4.4 0-8-3.6-8-8v-53a48.01 48.01 0 1 1 56 0z\"}}]})(props);\n};\nexport function AiFillUpCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm178 555h-46.9c-10.2 0-19.9-4.9-25.9-13.2L512 460.4 406.8 605.8c-6 8.3-15.6 13.2-25.9 13.2H334c-6.5 0-10.3-7.4-6.5-12.7l178-246c3.2-4.4 9.7-4.4 12.9 0l178 246c3.9 5.3.1 12.7-6.4 12.7z\"}}]})(props);\n};\nexport function AiFillUpSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM690 624h-46.9c-10.2 0-19.9-4.9-25.9-13.2L512 465.4 406.8 610.8c-6 8.3-15.6 13.2-25.9 13.2H334c-6.5 0-10.3-7.4-6.5-12.7l178-246c3.2-4.4 9.7-4.4 12.9 0l178 246c3.9 5.3.1 12.7-6.4 12.7z\"}}]})(props);\n};\nexport function AiFillUsb (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M408 312h48c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8zm352 120V144c0-17.7-14.3-32-32-32H296c-17.7 0-32 14.3-32 32v288c-66.2 0-120 52.1-120 116v356c0 4.4 3.6 8 8 8h720c4.4 0 8-3.6 8-8V548c0-63.9-53.8-116-120-116zm-72 0H336V184h352v248zM568 312h48c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiFillVideoCamera (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M912 302.3L784 376V224c0-35.3-28.7-64-64-64H128c-35.3 0-64 28.7-64 64v576c0 35.3 28.7 64 64 64h592c35.3 0 64-28.7 64-64V648l128 73.7c21.3 12.3 48-3.1 48-27.6V330c0-24.6-26.7-40-48-27.7zM328 352c0 4.4-3.6 8-8 8H208c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h112c4.4 0 8 3.6 8 8v48zm560 273l-104-59.8V458.9L888 399v226z\"}}]})(props);\n};\nexport function AiFillWallet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-32 464H528V448h320v128zm-268-64a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}}]})(props);\n};\nexport function AiFillWarning (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M955.7 856l-416-720c-6.2-10.7-16.9-16-27.7-16s-21.6 5.3-27.7 16l-416 720C56 877.4 71.4 904 96 904h832c24.6 0 40-26.6 27.7-48zM480 416c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v184c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V416zm32 352a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96z\"}}]})(props);\n};\nexport function AiFillWechat (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M690.1 377.4c5.9 0 11.8.2 17.6.5-24.4-128.7-158.3-227.1-319.9-227.1C209 150.8 64 271.4 64 420.2c0 81.1 43.6 154.2 111.9 203.6a21.5 21.5 0 0 1 9.1 17.6c0 2.4-.5 4.6-1.1 6.9-5.5 20.3-14.2 52.8-14.6 54.3-.7 2.6-1.7 5.2-1.7 7.9 0 5.9 4.8 10.8 10.8 10.8 2.3 0 4.2-.9 6.2-2l70.9-40.9c5.3-3.1 11-5 17.2-5 3.2 0 6.4.5 9.5 1.4 33.1 9.5 68.8 14.8 105.7 14.8 6 0 11.9-.1 17.8-.4-7.1-21-10.9-43.1-10.9-66 0-135.8 132.2-245.8 295.3-245.8zm-194.3-86.5c23.8 0 43.2 19.3 43.2 43.1s-19.3 43.1-43.2 43.1c-23.8 0-43.2-19.3-43.2-43.1s19.4-43.1 43.2-43.1zm-215.9 86.2c-23.8 0-43.2-19.3-43.2-43.1s19.3-43.1 43.2-43.1 43.2 19.3 43.2 43.1-19.4 43.1-43.2 43.1zm586.8 415.6c56.9-41.2 93.2-102 93.2-169.7 0-124-120.8-224.5-269.9-224.5-149 0-269.9 100.5-269.9 224.5S540.9 847.5 690 847.5c30.8 0 60.6-4.4 88.1-12.3 2.6-.8 5.2-1.2 7.9-1.2 5.2 0 9.9 1.6 14.3 4.1l59.1 34c1.7 1 3.3 1.7 5.2 1.7a9 9 0 0 0 6.4-2.6 9 9 0 0 0 2.6-6.4c0-2.2-.9-4.4-1.4-6.6-.3-1.2-7.6-28.3-12.2-45.3-.5-1.9-.9-3.8-.9-5.7.1-5.9 3.1-11.2 7.6-14.5zM600.2 587.2c-19.9 0-36-16.1-36-35.9 0-19.8 16.1-35.9 36-35.9s36 16.1 36 35.9c0 19.8-16.2 35.9-36 35.9zm179.9 0c-19.9 0-36-16.1-36-35.9 0-19.8 16.1-35.9 36-35.9s36 16.1 36 35.9a36.08 36.08 0 0 1-36 35.9z\"}}]})(props);\n};\nexport function AiFillWeiboCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm-44.4 672C353.1 736 236 680.4 236 588.9c0-47.8 30.2-103.1 82.3-155.3 69.5-69.6 150.6-101.4 181.1-70.8 13.5 13.5 14.8 36.8 6.1 64.6-4.5 14 13.1 6.3 13.1 6.3 56.2-23.6 105.2-25 123.1.7 9.6 13.7 8.6 32.8-.2 55.1-4.1 10.2 1.3 11.8 9 14.1 31.7 9.8 66.9 33.6 66.9 75.5.2 69.5-99.7 156.9-249.8 156.9zm207.3-290.8a34.9 34.9 0 0 0-7.2-34.1 34.68 34.68 0 0 0-33.1-10.7 18.24 18.24 0 0 1-7.6-35.7c24.1-5.1 50.1 2.3 67.7 21.9 17.7 19.6 22.4 46.3 14.9 69.8a18.13 18.13 0 0 1-22.9 11.7 18.18 18.18 0 0 1-11.8-22.9zm106 34.3s0 .1 0 0a21.1 21.1 0 0 1-26.6 13.7 21.19 21.19 0 0 1-13.6-26.7c11-34.2 4-73.2-21.7-101.8a104.04 104.04 0 0 0-98.9-32.1 21.14 21.14 0 0 1-25.1-16.3 21.07 21.07 0 0 1 16.2-25.1c49.4-10.5 102.8 4.8 139.1 45.1 36.3 40.2 46.1 95.1 30.6 143.2zm-334.5 6.1c-91.4 9-160.7 65.1-154.7 125.2 5.9 60.1 84.8 101.5 176.2 92.5 91.4-9.1 160.7-65.1 154.7-125.3-5.9-60.1-84.8-101.5-176.2-92.4zm80.2 141.7c-18.7 42.3-72.3 64.8-117.8 50.1-43.9-14.2-62.5-57.7-43.3-96.8 18.9-38.4 68-60.1 111.5-48.8 45 11.7 68 54.2 49.6 95.5zm-93-32.2c-14.2-5.9-32.4.2-41.2 13.9-8.8 13.8-4.7 30.2 9.3 36.6 14.3 6.5 33.2.3 42-13.8 8.8-14.3 4.2-30.6-10.1-36.7zm34.9-14.5c-5.4-2.2-12.2.5-15.4 5.8-3.1 5.4-1.4 11.5 4.1 13.8 5.5 2.3 12.6-.3 15.8-5.8 3-5.6 1-11.8-4.5-13.8z\"}}]})(props);\n};\nexport function AiFillWeiboSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M433.6 595.1c-14.2-5.9-32.4.2-41.2 13.9-8.8 13.8-4.7 30.2 9.3 36.6 14.3 6.5 33.2.3 42-13.8 8.8-14.3 4.2-30.6-10.1-36.7zM880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM467.6 736C353.1 736 236 680.4 236 588.9c0-47.8 30.2-103.1 82.3-155.3 69.5-69.6 150.6-101.4 181.1-70.8 13.5 13.5 14.8 36.8 6.1 64.6-4.5 14 13.1 6.3 13.1 6.3 56.2-23.6 105.2-25 123.1.7 9.6 13.7 8.6 32.8-.2 55.1-4.1 10.2 1.3 11.8 9 14.1 31.7 9.8 66.9 33.6 66.9 75.5.2 69.5-99.7 156.9-249.8 156.9zm207.3-290.8a34.9 34.9 0 0 0-7.2-34.1 34.68 34.68 0 0 0-33.1-10.7 18.24 18.24 0 0 1-7.6-35.7c24.1-5.1 50.1 2.3 67.7 21.9 17.7 19.6 22.4 46.3 14.9 69.8a18.13 18.13 0 0 1-22.9 11.7 18.18 18.18 0 0 1-11.8-22.9zm106 34.3s0 .1 0 0a21.1 21.1 0 0 1-26.6 13.7 21.19 21.19 0 0 1-13.6-26.7c11-34.2 4-73.2-21.7-101.8a104.04 104.04 0 0 0-98.9-32.1 21.14 21.14 0 0 1-25.1-16.3 21.07 21.07 0 0 1 16.2-25.1c49.4-10.5 102.8 4.8 139.1 45.1 36.3 40.2 46.1 95.1 30.6 143.2zm-334.5 6.1c-91.4 9-160.7 65.1-154.7 125.2 5.9 60.1 84.8 101.5 176.2 92.5 91.4-9.1 160.7-65.1 154.7-125.3-5.9-60.1-84.8-101.5-176.2-92.4zm80.2 141.7c-18.7 42.3-72.3 64.8-117.8 50.1-43.9-14.2-62.5-57.7-43.3-96.8 18.9-38.4 68-60.1 111.5-48.8 45 11.7 68 54.2 49.6 95.5zm-58.1-46.7c-5.4-2.2-12.2.5-15.4 5.8-3.1 5.4-1.4 11.5 4.1 13.8 5.5 2.3 12.6-.3 15.8-5.8 3-5.6 1-11.8-4.5-13.8z\"}}]})(props);\n};\nexport function AiFillWindows (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M523.8 191.4v288.9h382V128.1zm0 642.2l382 62.2v-352h-382zM120.1 480.2H443V201.9l-322.9 53.5zm0 290.4L443 823.2V543.8H120.1z\"}}]})(props);\n};\nexport function AiFillYahoo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M937.3 231H824.7c-15.5 0-27.7 12.6-27.1 28.1l13.1 366h84.4l65.4-366.4c2.7-15.2-7.8-27.7-23.2-27.7zm-77.4 450.4h-14.1c-27.1 0-49.2 22.2-49.2 49.3v14.1c0 27.1 22.2 49.3 49.2 49.3h14.1c27.1 0 49.2-22.2 49.2-49.3v-14.1c0-27.1-22.2-49.3-49.2-49.3zM402.6 231C216.2 231 65 357 65 512.5S216.2 794 402.6 794s337.6-126 337.6-281.5S589.1 231 402.6 231zm225.2 225.2h-65.3L458.9 559.8v65.3h84.4v56.3H318.2v-56.3h84.4v-65.3L242.9 399.9h-37v-56.3h168.5v56.3h-37l93.4 93.5 28.1-28.1V400h168.8v56.2z\"}}]})(props);\n};\nexport function AiFillYoutube (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M941.3 296.1a112.3 112.3 0 0 0-79.2-79.3C792.2 198 512 198 512 198s-280.2 0-350.1 18.7A112.12 112.12 0 0 0 82.7 296C64 366 64 512 64 512s0 146 18.7 215.9c10.3 38.6 40.7 69 79.2 79.3C231.8 826 512 826 512 826s280.2 0 350.1-18.8c38.6-10.3 68.9-40.7 79.2-79.3C960 658 960 512 960 512s0-146-18.7-215.9zM423 646V378l232 133-232 135z\"}}]})(props);\n};\nexport function AiFillYuque (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 370.6c-9.9-39.4 9.9-102.2 73.4-124.4l-67.9-3.6s-25.7-90-143.6-98c-117.9-8.1-195-3-195-3s87.4 55.6 52.4 154.7c-25.6 52.5-65.8 95.6-108.8 144.7-1.3 1.3-2.5 2.6-3.5 3.7C319.4 605 96 860 96 860c245.9 64.4 410.7-6.3 508.2-91.1 20.5-.2 35.9-.3 46.3-.3 135.8 0 250.6-117.6 245.9-248.4-3.2-89.9-31.9-110.2-41.8-149.6z\"}}]})(props);\n};\nexport function AiFillZhihuCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm-90.7 477.8l-.1 1.5c-1.5 20.4-6.3 43.9-12.9 67.6l24-18.1 71 80.7c9.2 33-3.3 63.1-3.3 63.1l-95.7-111.9v-.1c-8.9 29-20.1 57.3-33.3 84.7-22.6 45.7-55.2 54.7-89.5 57.7-34.4 3-23.3-5.3-23.3-5.3 68-55.5 78-87.8 96.8-123.1 11.9-22.3 20.4-64.3 25.3-96.8H264.1s4.8-31.2 19.2-41.7h101.6c.6-15.3-1.3-102.8-2-131.4h-49.4c-9.2 45-41 56.7-48.1 60.1-7 3.4-23.6 7.1-21.1 0 2.6-7.1 27-46.2 43.2-110.7 16.3-64.6 63.9-62 63.9-62-12.8 22.5-22.4 73.6-22.4 73.6h159.7c10.1 0 10.6 39 10.6 39h-90.8c-.7 22.7-2.8 83.8-5 131.4H519s12.2 15.4 12.2 41.7H421.3zm346.5 167h-87.6l-69.5 46.6-16.4-46.6h-40.1V321.5h213.6v387.3zM408.2 611s0-.1 0 0zm216 94.3l56.8-38.1h45.6-.1V364.7H596.7v302.5h14.1z\"}}]})(props);\n};\nexport function AiFillZhihuSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM432.3 592.8l71 80.7c9.2 33-3.3 63.1-3.3 63.1l-95.7-111.9v-.1c-8.9 29-20.1 57.3-33.3 84.7-22.6 45.7-55.2 54.7-89.5 57.7-34.4 3-23.3-5.3-23.3-5.3 68-55.5 78-87.8 96.8-123.1 11.9-22.3 20.4-64.3 25.3-96.8H264.1s4.8-31.2 19.2-41.7h101.6c.6-15.3-1.3-102.8-2-131.4h-49.4c-9.2 45-41 56.7-48.1 60.1-7 3.4-23.6 7.1-21.1 0 2.6-7.1 27-46.2 43.2-110.7 16.3-64.6 63.9-62 63.9-62-12.8 22.5-22.4 73.6-22.4 73.6h159.7c10.1 0 10.6 39 10.6 39h-90.8c-.7 22.7-2.8 83.8-5 131.4H519s12.2 15.4 12.2 41.7h-110l-.1 1.5c-1.5 20.4-6.3 43.9-12.9 67.6l24.1-18.1zm335.5 116h-87.6l-69.5 46.6-16.4-46.6h-40.1V321.5h213.6v387.3zM408.2 611s0-.1 0 0zm216 94.3l56.8-38.1h45.6-.1V364.7H596.7v302.5h14.1z\"}}]})(props);\n};\nexport function AiOutlineAccountBook (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 184H712v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H384v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H144c-17.7 0-32 14.3-32 32v664c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V216c0-17.7-14.3-32-32-32zm-40 656H184V256h128v48c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-48h256v48c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-48h128v584zM639.5 414h-45c-3 0-5.8 1.7-7.1 4.4L514 563.8h-2.8l-73.4-145.4a8 8 0 0 0-7.1-4.4h-46c-1.3 0-2.7.3-3.8 1-3.9 2.1-5.3 7-3.2 10.9l89.3 164h-48.6c-4.4 0-8 3.6-8 8v21.3c0 4.4 3.6 8 8 8h65.1v33.7h-65.1c-4.4 0-8 3.6-8 8v21.3c0 4.4 3.6 8 8 8h65.1V752c0 4.4 3.6 8 8 8h41.3c4.4 0 8-3.6 8-8v-53.8h65.4c4.4 0 8-3.6 8-8v-21.3c0-4.4-3.6-8-8-8h-65.4v-33.7h65.4c4.4 0 8-3.6 8-8v-21.3c0-4.4-3.6-8-8-8h-49.1l89.3-164.1c.6-1.2 1-2.5 1-3.8.1-4.4-3.4-8-7.9-8z\"}}]})(props);\n};\nexport function AiOutlineAim (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683657482\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M952 474H829.8C812.5 327.6 696.4 211.5 550 194.2V72c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8v122.2C327.6 211.5 211.5 327.6 194.2 474H72c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h122.2C211.5 696.4 327.6 812.5 474 829.8V952c0 4.4 3.6 8 8 8h60c4.4 0 8-3.6 8-8V829.8C696.4 812.5 812.5 696.4 829.8 550H952c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8zM512 756c-134.8 0-244-109.2-244-244s109.2-244 244-244 244 109.2 244 244-109.2 244-244 244z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 392c-32.1 0-62.1 12.4-84.8 35.2-22.7 22.7-35.2 52.7-35.2 84.8s12.5 62.1 35.2 84.8C449.9 619.4 480 632 512 632s62.1-12.5 84.8-35.2C619.4 574.1 632 544 632 512s-12.5-62.1-35.2-84.8C574.1 404.4 544.1 392 512 392z\"}}]})(props);\n};\nexport function AiOutlineAlert (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M193 796c0 17.7 14.3 32 32 32h574c17.7 0 32-14.3 32-32V563c0-176.2-142.8-319-319-319S193 386.8 193 563v233zm72-233c0-136.4 110.6-247 247-247s247 110.6 247 247v193H404V585c0-5.5-4.5-10-10-10h-44c-5.5 0-10 4.5-10 10v171h-75V563zm-48.1-252.5l39.6-39.6c3.1-3.1 3.1-8.2 0-11.3l-67.9-67.9a8.03 8.03 0 0 0-11.3 0l-39.6 39.6a8.03 8.03 0 0 0 0 11.3l67.9 67.9c3.1 3.1 8.1 3.1 11.3 0zm669.6-79.2l-39.6-39.6a8.03 8.03 0 0 0-11.3 0l-67.9 67.9a8.03 8.03 0 0 0 0 11.3l39.6 39.6c3.1 3.1 8.2 3.1 11.3 0l67.9-67.9c3.1-3.2 3.1-8.2 0-11.3zM832 892H192c-17.7 0-32 14.3-32 32v24c0 4.4 3.6 8 8 8h688c4.4 0 8-3.6 8-8v-24c0-17.7-14.3-32-32-32zM484 180h56c4.4 0 8-3.6 8-8V76c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v96c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlineAlibaba (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M602.9 669.8c-37.2 2.6-33.6-17.3-11.5-46.2 50.4-67.2 143.7-158.5 147.9-225.2 5.8-86.6-81.3-113.4-171-113.4-62.4 1.6-127 18.9-171 34.6-151.6 53.5-246.6 137.5-306.9 232-62.4 93.4-43 183.2 91.8 185.8 101.8-4.2 170.5-32.5 239.7-68.2.5 0-192.5 55.1-263.9 14.7-7.9-4.2-15.7-10-17.8-26.2 0-33.1 54.6-67.7 86.6-78.7v-56.7c64.5 22.6 140.6 16.3 205.7-32 2.1 5.8 4.2 13.1 3.7 21h11c2.6-22.6-12.6-44.6-37.8-46.2 7.3 5.8 12.6 10.5 15.2 14.7l-1 1-.5.5c-83.9 58.8-165.3 31.5-173.1 29.9l46.7-45.7-13.1-33.1c92.9-32.5 169.5-56.2 296.9-78.7l-28.5-23 14.7-8.9c75.5 21 126.4 36.7 123.8 76.6-1 6.8-3.7 14.7-7.9 23.1C660.1 466.1 594 538 567.2 569c-17.3 20.5-34.6 39.4-46.7 58.3-13.6 19.4-20.5 37.3-21 53.5 2.6 131.8 391.4-61.9 468-112.9-111.7 47.8-232.9 93.5-364.6 101.9zm85-302.9c2.8 5.2 4.1 11.6 4.1 19.1-.1-6.8-1.4-13.3-4.1-19.1z\"}}]})(props);\n};\nexport function AiOutlineAlignCenter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M264 230h496c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H264c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm496 424c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H264c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h496zm144 140H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-424H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineAlignLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M120 230h496c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm0 424h496c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm784 140H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-424H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineAlignRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M904 158H408c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h496c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 424H408c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h496c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 212H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-424H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineAlipayCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M308.6 545.7c-19.8 2-57.1 10.7-77.4 28.6-61 53-24.5 150 99 150 71.8 0 143.5-45.7 199.8-119-80.2-38.9-148.1-66.8-221.4-59.6zm460.5 67c100.1 33.4 154.7 43 166.7 44.8A445.9 445.9 0 0 0 960 512c0-247.4-200.6-448-448-448S64 264.6 64 512s200.6 448 448 448c155.9 0 293.2-79.7 373.5-200.5-75.6-29.8-213.6-85-286.8-120.1-69.9 85.7-160.1 137.8-253.7 137.8-158.4 0-212.1-138.1-137.2-229 16.3-19.8 44.2-38.7 87.3-49.4 67.5-16.5 175 10.3 275.7 43.4 18.1-33.3 33.4-69.9 44.7-108.9H305.1V402h160v-56.2H271.3v-31.3h193.8v-80.1s0-13.5 13.7-13.5H557v93.6h191.7v31.3H557.1V402h156.4c-15 61.1-37.7 117.4-66.2 166.8 47.5 17.1 90.1 33.3 121.8 43.9z\"}}]})(props);\n};\nexport function AiOutlineAlipay (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M789 610.3c-38.7-12.9-90.7-32.7-148.5-53.6 34.8-60.3 62.5-129 80.7-203.6H530.5v-68.6h233.6v-38.3H530.5V132h-95.4c-16.7 0-16.7 16.5-16.7 16.5v97.8H182.2v38.3h236.3v68.6H223.4v38.3h378.4a667.18 667.18 0 0 1-54.5 132.9c-122.8-40.4-253.8-73.2-336.1-53-52.6 13-86.5 36.1-106.5 60.3-91.4 111-25.9 279.6 167.2 279.6C386 811.2 496 747.6 581.2 643 708.3 704 960 808.7 960 808.7V659.4s-31.6-2.5-171-49.1zM253.9 746.6c-150.5 0-195-118.3-120.6-183.1 24.8-21.9 70.2-32.6 94.4-35 89.4-8.8 172.2 25.2 269.9 72.8-68.8 89.5-156.3 145.3-243.7 145.3z\"}}]})(props);\n};\nexport function AiOutlineAliwangwang (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M868.2 377.4c-18.9-45.1-46.3-85.6-81.2-120.6a377.26 377.26 0 0 0-120.5-81.2A375.65 375.65 0 0 0 519 145.8c-41.9 0-82.9 6.7-121.9 20C306 123.3 200.8 120 170.6 120c-2.2 0-7.4 0-9.4.2-11.9.4-22.8 6.5-29.2 16.4-6.5 9.9-7.7 22.4-3.4 33.5l64.3 161.6a378.59 378.59 0 0 0-52.8 193.2c0 51.4 10 101 29.8 147.6 18.9 45 46.2 85.6 81.2 120.5 34.7 34.8 75.4 62.1 120.5 81.2C418.3 894 467.9 904 519 904c51.3 0 100.9-10.1 147.7-29.8 44.9-18.9 85.5-46.3 120.4-81.2 34.7-34.8 62.1-75.4 81.2-120.6a376.5 376.5 0 0 0 29.8-147.6c-.2-51.2-10.1-100.8-29.9-147.4zm-66.4 266.5a307.08 307.08 0 0 1-65.9 98c-28.4 28.5-61.3 50.7-97.7 65.9h-.1c-38 16-78.3 24.2-119.9 24.2a306.51 306.51 0 0 1-217.5-90.2c-28.4-28.5-50.6-61.4-65.8-97.8v-.1c-16-37.8-24.1-78.2-24.1-119.9 0-55.4 14.8-109.7 42.8-157l13.2-22.1-9.5-23.9L206 192c14.9.6 35.9 2.1 59.7 5.6 43.8 6.5 82.5 17.5 114.9 32.6l19 8.9 19.9-6.8c31.5-10.8 64.8-16.2 98.9-16.2a306.51 306.51 0 0 1 217.5 90.2c28.4 28.5 50.6 61.4 65.8 97.8l.1.1.1.1c16 37.6 24.1 78 24.2 119.8-.1 41.7-8.3 82-24.3 119.8zM681.1 364.2c-20.4 0-37.1 16.7-37.1 37.1v55.1c0 20.4 16.6 37.1 37.1 37.1s37.1-16.7 37.1-37.1v-55.1c0-20.5-16.7-37.1-37.1-37.1zm-175.2 0c-20.5 0-37.1 16.7-37.1 37.1v55.1c0 20.4 16.7 37.1 37.1 37.1 20.5 0 37.1-16.7 37.1-37.1v-55.1c0-20.5-16.7-37.1-37.1-37.1z\"}}]})(props);\n};\nexport function AiOutlineAliyun (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M959.2 383.9c-.3-82.1-66.9-148.6-149.1-148.6H575.9l21.6 85.2 201 43.7a42.58 42.58 0 0 1 32.9 39.7c.1.5.1 216.1 0 216.6a42.58 42.58 0 0 1-32.9 39.7l-201 43.7-21.6 85.3h234.2c82.1 0 148.8-66.5 149.1-148.6V383.9zM225.5 660.4a42.58 42.58 0 0 1-32.9-39.7c-.1-.6-.1-216.1 0-216.6.8-19.4 14.6-35.5 32.9-39.7l201-43.7 21.6-85.2H213.8c-82.1 0-148.8 66.4-149.1 148.6V641c.3 82.1 67 148.6 149.1 148.6H448l-21.6-85.3-200.9-43.9zm200.9-158.8h171v21.3h-171z\"}}]})(props);\n};\nexport function AiOutlineAmazon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M825 768.9c-3.3-.9-7.3-.4-11.9 1.3-61.6 28.2-121.5 48.3-179.7 60.2C507.7 856 385.2 842.6 266 790.3c-33.1-14.6-79.1-39.2-138-74a9.36 9.36 0 0 0-5.3-2c-2-.1-3.7.1-5.3.9-1.6.8-2.8 1.8-3.7 3.1-.9 1.3-1.1 3.1-.4 5.4.6 2.2 2.1 4.7 4.6 7.4 10.4 12.2 23.3 25.2 38.6 39s35.6 29.4 60.9 46.8c25.3 17.4 51.8 32.9 79.3 46.4 27.6 13.5 59.6 24.9 96.1 34.1s73 13.8 109.4 13.8c36.2 0 71.4-3.7 105.5-10.9 34.2-7.3 63-15.9 86.5-25.9 23.4-9.9 45-21 64.8-33 19.8-12 34.4-22.2 43.9-30.3 9.5-8.2 16.3-14.6 20.2-19.4 4.6-5.7 6.9-10.6 6.9-14.9.1-4.5-1.7-7.1-5-7.9zM527.4 348.1c-15.2 1.3-33.5 4.1-55 8.3-21.5 4.1-41.4 9.3-59.8 15.4s-37.2 14.6-56.3 25.4c-19.2 10.8-35.5 23.2-49 37s-24.5 31.1-33.1 52c-8.6 20.8-12.9 43.7-12.9 68.7 0 27.1 4.7 51.2 14.3 72.5 9.5 21.3 22.2 38 38.2 50.4 15.9 12.4 34 22.1 54 29.2 20 7.1 41.2 10.3 63.2 9.4 22-.9 43.5-4.3 64.4-10.3 20.8-5.9 40.4-15.4 58.6-28.3 18.2-12.9 33.1-28.2 44.8-45.7 4.3 6.6 8.1 11.5 11.5 14.7l8.7 8.9c5.8 5.9 14.7 14.6 26.7 26.1 11.9 11.5 24.1 22.7 36.3 33.7l104.4-99.9-6-4.9c-4.3-3.3-9.4-8-15.2-14.3-5.8-6.2-11.6-13.1-17.2-20.5-5.7-7.4-10.6-16.1-14.7-25.9-4.1-9.8-6.2-19.3-6.2-28.5V258.7c0-10.1-1.9-21-5.7-32.8-3.9-11.7-10.7-24.5-20.7-38.3-10-13.8-22.4-26.2-37.2-37-14.9-10.8-34.7-20-59.6-27.4-24.8-7.4-52.6-11.1-83.2-11.1-31.3 0-60.4 3.7-87.6 10.9-27.1 7.3-50.3 17-69.7 29.2-19.3 12.2-35.9 26.3-49.7 42.4-13.8 16.1-24.1 32.9-30.8 50.4-6.7 17.5-10.1 35.2-10.1 53.1L408 310c5.5-16.4 12.9-30.6 22-42.8 9.2-12.2 17.9-21 25.8-26.5 8-5.5 16.6-9.9 25.7-13.2 9.2-3.3 15.4-5 18.6-5.4 3.2-.3 5.7-.4 7.6-.4 26.7 0 45.2 7.9 55.6 23.6 6.5 9.5 9.7 23.9 9.7 43.3v56.6c-15.2.6-30.4 1.6-45.6 2.9zM573.1 500c0 16.6-2.2 31.7-6.5 45-9.2 29.1-26.7 47.4-52.4 54.8-22.4 6.6-43.7 3.3-63.9-9.8-21.5-14-32.2-33.8-32.2-59.3 0-19.9 5-36.9 15-51.1 10-14.1 23.3-24.7 40-31.7s33-12 49-14.9c15.9-3 33-4.8 51-5.4V500zm335.2 218.9c-4.3-5.4-15.9-8.9-34.9-10.7-19-1.8-35.5-1.7-49.7.4-15.3 1.8-31.1 6.2-47.3 13.4-16.3 7.1-23.4 13.1-21.6 17.8l.7 1.3.9.7 1.4.2h4.6c.8 0 1.8-.1 3.2-.2 1.4-.1 2.7-.3 3.9-.4 1.2-.1 2.9-.3 5.1-.4 2.1-.1 4.1-.4 6-.7.3 0 3.7-.3 10.3-.9 6.6-.6 11.4-1 14.3-1.3 2.9-.3 7.8-.6 14.5-.9 6.7-.3 12.1-.3 16.1 0 4 .3 8.5.7 13.6 1.1 5.1.4 9.2 1.3 12.4 2.7 3.2 1.3 5.6 3 7.1 5.1 5.2 6.6 4.2 21.2-3 43.9s-14 40.8-20.4 54.2c-2.8 5.7-2.8 9.2 0 10.7s6.7.1 11.9-4c15.6-12.2 28.6-30.6 39.1-55.3 6.1-14.6 10.5-29.8 13.1-45.7 2.4-15.9 2-26.2-1.3-31z\"}}]})(props);\n};\nexport function AiOutlineAndroid (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M448.3 225.2c-18.6 0-32 13.4-32 31.9s13.5 31.9 32 31.9c18.6 0 32-13.4 32-31.9.1-18.4-13.4-31.9-32-31.9zm393.9 96.4c-13.8-13.8-32.7-21.5-53.2-21.5-3.9 0-7.4.4-10.7 1v-1h-3.6c-5.5-30.6-18.6-60.5-38.1-87.4-18.7-25.7-43-47.9-70.8-64.9l25.1-35.8v-3.3c0-.8.4-2.3.7-3.8.6-2.4 1.4-5.5 1.4-8.9 0-18.5-13.5-31.9-32-31.9-9.8 0-19.5 5.7-25.9 15.4l-29.3 42.1c-30-9.8-62.4-15-93.8-15-31.3 0-63.7 5.2-93.8 15L389 79.4c-6.6-9.6-16.1-15.4-26-15.4-18.6 0-32 13.4-32 31.9 0 6.2 2.5 12.8 6.7 17.4l22.6 32.3c-28.7 17-53.5 39.4-72.2 65.1-19.4 26.9-32 56.8-36.7 87.4h-5.5v1c-3.2-.6-6.7-1-10.7-1-20.3 0-39.2 7.5-53.1 21.3-13.8 13.8-21.5 32.6-21.5 53v235c0 20.3 7.5 39.1 21.4 52.9 13.8 13.8 32.8 21.5 53.2 21.5 3.9 0 7.4-.4 10.7-1v93.5c0 29.2 23.9 53.1 53.2 53.1H331v58.3c0 20.3 7.5 39.1 21.4 52.9 13.8 13.8 32.8 21.5 53.2 21.5 20.3 0 39.2-7.5 53.1-21.3 13.8-13.8 21.5-32.6 21.5-53v-58.2H544v58.1c0 20.3 7.5 39.1 21.4 52.9 13.8 13.8 32.8 21.5 53.2 21.5 20.4 0 39.2-7.5 53.1-21.6 13.8-13.8 21.5-32.6 21.5-53v-58.2h31.9c29.3 0 53.2-23.8 53.2-53.1v-91.4c3.2.6 6.7 1 10.7 1 20.3 0 39.2-7.5 53.1-21.3 13.8-13.8 21.5-32.6 21.5-53v-235c-.1-20.3-7.6-39-21.4-52.9zM246 609.6c0 6.8-3.9 10.6-10.7 10.6-6.8 0-10.7-3.8-10.7-10.6V374.5c0-6.8 3.9-10.6 10.7-10.6 6.8 0 10.7 3.8 10.7 10.6v235.1zm131.1-396.8c37.5-27.3 85.3-42.3 135-42.3s97.5 15.1 135 42.5c32.4 23.7 54.2 54.2 62.7 87.5H314.4c8.5-33.4 30.5-64 62.7-87.7zm39.3 674.7c-.6 5.6-4.4 8.7-10.5 8.7-6.8 0-10.7-3.8-10.7-10.6v-58.2h21.2v60.1zm202.3 8.7c-6.8 0-10.7-3.8-10.7-10.6v-58.2h21.2v60.1c-.6 5.6-4.3 8.7-10.5 8.7zm95.8-132.6H309.9V364h404.6v399.6zm85.2-154c0 6.8-3.9 10.6-10.7 10.6-6.8 0-10.7-3.8-10.7-10.6V374.5c0-6.8 3.9-10.6 10.7-10.6 6.8 0 10.7 3.8 10.7 10.6v235.1zM576.1 225.2c-18.6 0-32 13.4-32 31.9s13.5 31.9 32 31.9c18.6 0 32.1-13.4 32.1-32-.1-18.6-13.4-31.8-32.1-31.8z\"}}]})(props);\n};\nexport function AiOutlineAntCloud (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M378.9 738c-3.1 0-6.1-.5-8.8-1.5l4.4 30.7h26.3l-15.5-29.9c-2.1.5-4.2.7-6.4.7zm421-291.2c-12.6 0-24.8 1.5-36.5 4.2-21.4-38.4-62.3-64.3-109.3-64.3-6.9 0-13.6.6-20.2 1.6-35.4-77.4-113.4-131.1-203.9-131.1-112.3 0-205.3 82.6-221.6 190.4C127.3 455.5 64 523.8 64 607c0 88.4 71.6 160.1 160 160.2h50l13.2-27.6c-26.2-8.3-43.3-29-39.1-48.8 4.6-21.6 32.8-33.9 63.1-27.5 22.9 4.9 40.4 19.1 45.5 35.1a26.1 26.1 0 0 1 22.1-12.4h.2c-.8-3.2-1.2-6.5-1.2-9.9 0-20.1 14.8-36.7 34.1-39.6v-25.4c0-4.4 3.6-8 8-8s8 3.6 8 8v26.3c4.6 1.2 8.8 3.2 12.6 5.8l19.5-21.4c3-3.3 8-3.5 11.3-.5 3.3 3 3.5 8 .5 11.3l-20 22-.2.2a40 40 0 0 1-46.9 59.2c-.4 5.6-2.6 10.7-6 14.8l20 38.4H804v-.1c86.5-2.2 156-73 156-160.1 0-88.5-71.7-160.2-160.1-160.2zM338.2 737.2l-4.3 30h24.4l-5.9-41.5c-3.5 4.6-8.3 8.5-14.2 11.5zM797.5 305a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm-65.7 61.3a24 24 0 1 0 48 0 24 24 0 1 0-48 0zM303.4 742.9l-11.6 24.3h26l3.5-24.7c-5.7.8-11.7 1-17.9.4z\"}}]})(props);\n};\nexport function AiOutlineAntDesign (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M716.3 313.8c19-18.9 19-49.7 0-68.6l-69.9-69.9.1.1c-18.5-18.5-50.3-50.3-95.3-95.2-21.2-20.7-55.5-20.5-76.5.5L80.9 474.2a53.84 53.84 0 0 0 0 76.4L474.6 944a54.14 54.14 0 0 0 76.5 0l165.1-165c19-18.9 19-49.7 0-68.6a48.7 48.7 0 0 0-68.7 0l-125 125.2c-5.2 5.2-13.3 5.2-18.5 0L189.5 521.4c-5.2-5.2-5.2-13.3 0-18.5l314.4-314.2c.4-.4.9-.7 1.3-1.1 5.2-4.1 12.4-3.7 17.2 1.1l125.2 125.1c19 19 49.8 19 68.7 0zM408.6 514.4a106.3 106.2 0 1 0 212.6 0 106.3 106.2 0 1 0-212.6 0zm536.2-38.6L821.9 353.5c-19-18.9-49.8-18.9-68.7.1a48.4 48.4 0 0 0 0 68.6l83 82.9c5.2 5.2 5.2 13.3 0 18.5l-81.8 81.7a48.4 48.4 0 0 0 0 68.6 48.7 48.7 0 0 0 68.7 0l121.8-121.7a53.93 53.93 0 0 0-.1-76.4z\"}}]})(props);\n};\nexport function AiOutlineApartment (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M908 640H804V488c0-4.4-3.6-8-8-8H548v-96h108c8.8 0 16-7.2 16-16V80c0-8.8-7.2-16-16-16H368c-8.8 0-16 7.2-16 16v288c0 8.8 7.2 16 16 16h108v96H228c-4.4 0-8 3.6-8 8v152H116c-8.8 0-16 7.2-16 16v288c0 8.8 7.2 16 16 16h288c8.8 0 16-7.2 16-16V656c0-8.8-7.2-16-16-16H292v-88h440v88H620c-8.8 0-16 7.2-16 16v288c0 8.8 7.2 16 16 16h288c8.8 0 16-7.2 16-16V656c0-8.8-7.2-16-16-16zm-564 76v168H176V716h168zm84-408V140h168v168H428zm420 576H680V716h168v168z\"}}]})(props);\n};\nexport function AiOutlineApi (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M917.7 148.8l-42.4-42.4c-1.6-1.6-3.6-2.3-5.7-2.3s-4.1.8-5.7 2.3l-76.1 76.1a199.27 199.27 0 0 0-112.1-34.3c-51.2 0-102.4 19.5-141.5 58.6L432.3 308.7a8.03 8.03 0 0 0 0 11.3L704 591.7c1.6 1.6 3.6 2.3 5.7 2.3 2 0 4.1-.8 5.7-2.3l101.9-101.9c68.9-69 77-175.7 24.3-253.5l76.1-76.1c3.1-3.2 3.1-8.3 0-11.4zM769.1 441.7l-59.4 59.4-186.8-186.8 59.4-59.4c24.9-24.9 58.1-38.7 93.4-38.7 35.3 0 68.4 13.7 93.4 38.7 24.9 24.9 38.7 58.1 38.7 93.4 0 35.3-13.8 68.4-38.7 93.4zm-190.2 105a8.03 8.03 0 0 0-11.3 0L501 613.3 410.7 523l66.7-66.7c3.1-3.1 3.1-8.2 0-11.3L441 408.6a8.03 8.03 0 0 0-11.3 0L363 475.3l-43-43a7.85 7.85 0 0 0-5.7-2.3c-2 0-4.1.8-5.7 2.3L206.8 534.2c-68.9 69-77 175.7-24.3 253.5l-76.1 76.1a8.03 8.03 0 0 0 0 11.3l42.4 42.4c1.6 1.6 3.6 2.3 5.7 2.3s4.1-.8 5.7-2.3l76.1-76.1c33.7 22.9 72.9 34.3 112.1 34.3 51.2 0 102.4-19.5 141.5-58.6l101.9-101.9c3.1-3.1 3.1-8.2 0-11.3l-43-43 66.7-66.7c3.1-3.1 3.1-8.2 0-11.3l-36.6-36.2zM441.7 769.1a131.32 131.32 0 0 1-93.4 38.7c-35.3 0-68.4-13.7-93.4-38.7a131.32 131.32 0 0 1-38.7-93.4c0-35.3 13.7-68.4 38.7-93.4l59.4-59.4 186.8 186.8-59.4 59.4z\"}}]})(props);\n};\nexport function AiOutlineApple (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M747.4 535.7c-.4-68.2 30.5-119.6 92.9-157.5-34.9-50-87.7-77.5-157.3-82.8-65.9-5.2-138 38.4-164.4 38.4-27.9 0-91.7-36.6-141.9-36.6C273.1 298.8 163 379.8 163 544.6c0 48.7 8.9 99 26.7 150.8 23.8 68.2 109.6 235.3 199.1 232.6 46.8-1.1 79.9-33.2 140.8-33.2 59.1 0 89.7 33.2 141.9 33.2 90.3-1.3 167.9-153.2 190.5-221.6-121.1-57.1-114.6-167.2-114.6-170.7zm-10.6 267c-14.3 19.9-28.7 35.6-41.9 45.7-10.5 8-18.6 11.4-24 11.6-9-.1-17.7-2.3-34.7-8.8-1.2-.5-2.5-1-4.2-1.6l-4.4-1.7c-17.4-6.7-27.8-10.3-41.1-13.8-18.6-4.8-37.1-7.4-56.9-7.4-20.2 0-39.2 2.5-58.1 7.2-13.9 3.5-25.6 7.4-42.7 13.8-.7.3-8.1 3.1-10.2 3.9-3.5 1.3-6.2 2.3-8.7 3.2-10.4 3.6-17 5.1-22.9 5.2-.7 0-1.3-.1-1.8-.2-1.1-.2-2.5-.6-4.1-1.3-4.5-1.8-9.9-5.1-16-9.8-14-10.9-29.4-28-45.1-49.9-27.5-38.6-53.5-89.8-66-125.7-15.4-44.8-23-87.7-23-128.6 0-60.2 17.8-106 48.4-137.1 26.3-26.6 61.7-41.5 97.8-42.3 5.9.1 14.5 1.5 25.4 4.5 8.6 2.3 18 5.4 30.7 9.9 3.8 1.4 16.9 6.1 18.5 6.7 7.7 2.8 13.5 4.8 19.2 6.6 18.2 5.8 32.3 9 47.6 9 15.5 0 28.8-3.3 47.7-9.8 7.1-2.4 32.9-12 37.5-13.6 25.6-9.1 44.5-14 60.8-15.2 4.8-.4 9.1-.4 13.2-.1 22.7 1.8 42.1 6.3 58.6 13.8-37.6 43.4-57 96.5-56.9 158.4-.3 14.7.9 31.7 5.1 51.8 6.4 30.5 18.6 60.7 37.9 89 14.7 21.5 32.9 40.9 54.7 57.8-11.5 23.7-25.6 48.2-40.4 68.8zm-94.5-572c50.7-60.2 46.1-115 44.6-134.7-44.8 2.6-96.6 30.5-126.1 64.8-32.5 36.8-51.6 82.3-47.5 133.6 48.4 3.7 92.6-21.2 129-63.7z\"}}]})(props);\n};\nexport function AiOutlineAppstoreAdd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683928793\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M464 144H160c-8.8 0-16 7.2-16 16v304c0 8.8 7.2 16 16 16h304c8.8 0 16-7.2 16-16V160c0-8.8-7.2-16-16-16z m-52 268H212V212h200v200zM864 144H560c-8.8 0-16 7.2-16 16v304c0 8.8 7.2 16 16 16h304c8.8 0 16-7.2 16-16V160c0-8.8-7.2-16-16-16z m-52 268H612V212h200v200zM864 544H560c-8.8 0-16 7.2-16 16v304c0 8.8 7.2 16 16 16h304c8.8 0 16-7.2 16-16V560c0-8.8-7.2-16-16-16z m-52 268H612V612h200v200zM424 712H296V584c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v128H104c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h128v128c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V776h128c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineAppstore (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M464 144H160c-8.8 0-16 7.2-16 16v304c0 8.8 7.2 16 16 16h304c8.8 0 16-7.2 16-16V160c0-8.8-7.2-16-16-16zm-52 268H212V212h200v200zm452-268H560c-8.8 0-16 7.2-16 16v304c0 8.8 7.2 16 16 16h304c8.8 0 16-7.2 16-16V160c0-8.8-7.2-16-16-16zm-52 268H612V212h200v200zM464 544H160c-8.8 0-16 7.2-16 16v304c0 8.8 7.2 16 16 16h304c8.8 0 16-7.2 16-16V560c0-8.8-7.2-16-16-16zm-52 268H212V612h200v200zm452-268H560c-8.8 0-16 7.2-16 16v304c0 8.8 7.2 16 16 16h304c8.8 0 16-7.2 16-16V560c0-8.8-7.2-16-16-16zm-52 268H612V612h200v200z\"}}]})(props);\n};\nexport function AiOutlineAreaChart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M888 792H200V168c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v688c0 4.4 3.6 8 8 8h752c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-616-64h536c4.4 0 8-3.6 8-8V284c0-7.2-8.7-10.7-13.7-5.7L592 488.6l-125.4-124a8.03 8.03 0 0 0-11.3 0l-189 189.6a7.87 7.87 0 0 0-2.3 5.6V720c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlineArrowDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M862 465.3h-81c-4.6 0-9 2-12.1 5.5L550 723.1V160c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8v563.1L255.1 470.8c-3-3.5-7.4-5.5-12.1-5.5h-81c-6.8 0-10.5 8.1-6 13.2L487.9 861a31.96 31.96 0 0 0 48.3 0L868 478.5c4.5-5.2.8-13.2-6-13.2z\"}}]})(props);\n};\nexport function AiOutlineArrowLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M872 474H286.9l350.2-304c5.6-4.9 2.2-14-5.2-14h-88.5c-3.9 0-7.6 1.4-10.5 3.9L155 487.8a31.96 31.96 0 0 0 0 48.3L535.1 866c1.5 1.3 3.3 2 5.2 2h91.5c7.4 0 10.8-9.2 5.2-14L286.9 550H872c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineArrowRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M869 487.8L491.2 159.9c-2.9-2.5-6.6-3.9-10.5-3.9h-88.5c-7.4 0-10.8 9.2-5.2 14l350.2 304H152c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h585.1L386.9 854c-5.6 4.9-2.2 14 5.2 14h91.5c1.9 0 3.8-.7 5.2-2L869 536.2a32.07 32.07 0 0 0 0-48.4z\"}}]})(props);\n};\nexport function AiOutlineArrowUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M868 545.5L536.1 163a31.96 31.96 0 0 0-48.3 0L156 545.5a7.97 7.97 0 0 0 6 13.2h81c4.6 0 9-2 12.1-5.5L474 300.9V864c0 4.4 3.6 8 8 8h60c4.4 0 8-3.6 8-8V300.9l218.9 252.3c3 3.5 7.4 5.5 12.1 5.5h81c6.8 0 10.5-8 6-13.2z\"}}]})(props);\n};\nexport function AiOutlineArrowsAlt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M855 160.1l-189.2 23.5c-6.6.8-9.3 8.8-4.7 13.5l54.7 54.7-153.5 153.5a8.03 8.03 0 0 0 0 11.3l45.1 45.1c3.1 3.1 8.2 3.1 11.3 0l153.6-153.6 54.7 54.7a7.94 7.94 0 0 0 13.5-4.7L863.9 169a7.9 7.9 0 0 0-8.9-8.9zM416.6 562.3a8.03 8.03 0 0 0-11.3 0L251.8 715.9l-54.7-54.7a7.94 7.94 0 0 0-13.5 4.7L160.1 855c-.6 5.2 3.7 9.5 8.9 8.9l189.2-23.5c6.6-.8 9.3-8.8 4.7-13.5l-54.7-54.7 153.6-153.6c3.1-3.1 3.1-8.2 0-11.3l-45.2-45z\"}}]})(props);\n};\nexport function AiOutlineAudioMuted (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569682811064\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M682 455V311l-76 76v68c-0.1 50.7-42 92.1-94 92-19.1 0.1-36.8-5.4-52-15l-54 55c29.1 22.4 65.9 36 106 36 93.8 0 170-75.1 170-168z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M833 446h-60c-4.4 0-8 3.6-8 8 0 140.3-113.7 254-254 254-63 0-120.7-23-165-61l-54 54c48.9 43.2 110.8 72.3 179 81v102H326c-13.9 0-24.9 14.3-25 32v36c0.1 4.4 2.9 8 6 8h408c3.2 0 6-3.6 6-8v-36c0-17.7-11-32-25-32H547V782c165.3-17.9 294-157.9 294-328 0-4.4-3.6-8-8-8zM846.1 68.3l-43.5-41.9c-3.1-3-8.1-3-11.2 0.1l-129 129C634.3 101.2 577 64 511 64c-93.9 0-170 75.3-170 168v224c0 6.7 0.4 13.3 1.2 19.8l-68 68c-10.5-27.9-16.3-58.2-16.2-89.8-0.2-4.4-3.8-8-8-8h-60c-4.4 0-8 3.6-8 8 0 53 12.5 103 34.6 147.4l-137 137c-3.1 3.1-3.1 8.2 0 11.3l42.7 42.7c3.1 3.1 8.2 3.1 11.3 0L846.2 79.8l0.1-0.1c3.1-3.2 3-8.3-0.2-11.4zM417 401V232c0-50.6 41.9-92 94-92 46 0 84.1 32.3 92.3 74.7L417 401z\"}}]})(props);\n};\nexport function AiOutlineAudio (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M842 454c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8 0 140.3-113.7 254-254 254S258 594.3 258 454c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8 0 168.7 126.6 307.9 290 327.6V884H326.7c-13.7 0-24.7 14.3-24.7 32v36c0 4.4 2.8 8 6.2 8h407.6c3.4 0 6.2-3.6 6.2-8v-36c0-17.7-11-32-24.7-32H548V782.1c165.3-18 294-158 294-328.1zM512 624c93.9 0 170-75.2 170-168V232c0-92.8-76.1-168-170-168s-170 75.2-170 168v224c0 92.8 76.1 168 170 168zm-94-392c0-50.6 41.9-92 94-92s94 41.4 94 92v224c0 50.6-41.9 92-94 92s-94-41.4-94-92V232z\"}}]})(props);\n};\nexport function AiOutlineAudit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M296 250c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h384c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H296zm184 144H296c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zm-48 458H208V148h560v320c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V108c0-17.7-14.3-32-32-32H168c-17.7 0-32 14.3-32 32v784c0 17.7 14.3 32 32 32h264c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm440-88H728v-36.6c46.3-13.8 80-56.6 80-107.4 0-61.9-50.1-112-112-112s-112 50.1-112 112c0 50.7 33.7 93.6 80 107.4V764H520c-8.8 0-16 7.2-16 16v152c0 8.8 7.2 16 16 16h352c8.8 0 16-7.2 16-16V780c0-8.8-7.2-16-16-16zM646 620c0-27.6 22.4-50 50-50s50 22.4 50 50-22.4 50-50 50-50-22.4-50-50zm180 266H566v-60h260v60z\"}}]})(props);\n};\nexport function AiOutlineBackward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M485.6 249.9L198.2 498c-8.3 7.1-8.3 20.8 0 27.9l287.4 248.2c10.7 9.2 26.4.9 26.4-14V263.8c0-14.8-15.7-23.2-26.4-13.9zm320 0L518.2 498a18.6 18.6 0 0 0-6.2 14c0 5.2 2.1 10.4 6.2 14l287.4 248.2c10.7 9.2 26.4.9 26.4-14V263.8c0-14.8-15.7-23.2-26.4-13.9z\"}}]})(props);\n};\nexport function AiOutlineBank (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M894 462c30.9 0 43.8-39.7 18.7-58L530.8 126.2a31.81 31.81 0 0 0-37.6 0L111.3 404c-25.1 18.2-12.2 58 18.8 58H192v374h-72c-4.4 0-8 3.6-8 8v52c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-52c0-4.4-3.6-8-8-8h-72V462h62zM512 196.7l271.1 197.2H240.9L512 196.7zM264 462h117v374H264V462zm189 0h117v374H453V462zm307 374H642V462h118v374z\"}}]})(props);\n};\nexport function AiOutlineBarChart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M888 792H200V168c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v688c0 4.4 3.6 8 8 8h752c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-600-80h56c4.4 0 8-3.6 8-8V560c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v144c0 4.4 3.6 8 8 8zm152 0h56c4.4 0 8-3.6 8-8V384c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v320c0 4.4 3.6 8 8 8zm152 0h56c4.4 0 8-3.6 8-8V462c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v242c0 4.4 3.6 8 8 8zm152 0h56c4.4 0 8-3.6 8-8V304c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v400c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlineBarcode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M120 160H72c-4.4 0-8 3.6-8 8v688c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V168c0-4.4-3.6-8-8-8zm833 0h-48c-4.4 0-8 3.6-8 8v688c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V168c0-4.4-3.6-8-8-8zM200 736h112c4.4 0 8-3.6 8-8V168c0-4.4-3.6-8-8-8H200c-4.4 0-8 3.6-8 8v560c0 4.4 3.6 8 8 8zm321 0h48c4.4 0 8-3.6 8-8V168c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v560c0 4.4 3.6 8 8 8zm126 0h178c4.4 0 8-3.6 8-8V168c0-4.4-3.6-8-8-8H647c-4.4 0-8 3.6-8 8v560c0 4.4 3.6 8 8 8zm-255 0h48c4.4 0 8-3.6 8-8V168c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v560c0 4.4 3.6 8 8 8zm-79 64H201c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h112c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zm257 0h-48c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zm256 0H648c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h178c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zm-385 0h-48c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineBars (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M912 192H328c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h584c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 284H328c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h584c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 284H328c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h584c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM104 228a56 56 0 1 0 112 0 56 56 0 1 0-112 0zm0 284a56 56 0 1 0 112 0 56 56 0 1 0-112 0zm0 284a56 56 0 1 0 112 0 56 56 0 1 0-112 0z\"}}]})(props);\n};\nexport function AiOutlineBehanceSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM598.5 350.9h138.4v33.7H598.5v-33.7zM512 628.8a89.52 89.52 0 0 1-27 31c-11.8 8.2-24.9 14.2-38.8 17.7a167.4 167.4 0 0 1-44.6 5.7H236V342.1h161c16.3 0 31.1 1.5 44.6 4.3 13.4 2.8 24.8 7.6 34.4 14.1 9.5 6.5 17 15.2 22.3 26 5.2 10.7 7.9 24.1 7.9 40 0 17.2-3.9 31.4-11.7 42.9-7.9 11.5-19.3 20.8-34.8 28.1 21.1 6 36.6 16.7 46.8 31.7 10.4 15.2 15.5 33.4 15.5 54.8 0 17.4-3.3 32.3-10 44.8zM790.8 576H612.4c0 19.4 6.7 38 16.8 48 10.2 9.9 24.8 14.9 43.9 14.9 13.8 0 25.5-3.5 35.5-10.4 9.9-6.9 15.9-14.2 18.1-21.8h59.8c-9.6 29.7-24.2 50.9-44 63.7-19.6 12.8-43.6 19.2-71.5 19.2-19.5 0-37-3.2-52.7-9.3-15.1-5.9-28.7-14.9-39.9-26.5a121.2 121.2 0 0 1-25.1-41.2c-6.1-16.9-9.1-34.7-8.9-52.6 0-18.5 3.1-35.7 9.1-51.7 11.5-31.1 35.4-56 65.9-68.9 16.3-6.8 33.8-10.2 51.5-10 21 0 39.2 4 55 12.2a111.6 111.6 0 0 1 38.6 32.8c10.1 13.7 17.2 29.3 21.7 46.9 4.3 17.3 5.8 35.5 4.6 54.7zm-122-95.6c-10.8 0-19.9 1.9-26.9 5.6-7 3.7-12.8 8.3-17.2 13.6a48.4 48.4 0 0 0-9.1 17.4c-1.6 5.3-2.7 10.7-3.1 16.2H723c-1.6-17.3-7.6-30.1-15.6-39.1-8.4-8.9-21.9-13.7-38.6-13.7zm-248.5-10.1c8.7-6.3 12.9-16.7 12.9-31 .3-6.8-1.1-13.5-4.1-19.6-2.7-4.9-6.7-9-11.6-11.9a44.8 44.8 0 0 0-16.6-6c-6.4-1.2-12.9-1.8-19.3-1.7h-70.3v79.7h76.1c13.1.1 24.2-3.1 32.9-9.5zm11.8 72c-9.8-7.5-22.9-11.2-39.2-11.2h-81.8v94h80.2c7.5 0 14.4-.7 21.1-2.1s12.7-3.8 17.8-7.2c5.1-3.3 9.2-7.8 12.3-13.6 3-5.8 4.5-13.2 4.5-22.1 0-17.7-5-30.2-14.9-37.8z\"}}]})(props);\n};\nexport function AiOutlineBehance (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M634 294.3h199.5v48.4H634zM434.1 485.8c44.1-21.1 67.2-53.2 67.2-102.8 0-98.1-73-121.9-157.3-121.9H112v492.4h238.5c89.4 0 173.3-43 173.3-143 0-61.8-29.2-107.5-89.7-124.7zM220.2 345.1h101.5c39.1 0 74.2 10.9 74.2 56.3 0 41.8-27.3 58.6-66 58.6H220.2V345.1zm115.5 324.8H220.1V534.3H338c47.6 0 77.7 19.9 77.7 70.3 0 49.6-35.9 65.3-80 65.3zm575.8-89.5c0-105.5-61.7-193.4-173.3-193.4-108.5 0-182.3 81.7-182.3 188.8 0 111 69.9 187.2 182.3 187.2 85.1 0 140.2-38.3 166.7-120h-86.3c-9.4 30.5-47.6 46.5-77.3 46.5-57.4 0-87.4-33.6-87.4-90.7h256.9c.3-5.9.7-12.1.7-18.4zM653.9 537c3.1-46.9 34.4-76.2 81.2-76.2 49.2 0 73.8 28.9 78.1 76.2H653.9z\"}}]})(props);\n};\nexport function AiOutlineBell (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M816 768h-24V428c0-141.1-104.3-257.7-240-277.1V112c0-22.1-17.9-40-40-40s-40 17.9-40 40v38.9c-135.7 19.4-240 136-240 277.1v340h-24c-17.7 0-32 14.3-32 32v32c0 4.4 3.6 8 8 8h216c0 61.8 50.2 112 112 112s112-50.2 112-112h216c4.4 0 8-3.6 8-8v-32c0-17.7-14.3-32-32-32zM512 888c-26.5 0-48-21.5-48-48h96c0 26.5-21.5 48-48 48zM304 768V428c0-55.6 21.6-107.8 60.9-147.1S456.4 220 512 220c55.6 0 107.8 21.6 147.1 60.9S720 372.4 720 428v340H304z\"}}]})(props);\n};\nexport function AiOutlineBgColors (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M766.4 744.3c43.7 0 79.4-36.2 79.4-80.5 0-53.5-79.4-140.8-79.4-140.8S687 610.3 687 663.8c0 44.3 35.7 80.5 79.4 80.5zm-377.1-44.1c7.1 7.1 18.6 7.1 25.6 0l256.1-256c7.1-7.1 7.1-18.6 0-25.6l-256-256c-.6-.6-1.3-1.2-2-1.7l-78.2-78.2a9.11 9.11 0 0 0-12.8 0l-48 48a9.11 9.11 0 0 0 0 12.8l67.2 67.2-207.8 207.9c-7.1 7.1-7.1 18.6 0 25.6l255.9 256zm12.9-448.6l178.9 178.9H223.4l178.8-178.9zM904 816H120c-4.4 0-8 3.6-8 8v80c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-80c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineBlock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M856 376H648V168c0-8.8-7.2-16-16-16H168c-8.8 0-16 7.2-16 16v464c0 8.8 7.2 16 16 16h208v208c0 8.8 7.2 16 16 16h464c8.8 0 16-7.2 16-16V392c0-8.8-7.2-16-16-16zm-480 16v188H220V220h360v156H392c-8.8 0-16 7.2-16 16zm204 52v136H444V444h136zm224 360H444V648h188c8.8 0 16-7.2 16-16V444h156v360z\"}}]})(props);\n};\nexport function AiOutlineBold (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M697.8 481.4c33.6-35 54.2-82.3 54.2-134.3v-10.2C752 229.3 663.9 142 555.3 142H259.4c-15.1 0-27.4 12.3-27.4 27.4v679.1c0 16.3 13.2 29.5 29.5 29.5h318.7c117 0 211.8-94.2 211.8-210.5v-11c0-73-37.4-137.3-94.2-175.1zM328 238h224.7c57.1 0 103.3 44.4 103.3 99.3v9.5c0 54.8-46.3 99.3-103.3 99.3H328V238zm366.6 429.4c0 62.9-51.7 113.9-115.5 113.9H328V542.7h251.1c63.8 0 115.5 51 115.5 113.9v10.8z\"}}]})(props);\n};\nexport function AiOutlineBook (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V96c0-17.7-14.3-32-32-32zm-260 72h96v209.9L621.5 312 572 347.4V136zm220 752H232V136h280v296.9c0 3.3 1 6.6 3 9.3a15.9 15.9 0 0 0 22.3 3.7l83.8-59.9 81.4 59.4c2.7 2 6 3.1 9.4 3.1 8.8 0 16-7.2 16-16V136h64v752z\"}}]})(props);\n};\nexport function AiOutlineBorderBottom (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M872 808H152c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h720c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-720-94h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm0-498h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm0 332h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm0-166h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm166 166h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm0-332h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm332 0h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm0 332h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm222-72h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-388 72h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm388-404h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-388 72h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm388 426h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-388 72h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm388-404h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-388 72h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlineBorderHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M540 144h-56c-4.4 0-8 3.6-8 8v720c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V152c0-4.4-3.6-8-8-8zm-166 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm498 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-664 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm498 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM208 310h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm664 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-664 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 166h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm664 332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM374 808h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm332 332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineBorderInner (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M872 476H548V144h-72v332H152c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h324v332h72V548h324c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-166h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 498h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-664h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 498h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM650 216h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm56 592h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-332 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-56-592h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm-166 0h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm56 592h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-56-426h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm56 260h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineBorderLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M208 144h-56c-4.4 0-8 3.6-8 8v720c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V152c0-4.4-3.6-8-8-8zm166 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm498 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-332 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm166 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM540 310h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm332 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-332 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 166h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm332 332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM374 808h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm332 332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineBorderOuter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656zM484 366h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zM302 548h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm364 0h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm-182 0h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm0 182h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlineBorderRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M872 144h-56c-4.4 0-8 3.6-8 8v720c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V152c0-4.4-3.6-8-8-8zm-166 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-498 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm332 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-166 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm166 166h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-332 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm332 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 166h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM208 808h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm498 332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM374 808h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineBorderTop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M872 144H152c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h720c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM208 310h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 498h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 166h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm166-166h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm332 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm166 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-332 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm332 332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-332 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm332-498h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-332 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm332 332h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-332 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineBorderVerticle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M872 476H152c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h720c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-166h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 498h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-664h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 498h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM650 216h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm56 592h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-332 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-56-592h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm-166 0h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm332 0h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zM208 808h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm332 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM152 382h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm332 0h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zM208 642h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm332 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineBorder (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}}]})(props);\n};\nexport function AiOutlineBorderlessTable (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683537953\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M117 368h231v64H117zM676 368h241v64H676zM412 368h200v64H412zM412 592h200v64H412zM676 592h241v64H676zM117 592h231v64H117zM412 432V179h-64v666h64V592zM676 368V179h-64v666h64V432z\"}}]})(props);\n};\nexport function AiOutlineBoxPlot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M952 224h-52c-4.4 0-8 3.6-8 8v248h-92V304c0-4.4-3.6-8-8-8H232c-4.4 0-8 3.6-8 8v176h-92V232c0-4.4-3.6-8-8-8H72c-4.4 0-8 3.6-8 8v560c0 4.4 3.6 8 8 8h52c4.4 0 8-3.6 8-8V548h92v172c0 4.4 3.6 8 8 8h560c4.4 0 8-3.6 8-8V548h92v244c0 4.4 3.6 8 8 8h52c4.4 0 8-3.6 8-8V232c0-4.4-3.6-8-8-8zM296 368h88v288h-88V368zm432 288H448V368h280v288z\"}}]})(props);\n};\nexport function AiOutlineBranches (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M740 161c-61.8 0-112 50.2-112 112 0 50.1 33.1 92.6 78.5 106.9v95.9L320 602.4V318.1c44.2-15 76-56.9 76-106.1 0-61.8-50.2-112-112-112s-112 50.2-112 112c0 49.2 31.8 91 76 106.1V706c-44.2 15-76 56.9-76 106.1 0 61.8 50.2 112 112 112s112-50.2 112-112c0-49.2-31.8-91-76-106.1v-27.8l423.5-138.7a50.52 50.52 0 0 0 34.9-48.2V378.2c42.9-15.8 73.6-57 73.6-105.2 0-61.8-50.2-112-112-112zm-504 51a48.01 48.01 0 0 1 96 0 48.01 48.01 0 0 1-96 0zm96 600a48.01 48.01 0 0 1-96 0 48.01 48.01 0 0 1 96 0zm408-491a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96z\"}}]})(props);\n};\nexport function AiOutlineBug (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M304 280h56c4.4 0 8-3.6 8-8 0-28.3 5.9-53.2 17.1-73.5 10.6-19.4 26-34.8 45.4-45.4C450.9 142 475.7 136 504 136h16c28.3 0 53.2 5.9 73.5 17.1 19.4 10.6 34.8 26 45.4 45.4C650 218.9 656 243.7 656 272c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8 0-40-8.8-76.7-25.9-108.1-17.2-31.5-42.5-56.8-74-74C596.7 72.8 560 64 520 64h-16c-40 0-76.7 8.8-108.1 25.9-31.5 17.2-56.8 42.5-74 74C304.8 195.3 296 232 296 272c0 4.4 3.6 8 8 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M940 512H792V412c76.8 0 139-62.2 139-139 0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8 0 34.8-28.2 63-63 63H232c-34.8 0-63-28.2-63-63 0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8 0 76.8 62.2 139 139 139v100H84c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h148v96c0 6.5.2 13 .7 19.3C164.1 728.6 116 796.7 116 876c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8 0-44.2 23.9-82.9 59.6-103.7 6 17.2 13.6 33.6 22.7 49 24.3 41.5 59 76.2 100.5 100.5S460.5 960 512 960s99.8-13.9 141.3-38.2c41.5-24.3 76.2-59 100.5-100.5 9.1-15.5 16.7-31.9 22.7-49C812.1 793.1 836 831.8 836 876c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8 0-79.3-48.1-147.4-116.7-176.7.4-6.4.7-12.8.7-19.3v-96h148c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM716 680c0 36.8-9.7 72-27.8 102.9-17.7 30.3-43 55.6-73.3 73.3C584 874.3 548.8 884 512 884s-72-9.7-102.9-27.8c-30.3-17.7-55.6-43-73.3-73.3C317.7 752 308 716.8 308 680V412h408v268z\"}}]})(props);\n};\nexport function AiOutlineBuild (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M916 210H376c-17.7 0-32 14.3-32 32v236H108c-17.7 0-32 14.3-32 32v272c0 17.7 14.3 32 32 32h540c17.7 0 32-14.3 32-32V546h236c17.7 0 32-14.3 32-32V242c0-17.7-14.3-32-32-32zm-504 68h200v200H412V278zm-68 468H144V546h200v200zm268 0H412V546h200v200zm268-268H680V278h200v200z\"}}]})(props);\n};\nexport function AiOutlineBulb (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M632 888H392c-4.4 0-8 3.6-8 8v32c0 17.7 14.3 32 32 32h192c17.7 0 32-14.3 32-32v-32c0-4.4-3.6-8-8-8zM512 64c-181.1 0-328 146.9-328 328 0 121.4 66 227.4 164 284.1V792c0 17.7 14.3 32 32 32h264c17.7 0 32-14.3 32-32V676.1c98-56.7 164-162.7 164-284.1 0-181.1-146.9-328-328-328zm127.9 549.8L604 634.6V752H420V634.6l-35.9-20.8C305.4 568.3 256 484.5 256 392c0-141.4 114.6-256 256-256s256 114.6 256 256c0 92.5-49.4 176.3-128.1 221.8z\"}}]})(props);\n};\nexport function AiOutlineCalculator (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M251.2 387H320v68.8c0 1.8 1.8 3.2 4 3.2h48c2.2 0 4-1.4 4-3.3V387h68.8c1.8 0 3.2-1.8 3.2-4v-48c0-2.2-1.4-4-3.3-4H376v-68.8c0-1.8-1.8-3.2-4-3.2h-48c-2.2 0-4 1.4-4 3.2V331h-68.8c-1.8 0-3.2 1.8-3.2 4v48c0 2.2 1.4 4 3.2 4zm328 0h193.6c1.8 0 3.2-1.8 3.2-4v-48c0-2.2-1.4-4-3.3-4H579.2c-1.8 0-3.2 1.8-3.2 4v48c0 2.2 1.4 4 3.2 4zm0 265h193.6c1.8 0 3.2-1.8 3.2-4v-48c0-2.2-1.4-4-3.3-4H579.2c-1.8 0-3.2 1.8-3.2 4v48c0 2.2 1.4 4 3.2 4zm0 104h193.6c1.8 0 3.2-1.8 3.2-4v-48c0-2.2-1.4-4-3.3-4H579.2c-1.8 0-3.2 1.8-3.2 4v48c0 2.2 1.4 4 3.2 4zm-195.7-81l61.2-74.9c4.3-5.2.7-13.1-5.9-13.1H388c-2.3 0-4.5 1-5.9 2.9l-34 41.6-34-41.6a7.85 7.85 0 0 0-5.9-2.9h-50.9c-6.6 0-10.2 7.9-5.9 13.1l61.2 74.9-62.7 76.8c-4.4 5.2-.8 13.1 5.8 13.1h50.8c2.3 0 4.5-1 5.9-2.9l35.5-43.5 35.5 43.5c1.5 1.8 3.7 2.9 5.9 2.9h50.8c6.6 0 10.2-7.9 5.9-13.1L383.5 675zM880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-36 732H180V180h664v664z\"}}]})(props);\n};\nexport function AiOutlineCalendar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 184H712v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H384v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H144c-17.7 0-32 14.3-32 32v664c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V216c0-17.7-14.3-32-32-32zm-40 656H184V460h656v380zM184 392V256h128v48c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-48h256v48c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-48h128v136H184z\"}}]})(props);\n};\nexport function AiOutlineCamera (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M864 248H728l-32.4-90.8a32.07 32.07 0 0 0-30.2-21.2H358.6c-13.5 0-25.6 8.5-30.1 21.2L296 248H160c-44.2 0-80 35.8-80 80v456c0 44.2 35.8 80 80 80h704c44.2 0 80-35.8 80-80V328c0-44.2-35.8-80-80-80zm8 536c0 4.4-3.6 8-8 8H160c-4.4 0-8-3.6-8-8V328c0-4.4 3.6-8 8-8h186.7l17.1-47.8 22.9-64.2h250.5l22.9 64.2 17.1 47.8H864c4.4 0 8 3.6 8 8v456zM512 384c-88.4 0-160 71.6-160 160s71.6 160 160 160 160-71.6 160-160-71.6-160-160-160zm0 256c-53 0-96-43-96-96s43-96 96-96 96 43 96 96-43 96-96 96z\"}}]})(props);\n};\nexport function AiOutlineCar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M380 704h264c4.4 0 8-3.6 8-8v-84c0-4.4-3.6-8-8-8h-40c-4.4 0-8 3.6-8 8v36H428v-36c0-4.4-3.6-8-8-8h-40c-4.4 0-8 3.6-8 8v84c0 4.4 3.6 8 8 8zm340-123a40 40 0 1 0 80 0 40 40 0 1 0-80 0zm239-167.6L935.3 372a8 8 0 0 0-10.9-2.9l-50.7 29.6-78.3-216.2a63.9 63.9 0 0 0-60.9-44.4H301.2c-34.7 0-65.5 22.4-76.2 55.5l-74.6 205.2-50.8-29.6a8 8 0 0 0-10.9 2.9L65 413.4c-2.2 3.8-.9 8.6 2.9 10.8l60.4 35.2-14.5 40c-1.2 3.2-1.8 6.6-1.8 10v348.2c0 15.7 11.8 28.4 26.3 28.4h67.6c12.3 0 23-9.3 25.6-22.3l7.7-37.7h545.6l7.7 37.7c2.7 13 13.3 22.3 25.6 22.3h67.6c14.5 0 26.3-12.7 26.3-28.4V509.4c0-3.4-.6-6.8-1.8-10l-14.5-40 60.3-35.2a8 8 0 0 0 3-10.8zM840 517v237H184V517l15.6-43h624.8l15.6 43zM292.7 218.1l.5-1.3.4-1.3c1.1-3.3 4.1-5.5 7.6-5.5h427.6l75.4 208H220l72.7-199.9zM224 581a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}}]})(props);\n};\nexport function AiOutlineCaretDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M840.4 300H183.6c-19.7 0-30.7 20.8-18.5 35l328.4 380.8c9.4 10.9 27.5 10.9 37 0L858.9 335c12.2-14.2 1.2-35-18.5-35z\"}}]})(props);\n};\nexport function AiOutlineCaretLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M689 165.1L308.2 493.5c-10.9 9.4-10.9 27.5 0 37L689 858.9c14.2 12.2 35 1.2 35-18.5V183.6c0-19.7-20.8-30.7-35-18.5z\"}}]})(props);\n};\nexport function AiOutlineCaretRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M715.8 493.5L335 165.1c-14.2-12.2-35-1.2-35 18.5v656.8c0 19.7 20.8 30.7 35 18.5l380.8-328.4c10.9-9.4 10.9-27.6 0-37z\"}}]})(props);\n};\nexport function AiOutlineCaretUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M858.9 689L530.5 308.2c-9.4-10.9-27.5-10.9-37 0L165.1 689c-12.2 14.2-1.2 35 18.5 35h656.8c19.7 0 30.7-20.8 18.5-35z\"}}]})(props);\n};\nexport function AiOutlineCarryOut (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 184H712v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H384v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H144c-17.7 0-32 14.3-32 32v664c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V216c0-17.7-14.3-32-32-32zm-40 656H184V256h128v48c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-48h256v48c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-48h128v584zM688 420h-55.2c-5.1 0-10 2.5-13 6.6L468.9 634.4l-64.7-89c-3-4.1-7.8-6.6-13-6.6H336c-6.5 0-10.3 7.4-6.5 12.7l126.4 174a16.1 16.1 0 0 0 26 0l212.6-292.7c3.8-5.4 0-12.8-6.5-12.8z\"}}]})(props);\n};\nexport function AiOutlineCheckCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M699 353h-46.9c-10.2 0-19.9 4.9-25.9 13.3L469 584.3l-71.2-98.8c-6-8.3-15.6-13.3-25.9-13.3H325c-6.5 0-10.3 7.4-6.5 12.7l124.6 172.8a31.8 31.8 0 0 0 51.7 0l210.6-292c3.9-5.3.1-12.7-6.4-12.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}}]})(props);\n};\nexport function AiOutlineCheckSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M433.1 657.7a31.8 31.8 0 0 0 51.7 0l210.6-292c3.8-5.3 0-12.7-6.5-12.7H642c-10.2 0-19.9 4.9-25.9 13.3L459 584.3l-71.2-98.8c-6-8.3-15.6-13.3-25.9-13.3H315c-6.5 0-10.3 7.4-6.5 12.7l124.6 172.8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}}]})(props);\n};\nexport function AiOutlineCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M912 190h-69.9c-9.8 0-19.1 4.5-25.1 12.2L404.7 724.5 207 474a32 32 0 0 0-25.1-12.2H112c-6.7 0-10.4 7.7-6.3 12.9l273.9 347c12.8 16.2 37.4 16.2 50.3 0l488.4-618.9c4.1-5.1.4-12.8-6.3-12.8z\"}}]})(props);\n};\nexport function AiOutlineChrome (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 512.3v-.3c0-229.8-186.2-416-416-416S96 282.2 96 512v.4c0 229.8 186.2 416 416 416s416-186.2 416-416v-.3.2zm-6.7-74.6l.6 3.3-.6-3.3zM676.7 638.2c53.5-82.2 52.5-189.4-11.1-263.7l162.4-8.4c20.5 44.4 32 93.8 32 145.9 0 185.2-144.6 336.6-327.1 347.4l143.8-221.2zM512 652.3c-77.5 0-140.2-62.7-140.2-140.2 0-77.7 62.7-140.2 140.2-140.2S652.2 434.5 652.2 512 589.5 652.3 512 652.3zm369.2-331.7l-3-5.7 3 5.7zM512 164c121.3 0 228.2 62.1 290.4 156.2l-263.6-13.9c-97.5-5.7-190.2 49.2-222.3 141.1L227.8 311c63.1-88.9 166.9-147 284.2-147zM102.5 585.8c26 145 127.1 264 261.6 315.1C229.6 850 128.5 731 102.5 585.8zM164 512c0-55.9 13.2-108.7 36.6-155.5l119.7 235.4c44.1 86.7 137.4 139.7 234 121.6l-74 145.1C302.9 842.5 164 693.5 164 512zm324.7 415.4c4 .2 8 .4 12 .5-4-.2-8-.3-12-.5z\"}}]})(props);\n};\nexport function AiOutlineCiCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372zm218-572.1h-50.4c-4.4 0-8 3.6-8 8v384.2c0 4.4 3.6 8 8 8H730c4.4 0 8-3.6 8-8V319.9c0-4.4-3.6-8-8-8zm-281.4 49.6c49.5 0 83.1 31.5 87 77.6.4 4.2 3.8 7.4 8 7.4h52.6c2.4 0 4.4-2 4.4-4.4 0-81.2-64-138.1-152.3-138.1C345.4 304 286 373.5 286 488.4v49c0 114 59.4 182.6 162.3 182.6 88 0 152.3-55.1 152.3-132.5 0-2.4-2-4.4-4.4-4.4h-52.7c-4.2 0-7.6 3.2-8 7.3-4.2 43-37.7 72.4-87 72.4-61.1 0-95.6-44.9-95.6-125.2v-49.3c.1-81.4 34.6-126.8 95.7-126.8z\"}}]})(props);\n};\nexport function AiOutlineCi (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372zm218-572.1h-50.4c-4.4 0-8 3.6-8 8v384.2c0 4.4 3.6 8 8 8H730c4.4 0 8-3.6 8-8V319.9c0-4.4-3.6-8-8-8zm-281.4 49.6c49.5 0 83.1 31.5 87 77.6.4 4.2 3.8 7.4 8 7.4h52.6c2.4 0 4.4-2 4.4-4.4 0-81.2-64-138.1-152.3-138.1C345.4 304 286 373.5 286 488.4v49c0 114 59.4 182.6 162.3 182.6 88 0 152.3-55.1 152.3-132.5 0-2.4-2-4.4-4.4-4.4h-52.7c-4.2 0-7.6 3.2-8 7.3-4.2 43-37.7 72.4-87 72.4-61.1 0-95.6-44.9-95.6-125.2v-49.3c.1-81.4 34.6-126.8 95.7-126.8z\"}}]})(props);\n};\nexport function AiOutlineClear (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683368540\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M899.1 869.6l-53-305.6H864c14.4 0 26-11.6 26-26V346c0-14.4-11.6-26-26-26H618V138c0-14.4-11.6-26-26-26H432c-14.4 0-26 11.6-26 26v182H160c-14.4 0-26 11.6-26 26v192c0 14.4 11.6 26 26 26h17.9l-53 305.6c-0.3 1.5-0.4 3-0.4 4.4 0 14.4 11.6 26 26 26h723c1.5 0 3-0.1 4.4-0.4 14.2-2.4 23.7-15.9 21.2-30zM204 390h272V182h72v208h272v104H204V390z m468 440V674c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v156H416V674c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v156H202.8l45.1-260H776l45.1 260H672z\"}}]})(props);\n};\nexport function AiOutlineClockCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M686.7 638.6L544.1 535.5V288c0-4.4-3.6-8-8-8H488c-4.4 0-8 3.6-8 8v275.4c0 2.6 1.2 5 3.3 6.5l165.4 120.6c3.6 2.6 8.6 1.8 11.2-1.7l28.6-39c2.6-3.7 1.8-8.7-1.8-11.2z\"}}]})(props);\n};\nexport function AiOutlineCloseCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M685.4 354.8c0-4.4-3.6-8-8-8l-66 .3L512 465.6l-99.3-118.4-66.1-.3c-4.4 0-8 3.5-8 8 0 1.9.7 3.7 1.9 5.2l130.1 155L340.5 670a8.32 8.32 0 0 0-1.9 5.2c0 4.4 3.6 8 8 8l66.1-.3L512 564.4l99.3 118.4 66 .3c4.4 0 8-3.5 8-8 0-1.9-.7-3.7-1.9-5.2L553.5 515l130.1-155c1.2-1.4 1.8-3.3 1.8-5.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 65C264.6 65 64 265.6 64 513s200.6 448 448 448 448-200.6 448-448S759.4 65 512 65zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}}]})(props);\n};\nexport function AiOutlineCloseSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M354 671h58.9c4.7 0 9.2-2.1 12.3-5.7L512 561.8l86.8 103.5c3 3.6 7.5 5.7 12.3 5.7H670c6.8 0 10.5-7.9 6.1-13.1L553.8 512l122.4-145.9c4.4-5.2.7-13.1-6.1-13.1h-58.9c-4.7 0-9.2 2.1-12.3 5.7L512 462.2l-86.8-103.5c-3-3.6-7.5-5.7-12.3-5.7H354c-6.8 0-10.5 7.9-6.1 13.1L470.2 512 347.9 657.9A7.95 7.95 0 0 0 354 671z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}}]})(props);\n};\nexport function AiOutlineClose (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M563.8 512l262.5-312.9c4.4-5.2.7-13.1-6.1-13.1h-79.8c-4.7 0-9.2 2.1-12.3 5.7L511.6 449.8 295.1 191.7c-3-3.6-7.5-5.7-12.3-5.7H203c-6.8 0-10.5 7.9-6.1 13.1L459.4 512 196.9 824.9A7.95 7.95 0 0 0 203 838h79.8c4.7 0 9.2-2.1 12.3-5.7l216.5-258.1 216.5 258.1c3 3.6 7.5 5.7 12.3 5.7h79.8c6.8 0 10.5-7.9 6.1-13.1L563.8 512z\"}}]})(props);\n};\nexport function AiOutlineCloudDownload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M624 706.3h-74.1V464c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8v242.3H400c-6.7 0-10.4 7.7-6.3 12.9l112 141.7a8 8 0 0 0 12.6 0l112-141.7c4.1-5.2.4-12.9-6.3-12.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M811.4 366.7C765.6 245.9 648.9 160 512.2 160S258.8 245.8 213 366.6C127.3 389.1 64 467.2 64 560c0 110.5 89.5 200 199.9 200H304c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8h-40.1c-33.7 0-65.4-13.4-89-37.7-23.5-24.2-36-56.8-34.9-90.6.9-26.4 9.9-51.2 26.2-72.1 16.7-21.3 40.1-36.8 66.1-43.7l37.9-9.9 13.9-36.6c8.6-22.8 20.6-44.1 35.7-63.4a245.6 245.6 0 0 1 52.4-49.9c41.1-28.9 89.5-44.2 140-44.2s98.9 15.3 140 44.2c19.9 14 37.5 30.8 52.4 49.9 15.1 19.3 27.1 40.7 35.7 63.4l13.8 36.5 37.8 10C846.1 454.5 884 503.8 884 560c0 33.1-12.9 64.3-36.3 87.7a123.07 123.07 0 0 1-87.6 36.3H720c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h40.1C870.5 760 960 670.5 960 560c0-92.7-63.1-170.7-148.6-193.3z\"}}]})(props);\n};\nexport function AiOutlineCloudServer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M704 446H320c-4.4 0-8 3.6-8 8v402c0 4.4 3.6 8 8 8h384c4.4 0 8-3.6 8-8V454c0-4.4-3.6-8-8-8zm-328 64h272v117H376V510zm272 290H376V683h272v117z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M424 748a32 32 0 1 0 64 0 32 32 0 1 0-64 0zm0-178a32 32 0 1 0 64 0 32 32 0 1 0-64 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M811.4 368.9C765.6 248 648.9 162 512.2 162S258.8 247.9 213 368.8C126.9 391.5 63.5 470.2 64 563.6 64.6 668 145.6 752.9 247.6 762c4.7.4 8.7-3.3 8.7-8v-60.4c0-4-3-7.4-7-7.9-27-3.4-52.5-15.2-72.1-34.5-24-23.5-37.2-55.1-37.2-88.6 0-28 9.1-54.4 26.2-76.4 16.7-21.4 40.2-36.9 66.1-43.7l37.9-10 13.9-36.7c8.6-22.8 20.6-44.2 35.7-63.5 14.9-19.2 32.6-36 52.4-50 41.1-28.9 89.5-44.2 140-44.2s98.9 15.3 140 44.3c19.9 14 37.5 30.8 52.4 50 15.1 19.3 27.1 40.7 35.7 63.5l13.8 36.6 37.8 10c54.2 14.4 92.1 63.7 92.1 120 0 33.6-13.2 65.1-37.2 88.6-19.5 19.2-44.9 31.1-71.9 34.5-4 .5-6.9 3.9-6.9 7.9V754c0 4.7 4.1 8.4 8.8 8 101.7-9.2 182.5-94 183.2-198.2.6-93.4-62.7-172.1-148.6-194.9z\"}}]})(props);\n};\nexport function AiOutlineCloudSync (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M811.4 368.9C765.6 248 648.9 162 512.2 162S258.8 247.9 213 368.8C126.9 391.5 63.5 470.2 64 563.6 64.6 668 145.6 752.9 247.6 762c4.7.4 8.7-3.3 8.7-8v-60.4c0-4-3-7.4-7-7.9-27-3.4-52.5-15.2-72.1-34.5-24-23.5-37.2-55.1-37.2-88.6 0-28 9.1-54.4 26.2-76.4 16.7-21.4 40.2-36.9 66.1-43.7l37.9-10 13.9-36.7c8.6-22.8 20.6-44.2 35.7-63.5 14.9-19.2 32.6-36 52.4-50 41.1-28.9 89.5-44.2 140-44.2s98.9 15.3 140 44.3c19.9 14 37.5 30.8 52.4 50 15.1 19.3 27.1 40.7 35.7 63.5l13.8 36.6 37.8 10c54.2 14.4 92.1 63.7 92.1 120 0 33.6-13.2 65.1-37.2 88.6-19.5 19.2-44.9 31.1-71.9 34.5-4 .5-6.9 3.9-6.9 7.9V754c0 4.7 4.1 8.4 8.8 8 101.7-9.2 182.5-94 183.2-198.2.6-93.4-62.7-172.1-148.6-194.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M376.9 656.4c1.8-33.5 15.7-64.7 39.5-88.6 25.4-25.5 60-39.8 96-39.8 36.2 0 70.3 14.1 96 39.8 1.4 1.4 2.7 2.8 4.1 4.3l-25 19.6a8 8 0 0 0 3 14.1l98.2 24c5 1.2 9.9-2.6 9.9-7.7l.5-101.3c0-6.7-7.6-10.5-12.9-6.3L663 532.7c-36.6-42-90.4-68.6-150.5-68.6-107.4 0-195 85.1-199.4 191.7-.2 4.5 3.4 8.3 8 8.3H369c4.2-.1 7.7-3.4 7.9-7.7zM703 664h-47.9c-4.2 0-7.7 3.3-8 7.6-1.8 33.5-15.7 64.7-39.5 88.6-25.4 25.5-60 39.8-96 39.8-36.2 0-70.3-14.1-96-39.8-1.4-1.4-2.7-2.8-4.1-4.3l25-19.6a8 8 0 0 0-3-14.1l-98.2-24c-5-1.2-9.9 2.6-9.9 7.7l-.4 101.4c0 6.7 7.6 10.5 12.9 6.3l23.2-18.2c36.6 42 90.4 68.6 150.5 68.6 107.4 0 195-85.1 199.4-191.7.2-4.5-3.4-8.3-8-8.3z\"}}]})(props);\n};\nexport function AiOutlineCloudUpload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M518.3 459a8 8 0 0 0-12.6 0l-112 141.7a7.98 7.98 0 0 0 6.3 12.9h73.9V856c0 4.4 3.6 8 8 8h60c4.4 0 8-3.6 8-8V613.7H624c6.7 0 10.4-7.7 6.3-12.9L518.3 459z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M811.4 366.7C765.6 245.9 648.9 160 512.2 160S258.8 245.8 213 366.6C127.3 389.1 64 467.2 64 560c0 110.5 89.5 200 199.9 200H304c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8h-40.1c-33.7 0-65.4-13.4-89-37.7-23.5-24.2-36-56.8-34.9-90.6.9-26.4 9.9-51.2 26.2-72.1 16.7-21.3 40.1-36.8 66.1-43.7l37.9-9.9 13.9-36.6c8.6-22.8 20.6-44.1 35.7-63.4a245.6 245.6 0 0 1 52.4-49.9c41.1-28.9 89.5-44.2 140-44.2s98.9 15.3 140 44.2c19.9 14 37.5 30.8 52.4 49.9 15.1 19.3 27.1 40.7 35.7 63.4l13.8 36.5 37.8 10C846.1 454.5 884 503.8 884 560c0 33.1-12.9 64.3-36.3 87.7a123.07 123.07 0 0 1-87.6 36.3H720c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h40.1C870.5 760 960 670.5 960 560c0-92.7-63.1-170.7-148.6-193.3z\"}}]})(props);\n};\nexport function AiOutlineCloud (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M811.4 418.7C765.6 297.9 648.9 212 512.2 212S258.8 297.8 213 418.6C127.3 441.1 64 519.1 64 612c0 110.5 89.5 200 199.9 200h496.2C870.5 812 960 722.5 960 612c0-92.7-63.1-170.7-148.6-193.3zm36.3 281a123.07 123.07 0 0 1-87.6 36.3H263.9c-33.1 0-64.2-12.9-87.6-36.3A123.3 123.3 0 0 1 140 612c0-28 9.1-54.3 26.2-76.3a125.7 125.7 0 0 1 66.1-43.7l37.9-9.9 13.9-36.6c8.6-22.8 20.6-44.1 35.7-63.4a245.6 245.6 0 0 1 52.4-49.9c41.1-28.9 89.5-44.2 140-44.2s98.9 15.3 140 44.2c19.9 14 37.5 30.8 52.4 49.9 15.1 19.3 27.1 40.7 35.7 63.4l13.8 36.5 37.8 10c54.3 14.5 92.1 63.8 92.1 120 0 33.1-12.9 64.3-36.3 87.7z\"}}]})(props);\n};\nexport function AiOutlineCluster (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M888 680h-54V540H546v-92h238c8.8 0 16-7.2 16-16V168c0-8.8-7.2-16-16-16H240c-8.8 0-16 7.2-16 16v264c0 8.8 7.2 16 16 16h238v92H190v140h-54c-4.4 0-8 3.6-8 8v176c0 4.4 3.6 8 8 8h176c4.4 0 8-3.6 8-8V688c0-4.4-3.6-8-8-8h-54v-72h220v72h-54c-4.4 0-8 3.6-8 8v176c0 4.4 3.6 8 8 8h176c4.4 0 8-3.6 8-8V688c0-4.4-3.6-8-8-8h-54v-72h220v72h-54c-4.4 0-8 3.6-8 8v176c0 4.4 3.6 8 8 8h176c4.4 0 8-3.6 8-8V688c0-4.4-3.6-8-8-8zM256 805.3c0 1.5-1.2 2.7-2.7 2.7h-58.7c-1.5 0-2.7-1.2-2.7-2.7v-58.7c0-1.5 1.2-2.7 2.7-2.7h58.7c1.5 0 2.7 1.2 2.7 2.7v58.7zm288 0c0 1.5-1.2 2.7-2.7 2.7h-58.7c-1.5 0-2.7-1.2-2.7-2.7v-58.7c0-1.5 1.2-2.7 2.7-2.7h58.7c1.5 0 2.7 1.2 2.7 2.7v58.7zM288 384V216h448v168H288zm544 421.3c0 1.5-1.2 2.7-2.7 2.7h-58.7c-1.5 0-2.7-1.2-2.7-2.7v-58.7c0-1.5 1.2-2.7 2.7-2.7h58.7c1.5 0 2.7 1.2 2.7 2.7v58.7zM360 300a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}}]})(props);\n};\nexport function AiOutlineCodeSandbox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M709.6 210l.4-.2h.2L512 96 313.9 209.8h-.2l.7.3L151.5 304v416L512 928l360.5-208V304l-162.9-94zM482.7 843.6L339.6 761V621.4L210 547.8V372.9l272.7 157.3v313.4zM238.2 321.5l134.7-77.8 138.9 79.7 139.1-79.9 135.2 78-273.9 158-274-158zM814 548.3l-128.8 73.1v139.1l-143.9 83V530.4L814 373.1v175.2z\"}}]})(props);\n};\nexport function AiOutlineCode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M516 673c0 4.4 3.4 8 7.5 8h185c4.1 0 7.5-3.6 7.5-8v-48c0-4.4-3.4-8-7.5-8h-185c-4.1 0-7.5 3.6-7.5 8v48zm-194.9 6.1l192-161c3.8-3.2 3.8-9.1 0-12.3l-192-160.9A7.95 7.95 0 0 0 308 351v62.7c0 2.4 1 4.6 2.9 6.1L420.7 512l-109.8 92.2a8.1 8.1 0 0 0-2.9 6.1V673c0 6.8 7.9 10.5 13.1 6.1zM880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}}]})(props);\n};\nexport function AiOutlineCodepenCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M488.1 414.7V303.4L300.9 428l83.6 55.8zm254.1 137.7v-79.8l-59.8 39.9zM512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm278 533c0 1.1-.1 2.1-.2 3.1 0 .4-.1.7-.2 1a14.16 14.16 0 0 1-.8 3.2c-.2.6-.4 1.2-.6 1.7-.2.4-.4.8-.5 1.2-.3.5-.5 1.1-.8 1.6-.2.4-.4.7-.7 1.1-.3.5-.7 1-1 1.5-.3.4-.5.7-.8 1-.4.4-.8.9-1.2 1.3-.3.3-.6.6-1 .9-.4.4-.9.8-1.4 1.1-.4.3-.7.6-1.1.8-.1.1-.3.2-.4.3L525.2 786c-4 2.7-8.6 4-13.2 4-4.7 0-9.3-1.4-13.3-4L244.6 616.9c-.1-.1-.3-.2-.4-.3l-1.1-.8c-.5-.4-.9-.7-1.3-1.1-.3-.3-.6-.6-1-.9-.4-.4-.8-.8-1.2-1.3a7 7 0 0 1-.8-1c-.4-.5-.7-1-1-1.5-.2-.4-.5-.7-.7-1.1-.3-.5-.6-1.1-.8-1.6-.2-.4-.4-.8-.5-1.2-.2-.6-.4-1.2-.6-1.7-.1-.4-.3-.8-.4-1.2-.2-.7-.3-1.3-.4-2-.1-.3-.1-.7-.2-1-.1-1-.2-2.1-.2-3.1V427.9c0-1 .1-2.1.2-3.1.1-.3.1-.7.2-1a14.16 14.16 0 0 1 .8-3.2c.2-.6.4-1.2.6-1.7.2-.4.4-.8.5-1.2.2-.5.5-1.1.8-1.6.2-.4.4-.7.7-1.1.6-.9 1.2-1.7 1.8-2.5.4-.4.8-.9 1.2-1.3.3-.3.6-.6 1-.9.4-.4.9-.8 1.3-1.1.4-.3.7-.6 1.1-.8.1-.1.3-.2.4-.3L498.7 239c8-5.3 18.5-5.3 26.5 0l254.1 169.1c.1.1.3.2.4.3l1.1.8 1.4 1.1c.3.3.6.6 1 .9.4.4.8.8 1.2 1.3.7.8 1.3 1.6 1.8 2.5.2.4.5.7.7 1.1.3.5.6 1 .8 1.6.2.4.4.8.5 1.2.2.6.4 1.2.6 1.7.1.4.3.8.4 1.2.2.7.3 1.3.4 2 .1.3.1.7.2 1 .1 1 .2 2.1.2 3.1V597zm-254.1 13.3v111.3L723.1 597l-83.6-55.8zM281.8 472.6v79.8l59.8-39.9zM512 456.1l-84.5 56.4 84.5 56.4 84.5-56.4zM723.1 428L535.9 303.4v111.3l103.6 69.1zM384.5 541.2L300.9 597l187.2 124.6V610.3l-103.6-69.1z\"}}]})(props);\n};\nexport function AiOutlineCodepen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M911.7 385.3l-.3-1.5c-.2-1-.3-1.9-.6-2.9-.2-.6-.4-1.1-.5-1.7-.3-.8-.5-1.7-.9-2.5-.2-.6-.5-1.1-.8-1.7-.4-.8-.8-1.5-1.2-2.3-.3-.5-.6-1.1-1-1.6-.8-1.2-1.7-2.4-2.6-3.6-.5-.6-1.1-1.3-1.7-1.9-.4-.5-.9-.9-1.4-1.3-.6-.6-1.3-1.1-1.9-1.6-.5-.4-1-.8-1.6-1.2-.2-.1-.4-.3-.6-.4L531.1 117.8a34.3 34.3 0 0 0-38.1 0L127.3 361.3c-.2.1-.4.3-.6.4-.5.4-1 .8-1.6 1.2-.7.5-1.3 1.1-1.9 1.6-.5.4-.9.9-1.4 1.3-.6.6-1.2 1.2-1.7 1.9-1 1.1-1.8 2.3-2.6 3.6-.3.5-.7 1-1 1.6-.4.7-.8 1.5-1.2 2.3-.3.5-.5 1.1-.8 1.7-.3.8-.6 1.7-.9 2.5-.2.6-.4 1.1-.5 1.7-.2.9-.4 1.9-.6 2.9l-.3 1.5c-.2 1.5-.3 3-.3 4.5v243.5c0 1.5.1 3 .3 4.5l.3 1.5.6 2.9c.2.6.3 1.1.5 1.7.3.9.6 1.7.9 2.5.2.6.5 1.1.8 1.7.4.8.7 1.5 1.2 2.3.3.5.6 1.1 1 1.6.5.7.9 1.4 1.5 2.1l1.2 1.5c.5.6 1.1 1.3 1.7 1.9.4.5.9.9 1.4 1.3.6.6 1.3 1.1 1.9 1.6.5.4 1 .8 1.6 1.2.2.1.4.3.6.4L493 905.7c5.6 3.8 12.3 5.8 19.1 5.8 6.6 0 13.3-1.9 19.1-5.8l365.6-243.5c.2-.1.4-.3.6-.4.5-.4 1-.8 1.6-1.2.7-.5 1.3-1.1 1.9-1.6.5-.4.9-.9 1.4-1.3.6-.6 1.2-1.2 1.7-1.9l1.2-1.5 1.5-2.1c.3-.5.7-1 1-1.6.4-.8.8-1.5 1.2-2.3.3-.5.5-1.1.8-1.7.3-.8.6-1.7.9-2.5.2-.5.4-1.1.5-1.7.3-.9.4-1.9.6-2.9l.3-1.5c.2-1.5.3-3 .3-4.5V389.8c-.3-1.5-.4-3-.6-4.5zM546.4 210.5l269.4 179.4-120.3 80.4-149-99.6V210.5zm-68.8 0v160.2l-149 99.6-120.3-80.4 269.3-179.4zM180.7 454.1l86 57.5-86 57.5v-115zm296.9 358.5L208.3 633.2l120.3-80.4 149 99.6v160.2zM512 592.8l-121.6-81.2L512 430.3l121.6 81.2L512 592.8zm34.4 219.8V652.4l149-99.6 120.3 80.4-269.3 179.4zM843.3 569l-86-57.5 86-57.5v115z\"}}]})(props);\n};\nexport function AiOutlineCoffee (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M275 281c19.9 0 36-16.1 36-36V36c0-19.9-16.1-36-36-36s-36 16.1-36 36v209c0 19.9 16.1 36 36 36zm613 144H768c0-39.8-32.2-72-72-72H200c-39.8 0-72 32.2-72 72v248c0 3.4.2 6.7.7 9.9-.5 7-.7 14-.7 21.1 0 176.7 143.3 320 320 320 160.1 0 292.7-117.5 316.3-271H888c39.8 0 72-32.2 72-72V497c0-39.8-32.2-72-72-72zM696 681h-1.1c.7 7.6 1.1 15.2 1.1 23 0 137-111 248-248 248S200 841 200 704c0-7.8.4-15.4 1.1-23H200V425h496v256zm192-8H776V497h112v176zM613 281c19.9 0 36-16.1 36-36V36c0-19.9-16.1-36-36-36s-36 16.1-36 36v209c0 19.9 16.1 36 36 36zm-170 0c19.9 0 36-16.1 36-36V36c0-19.9-16.1-36-36-36s-36 16.1-36 36v209c0 19.9 16.1 36 36 36z\"}}]})(props);\n};\nexport function AiOutlineColumnHeight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M840 836H184c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h656c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8zm0-724H184c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h656c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8zM610.8 378c6 0 9.4-7 5.7-11.7L515.7 238.7a7.14 7.14 0 0 0-11.3 0L403.6 366.3a7.23 7.23 0 0 0 5.7 11.7H476v268h-62.8c-6 0-9.4 7-5.7 11.7l100.8 127.5c2.9 3.7 8.5 3.7 11.3 0l100.8-127.5c3.7-4.7.4-11.7-5.7-11.7H548V378h62.8z\"}}]})(props);\n};\nexport function AiOutlineColumnWidth (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M180 176h-60c-4.4 0-8 3.6-8 8v656c0 4.4 3.6 8 8 8h60c4.4 0 8-3.6 8-8V184c0-4.4-3.6-8-8-8zm724 0h-60c-4.4 0-8 3.6-8 8v656c0 4.4 3.6 8 8 8h60c4.4 0 8-3.6 8-8V184c0-4.4-3.6-8-8-8zM785.3 504.3L657.7 403.6a7.23 7.23 0 0 0-11.7 5.7V476H378v-62.8c0-6-7-9.4-11.7-5.7L238.7 508.3a7.14 7.14 0 0 0 0 11.3l127.5 100.8c4.7 3.7 11.7.4 11.7-5.7V548h268v62.8c0 6 7 9.4 11.7 5.7l127.5-100.8c3.8-2.9 3.8-8.5.2-11.4z\"}}]})(props);\n};\nexport function AiOutlineComment (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569682881658\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M573 421c-23.1 0-41 17.9-41 40s17.9 40 41 40c21.1 0 39-17.9 39-40s-17.9-40-39-40zM293 421c-23.1 0-41 17.9-41 40s17.9 40 41 40c21.1 0 39-17.9 39-40s-17.9-40-39-40z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M894 345c-48.1-66-115.3-110.1-189-130v0.1c-17.1-19-36.4-36.5-58-52.1-163.7-119-393.5-82.7-513 81-96.3 133-92.2 311.9 6 439l0.8 132.6c0 3.2 0.5 6.4 1.5 9.4 5.3 16.9 23.3 26.2 40.1 20.9L309 806c33.5 11.9 68.1 18.7 102.5 20.6l-0.5 0.4c89.1 64.9 205.9 84.4 313 49l127.1 41.4c3.2 1 6.5 1.6 9.9 1.6 17.7 0 32-14.3 32-32V753c88.1-119.6 90.4-284.9 1-408zM323 735l-12-5-99 31-1-104-8-9c-84.6-103.2-90.2-251.9-11-361 96.4-132.2 281.2-161.4 413-66 132.2 96.1 161.5 280.6 66 412-80.1 109.9-223.5 150.5-348 102z m505-17l-8 10 1 104-98-33-12 5c-56 20.8-115.7 22.5-171 7l-0.2-0.1C613.7 788.2 680.7 742.2 729 676c76.4-105.3 88.8-237.6 44.4-350.4l0.6 0.4c23 16.5 44.1 37.1 62 62 72.6 99.6 68.5 235.2-8 330z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M433 421c-23.1 0-41 17.9-41 40s17.9 40 41 40c21.1 0 39-17.9 39-40s-17.9-40-39-40z\"}}]})(props);\n};\nexport function AiOutlineCompass (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372zm198.4-588.1a32 32 0 0 0-24.5.5L414.9 415 296.4 686c-3.6 8.2-3.6 17.5 0 25.7 3.4 7.8 9.7 13.9 17.7 17 3.8 1.5 7.7 2.2 11.7 2.2 4.4 0 8.7-.9 12.8-2.7l271-118.6 118.5-271a32.06 32.06 0 0 0-17.7-42.7zM576.8 534.4l26.2 26.2-42.4 42.4-26.2-26.2L380 644.4 447.5 490 422 464.4l42.4-42.4 25.5 25.5L644.4 380l-67.6 154.4zM464.4 422L422 464.4l25.5 25.6 86.9 86.8 26.2 26.2 42.4-42.4-26.2-26.2-86.8-86.9z\"}}]})(props);\n};\nexport function AiOutlineCompress (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683667781\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M326 664H104c-8.8 0-16 7.2-16 16v48c0 8.8 7.2 16 16 16h174v176c0 8.8 7.2 16 16 16h48c8.8 0 16-7.2 16-16V696c0-17.7-14.3-32-32-32zM342 88h-48c-8.8 0-16 7.2-16 16v176H104c-8.8 0-16 7.2-16 16v48c0 8.8 7.2 16 16 16h222c17.7 0 32-14.3 32-32V104c0-8.8-7.2-16-16-16zM920 664H698c-17.7 0-32 14.3-32 32v224c0 8.8 7.2 16 16 16h48c8.8 0 16-7.2 16-16V744h174c8.8 0 16-7.2 16-16v-48c0-8.8-7.2-16-16-16zM920 280H746V104c0-8.8-7.2-16-16-16h-48c-8.8 0-16 7.2-16 16v224c0 17.7 14.3 32 32 32h222c8.8 0 16-7.2 16-16v-48c0-8.8-7.2-16-16-16z\"}}]})(props);\n};\nexport function AiOutlineConsoleSql (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683650778\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M301.3 496.7c-23.8 0-40.2-10.5-41.6-26.9H205c0.9 43.4 36.9 70.3 93.9 70.3 59.1 0 95-28.4 95-75.5 0-35.8-20-55.9-64.5-64.5l-29.1-5.6c-23.8-4.7-33.8-11.9-33.8-24.2 0-15 13.3-24.5 33.4-24.5 20.1 0 35.3 11.1 36.6 27h53c-0.9-41.7-37.5-70.3-90.3-70.3-54.4 0-89.7 28.9-89.7 73 0 35.5 21.2 58 62.5 65.8l29.7 5.9c25.8 5.2 35.6 11.9 35.6 24.4 0.1 14.7-14.5 25.1-36 25.1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M928 140H96c-17.7 0-32 14.3-32 32v496c0 17.7 14.3 32 32 32h380v112H304c-8.8 0-16 7.2-16 16v48c0 4.4 3.6 8 8 8h432c4.4 0 8-3.6 8-8v-48c0-8.8-7.2-16-16-16H548V700h380c17.7 0 32-14.3 32-32V172c0-17.7-14.3-32-32-32z m-40 488H136V212h752v416z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M828.5 486.7h-95.8V308.5h-57.4V534h153.2zM529.9 540.1c14.1 0 27.2-2 39.1-5.8l13.3 20.3h53.3L607.9 511c21.1-20 33-51.1 33-89.8 0-73.3-43.3-118.8-110.9-118.8s-111.2 45.3-111.2 118.8c-0.1 73.7 43 118.9 111.1 118.9z m0-190c31.6 0 52.7 27.7 52.7 71.1 0 16.7-3.6 30.6-10 40.5l-5.2-6.9h-48.8L542 491c-3.9 0.9-8 1.4-12.2 1.4-31.7 0-52.8-27.5-52.8-71.2 0.1-43.6 21.2-71.1 52.9-71.1z\"}}]})(props);\n};\nexport function AiOutlineContacts (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M594.3 601.5a111.8 111.8 0 0 0 29.1-75.5c0-61.9-49.9-112-111.4-112s-111.4 50.1-111.4 112c0 29.1 11 55.5 29.1 75.5a158.09 158.09 0 0 0-74.6 126.1 8 8 0 0 0 8 8.4H407c4.2 0 7.6-3.3 7.9-7.5 3.8-50.6 46-90.5 97.2-90.5s93.4 40 97.2 90.5c.3 4.2 3.7 7.5 7.9 7.5H661a8 8 0 0 0 8-8.4c-2.8-53.3-32-99.7-74.7-126.1zM512 578c-28.5 0-51.7-23.3-51.7-52s23.2-52 51.7-52 51.7 23.3 51.7 52-23.2 52-51.7 52zm416-354H768v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H548v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H328v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H96c-17.7 0-32 14.3-32 32v576c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V256c0-17.7-14.3-32-32-32zm-40 568H136V296h120v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56h148v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56h148v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56h120v496z\"}}]})(props);\n};\nexport function AiOutlineContainer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V96c0-17.7-14.3-32-32-32zm-40 824H232V687h97.9c11.6 32.8 32 62.3 59.1 84.7 34.5 28.5 78.2 44.3 123 44.3s88.5-15.7 123-44.3c27.1-22.4 47.5-51.9 59.1-84.7H792v-63H643.6l-5.2 24.7C626.4 708.5 573.2 752 512 752s-114.4-43.5-126.5-103.3l-5.2-24.7H232V136h560v752zM320 341h384c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H320c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8zm0 160h384c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H320c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlineControl (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656zM340 683v77c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-77c-10.1 3.3-20.8 5-32 5s-21.9-1.8-32-5zm64-198V264c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v221c10.1-3.3 20.8-5 32-5s21.9 1.8 32 5zm-64 198c10.1 3.3 20.8 5 32 5s21.9-1.8 32-5c41.8-13.5 72-52.7 72-99s-30.2-85.5-72-99c-10.1-3.3-20.8-5-32-5s-21.9 1.8-32 5c-41.8 13.5-72 52.7-72 99s30.2 85.5 72 99zm.1-115.7c.3-.6.7-1.2 1-1.8v-.1l1.2-1.8c.1-.2.2-.3.3-.5.3-.5.7-.9 1-1.4.1-.1.2-.3.3-.4.5-.6.9-1.1 1.4-1.6l.3-.3 1.2-1.2.4-.4c.5-.5 1-.9 1.6-1.4.6-.5 1.1-.9 1.7-1.3.2-.1.3-.2.5-.3.5-.3.9-.7 1.4-1 .1-.1.3-.2.4-.3.6-.4 1.2-.7 1.9-1.1.1-.1.3-.1.4-.2.5-.3 1-.5 1.6-.8l.6-.3c.7-.3 1.3-.6 2-.8.7-.3 1.4-.5 2.1-.7.2-.1.4-.1.6-.2.6-.2 1.1-.3 1.7-.4.2 0 .3-.1.5-.1.7-.2 1.5-.3 2.2-.4.2 0 .3 0 .5-.1.6-.1 1.2-.1 1.8-.2h.6c.8 0 1.5-.1 2.3-.1s1.5 0 2.3.1h.6c.6 0 1.2.1 1.8.2.2 0 .3 0 .5.1.7.1 1.5.2 2.2.4.2 0 .3.1.5.1.6.1 1.2.3 1.7.4.2.1.4.1.6.2.7.2 1.4.4 2.1.7.7.2 1.3.5 2 .8l.6.3c.5.2 1.1.5 1.6.8.1.1.3.1.4.2.6.3 1.3.7 1.9 1.1.1.1.3.2.4.3.5.3 1 .6 1.4 1 .2.1.3.2.5.3.6.4 1.2.9 1.7 1.3s1.1.9 1.6 1.4l.4.4 1.2 1.2.3.3c.5.5 1 1.1 1.4 1.6.1.1.2.3.3.4.4.4.7.9 1 1.4.1.2.2.3.3.5l1.2 1.8s0 .1.1.1a36.18 36.18 0 0 1 5.1 18.5c0 6-1.5 11.7-4.1 16.7-.3.6-.7 1.2-1 1.8 0 0 0 .1-.1.1l-1.2 1.8c-.1.2-.2.3-.3.5-.3.5-.7.9-1 1.4-.1.1-.2.3-.3.4-.5.6-.9 1.1-1.4 1.6l-.3.3-1.2 1.2-.4.4c-.5.5-1 .9-1.6 1.4-.6.5-1.1.9-1.7 1.3-.2.1-.3.2-.5.3-.5.3-.9.7-1.4 1-.1.1-.3.2-.4.3-.6.4-1.2.7-1.9 1.1-.1.1-.3.1-.4.2-.5.3-1 .5-1.6.8l-.6.3c-.7.3-1.3.6-2 .8-.7.3-1.4.5-2.1.7-.2.1-.4.1-.6.2-.6.2-1.1.3-1.7.4-.2 0-.3.1-.5.1-.7.2-1.5.3-2.2.4-.2 0-.3 0-.5.1-.6.1-1.2.1-1.8.2h-.6c-.8 0-1.5.1-2.3.1s-1.5 0-2.3-.1h-.6c-.6 0-1.2-.1-1.8-.2-.2 0-.3 0-.5-.1-.7-.1-1.5-.2-2.2-.4-.2 0-.3-.1-.5-.1-.6-.1-1.2-.3-1.7-.4-.2-.1-.4-.1-.6-.2-.7-.2-1.4-.4-2.1-.7-.7-.2-1.3-.5-2-.8l-.6-.3c-.5-.2-1.1-.5-1.6-.8-.1-.1-.3-.1-.4-.2-.6-.3-1.3-.7-1.9-1.1-.1-.1-.3-.2-.4-.3-.5-.3-1-.6-1.4-1-.2-.1-.3-.2-.5-.3-.6-.4-1.2-.9-1.7-1.3s-1.1-.9-1.6-1.4l-.4-.4-1.2-1.2-.3-.3c-.5-.5-1-1.1-1.4-1.6-.1-.1-.2-.3-.3-.4-.4-.4-.7-.9-1-1.4-.1-.2-.2-.3-.3-.5l-1.2-1.8v-.1c-.4-.6-.7-1.2-1-1.8-2.6-5-4.1-10.7-4.1-16.7s1.5-11.7 4.1-16.7zM620 539v221c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V539c-10.1 3.3-20.8 5-32 5s-21.9-1.8-32-5zm64-198v-77c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v77c10.1-3.3 20.8-5 32-5s21.9 1.8 32 5zm-64 198c10.1 3.3 20.8 5 32 5s21.9-1.8 32-5c41.8-13.5 72-52.7 72-99s-30.2-85.5-72-99c-10.1-3.3-20.8-5-32-5s-21.9 1.8-32 5c-41.8 13.5-72 52.7-72 99s30.2 85.5 72 99zm.1-115.7c.3-.6.7-1.2 1-1.8v-.1l1.2-1.8c.1-.2.2-.3.3-.5.3-.5.7-.9 1-1.4.1-.1.2-.3.3-.4.5-.6.9-1.1 1.4-1.6l.3-.3 1.2-1.2.4-.4c.5-.5 1-.9 1.6-1.4.6-.5 1.1-.9 1.7-1.3.2-.1.3-.2.5-.3.5-.3.9-.7 1.4-1 .1-.1.3-.2.4-.3.6-.4 1.2-.7 1.9-1.1.1-.1.3-.1.4-.2.5-.3 1-.5 1.6-.8l.6-.3c.7-.3 1.3-.6 2-.8.7-.3 1.4-.5 2.1-.7.2-.1.4-.1.6-.2.6-.2 1.1-.3 1.7-.4.2 0 .3-.1.5-.1.7-.2 1.5-.3 2.2-.4.2 0 .3 0 .5-.1.6-.1 1.2-.1 1.8-.2h.6c.8 0 1.5-.1 2.3-.1s1.5 0 2.3.1h.6c.6 0 1.2.1 1.8.2.2 0 .3 0 .5.1.7.1 1.5.2 2.2.4.2 0 .3.1.5.1.6.1 1.2.3 1.7.4.2.1.4.1.6.2.7.2 1.4.4 2.1.7.7.2 1.3.5 2 .8l.6.3c.5.2 1.1.5 1.6.8.1.1.3.1.4.2.6.3 1.3.7 1.9 1.1.1.1.3.2.4.3.5.3 1 .6 1.4 1 .2.1.3.2.5.3.6.4 1.2.9 1.7 1.3s1.1.9 1.6 1.4l.4.4 1.2 1.2.3.3c.5.5 1 1.1 1.4 1.6.1.1.2.3.3.4.4.4.7.9 1 1.4.1.2.2.3.3.5l1.2 1.8v.1a36.18 36.18 0 0 1 5.1 18.5c0 6-1.5 11.7-4.1 16.7-.3.6-.7 1.2-1 1.8v.1l-1.2 1.8c-.1.2-.2.3-.3.5-.3.5-.7.9-1 1.4-.1.1-.2.3-.3.4-.5.6-.9 1.1-1.4 1.6l-.3.3-1.2 1.2-.4.4c-.5.5-1 .9-1.6 1.4-.6.5-1.1.9-1.7 1.3-.2.1-.3.2-.5.3-.5.3-.9.7-1.4 1-.1.1-.3.2-.4.3-.6.4-1.2.7-1.9 1.1-.1.1-.3.1-.4.2-.5.3-1 .5-1.6.8l-.6.3c-.7.3-1.3.6-2 .8-.7.3-1.4.5-2.1.7-.2.1-.4.1-.6.2-.6.2-1.1.3-1.7.4-.2 0-.3.1-.5.1-.7.2-1.5.3-2.2.4-.2 0-.3 0-.5.1-.6.1-1.2.1-1.8.2h-.6c-.8 0-1.5.1-2.3.1s-1.5 0-2.3-.1h-.6c-.6 0-1.2-.1-1.8-.2-.2 0-.3 0-.5-.1-.7-.1-1.5-.2-2.2-.4-.2 0-.3-.1-.5-.1-.6-.1-1.2-.3-1.7-.4-.2-.1-.4-.1-.6-.2-.7-.2-1.4-.4-2.1-.7-.7-.2-1.3-.5-2-.8l-.6-.3c-.5-.2-1.1-.5-1.6-.8-.1-.1-.3-.1-.4-.2-.6-.3-1.3-.7-1.9-1.1-.1-.1-.3-.2-.4-.3-.5-.3-1-.6-1.4-1-.2-.1-.3-.2-.5-.3-.6-.4-1.2-.9-1.7-1.3s-1.1-.9-1.6-1.4l-.4-.4-1.2-1.2-.3-.3c-.5-.5-1-1.1-1.4-1.6-.1-.1-.2-.3-.3-.4-.4-.4-.7-.9-1-1.4-.1-.2-.2-.3-.3-.5l-1.2-1.8v-.1c-.4-.6-.7-1.2-1-1.8-2.6-5-4.1-10.7-4.1-16.7s1.5-11.7 4.1-16.7z\"}}]})(props);\n};\nexport function AiOutlineCopy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H296c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h496v688c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V96c0-17.7-14.3-32-32-32zM704 192H192c-17.7 0-32 14.3-32 32v530.7c0 8.5 3.4 16.6 9.4 22.6l173.3 173.3c2.2 2.2 4.7 4 7.4 5.5v1.9h4.2c3.5 1.3 7.2 2 11 2H704c17.7 0 32-14.3 32-32V224c0-17.7-14.3-32-32-32zM350 856.2L263.9 770H350v86.2zM664 888H414V746c0-22.1-17.9-40-40-40H232V264h432v624z\"}}]})(props);\n};\nexport function AiOutlineCopyrightCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372zm5.6-532.7c53 0 89 33.8 93 83.4.3 4.2 3.8 7.4 8 7.4h56.7c2.6 0 4.7-2.1 4.7-4.7 0-86.7-68.4-147.4-162.7-147.4C407.4 290 344 364.2 344 486.8v52.3C344 660.8 407.4 734 517.3 734c94 0 162.7-58.8 162.7-141.4 0-2.6-2.1-4.7-4.7-4.7h-56.8c-4.2 0-7.6 3.2-8 7.3-4.2 46.1-40.1 77.8-93 77.8-65.3 0-102.1-47.9-102.1-133.6v-52.6c.1-87 37-135.5 102.2-135.5z\"}}]})(props);\n};\nexport function AiOutlineCopyright (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372zm5.6-532.7c53 0 89 33.8 93 83.4.3 4.2 3.8 7.4 8 7.4h56.7c2.6 0 4.7-2.1 4.7-4.7 0-86.7-68.4-147.4-162.7-147.4C407.4 290 344 364.2 344 486.8v52.3C344 660.8 407.4 734 517.3 734c94 0 162.7-58.8 162.7-141.4 0-2.6-2.1-4.7-4.7-4.7h-56.8c-4.2 0-7.6 3.2-8 7.3-4.2 46.1-40.1 77.8-93 77.8-65.3 0-102.1-47.9-102.1-133.6v-52.6c.1-87 37-135.5 102.2-135.5z\"}}]})(props);\n};\nexport function AiOutlineCreditCard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 160H96c-17.7 0-32 14.3-32 32v640c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V192c0-17.7-14.3-32-32-32zm-792 72h752v120H136V232zm752 560H136V440h752v352zm-237-64h165c4.4 0 8-3.6 8-8v-72c0-4.4-3.6-8-8-8H651c-4.4 0-8 3.6-8 8v72c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlineCrown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M899.6 276.5L705 396.4 518.4 147.5a8.06 8.06 0 0 0-12.9 0L319 396.4 124.3 276.5c-5.7-3.5-13.1 1.2-12.2 7.9L188.5 865c1.1 7.9 7.9 14 16 14h615.1c8 0 14.9-6 15.9-14l76.4-580.6c.8-6.7-6.5-11.4-12.3-7.9zm-126 534.1H250.3l-53.8-409.4 139.8 86.1L512 252.9l175.7 234.4 139.8-86.1-53.9 409.4zM512 509c-62.1 0-112.6 50.5-112.6 112.6S449.9 734.2 512 734.2s112.6-50.5 112.6-112.6S574.1 509 512 509zm0 160.9c-26.6 0-48.2-21.6-48.2-48.3 0-26.6 21.6-48.3 48.2-48.3s48.2 21.6 48.2 48.3c0 26.6-21.6 48.3-48.2 48.3z\"}}]})(props);\n};\nexport function AiOutlineCustomerService (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 128c-212.1 0-384 171.9-384 384v360c0 13.3 10.7 24 24 24h184c35.3 0 64-28.7 64-64V624c0-35.3-28.7-64-64-64H200v-48c0-172.3 139.7-312 312-312s312 139.7 312 312v48H688c-35.3 0-64 28.7-64 64v208c0 35.3 28.7 64 64 64h184c13.3 0 24-10.7 24-24V512c0-212.1-171.9-384-384-384zM328 632v192H200V632h128zm496 192H696V632h128v192z\"}}]})(props);\n};\nexport function AiOutlineDash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M112 476h160v72H112zm320 0h160v72H432zm320 0h160v72H752z\"}}]})(props);\n};\nexport function AiOutlineDashboard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M924.8 385.6a446.7 446.7 0 0 0-96-142.4 446.7 446.7 0 0 0-142.4-96C631.1 123.8 572.5 112 512 112s-119.1 11.8-174.4 35.2a446.7 446.7 0 0 0-142.4 96 446.7 446.7 0 0 0-96 142.4C75.8 440.9 64 499.5 64 560c0 132.7 58.3 257.7 159.9 343.1l1.7 1.4c5.8 4.8 13.1 7.5 20.6 7.5h531.7c7.5 0 14.8-2.7 20.6-7.5l1.7-1.4C901.7 817.7 960 692.7 960 560c0-60.5-11.9-119.1-35.2-174.4zM761.4 836H262.6A371.12 371.12 0 0 1 140 560c0-99.4 38.7-192.8 109-263 70.3-70.3 163.7-109 263-109 99.4 0 192.8 38.7 263 109 70.3 70.3 109 163.7 109 263 0 105.6-44.5 205.5-122.6 276zM623.5 421.5a8.03 8.03 0 0 0-11.3 0L527.7 506c-18.7-5-39.4-.2-54.1 14.5a55.95 55.95 0 0 0 0 79.2 55.95 55.95 0 0 0 79.2 0 55.87 55.87 0 0 0 14.5-54.1l84.5-84.5c3.1-3.1 3.1-8.2 0-11.3l-28.3-28.3zM490 320h44c4.4 0 8-3.6 8-8v-80c0-4.4-3.6-8-8-8h-44c-4.4 0-8 3.6-8 8v80c0 4.4 3.6 8 8 8zm260 218v44c0 4.4 3.6 8 8 8h80c4.4 0 8-3.6 8-8v-44c0-4.4-3.6-8-8-8h-80c-4.4 0-8 3.6-8 8zm12.7-197.2l-31.1-31.1a8.03 8.03 0 0 0-11.3 0l-56.6 56.6a8.03 8.03 0 0 0 0 11.3l31.1 31.1c3.1 3.1 8.2 3.1 11.3 0l56.6-56.6c3.1-3.1 3.1-8.2 0-11.3zm-458.6-31.1a8.03 8.03 0 0 0-11.3 0l-31.1 31.1a8.03 8.03 0 0 0 0 11.3l56.6 56.6c3.1 3.1 8.2 3.1 11.3 0l31.1-31.1c3.1-3.1 3.1-8.2 0-11.3l-56.6-56.6zM262 530h-80c-4.4 0-8 3.6-8 8v44c0 4.4 3.6 8 8 8h80c4.4 0 8-3.6 8-8v-44c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineDatabase (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V96c0-17.7-14.3-32-32-32zm-600 72h560v208H232V136zm560 480H232V408h560v208zm0 272H232V680h560v208zM304 240a40 40 0 1 0 80 0 40 40 0 1 0-80 0zm0 272a40 40 0 1 0 80 0 40 40 0 1 0-80 0zm0 272a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}}]})(props);\n};\nexport function AiOutlineDeleteColumn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683386799\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M651.1 641.9c-1.4-1.2-3.2-1.9-5.1-1.9h-54.7c-2.4 0-4.6 1.1-6.1 2.9L512 730.7l-73.1-87.8c-1.5-1.8-3.8-2.9-6.1-2.9H378c-1.9 0-3.7 0.7-5.1 1.9-3.4 2.8-3.9 7.9-1 11.3L474.2 776 371.8 898.9c-2.8 3.4-2.4 8.4 1 11.3 1.4 1.2 3.2 1.9 5.1 1.9h54.7c2.4 0 4.6-1.1 6.1-2.9l73.1-87.8 73.1 87.8c1.5 1.8 3.8 2.9 6.1 2.9h55c1.9 0 3.7-0.7 5.1-1.9 3.4-2.8 3.9-7.9 1-11.3L549.8 776l102.4-122.9c2.8-3.4 2.3-8.4-1.1-11.2zM472 544h80c4.4 0 8-3.6 8-8V120c0-4.4-3.6-8-8-8h-80c-4.4 0-8 3.6-8 8v416c0 4.4 3.6 8 8 8zM350 386H184V136c0-3.3-2.7-6-6-6h-60c-3.3 0-6 2.7-6 6v292c0 16.6 13.4 30 30 30h208c3.3 0 6-2.7 6-6v-60c0-3.3-2.7-6-6-6zM906 130h-60c-3.3 0-6 2.7-6 6v250H674c-3.3 0-6 2.7-6 6v60c0 3.3 2.7 6 6 6h208c16.6 0 30-13.4 30-30V136c0-3.3-2.7-6-6-6z\"}}]})(props);\n};\nexport function AiOutlineDeleteRow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683582196\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M819.8 512l102.4-122.9c2.8-3.4 2.4-8.4-1-11.3-1.4-1.2-3.2-1.9-5.1-1.9h-54.7c-2.4 0-4.6 1.1-6.1 2.9L782 466.7l-73.1-87.8c-1.5-1.8-3.8-2.9-6.1-2.9H648c-1.9 0-3.7 0.7-5.1 1.9-3.4 2.8-3.9 7.9-1 11.3L744.2 512 641.8 634.9c-2.8 3.4-2.4 8.4 1 11.3 1.4 1.2 3.2 1.9 5.1 1.9h54.7c2.4 0 4.6-1.1 6.1-2.9l73.1-87.8 73.1 87.8c1.5 1.8 3.8 2.9 6.1 2.9h55c1.9 0 3.7-0.7 5.1-1.9 3.4-2.8 3.9-7.9 1-11.3L819.8 512zM536 464H120c-4.4 0-8 3.6-8 8v80c0 4.4 3.6 8 8 8h416c4.4 0 8-3.6 8-8v-80c0-4.4-3.6-8-8-8zM452 668h-60c-3.3 0-6 2.7-6 6v166H136c-3.3 0-6 2.7-6 6v60c0 3.3 2.7 6 6 6h292c16.6 0 30-13.4 30-30V674c0-3.3-2.7-6-6-6zM136 184h250v166c0 3.3 2.7 6 6 6h60c3.3 0 6-2.7 6-6V142c0-16.6-13.4-30-30-30H136c-3.3 0-6 2.7-6 6v60c0 3.3 2.7 6 6 6z\"}}]})(props);\n};\nexport function AiOutlineDelete (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M360 184h-8c4.4 0 8-3.6 8-8v8h304v-8c0 4.4 3.6 8 8 8h-8v72h72v-80c0-35.3-28.7-64-64-64H352c-35.3 0-64 28.7-64 64v80h72v-72zm504 72H160c-17.7 0-32 14.3-32 32v32c0 4.4 3.6 8 8 8h60.4l24.7 523c1.6 34.1 29.8 61 63.9 61h454c34.2 0 62.3-26.8 63.9-61l24.7-523H888c4.4 0 8-3.6 8-8v-32c0-17.7-14.3-32-32-32zM731.3 840H292.7l-24.2-512h487l-24.2 512z\"}}]})(props);\n};\nexport function AiOutlineDeliveredProcedure (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683642448\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M632 698.3l141.9-112c4.1-3.2 4.1-9.4 0-12.6L632 461.7c-5.3-4.2-13-0.4-13 6.3v76H295c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h324v76c0 6.7 7.8 10.4 13 6.3zM893.3 293.3L730.7 130.7c-7.5-7.5-16.7-13-26.7-16V112H144c-17.7 0-32 14.3-32 32v278c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V184h136v136c0 17.7 14.3 32 32 32h320c17.7 0 32-14.3 32-32V205.8l136 136V422c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-83.5c0-17-6.7-33.2-18.7-45.2zM640 288H384V184h256v104zM904 724h-56c-4.4 0-8 3.6-8 8v108H184V732c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v148c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V732c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineDeploymentUnit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M888.3 693.2c-42.5-24.6-94.3-18-129.2 12.8l-53-30.7V523.6c0-15.7-8.4-30.3-22-38.1l-136-78.3v-67.1c44.2-15 76-56.8 76-106.1 0-61.9-50.1-112-112-112s-112 50.1-112 112c0 49.3 31.8 91.1 76 106.1v67.1l-136 78.3c-13.6 7.8-22 22.4-22 38.1v151.6l-53 30.7c-34.9-30.8-86.8-37.4-129.2-12.8-53.5 31-71.7 99.4-41 152.9 30.8 53.5 98.9 71.9 152.2 41 42.5-24.6 62.7-73 53.6-118.8l48.7-28.3 140.6 81c6.8 3.9 14.4 5.9 22 5.9s15.2-2 22-5.9L674.5 740l48.7 28.3c-9.1 45.7 11.2 94.2 53.6 118.8 53.3 30.9 121.5 12.6 152.2-41 30.8-53.6 12.6-122-40.7-152.9zm-673 138.4a47.6 47.6 0 0 1-65.2-17.6c-13.2-22.9-5.4-52.3 17.5-65.5a47.6 47.6 0 0 1 65.2 17.6c13.2 22.9 5.4 52.3-17.5 65.5zM522 463.8zM464 234a48.01 48.01 0 0 1 96 0 48.01 48.01 0 0 1-96 0zm170 446.2l-122 70.3-122-70.3V539.8l122-70.3 122 70.3v140.4zm239.9 133.9c-13.2 22.9-42.4 30.8-65.2 17.6-22.8-13.2-30.7-42.6-17.5-65.5s42.4-30.8 65.2-17.6c22.9 13.2 30.7 42.5 17.5 65.5z\"}}]})(props);\n};\nexport function AiOutlineDesktop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 140H96c-17.7 0-32 14.3-32 32v496c0 17.7 14.3 32 32 32h380v112H304c-8.8 0-16 7.2-16 16v48c0 4.4 3.6 8 8 8h432c4.4 0 8-3.6 8-8v-48c0-8.8-7.2-16-16-16H548V700h380c17.7 0 32-14.3 32-32V172c0-17.7-14.3-32-32-32zm-40 488H136V212h752v416z\"}}]})(props);\n};\nexport function AiOutlineDiff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M476 399.1c0-3.9-3.1-7.1-7-7.1h-42c-3.8 0-7 3.2-7 7.1V484h-84.5c-4.1 0-7.5 3.1-7.5 7v42c0 3.8 3.4 7 7.5 7H420v84.9c0 3.9 3.2 7.1 7 7.1h42c3.9 0 7-3.2 7-7.1V540h84.5c4.1 0 7.5-3.2 7.5-7v-42c0-3.9-3.4-7-7.5-7H476v-84.9zM560.5 704h-225c-4.1 0-7.5 3.2-7.5 7v42c0 3.8 3.4 7 7.5 7h225c4.1 0 7.5-3.2 7.5-7v-42c0-3.8-3.4-7-7.5-7zm-7.1-502.6c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v704c0 17.7 14.3 32 32 32h512c17.7 0 32-14.3 32-32V397.3c0-8.5-3.4-16.6-9.4-22.6L553.4 201.4zM664 888H232V264h282.2L664 413.8V888zm190.2-581.4L611.3 72.9c-6-5.7-13.9-8.9-22.2-8.9H296c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h277l219 210.6V824c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V329.6c0-8.7-3.5-17-9.8-23z\"}}]})(props);\n};\nexport function AiOutlineDingding (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M573.7 252.5C422.5 197.4 201.3 96.7 201.3 96.7c-15.7-4.1-17.9 11.1-17.9 11.1-5 61.1 33.6 160.5 53.6 182.8 19.9 22.3 319.1 113.7 319.1 113.7S326 357.9 270.5 341.9c-55.6-16-37.9 17.8-37.9 17.8 11.4 61.7 64.9 131.8 107.2 138.4 42.2 6.6 220.1 4 220.1 4s-35.5 4.1-93.2 11.9c-42.7 5.8-97 12.5-111.1 17.8-33.1 12.5 24 62.6 24 62.6 84.7 76.8 129.7 50.5 129.7 50.5 33.3-10.7 61.4-18.5 85.2-24.2L565 743.1h84.6L603 928l205.3-271.9H700.8l22.3-38.7c.3.5.4.8.4.8S799.8 496.1 829 433.8l.6-1h-.1c5-10.8 8.6-19.7 10-25.8 17-71.3-114.5-99.4-265.8-154.5z\"}}]})(props);\n};\nexport function AiOutlineDingtalk (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M573.7 252.5C422.5 197.4 201.3 96.7 201.3 96.7c-15.7-4.1-17.9 11.1-17.9 11.1-5 61.1 33.6 160.5 53.6 182.8 19.9 22.3 319.1 113.7 319.1 113.7S326 357.9 270.5 341.9c-55.6-16-37.9 17.8-37.9 17.8 11.4 61.7 64.9 131.8 107.2 138.4 42.2 6.6 220.1 4 220.1 4s-35.5 4.1-93.2 11.9c-42.7 5.8-97 12.5-111.1 17.8-33.1 12.5 24 62.6 24 62.6 84.7 76.8 129.7 50.5 129.7 50.5 33.3-10.7 61.4-18.5 85.2-24.2L565 743.1h84.6L603 928l205.3-271.9H700.8l22.3-38.7c.3.5.4.8.4.8S799.8 496.1 829 433.8l.6-1h-.1c5-10.8 8.6-19.7 10-25.8 17-71.3-114.5-99.4-265.8-154.5z\"}}]})(props);\n};\nexport function AiOutlineDisconnect (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832.6 191.4c-84.6-84.6-221.5-84.6-306 0l-96.9 96.9 51 51 96.9-96.9c53.8-53.8 144.6-59.5 204 0 59.5 59.5 53.8 150.2 0 204l-96.9 96.9 51.1 51.1 96.9-96.9c84.4-84.6 84.4-221.5-.1-306.1zM446.5 781.6c-53.8 53.8-144.6 59.5-204 0-59.5-59.5-53.8-150.2 0-204l96.9-96.9-51.1-51.1-96.9 96.9c-84.6 84.6-84.6 221.5 0 306s221.5 84.6 306 0l96.9-96.9-51-51-96.8 97zM260.3 209.4a8.03 8.03 0 0 0-11.3 0L209.4 249a8.03 8.03 0 0 0 0 11.3l554.4 554.4c3.1 3.1 8.2 3.1 11.3 0l39.6-39.6c3.1-3.1 3.1-8.2 0-11.3L260.3 209.4z\"}}]})(props);\n};\nexport function AiOutlineDislike (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M885.9 490.3c3.6-12 5.4-24.4 5.4-37 0-28.3-9.3-55.5-26.1-77.7 3.6-12 5.4-24.4 5.4-37 0-28.3-9.3-55.5-26.1-77.7 3.6-12 5.4-24.4 5.4-37 0-51.6-30.7-98.1-78.3-118.4a66.1 66.1 0 0 0-26.5-5.4H144c-17.7 0-32 14.3-32 32v364c0 17.7 14.3 32 32 32h129.3l85.8 310.8C372.9 889 418.9 924 470.9 924c29.7 0 57.4-11.8 77.9-33.4 20.5-21.5 31-49.7 29.5-79.4l-6-122.9h239.9c12.1 0 23.9-3.2 34.3-9.3 40.4-23.5 65.5-66.1 65.5-111 0-28.3-9.3-55.5-26.1-77.7zM184 456V172h81v284h-81zm627.2 160.4H496.8l9.6 198.4c.6 11.9-4.7 23.1-14.6 30.5-6.1 4.5-13.6 6.8-21.1 6.7a44.28 44.28 0 0 1-42.2-32.3L329 459.2V172h415.4a56.85 56.85 0 0 1 33.6 51.8c0 9.7-2.3 18.9-6.9 27.3l-13.9 25.4 21.9 19a56.76 56.76 0 0 1 19.6 43c0 9.7-2.3 18.9-6.9 27.3l-13.9 25.4 21.9 19a56.76 56.76 0 0 1 19.6 43c0 9.7-2.3 18.9-6.9 27.3l-14 25.5 21.9 19a56.76 56.76 0 0 1 19.6 43c0 19.1-11 37.5-28.8 48.4z\"}}]})(props);\n};\nexport function AiOutlineDollarCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372zm47.7-395.2l-25.4-5.9V348.6c38 5.2 61.5 29 65.5 58.2.5 4 3.9 6.9 7.9 6.9h44.9c4.7 0 8.4-4.1 8-8.8-6.1-62.3-57.4-102.3-125.9-109.2V263c0-4.4-3.6-8-8-8h-28.1c-4.4 0-8 3.6-8 8v33c-70.8 6.9-126.2 46-126.2 119 0 67.6 49.8 100.2 102.1 112.7l24.7 6.3v142.7c-44.2-5.9-69-29.5-74.1-61.3-.6-3.8-4-6.6-7.9-6.6H363c-4.7 0-8.4 4-8 8.7 4.5 55 46.2 105.6 135.2 112.1V761c0 4.4 3.6 8 8 8h28.4c4.4 0 8-3.6 8-8.1l-.2-31.7c78.3-6.9 134.3-48.8 134.3-124-.1-69.4-44.2-100.4-109-116.4zm-68.6-16.2c-5.6-1.6-10.3-3.1-15-5-33.8-12.2-49.5-31.9-49.5-57.3 0-36.3 27.5-57 64.5-61.7v124zM534.3 677V543.3c3.1.9 5.9 1.6 8.8 2.2 47.3 14.4 63.2 34.4 63.2 65.1 0 39.1-29.4 62.6-72 66.4z\"}}]})(props);\n};\nexport function AiOutlineDollar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372zm47.7-395.2l-25.4-5.9V348.6c38 5.2 61.5 29 65.5 58.2.5 4 3.9 6.9 7.9 6.9h44.9c4.7 0 8.4-4.1 8-8.8-6.1-62.3-57.4-102.3-125.9-109.2V263c0-4.4-3.6-8-8-8h-28.1c-4.4 0-8 3.6-8 8v33c-70.8 6.9-126.2 46-126.2 119 0 67.6 49.8 100.2 102.1 112.7l24.7 6.3v142.7c-44.2-5.9-69-29.5-74.1-61.3-.6-3.8-4-6.6-7.9-6.6H363c-4.7 0-8.4 4-8 8.7 4.5 55 46.2 105.6 135.2 112.1V761c0 4.4 3.6 8 8 8h28.4c4.4 0 8-3.6 8-8.1l-.2-31.7c78.3-6.9 134.3-48.8 134.3-124-.1-69.4-44.2-100.4-109-116.4zm-68.6-16.2c-5.6-1.6-10.3-3.1-15-5-33.8-12.2-49.5-31.9-49.5-57.3 0-36.3 27.5-57 64.5-61.7v124zM534.3 677V543.3c3.1.9 5.9 1.6 8.8 2.2 47.3 14.4 63.2 34.4 63.2 65.1 0 39.1-29.4 62.6-72 66.4z\"}}]})(props);\n};\nexport function AiOutlineDotChart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M888 792H200V168c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v688c0 4.4 3.6 8 8 8h752c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM288 604a64 64 0 1 0 128 0 64 64 0 1 0-128 0zm118-224a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm158 228a96 96 0 1 0 192 0 96 96 0 1 0-192 0zm148-314a56 56 0 1 0 112 0 56 56 0 1 0-112 0z\"}}]})(props);\n};\nexport function AiOutlineDoubleLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M272.9 512l265.4-339.1c4.1-5.2.4-12.9-6.3-12.9h-77.3c-4.9 0-9.6 2.3-12.6 6.1L186.8 492.3a31.99 31.99 0 0 0 0 39.5l255.3 326.1c3 3.9 7.7 6.1 12.6 6.1H532c6.7 0 10.4-7.7 6.3-12.9L272.9 512zm304 0l265.4-339.1c4.1-5.2.4-12.9-6.3-12.9h-77.3c-4.9 0-9.6 2.3-12.6 6.1L490.8 492.3a31.99 31.99 0 0 0 0 39.5l255.3 326.1c3 3.9 7.7 6.1 12.6 6.1H836c6.7 0 10.4-7.7 6.3-12.9L576.9 512z\"}}]})(props);\n};\nexport function AiOutlineDoubleRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M533.2 492.3L277.9 166.1c-3-3.9-7.7-6.1-12.6-6.1H188c-6.7 0-10.4 7.7-6.3 12.9L447.1 512 181.7 851.1A7.98 7.98 0 0 0 188 864h77.3c4.9 0 9.6-2.3 12.6-6.1l255.3-326.1c9.1-11.7 9.1-27.9 0-39.5zm304 0L581.9 166.1c-3-3.9-7.7-6.1-12.6-6.1H492c-6.7 0-10.4 7.7-6.3 12.9L751.1 512 485.7 851.1A7.98 7.98 0 0 0 492 864h77.3c4.9 0 9.6-2.3 12.6-6.1l255.3-326.1c9.1-11.7 9.1-27.9 0-39.5z\"}}]})(props);\n};\nexport function AiOutlineDownCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M690 405h-46.9c-10.2 0-19.9 4.9-25.9 13.2L512 563.6 406.8 418.2c-6-8.3-15.6-13.2-25.9-13.2H334c-6.5 0-10.3 7.4-6.5 12.7l178 246c3.2 4.4 9.7 4.4 12.9 0l178-246c3.9-5.3.1-12.7-6.4-12.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}}]})(props);\n};\nexport function AiOutlineDownSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M505.5 658.7c3.2 4.4 9.7 4.4 12.9 0l178-246c3.8-5.3 0-12.7-6.5-12.7H643c-10.2 0-19.9 4.9-25.9 13.2L512 558.6 406.8 413.2c-6-8.3-15.6-13.2-25.9-13.2H334c-6.5 0-10.3 7.4-6.5 12.7l178 246z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}}]})(props);\n};\nexport function AiOutlineDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M884 256h-75c-5.1 0-9.9 2.5-12.9 6.6L512 654.2 227.9 262.6c-3-4.1-7.8-6.6-12.9-6.6h-75c-6.5 0-10.3 7.4-6.5 12.7l352.6 486.1c12.8 17.6 39 17.6 51.7 0l352.6-486.1c3.9-5.3.1-12.7-6.4-12.7z\"}}]})(props);\n};\nexport function AiOutlineDownload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M505.7 661a8 8 0 0 0 12.6 0l112-141.7c4.1-5.2.4-12.9-6.3-12.9h-74.1V168c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8v338.3H400c-6.7 0-10.4 7.7-6.3 12.9l112 141.8zM878 626h-60c-4.4 0-8 3.6-8 8v154H214V634c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8v198c0 17.7 14.3 32 32 32h684c17.7 0 32-14.3 32-32V634c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineDrag (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M909.3 506.3L781.7 405.6a7.23 7.23 0 0 0-11.7 5.7V476H548V254h64.8c6 0 9.4-7 5.7-11.7L517.7 114.7a7.14 7.14 0 0 0-11.3 0L405.6 242.3a7.23 7.23 0 0 0 5.7 11.7H476v222H254v-64.8c0-6-7-9.4-11.7-5.7L114.7 506.3a7.14 7.14 0 0 0 0 11.3l127.5 100.8c4.7 3.7 11.7.4 11.7-5.7V548h222v222h-64.8c-6 0-9.4 7-5.7 11.7l100.8 127.5c2.9 3.7 8.5 3.7 11.3 0l100.8-127.5c3.7-4.7.4-11.7-5.7-11.7H548V548h222v64.8c0 6 7 9.4 11.7 5.7l127.5-100.8a7.3 7.3 0 0 0 .1-11.4z\"}}]})(props);\n};\nexport function AiOutlineDribbbleSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M498.6 432c-40.8-72.5-84.7-133.4-91.2-142.3-68.8 32.5-120.3 95.9-136.2 172.2 11 .2 112.4.7 227.4-29.9zm66.5 21.8c5.7 11.7 11.2 23.6 16.3 35.6 1.8 4.2 3.6 8.4 5.3 12.7 81.8-10.3 163.2 6.2 171.3 7.9-.5-58.1-21.3-111.4-55.5-153.3-5.3 7.1-46.5 60-137.4 97.1zM880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM512 800c-158.8 0-288-129.2-288-288s129.2-288 288-288 288 129.2 288 288-129.2 288-288 288zm89.7-259.1c32.2 88.4 45.3 160.4 47.8 175.4 55.2-37.3 94.5-96.4 105.4-164.9-8.4-2.6-76.1-22.8-153.2-10.5zm-72.5-26.4c3.2-1 6.4-2 9.7-2.9-6.2-14-12.9-28-19.9-41.7-122.8 36.8-242.1 35.2-252.8 35-.1 2.5-.1 5-.1 7.5 0 63.2 23.9 120.9 63.2 164.5 5.5-9.6 73-121.4 199.9-162.4zm145.9-186.2a245.2 245.2 0 0 0-220.8-55.1c6.8 9.1 51.5 69.9 91.8 144 87.5-32.8 124.5-82.6 129-88.9zM554 552.8c-138.7 48.3-188.6 144.6-193 153.6 41.7 32.5 94.1 51.9 151 51.9 34.1 0 66.6-6.9 96.1-19.5-3.7-21.6-17.9-96.8-52.5-186.6l-1.6.6z\"}}]})(props);\n};\nexport function AiOutlineDribbble (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 96C282.6 96 96 282.6 96 512s186.6 416 416 416 416-186.6 416-416S741.4 96 512 96zm275.1 191.8c49.5 60.5 79.5 137.5 80.2 221.4-11.7-2.5-129.2-26.3-247.4-11.4-2.5-6.1-5-12.2-7.6-18.3-7.4-17.3-15.3-34.6-23.6-51.5C720 374.3 779.6 298 787.1 287.8zM512 157.2c90.3 0 172.8 33.9 235.5 89.5-6.4 9.1-59.9 81-186.2 128.4-58.2-107-122.7-194.8-132.6-208 27.3-6.6 55.2-9.9 83.3-9.9zM360.9 191c9.4 12.8 72.9 100.9 131.7 205.5C326.4 440.6 180 440 164.1 439.8c23.1-110.3 97.4-201.9 196.8-248.8zM156.7 512.5c0-3.6.1-7.3.2-10.9 15.5.3 187.7 2.5 365.2-50.6 10.2 19.9 19.9 40.1 28.8 60.3-4.7 1.3-9.4 2.7-14 4.2C353.6 574.9 256.1 736.4 248 750.1c-56.7-63-91.3-146.3-91.3-237.6zM512 867.8c-82.2 0-157.9-28-218.1-75 6.4-13.1 78.3-152 278.7-221.9l2.3-.8c49.9 129.6 70.5 238.3 75.8 269.5A350.46 350.46 0 0 1 512 867.8zm198.5-60.7c-3.6-21.6-22.5-125.6-69-253.3C752.9 536 850.7 565.2 862.8 569c-15.8 98.8-72.5 184.2-152.3 238.1z\"}}]})(props);\n};\nexport function AiOutlineDropbox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M64 556.9l264.2 173.5L512.5 577 246.8 412.7zm896-290.3zm0 0L696.8 95 512.5 248.5l265.2 164.2L512.5 577l184.3 153.4L960 558.8 777.7 412.7zM513 609.8L328.2 763.3l-79.4-51.5v57.8L513 928l263.7-158.4v-57.8l-78.9 51.5zM328.2 95L64 265.1l182.8 147.6 265.7-164.2zM64 556.9z\"}}]})(props);\n};\nexport function AiOutlineEdit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M257.7 752c2 0 4-.2 6-.5L431.9 722c2-.4 3.9-1.3 5.3-2.8l423.9-423.9a9.96 9.96 0 0 0 0-14.1L694.9 114.9c-1.9-1.9-4.4-2.9-7.1-2.9s-5.2 1-7.1 2.9L256.8 538.8c-1.5 1.5-2.4 3.3-2.8 5.3l-29.5 168.2a33.5 33.5 0 0 0 9.4 29.8c6.6 6.4 14.9 9.9 23.8 9.9zm67.4-174.4L687.8 215l73.3 73.3-362.7 362.6-88.9 15.7 15.6-89zM880 836H144c-17.7 0-32 14.3-32 32v36c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-36c0-17.7-14.3-32-32-32z\"}}]})(props);\n};\nexport function AiOutlineEllipsis (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M176 511a56 56 0 1 0 112 0 56 56 0 1 0-112 0zm280 0a56 56 0 1 0 112 0 56 56 0 1 0-112 0zm280 0a56 56 0 1 0 112 0 56 56 0 1 0-112 0z\"}}]})(props);\n};\nexport function AiOutlineEnter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M864 170h-60c-4.4 0-8 3.6-8 8v518H310v-73c0-6.7-7.8-10.5-13-6.3l-141.9 112a8 8 0 0 0 0 12.6l141.9 112c5.3 4.2 13 .4 13-6.3v-75h498c35.3 0 64-28.7 64-64V178c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineEnvironment (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 289.1a362.49 362.49 0 0 0-79.9-115.7 370.83 370.83 0 0 0-118.2-77.8C610.7 76.6 562.1 67 512 67c-50.1 0-98.7 9.6-144.5 28.5-44.3 18.3-84 44.5-118.2 77.8A363.6 363.6 0 0 0 169.4 289c-19.5 45-29.4 92.8-29.4 142 0 70.6 16.9 140.9 50.1 208.7 26.7 54.5 64 107.6 111 158.1 80.3 86.2 164.5 138.9 188.4 153a43.9 43.9 0 0 0 22.4 6.1c7.8 0 15.5-2 22.4-6.1 23.9-14.1 108.1-66.8 188.4-153 47-50.4 84.3-103.6 111-158.1C867.1 572 884 501.8 884 431.1c0-49.2-9.9-97-29.4-142zM512 880.2c-65.9-41.9-300-207.8-300-449.1 0-77.9 31.1-151.1 87.6-206.3C356.3 169.5 431.7 139 512 139s155.7 30.5 212.4 85.9C780.9 280 812 353.2 812 431.1c0 241.3-234.1 407.2-300 449.1zm0-617.2c-97.2 0-176 78.8-176 176s78.8 176 176 176 176-78.8 176-176-78.8-176-176-176zm79.2 255.2A111.6 111.6 0 0 1 512 551c-29.9 0-58-11.7-79.2-32.8A111.6 111.6 0 0 1 400 439c0-29.9 11.7-58 32.8-79.2C454 338.6 482.1 327 512 327c29.9 0 58 11.6 79.2 32.8C612.4 381 624 409.1 624 439c0 29.9-11.6 58-32.8 79.2z\"}}]})(props);\n};\nexport function AiOutlineEuroCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372zm117.7-588.6c-15.9-3.5-34.4-5.4-55.3-5.4-106.7 0-178.9 55.7-198.6 149.9H344c-4.4 0-8 3.6-8 8v27.2c0 4.4 3.6 8 8 8h26.4c-.3 4.1-.3 8.4-.3 12.8v36.9H344c-4.4 0-8 3.6-8 8V568c0 4.4 3.6 8 8 8h30.2c17.2 99.2 90.4 158 200.2 158 20.9 0 39.4-1.7 55.3-5.1 3.7-.8 6.4-4 6.4-7.8v-42.8c0-5-4.6-8.8-9.5-7.8-14.7 2.8-31.9 4.1-51.8 4.1-68.5 0-114.5-36.6-129.8-98.6h130.6c4.4 0 8-3.6 8-8v-27.2c0-4.4-3.6-8-8-8H439.2v-36c0-4.7 0-9.4.3-13.8h135.9c4.4 0 8-3.6 8-8v-27.2c0-4.4-3.6-8-8-8H447.1c17.2-56.9 62.3-90.4 127.6-90.4 19.9 0 37.1 1.5 51.7 4.4a8 8 0 0 0 9.6-7.8v-42.8c0-3.8-2.6-7-6.3-7.8z\"}}]})(props);\n};\nexport function AiOutlineEuro (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372zm117.7-588.6c-15.9-3.5-34.4-5.4-55.3-5.4-106.7 0-178.9 55.7-198.6 149.9H344c-4.4 0-8 3.6-8 8v27.2c0 4.4 3.6 8 8 8h26.4c-.3 4.1-.3 8.4-.3 12.8v36.9H344c-4.4 0-8 3.6-8 8V568c0 4.4 3.6 8 8 8h30.2c17.2 99.2 90.4 158 200.2 158 20.9 0 39.4-1.7 55.3-5.1 3.7-.8 6.4-4 6.4-7.8v-42.8c0-5-4.6-8.8-9.5-7.8-14.7 2.8-31.9 4.1-51.8 4.1-68.5 0-114.5-36.6-129.8-98.6h130.6c4.4 0 8-3.6 8-8v-27.2c0-4.4-3.6-8-8-8H439.2v-36c0-4.7 0-9.4.3-13.8h135.9c4.4 0 8-3.6 8-8v-27.2c0-4.4-3.6-8-8-8H447.1c17.2-56.9 62.3-90.4 127.6-90.4 19.9 0 37.1 1.5 51.7 4.4a8 8 0 0 0 9.6-7.8v-42.8c0-3.8-2.6-7-6.3-7.8z\"}}]})(props);\n};\nexport function AiOutlineException (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M688 312v-48c0-4.4-3.6-8-8-8H296c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h384c4.4 0 8-3.6 8-8zm-392 88c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H296zm376 116c-119.3 0-216 96.7-216 216s96.7 216 216 216 216-96.7 216-216-96.7-216-216-216zm107.5 323.5C750.8 868.2 712.6 884 672 884s-78.8-15.8-107.5-44.5C535.8 810.8 520 772.6 520 732s15.8-78.8 44.5-107.5C593.2 595.8 631.4 580 672 580s78.8 15.8 107.5 44.5C808.2 653.2 824 691.4 824 732s-15.8 78.8-44.5 107.5zM640 812a32 32 0 1 0 64 0 32 32 0 1 0-64 0zm12-64h40c4.4 0 8-3.6 8-8V628c0-4.4-3.6-8-8-8h-40c-4.4 0-8 3.6-8 8v112c0 4.4 3.6 8 8 8zM440 852H208V148h560v344c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V108c0-17.7-14.3-32-32-32H168c-17.7 0-32 14.3-32 32v784c0 17.7 14.3 32 32 32h272c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineExclamationCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M464 688a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm24-112h48c4.4 0 8-3.6 8-8V296c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v272c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlineExclamation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M448 804a64 64 0 1 0 128 0 64 64 0 1 0-128 0zm32-168h64c4.4 0 8-3.6 8-8V164c0-4.4-3.6-8-8-8h-64c-4.4 0-8 3.6-8 8v464c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlineExpandAlt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M855 160.1l-189.2 23.5c-6.6.8-9.3 8.8-4.7 13.5l54.7 54.7-153.5 153.5a8.03 8.03 0 0 0 0 11.3l45.1 45.1c3.1 3.1 8.2 3.1 11.3 0l153.6-153.6 54.7 54.7a7.94 7.94 0 0 0 13.5-4.7L863.9 169a7.9 7.9 0 0 0-8.9-8.9zM416.6 562.3a8.03 8.03 0 0 0-11.3 0L251.8 715.9l-54.7-54.7a7.94 7.94 0 0 0-13.5 4.7L160.1 855c-.6 5.2 3.7 9.5 8.9 8.9l189.2-23.5c6.6-.8 9.3-8.8 4.7-13.5l-54.7-54.7 153.6-153.6c3.1-3.1 3.1-8.2 0-11.3l-45.2-45z\"}}]})(props);\n};\nexport function AiOutlineExpand (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683683230\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M342 88H120c-17.7 0-32 14.3-32 32v224c0 8.8 7.2 16 16 16h48c8.8 0 16-7.2 16-16V168h174c8.8 0 16-7.2 16-16v-48c0-8.8-7.2-16-16-16zM920 664h-48c-8.8 0-16 7.2-16 16v176H682c-8.8 0-16 7.2-16 16v48c0 8.8 7.2 16 16 16h222c17.7 0 32-14.3 32-32V680c0-8.8-7.2-16-16-16zM342 856H168V680c0-8.8-7.2-16-16-16h-48c-8.8 0-16 7.2-16 16v224c0 17.7 14.3 32 32 32h222c8.8 0 16-7.2 16-16v-48c0-8.8-7.2-16-16-16zM904 88H682c-8.8 0-16 7.2-16 16v48c0 8.8 7.2 16 16 16h174v176c0 8.8 7.2 16 16 16h48c8.8 0 16-7.2 16-16V120c0-17.7-14.3-32-32-32z\"}}]})(props);\n};\nexport function AiOutlineExperiment (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 472a40 40 0 1 0 80 0 40 40 0 1 0-80 0zm367 352.9L696.3 352V178H768v-68H256v68h71.7v174L145 824.9c-2.8 7.4-4.3 15.2-4.3 23.1 0 35.3 28.7 64 64 64h614.6c7.9 0 15.7-1.5 23.1-4.3 33-12.7 49.4-49.8 36.6-82.8zM395.7 364.7V180h232.6v184.7L719.2 600c-20.7-5.3-42.1-8-63.9-8-61.2 0-119.2 21.5-165.3 60a188.78 188.78 0 0 1-121.3 43.9c-32.7 0-64.1-8.3-91.8-23.7l118.8-307.5zM210.5 844l41.7-107.8c35.7 18.1 75.4 27.8 116.6 27.8 61.2 0 119.2-21.5 165.3-60 33.9-28.2 76.3-43.9 121.3-43.9 35 0 68.4 9.5 97.6 27.1L813.5 844h-603z\"}}]})(props);\n};\nexport function AiOutlineExport (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M888.3 757.4h-53.8c-4.2 0-7.7 3.5-7.7 7.7v61.8H197.1V197.1h629.8v61.8c0 4.2 3.5 7.7 7.7 7.7h53.8c4.2 0 7.7-3.4 7.7-7.7V158.7c0-17-13.7-30.7-30.7-30.7H158.7c-17 0-30.7 13.7-30.7 30.7v706.6c0 17 13.7 30.7 30.7 30.7h706.6c17 0 30.7-13.7 30.7-30.7V765.1c0-4.3-3.5-7.7-7.7-7.7zm18.6-251.7L765 393.7c-5.3-4.2-13-.4-13 6.3v76H438c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h314v76c0 6.7 7.8 10.5 13 6.3l141.9-112a8 8 0 0 0 0-12.6z\"}}]})(props);\n};\nexport function AiOutlineEyeInvisible (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M942.2 486.2Q889.47 375.11 816.7 305l-50.88 50.88C807.31 395.53 843.45 447.4 874.7 512 791.5 684.2 673.4 766 512 766q-72.67 0-133.87-22.38L323 798.75Q408 838 512 838q288.3 0 430.2-300.3a60.29 60.29 0 0 0 0-51.5zm-63.57-320.64L836 122.88a8 8 0 0 0-11.32 0L715.31 232.2Q624.86 186 512 186q-288.3 0-430.2 300.3a60.3 60.3 0 0 0 0 51.5q56.69 119.4 136.5 191.41L112.48 835a8 8 0 0 0 0 11.31L155.17 889a8 8 0 0 0 11.31 0l712.15-712.12a8 8 0 0 0 0-11.32zM149.3 512C232.6 339.8 350.7 258 512 258c54.54 0 104.13 9.36 149.12 28.39l-70.3 70.3a176 176 0 0 0-238.13 238.13l-83.42 83.42C223.1 637.49 183.3 582.28 149.3 512zm246.7 0a112.11 112.11 0 0 1 146.2-106.69L401.31 546.2A112 112 0 0 1 396 512z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M508 624c-3.46 0-6.87-.16-10.25-.47l-52.82 52.82a176.09 176.09 0 0 0 227.42-227.42l-52.82 52.82c.31 3.38.47 6.79.47 10.25a111.94 111.94 0 0 1-112 112z\"}}]})(props);\n};\nexport function AiOutlineEye (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M942.2 486.2C847.4 286.5 704.1 186 512 186c-192.2 0-335.4 100.5-430.2 300.3a60.3 60.3 0 0 0 0 51.5C176.6 737.5 319.9 838 512 838c192.2 0 335.4-100.5 430.2-300.3 7.7-16.2 7.7-35 0-51.5zM512 766c-161.3 0-279.4-81.8-362.7-254C232.6 339.8 350.7 258 512 258c161.3 0 279.4 81.8 362.7 254C791.5 684.2 673.4 766 512 766zm-4-430c-97.2 0-176 78.8-176 176s78.8 176 176 176 176-78.8 176-176-78.8-176-176-176zm0 288c-61.9 0-112-50.1-112-112s50.1-112 112-112 112 50.1 112 112-50.1 112-112 112z\"}}]})(props);\n};\nexport function AiOutlineFacebook (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-32 736H663.9V602.2h104l15.6-120.7H663.9v-77.1c0-35 9.7-58.8 59.8-58.8h63.9v-108c-11.1-1.5-49-4.8-93.2-4.8-92.2 0-155.3 56.3-155.3 159.6v89H434.9v120.7h104.3V848H176V176h672v672z\"}}]})(props);\n};\nexport function AiOutlineFall (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M925.9 804l-24-199.2c-.8-6.6-8.9-9.4-13.6-4.7L829 659.5 557.7 388.3c-6.3-6.2-16.4-6.2-22.6 0L433.3 490 156.6 213.3a8.03 8.03 0 0 0-11.3 0l-45 45.2a8.03 8.03 0 0 0 0 11.3L422 591.7c6.2 6.3 16.4 6.3 22.6 0L546.4 490l226.1 226-59.3 59.3a8.01 8.01 0 0 0 4.7 13.6l199.2 24c5.1.7 9.5-3.7 8.8-8.9z\"}}]})(props);\n};\nexport function AiOutlineFastBackward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M517.6 273.5L230.2 499.3a16.14 16.14 0 0 0 0 25.4l287.4 225.8c10.7 8.4 26.4.8 26.4-12.7V286.2c0-13.5-15.7-21.1-26.4-12.7zm320 0L550.2 499.3a16.14 16.14 0 0 0 0 25.4l287.4 225.8c10.7 8.4 26.4.8 26.4-12.7V286.2c0-13.5-15.7-21.1-26.4-12.7zm-620-25.5h-51.2c-3.5 0-6.4 2.7-6.4 6v516c0 3.3 2.9 6 6.4 6h51.2c3.5 0 6.4-2.7 6.4-6V254c0-3.3-2.9-6-6.4-6z\"}}]})(props);\n};\nexport function AiOutlineFastForward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M793.8 499.3L506.4 273.5c-10.7-8.4-26.4-.8-26.4 12.7v451.6c0 13.5 15.7 21.1 26.4 12.7l287.4-225.8a16.14 16.14 0 0 0 0-25.4zm-320 0L186.4 273.5c-10.7-8.4-26.4-.8-26.4 12.7v451.5c0 13.5 15.7 21.1 26.4 12.7l287.4-225.8c4.1-3.2 6.2-8 6.2-12.7 0-4.6-2.1-9.4-6.2-12.6zM857.6 248h-51.2c-3.5 0-6.4 2.7-6.4 6v516c0 3.3 2.9 6 6.4 6h51.2c3.5 0 6.4-2.7 6.4-6V254c0-3.3-2.9-6-6.4-6z\"}}]})(props);\n};\nexport function AiOutlineFieldBinary (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683645783\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M600 395.4h91V649h79V267c0-4.4-3.6-8-8-8h-48.2c-3.7 0-7 2.6-7.7 6.3-2.6 12.1-6.9 22.3-12.9 30.9-7.2 10.1-15.9 18.2-26.3 24.4-10.3 6.2-22 10.5-35 12.9-10.4 1.9-21 3-32 3.1-4.4 0.1-7.9 3.6-7.9 8v42.8c0 4.4 3.6 8 8 8zM871 702H567c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h304c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zM443.9 312.7c-16.1-19-34.4-32.4-55.2-40.4-21.3-8.2-44.1-12.3-68.4-12.3-23.9 0-46.4 4.1-67.7 12.3-20.8 8-39 21.4-54.8 40.3-15.9 19.1-28.7 44.7-38.3 77-9.6 32.5-14.5 73-14.5 121.5 0 49.9 4.9 91.4 14.5 124.4 9.6 32.8 22.4 58.7 38.3 77.7 15.8 18.9 34 32.3 54.8 40.3 21.3 8.2 43.8 12.3 67.7 12.3 24.4 0 47.2-4.1 68.4-12.3 20.8-8 39.2-21.4 55.2-40.4 16.1-19 29-44.9 38.6-77.7 9.6-33 14.5-74.5 14.5-124.4 0-48.4-4.9-88.9-14.5-121.5-9.5-32.1-22.4-57.7-38.6-76.8z m-29.5 251.7c-1 21.4-4.2 42-9.5 61.9-5.5 20.7-14.5 38.5-27 53.4-13.6 16.3-33.2 24.3-57.6 24.3-24 0-43.2-8.1-56.7-24.4-12.2-14.8-21.1-32.6-26.6-53.3-5.3-19.9-8.5-40.6-9.5-61.9-1-20.8-1.5-38.5-1.5-53.2 0-8.8 0.1-19.4 0.4-31.8 0.2-12.7 1.1-25.8 2.6-39.2 1.5-13.6 4-27.1 7.6-40.5 3.7-13.8 8.8-26.3 15.4-37.4 6.9-11.6 15.8-21.1 26.7-28.3 11.4-7.6 25.3-11.3 41.5-11.3 16.1 0 30.1 3.7 41.7 11.2 11.1 7.2 20.3 16.6 27.4 28.2 6.9 11.2 12.1 23.8 15.6 37.7 3.3 13.2 5.8 26.6 7.5 40.1 1.8 13.5 2.8 26.6 3 39.4 0.2 12.4 0.4 23 0.4 31.8 0.1 14.8-0.4 32.5-1.4 53.3z\"}}]})(props);\n};\nexport function AiOutlineFieldNumber (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683604581\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M508 280h-63.3c-3.3 0-6 2.7-6 6v340.2H433L197.4 282.6c-1.1-1.6-3-2.6-4.9-2.6H126c-3.3 0-6 2.7-6 6v464c0 3.3 2.7 6 6 6h62.7c3.3 0 6-2.7 6-6V405.1h5.7l238.2 348.3c1.1 1.6 3 2.6 5 2.6H508c3.3 0 6-2.7 6-6V286c0-3.3-2.7-6-6-6zM886 693H582c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h304c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zM733.8 630c52.9 0 95.2-17.2 126.2-51.7 29.4-32.9 44-75.8 44-128.8 0-53.1-14.6-96.5-44-129.3-30.9-34.8-73.2-52.2-126.2-52.2-53.7 0-95.9 17.5-126.3 52.8-29.2 33.1-43.4 75.9-43.4 128.7 0 52.4 14.3 95.2 43.5 128.3 30.6 34.7 73 52.2 126.2 52.2z m-71.5-263.7c16.9-20.6 40.3-30.9 71.4-30.9 31.5 0 54.8 9.6 71 29.1 16.4 20.3 24.9 48.6 24.9 84.9 0 36.3-8.4 64.1-24.8 83.9-16.5 19.4-40 29.2-71.1 29.2-31.2 0-55-10.3-71.4-30.4-16.3-20.1-24.5-47.3-24.5-82.6 0.1-35.8 8.2-63 24.5-83.2z\"}}]})(props);\n};\nexport function AiOutlineFieldString (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683607277\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M875.6 515.9c2.1 0.8 4.4-0.3 5.2-2.4 0.2-0.4 0.2-0.9 0.2-1.4v-58.3c0-1.8-1.1-3.3-2.8-3.8-6-1.8-17.2-3-27.2-3-32.9 0-61.7 16.7-73.5 41.2v-28.6c0-4.4-3.6-8-8-8H717c-4.4 0-8 3.6-8 8V729c0 4.4 3.6 8 8 8h54.8c4.4 0 8-3.6 8-8V572.7c0-36.2 26.1-60.2 65.1-60.2 10.4 0.1 26.6 1.8 30.7 3.4zM338.6 475.4l-54.7-12.6c-61.2-14.2-87.7-34.8-87.7-70.7 0-44.6 39.1-73.5 96.9-73.5 52.8 0 91.4 26.5 99.9 68.9h70C455.9 311.6 387.6 259 293.4 259c-103.3 0-171 55.5-171 139 0 68.6 38.6 109.5 122.2 128.5l61.6 14.3c63.6 14.9 91.6 37.1 91.6 75.1 0 44.1-43.5 75.2-102.5 75.2-60.6 0-104.5-27.2-112.8-70.5H111c7.2 79.9 75.6 130.4 179.1 130.4C402.3 751 471 695.2 471 605.3c0-70.2-38.6-108.5-132.4-129.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M877 729m-36 0a36 36 0 1 0 72 0 36 36 0 1 0-72 0Z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M653 457.8h-51.4V396c0-4.4-3.6-8-8-8h-54.7c-4.4 0-8 3.6-8 8v61.8H495c-4.4 0-8 3.6-8 8v42.3c0 4.4 3.6 8 8 8h35.9v147.5c0 56.2 27.4 79.4 93.1 79.4 11.7 0 23.6-1.2 33.8-3.1 1.9-0.3 3.2-2 3.2-3.9v-49.3c0-2.2-1.8-4-4-4h-0.4c-4.9 0.5-6.2 0.6-8.3 0.8-4.1 0.3-7.8 0.5-12.6 0.5-24.1 0-34.1-10.3-34.1-35.6V516.1H653c4.4 0 8-3.6 8-8v-42.3c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineFieldTime (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683618210\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M945 412H689c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h256c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zM811 548H689c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h122c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zM477.3 322.5H434c-6.2 0-11.2 5-11.2 11.2v248c0 3.6 1.7 6.9 4.6 9l148.9 108.6c5 3.6 12 2.6 15.6-2.4l25.7-35.1v-0.1c3.6-5 2.5-12-2.5-15.6l-126.7-91.6V333.7c0.1-6.2-5-11.2-11.1-11.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M804.8 673.9H747c-5.6 0-10.9 2.9-13.9 7.7-12.7 20.1-27.5 38.7-44.5 55.7-29.3 29.3-63.4 52.3-101.3 68.3-39.3 16.6-81 25-124 25-43.1 0-84.8-8.4-124-25-37.9-16-72-39-101.3-68.3s-52.3-63.4-68.3-101.3c-16.6-39.2-25-80.9-25-124 0-43.1 8.4-84.7 25-124 16-37.9 39-72 68.3-101.3 29.3-29.3 63.4-52.3 101.3-68.3 39.2-16.6 81-25 124-25 43.1 0 84.8 8.4 124 25 37.9 16 72 39 101.3 68.3 17 17 31.8 35.6 44.5 55.7 3 4.8 8.3 7.7 13.9 7.7h57.8c6.9 0 11.3-7.2 8.2-13.3-65.2-129.7-197.4-214-345-215.7-216.1-2.7-395.6 174.2-396 390.1C71.6 727.5 246.9 903 463.2 903c149.5 0 283.9-84.6 349.8-215.8 3.1-6.1-1.4-13.3-8.2-13.3z\"}}]})(props);\n};\nexport function AiOutlineFileAdd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM790.2 326H602V137.8L790.2 326zm1.8 562H232V136h302v216a42 42 0 0 0 42 42h216v494zM544 472c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v108H372c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h108v108c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V644h108c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H544V472z\"}}]})(props);\n};\nexport function AiOutlineFileDone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M688 312v-48c0-4.4-3.6-8-8-8H296c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h384c4.4 0 8-3.6 8-8zm-392 88c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H296zm376 116c-119.3 0-216 96.7-216 216s96.7 216 216 216 216-96.7 216-216-96.7-216-216-216zm107.5 323.5C750.8 868.2 712.6 884 672 884s-78.8-15.8-107.5-44.5C535.8 810.8 520 772.6 520 732s15.8-78.8 44.5-107.5C593.2 595.8 631.4 580 672 580s78.8 15.8 107.5 44.5C808.2 653.2 824 691.4 824 732s-15.8 78.8-44.5 107.5zM761 656h-44.3c-2.6 0-5 1.2-6.5 3.3l-63.5 87.8-23.1-31.9a7.92 7.92 0 0 0-6.5-3.3H573c-6.5 0-10.3 7.4-6.5 12.7l73.8 102.1c3.2 4.4 9.7 4.4 12.9 0l114.2-158c3.9-5.3.1-12.7-6.4-12.7zM440 852H208V148h560v344c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V108c0-17.7-14.3-32-32-32H168c-17.7 0-32 14.3-32 32v784c0 17.7 14.3 32 32 32h272c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineFileExcel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM790.2 326H602V137.8L790.2 326zm1.8 562H232V136h302v216a42 42 0 0 0 42 42h216v494zM514.1 580.1l-61.8-102.4c-2.2-3.6-6.1-5.8-10.3-5.8h-38.4c-2.3 0-4.5.6-6.4 1.9-5.6 3.5-7.3 10.9-3.7 16.6l82.3 130.4-83.4 132.8a12.04 12.04 0 0 0 10.2 18.4h34.5c4.2 0 8-2.2 10.2-5.7L510 664.8l62.3 101.4c2.2 3.6 6.1 5.7 10.2 5.7H620c2.3 0 4.5-.7 6.5-1.9 5.6-3.6 7.2-11 3.6-16.6l-84-130.4 85.3-132.5a12.04 12.04 0 0 0-10.1-18.5h-35.7c-4.2 0-8.1 2.2-10.3 5.8l-61.2 102.3z\"}}]})(props);\n};\nexport function AiOutlineFileExclamation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM790.2 326H602V137.8L790.2 326zm1.8 562H232V136h302v216a42 42 0 0 0 42 42h216v494zM472 744a40 40 0 1 0 80 0 40 40 0 1 0-80 0zm16-104h48c4.4 0 8-3.6 8-8V448c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v184c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlineFileGif (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683725598\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M551.5 490.5H521c-4.6 0-8.4 3.7-8.4 8.4V720c0 4.6 3.7 8.4 8.4 8.4h30.5c4.6 0 8.4-3.7 8.4-8.4V498.9c-0.1-4.6-3.8-8.4-8.4-8.4zM477.3 600h-88.1c-4.6 0-8.4 3.7-8.4 8.4v23.8c0 4.6 3.7 8.4 8.4 8.4h47.6v0.7c-0.6 29.9-23 49.8-56.5 49.8-39.2 0-63.6-30.7-63.6-81.4 0-50.1 23.9-80.6 62.3-80.6 28.1 0 47.5 13.5 55.4 38.3l0.9 2.8h49.2l-0.7-4.6C475.9 515.9 434.7 484 379 484c-68.8 0-113 49.4-113 125.9 0 77.5 43.7 126.1 113.6 126.1 64.4 0 106-40.3 106-102.9v-24.8c0-4.6-3.7-8.3-8.3-8.3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM602 137.8L790.2 326H602V137.8zM792 888H232V136h302v216c0 23.2 18.8 42 42 42h216v494z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M608.2 727.8h32.3c4.6 0 8.4-3.7 8.4-8.4v-84.8h87.8c4.6 0 8.4-3.7 8.4-8.4v-25.5c0-4.6-3.7-8.4-8.4-8.4h-87.8v-58.9h96.8c4.6 0 8.4-3.7 8.4-8.4v-26.8c0-4.6-3.7-8.4-8.4-8.4H608.2c-4.6 0-8.4 3.7-8.4 8.4v221.1c0 4.8 3.8 8.5 8.4 8.5z\"}}]})(props);\n};\nexport function AiOutlineFileImage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M553.1 509.1l-77.8 99.2-41.1-52.4a8 8 0 0 0-12.6 0l-99.8 127.2a7.98 7.98 0 0 0 6.3 12.9H696c6.7 0 10.4-7.7 6.3-12.9l-136.5-174a8.1 8.1 0 0 0-12.7 0zM360 442a40 40 0 1 0 80 0 40 40 0 1 0-80 0zm494.6-153.4L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM790.2 326H602V137.8L790.2 326zm1.8 562H232V136h302v216a42 42 0 0 0 42 42h216v494z\"}}]})(props);\n};\nexport function AiOutlineFileJpg (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M874.6 301.8L596.8 21.3c-4.5-4.5-9.4-8.3-14.7-11.5-1.4-.8-2.8-1.6-4.3-2.3-.9-.5-1.9-.9-2.8-1.3-9-4-18.9-6.2-29-6.2H201c-39.8 0-73 32.2-73 72v880c0 39.8 33.2 72 73 72h623c39.8 0 71-32.2 71-72V352.5c0-19-7-37.2-20.4-50.7zM583 110.4L783.8 312H583V110.4zM823 952H200V72h311v240c0 39.8 33.2 72 73 72h239v568zM350 696.5c0 24.2-7.5 31.4-21.9 31.4-9 0-18.4-5.8-24.8-18.5L272.9 732c13.4 22.9 32.3 34.2 61.3 34.2 41.6 0 60.8-29.9 60.8-66.2V577h-45v119.5zM501.3 577H437v186h44v-62h21.6c39.1 0 73.1-19.6 73.1-63.6 0-45.8-33.5-60.4-74.4-60.4zm-.8 89H481v-53h18.2c21.5 0 33.4 6.2 33.4 24.9 0 18.1-10.5 28.1-32.1 28.1zm182.5-9v36h30v30.1c-4 2.9-11 4.7-17.7 4.7-34.3 0-50.7-21.4-50.7-58.2 0-36.1 19.7-57.4 47.1-57.4 15.3 0 25 6.2 34 14.4l23.7-28.3c-12.7-12.8-32.1-24.2-59.2-24.2-49.6 0-91.1 35.3-91.1 97 0 62.7 40 95.1 91.5 95.1 25.9 0 49.2-10.2 61.5-22.6V657H683z\"}}]})(props);\n};\nexport function AiOutlineFileMarkdown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM790.2 326H602V137.8L790.2 326zm1.8 562H232V136h302v216a42 42 0 0 0 42 42h216v494zM429 481.2c-1.9-4.4-6.2-7.2-11-7.2h-35c-6.6 0-12 5.4-12 12v272c0 6.6 5.4 12 12 12h27.1c6.6 0 12-5.4 12-12V582.1l66.8 150.2a12 12 0 0 0 11 7.1H524c4.7 0 9-2.8 11-7.1l66.8-150.6V758c0 6.6 5.4 12 12 12H641c6.6 0 12-5.4 12-12V486c0-6.6-5.4-12-12-12h-34.7c-4.8 0-9.1 2.8-11 7.2l-83.1 191-83.2-191z\"}}]})(props);\n};\nexport function AiOutlineFilePdf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M531.3 574.4l.3-1.4c5.8-23.9 13.1-53.7 7.4-80.7-3.8-21.3-19.5-29.6-32.9-30.2-15.8-.7-29.9 8.3-33.4 21.4-6.6 24-.7 56.8 10.1 98.6-13.6 32.4-35.3 79.5-51.2 107.5-29.6 15.3-69.3 38.9-75.2 68.7-1.2 5.5.2 12.5 3.5 18.8 3.7 7 9.6 12.4 16.5 15 3 1.1 6.6 2 10.8 2 17.6 0 46.1-14.2 84.1-79.4 5.8-1.9 11.8-3.9 17.6-5.9 27.2-9.2 55.4-18.8 80.9-23.1 28.2 15.1 60.3 24.8 82.1 24.8 21.6 0 30.1-12.8 33.3-20.5 5.6-13.5 2.9-30.5-6.2-39.6-13.2-13-45.3-16.4-95.3-10.2-24.6-15-40.7-35.4-52.4-65.8zM421.6 726.3c-13.9 20.2-24.4 30.3-30.1 34.7 6.7-12.3 19.8-25.3 30.1-34.7zm87.6-235.5c5.2 8.9 4.5 35.8.5 49.4-4.9-19.9-5.6-48.1-2.7-51.4.8.1 1.5.7 2.2 2zm-1.6 120.5c10.7 18.5 24.2 34.4 39.1 46.2-21.6 4.9-41.3 13-58.9 20.2-4.2 1.7-8.3 3.4-12.3 5 13.3-24.1 24.4-51.4 32.1-71.4zm155.6 65.5c.1.2.2.5-.4.9h-.2l-.2.3c-.8.5-9 5.3-44.3-8.6 40.6-1.9 45 7.3 45.1 7.4zm191.4-388.2L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM790.2 326H602V137.8L790.2 326zm1.8 562H232V136h302v216a42 42 0 0 0 42 42h216v494z\"}}]})(props);\n};\nexport function AiOutlineFilePpt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M424 476c-4.4 0-8 3.6-8 8v276c0 4.4 3.6 8 8 8h32.5c4.4 0 8-3.6 8-8v-95.5h63.3c59.4 0 96.2-38.9 96.2-94.1 0-54.5-36.3-94.3-96-94.3H424zm150.6 94.3c0 43.4-26.5 54.3-71.2 54.3h-38.9V516.2h56.2c33.8 0 53.9 19.7 53.9 54.1zm280-281.7L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM790.2 326H602V137.8L790.2 326zm1.8 562H232V136h302v216a42 42 0 0 0 42 42h216v494z\"}}]})(props);\n};\nexport function AiOutlineFileProtect (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M644.7 669.2a7.92 7.92 0 0 0-6.5-3.3H594c-6.5 0-10.3 7.4-6.5 12.7l73.8 102.1c3.2 4.4 9.7 4.4 12.9 0l114.2-158c3.8-5.3 0-12.7-6.5-12.7h-44.3c-2.6 0-5 1.2-6.5 3.3l-63.5 87.8-22.9-31.9zM688 306v-48c0-4.4-3.6-8-8-8H296c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h384c4.4 0 8-3.6 8-8zm-392 88c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H296zm184 458H208V148h560v296c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V108c0-17.7-14.3-32-32-32H168c-17.7 0-32 14.3-32 32v784c0 17.7 14.3 32 32 32h312c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm402.6-320.8l-192-66.7c-.9-.3-1.7-.4-2.6-.4s-1.8.1-2.6.4l-192 66.7a7.96 7.96 0 0 0-5.4 7.5v251.1c0 2.5 1.1 4.8 3.1 6.3l192 150.2c1.4 1.1 3.2 1.7 4.9 1.7s3.5-.6 4.9-1.7l192-150.2c1.9-1.5 3.1-3.8 3.1-6.3V538.7c0-3.4-2.2-6.4-5.4-7.5zM826 763.7L688 871.6 550 763.7V577l138-48 138 48v186.7z\"}}]})(props);\n};\nexport function AiOutlineFileSearch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M688 312v-48c0-4.4-3.6-8-8-8H296c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h384c4.4 0 8-3.6 8-8zm-392 88c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H296zm144 452H208V148h560v344c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V108c0-17.7-14.3-32-32-32H168c-17.7 0-32 14.3-32 32v784c0 17.7 14.3 32 32 32h272c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm445.7 51.5l-93.3-93.3C814.7 780.7 828 743.9 828 704c0-97.2-78.8-176-176-176s-176 78.8-176 176 78.8 176 176 176c35.8 0 69-10.7 96.8-29l94.7 94.7c1.6 1.6 3.6 2.3 5.6 2.3s4.1-.8 5.6-2.3l31-31a7.9 7.9 0 0 0 0-11.2zM652 816c-61.9 0-112-50.1-112-112s50.1-112 112-112 112 50.1 112 112-50.1 112-112 112z\"}}]})(props);\n};\nexport function AiOutlineFileSync (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M296 256c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h384c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H296zm192 200v-48c0-4.4-3.6-8-8-8H296c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h184c4.4 0 8-3.6 8-8zm-48 396H208V148h560v344c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V108c0-17.7-14.3-32-32-32H168c-17.7 0-32 14.3-32 32v784c0 17.7 14.3 32 32 32h272c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm104.1-115.6c1.8-34.5 16.2-66.8 40.8-91.4 26.2-26.2 62-41 99.1-41 37.4 0 72.6 14.6 99.1 41 3.2 3.2 6.3 6.6 9.2 10.1L769.2 673a8 8 0 0 0 3 14.1l93.3 22.5c5 1.2 9.8-2.6 9.9-7.7l.6-95.4a8 8 0 0 0-12.9-6.4l-20.3 15.8C805.4 569.6 748.1 540 684 540c-109.9 0-199.6 86.9-204 195.7-.2 4.5 3.5 8.3 8 8.3h48.1c4.3 0 7.8-3.3 8-7.6zM880 744h-48.1c-4.3 0-7.8 3.3-8 7.6-1.8 34.5-16.2 66.8-40.8 91.4-26.2 26.2-62 41-99.1 41-37.4 0-72.6-14.6-99.1-41-3.2-3.2-6.3-6.6-9.2-10.1l23.1-17.9a8 8 0 0 0-3-14.1l-93.3-22.5c-5-1.2-9.8 2.6-9.9 7.7l-.6 95.4a8 8 0 0 0 12.9 6.4l20.3-15.8C562.6 918.4 619.9 948 684 948c109.9 0 199.6-86.9 204-195.7.2-4.5-3.5-8.3-8-8.3z\"}}]})(props);\n};\nexport function AiOutlineFileText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM790.2 326H602V137.8L790.2 326zm1.8 562H232V136h302v216a42 42 0 0 0 42 42h216v494zM504 618H320c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zM312 490v48c0 4.4 3.6 8 8 8h384c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H320c-4.4 0-8 3.6-8 8z\"}}]})(props);\n};\nexport function AiOutlineFileUnknown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.7L639.4 73.4c-6-6-14.2-9.4-22.7-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.6-9.4-22.6zM790.2 326H602V137.8L790.2 326zm1.8 562H232V136h302v216a42 42 0 0 0 42 42h216v494zM402 549c0 5.4 4.4 9.5 9.8 9.5h32.4c5.4 0 9.8-4.2 9.8-9.4 0-28.2 25.8-51.6 58-51.6s58 23.4 58 51.5c0 25.3-21 47.2-49.3 50.9-19.3 2.8-34.5 20.3-34.7 40.1v32c0 5.5 4.5 10 10 10h32c5.5 0 10-4.5 10-10v-12.2c0-6 4-11.5 9.7-13.3 44.6-14.4 75-54 74.3-98.9-.8-55.5-49.2-100.8-108.5-101.6-61.4-.7-111.5 45.6-111.5 103zm78 195a32 32 0 1 0 64 0 32 32 0 1 0-64 0z\"}}]})(props);\n};\nexport function AiOutlineFileWord (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM790.2 326H602V137.8L790.2 326zm1.8 562H232V136h302v216a42 42 0 0 0 42 42h216v494zM528.1 472h-32.2c-5.5 0-10.3 3.7-11.6 9.1L434.6 680l-46.1-198.7c-1.3-5.4-6.1-9.3-11.7-9.3h-35.4a12.02 12.02 0 0 0-11.6 15.1l74.2 276c1.4 5.2 6.2 8.9 11.6 8.9h32c5.4 0 10.2-3.6 11.6-8.9l52.8-197 52.8 197c1.4 5.2 6.2 8.9 11.6 8.9h31.8c5.4 0 10.2-3.6 11.6-8.9l74.4-276a12.04 12.04 0 0 0-11.6-15.1H647c-5.6 0-10.4 3.9-11.7 9.3l-45.8 199.1-49.8-199.3c-1.3-5.4-6.1-9.1-11.6-9.1z\"}}]})(props);\n};\nexport function AiOutlineFileZip (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M296 392h64v64h-64zm0 190v160h128V582h-64v-62h-64v62zm80 48v64h-32v-64h32zm-16-302h64v64h-64zm-64-64h64v64h-64zm64 192h64v64h-64zm0-256h64v64h-64zm494.6 88.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM790.2 326H602V137.8L790.2 326zm1.8 562H232V136h64v64h64v-64h174v216a42 42 0 0 0 42 42h216v494z\"}}]})(props);\n};\nexport function AiOutlineFile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM790.2 326H602V137.8L790.2 326zm1.8 562H232V136h302v216a42 42 0 0 0 42 42h216v494z\"}}]})(props);\n};\nexport function AiOutlineFilter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880.1 154H143.9c-24.5 0-39.8 26.7-27.5 48L349 597.4V838c0 17.7 14.2 32 31.8 32h262.4c17.6 0 31.8-14.3 31.8-32V597.4L907.7 202c12.2-21.3-3.1-48-27.6-48zM603.4 798H420.6V642h182.9v156zm9.6-236.6l-9.5 16.6h-183l-9.5-16.6L212.7 226h598.6L613 561.4z\"}}]})(props);\n};\nexport function AiOutlineFire (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M834.1 469.2A347.49 347.49 0 0 0 751.2 354l-29.1-26.7a8.09 8.09 0 0 0-13 3.3l-13 37.3c-8.1 23.4-23 47.3-44.1 70.8-1.4 1.5-3 1.9-4.1 2-1.1.1-2.8-.1-4.3-1.5-1.4-1.2-2.1-3-2-4.8 3.7-60.2-14.3-128.1-53.7-202C555.3 171 510 123.1 453.4 89.7l-41.3-24.3c-5.4-3.2-12.3 1-12 7.3l2.2 48c1.5 32.8-2.3 61.8-11.3 85.9-11 29.5-26.8 56.9-47 81.5a295.64 295.64 0 0 1-47.5 46.1 352.6 352.6 0 0 0-100.3 121.5A347.75 347.75 0 0 0 160 610c0 47.2 9.3 92.9 27.7 136a349.4 349.4 0 0 0 75.5 110.9c32.4 32 70 57.2 111.9 74.7C418.5 949.8 464.5 959 512 959s93.5-9.2 136.9-27.3A348.6 348.6 0 0 0 760.8 857c32.4-32 57.8-69.4 75.5-110.9a344.2 344.2 0 0 0 27.7-136c0-48.8-10-96.2-29.9-140.9zM713 808.5c-53.7 53.2-125 82.4-201 82.4s-147.3-29.2-201-82.4c-53.5-53.1-83-123.5-83-198.4 0-43.5 9.8-85.2 29.1-124 18.8-37.9 46.8-71.8 80.8-97.9a349.6 349.6 0 0 0 58.6-56.8c25-30.5 44.6-64.5 58.2-101a240 240 0 0 0 12.1-46.5c24.1 22.2 44.3 49 61.2 80.4 33.4 62.6 48.8 118.3 45.8 165.7a74.01 74.01 0 0 0 24.4 59.8 73.36 73.36 0 0 0 53.4 18.8c19.7-1 37.8-9.7 51-24.4 13.3-14.9 24.8-30.1 34.4-45.6 14 17.9 25.7 37.4 35 58.4 15.9 35.8 24 73.9 24 113.1 0 74.9-29.5 145.4-83 198.4z\"}}]})(props);\n};\nexport function AiOutlineFlag (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 305H624V192c0-17.7-14.3-32-32-32H184v-40c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v784c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V640h248v113c0 17.7 14.3 32 32 32h416c17.7 0 32-14.3 32-32V337c0-17.7-14.3-32-32-32zM184 568V232h368v336H184zm656 145H504v-73h112c4.4 0 8-3.6 8-8V377h216v336z\"}}]})(props);\n};\nexport function AiOutlineFolderAdd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M484 443.1V528h-84.5c-4.1 0-7.5 3.1-7.5 7v42c0 3.8 3.4 7 7.5 7H484v84.9c0 3.9 3.2 7.1 7 7.1h42c3.9 0 7-3.2 7-7.1V584h84.5c4.1 0 7.5-3.2 7.5-7v-42c0-3.9-3.4-7-7.5-7H540v-84.9c0-3.9-3.1-7.1-7-7.1h-42c-3.8 0-7 3.2-7 7.1zm396-144.7H521L403.7 186.2a8.15 8.15 0 0 0-5.5-2.2H144c-17.7 0-32 14.3-32 32v592c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V330.4c0-17.7-14.3-32-32-32zM840 768H184V256h188.5l119.6 114.4H840V768z\"}}]})(props);\n};\nexport function AiOutlineFolderOpen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 444H820V330.4c0-17.7-14.3-32-32-32H473L355.7 186.2a8.15 8.15 0 0 0-5.5-2.2H96c-17.7 0-32 14.3-32 32v592c0 17.7 14.3 32 32 32h698c13 0 24.8-7.9 29.7-20l134-332c1.5-3.8 2.3-7.9 2.3-12 0-17.7-14.3-32-32-32zM136 256h188.5l119.6 114.4H748V444H238c-13 0-24.8 7.9-29.7 20L136 643.2V256zm635.3 512H159l103.3-256h612.4L771.3 768z\"}}]})(props);\n};\nexport function AiOutlineFolderView (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683698855\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M309.1 554.3c-5.4 11.6-5.4 24.9 0 36.4C353.3 684 421.6 732 512.5 732s159.2-48.1 203.4-141.3c5.4-11.5 5.4-24.8 0.1-36.3l-0.1-0.1-0.1-0.1C671.7 461 603.4 413 512.5 413s-159.2 48.1-203.4 141.3zM512.5 477c62.1 0 107.4 30 141.1 95.5C620 638 574.6 668 512.5 668s-107.4-30-141.1-95.5c33.7-65.5 79-95.5 141.1-95.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M513 573m-56 0a56 56 0 1 0 112 0 56 56 0 1 0-112 0Z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 298.4H521L403.7 186.2c-1.5-1.4-3.5-2.2-5.5-2.2H144c-17.7 0-32 14.3-32 32v592c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V330.4c0-17.7-14.3-32-32-32zM840 768H184V256h188.5l119.6 114.4H840V768z\"}}]})(props);\n};\nexport function AiOutlineFolder (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 298.4H521L403.7 186.2a8.15 8.15 0 0 0-5.5-2.2H144c-17.7 0-32 14.3-32 32v592c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V330.4c0-17.7-14.3-32-32-32zM840 768H184V256h188.5l119.6 114.4H840V768z\"}}]})(props);\n};\nexport function AiOutlineFontColors (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M904 816H120c-4.4 0-8 3.6-8 8v80c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-80c0-4.4-3.6-8-8-8zm-650.3-80h85c4.2 0 8-2.7 9.3-6.8l53.7-166h219.2l53.2 166c1.3 4 5 6.8 9.3 6.8h89.1c1.1 0 2.2-.2 3.2-.5a9.7 9.7 0 0 0 6-12.4L573.6 118.6a9.9 9.9 0 0 0-9.2-6.6H462.1c-4.2 0-7.9 2.6-9.2 6.6L244.5 723.1c-.4 1-.5 2.1-.5 3.2-.1 5.3 4.3 9.7 9.7 9.7zm255.9-516.1h4.1l83.8 263.8H424.9l84.7-263.8z\"}}]})(props);\n};\nexport function AiOutlineFontSize (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M920 416H616c-4.4 0-8 3.6-8 8v112c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-56h60v320h-46c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h164c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8h-46V480h60v56c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V424c0-4.4-3.6-8-8-8zM656 296V168c0-4.4-3.6-8-8-8H104c-4.4 0-8 3.6-8 8v128c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-64h168v560h-92c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h264c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-92V232h168v64c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8z\"}}]})(props);\n};\nexport function AiOutlineFork (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M752 100c-61.8 0-112 50.2-112 112 0 47.7 29.9 88.5 72 104.6v27.6L512 601.4 312 344.2v-27.6c42.1-16.1 72-56.9 72-104.6 0-61.8-50.2-112-112-112s-112 50.2-112 112c0 50.6 33.8 93.5 80 107.3v34.4c0 9.7 3.3 19.3 9.3 27L476 672.3v33.6c-44.2 15-76 56.9-76 106.1 0 61.8 50.2 112 112 112s112-50.2 112-112c0-49.2-31.8-91-76-106.1v-33.6l226.7-291.6c6-7.7 9.3-17.3 9.3-27v-34.4c46.2-13.8 80-56.7 80-107.3 0-61.8-50.2-112-112-112zM224 212a48.01 48.01 0 0 1 96 0 48.01 48.01 0 0 1-96 0zm336 600a48.01 48.01 0 0 1-96 0 48.01 48.01 0 0 1 96 0zm192-552a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96z\"}}]})(props);\n};\nexport function AiOutlineForm (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M904 512h-56c-4.4 0-8 3.6-8 8v320H184V184h320c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V520c0-4.4-3.6-8-8-8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M355.9 534.9L354 653.8c-.1 8.9 7.1 16.2 16 16.2h.4l118-2.9c2-.1 4-.9 5.4-2.3l415.9-415c3.1-3.1 3.1-8.2 0-11.3L785.4 114.3c-1.6-1.6-3.6-2.3-5.7-2.3s-4.1.8-5.7 2.3l-415.8 415a8.3 8.3 0 0 0-2.3 5.6zm63.5 23.6L779.7 199l45.2 45.1-360.5 359.7-45.7 1.1.7-46.4z\"}}]})(props);\n};\nexport function AiOutlineFormatPainter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683552617\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M840 192h-56v-72c0-13.3-10.7-24-24-24H168c-13.3 0-24 10.7-24 24v272c0 13.3 10.7 24 24 24h592c13.3 0 24-10.7 24-24V256h32v200H465c-22.1 0-40 17.9-40 40v136h-44c-4.4 0-8 3.6-8 8v228c0 0.6 0.1 1.3 0.2 1.9-0.1 2-0.2 4.1-0.2 6.1 0 46.4 37.6 84 84 84s84-37.6 84-84c0-2.1-0.1-4.1-0.2-6.1 0.1-0.6 0.2-1.2 0.2-1.9V640c0-4.4-3.6-8-8-8h-44V520h351c22.1 0 40-17.9 40-40V232c0-22.1-17.9-40-40-40zM720 352H208V160h512v192zM477 876c0 11-9 20-20 20s-20-9-20-20V696h40v180z\"}}]})(props);\n};\nexport function AiOutlineForward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M825.8 498L538.4 249.9c-10.7-9.2-26.4-.9-26.4 14v496.3c0 14.9 15.7 23.2 26.4 14L825.8 526c8.3-7.2 8.3-20.8 0-28zm-320 0L218.4 249.9c-10.7-9.2-26.4-.9-26.4 14v496.3c0 14.9 15.7 23.2 26.4 14L505.8 526c4.1-3.6 6.2-8.8 6.2-14 0-5.2-2.1-10.4-6.2-14z\"}}]})(props);\n};\nexport function AiOutlineFrown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M288 421a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm352 0a48 48 0 1 0 96 0 48 48 0 1 0-96 0zM512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm263 711c-34.2 34.2-74 61-118.3 79.8C611 874.2 562.3 884 512 884c-50.3 0-99-9.8-144.8-29.2A370.4 370.4 0 0 1 248.9 775c-34.2-34.2-61-74-79.8-118.3C149.8 611 140 562.3 140 512s9.8-99 29.2-144.8A370.4 370.4 0 0 1 249 248.9c34.2-34.2 74-61 118.3-79.8C413 149.8 461.7 140 512 140c50.3 0 99 9.8 144.8 29.2A370.4 370.4 0 0 1 775.1 249c34.2 34.2 61 74 79.8 118.3C874.2 413 884 461.7 884 512s-9.8 99-29.2 144.8A368.89 368.89 0 0 1 775 775zM512 533c-85.5 0-155.6 67.3-160 151.6a8 8 0 0 0 8 8.4h48.1c4.2 0 7.8-3.2 8.1-7.4C420 636.1 461.5 597 512 597s92.1 39.1 95.8 88.6c.3 4.2 3.9 7.4 8.1 7.4H664a8 8 0 0 0 8-8.4C667.6 600.3 597.5 533 512 533z\"}}]})(props);\n};\nexport function AiOutlineFullscreenExit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M391 240.9c-.8-6.6-8.9-9.4-13.6-4.7l-43.7 43.7L200 146.3a8.03 8.03 0 0 0-11.3 0l-42.4 42.3a8.03 8.03 0 0 0 0 11.3L280 333.6l-43.9 43.9a8.01 8.01 0 0 0 4.7 13.6L401 410c5.1.6 9.5-3.7 8.9-8.9L391 240.9zm10.1 373.2L240.8 633c-6.6.8-9.4 8.9-4.7 13.6l43.9 43.9L146.3 824a8.03 8.03 0 0 0 0 11.3l42.4 42.3c3.1 3.1 8.2 3.1 11.3 0L333.7 744l43.7 43.7A8.01 8.01 0 0 0 391 783l18.9-160.1c.6-5.1-3.7-9.4-8.8-8.8zm221.8-204.2L783.2 391c6.6-.8 9.4-8.9 4.7-13.6L744 333.6 877.7 200c3.1-3.1 3.1-8.2 0-11.3l-42.4-42.3a8.03 8.03 0 0 0-11.3 0L690.3 279.9l-43.7-43.7a8.01 8.01 0 0 0-13.6 4.7L614.1 401c-.6 5.2 3.7 9.5 8.8 8.9zM744 690.4l43.9-43.9a8.01 8.01 0 0 0-4.7-13.6L623 614c-5.1-.6-9.5 3.7-8.9 8.9L633 783.1c.8 6.6 8.9 9.4 13.6 4.7l43.7-43.7L824 877.7c3.1 3.1 8.2 3.1 11.3 0l42.4-42.3c3.1-3.1 3.1-8.2 0-11.3L744 690.4z\"}}]})(props);\n};\nexport function AiOutlineFullscreen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M290 236.4l43.9-43.9a8.01 8.01 0 0 0-4.7-13.6L169 160c-5.1-.6-9.5 3.7-8.9 8.9L179 329.1c.8 6.6 8.9 9.4 13.6 4.7l43.7-43.7L370 423.7c3.1 3.1 8.2 3.1 11.3 0l42.4-42.3c3.1-3.1 3.1-8.2 0-11.3L290 236.4zm352.7 187.3c3.1 3.1 8.2 3.1 11.3 0l133.7-133.6 43.7 43.7a8.01 8.01 0 0 0 13.6-4.7L863.9 169c.6-5.1-3.7-9.5-8.9-8.9L694.8 179c-6.6.8-9.4 8.9-4.7 13.6l43.9 43.9L600.3 370a8.03 8.03 0 0 0 0 11.3l42.4 42.4zM845 694.9c-.8-6.6-8.9-9.4-13.6-4.7l-43.7 43.7L654 600.3a8.03 8.03 0 0 0-11.3 0l-42.4 42.3a8.03 8.03 0 0 0 0 11.3L734 787.6l-43.9 43.9a8.01 8.01 0 0 0 4.7 13.6L855 864c5.1.6 9.5-3.7 8.9-8.9L845 694.9zm-463.7-94.6a8.03 8.03 0 0 0-11.3 0L236.3 733.9l-43.7-43.7a8.01 8.01 0 0 0-13.6 4.7L160.1 855c-.6 5.1 3.7 9.5 8.9 8.9L329.2 845c6.6-.8 9.4-8.9 4.7-13.6L290 787.6 423.7 654c3.1-3.1 3.1-8.2 0-11.3l-42.4-42.4z\"}}]})(props);\n};\nexport function AiOutlineFunction (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683610100\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M841 370c3-3.3 2.7-8.3-0.6-11.3-1.5-1.3-3.4-2.1-5.3-2.1h-72.6c-2.4 0-4.6 1-6.1 2.8L633.5 504.6c-2.9 3.4-7.9 3.8-11.3 0.9-0.9-0.8-1.6-1.7-2.1-2.8l-63.5-141.3c-1.3-2.9-4.1-4.7-7.3-4.7H380.7l0.9-4.7 8-42.3c10.5-55.4 38-81.4 85.8-81.4 18.6 0 35.5 1.7 48.8 4.7l14.1-66.8c-22.6-4.7-35.2-6.1-54.9-6.1-103.3 0-156.4 44.3-175.9 147.3l-9.4 49.4h-97.6c-3.8 0-7.1 2.7-7.8 6.4L181.9 415c-0.9 4.3 1.9 8.6 6.2 9.5 0.5 0.1 1.1 0.2 1.6 0.2H284l-89 429.9c-0.9 4.3 1.9 8.6 6.2 9.5 0.5 0.1 1.1 0.2 1.6 0.2H269c3.8 0 7.1-2.7 7.8-6.4l89.7-433.1h135.8l68.2 139.1c1.4 2.9 1 6.4-1.2 8.8l-180.6 203c-2.9 3.3-2.6 8.4 0.7 11.3 1.5 1.3 3.4 2 5.3 2h72.7c2.4 0 4.6-1 6.1-2.8l123.7-146.7c2.8-3.4 7.9-3.8 11.3-1 0.9 0.8 1.6 1.7 2.1 2.8L676.4 784c1.3 2.8 4.1 4.7 7.3 4.7h64.6c4.4 0 8-3.6 8-8 0-1.2-0.3-2.4-0.8-3.5l-95.2-198.9c-1.4-2.9-0.9-6.4 1.3-8.8L841 370z\"}}]})(props);\n};\nexport function AiOutlineFundProjectionScreen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683753031\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M312.1 591.5c3.1 3.1 8.2 3.1 11.3 0l101.8-101.8 86.1 86.2c3.1 3.1 8.2 3.1 11.3 0l226.3-226.5c3.1-3.1 3.1-8.2 0-11.3l-36.8-36.8c-3.1-3.1-8.2-3.1-11.3 0L517 485.3l-86.1-86.2c-3.1-3.1-8.2-3.1-11.3 0L275.3 543.4c-3.1 3.1-3.1 8.2 0 11.3l36.8 36.8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M904 160H548V96c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H120c-17.7 0-32 14.3-32 32v520c0 17.7 14.3 32 32 32h356.4v32L311.6 884.1c-3.7 2.4-4.7 7.3-2.3 11l30.3 47.2v0.1c2.4 3.7 7.4 4.7 11.1 2.3L512 838.9l161.3 105.8c3.7 2.4 8.7 1.4 11.1-2.3v-0.1l30.3-47.2c2.4-3.7 1.3-8.6-2.3-11L548 776.3V744h356c17.7 0 32-14.3 32-32V192c0-17.7-14.3-32-32-32z m-40 512H160V232h704v440z\"}}]})(props);\n};\nexport function AiOutlineFundView (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683816874\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M956 686.5l-0.1-0.1-0.1-0.1C911.7 593 843.4 545 752.5 545s-159.2 48.1-203.4 141.3v0.1c-5.4 11.5-5.4 24.9 0 36.4C593.3 816 661.6 864 752.5 864s159.2-48.1 203.4-141.3c5.4-11.5 5.4-24.8 0.1-36.2zM752.5 800c-62.1 0-107.4-30-141.1-95.5C645 639 690.4 609 752.5 609c62.1 0 107.4 30 141.1 95.5C860 770 814.6 800 752.5 800z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M753 705m-56 0a56 56 0 1 0 112 0 56 56 0 1 0-112 0Z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M136 232h704v253h72V192c0-17.7-14.3-32-32-32H96c-17.7 0-32 14.3-32 32v520c0 17.7 14.3 32 32 32h352v-72H136V232z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M724.9 338.1l-36.8-36.8c-3.1-3.1-8.2-3.1-11.3 0L493 485.3l-86.1-86.2c-3.1-3.1-8.2-3.1-11.3 0L251.3 543.4c-3.1 3.1-3.1 8.2 0 11.3l36.8 36.8c3.1 3.1 8.2 3.1 11.3 0l101.8-101.8 86.1 86.2c3.1 3.1 8.2 3.1 11.3 0l226.3-226.5c3.2-3.1 3.2-8.2 0-11.3z\"}}]})(props);\n};\nexport function AiOutlineFund (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M926 164H94c-17.7 0-32 14.3-32 32v640c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V196c0-17.7-14.3-32-32-32zm-40 632H134V236h752v560zm-658.9-82.3c3.1 3.1 8.2 3.1 11.3 0l172.5-172.5 114.4 114.5c3.1 3.1 8.2 3.1 11.3 0l297-297.2c3.1-3.1 3.1-8.2 0-11.3l-36.8-36.8a8.03 8.03 0 0 0-11.3 0L531 565 416.6 450.5a8.03 8.03 0 0 0-11.3 0l-214.9 215a8.03 8.03 0 0 0 0 11.3l36.7 36.9z\"}}]})(props);\n};\nexport function AiOutlineFunnelPlot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880.1 154H143.9c-24.5 0-39.8 26.7-27.5 48L349 607.4V838c0 17.7 14.2 32 31.8 32h262.4c17.6 0 31.8-14.3 31.8-32V607.4L907.7 202c12.2-21.3-3.1-48-27.6-48zM603.4 798H420.6V650h182.9v148zm9.6-226.6l-8.4 14.6H419.3l-8.4-14.6L334.4 438h355.2L613 571.4zM726.3 374H297.7l-85-148h598.6l-85 148z\"}}]})(props);\n};\nexport function AiOutlineGateway (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 392c8.8 0 16-7.2 16-16V192c0-8.8-7.2-16-16-16H744c-8.8 0-16 7.2-16 16v56H296v-56c0-8.8-7.2-16-16-16H96c-8.8 0-16 7.2-16 16v184c0 8.8 7.2 16 16 16h56v240H96c-8.8 0-16 7.2-16 16v184c0 8.8 7.2 16 16 16h184c8.8 0 16-7.2 16-16v-56h432v56c0 8.8 7.2 16 16 16h184c8.8 0 16-7.2 16-16V648c0-8.8-7.2-16-16-16h-56V392h56zM792 240h88v88h-88v-88zm-648 88v-88h88v88h-88zm88 456h-88v-88h88v88zm648-88v88h-88v-88h88zm-80-64h-56c-8.8 0-16 7.2-16 16v56H296v-56c0-8.8-7.2-16-16-16h-56V392h56c8.8 0 16-7.2 16-16v-56h432v56c0 8.8 7.2 16 16 16h56v240z\"}}]})(props);\n};\nexport function AiOutlineGif (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683621237\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M944 299H692c-4.4 0-8 3.6-8 8v406c0 4.4 3.6 8 8 8h59.2c4.4 0 8-3.6 8-8V549.9h168.2c4.4 0 8-3.6 8-8V495c0-4.4-3.6-8-8-8H759.2V364.2H944c4.4 0 8-3.6 8-8V307c0-4.4-3.6-8-8-8zM588 300h-56c-4.4 0-8 3.6-8 8v406c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V308c0-4.4-3.6-8-8-8zM452 500.9H290.5c-4.4 0-8 3.6-8 8v43.7c0 4.4 3.6 8 8 8h94.9l-0.3 8.9c-1.2 58.8-45.6 98.5-110.9 98.5-76.2 0-123.9-59.7-123.9-156.7 0-95.8 46.8-155.2 121.5-155.2 54.8 0 93.1 26.9 108.5 75.4h76.2c-13.6-87.2-86-143.4-184.7-143.4C150 288 72 375.2 72 511.9 72 650.2 149.1 736 273 736c114.1 0 187-70.7 187-181.6v-45.5c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineGift (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 310H732.4c13.6-21.4 21.6-46.8 21.6-74 0-76.1-61.9-138-138-138-41.4 0-78.7 18.4-104 47.4-25.3-29-62.6-47.4-104-47.4-76.1 0-138 61.9-138 138 0 27.2 7.9 52.6 21.6 74H144c-17.7 0-32 14.3-32 32v200c0 4.4 3.6 8 8 8h40v344c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V550h40c4.4 0 8-3.6 8-8V342c0-17.7-14.3-32-32-32zm-334-74c0-38.6 31.4-70 70-70s70 31.4 70 70-31.4 70-70 70h-70v-70zm-138-70c38.6 0 70 31.4 70 70v70h-70c-38.6 0-70-31.4-70-70s31.4-70 70-70zM180 482V378h298v104H180zm48 68h250v308H228V550zm568 308H546V550h250v308zm48-376H546V378h298v104z\"}}]})(props);\n};\nexport function AiOutlineGithub (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M511.6 76.3C264.3 76.2 64 276.4 64 523.5 64 718.9 189.3 885 363.8 946c23.5 5.9 19.9-10.8 19.9-22.2v-77.5c-135.7 15.9-141.2-73.9-150.3-88.9C215 726 171.5 718 184.5 703c30.9-15.9 62.4 4 98.9 57.9 26.4 39.1 77.9 32.5 104 26 5.7-23.5 17.9-44.5 34.7-60.8-140.6-25.2-199.2-111-199.2-213 0-49.5 16.3-95 48.3-131.7-20.4-60.5 1.9-112.3 4.9-120 58.1-5.2 118.5 41.6 123.2 45.3 33-8.9 70.7-13.6 112.9-13.6 42.4 0 80.2 4.9 113.5 13.9 11.3-8.6 67.3-48.8 121.3-43.9 2.9 7.7 24.7 58.3 5.5 118 32.4 36.8 48.9 82.7 48.9 132.3 0 102.2-59 188.1-200 212.9a127.5 127.5 0 0 1 38.1 91v112.5c.8 9 0 17.9 15 17.9 177.1-59.7 304.6-227 304.6-424.1 0-247.2-200.4-447.3-447.5-447.3z\"}}]})(props);\n};\nexport function AiOutlineGitlab (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M913.9 552.2L805 181.4v-.1c-7.6-22.9-25.7-36.5-48.3-36.5-23.4 0-42.5 13.5-49.7 35.2l-71.4 213H388.8l-71.4-213c-7.2-21.7-26.3-35.2-49.7-35.2-23.1 0-42.5 14.8-48.4 36.6L110.5 552.2c-4.4 14.7 1.2 31.4 13.5 40.7l368.5 276.4c2.6 3.6 6.2 6.3 10.4 7.8l8.6 6.4 8.5-6.4c4.9-1.7 9-4.7 11.9-8.9l368.4-275.4c12.4-9.2 18-25.9 13.6-40.6zM751.7 193.4c1-1.8 2.9-1.9 3.5-1.9 1.1 0 2.5.3 3.4 3L818 394.3H684.5l67.2-200.9zm-487.4 1c.9-2.6 2.3-2.9 3.4-2.9 2.7 0 2.9.1 3.4 1.7l67.3 201.2H206.5l57.8-200zM158.8 558.7l28.2-97.3 202.4 270.2-230.6-172.9zm73.9-116.4h122.1l90.8 284.3-212.9-284.3zM512.9 776L405.7 442.3H620L512.9 776zm157.9-333.7h119.5L580 723.1l90.8-280.8zm-40.7 293.9l207.3-276.7 29.5 99.2-236.8 177.5z\"}}]})(props);\n};\nexport function AiOutlineGlobal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.4 800.9c.2-.3.5-.6.7-.9C920.6 722.1 960 621.7 960 512s-39.4-210.1-104.8-288c-.2-.3-.5-.5-.7-.8-1.1-1.3-2.1-2.5-3.2-3.7-.4-.5-.8-.9-1.2-1.4l-4.1-4.7-.1-.1c-1.5-1.7-3.1-3.4-4.6-5.1l-.1-.1c-3.2-3.4-6.4-6.8-9.7-10.1l-.1-.1-4.8-4.8-.3-.3c-1.5-1.5-3-2.9-4.5-4.3-.5-.5-1-1-1.6-1.5-1-1-2-1.9-3-2.8-.3-.3-.7-.6-1-1C736.4 109.2 629.5 64 512 64s-224.4 45.2-304.3 119.2c-.3.3-.7.6-1 1-1 .9-2 1.9-3 2.9-.5.5-1 1-1.6 1.5-1.5 1.4-3 2.9-4.5 4.3l-.3.3-4.8 4.8-.1.1c-3.3 3.3-6.5 6.7-9.7 10.1l-.1.1c-1.6 1.7-3.1 3.4-4.6 5.1l-.1.1c-1.4 1.5-2.8 3.1-4.1 4.7-.4.5-.8.9-1.2 1.4-1.1 1.2-2.1 2.5-3.2 3.7-.2.3-.5.5-.7.8C103.4 301.9 64 402.3 64 512s39.4 210.1 104.8 288c.2.3.5.6.7.9l3.1 3.7c.4.5.8.9 1.2 1.4l4.1 4.7c0 .1.1.1.1.2 1.5 1.7 3 3.4 4.6 5l.1.1c3.2 3.4 6.4 6.8 9.6 10.1l.1.1c1.6 1.6 3.1 3.2 4.7 4.7l.3.3c3.3 3.3 6.7 6.5 10.1 9.6 80.1 74 187 119.2 304.5 119.2s224.4-45.2 304.3-119.2a300 300 0 0 0 10-9.6l.3-.3c1.6-1.6 3.2-3.1 4.7-4.7l.1-.1c3.3-3.3 6.5-6.7 9.6-10.1l.1-.1c1.5-1.7 3.1-3.3 4.6-5 0-.1.1-.1.1-.2 1.4-1.5 2.8-3.1 4.1-4.7.4-.5.8-.9 1.2-1.4a99 99 0 0 0 3.3-3.7zm4.1-142.6c-13.8 32.6-32 62.8-54.2 90.2a444.07 444.07 0 0 0-81.5-55.9c11.6-46.9 18.8-98.4 20.7-152.6H887c-3 40.9-12.6 80.6-28.5 118.3zM887 484H743.5c-1.9-54.2-9.1-105.7-20.7-152.6 29.3-15.6 56.6-34.4 81.5-55.9A373.86 373.86 0 0 1 887 484zM658.3 165.5c39.7 16.8 75.8 40 107.6 69.2a394.72 394.72 0 0 1-59.4 41.8c-15.7-45-35.8-84.1-59.2-115.4 3.7 1.4 7.4 2.9 11 4.4zm-90.6 700.6c-9.2 7.2-18.4 12.7-27.7 16.4V697a389.1 389.1 0 0 1 115.7 26.2c-8.3 24.6-17.9 47.3-29 67.8-17.4 32.4-37.8 58.3-59 75.1zm59-633.1c11 20.6 20.7 43.3 29 67.8A389.1 389.1 0 0 1 540 327V141.6c9.2 3.7 18.5 9.1 27.7 16.4 21.2 16.7 41.6 42.6 59 75zM540 640.9V540h147.5c-1.6 44.2-7.1 87.1-16.3 127.8l-.3 1.2A445.02 445.02 0 0 0 540 640.9zm0-156.9V383.1c45.8-2.8 89.8-12.5 130.9-28.1l.3 1.2c9.2 40.7 14.7 83.5 16.3 127.8H540zm-56 56v100.9c-45.8 2.8-89.8 12.5-130.9 28.1l-.3-1.2c-9.2-40.7-14.7-83.5-16.3-127.8H484zm-147.5-56c1.6-44.2 7.1-87.1 16.3-127.8l.3-1.2c41.1 15.6 85 25.3 130.9 28.1V484H336.5zM484 697v185.4c-9.2-3.7-18.5-9.1-27.7-16.4-21.2-16.7-41.7-42.7-59.1-75.1-11-20.6-20.7-43.3-29-67.8 37.2-14.6 75.9-23.3 115.8-26.1zm0-370a389.1 389.1 0 0 1-115.7-26.2c8.3-24.6 17.9-47.3 29-67.8 17.4-32.4 37.8-58.4 59.1-75.1 9.2-7.2 18.4-12.7 27.7-16.4V327zM365.7 165.5c3.7-1.5 7.3-3 11-4.4-23.4 31.3-43.5 70.4-59.2 115.4-21-12-40.9-26-59.4-41.8 31.8-29.2 67.9-52.4 107.6-69.2zM165.5 365.7c13.8-32.6 32-62.8 54.2-90.2 24.9 21.5 52.2 40.3 81.5 55.9-11.6 46.9-18.8 98.4-20.7 152.6H137c3-40.9 12.6-80.6 28.5-118.3zM137 540h143.5c1.9 54.2 9.1 105.7 20.7 152.6a444.07 444.07 0 0 0-81.5 55.9A373.86 373.86 0 0 1 137 540zm228.7 318.5c-39.7-16.8-75.8-40-107.6-69.2 18.5-15.8 38.4-29.7 59.4-41.8 15.7 45 35.8 84.1 59.2 115.4-3.7-1.4-7.4-2.9-11-4.4zm292.6 0c-3.7 1.5-7.3 3-11 4.4 23.4-31.3 43.5-70.4 59.2-115.4 21 12 40.9 26 59.4 41.8a373.81 373.81 0 0 1-107.6 69.2z\"}}]})(props);\n};\nexport function AiOutlineGold (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M342 472h342c.4 0 .9 0 1.3-.1 4.4-.7 7.3-4.8 6.6-9.2l-40.2-248c-.6-3.9-4-6.7-7.9-6.7H382.2c-3.9 0-7.3 2.8-7.9 6.7l-40.2 248c-.1.4-.1.9-.1 1.3 0 4.4 3.6 8 8 8zm91.2-196h159.5l20.7 128h-201l20.8-128zm2.5 282.7c-.6-3.9-4-6.7-7.9-6.7H166.2c-3.9 0-7.3 2.8-7.9 6.7l-40.2 248c-.1.4-.1.9-.1 1.3 0 4.4 3.6 8 8 8h342c.4 0 .9 0 1.3-.1 4.4-.7 7.3-4.8 6.6-9.2l-40.2-248zM196.5 748l20.7-128h159.5l20.7 128H196.5zm709.4 58.7l-40.2-248c-.6-3.9-4-6.7-7.9-6.7H596.2c-3.9 0-7.3 2.8-7.9 6.7l-40.2 248c-.1.4-.1.9-.1 1.3 0 4.4 3.6 8 8 8h342c.4 0 .9 0 1.3-.1 4.3-.7 7.3-4.8 6.6-9.2zM626.5 748l20.7-128h159.5l20.7 128H626.5z\"}}]})(props);\n};\nexport function AiOutlineGooglePlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M879.5 470.4c-.3-27-.4-54.2-.5-81.3h-80.8c-.3 27-.5 54.1-.7 81.3-27.2.1-54.2.3-81.2.6v80.9c27 .3 54.2.5 81.2.8.3 27 .3 54.1.5 81.1h80.9c.1-27 .3-54.1.5-81.3 27.2-.3 54.2-.4 81.2-.7v-80.9c-26.9-.2-54.1-.2-81.1-.5zm-530 .4c-.1 32.3 0 64.7.1 97 54.2 1.8 108.5 1 162.7 1.8-23.9 120.3-187.4 159.3-273.9 80.7-89-68.9-84.8-220 7.7-284 64.7-51.6 156.6-38.9 221.3 5.8 25.4-23.5 49.2-48.7 72.1-74.7-53.8-42.9-119.8-73.5-190-70.3-146.6-4.9-281.3 123.5-283.7 270.2-9.4 119.9 69.4 237.4 180.6 279.8 110.8 42.7 252.9 13.6 323.7-86 46.7-62.9 56.8-143.9 51.3-220-90.7-.7-181.3-.6-271.9-.3z\"}}]})(props);\n};\nexport function AiOutlineGoogle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M881 442.4H519.7v148.5h206.4c-8.9 48-35.9 88.6-76.6 115.8-34.4 23-78.3 36.6-129.9 36.6-99.9 0-184.4-67.5-214.6-158.2-7.6-23-12-47.6-12-72.9s4.4-49.9 12-72.9c30.3-90.6 114.8-158.1 214.7-158.1 56.3 0 106.8 19.4 146.6 57.4l110-110.1c-66.5-62-153.2-100-256.6-100-149.9 0-279.6 86-342.7 211.4-26 51.8-40.8 110.4-40.8 172.4S151 632.8 177 684.6C240.1 810 369.8 896 519.7 896c103.6 0 190.4-34.4 253.8-93 72.5-66.8 114.4-165.2 114.4-282.1 0-27.2-2.4-53.3-6.9-78.5z\"}}]})(props);\n};\nexport function AiOutlineGroup (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683739097\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M912 820.1V203.9c28-9.9 48-36.6 48-67.9 0-39.8-32.2-72-72-72-31.3 0-58 20-67.9 48H203.9C194 84 167.3 64 136 64c-39.8 0-72 32.2-72 72 0 31.3 20 58 48 67.9v616.2C84 830 64 856.7 64 888c0 39.8 32.2 72 72 72 31.3 0 58-20 67.9-48h616.2c9.9 28 36.6 48 67.9 48 39.8 0 72-32.2 72-72 0-31.3-20-58-48-67.9zM888 112c13.3 0 24 10.7 24 24s-10.7 24-24 24-24-10.7-24-24 10.7-24 24-24zM136 912c-13.3 0-24-10.7-24-24s10.7-24 24-24 24 10.7 24 24-10.7 24-24 24z m0-752c-13.3 0-24-10.7-24-24s10.7-24 24-24 24 10.7 24 24-10.7 24-24 24z m704 680H184V184h656v656z m48 72c-13.3 0-24-10.7-24-24s10.7-24 24-24 24 10.7 24 24-10.7 24-24 24z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M288 474h448c8.8 0 16-7.2 16-16V282c0-8.8-7.2-16-16-16H288c-8.8 0-16 7.2-16 16v176c0 8.8 7.2 16 16 16z m56-136h336v64H344v-64zM288 758h448c8.8 0 16-7.2 16-16V566c0-8.8-7.2-16-16-16H288c-8.8 0-16 7.2-16 16v176c0 8.8 7.2 16 16 16z m56-136h336v64H344v-64z\"}}]})(props);\n};\nexport function AiOutlineHdd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V96c0-17.7-14.3-32-32-32zm-600 72h560v208H232V136zm560 480H232V408h560v208zm0 272H232V680h560v208zM496 208H312c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zM312 544h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H312c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8zm328 244a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}}]})(props);\n};\nexport function AiOutlineHeart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M923 283.6a260.04 260.04 0 0 0-56.9-82.8 264.4 264.4 0 0 0-84-55.5A265.34 265.34 0 0 0 679.7 125c-49.3 0-97.4 13.5-139.2 39-10 6.1-19.5 12.8-28.5 20.1-9-7.3-18.5-14-28.5-20.1-41.8-25.5-89.9-39-139.2-39-35.5 0-69.9 6.8-102.4 20.3-31.4 13-59.7 31.7-84 55.5a258.44 258.44 0 0 0-56.9 82.8c-13.9 32.3-21 66.6-21 101.9 0 33.3 6.8 68 20.3 103.3 11.3 29.5 27.5 60.1 48.2 91 32.8 48.9 77.9 99.9 133.9 151.6 92.8 85.7 184.7 144.9 188.6 147.3l23.7 15.2c10.5 6.7 24 6.7 34.5 0l23.7-15.2c3.9-2.5 95.7-61.6 188.6-147.3 56-51.7 101.1-102.7 133.9-151.6 20.7-30.9 37-61.5 48.2-91 13.5-35.3 20.3-70 20.3-103.3.1-35.3-7-69.6-20.9-101.9zM512 814.8S156 586.7 156 385.5C156 283.6 240.3 201 344.3 201c73.1 0 136.5 40.8 167.7 100.4C543.2 241.8 606.6 201 679.7 201c104 0 188.3 82.6 188.3 184.5 0 201.2-356 429.3-356 429.3z\"}}]})(props);\n};\nexport function AiOutlineHeatMap (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M955.7 856l-416-720c-6.2-10.7-16.9-16-27.7-16s-21.6 5.3-27.7 16l-416 720C56 877.4 71.4 904 96 904h832c24.6 0 40-26.6 27.7-48zm-790.4-23.9L512 231.9 858.7 832H165.3zm319-474.1l-228 394c-12.3 21.3 3.1 48 27.7 48h455.8c24.7 0 40.1-26.7 27.7-48L539.7 358c-6.2-10.7-17-16-27.7-16-10.8 0-21.6 5.3-27.7 16zm214 386H325.7L512 422l186.3 322zm-214-194.1l-57 98.4C415 669.5 430.4 696 455 696h114c24.6 0 39.9-26.5 27.7-47.7l-57-98.4c-6.1-10.6-16.9-15.9-27.7-15.9s-21.5 5.3-27.7 15.9zm57.1 98.4h-58.7l29.4-50.7 29.3 50.7z\"}}]})(props);\n};\nexport function AiOutlineHighlight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M957.6 507.4L603.2 158.2a7.9 7.9 0 0 0-11.2 0L353.3 393.4a8.03 8.03 0 0 0-.1 11.3l.1.1 40 39.4-117.2 115.3a8.03 8.03 0 0 0-.1 11.3l.1.1 39.5 38.9-189.1 187H72.1c-4.4 0-8.1 3.6-8.1 8V860c0 4.4 3.6 8 8 8h344.9c2.1 0 4.1-.8 5.6-2.3l76.1-75.6 40.4 39.8a7.9 7.9 0 0 0 11.2 0l117.1-115.6 40.1 39.5a7.9 7.9 0 0 0 11.2 0l238.7-235.2c3.4-3 3.4-8 .3-11.2zM389.8 796.2H229.6l134.4-133 80.1 78.9-54.3 54.1zm154.8-62.1L373.2 565.2l68.6-67.6 171.4 168.9-68.6 67.6zM713.1 658L450.3 399.1 597.6 254l262.8 259-147.3 145z\"}}]})(props);\n};\nexport function AiOutlineHistory (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M536.1 273H488c-4.4 0-8 3.6-8 8v275.3c0 2.6 1.2 5 3.3 6.5l165.3 120.7c3.6 2.6 8.6 1.9 11.2-1.7l28.6-39c2.7-3.7 1.9-8.7-1.7-11.2L544.1 528.5V281c0-4.4-3.6-8-8-8zm219.8 75.2l156.8 38.3c5 1.2 9.9-2.6 9.9-7.7l.8-161.5c0-6.7-7.7-10.5-12.9-6.3L752.9 334.1a8 8 0 0 0 3 14.1zm167.7 301.1l-56.7-19.5a8 8 0 0 0-10.1 4.8c-1.9 5.1-3.9 10.1-6 15.1-17.8 42.1-43.3 80-75.9 112.5a353 353 0 0 1-112.5 75.9 352.18 352.18 0 0 1-137.7 27.8c-47.8 0-94.1-9.3-137.7-27.8a353 353 0 0 1-112.5-75.9c-32.5-32.5-58-70.4-75.9-112.5A353.44 353.44 0 0 1 171 512c0-47.8 9.3-94.2 27.8-137.8 17.8-42.1 43.3-80 75.9-112.5a353 353 0 0 1 112.5-75.9C430.6 167.3 477 158 524.8 158s94.1 9.3 137.7 27.8A353 353 0 0 1 775 261.7c10.2 10.3 19.8 21 28.6 32.3l59.8-46.8C784.7 146.6 662.2 81.9 524.6 82 285 82.1 92.6 276.7 95 516.4 97.4 751.9 288.9 942 524.8 942c185.5 0 343.5-117.6 403.7-282.3 1.5-4.2-.7-8.9-4.9-10.4z\"}}]})(props);\n};\nexport function AiOutlineHolder (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M300,276.497424 C317.32646,286.500861 338.67354,286.500861 356,276.497424 C373.326461,266.493987 384,248.006874 384,228 C384,207.993128 373.326461,189.506014 356,179.502578 C338.67354,169.499141 317.32646,169.499141 300,179.502578 C282.673539,189.506014 272,207.993128 272,228 C272,248.006874 282.673539,266.493987 300,276.497424 Z M300,560.497426 C317.32646,570.500863 338.67354,570.500863 356,560.497426 C373.326461,550.493989 384,532.006876 384,512.000002 C384,491.993129 373.326461,473.506016 356,463.502579 C338.67354,453.499142 317.32646,453.499142 300,463.502579 C282.673539,473.506016 272,491.993129 272,512.000002 C272,532.006876 282.673539,550.493989 300,560.497426 Z M640,228 C640,248.006874 650.673539,266.493987 668,276.497424 C685.32646,286.500861 706.67354,286.500861 724,276.497424 C741.326461,266.493987 752,248.006874 752,228 C752,207.993128 741.326461,189.506014 724,179.502578 C706.67354,169.499141 685.32646,169.499141 668,179.502578 C650.673539,189.506014 640,207.993128 640,228 L640,228 Z M640,512.000002 C640,532.006876 650.673539,550.493989 668,560.497426 C685.32646,570.500863 706.67354,570.500863 724,560.497426 C741.326461,550.493989 752,532.006876 752,512.000002 C752,491.993129 741.326461,473.506016 724,463.502579 C706.67354,453.499142 685.32646,453.499142 668,463.502579 C650.673539,473.506016 640,491.993129 640,512.000002 L640,512.000002 Z M300,844.497427 C317.32646,854.500864 338.67354,854.500864 356,844.497427 C373.326461,834.493991 384,816.006877 384,796.000003 C384,775.993131 373.326461,757.506018 356,747.502581 C338.67354,737.499144 317.32646,737.499144 300,747.502581 C282.673539,757.506018 272,775.993131 272,796.000003 C272,816.006877 282.673539,834.493991 300,844.497427 Z M640,796.000003 C640,816.006877 650.673539,834.493991 668,844.497427 C685.32646,854.500864 706.67354,854.500864 724,844.497427 C741.326461,834.493991 752,816.006877 752,796.000003 C752,775.993131 741.326461,757.506018 724,747.502581 C706.67354,737.499144 685.32646,737.499144 668,747.502581 C650.673539,757.506018 640,775.993131 640,796.000003 L640,796.000003 Z\"}}]})(props);\n};\nexport function AiOutlineHome (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M946.5 505L560.1 118.8l-25.9-25.9a31.5 31.5 0 0 0-44.4 0L77.5 505a63.9 63.9 0 0 0-18.8 46c.4 35.2 29.7 63.3 64.9 63.3h42.5V940h691.8V614.3h43.4c17.1 0 33.2-6.7 45.3-18.8a63.6 63.6 0 0 0 18.7-45.3c0-17-6.7-33.1-18.8-45.2zM568 868H456V664h112v204zm217.9-325.7V868H632V640c0-22.1-17.9-40-40-40H432c-22.1 0-40 17.9-40 40v228H238.1V542.3h-96l370-369.7 23.1 23.1L882 542.3h-96.1z\"}}]})(props);\n};\nexport function AiOutlineHourglass (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M742 318V184h86c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H196c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h86v134c0 81.5 42.4 153.2 106.4 194-64 40.8-106.4 112.5-106.4 194v134h-86c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h632c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-86V706c0-81.5-42.4-153.2-106.4-194 64-40.8 106.4-112.5 106.4-194zm-72 388v134H354V706c0-42.2 16.4-81.9 46.3-111.7C430.1 564.4 469.8 548 512 548s81.9 16.4 111.7 46.3C653.6 624.1 670 663.8 670 706zm0-388c0 42.2-16.4 81.9-46.3 111.7C593.9 459.6 554.2 476 512 476s-81.9-16.4-111.7-46.3A156.63 156.63 0 0 1 354 318V184h316v134z\"}}]})(props);\n};\nexport function AiOutlineHtml5 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M145 96l66 746.6L511.8 928l299.6-85.4L878.7 96H145zm610.9 700.6l-244.1 69.6-245.2-69.6-56.7-641.2h603.8l-57.8 641.2zM281 249l1.7 24.3 22.7 253.5h206.5v-.1h112.9l-11.4 118.5L511 672.9v.2h-.8l-102.4-27.7-6.5-73.2h-91l11.3 144.7 188.6 52h1.7v-.4l187.7-51.7 1.7-16.3 21.2-242.2 3.2-24.3H511v.2H389.9l-8.2-94.2h352.1l1.7-19.5 4.8-47.2L742 249H511z\"}}]})(props);\n};\nexport function AiOutlineIdcard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 160H96c-17.7 0-32 14.3-32 32v640c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V192c0-17.7-14.3-32-32-32zm-40 632H136V232h752v560zM610.3 476h123.4c1.3 0 2.3-3.6 2.3-8v-48c0-4.4-1-8-2.3-8H610.3c-1.3 0-2.3 3.6-2.3 8v48c0 4.4 1 8 2.3 8zm4.8 144h185.7c3.9 0 7.1-3.6 7.1-8v-48c0-4.4-3.2-8-7.1-8H615.1c-3.9 0-7.1 3.6-7.1 8v48c0 4.4 3.2 8 7.1 8zM224 673h43.9c4.2 0 7.6-3.3 7.9-7.5 3.8-50.5 46-90.5 97.2-90.5s93.4 40 97.2 90.5c.3 4.2 3.7 7.5 7.9 7.5H522a8 8 0 0 0 8-8.4c-2.8-53.3-32-99.7-74.6-126.1a111.8 111.8 0 0 0 29.1-75.5c0-61.9-49.9-112-111.4-112s-111.4 50.1-111.4 112c0 29.1 11 55.5 29.1 75.5a158.09 158.09 0 0 0-74.6 126.1c-.4 4.6 3.2 8.4 7.8 8.4zm149-262c28.5 0 51.7 23.3 51.7 52s-23.2 52-51.7 52-51.7-23.3-51.7-52 23.2-52 51.7-52z\"}}]})(props);\n};\nexport function AiOutlineIe (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M852.6 367.6c16.3-36.9 32.1-90.7 32.1-131.8 0-109.1-119.5-147.6-314.5-57.9-161.4-10.8-316.8 110.5-355.6 279.7 46.3-52.3 117.4-123.4 183-151.7C316.1 378.3 246.7 470 194 565.6c-31.1 56.9-66 148.8-66 217.5 0 147.9 139.3 129.8 270.4 63 47.1 23.1 99.8 23.4 152.5 23.4 145.7 0 276.4-81.4 325.2-219H694.9c-78.8 132.9-295.2 79.5-295.2-71.2h493.2c9.6-65.4-2.5-143.6-40.3-211.7zM224.8 648.3c26.6 76.7 80.6 143.8 150.4 185-133.1 73.4-259.9 43.6-150.4-185zm174-163.3c3-82.7 75.4-142.3 156-142.3 80.1 0 153 59.6 156 142.3h-312zm276.8-281.4c32.1-15.4 72.8-33 108.8-33 47.1 0 81.4 32.6 81.4 80.6 0 30-11.1 73.5-21.9 101.8-39.3-63.5-98.9-122.4-168.3-149.4z\"}}]})(props);\n};\nexport function AiOutlineImport (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M888.3 757.4h-53.8c-4.2 0-7.7 3.5-7.7 7.7v61.8H197.1V197.1h629.8v61.8c0 4.2 3.5 7.7 7.7 7.7h53.8c4.2 0 7.7-3.4 7.7-7.7V158.7c0-17-13.7-30.7-30.7-30.7H158.7c-17 0-30.7 13.7-30.7 30.7v706.6c0 17 13.7 30.7 30.7 30.7h706.6c17 0 30.7-13.7 30.7-30.7V765.1c0-4.3-3.5-7.7-7.7-7.7zM902 476H588v-76c0-6.7-7.8-10.5-13-6.3l-141.9 112a8 8 0 0 0 0 12.6l141.9 112c5.3 4.2 13 .4 13-6.3v-76h314c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineInbox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M885.2 446.3l-.2-.8-112.2-285.1c-5-16.1-19.9-27.2-36.8-27.2H281.2c-17 0-32.1 11.3-36.9 27.6L139.4 443l-.3.7-.2.8c-1.3 4.9-1.7 9.9-1 14.8-.1 1.6-.2 3.2-.2 4.8V830a60.9 60.9 0 0 0 60.8 60.8h627.2c33.5 0 60.8-27.3 60.9-60.8V464.1c0-1.3 0-2.6-.1-3.7.4-4.9 0-9.6-1.3-14.1zm-295.8-43l-.3 15.7c-.8 44.9-31.8 75.1-77.1 75.1-22.1 0-41.1-7.1-54.8-20.6S436 441.2 435.6 419l-.3-15.7H229.5L309 210h399.2l81.7 193.3H589.4zm-375 76.8h157.3c24.3 57.1 76 90.8 140.4 90.8 33.7 0 65-9.4 90.3-27.2 22.2-15.6 39.5-37.4 50.7-63.6h156.5V814H214.4V480.1z\"}}]})(props);\n};\nexport function AiOutlineInfoCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M464 336a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm72 112h-48c-4.4 0-8 3.6-8 8v272c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V456c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineInfo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M448 224a64 64 0 1 0 128 0 64 64 0 1 0-128 0zm96 168h-64c-4.4 0-8 3.6-8 8v464c0 4.4 3.6 8 8 8h64c4.4 0 8-3.6 8-8V400c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineInsertRowAbove (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683507961\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M878.7 336H145.3c-18.4 0-33.3 14.3-33.3 32v464c0 17.7 14.9 32 33.3 32h733.3c18.4 0 33.3-14.3 33.3-32V368c0.1-17.7-14.8-32-33.2-32zM360 792H184V632h176v160z m0-224H184V408h176v160z m240 224H424V632h176v160z m0-224H424V408h176v160z m240 224H664V632h176v160z m0-224H664V408h176v160zM904 160H120c-4.4 0-8 3.6-8 8v80c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-80c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineInsertRowBelow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683503597\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M904 768H120c-4.4 0-8 3.6-8 8v80c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-80c0-4.4-3.6-8-8-8zM878.7 160H145.3c-18.4 0-33.3 14.3-33.3 32v464c0 17.7 14.9 32 33.3 32h733.3c18.4 0 33.3-14.3 33.3-32V192c0.1-17.7-14.8-32-33.2-32zM360 616H184V456h176v160z m0-224H184V232h176v160z m240 224H424V456h176v160z m0-224H424V232h176v160z m240 224H664V456h176v160z m0-224H664V232h176v160z\"}}]})(props);\n};\nexport function AiOutlineInsertRowLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683561749\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M248 112h-80c-4.4 0-8 3.6-8 8v784c0 4.4 3.6 8 8 8h80c4.4 0 8-3.6 8-8V120c0-4.4-3.6-8-8-8zM832 112H368c-17.7 0-32 14.9-32 33.3v733.3c0 18.4 14.3 33.3 32 33.3h464c17.7 0 32-14.9 32-33.3V145.3c0-18.4-14.3-33.3-32-33.3zM568 840H408V664h160v176z m0-240H408V424h160v176z m0-240H408V184h160v176z m224 480H632V664h160v176z m0-240H632V424h160v176z m0-240H632V184h160v176z\"}}]})(props);\n};\nexport function AiOutlineInsertRowRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683555439\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M856 112h-80c-4.4 0-8 3.6-8 8v784c0 4.4 3.6 8 8 8h80c4.4 0 8-3.6 8-8V120c0-4.4-3.6-8-8-8zM656 112H192c-17.7 0-32 14.9-32 33.3v733.3c0 18.4 14.3 33.3 32 33.3h464c17.7 0 32-14.9 32-33.3V145.3c0-18.4-14.3-33.3-32-33.3zM392 840H232V664h160v176z m0-240H232V424h160v176z m0-240H232V184h160v176z m224 480H456V664h160v176z m0-240H456V424h160v176z m0-240H456V184h160v176z\"}}]})(props);\n};\nexport function AiOutlineInstagram (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 306.9c-113.5 0-205.1 91.6-205.1 205.1S398.5 717.1 512 717.1 717.1 625.5 717.1 512 625.5 306.9 512 306.9zm0 338.4c-73.4 0-133.3-59.9-133.3-133.3S438.6 378.7 512 378.7 645.3 438.6 645.3 512 585.4 645.3 512 645.3zm213.5-394.6c-26.5 0-47.9 21.4-47.9 47.9s21.4 47.9 47.9 47.9 47.9-21.3 47.9-47.9a47.84 47.84 0 0 0-47.9-47.9zM911.8 512c0-55.2.5-109.9-2.6-165-3.1-64-17.7-120.8-64.5-167.6-46.9-46.9-103.6-61.4-167.6-64.5-55.2-3.1-109.9-2.6-165-2.6-55.2 0-109.9-.5-165 2.6-64 3.1-120.8 17.7-167.6 64.5C132.6 226.3 118.1 283 115 347c-3.1 55.2-2.6 109.9-2.6 165s-.5 109.9 2.6 165c3.1 64 17.7 120.8 64.5 167.6 46.9 46.9 103.6 61.4 167.6 64.5 55.2 3.1 109.9 2.6 165 2.6 55.2 0 109.9.5 165-2.6 64-3.1 120.8-17.7 167.6-64.5 46.9-46.9 61.4-103.6 64.5-167.6 3.2-55.1 2.6-109.8 2.6-165zm-88 235.8c-7.3 18.2-16.1 31.8-30.2 45.8-14.1 14.1-27.6 22.9-45.8 30.2C695.2 844.7 570.3 840 512 840c-58.3 0-183.3 4.7-235.9-16.1-18.2-7.3-31.8-16.1-45.8-30.2-14.1-14.1-22.9-27.6-30.2-45.8C179.3 695.2 184 570.3 184 512c0-58.3-4.7-183.3 16.1-235.9 7.3-18.2 16.1-31.8 30.2-45.8s27.6-22.9 45.8-30.2C328.7 179.3 453.7 184 512 184s183.3-4.7 235.9 16.1c18.2 7.3 31.8 16.1 45.8 30.2 14.1 14.1 22.9 27.6 30.2 45.8C844.7 328.7 840 453.7 840 512c0 58.3 4.7 183.2-16.2 235.8z\"}}]})(props);\n};\nexport function AiOutlineInsurance (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M441.6 306.8L403 288.6a6.1 6.1 0 0 0-8.4 3.7c-17.5 58.5-45.2 110.1-82.2 153.6a6.05 6.05 0 0 0-1.2 5.6l13.2 43.5c1.3 4.4 7 5.7 10.2 2.4 7.7-8.1 15.4-16.9 23.1-26V656c0 4.4 3.6 8 8 8H403c4.4 0 8-3.6 8-8V393.1a429.2 429.2 0 0 0 33.6-79c1-2.9-.3-6-3-7.3zm26.8 9.2v127.2c0 4.4 3.6 8 8 8h65.9v18.6h-94.9c-4.4 0-8 3.6-8 8v35.6c0 4.4 3.6 8 8 8h55.1c-19.1 30.8-42.4 55.7-71 76a6 6 0 0 0-1.6 8.1l22.8 36.5c1.9 3.1 6.2 3.8 8.9 1.4 31.6-26.8 58.7-62.9 80.6-107.6v120c0 4.4 3.6 8 8 8h36.2c4.4 0 8-3.6 8-8V536c21.3 41.7 47.5 77.5 78.1 106.9 2.6 2.5 6.8 2.1 8.9-.7l26.3-35.3c2-2.7 1.4-6.5-1.2-8.4-30.5-22.6-54.2-47.8-72.3-76.9h59c4.4 0 8-3.6 8-8V478c0-4.4-3.6-8-8-8h-98.8v-18.6h66.7c4.4 0 8-3.6 8-8V316c0-4.4-3.6-8-8-8H476.4c-4.4 0-8 3.6-8 8zm51.5 42.8h97.9v41.6h-97.9v-41.6zm347-188.9L527.1 54.1C523 52.7 517.5 52 512 52s-11 .7-15.1 2.1L157.1 169.9c-8.3 2.8-15.1 12.4-15.1 21.2v482.4c0 8.8 5.7 20.4 12.6 25.9L499.3 968c3.5 2.7 8 4.1 12.6 4.1s9.2-1.4 12.6-4.1l344.7-268.6c6.9-5.4 12.6-17 12.6-25.9V191.1c.2-8.8-6.6-18.3-14.9-21.2zM810 654.3L512 886.5 214 654.3V226.7l298-101.6 298 101.6v427.6z\"}}]})(props);\n};\nexport function AiOutlineInteraction (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656zM304.8 524h50.7c3.7 0 6.8-3 6.8-6.8v-78.9c0-19.7 15.9-35.6 35.5-35.6h205.7v53.4c0 5.7 6.5 8.8 10.9 5.3l109.1-85.7c3.5-2.7 3.5-8 0-10.7l-109.1-85.7c-4.4-3.5-10.9-.3-10.9 5.3V338H397.7c-55.1 0-99.7 44.8-99.7 100.1V517c0 4 3 7 6.8 7zm-4.2 134.9l109.1 85.7c4.4 3.5 10.9.3 10.9-5.3v-53.4h205.7c55.1 0 99.7-44.8 99.7-100.1v-78.9c0-3.7-3-6.8-6.8-6.8h-50.7c-3.7 0-6.8 3-6.8 6.8v78.9c0 19.7-15.9 35.6-35.5 35.6H420.6V568c0-5.7-6.5-8.8-10.9-5.3l-109.1 85.7c-3.5 2.5-3.5 7.8 0 10.5z\"}}]})(props);\n};\nexport function AiOutlineIssuesClose (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M464 688a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm72-112c4.4 0 8-3.6 8-8V296c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v272c0 4.4 3.6 8 8 8h48zm400-188h-59.3c-2.6 0-5 1.2-6.5 3.3L763.7 538.1l-49.9-68.8a7.92 7.92 0 0 0-6.5-3.3H648c-6.5 0-10.3 7.4-6.5 12.7l109.2 150.7a16.1 16.1 0 0 0 26 0l165.8-228.7c3.8-5.3 0-12.7-6.5-12.7zm-44 306h-64.2c-5.5 0-10.6 2.9-13.6 7.5a352.2 352.2 0 0 1-49.8 62.2A355.92 355.92 0 0 1 651.1 840a355 355 0 0 1-138.7 27.9c-48.1 0-94.8-9.4-138.7-27.9a355.92 355.92 0 0 1-113.3-76.3A353.06 353.06 0 0 1 184 650.5c-18.6-43.8-28-90.5-28-138.5s9.4-94.7 28-138.5c17.9-42.4 43.6-80.5 76.4-113.2 32.8-32.7 70.9-58.4 113.3-76.3a355 355 0 0 1 138.7-27.9c48.1 0 94.8 9.4 138.7 27.9 42.4 17.9 80.5 43.6 113.3 76.3 19 19 35.6 39.8 49.8 62.2 2.9 4.7 8.1 7.5 13.6 7.5H892c6 0 9.8-6.3 7.2-11.6C828.8 178.5 684.7 82 517.7 80 278.9 77.2 80.5 272.5 80 511.2 79.5 750.1 273.3 944 512.4 944c169.2 0 315.6-97 386.7-238.4A8 8 0 0 0 892 694z\"}}]})(props);\n};\nexport function AiOutlineItalic (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M798 160H366c-4.4 0-8 3.6-8 8v64c0 4.4 3.6 8 8 8h181.2l-156 544H229c-4.4 0-8 3.6-8 8v64c0 4.4 3.6 8 8 8h432c4.4 0 8-3.6 8-8v-64c0-4.4-3.6-8-8-8H474.4l156-544H798c4.4 0 8-3.6 8-8v-64c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineKey (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M608 112c-167.9 0-304 136.1-304 304 0 70.3 23.9 135 63.9 186.5l-41.1 41.1-62.3-62.3a8.15 8.15 0 0 0-11.4 0l-39.8 39.8a8.15 8.15 0 0 0 0 11.4l62.3 62.3-44.9 44.9-62.3-62.3a8.15 8.15 0 0 0-11.4 0l-39.8 39.8a8.15 8.15 0 0 0 0 11.4l62.3 62.3-65.3 65.3a8.03 8.03 0 0 0 0 11.3l42.3 42.3c3.1 3.1 8.2 3.1 11.3 0l253.6-253.6A304.06 304.06 0 0 0 608 720c167.9 0 304-136.1 304-304S775.9 112 608 112zm161.2 465.2C726.2 620.3 668.9 644 608 644c-60.9 0-118.2-23.7-161.2-66.8-43.1-43-66.8-100.3-66.8-161.2 0-60.9 23.7-118.2 66.8-161.2 43-43.1 100.3-66.8 161.2-66.8 60.9 0 118.2 23.7 161.2 66.8 43.1 43 66.8 100.3 66.8 161.2 0 60.9-23.7 118.2-66.8 161.2z\"}}]})(props);\n};\nexport function AiOutlineLaptop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M956.9 845.1L896.4 632V168c0-17.7-14.3-32-32-32h-704c-17.7 0-32 14.3-32 32v464L67.9 845.1C60.4 866 75.8 888 98 888h828.8c22.2 0 37.6-22 30.1-42.9zM200.4 208h624v395h-624V208zm228.3 608l8.1-37h150.3l8.1 37H428.7zm224 0l-19.1-86.7c-.8-3.7-4.1-6.3-7.8-6.3H398.2c-3.8 0-7 2.6-7.8 6.3L371.3 816H151l42.3-149h638.2l42.3 149H652.7z\"}}]})(props);\n};\nexport function AiOutlineLayout (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-696 72h136v656H184V184zm656 656H384V384h456v456zM384 320V184h456v136H384z\"}}]})(props);\n};\nexport function AiOutlineLeftCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M603.3 327.5l-246 178a7.95 7.95 0 0 0 0 12.9l246 178c5.3 3.8 12.7 0 12.7-6.5V643c0-10.2-4.9-19.9-13.2-25.9L457.4 512l145.4-105.2c8.3-6 13.2-15.6 13.2-25.9V334c0-6.5-7.4-10.3-12.7-6.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}}]})(props);\n};\nexport function AiOutlineLeftSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M365.3 518.5l246 178c5.3 3.8 12.7 0 12.7-6.5v-46.9c0-10.2-4.9-19.9-13.2-25.9L465.4 512l145.4-105.2c8.3-6 13.2-15.6 13.2-25.9V334c0-6.5-7.4-10.3-12.7-6.5l-246 178a8.05 8.05 0 0 0 0 13z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}}]})(props);\n};\nexport function AiOutlineLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M724 218.3V141c0-6.7-7.7-10.4-12.9-6.3L260.3 486.8a31.86 31.86 0 0 0 0 50.3l450.8 352.1c5.3 4.1 12.9.4 12.9-6.3v-77.3c0-4.9-2.3-9.6-6.1-12.6l-360-281 360-281.1c3.8-3 6.1-7.7 6.1-12.6z\"}}]})(props);\n};\nexport function AiOutlineLike (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M885.9 533.7c16.8-22.2 26.1-49.4 26.1-77.7 0-44.9-25.1-87.4-65.5-111.1a67.67 67.67 0 0 0-34.3-9.3H572.4l6-122.9c1.4-29.7-9.1-57.9-29.5-79.4A106.62 106.62 0 0 0 471 99.9c-52 0-98 35-111.8 85.1l-85.9 311H144c-17.7 0-32 14.3-32 32v364c0 17.7 14.3 32 32 32h601.3c9.2 0 18.2-1.8 26.5-5.4 47.6-20.3 78.3-66.8 78.3-118.4 0-12.6-1.8-25-5.4-37 16.8-22.2 26.1-49.4 26.1-77.7 0-12.6-1.8-25-5.4-37 16.8-22.2 26.1-49.4 26.1-77.7-.2-12.6-2-25.1-5.6-37.1zM184 852V568h81v284h-81zm636.4-353l-21.9 19 13.9 25.4a56.2 56.2 0 0 1 6.9 27.3c0 16.5-7.2 32.2-19.6 43l-21.9 19 13.9 25.4a56.2 56.2 0 0 1 6.9 27.3c0 16.5-7.2 32.2-19.6 43l-21.9 19 13.9 25.4a56.2 56.2 0 0 1 6.9 27.3c0 22.4-13.2 42.6-33.6 51.8H329V564.8l99.5-360.5a44.1 44.1 0 0 1 42.2-32.3c7.6 0 15.1 2.2 21.1 6.7 9.9 7.4 15.2 18.6 14.6 30.5l-9.6 198.4h314.4C829 418.5 840 436.9 840 456c0 16.5-7.2 32.1-19.6 43z\"}}]})(props);\n};\nexport function AiOutlineLineChart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M888 792H200V168c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v688c0 4.4 3.6 8 8 8h752c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM305.8 637.7c3.1 3.1 8.1 3.1 11.3 0l138.3-137.6L583 628.5c3.1 3.1 8.2 3.1 11.3 0l275.4-275.3c3.1-3.1 3.1-8.2 0-11.3l-39.6-39.6a8.03 8.03 0 0 0-11.3 0l-230 229.9L461.4 404a8.03 8.03 0 0 0-11.3 0L266.3 586.7a8.03 8.03 0 0 0 0 11.3l39.5 39.7z\"}}]})(props);\n};\nexport function AiOutlineLineHeight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M648 160H104c-4.4 0-8 3.6-8 8v128c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-64h168v560h-92c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h264c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-92V232h168v64c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V168c0-4.4-3.6-8-8-8zm272.8 546H856V318h64.8c6 0 9.4-7 5.7-11.7L825.7 178.7a7.14 7.14 0 0 0-11.3 0L713.6 306.3a7.23 7.23 0 0 0 5.7 11.7H784v388h-64.8c-6 0-9.4 7-5.7 11.7l100.8 127.5c2.9 3.7 8.5 3.7 11.3 0l100.8-127.5a7.2 7.2 0 0 0-5.6-11.7z\"}}]})(props);\n};\nexport function AiOutlineLine (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M904 476H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineLink (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M574 665.4a8.03 8.03 0 0 0-11.3 0L446.5 781.6c-53.8 53.8-144.6 59.5-204 0-59.5-59.5-53.8-150.2 0-204l116.2-116.2c3.1-3.1 3.1-8.2 0-11.3l-39.8-39.8a8.03 8.03 0 0 0-11.3 0L191.4 526.5c-84.6 84.6-84.6 221.5 0 306s221.5 84.6 306 0l116.2-116.2c3.1-3.1 3.1-8.2 0-11.3L574 665.4zm258.6-474c-84.6-84.6-221.5-84.6-306 0L410.3 307.6a8.03 8.03 0 0 0 0 11.3l39.7 39.7c3.1 3.1 8.2 3.1 11.3 0l116.2-116.2c53.8-53.8 144.6-59.5 204 0 59.5 59.5 53.8 150.2 0 204L665.3 562.6a8.03 8.03 0 0 0 0 11.3l39.8 39.8c3.1 3.1 8.2 3.1 11.3 0l116.2-116.2c84.5-84.6 84.5-221.5 0-306.1zM610.1 372.3a8.03 8.03 0 0 0-11.3 0L372.3 598.7a8.03 8.03 0 0 0 0 11.3l39.6 39.6c3.1 3.1 8.2 3.1 11.3 0l226.4-226.4c3.1-3.1 3.1-8.2 0-11.3l-39.5-39.6z\"}}]})(props);\n};\nexport function AiOutlineLinkedin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M847.7 112H176.3c-35.5 0-64.3 28.8-64.3 64.3v671.4c0 35.5 28.8 64.3 64.3 64.3h671.4c35.5 0 64.3-28.8 64.3-64.3V176.3c0-35.5-28.8-64.3-64.3-64.3zm0 736c-447.8-.1-671.7-.2-671.7-.3.1-447.8.2-671.7.3-671.7 447.8.1 671.7.2 671.7.3-.1 447.8-.2 671.7-.3 671.7zM230.6 411.9h118.7v381.8H230.6zm59.4-52.2c37.9 0 68.8-30.8 68.8-68.8a68.8 68.8 0 1 0-137.6 0c-.1 38 30.7 68.8 68.8 68.8zm252.3 245.1c0-49.8 9.5-98 71.2-98 60.8 0 61.7 56.9 61.7 101.2v185.7h118.6V584.3c0-102.8-22.2-181.9-142.3-181.9-57.7 0-96.4 31.7-112.3 61.7h-1.6v-52.2H423.7v381.8h118.6V604.8z\"}}]})(props);\n};\nexport function AiOutlineLoading3Quarters (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 1024c-69.1 0-136.2-13.5-199.3-40.2C251.7 958 197 921 150 874c-47-47-84-101.7-109.8-162.7C13.5 648.2 0 581.1 0 512c0-19.9 16.1-36 36-36s36 16.1 36 36c0 59.4 11.6 117 34.6 171.3 22.2 52.4 53.9 99.5 94.3 139.9 40.4 40.4 87.5 72.2 139.9 94.3C395 940.4 452.6 952 512 952c59.4 0 117-11.6 171.3-34.6 52.4-22.2 99.5-53.9 139.9-94.3 40.4-40.4 72.2-87.5 94.3-139.9C940.4 629 952 571.4 952 512c0-59.4-11.6-117-34.6-171.3a440.45 440.45 0 0 0-94.3-139.9 437.71 437.71 0 0 0-139.9-94.3C629 83.6 571.4 72 512 72c-19.9 0-36-16.1-36-36s16.1-36 36-36c69.1 0 136.2 13.5 199.3 40.2C772.3 66 827 103 874 150c47 47 83.9 101.8 109.7 162.7 26.7 63.1 40.2 130.2 40.2 199.3s-13.5 136.2-40.2 199.3C958 772.3 921 827 874 874c-47 47-101.8 83.9-162.7 109.7-63.1 26.8-130.2 40.3-199.3 40.3z\"}}]})(props);\n};\nexport function AiOutlineLoading (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M988 548c-19.9 0-36-16.1-36-36 0-59.4-11.6-117-34.6-171.3a440.45 440.45 0 0 0-94.3-139.9 437.71 437.71 0 0 0-139.9-94.3C629 83.6 571.4 72 512 72c-19.9 0-36-16.1-36-36s16.1-36 36-36c69.1 0 136.2 13.5 199.3 40.3C772.3 66 827 103 874 150c47 47 83.9 101.8 109.7 162.7 26.7 63.1 40.2 130.2 40.2 199.3.1 19.9-16 36-35.9 36z\"}}]})(props);\n};\nexport function AiOutlineLock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 464h-68V240c0-70.7-57.3-128-128-128H388c-70.7 0-128 57.3-128 128v224h-68c-17.7 0-32 14.3-32 32v384c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V496c0-17.7-14.3-32-32-32zM332 240c0-30.9 25.1-56 56-56h248c30.9 0 56 25.1 56 56v224H332V240zm460 600H232V536h560v304zM484 701v53c0 4.4 3.6 8 8 8h40c4.4 0 8-3.6 8-8v-53a48.01 48.01 0 1 0-56 0z\"}}]})(props);\n};\nexport function AiOutlineLogin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M521.7 82c-152.5-.4-286.7 78.5-363.4 197.7-3.4 5.3.4 12.3 6.7 12.3h70.3c4.8 0 9.3-2.1 12.3-5.8 7-8.5 14.5-16.7 22.4-24.5 32.6-32.5 70.5-58.1 112.7-75.9 43.6-18.4 90-27.8 137.9-27.8 47.9 0 94.3 9.3 137.9 27.8 42.2 17.8 80.1 43.4 112.7 75.9 32.6 32.5 58.1 70.4 76 112.5C865.7 417.8 875 464.1 875 512c0 47.9-9.4 94.2-27.8 137.8-17.8 42.1-43.4 80-76 112.5s-70.5 58.1-112.7 75.9A352.8 352.8 0 0 1 520.6 866c-47.9 0-94.3-9.4-137.9-27.8A353.84 353.84 0 0 1 270 762.3c-7.9-7.9-15.3-16.1-22.4-24.5-3-3.7-7.6-5.8-12.3-5.8H165c-6.3 0-10.2 7-6.7 12.3C234.9 863.2 368.5 942 520.6 942c236.2 0 428-190.1 430.4-425.6C953.4 277.1 761.3 82.6 521.7 82zM395.02 624v-76h-314c-4.4 0-8-3.6-8-8v-56c0-4.4 3.6-8 8-8h314v-76c0-6.7 7.8-10.5 13-6.3l141.9 112a8 8 0 0 1 0 12.6l-141.9 112c-5.2 4.1-13 .4-13-6.3z\"}}]})(props);\n};\nexport function AiOutlineLogout (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M868 732h-70.3c-4.8 0-9.3 2.1-12.3 5.8-7 8.5-14.5 16.7-22.4 24.5a353.84 353.84 0 0 1-112.7 75.9A352.8 352.8 0 0 1 512.4 866c-47.9 0-94.3-9.4-137.9-27.8a353.84 353.84 0 0 1-112.7-75.9 353.28 353.28 0 0 1-76-112.5C167.3 606.2 158 559.9 158 512s9.4-94.2 27.8-137.8c17.8-42.1 43.4-80 76-112.5s70.5-58.1 112.7-75.9c43.6-18.4 90-27.8 137.9-27.8 47.9 0 94.3 9.3 137.9 27.8 42.2 17.8 80.1 43.4 112.7 75.9 7.9 7.9 15.3 16.1 22.4 24.5 3 3.7 7.6 5.8 12.3 5.8H868c6.3 0 10.2-7 6.7-12.3C798 160.5 663.8 81.6 511.3 82 271.7 82.6 79.6 277.1 82 516.4 84.4 751.9 276.2 942 512.4 942c152.1 0 285.7-78.8 362.3-197.7 3.4-5.3-.4-12.3-6.7-12.3zm88.9-226.3L815 393.7c-5.3-4.2-13-.4-13 6.3v76H488c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h314v76c0 6.7 7.8 10.5 13 6.3l141.9-112a8 8 0 0 0 0-12.6z\"}}]})(props);\n};\nexport function AiOutlineMacCommand (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683819749\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32z m-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M370.8 554.4c-54.6 0-98.8 44.2-98.8 98.8s44.2 98.8 98.8 98.8 98.8-44.2 98.8-98.8v-42.4h84.7v42.4c0 54.6 44.2 98.8 98.8 98.8s98.8-44.2 98.8-98.8-44.2-98.8-98.8-98.8h-42.4v-84.7h42.4c54.6 0 98.8-44.2 98.8-98.8 0-54.6-44.2-98.8-98.8-98.8s-98.8 44.2-98.8 98.8v42.4h-84.7v-42.4c0-54.6-44.2-98.8-98.8-98.8S272 316.2 272 370.8s44.2 98.8 98.8 98.8h42.4v84.7h-42.4z m42.4 98.8c0 23.4-19 42.4-42.4 42.4s-42.4-19-42.4-42.4 19-42.4 42.4-42.4h42.4v42.4z m197.6-282.4c0-23.4 19-42.4 42.4-42.4s42.4 19 42.4 42.4-19 42.4-42.4 42.4h-42.4v-42.4z m0 240h42.4c23.4 0 42.4 19 42.4 42.4s-19 42.4-42.4 42.4-42.4-19-42.4-42.4v-42.4zM469.6 469.6h84.7v84.7h-84.7v-84.7z m-98.8-56.4c-23.4 0-42.4-19-42.4-42.4s19-42.4 42.4-42.4 42.4 19 42.4 42.4v42.4h-42.4z\"}}]})(props);\n};\nexport function AiOutlineMail (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 160H96c-17.7 0-32 14.3-32 32v640c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V192c0-17.7-14.3-32-32-32zm-40 110.8V792H136V270.8l-27.6-21.5 39.3-50.5 42.8 33.3h643.1l42.8-33.3 39.3 50.5-27.7 21.5zM833.6 232L512 482 190.4 232l-42.8-33.3-39.3 50.5 27.6 21.5 341.6 265.6a55.99 55.99 0 0 0 68.7 0L888 270.8l27.6-21.5-39.3-50.5-42.7 33.2z\"}}]})(props);\n};\nexport function AiOutlineMan (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M874 120H622c-3.3 0-6 2.7-6 6v56c0 3.3 2.7 6 6 6h160.4L583.1 387.3c-50-38.5-111-59.3-175.1-59.3-76.9 0-149.3 30-203.6 84.4S120 539.1 120 616s30 149.3 84.4 203.6C258.7 874 331.1 904 408 904s149.3-30 203.6-84.4C666 765.3 696 692.9 696 616c0-64.1-20.8-124.9-59.2-174.9L836 241.9V402c0 3.3 2.7 6 6 6h56c3.3 0 6-2.7 6-6V150c0-16.5-13.5-30-30-30zM408 828c-116.9 0-212-95.1-212-212s95.1-212 212-212 212 95.1 212 212-95.1 212-212 212z\"}}]})(props);\n};\nexport function AiOutlineMedicineBox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M839.2 278.1a32 32 0 0 0-30.4-22.1H736V144c0-17.7-14.3-32-32-32H320c-17.7 0-32 14.3-32 32v112h-72.8a31.9 31.9 0 0 0-30.4 22.1L112 502v378c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V502l-72.8-223.9zM360 184h304v72H360v-72zm480 656H184V513.4L244.3 328h535.4L840 513.4V840zM652 572H544V464c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v108H372c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h108v108c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V636h108c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineMediumWorkmark (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M517.2 590.55c0 3.55 0 4.36 2.4 6.55l13.43 13.25v.57h-59.57v-25.47a41.44 41.44 0 0 1-39.5 27.65c-30.61 0-52.84-24.25-52.84-68.87 0-41.8 23.99-69.69 57.65-69.69a35.15 35.15 0 0 1 34.61 21.67v-56.19a6.99 6.99 0 0 0-2.71-6.79l-12.8-12.45v-.56l59.33-7.04v177.37zm-43.74-8.09v-83.83a22.2 22.2 0 0 0-17.74-8.4c-14.48 0-28.47 13.25-28.47 52.62 0 36.86 12.07 49.88 27.1 49.88a23.91 23.91 0 0 0 19.11-10.27zm83.23 28.46V497.74a7.65 7.65 0 0 0-2.4-6.79l-13.19-13.74v-.57h59.56v114.8c0 3.55 0 4.36 2.4 6.54l13.12 12.45v.57l-59.49-.08zm-2.16-175.67c0-13.4 10.74-24.25 23.99-24.25 13.25 0 23.98 10.86 23.98 24.25 0 13.4-10.73 24.25-23.98 24.25s-23.99-10.85-23.99-24.25zm206.83 155.06c0 3.55 0 4.6 2.4 6.79l13.43 13.25v.57h-59.88V581.9a43.4 43.4 0 0 1-41.01 31.2c-26.55 0-40.78-19.56-40.78-56.59 0-17.86 0-37.43.56-59.41a6.91 6.91 0 0 0-2.4-6.55L620.5 477.2v-.57h59.09v73.81c0 24.25 3.51 40.42 18.54 40.42a23.96 23.96 0 0 0 19.35-12.2v-80.85a7.65 7.65 0 0 0-2.4-6.79l-13.27-13.82v-.57h59.56V590.3zm202.76 20.6c0-4.36.8-59.97.8-72.75 0-24.25-3.76-40.98-20.63-40.98a26.7 26.7 0 0 0-21.19 11.64 99.68 99.68 0 0 1 2.4 23.04c0 16.81-.56 38.23-.8 59.66a6.91 6.91 0 0 0 2.4 6.55l13.43 12.45v.56h-60.12c0-4.04.8-59.98.8-72.76 0-24.65-3.76-40.98-20.39-40.98-8.2.3-15.68 4.8-19.83 11.96v82.46c0 3.56 0 4.37 2.4 6.55l13.11 12.45v.56h-59.48V498.15a7.65 7.65 0 0 0-2.4-6.8l-13.19-14.14v-.57H841v28.78c5.53-19 23.13-31.76 42.7-30.96 19.82 0 33.26 11.16 38.93 32.34a46.41 46.41 0 0 1 44.77-32.34c26.55 0 41.58 19.8 41.58 57.23 0 17.87-.56 38.24-.8 59.66a6.5 6.5 0 0 0 2.72 6.55l13.11 12.45v.57h-59.88zM215.87 593.3l17.66 17.05v.57h-89.62v-.57l17.99-17.05a6.91 6.91 0 0 0 2.4-6.55V477.69c0-4.6 0-10.83.8-16.16L104.66 613.1h-.72l-62.6-139.45c-1.37-3.47-1.77-3.72-2.65-6.06v91.43a32.08 32.08 0 0 0 2.96 17.87l25.19 33.46v.57H0v-.57l25.18-33.55a32.16 32.16 0 0 0 2.96-17.78V457.97A19.71 19.71 0 0 0 24 444.15L6.16 420.78v-.56h63.96l53.56 118.1 47.17-118.1h62.6v.56l-17.58 19.8a6.99 6.99 0 0 0-2.72 6.8v139.37a6.5 6.5 0 0 0 2.72 6.55zm70.11-54.65v.56c0 34.6 17.67 48.5 38.38 48.5a43.5 43.5 0 0 0 40.77-24.97h.56c-7.2 34.2-28.14 50.36-59.48 50.36-33.82 0-65.72-20.61-65.72-68.39 0-50.2 31.98-70.25 67.32-70.25 28.46 0 58.76 13.58 58.76 57.24v6.95h-80.59zm0-6.95h39.42v-7.04c0-35.57-7.28-45.03-18.23-45.03-13.27 0-21.35 14.15-21.35 52.07h.16z\"}}]})(props);\n};\nexport function AiOutlineMedium (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M834.7 279.8l61.3-58.9V208H683.7L532.4 586.4 360.3 208H137.7v12.9l71.6 86.6c7 6.4 10.6 15.8 9.7 25.2V673c2.2 12.3-1.7 24.8-10.3 33.7L128 805v12.7h228.6v-12.9l-80.6-98a39.99 39.99 0 0 1-11.1-33.7V378.7l200.7 439.2h23.3l172.6-439.2v349.9c0 9.2 0 11.1-6 17.2l-62.1 60.3V819h301.2v-12.9l-59.9-58.9c-5.2-4-7.9-10.7-6.8-17.2V297a18.1 18.1 0 0 1 6.8-17.2z\"}}]})(props);\n};\nexport function AiOutlineMeh (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M288 421a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm352 0a48 48 0 1 0 96 0 48 48 0 1 0-96 0zM512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm263 711c-34.2 34.2-74 61-118.3 79.8C611 874.2 562.3 884 512 884c-50.3 0-99-9.8-144.8-29.2A370.4 370.4 0 0 1 248.9 775c-34.2-34.2-61-74-79.8-118.3C149.8 611 140 562.3 140 512s9.8-99 29.2-144.8A370.4 370.4 0 0 1 249 248.9c34.2-34.2 74-61 118.3-79.8C413 149.8 461.7 140 512 140c50.3 0 99 9.8 144.8 29.2A370.4 370.4 0 0 1 775.1 249c34.2 34.2 61 74 79.8 118.3C874.2 413 884 461.7 884 512s-9.8 99-29.2 144.8A368.89 368.89 0 0 1 775 775zM664 565H360c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h304c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineMenuFold (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M408 442h480c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H408c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm-8 204c0 4.4 3.6 8 8 8h480c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H408c-4.4 0-8 3.6-8 8v56zm504-486H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 632H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM115.4 518.9L271.7 642c5.8 4.6 14.4.5 14.4-6.9V388.9c0-7.4-8.5-11.5-14.4-6.9L115.4 505.1a8.74 8.74 0 0 0 0 13.8z\"}}]})(props);\n};\nexport function AiOutlineMenuUnfold (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M408 442h480c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H408c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm-8 204c0 4.4 3.6 8 8 8h480c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H408c-4.4 0-8 3.6-8 8v56zm504-486H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 632H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM142.4 642.1L298.7 519a8.84 8.84 0 0 0 0-13.9L142.4 381.9c-5.8-4.6-14.4-.5-14.4 6.9v246.3a8.9 8.9 0 0 0 14.4 7z\"}}]})(props);\n};\nexport function AiOutlineMenu (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M904 160H120c-4.4 0-8 3.6-8 8v64c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-64c0-4.4-3.6-8-8-8zm0 624H120c-4.4 0-8 3.6-8 8v64c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-64c0-4.4-3.6-8-8-8zm0-312H120c-4.4 0-8 3.6-8 8v64c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-64c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineMergeCells (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683404098\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M482.2 508.4L331.3 389c-3-2.4-7.3-0.2-7.3 3.6V478H184V184h204v128c0 2.2 1.8 4 4 4h60c2.2 0 4-1.8 4-4V144c0-15.5-12.5-28-28-28H144c-15.5 0-28 12.5-28 28v736c0 15.5 12.5 28 28 28h284c15.5 0 28-12.5 28-28V712c0-2.2-1.8-4-4-4h-60c-2.2 0-4 1.8-4 4v128H184V546h140v85.4c0 3.8 4.4 6 7.3 3.6l150.9-119.4c2.4-1.8 2.4-5.4 0-7.2zM880 116H596c-15.5 0-28 12.5-28 28v168c0 2.2 1.8 4 4 4h60c2.2 0 4-1.8 4-4V184h204v294H700v-85.4c0-3.8-4.3-6-7.3-3.6l-151 119.4c-2.3 1.8-2.3 5.3 0 7.1l151 119.5c2.9 2.3 7.3 0.2 7.3-3.6V546h140v294H636V712c0-2.2-1.8-4-4-4h-60c-2.2 0-4 1.8-4 4v168c0 15.5 12.5 28 28 28h284c15.5 0 28-12.5 28-28V144c0-15.5-12.5-28-28-28z\"}}]})(props);\n};\nexport function AiOutlineMessage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M464 512a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm200 0a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm-400 0a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm661.2-173.6c-22.6-53.7-55-101.9-96.3-143.3a444.35 444.35 0 0 0-143.3-96.3C630.6 75.7 572.2 64 512 64h-2c-60.6.3-119.3 12.3-174.5 35.9a445.35 445.35 0 0 0-142 96.5c-40.9 41.3-73 89.3-95.2 142.8-23 55.4-34.6 114.3-34.3 174.9A449.4 449.4 0 0 0 112 714v152a46 46 0 0 0 46 46h152.1A449.4 449.4 0 0 0 510 960h2.1c59.9 0 118-11.6 172.7-34.3a444.48 444.48 0 0 0 142.8-95.2c41.3-40.9 73.8-88.7 96.5-142 23.6-55.2 35.6-113.9 35.9-174.5.3-60.9-11.5-120-34.8-175.6zm-151.1 438C704 845.8 611 884 512 884h-1.7c-60.3-.3-120.2-15.3-173.1-43.5l-8.4-4.5H188V695.2l-4.5-8.4C155.3 633.9 140.3 574 140 513.7c-.4-99.7 37.7-193.3 107.6-263.8 69.8-70.5 163.1-109.5 262.8-109.9h1.7c50 0 98.5 9.7 144.2 28.9 44.6 18.7 84.6 45.6 119 80 34.3 34.3 61.3 74.4 80 119 19.4 46.2 29.1 95.2 28.9 145.8-.6 99.6-39.7 192.9-110.1 262.7z\"}}]})(props);\n};\nexport function AiOutlineMinusCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M696 480H328c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h368c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}}]})(props);\n};\nexport function AiOutlineMinusSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M328 544h368c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H328c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}}]})(props);\n};\nexport function AiOutlineMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M872 474H152c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h720c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineMobile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M744 62H280c-35.3 0-64 28.7-64 64v768c0 35.3 28.7 64 64 64h464c35.3 0 64-28.7 64-64V126c0-35.3-28.7-64-64-64zm-8 824H288V134h448v752zM472 784a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}}]})(props);\n};\nexport function AiOutlineMoneyCollect (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M911.5 700.7a8 8 0 0 0-10.3-4.8L840 718.2V180c0-37.6-30.4-68-68-68H252c-37.6 0-68 30.4-68 68v538.2l-61.3-22.3c-.9-.3-1.8-.5-2.7-.5-4.4 0-8 3.6-8 8V763c0 3.3 2.1 6.3 5.3 7.5L501 910.1c7.1 2.6 14.8 2.6 21.9 0l383.8-139.5c3.2-1.2 5.3-4.2 5.3-7.5v-59.6c0-1-.2-1.9-.5-2.8zM512 837.5l-256-93.1V184h512v560.4l-256 93.1zM660.6 312h-54.5c-3 0-5.8 1.7-7.1 4.4l-84.7 168.8H511l-84.7-168.8a8 8 0 0 0-7.1-4.4h-55.7c-1.3 0-2.6.3-3.8 1-3.9 2.1-5.3 7-3.2 10.8l103.9 191.6h-57c-4.4 0-8 3.6-8 8v27.1c0 4.4 3.6 8 8 8h76v39h-76c-4.4 0-8 3.6-8 8v27.1c0 4.4 3.6 8 8 8h76V704c0 4.4 3.6 8 8 8h49.9c4.4 0 8-3.6 8-8v-63.5h76.3c4.4 0 8-3.6 8-8v-27.1c0-4.4-3.6-8-8-8h-76.3v-39h76.3c4.4 0 8-3.6 8-8v-27.1c0-4.4-3.6-8-8-8H564l103.7-191.6c.6-1.2 1-2.5 1-3.8-.1-4.3-3.7-7.9-8.1-7.9z\"}}]})(props);\n};\nexport function AiOutlineMonitor (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M692.8 412.7l.2-.2-34.6-44.3a7.97 7.97 0 0 0-11.2-1.4l-50.4 39.3-70.5-90.1a7.97 7.97 0 0 0-11.2-1.4l-37.9 29.7a7.97 7.97 0 0 0-1.4 11.2l70.5 90.2-.2.1 34.6 44.3c2.7 3.5 7.7 4.1 11.2 1.4l50.4-39.3 64.1 82c2.7 3.5 7.7 4.1 11.2 1.4l37.9-29.6c3.5-2.7 4.1-7.7 1.4-11.2l-64.1-82.1zM608 112c-167.9 0-304 136.1-304 304 0 70.3 23.9 135 63.9 186.5L114.3 856.1a8.03 8.03 0 0 0 0 11.3l42.3 42.3c3.1 3.1 8.2 3.1 11.3 0l253.6-253.6C473 696.1 537.7 720 608 720c167.9 0 304-136.1 304-304S775.9 112 608 112zm161.2 465.2C726.2 620.3 668.9 644 608 644s-118.2-23.7-161.2-66.8C403.7 534.2 380 476.9 380 416s23.7-118.2 66.8-161.2c43-43.1 100.3-66.8 161.2-66.8s118.2 23.7 161.2 66.8c43.1 43 66.8 100.3 66.8 161.2s-23.7 118.2-66.8 161.2z\"}}]})(props);\n};\nexport function AiOutlineMore (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M456 231a56 56 0 1 0 112 0 56 56 0 1 0-112 0zm0 280a56 56 0 1 0 112 0 56 56 0 1 0-112 0zm0 280a56 56 0 1 0 112 0 56 56 0 1 0-112 0z\"}}]})(props);\n};\nexport function AiOutlineNodeCollapse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683371420\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M952 612c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H298c-14.2-35.2-48.7-60-89-60-53 0-96 43-96 96s43 96 96 96c40.3 0 74.8-24.8 89-60h150.3v152c0 55.2 44.8 100 100 100H952c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H548.3c-15.5 0-28-12.5-28-28V612H952zM451.7 313.7l172.5 136.2c6.3 5.1 15.8 0.5 15.8-7.7V344h264c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8H640v-98.2c0-8.1-9.4-12.8-15.8-7.7L451.7 298.3c-4.9 3.9-4.9 11.5 0 15.4z\"}}]})(props);\n};\nexport function AiOutlineNodeExpand (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683374330\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M952 612c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H298c-14.2-35.2-48.7-60-89-60-53 0-96 43-96 96s43 96 96 96c40.3 0 74.8-24.8 89-60h150.3v152c0 55.2 44.8 100 100 100H952c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H548.3c-15.5 0-28-12.5-28-28V612H952zM456 344h264v98.2c0 8.1 9.5 12.8 15.8 7.7l172.5-136.2c5-3.9 5-11.4 0-15.3L735.8 162.1c-6.4-5.1-15.8-0.5-15.8 7.7V268H456c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlineNodeIndex (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683635191\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M843.5 737.4c-12.4-75.2-79.2-129.1-155.3-125.4S550.9 676 546 752c-153.5-4.8-208-40.7-199.1-113.7 3.3-27.3 19.8-41.9 50.1-49 18.4-4.3 38.8-4.9 57.3-3.2 1.7 0.2 3.5 0.3 5.2 0.5 11.3 2.7 22.8 5 34.3 6.8 34.1 5.6 68.8 8.4 101.8 6.6 92.8-5 156-45.9 159.2-132.7 3.1-84.1-54.7-143.7-147.9-183.6-29.9-12.8-61.6-22.7-93.3-30.2-14.3-3.4-26.3-5.7-35.2-7.2-7.9-75.9-71.5-133.8-147.8-134.4-76.3-0.6-140.9 56.1-150.1 131.9s40 146.3 114.2 163.9c74.2 17.6 149.9-23.3 175.7-95.1 9.4 1.7 18.7 3.6 28 5.8 28.2 6.6 56.4 15.4 82.4 26.6 70.7 30.2 109.3 70.1 107.5 119.9-1.6 44.6-33.6 65.2-96.2 68.6-27.5 1.5-57.6-0.9-87.3-5.8-8.3-1.4-15.9-2.8-22.6-4.3-3.9-0.8-6.6-1.5-7.8-1.8l-3.1-0.6c-2.2-0.3-5.9-0.8-10.7-1.3-25-2.3-52.1-1.5-78.5 4.6-55.2 12.9-93.9 47.2-101.1 105.8-15.7 126.2 78.6 184.7 276 188.9 29.1 70.4 106.4 107.9 179.6 87 73.3-20.9 119.3-93.4 106.9-168.6zM329.1 345.2c-46 0-83.3-37.3-83.3-83.3s37.3-83.3 83.3-83.3 83.3 37.3 83.3 83.3-37.3 83.3-83.3 83.3zM695.6 845c-46 0-83.3-37.3-83.3-83.3s37.3-83.3 83.3-83.3 83.3 37.3 83.3 83.3-37.3 83.3-83.3 83.3z\"}}]})(props);\n};\nexport function AiOutlineNotification (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112c-3.8 0-7.7.7-11.6 2.3L292 345.9H128c-8.8 0-16 7.4-16 16.6v299c0 9.2 7.2 16.6 16 16.6h101.7c-3.7 11.6-5.7 23.9-5.7 36.4 0 65.9 53.8 119.5 120 119.5 55.4 0 102.1-37.6 115.9-88.4l408.6 164.2c3.9 1.5 7.8 2.3 11.6 2.3 16.9 0 32-14.2 32-33.2V145.2C912 126.2 897 112 880 112zM344 762.3c-26.5 0-48-21.4-48-47.8 0-11.2 3.9-21.9 11-30.4l84.9 34.1c-2 24.6-22.7 44.1-47.9 44.1zm496 58.4L318.8 611.3l-12.9-5.2H184V417.9h121.9l12.9-5.2L840 203.3v617.4z\"}}]})(props);\n};\nexport function AiOutlineNumber (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M872 394c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8H708V152c0-4.4-3.6-8-8-8h-64c-4.4 0-8 3.6-8 8v166H400V152c0-4.4-3.6-8-8-8h-64c-4.4 0-8 3.6-8 8v166H152c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h168v236H152c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h168v166c0 4.4 3.6 8 8 8h64c4.4 0 8-3.6 8-8V706h228v166c0 4.4 3.6 8 8 8h64c4.4 0 8-3.6 8-8V706h164c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8H708V394h164zM628 630H400V394h228v236z\"}}]})(props);\n};\nexport function AiOutlineOneToOne (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683653709\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M316 672h60c4.4 0 8-3.6 8-8V360c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8v304c0 4.4 3.6 8 8 8zM512 622c22.1 0 40-17.9 40-39 0-23.1-17.9-41-40-41s-40 17.9-40 41c0 21.1 17.9 39 40 39zM512 482c22.1 0 40-17.9 40-39 0-23.1-17.9-41-40-41s-40 17.9-40 41c0 21.1 17.9 39 40 39z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32z m-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M648 672h60c4.4 0 8-3.6 8-8V360c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8v304c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlineOrderedList (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M920 760H336c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h584c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-568H336c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h584c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 284H336c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h584c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM216 712H100c-2.2 0-4 1.8-4 4v34c0 2.2 1.8 4 4 4h72.4v20.5h-35.7c-2.2 0-4 1.8-4 4v34c0 2.2 1.8 4 4 4h35.7V838H100c-2.2 0-4 1.8-4 4v34c0 2.2 1.8 4 4 4h116c2.2 0 4-1.8 4-4V716c0-2.2-1.8-4-4-4zM100 188h38v120c0 2.2 1.8 4 4 4h40c2.2 0 4-1.8 4-4V152c0-4.4-3.6-8-8-8h-78c-2.2 0-4 1.8-4 4v36c0 2.2 1.8 4 4 4zm116 240H100c-2.2 0-4 1.8-4 4v36c0 2.2 1.8 4 4 4h68.4l-70.3 77.7a8.3 8.3 0 0 0-2.1 5.4V592c0 2.2 1.8 4 4 4h116c2.2 0 4-1.8 4-4v-36c0-2.2-1.8-4-4-4h-68.4l70.3-77.7a8.3 8.3 0 0 0 2.1-5.4V432c0-2.2-1.8-4-4-4z\"}}]})(props);\n};\nexport function AiOutlinePaperClip (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M779.3 196.6c-94.2-94.2-247.6-94.2-341.7 0l-261 260.8c-1.7 1.7-2.6 4-2.6 6.4s.9 4.7 2.6 6.4l36.9 36.9a9 9 0 0 0 12.7 0l261-260.8c32.4-32.4 75.5-50.2 121.3-50.2s88.9 17.8 121.2 50.2c32.4 32.4 50.2 75.5 50.2 121.2 0 45.8-17.8 88.8-50.2 121.2l-266 265.9-43.1 43.1c-40.3 40.3-105.8 40.3-146.1 0-19.5-19.5-30.2-45.4-30.2-73s10.7-53.5 30.2-73l263.9-263.8c6.7-6.6 15.5-10.3 24.9-10.3h.1c9.4 0 18.1 3.7 24.7 10.3 6.7 6.7 10.3 15.5 10.3 24.9 0 9.3-3.7 18.1-10.3 24.7L372.4 653c-1.7 1.7-2.6 4-2.6 6.4s.9 4.7 2.6 6.4l36.9 36.9a9 9 0 0 0 12.7 0l215.6-215.6c19.9-19.9 30.8-46.3 30.8-74.4s-11-54.6-30.8-74.4c-41.1-41.1-107.9-41-149 0L463 364 224.8 602.1A172.22 172.22 0 0 0 174 724.8c0 46.3 18.1 89.8 50.8 122.5 33.9 33.8 78.3 50.7 122.7 50.7 44.4 0 88.8-16.9 122.6-50.7l309.2-309C824.8 492.7 850 432 850 367.5c.1-64.6-25.1-125.3-70.7-170.9z\"}}]})(props);\n};\nexport function AiOutlinePartition (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683632175\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M640.6 429.8h257.1c7.9 0 14.3-6.4 14.3-14.3V158.3c0-7.9-6.4-14.3-14.3-14.3H640.6c-7.9 0-14.3 6.4-14.3 14.3v92.9H490.6c-3.9 0-7.1 3.2-7.1 7.1v221.5h-85.7v-96.5c0-7.9-6.4-14.3-14.3-14.3H126.3c-7.9 0-14.3 6.4-14.3 14.3v257.2c0 7.9 6.4 14.3 14.3 14.3h257.1c7.9 0 14.3-6.4 14.3-14.3V544h85.7v221.5c0 3.9 3.2 7.1 7.1 7.1h135.7v92.9c0 7.9 6.4 14.3 14.3 14.3h257.1c7.9 0 14.3-6.4 14.3-14.3v-257c0-7.9-6.4-14.3-14.3-14.3h-257c-7.9 0-14.3 6.4-14.3 14.3v100h-78.6v-393h78.6v100c0 7.9 6.4 14.3 14.3 14.3z m53.5-217.9h150V362h-150V211.9zM329.9 587h-150V437h150v150z m364.2 75.1h150v150.1h-150V662.1z\"}}]})(props);\n};\nexport function AiOutlinePauseCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372zm-88-532h-48c-4.4 0-8 3.6-8 8v304c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V360c0-4.4-3.6-8-8-8zm224 0h-48c-4.4 0-8 3.6-8 8v304c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V360c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlinePause (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M304 176h80v672h-80zm408 0h-64c-4.4 0-8 3.6-8 8v656c0 4.4 3.6 8 8 8h64c4.4 0 8-3.6 8-8V184c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlinePayCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372zm159.6-585h-59.5c-3 0-5.8 1.7-7.1 4.4l-90.6 180H511l-90.6-180a8 8 0 0 0-7.1-4.4h-60.7c-1.3 0-2.6.3-3.8 1-3.9 2.1-5.3 7-3.2 10.9L457 515.7h-61.4c-4.4 0-8 3.6-8 8v29.9c0 4.4 3.6 8 8 8h81.7V603h-81.7c-4.4 0-8 3.6-8 8v29.9c0 4.4 3.6 8 8 8h81.7V717c0 4.4 3.6 8 8 8h54.3c4.4 0 8-3.6 8-8v-68.1h82c4.4 0 8-3.6 8-8V611c0-4.4-3.6-8-8-8h-82v-41.5h82c4.4 0 8-3.6 8-8v-29.9c0-4.4-3.6-8-8-8h-62l111.1-204.8c.6-1.2 1-2.5 1-3.8-.1-4.4-3.7-8-8.1-8z\"}}]})(props);\n};\nexport function AiOutlinePercentage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M855.7 210.8l-42.4-42.4a8.03 8.03 0 0 0-11.3 0L168.3 801.9a8.03 8.03 0 0 0 0 11.3l42.4 42.4c3.1 3.1 8.2 3.1 11.3 0L855.6 222c3.2-3 3.2-8.1.1-11.2zM304 448c79.4 0 144-64.6 144-144s-64.6-144-144-144-144 64.6-144 144 64.6 144 144 144zm0-216c39.7 0 72 32.3 72 72s-32.3 72-72 72-72-32.3-72-72 32.3-72 72-72zm416 344c-79.4 0-144 64.6-144 144s64.6 144 144 144 144-64.6 144-144-64.6-144-144-144zm0 216c-39.7 0-72-32.3-72-72s32.3-72 72-72 72 32.3 72 72-32.3 72-72 72z\"}}]})(props);\n};\nexport function AiOutlinePhone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M877.1 238.7L770.6 132.3c-13-13-30.4-20.3-48.8-20.3s-35.8 7.2-48.8 20.3L558.3 246.8c-13 13-20.3 30.5-20.3 48.9 0 18.5 7.2 35.8 20.3 48.9l89.6 89.7a405.46 405.46 0 0 1-86.4 127.3c-36.7 36.9-79.6 66-127.2 86.6l-89.6-89.7c-13-13-30.4-20.3-48.8-20.3a68.2 68.2 0 0 0-48.8 20.3L132.3 673c-13 13-20.3 30.5-20.3 48.9 0 18.5 7.2 35.8 20.3 48.9l106.4 106.4c22.2 22.2 52.8 34.9 84.2 34.9 6.5 0 12.8-.5 19.2-1.6 132.4-21.8 263.8-92.3 369.9-198.3C818 606 888.4 474.6 910.4 342.1c6.3-37.6-6.3-76.3-33.3-103.4zm-37.6 91.5c-19.5 117.9-82.9 235.5-178.4 331s-213 158.9-330.9 178.4c-14.8 2.5-30-2.5-40.8-13.2L184.9 721.9 295.7 611l119.8 120 .9.9 21.6-8a481.29 481.29 0 0 0 285.7-285.8l8-21.6-120.8-120.7 110.8-110.9 104.5 104.5c10.8 10.8 15.8 26 13.3 40.8z\"}}]})(props);\n};\nexport function AiOutlinePicCenter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M952 792H72c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h880c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-632H72c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h880c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM848 660c8.8 0 16-7.2 16-16V380c0-8.8-7.2-16-16-16H176c-8.8 0-16 7.2-16 16v264c0 8.8 7.2 16 16 16h672zM232 436h560v152H232V436z\"}}]})(props);\n};\nexport function AiOutlinePicLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M952 792H72c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h880c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-632H72c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h880c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM608 660c8.8 0 16-7.2 16-16V380c0-8.8-7.2-16-16-16H96c-8.8 0-16 7.2-16 16v264c0 8.8 7.2 16 16 16h512zM152 436h400v152H152V436zm552 210c0 4.4 3.6 8 8 8h224c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H712c-4.4 0-8 3.6-8 8v56zm8-204h224c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H712c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlinePicRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M952 792H72c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h880c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-632H72c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h880c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-24 500c8.8 0 16-7.2 16-16V380c0-8.8-7.2-16-16-16H416c-8.8 0-16 7.2-16 16v264c0 8.8 7.2 16 16 16h512zM472 436h400v152H472V436zM80 646c0 4.4 3.6 8 8 8h224c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H88c-4.4 0-8 3.6-8 8v56zm8-204h224c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H88c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlinePicture (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 160H96c-17.7 0-32 14.3-32 32v640c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V192c0-17.7-14.3-32-32-32zm-40 632H136v-39.9l138.5-164.3 150.1 178L658.1 489 888 761.6V792zm0-129.8L664.2 396.8c-3.2-3.8-9-3.8-12.2 0L424.6 666.4l-144-170.7c-3.2-3.8-9-3.8-12.2 0L136 652.7V232h752v430.2zM304 456a88 88 0 1 0 0-176 88 88 0 0 0 0 176zm0-116c15.5 0 28 12.5 28 28s-12.5 28-28 28-28-12.5-28-28 12.5-28 28-28z\"}}]})(props);\n};\nexport function AiOutlinePieChart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M864 518H506V160c0-4.4-3.6-8-8-8h-26a398.46 398.46 0 0 0-282.8 117.1 398.19 398.19 0 0 0-85.7 127.1A397.61 397.61 0 0 0 72 552a398.46 398.46 0 0 0 117.1 282.8c36.7 36.7 79.5 65.6 127.1 85.7A397.61 397.61 0 0 0 472 952a398.46 398.46 0 0 0 282.8-117.1c36.7-36.7 65.6-79.5 85.7-127.1A397.61 397.61 0 0 0 872 552v-26c0-4.4-3.6-8-8-8zM705.7 787.8A331.59 331.59 0 0 1 470.4 884c-88.1-.4-170.9-34.9-233.2-97.2C174.5 724.1 140 640.7 140 552c0-88.7 34.5-172.1 97.2-234.8 54.6-54.6 124.9-87.9 200.8-95.5V586h364.3c-7.7 76.3-41.3 147-96.6 201.8zM952 462.4l-2.6-28.2c-8.5-92.1-49.4-179-115.2-244.6A399.4 399.4 0 0 0 589 74.6L560.7 72c-4.7-.4-8.7 3.2-8.7 7.9V464c0 4.4 3.6 8 8 8l384-1c4.7 0 8.4-4 8-8.6zm-332.2-58.2V147.6a332.24 332.24 0 0 1 166.4 89.8c45.7 45.6 77 103.6 90 166.1l-256.4.7z\"}}]})(props);\n};\nexport function AiOutlinePlayCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M719.4 499.1l-296.1-215A15.9 15.9 0 0 0 398 297v430c0 13.1 14.8 20.5 25.3 12.9l296.1-215a15.9 15.9 0 0 0 0-25.8zm-257.6 134V390.9L628.5 512 461.8 633.1z\"}}]})(props);\n};\nexport function AiOutlinePlaySquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M442.3 677.6l199.4-156.7a11.3 11.3 0 0 0 0-17.7L442.3 346.4c-7.4-5.8-18.3-.6-18.3 8.8v313.5c0 9.4 10.9 14.7 18.3 8.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}}]})(props);\n};\nexport function AiOutlinePlusCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M696 480H544V328c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v152H328c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h152v152c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V544h152c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}}]})(props);\n};\nexport function AiOutlinePlusSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M328 544h152v152c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V544h152c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H544V328c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v152H328c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}}]})(props);\n};\nexport function AiOutlinePlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1551322312294\",\"style\":\"\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M474 152m8 0l60 0q8 0 8 8l0 704q0 8-8 8l-60 0q-8 0-8-8l0-704q0-8 8-8Z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M168 474m8 0l672 0q8 0 8 8l0 60q0 8-8 8l-672 0q-8 0-8-8l0-60q0-8 8-8Z\"}}]})(props);\n};\nexport function AiOutlinePoundCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372zm138-209.8H469.8v-4.7c27.4-17.2 43.9-50.4 43.9-91.1 0-14.1-2.2-27.9-5.3-41H607c4.4 0 8-3.6 8-8v-30c0-4.4-3.6-8-8-8H495c-7.2-22.6-13.4-45.7-13.4-70.5 0-43.5 34-70.2 87.3-70.2 21.5 0 42.5 4.1 60.4 10.5 5.2 1.9 10.6-2 10.6-7.6v-39.5c0-3.3-2.1-6.3-5.2-7.5-18.8-7.2-43.8-12.7-70.3-12.7-92.9 0-151.5 44.5-151.5 120.3 0 26.3 6.9 52 14.6 77.1H374c-4.4 0-8 3.6-8 8v30c0 4.4 3.6 8 8 8h67.1c3.4 14.7 5.9 29.4 5.9 44.2 0 45.2-28.8 83.3-72.8 94.2-3.6.9-6.1 4.1-6.1 7.8V722c0 4.4 3.6 8 8 8H650c4.4 0 8-3.6 8-8v-39.8c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlinePound (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372zm138-209.8H469.8v-4.7c27.4-17.2 43.9-50.4 43.9-91.1 0-14.1-2.2-27.9-5.3-41H607c4.4 0 8-3.6 8-8v-30c0-4.4-3.6-8-8-8H495c-7.2-22.6-13.4-45.7-13.4-70.5 0-43.5 34-70.2 87.3-70.2 21.5 0 42.5 4.1 60.4 10.5 5.2 1.9 10.6-2 10.6-7.6v-39.5c0-3.3-2.1-6.3-5.2-7.5-18.8-7.2-43.8-12.7-70.3-12.7-92.9 0-151.5 44.5-151.5 120.3 0 26.3 6.9 52 14.6 77.1H374c-4.4 0-8 3.6-8 8v30c0 4.4 3.6 8 8 8h67.1c3.4 14.7 5.9 29.4 5.9 44.2 0 45.2-28.8 83.3-72.8 94.2-3.6.9-6.1 4.1-6.1 7.8V722c0 4.4 3.6 8 8 8H650c4.4 0 8-3.6 8-8v-39.8c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlinePoweroff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M705.6 124.9a8 8 0 0 0-11.6 7.2v64.2c0 5.5 2.9 10.6 7.5 13.6a352.2 352.2 0 0 1 62.2 49.8c32.7 32.8 58.4 70.9 76.3 113.3a355 355 0 0 1 27.9 138.7c0 48.1-9.4 94.8-27.9 138.7a355.92 355.92 0 0 1-76.3 113.3 353.06 353.06 0 0 1-113.2 76.4c-43.8 18.6-90.5 28-138.5 28s-94.7-9.4-138.5-28a353.06 353.06 0 0 1-113.2-76.4A355.92 355.92 0 0 1 184 650.4a355 355 0 0 1-27.9-138.7c0-48.1 9.4-94.8 27.9-138.7 17.9-42.4 43.6-80.5 76.3-113.3 19-19 39.8-35.6 62.2-49.8 4.7-2.9 7.5-8.1 7.5-13.6V132c0-6-6.3-9.8-11.6-7.2C178.5 195.2 82 339.3 80 506.3 77.2 745.1 272.5 943.5 511.2 944c239 .5 432.8-193.3 432.8-432.4 0-169.2-97-315.7-238.4-386.7zM480 560h64c4.4 0 8-3.6 8-8V88c0-4.4-3.6-8-8-8h-64c-4.4 0-8 3.6-8 8v464c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlinePrinter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M820 436h-40c-4.4 0-8 3.6-8 8v40c0 4.4 3.6 8 8 8h40c4.4 0 8-3.6 8-8v-40c0-4.4-3.6-8-8-8zm32-104H732V120c0-4.4-3.6-8-8-8H300c-4.4 0-8 3.6-8 8v212H172c-44.2 0-80 35.8-80 80v328c0 17.7 14.3 32 32 32h168v132c0 4.4 3.6 8 8 8h424c4.4 0 8-3.6 8-8V772h168c17.7 0 32-14.3 32-32V412c0-44.2-35.8-80-80-80zM360 180h304v152H360V180zm304 664H360V568h304v276zm200-140H732V500H292v204H160V412c0-6.6 5.4-12 12-12h680c6.6 0 12 5.4 12 12v292z\"}}]})(props);\n};\nexport function AiOutlineProfile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656zM492 400h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H492c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8zm0 144h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H492c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8zm0 144h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H492c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8zM340 368a40 40 0 1 0 80 0 40 40 0 1 0-80 0zm0 144a40 40 0 1 0 80 0 40 40 0 1 0-80 0zm0 144a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}}]})(props);\n};\nexport function AiOutlineProject (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M280 752h80c4.4 0 8-3.6 8-8V280c0-4.4-3.6-8-8-8h-80c-4.4 0-8 3.6-8 8v464c0 4.4 3.6 8 8 8zm192-280h80c4.4 0 8-3.6 8-8V280c0-4.4-3.6-8-8-8h-80c-4.4 0-8 3.6-8 8v184c0 4.4 3.6 8 8 8zm192 72h80c4.4 0 8-3.6 8-8V280c0-4.4-3.6-8-8-8h-80c-4.4 0-8 3.6-8 8v256c0 4.4 3.6 8 8 8zm216-432H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}}]})(props);\n};\nexport function AiOutlinePropertySafety (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M866.9 169.9L527.1 54.1C523 52.7 517.5 52 512 52s-11 .7-15.1 2.1L157.1 169.9c-8.3 2.8-15.1 12.4-15.1 21.2v482.4c0 8.8 5.7 20.4 12.6 25.9L499.3 968c3.5 2.7 8 4.1 12.6 4.1s9.2-1.4 12.6-4.1l344.7-268.6c6.9-5.4 12.6-17 12.6-25.9V191.1c.2-8.8-6.6-18.3-14.9-21.2zM810 654.3L512 886.5 214 654.3V226.7l298-101.6 298 101.6v427.6zM430.5 318h-46c-1.7 0-3.3.4-4.8 1.2a10.1 10.1 0 0 0-4 13.6l88 161.1h-45.2c-5.5 0-10 4.5-10 10v21.3c0 5.5 4.5 10 10 10h63.1v29.7h-63.1c-5.5 0-10 4.5-10 10v21.3c0 5.5 4.5 10 10 10h63.1V658c0 5.5 4.5 10 10 10h41.3c5.5 0 10-4.5 10-10v-51.8h63.4c5.5 0 10-4.5 10-10v-21.3c0-5.5-4.5-10-10-10h-63.4v-29.7h63.4c5.5 0 10-4.5 10-10v-21.3c0-5.5-4.5-10-10-10h-45.7l87.7-161.1a10.05 10.05 0 0 0-8.8-14.8h-45c-3.8 0-7.2 2.1-8.9 5.5l-73.2 144.3-72.9-144.3c-1.7-3.4-5.2-5.5-9-5.5z\"}}]})(props);\n};\nexport function AiOutlinePullRequest (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M788 705.9V192c0-8.8-7.2-16-16-16H602v-68.8c0-6-7-9.4-11.7-5.7L462.7 202.3a7.14 7.14 0 0 0 0 11.3l127.5 100.8c4.7 3.7 11.7.4 11.7-5.7V240h114v465.9c-44.2 15-76 56.9-76 106.1 0 61.8 50.2 112 112 112s112-50.2 112-112c.1-49.2-31.7-91-75.9-106.1zM752 860a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96zM384 212c0-61.8-50.2-112-112-112s-112 50.2-112 112c0 49.2 31.8 91 76 106.1V706c-44.2 15-76 56.9-76 106.1 0 61.8 50.2 112 112 112s112-50.2 112-112c0-49.2-31.8-91-76-106.1V318.1c44.2-15.1 76-56.9 76-106.1zm-160 0a48.01 48.01 0 0 1 96 0 48.01 48.01 0 0 1-96 0zm96 600a48.01 48.01 0 0 1-96 0 48.01 48.01 0 0 1 96 0z\"}}]})(props);\n};\nexport function AiOutlinePushpin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M878.3 392.1L631.9 145.7c-6.5-6.5-15-9.7-23.5-9.7s-17 3.2-23.5 9.7L423.8 306.9c-12.2-1.4-24.5-2-36.8-2-73.2 0-146.4 24.1-206.5 72.3a33.23 33.23 0 0 0-2.7 49.4l181.7 181.7-215.4 215.2a15.8 15.8 0 0 0-4.6 9.8l-3.4 37.2c-.9 9.4 6.6 17.4 15.9 17.4.5 0 1 0 1.5-.1l37.2-3.4c3.7-.3 7.2-2 9.8-4.6l215.4-215.4 181.7 181.7c6.5 6.5 15 9.7 23.5 9.7 9.7 0 19.3-4.2 25.9-12.4 56.3-70.3 79.7-158.3 70.2-243.4l161.1-161.1c12.9-12.8 12.9-33.8 0-46.8zM666.2 549.3l-24.5 24.5 3.8 34.4a259.92 259.92 0 0 1-30.4 153.9L262 408.8c12.9-7.1 26.3-13.1 40.3-17.9 27.2-9.4 55.7-14.1 84.7-14.1 9.6 0 19.3.5 28.9 1.6l34.4 3.8 24.5-24.5L608.5 224 800 415.5 666.2 549.3z\"}}]})(props);\n};\nexport function AiOutlineQq (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M824.8 613.2c-16-51.4-34.4-94.6-62.7-165.3C766.5 262.2 689.3 112 511.5 112 331.7 112 256.2 265.2 261 447.9c-28.4 70.8-46.7 113.7-62.7 165.3-34 109.5-23 154.8-14.6 155.8 18 2.2 70.1-82.4 70.1-82.4 0 49 25.2 112.9 79.8 159-26.4 8.1-85.7 29.9-71.6 53.8 11.4 19.3 196.2 12.3 249.5 6.3 53.3 6 238.1 13 249.5-6.3 14.1-23.8-45.3-45.7-71.6-53.8 54.6-46.2 79.8-110.1 79.8-159 0 0 52.1 84.6 70.1 82.4 8.5-1.1 19.5-46.4-14.5-155.8z\"}}]})(props);\n};\nexport function AiOutlineQrcode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M468 128H160c-17.7 0-32 14.3-32 32v308c0 4.4 3.6 8 8 8h332c4.4 0 8-3.6 8-8V136c0-4.4-3.6-8-8-8zm-56 284H192V192h220v220zm-138-74h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm194 210H136c-4.4 0-8 3.6-8 8v308c0 17.7 14.3 32 32 32h308c4.4 0 8-3.6 8-8V556c0-4.4-3.6-8-8-8zm-56 284H192V612h220v220zm-138-74h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm590-630H556c-4.4 0-8 3.6-8 8v332c0 4.4 3.6 8 8 8h332c4.4 0 8-3.6 8-8V160c0-17.7-14.3-32-32-32zm-32 284H612V192h220v220zm-138-74h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm194 210h-48c-4.4 0-8 3.6-8 8v134h-78V556c0-4.4-3.6-8-8-8H556c-4.4 0-8 3.6-8 8v332c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V644h78v102c0 4.4 3.6 8 8 8h190c4.4 0 8-3.6 8-8V556c0-4.4-3.6-8-8-8zM746 832h-48c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zm142 0h-48c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineQuestionCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M623.6 316.7C593.6 290.4 554 276 512 276s-81.6 14.5-111.6 40.7C369.2 344 352 380.7 352 420v7.6c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V420c0-44.1 43.1-80 96-80s96 35.9 96 80c0 31.1-22 59.6-56.1 72.7-21.2 8.1-39.2 22.3-52.1 40.9-13.1 19-19.9 41.8-19.9 64.9V620c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-22.7a48.3 48.3 0 0 1 30.9-44.8c59-22.7 97.1-74.7 97.1-132.5.1-39.3-17.1-76-48.3-103.3zM472 732a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}}]})(props);\n};\nexport function AiOutlineQuestion (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M764 280.9c-14-30.6-33.9-58.1-59.3-81.6C653.1 151.4 584.6 125 512 125s-141.1 26.4-192.7 74.2c-25.4 23.6-45.3 51-59.3 81.7-14.6 32-22 65.9-22 100.9v27c0 6.2 5 11.2 11.2 11.2h54c6.2 0 11.2-5 11.2-11.2v-27c0-99.5 88.6-180.4 197.6-180.4s197.6 80.9 197.6 180.4c0 40.8-14.5 79.2-42 111.2-27.2 31.7-65.6 54.4-108.1 64-24.3 5.5-46.2 19.2-61.7 38.8a110.85 110.85 0 0 0-23.9 68.6v31.4c0 6.2 5 11.2 11.2 11.2h54c6.2 0 11.2-5 11.2-11.2v-31.4c0-15.7 10.9-29.5 26-32.9 58.4-13.2 111.4-44.7 149.3-88.7 19.1-22.3 34-47.1 44.3-74 10.7-27.9 16.1-57.2 16.1-87 0-35-7.4-69-22-100.9zM512 787c-30.9 0-56 25.1-56 56s25.1 56 56 56 56-25.1 56-56-25.1-56-56-56z\"}}]})(props);\n};\nexport function AiOutlineRadarChart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M926.8 397.1l-396-288a31.81 31.81 0 0 0-37.6 0l-396 288a31.99 31.99 0 0 0-11.6 35.8l151.3 466a32 32 0 0 0 30.4 22.1h489.5c13.9 0 26.1-8.9 30.4-22.1l151.3-466c4.2-13.2-.5-27.6-11.7-35.8zM838.6 417l-98.5 32-200-144.7V199.9L838.6 417zM466 567.2l-89.1 122.3-55.2-169.2L466 567.2zm-116.3-96.8L484 373.3v140.8l-134.3-43.7zM512 599.2l93.9 128.9H418.1L512 599.2zm28.1-225.9l134.2 97.1L540.1 514V373.3zM558 567.2l144.3-46.9-55.2 169.2L558 567.2zm-74-367.3v104.4L283.9 449l-98.5-32L484 199.9zM169.3 470.8l86.5 28.1 80.4 246.4-53.8 73.9-113.1-348.4zM327.1 853l50.3-69h269.3l50.3 69H327.1zm414.5-33.8l-53.8-73.9 80.4-246.4 86.5-28.1-113.1 348.4z\"}}]})(props);\n};\nexport function AiOutlineRadiusBottomleft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M712 824h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm2-696h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM136 374h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm0-174h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm752 624h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-348 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-230 72h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm230 624H358c-87.3 0-158-70.7-158-158V484c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v182c0 127 103 230 230 230h182c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineRadiusBottomright (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M368 824h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-58-624h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm578 102h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM192 824h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0-174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm292 72h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm174 0h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm230 276h-56c-4.4 0-8 3.6-8 8v182c0 87.3-70.7 158-158 158H484c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h182c127 0 230-103 230-230V484c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineRadiusSetting (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M396 140h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-44 684h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm524-204h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM192 344h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 160h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 160h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 160h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm320 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm160 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm140-284c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V370c0-127-103-230-230-230H484c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h170c87.3 0 158 70.7 158 158v170zM236 96H92c-4.4 0-8 3.6-8 8v144c0 4.4 3.6 8 8 8h144c4.4 0 8-3.6 8-8V104c0-4.4-3.6-8-8-8zm-48 101.6c0 1.3-1.1 2.4-2.4 2.4h-43.2c-1.3 0-2.4-1.1-2.4-2.4v-43.2c0-1.3 1.1-2.4 2.4-2.4h43.2c1.3 0 2.4 1.1 2.4 2.4v43.2zM920 780H776c-4.4 0-8 3.6-8 8v144c0 4.4 3.6 8 8 8h144c4.4 0 8-3.6 8-8V788c0-4.4-3.6-8-8-8zm-48 101.6c0 1.3-1.1 2.4-2.4 2.4h-43.2c-1.3 0-2.4-1.1-2.4-2.4v-43.2c0-1.3 1.1-2.4 2.4-2.4h43.2c1.3 0 2.4 1.1 2.4 2.4v43.2z\"}}]})(props);\n};\nexport function AiOutlineRadiusUpleft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M656 200h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm58 624h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM192 650h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm696-696h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-348 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-174 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm174-696H358c-127 0-230 103-230 230v182c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V358c0-87.3 70.7-158 158-158h182c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineRadiusUpright (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M368 128h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-2 696h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm522-174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM192 128h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 174h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm348 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm174 0h-56c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm-48-696H484c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h182c87.3 0 158 70.7 158 158v182c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V358c0-127-103-230-230-230z\"}}]})(props);\n};\nexport function AiOutlineRead (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 161H699.2c-49.1 0-97.1 14.1-138.4 40.7L512 233l-48.8-31.3A255.2 255.2 0 0 0 324.8 161H96c-17.7 0-32 14.3-32 32v568c0 17.7 14.3 32 32 32h228.8c49.1 0 97.1 14.1 138.4 40.7l44.4 28.6c1.3.8 2.8 1.3 4.3 1.3s3-.4 4.3-1.3l44.4-28.6C602 807.1 650.1 793 699.2 793H928c17.7 0 32-14.3 32-32V193c0-17.7-14.3-32-32-32zM324.8 721H136V233h188.8c35.4 0 69.8 10.1 99.5 29.2l48.8 31.3 6.9 4.5v462c-47.6-25.6-100.8-39-155.2-39zm563.2 0H699.2c-54.4 0-107.6 13.4-155.2 39V298l6.9-4.5 48.8-31.3c29.7-19.1 64.1-29.2 99.5-29.2H888v488zM396.9 361H211.1c-3.9 0-7.1 3.4-7.1 7.5v45c0 4.1 3.2 7.5 7.1 7.5h185.7c3.9 0 7.1-3.4 7.1-7.5v-45c.1-4.1-3.1-7.5-7-7.5zm223.1 7.5v45c0 4.1 3.2 7.5 7.1 7.5h185.7c3.9 0 7.1-3.4 7.1-7.5v-45c0-4.1-3.2-7.5-7.1-7.5H627.1c-3.9 0-7.1 3.4-7.1 7.5zM396.9 501H211.1c-3.9 0-7.1 3.4-7.1 7.5v45c0 4.1 3.2 7.5 7.1 7.5h185.7c3.9 0 7.1-3.4 7.1-7.5v-45c.1-4.1-3.1-7.5-7-7.5zm416 0H627.1c-3.9 0-7.1 3.4-7.1 7.5v45c0 4.1 3.2 7.5 7.1 7.5h185.7c3.9 0 7.1-3.4 7.1-7.5v-45c.1-4.1-3.1-7.5-7-7.5z\"}}]})(props);\n};\nexport function AiOutlineReconciliation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M676 565c-50.8 0-92 41.2-92 92s41.2 92 92 92 92-41.2 92-92-41.2-92-92-92zm0 126c-18.8 0-34-15.2-34-34s15.2-34 34-34 34 15.2 34 34-15.2 34-34 34zm204-523H668c0-30.9-25.1-56-56-56h-80c-30.9 0-56 25.1-56 56H264c-17.7 0-32 14.3-32 32v200h-88c-17.7 0-32 14.3-32 32v448c0 17.7 14.3 32 32 32h336c17.7 0 32-14.3 32-32v-16h368c17.7 0 32-14.3 32-32V200c0-17.7-14.3-32-32-32zm-412 64h72v-56h64v56h72v48H468v-48zm-20 616H176V616h272v232zm0-296H176v-88h272v88zm392 240H512V432c0-17.7-14.3-32-32-32H304V240h100v104h336V240h100v552zM704 408v96c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-96c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8zM592 512h48c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlineRedEnvelope (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M440.6 462.6a8.38 8.38 0 0 0-7.5-4.6h-48.8c-1.3 0-2.6.4-3.9 1a8.4 8.4 0 0 0-3.4 11.4l87.4 161.1H419c-4.6 0-8.4 3.8-8.4 8.4V665c0 4.6 3.8 8.4 8.4 8.4h63V702h-63c-4.6 0-8.4 3.8-8.4 8.4v25.1c0 4.6 3.8 8.4 8.4 8.4h63v49.9c0 4.6 3.8 8.4 8.4 8.4h43.7c4.6 0 8.4-3.8 8.4-8.4v-49.9h63.3c4.7 0 8.4-3.8 8.2-8.5v-25c0-4.6-3.8-8.4-8.4-8.4h-63.3v-28.6h63.3c4.6 0 8.4-3.8 8.4-8.4v-25.1c0-4.6-3.8-8.4-8.4-8.4h-45.9l87.2-161a8.45 8.45 0 0 0-7.4-12.4h-47.8c-3.1 0-6 1.8-7.5 4.6l-71.9 141.9-71.7-142zM832 64H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V96c0-17.7-14.3-32-32-32zm-40 824H232V193.1l260.3 204.1c11.6 9.1 27.9 9.1 39.5 0L792 193.1V888zm0-751.3h-31.7L512 331.3 263.7 136.7H232v-.7h560v.7z\"}}]})(props);\n};\nexport function AiOutlineReddit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M288 568a56 56 0 1 0 112 0 56 56 0 1 0-112 0zm338.7 119.7c-23.1 18.2-68.9 37.8-114.7 37.8s-91.6-19.6-114.7-37.8c-14.4-11.3-35.3-8.9-46.7 5.5s-8.9 35.3 5.5 46.7C396.3 771.6 457.5 792 512 792s115.7-20.4 155.9-52.1a33.25 33.25 0 1 0-41.2-52.2zM960 456c0-61.9-50.1-112-112-112-42.1 0-78.7 23.2-97.9 57.6-57.6-31.5-127.7-51.8-204.1-56.5L612.9 195l127.9 36.9c11.5 32.6 42.6 56.1 79.2 56.1 46.4 0 84-37.6 84-84s-37.6-84-84-84c-32 0-59.8 17.9-74 44.2L603.5 123a33.2 33.2 0 0 0-39.6 18.4l-90.8 203.9c-74.5 5.2-142.9 25.4-199.2 56.2A111.94 111.94 0 0 0 176 344c-61.9 0-112 50.1-112 112 0 45.8 27.5 85.1 66.8 102.5-7.1 21-10.8 43-10.8 65.5 0 154.6 175.5 280 392 280s392-125.4 392-280c0-22.6-3.8-44.5-10.8-65.5C932.5 541.1 960 501.8 960 456zM820 172.5a31.5 31.5 0 1 1 0 63 31.5 31.5 0 0 1 0-63zM120 456c0-30.9 25.1-56 56-56a56 56 0 0 1 50.6 32.1c-29.3 22.2-53.5 47.8-71.5 75.9a56.23 56.23 0 0 1-35.1-52zm392 381.5c-179.8 0-325.5-95.6-325.5-213.5S332.2 410.5 512 410.5 837.5 506.1 837.5 624 691.8 837.5 512 837.5zM868.8 508c-17.9-28.1-42.2-53.7-71.5-75.9 9-18.9 28.3-32.1 50.6-32.1 30.9 0 56 25.1 56 56 .1 23.5-14.5 43.7-35.1 52zM624 568a56 56 0 1 0 112 0 56 56 0 1 0-112 0z\"}}]})(props);\n};\nexport function AiOutlineRedo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M758.2 839.1C851.8 765.9 912 651.9 912 523.9 912 303 733.5 124.3 512.6 124 291.4 123.7 112 302.8 112 523.9c0 125.2 57.5 236.9 147.6 310.2 3.5 2.8 8.6 2.2 11.4-1.3l39.4-50.5c2.7-3.4 2.1-8.3-1.2-11.1-8.1-6.6-15.9-13.7-23.4-21.2a318.64 318.64 0 0 1-68.6-101.7C200.4 609 192 567.1 192 523.9s8.4-85.1 25.1-124.5c16.1-38.1 39.2-72.3 68.6-101.7 29.4-29.4 63.6-52.5 101.7-68.6C426.9 212.4 468.8 204 512 204s85.1 8.4 124.5 25.1c38.1 16.1 72.3 39.2 101.7 68.6 29.4 29.4 52.5 63.6 68.6 101.7 16.7 39.4 25.1 81.3 25.1 124.5s-8.4 85.1-25.1 124.5a318.64 318.64 0 0 1-68.6 101.7c-9.3 9.3-19.1 18-29.3 26L668.2 724a8 8 0 0 0-14.1 3l-39.6 162.2c-1.2 5 2.6 9.9 7.7 9.9l167 .8c6.7 0 10.5-7.7 6.3-12.9l-37.3-47.9z\"}}]})(props);\n};\nexport function AiOutlineReload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M909.1 209.3l-56.4 44.1C775.8 155.1 656.2 92 521.9 92 290 92 102.3 279.5 102 511.5 101.7 743.7 289.8 932 521.9 932c181.3 0 335.8-115 394.6-276.1 1.5-4.2-.7-8.9-4.9-10.3l-56.7-19.5a8 8 0 0 0-10.1 4.8c-1.8 5-3.8 10-5.9 14.9-17.3 41-42.1 77.8-73.7 109.4A344.77 344.77 0 0 1 655.9 829c-42.3 17.9-87.4 27-133.8 27-46.5 0-91.5-9.1-133.8-27A341.5 341.5 0 0 1 279 755.2a342.16 342.16 0 0 1-73.7-109.4c-17.9-42.4-27-87.4-27-133.9s9.1-91.5 27-133.9c17.3-41 42.1-77.8 73.7-109.4 31.6-31.6 68.4-56.4 109.3-73.8 42.3-17.9 87.4-27 133.8-27 46.5 0 91.5 9.1 133.8 27a341.5 341.5 0 0 1 109.3 73.8c9.9 9.9 19.2 20.4 27.8 31.4l-60.2 47a8 8 0 0 0 3 14.1l175.6 43c5 1.2 9.9-2.6 9.9-7.7l.8-180.9c-.1-6.6-7.8-10.3-13-6.2z\"}}]})(props);\n};\nexport function AiOutlineRest (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M508 704c79.5 0 144-64.5 144-144s-64.5-144-144-144-144 64.5-144 144 64.5 144 144 144zm0-224c44.2 0 80 35.8 80 80s-35.8 80-80 80-80-35.8-80-80 35.8-80 80-80z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M832 256h-28.1l-35.7-120.9c-4-13.7-16.5-23.1-30.7-23.1h-451c-14.3 0-26.8 9.4-30.7 23.1L220.1 256H192c-17.7 0-32 14.3-32 32v28c0 4.4 3.6 8 8 8h45.8l47.7 558.7a32 32 0 0 0 31.9 29.3h429.2a32 32 0 0 0 31.9-29.3L802.2 324H856c4.4 0 8-3.6 8-8v-28c0-17.7-14.3-32-32-32zm-518.6-76h397.2l22.4 76H291l22.4-76zm376.2 664H326.4L282 324h451.9l-44.3 520z\"}}]})(props);\n};\nexport function AiOutlineRetweet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M136 552h63.6c4.4 0 8-3.6 8-8V288.7h528.6v72.6c0 1.9.6 3.7 1.8 5.2a8.3 8.3 0 0 0 11.7 1.4L893 255.4c4.3-5 3.6-10.3 0-13.2L749.7 129.8a8.22 8.22 0 0 0-5.2-1.8c-4.6 0-8.4 3.8-8.4 8.4V209H199.7c-39.5 0-71.7 32.2-71.7 71.8V544c0 4.4 3.6 8 8 8zm752-80h-63.6c-4.4 0-8 3.6-8 8v255.3H287.8v-72.6c0-1.9-.6-3.7-1.8-5.2a8.3 8.3 0 0 0-11.7-1.4L131 768.6c-4.3 5-3.6 10.3 0 13.2l143.3 112.4c1.5 1.2 3.3 1.8 5.2 1.8 4.6 0 8.4-3.8 8.4-8.4V815h536.6c39.5 0 71.7-32.2 71.7-71.8V480c-.2-4.4-3.8-8-8.2-8z\"}}]})(props);\n};\nexport function AiOutlineRightCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M666.7 505.5l-246-178A8 8 0 0 0 408 334v46.9c0 10.2 4.9 19.9 13.2 25.9L566.6 512 421.2 617.2c-8.3 6-13.2 15.6-13.2 25.9V690c0 6.5 7.4 10.3 12.7 6.5l246-178c4.4-3.2 4.4-9.8 0-13z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}}]})(props);\n};\nexport function AiOutlineRightSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M412.7 696.5l246-178c4.4-3.2 4.4-9.7 0-12.9l-246-178c-5.3-3.8-12.7 0-12.7 6.5V381c0 10.2 4.9 19.9 13.2 25.9L558.6 512 413.2 617.2c-8.3 6-13.2 15.6-13.2 25.9V690c0 6.5 7.4 10.3 12.7 6.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}}]})(props);\n};\nexport function AiOutlineRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M765.7 486.8L314.9 134.7A7.97 7.97 0 0 0 302 141v77.3c0 4.9 2.3 9.6 6.1 12.6l360 281.1-360 281.1c-3.9 3-6.1 7.7-6.1 12.6V883c0 6.7 7.7 10.4 12.9 6.3l450.8-352.1a31.96 31.96 0 0 0 0-50.4z\"}}]})(props);\n};\nexport function AiOutlineRise (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M917 211.1l-199.2 24c-6.6.8-9.4 8.9-4.7 13.6l59.3 59.3-226 226-101.8-101.7c-6.3-6.3-16.4-6.2-22.6 0L100.3 754.1a8.03 8.03 0 0 0 0 11.3l45 45.2c3.1 3.1 8.2 3.1 11.3 0L433.3 534 535 635.7c6.3 6.2 16.4 6.2 22.6 0L829 364.5l59.3 59.3a8.01 8.01 0 0 0 13.6-4.7l24-199.2c.7-5.1-3.7-9.5-8.9-8.8z\"}}]})(props);\n};\nexport function AiOutlineRobot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M300 328a60 60 0 1 0 120 0 60 60 0 1 0-120 0zM852 64H172c-17.7 0-32 14.3-32 32v660c0 17.7 14.3 32 32 32h680c17.7 0 32-14.3 32-32V96c0-17.7-14.3-32-32-32zm-32 660H204V128h616v596zM604 328a60 60 0 1 0 120 0 60 60 0 1 0-120 0zm250.2 556H169.8c-16.5 0-29.8 14.3-29.8 32v36c0 4.4 3.3 8 7.4 8h729.1c4.1 0 7.4-3.6 7.4-8v-36c.1-17.7-13.2-32-29.7-32zM664 508H360c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h304c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineRocket (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M864 736c0-111.6-65.4-208-160-252.9V317.3c0-15.1-5.3-29.7-15.1-41.2L536.5 95.4C530.1 87.8 521 84 512 84s-18.1 3.8-24.5 11.4L335.1 276.1a63.97 63.97 0 0 0-15.1 41.2v165.8C225.4 528 160 624.4 160 736h156.5c-2.3 7.2-3.5 15-3.5 23.8 0 22.1 7.6 43.7 21.4 60.8a97.2 97.2 0 0 0 43.1 30.6c23.1 54 75.6 88.8 134.5 88.8 29.1 0 57.3-8.6 81.4-24.8 23.6-15.8 41.9-37.9 53-64a97 97 0 0 0 43.1-30.5 97.52 97.52 0 0 0 21.4-60.8c0-8.4-1.1-16.4-3.1-23.8H864zM762.3 621.4c9.4 14.6 17 30.3 22.5 46.6H700V558.7a211.6 211.6 0 0 1 62.3 62.7zM388 483.1V318.8l124-147 124 147V668H388V483.1zM239.2 668c5.5-16.3 13.1-32 22.5-46.6 16.3-25.2 37.5-46.5 62.3-62.7V668h-84.8zm388.9 116.2c-5.2 3-11.2 4.2-17.1 3.4l-19.5-2.4-2.8 19.4c-5.4 37.9-38.4 66.5-76.7 66.5-38.3 0-71.3-28.6-76.7-66.5l-2.8-19.5-19.5 2.5a27.7 27.7 0 0 1-17.1-3.5c-8.7-5-14.1-14.3-14.1-24.4 0-10.6 5.9-19.4 14.6-23.8h231.3c8.8 4.5 14.6 13.3 14.6 23.8-.1 10.2-5.5 19.6-14.2 24.5zM464 400a48 48 0 1 0 96 0 48 48 0 1 0-96 0z\"}}]})(props);\n};\nexport function AiOutlineRollback (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M793 242H366v-74c0-6.7-7.7-10.4-12.9-6.3l-142 112a8 8 0 0 0 0 12.6l142 112c5.2 4.1 12.9.4 12.9-6.3v-74h415v470H175c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h618c35.3 0 64-28.7 64-64V306c0-35.3-28.7-64-64-64z\"}}]})(props);\n};\nexport function AiOutlineRotateLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683455503\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M672 418H144c-17.7 0-32 14.3-32 32v414c0 17.7 14.3 32 32 32h528c17.7 0 32-14.3 32-32V450c0-17.7-14.3-32-32-32z m-44 402H188V494h440v326z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M819.3 328.5c-78.8-100.7-196-153.6-314.6-154.2l-0.2-64c0-6.5-7.6-10.1-12.6-6.1l-128 101c-4 3.1-3.9 9.1 0 12.3L492 318.6c5.1 4 12.7 0.4 12.6-6.1v-63.9c12.9 0.1 25.9 0.9 38.8 2.5 42.1 5.2 82.1 18.2 119 38.7 38.1 21.2 71.2 49.7 98.4 84.3 27.1 34.7 46.7 73.7 58.1 115.8 11 40.7 14 82.7 8.9 124.8-0.7 5.4-1.4 10.8-2.4 16.1h74.9c14.8-103.6-11.3-213-81-302.3z\"}}]})(props);\n};\nexport function AiOutlineRotateRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683458761\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M480.5 251.2c13-1.6 25.9-2.4 38.8-2.5v63.9c0 6.5 7.5 10.1 12.6 6.1L660 217.6c4-3.2 4-9.2 0-12.3l-128-101c-5.1-4-12.6-0.4-12.6 6.1l-0.2 64c-118.6 0.5-235.8 53.4-314.6 154.2-69.6 89.2-95.7 198.6-81.1 302.4h74.9c-0.9-5.3-1.7-10.7-2.4-16.1-5.1-42.1-2.1-84.1 8.9-124.8 11.4-42.2 31-81.1 58.1-115.8 27.2-34.7 60.3-63.2 98.4-84.3 37-20.6 76.9-33.6 119.1-38.8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 418H352c-17.7 0-32 14.3-32 32v414c0 17.7 14.3 32 32 32h528c17.7 0 32-14.3 32-32V450c0-17.7-14.3-32-32-32z m-44 402H396V494h440v326z\"}}]})(props);\n};\nexport function AiOutlineSafetyCertificate (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M866.9 169.9L527.1 54.1C523 52.7 517.5 52 512 52s-11 .7-15.1 2.1L157.1 169.9c-8.3 2.8-15.1 12.4-15.1 21.2v482.4c0 8.8 5.7 20.4 12.6 25.9L499.3 968c3.5 2.7 8 4.1 12.6 4.1s9.2-1.4 12.6-4.1l344.7-268.6c6.9-5.4 12.6-17 12.6-25.9V191.1c.2-8.8-6.6-18.3-14.9-21.2zM810 654.3L512 886.5 214 654.3V226.7l298-101.6 298 101.6v427.6zm-405.8-201c-3-4.1-7.8-6.6-13-6.6H336c-6.5 0-10.3 7.4-6.5 12.7l126.4 174a16.1 16.1 0 0 0 26 0l212.6-292.7c3.8-5.3 0-12.7-6.5-12.7h-55.2c-5.1 0-10 2.5-13 6.6L468.9 542.4l-64.7-89.1z\"}}]})(props);\n};\nexport function AiOutlineSafety (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64L128 192v384c0 212.1 171.9 384 384 384s384-171.9 384-384V192L512 64zm312 512c0 172.3-139.7 312-312 312S200 748.3 200 576V246l312-110 312 110v330z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M378.4 475.1a35.91 35.91 0 0 0-50.9 0 35.91 35.91 0 0 0 0 50.9l129.4 129.4 2.1 2.1a33.98 33.98 0 0 0 48.1 0L730.6 434a33.98 33.98 0 0 0 0-48.1l-2.8-2.8a33.98 33.98 0 0 0-48.1 0L483 579.7 378.4 475.1z\"}}]})(props);\n};\nexport function AiOutlineSave (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M893.3 293.3L730.7 130.7c-7.5-7.5-16.7-13-26.7-16V112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V338.5c0-17-6.7-33.2-18.7-45.2zM384 184h256v104H384V184zm456 656H184V184h136v136c0 17.7 14.3 32 32 32h320c17.7 0 32-14.3 32-32V205.8l136 136V840zM512 442c-79.5 0-144 64.5-144 144s64.5 144 144 144 144-64.5 144-144-64.5-144-144-144zm0 224c-44.2 0-80-35.8-80-80s35.8-80 80-80 80 35.8 80 80-35.8 80-80 80z\"}}]})(props);\n};\nexport function AiOutlineScan (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M136 384h56c4.4 0 8-3.6 8-8V200h176c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H196c-37.6 0-68 30.4-68 68v180c0 4.4 3.6 8 8 8zm512-184h176v176c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V196c0-37.6-30.4-68-68-68H648c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zM376 824H200V648c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v180c0 37.6 30.4 68 68 68h180c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm512-184h-56c-4.4 0-8 3.6-8 8v176H648c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h180c37.6 0 68-30.4 68-68V648c0-4.4-3.6-8-8-8zm16-164H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineSchedule (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 224H768v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H548v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H328v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H96c-17.7 0-32 14.3-32 32v576c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V256c0-17.7-14.3-32-32-32zm-40 568H136V296h120v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56h148v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56h148v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56h120v496zM416 496H232c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zm0 136H232c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zm308.2-177.4L620.6 598.3l-52.8-73.1c-3-4.2-7.8-6.6-12.9-6.6H500c-6.5 0-10.3 7.4-6.5 12.7l114.1 158.2a15.9 15.9 0 0 0 25.8 0l165-228.7c3.8-5.3 0-12.7-6.5-12.7H737c-5-.1-9.8 2.4-12.8 6.5z\"}}]})(props);\n};\nexport function AiOutlineScissor (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M567.1 512l318.5-319.3c5-5 1.5-13.7-5.6-13.7h-90.5c-2.1 0-4.2.8-5.6 2.3l-273.3 274-90.2-90.5c12.5-22.1 19.7-47.6 19.7-74.8 0-83.9-68.1-152-152-152s-152 68.1-152 152 68.1 152 152 152c27.7 0 53.6-7.4 75.9-20.3l90 90.3-90.1 90.3A151.04 151.04 0 0 0 288 582c-83.9 0-152 68.1-152 152s68.1 152 152 152 152-68.1 152-152c0-27.2-7.2-52.7-19.7-74.8l90.2-90.5 273.3 274c1.5 1.5 3.5 2.3 5.6 2.3H880c7.1 0 10.7-8.6 5.6-13.7L567.1 512zM288 370c-44.1 0-80-35.9-80-80s35.9-80 80-80 80 35.9 80 80-35.9 80-80 80zm0 444c-44.1 0-80-35.9-80-80s35.9-80 80-80 80 35.9 80 80-35.9 80-80 80z\"}}]})(props);\n};\nexport function AiOutlineSearch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M909.6 854.5L649.9 594.8C690.2 542.7 712 479 712 412c0-80.2-31.3-155.4-87.9-212.1-56.6-56.7-132-87.9-212.1-87.9s-155.5 31.3-212.1 87.9C143.2 256.5 112 331.8 112 412c0 80.1 31.3 155.5 87.9 212.1C256.5 680.8 331.8 712 412 712c67 0 130.6-21.8 182.7-62l259.7 259.6a8.2 8.2 0 0 0 11.6 0l43.6-43.5a8.2 8.2 0 0 0 0-11.6zM570.4 570.4C528 612.7 471.8 636 412 636s-116-23.3-158.4-65.6C211.3 528 188 471.8 188 412s23.3-116.1 65.6-158.4C296 211.3 352.2 188 412 188s116.1 23.2 158.4 65.6S636 352.2 636 412s-23.3 116.1-65.6 158.4z\"}}]})(props);\n};\nexport function AiOutlineSecurityScan (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M866.9 169.9L527.1 54.1C523 52.7 517.5 52 512 52s-11 .7-15.1 2.1L157.1 169.9c-8.3 2.8-15.1 12.4-15.1 21.2v482.4c0 8.8 5.7 20.4 12.6 25.9L499.3 968c3.5 2.7 8 4.1 12.6 4.1s9.2-1.4 12.6-4.1l344.7-268.6c6.9-5.4 12.6-17 12.6-25.9V191.1c.2-8.8-6.6-18.3-14.9-21.2zM810 654.3L512 886.5 214 654.3V226.7l298-101.6 298 101.6v427.6zM402.9 528.8l-77.5 77.5a8.03 8.03 0 0 0 0 11.3l34 34c3.1 3.1 8.2 3.1 11.3 0l77.5-77.5c55.7 35.1 130.1 28.4 178.6-20.1 56.3-56.3 56.3-147.5 0-203.8-56.3-56.3-147.5-56.3-203.8 0-48.5 48.5-55.2 123-20.1 178.6zm65.4-133.3c31.3-31.3 82-31.3 113.2 0 31.3 31.3 31.3 82 0 113.2-31.3 31.3-82 31.3-113.2 0s-31.3-81.9 0-113.2z\"}}]})(props);\n};\nexport function AiOutlineSelect (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h360c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H184V184h656v320c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V144c0-17.7-14.3-32-32-32zM653.3 599.4l52.2-52.2a8.01 8.01 0 0 0-4.7-13.6l-179.4-21c-5.1-.6-9.5 3.7-8.9 8.9l21 179.4c.8 6.6 8.9 9.4 13.6 4.7l52.4-52.4 256.2 256.2c3.1 3.1 8.2 3.1 11.3 0l42.4-42.4c3.1-3.1 3.1-8.2 0-11.3L653.3 599.4z\"}}]})(props);\n};\nexport function AiOutlineSend (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683742680\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M931.4 498.9L94.9 79.5c-3.4-1.7-7.3-2.1-11-1.2-8.5 2.1-13.8 10.7-11.7 19.3l86.2 352.2c1.3 5.3 5.2 9.6 10.4 11.3l147.7 50.7-147.6 50.7c-5.2 1.8-9.1 6-10.3 11.3L72.2 926.5c-0.9 3.7-0.5 7.6 1.2 10.9 3.9 7.9 13.5 11.1 21.5 7.2l836.5-417c3.1-1.5 5.6-4.1 7.2-7.1 3.9-8 0.7-17.6-7.2-21.6zM170.8 826.3l50.3-205.6 295.2-101.3c2.3-0.8 4.2-2.6 5-5 1.4-4.2-0.8-8.7-5-10.2L221.1 403 171 198.2l628 314.9-628.2 313.2z\"}}]})(props);\n};\nexport function AiOutlineSetting (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M924.8 625.7l-65.5-56c3.1-19 4.7-38.4 4.7-57.8s-1.6-38.8-4.7-57.8l65.5-56a32.03 32.03 0 0 0 9.3-35.2l-.9-2.6a443.74 443.74 0 0 0-79.7-137.9l-1.8-2.1a32.12 32.12 0 0 0-35.1-9.5l-81.3 28.9c-30-24.6-63.5-44-99.7-57.6l-15.7-85a32.05 32.05 0 0 0-25.8-25.7l-2.7-.5c-52.1-9.4-106.9-9.4-159 0l-2.7.5a32.05 32.05 0 0 0-25.8 25.7l-15.8 85.4a351.86 351.86 0 0 0-99 57.4l-81.9-29.1a32 32 0 0 0-35.1 9.5l-1.8 2.1a446.02 446.02 0 0 0-79.7 137.9l-.9 2.6c-4.5 12.5-.8 26.5 9.3 35.2l66.3 56.6c-3.1 18.8-4.6 38-4.6 57.1 0 19.2 1.5 38.4 4.6 57.1L99 625.5a32.03 32.03 0 0 0-9.3 35.2l.9 2.6c18.1 50.4 44.9 96.9 79.7 137.9l1.8 2.1a32.12 32.12 0 0 0 35.1 9.5l81.9-29.1c29.8 24.5 63.1 43.9 99 57.4l15.8 85.4a32.05 32.05 0 0 0 25.8 25.7l2.7.5a449.4 449.4 0 0 0 159 0l2.7-.5a32.05 32.05 0 0 0 25.8-25.7l15.7-85a350 350 0 0 0 99.7-57.6l81.3 28.9a32 32 0 0 0 35.1-9.5l1.8-2.1c34.8-41.1 61.6-87.5 79.7-137.9l.9-2.6c4.5-12.3.8-26.3-9.3-35zM788.3 465.9c2.5 15.1 3.8 30.6 3.8 46.1s-1.3 31-3.8 46.1l-6.6 40.1 74.7 63.9a370.03 370.03 0 0 1-42.6 73.6L721 702.8l-31.4 25.8c-23.9 19.6-50.5 35-79.3 45.8l-38.1 14.3-17.9 97a377.5 377.5 0 0 1-85 0l-17.9-97.2-37.8-14.5c-28.5-10.8-55-26.2-78.7-45.7l-31.4-25.9-93.4 33.2c-17-22.9-31.2-47.6-42.6-73.6l75.5-64.5-6.5-40c-2.4-14.9-3.7-30.3-3.7-45.5 0-15.3 1.2-30.6 3.7-45.5l6.5-40-75.5-64.5c11.3-26.1 25.6-50.7 42.6-73.6l93.4 33.2 31.4-25.9c23.7-19.5 50.2-34.9 78.7-45.7l37.9-14.3 17.9-97.2c28.1-3.2 56.8-3.2 85 0l17.9 97 38.1 14.3c28.7 10.8 55.4 26.2 79.3 45.8l31.4 25.8 92.8-32.9c17 22.9 31.2 47.6 42.6 73.6L781.8 426l6.5 39.9zM512 326c-97.2 0-176 78.8-176 176s78.8 176 176 176 176-78.8 176-176-78.8-176-176-176zm79.2 255.2A111.6 111.6 0 0 1 512 614c-29.9 0-58-11.7-79.2-32.8A111.6 111.6 0 0 1 400 502c0-29.9 11.7-58 32.8-79.2C454 401.6 482.1 390 512 390c29.9 0 58 11.6 79.2 32.8A111.6 111.6 0 0 1 624 502c0 29.9-11.7 58-32.8 79.2z\"}}]})(props);\n};\nexport function AiOutlineShake (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M324 666a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm616.7-309.6L667.6 83.2C655.2 70.9 638.7 64 621.1 64s-34.1 6.8-46.5 19.2L83.3 574.5a65.85 65.85 0 0 0 0 93.1l273.2 273.2c12.3 12.3 28.9 19.2 46.5 19.2s34.1-6.8 46.5-19.2l491.3-491.3c25.6-25.7 25.6-67.5-.1-93.1zM403 880.1L143.9 621l477.2-477.2 259 259.2L403 880.1zM152.8 373.7a7.9 7.9 0 0 0 11.2 0L373.7 164a7.9 7.9 0 0 0 0-11.2l-38.4-38.4a7.9 7.9 0 0 0-11.2 0L114.3 323.9a7.9 7.9 0 0 0 0 11.2l38.5 38.6zm718.6 276.6a7.9 7.9 0 0 0-11.2 0L650.3 860.1a7.9 7.9 0 0 0 0 11.2l38.4 38.4a7.9 7.9 0 0 0 11.2 0L909.7 700a7.9 7.9 0 0 0 0-11.2l-38.3-38.5z\"}}]})(props);\n};\nexport function AiOutlineShareAlt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M752 664c-28.5 0-54.8 10-75.4 26.7L469.4 540.8a160.68 160.68 0 0 0 0-57.6l207.2-149.9C697.2 350 723.5 360 752 360c66.2 0 120-53.8 120-120s-53.8-120-120-120-120 53.8-120 120c0 11.6 1.6 22.7 4.7 33.3L439.9 415.8C410.7 377.1 364.3 352 312 352c-88.4 0-160 71.6-160 160s71.6 160 160 160c52.3 0 98.7-25.1 127.9-63.8l196.8 142.5c-3.1 10.6-4.7 21.8-4.7 33.3 0 66.2 53.8 120 120 120s120-53.8 120-120-53.8-120-120-120zm0-476c28.7 0 52 23.3 52 52s-23.3 52-52 52-52-23.3-52-52 23.3-52 52-52zM312 600c-48.5 0-88-39.5-88-88s39.5-88 88-88 88 39.5 88 88-39.5 88-88 88zm440 236c-28.7 0-52-23.3-52-52s23.3-52 52-52 52 23.3 52 52-23.3 52-52 52z\"}}]})(props);\n};\nexport function AiOutlineShop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M882 272.1V144c0-17.7-14.3-32-32-32H174c-17.7 0-32 14.3-32 32v128.1c-16.7 1-30 14.9-30 31.9v131.7a177 177 0 0 0 14.4 70.4c4.3 10.2 9.6 19.8 15.6 28.9v345c0 17.6 14.3 32 32 32h676c17.7 0 32-14.3 32-32V535a175 175 0 0 0 15.6-28.9c9.5-22.3 14.4-46 14.4-70.4V304c0-17-13.3-30.9-30-31.9zM214 184h596v88H214v-88zm362 656.1H448V736h128v104.1zm234 0H640V704c0-17.7-14.3-32-32-32H416c-17.7 0-32 14.3-32 32v136.1H214V597.9c2.9 1.4 5.9 2.8 9 4 22.3 9.4 46 14.1 70.4 14.1s48-4.7 70.4-14.1c13.8-5.8 26.8-13.2 38.7-22.1.2-.1.4-.1.6 0a180.4 180.4 0 0 0 38.7 22.1c22.3 9.4 46 14.1 70.4 14.1 24.4 0 48-4.7 70.4-14.1 13.8-5.8 26.8-13.2 38.7-22.1.2-.1.4-.1.6 0a180.4 180.4 0 0 0 38.7 22.1c22.3 9.4 46 14.1 70.4 14.1 24.4 0 48-4.7 70.4-14.1 3-1.3 6-2.6 9-4v242.2zm30-404.4c0 59.8-49 108.3-109.3 108.3-40.8 0-76.4-22.1-95.2-54.9-2.9-5-8.1-8.1-13.9-8.1h-.6c-5.7 0-11 3.1-13.9 8.1A109.24 109.24 0 0 1 512 544c-40.7 0-76.2-22-95-54.7-3-5.1-8.4-8.3-14.3-8.3s-11.4 3.2-14.3 8.3a109.63 109.63 0 0 1-95.1 54.7C233 544 184 495.5 184 435.7v-91.2c0-.3.2-.5.5-.5h655c.3 0 .5.2.5.5v91.2z\"}}]})(props);\n};\nexport function AiOutlineShoppingCart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M922.9 701.9H327.4l29.9-60.9 496.8-.9c16.8 0 31.2-12 34.2-28.6l68.8-385.1c1.8-10.1-.9-20.5-7.5-28.4a34.99 34.99 0 0 0-26.6-12.5l-632-2.1-5.4-25.4c-3.4-16.2-18-28-34.6-28H96.5a35.3 35.3 0 1 0 0 70.6h125.9L246 312.8l58.1 281.3-74.8 122.1a34.96 34.96 0 0 0-3 36.8c6 11.9 18.1 19.4 31.5 19.4h62.8a102.43 102.43 0 0 0-20.6 61.7c0 56.6 46 102.6 102.6 102.6s102.6-46 102.6-102.6c0-22.3-7.4-44-20.6-61.7h161.1a102.43 102.43 0 0 0-20.6 61.7c0 56.6 46 102.6 102.6 102.6s102.6-46 102.6-102.6c0-22.3-7.4-44-20.6-61.7H923c19.4 0 35.3-15.8 35.3-35.3a35.42 35.42 0 0 0-35.4-35.2zM305.7 253l575.8 1.9-56.4 315.8-452.3.8L305.7 253zm96.9 612.7c-17.4 0-31.6-14.2-31.6-31.6 0-17.4 14.2-31.6 31.6-31.6s31.6 14.2 31.6 31.6a31.6 31.6 0 0 1-31.6 31.6zm325.1 0c-17.4 0-31.6-14.2-31.6-31.6 0-17.4 14.2-31.6 31.6-31.6s31.6 14.2 31.6 31.6a31.6 31.6 0 0 1-31.6 31.6z\"}}]})(props);\n};\nexport function AiOutlineShopping (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 312H696v-16c0-101.6-82.4-184-184-184s-184 82.4-184 184v16H192c-17.7 0-32 14.3-32 32v536c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V344c0-17.7-14.3-32-32-32zm-432-16c0-61.9 50.1-112 112-112s112 50.1 112 112v16H400v-16zm392 544H232V384h96v88c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-88h224v88c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-88h96v456z\"}}]})(props);\n};\nexport function AiOutlineShrink (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M881.7 187.4l-45.1-45.1a8.03 8.03 0 0 0-11.3 0L667.8 299.9l-54.7-54.7a7.94 7.94 0 0 0-13.5 4.7L576.1 439c-.6 5.2 3.7 9.5 8.9 8.9l189.2-23.5c6.6-.8 9.3-8.8 4.7-13.5l-54.7-54.7 157.6-157.6c3-3 3-8.1-.1-11.2zM439 576.1l-189.2 23.5c-6.6.8-9.3 8.9-4.7 13.5l54.7 54.7-157.5 157.5a8.03 8.03 0 0 0 0 11.3l45.1 45.1c3.1 3.1 8.2 3.1 11.3 0l157.6-157.6 54.7 54.7a7.94 7.94 0 0 0 13.5-4.7L447.9 585a7.9 7.9 0 0 0-8.9-8.9z\"}}]})(props);\n};\nexport function AiOutlineSisternode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683586275\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M672 432c-120.3 0-219.9 88.5-237.3 204H320c-15.5 0-28-12.5-28-28V244h291c14.2 35.2 48.7 60 89 60 53 0 96-43 96-96s-43-96-96-96c-40.3 0-74.8 24.8-89 60H112v72h108v364c0 55.2 44.8 100 100 100h114.7c17.4 115.5 117 204 237.3 204 132.5 0 240-107.5 240-240S804.5 432 672 432z m128 266c0 4.4-3.6 8-8 8h-86v86c0 4.4-3.6 8-8 8h-52c-4.4 0-8-3.6-8-8v-86h-86c-4.4 0-8-3.6-8-8v-52c0-4.4 3.6-8 8-8h86v-86c0-4.4 3.6-8 8-8h52c4.4 0 8 3.6 8 8v86h86c4.4 0 8 3.6 8 8v52z\"}}]})(props);\n};\nexport function AiOutlineSketch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M925.6 405.1l-203-253.7a6.5 6.5 0 0 0-5-2.4H306.4c-1.9 0-3.8.9-5 2.4l-203 253.7a6.5 6.5 0 0 0 .2 8.3l408.6 459.5c1.2 1.4 3 2.1 4.8 2.1 1.8 0 3.5-.8 4.8-2.1l408.6-459.5a6.5 6.5 0 0 0 .2-8.3zM645.2 206.4l34.4 133.9-132.5-133.9h98.1zm8.2 178.5H370.6L512 242l141.4 142.9zM378.8 206.4h98.1L344.3 340.3l34.5-133.9zm-53.4 7l-44.1 171.5h-93.1l137.2-171.5zM194.6 434.9H289l125.8 247.7-220.2-247.7zM512 763.4L345.1 434.9h333.7L512 763.4zm97.1-80.8L735 434.9h94.4L609.1 682.6zm133.6-297.7l-44.1-171.5 137.2 171.5h-93.1z\"}}]})(props);\n};\nexport function AiOutlineSkin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M870 126H663.8c-17.4 0-32.9 11.9-37 29.3C614.3 208.1 567 246 512 246s-102.3-37.9-114.8-90.7a37.93 37.93 0 0 0-37-29.3H154a44 44 0 0 0-44 44v252a44 44 0 0 0 44 44h75v388a44 44 0 0 0 44 44h478a44 44 0 0 0 44-44V466h75a44 44 0 0 0 44-44V170a44 44 0 0 0-44-44zm-28 268H723v432H301V394H182V198h153.3c28.2 71.2 97.5 120 176.7 120s148.5-48.8 176.7-120H842v196z\"}}]})(props);\n};\nexport function AiOutlineSkype (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M883.7 578.6c4.1-22.5 6.3-45.5 6.3-68.5 0-51-10-100.5-29.7-147-19-45-46.3-85.4-81-120.1a375.79 375.79 0 0 0-120.1-80.9c-46.6-19.7-96-29.7-147-29.7-24 0-48.1 2.3-71.5 6.8A225.1 225.1 0 0 0 335.6 113c-59.7 0-115.9 23.3-158.1 65.5A222.25 222.25 0 0 0 112 336.6c0 38 9.8 75.4 28.1 108.4-3.7 21.4-5.7 43.3-5.7 65.1 0 51 10 100.5 29.7 147 19 45 46.2 85.4 80.9 120.1 34.7 34.7 75.1 61.9 120.1 80.9 46.6 19.7 96 29.7 147 29.7 22.2 0 44.4-2 66.2-5.9 33.5 18.9 71.3 29 110 29 59.7 0 115.9-23.2 158.1-65.5 42.3-42.2 65.5-98.4 65.5-158.1.1-38-9.7-75.5-28.2-108.7zm-88.1 216C766.9 823.4 729 839 688.4 839c-26.1 0-51.8-6.8-74.6-19.7l-22.5-12.7-25.5 4.5c-17.8 3.2-35.8 4.8-53.6 4.8-41.4 0-81.3-8.1-119.1-24.1-36.3-15.3-69-37.3-97.2-65.5a304.29 304.29 0 0 1-65.5-97.1c-16-37.7-24-77.6-24-119 0-17.4 1.6-35.2 4.6-52.8l4.4-25.1L203 410a151.02 151.02 0 0 1-19.1-73.4c0-40.6 15.7-78.5 44.4-107.2C257.1 200.7 295 185 335.6 185a153 153 0 0 1 71.4 17.9l22.4 11.8 24.8-4.8c18.9-3.6 38.4-5.5 58-5.5 41.4 0 81.3 8.1 119 24 36.5 15.4 69.1 37.4 97.2 65.5 28.2 28.1 50.2 60.8 65.6 97.2 16 37.7 24 77.6 24 119 0 18.4-1.7 37-5.1 55.5l-4.7 25.5 12.6 22.6c12.6 22.5 19.2 48 19.2 73.7 0 40.7-15.7 78.5-44.4 107.2zM583.4 466.2L495 446.6c-33.6-7.7-72.3-17.8-72.3-49.5s27.1-53.9 76.1-53.9c98.7 0 89.7 67.8 138.7 67.8 25.8 0 48.4-15.2 48.4-41.2 0-60.8-97.4-106.5-180-106.5-89.7 0-185.2 38.1-185.2 139.5 0 48.8 17.4 100.8 113.6 124.9l119.4 29.8c36.1 8.9 45.2 29.2 45.2 47.6 0 30.5-30.3 60.3-85.2 60.3-107.2 0-92.3-82.5-149.7-82.5-25.8 0-44.5 17.8-44.5 43.1 0 49.4 60 115.4 194.2 115.4 127.7 0 191-61.5 191-144 0-53.1-24.5-109.6-121.3-131.2z\"}}]})(props);\n};\nexport function AiOutlineSlackSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM529 311.4c0-27.8 22.5-50.4 50.3-50.4 27.8 0 50.3 22.6 50.3 50.4v134.4c0 27.8-22.5 50.4-50.3 50.4-27.8 0-50.3-22.6-50.3-50.4V311.4zM361.5 580.2c0 27.8-22.5 50.4-50.3 50.4-13.3 0-26.1-5.3-35.6-14.8-9.4-9.5-14.7-22.3-14.7-35.6 0-27.8 22.5-50.4 50.3-50.4h50.3v50.4zm134 134.4c0 27.8-22.5 50.4-50.3 50.4-27.8 0-50.3-22.6-50.3-50.4V580.2c0-27.8 22.5-50.4 50.3-50.4 13.3 0 26.1 5.3 35.6 14.8s14.7 22.3 14.7 35.6v134.4zm-50.2-218.4h-134c-27.8 0-50.3-22.6-50.3-50.4 0-27.8 22.5-50.4 50.3-50.4h134c27.8 0 50.3 22.6 50.3 50.4-.1 27.9-22.6 50.4-50.3 50.4zm0-134.4c-13.3 0-26.1-5.3-35.6-14.8S395 324.8 395 311.4c0-27.8 22.5-50.4 50.3-50.4 27.8 0 50.3 22.6 50.3 50.4v50.4h-50.3zm134 403.2c-27.8 0-50.3-22.6-50.3-50.4v-50.4h50.3c27.8 0 50.3 22.6 50.3 50.4 0 27.8-22.5 50.4-50.3 50.4zm134-134.4h-134c-13.3 0-26.1-5.3-35.6-14.8-9.4-9.5-14.7-22.3-14.7-35.6 0-27.8 22.5-50.4 50.3-50.4h134c27.8 0 50.3 22.6 50.3 50.4 0 27.8-22.5 50.4-50.3 50.4zm0-134.4H663v-50.4c0-27.8 22.5-50.4 50.3-50.4s50.3 22.6 50.3 50.4c0 27.8-22.5 50.4-50.3 50.4z\"}}]})(props);\n};\nexport function AiOutlineSlack (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M409.4 128c-42.4 0-76.7 34.4-76.7 76.8 0 20.3 8.1 39.9 22.4 54.3 14.4 14.4 33.9 22.5 54.3 22.5h76.7v-76.8c0-42.3-34.3-76.7-76.7-76.8zm0 204.8H204.7c-42.4 0-76.7 34.4-76.7 76.8s34.4 76.8 76.7 76.8h204.6c42.4 0 76.7-34.4 76.7-76.8.1-42.4-34.3-76.8-76.6-76.8zM614 486.4c42.4 0 76.8-34.4 76.7-76.8V204.8c0-42.4-34.3-76.8-76.7-76.8-42.4 0-76.7 34.4-76.7 76.8v204.8c0 42.5 34.3 76.8 76.7 76.8zm281.4-76.8c0-42.4-34.4-76.8-76.7-76.8S742 367.2 742 409.6v76.8h76.7c42.3 0 76.7-34.4 76.7-76.8zm-76.8 128H614c-42.4 0-76.7 34.4-76.7 76.8 0 20.3 8.1 39.9 22.4 54.3 14.4 14.4 33.9 22.5 54.3 22.5h204.6c42.4 0 76.7-34.4 76.7-76.8.1-42.4-34.3-76.7-76.7-76.8zM614 742.4h-76.7v76.8c0 42.4 34.4 76.8 76.7 76.8 42.4 0 76.8-34.4 76.7-76.8.1-42.4-34.3-76.7-76.7-76.8zM409.4 537.6c-42.4 0-76.7 34.4-76.7 76.8v204.8c0 42.4 34.4 76.8 76.7 76.8 42.4 0 76.8-34.4 76.7-76.8V614.4c0-20.3-8.1-39.9-22.4-54.3-14.4-14.4-34-22.5-54.3-22.5zM128 614.4c0 20.3 8.1 39.9 22.4 54.3 14.4 14.4 33.9 22.5 54.3 22.5 42.4 0 76.8-34.4 76.7-76.8v-76.8h-76.7c-42.3 0-76.7 34.4-76.7 76.8z\"}}]})(props);\n};\nexport function AiOutlineSliders (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M320 224h-66v-56c0-4.4-3.6-8-8-8h-52c-4.4 0-8 3.6-8 8v56h-66c-4.4 0-8 3.6-8 8v560c0 4.4 3.6 8 8 8h66v56c0 4.4 3.6 8 8 8h52c4.4 0 8-3.6 8-8v-56h66c4.4 0 8-3.6 8-8V232c0-4.4-3.6-8-8-8zm-60 508h-80V292h80v440zm644-436h-66v-96c0-4.4-3.6-8-8-8h-52c-4.4 0-8 3.6-8 8v96h-66c-4.4 0-8 3.6-8 8v416c0 4.4 3.6 8 8 8h66v96c0 4.4 3.6 8 8 8h52c4.4 0 8-3.6 8-8v-96h66c4.4 0 8-3.6 8-8V304c0-4.4-3.6-8-8-8zm-60 364h-80V364h80v296zM612 404h-66V232c0-4.4-3.6-8-8-8h-52c-4.4 0-8 3.6-8 8v172h-66c-4.4 0-8 3.6-8 8v200c0 4.4 3.6 8 8 8h66v172c0 4.4 3.6 8 8 8h52c4.4 0 8-3.6 8-8V620h66c4.4 0 8-3.6 8-8V412c0-4.4-3.6-8-8-8zm-60 145a3 3 0 0 1-3 3h-74a3 3 0 0 1-3-3v-74a3 3 0 0 1 3-3h74a3 3 0 0 1 3 3v74z\"}}]})(props);\n};\nexport function AiOutlineSmallDash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M112 476h72v72h-72zm182 0h72v72h-72zm364 0h72v72h-72zm182 0h72v72h-72zm-364 0h72v72h-72z\"}}]})(props);\n};\nexport function AiOutlineSmile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M288 421a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm352 0a48 48 0 1 0 96 0 48 48 0 1 0-96 0zM512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm263 711c-34.2 34.2-74 61-118.3 79.8C611 874.2 562.3 884 512 884c-50.3 0-99-9.8-144.8-29.2A370.4 370.4 0 0 1 248.9 775c-34.2-34.2-61-74-79.8-118.3C149.8 611 140 562.3 140 512s9.8-99 29.2-144.8A370.4 370.4 0 0 1 249 248.9c34.2-34.2 74-61 118.3-79.8C413 149.8 461.7 140 512 140c50.3 0 99 9.8 144.8 29.2A370.4 370.4 0 0 1 775.1 249c34.2 34.2 61 74 79.8 118.3C874.2 413 884 461.7 884 512s-9.8 99-29.2 144.8A368.89 368.89 0 0 1 775 775zM664 533h-48.1c-4.2 0-7.8 3.2-8.1 7.4C604 589.9 562.5 629 512 629s-92.1-39.1-95.8-88.6c-.3-4.2-3.9-7.4-8.1-7.4H360a8 8 0 0 0-8 8.4c4.4 84.3 74.5 151.6 160 151.6s155.6-67.3 160-151.6a8 8 0 0 0-8-8.4z\"}}]})(props);\n};\nexport function AiOutlineSnippets (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 112H724V72c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v40H500V72c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v40H320c-17.7 0-32 14.3-32 32v120h-96c-17.7 0-32 14.3-32 32v632c0 17.7 14.3 32 32 32h512c17.7 0 32-14.3 32-32v-96h96c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM664 888H232V336h218v174c0 22.1 17.9 40 40 40h174v338zm0-402H514V336h.2L664 485.8v.2zm128 274h-56V456L544 264H360v-80h68v32c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-32h152v32c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-32h68v576z\"}}]})(props);\n};\nexport function AiOutlineSolution (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M688 264c0-4.4-3.6-8-8-8H296c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h384c4.4 0 8-3.6 8-8v-48zm-8 136H296c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h384c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zM480 544H296c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zm-48 308H208V148h560v344c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V108c0-17.7-14.3-32-32-32H168c-17.7 0-32 14.3-32 32v784c0 17.7 14.3 32 32 32h264c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm356.8-74.4c29-26.3 47.2-64.3 47.2-106.6 0-79.5-64.5-144-144-144s-144 64.5-144 144c0 42.3 18.2 80.3 47.2 106.6-57 32.5-96.2 92.7-99.2 162.1-.2 4.5 3.5 8.3 8 8.3h48.1c4.2 0 7.7-3.3 8-7.6C564 871.2 621.7 816 692 816s128 55.2 131.9 124.4c.2 4.2 3.7 7.6 8 7.6H880c4.6 0 8.2-3.8 8-8.3-2.9-69.5-42.2-129.6-99.2-162.1zM692 591c44.2 0 80 35.8 80 80s-35.8 80-80 80-80-35.8-80-80 35.8-80 80-80z\"}}]})(props);\n};\nexport function AiOutlineSortAscending (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M839.6 433.8L749 150.5a9.24 9.24 0 0 0-8.9-6.5h-77.4c-4.1 0-7.6 2.6-8.9 6.5l-91.3 283.3c-.3.9-.5 1.9-.5 2.9 0 5.1 4.2 9.3 9.3 9.3h56.4c4.2 0 7.8-2.8 9-6.8l17.5-61.6h89l17.3 61.5c1.1 4 4.8 6.8 9 6.8h61.2c1 0 1.9-.1 2.8-.4 2.4-.8 4.3-2.4 5.5-4.6 1.1-2.2 1.3-4.7.6-7.1zM663.3 325.5l32.8-116.9h6.3l32.1 116.9h-71.2zm143.5 492.9H677.2v-.4l132.6-188.9c1.1-1.6 1.7-3.4 1.7-5.4v-36.4c0-5.1-4.2-9.3-9.3-9.3h-204c-5.1 0-9.3 4.2-9.3 9.3v43c0 5.1 4.2 9.3 9.3 9.3h122.6v.4L587.7 828.9a9.35 9.35 0 0 0-1.7 5.4v36.4c0 5.1 4.2 9.3 9.3 9.3h211.4c5.1 0 9.3-4.2 9.3-9.3v-43a9.2 9.2 0 0 0-9.2-9.3zM416 702h-76V172c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v530h-76c-6.7 0-10.5 7.8-6.3 13l112 141.9a8 8 0 0 0 12.6 0l112-141.9c4.1-5.2.4-13-6.3-13z\"}}]})(props);\n};\nexport function AiOutlineSortDescending (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M839.6 433.8L749 150.5a9.24 9.24 0 0 0-8.9-6.5h-77.4c-4.1 0-7.6 2.6-8.9 6.5l-91.3 283.3c-.3.9-.5 1.9-.5 2.9 0 5.1 4.2 9.3 9.3 9.3h56.4c4.2 0 7.8-2.8 9-6.8l17.5-61.6h89l17.3 61.5c1.1 4 4.8 6.8 9 6.8h61.2c1 0 1.9-.1 2.8-.4 2.4-.8 4.3-2.4 5.5-4.6 1.1-2.2 1.3-4.7.6-7.1zM663.3 325.5l32.8-116.9h6.3l32.1 116.9h-71.2zm143.5 492.9H677.2v-.4l132.6-188.9c1.1-1.6 1.7-3.4 1.7-5.4v-36.4c0-5.1-4.2-9.3-9.3-9.3h-204c-5.1 0-9.3 4.2-9.3 9.3v43c0 5.1 4.2 9.3 9.3 9.3h122.6v.4L587.7 828.9a9.35 9.35 0 0 0-1.7 5.4v36.4c0 5.1 4.2 9.3 9.3 9.3h211.4c5.1 0 9.3-4.2 9.3-9.3v-43a9.2 9.2 0 0 0-9.2-9.3zM310.3 167.1a8 8 0 0 0-12.6 0L185.7 309c-4.2 5.3-.4 13 6.3 13h76v530c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V322h76c6.7 0 10.5-7.8 6.3-13l-112-141.9z\"}}]})(props);\n};\nexport function AiOutlineSound (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M625.9 115c-5.9 0-11.9 1.6-17.4 5.3L254 352H90c-8.8 0-16 7.2-16 16v288c0 8.8 7.2 16 16 16h164l354.5 231.7c5.5 3.6 11.6 5.3 17.4 5.3 16.7 0 32.1-13.3 32.1-32.1V147.1c0-18.8-15.4-32.1-32.1-32.1zM586 803L293.4 611.7l-18-11.7H146V424h129.4l17.9-11.7L586 221v582zm348-327H806c-8.8 0-16 7.2-16 16v40c0 8.8 7.2 16 16 16h128c8.8 0 16-7.2 16-16v-40c0-8.8-7.2-16-16-16zm-41.9 261.8l-110.3-63.7a15.9 15.9 0 0 0-21.7 5.9l-19.9 34.5c-4.4 7.6-1.8 17.4 5.8 21.8L856.3 800a15.9 15.9 0 0 0 21.7-5.9l19.9-34.5c4.4-7.6 1.7-17.4-5.8-21.8zM760 344a15.9 15.9 0 0 0 21.7 5.9L892 286.2c7.6-4.4 10.2-14.2 5.8-21.8L878 230a15.9 15.9 0 0 0-21.7-5.9L746 287.8a15.99 15.99 0 0 0-5.8 21.8L760 344z\"}}]})(props);\n};\nexport function AiOutlineSplitCells (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683545621\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M938.2 508.4L787.3 389c-3-2.4-7.3-0.2-7.3 3.6V478H636V184h204v128c0 2.2 1.8 4 4 4h60c2.2 0 4-1.8 4-4V144c0-15.5-12.5-28-28-28H596c-15.5 0-28 12.5-28 28v736c0 15.5 12.5 28 28 28h284c15.5 0 28-12.5 28-28V712c0-2.2-1.8-4-4-4h-60c-2.2 0-4 1.8-4 4v128H636V546h144v85.4c0 3.8 4.4 6 7.3 3.6l150.9-119.4c2.4-1.8 2.4-5.4 0-7.2zM428 116H144c-15.5 0-28 12.5-28 28v168c0 2.2 1.8 4 4 4h60c2.2 0 4-1.8 4-4V184h204v294H244v-85.4c0-3.8-4.3-6-7.3-3.6l-151 119.4c-2.3 1.8-2.3 5.3 0 7.1l151 119.5c2.9 2.3 7.3 0.2 7.3-3.6V546h144v294H184V712c0-2.2-1.8-4-4-4h-60c-2.2 0-4 1.8-4 4v168c0 15.5 12.5 28 28 28h284c15.5 0 28-12.5 28-28V144c0-15.5-12.5-28-28-28z\"}}]})(props);\n};\nexport function AiOutlineStar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M908.1 353.1l-253.9-36.9L540.7 86.1c-3.1-6.3-8.2-11.4-14.5-14.5-15.8-7.8-35-1.3-42.9 14.5L369.8 316.2l-253.9 36.9c-7 1-13.4 4.3-18.3 9.3a32.05 32.05 0 0 0 .6 45.3l183.7 179.1-43.4 252.9a31.95 31.95 0 0 0 46.4 33.7L512 754l227.1 119.4c6.2 3.3 13.4 4.4 20.3 3.2 17.4-3 29.1-19.5 26.1-36.9l-43.4-252.9 183.7-179.1c5-4.9 8.3-11.3 9.3-18.3 2.7-17.5-9.5-33.7-27-36.3zM664.8 561.6l36.1 210.3L512 672.7 323.1 772l36.1-210.3-152.8-149L417.6 382 512 190.7 606.4 382l211.2 30.7-152.8 148.9z\"}}]})(props);\n};\nexport function AiOutlineStepBackward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M347.6 528.95l383.2 301.02c14.25 11.2 35.2 1.1 35.2-16.95V210.97c0-18.05-20.95-28.14-35.2-16.94L347.6 495.05a21.53 21.53 0 0 0 0 33.9M330 864h-64a8 8 0 0 1-8-8V168a8 8 0 0 1 8-8h64a8 8 0 0 1 8 8v688a8 8 0 0 1-8 8\"}}]})(props);\n};\nexport function AiOutlineStepForward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M676.4 528.95L293.2 829.97c-14.25 11.2-35.2 1.1-35.2-16.95V210.97c0-18.05 20.95-28.14 35.2-16.94l383.2 301.02a21.53 21.53 0 0 1 0 33.9M694 864h64a8 8 0 0 0 8-8V168a8 8 0 0 0-8-8h-64a8 8 0 0 0-8 8v688a8 8 0 0 0 8 8\"}}]})(props);\n};\nexport function AiOutlineStock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M904 747H120c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM165.7 621.8l39.7 39.5c3.1 3.1 8.2 3.1 11.3 0l234.7-233.9 97.6 97.3a32.11 32.11 0 0 0 45.2 0l264.2-263.2c3.1-3.1 3.1-8.2 0-11.3l-39.7-39.6a8.03 8.03 0 0 0-11.3 0l-235.7 235-97.7-97.3a32.11 32.11 0 0 0-45.2 0L165.7 610.5a7.94 7.94 0 0 0 0 11.3z\"}}]})(props);\n};\nexport function AiOutlineStop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372 0-89 31.3-170.8 83.5-234.8l523.3 523.3C682.8 852.7 601 884 512 884zm288.5-137.2L277.2 223.5C341.2 171.3 423 140 512 140c205.4 0 372 166.6 372 372 0 89-31.3 170.8-83.5 234.8z\"}}]})(props);\n};\nexport function AiOutlineStrikethrough (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M952 474H569.9c-10-2-20.5-4-31.6-6-15.9-2.9-22.2-4.1-30.8-5.8-51.3-10-82.2-20-106.8-34.2-35.1-20.5-52.2-48.3-52.2-85.1 0-37 15.2-67.7 44-89 28.4-21 68.8-32.1 116.8-32.1 54.8 0 97.1 14.4 125.8 42.8 14.6 14.4 25.3 32.1 31.8 52.6 1.3 4.1 2.8 10 4.3 17.8.9 4.8 5.2 8.2 9.9 8.2h72.8c5.6 0 10.1-4.6 10.1-10.1v-1c-.7-6.8-1.3-12.1-2-16-7.3-43.5-28-81.7-59.7-110.3-44.4-40.5-109.7-61.8-188.7-61.8-72.3 0-137.4 18.1-183.3 50.9-25.6 18.4-45.4 41.2-58.6 67.7-13.5 27.1-20.3 58.4-20.3 92.9 0 29.5 5.7 54.5 17.3 76.5 8.3 15.7 19.6 29.5 34.1 42H72c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h433.2c2.1.4 3.9.8 5.9 1.2 30.9 6.2 49.5 10.4 66.6 15.2 23 6.5 40.6 13.3 55.2 21.5 35.8 20.2 53.3 49.2 53.3 89 0 35.3-15.5 66.8-43.6 88.8-30.5 23.9-75.6 36.4-130.5 36.4-43.7 0-80.7-8.5-110.2-25-29.1-16.3-49.1-39.8-59.7-69.5-.8-2.2-1.7-5.2-2.7-9-1.2-4.4-5.3-7.5-9.7-7.5h-79.7c-5.6 0-10.1 4.6-10.1 10.1v1c.2 2.3.4 4.2.6 5.7 6.5 48.8 30.3 88.8 70.7 118.8 47.1 34.8 113.4 53.2 191.8 53.2 84.2 0 154.8-19.8 204.2-57.3 25-18.9 44.2-42.2 57.1-69 13-27.1 19.7-57.9 19.7-91.5 0-31.8-5.8-58.4-17.8-81.4-5.8-11.2-13.1-21.5-21.8-30.8H952c4.4 0 8-3.6 8-8v-60a8 8 0 0 0-8-7.9z\"}}]})(props);\n};\nexport function AiOutlineSubnode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683432252\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M688 240c-138 0-252 102.8-269.6 236H249c-14.2-35.2-48.7-60-89-60-53 0-96 43-96 96s43 96 96 96c40.3 0 74.8-24.8 89-60h169.3C436 681.2 550 784 688 784c150.2 0 272-121.8 272-272S838.2 240 688 240z m128 298c0 4.4-3.6 8-8 8h-86v86c0 4.4-3.6 8-8 8h-52c-4.4 0-8-3.6-8-8v-86h-86c-4.4 0-8-3.6-8-8v-52c0-4.4 3.6-8 8-8h86v-86c0-4.4 3.6-8 8-8h52c4.4 0 8 3.6 8 8v86h86c4.4 0 8 3.6 8 8v52z\"}}]})(props);\n};\nexport function AiOutlineSwapLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M872 572H266.8l144.3-183c4.1-5.2.4-13-6.3-13H340c-9.8 0-19.1 4.5-25.1 12.2l-164 208c-16.5 21-1.6 51.8 25.1 51.8h696c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineSwapRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M873.1 596.2l-164-208A32 32 0 0 0 684 376h-64.8c-6.7 0-10.4 7.7-6.3 13l144.3 183H152c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h695.9c26.8 0 41.7-30.8 25.2-51.8z\"}}]})(props);\n};\nexport function AiOutlineSwap (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M847.9 592H152c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h605.2L612.9 851c-4.1 5.2-.4 13 6.3 13h72.5c4.9 0 9.5-2.2 12.6-6.1l168.8-214.1c16.5-21 1.6-51.8-25.2-51.8zM872 356H266.8l144.3-183c4.1-5.2.4-13-6.3-13h-72.5c-4.9 0-9.5 2.2-12.6 6.1L150.9 380.2c-16.5 21-1.6 51.8 25.1 51.8h696c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineSwitcher (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M752 240H144c-17.7 0-32 14.3-32 32v608c0 17.7 14.3 32 32 32h608c17.7 0 32-14.3 32-32V272c0-17.7-14.3-32-32-32zm-40 600H184V312h528v528zm168-728H264c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h576v576c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V144c0-17.7-14.3-32-32-32zM300 550h296v64H300z\"}}]})(props);\n};\nexport function AiOutlineSync (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M168 504.2c1-43.7 10-86.1 26.9-126 17.3-41 42.1-77.7 73.7-109.4S337 212.3 378 195c42.4-17.9 87.4-27 133.9-27s91.5 9.1 133.8 27A341.5 341.5 0 0 1 755 268.8c9.9 9.9 19.2 20.4 27.8 31.4l-60.2 47a8 8 0 0 0 3 14.1l175.7 43c5 1.2 9.9-2.6 9.9-7.7l.8-180.9c0-6.7-7.7-10.5-12.9-6.3l-56.4 44.1C765.8 155.1 646.2 92 511.8 92 282.7 92 96.3 275.6 92 503.8a8 8 0 0 0 8 8.2h60c4.4 0 7.9-3.5 8-7.8zm756 7.8h-60c-4.4 0-7.9 3.5-8 7.8-1 43.7-10 86.1-26.9 126-17.3 41-42.1 77.8-73.7 109.4A342.45 342.45 0 0 1 512.1 856a342.24 342.24 0 0 1-243.2-100.8c-9.9-9.9-19.2-20.4-27.8-31.4l60.2-47a8 8 0 0 0-3-14.1l-175.7-43c-5-1.2-9.9 2.6-9.9 7.7l-.7 181c0 6.7 7.7 10.5 12.9 6.3l56.4-44.1C258.2 868.9 377.8 932 512.2 932c229.2 0 415.5-183.7 419.8-411.8a8 8 0 0 0-8-8.2z\"}}]})(props);\n};\nexport function AiOutlineTable (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 160H96c-17.7 0-32 14.3-32 32v640c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V192c0-17.7-14.3-32-32-32zm-40 208H676V232h212v136zm0 224H676V432h212v160zM412 432h200v160H412V432zm200-64H412V232h200v136zm-476 64h212v160H136V432zm0-200h212v136H136V232zm0 424h212v136H136V656zm276 0h200v136H412V656zm476 136H676V656h212v136z\"}}]})(props);\n};\nexport function AiOutlineTablet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M800 64H224c-35.3 0-64 28.7-64 64v768c0 35.3 28.7 64 64 64h576c35.3 0 64-28.7 64-64V128c0-35.3-28.7-64-64-64zm-8 824H232V136h560v752zM472 784a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}}]})(props);\n};\nexport function AiOutlineTag (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M938 458.8l-29.6-312.6c-1.5-16.2-14.4-29-30.6-30.6L565.2 86h-.4c-3.2 0-5.7 1-7.6 2.9L88.9 557.2a9.96 9.96 0 0 0 0 14.1l363.8 363.8c1.9 1.9 4.4 2.9 7.1 2.9s5.2-1 7.1-2.9l468.3-468.3c2-2.1 3-5 2.8-8zM459.7 834.7L189.3 564.3 589 164.6 836 188l23.4 247-399.7 399.7zM680 256c-48.5 0-88 39.5-88 88s39.5 88 88 88 88-39.5 88-88-39.5-88-88-88zm0 120c-17.7 0-32-14.3-32-32s14.3-32 32-32 32 14.3 32 32-14.3 32-32 32z\"}}]})(props);\n};\nexport function AiOutlineTags (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M483.2 790.3L861.4 412c1.7-1.7 2.5-4 2.3-6.3l-25.5-301.4c-.7-7.8-6.8-13.9-14.6-14.6L522.2 64.3c-2.3-.2-4.7.6-6.3 2.3L137.7 444.8a8.03 8.03 0 0 0 0 11.3l334.2 334.2c3.1 3.2 8.2 3.2 11.3 0zm62.6-651.7l224.6 19 19 224.6L477.5 694 233.9 450.5l311.9-311.9zm60.16 186.23a48 48 0 1 0 67.88-67.89 48 48 0 1 0-67.88 67.89zM889.7 539.8l-39.6-39.5a8.03 8.03 0 0 0-11.3 0l-362 361.3-237.6-237a8.03 8.03 0 0 0-11.3 0l-39.6 39.5a8.03 8.03 0 0 0 0 11.3l243.2 242.8 39.6 39.5c3.1 3.1 8.2 3.1 11.3 0l407.3-406.6c3.1-3.1 3.1-8.2 0-11.3z\"}}]})(props);\n};\nexport function AiOutlineTaobaoCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zM315.7 291.5c27.3 0 49.5 22.1 49.5 49.4s-22.1 49.4-49.5 49.4a49.4 49.4 0 1 1 0-98.8zM366.9 578c-13.6 42.3-10.2 26.7-64.4 144.5l-78.5-49s87.7-79.8 105.6-116.2c19.2-38.4-21.1-58.9-21.1-58.9l-60.2-37.5 32.7-50.2c45.4 33.7 48.7 36.6 79.2 67.2 23.8 23.9 20.7 56.8 6.7 100.1zm427.2 55c-15.3 143.8-202.4 90.3-202.4 90.3l10.2-41.1 43.3 9.3c80 5 72.3-64.9 72.3-64.9V423c.6-77.3-72.6-85.4-204.2-38.3l30.6 8.3c-2.5 9-12.5 23.2-25.2 38.6h176v35.6h-99.1v44.5h98.7v35.7h-98.7V622c14.9-4.8 28.6-11.5 40.5-20.5l-8.7-32.5 46.5-14.4 38.8 94.9-57.3 23.9-10.2-37.8c-25.6 19.5-78.8 48-171.8 45.4-99.2 2.6-73.7-112-73.7-112l2.5-1.3H472c-.5 14.7-6.6 38.7 1.7 51.8 6.8 10.8 24.2 12.6 35.3 13.1 1.3.1 2.6.1 3.9.1v-85.3h-101v-35.7h101v-44.5H487c-22.7 24.1-43.5 44.1-43.5 44.1l-30.6-26.7c21.7-22.9 43.3-59.1 56.8-83.2-10.9 4.4-22 9.2-33.6 14.2-11.2 14.3-24.2 29-38.7 43.5.5.8-50-28.4-50-28.4 52.2-44.4 81.4-139.9 81.4-139.9l72.5 20.4s-5.9 14-18.4 35.6c290.3-82.3 307.4 50.5 307.4 50.5s19.1 91.8 3.8 235.7z\"}}]})(props);\n};\nexport function AiOutlineTaobao (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M168.5 273.7a68.7 68.7 0 1 0 137.4 0 68.7 68.7 0 1 0-137.4 0zm730 79.2s-23.7-184.4-426.9-70.1c17.3-30 25.6-49.5 25.6-49.5L396.4 205s-40.6 132.6-113 194.4c0 0 70.1 40.6 69.4 39.4 20.1-20.1 38.2-40.6 53.7-60.4 16.1-7 31.5-13.6 46.7-19.8-18.6 33.5-48.7 83.8-78.8 115.6l42.4 37s28.8-27.7 60.4-61.2h36v61.8H372.9v49.5h140.3v118.5c-1.7 0-3.6 0-5.4-.2-15.4-.7-39.5-3.3-49-18.2-11.5-18.1-3-51.5-2.4-71.9h-97l-3.4 1.8s-35.5 159.1 102.3 155.5c129.1 3.6 203-36 238.6-63.1l14.2 52.6 79.6-33.2-53.9-131.9-64.6 20.1 12.1 45.2c-16.6 12.4-35.6 21.7-56.2 28.4V561.3h137.1v-49.5H628.1V450h137.6v-49.5H521.3c17.6-21.4 31.5-41.1 35-53.6l-42.5-11.6c182.8-65.5 284.5-54.2 283.6 53.2v282.8s10.8 97.1-100.4 90.1l-60.2-12.9-14.2 57.1S882.5 880 903.7 680.2c21.3-200-5.2-327.3-5.2-327.3zm-707.4 18.3l-45.4 69.7 83.6 52.1s56 28.5 29.4 81.9C233.8 625.5 112 736.3 112 736.3l109 68.1c75.4-163.7 70.5-142 89.5-200.7 19.5-60.1 23.7-105.9-9.4-139.1-42.4-42.6-47-46.6-110-93.4z\"}}]})(props);\n};\nexport function AiOutlineTeam (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M824.2 699.9a301.55 301.55 0 0 0-86.4-60.4C783.1 602.8 812 546.8 812 484c0-110.8-92.4-201.7-203.2-200-109.1 1.7-197 90.6-197 200 0 62.8 29 118.8 74.2 155.5a300.95 300.95 0 0 0-86.4 60.4C345 754.6 314 826.8 312 903.8a8 8 0 0 0 8 8.2h56c4.3 0 7.9-3.4 8-7.7 1.9-58 25.4-112.3 66.7-153.5A226.62 226.62 0 0 1 612 684c60.9 0 118.2 23.7 161.3 66.8C814.5 792 838 846.3 840 904.3c.1 4.3 3.7 7.7 8 7.7h56a8 8 0 0 0 8-8.2c-2-77-33-149.2-87.8-203.9zM612 612c-34.2 0-66.4-13.3-90.5-37.5a126.86 126.86 0 0 1-37.5-91.8c.3-32.8 13.4-64.5 36.3-88 24-24.6 56.1-38.3 90.4-38.7 33.9-.3 66.8 12.9 91 36.6 24.8 24.3 38.4 56.8 38.4 91.4 0 34.2-13.3 66.3-37.5 90.5A127.3 127.3 0 0 1 612 612zM361.5 510.4c-.9-8.7-1.4-17.5-1.4-26.4 0-15.9 1.5-31.4 4.3-46.5.7-3.6-1.2-7.3-4.5-8.8-13.6-6.1-26.1-14.5-36.9-25.1a127.54 127.54 0 0 1-38.7-95.4c.9-32.1 13.8-62.6 36.3-85.6 24.7-25.3 57.9-39.1 93.2-38.7 31.9.3 62.7 12.6 86 34.4 7.9 7.4 14.7 15.6 20.4 24.4 2 3.1 5.9 4.4 9.3 3.2 17.6-6.1 36.2-10.4 55.3-12.4 5.6-.6 8.8-6.6 6.3-11.6-32.5-64.3-98.9-108.7-175.7-109.9-110.9-1.7-203.3 89.2-203.3 199.9 0 62.8 28.9 118.8 74.2 155.5-31.8 14.7-61.1 35-86.5 60.4-54.8 54.7-85.8 126.9-87.8 204a8 8 0 0 0 8 8.2h56.1c4.3 0 7.9-3.4 8-7.7 1.9-58 25.4-112.3 66.7-153.5 29.4-29.4 65.4-49.8 104.7-59.7 3.9-1 6.5-4.7 6-8.7z\"}}]})(props);\n};\nexport function AiOutlineThunderbolt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M848 359.3H627.7L825.8 109c4.1-5.3.4-13-6.3-13H436c-2.8 0-5.5 1.5-6.9 4L170 547.5c-3.1 5.3.7 12 6.9 12h174.4l-89.4 357.6c-1.9 7.8 7.5 13.3 13.3 7.7L853.5 373c5.2-4.9 1.7-13.7-5.5-13.7zM378.2 732.5l60.3-241H281.1l189.6-327.4h224.6L487 427.4h211L378.2 732.5z\"}}]})(props);\n};\nexport function AiOutlineToTop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M885 780H165c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h720c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8zM400 325.7h73.9V664c0 4.4 3.6 8 8 8h60c4.4 0 8-3.6 8-8V325.7H624c6.7 0 10.4-7.7 6.3-12.9L518.3 171a8 8 0 0 0-12.6 0l-112 141.7c-4.1 5.3-.4 13 6.3 13z\"}}]})(props);\n};\nexport function AiOutlineTool (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M876.6 239.5c-.5-.9-1.2-1.8-2-2.5-5-5-13.1-5-18.1 0L684.2 409.3l-67.9-67.9L788.7 169c.8-.8 1.4-1.6 2-2.5 3.6-6.1 1.6-13.9-4.5-17.5-98.2-58-226.8-44.7-311.3 39.7-67 67-89.2 162-66.5 247.4l-293 293c-3 3-2.8 7.9.3 11l169.7 169.7c3.1 3.1 8.1 3.3 11 .3l292.9-292.9c85.5 22.8 180.5.7 247.6-66.4 84.4-84.5 97.7-213.1 39.7-311.3zM786 499.8c-58.1 58.1-145.3 69.3-214.6 33.6l-8.8 8.8-.1-.1-274 274.1-79.2-79.2 230.1-230.1s0 .1.1.1l52.8-52.8c-35.7-69.3-24.5-156.5 33.6-214.6a184.2 184.2 0 0 1 144-53.5L537 318.9a32.05 32.05 0 0 0 0 45.3l124.5 124.5a32.05 32.05 0 0 0 45.3 0l132.8-132.8c3.7 51.8-14.4 104.8-53.6 143.9z\"}}]})(props);\n};\nexport function AiOutlineTrademarkCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372zm87.5-334.7c34.8-12.8 78.4-49 78.4-119.2 0-71.2-45.5-131.1-144.2-131.1H378c-4.4 0-8 3.6-8 8v410c0 4.4 3.6 8 8 8h54.5c4.4 0 8-3.6 8-8V561.2h88.7l74.6 159.2c1.3 2.8 4.1 4.6 7.2 4.6h62a7.9 7.9 0 0 0 7.1-11.5l-80.6-164.2zM522 505h-81.5V357h83.4c48 0 80.9 25.3 80.9 75.5 0 46.9-29.8 72.5-82.8 72.5z\"}}]})(props);\n};\nexport function AiOutlineTrademark (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372zm87.5-334.7c34.8-12.8 78.4-49 78.4-119.2 0-71.2-45.5-131.1-144.2-131.1H378c-4.4 0-8 3.6-8 8v410c0 4.4 3.6 8 8 8h54.5c4.4 0 8-3.6 8-8V561.2h88.7l74.6 159.2c1.3 2.8 4.1 4.6 7.2 4.6h62a7.9 7.9 0 0 0 7.1-11.5l-80.6-164.2zM522 505h-81.5V357h83.4c48 0 80.9 25.3 80.9 75.5 0 46.9-29.8 72.5-82.8 72.5z\"}}]})(props);\n};\nexport function AiOutlineTransaction (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M668.6 320c0-4.4-3.6-8-8-8h-54.5c-3 0-5.8 1.7-7.1 4.4l-84.7 168.8H511l-84.7-168.8a8 8 0 0 0-7.1-4.4h-55.7c-1.3 0-2.6.3-3.8 1-3.9 2.1-5.3 7-3.2 10.8l103.9 191.6h-57c-4.4 0-8 3.6-8 8v27.1c0 4.4 3.6 8 8 8h76v39h-76c-4.4 0-8 3.6-8 8v27.1c0 4.4 3.6 8 8 8h76V704c0 4.4 3.6 8 8 8h49.9c4.4 0 8-3.6 8-8v-63.5h76.3c4.4 0 8-3.6 8-8v-27.1c0-4.4-3.6-8-8-8h-76.3v-39h76.3c4.4 0 8-3.6 8-8v-27.1c0-4.4-3.6-8-8-8H564l103.7-191.6c.5-1.1.9-2.4.9-3.7zM157.9 504.2a352.7 352.7 0 0 1 103.5-242.4c32.5-32.5 70.3-58.1 112.4-75.9 43.6-18.4 89.9-27.8 137.6-27.8 47.8 0 94.1 9.3 137.6 27.8 42.1 17.8 79.9 43.4 112.4 75.9 10 10 19.3 20.5 27.9 31.4l-50 39.1a8 8 0 0 0 3 14.1l156.8 38.3c5 1.2 9.9-2.6 9.9-7.7l.8-161.5c0-6.7-7.7-10.5-12.9-6.3l-47.8 37.4C770.7 146.3 648.6 82 511.5 82 277 82 86.3 270.1 82 503.8a8 8 0 0 0 8 8.2h60c4.3 0 7.8-3.5 7.9-7.8zM934 512h-60c-4.3 0-7.9 3.5-8 7.8a352.7 352.7 0 0 1-103.5 242.4 352.57 352.57 0 0 1-112.4 75.9c-43.6 18.4-89.9 27.8-137.6 27.8s-94.1-9.3-137.6-27.8a352.57 352.57 0 0 1-112.4-75.9c-10-10-19.3-20.5-27.9-31.4l49.9-39.1a8 8 0 0 0-3-14.1l-156.8-38.3c-5-1.2-9.9 2.6-9.9 7.7l-.8 161.7c0 6.7 7.7 10.5 12.9 6.3l47.8-37.4C253.3 877.7 375.4 942 512.5 942 747 942 937.7 753.9 942 520.2a8 8 0 0 0-8-8.2z\"}}]})(props);\n};\nexport function AiOutlineTranslation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683569194\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M140 188h584v164h76V144c0-17.7-14.3-32-32-32H96c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h544v-76H140V188z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M414.3 256h-60.6c-3.4 0-6.4 2.2-7.6 5.4L219 629.4c-0.3 0.8-0.4 1.7-0.4 2.6 0 4.4 3.6 8 8 8h55.1c3.4 0 6.4-2.2 7.6-5.4L322 540h196.2L422 261.4c-1.3-3.2-4.3-5.4-7.7-5.4z m12.4 228h-85.5L384 360.2 426.7 484zM936 528H800v-93c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v93H592c-13.3 0-24 10.7-24 24v176c0 13.3 10.7 24 24 24h136v152c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V752h136c13.3 0 24-10.7 24-24V552c0-13.3-10.7-24-24-24zM728 680h-88v-80h88v80z m160 0h-88v-80h88v80z\"}}]})(props);\n};\nexport function AiOutlineTrophy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M868 160h-92v-40c0-4.4-3.6-8-8-8H256c-4.4 0-8 3.6-8 8v40h-92a44 44 0 0 0-44 44v148c0 81.7 60 149.6 138.2 162C265.7 630.2 359 721.7 476 734.5v105.2H280c-17.7 0-32 14.3-32 32V904c0 4.4 3.6 8 8 8h512c4.4 0 8-3.6 8-8v-32.3c0-17.7-14.3-32-32-32H548V734.5C665 721.7 758.3 630.2 773.8 514 852 501.6 912 433.7 912 352V204a44 44 0 0 0-44-44zM184 352V232h64v207.6a91.99 91.99 0 0 1-64-87.6zm520 128c0 49.1-19.1 95.4-53.9 130.1-34.8 34.8-81 53.9-130.1 53.9h-16c-49.1 0-95.4-19.1-130.1-53.9-34.8-34.8-53.9-81-53.9-130.1V184h384v296zm136-128c0 41-26.9 75.8-64 87.6V232h64v120z\"}}]})(props);\n};\nexport function AiOutlineTwitter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 254.3c-30.6 13.2-63.9 22.7-98.2 26.4a170.1 170.1 0 0 0 75-94 336.64 336.64 0 0 1-108.2 41.2A170.1 170.1 0 0 0 672 174c-94.5 0-170.5 76.6-170.5 170.6 0 13.2 1.6 26.4 4.2 39.1-141.5-7.4-267.7-75-351.6-178.5a169.32 169.32 0 0 0-23.2 86.1c0 59.2 30.1 111.4 76 142.1a172 172 0 0 1-77.1-21.7v2.1c0 82.9 58.6 151.6 136.7 167.4a180.6 180.6 0 0 1-44.9 5.8c-11.1 0-21.6-1.1-32.2-2.6C211 652 273.9 701.1 348.8 702.7c-58.6 45.9-132 72.9-211.7 72.9-14.3 0-27.5-.5-41.2-2.1C171.5 822 261.2 850 357.8 850 671.4 850 843 590.2 843 364.7c0-7.4 0-14.8-.5-22.2 33.2-24.3 62.3-54.4 85.5-88.2z\"}}]})(props);\n};\nexport function AiOutlineUnderline (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M824 804H200c-4.4 0-8 3.4-8 7.6v60.8c0 4.2 3.6 7.6 8 7.6h624c4.4 0 8-3.4 8-7.6v-60.8c0-4.2-3.6-7.6-8-7.6zm-312-76c69.4 0 134.6-27.1 183.8-76.2C745 602.7 772 537.4 772 468V156c0-6.6-5.4-12-12-12h-60c-6.6 0-12 5.4-12 12v312c0 97-79 176-176 176s-176-79-176-176V156c0-6.6-5.4-12-12-12h-60c-6.6 0-12 5.4-12 12v312c0 69.4 27.1 134.6 76.2 183.8C377.3 701 442.6 728 512 728z\"}}]})(props);\n};\nexport function AiOutlineUndo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M511.4 124C290.5 124.3 112 303 112 523.9c0 128 60.2 242 153.8 315.2l-37.5 48c-4.1 5.3-.3 13 6.3 12.9l167-.8c5.2 0 9-4.9 7.7-9.9L369.8 727a8 8 0 0 0-14.1-3L315 776.1c-10.2-8-20-16.7-29.3-26a318.64 318.64 0 0 1-68.6-101.7C200.4 609 192 567.1 192 523.9s8.4-85.1 25.1-124.5c16.1-38.1 39.2-72.3 68.6-101.7 29.4-29.4 63.6-52.5 101.7-68.6C426.9 212.4 468.8 204 512 204s85.1 8.4 124.5 25.1c38.1 16.1 72.3 39.2 101.7 68.6 29.4 29.4 52.5 63.6 68.6 101.7 16.7 39.4 25.1 81.3 25.1 124.5s-8.4 85.1-25.1 124.5a318.64 318.64 0 0 1-68.6 101.7c-7.5 7.5-15.3 14.5-23.4 21.2a7.93 7.93 0 0 0-1.2 11.1l39.4 50.5c2.8 3.5 7.9 4.1 11.4 1.3C854.5 760.8 912 649.1 912 523.9c0-221.1-179.4-400.2-400.6-399.9z\"}}]})(props);\n};\nexport function AiOutlineUngroup (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683823033\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M736 550H288c-8.8 0-16 7.2-16 16v176c0 8.8 7.2 16 16 16h448c8.8 0 16-7.2 16-16V566c0-8.8-7.2-16-16-16z m-56 136H344v-64h336v64zM888 816c-39.8 0-72 32.2-72 72s32.2 72 72 72 72-32.2 72-72-32.2-72-72-72z m0 96c-13.3 0-24-10.7-24-24s10.7-24 24-24 24 10.7 24 24-10.7 24-24 24zM736 266H288c-8.8 0-16 7.2-16 16v176c0 8.8 7.2 16 16 16h448c8.8 0 16-7.2 16-16V282c0-8.8-7.2-16-16-16z m-56 136H344v-64h336v64zM888 208c39.8 0 72-32.2 72-72s-32.2-72-72-72-72 32.2-72 72 32.2 72 72 72z m0-96c13.3 0 24 10.7 24 24s-10.7 24-24 24-24-10.7-24-24 10.7-24 24-24zM136 64c-39.8 0-72 32.2-72 72s32.2 72 72 72 72-32.2 72-72-32.2-72-72-72z m0 96c-13.3 0-24-10.7-24-24s10.7-24 24-24 24 10.7 24 24-10.7 24-24 24zM136 816c-39.8 0-72 32.2-72 72s32.2 72 72 72 72-32.2 72-72-32.2-72-72-72z m0 96c-13.3 0-24-10.7-24-24s10.7-24 24-24 24 10.7 24 24-10.7 24-24 24z\"}}]})(props);\n};\nexport function AiOutlineUnlock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 464H332V240c0-30.9 25.1-56 56-56h248c30.9 0 56 25.1 56 56v68c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-68c0-70.7-57.3-128-128-128H388c-70.7 0-128 57.3-128 128v224h-68c-17.7 0-32 14.3-32 32v384c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V496c0-17.7-14.3-32-32-32zm-40 376H232V536h560v304zM484 701v53c0 4.4 3.6 8 8 8h40c4.4 0 8-3.6 8-8v-53a48.01 48.01 0 1 0-56 0z\"}}]})(props);\n};\nexport function AiOutlineUnorderedList (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M912 192H328c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h584c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 284H328c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h584c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zm0 284H328c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h584c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM104 228a56 56 0 1 0 112 0 56 56 0 1 0-112 0zm0 284a56 56 0 1 0 112 0 56 56 0 1 0-112 0zm0 284a56 56 0 1 0 112 0 56 56 0 1 0-112 0z\"}}]})(props);\n};\nexport function AiOutlineUpCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M518.5 360.3a7.95 7.95 0 0 0-12.9 0l-178 246c-3.8 5.3 0 12.7 6.5 12.7H381c10.2 0 19.9-4.9 25.9-13.2L512 460.4l105.2 145.4c6 8.3 15.6 13.2 25.9 13.2H690c6.5 0 10.3-7.4 6.5-12.7l-178-246z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}}]})(props);\n};\nexport function AiOutlineUpSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M334 624h46.9c10.2 0 19.9-4.9 25.9-13.2L512 465.4l105.2 145.4c6 8.3 15.6 13.2 25.9 13.2H690c6.5 0 10.3-7.4 6.5-12.7l-178-246a7.95 7.95 0 0 0-12.9 0l-178 246A7.96 7.96 0 0 0 334 624z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}}]})(props);\n};\nexport function AiOutlineUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M890.5 755.3L537.9 269.2c-12.8-17.6-39-17.6-51.7 0L133.5 755.3A8 8 0 0 0 140 768h75c5.1 0 9.9-2.5 12.9-6.6L512 369.8l284.1 391.6c3 4.1 7.8 6.6 12.9 6.6h75c6.5 0 10.3-7.4 6.5-12.7z\"}}]})(props);\n};\nexport function AiOutlineUpload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M400 317.7h73.9V656c0 4.4 3.6 8 8 8h60c4.4 0 8-3.6 8-8V317.7H624c6.7 0 10.4-7.7 6.3-12.9L518.3 163a8 8 0 0 0-12.6 0l-112 141.7c-4.1 5.3-.4 13 6.3 13zM878 626h-60c-4.4 0-8 3.6-8 8v154H214V634c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8v198c0 17.7 14.3 32 32 32h684c17.7 0 32-14.3 32-32V634c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineUsb (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M760 432V144c0-17.7-14.3-32-32-32H296c-17.7 0-32 14.3-32 32v288c-66.2 0-120 52.1-120 116v356c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V548c0-24.3 21.6-44 48.1-44h495.8c26.5 0 48.1 19.7 48.1 44v356c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V548c0-63.9-53.8-116-120-116zm-424 0V184h352v248H336zm120-184h-48c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zm160 0h-48c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineUserAdd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M678.3 642.4c24.2-13 51.9-20.4 81.4-20.4h.1c3 0 4.4-3.6 2.2-5.6a371.67 371.67 0 0 0-103.7-65.8c-.4-.2-.8-.3-1.2-.5C719.2 505 759.6 431.7 759.6 349c0-137-110.8-248-247.5-248S264.7 212 264.7 349c0 82.7 40.4 156 102.6 201.1-.4.2-.8.3-1.2.5-44.7 18.9-84.8 46-119.3 80.6a373.42 373.42 0 0 0-80.4 119.5A373.6 373.6 0 0 0 137 888.8a8 8 0 0 0 8 8.2h59.9c4.3 0 7.9-3.5 8-7.8 2-77.2 32.9-149.5 87.6-204.3C357 628.2 432.2 597 512.2 597c56.7 0 111.1 15.7 158 45.1a8.1 8.1 0 0 0 8.1.3zM512.2 521c-45.8 0-88.9-17.9-121.4-50.4A171.2 171.2 0 0 1 340.5 349c0-45.9 17.9-89.1 50.3-121.6S466.3 177 512.2 177s88.9 17.9 121.4 50.4A171.2 171.2 0 0 1 683.9 349c0 45.9-17.9 89.1-50.3 121.6C601.1 503.1 558 521 512.2 521zM880 759h-84v-84c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v84h-84c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h84v84c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-84h84c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineUserDelete (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M678.3 655.4c24.2-13 51.9-20.4 81.4-20.4h.1c3 0 4.4-3.6 2.2-5.6a371.67 371.67 0 0 0-103.7-65.8c-.4-.2-.8-.3-1.2-.5C719.2 518 759.6 444.7 759.6 362c0-137-110.8-248-247.5-248S264.7 225 264.7 362c0 82.7 40.4 156 102.6 201.1-.4.2-.8.3-1.2.5-44.7 18.9-84.8 46-119.3 80.6a373.42 373.42 0 0 0-80.4 119.5A373.6 373.6 0 0 0 137 901.8a8 8 0 0 0 8 8.2h59.9c4.3 0 7.9-3.5 8-7.8 2-77.2 32.9-149.5 87.6-204.3C357 641.2 432.2 610 512.2 610c56.7 0 111.1 15.7 158 45.1a8.1 8.1 0 0 0 8.1.3zM512.2 534c-45.8 0-88.9-17.9-121.4-50.4A171.2 171.2 0 0 1 340.5 362c0-45.9 17.9-89.1 50.3-121.6S466.3 190 512.2 190s88.9 17.9 121.4 50.4A171.2 171.2 0 0 1 683.9 362c0 45.9-17.9 89.1-50.3 121.6C601.1 516.1 558 534 512.2 534zM880 772H640c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h240c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiOutlineUserSwitch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683921137\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M759 335c0-137-111-248-248-248S263 198 263 335c0 82.8 40.6 156.2 103 201.2-0.4 0.2-0.7 0.3-0.9 0.4-44.7 18.9-84.8 46-119.3 80.6-34.5 34.5-61.5 74.7-80.4 119.5C146.9 780.5 137 827 136 874.8c-0.1 4.5 3.5 8.2 8 8.2h59.9c4.3 0 7.9-3.5 8-7.8 2-77.2 32.9-149.5 87.6-204.3C356 614.2 431 583 511 583c137 0 248-111 248-248zM511 507c-95 0-172-77-172-172s77-172 172-172 172 77 172 172-77 172-172 172zM616 728h264c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H703.5l47.2-60.1c1.1-1.4 1.7-3.2 1.7-4.9 0-4.4-3.6-8-8-8h-72.6c-4.9 0-9.5 2.3-12.6 6.1l-68.5 87.1c-4.4 5.6-6.8 12.6-6.8 19.8 0.1 17.7 14.4 32 32.1 32zM856 792H592c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h176.5l-47.2 60.1c-1.1 1.4-1.7 3.2-1.7 4.9 0 4.4 3.6 8 8 8h72.6c4.9 0 9.5-2.3 12.6-6.1l68.5-87.1c4.4-5.6 6.8-12.6 6.8-19.8-0.1-17.7-14.4-32-32.1-32z\"}}]})(props);\n};\nexport function AiOutlineUser (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M858.5 763.6a374 374 0 0 0-80.6-119.5 375.63 375.63 0 0 0-119.5-80.6c-.4-.2-.8-.3-1.2-.5C719.5 518 760 444.7 760 362c0-137-111-248-248-248S264 225 264 362c0 82.7 40.5 156 102.8 201.1-.4.2-.8.3-1.2.5-44.8 18.9-85 46-119.5 80.6a375.63 375.63 0 0 0-80.6 119.5A371.7 371.7 0 0 0 136 901.8a8 8 0 0 0 8 8.2h60c4.4 0 7.9-3.5 8-7.8 2-77.2 33-149.5 87.8-204.3 56.7-56.7 132-87.9 212.2-87.9s155.5 31.2 212.2 87.9C779 752.7 810 825 812 902.2c.1 4.4 3.6 7.8 8 7.8h60a8 8 0 0 0 8-8.2c-1-47.8-10.9-94.3-29.5-138.2zM512 534c-45.9 0-89.1-17.9-121.6-50.4S340 407.9 340 362c0-45.9 17.9-89.1 50.4-121.6S466.1 190 512 190s89.1 17.9 121.6 50.4S684 316.1 684 362c0 45.9-17.9 89.1-50.4 121.6S557.9 534 512 534z\"}}]})(props);\n};\nexport function AiOutlineUsergroupAdd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M892 772h-80v-80c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v80h-80c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h80v80c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-80h80c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zM373.5 498.4c-.9-8.7-1.4-17.5-1.4-26.4 0-15.9 1.5-31.4 4.3-46.5.7-3.6-1.2-7.3-4.5-8.8-13.6-6.1-26.1-14.5-36.9-25.1a127.54 127.54 0 0 1-38.7-95.4c.9-32.1 13.8-62.6 36.3-85.6 24.7-25.3 57.9-39.1 93.2-38.7 31.9.3 62.7 12.6 86 34.4 7.9 7.4 14.7 15.6 20.4 24.4 2 3.1 5.9 4.4 9.3 3.2 17.6-6.1 36.2-10.4 55.3-12.4 5.6-.6 8.8-6.6 6.3-11.6-32.5-64.3-98.9-108.7-175.7-109.9-110.8-1.7-203.2 89.2-203.2 200 0 62.8 28.9 118.8 74.2 155.5-31.8 14.7-61.1 35-86.5 60.4-54.8 54.7-85.8 126.9-87.8 204a8 8 0 0 0 8 8.2h56.1c4.3 0 7.9-3.4 8-7.7 1.9-58 25.4-112.3 66.7-153.5 29.4-29.4 65.4-49.8 104.7-59.7 3.8-1.1 6.4-4.8 5.9-8.8zM824 472c0-109.4-87.9-198.3-196.9-200C516.3 270.3 424 361.2 424 472c0 62.8 29 118.8 74.2 155.5a300.95 300.95 0 0 0-86.4 60.4C357 742.6 326 814.8 324 891.8a8 8 0 0 0 8 8.2h56c4.3 0 7.9-3.4 8-7.7 1.9-58 25.4-112.3 66.7-153.5C505.8 695.7 563 672 624 672c110.4 0 200-89.5 200-200zm-109.5 90.5C690.3 586.7 658.2 600 624 600s-66.3-13.3-90.5-37.5a127.26 127.26 0 0 1-37.5-91.8c.3-32.8 13.4-64.5 36.3-88 24-24.6 56.1-38.3 90.4-38.7 33.9-.3 66.8 12.9 91 36.6 24.8 24.3 38.4 56.8 38.4 91.4-.1 34.2-13.4 66.3-37.6 90.5z\"}}]})(props);\n};\nexport function AiOutlineUsergroupDelete (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M888 784H664c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h224c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zM373.5 510.4c-.9-8.7-1.4-17.5-1.4-26.4 0-15.9 1.5-31.4 4.3-46.5.7-3.6-1.2-7.3-4.5-8.8-13.6-6.1-26.1-14.5-36.9-25.1a127.54 127.54 0 0 1-38.7-95.4c.9-32.1 13.8-62.6 36.3-85.6 24.7-25.3 57.9-39.1 93.2-38.7 31.9.3 62.7 12.6 86 34.4 7.9 7.4 14.7 15.6 20.4 24.4 2 3.1 5.9 4.4 9.3 3.2 17.6-6.1 36.2-10.4 55.3-12.4 5.6-.6 8.8-6.6 6.3-11.6-32.5-64.3-98.9-108.7-175.7-109.9-110.9-1.7-203.3 89.2-203.3 199.9 0 62.8 28.9 118.8 74.2 155.5-31.8 14.7-61.1 35-86.5 60.4-54.8 54.7-85.8 126.9-87.8 204a8 8 0 0 0 8 8.2h56.1c4.3 0 7.9-3.4 8-7.7 1.9-58 25.4-112.3 66.7-153.5 29.4-29.4 65.4-49.8 104.7-59.7 3.9-1 6.5-4.7 6-8.7zM824 484c0-109.4-87.9-198.3-196.9-200C516.3 282.3 424 373.2 424 484c0 62.8 29 118.8 74.2 155.5a300.95 300.95 0 0 0-86.4 60.4C357 754.6 326 826.8 324 903.8a8 8 0 0 0 8 8.2h56c4.3 0 7.9-3.4 8-7.7 1.9-58 25.4-112.3 66.7-153.5C505.8 707.7 563 684 624 684c110.4 0 200-89.5 200-200zm-109.5 90.5C690.3 598.7 658.2 612 624 612s-66.3-13.3-90.5-37.5a127.26 127.26 0 0 1-37.5-91.8c.3-32.8 13.4-64.5 36.3-88 24-24.6 56.1-38.3 90.4-38.7 33.9-.3 66.8 12.9 91 36.6 24.8 24.3 38.4 56.8 38.4 91.4-.1 34.2-13.4 66.3-37.6 90.5z\"}}]})(props);\n};\nexport function AiOutlineVerified (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683899926\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M447.8 588.8l-7.3-32.5c-0.2-1-0.6-1.9-1.1-2.7-2.5-3.7-7.4-4.7-11.1-2.2L405 567V411c0-4.4-3.6-8-8-8h-81c-4.4 0-8 3.6-8 8v36c0 4.4 3.6 8 8 8h37v192.4c0 1.7 0.5 3.3 1.5 4.7 2.6 3.6 7.6 4.4 11.2 1.8l79-56.8c2.6-1.9 3.8-5.1 3.1-8.3zM391.1 372.2l0.2 0.2c3.2 3 8.3 2.8 11.3-0.5l24.1-26.2c2.9-3.2 2.8-8.1-0.3-11.2l-53.7-52.1c-3.1-3-8.1-3-11.2 0.1l-24.7 24.7c-3.1 3.1-3.1 8.2 0.1 11.3l54.2 53.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M866.9 169.9L527.1 54.1C523 52.7 517.5 52 512 52s-11 0.7-15.1 2.1L157.1 169.9c-8.3 2.8-15.1 12.4-15.1 21.2v482.4c0 8.8 5.7 20.4 12.6 25.9L499.3 968c3.5 2.7 8 4.1 12.6 4.1s9.2-1.4 12.6-4.1l344.7-268.6c6.9-5.4 12.6-17 12.6-25.9V191.1c0.2-8.8-6.6-18.3-14.9-21.2zM810 654.3L512 886.5 214 654.3V226.7l298-101.6 298 101.6v427.6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M452 297v36c0 4.4 3.6 8 8 8h108v274h-38V405c0-4.4-3.6-8-8-8h-35c-4.4 0-8 3.6-8 8v210h-31c-4.4 0-8 3.6-8 8v37c0 4.4 3.6 8 8 8h244c4.4 0 8-3.6 8-8v-37c0-4.4-3.6-8-8-8h-72V493h58c4.4 0 8-3.6 8-8v-35c0-4.4-3.6-8-8-8h-58V341h63c4.4 0 8-3.6 8-8v-36c0-4.4-3.6-8-8-8H460c-4.4 0-8 3.6-8 8z\"}}]})(props);\n};\nexport function AiOutlineVerticalAlignBottom (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M859.9 780H164.1c-4.5 0-8.1 3.6-8.1 8v60c0 4.4 3.6 8 8.1 8h695.8c4.5 0 8.1-3.6 8.1-8v-60c0-4.4-3.6-8-8.1-8zM505.7 669a8 8 0 0 0 12.6 0l112-141.7c4.1-5.2.4-12.9-6.3-12.9h-74.1V176c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8v338.3H400c-6.7 0-10.4 7.7-6.3 12.9l112 141.8z\"}}]})(props);\n};\nexport function AiOutlineVerticalAlignMiddle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M859.9 474H164.1c-4.5 0-8.1 3.6-8.1 8v60c0 4.4 3.6 8 8.1 8h695.8c4.5 0 8.1-3.6 8.1-8v-60c0-4.4-3.6-8-8.1-8zm-353.6-74.7c2.9 3.7 8.5 3.7 11.3 0l100.8-127.5c3.7-4.7.4-11.7-5.7-11.7H550V104c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8v156h-62.8c-6 0-9.4 7-5.7 11.7l100.8 127.6zm11.4 225.4a7.14 7.14 0 0 0-11.3 0L405.6 752.3a7.23 7.23 0 0 0 5.7 11.7H474v156c0 4.4 3.6 8 8 8h60c4.4 0 8-3.6 8-8V764h62.8c6 0 9.4-7 5.7-11.7L517.7 624.7z\"}}]})(props);\n};\nexport function AiOutlineVerticalAlignTop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M859.9 168H164.1c-4.5 0-8.1 3.6-8.1 8v60c0 4.4 3.6 8 8.1 8h695.8c4.5 0 8.1-3.6 8.1-8v-60c0-4.4-3.6-8-8.1-8zM518.3 355a8 8 0 0 0-12.6 0l-112 141.7a7.98 7.98 0 0 0 6.3 12.9h73.9V848c0 4.4 3.6 8 8 8h60c4.4 0 8-3.6 8-8V509.7H624c6.7 0 10.4-7.7 6.3-12.9L518.3 355z\"}}]})(props);\n};\nexport function AiOutlineVerticalLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M762 164h-64c-4.4 0-8 3.6-8 8v688c0 4.4 3.6 8 8 8h64c4.4 0 8-3.6 8-8V172c0-4.4-3.6-8-8-8zm-508 0v72.4c0 9.5 4.2 18.4 11.4 24.5L564.6 512 265.4 763.1c-7.2 6.1-11.4 15-11.4 24.5V860c0 6.8 7.9 10.5 13.1 6.1L689 512 267.1 157.9A7.95 7.95 0 0 0 254 164z\"}}]})(props);\n};\nexport function AiOutlineVerticalRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M326 164h-64c-4.4 0-8 3.6-8 8v688c0 4.4 3.6 8 8 8h64c4.4 0 8-3.6 8-8V172c0-4.4-3.6-8-8-8zm444 72.4V164c0-6.8-7.9-10.5-13.1-6.1L335 512l421.9 354.1c5.2 4.4 13.1.7 13.1-6.1v-72.4c0-9.4-4.2-18.4-11.4-24.5L459.4 512l299.2-251.1c7.2-6.1 11.4-15.1 11.4-24.5z\"}}]})(props);\n};\nexport function AiOutlineVideoCameraAdd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683915274\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M368 724H252V608c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v116H72c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h116v116c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V788h116c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M912 302.3L784 376V224c0-35.3-28.7-64-64-64H128c-35.3 0-64 28.7-64 64v352h72V232h576v560H448v72h272c35.3 0 64-28.7 64-64V648l128 73.7c21.3 12.3 48-3.1 48-27.6V330c0-24.6-26.7-40-48-27.7zM888 625l-104-59.8V458.9L888 399v226z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M320 360c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H208c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h112z\"}}]})(props);\n};\nexport function AiOutlineVideoCamera (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M912 302.3L784 376V224c0-35.3-28.7-64-64-64H128c-35.3 0-64 28.7-64 64v576c0 35.3 28.7 64 64 64h592c35.3 0 64-28.7 64-64V648l128 73.7c21.3 12.3 48-3.1 48-27.6V330c0-24.6-26.7-40-48-27.7zM712 792H136V232h576v560zm176-167l-104-59.8V458.9L888 399v226zM208 360h112c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H208c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiOutlineWallet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 464H528V448h312v128zm0 264H184V184h656v200H496c-17.7 0-32 14.3-32 32v192c0 17.7 14.3 32 32 32h344v200zM580 512a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}}]})(props);\n};\nexport function AiOutlineWarning (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M464 720a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm16-304v184c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V416c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8zm475.7 440l-416-720c-6.2-10.7-16.9-16-27.7-16s-21.6 5.3-27.7 16l-416 720C56 877.4 71.4 904 96 904h832c24.6 0 40-26.6 27.7-48zm-783.5-27.9L512 239.9l339.8 588.2H172.2z\"}}]})(props);\n};\nexport function AiOutlineWechat (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M690.1 377.4c5.9 0 11.8.2 17.6.5-24.4-128.7-158.3-227.1-319.9-227.1C209 150.8 64 271.4 64 420.2c0 81.1 43.6 154.2 111.9 203.6a21.5 21.5 0 0 1 9.1 17.6c0 2.4-.5 4.6-1.1 6.9-5.5 20.3-14.2 52.8-14.6 54.3-.7 2.6-1.7 5.2-1.7 7.9 0 5.9 4.8 10.8 10.8 10.8 2.3 0 4.2-.9 6.2-2l70.9-40.9c5.3-3.1 11-5 17.2-5 3.2 0 6.4.5 9.5 1.4 33.1 9.5 68.8 14.8 105.7 14.8 6 0 11.9-.1 17.8-.4-7.1-21-10.9-43.1-10.9-66 0-135.8 132.2-245.8 295.3-245.8zm-194.3-86.5c23.8 0 43.2 19.3 43.2 43.1s-19.3 43.1-43.2 43.1c-23.8 0-43.2-19.3-43.2-43.1s19.4-43.1 43.2-43.1zm-215.9 86.2c-23.8 0-43.2-19.3-43.2-43.1s19.3-43.1 43.2-43.1 43.2 19.3 43.2 43.1-19.4 43.1-43.2 43.1zm586.8 415.6c56.9-41.2 93.2-102 93.2-169.7 0-124-120.8-224.5-269.9-224.5-149 0-269.9 100.5-269.9 224.5S540.9 847.5 690 847.5c30.8 0 60.6-4.4 88.1-12.3 2.6-.8 5.2-1.2 7.9-1.2 5.2 0 9.9 1.6 14.3 4.1l59.1 34c1.7 1 3.3 1.7 5.2 1.7a9 9 0 0 0 6.4-2.6 9 9 0 0 0 2.6-6.4c0-2.2-.9-4.4-1.4-6.6-.3-1.2-7.6-28.3-12.2-45.3-.5-1.9-.9-3.8-.9-5.7.1-5.9 3.1-11.2 7.6-14.5zM600.2 587.2c-19.9 0-36-16.1-36-35.9 0-19.8 16.1-35.9 36-35.9s36 16.1 36 35.9c0 19.8-16.2 35.9-36 35.9zm179.9 0c-19.9 0-36-16.1-36-35.9 0-19.8 16.1-35.9 36-35.9s36 16.1 36 35.9a36.08 36.08 0 0 1-36 35.9z\"}}]})(props);\n};\nexport function AiOutlineWeiboCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm-44.4 672C353.1 736 236 680.4 236 588.9c0-47.8 30.2-103.1 82.3-155.3 69.5-69.6 150.6-101.4 181.1-70.8 13.5 13.5 14.8 36.8 6.1 64.6-4.5 14 13.1 6.3 13.1 6.3 56.2-23.6 105.2-25 123.1.7 9.6 13.7 8.6 32.8-.2 55.1-4.1 10.2 1.3 11.8 9 14.1 31.7 9.8 66.9 33.6 66.9 75.5.2 69.5-99.7 156.9-249.8 156.9zm207.3-290.8a34.9 34.9 0 0 0-7.2-34.1 34.68 34.68 0 0 0-33.1-10.7 18.24 18.24 0 0 1-7.6-35.7c24.1-5.1 50.1 2.3 67.7 21.9 17.7 19.6 22.4 46.3 14.9 69.8a18.13 18.13 0 0 1-22.9 11.7 18.18 18.18 0 0 1-11.8-22.9zm106 34.3s0 .1 0 0a21.1 21.1 0 0 1-26.6 13.7 21.19 21.19 0 0 1-13.6-26.7c11-34.2 4-73.2-21.7-101.8a104.04 104.04 0 0 0-98.9-32.1 21.14 21.14 0 0 1-25.1-16.3 21.07 21.07 0 0 1 16.2-25.1c49.4-10.5 102.8 4.8 139.1 45.1 36.3 40.2 46.1 95.1 30.6 143.2zm-334.5 6.1c-91.4 9-160.7 65.1-154.7 125.2 5.9 60.1 84.8 101.5 176.2 92.5 91.4-9.1 160.7-65.1 154.7-125.3-5.9-60.1-84.8-101.5-176.2-92.4zm80.2 141.7c-18.7 42.3-72.3 64.8-117.8 50.1-43.9-14.2-62.5-57.7-43.3-96.8 18.9-38.4 68-60.1 111.5-48.8 45 11.7 68 54.2 49.6 95.5zm-93-32.2c-14.2-5.9-32.4.2-41.2 13.9-8.8 13.8-4.7 30.2 9.3 36.6 14.3 6.5 33.2.3 42-13.8 8.8-14.3 4.2-30.6-10.1-36.7zm34.9-14.5c-5.4-2.2-12.2.5-15.4 5.8-3.1 5.4-1.4 11.5 4.1 13.8 5.5 2.3 12.6-.3 15.8-5.8 3-5.6 1-11.8-4.5-13.8z\"}}]})(props);\n};\nexport function AiOutlineWeiboSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M433.6 595.1c-14.2-5.9-32.4.2-41.2 13.9-8.8 13.8-4.7 30.2 9.3 36.6 14.3 6.5 33.2.3 42-13.8 8.8-14.3 4.2-30.6-10.1-36.7zM880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM467.6 736C353.1 736 236 680.4 236 588.9c0-47.8 30.2-103.1 82.3-155.3 69.5-69.6 150.6-101.4 181.1-70.8 13.5 13.5 14.8 36.8 6.1 64.6-4.5 14 13.1 6.3 13.1 6.3 56.2-23.6 105.2-25 123.1.7 9.6 13.7 8.6 32.8-.2 55.1-4.1 10.2 1.3 11.8 9 14.1 31.7 9.8 66.9 33.6 66.9 75.5.2 69.5-99.7 156.9-249.8 156.9zm207.3-290.8a34.9 34.9 0 0 0-7.2-34.1 34.68 34.68 0 0 0-33.1-10.7 18.24 18.24 0 0 1-7.6-35.7c24.1-5.1 50.1 2.3 67.7 21.9 17.7 19.6 22.4 46.3 14.9 69.8a18.13 18.13 0 0 1-22.9 11.7 18.18 18.18 0 0 1-11.8-22.9zm106 34.3s0 .1 0 0a21.1 21.1 0 0 1-26.6 13.7 21.19 21.19 0 0 1-13.6-26.7c11-34.2 4-73.2-21.7-101.8a104.04 104.04 0 0 0-98.9-32.1 21.14 21.14 0 0 1-25.1-16.3 21.07 21.07 0 0 1 16.2-25.1c49.4-10.5 102.8 4.8 139.1 45.1 36.3 40.2 46.1 95.1 30.6 143.2zm-334.5 6.1c-91.4 9-160.7 65.1-154.7 125.2 5.9 60.1 84.8 101.5 176.2 92.5 91.4-9.1 160.7-65.1 154.7-125.3-5.9-60.1-84.8-101.5-176.2-92.4zm80.2 141.7c-18.7 42.3-72.3 64.8-117.8 50.1-43.9-14.2-62.5-57.7-43.3-96.8 18.9-38.4 68-60.1 111.5-48.8 45 11.7 68 54.2 49.6 95.5zm-58.1-46.7c-5.4-2.2-12.2.5-15.4 5.8-3.1 5.4-1.4 11.5 4.1 13.8 5.5 2.3 12.6-.3 15.8-5.8 3-5.6 1-11.8-4.5-13.8z\"}}]})(props);\n};\nexport function AiOutlineWeibo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M457.3 543c-68.1-17.7-145 16.2-174.6 76.2-30.1 61.2-1 129.1 67.8 151.3 71.2 23 155.2-12.2 184.4-78.3 28.7-64.6-7.2-131-77.6-149.2zm-52 156.2c-13.8 22.1-43.5 31.7-65.8 21.6-22-10-28.5-35.7-14.6-57.2 13.7-21.4 42.3-31 64.4-21.7 22.4 9.5 29.6 35 16 57.3zm45.5-58.5c-5 8.6-16.1 12.7-24.7 9.1-8.5-3.5-11.2-13.1-6.4-21.5 5-8.4 15.6-12.4 24.1-9.1 8.7 3.2 11.8 12.9 7 21.5zm334.5-197.2c15 4.8 31-3.4 35.9-18.3 11.8-36.6 4.4-78.4-23.2-109a111.39 111.39 0 0 0-106-34.3 28.45 28.45 0 0 0-21.9 33.8 28.39 28.39 0 0 0 33.8 21.8c18.4-3.9 38.3 1.8 51.9 16.7a54.2 54.2 0 0 1 11.3 53.3 28.45 28.45 0 0 0 18.2 36zm99.8-206c-56.7-62.9-140.4-86.9-217.7-70.5a32.98 32.98 0 0 0-25.4 39.3 33.12 33.12 0 0 0 39.3 25.5c55-11.7 114.4 5.4 154.8 50.1 40.3 44.7 51.2 105.7 34 159.1-5.6 17.4 3.9 36 21.3 41.7 17.4 5.6 36-3.9 41.6-21.2v-.1c24.1-75.4 8.9-161.1-47.9-223.9zM729 499c-12.2-3.6-20.5-6.1-14.1-22.1 13.8-34.7 15.2-64.7.3-86-28-40.1-104.8-37.9-192.8-1.1 0 0-27.6 12.1-20.6-9.8 13.5-43.5 11.5-79.9-9.6-101-47.7-47.8-174.6 1.8-283.5 110.6C127.3 471.1 80 557.5 80 632.2 80 775.1 263.2 862 442.5 862c235 0 391.3-136.5 391.3-245 0-65.5-55.2-102.6-104.8-118zM443 810.8c-143 14.1-266.5-50.5-275.8-144.5-9.3-93.9 99.2-181.5 242.2-195.6 143-14.2 266.5 50.5 275.8 144.4C694.4 709 586 796.6 443 810.8z\"}}]})(props);\n};\nexport function AiOutlineWhatsApp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"t\":\"1569683925316\",\"viewBox\":\"0 0 1024 1024\",\"version\":\"1.1\"},\"child\":[{\"tag\":\"defs\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"d\":\"M713.5 599.9c-10.9-5.6-65.2-32.2-75.3-35.8-10.1-3.8-17.5-5.6-24.8 5.6-7.4 11.1-28.4 35.8-35 43.3-6.4 7.4-12.9 8.3-23.8 2.8-64.8-32.4-107.3-57.8-150-131.1-11.3-19.5 11.3-18.1 32.4-60.2 3.6-7.4 1.8-13.7-1-19.3-2.8-5.6-24.8-59.8-34-81.9-8.9-21.5-18.1-18.5-24.8-18.9-6.4-0.4-13.7-0.4-21.1-0.4-7.4 0-19.3 2.8-29.4 13.7-10.1 11.1-38.6 37.8-38.6 92s39.5 106.7 44.9 114.1c5.6 7.4 77.7 118.6 188.4 166.5 70 30.2 97.4 32.8 132.4 27.6 21.3-3.2 65.2-26.6 74.3-52.5 9.1-25.8 9.1-47.9 6.4-52.5-2.7-4.9-10.1-7.7-21-13z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M925.2 338.4c-22.6-53.7-55-101.9-96.3-143.3-41.3-41.3-89.5-73.8-143.3-96.3C630.6 75.7 572.2 64 512 64h-2c-60.6 0.3-119.3 12.3-174.5 35.9-53.3 22.8-101.1 55.2-142 96.5-40.9 41.3-73 89.3-95.2 142.8-23 55.4-34.6 114.3-34.3 174.9 0.3 69.4 16.9 138.3 48 199.9v152c0 25.4 20.6 46 46 46h152.1c61.6 31.1 130.5 47.7 199.9 48h2.1c59.9 0 118-11.6 172.7-34.3 53.5-22.3 101.6-54.3 142.8-95.2 41.3-40.9 73.8-88.7 96.5-142 23.6-55.2 35.6-113.9 35.9-174.5 0.3-60.9-11.5-120-34.8-175.6z m-151.1 438C704 845.8 611 884 512 884h-1.7c-60.3-0.3-120.2-15.3-173.1-43.5l-8.4-4.5H188V695.2l-4.5-8.4C155.3 633.9 140.3 574 140 513.7c-0.4-99.7 37.7-193.3 107.6-263.8 69.8-70.5 163.1-109.5 262.8-109.9h1.7c50 0 98.5 9.7 144.2 28.9 44.6 18.7 84.6 45.6 119 80 34.3 34.3 61.3 74.4 80 119 19.4 46.2 29.1 95.2 28.9 145.8-0.6 99.6-39.7 192.9-110.1 262.7z\"}}]})(props);\n};\nexport function AiOutlineWifi (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M723 620.5C666.8 571.6 593.4 542 513 542s-153.8 29.6-210.1 78.6a8.1 8.1 0 0 0-.8 11.2l36 42.9c2.9 3.4 8 3.8 11.4.9C393.1 637.2 450.3 614 513 614s119.9 23.2 163.5 61.5c3.4 2.9 8.5 2.5 11.4-.9l36-42.9c2.8-3.3 2.4-8.3-.9-11.2zm117.4-140.1C751.7 406.5 637.6 362 513 362s-238.7 44.5-327.5 118.4a8.05 8.05 0 0 0-1 11.3l36 42.9c2.8 3.4 7.9 3.8 11.2 1C308 472.2 406.1 434 513 434s205 38.2 281.2 101.6c3.4 2.8 8.4 2.4 11.2-1l36-42.9c2.8-3.4 2.4-8.5-1-11.3zm116.7-139C835.7 241.8 680.3 182 511 182c-168.2 0-322.6 59-443.7 157.4a8 8 0 0 0-1.1 11.4l36 42.9c2.8 3.3 7.8 3.8 11.1 1.1C222 306.7 360.3 254 511 254c151.8 0 291 53.5 400 142.7 3.4 2.8 8.4 2.3 11.2-1.1l36-42.9c2.9-3.4 2.4-8.5-1.1-11.3zM448 778a64 64 0 1 0 128 0 64 64 0 1 0-128 0z\"}}]})(props);\n};\nexport function AiOutlineWindows (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M120.1 770.6L443 823.2V543.8H120.1v226.8zm63.4-163.5h196.2v141.6l-196.2-31.9V607.1zm340.3 226.5l382 62.2v-352h-382v289.8zm63.4-226.5h255.3v214.4l-255.3-41.6V607.1zm-63.4-415.7v288.8h382V128.1l-382 63.3zm318.7 225.5H587.3V245l255.3-42.3v214.2zm-722.4 63.3H443V201.9l-322.9 53.5v224.8zM183.5 309l196.2-32.5v140.4H183.5V309z\"}}]})(props);\n};\nexport function AiOutlineWoman (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M712.8 548.8c53.6-53.6 83.2-125 83.2-200.8 0-75.9-29.5-147.2-83.2-200.8C659.2 93.6 587.8 64 512 64s-147.2 29.5-200.8 83.2C257.6 200.9 228 272.1 228 348c0 63.8 20.9 124.4 59.4 173.9 7.3 9.4 15.2 18.3 23.7 26.9 8.5 8.5 17.5 16.4 26.8 23.7 39.6 30.8 86.3 50.4 136.1 57V736H360c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h114v140c0 4.4 3.6 8 8 8h60c4.4 0 8-3.6 8-8V812h114c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8H550V629.5c61.5-8.2 118.2-36.1 162.8-80.7zM512 556c-55.6 0-107.7-21.6-147.1-60.9C325.6 455.8 304 403.6 304 348s21.6-107.7 60.9-147.1C404.2 161.5 456.4 140 512 140s107.7 21.6 147.1 60.9C698.4 240.2 720 292.4 720 348s-21.6 107.7-60.9 147.1C619.7 534.4 567.6 556 512 556z\"}}]})(props);\n};\nexport function AiOutlineYahoo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M859.9 681.4h-14.1c-27.1 0-49.2 22.2-49.2 49.3v14.1c0 27.1 22.2 49.3 49.2 49.3h14.1c27.1 0 49.2-22.2 49.2-49.3v-14.1c0-27.1-22.2-49.3-49.2-49.3zM402.6 231C216.2 231 65 357 65 512.5S216.2 794 402.6 794s337.6-126 337.6-281.5S589.1 231 402.6 231zm0 507C245.1 738 121 634.6 121 512.5c0-62.3 32.3-119.7 84.9-161v48.4h37l159.8 159.9v65.3h-84.4v56.3h225.1v-56.3H459v-65.3l103.5-103.6h65.3v-56.3H459v65.3l-28.1 28.1-93.4-93.5h37v-56.3H216.4c49.4-35 114.3-56.6 186.2-56.6 157.6 0 281.6 103.4 281.6 225.5S560.2 738 402.6 738zm534.7-507H824.7c-15.5 0-27.7 12.6-27.1 28.1l13.1 366h84.4l65.4-366.4c2.7-15.2-7.8-27.7-23.2-27.7z\"}}]})(props);\n};\nexport function AiOutlineYoutube (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M960 509.2c0-2.2 0-4.7-.1-7.6-.1-8.1-.3-17.2-.5-26.9-.8-27.9-2.2-55.7-4.4-81.9-3-36.1-7.4-66.2-13.4-88.8a139.52 139.52 0 0 0-98.3-98.5c-28.3-7.6-83.7-12.3-161.7-15.2-37.1-1.4-76.8-2.3-116.5-2.8-13.9-.2-26.8-.3-38.4-.4h-29.4c-11.6.1-24.5.2-38.4.4-39.7.5-79.4 1.4-116.5 2.8-78 3-133.5 7.7-161.7 15.2A139.35 139.35 0 0 0 82.4 304C76.3 326.6 72 356.7 69 392.8c-2.2 26.2-3.6 54-4.4 81.9-.3 9.7-.4 18.8-.5 26.9 0 2.9-.1 5.4-.1 7.6v5.6c0 2.2 0 4.7.1 7.6.1 8.1.3 17.2.5 26.9.8 27.9 2.2 55.7 4.4 81.9 3 36.1 7.4 66.2 13.4 88.8 12.8 47.9 50.4 85.7 98.3 98.5 28.2 7.6 83.7 12.3 161.7 15.2 37.1 1.4 76.8 2.3 116.5 2.8 13.9.2 26.8.3 38.4.4h29.4c11.6-.1 24.5-.2 38.4-.4 39.7-.5 79.4-1.4 116.5-2.8 78-3 133.5-7.7 161.7-15.2 47.9-12.8 85.5-50.5 98.3-98.5 6.1-22.6 10.4-52.7 13.4-88.8 2.2-26.2 3.6-54 4.4-81.9.3-9.7.4-18.8.5-26.9 0-2.9.1-5.4.1-7.6v-5.6zm-72 5.2c0 2.1 0 4.4-.1 7.1-.1 7.8-.3 16.4-.5 25.7-.7 26.6-2.1 53.2-4.2 77.9-2.7 32.2-6.5 58.6-11.2 76.3-6.2 23.1-24.4 41.4-47.4 47.5-21 5.6-73.9 10.1-145.8 12.8-36.4 1.4-75.6 2.3-114.7 2.8-13.7.2-26.4.3-37.8.3h-28.6l-37.8-.3c-39.1-.5-78.2-1.4-114.7-2.8-71.9-2.8-124.9-7.2-145.8-12.8-23-6.2-41.2-24.4-47.4-47.5-4.7-17.7-8.5-44.1-11.2-76.3-2.1-24.7-3.4-51.3-4.2-77.9-.3-9.3-.4-18-.5-25.7 0-2.7-.1-5.1-.1-7.1v-4.8c0-2.1 0-4.4.1-7.1.1-7.8.3-16.4.5-25.7.7-26.6 2.1-53.2 4.2-77.9 2.7-32.2 6.5-58.6 11.2-76.3 6.2-23.1 24.4-41.4 47.4-47.5 21-5.6 73.9-10.1 145.8-12.8 36.4-1.4 75.6-2.3 114.7-2.8 13.7-.2 26.4-.3 37.8-.3h28.6l37.8.3c39.1.5 78.2 1.4 114.7 2.8 71.9 2.8 124.9 7.2 145.8 12.8 23 6.2 41.2 24.4 47.4 47.5 4.7 17.7 8.5 44.1 11.2 76.3 2.1 24.7 3.4 51.3 4.2 77.9.3 9.3.4 18 .5 25.7 0 2.7.1 5.1.1 7.1v4.8zM423 646l232-135-232-133z\"}}]})(props);\n};\nexport function AiOutlineYuque (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 370.6c-9.9-39.4 9.9-102.2 73.4-124.4l-67.9-3.6s-25.7-90-143.6-98c-117.8-8.1-194.9-3-195-3 .1 0 87.4 55.6 52.4 154.7-25.6 52.5-65.8 95.6-108.8 144.7-1.3 1.3-2.5 2.6-3.5 3.7C319.4 605 96 860 96 860c245.9 64.4 410.7-6.3 508.2-91.1 20.5-.2 35.9-.3 46.3-.3 135.8 0 250.6-117.6 245.9-248.4-3.2-89.9-31.9-110.2-41.8-149.6zm-204.1 334c-10.6 0-26.2.1-46.8.3l-23.6.2-17.8 15.5c-47.1 41-104.4 71.5-171.4 87.6-52.5 12.6-110 16.2-172.7 9.6 18-20.5 36.5-41.6 55.4-63.1 92-104.6 173.8-197.5 236.9-268.5l1.4-1.4 1.3-1.5c4.1-4.6 20.6-23.3 24.7-28.1 9.7-11.1 17.3-19.9 24.5-28.6 30.7-36.7 52.2-67.8 69-102.2l1.6-3.3 1.2-3.4c13.7-38.8 15.4-76.9 6.2-112.8 22.5.7 46.5 1.9 71.7 3.6 33.3 2.3 55.5 12.9 71.1 29.2 5.8 6 10.2 12.5 13.4 18.7 1 2 1.7 3.6 2.3 5l5 17.7c-15.7 34.5-19.9 73.3-11.4 107.2 3 11.8 6.9 22.4 12.3 34.4 2.1 4.7 9.5 20.1 11 23.3 10.3 22.7 15.4 43 16.7 78.7 3.3 94.6-82.7 181.9-182 181.9z\"}}]})(props);\n};\nexport function AiOutlineZhihu (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M564.7 230.1V803h60l25.2 71.4L756.3 803h131.5V230.1H564.7zm247.7 497h-59.9l-75.1 50.4-17.8-50.4h-18V308.3h170.7v418.8zM526.1 486.9H393.3c2.1-44.9 4.3-104.3 6.6-172.9h130.9l-.1-8.1c0-.6-.2-14.7-2.3-29.1-2.1-15-6.6-34.9-21-34.9H287.8c4.4-20.6 15.7-69.7 29.4-93.8l6.4-11.2-12.9-.7c-.8 0-19.6-.9-41.4 10.6-35.7 19-51.7 56.4-58.7 84.4-18.4 73.1-44.6 123.9-55.7 145.6-3.3 6.4-5.3 10.2-6.2 12.8-1.8 4.9-.8 9.8 2.8 13 10.5 9.5 38.2-2.9 38.5-3 .6-.3 1.3-.6 2.2-1 13.9-6.3 55.1-25 69.8-84.5h56.7c.7 32.2 3.1 138.4 2.9 172.9h-141l-2.1 1.5c-23.1 16.9-30.5 63.2-30.8 65.2l-1.4 9.2h167c-12.3 78.3-26.5 113.4-34 127.4-3.7 7-7.3 14-10.7 20.8-21.3 42.2-43.4 85.8-126.3 153.6-3.6 2.8-7 8-4.8 13.7 2.4 6.3 9.3 9.1 24.6 9.1 5.4 0 11.8-.3 19.4-1 49.9-4.4 100.8-18 135.1-87.6 17-35.1 31.7-71.7 43.9-108.9L497 850l5-12c.8-1.9 19-46.3 5.1-95.9l-.5-1.8-108.1-123-22 16.6c6.4-26.1 10.6-49.9 12.5-71.1h158.7v-8c0-40.1-18.5-63.9-19.2-64.9l-2.4-3z\"}}]})(props);\n};\nexport function AiOutlineZoomIn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M637 443H519V309c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8v134H325c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h118v134c0 4.4 3.6 8 8 8h60c4.4 0 8-3.6 8-8V519h118c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8zm284 424L775 721c122.1-148.9 113.6-369.5-26-509-148-148.1-388.4-148.1-537 0-148.1 148.6-148.1 389 0 537 139.5 139.6 360.1 148.1 509 26l146 146c3.2 2.8 8.3 2.8 11 0l43-43c2.8-2.7 2.8-7.8 0-11zM696 696c-118.8 118.7-311.2 118.7-430 0-118.7-118.8-118.7-311.2 0-430 118.8-118.7 311.2-118.7 430 0 118.7 118.8 118.7 311.2 0 430z\"}}]})(props);\n};\nexport function AiOutlineZoomOut (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M637 443H325c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h312c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8zm284 424L775 721c122.1-148.9 113.6-369.5-26-509-148-148.1-388.4-148.1-537 0-148.1 148.6-148.1 389 0 537 139.5 139.6 360.1 148.1 509 26l146 146c3.2 2.8 8.3 2.8 11 0l43-43c2.8-2.7 2.8-7.8 0-11zM696 696c-118.8 118.7-311.2 118.7-430 0-118.7-118.8-118.7-311.2 0-430 118.8-118.7 311.2-118.7 430 0 118.7 118.8 118.7 311.2 0 430z\"}}]})(props);\n};\nexport function AiTwotoneAccountBook (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M712 304c0 4.4-3.6 8-8 8h-56c-4.4 0-8-3.6-8-8v-48H384v48c0 4.4-3.6 8-8 8h-56c-4.4 0-8-3.6-8-8v-48H184v584h656V256H712v48zm-65.6 121.8l-89.3 164.1h49.1c4.4 0 8 3.6 8 8v21.3c0 4.4-3.6 8-8 8h-65.4v33.7h65.4c4.4 0 8 3.6 8 8v21.3c0 4.4-3.6 8-8 8h-65.4V752c0 4.4-3.6 8-8 8h-41.3c-4.4 0-8-3.6-8-8v-53.8h-65.1c-4.4 0-8-3.6-8-8v-21.3c0-4.4 3.6-8 8-8h65.1v-33.7h-65.1c-4.4 0-8-3.6-8-8v-21.3c0-4.4 3.6-8 8-8H467l-89.3-164c-2.1-3.9-.7-8.8 3.2-10.9 1.1-.7 2.5-1 3.8-1h46a8 8 0 0 1 7.1 4.4l73.4 145.4h2.8l73.4-145.4c1.3-2.7 4.1-4.4 7.1-4.4h45c4.5 0 8 3.6 7.9 8 0 1.3-.4 2.6-1 3.8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M639.5 414h-45c-3 0-5.8 1.7-7.1 4.4L514 563.8h-2.8l-73.4-145.4a8 8 0 0 0-7.1-4.4h-46c-1.3 0-2.7.3-3.8 1-3.9 2.1-5.3 7-3.2 10.9l89.3 164h-48.6c-4.4 0-8 3.6-8 8v21.3c0 4.4 3.6 8 8 8h65.1v33.7h-65.1c-4.4 0-8 3.6-8 8v21.3c0 4.4 3.6 8 8 8h65.1V752c0 4.4 3.6 8 8 8h41.3c4.4 0 8-3.6 8-8v-53.8h65.4c4.4 0 8-3.6 8-8v-21.3c0-4.4-3.6-8-8-8h-65.4v-33.7h65.4c4.4 0 8-3.6 8-8v-21.3c0-4.4-3.6-8-8-8h-49.1l89.3-164.1c.6-1.2 1-2.5 1-3.8.1-4.4-3.4-8-7.9-8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 184H712v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H384v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H144c-17.7 0-32 14.3-32 32v664c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V216c0-17.7-14.3-32-32-32zm-40 656H184V256h128v48c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-48h256v48c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-48h128v584z\"}}]})(props);\n};\nexport function AiTwotoneAlert (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M340 585c0-5.5 4.5-10 10-10h44c5.5 0 10 4.5 10 10v171h355V563c0-136.4-110.6-247-247-247S265 426.6 265 563v193h75V585z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M216.9 310.5l39.6-39.6c3.1-3.1 3.1-8.2 0-11.3l-67.9-67.9a8.03 8.03 0 0 0-11.3 0l-39.6 39.6a8.03 8.03 0 0 0 0 11.3l67.9 67.9c3.1 3.1 8.1 3.1 11.3 0zm669.6-79.2l-39.6-39.6a8.03 8.03 0 0 0-11.3 0l-67.9 67.9a8.03 8.03 0 0 0 0 11.3l39.6 39.6c3.1 3.1 8.2 3.1 11.3 0l67.9-67.9c3.1-3.2 3.1-8.2 0-11.3zM484 180h56c4.4 0 8-3.6 8-8V76c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v96c0 4.4 3.6 8 8 8zm348 712H192c-17.7 0-32 14.3-32 32v24c0 4.4 3.6 8 8 8h688c4.4 0 8-3.6 8-8v-24c0-17.7-14.3-32-32-32zm-639-96c0 17.7 14.3 32 32 32h574c17.7 0 32-14.3 32-32V563c0-176.2-142.8-319-319-319S193 386.8 193 563v233zm72-233c0-136.4 110.6-247 247-247s247 110.6 247 247v193H404V585c0-5.5-4.5-10-10-10h-44c-5.5 0-10 4.5-10 10v171h-75V563z\"}}]})(props);\n};\nexport function AiTwotoneApi (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M148.2 674.6zm106.7-92.3c-25 25-38.7 58.1-38.7 93.4s13.8 68.5 38.7 93.4c25 25 58.1 38.7 93.4 38.7 35.3 0 68.5-13.8 93.4-38.7l59.4-59.4-186.8-186.8-59.4 59.4zm420.8-366.1c-35.3 0-68.5 13.8-93.4 38.7l-59.4 59.4 186.8 186.8 59.4-59.4c24.9-25 38.7-58.1 38.7-93.4s-13.8-68.5-38.7-93.4c-25-25-58.1-38.7-93.4-38.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M578.9 546.7a8.03 8.03 0 0 0-11.3 0L501 613.3 410.7 523l66.7-66.7c3.1-3.1 3.1-8.2 0-11.3L441 408.6a8.03 8.03 0 0 0-11.3 0L363 475.3l-43-43a7.85 7.85 0 0 0-5.7-2.3c-2 0-4.1.8-5.7 2.3L206.8 534.2a199.45 199.45 0 0 0-58.6 140.4c-.2 39.5 11.2 79.1 34.3 113.1l-76.1 76.1a8.03 8.03 0 0 0 0 11.3l42.4 42.4c1.6 1.6 3.6 2.3 5.7 2.3s4.1-.8 5.7-2.3l76.1-76.1c33.7 22.9 72.9 34.3 112.1 34.3 51.2 0 102.4-19.5 141.5-58.6l101.9-101.9c3.1-3.1 3.1-8.2 0-11.3l-43-43 66.7-66.7c3.1-3.1 3.1-8.2 0-11.3l-36.6-36.2zM441.7 769.1a131.32 131.32 0 0 1-93.4 38.7c-35.3 0-68.4-13.7-93.4-38.7-24.9-24.9-38.7-58.1-38.7-93.4s13.7-68.4 38.7-93.4l59.4-59.4 186.8 186.8-59.4 59.4zm476-620.3l-42.4-42.4c-1.6-1.6-3.6-2.3-5.7-2.3s-4.1.8-5.7 2.3l-76.1 76.1a199.27 199.27 0 0 0-112.1-34.3c-51.2 0-102.4 19.5-141.5 58.6L432.3 308.7a8.03 8.03 0 0 0 0 11.3L704 591.7c1.6 1.6 3.6 2.3 5.7 2.3 2 0 4.1-.8 5.7-2.3l101.9-101.9c68.9-69 77-175.7 24.3-253.5l76.1-76.1c3.1-3.2 3.1-8.3 0-11.4zM769.1 441.7l-59.4 59.4-186.8-186.8 59.4-59.4c24.9-24.9 58.1-38.7 93.4-38.7s68.4 13.7 93.4 38.7c24.9 24.9 38.7 58.1 38.7 93.4s-13.8 68.4-38.7 93.4z\"}}]})(props);\n};\nexport function AiTwotoneAppstore (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M864 144H560c-8.8 0-16 7.2-16 16v304c0 8.8 7.2 16 16 16h304c8.8 0 16-7.2 16-16V160c0-8.8-7.2-16-16-16zm-52 268H612V212h200v200zM464 544H160c-8.8 0-16 7.2-16 16v304c0 8.8 7.2 16 16 16h304c8.8 0 16-7.2 16-16V560c0-8.8-7.2-16-16-16zm-52 268H212V612h200v200zm52-668H160c-8.8 0-16 7.2-16 16v304c0 8.8 7.2 16 16 16h304c8.8 0 16-7.2 16-16V160c0-8.8-7.2-16-16-16zm-52 268H212V212h200v200zm452 132H560c-8.8 0-16 7.2-16 16v304c0 8.8 7.2 16 16 16h304c8.8 0 16-7.2 16-16V560c0-8.8-7.2-16-16-16zm-52 268H612V612h200v200z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M212 212h200v200H212zm400 0h200v200H612zM212 612h200v200H212zm400 0h200v200H612z\"}}]})(props);\n};\nexport function AiTwotoneAudio (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 552c54.3 0 98-43.2 98-96V232c0-52.8-43.7-96-98-96s-98 43.2-98 96v224c0 52.8 43.7 96 98 96z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M842 454c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8 0 140.3-113.7 254-254 254S258 594.3 258 454c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8 0 168.7 126.6 307.9 290 327.6V884H326.7c-13.7 0-24.7 14.3-24.7 32v36c0 4.4 2.8 8 6.2 8h407.6c3.4 0 6.2-3.6 6.2-8v-36c0-17.7-11-32-24.7-32H548V782.1c165.3-18 294-158 294-328.1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 624c93.9 0 170-75.2 170-168V232c0-92.8-76.1-168-170-168s-170 75.2-170 168v224c0 92.8 76.1 168 170 168zm-98-392c0-52.8 43.7-96 98-96s98 43.2 98 96v224c0 52.8-43.7 96-98 96s-98-43.2-98-96V232z\"}}]})(props);\n};\nexport function AiTwotoneBank (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M240.9 393.9h542.2L512 196.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M894 462c30.9 0 43.8-39.7 18.7-58L530.8 126.2a31.81 31.81 0 0 0-37.6 0L111.3 404c-25.1 18.2-12.2 58 18.8 58H192v374h-72c-4.4 0-8 3.6-8 8v52c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-52c0-4.4-3.6-8-8-8h-72V462h62zM381 836H264V462h117v374zm189 0H453V462h117v374zm190 0H642V462h118v374zM240.9 393.9L512 196.7l271.1 197.2H240.9z\"}}]})(props);\n};\nexport function AiTwotoneBell (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 220c-55.6 0-107.8 21.6-147.1 60.9S304 372.4 304 428v340h416V428c0-55.6-21.6-107.8-60.9-147.1S567.6 220 512 220zm280 208c0-141.1-104.3-257.8-240-277.2v.1c135.7 19.4 240 136 240 277.1zM472 150.9v-.1C336.3 170.2 232 286.9 232 428c0-141.1 104.3-257.7 240-277.1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M816 768h-24V428c0-141.1-104.3-257.7-240-277.1V112c0-22.1-17.9-40-40-40s-40 17.9-40 40v38.9c-135.7 19.4-240 136-240 277.1v340h-24c-17.7 0-32 14.3-32 32v32c0 4.4 3.6 8 8 8h216c0 61.8 50.2 112 112 112s112-50.2 112-112h216c4.4 0 8-3.6 8-8v-32c0-17.7-14.3-32-32-32zM512 888c-26.5 0-48-21.5-48-48h96c0 26.5-21.5 48-48 48zm208-120H304V428c0-55.6 21.6-107.8 60.9-147.1S456.4 220 512 220c55.6 0 107.8 21.6 147.1 60.9S720 372.4 720 428v340z\"}}]})(props);\n};\nexport function AiTwotoneBook (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V96c0-17.7-14.3-32-32-32zm-260 72h96v209.9L621.5 312 572 347.4V136zM232 888V136h280v296.9c0 3.3 1 6.6 3 9.3a15.9 15.9 0 0 0 22.3 3.7l83.8-59.9 81.4 59.4c2.7 2 6 3.1 9.4 3.1 8.8 0 16-7.2 16-16V136h64v752H232z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M668 345.9V136h-96v211.4l49.5-35.4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M727.9 136v296.5c0 8.8-7.2 16-16 16-3.4 0-6.7-1.1-9.4-3.1L621.1 386l-83.8 59.9a15.9 15.9 0 0 1-22.3-3.7c-2-2.7-3-6-3-9.3V136H232v752h559.9V136h-64z\"}}]})(props);\n};\nexport function AiTwotoneBoxPlot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M296 368h88v288h-88zm152 0h280v288H448z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M952 224h-52c-4.4 0-8 3.6-8 8v248h-92V304c0-4.4-3.6-8-8-8H232c-4.4 0-8 3.6-8 8v176h-92V232c0-4.4-3.6-8-8-8H72c-4.4 0-8 3.6-8 8v560c0 4.4 3.6 8 8 8h52c4.4 0 8-3.6 8-8V548h92v172c0 4.4 3.6 8 8 8h560c4.4 0 8-3.6 8-8V548h92v244c0 4.4 3.6 8 8 8h52c4.4 0 8-3.6 8-8V232c0-4.4-3.6-8-8-8zM384 656h-88V368h88v288zm344 0H448V368h280v288z\"}}]})(props);\n};\nexport function AiTwotoneBug (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M308 412v268c0 36.779 9.678 71.962 27.805 102.907a205.39 205.39 0 0 0 73.288 73.288C440.038 874.322 475.22 884 512 884c36.779 0 71.962-9.678 102.907-27.805a205.39 205.39 0 0 0 73.288-73.288C706.322 751.962 716 716.78 716 680V412H308zm484 172v96c0 6.503-.222 12.954-.658 19.346C859.931 728.636 908 796.705 908 876a8 8 0 0 1-8 8h-56a8 8 0 0 1-8-8c0-44.24-23.94-82.888-59.57-103.697a278.635 278.635 0 0 1-22.658 49.018 281.39 281.39 0 0 1-100.45 100.45C611.84 946.072 563.546 960 512 960s-99.84-13.929-141.321-38.228a281.39 281.39 0 0 1-100.45-100.45 278.635 278.635 0 0 1-22.658-49.019C211.94 793.113 188 831.76 188 876a8 8 0 0 1-8 8h-56a8 8 0 0 1-8-8c0-79.295 48.07-147.363 116.658-176.654A284.122 284.122 0 0 1 232 680v-96H84a8 8 0 0 1-8-8v-56a8 8 0 0 1 8-8h148V412c-76.768 0-139-62.232-139-139a8 8 0 0 1 8-8h60a8 8 0 0 1 8 8c0 34.794 28.206 63 63 63h560c34.794 0 63-28.206 63-63a8 8 0 0 1 8-8h60a8 8 0 0 1 8 8c0 76.768-62.232 139-139 139v100h148a8 8 0 0 1 8 8v56a8 8 0 0 1-8 8H792zM368 272a8 8 0 0 1-8 8h-56a8 8 0 0 1-8-8c0-40.039 8.779-76.746 25.9-108.068 17.235-31.526 42.506-56.797 74.032-74.031C427.254 72.779 463.962 64 504 64h16c40.039 0 76.746 8.779 108.068 25.9 31.526 17.235 56.797 42.506 74.031 74.032C719.221 195.254 728 231.962 728 272a8 8 0 0 1-8 8h-56a8 8 0 0 1-8-8c0-28.326-5.938-53.154-17.077-73.531-10.625-19.437-25.955-34.767-45.392-45.392C573.154 141.937 548.326 136 520 136h-16c-28.326 0-53.154 5.938-73.531 17.077-19.437 10.625-34.767 25.955-45.392 45.392C373.937 218.846 368 243.674 368 272z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M308 412v268c0 36.779 9.678 71.962 27.805 102.907a205.39 205.39 0 0 0 73.288 73.288C440.038 874.322 475.22 884 512 884c36.779 0 71.962-9.678 102.907-27.805a205.39 205.39 0 0 0 73.288-73.288C706.322 751.962 716 716.78 716 680V412H308z\"}}]})(props);\n};\nexport function AiTwotoneBuild (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M144 546h200v200H144zm268-268h200v200H412z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M916 210H376c-17.7 0-32 14.3-32 32v236H108c-17.7 0-32 14.3-32 32v272c0 17.7 14.3 32 32 32h540c17.7 0 32-14.3 32-32V546h236c17.7 0 32-14.3 32-32V242c0-17.7-14.3-32-32-32zM344 746H144V546h200v200zm268 0H412V546h200v200zm0-268H412V278h200v200zm268 0H680V278h200v200z\"}}]})(props);\n};\nexport function AiTwotoneBulb (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 136c-141.4 0-256 114.6-256 256 0 92.5 49.4 176.3 128.1 221.8l35.9 20.8V752h184V634.6l35.9-20.8C718.6 568.3 768 484.5 768 392c0-141.4-114.6-256-256-256z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M632 888H392c-4.4 0-8 3.6-8 8v32c0 17.7 14.3 32 32 32h192c17.7 0 32-14.3 32-32v-32c0-4.4-3.6-8-8-8zM512 64c-181.1 0-328 146.9-328 328 0 121.4 66 227.4 164 284.1V792c0 17.7 14.3 32 32 32h264c17.7 0 32-14.3 32-32V676.1c98-56.7 164-162.7 164-284.1 0-181.1-146.9-328-328-328zm127.9 549.8L604 634.6V752H420V634.6l-35.9-20.8C305.4 568.3 256 484.5 256 392c0-141.4 114.6-256 256-256s256 114.6 256 256c0 92.5-49.4 176.3-128.1 221.8z\"}}]})(props);\n};\nexport function AiTwotoneCalculator (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h656V184H184v656zm256.2-75h-50.8c-2.2 0-4.5-1.1-5.9-2.9L348 718.6l-35.5 43.5a7.38 7.38 0 0 1-5.9 2.9h-50.8c-6.6 0-10.2-7.9-5.8-13.1l62.7-76.8-61.2-74.9c-4.3-5.2-.7-13.1 5.9-13.1h50.9c2.2 0 4.5 1.1 5.9 2.9l34 41.6 34-41.6c1.5-1.9 3.6-2.9 5.9-2.9h50.8c6.6 0 10.2 7.9 5.9 13.1L383.5 675l62.7 76.8c4.2 5.3.6 13.2-6 13.2zM576 335c0-2.2 1.4-4 3.2-4h193.5c1.9 0 3.3 1.8 3.3 4v48c0 2.2-1.4 4-3.2 4H579.2c-1.8 0-3.2-1.8-3.2-4v-48zm0 265c0-2.2 1.4-4 3.2-4h193.5c1.9 0 3.3 1.8 3.3 4v48c0 2.2-1.4 4-3.2 4H579.2c-1.8 0-3.2-1.8-3.2-4v-48zm0 104c0-2.2 1.4-4 3.2-4h193.5c1.9 0 3.3 1.8 3.3 4v48c0 2.2-1.4 4-3.2 4H579.2c-1.8 0-3.2-1.8-3.2-4v-48zM248 335c0-2.2 1.4-4 3.2-4H320v-68.8c0-1.8 1.8-3.2 4-3.2h48c2.2 0 4 1.4 4 3.2V331h68.7c1.9 0 3.3 1.8 3.3 4v48c0 2.2-1.4 4-3.2 4H376v68.7c0 1.9-1.8 3.3-4 3.3h-48c-2.2 0-4-1.4-4-3.2V387h-68.8c-1.8 0-3.2-1.8-3.2-4v-48z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M383.5 675l61.3-74.8c4.3-5.2.7-13.1-5.9-13.1h-50.8c-2.3 0-4.4 1-5.9 2.9l-34 41.6-34-41.6a7.69 7.69 0 0 0-5.9-2.9h-50.9c-6.6 0-10.2 7.9-5.9 13.1l61.2 74.9-62.7 76.8c-4.4 5.2-.8 13.1 5.8 13.1h50.8c2.3 0 4.4-1 5.9-2.9l35.5-43.5 35.5 43.5c1.4 1.8 3.7 2.9 5.9 2.9h50.8c6.6 0 10.2-7.9 6-13.2L383.5 675zM251.2 387H320v68.8c0 1.8 1.8 3.2 4 3.2h48c2.2 0 4-1.4 4-3.3V387h68.8c1.8 0 3.2-1.8 3.2-4v-48c0-2.2-1.4-4-3.3-4H376v-68.8c0-1.8-1.8-3.2-4-3.2h-48c-2.2 0-4 1.4-4 3.2V331h-68.8c-1.8 0-3.2 1.8-3.2 4v48c0 2.2 1.4 4 3.2 4zm328 369h193.6c1.8 0 3.2-1.8 3.2-4v-48c0-2.2-1.4-4-3.3-4H579.2c-1.8 0-3.2 1.8-3.2 4v48c0 2.2 1.4 4 3.2 4zm0-104h193.6c1.8 0 3.2-1.8 3.2-4v-48c0-2.2-1.4-4-3.3-4H579.2c-1.8 0-3.2 1.8-3.2 4v48c0 2.2 1.4 4 3.2 4zm0-265h193.6c1.8 0 3.2-1.8 3.2-4v-48c0-2.2-1.4-4-3.3-4H579.2c-1.8 0-3.2 1.8-3.2 4v48c0 2.2 1.4 4 3.2 4z\"}}]})(props);\n};\nexport function AiTwotoneCalendar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M712 304c0 4.4-3.6 8-8 8h-56c-4.4 0-8-3.6-8-8v-48H384v48c0 4.4-3.6 8-8 8h-56c-4.4 0-8-3.6-8-8v-48H184v136h656V256H712v48z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 184H712v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H384v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H144c-17.7 0-32 14.3-32 32v664c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V216c0-17.7-14.3-32-32-32zm-40 656H184V460h656v380zm0-448H184V256h128v48c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-48h256v48c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-48h128v136z\"}}]})(props);\n};\nexport function AiTwotoneCamera (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M864 320H677.2l-17.1-47.8-22.9-64.2H386.7l-22.9 64.2-17.1 47.8H160c-4.4 0-8 3.6-8 8v456c0 4.4 3.6 8 8 8h704c4.4 0 8-3.6 8-8V328c0-4.4-3.6-8-8-8zM512 704c-88.4 0-160-71.6-160-160s71.6-160 160-160 160 71.6 160 160-71.6 160-160 160z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 384c-88.4 0-160 71.6-160 160s71.6 160 160 160 160-71.6 160-160-71.6-160-160-160zm0 256c-53 0-96-43-96-96s43-96 96-96 96 43 96 96-43 96-96 96z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M864 248H728l-32.4-90.8a32.07 32.07 0 0 0-30.2-21.2H358.6c-13.5 0-25.6 8.5-30.1 21.2L296 248H160c-44.2 0-80 35.8-80 80v456c0 44.2 35.8 80 80 80h704c44.2 0 80-35.8 80-80V328c0-44.2-35.8-80-80-80zm8 536c0 4.4-3.6 8-8 8H160c-4.4 0-8-3.6-8-8V328c0-4.4 3.6-8 8-8h186.7l17.1-47.8 22.9-64.2h250.5l22.9 64.2 17.1 47.8H864c4.4 0 8 3.6 8 8v456z\"}}]})(props);\n};\nexport function AiTwotoneCar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M199.6 474L184 517v237h656V517l-15.6-43H199.6zM264 621c-22.1 0-40-17.9-40-40s17.9-40 40-40 40 17.9 40 40-17.9 40-40 40zm388 75c0 4.4-3.6 8-8 8H380c-4.4 0-8-3.6-8-8v-84c0-4.4 3.6-8 8-8h40c4.4 0 8 3.6 8 8v36h168v-36c0-4.4 3.6-8 8-8h40c4.4 0 8 3.6 8 8v84zm108-75c-22.1 0-40-17.9-40-40s17.9-40 40-40 40 17.9 40 40-17.9 40-40 40z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M720 581a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M959 413.4L935.3 372a8 8 0 0 0-10.9-2.9l-50.7 29.6-78.3-216.2a63.9 63.9 0 0 0-60.9-44.4H301.2c-34.7 0-65.5 22.4-76.2 55.5l-74.6 205.2-50.8-29.6a8 8 0 0 0-10.9 2.9L65 413.4c-2.2 3.8-.9 8.6 2.9 10.8l60.4 35.2-14.5 40c-1.2 3.2-1.8 6.6-1.8 10v348.2c0 15.7 11.8 28.4 26.3 28.4h67.6c12.3 0 23-9.3 25.6-22.3l7.7-37.7h545.6l7.7 37.7c2.7 13 13.3 22.3 25.6 22.3h67.6c14.5 0 26.3-12.7 26.3-28.4V509.4c0-3.4-.6-6.8-1.8-10l-14.5-40 60.3-35.2a8 8 0 0 0 3-10.8zM292.7 218.1l.5-1.3.4-1.3c1.1-3.3 4.1-5.5 7.6-5.5h427.6l75.4 208H220l72.7-199.9zM840 754H184V517l15.6-43h624.8l15.6 43v237z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M224 581a40 40 0 1 0 80 0 40 40 0 1 0-80 0zm420 23h-40c-4.4 0-8 3.6-8 8v36H428v-36c0-4.4-3.6-8-8-8h-40c-4.4 0-8 3.6-8 8v84c0 4.4 3.6 8 8 8h264c4.4 0 8-3.6 8-8v-84c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiTwotoneCarryOut (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 184H712v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H384v-64c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v64H144c-17.7 0-32 14.3-32 32v664c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V216c0-17.7-14.3-32-32-32zm-40 656H184V256h128v48c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-48h256v48c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-48h128v584z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M712 304c0 4.4-3.6 8-8 8h-56c-4.4 0-8-3.6-8-8v-48H384v48c0 4.4-3.6 8-8 8h-56c-4.4 0-8-3.6-8-8v-48H184v584h656V256H712v48zm-17.5 128.8L481.9 725.5a16.1 16.1 0 0 1-26 0l-126.4-174c-3.8-5.3 0-12.7 6.5-12.7h55.2c5.2 0 10 2.5 13 6.6l64.7 89 150.9-207.8c3-4.1 7.9-6.6 13-6.6H688c6.5 0 10.3 7.4 6.5 12.8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M688 420h-55.2c-5.1 0-10 2.5-13 6.6L468.9 634.4l-64.7-89c-3-4.1-7.8-6.6-13-6.6H336c-6.5 0-10.3 7.4-6.5 12.7l126.4 174a16.1 16.1 0 0 0 26 0l212.6-292.7c3.8-5.4 0-12.8-6.5-12.8z\"}}]})(props);\n};\nexport function AiTwotoneCheckCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm193.4 225.7l-210.6 292a31.8 31.8 0 0 1-51.7 0L318.5 484.9c-3.8-5.3 0-12.7 6.5-12.7h46.9c10.3 0 19.9 5 25.9 13.3l71.2 98.8 157.2-218c6-8.4 15.7-13.3 25.9-13.3H699c6.5 0 10.3 7.4 6.4 12.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M699 353h-46.9c-10.2 0-19.9 4.9-25.9 13.3L469 584.3l-71.2-98.8c-6-8.3-15.6-13.3-25.9-13.3H325c-6.5 0-10.3 7.4-6.5 12.7l124.6 172.8a31.8 31.8 0 0 0 51.7 0l210.6-292c3.9-5.3.1-12.7-6.4-12.7z\"}}]})(props);\n};\nexport function AiTwotoneCheckSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h656V184H184v656zm130-367.8h46.9c10.2 0 19.9 4.9 25.9 13.3l71.2 98.8 157.2-218c6-8.3 15.6-13.3 25.9-13.3H688c6.5 0 10.3 7.4 6.5 12.7l-210.6 292a31.8 31.8 0 0 1-51.7 0L307.5 484.9c-3.8-5.3 0-12.7 6.5-12.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M432.2 657.7a31.8 31.8 0 0 0 51.7 0l210.6-292c3.8-5.3 0-12.7-6.5-12.7h-46.9c-10.3 0-19.9 5-25.9 13.3L458 584.3l-71.2-98.8c-6-8.4-15.7-13.3-25.9-13.3H314c-6.5 0-10.3 7.4-6.5 12.7l124.7 172.8z\"}}]})(props);\n};\nexport function AiTwotoneCiCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm-63.5 522.8c49.3 0 82.8-29.4 87-72.4.4-4.1 3.8-7.3 8-7.3h52.7c2.4 0 4.4 2 4.4 4.4 0 77.4-64.3 132.5-152.3 132.5C345.4 720 286 651.4 286 537.4v-49C286 373.5 345.4 304 448.3 304c88.3 0 152.3 56.9 152.3 138.1 0 2.4-2 4.4-4.4 4.4h-52.6c-4.2 0-7.6-3.2-8-7.4-3.9-46.1-37.5-77.6-87-77.6-61.1 0-95.6 45.4-95.7 126.8v49.3c0 80.3 34.5 125.2 95.6 125.2zM738 704.1c0 4.4-3.6 8-8 8h-50.4c-4.4 0-8-3.6-8-8V319.9c0-4.4 3.6-8 8-8H730c4.4 0 8 3.6 8 8v384.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M730 311.9h-50.4c-4.4 0-8 3.6-8 8v384.2c0 4.4 3.6 8 8 8H730c4.4 0 8-3.6 8-8V319.9c0-4.4-3.6-8-8-8zm-281.4 49.6c49.5 0 83.1 31.5 87 77.6.4 4.2 3.8 7.4 8 7.4h52.6c2.4 0 4.4-2 4.4-4.4 0-81.2-64-138.1-152.3-138.1C345.4 304 286 373.5 286 488.4v49c0 114 59.4 182.6 162.3 182.6 88 0 152.3-55.1 152.3-132.5 0-2.4-2-4.4-4.4-4.4h-52.7c-4.2 0-7.6 3.2-8 7.3-4.2 43-37.7 72.4-87 72.4-61.1 0-95.6-44.9-95.6-125.2v-49.3c.1-81.4 34.6-126.8 95.7-126.8z\"}}]})(props);\n};\nexport function AiTwotoneCi (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm-63.5 522.8c49.3 0 82.8-29.4 87-72.4.4-4.1 3.8-7.3 8-7.3h52.7c2.4 0 4.4 2 4.4 4.4 0 77.4-64.3 132.5-152.3 132.5C345.4 720 286 651.4 286 537.4v-49C286 373.5 345.4 304 448.3 304c88.3 0 152.3 56.9 152.3 138.1 0 2.4-2 4.4-4.4 4.4h-52.6c-4.2 0-7.6-3.2-8-7.4-3.9-46.1-37.5-77.6-87-77.6-61.1 0-95.6 45.4-95.7 126.8v49.3c0 80.3 34.5 125.2 95.6 125.2zM738 704.1c0 4.4-3.6 8-8 8h-50.4c-4.4 0-8-3.6-8-8V319.9c0-4.4 3.6-8 8-8H730c4.4 0 8 3.6 8 8v384.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M730 311.9h-50.4c-4.4 0-8 3.6-8 8v384.2c0 4.4 3.6 8 8 8H730c4.4 0 8-3.6 8-8V319.9c0-4.4-3.6-8-8-8zm-281.4 49.6c49.5 0 83.1 31.5 87 77.6.4 4.2 3.8 7.4 8 7.4h52.6c2.4 0 4.4-2 4.4-4.4 0-81.2-64-138.1-152.3-138.1C345.4 304 286 373.5 286 488.4v49c0 114 59.4 182.6 162.3 182.6 88 0 152.3-55.1 152.3-132.5 0-2.4-2-4.4-4.4-4.4h-52.7c-4.2 0-7.6 3.2-8 7.3-4.2 43-37.7 72.4-87 72.4-61.1 0-95.6-44.9-95.6-125.2v-49.3c.1-81.4 34.6-126.8 95.7-126.8z\"}}]})(props);\n};\nexport function AiTwotoneClockCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm176.5 509.7l-28.6 39a7.99 7.99 0 0 1-11.2 1.7L483.3 569.8a7.92 7.92 0 0 1-3.3-6.5V288c0-4.4 3.6-8 8-8h48.1c4.4 0 8 3.6 8 8v247.5l142.6 103.1c3.6 2.5 4.4 7.5 1.8 11.1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M686.7 638.6L544.1 535.5V288c0-4.4-3.6-8-8-8H488c-4.4 0-8 3.6-8 8v275.3c0 2.6 1.2 5 3.3 6.5l165.4 120.6c3.6 2.6 8.6 1.9 11.2-1.7l28.6-39c2.6-3.6 1.8-8.6-1.8-11.1z\"}}]})(props);\n};\nexport function AiTwotoneCloseCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm171.8 527.1c1.2 1.5 1.9 3.3 1.9 5.2 0 4.5-3.6 8-8 8l-66-.3-99.3-118.4-99.3 118.5-66.1.3c-4.4 0-8-3.6-8-8 0-1.9.7-3.7 1.9-5.2L471 512.3l-130.1-155a8.32 8.32 0 0 1-1.9-5.2c0-4.5 3.6-8 8-8l66.1.3 99.3 118.4 99.4-118.5 66-.3c4.4 0 8 3.6 8 8 0 1.9-.6 3.8-1.8 5.2l-130.1 155 129.9 154.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M685.8 352c0-4.4-3.6-8-8-8l-66 .3-99.4 118.5-99.3-118.4-66.1-.3c-4.4 0-8 3.5-8 8 0 1.9.7 3.7 1.9 5.2l130.1 155-130.1 154.9a8.32 8.32 0 0 0-1.9 5.2c0 4.4 3.6 8 8 8l66.1-.3 99.3-118.5L611.7 680l66 .3c4.4 0 8-3.5 8-8 0-1.9-.7-3.7-1.9-5.2L553.9 512.2l130.1-155c1.2-1.4 1.8-3.3 1.8-5.2z\"}}]})(props);\n};\nexport function AiTwotoneCloseSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h656V184H184v656zm163.9-473.9A7.95 7.95 0 0 1 354 353h58.9c4.7 0 9.2 2.1 12.3 5.7L512 462.2l86.8-103.5c3-3.6 7.5-5.7 12.3-5.7H670c6.8 0 10.5 7.9 6.1 13.1L553.8 512l122.3 145.9c4.4 5.2.7 13.1-6.1 13.1h-58.9c-4.7 0-9.2-2.1-12.3-5.7L512 561.8l-86.8 103.5c-3 3.6-7.5 5.7-12.3 5.7H354c-6.8 0-10.5-7.9-6.1-13.1L470.2 512 347.9 366.1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M354 671h58.9c4.8 0 9.3-2.1 12.3-5.7L512 561.8l86.8 103.5c3.1 3.6 7.6 5.7 12.3 5.7H670c6.8 0 10.5-7.9 6.1-13.1L553.8 512l122.3-145.9c4.4-5.2.7-13.1-6.1-13.1h-58.9c-4.8 0-9.3 2.1-12.3 5.7L512 462.2l-86.8-103.5c-3.1-3.6-7.6-5.7-12.3-5.7H354c-6.8 0-10.5 7.9-6.1 13.1L470.2 512 347.9 657.9A7.95 7.95 0 0 0 354 671z\"}}]})(props);\n};\nexport function AiTwotoneCloud (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M791.9 492l-37.8-10-13.8-36.5c-8.6-22.7-20.6-44.1-35.7-63.4a245.73 245.73 0 0 0-52.4-49.9c-41.1-28.9-89.5-44.2-140-44.2s-98.9 15.3-140 44.2a245.6 245.6 0 0 0-52.4 49.9 240.47 240.47 0 0 0-35.7 63.4l-13.9 36.6-37.9 9.9a125.7 125.7 0 0 0-66.1 43.7A123.1 123.1 0 0 0 140 612c0 33.1 12.9 64.3 36.3 87.7 23.4 23.4 54.5 36.3 87.6 36.3h496.2c33.1 0 64.2-12.9 87.6-36.3A123.3 123.3 0 0 0 884 612c0-56.2-37.8-105.5-92.1-120z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M811.4 418.7C765.6 297.9 648.9 212 512.2 212S258.8 297.8 213 418.6C127.3 441.1 64 519.1 64 612c0 110.5 89.5 200 199.9 200h496.2C870.5 812 960 722.5 960 612c0-92.7-63.1-170.7-148.6-193.3zm36.3 281a123.07 123.07 0 0 1-87.6 36.3H263.9c-33.1 0-64.2-12.9-87.6-36.3A123.3 123.3 0 0 1 140 612c0-28 9.1-54.3 26.2-76.3a125.7 125.7 0 0 1 66.1-43.7l37.9-9.9 13.9-36.6c8.6-22.8 20.6-44.1 35.7-63.4a245.6 245.6 0 0 1 52.4-49.9c41.1-28.9 89.5-44.2 140-44.2s98.9 15.3 140 44.2c19.9 14 37.5 30.8 52.4 49.9 15.1 19.3 27.1 40.7 35.7 63.4l13.8 36.5 37.8 10c54.3 14.5 92.1 63.8 92.1 120 0 33.1-12.9 64.3-36.3 87.7z\"}}]})(props);\n};\nexport function AiTwotoneCode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h656V184H184v656zm339.5-223h185c4.1 0 7.5 3.6 7.5 8v48c0 4.4-3.4 8-7.5 8h-185c-4.1 0-7.5-3.6-7.5-8v-48c0-4.4 3.4-8 7.5-8zM308 610.3c0-2.3 1.1-4.6 2.9-6.1L420.7 512l-109.8-92.2a7.63 7.63 0 0 1-2.9-6.1V351c0-6.8 7.9-10.5 13.1-6.1l192 160.9c3.9 3.2 3.9 9.1 0 12.3l-192 161c-5.2 4.4-13.1.7-13.1-6.1v-62.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M321.1 679.1l192-161c3.9-3.2 3.9-9.1 0-12.3l-192-160.9A7.95 7.95 0 0 0 308 351v62.7c0 2.4 1 4.6 2.9 6.1L420.7 512l-109.8 92.2a8.1 8.1 0 0 0-2.9 6.1V673c0 6.8 7.9 10.5 13.1 6.1zM516 673c0 4.4 3.4 8 7.5 8h185c4.1 0 7.5-3.6 7.5-8v-48c0-4.4-3.4-8-7.5-8h-185c-4.1 0-7.5 3.6-7.5 8v48z\"}}]})(props);\n};\nexport function AiTwotoneCompass (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zM327.6 701.7c-2 .9-4.4 0-5.3-2.1-.4-1-.4-2.2 0-3.2L421 470.9 553.1 603l-225.5 98.7zm375.1-375.1L604 552.1 471.9 420l225.5-98.7c2-.9 4.4 0 5.3 2.1.4 1 .4 2.1 0 3.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M322.3 696.4c-.4 1-.4 2.2 0 3.2.9 2.1 3.3 3 5.3 2.1L553.1 603 421 470.9l-98.7 225.5zm375.1-375.1L471.9 420 604 552.1l98.7-225.5c.4-1.1.4-2.2 0-3.2-.9-2.1-3.3-3-5.3-2.1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}}]})(props);\n};\nexport function AiTwotoneContacts (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M460.3 526a51.7 52 0 1 0 103.4 0 51.7 52 0 1 0-103.4 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M768 352c0 4.4-3.6 8-8 8h-56c-4.4 0-8-3.6-8-8v-56H548v56c0 4.4-3.6 8-8 8h-56c-4.4 0-8-3.6-8-8v-56H328v56c0 4.4-3.6 8-8 8h-56c-4.4 0-8-3.6-8-8v-56H136v496h752V296H768v56zM661 736h-43.8c-4.2 0-7.6-3.3-7.9-7.5-3.8-50.5-46-90.5-97.2-90.5s-93.4 39.9-97.2 90.5c-.3 4.2-3.7 7.5-7.9 7.5h-43.9a8 8 0 0 1-8-8.4c2.8-53.3 31.9-99.6 74.6-126.1-18.1-20-29.1-46.4-29.1-75.5 0-61.9 49.9-112 111.4-112s111.4 50.1 111.4 112c0 29.1-11 55.6-29.1 75.5 42.7 26.4 71.9 72.8 74.7 126.1a8 8 0 0 1-8 8.4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M594.3 601.5a111.8 111.8 0 0 0 29.1-75.5c0-61.9-49.9-112-111.4-112s-111.4 50.1-111.4 112c0 29.1 11 55.5 29.1 75.5a158.09 158.09 0 0 0-74.6 126.1 8 8 0 0 0 8 8.4H407c4.2 0 7.6-3.3 7.9-7.5 3.8-50.6 46-90.5 97.2-90.5s93.4 40 97.2 90.5c.3 4.2 3.7 7.5 7.9 7.5H661a8 8 0 0 0 8-8.4c-2.8-53.3-32-99.7-74.7-126.1zM512 578c-28.5 0-51.7-23.3-51.7-52s23.2-52 51.7-52 51.7 23.3 51.7 52-23.2 52-51.7 52z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M928 224H768v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H548v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H328v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H96c-17.7 0-32 14.3-32 32v576c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V256c0-17.7-14.3-32-32-32zm-40 568H136V296h120v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56h148v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56h148v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56h120v496z\"}}]})(props);\n};\nexport function AiTwotoneContainer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M635 771.7c-34.5 28.6-78.2 44.3-123 44.3s-88.5-15.8-123-44.3a194.02 194.02 0 0 1-59.1-84.7H232v201h560V687h-97.9c-11.6 32.8-32 62.3-59.1 84.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M320 501h384c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H320c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V96c0-17.7-14.3-32-32-32zm-40 824H232V687h97.9c11.6 32.8 32 62.3 59.1 84.7 34.5 28.5 78.2 44.3 123 44.3s88.5-15.7 123-44.3c27.1-22.4 47.5-51.9 59.1-84.7H792v201zm0-264H643.6l-5.2 24.7C626.4 708.5 573.2 752 512 752s-114.4-43.5-126.5-103.3l-5.2-24.7H232V136h560v488z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M320 341h384c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H320c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiTwotoneControl (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M616 440a36 36 0 1 0 72 0 36 36 0 1 0-72 0zM340.4 601.5l1.5 2.4c0 .1.1.1.1.2l.9 1.2c.1.1.2.2.2.3 1 1.3 2 2.5 3.2 3.6l.2.2c.4.4.8.8 1.2 1.1.8.8 1.7 1.5 2.6 2.1h.1l1.2.9c.1.1.3.2.4.3 1.2.8 2.5 1.6 3.9 2.2.2.1.5.2.7.4.4.2.7.3 1.1.5.3.1.7.3 1 .4.5.2 1 .4 1.5.5.4.1.9.3 1.3.4l.9.3 1.4.3c.2.1.5.1.7.2.7.1 1.4.3 2.1.4.2 0 .4 0 .6.1.6.1 1.1.1 1.7.2.2 0 .4 0 .7.1.8 0 1.5.1 2.3.1s1.5 0 2.3-.1c.2 0 .4 0 .7-.1.6 0 1.2-.1 1.7-.2.2 0 .4 0 .6-.1.7-.1 1.4-.2 2.1-.4.2-.1.5-.1.7-.2l1.4-.3.9-.3c.4-.1.9-.3 1.3-.4.5-.2 1-.4 1.5-.5.3-.1.7-.3 1-.4.4-.2.7-.3 1.1-.5.2-.1.5-.2.7-.4 1.3-.7 2.6-1.4 3.9-2.2.1-.1.3-.2.4-.3l1.2-.9h.1c.9-.7 1.8-1.4 2.6-2.1.4-.4.8-.7 1.2-1.1l.2-.2c1.1-1.1 2.2-2.4 3.2-3.6.1-.1.2-.2.2-.3l.9-1.2c0-.1.1-.1.1-.2l1.5-2.4c.1-.2.2-.3.3-.5 2.7-5.1 4.3-10.9 4.3-17s-1.6-12-4.3-17c-.1-.2-.2-.4-.3-.5l-1.5-2.4c0-.1-.1-.1-.1-.2l-.9-1.2c-.1-.1-.2-.2-.2-.3-1-1.3-2-2.5-3.2-3.6l-.2-.2c-.4-.4-.8-.8-1.2-1.1-.8-.8-1.7-1.5-2.6-2.1h-.1l-1.2-.9c-.1-.1-.3-.2-.4-.3-1.2-.8-2.5-1.6-3.9-2.2-.2-.1-.5-.2-.7-.4-.4-.2-.7-.3-1.1-.5-.3-.1-.7-.3-1-.4-.5-.2-1-.4-1.5-.5-.4-.1-.9-.3-1.3-.4l-.9-.3-1.4-.3c-.2-.1-.5-.1-.7-.2-.7-.1-1.4-.3-2.1-.4-.2 0-.4 0-.6-.1-.6-.1-1.1-.1-1.7-.2-.2 0-.4 0-.7-.1-.8 0-1.5-.1-2.3-.1s-1.5 0-2.3.1c-.2 0-.4 0-.7.1-.6 0-1.2.1-1.7.2-.2 0-.4 0-.6.1-.7.1-1.4.2-2.1.4-.2.1-.5.1-.7.2l-1.4.3-.9.3c-.4.1-.9.3-1.3.4-.5.2-1 .4-1.5.5-.3.1-.7.3-1 .4-.4.2-.7.3-1.1.5-.2.1-.5.2-.7.4-1.3.7-2.6 1.4-3.9 2.2-.1.1-.3.2-.4.3l-1.2.9h-.1c-.9.7-1.8 1.4-2.6 2.1-.4.4-.8.7-1.2 1.1l-.2.2a54.8 54.8 0 0 0-3.2 3.6c-.1.1-.2.2-.2.3l-.9 1.2c0 .1-.1.1-.1.2l-1.5 2.4c-.1.2-.2.3-.3.5-2.7 5.1-4.3 10.9-4.3 17s1.6 12 4.3 17c.1.2.2.3.3.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h656V184H184v656zm436.4-499.1c-.2 0-.3.1-.4.1v-77c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v77c-.2 0-.3-.1-.4-.1 42 13.4 72.4 52.7 72.4 99.1 0 46.4-30.4 85.7-72.4 99.1.2 0 .3-.1.4-.1v221c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V539c.2 0 .3.1.4.1-42-13.4-72.4-52.7-72.4-99.1 0-46.4 30.4-85.7 72.4-99.1zM340 485V264c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v221c41.7 13.6 72 52.8 72 99s-30.3 85.5-72 99v77c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8v-77c-41.7-13.6-72-52.8-72-99s30.3-85.5 72-99z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M340 683v77c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-77c41.7-13.5 72-52.8 72-99s-30.3-85.4-72-99V264c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v221c-41.7 13.5-72 52.8-72 99s30.3 85.4 72 99zm.1-116c.1-.2.2-.3.3-.5l1.5-2.4c0-.1.1-.1.1-.2l.9-1.2c0-.1.1-.2.2-.3 1-1.2 2.1-2.5 3.2-3.6l.2-.2c.4-.4.8-.7 1.2-1.1.8-.7 1.7-1.4 2.6-2.1h.1l1.2-.9c.1-.1.3-.2.4-.3 1.3-.8 2.6-1.5 3.9-2.2.2-.2.5-.3.7-.4.4-.2.7-.3 1.1-.5.3-.1.7-.3 1-.4.5-.1 1-.3 1.5-.5.4-.1.9-.3 1.3-.4l.9-.3 1.4-.3c.2-.1.5-.1.7-.2.7-.2 1.4-.3 2.1-.4.2-.1.4-.1.6-.1.5-.1 1.1-.2 1.7-.2.3-.1.5-.1.7-.1.8-.1 1.5-.1 2.3-.1s1.5.1 2.3.1c.3.1.5.1.7.1.6.1 1.1.1 1.7.2.2.1.4.1.6.1.7.1 1.4.3 2.1.4.2.1.5.1.7.2l1.4.3.9.3c.4.1.9.3 1.3.4.5.1 1 .3 1.5.5.3.1.7.3 1 .4.4.2.7.3 1.1.5.2.2.5.3.7.4 1.4.6 2.7 1.4 3.9 2.2.1.1.3.2.4.3l1.2.9h.1c.9.6 1.8 1.3 2.6 2.1.4.3.8.7 1.2 1.1l.2.2c1.2 1.1 2.2 2.3 3.2 3.6 0 .1.1.2.2.3l.9 1.2c0 .1.1.1.1.2l1.5 2.4A36.03 36.03 0 0 1 408 584c0 6.1-1.6 11.9-4.3 17-.1.2-.2.3-.3.5l-1.5 2.4c0 .1-.1.1-.1.2l-.9 1.2c0 .1-.1.2-.2.3-1 1.2-2.1 2.5-3.2 3.6l-.2.2c-.4.4-.8.7-1.2 1.1-.8.7-1.7 1.4-2.6 2.1h-.1l-1.2.9c-.1.1-.3.2-.4.3-1.3.8-2.6 1.5-3.9 2.2-.2.2-.5.3-.7.4-.4.2-.7.3-1.1.5-.3.1-.7.3-1 .4-.5.1-1 .3-1.5.5-.4.1-.9.3-1.3.4l-.9.3-1.4.3c-.2.1-.5.1-.7.2-.7.2-1.4.3-2.1.4-.2.1-.4.1-.6.1-.5.1-1.1.2-1.7.2-.3.1-.5.1-.7.1-.8.1-1.5.1-2.3.1s-1.5-.1-2.3-.1c-.3-.1-.5-.1-.7-.1-.6-.1-1.1-.1-1.7-.2-.2-.1-.4-.1-.6-.1-.7-.1-1.4-.3-2.1-.4-.2-.1-.5-.1-.7-.2l-1.4-.3-.9-.3c-.4-.1-.9-.3-1.3-.4-.5-.1-1-.3-1.5-.5-.3-.1-.7-.3-1-.4-.4-.2-.7-.3-1.1-.5-.2-.2-.5-.3-.7-.4-1.4-.6-2.7-1.4-3.9-2.2-.1-.1-.3-.2-.4-.3l-1.2-.9h-.1c-.9-.6-1.8-1.3-2.6-2.1-.4-.3-.8-.7-1.2-1.1l-.2-.2c-1.2-1.1-2.2-2.3-3.2-3.6 0-.1-.1-.2-.2-.3l-.9-1.2c0-.1-.1-.1-.1-.2l-1.5-2.4c-.1-.2-.2-.3-.3-.5-2.7-5-4.3-10.9-4.3-17s1.6-11.9 4.3-17zm280.3-27.9c-.1 0-.2-.1-.4-.1v221c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V539c-.1 0-.2.1-.4.1 42-13.4 72.4-52.7 72.4-99.1 0-46.4-30.4-85.7-72.4-99.1.1 0 .2.1.4.1v-77c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v77c.1 0 .2-.1.4-.1-42 13.4-72.4 52.7-72.4 99.1 0 46.4 30.4 85.7 72.4 99.1zM652 404c19.9 0 36 16.1 36 36s-16.1 36-36 36-36-16.1-36-36 16.1-36 36-36z\"}}]})(props);\n};\nexport function AiTwotoneCopy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M232 706h142c22.1 0 40 17.9 40 40v142h250V264H232v442z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H296c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h496v688c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V96c0-17.7-14.3-32-32-32z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M704 192H192c-17.7 0-32 14.3-32 32v530.7c0 8.5 3.4 16.6 9.4 22.6l173.3 173.3c2.2 2.2 4.7 4 7.4 5.5v1.9h4.2c3.5 1.3 7.2 2 11 2H704c17.7 0 32-14.3 32-32V224c0-17.7-14.3-32-32-32zM350 856.2L263.9 770H350v86.2zM664 888H414V746c0-22.1-17.9-40-40-40H232V264h432v624z\"}}]})(props);\n};\nexport function AiTwotoneCopyrightCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm5.5 533c52.9 0 88.8-31.7 93-77.8.4-4.1 3.8-7.3 8-7.3h56.8c2.6 0 4.7 2.1 4.7 4.7 0 82.6-68.7 141.4-162.7 141.4C407.4 734 344 660.8 344 539.1v-52.3C344 364.2 407.4 290 517.3 290c94.3 0 162.7 60.7 162.7 147.4 0 2.6-2.1 4.7-4.7 4.7h-56.7c-4.2 0-7.7-3.2-8-7.4-4-49.6-40-83.4-93-83.4-65.2 0-102.1 48.5-102.2 135.5v52.6c0 85.7 36.8 133.6 102.1 133.6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M517.6 351.3c53 0 89 33.8 93 83.4.3 4.2 3.8 7.4 8 7.4h56.7c2.6 0 4.7-2.1 4.7-4.7 0-86.7-68.4-147.4-162.7-147.4C407.4 290 344 364.2 344 486.8v52.3C344 660.8 407.4 734 517.3 734c94 0 162.7-58.8 162.7-141.4 0-2.6-2.1-4.7-4.7-4.7h-56.8c-4.2 0-7.6 3.2-8 7.3-4.2 46.1-40.1 77.8-93 77.8-65.3 0-102.1-47.9-102.1-133.6v-52.6c.1-87 37-135.5 102.2-135.5z\"}}]})(props);\n};\nexport function AiTwotoneCopyright (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm5.5 533c52.9 0 88.8-31.7 93-77.8.4-4.1 3.8-7.3 8-7.3h56.8c2.6 0 4.7 2.1 4.7 4.7 0 82.6-68.7 141.4-162.7 141.4C407.4 734 344 660.8 344 539.1v-52.3C344 364.2 407.4 290 517.3 290c94.3 0 162.7 60.7 162.7 147.4 0 2.6-2.1 4.7-4.7 4.7h-56.7c-4.2 0-7.7-3.2-8-7.4-4-49.6-40-83.4-93-83.4-65.2 0-102.1 48.5-102.2 135.5v52.6c0 85.7 36.8 133.6 102.1 133.6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M517.6 351.3c53 0 89 33.8 93 83.4.3 4.2 3.8 7.4 8 7.4h56.7c2.6 0 4.7-2.1 4.7-4.7 0-86.7-68.4-147.4-162.7-147.4C407.4 290 344 364.2 344 486.8v52.3C344 660.8 407.4 734 517.3 734c94 0 162.7-58.8 162.7-141.4 0-2.6-2.1-4.7-4.7-4.7h-56.8c-4.2 0-7.6 3.2-8 7.3-4.2 46.1-40.1 77.8-93 77.8-65.3 0-102.1-47.9-102.1-133.6v-52.6c.1-87 37-135.5 102.2-135.5z\"}}]})(props);\n};\nexport function AiTwotoneCreditCard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M136 792h752V440H136v352zm507-144c0-4.4 3.6-8 8-8h165c4.4 0 8 3.6 8 8v72c0 4.4-3.6 8-8 8H651c-4.4 0-8-3.6-8-8v-72zM136 232h752v120H136z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M651 728h165c4.4 0 8-3.6 8-8v-72c0-4.4-3.6-8-8-8H651c-4.4 0-8 3.6-8 8v72c0 4.4 3.6 8 8 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M928 160H96c-17.7 0-32 14.3-32 32v640c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V192c0-17.7-14.3-32-32-32zm-40 632H136V440h752v352zm0-440H136V232h752v120z\"}}]})(props);\n};\nexport function AiTwotoneCrown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M911.9 283.9v.5L835.5 865c-1 8-7.9 14-15.9 14H204.5c-8.1 0-14.9-6.1-16-14l-76.4-580.6v-.6 1.6L188.5 866c1.1 7.9 7.9 14 16 14h615.1c8 0 14.9-6 15.9-14l76.4-580.6c.1-.5.1-1 0-1.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M773.6 810.6l53.9-409.4-139.8 86.1L512 252.9 336.3 487.3l-139.8-86.1 53.8 409.4h523.3zm-374.2-189c0-62.1 50.5-112.6 112.6-112.6s112.6 50.5 112.6 112.6v1c0 62.1-50.5 112.6-112.6 112.6s-112.6-50.5-112.6-112.6v-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 734.2c61.9 0 112.3-50.2 112.6-112.1v-.5c0-62.1-50.5-112.6-112.6-112.6s-112.6 50.5-112.6 112.6v.5c.3 61.9 50.7 112.1 112.6 112.1zm0-160.9c26.6 0 48.2 21.6 48.2 48.3 0 26.6-21.6 48.3-48.2 48.3s-48.2-21.6-48.2-48.3c0-26.6 21.6-48.3 48.2-48.3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M188.5 865c1.1 7.9 7.9 14 16 14h615.1c8 0 14.9-6 15.9-14l76.4-580.6v-.5c.3-6.4-6.7-10.8-12.3-7.4L705 396.4 518.4 147.5a8.06 8.06 0 0 0-12.9 0L319 396.4 124.3 276.5c-5.5-3.4-12.6.9-12.2 7.3v.6L188.5 865zm147.8-377.7L512 252.9l175.7 234.4 139.8-86.1-53.9 409.4H250.3l-53.8-409.4 139.8 86.1z\"}}]})(props);\n};\nexport function AiTwotoneCustomerService (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M696 632h128v192H696zm-496 0h128v192H200z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 128c-212.1 0-384 171.9-384 384v360c0 13.3 10.7 24 24 24h184c35.3 0 64-28.7 64-64V624c0-35.3-28.7-64-64-64H200v-48c0-172.3 139.7-312 312-312s312 139.7 312 312v48H688c-35.3 0-64 28.7-64 64v208c0 35.3 28.7 64 64 64h184c13.3 0 24-10.7 24-24V512c0-212.1-171.9-384-384-384zM328 632v192H200V632h128zm496 192H696V632h128v192z\"}}]})(props);\n};\nexport function AiTwotoneDashboard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 188c-99.3 0-192.7 38.7-263 109-70.3 70.2-109 163.6-109 263 0 105.6 44.5 205.5 122.6 276h498.8A371.12 371.12 0 0 0 884 560c0-99.3-38.7-192.7-109-263-70.2-70.3-163.6-109-263-109zm-30 44c0-4.4 3.6-8 8-8h44c4.4 0 8 3.6 8 8v80c0 4.4-3.6 8-8 8h-44c-4.4 0-8-3.6-8-8v-80zM270 582c0 4.4-3.6 8-8 8h-80c-4.4 0-8-3.6-8-8v-44c0-4.4 3.6-8 8-8h80c4.4 0 8 3.6 8 8v44zm90.7-204.4l-31.1 31.1a8.03 8.03 0 0 1-11.3 0l-56.6-56.6a8.03 8.03 0 0 1 0-11.3l31.1-31.1c3.1-3.1 8.2-3.1 11.3 0l56.6 56.6c3.1 3.1 3.1 8.2 0 11.3zm291.1 83.5l-84.5 84.5c5 18.7.2 39.4-14.5 54.1a55.95 55.95 0 0 1-79.2 0 55.95 55.95 0 0 1 0-79.2 55.87 55.87 0 0 1 54.1-14.5l84.5-84.5c3.1-3.1 8.2-3.1 11.3 0l28.3 28.3c3.1 3.1 3.1 8.2 0 11.3zm43-52.4l-31.1-31.1a8.03 8.03 0 0 1 0-11.3l56.6-56.6c3.1-3.1 8.2-3.1 11.3 0l31.1 31.1c3.1 3.1 3.1 8.2 0 11.3l-56.6 56.6a8.03 8.03 0 0 1-11.3 0zM846 538v44c0 4.4-3.6 8-8 8h-80c-4.4 0-8-3.6-8-8v-44c0-4.4 3.6-8 8-8h80c4.4 0 8 3.6 8 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M623.5 421.5a8.03 8.03 0 0 0-11.3 0L527.7 506c-18.7-5-39.4-.2-54.1 14.5a55.95 55.95 0 0 0 0 79.2 55.95 55.95 0 0 0 79.2 0 55.87 55.87 0 0 0 14.5-54.1l84.5-84.5c3.1-3.1 3.1-8.2 0-11.3l-28.3-28.3zM490 320h44c4.4 0 8-3.6 8-8v-80c0-4.4-3.6-8-8-8h-44c-4.4 0-8 3.6-8 8v80c0 4.4 3.6 8 8 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M924.8 385.6a446.7 446.7 0 0 0-96-142.4 446.7 446.7 0 0 0-142.4-96C631.1 123.8 572.5 112 512 112s-119.1 11.8-174.4 35.2a446.7 446.7 0 0 0-142.4 96 446.7 446.7 0 0 0-96 142.4C75.8 440.9 64 499.5 64 560c0 132.7 58.3 257.7 159.9 343.1l1.7 1.4c5.8 4.8 13.1 7.5 20.6 7.5h531.7c7.5 0 14.8-2.7 20.6-7.5l1.7-1.4C901.7 817.7 960 692.7 960 560c0-60.5-11.9-119.1-35.2-174.4zM761.4 836H262.6A371.12 371.12 0 0 1 140 560c0-99.4 38.7-192.8 109-263 70.3-70.3 163.7-109 263-109 99.4 0 192.8 38.7 263 109 70.3 70.3 109 163.7 109 263 0 105.6-44.5 205.5-122.6 276z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M762.7 340.8l-31.1-31.1a8.03 8.03 0 0 0-11.3 0l-56.6 56.6a8.03 8.03 0 0 0 0 11.3l31.1 31.1c3.1 3.1 8.2 3.1 11.3 0l56.6-56.6c3.1-3.1 3.1-8.2 0-11.3zM750 538v44c0 4.4 3.6 8 8 8h80c4.4 0 8-3.6 8-8v-44c0-4.4-3.6-8-8-8h-80c-4.4 0-8 3.6-8 8zM304.1 309.7a8.03 8.03 0 0 0-11.3 0l-31.1 31.1a8.03 8.03 0 0 0 0 11.3l56.6 56.6c3.1 3.1 8.2 3.1 11.3 0l31.1-31.1c3.1-3.1 3.1-8.2 0-11.3l-56.6-56.6zM262 530h-80c-4.4 0-8 3.6-8 8v44c0 4.4 3.6 8 8 8h80c4.4 0 8-3.6 8-8v-44c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiTwotoneDatabase (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M232 616h560V408H232v208zm112-144c22.1 0 40 17.9 40 40s-17.9 40-40 40-40-17.9-40-40 17.9-40 40-40zM232 888h560V680H232v208zm112-144c22.1 0 40 17.9 40 40s-17.9 40-40 40-40-17.9-40-40 17.9-40 40-40zM232 344h560V136H232v208zm112-144c22.1 0 40 17.9 40 40s-17.9 40-40 40-40-17.9-40-40 17.9-40 40-40z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M304 512a40 40 0 1 0 80 0 40 40 0 1 0-80 0zm0 272a40 40 0 1 0 80 0 40 40 0 1 0-80 0zm0-544a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V96c0-17.7-14.3-32-32-32zm-40 824H232V680h560v208zm0-272H232V408h560v208zm0-272H232V136h560v208z\"}}]})(props);\n};\nexport function AiTwotoneDelete (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M292.7 840h438.6l24.2-512h-487z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M864 256H736v-80c0-35.3-28.7-64-64-64H352c-35.3 0-64 28.7-64 64v80H160c-17.7 0-32 14.3-32 32v32c0 4.4 3.6 8 8 8h60.4l24.7 523c1.6 34.1 29.8 61 63.9 61h454c34.2 0 62.3-26.8 63.9-61l24.7-523H888c4.4 0 8-3.6 8-8v-32c0-17.7-14.3-32-32-32zm-504-72h304v72H360v-72zm371.3 656H292.7l-24.2-512h487l-24.2 512z\"}}]})(props);\n};\nexport function AiTwotoneDiff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M232 264v624h432V413.8L514.2 264H232zm336 489c0 3.8-3.4 7-7.5 7h-225c-4.1 0-7.5-3.2-7.5-7v-42c0-3.8 3.4-7 7.5-7h225c4.1 0 7.5 3.2 7.5 7v42zm0-262v42c0 3.8-3.4 7-7.5 7H476v84.9c0 3.9-3.1 7.1-7 7.1h-42c-3.8 0-7-3.2-7-7.1V540h-84.5c-4.1 0-7.5-3.2-7.5-7v-42c0-3.9 3.4-7 7.5-7H420v-84.9c0-3.9 3.2-7.1 7-7.1h42c3.9 0 7 3.2 7 7.1V484h84.5c4.1 0 7.5 3.1 7.5 7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M854.2 306.6L611.3 72.9c-6-5.7-13.9-8.9-22.2-8.9H296c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h277l219 210.6V824c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V329.6c0-8.7-3.5-17-9.8-23z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M553.4 201.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v704c0 17.7 14.3 32 32 32h512c17.7 0 32-14.3 32-32V397.3c0-8.5-3.4-16.6-9.4-22.6L553.4 201.4zM664 888H232V264h282.2L664 413.8V888z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M476 399.1c0-3.9-3.1-7.1-7-7.1h-42c-3.8 0-7 3.2-7 7.1V484h-84.5c-4.1 0-7.5 3.1-7.5 7v42c0 3.8 3.4 7 7.5 7H420v84.9c0 3.9 3.2 7.1 7 7.1h42c3.9 0 7-3.2 7-7.1V540h84.5c4.1 0 7.5-3.2 7.5-7v-42c0-3.9-3.4-7-7.5-7H476v-84.9zM560.5 704h-225c-4.1 0-7.5 3.2-7.5 7v42c0 3.8 3.4 7 7.5 7h225c4.1 0 7.5-3.2 7.5-7v-42c0-3.8-3.4-7-7.5-7z\"}}]})(props);\n};\nexport function AiTwotoneDislike (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M273 100.1v428h.3l-.3-428zM820.4 525l-21.9-19 14-25.5a56.2 56.2 0 0 0 6.9-27.3c0-16.5-7.1-32.2-19.6-43l-21.9-19 13.9-25.4a56.2 56.2 0 0 0 6.9-27.3c0-16.5-7.1-32.2-19.6-43l-21.9-19 13.9-25.4a56.2 56.2 0 0 0 6.9-27.3c0-22.4-13.2-42.6-33.6-51.8H345v345.2c18.6 67.2 46.4 168 83.5 302.5a44.28 44.28 0 0 0 42.2 32.3c7.5.1 15-2.2 21.1-6.7 9.9-7.4 15.2-18.6 14.6-30.5l-9.6-198.4h314.4C829 605.5 840 587.1 840 568c0-16.5-7.1-32.2-19.6-43z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M112 132v364c0 17.7 14.3 32 32 32h65V100h-65c-17.7 0-32 14.3-32 32zm773.9 358.3c3.6-12 5.4-24.4 5.4-37 0-28.3-9.3-55.5-26.1-77.7 3.6-12 5.4-24.4 5.4-37 0-28.3-9.3-55.5-26.1-77.7 3.6-12 5.4-24.4 5.4-37 0-51.6-30.7-98.1-78.3-118.4a66.1 66.1 0 0 0-26.5-5.4H273l.3 428 85.8 310.8C372.9 889 418.9 924 470.9 924c29.7 0 57.4-11.8 77.9-33.4 20.5-21.5 31-49.7 29.5-79.4l-6-122.9h239.9c12.1 0 23.9-3.2 34.3-9.3 40.4-23.5 65.5-66.1 65.5-111 0-28.3-9.3-55.5-26.1-77.7zm-74.7 126.1H496.8l9.6 198.4c.6 11.9-4.7 23.1-14.6 30.5-6.1 4.5-13.6 6.8-21.1 6.7a44.28 44.28 0 0 1-42.2-32.3c-37.1-134.4-64.9-235.2-83.5-302.5V172h399.4a56.85 56.85 0 0 1 33.6 51.8c0 9.7-2.3 18.9-6.9 27.3l-13.9 25.4 21.9 19a56.76 56.76 0 0 1 19.6 43c0 9.7-2.3 18.9-6.9 27.3l-13.9 25.4 21.9 19a56.76 56.76 0 0 1 19.6 43c0 9.7-2.3 18.9-6.9 27.3l-14 25.5 21.9 19a56.76 56.76 0 0 1 19.6 43c0 19.1-11 37.5-28.8 48.4z\"}}]})(props);\n};\nexport function AiTwotoneDollarCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M426.6 410.3c0 25.4 15.7 45.1 49.5 57.3 4.7 1.9 9.4 3.4 15 5v-124c-37 4.7-64.5 25.4-64.5 61.7zm116.5 135.2c-2.9-.6-5.7-1.3-8.8-2.2V677c42.6-3.8 72-27.3 72-66.4 0-30.7-15.9-50.7-63.2-65.1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm22.4 589.2l.2 31.7c0 4.5-3.6 8.1-8 8.1h-28.4c-4.4 0-8-3.6-8-8v-31.4c-89-6.5-130.7-57.1-135.2-112.1-.4-4.7 3.3-8.7 8-8.7h46.2c3.9 0 7.3 2.8 7.9 6.6 5.1 31.8 29.9 55.4 74.1 61.3V534l-24.7-6.3c-52.3-12.5-102.1-45.1-102.1-112.7 0-73 55.4-112.1 126.2-119v-33c0-4.4 3.6-8 8-8h28.1c4.4 0 8 3.6 8 8v32.7c68.5 6.9 119.8 46.9 125.9 109.2a8.1 8.1 0 0 1-8 8.8h-44.9c-4 0-7.4-2.9-7.9-6.9-4-29.2-27.5-53-65.5-58.2v134.3l25.4 5.9c64.8 16 108.9 47 109 116.4 0 75.2-56 117.1-134.3 124z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M559.7 488.8l-25.4-5.9V348.6c38 5.2 61.5 29 65.5 58.2.5 4 3.9 6.9 7.9 6.9h44.9c4.7 0 8.4-4.1 8-8.8-6.1-62.3-57.4-102.3-125.9-109.2V263c0-4.4-3.6-8-8-8h-28.1c-4.4 0-8 3.6-8 8v33c-70.8 6.9-126.2 46-126.2 119 0 67.6 49.8 100.2 102.1 112.7l24.7 6.3v142.7c-44.2-5.9-69-29.5-74.1-61.3-.6-3.8-4-6.6-7.9-6.6H363c-4.7 0-8.4 4-8 8.7 4.5 55 46.2 105.6 135.2 112.1V761c0 4.4 3.6 8 8 8h28.4c4.4 0 8-3.6 8-8.1l-.2-31.7c78.3-6.9 134.3-48.8 134.3-124-.1-69.4-44.2-100.4-109-116.4zm-68.6-16.2c-5.6-1.6-10.3-3.1-15-5-33.8-12.2-49.5-31.9-49.5-57.3 0-36.3 27.5-57 64.5-61.7v124zM534.3 677V543.3c3.1.9 5.9 1.6 8.8 2.2 47.3 14.4 63.2 34.4 63.2 65.1 0 39.1-29.4 62.6-72 66.4z\"}}]})(props);\n};\nexport function AiTwotoneDollar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M426.6 410.3c0 25.4 15.7 45.1 49.5 57.3 4.7 1.9 9.4 3.4 15 5v-124c-37 4.7-64.5 25.4-64.5 61.7zm116.5 135.2c-2.9-.6-5.7-1.3-8.8-2.2V677c42.6-3.8 72-27.3 72-66.4 0-30.7-15.9-50.7-63.2-65.1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm22.4 589.2l.2 31.7c0 4.5-3.6 8.1-8 8.1h-28.4c-4.4 0-8-3.6-8-8v-31.4c-89-6.5-130.7-57.1-135.2-112.1-.4-4.7 3.3-8.7 8-8.7h46.2c3.9 0 7.3 2.8 7.9 6.6 5.1 31.8 29.9 55.4 74.1 61.3V534l-24.7-6.3c-52.3-12.5-102.1-45.1-102.1-112.7 0-73 55.4-112.1 126.2-119v-33c0-4.4 3.6-8 8-8h28.1c4.4 0 8 3.6 8 8v32.7c68.5 6.9 119.8 46.9 125.9 109.2a8.1 8.1 0 0 1-8 8.8h-44.9c-4 0-7.4-2.9-7.9-6.9-4-29.2-27.5-53-65.5-58.2v134.3l25.4 5.9c64.8 16 108.9 47 109 116.4 0 75.2-56 117.1-134.3 124z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M559.7 488.8l-25.4-5.9V348.6c38 5.2 61.5 29 65.5 58.2.5 4 3.9 6.9 7.9 6.9h44.9c4.7 0 8.4-4.1 8-8.8-6.1-62.3-57.4-102.3-125.9-109.2V263c0-4.4-3.6-8-8-8h-28.1c-4.4 0-8 3.6-8 8v33c-70.8 6.9-126.2 46-126.2 119 0 67.6 49.8 100.2 102.1 112.7l24.7 6.3v142.7c-44.2-5.9-69-29.5-74.1-61.3-.6-3.8-4-6.6-7.9-6.6H363c-4.7 0-8.4 4-8 8.7 4.5 55 46.2 105.6 135.2 112.1V761c0 4.4 3.6 8 8 8h28.4c4.4 0 8-3.6 8-8.1l-.2-31.7c78.3-6.9 134.3-48.8 134.3-124-.1-69.4-44.2-100.4-109-116.4zm-68.6-16.2c-5.6-1.6-10.3-3.1-15-5-33.8-12.2-49.5-31.9-49.5-57.3 0-36.3 27.5-57 64.5-61.7v124zM534.3 677V543.3c3.1.9 5.9 1.6 8.8 2.2 47.3 14.4 63.2 34.4 63.2 65.1 0 39.1-29.4 62.6-72 66.4z\"}}]})(props);\n};\nexport function AiTwotoneDownCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm184.4 277.7l-178 246a7.95 7.95 0 0 1-12.9 0l-178-246c-3.8-5.3 0-12.7 6.5-12.7h46.9c10.3 0 19.9 4.9 25.9 13.2L512 563.6l105.2-145.4c6-8.3 15.7-13.2 25.9-13.2H690c6.5 0 10.3 7.4 6.4 12.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M690 405h-46.9c-10.2 0-19.9 4.9-25.9 13.2L512 563.6 406.8 418.2c-6-8.3-15.6-13.2-25.9-13.2H334c-6.5 0-10.3 7.4-6.5 12.7l178 246c3.2 4.4 9.7 4.4 12.9 0l178-246c3.9-5.3.1-12.7-6.4-12.7z\"}}]})(props);\n};\nexport function AiTwotoneDownSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h656V184H184v656zm150-440h46.9c10.3 0 19.9 4.9 25.9 13.2L512 558.6l105.2-145.4c6-8.3 15.7-13.2 25.9-13.2H690c6.5 0 10.3 7.4 6.4 12.7l-178 246a7.95 7.95 0 0 1-12.9 0l-178-246c-3.8-5.3 0-12.7 6.5-12.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M505.5 658.7c3.2 4.4 9.7 4.4 12.9 0l178-246c3.9-5.3.1-12.7-6.4-12.7h-46.9c-10.2 0-19.9 4.9-25.9 13.2L512 558.6 406.8 413.2c-6-8.3-15.6-13.2-25.9-13.2H334c-6.5 0-10.3 7.4-6.5 12.7l178 246z\"}}]})(props);\n};\nexport function AiTwotoneEdit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M761.1 288.3L687.8 215 325.1 577.6l-15.6 89 88.9-15.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 836H144c-17.7 0-32 14.3-32 32v36c0 4.4 3.6 8 8 8h784c4.4 0 8-3.6 8-8v-36c0-17.7-14.3-32-32-32zm-622.3-84c2 0 4-.2 6-.5L431.9 722c2-.4 3.9-1.3 5.3-2.8l423.9-423.9a9.96 9.96 0 0 0 0-14.1L694.9 114.9c-1.9-1.9-4.4-2.9-7.1-2.9s-5.2 1-7.1 2.9L256.8 538.8c-1.5 1.5-2.4 3.3-2.8 5.3l-29.5 168.2a33.5 33.5 0 0 0 9.4 29.8c6.6 6.4 14.9 9.9 23.8 9.9zm67.4-174.4L687.8 215l73.3 73.3-362.7 362.6-88.9 15.7 15.6-89z\"}}]})(props);\n};\nexport function AiTwotoneEnvironment (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M724.4 224.9C667.7 169.5 592.3 139 512 139s-155.7 30.5-212.4 85.8C243.1 280 212 353.2 212 431.1c0 241.3 234.1 407.2 300 449.1 65.9-41.9 300-207.8 300-449.1 0-77.9-31.1-151.1-87.6-206.2zM512 615c-97.2 0-176-78.8-176-176s78.8-176 176-176 176 78.8 176 176-78.8 176-176 176z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 263c-97.2 0-176 78.8-176 176s78.8 176 176 176 176-78.8 176-176-78.8-176-176-176zm79.2 255.2A111.6 111.6 0 0 1 512 551c-29.9 0-58-11.7-79.2-32.8A111.6 111.6 0 0 1 400 439c0-29.9 11.7-58 32.8-79.2C454 338.6 482.1 327 512 327c29.9 0 58 11.6 79.2 32.8S624 409.1 624 439c0 29.9-11.6 58-32.8 79.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 289.1a362.49 362.49 0 0 0-79.9-115.7 370.83 370.83 0 0 0-118.2-77.8C610.7 76.6 562.1 67 512 67c-50.1 0-98.7 9.6-144.5 28.5-44.3 18.3-84 44.5-118.2 77.8A363.6 363.6 0 0 0 169.4 289c-19.5 45-29.4 92.8-29.4 142 0 70.6 16.9 140.9 50.1 208.7 26.7 54.5 64 107.6 111 158.1 80.3 86.2 164.5 138.9 188.4 153a43.9 43.9 0 0 0 22.4 6.1c7.8 0 15.5-2 22.4-6.1 23.9-14.1 108.1-66.8 188.4-153 47-50.4 84.3-103.6 111-158.1C867.1 572 884 501.8 884 431.1c0-49.2-9.9-97-29.4-142zM512 880.2c-65.9-41.9-300-207.8-300-449.1 0-77.9 31.1-151.1 87.6-206.3C356.3 169.5 431.7 139 512 139s155.7 30.5 212.4 85.9C780.9 280 812 353.2 812 431.1c0 241.3-234.1 407.2-300 449.1z\"}}]})(props);\n};\nexport function AiTwotoneEuroCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm117.1 581.1c0 3.8-2.7 7-6.4 7.8-15.9 3.4-34.4 5.1-55.3 5.1-109.8 0-183-58.8-200.2-158H337c-4.4 0-8-3.6-8-8v-27.2c0-4.4 3.6-8 8-8h26.1v-36.9c0-4.4 0-8.7.3-12.8H337c-4.4 0-8-3.6-8-8v-27.2c0-4.4 3.6-8 8-8h31.8C388.5 345.7 460.7 290 567.4 290c20.9 0 39.4 1.9 55.3 5.4 3.7.8 6.3 4 6.3 7.8V346a8 8 0 0 1-9.6 7.8c-14.6-2.9-31.8-4.4-51.7-4.4-65.3 0-110.4 33.5-127.6 90.4h128.3c4.4 0 8 3.6 8 8V475c0 4.4-3.6 8-8 8H432.5c-.3 4.4-.3 9.1-.3 13.8v36h136.4c4.4 0 8 3.6 8 8V568c0 4.4-3.6 8-8 8H438c15.3 62 61.3 98.6 129.8 98.6 19.9 0 37.1-1.3 51.8-4.1 4.9-1 9.5 2.8 9.5 7.8v42.8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M619.6 670.5c-14.7 2.8-31.9 4.1-51.8 4.1-68.5 0-114.5-36.6-129.8-98.6h130.6c4.4 0 8-3.6 8-8v-27.2c0-4.4-3.6-8-8-8H432.2v-36c0-4.7 0-9.4.3-13.8h135.9c4.4 0 8-3.6 8-8v-27.2c0-4.4-3.6-8-8-8H440.1c17.2-56.9 62.3-90.4 127.6-90.4 19.9 0 37.1 1.5 51.7 4.4a8 8 0 0 0 9.6-7.8v-42.8c0-3.8-2.6-7-6.3-7.8-15.9-3.5-34.4-5.4-55.3-5.4-106.7 0-178.9 55.7-198.6 149.9H337c-4.4 0-8 3.6-8 8v27.2c0 4.4 3.6 8 8 8h26.4c-.3 4.1-.3 8.4-.3 12.8v36.9H337c-4.4 0-8 3.6-8 8V568c0 4.4 3.6 8 8 8h30.2c17.2 99.2 90.4 158 200.2 158 20.9 0 39.4-1.7 55.3-5.1 3.7-.8 6.4-4 6.4-7.8v-42.8c0-5-4.6-8.8-9.5-7.8z\"}}]})(props);\n};\nexport function AiTwotoneEuro (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm117.1 581.1c0 3.8-2.7 7-6.4 7.8-15.9 3.4-34.4 5.1-55.3 5.1-109.8 0-183-58.8-200.2-158H337c-4.4 0-8-3.6-8-8v-27.2c0-4.4 3.6-8 8-8h26.1v-36.9c0-4.4 0-8.7.3-12.8H337c-4.4 0-8-3.6-8-8v-27.2c0-4.4 3.6-8 8-8h31.8C388.5 345.7 460.7 290 567.4 290c20.9 0 39.4 1.9 55.3 5.4 3.7.8 6.3 4 6.3 7.8V346a8 8 0 0 1-9.6 7.8c-14.6-2.9-31.8-4.4-51.7-4.4-65.3 0-110.4 33.5-127.6 90.4h128.3c4.4 0 8 3.6 8 8V475c0 4.4-3.6 8-8 8H432.5c-.3 4.4-.3 9.1-.3 13.8v36h136.4c4.4 0 8 3.6 8 8V568c0 4.4-3.6 8-8 8H438c15.3 62 61.3 98.6 129.8 98.6 19.9 0 37.1-1.3 51.8-4.1 4.9-1 9.5 2.8 9.5 7.8v42.8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M619.6 670.5c-14.7 2.8-31.9 4.1-51.8 4.1-68.5 0-114.5-36.6-129.8-98.6h130.6c4.4 0 8-3.6 8-8v-27.2c0-4.4-3.6-8-8-8H432.2v-36c0-4.7 0-9.4.3-13.8h135.9c4.4 0 8-3.6 8-8v-27.2c0-4.4-3.6-8-8-8H440.1c17.2-56.9 62.3-90.4 127.6-90.4 19.9 0 37.1 1.5 51.7 4.4a8 8 0 0 0 9.6-7.8v-42.8c0-3.8-2.6-7-6.3-7.8-15.9-3.5-34.4-5.4-55.3-5.4-106.7 0-178.9 55.7-198.6 149.9H337c-4.4 0-8 3.6-8 8v27.2c0 4.4 3.6 8 8 8h26.4c-.3 4.1-.3 8.4-.3 12.8v36.9H337c-4.4 0-8 3.6-8 8V568c0 4.4 3.6 8 8 8h30.2c17.2 99.2 90.4 158 200.2 158 20.9 0 39.4-1.7 55.3-5.1 3.7-.8 6.4-4 6.4-7.8v-42.8c0-5-4.6-8.8-9.5-7.8z\"}}]})(props);\n};\nexport function AiTwotoneExclamationCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm-32 156c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v272c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V296zm32 440a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M488 576h48c4.4 0 8-3.6 8-8V296c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v272c0 4.4 3.6 8 8 8zm-24 112a48 48 0 1 0 96 0 48 48 0 1 0-96 0z\"}}]})(props);\n};\nexport function AiTwotoneExperiment (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M551.9 513c19.6 0 35.9-14.2 39.3-32.8A40.02 40.02 0 0 1 552 512a40 40 0 0 1-40-39.4v.5c0 22 17.9 39.9 39.9 39.9zM752 687.8l-.3-.3c-29-17.5-62.3-26.8-97-26.8-44.9 0-87.2 15.7-121 43.8a256.27 256.27 0 0 1-164.9 59.9c-41.2 0-81-9.8-116.7-28L210.5 844h603l-59.9-155.2-1.6-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M879 824.9L696.3 352V178H768v-68H256v68h71.7v174L145 824.9c-2.8 7.4-4.3 15.2-4.3 23.1 0 35.3 28.7 64 64 64h614.6c7.9 0 15.7-1.5 23.1-4.3 33-12.7 49.4-49.8 36.6-82.8zM395.7 364.7V180h232.6v184.7L719.2 600c-20.7-5.3-42.1-8-63.9-8-61.2 0-119.2 21.5-165.3 60a188.78 188.78 0 0 1-121.3 43.9c-32.7 0-64.1-8.3-91.8-23.7l118.8-307.5zM210.5 844l41.6-107.6.1-.2c35.7 18.1 75.4 27.8 116.6 27.8 61.2 0 119.2-21.5 165.3-60 33.9-28.2 76.3-43.9 121.3-43.9 35 0 68.4 9.5 97.6 27.1l.6 1.6L813.5 844h-603z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M552 512c19.3 0 35.4-13.6 39.2-31.8.6-2.7.8-5.4.8-8.2 0-22.1-17.9-40-40-40s-40 17.9-40 40v.6a40 40 0 0 0 40 39.4z\"}}]})(props);\n};\nexport function AiTwotoneEyeInvisible (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M254.89,758.85,380.46,633.28A176,176,0,0,1,629.28,384.46L757,256.72Q651.69,186.07,512,186,223.7,186,81.8,486.3a60.3,60.3,0,0,0,0,51.5Q151.07,683.71,254.89,758.85Z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M942.2,486.2Q889.46,375.11,816.7,305L672.48,449.27A176.09,176.09,0,0,1,445.26,676.48L323,798.75Q408,838,512,838q288.3,0,430.2-300.3A60.29,60.29,0,0,0,942.2,486.2Z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M942.2,486.2Q889.47,375.11,816.7,305l-50.88,50.88C807.31,395.53,843.45,447.4,874.7,512,791.5,684.2,673.4,766,512,766q-72.67,0-133.87-22.38L323,798.75Q408,838,512,838q288.3,0,430.2-300.3A60.29,60.29,0,0,0,942.2,486.2Z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M878.63,165.56,836,122.88a8,8,0,0,0-11.32,0L715.31,232.2Q624.86,186,512,186,223.7,186,81.8,486.3a60.3,60.3,0,0,0,0,51.5q56.69,119.4,136.5,191.41L112.48,835a8,8,0,0,0,0,11.31L155.17,889a8,8,0,0,0,11.31,0L878.63,176.88A8,8,0,0,0,878.63,165.56ZM149.3,512C232.6,339.8,350.7,258,512,258c54.54,0,104.13,9.36,149.12,28.39l-70.3,70.3A176,176,0,0,0,352.69,594.82l-83.42,83.42C223.1,637.49,183.3,582.28,149.3,512ZM396,512A112.11,112.11,0,0,1,542.2,405.31L401.31,546.2A112,112,0,0,1,396,512Z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M508,624c-3.46,0-6.87-.16-10.25-.47l-52.82,52.82A176.09,176.09,0,0,0,672.35,448.93l-52.82,52.82c.31,3.38.47,6.79.47,10.25A111.94,111.94,0,0,1,508,624Z\"}}]})(props);\n};\nexport function AiTwotoneEye (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M81.8 537.8a60.3 60.3 0 0 1 0-51.5C176.6 286.5 319.8 186 512 186c-192.2 0-335.4 100.5-430.2 300.3a60.3 60.3 0 0 0 0 51.5C176.6 737.5 319.9 838 512 838c-192.1 0-335.4-100.5-430.2-300.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 258c-161.3 0-279.4 81.8-362.7 254C232.6 684.2 350.7 766 512 766c161.4 0 279.5-81.8 362.7-254C791.4 339.8 673.3 258 512 258zm-4 430c-97.2 0-176-78.8-176-176s78.8-176 176-176 176 78.8 176 176-78.8 176-176 176z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M942.2 486.2C847.4 286.5 704.1 186 512 186c-192.2 0-335.4 100.5-430.2 300.3a60.3 60.3 0 0 0 0 51.5C176.6 737.5 319.9 838 512 838c192.2 0 335.4-100.5 430.2-300.3 7.7-16.2 7.7-35 0-51.5zM512 766c-161.3 0-279.4-81.8-362.7-254C232.6 339.8 350.7 258 512 258s279.4 81.8 362.7 254C791.5 684.2 673.4 766 512 766z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M508 336c-97.2 0-176 78.8-176 176s78.8 176 176 176 176-78.8 176-176-78.8-176-176-176zm0 288c-61.9 0-112-50.1-112-112s50.1-112 112-112 112 50.1 112 112-50.1 112-112 112z\"}}]})(props);\n};\nexport function AiTwotoneFileAdd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M534 352V136H232v752h560V394H576a42 42 0 0 1-42-42zm126 236v48c0 4.4-3.6 8-8 8H544v108c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V644H372c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h108V472c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v108h108c4.4 0 8 3.6 8 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM602 137.8L790.2 326H602V137.8zM792 888H232V136h302v216a42 42 0 0 0 42 42h216v494z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M544 472c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v108H372c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h108v108c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V644h108c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H544V472z\"}}]})(props);\n};\nexport function AiTwotoneFileExcel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M534 352V136H232v752h560V394H576a42 42 0 0 1-42-42zm51.6 120h35.7a12.04 12.04 0 0 1 10.1 18.5L546.1 623l84 130.4c3.6 5.6 2 13-3.6 16.6-2 1.2-4.2 1.9-6.5 1.9h-37.5c-4.1 0-8-2.1-10.2-5.7L510 664.8l-62.7 101.5c-2.2 3.5-6 5.7-10.2 5.7h-34.5a12.04 12.04 0 0 1-10.2-18.4l83.4-132.8-82.3-130.4c-3.6-5.7-1.9-13.1 3.7-16.6 1.9-1.3 4.1-1.9 6.4-1.9H442c4.2 0 8.1 2.2 10.3 5.8l61.8 102.4 61.2-102.3c2.2-3.6 6.1-5.8 10.3-5.8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM602 137.8L790.2 326H602V137.8zM792 888H232V136h302v216a42 42 0 0 0 42 42h216v494z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M514.1 580.1l-61.8-102.4c-2.2-3.6-6.1-5.8-10.3-5.8h-38.4c-2.3 0-4.5.6-6.4 1.9-5.6 3.5-7.3 10.9-3.7 16.6l82.3 130.4-83.4 132.8a12.04 12.04 0 0 0 10.2 18.4h34.5c4.2 0 8-2.2 10.2-5.7L510 664.8l62.3 101.4c2.2 3.6 6.1 5.7 10.2 5.7H620c2.3 0 4.5-.7 6.5-1.9 5.6-3.6 7.2-11 3.6-16.6l-84-130.4 85.3-132.5a12.04 12.04 0 0 0-10.1-18.5h-35.7c-4.2 0-8.1 2.2-10.3 5.8l-61.2 102.3z\"}}]})(props);\n};\nexport function AiTwotoneFileExclamation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M534 352V136H232v752h560V394H576a42 42 0 0 1-42-42zm-54 96c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v184c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V448zm32 336c-22.1 0-40-17.9-40-40s17.9-40 40-40 40 17.9 40 40-17.9 40-40 40z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM602 137.8L790.2 326H602V137.8zM792 888H232V136h302v216a42 42 0 0 0 42 42h216v494z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M488 640h48c4.4 0 8-3.6 8-8V448c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v184c0 4.4 3.6 8 8 8zm-16 104a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}}]})(props);\n};\nexport function AiTwotoneFileImage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M534 352V136H232v752h560V394H576a42 42 0 0 1-42-42zm-134 50c22.1 0 40 17.9 40 40s-17.9 40-40 40-40-17.9-40-40 17.9-40 40-40zm296 294H328.1c-6.7 0-10.4-7.7-6.3-12.9l99.8-127.2a8 8 0 0 1 12.6 0l41.1 52.4 77.8-99.2a8.1 8.1 0 0 1 12.7 0l136.5 174c4.1 5.2.4 12.9-6.3 12.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM602 137.8L790.2 326H602V137.8zM792 888H232V136h302v216a42 42 0 0 0 42 42h216v494z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M553.1 509.1l-77.8 99.2-41.1-52.4a8 8 0 0 0-12.6 0l-99.8 127.2a7.98 7.98 0 0 0 6.3 12.9H696c6.7 0 10.4-7.7 6.3-12.9l-136.5-174a8.1 8.1 0 0 0-12.7 0zM360 442a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}}]})(props);\n};\nexport function AiTwotoneFileMarkdown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M534 352V136H232v752h560V394H576a42 42 0 0 1-42-42zm72.3 122H641c6.6 0 12 5.4 12 12v272c0 6.6-5.4 12-12 12h-27.2c-6.6 0-12-5.4-12-12V581.7L535 732.3c-2 4.3-6.3 7.1-11 7.1h-24.1a12 12 0 0 1-11-7.1l-66.8-150.2V758c0 6.6-5.4 12-12 12H383c-6.6 0-12-5.4-12-12V486c0-6.6 5.4-12 12-12h35c4.8 0 9.1 2.8 11 7.2l83.2 191 83.1-191c1.9-4.4 6.2-7.2 11-7.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM602 137.8L790.2 326H602V137.8zM792 888H232V136h302v216a42 42 0 0 0 42 42h216v494z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M429 481.2c-1.9-4.4-6.2-7.2-11-7.2h-35c-6.6 0-12 5.4-12 12v272c0 6.6 5.4 12 12 12h27.1c6.6 0 12-5.4 12-12V582.1l66.8 150.2a12 12 0 0 0 11 7.1H524c4.7 0 9-2.8 11-7.1l66.8-150.6V758c0 6.6 5.4 12 12 12H641c6.6 0 12-5.4 12-12V486c0-6.6-5.4-12-12-12h-34.7c-4.8 0-9.1 2.8-11 7.2l-83.1 191-83.2-191z\"}}]})(props);\n};\nexport function AiTwotoneFilePdf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M509.2 490.8c-.7-1.3-1.4-1.9-2.2-2-2.9 3.3-2.2 31.5 2.7 51.4 4-13.6 4.7-40.5-.5-49.4zm-1.6 120.5c-7.7 20-18.8 47.3-32.1 71.4 4-1.6 8.1-3.3 12.3-5 17.6-7.2 37.3-15.3 58.9-20.2-14.9-11.8-28.4-27.7-39.1-46.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M534 352V136H232v752h560V394H576a42 42 0 0 1-42-42zm55 287.6c16.1-1.9 30.6-2.8 44.3-2.3 12.8.4 23.6 2 32 5.1.2.1.3.1.5.2.4.2.8.3 1.2.5.5.2 1.1.4 1.6.7.1.1.3.1.4.2 4.1 1.8 7.5 4 10.1 6.6 9.1 9.1 11.8 26.1 6.2 39.6-3.2 7.7-11.7 20.5-33.3 20.5-21.8 0-53.9-9.7-82.1-24.8-25.5 4.3-53.7 13.9-80.9 23.1-5.8 2-11.8 4-17.6 5.9-38 65.2-66.5 79.4-84.1 79.4-4.2 0-7.8-.9-10.8-2-6.9-2.6-12.8-8-16.5-15-.9-1.7-1.6-3.4-2.2-5.2-1.6-4.8-2.1-9.6-1.3-13.6l.6-2.7c.1-.2.1-.4.2-.6.2-.7.4-1.4.7-2.1 0-.1.1-.2.1-.3 4.1-11.9 13.6-23.4 27.7-34.6 12.3-9.8 27.1-18.7 45.9-28.4 15.9-28 37.6-75.1 51.2-107.4-10.8-41.8-16.7-74.6-10.1-98.6.9-3.3 2.5-6.4 4.6-9.1.2-.2.3-.4.5-.6.1-.1.1-.2.2-.2 6.3-7.5 16.9-11.9 28.1-11.5 16.6.7 29.7 11.5 33 30.1 1.7 8 2.2 16.5 1.9 25.7v.7c0 .5 0 1-.1 1.5-.7 13.3-3 26.6-7.3 44.7-.4 1.6-.8 3.2-1.2 5.2l-1 4.1-.1.3c.1.2.1.3.2.5l1.8 4.5c.1.3.3.7.4 1 .7 1.6 1.4 3.3 2.1 4.8v.1c8.7 18.8 19.7 33.4 33.9 45.1 4.3 3.5 8.9 6.7 13.9 9.8 1.8-.5 3.5-.7 5.3-.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M391.5 761c5.7-4.4 16.2-14.5 30.1-34.7-10.3 9.4-23.4 22.4-30.1 34.7zm270.9-83l.2-.3h.2c.6-.4.5-.7.4-.9-.1-.1-4.5-9.3-45.1-7.4 35.3 13.9 43.5 9.1 44.3 8.6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM602 137.8L790.2 326H602V137.8zM792 888H232V136h302v216a42 42 0 0 0 42 42h216v494z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M535.9 585.3c-.8-1.7-1.5-3.3-2.2-4.9-.1-.3-.3-.7-.4-1l-1.8-4.5c-.1-.2-.1-.3-.2-.5l.1-.3.2-1.1c4-16.3 8.6-35.3 9.4-54.4v-.7c.3-8.6-.2-17.2-2-25.6-3.8-21.3-19.5-29.6-32.9-30.2-11.3-.5-21.8 4-28.1 11.4-.1.1-.1.2-.2.2-.2.2-.4.4-.5.6-2.1 2.7-3.7 5.8-4.6 9.1-6.6 24-.7 56.8 10.1 98.6-13.6 32.4-35.3 79.4-51.2 107.4v.1c-27.7 14.3-64.1 35.8-73.6 62.9 0 .1-.1.2-.1.3-.2.7-.5 1.4-.7 2.1-.1.2-.1.4-.2.6-.2.9-.5 1.8-.6 2.7-.9 4-.4 8.8 1.3 13.6.6 1.8 1.3 3.5 2.2 5.2 3.7 7 9.6 12.4 16.5 15 3 1.1 6.6 2 10.8 2 17.6 0 46.1-14.2 84.1-79.4 5.8-1.9 11.8-3.9 17.6-5.9 27.2-9.2 55.4-18.8 80.9-23.1 28.2 15.1 60.3 24.8 82.1 24.8 21.6 0 30.1-12.8 33.3-20.5 5.6-13.5 2.9-30.5-6.2-39.6-2.6-2.6-6-4.8-10.1-6.6-.1-.1-.3-.1-.4-.2-.5-.2-1.1-.4-1.6-.7-.4-.2-.8-.3-1.2-.5-.2-.1-.3-.1-.5-.2-16.2-5.8-41.7-6.7-76.3-2.8l-5.3.6c-5-3-9.6-6.3-13.9-9.8-14.2-11.3-25.1-25.8-33.8-44.7zM391.5 761c6.7-12.3 19.8-25.3 30.1-34.7-13.9 20.2-24.4 30.3-30.1 34.7zM507 488.8c.8.1 1.5.7 2.2 2 5.2 8.9 4.5 35.8.5 49.4-4.9-19.9-5.6-48.1-2.7-51.4zm-19.2 188.9c-4.2 1.7-8.3 3.4-12.3 5 13.3-24.1 24.4-51.4 32.1-71.4 10.7 18.5 24.2 34.4 39.1 46.2-21.6 4.9-41.3 13-58.9 20.2zm175.4-.9c.1.2.2.5-.4.9h-.2l-.2.3c-.8.5-9 5.3-44.3-8.6 40.6-1.9 45 7.3 45.1 7.4z\"}}]})(props);\n};\nexport function AiTwotoneFilePpt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M464.5 516.2v108.4h38.9c44.7 0 71.2-10.9 71.2-54.3 0-34.4-20.1-54.1-53.9-54.1h-56.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M534 352V136H232v752h560V394H576a42 42 0 0 1-42-42zm90 218.4c0 55.2-36.8 94.1-96.2 94.1h-63.3V760c0 4.4-3.6 8-8 8H424c-4.4 0-8-3.6-8-8V484c0-4.4 3.6-8 8-8v.1h104c59.7 0 96 39.8 96 94.3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM602 137.8L790.2 326H602V137.8zM792 888H232V136h302v216a42 42 0 0 0 42 42h216v494z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M424 476.1c-4.4-.1-8 3.5-8 7.9v276c0 4.4 3.6 8 8 8h32.5c4.4 0 8-3.6 8-8v-95.5h63.3c59.4 0 96.2-38.9 96.2-94.1 0-54.5-36.3-94.3-96-94.3H424zm150.6 94.2c0 43.4-26.5 54.3-71.2 54.3h-38.9V516.2h56.2c33.8 0 53.9 19.7 53.9 54.1z\"}}]})(props);\n};\nexport function AiTwotoneFileText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M534 352V136H232v752h560V394H576a42 42 0 0 1-42-42zm-22 322c0 4.4-3.6 8-8 8H320c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h184c4.4 0 8 3.6 8 8v48zm200-184v48c0 4.4-3.6 8-8 8H320c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h384c4.4 0 8 3.6 8 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM602 137.8L790.2 326H602V137.8zM792 888H232V136h302v216a42 42 0 0 0 42 42h216v494z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M312 490v48c0 4.4 3.6 8 8 8h384c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H320c-4.4 0-8 3.6-8 8zm192 128H320c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiTwotoneFileUnknown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M534 352V136H232v752h560V394H576a42 42 0 0 1-42-42zm-22 424c-17.7 0-32-14.3-32-32s14.3-32 32-32 32 14.3 32 32-14.3 32-32 32zm110-228.4c.7 44.9-29.7 84.5-74.3 98.9-5.7 1.8-9.7 7.3-9.7 13.3V672c0 5.5-4.5 10-10 10h-32c-5.5 0-10-4.5-10-10v-32c.2-19.8 15.4-37.3 34.7-40.1C549 596.2 570 574.3 570 549c0-28.1-25.8-51.5-58-51.5s-58 23.4-58 51.6c0 5.2-4.4 9.4-9.8 9.4h-32.4c-5.4 0-9.8-4.1-9.8-9.5 0-57.4 50.1-103.7 111.5-103 59.3.8 107.7 46.1 108.5 101.6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.7L639.4 73.4c-6-6-14.2-9.4-22.7-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.6-9.4-22.6zM602 137.8L790.2 326H602V137.8zM792 888H232V136h302v216a42 42 0 0 0 42 42h216v494z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M480 744a32 32 0 1 0 64 0 32 32 0 1 0-64 0zm-78-195c0 5.4 4.4 9.5 9.8 9.5h32.4c5.4 0 9.8-4.2 9.8-9.4 0-28.2 25.8-51.6 58-51.6s58 23.4 58 51.5c0 25.3-21 47.2-49.3 50.9-19.3 2.8-34.5 20.3-34.7 40.1v32c0 5.5 4.5 10 10 10h32c5.5 0 10-4.5 10-10v-12.2c0-6 4-11.5 9.7-13.3 44.6-14.4 75-54 74.3-98.9-.8-55.5-49.2-100.8-108.5-101.6-61.4-.7-111.5 45.6-111.5 103z\"}}]})(props);\n};\nexport function AiTwotoneFileWord (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M534 352V136H232v752h560V394H576a42 42 0 0 1-42-42zm101.3 129.3c1.3-5.4 6.1-9.3 11.7-9.3h35.6a12.04 12.04 0 0 1 11.6 15.1l-74.4 276c-1.4 5.3-6.2 8.9-11.6 8.9h-31.8c-5.4 0-10.2-3.7-11.6-8.9l-52.8-197-52.8 197c-1.4 5.3-6.2 8.9-11.6 8.9h-32c-5.4 0-10.2-3.7-11.6-8.9l-74.2-276a12.02 12.02 0 0 1 11.6-15.1h35.4c5.6 0 10.4 3.9 11.7 9.3L434.6 680l49.7-198.9c1.3-5.4 6.1-9.1 11.6-9.1h32.2c5.5 0 10.3 3.7 11.6 9.1l49.8 199.3 45.8-199.1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM602 137.8L790.2 326H602V137.8zM792 888H232V136h302v216a42 42 0 0 0 42 42h216v494z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M528.1 472h-32.2c-5.5 0-10.3 3.7-11.6 9.1L434.6 680l-46.1-198.7c-1.3-5.4-6.1-9.3-11.7-9.3h-35.4a12.02 12.02 0 0 0-11.6 15.1l74.2 276c1.4 5.2 6.2 8.9 11.6 8.9h32c5.4 0 10.2-3.6 11.6-8.9l52.8-197 52.8 197c1.4 5.2 6.2 8.9 11.6 8.9h31.8c5.4 0 10.2-3.6 11.6-8.9l74.4-276a12.04 12.04 0 0 0-11.6-15.1H647c-5.6 0-10.4 3.9-11.7 9.3l-45.8 199.1-49.8-199.3c-1.3-5.4-6.1-9.1-11.6-9.1z\"}}]})(props);\n};\nexport function AiTwotoneFileZip (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M344 630h32v2h-32z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M534 352V136H360v64h64v64h-64v64h64v64h-64v64h64v64h-64v62h64v160H296V520h64v-64h-64v-64h64v-64h-64v-64h64v-64h-64v-64h-64v752h560V394H576a42 42 0 0 1-42-42z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM602 137.8L790.2 326H602V137.8zM792 888H232V136h64v64h64v-64h174v216a42 42 0 0 0 42 42h216v494z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M296 392h64v64h-64zm0-128h64v64h-64zm0 318v160h128V582h-64v-62h-64v62zm48 50v-2h32v64h-32v-62zm16-432h64v64h-64zm0 256h64v64h-64zm0-128h64v64h-64z\"}}]})(props);\n};\nexport function AiTwotoneFile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M534 352V136H232v752h560V394H576a42 42 0 0 1-42-42z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM602 137.8L790.2 326H602V137.8zM792 888H232V136h302v216a42 42 0 0 0 42 42h216v494z\"}}]})(props);\n};\nexport function AiTwotoneFilter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M420.6 798h182.9V642H420.6zM411 561.4l9.5 16.6h183l9.5-16.6L811.3 226H212.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880.1 154H143.9c-24.5 0-39.8 26.7-27.5 48L349 597.4V838c0 17.7 14.2 32 31.8 32h262.4c17.6 0 31.8-14.3 31.8-32V597.4L907.7 202c12.2-21.3-3.1-48-27.6-48zM603.5 798H420.6V642h182.9v156zm9.5-236.6l-9.5 16.6h-183l-9.5-16.6L212.7 226h598.6L613 561.4z\"}}]})(props);\n};\nexport function AiTwotoneFire (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M737 438.6c-9.6 15.5-21.1 30.7-34.4 45.6a73.1 73.1 0 0 1-51 24.4 73.36 73.36 0 0 1-53.4-18.8 74.01 74.01 0 0 1-24.4-59.8c3-47.4-12.4-103.1-45.8-165.7-16.9-31.4-37.1-58.2-61.2-80.4a240 240 0 0 1-12.1 46.5 354.26 354.26 0 0 1-58.2 101 349.6 349.6 0 0 1-58.6 56.8c-34 26.1-62 60-80.8 97.9a275.96 275.96 0 0 0-29.1 124c0 74.9 29.5 145.3 83 198.4 53.7 53.2 125 82.4 201 82.4s147.3-29.2 201-82.4c53.5-53 83-123.5 83-198.4 0-39.2-8.1-77.3-24-113.1-9.3-21-21-40.5-35-58.4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M834.1 469.2A347.49 347.49 0 0 0 751.2 354l-29.1-26.7a8.09 8.09 0 0 0-13 3.3l-13 37.3c-8.1 23.4-23 47.3-44.1 70.8-1.4 1.5-3 1.9-4.1 2-1.1.1-2.8-.1-4.3-1.5-1.4-1.2-2.1-3-2-4.8 3.7-60.2-14.3-128.1-53.7-202C555.3 171 510 123.1 453.4 89.7l-41.3-24.3c-5.4-3.2-12.3 1-12 7.3l2.2 48c1.5 32.8-2.3 61.8-11.3 85.9-11 29.5-26.8 56.9-47 81.5a295.64 295.64 0 0 1-47.5 46.1 352.6 352.6 0 0 0-100.3 121.5A347.75 347.75 0 0 0 160 610c0 47.2 9.3 92.9 27.7 136a349.4 349.4 0 0 0 75.5 110.9c32.4 32 70 57.2 111.9 74.7C418.5 949.8 464.5 959 512 959s93.5-9.2 136.9-27.3A348.6 348.6 0 0 0 760.8 857c32.4-32 57.8-69.4 75.5-110.9a344.2 344.2 0 0 0 27.7-136c0-48.8-10-96.2-29.9-140.9zM713 808.5c-53.7 53.2-125 82.4-201 82.4s-147.3-29.2-201-82.4c-53.5-53.1-83-123.5-83-198.4 0-43.5 9.8-85.2 29.1-124 18.8-37.9 46.8-71.8 80.8-97.9a349.6 349.6 0 0 0 58.6-56.8c25-30.5 44.6-64.5 58.2-101a240 240 0 0 0 12.1-46.5c24.1 22.2 44.3 49 61.2 80.4 33.4 62.6 48.8 118.3 45.8 165.7a74.01 74.01 0 0 0 24.4 59.8 73.36 73.36 0 0 0 53.4 18.8c19.7-1 37.8-9.7 51-24.4 13.3-14.9 24.8-30.1 34.4-45.6 14 17.9 25.7 37.4 35 58.4 15.9 35.8 24 73.9 24 113.1 0 74.9-29.5 145.4-83 198.4z\"}}]})(props);\n};\nexport function AiTwotoneFlag (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M184 232h368v336H184z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M624 632c0 4.4-3.6 8-8 8H504v73h336V377H624v255z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 305H624V192c0-17.7-14.3-32-32-32H184v-40c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v784c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V640h248v113c0 17.7 14.3 32 32 32h416c17.7 0 32-14.3 32-32V337c0-17.7-14.3-32-32-32zM184 568V232h368v336H184zm656 145H504v-73h112c4.4 0 8-3.6 8-8V377h216v336z\"}}]})(props);\n};\nexport function AiTwotoneFolderAdd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M372.5 256H184v512h656V370.4H492.1L372.5 256zM540 443.1V528h84.5c4.1 0 7.5 3.1 7.5 7v42c0 3.8-3.4 7-7.5 7H540v84.9c0 3.9-3.1 7.1-7 7.1h-42c-3.8 0-7-3.2-7-7.1V584h-84.5c-4.1 0-7.5-3.2-7.5-7v-42c0-3.9 3.4-7 7.5-7H484v-84.9c0-3.9 3.2-7.1 7-7.1h42c3.9 0 7 3.2 7 7.1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 298.4H521L403.7 186.2a8.15 8.15 0 0 0-5.5-2.2H144c-17.7 0-32 14.3-32 32v592c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V330.4c0-17.7-14.3-32-32-32zM840 768H184V256h188.5l119.6 114.4H840V768z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M484 443.1V528h-84.5c-4.1 0-7.5 3.1-7.5 7v42c0 3.8 3.4 7 7.5 7H484v84.9c0 3.9 3.2 7.1 7 7.1h42c3.9 0 7-3.2 7-7.1V584h84.5c4.1 0 7.5-3.2 7.5-7v-42c0-3.9-3.4-7-7.5-7H540v-84.9c0-3.9-3.1-7.1-7-7.1h-42c-3.8 0-7 3.2-7 7.1z\"}}]})(props);\n};\nexport function AiTwotoneFolderOpen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M159 768h612.3l103.4-256H262.3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M928 444H820V330.4c0-17.7-14.3-32-32-32H473L355.7 186.2a8.15 8.15 0 0 0-5.5-2.2H96c-17.7 0-32 14.3-32 32v592c0 17.7 14.3 32 32 32h698c13 0 24.8-7.9 29.7-20l134-332c1.5-3.8 2.3-7.9 2.3-12 0-17.7-14.3-32-32-32zM136 256h188.5l119.6 114.4H748V444H238c-13 0-24.8 7.9-29.7 20L136 643.2V256zm635.3 512H159l103.3-256h612.4L771.3 768z\"}}]})(props);\n};\nexport function AiTwotoneFolder (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 298.4H521L403.7 186.2a8.15 8.15 0 0 0-5.5-2.2H144c-17.7 0-32 14.3-32 32v592c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V330.4c0-17.7-14.3-32-32-32zM840 768H184V256h188.5l119.6 114.4H840V768z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M372.5 256H184v512h656V370.4H492.1z\"}}]})(props);\n};\nexport function AiTwotoneFrown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zM288 421a48.01 48.01 0 0 1 96 0 48.01 48.01 0 0 1-96 0zm376 272h-48.1c-4.2 0-7.8-3.2-8.1-7.4C604 636.1 562.5 597 512 597s-92.1 39.1-95.8 88.6c-.3 4.2-3.9 7.4-8.1 7.4H360a8 8 0 0 1-8-8.4c4.4-84.3 74.5-151.6 160-151.6s155.6 67.3 160 151.6a8 8 0 0 1-8 8.4zm24-224a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M288 421a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm224 112c-85.5 0-155.6 67.3-160 151.6a8 8 0 0 0 8 8.4h48.1c4.2 0 7.8-3.2 8.1-7.4 3.7-49.5 45.3-88.6 95.8-88.6s92 39.1 95.8 88.6c.3 4.2 3.9 7.4 8.1 7.4H664a8 8 0 0 0 8-8.4C667.6 600.3 597.5 533 512 533zm128-112a48 48 0 1 0 96 0 48 48 0 1 0-96 0z\"}}]})(props);\n};\nexport function AiTwotoneFund (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 160H96c-17.7 0-32 14.3-32 32v640c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V192c0-17.7-14.3-32-32-32zm-40 632H136V232h752v560z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M136 792h752V232H136v560zm56.4-130.5l214.9-215c3.1-3.1 8.2-3.1 11.3 0L533 561l254.5-254.6c3.1-3.1 8.2-3.1 11.3 0l36.8 36.8c3.1 3.1 3.1 8.2 0 11.3l-297 297.2a8.03 8.03 0 0 1-11.3 0L412.9 537.2 240.4 709.7a8.03 8.03 0 0 1-11.3 0l-36.7-36.9a8.03 8.03 0 0 1 0-11.3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M229.1 709.7c3.1 3.1 8.2 3.1 11.3 0l172.5-172.5 114.4 114.5c3.1 3.1 8.2 3.1 11.3 0l297-297.2c3.1-3.1 3.1-8.2 0-11.3l-36.8-36.8a8.03 8.03 0 0 0-11.3 0L533 561 418.6 446.5a8.03 8.03 0 0 0-11.3 0l-214.9 215a8.03 8.03 0 0 0 0 11.3l36.7 36.9z\"}}]})(props);\n};\nexport function AiTwotoneFunnelPlot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M420.6 798h182.9V650H420.6zM297.7 374h428.6l85-148H212.7zm113.2 197.4l8.4 14.6h185.3l8.4-14.6L689.6 438H334.4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880.1 154H143.9c-24.5 0-39.8 26.7-27.5 48L349 607.4V838c0 17.7 14.2 32 31.8 32h262.4c17.6 0 31.8-14.3 31.8-32V607.4L907.7 202c12.2-21.3-3.1-48-27.6-48zM603.5 798H420.6V650h182.9v148zm9.5-226.6l-8.4 14.6H419.3l-8.4-14.6L334.4 438h355.2L613 571.4zM726.3 374H297.7l-85-148h598.6l-85 148z\"}}]})(props);\n};\nexport function AiTwotoneGift (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M546 378h298v104H546zM228 550h250v308H228zm-48-172h298v104H180zm366 172h250v308H546z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 310H732.4c13.6-21.4 21.6-46.8 21.6-74 0-76.1-61.9-138-138-138-41.4 0-78.7 18.4-104 47.4-25.3-29-62.6-47.4-104-47.4-76.1 0-138 61.9-138 138 0 27.2 7.9 52.6 21.6 74H144c-17.7 0-32 14.3-32 32v200c0 4.4 3.6 8 8 8h40v344c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V550h40c4.4 0 8-3.6 8-8V342c0-17.7-14.3-32-32-32zM478 858H228V550h250v308zm0-376H180V378h298v104zm0-176h-70c-38.6 0-70-31.4-70-70s31.4-70 70-70 70 31.4 70 70v70zm68-70c0-38.6 31.4-70 70-70s70 31.4 70 70-31.4 70-70 70h-70v-70zm250 622H546V550h250v308zm48-376H546V378h298v104z\"}}]})(props);\n};\nexport function AiTwotoneGold (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M435.7 558.7c-.6-3.9-4-6.7-7.9-6.7H166.2c-3.9 0-7.3 2.8-7.9 6.7l-40.2 248c-.1.4-.1.9-.1 1.3 0 4.4 3.6 8 8 8h342c.4 0 .9 0 1.3-.1 4.4-.7 7.3-4.8 6.6-9.2l-40.2-248zM196.5 748l20.7-128h159.5l20.7 128H196.5zm709.4 58.7l-40.2-248c-.6-3.9-4-6.7-7.9-6.7H596.2c-3.9 0-7.3 2.8-7.9 6.7l-40.2 248c-.1.4-.1.9-.1 1.3 0 4.4 3.6 8 8 8h342c.4 0 .9 0 1.3-.1 4.3-.7 7.3-4.8 6.6-9.2zM626.5 748l20.7-128h159.5l20.7 128H626.5zM342 472h342c.4 0 .9 0 1.3-.1 4.4-.7 7.3-4.8 6.6-9.2l-40.2-248c-.6-3.9-4-6.7-7.9-6.7H382.2c-3.9 0-7.3 2.8-7.9 6.7l-40.2 248c-.1.4-.1.9-.1 1.3 0 4.4 3.6 8 8 8zm91.2-196h159.5l20.7 128h-201l20.8-128z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M592.7 276H433.2l-20.8 128h201zM217.2 620l-20.7 128h200.9l-20.7-128zm430 0l-20.7 128h200.9l-20.7-128z\"}}]})(props);\n};\nexport function AiTwotoneHdd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M232 888h560V680H232v208zm448-140c22.1 0 40 17.9 40 40s-17.9 40-40 40-40-17.9-40-40 17.9-40 40-40zM232 616h560V408H232v208zm72-128c0-4.4 3.6-8 8-8h184c4.4 0 8 3.6 8 8v48c0 4.4-3.6 8-8 8H312c-4.4 0-8-3.6-8-8v-48zm-72-144h560V136H232v208zm72-128c0-4.4 3.6-8 8-8h184c4.4 0 8 3.6 8 8v48c0 4.4-3.6 8-8 8H312c-4.4 0-8-3.6-8-8v-48z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V96c0-17.7-14.3-32-32-32zm-40 824H232V680h560v208zm0-272H232V408h560v208zm0-272H232V136h560v208z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M312 544h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H312c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8zm0-272h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H312c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8zm328 516a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}}]})(props);\n};\nexport function AiTwotoneHeart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M923 283.6a260.04 260.04 0 0 0-56.9-82.8 264.4 264.4 0 0 0-84-55.5A265.34 265.34 0 0 0 679.7 125c-49.3 0-97.4 13.5-139.2 39-10 6.1-19.5 12.8-28.5 20.1-9-7.3-18.5-14-28.5-20.1-41.8-25.5-89.9-39-139.2-39-35.5 0-69.9 6.8-102.4 20.3-31.4 13-59.7 31.7-84 55.5a258.44 258.44 0 0 0-56.9 82.8c-13.9 32.3-21 66.6-21 101.9 0 33.3 6.8 68 20.3 103.3 11.3 29.5 27.5 60.1 48.2 91 32.8 48.9 77.9 99.9 133.9 151.6 92.8 85.7 184.7 144.9 188.6 147.3l23.7 15.2c10.5 6.7 24 6.7 34.5 0l23.7-15.2c3.9-2.5 95.7-61.6 188.6-147.3 56-51.7 101.1-102.7 133.9-151.6 20.7-30.9 37-61.5 48.2-91 13.5-35.3 20.3-70 20.3-103.3.1-35.3-7-69.6-20.9-101.9zM512 814.8S156 586.7 156 385.5C156 283.6 240.3 201 344.3 201c73.1 0 136.5 40.8 167.7 100.4C543.2 241.8 606.6 201 679.7 201c104 0 188.3 82.6 188.3 184.5 0 201.2-356 429.3-356 429.3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M679.7 201c-73.1 0-136.5 40.8-167.7 100.4C480.8 241.8 417.4 201 344.3 201c-104 0-188.3 82.6-188.3 184.5 0 201.2 356 429.3 356 429.3s356-228.1 356-429.3C868 283.6 783.7 201 679.7 201z\"}}]})(props);\n};\nexport function AiTwotoneHighlight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M229.6 796.3h160.2l54.3-54.1-80.1-78.9zm220.7-397.1l262.8 258.9 147.3-145-262.8-259zm-77.1 166.1l171.4 168.9 68.6-67.6-171.4-168.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M957.6 507.5L603.2 158.3a7.9 7.9 0 0 0-11.2 0L353.3 393.5a8.03 8.03 0 0 0-.1 11.3l.1.1 40 39.4-117.2 115.3a8.03 8.03 0 0 0-.1 11.3l.1.1 39.5 38.9-189.1 187H72.1c-4.4 0-8.1 3.6-8.1 8v55.2c0 4.4 3.6 8 8 8h344.9c2.1 0 4.1-.8 5.6-2.3l76.1-75.6L539 830a7.9 7.9 0 0 0 11.2 0l117.1-115.6 40.1 39.5a7.9 7.9 0 0 0 11.2 0l238.7-235.2c3.4-3 3.4-8 .3-11.2zM389.8 796.3H229.6l134.4-133 80.1 78.9-54.3 54.1zm154.8-62.1L373.2 565.3l68.6-67.6 171.4 168.9-68.6 67.6zm168.5-76.1L450.3 399.2l147.3-145.1 262.8 259-147.3 145z\"}}]})(props);\n};\nexport function AiTwotoneHome (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512.1 172.6l-370 369.7h96V868H392V640c0-22.1 17.9-40 40-40h160c22.1 0 40 17.9 40 40v228h153.9V542.3H882L535.2 195.7l-23.1-23.1zm434.5 422.9c-6 6-13.1 10.8-20.8 13.9 7.7-3.2 14.8-7.9 20.8-13.9zm-887-34.7c5 30.3 31.4 53.5 63.1 53.5h.9c-31.9 0-58.9-23-64-53.5zm-.9-10.5v-1.9 1.9zm.1-2.6c.1-3.1.5-6.1 1-9.1-.6 2.9-.9 6-1 9.1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M951 510c0-.1-.1-.1-.1-.2l-1.8-2.1c-.1-.1-.2-.3-.4-.4-.7-.8-1.5-1.6-2.2-2.4L560.1 118.8l-25.9-25.9a31.5 31.5 0 0 0-44.4 0L77.5 505a63.6 63.6 0 0 0-16 26.6l-.6 2.1-.3 1.1-.3 1.2c-.2.7-.3 1.4-.4 2.1 0 .1 0 .3-.1.4-.6 3-.9 6-1 9.1v3.3c0 .5 0 1 .1 1.5 0 .5 0 .9.1 1.4 0 .5.1 1 .1 1.5 0 .6.1 1.2.2 1.8 0 .3.1.6.1.9l.3 2.5v.1c5.1 30.5 32.2 53.5 64 53.5h42.5V940h691.7V614.3h43.4c8.6 0 16.9-1.7 24.5-4.9s14.7-7.9 20.8-13.9a63.6 63.6 0 0 0 18.7-45.3c0-14.7-5-28.8-14.3-40.2zM568 868H456V664h112v204zm217.9-325.7V868H632V640c0-22.1-17.9-40-40-40H432c-22.1 0-40 17.9-40 40v228H238.1V542.3h-96l370-369.7 23.1 23.1L882 542.3h-96.1z\"}}]})(props);\n};\nexport function AiTwotoneHourglass (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 548c-42.2 0-81.9 16.4-111.7 46.3A156.63 156.63 0 0 0 354 706v134h316V706c0-42.2-16.4-81.9-46.3-111.7A156.63 156.63 0 0 0 512 548zM354 318c0 42.2 16.4 81.9 46.3 111.7C430.1 459.6 469.8 476 512 476s81.9-16.4 111.7-46.3C653.6 399.9 670 360.2 670 318V184H354v134z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M742 318V184h86c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8H196c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h86v134c0 81.5 42.4 153.2 106.4 194-64 40.8-106.4 112.5-106.4 194v134h-86c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h632c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-86V706c0-81.5-42.4-153.2-106.4-194 64-40.8 106.4-112.5 106.4-194zm-72 388v134H354V706c0-42.2 16.4-81.9 46.3-111.7C430.1 564.4 469.8 548 512 548s81.9 16.4 111.7 46.3C653.6 624.1 670 663.8 670 706zm0-388c0 42.2-16.4 81.9-46.3 111.7C593.9 459.6 554.2 476 512 476s-81.9-16.4-111.7-46.3A156.63 156.63 0 0 1 354 318V184h316v134z\"}}]})(props);\n};\nexport function AiTwotoneHtml5 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M145 96l66 746.6L511.8 928l299.6-85.4L878.7 96H145zm610.9 700.6l-244.1 69.6-245.2-69.6-56.7-641.2h603.8l-57.8 641.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M209.9 155.4l56.7 641.2 245.2 69.6 244.1-69.6 57.8-641.2H209.9zm530.4 117.9l-4.8 47.2-1.7 19.5H381.7l8.2 94.2H511v-.2h214.7l-3.2 24.3-21.2 242.2-1.7 16.3-187.7 51.7v.4h-1.7l-188.6-52-11.3-144.7h91l6.5 73.2 102.4 27.7h.8v-.2l102.4-27.7 11.4-118.5H511.9v.1H305.4l-22.7-253.5L281 249h461l-1.7 24.3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M281 249l1.7 24.3 22.7 253.5h206.5v-.1h112.9l-11.4 118.5L511 672.9v.2h-.8l-102.4-27.7-6.5-73.2h-91l11.3 144.7 188.6 52h1.7v-.4l187.7-51.7 1.7-16.3 21.2-242.2 3.2-24.3H511v.2H389.9l-8.2-94.2h352.1l1.7-19.5 4.8-47.2L742 249H511z\"}}]})(props);\n};\nexport function AiTwotoneIdcard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 160H96c-17.7 0-32 14.3-32 32v640c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V192c0-17.7-14.3-32-32-32zm-40 632H136V232h752v560z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M136 792h752V232H136v560zm472-372c0-4.4 1-8 2.3-8h123.4c1.3 0 2.3 3.6 2.3 8v48c0 4.4-1 8-2.3 8H610.3c-1.3 0-2.3-3.6-2.3-8v-48zm0 144c0-4.4 3.2-8 7.1-8h185.7c3.9 0 7.1 3.6 7.1 8v48c0 4.4-3.2 8-7.1 8H615.1c-3.9 0-7.1-3.6-7.1-8v-48zM216.2 664.6c2.8-53.3 31.9-99.6 74.6-126.1-18.1-20-29.1-46.4-29.1-75.5 0-61.9 49.9-112 111.4-112s111.4 50.1 111.4 112c0 29.1-11 55.6-29.1 75.5 42.6 26.4 71.8 72.8 74.6 126.1a8 8 0 0 1-8 8.4h-43.9c-4.2 0-7.6-3.3-7.9-7.5-3.8-50.5-46-90.5-97.2-90.5s-93.4 40-97.2 90.5c-.3 4.2-3.7 7.5-7.9 7.5H224c-4.6 0-8.2-3.8-7.8-8.4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M321.3 463a51.7 52 0 1 0 103.4 0 51.7 52 0 1 0-103.4 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M610.3 476h123.4c1.3 0 2.3-3.6 2.3-8v-48c0-4.4-1-8-2.3-8H610.3c-1.3 0-2.3 3.6-2.3 8v48c0 4.4 1 8 2.3 8zm4.8 144h185.7c3.9 0 7.1-3.6 7.1-8v-48c0-4.4-3.2-8-7.1-8H615.1c-3.9 0-7.1 3.6-7.1 8v48c0 4.4 3.2 8 7.1 8zM224 673h43.9c4.2 0 7.6-3.3 7.9-7.5 3.8-50.5 46-90.5 97.2-90.5s93.4 40 97.2 90.5c.3 4.2 3.7 7.5 7.9 7.5H522a8 8 0 0 0 8-8.4c-2.8-53.3-32-99.7-74.6-126.1a111.8 111.8 0 0 0 29.1-75.5c0-61.9-49.9-112-111.4-112s-111.4 50.1-111.4 112c0 29.1 11 55.5 29.1 75.5a158.09 158.09 0 0 0-74.6 126.1c-.4 4.6 3.2 8.4 7.8 8.4zm149-262c28.5 0 51.7 23.3 51.7 52s-23.2 52-51.7 52-51.7-23.3-51.7-52 23.2-52 51.7-52z\"}}]})(props);\n};\nexport function AiTwotoneInfoCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm32 588c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V456c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v272zm-32-344a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M464 336a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm72 112h-48c-4.4 0-8 3.6-8 8v272c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V456c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiTwotoneInsurance (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M866.9 169.9L527.1 54.1C523 52.7 517.5 52 512 52s-11 .7-15.1 2.1L157.1 169.9c-8.3 2.8-15.1 12.4-15.1 21.2v482.4c0 8.8 5.7 20.4 12.6 25.9L499.3 968c3.5 2.7 8 4.1 12.6 4.1s9.2-1.4 12.6-4.1l344.7-268.6c6.9-5.4 12.6-17 12.6-25.9V191.1c.2-8.8-6.6-18.3-14.9-21.2zM810 654.3L512 886.5 214 654.3V226.7l298-101.6 298 101.6v427.6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M521.9 358.8h97.9v41.6h-97.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M214 226.7v427.6l298 232.2 298-232.2V226.7L512 125.1 214 226.7zM413.3 656h-.2c0 4.4-3.6 8-8 8h-37.3c-4.4 0-8-3.6-8-8V471.4c-7.7 9.2-15.4 17.9-23.1 26a6.04 6.04 0 0 1-10.2-2.4l-13.2-43.5c-.6-2-.2-4.1 1.2-5.6 37-43.4 64.7-95.1 82.2-153.6 1.1-3.5 5-5.3 8.4-3.7l38.6 18.3c2.7 1.3 4.1 4.4 3.2 7.2a429.2 429.2 0 0 1-33.6 79V656zm257.9-340v127.2c0 4.4-3.6 8-8 8h-66.7v18.6h98.8c4.4 0 8 3.6 8 8v35.6c0 4.4-3.6 8-8 8h-59c18.1 29.1 41.8 54.3 72.3 76.9 2.6 2.1 3.2 5.9 1.2 8.5l-26.3 35.3a5.92 5.92 0 0 1-8.9.7c-30.6-29.3-56.8-65.2-78.1-106.9V656c0 4.4-3.6 8-8 8h-36.2c-4.4 0-8-3.6-8-8V536c-22 44.7-49 80.8-80.6 107.6a6.38 6.38 0 0 1-4.8 1.4c-1.7-.3-3.2-1.3-4.1-2.8L432 605.7a6 6 0 0 1 1.6-8.1c28.6-20.3 51.9-45.2 71-76h-55.1c-4.4 0-8-3.6-8-8V478c0-4.4 3.6-8 8-8h94.9v-18.6h-65.9c-4.4 0-8-3.6-8-8V316c0-4.4 3.6-8 8-8h184.7c4.4 0 8 3.6 8 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M443.7 306.9l-38.6-18.3c-3.4-1.6-7.3.2-8.4 3.7-17.5 58.5-45.2 110.2-82.2 153.6a5.7 5.7 0 0 0-1.2 5.6l13.2 43.5c1.4 4.5 7 5.8 10.2 2.4 7.7-8.1 15.4-16.8 23.1-26V656c0 4.4 3.6 8 8 8h37.3c4.4 0 8-3.6 8-8h.2V393.1a429.2 429.2 0 0 0 33.6-79c.9-2.8-.5-5.9-3.2-7.2zm26.8 9.1v127.4c0 4.4 3.6 8 8 8h65.9V470h-94.9c-4.4 0-8 3.6-8 8v35.6c0 4.4 3.6 8 8 8h55.1c-19.1 30.8-42.4 55.7-71 76a6 6 0 0 0-1.6 8.1l22.8 36.5c.9 1.5 2.4 2.5 4.1 2.8 1.7.3 3.5-.2 4.8-1.4 31.6-26.8 58.6-62.9 80.6-107.6v120c0 4.4 3.6 8 8 8h36.2c4.4 0 8-3.6 8-8V535.9c21.3 41.7 47.5 77.6 78.1 106.9 2.6 2.5 6.7 2.2 8.9-.7l26.3-35.3c2-2.6 1.4-6.4-1.2-8.5-30.5-22.6-54.2-47.8-72.3-76.9h59c4.4 0 8-3.6 8-8v-35.6c0-4.4-3.6-8-8-8h-98.8v-18.6h66.7c4.4 0 8-3.6 8-8V316c0-4.4-3.6-8-8-8H478.5c-4.4 0-8 3.6-8 8zm51.4 42.8h97.9v41.6h-97.9v-41.6z\"}}]})(props);\n};\nexport function AiTwotoneInteraction (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h656V184H184v656zm114-401.9c0-55.3 44.6-100.1 99.7-100.1h205.8v-53.4c0-5.6 6.5-8.8 10.9-5.3L723.5 365c3.5 2.7 3.5 8 0 10.7l-109.1 85.7c-4.4 3.5-10.9.4-10.9-5.3v-53.4H397.8c-19.6 0-35.5 15.9-35.5 35.6v78.9c0 3.8-3.1 6.8-6.8 6.8h-50.7c-3.8 0-6.8-3-6.8-7v-78.9zm2.6 210.3l109.1-85.7c4.4-3.5 10.9-.4 10.9 5.3v53.4h205.6c19.6 0 35.5-15.9 35.5-35.6v-78.9c0-3.8 3.1-6.8 6.8-6.8h50.7c3.8 0 6.8 3.1 6.8 6.8v78.9c0 55.3-44.6 100.1-99.7 100.1H420.6v53.4c0 5.6-6.5 8.8-10.9 5.3l-109.1-85.7c-3.5-2.7-3.5-8 0-10.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M304.8 524h50.7c3.7 0 6.8-3 6.8-6.8v-78.9c0-19.7 15.9-35.6 35.5-35.6h205.7v53.4c0 5.7 6.5 8.8 10.9 5.3l109.1-85.7c3.5-2.7 3.5-8 0-10.7l-109.1-85.7c-4.4-3.5-10.9-.3-10.9 5.3V338H397.7c-55.1 0-99.7 44.8-99.7 100.1V517c0 4 3 7 6.8 7zm-4.2 134.9l109.1 85.7c4.4 3.5 10.9.3 10.9-5.3v-53.4h205.7c55.1 0 99.7-44.8 99.7-100.1v-78.9c0-3.7-3-6.8-6.8-6.8h-50.7c-3.7 0-6.8 3-6.8 6.8v78.9c0 19.7-15.9 35.6-35.5 35.6H420.6V568c0-5.7-6.5-8.8-10.9-5.3l-109.1 85.7c-3.5 2.5-3.5 7.8 0 10.5z\"}}]})(props);\n};\nexport function AiTwotoneLayout (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M384 185h456v136H384zm-200 0h136v656H184zm696-73H144c-17.7 0-32 14.3-32 32v1c0-17.7 14.3-32 32-32h736c17.7 0 32 14.3 32 32v-1c0-17.7-14.3-32-32-32zM384 385h456v456H384z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 113H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V145c0-17.7-14.3-32-32-32zM320 841H184V185h136v656zm520 0H384V385h456v456zm0-520H384V185h456v136z\"}}]})(props);\n};\nexport function AiTwotoneLeftCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm104 240.9c0 10.3-4.9 19.9-13.2 25.9L457.4 512l145.4 105.1c8.3 6 13.2 15.7 13.2 25.9v46.9c0 6.5-7.4 10.3-12.7 6.5l-246-178a7.95 7.95 0 0 1 0-12.9l246-178c5.3-3.8 12.7 0 12.7 6.5v46.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M603.3 327.5l-246 178a7.95 7.95 0 0 0 0 12.9l246 178c5.3 3.8 12.7 0 12.7-6.5V643c0-10.2-4.9-19.9-13.2-25.9L457.4 512l145.4-105.2c8.3-6 13.2-15.6 13.2-25.9V334c0-6.5-7.4-10.3-12.7-6.5z\"}}]})(props);\n};\nexport function AiTwotoneLeftSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h656V184H184v656zm181.3-334.5l246-178c5.3-3.8 12.7 0 12.7 6.5v46.9c0 10.3-4.9 19.9-13.2 25.9L465.4 512l145.4 105.2c8.3 6 13.2 15.7 13.2 25.9V690c0 6.5-7.4 10.3-12.7 6.4l-246-178a7.95 7.95 0 0 1 0-12.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M365.3 518.4l246 178c5.3 3.9 12.7.1 12.7-6.4v-46.9c0-10.2-4.9-19.9-13.2-25.9L465.4 512l145.4-105.2c8.3-6 13.2-15.6 13.2-25.9V334c0-6.5-7.4-10.3-12.7-6.5l-246 178a7.95 7.95 0 0 0 0 12.9z\"}}]})(props);\n};\nexport function AiTwotoneLike (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M273 495.9v428l.3-428zm538.2-88.3H496.8l9.6-198.4c.6-11.9-4.7-23.1-14.6-30.5-6.1-4.5-13.6-6.8-21.1-6.7-19.6.1-36.9 13.4-42.2 32.3-37.1 134.4-64.9 235.2-83.5 302.5V852h399.4a56.85 56.85 0 0 0 33.6-51.8c0-9.7-2.3-18.9-6.9-27.3l-13.9-25.4 21.9-19a56.76 56.76 0 0 0 19.6-43c0-9.7-2.3-18.9-6.9-27.3l-13.9-25.4 21.9-19a56.76 56.76 0 0 0 19.6-43c0-9.7-2.3-18.9-6.9-27.3l-14-25.5 21.9-19a56.76 56.76 0 0 0 19.6-43c0-19.1-11-37.5-28.8-48.4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M112 528v364c0 17.7 14.3 32 32 32h65V496h-65c-17.7 0-32 14.3-32 32zm773.9 5.7c16.8-22.2 26.1-49.4 26.1-77.7 0-44.9-25.1-87.5-65.5-111a67.67 67.67 0 0 0-34.3-9.3H572.3l6-122.9c1.5-29.7-9-57.9-29.5-79.4a106.4 106.4 0 0 0-77.9-33.4c-52 0-98 35-111.8 85.1l-85.8 310.8-.3 428h472.1c9.3 0 18.2-1.8 26.5-5.4 47.6-20.3 78.3-66.8 78.3-118.4 0-12.6-1.8-25-5.4-37 16.8-22.2 26.1-49.4 26.1-77.7 0-12.6-1.8-25-5.4-37 16.8-22.2 26.1-49.4 26.1-77.7 0-12.6-1.8-25-5.4-37zM820.4 499l-21.9 19 14 25.5a56.2 56.2 0 0 1 6.9 27.3c0 16.5-7.1 32.2-19.6 43l-21.9 19 13.9 25.4a56.2 56.2 0 0 1 6.9 27.3c0 16.5-7.1 32.2-19.6 43l-21.9 19 13.9 25.4a56.2 56.2 0 0 1 6.9 27.3c0 22.4-13.2 42.6-33.6 51.8H345V506.8c18.6-67.2 46.4-168 83.5-302.5a44.28 44.28 0 0 1 42.2-32.3c7.5-.1 15 2.2 21.1 6.7 9.9 7.4 15.2 18.6 14.6 30.5l-9.6 198.4h314.4C829 418.5 840 436.9 840 456c0 16.5-7.1 32.2-19.6 43z\"}}]})(props);\n};\nexport function AiTwotoneLock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 464h-68V240c0-70.7-57.3-128-128-128H388c-70.7 0-128 57.3-128 128v224h-68c-17.7 0-32 14.3-32 32v384c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V496c0-17.7-14.3-32-32-32zM332 240c0-30.9 25.1-56 56-56h248c30.9 0 56 25.1 56 56v224H332V240zm460 600H232V536h560v304z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M232 840h560V536H232v304zm280-226a48.01 48.01 0 0 1 28 87v53c0 4.4-3.6 8-8 8h-40c-4.4 0-8-3.6-8-8v-53a48.01 48.01 0 0 1 28-87z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M484 701v53c0 4.4 3.6 8 8 8h40c4.4 0 8-3.6 8-8v-53a48.01 48.01 0 1 0-56 0z\"}}]})(props);\n};\nexport function AiTwotoneMail (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M477.5 536.3L135.9 270.7l-27.5-21.4 27.6 21.5V792h752V270.8L546.2 536.3a55.99 55.99 0 0 1-68.7 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M876.3 198.8l39.3 50.5-27.6 21.5 27.7-21.5-39.3-50.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M928 160H96c-17.7 0-32 14.3-32 32v640c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V192c0-17.7-14.3-32-32-32zm-94.5 72.1L512 482 190.5 232.1h643zm54.5 38.7V792H136V270.8l-27.6-21.5 27.5 21.4 341.6 265.6a55.99 55.99 0 0 0 68.7 0L888 270.8l27.6-21.5-39.3-50.5h.1l39.3 50.5-27.7 21.5z\"}}]})(props);\n};\nexport function AiTwotoneMedicineBox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M244.3 328L184 513.4V840h656V513.4L779.7 328H244.3zM660 628c0 4.4-3.6 8-8 8H544v108c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V636H372c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h108V464c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v108h108c4.4 0 8 3.6 8 8v48z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M652 572H544V464c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v108H372c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h108v108c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V636h108c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M839.2 278.1a32 32 0 0 0-30.4-22.1H736V144c0-17.7-14.3-32-32-32H320c-17.7 0-32 14.3-32 32v112h-72.8a31.9 31.9 0 0 0-30.4 22.1L112 502v378c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V502l-72.8-223.9zM360 184h304v72H360v-72zm480 656H184V513.4L244.3 328h535.4L840 513.4V840z\"}}]})(props);\n};\nexport function AiTwotoneMeh (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zM288 421a48.01 48.01 0 0 1 96 0 48.01 48.01 0 0 1-96 0zm384 200c0 4.4-3.6 8-8 8H360c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h304c4.4 0 8 3.6 8 8v48zm16-152a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M288 421a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm376 144H360c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h304c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zm-24-144a48 48 0 1 0 96 0 48 48 0 1 0-96 0z\"}}]})(props);\n};\nexport function AiTwotoneMessage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M775.3 248.9a369.62 369.62 0 0 0-119-80A370.2 370.2 0 0 0 512.1 140h-1.7c-99.7.4-193 39.4-262.8 109.9-69.9 70.5-108 164.1-107.6 263.8.3 60.3 15.3 120.2 43.5 173.1l4.5 8.4V836h140.8l8.4 4.5c52.9 28.2 112.8 43.2 173.1 43.5h1.7c99 0 192-38.2 262.1-107.6 70.4-69.8 109.5-163.1 110.1-262.7.2-50.6-9.5-99.6-28.9-145.8a370.15 370.15 0 0 0-80-119zM312 560a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96zm200 0a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96zm200 0a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M664 512a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm-400 0a48 48 0 1 0 96 0 48 48 0 1 0-96 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M925.2 338.4c-22.6-53.7-55-101.9-96.3-143.3a444.35 444.35 0 0 0-143.3-96.3C630.6 75.7 572.2 64 512 64h-2c-60.6.3-119.3 12.3-174.5 35.9a445.35 445.35 0 0 0-142 96.5c-40.9 41.3-73 89.3-95.2 142.8-23 55.4-34.6 114.3-34.3 174.9A449.4 449.4 0 0 0 112 714v152a46 46 0 0 0 46 46h152.1A449.4 449.4 0 0 0 510 960h2.1c59.9 0 118-11.6 172.7-34.3a444.48 444.48 0 0 0 142.8-95.2c41.3-40.9 73.8-88.7 96.5-142 23.6-55.2 35.6-113.9 35.9-174.5.3-60.9-11.5-120-34.8-175.6zm-151.1 438C704 845.8 611 884 512 884h-1.7c-60.3-.3-120.2-15.3-173.1-43.5l-8.4-4.5H188V695.2l-4.5-8.4C155.3 633.9 140.3 574 140 513.7c-.4-99.7 37.7-193.3 107.6-263.8 69.8-70.5 163.1-109.5 262.8-109.9h1.7c50 0 98.5 9.7 144.2 28.9 44.6 18.7 84.6 45.6 119 80 34.3 34.3 61.3 74.4 80 119 19.4 46.2 29.1 95.2 28.9 145.8-.6 99.6-39.7 192.9-110.1 262.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M464 512a48 48 0 1 0 96 0 48 48 0 1 0-96 0z\"}}]})(props);\n};\nexport function AiTwotoneMinusCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm192 396c0 4.4-3.6 8-8 8H328c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h368c4.4 0 8 3.6 8 8v48z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M696 480H328c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h368c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiTwotoneMinusSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h656V184H184v656zm136-352c0-4.4 3.6-8 8-8h368c4.4 0 8 3.6 8 8v48c0 4.4-3.6 8-8 8H328c-4.4 0-8-3.6-8-8v-48z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M328 544h368c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H328c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiTwotoneMobile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M744 64H280c-35.3 0-64 28.7-64 64v768c0 35.3 28.7 64 64 64h464c35.3 0 64-28.7 64-64V128c0-35.3-28.7-64-64-64zm-8 824H288V136h448v752z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M288 888h448V136H288v752zm224-142c22.1 0 40 17.9 40 40s-17.9 40-40 40-40-17.9-40-40 17.9-40 40-40z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M472 786a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}}]})(props);\n};\nexport function AiTwotoneMoneyCollect (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M256 744.4l256 93.1 256-93.1V184H256v560.4zM359.7 313c1.2-.7 2.5-1 3.8-1h55.7a8 8 0 0 1 7.1 4.4L511 485.2h3.3L599 316.4c1.3-2.7 4.1-4.4 7.1-4.4h54.5c4.4 0 8 3.6 8.1 7.9 0 1.3-.4 2.6-1 3.8L564 515.3h57.6c4.4 0 8 3.6 8 8v27.1c0 4.4-3.6 8-8 8h-76.3v39h76.3c4.4 0 8 3.6 8 8v27.1c0 4.4-3.6 8-8 8h-76.3V704c0 4.4-3.6 8-8 8h-49.9c-4.4 0-8-3.6-8-8v-63.4h-76c-4.4 0-8-3.6-8-8v-27.1c0-4.4 3.6-8 8-8h76v-39h-76c-4.4 0-8-3.6-8-8v-27.1c0-4.4 3.6-8 8-8h57L356.5 323.8c-2.1-3.8-.7-8.7 3.2-10.8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M911.5 700.7a8 8 0 0 0-10.3-4.8L840 718.2V180c0-37.6-30.4-68-68-68H252c-37.6 0-68 30.4-68 68v538.2l-61.3-22.3c-.9-.3-1.8-.5-2.7-.5-4.4 0-8 3.6-8 8V763c0 3.3 2.1 6.3 5.3 7.5L501 910.1c7.1 2.6 14.8 2.6 21.9 0l383.8-139.5c3.2-1.2 5.3-4.2 5.3-7.5v-59.6c0-1-.2-1.9-.5-2.8zM768 744.4l-256 93.1-256-93.1V184h512v560.4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M460.4 515.4h-57c-4.4 0-8 3.6-8 8v27.1c0 4.4 3.6 8 8 8h76v39h-76c-4.4 0-8 3.6-8 8v27.1c0 4.4 3.6 8 8 8h76V704c0 4.4 3.6 8 8 8h49.9c4.4 0 8-3.6 8-8v-63.5h76.3c4.4 0 8-3.6 8-8v-27.1c0-4.4-3.6-8-8-8h-76.3v-39h76.3c4.4 0 8-3.6 8-8v-27.1c0-4.4-3.6-8-8-8H564l103.7-191.6c.6-1.2 1-2.5 1-3.8-.1-4.3-3.7-7.9-8.1-7.9h-54.5c-3 0-5.8 1.7-7.1 4.4l-84.7 168.8H511l-84.7-168.8a8 8 0 0 0-7.1-4.4h-55.7c-1.3 0-2.6.3-3.8 1-3.9 2.1-5.3 7-3.2 10.8l103.9 191.6z\"}}]})(props);\n};\nexport function AiTwotoneNotification (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M229.6 678.1c-3.7 11.6-5.6 23.9-5.6 36.4 0-12.5 2-24.8 5.7-36.4h-.1zm76.3-260.2H184v188.2h121.9l12.9 5.2L840 820.7V203.3L318.8 412.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112c-3.8 0-7.7.7-11.6 2.3L292 345.9H128c-8.8 0-16 7.4-16 16.6v299c0 9.2 7.2 16.6 16 16.6h101.7c-3.7 11.6-5.7 23.9-5.7 36.4 0 65.9 53.8 119.5 120 119.5 55.4 0 102.1-37.6 115.9-88.4l408.6 164.2c3.9 1.5 7.8 2.3 11.6 2.3 16.9 0 32-14.2 32-33.2V145.2C912 126.2 897 112 880 112zM344 762.3c-26.5 0-48-21.4-48-47.8 0-11.2 3.9-21.9 11-30.4l84.9 34.1c-2 24.6-22.7 44.1-47.9 44.1zm496 58.4L318.8 611.3l-12.9-5.2H184V417.9h121.9l12.9-5.2L840 203.3v617.4z\"}}]})(props);\n};\nexport function AiTwotonePauseCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm-80 524c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V360c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v304zm224 0c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V360c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v304z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M424 352h-48c-4.4 0-8 3.6-8 8v304c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V360c0-4.4-3.6-8-8-8zm224 0h-48c-4.4 0-8 3.6-8 8v304c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V360c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiTwotonePhone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M721.7 184.9L610.9 295.8l120.8 120.7-8 21.6A481.29 481.29 0 0 1 438 723.9l-21.6 8-.9-.9-119.8-120-110.8 110.9 104.5 104.5c10.8 10.7 26 15.7 40.8 13.2 117.9-19.5 235.4-82.9 330.9-178.4s158.9-213.1 178.4-331c2.5-14.8-2.5-30-13.3-40.8L721.7 184.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M877.1 238.7L770.6 132.3c-13-13-30.4-20.3-48.8-20.3s-35.8 7.2-48.8 20.3L558.3 246.8c-13 13-20.3 30.5-20.3 48.9 0 18.5 7.2 35.8 20.3 48.9l89.6 89.7a405.46 405.46 0 0 1-86.4 127.3c-36.7 36.9-79.6 66-127.2 86.6l-89.6-89.7c-13-13-30.4-20.3-48.8-20.3a68.2 68.2 0 0 0-48.8 20.3L132.3 673c-13 13-20.3 30.5-20.3 48.9 0 18.5 7.2 35.8 20.3 48.9l106.4 106.4c22.2 22.2 52.8 34.9 84.2 34.9 6.5 0 12.8-.5 19.2-1.6 132.4-21.8 263.8-92.3 369.9-198.3C818 606 888.4 474.6 910.4 342.1c6.3-37.6-6.3-76.3-33.3-103.4zm-37.6 91.5c-19.5 117.9-82.9 235.5-178.4 331s-213 158.9-330.9 178.4c-14.8 2.5-30-2.5-40.8-13.2L184.9 721.9 295.7 611l119.8 120 .9.9 21.6-8a481.29 481.29 0 0 0 285.7-285.8l8-21.6-120.8-120.7 110.8-110.9 104.5 104.5c10.8 10.8 15.8 26 13.3 40.8z\"}}]})(props);\n};\nexport function AiTwotonePicture (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M928 160H96c-17.7 0-32 14.3-32 32v640c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V192c0-17.7-14.3-32-32-32zm-40 632H136v-39.9l138.5-164.3 150.1 178L658.1 489 888 761.6V792zm0-129.8L664.2 396.8c-3.2-3.8-9-3.8-12.2 0L424.6 666.4l-144-170.7c-3.2-3.8-9-3.8-12.2 0L136 652.7V232h752v430.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M424.6 765.8l-150.1-178L136 752.1V792h752v-30.4L658.1 489z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M136 652.7l132.4-157c3.2-3.8 9-3.8 12.2 0l144 170.7L652 396.8c3.2-3.8 9-3.8 12.2 0L888 662.2V232H136v420.7zM304 280a88 88 0 1 1 0 176 88 88 0 0 1 0-176z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M276 368a28 28 0 1 0 56 0 28 28 0 1 0-56 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M304 456a88 88 0 1 0 0-176 88 88 0 0 0 0 176zm0-116c15.5 0 28 12.5 28 28s-12.5 28-28 28-28-12.5-28-28 12.5-28 28-28z\"}}]})(props);\n};\nexport function AiTwotonePieChart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M316.2 920.5c-47.6-20.1-90.4-49-127.1-85.7a398.19 398.19 0 0 1-85.7-127.1A397.12 397.12 0 0 1 72 552.2v.2a398.57 398.57 0 0 0 117 282.5c36.7 36.7 79.4 65.5 127 85.6A396.64 396.64 0 0 0 471.6 952c27 0 53.6-2.7 79.7-7.9-25.9 5.2-52.4 7.8-79.3 7.8-54 .1-106.4-10.5-155.8-31.4zM560 472c-4.4 0-8-3.6-8-8V79.9c0-1.3.3-2.5.9-3.6-.9 1.3-1.5 2.9-1.5 4.6v383.7c0 4.4 3.6 8 8 8l383.6-1c1.6 0 3.1-.5 4.4-1.3-1 .5-2.2.7-3.4.7l-384 1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M619.8 147.6v256.6l256.4-.7c-13-62.5-44.3-120.5-90-166.1a332.24 332.24 0 0 0-166.4-89.8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M438 221.7c-75.9 7.6-146.2 40.9-200.8 95.5C174.5 379.9 140 463.3 140 552s34.5 172.1 97.2 234.8c62.3 62.3 145.1 96.8 233.2 97.2 88.2.4 172.7-34.1 235.3-96.2C761 733 794.6 662.3 802.3 586H438V221.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M864 518H506V160c0-4.4-3.6-8-8-8h-26a398.46 398.46 0 0 0-282.8 117.1 398.19 398.19 0 0 0-85.7 127.1A397.61 397.61 0 0 0 72 552v.2c0 53.9 10.6 106.2 31.4 155.5 20.1 47.6 49 90.4 85.7 127.1 36.7 36.7 79.5 65.6 127.1 85.7A397.61 397.61 0 0 0 472 952c26.9 0 53.4-2.6 79.3-7.8 26.1-5.3 51.7-13.1 76.4-23.6 47.6-20.1 90.4-49 127.1-85.7 36.7-36.7 65.6-79.5 85.7-127.1A397.61 397.61 0 0 0 872 552v-26c0-4.4-3.6-8-8-8zM705.7 787.8A331.59 331.59 0 0 1 470.4 884c-88.1-.4-170.9-34.9-233.2-97.2C174.5 724.1 140 640.7 140 552s34.5-172.1 97.2-234.8c54.6-54.6 124.9-87.9 200.8-95.5V586h364.3c-7.7 76.3-41.3 147-96.6 201.8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M952 462.4l-2.6-28.2c-8.5-92.1-49.4-179-115.2-244.6A399.4 399.4 0 0 0 589 74.6L560.7 72c-3.4-.3-6.4 1.5-7.8 4.3a8.7 8.7 0 0 0-.9 3.6V464c0 4.4 3.6 8 8 8l384-1c1.2 0 2.3-.3 3.4-.7a8.1 8.1 0 0 0 4.6-7.9zm-332.2-58.2V147.6a332.24 332.24 0 0 1 166.4 89.8c45.7 45.6 77 103.6 90 166.1l-256.4.7z\"}}]})(props);\n};\nexport function AiTwotonePlayCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm164.1 378.2L457.7 677.1a8.02 8.02 0 0 1-12.7-6.5V353a8 8 0 0 1 12.7-6.5l218.4 158.8a7.9 7.9 0 0 1 0 12.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M676.1 505.3L457.7 346.5A8 8 0 0 0 445 353v317.6a8.02 8.02 0 0 0 12.7 6.5l218.4-158.9a7.9 7.9 0 0 0 0-12.9z\"}}]})(props);\n};\nexport function AiTwotonePlaySquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h656V184H184v656zm240-484.7c0-9.4 10.9-14.7 18.3-8.8l199.4 156.7a11.2 11.2 0 0 1 0 17.6L442.3 677.6c-7.4 5.8-18.3.6-18.3-8.8V355.3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M442.3 677.6l199.4-156.8a11.2 11.2 0 0 0 0-17.6L442.3 346.5c-7.4-5.9-18.3-.6-18.3 8.8v313.5c0 9.4 10.9 14.6 18.3 8.8z\"}}]})(props);\n};\nexport function AiTwotonePlusCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm192 396c0 4.4-3.6 8-8 8H544v152c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V544H328c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h152V328c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v152h152c4.4 0 8 3.6 8 8v48z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M696 480H544V328c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v152H328c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h152v152c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V544h152c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiTwotonePlusSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h656V184H184v656zm136-352c0-4.4 3.6-8 8-8h152V328c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v152h152c4.4 0 8 3.6 8 8v48c0 4.4-3.6 8-8 8H544v152c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V544H328c-4.4 0-8-3.6-8-8v-48z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M328 544h152v152c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V544h152c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H544V328c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v152H328c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiTwotonePoundCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm146 582.1c0 4.4-3.6 8-8 8H376.2c-4.4 0-8-3.6-8-8v-38.5c0-3.7 2.5-6.9 6.1-7.8 44-10.9 72.8-49 72.8-94.2 0-14.7-2.5-29.4-5.9-44.2H374c-4.4 0-8-3.6-8-8v-30c0-4.4 3.6-8 8-8h53.7c-7.8-25.1-14.6-50.7-14.6-77.1 0-75.8 58.6-120.3 151.5-120.3 26.5 0 51.4 5.5 70.3 12.7 3.1 1.2 5.2 4.2 5.2 7.5v39.5a8 8 0 0 1-10.6 7.6c-17.9-6.4-39-10.5-60.4-10.5-53.3 0-87.3 26.6-87.3 70.2 0 24.7 6.2 47.9 13.4 70.5h112c4.4 0 8 3.6 8 8v30c0 4.4-3.6 8-8 8h-98.6c3.1 13.2 5.3 26.9 5.3 41 0 40.7-16.5 73.9-43.9 91.1v4.7h180c4.4 0 8 3.6 8 8v39.8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M650 674.3H470v-4.7c27.4-17.2 43.9-50.4 43.9-91.1 0-14.1-2.2-27.8-5.3-41h98.6c4.4 0 8-3.6 8-8v-30c0-4.4-3.6-8-8-8h-112c-7.2-22.6-13.4-45.8-13.4-70.5 0-43.6 34-70.2 87.3-70.2 21.4 0 42.5 4.1 60.4 10.5a8 8 0 0 0 10.6-7.6v-39.5c0-3.3-2.1-6.3-5.2-7.5-18.9-7.2-43.8-12.7-70.3-12.7-92.9 0-151.5 44.5-151.5 120.3 0 26.4 6.8 52 14.6 77.1H374c-4.4 0-8 3.6-8 8v30c0 4.4 3.6 8 8 8h67.2c3.4 14.8 5.9 29.5 5.9 44.2 0 45.2-28.8 83.3-72.8 94.2-3.6.9-6.1 4.1-6.1 7.8v38.5c0 4.4 3.6 8 8 8H650c4.4 0 8-3.6 8-8v-39.8c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiTwotonePrinter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M360 180h304v152H360zm492 220H172c-6.6 0-12 5.4-12 12v292h132V500h440v204h132V412c0-6.6-5.4-12-12-12zm-24 84c0 4.4-3.6 8-8 8h-40c-4.4 0-8-3.6-8-8v-40c0-4.4 3.6-8 8-8h40c4.4 0 8 3.6 8 8v40z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M852 332H732V120c0-4.4-3.6-8-8-8H300c-4.4 0-8 3.6-8 8v212H172c-44.2 0-80 35.8-80 80v328c0 17.7 14.3 32 32 32h168v132c0 4.4 3.6 8 8 8h424c4.4 0 8-3.6 8-8V772h168c17.7 0 32-14.3 32-32V412c0-44.2-35.8-80-80-80zM360 180h304v152H360V180zm304 664H360V568h304v276zm200-140H732V500H292v204H160V412c0-6.6 5.4-12 12-12h680c6.6 0 12 5.4 12 12v292z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M820 436h-40c-4.4 0-8 3.6-8 8v40c0 4.4 3.6 8 8 8h40c4.4 0 8-3.6 8-8v-40c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiTwotoneProfile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h656V184H184v656zm300-496c0-4.4 3.6-8 8-8h184c4.4 0 8 3.6 8 8v48c0 4.4-3.6 8-8 8H492c-4.4 0-8-3.6-8-8v-48zm0 144c0-4.4 3.6-8 8-8h184c4.4 0 8 3.6 8 8v48c0 4.4-3.6 8-8 8H492c-4.4 0-8-3.6-8-8v-48zm0 144c0-4.4 3.6-8 8-8h184c4.4 0 8 3.6 8 8v48c0 4.4-3.6 8-8 8H492c-4.4 0-8-3.6-8-8v-48zM380 328c22.1 0 40 17.9 40 40s-17.9 40-40 40-40-17.9-40-40 17.9-40 40-40zm0 144c22.1 0 40 17.9 40 40s-17.9 40-40 40-40-17.9-40-40 17.9-40 40-40zm0 144c22.1 0 40 17.9 40 40s-17.9 40-40 40-40-17.9-40-40 17.9-40 40-40z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M340 656a40 40 0 1 0 80 0 40 40 0 1 0-80 0zm0-144a40 40 0 1 0 80 0 40 40 0 1 0-80 0zm0-144a40 40 0 1 0 80 0 40 40 0 1 0-80 0zm152 320h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H492c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8zm0-144h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H492c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8zm0-144h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H492c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiTwotoneProject (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h656V184H184v656zm472-560c0-4.4 3.6-8 8-8h80c4.4 0 8 3.6 8 8v256c0 4.4-3.6 8-8 8h-80c-4.4 0-8-3.6-8-8V280zm-192 0c0-4.4 3.6-8 8-8h80c4.4 0 8 3.6 8 8v184c0 4.4-3.6 8-8 8h-80c-4.4 0-8-3.6-8-8V280zm-192 0c0-4.4 3.6-8 8-8h80c4.4 0 8 3.6 8 8v464c0 4.4-3.6 8-8 8h-80c-4.4 0-8-3.6-8-8V280z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M280 752h80c4.4 0 8-3.6 8-8V280c0-4.4-3.6-8-8-8h-80c-4.4 0-8 3.6-8 8v464c0 4.4 3.6 8 8 8zm192-280h80c4.4 0 8-3.6 8-8V280c0-4.4-3.6-8-8-8h-80c-4.4 0-8 3.6-8 8v184c0 4.4 3.6 8 8 8zm192 72h80c4.4 0 8-3.6 8-8V280c0-4.4-3.6-8-8-8h-80c-4.4 0-8 3.6-8 8v256c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiTwotonePropertySafety (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M866.9 169.9L527.1 54.1C523 52.7 517.5 52 512 52s-11 .7-15.1 2.1L157.1 169.9c-8.3 2.8-15.1 12.4-15.1 21.2v482.4c0 8.8 5.7 20.4 12.6 25.9L499.3 968c3.5 2.7 8 4.1 12.6 4.1s9.2-1.4 12.6-4.1l344.7-268.6c6.9-5.4 12.6-17 12.6-25.9V191.1c.2-8.8-6.6-18.3-14.9-21.2zM810 654.3L512 886.5 214 654.3V226.7l298-101.6 298 101.6v427.6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M214 226.7v427.6l298 232.2 298-232.2V226.7L512 125.1 214 226.7zM593.9 318h45c5.5 0 10 4.5 10 10 .1 1.7-.3 3.3-1.1 4.8l-87.7 161.1h45.7c5.5 0 10 4.5 10 10v21.3c0 5.5-4.5 10-10 10h-63.4v29.7h63.4c5.5 0 10 4.5 10 10v21.3c0 5.5-4.5 10-10 10h-63.4V658c0 5.5-4.5 10-10 10h-41.3c-5.5 0-10-4.5-10-10v-51.8H418c-5.5 0-10-4.5-10-10v-21.3c0-5.5 4.5-10 10-10h63.1v-29.7H418c-5.5 0-10-4.5-10-10v-21.3c0-5.5 4.5-10 10-10h45.2l-88-161.1c-2.6-4.8-.9-10.9 4-13.6 1.5-.8 3.1-1.2 4.8-1.2h46c3.8 0 7.2 2.1 8.9 5.5l72.9 144.3L585 323.5a10 10 0 0 1 8.9-5.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M438.9 323.5a9.88 9.88 0 0 0-8.9-5.5h-46c-1.7 0-3.3.4-4.8 1.2-4.9 2.7-6.6 8.8-4 13.6l88 161.1H418c-5.5 0-10 4.5-10 10v21.3c0 5.5 4.5 10 10 10h63.1v29.7H418c-5.5 0-10 4.5-10 10v21.3c0 5.5 4.5 10 10 10h63.1V658c0 5.5 4.5 10 10 10h41.3c5.5 0 10-4.5 10-10v-51.8h63.4c5.5 0 10-4.5 10-10v-21.3c0-5.5-4.5-10-10-10h-63.4v-29.7h63.4c5.5 0 10-4.5 10-10v-21.3c0-5.5-4.5-10-10-10h-45.7l87.7-161.1c.8-1.5 1.2-3.1 1.1-4.8 0-5.5-4.5-10-10-10h-45a10 10 0 0 0-8.9 5.5l-73.2 144.3-72.9-144.3z\"}}]})(props);\n};\nexport function AiTwotonePushpin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M474.8 357.7l-24.5 24.5-34.4-3.8c-9.6-1.1-19.3-1.6-28.9-1.6-29 0-57.5 4.7-84.7 14.1-14 4.8-27.4 10.8-40.3 17.9l353.1 353.3a259.92 259.92 0 0 0 30.4-153.9l-3.8-34.4 24.5-24.5L800 415.5 608.5 224 474.8 357.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M878.3 392.1L631.9 145.7c-6.5-6.5-15-9.7-23.5-9.7s-17 3.2-23.5 9.7L423.8 306.9c-12.2-1.4-24.5-2-36.8-2-73.2 0-146.4 24.1-206.5 72.3a33.23 33.23 0 0 0-2.7 49.4l181.7 181.7-215.4 215.2a15.8 15.8 0 0 0-4.6 9.8l-3.4 37.2c-.9 9.4 6.6 17.4 15.9 17.4.5 0 1 0 1.5-.1l37.2-3.4c3.7-.3 7.2-2 9.8-4.6l215.4-215.4 181.7 181.7c6.5 6.5 15 9.7 23.5 9.7 9.7 0 19.3-4.2 25.9-12.4 56.3-70.3 79.7-158.3 70.2-243.4l161.1-161.1c12.9-12.8 12.9-33.8 0-46.8zM666.2 549.3l-24.5 24.5 3.8 34.4a259.92 259.92 0 0 1-30.4 153.9L262 408.8c12.9-7.1 26.3-13.1 40.3-17.9 27.2-9.4 55.7-14.1 84.7-14.1 9.6 0 19.3.5 28.9 1.6l34.4 3.8 24.5-24.5L608.5 224 800 415.5 666.2 549.3z\"}}]})(props);\n};\nexport function AiTwotoneQuestionCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm0 632c-22.1 0-40-17.9-40-40s17.9-40 40-40 40 17.9 40 40-17.9 40-40 40zm62.9-219.5a48.3 48.3 0 0 0-30.9 44.8V620c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8v-21.5c0-23.1 6.7-45.9 19.9-64.9 12.9-18.6 30.9-32.8 52.1-40.9 34-13.1 56-41.6 56-72.7 0-44.1-43.1-80-96-80s-96 35.9-96 80v7.6c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V420c0-39.3 17.2-76 48.4-103.3C430.4 290.4 470 276 512 276s81.6 14.5 111.6 40.7C654.8 344 672 380.7 672 420c0 57.8-38.1 109.8-97.1 132.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M472 732a40 40 0 1 0 80 0 40 40 0 1 0-80 0zm151.6-415.3C593.6 290.5 554 276 512 276s-81.6 14.4-111.6 40.7C369.2 344 352 380.7 352 420v7.6c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V420c0-44.1 43.1-80 96-80s96 35.9 96 80c0 31.1-22 59.6-56 72.7-21.2 8.1-39.2 22.3-52.1 40.9-13.2 19-19.9 41.8-19.9 64.9V620c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-22.7a48.3 48.3 0 0 1 30.9-44.8c59-22.7 97.1-74.7 97.1-132.5 0-39.3-17.2-76-48.4-103.3z\"}}]})(props);\n};\nexport function AiTwotoneReconciliation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M740 344H404V240H304v160h176c17.7 0 32 14.3 32 32v360h328V240H740v104zM584 448c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v56c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8v-56zm92 301c-50.8 0-92-41.2-92-92s41.2-92 92-92 92 41.2 92 92-41.2 92-92 92zm92-341v96c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8v-96c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M642 657a34 34 0 1 0 68 0 34 34 0 1 0-68 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M592 512h48c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8zm112-104v96c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-96c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 168H668c0-30.9-25.1-56-56-56h-80c-30.9 0-56 25.1-56 56H264c-17.7 0-32 14.3-32 32v200h-88c-17.7 0-32 14.3-32 32v448c0 17.7 14.3 32 32 32h336c17.7 0 32-14.3 32-32v-16h368c17.7 0 32-14.3 32-32V200c0-17.7-14.3-32-32-32zm-412 64h72v-56h64v56h72v48H468v-48zm-20 616H176V616h272v232zm0-296H176v-88h272v88zm392 240H512V432c0-17.7-14.3-32-32-32H304V240h100v104h336V240h100v552z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M676 565c-50.8 0-92 41.2-92 92s41.2 92 92 92 92-41.2 92-92-41.2-92-92-92zm0 126c-18.8 0-34-15.2-34-34s15.2-34 34-34 34 15.2 34 34-15.2 34-34 34z\"}}]})(props);\n};\nexport function AiTwotoneRedEnvelope (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M832 64H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V96c0-17.7-14.3-32-32-32zm-40 824H232V193.1l260.3 204.1c11.6 9.1 27.9 9.1 39.5 0L792 193.1V888zm0-751.3h-31.7L512 331.3 263.7 136.7H232v-.7h560v.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M492.3 397.2L232 193.1V888h560V193.1L531.8 397.2a31.99 31.99 0 0 1-39.5 0zm99.4 60.9h47.8a8.45 8.45 0 0 1 7.4 12.4l-87.2 161h45.9c4.6 0 8.4 3.8 8.4 8.4V665c0 4.6-3.8 8.4-8.4 8.4h-63.3V702h63.3c4.6 0 8.4 3.8 8.4 8.4v25c.2 4.7-3.5 8.5-8.2 8.5h-63.3v49.9c0 4.6-3.8 8.4-8.4 8.4h-43.7c-4.6 0-8.4-3.8-8.4-8.4v-49.9h-63c-4.6 0-8.4-3.8-8.4-8.4v-25.1c0-4.6 3.8-8.4 8.4-8.4h63v-28.6h-63c-4.6 0-8.4-3.8-8.4-8.4v-25.1c0-4.6 3.8-8.4 8.4-8.4h45.4L377 470.4a8.4 8.4 0 0 1 3.4-11.4c1.3-.6 2.6-1 3.9-1h48.8c3.2 0 6.1 1.8 7.5 4.6l71.7 142 71.9-141.9a8.6 8.6 0 0 1 7.5-4.6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M232 136.7h31.7L512 331.3l248.3-194.6H792v-.7H232z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M440.6 462.6a8.38 8.38 0 0 0-7.5-4.6h-48.8c-1.3 0-2.6.4-3.9 1a8.4 8.4 0 0 0-3.4 11.4l87.4 161.1H419c-4.6 0-8.4 3.8-8.4 8.4V665c0 4.6 3.8 8.4 8.4 8.4h63V702h-63c-4.6 0-8.4 3.8-8.4 8.4v25.1c0 4.6 3.8 8.4 8.4 8.4h63v49.9c0 4.6 3.8 8.4 8.4 8.4h43.7c4.6 0 8.4-3.8 8.4-8.4v-49.9h63.3c4.7 0 8.4-3.8 8.2-8.5v-25c0-4.6-3.8-8.4-8.4-8.4h-63.3v-28.6h63.3c4.6 0 8.4-3.8 8.4-8.4v-25.1c0-4.6-3.8-8.4-8.4-8.4h-45.9l87.2-161a8.45 8.45 0 0 0-7.4-12.4h-47.8c-3.1 0-6 1.8-7.5 4.6l-71.9 141.9-71.7-142z\"}}]})(props);\n};\nexport function AiTwotoneRest (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M326.4 844h363.2l44.3-520H282l44.4 520zM508 416c79.5 0 144 64.5 144 144s-64.5 144-144 144-144-64.5-144-144 64.5-144 144-144z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M508 704c79.5 0 144-64.5 144-144s-64.5-144-144-144-144 64.5-144 144 64.5 144 144 144zm0-224c44.2 0 80 35.8 80 80s-35.8 80-80 80-80-35.8-80-80 35.8-80 80-80z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M832 256h-28.1l-35.7-120.9c-4-13.7-16.5-23.1-30.7-23.1h-451c-14.3 0-26.8 9.4-30.7 23.1L220.1 256H192c-17.7 0-32 14.3-32 32v28c0 4.4 3.6 8 8 8h45.8l47.7 558.7a32 32 0 0 0 31.9 29.3h429.2a32 32 0 0 0 31.9-29.3L802.2 324H856c4.4 0 8-3.6 8-8v-28c0-17.7-14.3-32-32-32zm-518.6-76h397.2l22.4 76H291l22.4-76zm376.2 664H326.4L282 324h451.9l-44.3 520z\"}}]})(props);\n};\nexport function AiTwotoneRightCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm154.7 378.4l-246 178c-5.3 3.8-12.7 0-12.7-6.5V643c0-10.2 4.9-19.9 13.2-25.9L566.6 512 421.2 406.8c-8.3-6-13.2-15.6-13.2-25.9V334c0-6.5 7.4-10.3 12.7-6.5l246 178c4.4 3.2 4.4 9.7 0 12.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M666.7 505.5l-246-178c-5.3-3.8-12.7 0-12.7 6.5v46.9c0 10.3 4.9 19.9 13.2 25.9L566.6 512 421.2 617.1c-8.3 6-13.2 15.7-13.2 25.9v46.9c0 6.5 7.4 10.3 12.7 6.5l246-178c4.4-3.2 4.4-9.7 0-12.9z\"}}]})(props);\n};\nexport function AiTwotoneRightSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h656V184H184v656zm216-196.9c0-10.2 4.9-19.9 13.2-25.9L558.6 512 413.2 406.8c-8.3-6-13.2-15.6-13.2-25.9V334c0-6.5 7.4-10.3 12.7-6.5l246 178c4.4 3.2 4.4 9.7 0 12.9l-246 178c-5.3 3.9-12.7.1-12.7-6.4v-46.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M412.7 696.4l246-178c4.4-3.2 4.4-9.7 0-12.9l-246-178c-5.3-3.8-12.7 0-12.7 6.5v46.9c0 10.3 4.9 19.9 13.2 25.9L558.6 512 413.2 617.2c-8.3 6-13.2 15.7-13.2 25.9V690c0 6.5 7.4 10.3 12.7 6.4z\"}}]})(props);\n};\nexport function AiTwotoneRocket (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M261.7 621.4c-9.4 14.6-17 30.3-22.5 46.6H324V558.7c-24.8 16.2-46 37.5-62.3 62.7zM700 558.7V668h84.8c-5.5-16.3-13.1-32-22.5-46.6a211.6 211.6 0 0 0-62.3-62.7zm-64-239.9l-124-147-124 147V668h248V318.8zM512 448a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M864 736c0-111.6-65.4-208-160-252.9V317.3c0-15.1-5.3-29.7-15.1-41.2L536.5 95.4C530.1 87.8 521 84 512 84s-18.1 3.8-24.5 11.4L335.1 276.1a63.97 63.97 0 0 0-15.1 41.2v165.8C225.4 528 160 624.4 160 736h156.5c-2.3 7.2-3.5 15-3.5 23.8 0 22.1 7.6 43.7 21.4 60.8a97.2 97.2 0 0 0 43.1 30.6c23.1 54 75.6 88.8 134.5 88.8 29.1 0 57.3-8.6 81.4-24.8 23.6-15.8 41.9-37.9 53-64a97 97 0 0 0 43.1-30.5 97.52 97.52 0 0 0 21.4-60.8c0-8.4-1.1-16.4-3.1-23.8L864 736zm-540-68h-84.8c5.5-16.3 13.1-32 22.5-46.6 16.3-25.2 37.5-46.5 62.3-62.7V668zm64-184.9V318.8l124-147 124 147V668H388V483.1zm240.1 301.1c-5.2 3-11.2 4.2-17.1 3.4l-19.5-2.4-2.8 19.4c-5.4 37.9-38.4 66.5-76.7 66.5s-71.3-28.6-76.7-66.5l-2.8-19.5-19.5 2.5a27.7 27.7 0 0 1-17.1-3.5c-8.7-5-14.1-14.3-14.1-24.4 0-10.6 5.9-19.4 14.6-23.8h231.3c8.8 4.5 14.6 13.3 14.6 23.8-.1 10.2-5.5 19.6-14.2 24.5zM700 668V558.7a211.6 211.6 0 0 1 62.3 62.7c9.4 14.6 17 30.3 22.5 46.6H700z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M464 400a48 48 0 1 0 96 0 48 48 0 1 0-96 0z\"}}]})(props);\n};\nexport function AiTwotoneSafetyCertificate (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M866.9 169.9L527.1 54.1C523 52.7 517.5 52 512 52s-11 .7-15.1 2.1L157.1 169.9c-8.3 2.8-15.1 12.4-15.1 21.2v482.4c0 8.8 5.7 20.4 12.6 25.9L499.3 968c3.5 2.7 8 4.1 12.6 4.1s9.2-1.4 12.6-4.1l344.7-268.6c6.9-5.4 12.6-17 12.6-25.9V191.1c.2-8.8-6.6-18.3-14.9-21.2zM810 654.3L512 886.5 214 654.3V226.7l298-101.6 298 101.6v427.6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M214 226.7v427.6l298 232.2 298-232.2V226.7L512 125.1 214 226.7zM632.8 328H688c6.5 0 10.3 7.4 6.5 12.7L481.9 633.4a16.1 16.1 0 0 1-26 0l-126.4-174c-3.8-5.3 0-12.7 6.5-12.7h55.2c5.2 0 10 2.5 13 6.6l64.7 89.1 150.9-207.8c3-4.1 7.9-6.6 13-6.6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M404.2 453.3c-3-4.1-7.8-6.6-13-6.6H336c-6.5 0-10.3 7.4-6.5 12.7l126.4 174a16.1 16.1 0 0 0 26 0l212.6-292.7c3.8-5.3 0-12.7-6.5-12.7h-55.2c-5.1 0-10 2.5-13 6.6L468.9 542.4l-64.7-89.1z\"}}]})(props);\n};\nexport function AiTwotoneSave (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M704 320c0 17.7-14.3 32-32 32H352c-17.7 0-32-14.3-32-32V184H184v656h656V341.8l-136-136V320zM512 730c-79.5 0-144-64.5-144-144s64.5-144 144-144 144 64.5 144 144-64.5 144-144 144z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 442c-79.5 0-144 64.5-144 144s64.5 144 144 144 144-64.5 144-144-64.5-144-144-144zm0 224c-44.2 0-80-35.8-80-80s35.8-80 80-80 80 35.8 80 80-35.8 80-80 80z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M893.3 293.3L730.7 130.7c-.7-.7-1.4-1.3-2.1-2-.1-.1-.3-.2-.4-.3-.7-.7-1.5-1.3-2.2-1.9a64 64 0 0 0-22-11.7V112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V338.5c0-17-6.7-33.2-18.7-45.2zM384 184h256v104H384V184zm456 656H184V184h136v136c0 17.7 14.3 32 32 32h320c17.7 0 32-14.3 32-32V205.8l136 136V840z\"}}]})(props);\n};\nexport function AiTwotoneSchedule (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M768 352c0 4.4-3.6 8-8 8h-56c-4.4 0-8-3.6-8-8v-56H548v56c0 4.4-3.6 8-8 8h-56c-4.4 0-8-3.6-8-8v-56H328v56c0 4.4-3.6 8-8 8h-56c-4.4 0-8-3.6-8-8v-56H136v496h752V296H768v56zM424 688c0 4.4-3.6 8-8 8H232c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h184c4.4 0 8 3.6 8 8v48zm0-136c0 4.4-3.6 8-8 8H232c-4.4 0-8-3.6-8-8v-48c0-4.4 3.6-8 8-8h184c4.4 0 8 3.6 8 8v48zm374.4-91.2l-165 228.7a15.9 15.9 0 0 1-25.8 0L493.5 531.3c-3.8-5.3 0-12.7 6.5-12.7h54.9c5.1 0 9.9 2.4 12.9 6.6l52.8 73.1 103.6-143.7c3-4.1 7.8-6.6 12.8-6.5h54.9c6.5 0 10.3 7.4 6.5 12.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M724.2 454.6L620.6 598.3l-52.8-73.1c-3-4.2-7.8-6.6-12.9-6.6H500c-6.5 0-10.3 7.4-6.5 12.7l114.1 158.2a15.9 15.9 0 0 0 25.8 0l165-228.7c3.8-5.3 0-12.7-6.5-12.7H737c-5-.1-9.8 2.4-12.8 6.5zM416 496H232c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M928 224H768v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H548v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H328v-56c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v56H96c-17.7 0-32 14.3-32 32v576c0 17.7 14.3 32 32 32h832c17.7 0 32-14.3 32-32V256c0-17.7-14.3-32-32-32zm-40 568H136V296h120v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56h148v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56h148v56c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-56h120v496z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M416 632H232c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h184c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8z\"}}]})(props);\n};\nexport function AiTwotoneSecurityScan (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M866.9 169.9L527.1 54.1C523 52.7 517.5 52 512 52s-11 .7-15.1 2.1L157.1 169.9c-8.3 2.8-15.1 12.4-15.1 21.2v482.4c0 8.8 5.7 20.4 12.6 25.9L499.3 968c3.5 2.7 8 4.1 12.6 4.1s9.2-1.4 12.6-4.1l344.7-268.6c6.9-5.4 12.6-17 12.6-25.9V191.1c.2-8.8-6.6-18.3-14.9-21.2zM810 654.3L512 886.5 214 654.3V226.7l298-101.6 298 101.6v427.6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M460.7 451.1a80.1 80.1 0 1 0 160.2 0 80.1 80.1 0 1 0-160.2 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M214 226.7v427.6l298 232.2 298-232.2V226.7L512 125.1 214 226.7zm428.7 122.5c56.3 56.3 56.3 147.5 0 203.8-48.5 48.5-123 55.2-178.6 20.1l-77.5 77.5a8.03 8.03 0 0 1-11.3 0l-34-34a8.03 8.03 0 0 1 0-11.3l77.5-77.5c-35.1-55.7-28.4-130.1 20.1-178.6 56.3-56.3 147.5-56.3 203.8 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M418.8 527.8l-77.5 77.5a8.03 8.03 0 0 0 0 11.3l34 34c3.1 3.1 8.2 3.1 11.3 0l77.5-77.5c55.6 35.1 130.1 28.4 178.6-20.1 56.3-56.3 56.3-147.5 0-203.8-56.3-56.3-147.5-56.3-203.8 0-48.5 48.5-55.2 122.9-20.1 178.6zm65.4-133.3a80.1 80.1 0 0 1 113.3 0 80.1 80.1 0 0 1 0 113.3c-31.3 31.3-82 31.3-113.3 0s-31.3-82 0-113.3z\"}}]})(props);\n};\nexport function AiTwotoneSetting (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M859.3 569.7l.2.1c3.1-18.9 4.6-38.2 4.6-57.3 0-17.1-1.3-34.3-3.7-51.1 2.4 16.7 3.6 33.6 3.6 50.5 0 19.4-1.6 38.8-4.7 57.8zM99 398.1c-.5-.4-.9-.8-1.4-1.3.7.7 1.4 1.4 2.2 2.1l65.5 55.9v-.1L99 398.1zm536.6-216h.1l-15.5-83.8c-.2-1-.4-1.9-.7-2.8.1.5.3 1.1.4 1.6l15.7 85zm54 546.5l31.4-25.8 92.8 32.9c17-22.9 31.3-47.5 42.6-73.6l-74.7-63.9 6.6-40.1c2.5-15.1 3.8-30.6 3.8-46.1s-1.3-31-3.8-46.1l-6.5-39.9 74.7-63.9c-11.4-26-25.6-50.7-42.6-73.6l-92.8 32.9-31.4-25.8c-23.9-19.6-50.6-35-79.3-45.8l-38.1-14.3-17.9-97a377.5 377.5 0 0 0-85 0l-17.9 97.2-37.9 14.3c-28.5 10.8-55 26.2-78.7 45.7l-31.4 25.9-93.4-33.2c-17 22.9-31.3 47.5-42.6 73.6l75.5 64.5-6.5 40c-2.5 14.9-3.7 30.2-3.7 45.5 0 15.2 1.3 30.6 3.7 45.5l6.5 40-75.5 64.5c11.4 26 25.6 50.7 42.6 73.6l93.4-33.2 31.4 25.9c23.7 19.5 50.2 34.9 78.7 45.7l37.8 14.5 17.9 97.2c28.2 3.2 56.9 3.2 85 0l17.9-97 38.1-14.3c28.8-10.8 55.4-26.2 79.3-45.8zm-177.1-50.3c-30.5 0-59.2-7.8-84.3-21.5C373.3 627 336 568.9 336 502c0-97.2 78.8-176 176-176 66.9 0 125 37.3 154.8 92.2 13.7 25 21.5 53.7 21.5 84.3 0 97.1-78.7 175.8-175.8 175.8zM207.2 812.8c-5.5 1.9-11.2 2.3-16.6 1.2 5.7 1.2 11.7 1 17.5-1l81.4-29c-.1-.1-.3-.2-.4-.3l-81.9 29.1zm717.6-414.7l-65.5 56c0 .2.1.5.1.7l65.4-55.9c7.1-6.1 11.1-14.9 11.2-24-.3 8.8-4.3 17.3-11.2 23.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M935.8 646.6c.5 4.7 0 9.5-1.7 14.1l-.9 2.6a446.02 446.02 0 0 1-79.7 137.9l-1.8 2.1a32 32 0 0 1-35.1 9.5l-81.3-28.9a350 350 0 0 1-99.7 57.6l-15.7 85a32.05 32.05 0 0 1-25.8 25.7l-2.7.5a445.2 445.2 0 0 1-79.2 7.1h.3c26.7 0 53.4-2.4 79.4-7.1l2.7-.5a32.05 32.05 0 0 0 25.8-25.7l15.7-84.9c36.2-13.6 69.6-32.9 99.6-57.5l81.2 28.9a32 32 0 0 0 35.1-9.5l1.8-2.1c34.8-41.1 61.5-87.4 79.6-137.7l.9-2.6c1.6-4.7 2.1-9.7 1.5-14.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M688 502c0-30.3-7.7-58.9-21.2-83.8C637 363.3 578.9 326 512 326c-97.2 0-176 78.8-176 176 0 66.9 37.3 125 92.2 154.8 24.9 13.5 53.4 21.2 83.8 21.2 97.2 0 176-78.8 176-176zm-288 0c0-29.9 11.7-58 32.8-79.2C454 401.6 482.1 390 512 390c29.9 0 58 11.6 79.2 32.8A111.6 111.6 0 0 1 624 502c0 29.9-11.7 58-32.8 79.2A111.6 111.6 0 0 1 512 614c-29.9 0-58-11.7-79.2-32.8A111.6 111.6 0 0 1 400 502z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M594.1 952.2a32.05 32.05 0 0 0 25.8-25.7l15.7-85a350 350 0 0 0 99.7-57.6l81.3 28.9a32 32 0 0 0 35.1-9.5l1.8-2.1c34.8-41.1 61.6-87.5 79.7-137.9l.9-2.6c1.7-4.6 2.2-9.4 1.7-14.1-.9-7.9-4.7-15.4-11-20.9l-65.3-55.9-.2-.1c3.1-19 4.7-38.4 4.7-57.8 0-16.9-1.2-33.9-3.6-50.5-.3-2.2-.7-4.4-1-6.6 0-.2-.1-.5-.1-.7l65.5-56c6.9-5.9 10.9-14.4 11.2-23.2.1-4-.5-8.1-1.9-12l-.9-2.6a443.74 443.74 0 0 0-79.7-137.9l-1.8-2.1a32.12 32.12 0 0 0-35.1-9.5l-81.3 28.9c-30-24.6-63.4-44-99.6-57.6h-.1l-15.7-85c-.1-.5-.2-1.1-.4-1.6a32.08 32.08 0 0 0-25.4-24.1l-2.7-.5c-52.1-9.4-106.9-9.4-159 0l-2.7.5a32.05 32.05 0 0 0-25.8 25.7l-15.8 85.4a351.86 351.86 0 0 0-99 57.4l-81.9-29.1a32 32 0 0 0-35.1 9.5l-1.8 2.1a446.02 446.02 0 0 0-79.7 137.9l-.9 2.6a32.09 32.09 0 0 0 7.9 33.9c.5.4.9.9 1.4 1.3l66.3 56.6v.1c-3.1 18.8-4.6 37.9-4.6 57 0 19.2 1.5 38.4 4.6 57.1L99 625.5a32.03 32.03 0 0 0-9.3 35.2l.9 2.6c18.1 50.4 44.9 96.9 79.7 137.9l1.8 2.1c4.9 5.7 11.4 9.4 18.5 10.7 5.4 1 11.1.7 16.6-1.2l81.9-29.1c.1.1.3.2.4.3 29.7 24.3 62.8 43.6 98.6 57.1l15.8 85.4a32.05 32.05 0 0 0 25.8 25.7l2.7.5c26.1 4.7 52.8 7.1 79.5 7.1h.3c26.6 0 53.3-2.4 79.2-7.1l2.7-.5zm-39.8-66.5a377.5 377.5 0 0 1-85 0l-17.9-97.2-37.8-14.5c-28.5-10.8-55-26.2-78.7-45.7l-31.4-25.9-93.4 33.2c-17-22.9-31.2-47.6-42.6-73.6l75.5-64.5-6.5-40c-2.4-14.9-3.7-30.3-3.7-45.5 0-15.3 1.2-30.6 3.7-45.5l6.5-40-75.5-64.5c11.3-26.1 25.6-50.7 42.6-73.6l93.4 33.2 31.4-25.9c23.7-19.5 50.2-34.9 78.7-45.7l37.9-14.3 17.9-97.2c28.1-3.2 56.8-3.2 85 0l17.9 97 38.1 14.3c28.7 10.8 55.4 26.2 79.3 45.8l31.4 25.8 92.8-32.9c17 22.9 31.2 47.6 42.6 73.6L781.8 426l6.5 39.9c2.5 15.1 3.8 30.6 3.8 46.1s-1.3 31-3.8 46.1l-6.6 40.1 74.7 63.9a370.03 370.03 0 0 1-42.6 73.6L721 702.8l-31.4 25.8c-23.9 19.6-50.5 35-79.3 45.8l-38.1 14.3-17.9 97z\"}}]})(props);\n};\nexport function AiTwotoneShop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M839.5 344h-655c-.3 0-.5.2-.5.5v91.2c0 59.8 49 108.3 109.3 108.3 40.7 0 76.2-22 95.1-54.7 2.9-5.1 8.4-8.3 14.3-8.3s11.3 3.2 14.3 8.3c18.8 32.7 54.3 54.7 95 54.7 40.8 0 76.4-22.1 95.1-54.9 2.9-5 8.2-8.1 13.9-8.1h.6c5.8 0 11 3.1 13.9 8.1 18.8 32.8 54.4 54.9 95.2 54.9C791 544 840 495.5 840 435.7v-91.2c0-.3-.2-.5-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M882 272.1V144c0-17.7-14.3-32-32-32H174c-17.7 0-32 14.3-32 32v128.1c-16.7 1-30 14.9-30 31.9v131.7a177 177 0 0 0 14.4 70.4c4.3 10.2 9.6 19.8 15.6 28.9v345c0 17.6 14.3 32 32 32h676c17.7 0 32-14.3 32-32V535a175 175 0 0 0 15.6-28.9c9.5-22.3 14.4-46 14.4-70.4V304c0-17-13.3-30.9-30-31.9zM214 184h596v88H214v-88zm362 656.1H448V736h128v104.1zm234.4 0H640V704c0-17.7-14.3-32-32-32H416c-17.7 0-32 14.3-32 32v136.1H214V597.9c2.9 1.4 5.9 2.8 9 4 22.3 9.4 46 14.1 70.4 14.1 24.4 0 48-4.7 70.4-14.1 13.8-5.8 26.8-13.2 38.7-22.1.2-.1.4-.1.6 0a180.4 180.4 0 0 0 38.7 22.1c22.3 9.4 46 14.1 70.4 14.1s48-4.7 70.4-14.1c13.8-5.8 26.8-13.2 38.7-22.1.2-.1.4-.1.6 0a180.4 180.4 0 0 0 38.7 22.1c22.3 9.4 46 14.1 70.4 14.1s48-4.7 70.4-14.1c3-1.3 6-2.6 9-4v242.2zM840 435.7c0 59.8-49 108.3-109.3 108.3-40.8 0-76.4-22.1-95.2-54.9-2.9-5-8.1-8.1-13.9-8.1h-.6c-5.7 0-11 3.1-13.9 8.1A109.24 109.24 0 0 1 512 544c-40.7 0-76.2-22-95-54.7-3-5.1-8.4-8.3-14.3-8.3s-11.4 3.2-14.3 8.3a109.63 109.63 0 0 1-95.1 54.7C233 544 184 495.5 184 435.7v-91.2c0-.3.2-.5.5-.5h655c.3 0 .5.2.5.5v91.2z\"}}]})(props);\n};\nexport function AiTwotoneShopping (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M696 472c0 4.4-3.6 8-8 8h-56c-4.4 0-8-3.6-8-8v-88H400v88c0 4.4-3.6 8-8 8h-56c-4.4 0-8-3.6-8-8v-88h-96v456h560V384h-96v88z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M832 312H696v-16c0-101.6-82.4-184-184-184s-184 82.4-184 184v16H192c-17.7 0-32 14.3-32 32v536c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V344c0-17.7-14.3-32-32-32zm-432-16c0-61.9 50.1-112 112-112s112 50.1 112 112v16H400v-16zm392 544H232V384h96v88c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-88h224v88c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-88h96v456z\"}}]})(props);\n};\nexport function AiTwotoneSkin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 318c-79.2 0-148.5-48.8-176.7-120H182v196h119v432h422V394h119V198H688.7c-28.2 71.2-97.5 120-176.7 120z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M870 126H663.8c-17.4 0-32.9 11.9-37 29.3C614.3 208.1 567 246 512 246s-102.3-37.9-114.8-90.7a37.93 37.93 0 0 0-37-29.3H154a44 44 0 0 0-44 44v252a44 44 0 0 0 44 44h75v388a44 44 0 0 0 44 44h478a44 44 0 0 0 44-44V466h75a44 44 0 0 0 44-44V170a44 44 0 0 0-44-44zm-28 268H723v432H301V394H182V198h153.3c28.2 71.2 97.5 120 176.7 120s148.5-48.8 176.7-120H842v196z\"}}]})(props);\n};\nexport function AiTwotoneSliders (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M180 292h80v440h-80zm369 180h-74a3 3 0 0 0-3 3v74a3 3 0 0 0 3 3h74a3 3 0 0 0 3-3v-74a3 3 0 0 0-3-3zm215-108h80v296h-80z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M904 296h-66v-96c0-4.4-3.6-8-8-8h-52c-4.4 0-8 3.6-8 8v96h-66c-4.4 0-8 3.6-8 8v416c0 4.4 3.6 8 8 8h66v96c0 4.4 3.6 8 8 8h52c4.4 0 8-3.6 8-8v-96h66c4.4 0 8-3.6 8-8V304c0-4.4-3.6-8-8-8zm-60 364h-80V364h80v296zM612 404h-66V232c0-4.4-3.6-8-8-8h-52c-4.4 0-8 3.6-8 8v172h-66c-4.4 0-8 3.6-8 8v200c0 4.4 3.6 8 8 8h66v172c0 4.4 3.6 8 8 8h52c4.4 0 8-3.6 8-8V620h66c4.4 0 8-3.6 8-8V412c0-4.4-3.6-8-8-8zm-60 145a3 3 0 0 1-3 3h-74a3 3 0 0 1-3-3v-74a3 3 0 0 1 3-3h74a3 3 0 0 1 3 3v74zM320 224h-66v-56c0-4.4-3.6-8-8-8h-52c-4.4 0-8 3.6-8 8v56h-66c-4.4 0-8 3.6-8 8v560c0 4.4 3.6 8 8 8h66v56c0 4.4 3.6 8 8 8h52c4.4 0 8-3.6 8-8v-56h66c4.4 0 8-3.6 8-8V232c0-4.4-3.6-8-8-8zm-60 508h-80V292h80v440z\"}}]})(props);\n};\nexport function AiTwotoneSmile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zM288 421a48.01 48.01 0 0 1 96 0 48.01 48.01 0 0 1-96 0zm224 272c-85.5 0-155.6-67.3-160-151.6a8 8 0 0 1 8-8.4h48.1c4.2 0 7.8 3.2 8.1 7.4C420 589.9 461.5 629 512 629s92.1-39.1 95.8-88.6c.3-4.2 3.9-7.4 8.1-7.4H664a8 8 0 0 1 8 8.4C667.6 625.7 597.5 693 512 693zm176-224a48.01 48.01 0 0 1 0-96 48.01 48.01 0 0 1 0 96z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M288 421a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm376 112h-48.1c-4.2 0-7.8 3.2-8.1 7.4-3.7 49.5-45.3 88.6-95.8 88.6s-92-39.1-95.8-88.6c-.3-4.2-3.9-7.4-8.1-7.4H360a8 8 0 0 0-8 8.4c4.4 84.3 74.5 151.6 160 151.6s155.6-67.3 160-151.6a8 8 0 0 0-8-8.4zm-24-112a48 48 0 1 0 96 0 48 48 0 1 0-96 0z\"}}]})(props);\n};\nexport function AiTwotoneSnippets (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M450 510V336H232v552h432V550H490c-22.1 0-40-17.9-40-40z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M832 112H724V72c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v40H500V72c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v40H320c-17.7 0-32 14.3-32 32v120h-96c-17.7 0-32 14.3-32 32v632c0 17.7 14.3 32 32 32h512c17.7 0 32-14.3 32-32v-96h96c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zM664 888H232V336h218v174c0 22.1 17.9 40 40 40h174v338zm0-402H514V336h.2L664 485.8v.2zm128 274h-56V456L544 264H360v-80h68v32c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-32h152v32c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-32h68v576z\"}}]})(props);\n};\nexport function AiTwotoneSound (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M275.4 424H146v176h129.4l18 11.7L586 803V221L293.3 412.3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M892.1 737.8l-110.3-63.7a15.9 15.9 0 0 0-21.7 5.9l-19.9 34.5c-4.4 7.6-1.8 17.4 5.8 21.8L856.3 800a15.9 15.9 0 0 0 21.7-5.9l19.9-34.5c4.4-7.6 1.7-17.4-5.8-21.8zM934 476H806c-8.8 0-16 7.2-16 16v40c0 8.8 7.2 16 16 16h128c8.8 0 16-7.2 16-16v-40c0-8.8-7.2-16-16-16zM760 344a15.9 15.9 0 0 0 21.7 5.9L892 286.2c7.6-4.4 10.2-14.2 5.8-21.8L878 230a15.9 15.9 0 0 0-21.7-5.9L746 287.8a15.99 15.99 0 0 0-5.8 21.8L760 344zM625.9 115c-5.9 0-11.9 1.6-17.4 5.3L254 352H90c-8.8 0-16 7.2-16 16v288c0 8.8 7.2 16 16 16h164l354.5 231.7c5.5 3.6 11.6 5.3 17.4 5.3 16.7 0 32.1-13.3 32.1-32.1V147.1c0-18.8-15.4-32.1-32.1-32.1zM586 803L293.4 611.7l-18-11.7H146V424h129.4l17.9-11.7L586 221v582z\"}}]})(props);\n};\nexport function AiTwotoneStar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512.5 190.4l-94.4 191.3-211.2 30.7 152.8 149-36.1 210.3 188.9-99.3 188.9 99.2-36.1-210.3 152.8-148.9-211.2-30.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M908.6 352.8l-253.9-36.9L541.2 85.8c-3.1-6.3-8.2-11.4-14.5-14.5-15.8-7.8-35-1.3-42.9 14.5L370.3 315.9l-253.9 36.9c-7 1-13.4 4.3-18.3 9.3a32.05 32.05 0 0 0 .6 45.3l183.7 179.1L239 839.4a31.95 31.95 0 0 0 46.4 33.7l227.1-119.4 227.1 119.4c6.2 3.3 13.4 4.4 20.3 3.2 17.4-3 29.1-19.5 26.1-36.9l-43.4-252.9 183.7-179.1c5-4.9 8.3-11.3 9.3-18.3 2.7-17.5-9.5-33.7-27-36.3zM665.3 561.3l36.1 210.3-188.9-99.2-188.9 99.3 36.1-210.3-152.8-149 211.2-30.7 94.4-191.3 94.4 191.3 211.2 30.7-152.8 148.9z\"}}]})(props);\n};\nexport function AiTwotoneStop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm288.5 682.8L277.7 224C258 240 240 258 224 277.7l522.8 522.8C682.8 852.7 601 884 512 884c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372c0 89-31.3 170.8-83.5 234.8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372c89 0 170.8-31.3 234.8-83.5L224 277.7c16-19.7 34-37.7 53.7-53.7l522.8 522.8C852.7 682.8 884 601 884 512c0-205.4-166.6-372-372-372z\"}}]})(props);\n};\nexport function AiTwotoneSwitcher (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h528V312H184v528zm116-290h296v64H300v-64z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H264c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h576v576c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8V144c0-17.7-14.3-32-32-32z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M752 240H144c-17.7 0-32 14.3-32 32v608c0 17.7 14.3 32 32 32h608c17.7 0 32-14.3 32-32V272c0-17.7-14.3-32-32-32zm-40 600H184V312h528v528z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M300 550h296v64H300z\"}}]})(props);\n};\nexport function AiTwotoneTablet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M800 64H224c-35.3 0-64 28.7-64 64v768c0 35.3 28.7 64 64 64h576c35.3 0 64-28.7 64-64V128c0-35.3-28.7-64-64-64zm-8 824H232V136h560v752z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M232 888h560V136H232v752zm280-144c22.1 0 40 17.9 40 40s-17.9 40-40 40-40-17.9-40-40 17.9-40 40-40z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M472 784a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}}]})(props);\n};\nexport function AiTwotoneTag (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M589 164.6L189.3 564.3l270.4 270.4L859.4 435 836 188l-247-23.4zM680 432c-48.5 0-88-39.5-88-88s39.5-88 88-88 88 39.5 88 88-39.5 88-88 88z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M680 256c-48.5 0-88 39.5-88 88s39.5 88 88 88 88-39.5 88-88-39.5-88-88-88zm0 120c-17.7 0-32-14.3-32-32s14.3-32 32-32 32 14.3 32 32-14.3 32-32 32z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M938 458.8l-29.6-312.6c-1.5-16.2-14.4-29-30.6-30.6L565.2 86h-.4c-3.2 0-5.7 1-7.6 2.9L88.9 557.2a9.96 9.96 0 0 0 0 14.1l363.8 363.8a9.9 9.9 0 0 0 7.1 2.9c2.7 0 5.2-1 7.1-2.9l468.3-468.3c2-2.1 3-5 2.8-8zM459.7 834.7L189.3 564.3 589 164.6 836 188l23.4 247-399.7 399.7z\"}}]})(props);\n};\nexport function AiTwotoneTags (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M477.5 694l311.9-311.8-19-224.6-224.6-19-311.9 311.9L477.5 694zm116-415.5a47.81 47.81 0 0 1 33.9-33.9c16.6-4.4 34.2.3 46.4 12.4a47.93 47.93 0 0 1 12.4 46.4 47.81 47.81 0 0 1-33.9 33.9c-16.6 4.4-34.2-.3-46.4-12.4a48.3 48.3 0 0 1-12.4-46.4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M476.6 792.6c-1.7-.2-3.4-1-4.7-2.3L137.7 456.1a8.03 8.03 0 0 1 0-11.3L515.9 66.6c1.2-1.3 2.9-2.1 4.7-2.3h-.4c-2.3-.2-4.7.6-6.3 2.3L135.7 444.8a8.03 8.03 0 0 0 0 11.3l334.2 334.2c1.8 1.9 4.3 2.6 6.7 2.3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M889.7 539.8l-39.6-39.5a8.03 8.03 0 0 0-11.3 0l-362 361.3-237.6-237a8.03 8.03 0 0 0-11.3 0l-39.6 39.5a8.03 8.03 0 0 0 0 11.3l243.2 242.8 39.6 39.5c3.1 3.1 8.2 3.1 11.3 0l407.3-406.6c3.1-3.1 3.1-8.2 0-11.3zM652.3 337.3a47.81 47.81 0 0 0 33.9-33.9c4.4-16.6-.3-34.2-12.4-46.4a47.93 47.93 0 0 0-46.4-12.4 47.81 47.81 0 0 0-33.9 33.9c-4.4 16.6.3 34.2 12.4 46.4a48.3 48.3 0 0 0 46.4 12.4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M137.7 444.8a8.03 8.03 0 0 0 0 11.3l334.2 334.2c1.3 1.3 2.9 2.1 4.7 2.3 2.4.3 4.8-.5 6.6-2.3L861.4 412c1.7-1.7 2.5-4 2.3-6.3l-25.5-301.4c-.7-7.8-6.8-13.9-14.6-14.6L522.2 64.3h-1.6c-1.8.2-3.4 1-4.7 2.3L137.7 444.8zm408.1-306.2l224.6 19 19 224.6L477.5 694 233.9 450.5l311.9-311.9z\"}}]})(props);\n};\nexport function AiTwotoneThunderbolt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M695.4 164.1H470.8L281.2 491.5h157.4l-60.3 241 319.8-305.1h-211z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M848.1 359.3H627.8L825.9 109c4.1-5.3.4-13-6.3-13H436.1c-2.8 0-5.5 1.5-6.9 4L170.1 547.5c-3.1 5.3.7 12 6.9 12h174.4L262 917.1c-1.9 7.8 7.5 13.3 13.3 7.7L853.6 373c5.2-4.9 1.7-13.7-5.5-13.7zM378.3 732.5l60.3-241H281.2l189.6-327.4h224.6L487.1 427.4h211L378.3 732.5z\"}}]})(props);\n};\nexport function AiTwotoneTool (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M706.8 488.7a32.05 32.05 0 0 1-45.3 0L537 364.2a32.05 32.05 0 0 1 0-45.3l132.9-132.8a184.2 184.2 0 0 0-144 53.5c-58.1 58.1-69.3 145.3-33.6 214.6L439.5 507c-.1 0-.1-.1-.1-.1L209.3 737l79.2 79.2 274-274.1.1.1 8.8-8.8c69.3 35.7 156.5 24.5 214.6-33.6 39.2-39.1 57.3-92.1 53.6-143.9L706.8 488.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M876.6 239.5c-.5-.9-1.2-1.8-2-2.5-5-5-13.1-5-18.1 0L684.2 409.3l-67.9-67.9L788.7 169c.8-.8 1.4-1.6 2-2.5 3.6-6.1 1.6-13.9-4.5-17.5-98.2-58-226.8-44.7-311.3 39.7-67 67-89.2 162-66.5 247.4l-293 293c-3 3-2.8 7.9.3 11l169.7 169.7c3.1 3.1 8.1 3.3 11 .3l292.9-292.9c85.5 22.8 180.5.7 247.6-66.4 84.4-84.5 97.7-213.1 39.7-311.3zM786 499.8c-58.1 58.1-145.3 69.3-214.6 33.6l-8.8 8.8-.1-.1-274 274.1-79.2-79.2 230.1-230.1s0 .1.1.1l52.8-52.8c-35.7-69.3-24.5-156.5 33.6-214.6a184.2 184.2 0 0 1 144-53.5L537 318.9a32.05 32.05 0 0 0 0 45.3l124.5 124.5a32.05 32.05 0 0 0 45.3 0l132.8-132.8c3.7 51.8-14.4 104.8-53.6 143.9z\"}}]})(props);\n};\nexport function AiTwotoneTrademarkCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm170.7 584.2c-1.1.5-2.3.8-3.5.8h-62c-3.1 0-5.9-1.8-7.2-4.6l-74.6-159.2h-88.7V717c0 4.4-3.6 8-8 8H384c-4.4 0-8-3.6-8-8V307c0-4.4 3.6-8 8-8h155.6c98.8 0 144.2 59.9 144.2 131.1 0 70.2-43.6 106.4-78.4 119.2l80.8 164.2c2.1 3.9.4 8.7-3.5 10.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M529.9 357h-83.4v148H528c53 0 82.8-25.6 82.8-72.4 0-50.3-32.9-75.6-80.9-75.6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M605.4 549.3c34.8-12.8 78.4-49 78.4-119.2 0-71.2-45.4-131.1-144.2-131.1H384c-4.4 0-8 3.6-8 8v410c0 4.4 3.6 8 8 8h54.7c4.4 0 8-3.6 8-8V561.2h88.7L610 720.4c1.3 2.8 4.1 4.6 7.2 4.6h62c1.2 0 2.4-.3 3.5-.8 3.9-2 5.6-6.8 3.5-10.7l-80.8-164.2zM528 505h-81.5V357h83.4c48 0 80.9 25.3 80.9 75.6 0 46.8-29.8 72.4-82.8 72.4z\"}}]})(props);\n};\nexport function AiTwotoneTrophy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M320 480c0 49.1 19.1 95.3 53.9 130.1 34.7 34.8 81 53.9 130.1 53.9h16c49.1 0 95.3-19.1 130.1-53.9 34.8-34.7 53.9-81 53.9-130.1V184H320v296zM184 352c0 41 26.9 75.8 64 87.6-37.1-11.9-64-46.7-64-87.6zm364 382.5C665 721.8 758.4 630.2 773.8 514 758.3 630.2 665 721.7 548 734.5zM250.2 514C265.6 630.2 359 721.8 476 734.5 359 721.7 265.7 630.2 250.2 514z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M868 160h-92v-40c0-4.4-3.6-8-8-8H256c-4.4 0-8 3.6-8 8v40h-92a44 44 0 0 0-44 44v148c0 81.7 60 149.6 138.2 162C265.7 630.2 359 721.7 476 734.5v105.2H280c-17.7 0-32 14.3-32 32V904c0 4.4 3.6 8 8 8h512c4.4 0 8-3.6 8-8v-32.3c0-17.7-14.3-32-32-32H548V734.5C665 721.7 758.3 630.2 773.8 514 852 501.6 912 433.7 912 352V204a44 44 0 0 0-44-44zM248 439.6a91.99 91.99 0 0 1-64-87.6V232h64v207.6zM704 480c0 49.1-19.1 95.4-53.9 130.1-34.8 34.8-81 53.9-130.1 53.9h-16c-49.1 0-95.4-19.1-130.1-53.9-34.8-34.8-53.9-81-53.9-130.1V184h384v296zm136-128c0 41-26.9 75.8-64 87.6V232h64v120z\"}}]})(props);\n};\nexport function AiTwotoneUnlock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M232 840h560V536H232v304zm280-226a48.01 48.01 0 0 1 28 87v53c0 4.4-3.6 8-8 8h-40c-4.4 0-8-3.6-8-8v-53a48.01 48.01 0 0 1 28-87z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M484 701v53c0 4.4 3.6 8 8 8h40c4.4 0 8-3.6 8-8v-53a48.01 48.01 0 1 0-56 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M832 464H332V240c0-30.9 25.1-56 56-56h248c30.9 0 56 25.1 56 56v68c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-68c0-70.7-57.3-128-128-128H388c-70.7 0-128 57.3-128 128v224h-68c-17.7 0-32 14.3-32 32v384c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V496c0-17.7-14.3-32-32-32zm-40 376H232V536h560v304z\"}}]})(props);\n};\nexport function AiTwotoneUpCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M512 140c-205.4 0-372 166.6-372 372s166.6 372 372 372 372-166.6 372-372-166.6-372-372-372zm178 479h-46.9c-10.2 0-19.9-4.9-25.9-13.2L512 460.4 406.8 605.8c-6 8.3-15.6 13.2-25.9 13.2H334c-6.5 0-10.3-7.4-6.5-12.7l178-246c3.2-4.4 9.7-4.4 12.9 0l178 246c3.9 5.3.1 12.7-6.4 12.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M518.4 360.3a7.95 7.95 0 0 0-12.9 0l-178 246c-3.8 5.3 0 12.7 6.5 12.7h46.9c10.3 0 19.9-4.9 25.9-13.2L512 460.4l105.2 145.4c6 8.3 15.7 13.2 25.9 13.2H690c6.5 0 10.3-7.4 6.4-12.7l-178-246z\"}}]})(props);\n};\nexport function AiTwotoneUpSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 728H184V184h656v656z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h656V184H184v656zm143.5-228.7l178-246c3.2-4.4 9.7-4.4 12.9 0l178 246c3.9 5.3.1 12.7-6.4 12.7h-46.9c-10.2 0-19.9-4.9-25.9-13.2L512 465.4 406.8 610.8c-6 8.3-15.6 13.2-25.9 13.2H334c-6.5 0-10.3-7.4-6.5-12.7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M334 624h46.9c10.3 0 19.9-4.9 25.9-13.2L512 465.4l105.2 145.4c6 8.3 15.7 13.2 25.9 13.2H690c6.5 0 10.3-7.4 6.4-12.7l-178-246a7.95 7.95 0 0 0-12.9 0l-178 246c-3.8 5.3 0 12.7 6.5 12.7z\"}}]})(props);\n};\nexport function AiTwotoneUsb (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M759.9 504H264.1c-26.5 0-48.1 19.7-48.1 44v292h592V548c0-24.3-21.6-44-48.1-44z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M456 248h-48c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zm160 0h-48c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M760 432V144c0-17.7-14.3-32-32-32H296c-17.7 0-32 14.3-32 32v288c-66.2 0-120 52.1-120 116v356c0 4.4 3.6 8 8 8h720c4.4 0 8-3.6 8-8V548c0-63.9-53.8-116-120-116zM336 184h352v248H336V184zm472 656H216V548c0-24.3 21.6-44 48.1-44h495.8c26.5 0 48.1 19.7 48.1 44v292z\"}}]})(props);\n};\nexport function AiTwotoneVideoCamera (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M136 792h576V232H136v560zm64-488c0-4.4 3.6-8 8-8h112c4.4 0 8 3.6 8 8v48c0 4.4-3.6 8-8 8H208c-4.4 0-8-3.6-8-8v-48z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M912 302.3L784 376V224c0-35.3-28.7-64-64-64H128c-35.3 0-64 28.7-64 64v576c0 35.3 28.7 64 64 64h592c35.3 0 64-28.7 64-64V648l128 73.7c21.3 12.3 48-3.1 48-27.6V330c0-24.6-26.7-40-48-27.7zM712 792H136V232h576v560zm176-167l-104-59.8V458.9L888 399v226z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M208 360h112c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8H208c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8z\"}}]})(props);\n};\nexport function AiTwotoneWallet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M880 112H144c-17.7 0-32 14.3-32 32v736c0 17.7 14.3 32 32 32h736c17.7 0 32-14.3 32-32V144c0-17.7-14.3-32-32-32zm-40 464H528V448h312v128zm0-192H496c-17.7 0-32 14.3-32 32v192c0 17.7 14.3 32 32 32h344v200H184V184h656v200z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M528 576h312V448H528v128zm92-104c22.1 0 40 17.9 40 40s-17.9 40-40 40-40-17.9-40-40 17.9-40 40-40z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M580 512a40 40 0 1 0 80 0 40 40 0 1 0-80 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M184 840h656V640H496c-17.7 0-32-14.3-32-32V416c0-17.7 14.3-32 32-32h344V184H184v656z\"}}]})(props);\n};\nexport function AiTwotoneWarning (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 1024 1024\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M955.7 856l-416-720c-6.2-10.7-16.9-16-27.7-16s-21.6 5.3-27.7 16l-416 720C56 877.4 71.4 904 96 904h832c24.6 0 40-26.6 27.7-48zm-783.5-27.9L512 239.9l339.8 588.2H172.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M172.2 828.1h679.6L512 239.9 172.2 828.1zM560 720a48.01 48.01 0 0 1-96 0 48.01 48.01 0 0 1 96 0zm-16-304v184c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V416c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M464 720a48 48 0 1 0 96 0 48 48 0 1 0-96 0zm16-304v184c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V416c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8z\"}}]})(props);\n};\n","import React, { useEffect, useContext, useState } from 'react'\r\nimport HighchartsReact from 'highcharts-react-official'\r\nimport Highcharts from 'highcharts/highstock'\r\nimport Dialog from '../components/Dialog'\r\nimport Button from '../components/Button'\r\nimport AstroDialog from '../dialogs/AstroDialog'\r\nimport QSpecDialog from '../dialogs/QSpectrum'\r\nimport IxDialog from '../dialogs/IxDialog'\r\nimport moment from 'moment'\r\nimport DataContext from '../context/DataContext'\r\nimport UserContext from '../context/UserContext'\r\nimport {getBreakdown} from '../utils/processor'\r\nimport useContextCommunicator from '../hooks/useContextCommunicator'\r\nimport useErrorHandler from '../hooks/useErrorHandler'\r\nimport useInstrument from '../hooks/useInstrument'\r\nimport { AiOutlineArrowUp, AiOutlineArrowLeft, AiOutlineArrowDown } from 'react-icons/ai'\r\nimport { NavLink, Navigate } from 'react-router-dom'\r\n// import { parseISO, set } from 'date-fns'\r\n\r\nexport default function Instrument() {\r\n // ----------------- context defs\r\n const { instrumentShown, addModel, deleteModel, editModel, visitedFrom, setLBCCommand, loadedCount, addedFromSearch, setAddedFromSearchFunc } = useContext(DataContext)\r\n const { stocks, customStocks } = useContext(UserContext)\r\n const {deleteInstrument, getInstrument, addInstrumentCommand} = useContextCommunicator()\r\n const {errorHandler} = useErrorHandler()\r\n const {removeSplitsCommand, updateInstrumentCommand, qSpecCalculateProjLine} = useInstrument()\r\n const months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']\r\n\r\n // ----------------- state and var defs\r\n const [instrument, setInstrument] = useState({\r\n code: 'None',\r\n title: 'None',\r\n data: [],\r\n zones: [],\r\n loaded: false,\r\n stockIsFavorite: false,\r\n LBCBars: 0,\r\n LBCTime: new Date()\r\n })\r\n const [addDialog, setAddDialog] = useState(false)\r\n const [astroOpen, setAstroOpen] = useState(false)\r\n const [qspecOpen, setQspecOpen] = useState(false)\r\n const [ixOpen, toggleIx] = useState(false)\r\n const [openZones, setOpenZones] = React.useState(0)\r\n const [editDialog, setEditDialog] = useState({\r\n editOpen: false,\r\n editIndex: null,\r\n type: null,\r\n name: ''\r\n })\r\n const [lbcDisabled, setLBCDisabled] = useState(true)\r\n const [NavigateElement, setNavigate] = useState(null)\r\n const [LBCValue, setLBCValue] = useState(0)\r\n const [expertsShow, setExpertsShow] = useState(false)\r\n const [calculating, setCalculating] = useState(false)\r\n const [showVolume, setShowVolume] = useState(false)\r\n\r\n // --------------- data load\r\n const loadFunc = async () => {\r\n let stockFavorite = false\r\n // Check if instrument is in user favorites\r\n let stockIndex = stocks.findIndex(item => item === instrumentShown)\r\n let customIndex = customStocks.findIndex(item => item === instrumentShown)\r\n if (stockIndex !== -1 || instrumentShown === '' || customIndex !== -1) {\r\n stockFavorite = true\r\n } else {\r\n stockIndex = customStocks.findIndex(item => item === instrumentShown)\r\n if (stockIndex !== -1) stockFavorite = true\r\n }\r\n // if (dataStatus === \"download_complete\") {\r\n try {\r\n let data = await getInstrument()\r\n if (data && data.loaded) {\r\n if (data.stock !== \"None\") {\r\n const headerArr = data.header.split(' - ')\r\n data.code = headerArr[0]\r\n data.title = headerArr[1]\r\n data.stockIsFavorite = stockFavorite\r\n\r\n // see if minMax values are set, if not then generate them\r\n if (!data.minTime) {\r\n data.minTime = (moment(new Date()).valueOf()) - (1000*3600*24*365*1.5)\r\n }\r\n\r\n if (!data.maxTime) {\r\n data.maxTime = (moment(new Date()).valueOf()) + (1000*3600*24*180)\r\n }\r\n \r\n setInstrument(data)\r\n setLBCValue(data.LBCBars)\r\n } else {\r\n setNavigate()\r\n }\r\n } else {\r\n }\r\n } catch (e) {\r\n console.log(e.message)\r\n errorHandler(e)\r\n }\r\n // }\r\n }\r\n\r\n useEffect(() => {\r\n // Get Data\r\n if ((instrument.stock !== instrumentShown) || (!instrument.loaded && (loadedCount === (stocks.length + customStocks.length)))) {\r\n loadFunc()\r\n }\r\n\r\n // look for empty models\r\n instrument.data.forEach(entry => {\r\n if (!entry.data.length) {\r\n // updateEmptyIxData(instrument.code, entry.name)\r\n }\r\n })\r\n // separate volume from stock data, add as a second entry in the array\r\n // if (instrument.data.findIndex(el => el.name === 'Volume') > -1 && instrument.data[1].visible !== showVolume) {\r\n // const newData = {...instrument}\r\n // if (showVolume) {\r\n // newData.data[1].visible = true\r\n // newData.data[1].visibleTemp = true\r\n // } else {\r\n // newData.data[1].visible = false\r\n // newData.data[1].visibleTemp = false\r\n // }\r\n // setInstrument(newData)\r\n // setShowVolume(true)\r\n // }\r\n\r\n return () => {\r\n }\r\n\r\n }, [loadedCount, instrumentShown, instrument, addModel, deleteModel, showVolume])\r\n\r\n // yAxis setup based on how many models exist\r\n let yAxisParams = [{}]\r\n instrument.data.forEach((element, index) => {\r\n if (index !== 0) {\r\n let modelAxisObject = {\r\n height: '100%',\r\n visible: false\r\n }\r\n yAxisParams.push(modelAxisObject)\r\n }\r\n })\r\n \r\n\r\n // // Graph data setup\r\n // const minTime = (moment(new Date()).valueOf()) - (1000*3600*24*180)\r\n // const maxTime = (moment(new Date()).valueOf()) + (1000*3600*24*180)\r\n\r\n const chartOptions = {\r\n tooltip: {\r\n\r\n formatter: function() {\r\n if (this.points[0].series.name==='Series 1') {\r\n let date = new Date(this.x)\r\n const day = date.getUTCDate()\r\n const month = date.getUTCMonth()+1\r\n const year = date.getUTCFullYear()\r\n\r\n let zone_description = 'Closing Price: '+this.y+`
    Date: ${day}/${month}/${year}`\r\n\r\n return zone_description;\r\n } else {\r\n // return 'Date: '+moment(this.x).format('X')\r\n let date = new Date(this.x)\r\n const day = date.getUTCDate()\r\n const month = date.getUTCMonth()+1\r\n const year = date.getUTCFullYear()\r\n return `Date: ${day}/${month}/${year}`\r\n }\r\n }\r\n },\r\n // rangeSelector: {\r\n // // zoom buttons for 1m 3m YTD etc. disabled, change later if needed\r\n // buttonTheme: {\r\n // visibility: 'hidden'\r\n // },\r\n // },\r\n boost: {\r\n enabled: true,\r\n useGPUTranslations: true,\r\n },\r\n plotOptions: {\r\n series: [{\r\n dataGrouping: {\r\n units: [[\r\n 'day', // unit name\r\n [1] // allowed multiples\r\n ], [\r\n 'month',\r\n [1, 2, 3, 4, 6]\r\n ]]\r\n },\r\n // general options for all series\r\n turboThreshold: 1000,\r\n // compare: 'percent',\r\n showInNavigator: true,\r\n lineWidth: 2,\r\n states: {\r\n hover: {\r\n lineWidth: 3\r\n }\r\n }\r\n }, {showInNavigator: false}]\r\n },\r\n // rangeSelector: {\r\n // selected: 0\r\n // },\r\n xAxis: {\r\n min: instrument.minTime,\r\n max: instrument.maxTime,\r\n // plotBands: predictableZonesChart,\r\n plotLines: [{\r\n color: '#FF0000',\r\n width: 2,\r\n value: instrument.LBCTime,\r\n label: {\r\n text: \"LBC: \"+moment(parseInt(instrument.LBCTime)).format('L')\r\n },\r\n zIndex: 10\r\n // label: {\r\n // formatter:function(){\r\n // return Highcharts.dateFormat('%Y %M %d',this.value);\r\n // }\r\n // }\r\n }],\r\n },\r\n yAxis: yAxisParams,\r\n series: instrument.data\r\n // }, projLine]\r\n }\r\n\r\n // --------------- handlers\r\n\r\n const openAstroDialog = () => {\r\n setAstroOpen(true)\r\n setAddDialog(false)\r\n }\r\n\r\n const openQSpecDialog = () => {\r\n setQspecOpen(true)\r\n setAddDialog(false)\r\n }\r\n\r\n const submitModelHandler = async (model) => {\r\n setCalculating(true)\r\n try {\r\n await addModel(model)\r\n let newState = {...instrument}\r\n setInstrument(newState)\r\n \r\n if (model.type === 'astro') {\r\n setAstroOpen(false)\r\n } else if (model.type === 'qspec') {\r\n setQspecOpen(false)\r\n }\r\n } catch (e) {\r\n errorHandler(e.message)\r\n }\r\n setCalculating(false)\r\n loadFunc()\r\n }\r\n\r\n const openEditDialog = (modelIndex) => {\r\n let modelIndexToSubmit = modelIndex\r\n // if (instrument.data.findIndex(el => el.name === 'Volume') > -1) {\r\n // modelIndexToSubmit = modelIndex-1\r\n // }\r\n const modelInfo = {...instrument.data[modelIndexToSubmit+1]}\r\n let newState = {...editDialog}\r\n newState.editIndex = modelIndex\r\n newState.name = modelInfo.name\r\n\r\n if (modelInfo.name[0] === 'A') {\r\n newState.type = 'astro'\r\n newState.editOpen = true\r\n } else if (modelInfo.name[0] === 'S') {\r\n newState.type = 'qSpec'\r\n newState.editOpen = true\r\n } else if (modelInfo.name[0] === 'I') {\r\n toggleIx(true)\r\n }\r\n setEditDialog(newState)\r\n }\r\n\r\n const deleteModelHandler = async (modelIndex) => {\r\n // console.log(editDialog)\r\n try {\r\n await deleteModel(modelIndex, editDialog.name)\r\n\r\n loadFunc()\r\n closeEditDialog()\r\n } catch (e) {\r\n errorHandler(e)\r\n }\r\n }\r\n\r\n const closeEditDialog = () => {\r\n let newState = {...editDialog}\r\n newState = { \r\n editOpen: false,\r\n editIndex: null,\r\n type: null,\r\n name: ''\r\n }\r\n setEditDialog(newState)\r\n }\r\n\r\n const submitEditHandler = async (model, modelIndex) => {\r\n try {\r\n const editedModel = await editModel(modelIndex, model)\r\n let newState = {...instrument}\r\n newState.data[modelIndex+1] = editedModel\r\n setInstrument(newState)\r\n closeEditDialog()\r\n } catch (e) {\r\n errorHandler(e)\r\n }\r\n }\r\n\r\n const toggleModelVisibility = (index) => {\r\n let newState = {...instrument}\r\n\r\n // Temporary workaround code: visbility is now controlled by lineWidth. based on visibleTemp parameter, lineWidth is set to either 1 or 0\r\n // newState.data[index+1].visibleTemp = !newState.data[index+1].visibleTemp\r\n // if (newState.data[index+1].visibleTemp) {\r\n // newState.data[index+1].lineWidth = 1\r\n // } else {\r\n // newState.data[index+1].lineWidth = 0\r\n // }\r\n\r\n // old code, revive when HighCharts update comes out\r\n newState.data[index+1].visible = !newState.data[index+1].visible\r\n setInstrument(newState)\r\n }\r\n\r\n const openZoneDetailHandler = (index) => {\r\n if (openZones === 0) {\r\n setOpenZones(index)\r\n } else {\r\n setOpenZones(0)\r\n }\r\n }\r\n\r\n const addInstrumentHandler = async () => {\r\n try {\r\n let updatedInstrument = await addInstrumentCommand(instrumentShown)\r\n updatedInstrument.stockIsFavorite = true\r\n setAddedFromSearchFunc(true)\r\n setInstrument(updatedInstrument)\r\n } catch (e) {\r\n errorHandler(e)\r\n }\r\n }\r\n\r\n const openIntermarketDialog = () => {\r\n toggleIx(true)\r\n }\r\n\r\n const LBCBarsChangedHandler = (event) => {\r\n setLBCDisabled(false)\r\n setLBCValue(event.target.value)\r\n }\r\n\r\n const LBCRecalculateHandler = async () => {\r\n\r\n // if (instrument.LBCBars < 0) {\r\n // return alert('LBC Cannot be less than 0')\r\n // }\r\n\r\n const newData = await setLBCCommand(instrument.stock, Math.abs(LBCValue), instrument.type)\r\n let newState = {...instrument}\r\n\r\n newData.models.forEach((model, relIndex) => {\r\n // find index of model in data\r\n const modelIndex = newState.data.findIndex(item => item.name === model.name)\r\n newState.data[modelIndex].data = newData.models[relIndex].data\r\n })\r\n newState.LBCBars = newData.LBCBars\r\n newState.LBCTime = newData.LBCTime\r\n setInstrument(newState)\r\n setLBCDisabled(true)\r\n setLBCValue(Math.abs(LBCValue))\r\n }\r\n\r\n const expertsShowHandler = () => {\r\n setExpertsShow(!expertsShow)\r\n }\r\n\r\n const expertsIxHandler = () => {\r\n setExpertsShow(!expertsShow)\r\n toggleIx(true)\r\n }\r\n\r\n const toggleShowingSplitsHandler = async () => {\r\n const newChartData = await removeSplitsCommand(instrument.stock)\r\n let newState = {...instrument}\r\n newState.data[0].data = newChartData\r\n updateInstrumentCommand(newState)\r\n }\r\n\r\n\r\n // --------------- pre-render\r\n // todays date\r\n const today = moment().add(6, 'days').format('MMM-DD')\r\n\r\n // daily breakdowns\r\n let breakdown = {week: []}\r\n if (instrument.loaded) {\r\n breakdown = getBreakdown(instrument.daily)\r\n }\r\n\r\n const weekDays = breakdown.week.map(element => {\r\n const key = \"week\" + Math.floor(Math.random()*10000)\r\n if (element[0]>element[1]) {\r\n return (
    )\r\n } else if (element[0]
    )\r\n } else {\r\n return (
    )\r\n }\r\n })\r\n\r\n // models & top header\r\n\r\n let modelsDiv =
    \r\n {/* */}\r\n

    No models

    \r\n

    ADD TO FAVORITES TO ENABLE ANALYSIS

    \r\n
    \r\n let models = null\r\n if (instrument.stockIsFavorite && instrument.data.length > 0) {\r\n // models\r\n const modelsArray = instrument.data.filter((element, index) => index !== 0)\r\n let volumeExists = false\r\n models = modelsArray.map((element, index) => {\r\n if (element.name === 'Volume') {\r\n volumeExists = true\r\n return\r\n }\r\n let modelIndex = volumeExists?index-1:index\r\n let key = \"model\"+modelIndex\r\n\r\n let headerText, modelText\r\n if (element.name[0] === 'A') {\r\n headerText = 'Natural'\r\n modelText = element.header\r\n } else if (element.name[0] === 'S') {\r\n headerText = 'Spectrum'\r\n modelText = element.header\r\n } else if (element.name[0] === 'I') {\r\n headerText = 'Intermarket'\r\n modelText = element.header\r\n }\r\n\r\n\r\n return (\r\n
    \r\n toggleModelVisibility(modelIndex)}\r\n />\r\n
    openEditDialog(modelIndex)}>\r\n
    \r\n
    \r\n
    \r\n
    \r\n {headerText}\r\n
    \r\n {modelText ? \r\n
    \r\n {modelText}\r\n
    \r\n :\r\n null\r\n }\r\n
    \r\n {/* \r\n {header}\r\n */}\r\n
    \r\n
    \r\n )\r\n })\r\n\r\n if (!models.length) {\r\n models =
    \r\n

    No models

    \r\n {/* */}\r\n
    \r\n }\r\n\r\n modelsDiv =
    \r\n
    \r\n \r\n
    \r\n\r\n
    \r\n {models}\r\n
    \r\n
    \r\n\r\n }\r\n\r\n // tradable zones\r\n let zonesElement = null\r\n if (instrument.zones) {\r\n zonesElement = instrument.zones.map((element, index) => {\r\n let title = 'Cycle'+index\r\n const dateFrom = moment('01/01/2021', 'MM/DD/YYYY').add(element[1], 'days').format('DD-MMM')\r\n const dateTo = moment('01/01/2021', 'MM/DD/YYYY').add(element[2], 'days').format('DD-MMM')\r\n \r\n let trend = \"No\"\r\n let trendIcon\r\n if (element[0][0] > element[0][1]) {\r\n trend = \"Up\"\r\n trendIcon = \r\n } else if (element[0][0] < element[0][1]) {\r\n trend = \"Down\"\r\n trendIcon = \r\n }\r\n let averageMovement = []\r\n const zoneBreakdown = element[0][3].map((zoneYear) => {\r\n let changeVal = (zoneYear.close - zoneYear.open).toFixed(2)\r\n let openVal = zoneYear.open.toFixed(2)\r\n let closeVal = zoneYear.close.toFixed(2)\r\n if (changeVal === '0.00') {\r\n changeVal = (zoneYear.close - zoneYear.open).toFixed(4)\r\n openVal = zoneYear.open.toFixed(4)\r\n closeVal = zoneYear.close.toFixed(4)\r\n }\r\n const changePercent = (changeVal/zoneYear.open)*100\r\n let zoneColorClass = \"instrument--tzs__zone-green\"\r\n if (changeVal <= 0) {\r\n zoneColorClass = \"instrument--tzs__zone-red\"\r\n }\r\n averageMovement.push(changePercent)\r\n return
  • {zoneYear.year}/ {zoneYear.from[0]} - {zoneYear.to[0]} / Open: {openVal} / Close: {closeVal} / Change: ${changeVal} / % {changePercent.toFixed(2)}
  • \r\n })\r\n \r\n let detailClass = \"instrument--tzs__zone--hidden\"\r\n if (openZones === index+1) {\r\n detailClass = \"instrument--tzs__zone--shown\"\r\n }\r\n\r\n // Calculate Average Change\r\n let averageSum = 0\r\n averageMovement.forEach(item => {\r\n averageSum = averageSum + item\r\n })\r\n const average = (averageSum/averageMovement.length).toFixed(2)\r\n\r\n // Calculate Median Value\r\n // console.log(averageMovement.sort())\r\n let medianValue = ''\r\n const sortedArr = averageMovement.sort(function(a, b) {\r\n return a - b;\r\n })\r\n if (averageMovement.length%2 == 0) {\r\n const firstIndex = (sortedArr.length/2)-1\r\n const secondIndex = firstIndex+1\r\n medianValue = ((sortedArr[firstIndex]+sortedArr[secondIndex])/2).toFixed(2)\r\n } else {\r\n const midpoint = parseInt(sortedArr.length/2)\r\n medianValue = (sortedArr[midpoint]).toFixed(2)\r\n }\r\n\r\n return (\r\n
    openZoneDetailHandler(index+1)}>\r\n

    {trendIcon} {trend} trend from: {dateFrom} to: {dateTo}. Average: {average}%. Median: {medianValue}%

    \r\n
      \r\n {zoneBreakdown}\r\n
    \r\n
    \r\n )\r\n })\r\n }\r\n\r\n // edit dialog\r\n let dialogContent = null\r\n if (editDialog.type === 'astro') {\r\n dialogContent = deleteModelHandler(editDialog.editIndex)}\r\n closeClicked={closeEditDialog}\r\n submitClicked={(object) => submitEditHandler(object, editDialog.editIndex)} />\r\n } else if (editDialog.type === 'qSpec') {\r\n dialogContent = deleteModelHandler(editDialog.editIndex)}\r\n submitClicked={(object) => submitEditHandler(object, editDialog.editIndex)} />\r\n }\r\n\r\n // intermarket string\r\n let ixDiv = null\r\n // let ixDialogDiv = null\r\n if (instrument.ix && instrument.ix.length) {\r\n ixDiv = (\r\n
    \r\n

    Intermarket Analysis: {instrument.ix.length} Leading Instruments found. Click to View

    \r\n
    )\r\n\r\n \r\n // ixDialogDiv = instrument.ix.map(item => {\r\n // return (\r\n //
  • getIntermarketChartHandler(item[0],item[2], item[4])}>{item[0]} - {item[1]}: {item[2]}, {item[3]}, {item[4]}
  • \r\n // )\r\n // })\r\n }\r\n\r\n\r\n // Header\r\n let header\r\n let expertsClass = \"instrument__experts-dialog instrument__experts-dialog--hidden\"\r\n if (expertsShow) {\r\n expertsClass = \"instrument__experts-dialog\"\r\n }\r\n if (!instrument.loaded) {\r\n header =
    \r\n

    Loading...

    \r\n
    \r\n } else if (instrument.stockIsFavorite) {\r\n header =
    \r\n
    \r\n
    \r\n
    \r\n {addedFromSearch ? Back to Results : null }\r\n {/* */}\r\n
    \r\n
    \r\n

    Intermarket Analysis

    \r\n

    Intermarket Analysis

    \r\n
    \r\n
    \r\n
    \r\n

    {instrument.stock}

    \r\n

    {instrument.code}

    \r\n
    \r\n
    \r\n \r\n
    \r\n
    \r\n
    \r\n } else {\r\n header =
    \r\n
    \r\n Back to Results\r\n
    \r\n\r\n

    {instrument.stock}

    \r\n

    {instrument.header}

    \r\n

    PREVIEW ONLY. Add to Favorite to work with this instrument

    \r\n\r\n
    \r\n \r\n
    \r\n
    \r\n }\r\n\r\n // ----------- NEW PZ DISPLAY\r\n\r\n\r\n // 2. Get current year and get all days of this year\r\n const currentYear = new Date().getFullYear()\r\n const daysOfYear = []\r\n let i = 1\r\n for (let d = new Date(currentYear, 0, 1); d <= new Date(currentYear, 11, 31); d.setDate(d.getDate() + 1)) {\r\n daysOfYear.push({\r\n string: d.toDateString().slice(4)\r\n });\r\n }\r\n\r\n // var now = new Date();\r\n // var start = new Date(now.getFullYear(), 0, 0);\r\n // var diff = now - start;\r\n // var oneDay = 1000 * 60 * 60 * 24;\r\n // var day = Math.floor(diff / oneDay);\r\n\r\n const daysOfYearDivs = daysOfYear.map((el, index) => {\r\n let classString\r\n\r\n instrument.zones.forEach(zone => {\r\n // if (index === day) {\r\n // classString = 'blue'\r\n // } else \r\n if (index >= zone[1] && index <= zone[2]) {\r\n if (zone[0][0] > zone[0][1]) {\r\n classString = 'green'\r\n } else if (zone[0][1] > zone[0][0]) {\r\n classString = 'tomato'\r\n }\r\n }\r\n })\r\n\r\n return (\r\n
    \r\n
    \r\n )\r\n })\r\n\r\n const daysOfYearTickers = daysOfYear.map((el, index) => {\r\n if (index === 0) {\r\n return (\r\n
    \r\n\r\n
    \r\n )\r\n } else if (daysOfYear[index-1].string.slice(0, 4) !== el.string.slice(0, 4)) {\r\n return (\r\n
    \r\n\r\n
    \r\n )\r\n } else {\r\n return (\r\n
    \r\n\r\n
    \r\n )\r\n }\r\n })\r\n\r\n const daysOfYearMonths = months.map((el) => {\r\n return (\r\n
    \r\n {el}\r\n
    \r\n )\r\n })\r\n\r\n let lastPrice\r\n try {lastPrice = instrument.data[0].data[instrument.data[0].data.length-1][1]}\r\n catch {}\r\n\r\n // Volume Showing Option\r\n // let volumeCheckBoxDiv\r\n // if (instrument.data.findIndex(el => el.name === 'Volume') > -1) {\r\n // volumeCheckBoxDiv = (\r\n // \r\n // setShowVolume(e.target.checked)} title='Display Volume on Chart' />\r\n // \r\n // \r\n // )\r\n // }\r\n\r\n let volume = instrument.volume>0?\r\n
    Volume: {instrument.volume}
    \r\n :null;\r\n\r\n\r\n // Main Render\r\n return (\r\n
    \r\n {NavigateElement}\r\n {header}\r\n \r\n
    \r\n
    \r\n

    Daily Breakdown

    \r\n

    Starting from today and ending on {today}

    \r\n
    \r\n
    \r\n {weekDays}\r\n
    \r\n {/*
    \r\n

    - Positive

    \r\n

    - Negative

    \r\n

    - Equal

    \r\n
    */}\r\n
    \r\n
    \r\n\r\n
    \r\n
    Latest Price: {lastPrice}
    \r\n {volume}\r\n {ixDiv}\r\n
    \r\n\r\n
    \r\n

    LBC

    \r\n \r\n LBCBarsChangedHandler(e)} disabled={instrument.stockIsFavorite? false : true} min=\"0\"/>\r\n  bars\r\n \r\n \r\n
    \r\n
    \r\n\r\n
    \r\n
    \r\n \r\n
    \r\n {modelsDiv}\r\n
    \r\n {/* {basicInfo} */}\r\n
    \r\n

    Predictable Zones For the Year

    \r\n

    Based on a 12 year analysis

    \r\n
    \r\n
    \r\n {daysOfYearDivs}\r\n
    \r\n
    \r\n {daysOfYearTickers}\r\n
    \r\n
    \r\n {daysOfYearMonths}\r\n
    \r\n
    \r\n Current Year\r\n {zonesElement}\r\n
    \r\n\r\n {instrument.stockIsFavorite? : null}\r\n\r\n {/* DIALOGS */}\r\n setAddDialog(false)}>\r\n

    Add New Model

    \r\n \r\n \r\n\r\n \r\n
    \r\n\r\n setAstroOpen(false)}>\r\n setAstroOpen(false)} />\r\n \r\n\r\n setQspecOpen(false)}>\r\n setQspecOpen(false)} />\r\n \r\n\r\n \r\n {dialogContent}\r\n \r\n\r\n toggleIx(false)}>\r\n toggleIx(false)}\r\n instrData={instrument.data}\r\n stockIsFavorite={instrument.stockIsFavorite}\r\n ixSelected={() => loadFunc()}\r\n />\r\n \r\n
    \r\n )\r\n}\r\n","export default function toInteger(dirtyNumber) {\n if (dirtyNumber === null || dirtyNumber === true || dirtyNumber === false) {\n return NaN;\n }\n\n var number = Number(dirtyNumber);\n\n if (isNaN(number)) {\n return number;\n }\n\n return number < 0 ? Math.ceil(number) : Math.floor(number);\n}","export default function requiredArgs(required, args) {\n if (args.length < required) {\n throw new TypeError(required + ' argument' + (required > 1 ? 's' : '') + ' required, but only ' + args.length + ' present');\n }\n}","function _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name toDate\n * @category Common Helpers\n * @summary Convert the given argument to an instance of Date.\n *\n * @description\n * Convert the given argument to an instance of Date.\n *\n * If the argument is an instance of Date, the function returns its clone.\n *\n * If the argument is a number, it is treated as a timestamp.\n *\n * If the argument is none of the above, the function returns Invalid Date.\n *\n * **Note**: *all* Date arguments passed to any *date-fns* function is processed by `toDate`.\n *\n * @param {Date|Number} argument - the value to convert\n * @returns {Date} the parsed date in the local time zone\n * @throws {TypeError} 1 argument required\n *\n * @example\n * // Clone the date:\n * const result = toDate(new Date(2014, 1, 11, 11, 30, 30))\n * //=> Tue Feb 11 2014 11:30:30\n *\n * @example\n * // Convert the timestamp to date:\n * const result = toDate(1392098430000)\n * //=> Tue Feb 11 2014 11:30:30\n */\n\nexport default function toDate(argument) {\n requiredArgs(1, arguments);\n var argStr = Object.prototype.toString.call(argument); // Clone the date\n\n if (argument instanceof Date || _typeof(argument) === 'object' && argStr === '[object Date]') {\n // Prevent the date to lose the milliseconds when passed to new Date() in IE10\n return new Date(argument.getTime());\n } else if (typeof argument === 'number' || argStr === '[object Number]') {\n return new Date(argument);\n } else {\n if ((typeof argument === 'string' || argStr === '[object String]') && typeof console !== 'undefined') {\n // eslint-disable-next-line no-console\n console.warn(\"Starting with v2.0.0-beta.1 date-fns doesn't accept strings as date arguments. Please use `parseISO` to parse strings. See: https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#string-arguments\"); // eslint-disable-next-line no-console\n\n console.warn(new Error().stack);\n }\n\n return new Date(NaN);\n }\n}","// THIS FILE IS AUTO GENERATED\nimport { GenIcon } from '../lib';\nexport function Tb2Fa (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 16h-4l3.47 -4.66a2 2 0 1 0 -3.47 -1.54\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 16v-8h4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"12\",\"x2\":\"13\",\"y2\":\"12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 16v-6a2 2 0 0 1 4 0v6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"13\",\"x2\":\"21\",\"y2\":\"13\"}}]})(props);\n};\nexport function Tb3DCubeSphere (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 17.6l-2 -1.1v-2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 10v-2.5l2 -1.1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 4.1l2 -1.1l2 1.1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 6.4l2 1.1v2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 14v2.5l-2 1.12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 19.9l-2 1.1l-2 -1.1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"14\",\"y2\":\"10.9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"8.6\",\"x2\":\"20\",\"y2\":\"7.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"14.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"18.5\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l-2 -1.12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"8.6\",\"x2\":\"4\",\"y2\":\"7.5\"}}]})(props);\n};\nexport function Tb3DRotate (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 15.5l4 -2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 13l4 2.5v4.996l4 -2.496v-5l-4 -2.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 13v5l4 2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 4a7 7 0 0 1 7 7v4l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 12l-3 3\"}}]})(props);\n};\nexport function TbABOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 16v-5.5a2.5 2.5 0 0 1 5 0v5.5m0 -4h-5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8h3a2 2 0 1 1 0 4h-3m3 0a2 2 0 0 1 .83 3.82m-3.83 -3.82v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbAB (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 16v-5.5a2.5 2.5 0 0 1 5 0v5.5m0 -4h-5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"6\",\"x2\":\"12\",\"y2\":\"18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16v-8h3a2 2 0 0 1 0 4h-3m3 0a2 2 0 0 1 0 4h-3\"}}]})(props);\n};\nexport function TbAbacus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 3v18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 21v-18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7h14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 15h14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 13v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 13v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 5v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 5v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 5v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21h18\"}}]})(props);\n};\nexport function TbAccessPointOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.828 9.172a4 4 0 0 1 1.172 2.828\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.657 6.343a8 8 0 0 1 1.635 8.952\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.168 14.828a4 4 0 0 1 0 -5.656\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.337 17.657a8 8 0 0 1 0 -11.314\"}}]})(props);\n};\nexport function TbAccessPoint (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"12.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.828 9.172a4 4 0 0 1 0 5.656\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.657 6.343a8 8 0 0 1 0 11.314\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.168 14.828a4 4 0 0 1 0 -5.656\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.337 17.657a8 8 0 0 1 0 -11.314\"}}]})(props);\n};\nexport function TbAccessibleOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 16.5l2 -3l2 3m-2 -3v-1.5m2.627 -1.376l.373 -.124m-6 0l2.231 .744\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.042 16.045a9 9 0 0 0 -12.087 -12.087m-2.318 1.677a9 9 0 1 0 12.725 12.73\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8a0.5 .5 0 1 0 -.5 -.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbAccessible (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 16.5l2 -3l2 3m-2 -3v-2l3 -1m-6 0l3 1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"7.5\",\"r\":\".5\",\"fill\":\"currentColor\"}}]})(props);\n};\nexport function TbActivityHeartbeat (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h4.5l1.5 -6l4 12l2 -9l1.5 3h4.5\"}}]})(props);\n};\nexport function TbActivity (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h4l3 8l4 -16l3 8h4\"}}]})(props);\n};\nexport function TbAd2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.933 5h-6.933v16h13v-8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 17h-5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 13h5v-4h-5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 5v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 6l2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 9h2\"}}]})(props);\n};\nexport function TbAd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"5\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 15v-4a2 2 0 0 1 4 0v4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"13\",\"x2\":\"11\",\"y2\":\"13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 9v6h-1.5a1.5 1.5 0 1 1 1.5 -1.5\"}}]})(props);\n};\nexport function TbAddressBook (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 6v12a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 2 -2h10a2 2 0 0 1 2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 16h6\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"13\",\"cy\":\"11\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16h3\"}}]})(props);\n};\nexport function TbAdjustmentsAlt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"8\",\"width\":\"4\",\"height\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"4\",\"x2\":\"6\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"12\",\"x2\":\"6\",\"y2\":\"20\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"10\",\"y\":\"14\",\"width\":\"4\",\"height\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"18\",\"x2\":\"12\",\"y2\":\"20\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"16\",\"y\":\"5\",\"width\":\"4\",\"height\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"4\",\"x2\":\"18\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"9\",\"x2\":\"18\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbAdjustmentsHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"6\",\"x2\":\"12\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"6\",\"x2\":\"20\",\"y2\":\"6\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"12\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"6\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"18\",\"x2\":\"15\",\"y2\":\"18\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"18\",\"x2\":\"20\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbAdjustmentsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"10\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12v8\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"16\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18v2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"7\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 4v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 9v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 18v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbAdjustments (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"10\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"4\",\"x2\":\"6\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"12\",\"x2\":\"6\",\"y2\":\"20\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"16\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"18\",\"x2\":\"12\",\"y2\":\"20\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"7\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"4\",\"x2\":\"18\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"9\",\"x2\":\"18\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbAerialLift (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 5l16 -2m-8 1v10m-5.106 -6h10.306c2.45 3 2.45 9 -.2 12h-10.106c-2.544 -3 -2.544 -9 0 -12zm-1.894 6h14\"}}]})(props);\n};\nexport function TbAffiliate (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.931 6.936l1.275 4.249m5.607 5.609l4.251 1.275\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.683 12.317l5.759 -5.759\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5.5\",\"cy\":\"5.5\",\"r\":\"1.5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18.5\",\"cy\":\"5.5\",\"r\":\"1.5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18.5\",\"cy\":\"18.5\",\"r\":\"1.5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8.5\",\"cy\":\"15.5\",\"r\":\"4.5\"}}]})(props);\n};\nexport function TbAlarmOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.587 7.566a7 7 0 1 0 9.833 9.864m1.35 -2.645a7 7 0 0 0 -8.536 -8.56\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v1h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.261 5.265l-1.011 .735\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4l2.75 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbAlarm (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"13\",\"r\":\"7\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"12 10 12 13 14 13\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"4\",\"x2\":\"4.25\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"4\",\"x2\":\"19.75\",\"y2\":\"6\"}}]})(props);\n};\nexport function TbAlbum (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4v7l2 -2l2 2v-7\"}}]})(props);\n};\nexport function TbAlertCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"16\",\"x2\":\"12.01\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbAlertOctagon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.7 3h6.6c.3 0 .5 .1 .7 .3l4.7 4.7c.2 .2 .3 .4 .3 .7v6.6c0 .3 -.1 .5 -.3 .7l-4.7 4.7c-.2 .2 -.4 .3 -.7 .3h-6.6c-.3 0 -.5 -.1 -.7 -.3l-4.7 -4.7c-.2 -.2 -.3 -.4 -.3 -.7v-6.6c0 -.3 .1 -.5 .3 -.7l4.7 -4.7c.2 -.2 .4 -.3 .7 -.3z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"16\",\"x2\":\"12.01\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbAlertTriangle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9v2m0 4v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 19h14a2 2 0 0 0 1.84 -2.75l-7.1 -12.25a2 2 0 0 0 -3.5 0l-7.1 12.25a2 2 0 0 0 1.75 2.75\"}}]})(props);\n};\nexport function TbAlien (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 17a2.5 2.5 0 0 0 2 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3c-4.664 0 -7.396 2.331 -7.862 5.595a11.816 11.816 0 0 0 2 8.592a10.777 10.777 0 0 0 3.199 3.064c1.666 1 3.664 1 5.33 0a10.777 10.777 0 0 0 3.199 -3.064a11.89 11.89 0 0 0 2 -8.592c-.466 -3.265 -3.198 -5.595 -7.862 -5.595z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"11\",\"x2\":\"10\",\"y2\":\"13\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"11\",\"x2\":\"14\",\"y2\":\"13\"}}]})(props);\n};\nexport function TbAlignCenter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"6\",\"x2\":\"20\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"12\",\"x2\":\"16\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"18\",\"x2\":\"18\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbAlignJustified (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"6\",\"x2\":\"20\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"18\",\"x2\":\"16\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbAlignLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"6\",\"x2\":\"20\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"14\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"18\",\"x2\":\"18\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbAlignRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"6\",\"x2\":\"20\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"18\",\"x2\":\"20\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbAmbulance (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 17h-2v-11a1 1 0 0 1 1 -1h9v12m-4 0h6m4 0h2v-6h-8m0 -5h5l3 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10h4m-2 -2v4\"}}]})(props);\n};\nexport function TbAnchorOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 13a8 8 0 0 0 14.138 5.13m1.44 -2.56a7.99 7.99 0 0 0 .422 -2.57\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 13h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 13h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.866 8.873a3.001 3.001 0 1 0 -3.737 -3.747\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbAnchor (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9v12m-8 -8a8 8 0 0 0 16 0m1 0h-2m-14 0h-2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"6\",\"r\":\"3\"}}]})(props);\n};\nexport function TbAngle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 19h-18l9 -15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.615 15.171h.015\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.515 11.771h.015\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.715 8.671h.015\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.415 5.971h.015\"}}]})(props);\n};\nexport function TbAnkh (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 13h12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-8l-.422 -.211a6.472 6.472 0 0 1 -3.578 -5.789a4 4 0 1 1 8 0a6.472 6.472 0 0 1 -3.578 5.789l-.422 .211\"}}]})(props);\n};\nexport function TbAntennaBars1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"18\",\"x2\":\"6\",\"y2\":\"18.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"18\",\"x2\":\"10\",\"y2\":\"18.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"18\",\"x2\":\"14\",\"y2\":\"18.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"18\",\"x2\":\"18\",\"y2\":\"18.01\"}}]})(props);\n};\nexport function TbAntennaBars2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"18\",\"x2\":\"6\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"18\",\"x2\":\"10\",\"y2\":\"18.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"18\",\"x2\":\"14\",\"y2\":\"18.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"18\",\"x2\":\"18\",\"y2\":\"18.01\"}}]})(props);\n};\nexport function TbAntennaBars3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"18\",\"x2\":\"6\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"18\",\"x2\":\"10\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"18\",\"x2\":\"14\",\"y2\":\"18.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"18\",\"x2\":\"18\",\"y2\":\"18.01\"}}]})(props);\n};\nexport function TbAntennaBars4 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"18\",\"x2\":\"6\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"18\",\"x2\":\"10\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"18\",\"x2\":\"14\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"18\",\"x2\":\"18\",\"y2\":\"18.01\"}}]})(props);\n};\nexport function TbAntennaBars5 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"18\",\"x2\":\"6\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"18\",\"x2\":\"10\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"18\",\"x2\":\"14\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"18\",\"x2\":\"18\",\"y2\":\"6\"}}]})(props);\n};\nexport function TbAntennaBarsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 18v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 18v-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 18v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 14v-8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbAntenna (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 4v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4.5v7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5v16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 5.5v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 8h-16\"}}]})(props);\n};\nexport function TbAperture (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3.6\",\"y1\":\"15\",\"x2\":\"14.15\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3.6\",\"y1\":\"15\",\"x2\":\"14.15\",\"y2\":\"15\",\"transform\":\"rotate(72 12 12)\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3.6\",\"y1\":\"15\",\"x2\":\"14.15\",\"y2\":\"15\",\"transform\":\"rotate(144 12 12)\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3.6\",\"y1\":\"15\",\"x2\":\"14.15\",\"y2\":\"15\",\"transform\":\"rotate(216 12 12)\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3.6\",\"y1\":\"15\",\"x2\":\"14.15\",\"y2\":\"15\",\"transform\":\"rotate(288 12 12)\"}}]})(props);\n};\nexport function TbApiAppOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 15h-6.5a2.5 2.5 0 1 1 0 -5h.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 15v3.5a2.5 2.5 0 1 1 -5 0v-.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 9h5.5a2.5 2.5 0 1 1 0 5h-.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12v-3m.042 -3.957a2.5 2.5 0 0 1 4.958 .457v.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbApiApp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 15h-6.5a2.5 2.5 0 1 1 0 -5h.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 12v6.5a2.5 2.5 0 1 1 -5 0v-.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9h6.5a2.5 2.5 0 1 1 0 5h-.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12v-6.5a2.5 2.5 0 0 1 5 0v.5\"}}]})(props);\n};\nexport function TbApiOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 13h5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 16v-4m0 -4h3a2 2 0 0 1 2 2v1c0 .554 -.225 1.055 -.589 1.417m-3.411 .583h-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 8v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 16v-5.5a2.5 2.5 0 0 0 -5 0v5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbApi (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 13h5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 16v-8h3a2 2 0 0 1 2 2v1a2 2 0 0 1 -2 2h-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 8v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 16v-5.5a2.5 2.5 0 0 0 -5 0v5.5\"}}]})(props);\n};\nexport function TbAppWindow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"5\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 8h.01\"}}]})(props);\n};\nexport function TbApple (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"14\",\"r\":\"7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 11v-6a2 2 0 0 1 2 -2h2v1a2 2 0 0 1 -2 2h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10.5c1.333 .667 2.667 .667 4 0\"}}]})(props);\n};\nexport function TbAppsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h1a1 1 0 0 1 1 1v1m-.29 3.704a0.997 .997 0 0 1 -.71 .296h-4a1 1 0 0 1 -1 -1v-4c0 -.276 .111 -.525 .292 -.706\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 14h1a1 1 0 0 1 1 1v1m-.29 3.704a0.997 .997 0 0 1 -.71 .296h-4a1 1 0 0 1 -1 -1v-4c0 -.276 .111 -.525 .292 -.706\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"14\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 7h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbApps (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"14\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"14\",\"y\":\"14\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"7\",\"x2\":\"20\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"4\",\"x2\":\"17\",\"y2\":\"10\"}}]})(props);\n};\nexport function TbArchiveOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h11a2 2 0 1 1 0 4h-7m-4 0h-3a2 2 0 0 1 -.826 -3.822\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 8v10a2 2 0 0 0 2 2h10a2 2 0 0 0 1.824 -1.18m.176 -3.82v-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbArchive (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"4\",\"width\":\"18\",\"height\":\"4\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 8v10a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"12\",\"x2\":\"14\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbArmchair2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 10v-4a3 3 0 0 1 3 -3h8a3 3 0 0 1 3 3v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 15v-2a3 3 0 1 1 3 3v3h-14v-3a3 3 0 1 1 3 -3v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 19v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 19v2\"}}]})(props);\n};\nexport function TbArmchair (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 11a2 2 0 0 1 2 2v2h10v-2a2 2 0 1 1 4 0v4a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-4a2 2 0 0 1 2 -2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 11v-5a3 3 0 0 1 3 -3h8a3 3 0 0 1 3 3v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 19v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 19v2\"}}]})(props);\n};\nexport function TbArrowAutofitContent (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 4l-3 3l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 4l3 3l-3 3\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"14\",\"width\":\"16\",\"height\":\"6\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 7h-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 7h-7\"}}]})(props);\n};\nexport function TbArrowAutofitDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20h-6a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 2 -2h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 4v17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 18l3 3l3 -3\"}}]})(props);\n};\nexport function TbArrowAutofitHeight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20h-6a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 2 -2h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 14v7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 3v7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 18l3 3l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 6l3 -3l3 3\"}}]})(props);\n};\nexport function TbArrowAutofitLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12v-6a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 18h-17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15l-3 3l3 3\"}}]})(props);\n};\nexport function TbArrowAutofitRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12v-6a2 2 0 0 0 -2 -2h-12a2 2 0 0 0 -2 2v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18h17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15l3 3l-3 3\"}}]})(props);\n};\nexport function TbArrowAutofitUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4h-6a2 2 0 0 0 -2 2v12a2 2 0 0 0 2 2h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 20v-17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 6l3 -3l3 3\"}}]})(props);\n};\nexport function TbArrowAutofitWidth (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12v-6a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 18h-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 18h-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15l-3 3l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15l3 3l-3 3\"}}]})(props);\n};\nexport function TbArrowBackUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 13l-4 -4l4 -4m-4 4h11a4 4 0 0 1 0 8h-1\"}}]})(props);\n};\nexport function TbArrowBack (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 11l-4 4l4 4m-4 -4h11a4 4 0 0 0 0 -8h-1\"}}]})(props);\n};\nexport function TbArrowBarDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"20\",\"x2\":\"12\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"20\",\"x2\":\"16\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"20\",\"x2\":\"8\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"4\"}}]})(props);\n};\nexport function TbArrowBarLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"14\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"8\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"8\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbArrowBarRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"12\",\"x2\":\"10\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"12\",\"x2\":\"16\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"12\",\"x2\":\"16\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"4\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbArrowBarToDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"20\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"14\",\"x2\":\"12\",\"y2\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"14\",\"x2\":\"16\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"14\",\"x2\":\"8\",\"y2\":\"10\"}}]})(props);\n};\nexport function TbArrowBarToLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"12\",\"x2\":\"14\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"12\",\"x2\":\"14\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"4\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbArrowBarToRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"12\",\"x2\":\"4\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"12\",\"x2\":\"10\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"12\",\"x2\":\"10\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbArrowBarToUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"10\",\"x2\":\"12\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"10\",\"x2\":\"16\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"10\",\"x2\":\"8\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"4\"}}]})(props);\n};\nexport function TbArrowBarUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"16\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"8\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"20\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbArrowBearLeft2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 3h-5v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 3l7.536 7.536a5 5 0 0 1 1.464 3.534v6.93\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 5l-4.5 4.5\"}}]})(props);\n};\nexport function TbArrowBearLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 3h-5v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 3l7.536 7.536a5 5 0 0 1 1.464 3.534v6.93\"}}]})(props);\n};\nexport function TbArrowBearRight2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3h5v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 3l-7.536 7.536a5 5 0 0 0 -1.464 3.534v6.93\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 5l4.5 4.5\"}}]})(props);\n};\nexport function TbArrowBearRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3h5v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 3l-7.536 7.536a5 5 0 0 0 -1.464 3.534v6.93\"}}]})(props);\n};\nexport function TbArrowBigDownLine (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 12h3.586a1 1 0 0 1 .707 1.707l-6.586 6.586a1 1 0 0 1 -1.414 0l-6.586 -6.586a1 1 0 0 1 .707 -1.707h3.586v-6h6v6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3h-6\"}}]})(props);\n};\nexport function TbArrowBigDownLines (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 12h3.586a1 1 0 0 1 .707 1.707l-6.586 6.586a1 1 0 0 1 -1.414 0l-6.586 -6.586a1 1 0 0 1 .707 -1.707h3.586v-3h6v3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3h-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 6h-6\"}}]})(props);\n};\nexport function TbArrowBigDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 4v8h3.586a1 1 0 0 1 .707 1.707l-6.586 6.586a1 1 0 0 1 -1.414 0l-6.586 -6.586a1 1 0 0 1 .707 -1.707h3.586v-8a1 1 0 0 1 1 -1h4a1 1 0 0 1 1 1z\"}}]})(props);\n};\nexport function TbArrowBigLeftLine (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 15v3.586a1 1 0 0 1 -1.707 .707l-6.586 -6.586a1 1 0 0 1 0 -1.414l6.586 -6.586a1 1 0 0 1 1.707 .707v3.586h6v6h-6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 15v-6\"}}]})(props);\n};\nexport function TbArrowBigLeftLines (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 15v3.586a1 1 0 0 1 -1.707 .707l-6.586 -6.586a1 1 0 0 1 0 -1.414l6.586 -6.586a1 1 0 0 1 1.707 .707v3.586h3v6h-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 15v-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15v-6\"}}]})(props);\n};\nexport function TbArrowBigLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 15h-8v3.586a1 1 0 0 1 -1.707 .707l-6.586 -6.586a1 1 0 0 1 0 -1.414l6.586 -6.586a1 1 0 0 1 1.707 .707v3.586h8a1 1 0 0 1 1 1v4a1 1 0 0 1 -1 1z\"}}]})(props);\n};\nexport function TbArrowBigRightLine (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9v-3.586a1 1 0 0 1 1.707 -.707l6.586 6.586a1 1 0 0 1 0 1.414l-6.586 6.586a1 1 0 0 1 -1.707 -.707v-3.586h-6v-6h6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 9v6\"}}]})(props);\n};\nexport function TbArrowBigRightLines (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9v-3.586a1 1 0 0 1 1.707 -.707l6.586 6.586a1 1 0 0 1 0 1.414l-6.586 6.586a1 1 0 0 1 -1.707 -.707v-3.586h-3v-6h3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 9v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 9v6\"}}]})(props);\n};\nexport function TbArrowBigRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 9h8v-3.586a1 1 0 0 1 1.707 -.707l6.586 6.586a1 1 0 0 1 0 1.414l-6.586 6.586a1 1 0 0 1 -1.707 -.707v-3.586h-8a1 1 0 0 1 -1 -1v-4a1 1 0 0 1 1 -1z\"}}]})(props);\n};\nexport function TbArrowBigTop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 20v-8h-3.586a1 1 0 0 1 -.707 -1.707l6.586 -6.586a1 1 0 0 1 1.414 0l6.586 6.586a1 1 0 0 1 -.707 1.707h-3.586v8a1 1 0 0 1 -1 1h-4a1 1 0 0 1 -1 -1z\"}}]})(props);\n};\nexport function TbArrowBigUpLine (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12h-3.586a1 1 0 0 1 -.707 -1.707l6.586 -6.586a1 1 0 0 1 1.414 0l6.586 6.586a1 1 0 0 1 -.707 1.707h-3.586v6h-6v-6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 21h6\"}}]})(props);\n};\nexport function TbArrowBigUpLines (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12h-3.586a1 1 0 0 1 -.707 -1.707l6.586 -6.586a1 1 0 0 1 1.414 0l6.586 6.586a1 1 0 0 1 -.707 1.707h-3.586v3h-6v-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 21h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18h6\"}}]})(props);\n};\nexport function TbArrowBottomBar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18l3 3l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 3h6\"}}]})(props);\n};\nexport function TbArrowBottomCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18l3 3l3 -3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"5\",\"r\":\"2\"}}]})(props);\n};\nexport function TbArrowBottomSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18l3 3l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4h-4v-4z\"}}]})(props);\n};\nexport function TbArrowBottomTail (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6v15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18l3 3l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 3l3 3l3 -3\"}}]})(props);\n};\nexport function TbArrowCurveLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 7l-4 -4l-4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 3v4.394a6.737 6.737 0 0 0 3 5.606a6.737 6.737 0 0 1 3 5.606v2.394\"}}]})(props);\n};\nexport function TbArrowCurveRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 7l4 -4l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4.394a6.737 6.737 0 0 1 -3 5.606a6.737 6.737 0 0 0 -3 5.606v2.394\"}}]})(props);\n};\nexport function TbArrowDownCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbArrowDownLeftCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"9\",\"x2\":\"9\",\"y2\":\"15\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"15 15 9 15 9 9\"}}]})(props);\n};\nexport function TbArrowDownLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"7\",\"x2\":\"7\",\"y2\":\"17\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 17 7 17 7 8\"}}]})(props);\n};\nexport function TbArrowDownRightCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"15\",\"x2\":\"9\",\"y2\":\"15\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"15 9 15 15 9 9\"}}]})(props);\n};\nexport function TbArrowDownRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"7\",\"x2\":\"17\",\"y2\":\"17\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"17 8 17 17 8 17\"}}]})(props);\n};\nexport function TbArrowDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"5\",\"x2\":\"12\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"13\",\"x2\":\"12\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"13\",\"x2\":\"12\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbArrowFork (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 3h5v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 3h-5v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 3l-7.536 7.536a5 5 0 0 0 -1.464 3.534v6.93\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l7.536 7.536a5 5 0 0 1 1.464 3.534v.93\"}}]})(props);\n};\nexport function TbArrowForwardUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 13l4 -4l-4 -4m4 4h-11a4 4 0 0 0 0 8h1\"}}]})(props);\n};\nexport function TbArrowForward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 11l4 4l-4 4m4 -4h-11a4 4 0 0 1 0 -8h1\"}}]})(props);\n};\nexport function TbArrowLeftBar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 12h-18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 9l-3 3l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 9v6\"}}]})(props);\n};\nexport function TbArrowLeftCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 12h-14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 9l-3 3l3 3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"12\",\"r\":\"2\"}}]})(props);\n};\nexport function TbArrowLeftRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 13l4 -4l-4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 13l-4 -4l4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14a5 5 0 0 1 5 -5h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 19v-5a5 5 0 0 0 -5 -5h-4\"}}]})(props);\n};\nexport function TbArrowLeftSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 12h-14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 9l-3 3l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 14h-4v-4h4z\"}}]})(props);\n};\nexport function TbArrowLeftTail (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 12h-15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 9l-3 3l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 9l-3 3l3 3\"}}]})(props);\n};\nexport function TbArrowLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"19\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"11\",\"y2\":\"18\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"11\",\"y2\":\"6\"}}]})(props);\n};\nexport function TbArrowLoopLeft2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 21v-6m0 -6v-1a4 4 0 1 1 4 4h-13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16l-4 -4l4 -4\"}}]})(props);\n};\nexport function TbArrowLoopLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 21v-13a4 4 0 1 1 4 4h-13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16l-4 -4l4 -4\"}}]})(props);\n};\nexport function TbArrowLoopRight2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-6m0 -6v-1a4 4 0 1 0 -4 4h13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 16l4 -4l-4 -4\"}}]})(props);\n};\nexport function TbArrowLoopRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-13a4 4 0 1 0 -4 4h13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 16l4 -4l-4 -4\"}}]})(props);\n};\nexport function TbArrowMerge (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 7l4 -4l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v5.394a6.737 6.737 0 0 1 -3 5.606a6.737 6.737 0 0 0 -3 5.606v1.394\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v5.394a6.737 6.737 0 0 0 3 5.606a6.737 6.737 0 0 1 3 5.606v1.394\"}}]})(props);\n};\nexport function TbArrowNarrowDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"5\",\"x2\":\"12\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"15\",\"x2\":\"12\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"15\",\"x2\":\"12\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbArrowNarrowLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"19\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"9\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"9\",\"y2\":\"8\"}}]})(props);\n};\nexport function TbArrowNarrowRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"19\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"16\",\"x2\":\"19\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"8\",\"x2\":\"19\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbArrowNarrowUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"5\",\"x2\":\"12\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"9\",\"x2\":\"12\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"9\",\"x2\":\"12\",\"y2\":\"5\"}}]})(props);\n};\nexport function TbArrowRampLeft2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 3v8.707\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 14l-4 -4l4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 21c0 -6.075 -4.925 -11 -11 -11h-3\"}}]})(props);\n};\nexport function TbArrowRampLeft3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 3v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16l-4 -4l4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 21v-6a3 3 0 0 0 -3 -3h-11\"}}]})(props);\n};\nexport function TbArrowRampLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"3\",\"x2\":\"17\",\"y2\":\"11.707\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 7l4 -4l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 14l-4 -4l4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21a11 11 0 0 0 -11 -11h-3\"}}]})(props);\n};\nexport function TbArrowRampRight2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 3v8.707\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 14l4 -4l-4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 21c0 -6.075 4.925 -11 11 -11h3\"}}]})(props);\n};\nexport function TbArrowRampRight3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 3v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16l4 -4l-4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 21v-6a3 3 0 0 1 3 -3h11\"}}]})(props);\n};\nexport function TbArrowRampRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"3\",\"x2\":\"7\",\"y2\":\"11.707\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7l-4 -4l-4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 14l4 -4l-4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 21a11 11 0 0 1 11 -11h3\"}}]})(props);\n};\nexport function TbArrowRightBar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15l3 -3l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 9v6\"}}]})(props);\n};\nexport function TbArrowRightCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15l3 -3l-3 -3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"12\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12h14\"}}]})(props);\n};\nexport function TbArrowRightSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"12\",\"x2\":\"21\",\"y2\":\"12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15l3 -3l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 10h4v4h-4z\"}}]})(props);\n};\nexport function TbArrowRightTail (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15l3 -3l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 15l3 -3l-3 -3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"12\",\"x2\":\"21\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbArrowRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"19\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"18\",\"x2\":\"19\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"6\",\"x2\":\"19\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbArrowRotaryFirstLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"transform\":\"matrix(-1 0 0 1 32 0)\",\"cx\":\"16\",\"cy\":\"7\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 10v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 9.5l-8.5 8.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 18h-5v-5\"}}]})(props);\n};\nexport function TbArrowRotaryFirstRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"7\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 10v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 9.5l8.5 8.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 18h5v-5\"}}]})(props);\n};\nexport function TbArrowRotaryLastLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"transform\":\"matrix(-1 0 0 1 30 0)\",\"cx\":\"15\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 15v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 9.5l-6.5 -6.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 3h-5v5\"}}]})(props);\n};\nexport function TbArrowRotaryLastRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 15v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.5 9.5l6.5 -6.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 3h5v5\"}}]})(props);\n};\nexport function TbArrowRotaryLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"transform\":\"matrix(-1 0 0 1 32 0)\",\"cx\":\"16\",\"cy\":\"7\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 10v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 7h-10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 11l-4 -4l4 -4\"}}]})(props);\n};\nexport function TbArrowRotaryRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"7\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 10v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 11l4 -4l-4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7h10\"}}]})(props);\n};\nexport function TbArrowRotaryStraight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"13\",\"cy\":\"13\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 16v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 3v7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 7l4 -4l4 4\"}}]})(props);\n};\nexport function TbArrowSharpTurnLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 18v-11.31a0.7 .7 0 0 0 -1.195 -.495l-9.805 9.805\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 16h-5v-5\"}}]})(props);\n};\nexport function TbArrowSharpTurnRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 18v-11.31a0.7 .7 0 0 1 1.195 -.495l9.805 9.805\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 16h5v-5\"}}]})(props);\n};\nexport function TbArrowTopBar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"21\",\"x2\":\"12\",\"y2\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 6l-3 -3l-3 3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"21\",\"x2\":\"15\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbArrowTopCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"17\",\"x2\":\"12\",\"y2\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 6l-3 -3l-3 3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"19\",\"r\":\"2\"}}]})(props);\n};\nexport function TbArrowTopSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"17\",\"x2\":\"12\",\"y2\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 6l-3 -3l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 21v-4h4v4z\"}}]})(props);\n};\nexport function TbArrowTopTail (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"18\",\"x2\":\"12\",\"y2\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 6l-3 -3l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 21l-3 -3l-3 3\"}}]})(props);\n};\nexport function TbArrowUpCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"8\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"8\"}}]})(props);\n};\nexport function TbArrowUpLeftCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"9\",\"x2\":\"15\",\"y2\":\"15\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"15 9 9 9 9 15\"}}]})(props);\n};\nexport function TbArrowUpLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"7\",\"x2\":\"17\",\"y2\":\"17\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 7 7 7 7 16\"}}]})(props);\n};\nexport function TbArrowUpRightCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"9\",\"x2\":\"9\",\"y2\":\"15\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"15 15 15 9 9 9\"}}]})(props);\n};\nexport function TbArrowUpRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"7\",\"x2\":\"7\",\"y2\":\"17\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"8 7 17 7 17 16\"}}]})(props);\n};\nexport function TbArrowUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"5\",\"x2\":\"12\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"11\",\"x2\":\"12\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"11\",\"x2\":\"12\",\"y2\":\"5\"}}]})(props);\n};\nexport function TbArrowWaveLeftDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 13.998h-4v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 11.998c-.887 1.284 -2.48 2.033 -4 2c-1.52 .033 -3.113 -.716 -4 -2s-2.48 -2.033 -4 -2c-1.52 -.033 -3 1 -4 2l-2 2\"}}]})(props);\n};\nexport function TbArrowWaveLeftUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 9.996h-4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 11.996c-.887 -1.285 -2.48 -2.033 -4 -2c-1.52 -.033 -3.113 .715 -4 2c-.887 1.284 -2.48 2.033 -4 2c-1.52 .033 -3 -1 -4 -2l-2 -2\"}}]})(props);\n};\nexport function TbArrowWaveRightDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 13.998h4v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 11.998c.887 1.284 2.48 2.033 4 2c1.52 .033 3.113 -.716 4 -2s2.48 -2.033 4 -2c1.52 -.033 3 1 4 2l2 2\"}}]})(props);\n};\nexport function TbArrowWaveRightUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 10h4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12c.887 -1.284 2.48 -2.033 4 -2c1.52 -.033 3.113 .716 4 2s2.48 2.033 4 2c1.52 .033 3 -1 4 -2l2 -2\"}}]})(props);\n};\nexport function TbArrowsCross (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 9l5 -5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20l5 -5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h4v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4l16 16\"}}]})(props);\n};\nexport function TbArrowsDiagonal2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 20 20 20 20 16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"14\",\"x2\":\"20\",\"y2\":\"20\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"8 4 4 4 4 8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"10\",\"y2\":\"10\"}}]})(props);\n};\nexport function TbArrowsDiagonalMinimize2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 10h-4v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 4l-6 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 14h4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 14l-6 6\"}}]})(props);\n};\nexport function TbArrowsDiagonalMinimize (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10h4v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4l6 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 14h-4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14l6 6\"}}]})(props);\n};\nexport function TbArrowsDiagonal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 4 20 4 20 8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"10\",\"x2\":\"20\",\"y2\":\"4\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"8 20 4 20 4 16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"10\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbArrowsDoubleNeSw (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 14l11 -11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 3h4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 17v4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 10l-11 11\"}}]})(props);\n};\nexport function TbArrowsDoubleNwSe (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 21l-11 -11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 14v-4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 14h4v-4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbArrowsDoubleSeNw (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"10\",\"x2\":\"14\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 17v4h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3h-4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 14l-11 -11\"}}]})(props);\n};\nexport function TbArrowsDoubleSwNe (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3l-11 11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 10v4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 10h4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 21l11 -11\"}}]})(props);\n};\nexport function TbArrowsDownUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"3\",\"x2\":\"17\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 18l-3 3l-3 -3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"21\",\"x2\":\"7\",\"y2\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 6l-3 -3l-3 3\"}}]})(props);\n};\nexport function TbArrowsDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"21\",\"x2\":\"7\",\"y2\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 18l-3 3l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18l3 3l3 -3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"21\",\"x2\":\"17\",\"y2\":\"3\"}}]})(props);\n};\nexport function TbArrowsHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"7 8 3 12 7 16\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"17 8 21 12 17 16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"12\",\"x2\":\"21\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbArrowsJoin2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7h1.948c1.913 0 3.705 .933 4.802 2.5a5.861 5.861 0 0 0 4.802 2.5h6.448\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17h1.95a5.854 5.854 0 0 0 4.798 -2.5a5.854 5.854 0 0 1 4.798 -2.5h5.454\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15l3 -3l-3 -3\"}}]})(props);\n};\nexport function TbArrowsJoin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7h5l3.5 5h9.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17h5l3.495 -5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15l3 -3l-3 -3\"}}]})(props);\n};\nexport function TbArrowsLeftDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 3l-4 4l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7h11a3 3 0 0 1 3 3v11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 17l4 4l4 -4\"}}]})(props);\n};\nexport function TbArrowsLeftRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"17\",\"x2\":\"3\",\"y2\":\"17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10l-3 -3l3 -3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"7\",\"x2\":\"21\",\"y2\":\"7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 20l3 -3l-3 -3\"}}]})(props);\n};\nexport function TbArrowsLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"7\",\"x2\":\"21\",\"y2\":\"7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 20l-3 -3l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 4l-3 3l3 3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"17\",\"x2\":\"21\",\"y2\":\"17\"}}]})(props);\n};\nexport function TbArrowsMaximize (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 4 20 4 20 8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"10\",\"x2\":\"20\",\"y2\":\"4\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"8 20 4 20 4 16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"10\",\"y2\":\"14\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 20 20 20 20 16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"14\",\"x2\":\"20\",\"y2\":\"20\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"8 4 4 4 4 8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"10\",\"y2\":\"10\"}}]})(props);\n};\nexport function TbArrowsMinimize (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"5 9 9 9 9 5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"9\",\"y2\":\"9\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"5 15 9 15 9 19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"9\",\"y2\":\"15\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"19 9 15 9 15 5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"9\",\"x2\":\"21\",\"y2\":\"3\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"19 15 15 15 15 19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"15\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbArrowsRandom (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 21.004h-4v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 21.004l5 -5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 9.504l-3.5 -2l2 -3.504\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7.504l6.83 -1.87\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16.004l4 -1l1 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15.004l-3.5 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 5.004l-.5 4l-4 -.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.5 9.004l-4.5 -5.5\"}}]})(props);\n};\nexport function TbArrowsRightDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17l4 4l4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 21v-11a3 3 0 0 1 3 -3h11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 11l4 -4l-4 -4\"}}]})(props);\n};\nexport function TbArrowsRightLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"7\",\"x2\":\"3\",\"y2\":\"7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 10l3 -3l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 20l-3 -3l3 -3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"17\",\"x2\":\"21\",\"y2\":\"17\"}}]})(props);\n};\nexport function TbArrowsRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"17\",\"x2\":\"3\",\"y2\":\"17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 4l3 3l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 20l3 -3l-3 -3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"7\",\"x2\":\"3\",\"y2\":\"7\"}}]})(props);\n};\nexport function TbArrowsShuffle2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 4l3 3l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 20l3 -3l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7h3a5 5 0 0 1 5 5a5 5 0 0 0 5 5h5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17h3a5 5 0 0 0 5 -5a5 5 0 0 1 5 -5h5\"}}]})(props);\n};\nexport function TbArrowsShuffle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 4l3 3l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 20l3 -3l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7h3a5 5 0 0 1 5 5a5 5 0 0 0 5 5h5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 7h-5a4.978 4.978 0 0 0 -2.998 .998m-4.002 8.003a4.984 4.984 0 0 1 -3 .999h-3\"}}]})(props);\n};\nexport function TbArrowsSort (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 9l4 -4l4 4m-4 -4v14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 15l-4 4l-4 -4m4 4v-14\"}}]})(props);\n};\nexport function TbArrowsSplit2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 17h-5.397a5 5 0 0 1 -4.096 -2.133l-.514 -.734a5 5 0 0 0 -4.096 -2.133h-3.897\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 7h-5.395a5 5 0 0 0 -4.098 2.135l-.51 .73a5 5 0 0 1 -4.097 2.135h-3.9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 10l3 -3l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 20l3 -3l-3 -3\"}}]})(props);\n};\nexport function TbArrowsSplit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 17h-8l-3.5 -5h-6.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 7h-8l-3.495 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 10l3 -3l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 20l3 -3l-3 -3\"}}]})(props);\n};\nexport function TbArrowsUpDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"3\",\"x2\":\"7\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6l-3 -3l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 18l-3 3l-3 -3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"21\",\"x2\":\"17\",\"y2\":\"3\"}}]})(props);\n};\nexport function TbArrowsUpLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 7l-4 -4l-4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 3v11a3 3 0 0 1 -3 3h-11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 13l-4 4l4 4\"}}]})(props);\n};\nexport function TbArrowsUpRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21l4 -4l-4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 17h-11a3 3 0 0 1 -3 -3v-11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7l-4 -4l-4 4\"}}]})(props);\n};\nexport function TbArrowsUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"3\",\"x2\":\"17\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6l3 -3l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 6l-3 -3l-3 3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"3\",\"x2\":\"7\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbArrowsVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"8 7 12 3 16 7\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"8 17 12 21 16 17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbArtboardOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8h3a1 1 0 0 1 1 1v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.716 15.698a0.997 .997 0 0 1 -.716 .302h-6a1 1 0 0 1 -1 -1v-6c0 -.273 .11 -.52 .287 -.7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 8h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 16h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 3v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 3v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 8h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 16h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 20v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbArtboard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"8\",\"width\":\"8\",\"height\":\"8\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"8\",\"x2\":\"4\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"16\",\"x2\":\"4\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"3\",\"x2\":\"8\",\"y2\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"3\",\"x2\":\"16\",\"y2\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"8\",\"x2\":\"21\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"16\",\"x2\":\"21\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"20\",\"x2\":\"8\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"20\",\"x2\":\"16\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbAspectRatioOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h10a2 2 0 0 1 2 2v10m-2 2h-14a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12v-3h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 12v1m-2 2h-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbAspectRatio (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"5\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12v-3h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 12v3h-3\"}}]})(props);\n};\nexport function TbAsset (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"15\",\"r\":\"6\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"15\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.218 17.975l6.619 -12.174\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.079 9.756l12.217 -6.631\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"15\",\"r\":\"2\"}}]})(props);\n};\nexport function TbAsteriskSimple (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v-9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l-9 -2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l9 -2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l6 8.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l-6 8.5\"}}]})(props);\n};\nexport function TbAsterisk (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l8 -4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l-8 -4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l8 4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l-8 4.5\"}}]})(props);\n};\nexport function TbAtOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.174 9.17a4 4 0 0 0 5.646 5.668m1.18 -2.838a4 4 0 0 0 -4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.695 15.697a2.5 2.5 0 0 0 1.305 -2.197v-1.5a9 9 0 0 0 -13.055 -8.047m-2.322 1.683a9 9 0 0 0 9.877 14.644\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbAt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12v1.5a2.5 2.5 0 0 0 5 0v-1.5a9 9 0 1 0 -5.5 8.28\"}}]})(props);\n};\nexport function TbAtom2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"21\",\"x2\":\"12\",\"y2\":\"21.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"9\",\"x2\":\"3\",\"y2\":\"9.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"9\",\"x2\":\"21\",\"y2\":\"9.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 20.1a9 9 0 0 1 -5 -7.1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20.1a9 9 0 0 0 5 -7.1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.2 5a9 9 0 0 1 11.4 0\"}}]})(props);\n};\nexport function TbAtomOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.172 9.172c-3.906 3.905 -5.805 8.337 -4.243 9.9c1.562 1.561 5.994 -.338 9.9 -4.244m1.884 -2.113c2.587 -3.277 3.642 -6.502 2.358 -7.786c-1.284 -1.284 -4.508 -.23 -7.784 2.357\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.929 4.929c-1.562 1.562 .337 5.994 4.243 9.9c3.905 3.905 8.337 5.804 9.9 4.242m-.072 -4.071c-.767 -1.794 -2.215 -3.872 -4.172 -5.828c-1.944 -1.945 -4.041 -3.402 -5.828 -4.172\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbAtom (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"12.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 2a4 10 0 0 0 -4 10a4 10 0 0 0 4 10a4 10 0 0 0 4 -10a4 10 0 0 0 -4 -10\",\"transform\":\"rotate(45 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 2a4 10 0 0 0 -4 10a4 10 0 0 0 4 10a4 10 0 0 0 4 -10a4 10 0 0 0 -4 -10\",\"transform\":\"rotate(-45 12 12)\"}}]})(props);\n};\nexport function TbAugmentedReality (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8v-2a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16v2a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2a2 2 0 0 1 2 2v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h2a2 2 0 0 0 2 -2v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12.5l4 -2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 10l4 2.5v4.5l4 -2.5v-4.5l-4 -2.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 10v4.5l4 2.5\"}}]})(props);\n};\nexport function TbAwardOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.72 12.704a6 6 0 0 0 -8.433 -8.418m-1.755 2.24a6 6 0 0 0 7.936 7.944\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.002 15.003l3.4 5.89l1.598 -3.233l.707 .046m1.108 -2.902l-1.617 -2.8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.802 12.003l-3.4 5.89l3.598 -.233l1.598 3.232l3.4 -5.889\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbAward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"9\",\"r\":\"6\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"9 14.2 9 21 12 19 15 21 15 14.2\",\"transform\":\"rotate(-30 12 9)\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"9 14.2 9 21 12 19 15 21 15 14.2\",\"transform\":\"rotate(30 12 9)\"}}]})(props);\n};\nexport function TbAxe (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 9l7.383 7.418c.823 .82 .823 2.148 0 2.967a2.11 2.11 0 0 1 -2.976 0l-7.407 -7.385\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.66 15.66l-3.32 -3.32a1.25 1.25 0 0 1 .42 -2.044l3.24 -1.296l6 -6l3 3l-6 6l-1.296 3.24a1.25 1.25 0 0 1 -2.044 .42z\"}}]})(props);\n};\nexport function TbAxisX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 13v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 9v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 5v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 20l3 -3l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 17h16\"}}]})(props);\n};\nexport function TbAxisY (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 20h-.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 20h-.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 20h-.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 7l3 -3l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 20v-16\"}}]})(props);\n};\nexport function TbBabyCarriage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 5h2.5l1.632 4.897a6 6 0 0 0 5.693 4.103h2.675a5.5 5.5 0 0 0 0 -11h-.5v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 9h14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17l1 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 14l1 3\"}}]})(props);\n};\nexport function TbBackhoe (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"4\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"13\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"19\",\"x2\":\"4\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"15\",\"x2\":\"13\",\"y2\":\"15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12v-5h2a3 3 0 0 1 3 3v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 15v-2a1 1 0 0 1 1 -1h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21.12 9.88l-3.12 -4.88l-5 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21.12 9.88a3 3 0 0 1 -2.12 5.12a3 3 0 0 1 -2.12 -.88l4.24 -4.24z\"}}]})(props);\n};\nexport function TbBackpack (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7h2a6 6 0 0 1 6 6v6a1 1 0 0 1 -1 1h-12a1 1 0 0 1 -1 -1v-6a6 6 0 0 1 6 -6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 7v-1a2 2 0 1 1 4 0v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 15h4\"}}]})(props);\n};\nexport function TbBackspace (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 6a1 1 0 0 1 1 1v10a1 1 0 0 1 -1 1h-11l-5 -5a1.5 1.5 0 0 1 0 -2l5 -5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 10l4 4m0 -4l-4 4\"}}]})(props);\n};\nexport function TbBadgeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7v10l5 3l5 -3m0 -4v-9l-5 3l-2.496 -1.497\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBadge (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v-13l-5 3l-5 -3v13l5 3z\"}}]})(props);\n};\nexport function TbBadgesOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.505 14.497l-2.505 1.503l-5 -3v4l5 3l5 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.873 9.876l3.127 -1.876v-4l-5 3l-2.492 -1.495m-2.508 1.495v1l2.492 1.495\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBadges (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v-4l-5 3l-5 -3v4l5 3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 8v-4l-5 3l-5 -3v4l5 3z\"}}]})(props);\n};\nexport function TbBallAmericanFootball (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"9\",\"x2\":\"9\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"10\",\"x2\":\"14\",\"y2\":\"12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 21a5 5 0 0 0 -5 -5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 3c-7.18 0 -13 5.82 -13 13a5 5 0 0 0 5 5c7.18 0 13 -5.82 13 -13a5 5 0 0 0 -5 -5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 3a5 5 0 0 0 5 5\"}}]})(props);\n};\nexport function TbBallBaseball (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.636 18.364a9 9 0 1 0 12.728 -12.728a9 9 0 0 0 -12.728 12.728z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.495 3.02a9 9 0 0 1 -9.475 9.475\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.98 11.505a9 9 0 0 0 -9.475 9.475\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 9l2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 13l2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7l2 1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 11l1 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 11l1 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 16l2 1\"}}]})(props);\n};\nexport function TbBallBasketball (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5.65\",\"y1\":\"5.65\",\"x2\":\"18.35\",\"y2\":\"18.35\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5.65\",\"y1\":\"18.35\",\"x2\":\"18.35\",\"y2\":\"5.65\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3a9 9 0 0 0 9 9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12a9 9 0 0 1 9 9\"}}]})(props);\n};\nexport function TbBallBowling (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"9\",\"x2\":\"11\",\"y2\":\"9.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"8\",\"x2\":\"15\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"12\",\"x2\":\"14\",\"y2\":\"12.01\"}}]})(props);\n};\nexport function TbBallFootballOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.041 16.046a9 9 0 0 0 -12.084 -12.09m-2.323 1.683a9 9 0 0 0 12.726 12.73\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7l4.755 3.455l-.566 1.743l-.98 3.014l-.209 .788h-6l-1.755 -5.545l1.86 -1.351l2.313 -1.681z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"16\",\"x2\":\"17.5\",\"y2\":\"19\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.755 10.455l3.745 -1.455\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.061 16.045l-2.561 2.955\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.245 10.455l-3.745 -1.455\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbBallFootball (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7l4.76 3.45l-1.76 5.55h-6l-1.76 -5.55z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m3 13l2.5 3m-.74 -8.55l3.74 -1.45m-11.44 7.05l-2.56 2.95m.74 -8.55l-3.74 -1.45\"}}]})(props);\n};\nexport function TbBallTennis (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 5.3a9 9 0 0 1 0 13.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 5.3a9 9 0 0 0 0 13.4\"}}]})(props);\n};\nexport function TbBallVolleyball (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12a8 8 0 0 0 8 4m-12.5 -2.5a12 12 0 0 0 8.5 6.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12a8 8 0 0 0 8 4m-12.5 -2.5a12 12 0 0 0 8.5 6.5\",\"transform\":\"rotate(120 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12a8 8 0 0 0 8 4m-12.5 -2.5a12 12 0 0 0 8.5 6.5\",\"transform\":\"rotate(240 12 12)\"}}]})(props);\n};\nexport function TbBallonOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 8a2 2 0 0 0 -2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.762 3.753a6 6 0 0 1 10.238 4.247c0 1.847 -.37 3.564 -1.007 4.993m-1.59 2.42c-.967 1.001 -2.14 1.587 -3.403 1.587c-3.314 0 -6 -4.03 -6 -9c0 -.593 .086 -1.166 .246 -1.707\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17v1a2 2 0 0 1 -2 2h-3a2 2 0 0 0 -2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBallon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 8a2 2 0 0 0 -2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8a6 6 0 1 1 12 0c0 4.97 -2.686 9 -6 9s-6 -4.03 -6 -9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17v1a2 2 0 0 1 -2 2h-3a2 2 0 0 0 -2 2\"}}]})(props);\n};\nexport function TbBallpenOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 6l7 7l-2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10l-4.172 4.172a2.828 2.828 0 1 0 4 4l4.172 -4.172\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12l4.414 -4.414a2 2 0 0 0 0 -2.829l-1.171 -1.171a2 2 0 0 0 -2.829 0l-4.414 4.414\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20l1.768 -1.768\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBallpen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 6l7 7l-4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.828 18.172a2.828 2.828 0 0 0 4 0l10.586 -10.586a2 2 0 0 0 0 -2.829l-1.171 -1.171a2 2 0 0 0 -2.829 0l-10.586 10.586a2.828 2.828 0 0 0 0 4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20l1.768 -1.768\"}}]})(props);\n};\nexport function TbBan (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5.7\",\"y1\":\"5.7\",\"x2\":\"18.3\",\"y2\":\"18.3\"}}]})(props);\n};\nexport function TbBandage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"12\",\"x2\":\"14\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"12\",\"x2\":\"10\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"10\",\"x2\":\"12\",\"y2\":\"10.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"14\",\"x2\":\"12\",\"y2\":\"14.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 12.5l8 -8a4.94 4.94 0 0 1 7 7l-8 8a4.94 4.94 0 0 1 -7 -7\"}}]})(props);\n};\nexport function TbBarbellOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 12h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8h-2a1 1 0 0 0 -1 1v6a1 1 0 0 0 1 1h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.298 6.288a0.997 .997 0 0 0 -.298 .712v10a1 1 0 0 0 1 1h1a1 1 0 0 0 1 -1v-8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 15v2a1 1 0 0 0 1 1h1c.275 0 .523 -.11 .704 -.29m.296 -3.71v-7a1 1 0 0 0 -1 -1h-1a1 1 0 0 0 -1 1v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 8h2a1 1 0 0 1 1 1v6a1 1 0 0 1 -1 1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 12h-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBarbell (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 12h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8h-2a1 1 0 0 0 -1 1v6a1 1 0 0 0 1 1h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 7v10a1 1 0 0 0 1 1h1a1 1 0 0 0 1 -1v-10a1 1 0 0 0 -1 -1h-1a1 1 0 0 0 -1 1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 7v10a1 1 0 0 0 1 1h1a1 1 0 0 0 1 -1v-10a1 1 0 0 0 -1 -1h-1a1 1 0 0 0 -1 1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 8h2a1 1 0 0 1 1 1v6a1 1 0 0 1 -1 1h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 12h-1\"}}]})(props);\n};\nexport function TbBarcodeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 7v-1c0 -.552 .224 -1.052 .586 -1.414\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 17v1a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2a2 2 0 0 1 2 2v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h2c.551 0 1.05 -.223 1.412 -.584\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 11h1v2h-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 11v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 11v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 11v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBarcode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 7v-1a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 17v1a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2a2 2 0 0 1 2 2v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h2a2 2 0 0 0 2 -2v-1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"11\",\"width\":\"1\",\"height\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"11\",\"x2\":\"10\",\"y2\":\"13\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"14\",\"y\":\"11\",\"width\":\"1\",\"height\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"11\",\"x2\":\"19\",\"y2\":\"13\"}}]})(props);\n};\nexport function TbBarrelOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h8.722a2 2 0 0 1 1.841 1.22c.958 2.26 1.437 4.52 1.437 6.78a16.35 16.35 0 0 1 -.407 3.609m-.964 3.013l-.066 .158a2 2 0 0 1 -1.841 1.22h-9.444a2 2 0 0 1 -1.841 -1.22c-.958 -2.26 -1.437 -4.52 -1.437 -6.78c0 -2.21 .458 -4.42 1.374 -6.63\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4c.585 2.337 .913 4.674 .985 7.01m-.114 3.86a33.415 33.415 0 0 1 -.871 5.13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 4a34.42 34.42 0 0 0 -.366 1.632m-.506 3.501a32.126 32.126 0 0 0 -.128 2.867c0 2.667 .333 5.333 1 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 16h11.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.5 8h-7.5m-4 0h-3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBarrel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.278 4h9.444a2 2 0 0 1 1.841 1.22c.958 2.26 1.437 4.52 1.437 6.78c0 2.26 -.479 4.52 -1.437 6.78a2 2 0 0 1 -1.841 1.22h-9.444a2 2 0 0 1 -1.841 -1.22c-.958 -2.26 -1.437 -4.52 -1.437 -6.78c0 -2.26 .479 -4.52 1.437 -6.78a2 2 0 0 1 1.841 -1.22z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4c.667 2.667 1 5.333 1 8s-.333 5.333 -1 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 4c-.667 2.667 -1 5.333 -1 8s.333 5.333 1 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 16h15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.5 8h-15\"}}]})(props);\n};\nexport function TbBarrierBlockOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7h8a1 1 0 0 1 1 1v7c0 .27 -.107 .516 -.282 .696\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16h-11a1 1 0 0 1 -1 -1v-7a1 1 0 0 1 1 -1h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 16v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 16l4.244 -4.244\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.745 9.755l2.755 -2.755\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 16l1.249 -1.249\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.741 12.759l3.259 -3.259\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 13.5l4.752 -4.752\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 20h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 20h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 7v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBarrierBlock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"7\",\"width\":\"16\",\"height\":\"9\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 16v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 16l9 -9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 16l6.5 -6.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 13.5l6.5 -6.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 16v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 20h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 20h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 7v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7v-2\"}}]})(props);\n};\nexport function TbBaseline (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20h16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16v-8a4 4 0 1 1 8 0v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 10h8\"}}]})(props);\n};\nexport function TbBasketOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 10l1.359 -1.63\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.176 6.188l1.824 -2.188l5 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.77 18.757c-.358 .768 -1.027 1.262 -1.77 1.243h-10c-.966 .024 -1.807 -.817 -2 -2l-2 -8h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10h7l-1.397 5.587\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"15\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBasket (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"7 10 12 4 17 10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 10l-2 8a2 2.5 0 0 1 -2 2h-10a2 2.5 0 0 1 -2 -2l-2 -8z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"15\",\"r\":\"2\"}}]})(props);\n};\nexport function TbBathOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12h4a1 1 0 0 1 1 1v3c0 .311 -.036 .614 -.103 .904m-1.61 2.378a3.982 3.982 0 0 1 -2.287 .718h-10a4 4 0 0 1 -4 -4v-3a1 1 0 0 1 1 -1h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12v-6m1.178 -2.824c.252 -.113 .53 -.176 .822 -.176h3v2.25\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 21l1 -1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 21l-1 -1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBath (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h16a1 1 0 0 1 1 1v3a4 4 0 0 1 -4 4h-10a4 4 0 0 1 -4 -4v-3a1 1 0 0 1 1 -1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12v-7a2 2 0 0 1 2 -2h3v2.25\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 21l1 -1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 21l-1 -1.5\"}}]})(props);\n};\nexport function TbBattery1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 7h11a2 2 0 0 1 2 2v.5a0.5 .5 0 0 0 .5 .5a0.5 .5 0 0 1 .5 .5v3a0.5 .5 0 0 1 -.5 .5a0.5 .5 0 0 0 -.5 .5v.5a2 2 0 0 1 -2 2h-11a2 2 0 0 1 -2 -2v-6a2 2 0 0 1 2 -2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"10\",\"x2\":\"7\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbBattery2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 7h11a2 2 0 0 1 2 2v.5a0.5 .5 0 0 0 .5 .5a0.5 .5 0 0 1 .5 .5v3a0.5 .5 0 0 1 -.5 .5a0.5 .5 0 0 0 -.5 .5v.5a2 2 0 0 1 -2 2h-11a2 2 0 0 1 -2 -2v-6a2 2 0 0 1 2 -2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"10\",\"x2\":\"7\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"10\",\"x2\":\"10\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbBattery3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 7h11a2 2 0 0 1 2 2v.5a0.5 .5 0 0 0 .5 .5a0.5 .5 0 0 1 .5 .5v3a0.5 .5 0 0 1 -.5 .5a0.5 .5 0 0 0 -.5 .5v.5a2 2 0 0 1 -2 2h-11a2 2 0 0 1 -2 -2v-6a2 2 0 0 1 2 -2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"10\",\"x2\":\"7\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"10\",\"x2\":\"10\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"10\",\"x2\":\"13\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbBattery4 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 7h11a2 2 0 0 1 2 2v.5a0.5 .5 0 0 0 .5 .5a0.5 .5 0 0 1 .5 .5v3a0.5 .5 0 0 1 -.5 .5a0.5 .5 0 0 0 -.5 .5v.5a2 2 0 0 1 -2 2h-11a2 2 0 0 1 -2 -2v-6a2 2 0 0 1 2 -2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"10\",\"x2\":\"7\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"10\",\"x2\":\"10\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"10\",\"x2\":\"13\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"10\",\"x2\":\"16\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbBatteryAutomotive (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"6\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6v-2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"4\",\"x2\":\"19\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6.5\",\"y1\":\"13\",\"x2\":\"9.5\",\"y2\":\"13\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14.5\",\"y1\":\"13\",\"x2\":\"17.5\",\"y2\":\"13\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"11.5\",\"x2\":\"16\",\"y2\":\"14.5\"}}]})(props);\n};\nexport function TbBatteryCharging2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 9a2 2 0 0 1 2 -2h11a2 2 0 0 1 2 2v.5a0.5 .5 0 0 0 .5 .5a0.5 .5 0 0 1 .5 .5v3a0.5 .5 0 0 1 -.5 .5a0.5 .5 0 0 0 -.5 .5v.5a2 2 0 0 1 -2 2h-4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 15h6v2a2 2 0 0 1 -2 2h-2a2 2 0 0 1 -2 -2v-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 22v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 15v-2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15v-2.5\"}}]})(props);\n};\nexport function TbBatteryCharging (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 7h1a2 2 0 0 1 2 2v.5a0.5 .5 0 0 0 .5 .5a0.5 .5 0 0 1 .5 .5v3a0.5 .5 0 0 1 -.5 .5a0.5 .5 0 0 0 -.5 .5v.5a2 2 0 0 1 -2 2h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 7h-2a2 2 0 0 0 -2 2v6a2 2 0 0 0 2 2h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8l-2 4h3l-2 4\"}}]})(props);\n};\nexport function TbBatteryEco (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 9a2 2 0 0 1 2 -2h11a2 2 0 0 1 2 2v.5a0.5 .5 0 0 0 .5 .5a0.5 .5 0 0 1 .5 .5v3a0.5 .5 0 0 1 -.5 .5a0.5 .5 0 0 0 -.5 .5v.5a2 2 0 0 1 -2 2h-5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 16.143c0 -2.84 2.09 -5.143 4.667 -5.143h2.333v.857c0 2.84 -2.09 5.143 -4.667 5.143h-2.333v-.857z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 20v-3\"}}]})(props);\n};\nexport function TbBatteryOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7h6a2 2 0 0 1 2 2v.5a0.5 .5 0 0 0 .5 .5a0.5 .5 0 0 1 .5 .5v3a0.5 .5 0 0 1 -.5 .5a0.5 .5 0 0 0 -.5 .5v.5m-2 2h-11a2 2 0 0 1 -2 -2v-6a2 2 0 0 1 2 -2h1\"}}]})(props);\n};\nexport function TbBattery (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 7h11a2 2 0 0 1 2 2v.5a0.5 .5 0 0 0 .5 .5a0.5 .5 0 0 1 .5 .5v3a0.5 .5 0 0 1 -.5 .5a0.5 .5 0 0 0 -.5 .5v.5a2 2 0 0 1 -2 2h-11a2 2 0 0 1 -2 -2v-6a2 2 0 0 1 2 -2\"}}]})(props);\n};\nexport function TbBeachOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.071 15.102a7.502 7.502 0 0 0 -8.124 1.648\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.27 6.269l9.926 5.731a6 6 0 0 0 -10.32 -6.123\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.732 10c1.658 -2.87 2.225 -5.644 1.268 -6.196c-.957 -.552 -3.075 1.326 -4.732 4.196\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 9l-.739 1.279\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.794 12.82l-.794 1.376\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19.25a2.4 2.4 0 0 1 1 -.25a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 1.135 -.858\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBeach (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.553 16.75a7.5 7.5 0 0 0 -10.606 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 3.804a6 6 0 0 0 -8.196 2.196l10.392 6a6 6 0 0 0 -2.196 -8.196z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.732 10c1.658 -2.87 2.225 -5.644 1.268 -6.196c-.957 -.552 -3.075 1.326 -4.732 4.196\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 9l-3 5.196\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19.25a2.4 2.4 0 0 1 1 -.25a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 1 .25\"}}]})(props);\n};\nexport function TbBedOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7v11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 14h11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 14h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 18v-8a2 2 0 0 0 -2 -2h-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 11v3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"10\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBed (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7v11m0 -4h18m0 4v-8a2 2 0 0 0 -2 -2h-8v6\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"10\",\"r\":\"1\"}}]})(props);\n};\nexport function TbBeerOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7v1.111c0 1.242 .29 2.467 .845 3.578l.31 .622a8 8 0 0 1 .845 3.578v4.111h6v-4.111a8 8 0 0 1 .045 -.85m.953 -3.035l.157 -.315a7.999 7.999 0 0 0 .845 -3.578v-4.111h-9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 8h1m4 0h5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBeer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 20h6v-4.111a8 8 0 0 1 .845 -3.578l.31 -.622a8 8 0 0 0 .845 -3.578v-4.111h-10v4.111a8 8 0 0 0 .845 3.578l.31 .622a8 8 0 0 1 .845 3.578v4.111z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 8h10\"}}]})(props);\n};\nexport function TbBellMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5a2 2 0 1 1 4 0a7 7 0 0 1 4 6v3a4 4 0 0 0 2 3h-16a4 4 0 0 0 2 -3v-3a7 7 0 0 1 4 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17v1a3 3 0 0 0 6 0v-1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"11\",\"x2\":\"14\",\"y2\":\"11\"}}]})(props);\n};\nexport function TbBellOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17h-13a4 4 0 0 0 2 -3v-3a7 7 0 0 1 1.279 -3.716m2.072 -1.934c.209 -.127 .425 -.244 .649 -.35a2 2 0 1 1 4 0a7 7 0 0 1 4 6v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17v1a3 3 0 0 0 6 0v-1\"}}]})(props);\n};\nexport function TbBellPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5a2 2 0 1 1 4 0a7 7 0 0 1 4 6v3a4 4 0 0 0 2 3h-16a4 4 0 0 0 2 -3v-3a7 7 0 0 1 4 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17v1a3 3 0 0 0 6 0v-1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"11\",\"x2\":\"14\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"9\",\"x2\":\"12\",\"y2\":\"13\"}}]})(props);\n};\nexport function TbBellRinging2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.364 4.636a2 2 0 0 1 0 2.828a7 7 0 0 1 -1.414 7.072l-2.122 2.12a4 4 0 0 0 -.707 3.536l-11.313 -11.312a4 4 0 0 0 3.535 -.707l2.121 -2.123a7 7 0 0 1 7.072 -1.414a2 2 0 0 1 2.828 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.343 12.414l-.707 .707a3 3 0 0 0 4.243 4.243l.707 -.707\"}}]})(props);\n};\nexport function TbBellRinging (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5a2 2 0 0 1 4 0a7 7 0 0 1 4 6v3a4 4 0 0 0 2 3h-16a4 4 0 0 0 2 -3v-3a7 7 0 0 1 4 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17v1a3 3 0 0 0 6 0v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 6.727a11.05 11.05 0 0 0 -2.794 -3.727\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6.727a11.05 11.05 0 0 1 2.792 -3.727\"}}]})(props);\n};\nexport function TbBellSchool (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"10\",\"cy\":\"10\",\"r\":\"6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 15h.5a2 2 0 0 1 2 2v1a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2v-1a2 2 0 0 1 2 -2h.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 17a5.698 5.698 0 0 0 4.467 -7.932l-.467 -1.068\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10v.01\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"20\",\"cy\":\"8\",\"r\":\"1\"}}]})(props);\n};\nexport function TbBellX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5a2 2 0 1 1 4 0a7 7 0 0 1 4 6v3a4 4 0 0 0 2 3h-16a4 4 0 0 0 2 -3v-3a7 7 0 0 1 4 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17v1a3 3 0 0 0 6 0v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 9.5l3 3m0 -3l-3 3\"}}]})(props);\n};\nexport function TbBellZ (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5a2 2 0 1 1 4 0a7 7 0 0 1 4 6v3a4 4 0 0 0 2 3h-16a4 4 0 0 0 2 -3v-3a7 7 0 0 1 4 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17v1a3 3 0 0 0 6 0v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 9h4l-4 4h4\"}}]})(props);\n};\nexport function TbBell (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5a2 2 0 0 1 4 0a7 7 0 0 1 4 6v3a4 4 0 0 0 2 3h-16a4 4 0 0 0 2 -3v-3a7 7 0 0 1 4 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17v1a3 3 0 0 0 6 0v-1\"}}]})(props);\n};\nexport function TbBible (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 4v16h-12a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 2 -2h12z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 16h-12a2 2 0 0 0 -2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 9h4\"}}]})(props);\n};\nexport function TbBikeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"18\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.437 16.44a3 3 0 0 0 4.123 4.123m1.44 -2.563a3 3 0 0 0 -3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 19v-4l-3 -3l1.665 -1.332m2.215 -1.772l1.12 -.896l2 3h3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"5\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBike (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"18\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"18\",\"r\":\"3\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"12 19 12 15 9 12 14 8 16 11 19 11\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"5\",\"r\":\"1\"}}]})(props);\n};\nexport function TbBinary (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 10v-5h-1m8 14v-5h-1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"15\",\"y\":\"5\",\"width\":\"3\",\"height\":\"5\",\"rx\":\".5\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"10\",\"y\":\"14\",\"width\":\"3\",\"height\":\"5\",\"rx\":\".5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10h.01m-.01 9h.01\"}}]})(props);\n};\nexport function TbBiohazardOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.586 10.586a2 2 0 1 0 2.836 2.82\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.939 14c0 .173 .048 .351 .056 .533v.217a4.75 4.75 0 0 1 -4.533 4.745h-.217\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.495 14.745a4.75 4.75 0 0 1 7.737 -3.693\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.745 19.495a4.75 4.75 0 0 1 -4.69 -5.503h-.06\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.533 10.538a4.75 4.75 0 0 1 6.957 3.987v.217\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.295 10.929a4.75 4.75 0 0 1 -2.988 -3.64m.66 -3.324a4.75 4.75 0 0 1 .5 -.66l.164 -.172\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.349 3.133a4.75 4.75 0 0 1 -.836 7.385\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBiohazard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.939 14c0 .173 .048 .351 .056 .533l0 .217a4.75 4.75 0 0 1 -4.533 4.745l-.217 0m-4.75 -4.75a4.75 4.75 0 0 1 7.737 -3.693m6.513 8.443a4.75 4.75 0 0 1 -4.69 -5.503l-.06 0m1.764 -2.944a4.75 4.75 0 0 1 7.731 3.477l0 .217m-11.195 -3.813a4.75 4.75 0 0 1 -1.828 -7.624l.164 -.172m6.718 0a4.75 4.75 0 0 1 -1.665 7.798\"}}]})(props);\n};\nexport function TbBlockquote (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15h15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 19h-15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 11h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 7h-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 9h1a1 1 0 1 1 -1 1v-2.5a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 9h1a1 1 0 1 1 -1 1v-2.5a2 2 0 0 1 2 -2\"}}]})(props);\n};\nexport function TbBluetoothConnected (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"7 8 17 16 12 20 12 4 17 8 7 16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"5\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"12\",\"x2\":\"19\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbBluetoothOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.438 16.45l-4.438 3.55v-8m0 -4v-4l5 4l-2.776 2.22m-2.222 1.779l-5 4\"}}]})(props);\n};\nexport function TbBluetoothX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 8l10 8l-5 4v-16l1.003 .802m0 6.396l-6.003 4.802\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 6l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 6l-4 4\"}}]})(props);\n};\nexport function TbBluetooth (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"7 8 17 16 12 20 12 4 17 8 7 16\"}}]})(props);\n};\nexport function TbBlur (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21a9.01 9.01 0 0 0 2.32 -.302a9.004 9.004 0 0 0 1.74 -16.733a9 9 0 1 0 -4.06 17.035z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12h9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 15h8\"}}]})(props);\n};\nexport function TbBoldOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h4a3.5 3.5 0 0 1 2.222 6.204m-3.222 .796h-5v-5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.107 17.112a3.5 3.5 0 0 1 -3.107 1.888h-7v-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBold (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 5h6a3.5 3.5 0 0 1 0 7h-6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 12h1a3.5 3.5 0 0 1 0 7h-7v-7\"}}]})(props);\n};\nexport function TbBoltOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.212 15.21l-4.212 5.79v-7h-6l3.79 -5.21m1.685 -2.32l2.525 -3.47v6m1 1h5l-2.104 2.893\"}}]})(props);\n};\nexport function TbBolt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"13 3 13 10 19 10 11 21 11 14 5 14 13 3\"}}]})(props);\n};\nexport function TbBoneOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 8.502l.38 -.38a3 3 0 1 1 5.12 -2.122a3 3 0 1 1 -2.12 5.122l-.372 .372m-2.008 2.008l-2.378 2.378a3 3 0 1 1 -5.117 2.297l-.005 -.177l-.176 -.005a3 3 0 1 1 2.298 -5.115l2.378 -2.378\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3a3 3 0 0 1 3 3a3 3 0 1 1 -2.12 5.122l-4.758 4.758a3 3 0 1 1 -5.117 2.297l-.005 -.177l-.176 -.005a3 3 0 1 1 2.298 -5.115l4.758 -4.758a3 3 0 0 1 2.12 -5.122z\"}}]})(props);\n};\nexport function TbBook2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 4v16h-12a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 2 -2h12z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 16h-12a2 2 0 0 0 -2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 8h6\"}}]})(props);\n};\nexport function TbBookDownload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20h-6a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 2 -2h12v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 16h-7a2 2 0 0 0 -2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 19l3 3l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 22v-9\"}}]})(props);\n};\nexport function TbBookOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19a9 9 0 0 1 9 0a8.999 8.999 0 0 1 5.899 -1.096\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6a8.995 8.995 0 0 1 2.114 -.884m3.8 -.21c1.07 .17 2.116 .534 3.086 1.094a9 9 0 0 1 9 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6v13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6v2m0 4v7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 6v11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBookUpload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 20h-8a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 2 -2h12v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 16h-5a2 2 0 0 0 -2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 16l3 -3l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 13v9\"}}]})(props);\n};\nexport function TbBook (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19a9 9 0 0 1 9 0a9 9 0 0 1 9 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6a9 9 0 0 1 9 0a9 9 0 0 1 9 0\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"6\",\"x2\":\"3\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"6\",\"x2\":\"12\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"6\",\"x2\":\"21\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbBookmarkOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v3l-5 -3l-5 3v-13m1.178 -2.818c.252 -.113 .53 -.176 .822 -.176h6a2 2 0 0 1 2 2v7\"}}]})(props);\n};\nexport function TbBookmark (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4h6a2 2 0 0 1 2 2v14l-5 -3l-5 3v-14a2 2 0 0 1 2 -2\"}}]})(props);\n};\nexport function TbBookmarksOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7h2a2 2 0 0 1 2 2v2m0 4v6l-5 -3l-5 3v-12a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.265 4a2 2 0 0 1 1.735 -1h6a2 2 0 0 1 2 2v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBookmarks (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 7a2 2 0 0 1 2 2v12l-5 -3l-5 3v-12a2 2 0 0 1 2 -2h6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.265 4a2 2 0 0 1 1.735 -1h6a2 2 0 0 1 2 2v12l-1 -.6\"}}]})(props);\n};\nexport function TbBooksOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 9v10a1 1 0 0 1 -1 1h-2a1 1 0 0 1 -1 -1v-14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4a1 1 0 0 1 1 1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5a1 1 0 0 1 1 -1h2a1 1 0 0 1 1 1v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 13v6a1 1 0 0 1 -1 1h-2a1 1 0 0 1 -1 -1v-10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 8h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 16h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.254 10.244l-1.218 -4.424a1.02 1.02 0 0 1 .634 -1.219l.133 -.041l2.184 -.53c.562 -.135 1.133 .19 1.282 .732l3.236 11.75\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.585 19.589l-1.572 .38c-.562 .136 -1.133 -.19 -1.282 -.731l-.952 -3.458\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 9l4 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.207 15.199l.716 -.18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBooks (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"4\",\"width\":\"4\",\"height\":\"16\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"4\",\"width\":\"4\",\"height\":\"16\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 8h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 16h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.803 4.56l2.184 -.53c.562 -.135 1.133 .19 1.282 .732l3.695 13.418a1.02 1.02 0 0 1 -.634 1.219l-.133 .041l-2.184 .53c-.562 .135 -1.133 -.19 -1.282 -.732l-3.695 -13.418a1.02 1.02 0 0 1 .634 -1.219l.133 -.041z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 9l4 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16l3.923 -.98\"}}]})(props);\n};\nexport function TbBorderAll (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbBorderBottom (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"20\",\"x2\":\"4\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"4\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"4\",\"x2\":\"8\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"4\",\"x2\":\"16\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"8\",\"x2\":\"4\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"8\",\"x2\":\"20\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"4\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"12\",\"x2\":\"8\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"12\",\"x2\":\"16\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"16\",\"x2\":\"4\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"16\",\"x2\":\"12\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"16\",\"x2\":\"20\",\"y2\":\"16.01\"}}]})(props);\n};\nexport function TbBorderHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"4\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"4\",\"x2\":\"8\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"4\",\"x2\":\"16\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"8\",\"x2\":\"4\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"8\",\"x2\":\"20\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"16\",\"x2\":\"4\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"16\",\"x2\":\"12\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"16\",\"x2\":\"20\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"4\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"20\",\"x2\":\"8\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"20\",\"x2\":\"12\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"20\",\"x2\":\"16\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"20\",\"x2\":\"20\",\"y2\":\"20.01\"}}]})(props);\n};\nexport function TbBorderInner (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"4\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"4\",\"x2\":\"8\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"4\",\"x2\":\"16\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"8\",\"x2\":\"4\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"8\",\"x2\":\"20\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"16\",\"x2\":\"4\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"16\",\"x2\":\"20\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"4\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"20\",\"x2\":\"8\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"20\",\"x2\":\"16\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"20\",\"x2\":\"20\",\"y2\":\"20.01\"}}]})(props);\n};\nexport function TbBorderLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"4\",\"y2\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"4\",\"x2\":\"8\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"4\",\"x2\":\"16\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"8\",\"x2\":\"20\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"12\",\"x2\":\"8\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"12\",\"x2\":\"16\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"16\",\"x2\":\"12\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"16\",\"x2\":\"20\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"20\",\"x2\":\"8\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"20\",\"x2\":\"12\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"20\",\"x2\":\"16\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"20\",\"x2\":\"20\",\"y2\":\"20.01\"}}]})(props);\n};\nexport function TbBorderNone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"4\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"4\",\"x2\":\"8\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"4\",\"x2\":\"16\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"8\",\"x2\":\"4\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"8\",\"x2\":\"20\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"4\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"12\",\"x2\":\"8\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"12\",\"x2\":\"16\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"16\",\"x2\":\"4\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"16\",\"x2\":\"12\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"16\",\"x2\":\"20\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"4\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"20\",\"x2\":\"8\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"20\",\"x2\":\"12\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"20\",\"x2\":\"16\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"20\",\"x2\":\"20\",\"y2\":\"20.01\"}}]})(props);\n};\nexport function TbBorderOuter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"12\",\"x2\":\"8\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"12\",\"x2\":\"16\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"16\",\"x2\":\"12\",\"y2\":\"16.01\"}}]})(props);\n};\nexport function TbBorderRadius (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12v-4a4 4 0 0 1 4 -4h4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"4\",\"x2\":\"16\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"8\",\"x2\":\"20\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"16\",\"x2\":\"4\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"16\",\"x2\":\"20\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"4\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"20\",\"x2\":\"8\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"20\",\"x2\":\"12\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"20\",\"x2\":\"16\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"20\",\"x2\":\"20\",\"y2\":\"20.01\"}}]})(props);\n};\nexport function TbBorderRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"4\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"4\",\"x2\":\"8\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"4\",\"x2\":\"16\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"8\",\"x2\":\"4\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"4\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"12\",\"x2\":\"8\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"12\",\"x2\":\"16\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"16\",\"x2\":\"4\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"16\",\"x2\":\"12\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"4\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"20\",\"x2\":\"8\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"20\",\"x2\":\"12\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"20\",\"x2\":\"16\",\"y2\":\"20.01\"}}]})(props);\n};\nexport function TbBorderStyle2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 18v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 18v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 18v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 12h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 12h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6h16\"}}]})(props);\n};\nexport function TbBorderStyle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20v-14a2 2 0 0 1 2 -2h14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 8v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 16v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 20v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 20v.01\"}}]})(props);\n};\nexport function TbBorderTop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"8\",\"x2\":\"4\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"8\",\"x2\":\"20\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"4\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"12\",\"x2\":\"8\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"12\",\"x2\":\"16\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"16\",\"x2\":\"4\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"16\",\"x2\":\"12\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"16\",\"x2\":\"20\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"4\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"20\",\"x2\":\"8\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"20\",\"x2\":\"12\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"20\",\"x2\":\"16\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"20\",\"x2\":\"20\",\"y2\":\"20.01\"}}]})(props);\n};\nexport function TbBorderVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"4\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"4\",\"x2\":\"8\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"4\",\"x2\":\"16\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"8\",\"x2\":\"4\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"8\",\"x2\":\"20\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"4\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"12\",\"x2\":\"8\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"12\",\"x2\":\"16\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"16\",\"x2\":\"4\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"16\",\"x2\":\"20\",\"y2\":\"16.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"4\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"20\",\"x2\":\"8\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"20\",\"x2\":\"16\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"20\",\"x2\":\"20\",\"y2\":\"20.01\"}}]})(props);\n};\nexport function TbBottle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5h4v-2a1 1 0 0 0 -1 -1h-2a1 1 0 0 0 -1 1v2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3.5c0 1.626 .507 3.212 1.45 4.537l.05 .07a8.093 8.093 0 0 1 1.5 4.694v6.199a2 2 0 0 1 -2 2h-6a2 2 0 0 1 -2 -2v-6.2c0 -1.682 .524 -3.322 1.5 -4.693l.05 -.07a7.823 7.823 0 0 0 1.45 -4.537\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.003 14.803a2.4 2.4 0 0 0 .997 -.803a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 1 -.805\"}}]})(props);\n};\nexport function TbBow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 3h4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 3l-15 15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 18h3v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.5 20c1.576 -1.576 2.5 -4.095 2.5 -6.5c0 -4.81 -3.69 -8.5 -8.5 -8.5c-2.415 0 -4.922 .913 -6.5 2.5l12.5 12.5z\"}}]})(props);\n};\nexport function TbBoxMargin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8h8v8h-8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 4v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 20v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 20v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 16v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 8v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8v.01\"}}]})(props);\n};\nexport function TbBoxModel2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8h8v8h-8z\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbBoxModel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8h8v8h-8z\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16l3.3 3.3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8l3.3 -3.3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8l-3.3 -3.3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16l-3.3 3.3\"}}]})(props);\n};\nexport function TbBoxMultiple0 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 6a2 2 0 0 1 2 2v4a2 2 0 1 1 -4 0v-4a2 2 0 0 1 2 -2z\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"7\",\"y\":\"3\",\"width\":\"14\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v2a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h2\"}}]})(props);\n};\nexport function TbBoxMultiple1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"7\",\"y\":\"3\",\"width\":\"14\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v2a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14v-8l-2 2\"}}]})(props);\n};\nexport function TbBoxMultiple2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"7\",\"y\":\"3\",\"width\":\"14\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v2a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8a2 2 0 1 1 4 0c0 .591 -.417 1.318 -.816 1.858l-3.184 4.143l4 0\"}}]})(props);\n};\nexport function TbBoxMultiple3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"7\",\"y\":\"3\",\"width\":\"14\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v2a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10a2 2 0 1 0 -2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12a2 2 0 1 0 2 -2\"}}]})(props);\n};\nexport function TbBoxMultiple4 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"7\",\"y\":\"3\",\"width\":\"14\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v2a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 14v-8l-4 6h5\"}}]})(props);\n};\nexport function TbBoxMultiple5 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"7\",\"y\":\"3\",\"width\":\"14\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14h2a2 2 0 1 0 0 -4h-2v-4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v2a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h2\"}}]})(props);\n};\nexport function TbBoxMultiple6 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"7\",\"y\":\"3\",\"width\":\"14\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14\",\"cy\":\"12\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8a2 2 0 1 0 -4 0v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v2a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h2\"}}]})(props);\n};\nexport function TbBoxMultiple7 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"7\",\"y\":\"3\",\"width\":\"14\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6h4l-2 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v2a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h2\"}}]})(props);\n};\nexport function TbBoxMultiple8 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"7\",\"y\":\"3\",\"width\":\"14\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14\",\"cy\":\"8\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14\",\"cy\":\"12\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v2a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h2\"}}]})(props);\n};\nexport function TbBoxMultiple9 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"7\",\"y\":\"3\",\"width\":\"14\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14\",\"cy\":\"8\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12a2 2 0 1 0 4 0v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v2a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h2\"}}]})(props);\n};\nexport function TbBoxMultiple (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"7\",\"y\":\"3\",\"width\":\"14\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v2a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h2\"}}]})(props);\n};\nexport function TbBoxOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.765 17.757l-5.765 3.243l-8 -4.5v-9l2.236 -1.258m2.57 -1.445l3.194 -1.797l8 4.5v8.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.561 10.559l5.439 -3.059\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l-8 -4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBoxPadding (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 16v.01\"}}]})(props);\n};\nexport function TbBox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"12 3 20 7.5 20 16.5 12 21 4 16.5 4 7.5 12 3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"7.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"4\",\"y2\":\"7.5\"}}]})(props);\n};\nexport function TbBracesOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.176 5.177c-.113 .251 -.176 .53 -.176 .823v3c0 1.657 -.895 3 -2 3c1.105 0 2 1.343 2 3v3a2 2 0 0 0 2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4a2 2 0 0 1 2 2v3c0 1.657 .895 3 2 3c-1.105 0 -2 1.343 -2 3m-.176 3.821a2 2 0 0 1 -1.824 1.179\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBraces (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 4a2 2 0 0 0 -2 2v3a2 3 0 0 1 -2 3a2 3 0 0 1 2 3v3a2 2 0 0 0 2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4a2 2 0 0 1 2 2v3a2 3 0 0 0 2 3a2 3 0 0 0 -2 3v3a2 2 0 0 1 -2 2\"}}]})(props);\n};\nexport function TbBracketsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 5v15h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h3v11m0 4v1h-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBrackets (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h-3v16h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h3v16h-3\"}}]})(props);\n};\nexport function TbBrandAdobe (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.893 4.514l7.977 13.994a0.993 .993 0 0 1 -.394 1.365a1.04 1.04 0 0 1 -.5 .127h-3.476l-4.5 -8l-2.5 4h1.5l2 4h-8.977c-.565 0 -1.023 -.45 -1.023 -1.003c0 -.171 .045 -.34 .13 -.49l7.977 -13.993a1.034 1.034 0 0 1 1.786 0z\"}}]})(props);\n};\nexport function TbBrandAirbnb (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 10c-2 0 -3 1 -3 3c0 1.5 1.494 3.535 3 5.5c1 1 1.5 1.5 2.5 2s2.5 1 4.5 -.5s1.5 -3.5 .5 -6s-2.333 -5.5 -5 -9.5c-.834 -1 -1.5 -1.5 -2.503 -1.5c-1 0 -1.623 .45 -2.497 1.5c-2.667 4 -4 7 -5 9.5s-1.5 4.5 .5 6s3.5 1 4.5 .5s1.5 -1 2.5 -2c1.506 -1.965 3 -4 3 -5.5c0 -2 -1 -3 -3 -3z\"}}]})(props);\n};\nexport function TbBrandAirtable (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 10v8l7 -3v-2.6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6l9 3l9 -3l-9 -3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 12.3v8.7l7 -3v-8z\"}}]})(props);\n};\nexport function TbBrandAndroid (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"10\",\"x2\":\"4\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"10\",\"x2\":\"20\",\"y2\":\"16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 9h10v8a1 1 0 0 1 -1 1h-8a1 1 0 0 1 -1 -1v-8a5 5 0 0 1 10 0\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"3\",\"x2\":\"9\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"3\",\"x2\":\"15\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"18\",\"x2\":\"9\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"18\",\"x2\":\"15\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbBrandAngular (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.428 17.245l6.076 3.471a1 1 0 0 0 .992 0l6.076 -3.471a1 1 0 0 0 .495 -.734l1.323 -9.704a1 1 0 0 0 -.658 -1.078l-7.4 -2.612a1 1 0 0 0 -.665 0l-7.399 2.613a1 1 0 0 0 -.658 1.078l1.323 9.704a1 1 0 0 0 .495 .734z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 15l3 -8l3 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 13h4\"}}]})(props);\n};\nexport function TbBrandAppleArcade (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12.5v4.75a0.734 .734 0 0 1 -.055 .325a0.704 .704 0 0 1 -.348 .366l-5.462 2.58a4.998 4.998 0 0 1 -4.27 0l-5.462 -2.58a0.705 .705 0 0 1 -.401 -.691l-.002 -4.75\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.431 12.216l5.634 -2.332a5.065 5.065 0 0 1 3.87 0l5.634 2.332a0.692 .692 0 0 1 .028 1.269l-5.462 2.543a5.064 5.064 0 0 1 -4.27 0l-5.462 -2.543a0.691 .691 0 0 1 .028 -1.27z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"7\",\"x2\":\"12\",\"y2\":\"13\"}}]})(props);\n};\nexport function TbBrandApple (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 7c-3 0 -4 3 -4 5.5c0 3 2 7.5 4 7.5c1.088 -.046 1.679 -.5 3 -.5c1.312 0 1.5 .5 3 .5s4 -3 4 -5c-.028 -.01 -2.472 -.403 -2.5 -3c-.019 -2.17 2.416 -2.954 2.5 -3c-1.023 -1.492 -2.951 -1.963 -3.5 -2c-1.433 -.111 -2.83 1 -3.5 1c-.68 0 -1.9 -1 -3 -1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4a2 2 0 0 0 2 -2a2 2 0 0 0 -2 2\"}}]})(props);\n};\nexport function TbBrandAppstore (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16l1.106 -1.99m1.4 -2.522l2.494 -4.488\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 14h5m2.9 0h2.1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16l-2.51 -4.518m-1.487 -2.677l-1.003 -1.805\"}}]})(props);\n};\nexport function TbBrandAsana (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"7\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"16\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"16\",\"r\":\"3\"}}]})(props);\n};\nexport function TbBrandBehance (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 18v-12h4.5a3 3 0 0 1 0 6a3 3 0 0 1 0 6h-4.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"12\",\"x2\":\"7.5\",\"y2\":\"12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 13h7a3.5 3.5 0 0 0 -7 0v2a3.5 3.5 0 0 0 6.64 1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"6\",\"x2\":\"19\",\"y2\":\"6\"}}]})(props);\n};\nexport function TbBrandBing (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 3l4 1.5v12l6 -2.5l-2 -1l-1 -4l7 2.5v4.5l-10 5l-4 -2z\"}}]})(props);\n};\nexport function TbBrandBitbucket (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.648 4a0.64 .64 0 0 0 -.64 .744l3.14 14.528c.07 .417 .43 .724 .852 .728h10a0.644 .644 0 0 0 .642 -.539l3.35 -14.71a0.641 .641 0 0 0 -.64 -.744l-16.704 -.007z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 15h-4l-1 -6h6z\"}}]})(props);\n};\nexport function TbBrandBooking (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18v-9.5a4.5 4.5 0 0 1 4.5 -4.5h7a4.5 4.5 0 0 1 4.5 4.5v7a4.5 4.5 0 0 1 -4.5 4.5h-9.5a2 2 0 0 1 -2 -2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12h3.5a2 2 0 1 1 0 4h-3.5v-7a1 1 0 0 1 1 -1h1.5a2 2 0 1 1 0 4h-1.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"16\",\"x2\":\"16.01\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbBrandBootstrap (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 12a2 2 0 0 0 2 -2v-4a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v4a2 2 0 0 0 2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 12a2 2 0 0 1 2 2v4a2 2 0 0 0 2 2h12a2 2 0 0 0 2 -2v-4a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 16v-8h3.5a2 2 0 1 1 0 4h-3.5h4a2 2 0 1 1 0 4h-4z\"}}]})(props);\n};\nexport function TbBrandChrome (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"9\",\"x2\":\"20.4\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"9\",\"x2\":\"20.4\",\"y2\":\"9\",\"transform\":\"rotate(120 12 12)\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"9\",\"x2\":\"20.4\",\"y2\":\"9\",\"transform\":\"rotate(240 12 12)\"}}]})(props);\n};\nexport function TbBrandCodepen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 15l9 6l9 -6l-9 -6l-9 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 9l9 6l9 -6l-9 -6l-9 6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"9\",\"x2\":\"3\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"9\",\"x2\":\"21\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"15\",\"x2\":\"12\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbBrandCodesandbox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 7.5v9l-4 2.25l-4 2.25l-4 -2.25l-4 -2.25v-9l4 -2.25l4 -2.25l4 2.25z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l4 -2.25l4 -2.25\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l-4 -2.25l-4 -2.25\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12l-4 2v4.75\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12l4 2l0 4.75\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 5.25l4 2.25l4 -2.25\"}}]})(props);\n};\nexport function TbBrandCss3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 4l-2 14.5l-6 2l-6 -2l-2 -14.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 8h7l-4.5 4h4l-.5 3.5l-2.5 .75l-2.5 -.75l-.1 -.5\"}}]})(props);\n};\nexport function TbBrandCucumber (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 10.99c-.01 5.52 -4.48 10 -10 10.01v-2.26l-.01 -.01c-4.28 -1.11 -6.86 -5.47 -5.76 -9.75a8.001 8.001 0 0 1 9.74 -5.76c3.53 .91 6.03 4.13 6.03 7.78v-.01z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 8l-.5 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 14l.5 1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12.5l-1 .5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 14l-.5 1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 8l.5 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12.5l-1 -.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 10l-1 -.5\"}}]})(props);\n};\nexport function TbBrandDebian (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17c-2.397 -.943 -4 -3.153 -4 -5.635c0 -2.19 1.039 -3.14 1.604 -3.595c2.646 -2.133 6.396 -.27 6.396 3.23c0 2.5 -2.905 2.121 -3.5 1.5c-.595 -.621 -1 -1.5 -.5 -2.5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbBrandDeviantart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 3v4l-3.857 6h3.857v4h-6.429l-2.571 4h-3v-4l3.857 -6h-3.857v-4h6.429l2.571 -4z\"}}]})(props);\n};\nexport function TbBrandDiscord (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 7.5c3.5 -1 5.5 -1 9 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 16.5c3.5 1 6.5 1 10 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.5 17c0 1 1.5 3 2 3c1.5 0 2.833 -1.667 3.5 -3c.667 -1.667 .5 -5.833 -1.5 -11.5c-1.457 -1.015 -3 -1.34 -4.5 -1.5l-1 2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 17c0 1 -1.356 3 -1.832 3c-1.429 0 -2.698 -1.667 -3.333 -3c-.635 -1.667 -.476 -5.833 1.428 -11.5c1.388 -1.015 2.782 -1.34 4.237 -1.5l1 2.5\"}}]})(props);\n};\nexport function TbBrandDisqus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.847 21c-2.259 0 -4.323 -.667 -5.919 -2h-3.928l1.708 -3.266c-.545 -1.174 -.759 -2.446 -.758 -3.734c0 -4.97 3.84 -9 8.898 -9c5.052 0 9.152 4.03 9.152 9c0 4.972 -4.098 9 -9.153 9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.485 15h-1.485v-6h1.485c2.112 0 3.515 .823 3.515 2.981v.035c0 2.18 -1.403 2.984 -3.515 2.984z\"}}]})(props);\n};\nexport function TbBrandDocker (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 12.54c-1.804 -.345 -2.701 -1.08 -3.523 -2.94c-.487 .696 -1.102 1.568 -.92 2.4c.028 .238 -.32 1.002 -.557 1h-14c0 5.208 3.164 7 6.196 7c4.124 .022 7.828 -1.376 9.854 -5c1.146 -.101 2.296 -1.505 2.95 -2.46z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 10h3v3h-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 10h3v3h-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 10h3v3h-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 7h3v3h-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7h3v3h-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 4h3v3h-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.571 18c1.5 0 2.047 -.074 2.958 -.78\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"16\",\"x2\":\"10\",\"y2\":\"16.01\"}}]})(props);\n};\nexport function TbBrandDoctrine (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"14\",\"r\":\"7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 14h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 11l3 3l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 3l6.9 6\"}}]})(props);\n};\nexport function TbBrandDribbble (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 3.6c5 6 7 10.5 7.5 16.2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.4 19c3.5 -3.5 6 -6.5 14.5 -6.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.1 10.75c5 0 9.814 -.38 15.314 -5\"}}]})(props);\n};\nexport function TbBrandEdge (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.978 11.372a9 9 0 1 0 -1.593 5.773\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.978 11.372c.21 2.993 -5.034 2.413 -6.913 1.486c1.392 -1.6 .402 -4.038 -2.274 -3.851c-1.745 .122 -2.927 1.157 -2.784 3.202c.28 3.99 4.444 6.205 10.36 4.79\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.022 12.628c-.283 -4.043 8.717 -7.228 11.248 -2.688\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.628 20.978c-2.993 .21 -5.162 -4.725 -3.567 -9.748\"}}]})(props);\n};\nexport function TbBrandFacebook (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 10v4h3v7h4v-7h3l1 -4h-4v-2a1 1 0 0 1 1 -1h3v-4h-3a5 5 0 0 0 -5 5v2h-3\"}}]})(props);\n};\nexport function TbBrandFigma (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"6\",\"y\":\"3\",\"width\":\"12\",\"height\":\"6\",\"rx\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 9a3 3 0 0 0 0 6h3m-3 0a3 3 0 1 0 3 3v-15\"}}]})(props);\n};\nexport function TbBrandFirebase (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.53 17.05l6.15 -11.72h-.02c.38 -.74 1.28 -1.02 2.01 -.63c.26 .14 .48 .36 .62 .62l1.06 2.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.47 6.45c.58 -.59 1.53 -.59 2.11 -.01c.22 .22 .36 .5 .41 .81l1.5 9.11c.1 .62 -.2 1.24 -.76 1.54l-6.07 2.9c-.46 .25 -1.01 .26 -1.46 0l-6.02 -2.92c-.55 -.31 -.85 -.92 -.75 -1.54l1.96 -12.04c.12 -.82 .89 -1.38 1.7 -1.25c.46 .07 .87 .36 1.09 .77l1.24 1.76\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.57 17.18l10.93 -10.68\"}}]})(props);\n};\nexport function TbBrandFirefox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.028 7.82a9 9 0 1 0 12.823 -3.4c-1.636 -1.02 -3.064 -1.02 -4.851 -1.02h-1.647\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.914 9.485c-1.756 -1.569 -.805 -5.38 .109 -6.17c.086 .896 .585 1.208 1.111 1.685c.88 -.275 1.313 -.282 1.867 0c.82 -.91 1.694 -2.354 2.628 -2.093c-1.082 1.741 -.07 3.733 1.371 4.173c-.17 .975 -1.484 1.913 -2.76 2.686c-1.296 .938 -.722 1.85 0 2.234c.949 .506 3.611 -.995 4.545 .354c-1.698 .102 -1.536 3.107 -3.983 2.727c2.523 .957 4.345 .462 5.458 -.34c1.965 -1.52 2.879 -3.542 2.879 -5.557c-.014 -1.398 .194 -2.695 -1.26 -4.75\"}}]})(props);\n};\nexport function TbBrandFlickr (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"12\",\"r\":\"3\"}}]})(props);\n};\nexport function TbBrandFoursquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 3h10c.644 0 1.11 .696 .978 1.33l-1.984 9.859a1.014 1.014 0 0 1 -.994 .811h-2.254c-.308 0 -.6 .141 -.793 .382l-4.144 5.25c-.599 .752 -1.809 .331 -1.809 -.632v-16c0 -.564 .44 -1 1 -1z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"9\",\"x2\":\"17\",\"y2\":\"9\"}}]})(props);\n};\nexport function TbBrandFramer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15h12l-12 -12h12v6h-12v6l6 6v-6\"}}]})(props);\n};\nexport function TbBrandGit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"8\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"16\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 15v-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 11l-2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7l-1.9 -1.9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 20.4l-6.9 -6.9c-.781 -.781 -.781 -2.219 0 -3l6.9 -6.9c.781 -.781 2.219 -.781 3 0l6.9 6.9c.781 .781 .781 2.219 0 3l-6.9 6.9c-.781 .781 -2.219 .781 -3 0z\"}}]})(props);\n};\nexport function TbBrandGithub (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 19c-4.3 1.4 -4.3 -2.5 -6 -3m12 5v-3.5c0 -1 .1 -1.4 -.5 -2c2.8 -.3 5.5 -1.4 5.5 -6a4.6 4.6 0 0 0 -1.3 -3.2a4.2 4.2 0 0 0 -.1 -3.2s-1.1 -.3 -3.5 1.3a12.3 12.3 0 0 0 -6.2 0c-2.4 -1.6 -3.5 -1.3 -3.5 -1.3a4.2 4.2 0 0 0 -.1 3.2a4.6 4.6 0 0 0 -1.3 3.2c0 4.6 2.7 5.7 5.5 6c-.6 .6 -.6 1.2 -.5 2v3.5\"}}]})(props);\n};\nexport function TbBrandGitlab (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 14l-9 7l-9 -7l3 -11l3 7h6l3 -7z\"}}]})(props);\n};\nexport function TbBrandGmail (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h3a1 1 0 0 0 1 -1v-14a1 1 0 0 0 -1 -1h-3v16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 20h3v-16h-3a1 1 0 0 0 -1 1v14a1 1 0 0 0 1 1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4l-4 4l-4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6.5l8 7.5l8 -7.5\"}}]})(props);\n};\nexport function TbBrandGoogleAnalytics (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"10\",\"y\":\"9\",\"width\":\"4\",\"height\":\"12\",\"rx\":\"1.105\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"17\",\"y\":\"3\",\"width\":\"4\",\"height\":\"18\",\"rx\":\"1.105\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"19\",\"r\":\"2\"}}]})(props);\n};\nexport function TbBrandGoogleDrive (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 10l-6 10l-3 -5l6 -10z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 15h12l-3 5h-12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 15l-6 -10h6l6 10z\"}}]})(props);\n};\nexport function TbBrandGooglePlay (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 3.71v16.58a0.7 .7 0 0 0 1.05 .606l14.622 -8.42a0.55 .55 0 0 0 0 -.953l-14.622 -8.419a0.7 .7 0 0 0 -1.05 .607z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"9\",\"x2\":\"4.5\",\"y2\":\"20.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4.5\",\"y1\":\"3.5\",\"x2\":\"15\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbBrandGoogle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.788 5.108a9 9 0 1 0 3.212 6.892h-8\"}}]})(props);\n};\nexport function TbBrandGravatar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.64 5.632a9 9 0 1 0 6.36 -2.632v7.714\"}}]})(props);\n};\nexport function TbBrandHipchat (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.802 17.292s.077 -.055 .2 -.149c1.843 -1.425 2.998 -3.49 2.998 -5.789c0 -4.286 -4.03 -7.764 -8.998 -7.764c-4.97 0 -9.002 3.478 -9.002 7.764c0 4.288 4.03 7.646 9 7.646c.424 0 1.12 -.028 2.088 -.084c1.262 .82 3.104 1.493 4.716 1.493c.499 0 .734 -.41 .414 -.828c-.486 -.596 -1.156 -1.551 -1.416 -2.29z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 13.5c2.5 2.5 6.5 2.5 9 0\"}}]})(props);\n};\nexport function TbBrandHtml5 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 4l-2 14.5l-6 2l-6 -2l-2 -14.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.5 8h-7l.5 4h6l-.5 3.5l-2.5 .75l-2.5 -.75l-.1 -.5\"}}]})(props);\n};\nexport function TbBrandInstagram (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16.5\",\"y1\":\"7.5\",\"x2\":\"16.5\",\"y2\":\"7.501\"}}]})(props);\n};\nexport function TbBrandIntercom (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 8v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 7v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 7v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 8v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 15c4 2.667 6 2.667 10 0\"}}]})(props);\n};\nexport function TbBrandJavascript (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 4l-2 14.5l-6 2l-6 -2l-2 -14.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 8h3v8l-2 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.5 8h-2.5a0.5 .5 0 0 0 -.5 .5v3a0.5 .5 0 0 0 .5 .5h1.423a0.5 .5 0 0 1 .495 .57l-.418 2.93l-2 .5\"}}]})(props);\n};\nexport function TbBrandKickstarter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 9l2.975 -4.65c.615 -.9 1.405 -1.35 2.377 -1.35c.79 0 1.474 .286 2.054 .858c.576 .574 .866 1.256 .866 2.054c0 .588 -.153 1.109 -.46 1.559l-2.812 4.029l3.465 4.912c.356 .46 .535 .998 .535 1.613a2.92 2.92 0 0 1 -.843 2.098c-.561 .584 -1.242 .877 -2.04 .877c-.876 0 -1.545 -.29 -2.005 -.87l-4.112 -5.697v3.067c0 .876 -.313 1.69 -.611 2.175c-.543 .883 -1.35 1.325 -2.389 1.325c-.944 0 -1.753 -.327 -2.271 -.974c-.486 -.6 -.729 -1.392 -.729 -2.38v-11.371c0 -.934 .247 -1.706 .74 -2.313c.512 -.641 1.347 -.962 2.26 -.962c.868 0 1.821 .321 2.4 .962c.323 .356 .515 .714 .6 1.08c.052 .224 0 .643 0 1.26v2.698z\"}}]})(props);\n};\nexport function TbBrandKotlin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 20h-16v-16h16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"20\",\"y2\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12l8 -8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbBrandLastfm (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 8c-.83 -1 -1.388 -1 -2 -1c-.612 0 -2 .271 -2 2s1.384 2.233 3 3c1.616 .767 2.125 1.812 2 3s-1 2 -3 2s-3 -1 -3.5 -2s-1.585 -4.78 -2.497 -5.997a5 5 0 1 0 -1.003 6.997\"}}]})(props);\n};\nexport function TbBrandLinkedin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"11\",\"x2\":\"8\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"8\",\"x2\":\"8\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"16\",\"x2\":\"12\",\"y2\":\"11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16v-3a2 2 0 0 0 -4 0\"}}]})(props);\n};\nexport function TbBrandLoom (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.464 6.518a6.001 6.001 0 1 0 -3.023 7.965\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.482 17.464a6.001 6.001 0 1 0 -7.965 -3.023\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.54 17.482a6.001 6.001 0 1 0 3.024 -7.965\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.518 6.54a6.001 6.001 0 1 0 7.965 3.024\"}}]})(props);\n};\nexport function TbBrandMastercard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9.765a3 3 0 1 0 0 4.47\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"5\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbBrandMedium (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 9h1l3 3l3 -3h1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"15\",\"x2\":\"10\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"15\",\"x2\":\"16\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"9\",\"x2\":\"9\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"9\",\"x2\":\"15\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbBrandMercedes (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l7 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l-7 5\"}}]})(props);\n};\nexport function TbBrandMessenger (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 20l1.3 -3.9a9 8 0 1 1 3.4 2.9l-4.7 1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13l3 -2l2 2l3 -2\"}}]})(props);\n};\nexport function TbBrandMeta (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 10.174c1.766 -2.784 3.315 -4.174 4.648 -4.174c2 0 3.263 2.213 4 5.217c.704 2.869 .5 6.783 -2 6.783c-1.114 0 -2.648 -1.565 -4.148 -3.652a27.627 27.627 0 0 1 -2.5 -4.174z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 10.174c-1.766 -2.784 -3.315 -4.174 -4.648 -4.174c-2 0 -3.263 2.213 -4 5.217c-.704 2.869 -.5 6.783 2 6.783c1.114 0 2.648 -1.565 4.148 -3.652c1 -1.391 1.833 -2.783 2.5 -4.174z\"}}]})(props);\n};\nexport function TbBrandNetbeans (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 6.873a2 2 0 0 1 1 1.747v6.536a2 2 0 0 1 -1.029 1.748l-6 3.833a2 2 0 0 1 -1.942 0l-6 -3.833a2 2 0 0 1 -1.029 -1.747v-6.537a2 2 0 0 1 1.029 -1.748l6 -3.572a2.056 2.056 0 0 1 2 0l6 3.573h-.029z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.5 9.43a1 1 0 0 1 .5 .874v3.268a1 1 0 0 1 -.515 .874l-3 1.917a1 1 0 0 1 -.97 0l-3 -1.917a1 1 0 0 1 -.515 -.873v-3.269a1 1 0 0 1 .514 -.874l3 -1.786c.311 -.173 .69 -.173 1 0l3 1.787h-.014z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-9l-7.5 -4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l7.5 -4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.5 16l-3.5 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 14l-3.5 2\"}}]})(props);\n};\nexport function TbBrandNetflix (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 20v-16l7 16v-16\"}}]})(props);\n};\nexport function TbBrandNextjs (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 15v-6l7.745 10.65a9 9 0 1 1 2.255 -1.993\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 12v-3\"}}]})(props);\n};\nexport function TbBrandNotion (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7h3l6 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 7v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 17h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 7h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 7v10h-1l-7 -7\"}}]})(props);\n};\nexport function TbBrandNuxt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.146 8.583l-1.3 -2.09a1.046 1.046 0 0 0 -1.786 .017l-5.91 9.908a1.046 1.046 0 0 0 .897 1.582h3.913\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.043 18c.743 0 1.201 -.843 .82 -1.505l-4.044 -7.013a0.936 .936 0 0 0 -1.638 0l-4.043 7.013c-.382 .662 .076 1.505 .819 1.505h8.086z\"}}]})(props);\n};\nexport function TbBrandNytimes (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.036 5.058a8.001 8.001 0 1 0 8.706 9.965\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-11l-7.5 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.5 3a2.5 2.5 0 1 1 0 5l-11 -5a2.5 2.5 0 0 0 -.67 4.91\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 13h-.01\"}}]})(props);\n};\nexport function TbBrandOpenSource (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3a9 9 0 0 1 3.618 17.243l-2.193 -5.602a3 3 0 1 0 -2.849 0l-2.193 5.603a9 9 0 0 1 3.617 -17.244z\"}}]})(props);\n};\nexport function TbBrandOpera (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"ellipse\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"rx\":\"3\",\"ry\":\"5\"}}]})(props);\n};\nexport function TbBrandPagekit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.077 20h-5.077v-16h11v14h-5.077\"}}]})(props);\n};\nexport function TbBrandPatreon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3h3v18h-3z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"9.5\",\"r\":\"6.5\"}}]})(props);\n};\nexport function TbBrandPaypal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 13l2.5 0c2.5 0 5 -2.5 5 -5c0 -3 -1.9 -5 -5 -5h-5.5c-.5 0 -1 .5 -1 1l-2 14c0 .5 .5 1 1 1h2.8l1.2 -5c.1 -.6 .4 -1 1 -1zm7.5 -5.8c1.7 1 2.5 2.8 2.5 4.8c0 2.5 -2.5 4.5 -5 4.5h-2.6l-.6 3.6a1 1 0 0 1 -1 .8l-2.7 0a0.5 .5 0 0 1 -.5 -.6l.2 -1.4\"}}]})(props);\n};\nexport function TbBrandPhp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"ellipse\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"rx\":\"10\",\"ry\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 15l.395 -1.974l.605 -3.026h1.32a1 1 0 0 1 .986 1.164l-.167 1a1 1 0 0 1 -.986 .836h-1.653\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.5 15l.395 -1.974l.605 -3.026h1.32a1 1 0 0 1 .986 1.164l-.167 1a1 1 0 0 1 -.986 .836h-1.653\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7.5l-1 5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.6 10h2.4l-.5 3\"}}]})(props);\n};\nexport function TbBrandPinterest (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"20\",\"x2\":\"12\",\"y2\":\"11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.7 14c.437 1.263 1.43 2 2.55 2c2.071 0 3.75 -1.554 3.75 -4a5 5 0 1 0 -9.7 1.7\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbBrandPocket (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h14a2 2 0 0 1 2 2v6a9 9 0 0 1 -18 0v-6a2 2 0 0 1 2 -2\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"8 11 12 15 16 11\"}}]})(props);\n};\nexport function TbBrandProducthunt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 16v-8h2.5a2.5 2.5 0 1 1 0 5h-2.5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbBrandPython (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9h-7a2 2 0 0 0 -2 2v4a2 2 0 0 0 2 2h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 15h7a2 2 0 0 0 2 -2v-4a2 2 0 0 0 -2 -2h-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 9v-4a2 2 0 0 1 2 -2h4a2 2 0 0 1 2 2v5a2 2 0 0 1 -2 2h-4a2 2 0 0 0 -2 2v5a2 2 0 0 0 2 2h4a2 2 0 0 0 2 -2v-4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"6\",\"x2\":\"11\",\"y2\":\"6.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"18\",\"x2\":\"13\",\"y2\":\"18.01\"}}]})(props);\n};\nexport function TbBrandReactNative (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.357 9c-2.637 .68 -4.357 1.845 -4.357 3.175c0 2.107 4.405 3.825 9.85 3.825c.74 0 1.26 -.039 1.95 -.097\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.837 15.9c-.413 -.596 -.806 -1.133 -1.18 -1.8c-2.751 -4.9 -3.488 -9.77 -1.63 -10.873c1.15 -.697 3.047 .253 4.974 2.254\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.429 15.387c-.702 2.688 -.56 4.716 .56 5.395c1.783 1.08 5.387 -1.958 8.043 -6.804c.36 -.67 .683 -1.329 .968 -1.978\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18.52c1.928 2 3.817 2.95 4.978 2.253c1.85 -1.102 1.121 -5.972 -1.633 -10.873c-.384 -.677 -.777 -1.204 -1.18 -1.8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.66 15c2.612 -.687 4.34 -1.85 4.34 -3.176c0 -2.11 -4.408 -3.824 -9.845 -3.824c-.747 0 -1.266 .029 -1.955 .087\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12c.285 -.66 .607 -1.308 .968 -1.978c2.647 -4.844 6.253 -7.89 8.046 -6.801c1.11 .679 1.262 2.706 .56 5.393\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.26 12.015h-.01c-.01 .13 -.12 .24 -.26 .24a0.263 .263 0 0 1 -.25 -.26c0 -.14 .11 -.25 .24 -.25h-.01c.13 -.01 .25 .11 .25 .24\"}}]})(props);\n};\nexport function TbBrandReddit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8c2.648 0 5.028 .826 6.675 2.14a2.5 2.5 0 0 1 2.326 4.36c0 3.59 -4.03 6.5 -9 6.5c-4.875 0 -8.845 -2.8 -9 -6.294l-1 -.206a2.5 2.5 0 0 1 2.326 -4.36c1.646 -1.313 4.026 -2.14 6.674 -2.14z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8l1 -5l6 1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"4\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"13\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"13\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 17c.667 .333 1.333 .5 2 .5s1.333 -.167 2 -.5\"}}]})(props);\n};\nexport function TbBrandSafari (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"8 16 10 10 16 8 14 14 8 16\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbBrandSass (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 10.523c2.46 -.826 4.002 -.826 4.002 -2.155c0 -1.366 -1.347 -1.366 -2.735 -1.366c-1.91 0 -3.352 .49 -4.537 1.748c-.848 .902 -1.027 2.449 -.153 3.307c.973 .956 3.206 1.789 2.884 3.493c-.233 1.235 -1.469 1.823 -2.617 1.202c-.782 -.424 -.454 -1.746 .626 -2.512s2.822 -.992 4.1 -.24c.98 .575 1.046 1.724 .434 2.193\"}}]})(props);\n};\nexport function TbBrandSentry (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 18a1.93 1.93 0 0 0 .306 1.076a2 2 0 0 0 1.584 .924c.646 .033 -.537 0 .11 0h3a4.992 4.992 0 0 0 -3.66 -4.81c.558 -.973 1.24 -2.149 2.04 -3.531a8.997 8.997 0 0 1 5.62 8.341h4c.663 0 2.337 .005 3 0a2 2 0 0 0 1.84 -2.75l-7.1 -12.25a2 2 0 0 0 -3.5 0l-1.84 3.176c4.482 2.05 7.6 6.571 7.6 11.824\"}}]})(props);\n};\nexport function TbBrandShazam (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12l2 -2a2.828 2.828 0 0 1 4 0a2.828 2.828 0 0 1 0 4l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 12l-2 2a2.828 2.828 0 1 1 -4 -4l3 -3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbBrandSketch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.262 10.878l8 8.789c.4 .44 1.091 .44 1.491 0l8 -8.79c.313 -.344 .349 -.859 .087 -1.243l-3.537 -5.194a1 1 0 0 0 -.823 -.436h-8.926a1 1 0 0 0 -.823 .436l-3.54 5.192c-.263 .385 -.227 .901 .087 1.246z\"}}]})(props);\n};\nexport function TbBrandSkype (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3a9 9 0 0 1 8.603 11.65a4.5 4.5 0 0 1 -5.953 5.953a9 9 0 0 1 -11.253 -11.253a4.5 4.5 0 0 1 5.953 -5.954a8.987 8.987 0 0 1 2.65 -.396z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 14.5c.5 2 2.358 2.5 4 2.5c2.905 0 4 -1.187 4 -2.5c0 -1.503 -1.927 -2.5 -4 -2.5s-4 -.997 -4 -2.5c0 -1.313 1.095 -2.5 4 -2.5c1.642 0 3.5 .5 4 2.5\"}}]})(props);\n};\nexport function TbBrandSlack (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v-6a2 2 0 0 1 4 0v6m0 -2a2 2 0 1 1 2 2h-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12h6a2 2 0 0 1 0 4h-6m2 0a2 2 0 1 1 -2 2v-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v6a2 2 0 0 1 -4 0v-6m0 2a2 2 0 1 1 -2 -2h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12h-6a2 2 0 0 1 0 -4h6m-2 0a2 2 0 1 1 2 -2v6\"}}]})(props);\n};\nexport function TbBrandSnapchat (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.882 7.842a4.882 4.882 0 0 0 -9.764 0c0 4.273 -.213 6.409 -4.118 8.118c2 .882 2 .882 3 3c3 0 4 2 6 2s3 -2 6 -2c1 -2.118 1 -2.118 3 -3c-3.906 -1.709 -4.118 -3.845 -4.118 -8.118zm-13.882 8.119c4 -2.118 4 -4.118 1 -7.118m17 7.118c-4 -2.118 -4 -4.118 -1 -7.118\"}}]})(props);\n};\nexport function TbBrandSoundcloud (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 11h1c1.38 0 3 1.274 3 3c0 1.657 -1.5 3 -3 3l-6 0v-10c3 0 4.5 1.5 5 4z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"8\",\"x2\":\"9\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"17\",\"x2\":\"6\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"16\",\"x2\":\"3\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbBrandSpotify (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11.973c2.5 -1.473 5.5 -.973 7.5 .527\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 15c1.5 -1 4 -1 5 .5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 9c2 -1 6 -2 10 .5\"}}]})(props);\n};\nexport function TbBrandStackoverflow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 17v1a2 2 0 0 0 2 2h12a2 2 0 0 0 2 -2v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.322 12.582l7.956 .836\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.787 9.168l7.826 1.664\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.096 5.764l7.608 2.472\"}}]})(props);\n};\nexport function TbBrandSteam (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.5 5a4.5 4.5 0 1 1 -.653 8.953l-4.347 3.009l0 .038a3 3 0 0 1 -2.824 2.995l-.176 .005a3 3 0 0 1 -2.94 -2.402l-2.56 -1.098v-3.5l3.51 1.755a2.989 2.989 0 0 1 2.834 -.635l2.727 -3.818a4.5 4.5 0 0 1 4.429 -5.302z\"}},{\"tag\":\"circle\",\"attr\":{\"fill\":\"currentColor\",\"cx\":\"16.5\",\"cy\":\"9.5\",\"r\":\"1\"}}]})(props);\n};\nexport function TbBrandStripe (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.453 8.056c0 -.623 .518 -.979 1.442 -.979c1.69 0 3.41 .343 4.605 .923l.5 -4c-.948 -.449 -2.82 -1 -5.5 -1c-1.895 0 -3.373 .087 -4.5 1c-1.172 .956 -2 2.33 -2 4c0 3.03 1.958 4.906 5 6c1.961 .69 3 .743 3 1.5c0 .735 -.851 1.5 -2 1.5c-1.423 0 -3.963 -.609 -5.5 -1.5l-.5 4c1.321 .734 3.474 1.5 6 1.5c2.004 0 3.957 -.468 5.084 -1.36c1.263 -.979 1.916 -2.268 1.916 -4.14c0 -3.096 -1.915 -4.547 -5.003 -5.637c-1.646 -.605 -2.544 -1.07 -2.544 -1.807z\"}}]})(props);\n};\nexport function TbBrandSublimeText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 8l-14 4.5v-5.5l14 -4.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 17l-14 4.5v-5.5l14 -4.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 11.5l-14 -4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12.5l14 4.5\"}}]})(props);\n};\nexport function TbBrandSvelte (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 8l-5 3l.821 -.495c1.86 -1.15 4.412 -.49 5.574 1.352a3.91 3.91 0 0 1 -1.264 5.42l-5.053 3.126c-1.86 1.151 -4.312 .591 -5.474 -1.251a3.91 3.91 0 0 1 1.263 -5.42l.26 -.16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 17l5 -3l-.822 .496c-1.86 1.151 -4.411 .491 -5.574 -1.351a3.91 3.91 0 0 1 1.264 -5.42l5.054 -3.127c1.86 -1.15 4.311 -.59 5.474 1.252a3.91 3.91 0 0 1 -1.264 5.42l-.26 .16\"}}]})(props);\n};\nexport function TbBrandTabler (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 9l3 3l-3 3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"15\",\"x2\":\"16\",\"y2\":\"15\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"4\"}}]})(props);\n};\nexport function TbBrandTailwind (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.667 6c-2.49 0 -4.044 1.222 -4.667 3.667c.933 -1.223 2.023 -1.68 3.267 -1.375c.71 .174 1.217 .68 1.778 1.24c.916 .912 2 1.968 4.288 1.968c2.49 0 4.044 -1.222 4.667 -3.667c-.933 1.223 -2.023 1.68 -3.267 1.375c-.71 -.174 -1.217 -.68 -1.778 -1.24c-.916 -.912 -1.975 -1.968 -4.288 -1.968zm-4 6.5c-2.49 0 -4.044 1.222 -4.667 3.667c.933 -1.223 2.023 -1.68 3.267 -1.375c.71 .174 1.217 .68 1.778 1.24c.916 .912 1.975 1.968 4.288 1.968c2.49 0 4.044 -1.222 4.667 -3.667c-.933 1.223 -2.023 1.68 -3.267 1.375c-.71 -.174 -1.217 -.68 -1.778 -1.24c-.916 -.912 -1.975 -1.968 -4.288 -1.968z\"}}]})(props);\n};\nexport function TbBrandTelegram (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 10l-4 4l6 6l4 -16l-18 7l4 2l2 6l3 -4\"}}]})(props);\n};\nexport function TbBrandTidal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7l-2.5 2.5l2.5 2.5l2.5 -2.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14l-2.5 2.5l2.5 2.5l2.5 -2.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 7l-2.5 2.5l2.5 2.5l2.5 -2.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7l-2.5 2.5l2.5 2.5l2.5 -2.5z\"}}]})(props);\n};\nexport function TbBrandTiktok (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12a4 4 0 1 0 4 4v-12a5 5 0 0 0 5 5\"}}]})(props);\n};\nexport function TbBrandTinder (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.918 8.174c2.56 4.982 .501 11.656 -5.38 12.626c-7.702 1.687 -12.84 -7.716 -7.054 -13.229c.309 -.305 1.161 -1.095 1.516 -1.349c0 .528 .27 3.475 1 3.167c3 0 4 -4.222 3.587 -7.389c2.7 1.411 4.987 3.376 6.331 6.174z\"}}]})(props);\n};\nexport function TbBrandTripadvisor (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6.5\",\"cy\":\"13.5\",\"r\":\"1.5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17.5\",\"cy\":\"13.5\",\"r\":\"1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.5 9a4.5 4.5 0 1 0 3.5 1.671l1 -1.671h-4.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 9a4.5 4.5 0 1 1 -3.5 1.671l-1 -1.671h4.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 15.5l1.5 2l1.5 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 6.75c2 -.667 4 -.667 6 0\"}}]})(props);\n};\nexport function TbBrandTumblr (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 21h4v-4h-4v-6h4v-4h-4v-4h-4v1a3 3 0 0 1 -3 3h-1v4h4v6a4 4 0 0 0 4 4\"}}]})(props);\n};\nexport function TbBrandTwitch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 5v11a1 1 0 0 0 1 1h2v4l4 -4h5.584c.266 0 .52 -.105 .707 -.293l2.415 -2.414c.187 -.188 .293 -.442 .293 -.708v-8.585a1 1 0 0 0 -1 -1h-14a1 1 0 0 0 -1 1z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"8\",\"x2\":\"16\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbBrandTwitter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 4.01c-1 .49 -1.98 .689 -3 .99c-1.121 -1.265 -2.783 -1.335 -4.38 -.737s-2.643 2.06 -2.62 3.737v1c-3.245 .083 -6.135 -1.395 -8 -4c0 0 -4.182 7.433 4 11c-1.872 1.247 -3.739 2.088 -6 2c3.308 1.803 6.913 2.423 10.034 1.517c3.58 -1.04 6.522 -3.723 7.651 -7.742a13.84 13.84 0 0 0 .497 -3.753c-.002 -.249 1.51 -2.772 1.818 -4.013z\"}}]})(props);\n};\nexport function TbBrandUber (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"9\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h6\"}}]})(props);\n};\nexport function TbBrandUbuntu (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.723 7.41a7.992 7.992 0 0 0 -3.74 -2.162m-3.971 0a7.993 7.993 0 0 0 -3.789 2.216m-1.881 3.215a8 8 0 0 0 -.342 2.32c0 .738 .1 1.453 .287 2.132m1.96 3.428a7.993 7.993 0 0 0 3.759 2.19m3.998 -.003a7.993 7.993 0 0 0 3.747 -2.186m1.962 -3.43a8.008 8.008 0 0 0 .287 -2.131c0 -.764 -.107 -1.503 -.307 -2.203\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"17\",\"r\":\"2\"}}]})(props);\n};\nexport function TbBrandUnsplash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 11h5v4h6v-4h5v9h-16zm5 -7h6v4h-6z\"}}]})(props);\n};\nexport function TbBrandVercel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19h18l-9 -15z\"}}]})(props);\n};\nexport function TbBrandVimeo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 8.5l1 1s1.5 -1.102 2 -.5c.509 .609 1.863 7.65 2.5 9c.556 1.184 1.978 2.89 4 1.5c2 -1.5 7.5 -5.5 8.5 -11.5c.444 -2.661 -1 -4 -2.5 -4c-2 0 -4.047 1.202 -4.5 4c2.05 -1.254 2.551 1.003 1.5 3c-1.052 2.005 -2 3 -2.5 3c-.49 0 -.924 -1.165 -1.5 -3.5c-.59 -2.42 -.5 -6.5 -3 -6.5s-5.5 4.5 -5.5 4.5z\"}}]})(props);\n};\nexport function TbBrandVisualStudio (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8l2 -1l10 13l4 -2v-12l-4 -2l-10 13l-2 -1z\"}}]})(props);\n};\nexport function TbBrandVk (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 19h-4a8 8 0 0 1 -8 -8v-5h4v5a4 4 0 0 0 4 4h0v-9h4v4.5l.03 -.004a4.531 4.531 0 0 0 3.97 -4.496h4l-.342 1.711a6.858 6.858 0 0 1 -3.658 4.789h0a5.34 5.34 0 0 1 3.566 4.111l.434 2.389h0h-4a4.531 4.531 0 0 0 -3.97 -4.496v4.5z\"}}]})(props);\n};\nexport function TbBrandVue (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.5 5l-6.5 10l-6.5 -10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 5l-3 4.5l-3 -4.5h-7l10 16l10 -16z\"}}]})(props);\n};\nexport function TbBrandWhatsapp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21l1.65 -3.8a9 9 0 1 1 3.4 2.9l-5.05 .9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 10a0.5 .5 0 0 0 1 0v-1a0.5 .5 0 0 0 -1 0v1a5 5 0 0 0 5 5h1a0.5 .5 0 0 0 0 -1h-1a0.5 .5 0 0 0 0 1\"}}]})(props);\n};\nexport function TbBrandWindows (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.8 20l-12 -1.5c-1 -.1 -1.8 -.9 -1.8 -1.9v-9.2c0 -1 .8 -1.8 1.8 -1.9l12 -1.5c1.2 -.1 2.2 .8 2.2 1.9v12.1c0 1.2 -1.1 2.1 -2.2 1.9z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"5\",\"x2\":\"12\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbBrandYahoo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"6\",\"x2\":\"8\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"18\",\"x2\":\"14\",\"y2\":\"18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 6l5.5 7v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 13l6 -5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12.5\",\"y1\":\"8\",\"x2\":\"17.5\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"11\",\"x2\":\"20\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"18\",\"x2\":\"20\",\"y2\":\"18.01\"}}]})(props);\n};\nexport function TbBrandYcombinator (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 7.002l4 5.998l4 -6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"17\",\"x2\":\"12\",\"y2\":\"13\"}}]})(props);\n};\nexport function TbBrandYoutube (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"5\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 9l5 3l-5 3z\"}}]})(props);\n};\nexport function TbBread (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 5a3 3 0 0 1 2 5.235v6.765a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-6.764a3 3 0 0 1 1.824 -5.231l.176 -.005h10z\"}}]})(props);\n};\nexport function TbBriefcase (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"7\",\"width\":\"18\",\"height\":\"13\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 7v-2a2 2 0 0 1 2 -2h4a2 2 0 0 1 2 2v2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"12.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 13a20 20 0 0 0 18 0\"}}]})(props);\n};\nexport function TbBrightness2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6h3.5l2.5 -2.5l2.5 2.5h3.5v3.5l2.5 2.5l-2.5 2.5v3.5h-3.5l-2.5 2.5l-2.5 -2.5h-3.5v-3.5l-2.5 -2.5l2.5 -2.5z\"}}]})(props);\n};\nexport function TbBrightnessDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"5\",\"x2\":\"12\",\"y2\":\"5.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"7\",\"x2\":\"17\",\"y2\":\"7.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"12\",\"x2\":\"19\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"17\",\"x2\":\"17\",\"y2\":\"17.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"19\",\"x2\":\"12\",\"y2\":\"19.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"17\",\"x2\":\"7\",\"y2\":\"17.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"5\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"7\",\"x2\":\"7\",\"y2\":\"7.01\"}}]})(props);\n};\nexport function TbBrightnessHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9a3 3 0 0 0 0 6v-6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6h3.5l2.5 -2.5l2.5 2.5h3.5v3.5l2.5 2.5l-2.5 2.5v3.5h-3.5l-2.5 2.5l-2.5 -2.5h-3.5v-3.5l-2.5 -2.5l2.5 -2.5z\"}}]})(props);\n};\nexport function TbBrightnessUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"5\",\"x2\":\"12\",\"y2\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"7\",\"x2\":\"18.4\",\"y2\":\"5.6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"12\",\"x2\":\"21\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"17\",\"x2\":\"18.4\",\"y2\":\"18.4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"19\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"17\",\"x2\":\"5.6\",\"y2\":\"18.4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"12\",\"x2\":\"4\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"7\",\"x2\":\"5.6\",\"y2\":\"5.6\"}}]})(props);\n};\nexport function TbBrightness (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"9\",\"x2\":\"16.65\",\"y2\":\"4.35\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"14.3\",\"x2\":\"19.37\",\"y2\":\"6.93\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"19.6\",\"x2\":\"20.85\",\"y2\":\"10.75\"}}]})(props);\n};\nexport function TbBrowserCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8h16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 14.5l1.5 1.5l3 -3\"}}]})(props);\n};\nexport function TbBrowserOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h11a1 1 0 0 1 1 1v11m-.288 3.702a0.997 .997 0 0 1 -.712 .298h-14a1 1 0 0 1 -1 -1v-14c0 -.276 .112 -.526 .293 -.707\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8h4m4 0h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBrowserPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8h16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 14h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v4\"}}]})(props);\n};\nexport function TbBrowserX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8h16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 16l4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 16l-4 -4\"}}]})(props);\n};\nexport function TbBrowser (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"8\",\"x2\":\"20\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"4\",\"x2\":\"8\",\"y2\":\"8\"}}]})(props);\n};\nexport function TbBrushOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17a4 4 0 1 1 4 4h-4v-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 3a15.996 15.996 0 0 0 -9.309 4.704m-1.795 2.212a15.993 15.993 0 0 0 -1.696 3.284\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 3a15.996 15.996 0 0 1 -4.697 9.302m-2.195 1.786a15.993 15.993 0 0 1 -3.308 1.712\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBrush (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21v-4a4 4 0 1 1 4 4h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 3a16 16 0 0 0 -12.8 10.2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 3a16 16 0 0 1 -10.2 12.8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.6 9a9 9 0 0 1 4.4 4.4\"}}]})(props);\n};\nexport function TbBucketOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.184 17.173l-.184 .827c-.193 1.183 -1.034 2.024 -2 2h-6c-.966 .024 -1.807 -.817 -2 -2l-2 -9h4m4 0h6l-1.089 4.9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 9c0 -.596 .104 -1.167 .295 -1.697m1.705 -2.303a5 5 0 0 1 8 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBucket (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 9l-2 9a2 2.5 0 0 1 -2 2h-6a2 2.5 0 0 1 -2 -2l-2 -9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 9a5 5 0 0 1 10 0\"}}]})(props);\n};\nexport function TbBugOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.884 5.873a3 3 0 0 1 5.116 2.127v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 9h3a6 6 0 0 1 1 3v1m-.298 3.705a5.002 5.002 0 0 1 -9.702 -1.705v-3a6 6 0 0 1 1 -3h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 13h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 13h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20v-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 19l3.35 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 7l3.75 2.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 7l-3.75 2.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBug (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 9v-1a3 3 0 0 1 6 0v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 9h8a6 6 0 0 1 1 3v3a5 5 0 0 1 -10 0v-3a6 6 0 0 1 1 -3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"13\",\"x2\":\"7\",\"y2\":\"13\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"13\",\"x2\":\"21\",\"y2\":\"13\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"20\",\"x2\":\"12\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"19\",\"x2\":\"7.35\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"19\",\"x2\":\"16.65\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"7\",\"x2\":\"7.75\",\"y2\":\"9.4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"7\",\"x2\":\"16.25\",\"y2\":\"9.4\"}}]})(props);\n};\nexport function TbBuildingArch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 21v-15a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 21v-8a3 3 0 0 1 6 0v8\"}}]})(props);\n};\nexport function TbBuildingBank (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"10\",\"x2\":\"21\",\"y2\":\"10\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"5 6 12 3 19 6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"10\",\"x2\":\"4\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"10\",\"x2\":\"20\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"14\",\"x2\":\"8\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"14\",\"x2\":\"12\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"14\",\"x2\":\"16\",\"y2\":\"17\"}}]})(props);\n};\nexport function TbBuildingBridge2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 7h12a2 2 0 0 1 2 2v9a1 1 0 0 1 -1 1h-2a1 1 0 0 1 -1 -1v-2a4 4 0 0 0 -8 0v2a1 1 0 0 1 -1 1h-2a1 1 0 0 1 -1 -1v-9a2 2 0 0 1 2 -2\"}}]})(props);\n};\nexport function TbBuildingBridge (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"5\",\"x2\":\"6\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"5\",\"x2\":\"18\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"2\",\"y1\":\"15\",\"x2\":\"22\",\"y2\":\"15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 8a7.5 7.5 0 0 0 3 -2a6.5 6.5 0 0 0 12 0a7.5 7.5 0 0 0 3 2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"10\",\"x2\":\"12\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbBuildingCarousel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"6\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"8\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"4\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"8\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"16\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"16\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 22l4 -10l4 10\"}}]})(props);\n};\nexport function TbBuildingCastle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 19v-2a3 3 0 0 0 -6 0v2a1 1 0 0 1 -1 1h-4a1 1 0 0 1 -1 -1v-14h4v3h3v-3h4v3h3v-3h4v14a1 1 0 0 1 -1 1h-4a1 1 0 0 1 -1 -1z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"11\",\"x2\":\"21\",\"y2\":\"11\"}}]})(props);\n};\nexport function TbBuildingChurch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 21v-4a2 2 0 0 1 4 0v4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"5\",\"x2\":\"14\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 21v-7m-2 2l8 -8l8 8m-2 -2v7\"}}]})(props);\n};\nexport function TbBuildingCommunity (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 9l5 5v7h-5v-4m0 4h-5v-7l5 -5m1 1v-6a1 1 0 0 1 1 -1h10a1 1 0 0 1 1 1v17h-8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"7\",\"x2\":\"13\",\"y2\":\"7.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"7\",\"x2\":\"17\",\"y2\":\"7.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"11\",\"x2\":\"17\",\"y2\":\"11.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"15\",\"x2\":\"17\",\"y2\":\"15.01\"}}]})(props);\n};\nexport function TbBuildingCottage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 21v-11l2.5 -4.5l5.5 -2.5l5.5 2.5l2.5 4.5v11\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"9\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 21v-5a1 1 0 0 1 1 -1h4a1 1 0 0 1 1 1v5\"}}]})(props);\n};\nexport function TbBuildingFactory2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21h18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 21v-12l5 4v-4l5 4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 21v-8l-1.436 -9.574a0.5 .5 0 0 0 -.495 -.426h-1.145a0.5 .5 0 0 0 -.494 .418l-1.43 8.582\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 17h1\"}}]})(props);\n};\nexport function TbBuildingFactory (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 21c1.147 -4.02 1.983 -8.027 2 -12h6c.017 3.973 .853 7.98 2 12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 13h4.5c.025 2.612 .894 5.296 2 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"22\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbBuildingFortress (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 21h1a1 1 0 0 0 1 -1v-1h0a3 3 0 0 1 6 0m3 2h1a1 1 0 0 0 1 -1v-15l-3 -2l-3 2v6h-4v-6l-3 -2l-3 2v15a1 1 0 0 0 1 1h2m8 -2v1a1 1 0 0 0 1 1h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7h0v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 10h0v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 13h0v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 7h0v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 10h0v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 13h0v.01\"}}]})(props);\n};\nexport function TbBuildingHospital (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 21v-16a2 2 0 0 1 2 -2h10a2 2 0 0 1 2 2v16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 21v-4a2 2 0 0 1 2 -2h2a2 2 0 0 1 2 2v4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"9\",\"x2\":\"14\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"7\",\"x2\":\"12\",\"y2\":\"11\"}}]})(props);\n};\nexport function TbBuildingLighthouse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3l2 3l2 15h-8l2 -15z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"9\",\"x2\":\"16\",\"y2\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 11l2 -2l-2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 11l-2 -2l2 -2\"}}]})(props);\n};\nexport function TbBuildingMonument (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 18l2 -13l2 -2l2 2l2 13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 21v-3h14v3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbBuildingPavilon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21h7v-3a2 2 0 0 1 4 0v3h7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"21\",\"x2\":\"6\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"21\",\"x2\":\"18\",\"y2\":\"12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12h12a3 3 0 0 0 3 -3a9 8 0 0 1 -9 -6a9 8 0 0 1 -9 6a3 3 0 0 0 3 3\"}}]})(props);\n};\nexport function TbBuildingSkyscraper (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 21v-14l8 -4v18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 21v-10l-6 -4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"9\",\"x2\":\"9\",\"y2\":\"9.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"12\",\"x2\":\"9\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"15\",\"x2\":\"9\",\"y2\":\"15.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"18\",\"x2\":\"9\",\"y2\":\"18.01\"}}]})(props);\n};\nexport function TbBuildingStore (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7v1a3 3 0 0 0 6 0v-1m0 1a3 3 0 0 0 6 0v-1m0 1a3 3 0 0 0 6 0v-1h-18l2 -4h14l2 4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"21\",\"x2\":\"5\",\"y2\":\"10.85\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"21\",\"x2\":\"19\",\"y2\":\"10.85\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 21v-4a2 2 0 0 1 2 -2h2a2 2 0 0 1 2 2v4\"}}]})(props);\n};\nexport function TbBuildingWarehouse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21v-13l9 -4l9 4v13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 13h4v8h-10v-6h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 21v-9a1 1 0 0 0 -1 -1h-2a1 1 0 0 0 -1 1v3\"}}]})(props);\n};\nexport function TbBuilding (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"8\",\"x2\":\"10\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"12\",\"x2\":\"10\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"16\",\"x2\":\"10\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"8\",\"x2\":\"15\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"12\",\"x2\":\"15\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"16\",\"x2\":\"15\",\"y2\":\"16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 21v-16a2 2 0 0 1 2 -2h10a2 2 0 0 1 2 2v16\"}}]})(props);\n};\nexport function TbBulbOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h1m8 -9v1m8 8h1m-15.4 -6.4l.7 .7m12.1 -.7l-.7 .7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.089 7.083a5 5 0 0 1 5.826 5.84m-1.378 2.611a5.012 5.012 0 0 1 -.537 .466a3.5 3.5 0 0 0 -1 3a2 2 0 1 1 -4 0a3.5 3.5 0 0 0 -1 -3a5 5 0 0 1 -.528 -7.544\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.7 17h4.6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbBulb (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h1m8 -9v1m8 8h1m-15.4 -6.4l.7 .7m12.1 -.7l-.7 .7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 16a5 5 0 1 1 6 0a3.5 3.5 0 0 0 -1 3a2 2 0 0 1 -4 0a3.5 3.5 0 0 0 -1 -3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9.7\",\"y1\":\"17\",\"x2\":\"14.3\",\"y2\":\"17\"}}]})(props);\n};\nexport function TbBulldozer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"4\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"13\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 13v6h3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"19\",\"x2\":\"4\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"15\",\"x2\":\"13\",\"y2\":\"15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12v-5h2a3 3 0 0 1 3 3v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 15v-2a1 1 0 0 1 1 -1h7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"17\",\"x2\":\"15\",\"y2\":\"17\"}}]})(props);\n};\nexport function TbBus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 17h-2v-11a1 1 0 0 1 1 -1h14a5 7 0 0 1 5 7v5h-2m-4 0h-8\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 5 17.5 12 22 12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"2\",\"y1\":\"10\",\"x2\":\"17\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"5\",\"x2\":\"7\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"5\",\"x2\":\"12\",\"y2\":\"10\"}}]})(props);\n};\nexport function TbBusinessplan (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"ellipse\",\"attr\":{\"cx\":\"16\",\"cy\":\"6\",\"rx\":\"5\",\"ry\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 6v4c0 1.657 2.239 3 5 3s5 -1.343 5 -3v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 10v4c0 1.657 2.239 3 5 3s5 -1.343 5 -3v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 14v4c0 1.657 2.239 3 5 3s5 -1.343 5 -3v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 9h-2.5a1.5 1.5 0 0 0 0 3h1a1.5 1.5 0 0 1 0 3h-2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 15v1m0 -8v1\"}}]})(props);\n};\nexport function TbButterfly (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.995 18.176a3 3 0 1 1 -4.953 -2.449l-.025 .023a4.502 4.502 0 0 1 1.483 -8.75c1.414 0 2.675 .652 3.5 1.671a4.5 4.5 0 1 1 4.983 7.079a3 3 0 1 1 -4.983 2.25z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 19v-10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 3l3 2l3 -2\"}}]})(props);\n};\nexport function TbCSharp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 9a3 3 0 0 0 -3 -3h-.5a3.5 3.5 0 0 0 -3.5 3.5v5a3.5 3.5 0 0 0 3.5 3.5h.5a3 3 0 0 0 3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 7l-1 10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 7l-1 10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10h7.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 14h-7.5\"}}]})(props);\n};\nexport function TbCakeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 17v-5a3 3 0 0 0 -3 -3h-5m-4 0h-3a3 3 0 0 0 -3 3v8h17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.996 14.803c.312 .135 .654 .204 1.004 .197a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1m4 0a2.4 2.4 0 0 0 2 1c.35 .007 .692 -.062 1.004 -.197\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.172 6.188c.07 -.158 .163 -.31 .278 -.451l1.55 -1.737l1.465 1.638a2 2 0 0 1 -.65 3.19\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCake (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 20h18v-8a3 3 0 0 0 -3 -3h-12a3 3 0 0 0 -3 3v8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.996 14.803c.312 .135 .654 .204 1.004 .197a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1c.35 .007 .692 -.062 1.004 -.197\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4l1.465 1.638a2 2 0 1 1 -3.015 .099l1.55 -1.737z\"}}]})(props);\n};\nexport function TbCalculatorOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.823 19.824a2 2 0 0 1 -1.823 1.176h-12a2 2 0 0 1 -2 -2v-14c0 -.295 .064 -.575 .178 -.827m2.822 -1.173h11a2 2 0 0 1 2 2v11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10h-1a1 1 0 0 1 -1 -1v-1m3 -1h4a1 1 0 0 1 1 1v1a1 1 0 0 1 -1 1h-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 14v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 17v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 17v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCalculator (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"3\",\"width\":\"16\",\"height\":\"18\",\"rx\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"7\",\"width\":\"8\",\"height\":\"3\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"14\",\"x2\":\"8\",\"y2\":\"14.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"14\",\"x2\":\"12\",\"y2\":\"14.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"14\",\"x2\":\"16\",\"y2\":\"14.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"17\",\"x2\":\"8\",\"y2\":\"17.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"17\",\"x2\":\"12\",\"y2\":\"17.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"17\",\"x2\":\"16\",\"y2\":\"17.01\"}}]})(props);\n};\nexport function TbCalendarEvent (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"5\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"3\",\"x2\":\"16\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"3\",\"x2\":\"8\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"11\",\"x2\":\"20\",\"y2\":\"11\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"15\",\"width\":\"2\",\"height\":\"2\"}}]})(props);\n};\nexport function TbCalendarMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"5\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"3\",\"x2\":\"16\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"3\",\"x2\":\"8\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"11\",\"x2\":\"20\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"16\",\"x2\":\"14\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbCalendarOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.823 19.824a2 2 0 0 1 -1.823 1.176h-12a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 1.175 -1.823m3.825 -.177h9a2 2 0 0 1 2 2v9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"3\",\"x2\":\"16\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"3\",\"x2\":\"8\",\"y2\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 11h7m4 0h5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"15\",\"x2\":\"12\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"15\",\"x2\":\"12\",\"y2\":\"18\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbCalendarPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"5\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"3\",\"x2\":\"16\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"3\",\"x2\":\"8\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"11\",\"x2\":\"20\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"16\",\"x2\":\"14\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"14\",\"x2\":\"12\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbCalendarStats (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.795 21h-6.795a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 14v4h4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"18\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 3v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 11h16\"}}]})(props);\n};\nexport function TbCalendarTime (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.795 21h-6.795a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"18\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 3v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 11h16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 16.496v1.504l1 1\"}}]})(props);\n};\nexport function TbCalendar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"5\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"3\",\"x2\":\"16\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"3\",\"x2\":\"8\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"11\",\"x2\":\"20\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"15\",\"x2\":\"12\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"15\",\"x2\":\"12\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbCameraMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"13\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7h1a2 2 0 0 0 2 -2a1 1 0 0 1 1 -1h3m9 6v8a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-9a2 2 0 0 1 2 -2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"6\",\"x2\":\"21\",\"y2\":\"6\"}}]})(props);\n};\nexport function TbCameraOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.29 4.296a1 1 0 0 1 .71 -.296h6a1 1 0 0 1 1 1a2 2 0 0 0 2 2h1a2 2 0 0 1 2 2v8m-1.179 2.824c-.25 .113 -.528 .176 -.821 .176h-14a2 2 0 0 1 -2 -2v-9a2 2 0 0 1 2 -2h1c.292 0 .568 -.062 .818 -.175\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.436 10.44a3 3 0 1 0 4.126 4.122\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbCameraPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"13\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7h2a2 2 0 0 0 2 -2a1 1 0 0 1 1 -1h2m9 7v7a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-9a2 2 0 0 1 2 -2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"6\",\"x2\":\"21\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"3\",\"x2\":\"18\",\"y2\":\"9\"}}]})(props);\n};\nexport function TbCameraRotate (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7h1a2 2 0 0 0 2 -2a1 1 0 0 1 1 -1h6a1 1 0 0 1 1 1a2 2 0 0 0 2 2h1a2 2 0 0 1 2 2v9a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-9a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.245 15.904a3 3 0 0 0 3.755 -2.904m-2.25 -2.905a3 3 0 0 0 -3.75 2.905\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 13h2v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 13h-2v-2\"}}]})(props);\n};\nexport function TbCameraSelfie (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7h1a2 2 0 0 0 2 -2a1 1 0 0 1 1 -1h6a1 1 0 0 1 1 1a2 2 0 0 0 2 2h1a2 2 0 0 1 2 2v9a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-9a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 15a3.5 3.5 0 0 0 5 0\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"11\",\"x2\":\"15.01\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"11\",\"x2\":\"9.01\",\"y2\":\"11\"}}]})(props);\n};\nexport function TbCamera (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7h1a2 2 0 0 0 2 -2a1 1 0 0 1 1 -1h6a1 1 0 0 1 1 1a2 2 0 0 0 2 2h1a2 2 0 0 1 2 2v9a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-9a2 2 0 0 1 2 -2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"13\",\"r\":\"3\"}}]})(props);\n};\nexport function TbCandle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 21h6v-9a1 1 0 0 0 -1 -1h-4a1 1 0 0 0 -1 1v9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3l1.465 1.638a2 2 0 1 1 -3.015 .099l1.55 -1.737z\"}}]})(props);\n};\nexport function TbCandyOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.174 7.17l.119 -.12a2 2 0 0 1 2.828 0l2.829 2.83a2 2 0 0 1 0 2.828l-.124 .124m-1.996 1.996l-2.123 2.123a2 2 0 0 1 -2.828 0l-2.829 -2.831a2 2 0 0 1 0 -2.828l2.113 -2.112\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.243 9.172l3.086 -.772a1.5 1.5 0 0 0 .697 -2.516l-2.216 -2.217a1.5 1.5 0 0 0 -2.44 .47l-1.248 2.913\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.172 16.243l-.772 3.086a1.5 1.5 0 0 1 -2.516 .697l-2.217 -2.216a1.5 1.5 0 0 1 .47 -2.44l2.913 -1.248\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCandy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.05 11.293l4.243 -4.243a2 2 0 0 1 2.828 0l2.829 2.83a2 2 0 0 1 0 2.828l-4.243 4.243a2 2 0 0 1 -2.828 0l-2.829 -2.831a2 2 0 0 1 0 -2.828z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.243 9.172l3.086 -.772a1.5 1.5 0 0 0 .697 -2.516l-2.216 -2.217a1.5 1.5 0 0 0 -2.44 .47l-1.248 2.913\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.172 16.243l-.772 3.086a1.5 1.5 0 0 1 -2.516 .697l-2.217 -2.216a1.5 1.5 0 0 1 .47 -2.44l2.913 -1.248\"}}]})(props);\n};\nexport function TbCaptureOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16v2a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2a2 2 0 0 1 2 2v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h2c.554 0 1.055 -.225 1.417 -.589\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.87 9.887a3 3 0 0 0 4.255 4.23m.58 -3.416a3.012 3.012 0 0 0 -1.4 -1.403\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8v-2c0 -.548 .22 -1.044 .577 -1.405\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCapture (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8v-2a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16v2a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2a2 2 0 0 1 2 2v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h2a2 2 0 0 0 2 -2v-2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}}]})(props);\n};\nexport function TbCarCrane (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 18h8m4 0h2v-6a5 5 0 0 0 -5 -5h-1l1.5 5h4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18v-11h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17v-5h9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12v-6l18 -3v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12v-4l-4 -2\"}}]})(props);\n};\nexport function TbCarCrash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"10\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 6l4 5h1a2 2 0 0 1 2 2v4h-2m-4 0h-5m0 -6h8m-6 0v-5m2 0h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 8v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 12h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.5 15.5l1.5 1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.5 8.5l1.5 -1.5\"}}]})(props);\n};\nexport function TbCarOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.584 15.588a2 2 0 0 0 2.828 2.83\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 17h-2v-6l2 -5h1m4 0h4l4 5h1a2 2 0 0 1 2 2v4m-6 0h-6m-6 -6h8m4 0h3m-6 -3v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 17h-2v-6l2 -5h9l4 5h1a2 2 0 0 1 2 2v4h-2m-4 0h-6m-6 -6h15m-6 0v-5\"}}]})(props);\n};\nexport function TbCaravan (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"11\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"17\",\"x2\":\"13\",\"y2\":\"17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17h-5a1 1 0 0 1 -1 -1v-9a2 2 0 0 1 2 -2h10l4 4v8\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"6\",\"y\":\"8\",\"width\":\"6\",\"height\":\"4\",\"rx\":\"1\"}}]})(props);\n};\nexport function TbCardboardsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.96 16.953c.026 -.147 .04 -.298 .04 -.453v-8.5a2 2 0 0 0 -2 -2h-9m-4 0h-1a2 2 0 0 0 -2 2v8.5a2.5 2.5 0 0 0 2.5 2.5h1.06a3 3 0 0 0 2.34 -1.13l1.54 -1.92a2 2 0 0 1 3.12 0l1.54 1.92a3 3 0 0 0 2.34 1.13h1.06c.155 0 .307 -.014 .454 -.041\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.714 12.7a1 1 0 0 0 -1.417 -1.411l1.417 1.41z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCardboards (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 8v8.5a2.5 2.5 0 0 0 2.5 2.5h1.06a3 3 0 0 0 2.34 -1.13l1.54 -1.92a2 2 0 0 1 3.12 0l1.54 1.92a3 3 0 0 0 2.34 1.13h1.06a2.5 2.5 0 0 0 2.5 -2.5v-8.5a2 2 0 0 0 -2 -2h-14a2 2 0 0 0 -2 2z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16\",\"cy\":\"12\",\"r\":\"1\"}}]})(props);\n};\nexport function TbCaretDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15l-6 -6l-6 6h12\",\"transform\":\"rotate(180 12 12)\"}}]})(props);\n};\nexport function TbCaretLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15l-6 -6l-6 6h12\",\"transform\":\"rotate(270 12 12)\"}}]})(props);\n};\nexport function TbCaretRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15l-6 -6l-6 6h12\",\"transform\":\"rotate(90 12 12)\"}}]})(props);\n};\nexport function TbCaretUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15l-6 -6l-6 6h12\"}}]})(props);\n};\nexport function TbCashBanknoteOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.88 9.878a3 3 0 1 0 4.242 4.243m.58 -3.425a3.012 3.012 0 0 0 -1.412 -1.405\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6h9a2 2 0 0 1 2 2v8c0 .294 -.064 .574 -.178 .825m-2.822 1.175h-13a2 2 0 0 1 -2 -2v-8a2 2 0 0 1 2 -2h1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"12\",\"x2\":\"18.01\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"12\",\"x2\":\"6.01\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbCashBanknote (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"6\",\"width\":\"18\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"12\",\"x2\":\"18.01\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"12\",\"x2\":\"6.01\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbCashOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 9h6a2 2 0 0 1 2 2v6m-2 2h-10a2 2 0 0 1 -2 -2v-6a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.582 12.59a2 2 0 0 0 2.83 2.826\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 9v-2a2 2 0 0 0 -2 -2h-6m-4 0a2 2 0 0 0 -2 2v6a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"7\",\"y\":\"9\",\"width\":\"14\",\"height\":\"10\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14\",\"cy\":\"14\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 9v-2a2 2 0 0 0 -2 -2h-10a2 2 0 0 0 -2 2v6a2 2 0 0 0 2 2h2\"}}]})(props);\n};\nexport function TbCastOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 19a4 4 0 0 0 -4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 19a8 8 0 0 0 -8 -8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 19h3a3 3 0 0 0 .875 -.13m1.997 -2.002a3 3 0 0 0 .128 -.868v-8a3 3 0 0 0 -3 -3h-9m-3.865 .136a3 3 0 0 0 -1.935 1.864\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCast (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"19\",\"x2\":\"3.01\",\"y2\":\"19\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 19a4 4 0 0 0 -4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 19a8 8 0 0 0 -8 -8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 19h3a3 3 0 0 0 3 -3v-8a3 3 0 0 0 -3 -3h-12a3 3 0 0 0 -2.8 2\"}}]})(props);\n};\nexport function TbCeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 4a7.99 7.99 0 0 0 -2.581 .426\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.867 5.864a8 8 0 0 0 5.133 14.136\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 4a8.001 8.001 0 0 0 -7.29 4.7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12a8 8 0 0 0 8 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCe (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 4a8 8 0 1 0 0 16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 4a8 8 0 1 0 0 16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbCellSignal1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 20h-15.269a0.731 .731 0 0 1 -.517 -1.249l14.537 -14.537a0.731 .731 0 0 1 1.249 .517v15.269z\"}}]})(props);\n};\nexport function TbCellSignal2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 20h-15.269a0.731 .731 0 0 1 -.517 -1.249l14.537 -14.537a0.731 .731 0 0 1 1.249 .517v15.269z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 20v-5\"}}]})(props);\n};\nexport function TbCellSignal3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 20h-15.269a0.731 .731 0 0 1 -.517 -1.249l14.537 -14.537a0.731 .731 0 0 1 1.249 .517v15.269z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20v-9\"}}]})(props);\n};\nexport function TbCellSignal4 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 20h-15.269a0.731 .731 0 0 1 -.517 -1.249l14.537 -14.537a0.731 .731 0 0 1 1.249 .517v15.269z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 7v13\"}}]})(props);\n};\nexport function TbCellSignal5 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 20h-15.269a0.731 .731 0 0 1 -.517 -1.249l14.537 -14.537a0.731 .731 0 0 1 1.249 .517v15.269z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 7v13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20v-9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 20v-5\"}}]})(props);\n};\nexport function TbCellSignalOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 20h-15.269a0.731 .731 0 0 1 -.517 -1.249l7.265 -7.264m2 -2.001l5.272 -5.272a0.731 .731 0 0 1 1.249 .517v11.269\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCell (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4l-4 2v5l4 2l4 -2v-5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 11l4 2l4 -2v-5l-4 -2l-4 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13v5l4 2l4 -2v-5\"}}]})(props);\n};\nexport function TbCertificate2Off (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12a3 3 0 1 0 3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 18v4l2 -1l2 1v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 19h-2a2 2 0 0 1 -2 -2v-11m1.18 -2.825c.25 -.112 .529 -.175 .82 -.175h8a2 2 0 0 1 2 2v9m-.175 3.82a2 2 0 0 1 -1.825 1.18h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCertificate2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"15\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 7h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 18v4l2 -1l2 1v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 19h-2a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v12a2 2 0 0 1 -2 2h-2\"}}]})(props);\n};\nexport function TbCertificateOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.876 12.881a3 3 0 0 0 4.243 4.243m.588 -3.42a3.012 3.012 0 0 0 -1.437 -1.423\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 17.5v4.5l2 -1.5l2 1.5v-4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 19h-5a2 2 0 0 1 -2 -2v-10c0 -1.1 .9 -2 2 -2m4 0h10a2 2 0 0 1 2 2v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 9h3m4 0h5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCertificate (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"15\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 17.5v4.5l2 -1.5l2 1.5v-4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 19h-5a2 2 0 0 1 -2 -2v-10c0 -1.1 .9 -2 2 -2h14a2 2 0 0 1 2 2v10a2 2 0 0 1 -1 1.73\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"9\",\"x2\":\"18\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"12\",\"x2\":\"9\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"15\",\"x2\":\"8\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbChargingPile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"7\",\"x2\":\"17\",\"y2\":\"8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 11h1a2 2 0 0 1 2 2v3a1.5 1.5 0 0 0 3 0v-7l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20v-14a2 2 0 0 1 2 -2h6a2 2 0 0 1 2 2v14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 11.5l-1.5 2.5h3l-1.5 2.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"20\",\"x2\":\"15\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"8\",\"x2\":\"14\",\"y2\":\"8\"}}]})(props);\n};\nexport function TbChartArcs3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12a5 5 0 1 0 5 -5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.29 18.957a9 9 0 1 0 5.71 -15.957\"}}]})(props);\n};\nexport function TbChartArcs (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.924 11.132a5 5 0 1 0 -4.056 5.792\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12a9 9 0 1 0 9 -9\"}}]})(props);\n};\nexport function TbChartAreaLine (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"4 19 8 13 12 15 16 10 20 14 20 19 4 19\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"4 12 7 8 11 10 16 4 20 8\"}}]})(props);\n};\nexport function TbChartArea (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"19\",\"x2\":\"20\",\"y2\":\"19\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"4 15 8 9 12 11 16 6 20 10 20 15 4 15\"}}]})(props);\n};\nexport function TbChartArrowsVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 21v-14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 15l3 -3l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 10l3 -3l3 3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"21\",\"x2\":\"12\",\"y2\":\"12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6l3 -3l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 21v-18\"}}]})(props);\n};\nexport function TbChartArrows (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"18\",\"x2\":\"17\",\"y2\":\"18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 9l3 3l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 15l3 3l-3 3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"3\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 3l3 3l-3 3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"6\",\"x2\":\"21\",\"y2\":\"6\"}}]})(props);\n};\nexport function TbChartBar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"12\",\"width\":\"6\",\"height\":\"8\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"8\",\"width\":\"6\",\"height\":\"12\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"15\",\"y\":\"4\",\"width\":\"6\",\"height\":\"16\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"18\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbChartBubble (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"16\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14.5\",\"cy\":\"7.5\",\"r\":\"4.5\"}}]})(props);\n};\nexport function TbChartCandle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"6\",\"width\":\"4\",\"height\":\"5\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"4\",\"x2\":\"6\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"11\",\"x2\":\"6\",\"y2\":\"20\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"10\",\"y\":\"14\",\"width\":\"4\",\"height\":\"5\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"19\",\"x2\":\"12\",\"y2\":\"20\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"16\",\"y\":\"5\",\"width\":\"4\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"4\",\"x2\":\"18\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"11\",\"x2\":\"18\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbChartCircles (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9.5\",\"cy\":\"9.5\",\"r\":\"5.5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14.5\",\"cy\":\"14.5\",\"r\":\"5.5\"}}]})(props);\n};\nexport function TbChartDonut2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v5m4 4h5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbChartDonut3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v5m4 4h5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.929 14.582l-3.429 2.918\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbChartDonut4 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.848 14.667l-3.348 2.833\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v5m4 4h5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.219 15.328l2.781 4.172\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"4\"}}]})(props);\n};\nexport function TbChartDonut (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 3.2a9 9 0 1 0 10.8 10.8a1 1 0 0 0 -1 -1h-3.8a4.1 4.1 0 1 1 -5 -5v-4a0.9 .9 0 0 0 -1 -.8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3.5a9 9 0 0 1 5.5 5.5h-4.5a9 9 0 0 0 -1 -1v-4.5\"}}]})(props);\n};\nexport function TbChartDots2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3v18h18\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"15\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"13\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"12\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 3l-6 1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.113 6.65l2.771 3.695\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12.5l-5 2\"}}]})(props);\n};\nexport function TbChartDots3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"7\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16\",\"cy\":\"15\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"6\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"18\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17l5 -1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 8.5l7.81 5.37\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7l8 -1\"}}]})(props);\n};\nexport function TbChartDots (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3v18h18\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"9\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"7\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14\",\"cy\":\"15\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10.16\",\"y1\":\"10.62\",\"x2\":\"12.5\",\"y2\":\"13.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.088 13.328l2.837 -4.586\"}}]})(props);\n};\nexport function TbChartInfographic (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"7\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 3v4h4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"17\",\"x2\":\"9\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"14\",\"x2\":\"17\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"13\",\"x2\":\"13\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"12\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbChartLine (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"19\",\"x2\":\"20\",\"y2\":\"19\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"4 15 8 9 12 11 16 6 20 10\"}}]})(props);\n};\nexport function TbChartPie2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v9h9\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbChartPie3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l-6.5 5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v9h9\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbChartPie4 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l-6.5 5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v9h9\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l5 7.5\"}}]})(props);\n};\nexport function TbChartPie (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 3.2a9 9 0 1 0 10.8 10.8a1 1 0 0 0 -1 -1h-6.8a2 2 0 0 1 -2 -2v-7a0.9 .9 0 0 0 -1 -.8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3.5a9 9 0 0 1 5.5 5.5h-4.5a1 1 0 0 1 -1 -1v-4.5\"}}]})(props);\n};\nexport function TbChartRadar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3l9.5 7l-3.5 11h-12l-3.5 -11z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7.5l5.5 4l-2.5 5.5h-6.5l-2 -5.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 10l9.5 3l9.5 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v10l6 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 21l6 -8\"}}]})(props);\n};\nexport function TbCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12l5 5l10 -10\"}}]})(props);\n};\nexport function TbCheckbox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"9 11 12 14 20 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12v6a2 2 0 0 1 -2 2h-12a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 2 -2h9\"}}]})(props);\n};\nexport function TbChecklist (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.615 20h-2.615a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 19l2 2l4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 8h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12h2\"}}]})(props);\n};\nexport function TbChecks (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12l5 5l10 -10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 12l5 5m5 -5l5 -5\"}}]})(props);\n};\nexport function TbCheckupList (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h-2a2 2 0 0 0 -2 2v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-12a2 2 0 0 0 -2 -2h-2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"3\",\"width\":\"6\",\"height\":\"4\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 14h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 16l1 1l3 -3\"}}]})(props);\n};\nexport function TbCheese (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.519 20.008l16.481 -.008v-3.5a2 2 0 1 1 0 -4v-3.5h-16.722\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 9l-9.385 -4.992c-2.512 .12 -4.758 1.42 -6.327 3.425c-1.423 1.82 -2.288 4.221 -2.288 6.854c0 2.117 .56 4.085 1.519 5.721\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 13v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 16v.01\"}}]})(props);\n};\nexport function TbChevronDownLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8v8h8\"}}]})(props);\n};\nexport function TbChevronDownRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8v8h-8\"}}]})(props);\n};\nexport function TbChevronDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"6 9 12 15 18 9\"}}]})(props);\n};\nexport function TbChevronLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"15 6 9 12 15 18\"}}]})(props);\n};\nexport function TbChevronRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"9 6 15 12 9 18\"}}]})(props);\n};\nexport function TbChevronUpLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16v-8h8\"}}]})(props);\n};\nexport function TbChevronUpRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8h8v8\"}}]})(props);\n};\nexport function TbChevronUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"6 15 12 9 18 15\"}}]})(props);\n};\nexport function TbChevronsDownLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 5v8h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 9v8h8\"}}]})(props);\n};\nexport function TbChevronsDownRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 5v8h-8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 9v8h-8\"}}]})(props);\n};\nexport function TbChevronsDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"7 7 12 12 17 7\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"7 13 12 18 17 13\"}}]})(props);\n};\nexport function TbChevronsLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"11 7 6 12 11 17\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"17 7 12 12 17 17\"}}]})(props);\n};\nexport function TbChevronsRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"7 7 12 12 7 17\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"13 7 18 12 13 17\"}}]})(props);\n};\nexport function TbChevronsUpLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 15v-8h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 19v-8h8\"}}]})(props);\n};\nexport function TbChevronsUpRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 7h8v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 11h8v8\"}}]})(props);\n};\nexport function TbChevronsUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"7 11 12 6 17 11\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"7 17 12 12 17 17\"}}]})(props);\n};\nexport function TbChristmasTree (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3l4 4l-2 1l4 4l-3 1l4 4h-14l4 -4l-3 -1l4 -4l-2 -1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 17v3a1 1 0 0 1 -1 1h-2a1 1 0 0 1 -1 -1v-3\"}}]})(props);\n};\nexport function TbCircle0 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8a2 2 0 0 1 2 2v4a2 2 0 1 1 -4 0v-4a2 2 0 0 1 2 -2z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbCircle1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 16v-8l-2 2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbCircle2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10a2 2 0 1 1 4 0c0 .591 -.417 1.318 -.816 1.858l-3.184 4.143l4 0\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbCircle3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12a2 2 0 1 0 -2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 14a2 2 0 1 0 2 -2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbCircle4 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 16v-8l-4 6h5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbCircle5 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 16h2a2 2 0 1 0 0 -4h-2v-4h4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbCircle6 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"14\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10a2 2 0 1 0 -4 0v4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbCircle7 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 8h4l-2 8\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbCircle8 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"10\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"14\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbCircle9 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"10\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 14a2 2 0 1 0 4 0v-4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbCircleCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12l2 2l4 -4\"}}]})(props);\n};\nexport function TbCircleDashed (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.56 3.69a9 9 0 0 0 -2.92 1.95\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.69 8.56a9 9 0 0 0 -.69 3.44\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.69 15.44a9 9 0 0 0 1.95 2.92\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.56 20.31a9 9 0 0 0 3.44 .69\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.44 20.31a9 9 0 0 0 2.92 -1.95\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.31 15.44a9 9 0 0 0 .69 -3.44\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.31 8.56a9 9 0 0 0 -1.95 -2.92\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.44 3.69a9 9 0 0 0 -3.44 -.69\"}}]})(props);\n};\nexport function TbCircleDot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbCircleDotted (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7.5\",\"y1\":\"4.21\",\"x2\":\"7.5\",\"y2\":\"4.22\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4.21\",\"y1\":\"7.5\",\"x2\":\"4.21\",\"y2\":\"7.51\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"12\",\"x2\":\"3\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4.21\",\"y1\":\"16.5\",\"x2\":\"4.21\",\"y2\":\"16.51\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7.5\",\"y1\":\"19.79\",\"x2\":\"7.5\",\"y2\":\"19.8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"21\",\"x2\":\"12\",\"y2\":\"21.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16.5\",\"y1\":\"19.79\",\"x2\":\"16.5\",\"y2\":\"19.8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19.79\",\"y1\":\"16.5\",\"x2\":\"19.79\",\"y2\":\"16.51\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"12\",\"x2\":\"21\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19.79\",\"y1\":\"7.5\",\"x2\":\"19.79\",\"y2\":\"7.51\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16.5\",\"y1\":\"4.21\",\"x2\":\"16.5\",\"y2\":\"4.22\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"3.01\"}}]})(props);\n};\nexport function TbCircleHalf2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14l7 -7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 19l8.5 -8.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9l4.5 -4.5\"}}]})(props);\n};\nexport function TbCircleHalfVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h18\"}}]})(props);\n};\nexport function TbCircleHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v18\"}}]})(props);\n};\nexport function TbCircleMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"12\",\"x2\":\"15\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbCircleOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.042 16.045a9 9 0 0 0 -12.087 -12.087m-2.318 1.677a9 9 0 1 0 12.725 12.73\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCirclePlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"12\",\"x2\":\"15\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"9\",\"x2\":\"12\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbCircleRectangleOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10h3v3m-3 1h-7v-4h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.042 16.045a9 9 0 0 0 -12.087 -12.087m-2.318 1.677a9 9 0 1 0 12.725 12.73\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCircleRectangle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 10h10v4h-10z\"}}]})(props);\n};\nexport function TbCircleSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9.5\",\"cy\":\"9.5\",\"r\":\"6.5\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"10\",\"y\":\"10\",\"width\":\"11\",\"height\":\"11\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbCircleTriangle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20l7 -12h-14z\"}}]})(props);\n};\nexport function TbCircleX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10l4 4m0 -4l-4 4\"}}]})(props);\n};\nexport function TbCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbCircles (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"7\",\"r\":\"4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6.5\",\"cy\":\"17\",\"r\":\"4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17.5\",\"cy\":\"17\",\"r\":\"4\"}}]})(props);\n};\nexport function TbClearAll (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 6h12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12h12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18h12\"}}]})(props);\n};\nexport function TbClearFormatting (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 15l4 4m0 -4l-4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 6v-1h11v1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"19\",\"x2\":\"11\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"5\",\"x2\":\"9\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbClick (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"12\",\"x2\":\"6\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7.8\",\"y1\":\"7.8\",\"x2\":\"5.6\",\"y2\":\"5.6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16.2\",\"y1\":\"7.8\",\"x2\":\"18.4\",\"y2\":\"5.6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7.8\",\"y1\":\"16.2\",\"x2\":\"5.6\",\"y2\":\"18.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l9 3l-4 2l-2 4l-3 -9\"}}]})(props);\n};\nexport function TbClipboardCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h-2a2 2 0 0 0 -2 2v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-12a2 2 0 0 0 -2 -2h-2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"3\",\"width\":\"6\",\"height\":\"4\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 14l2 2l4 -4\"}}]})(props);\n};\nexport function TbClipboardList (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h-2a2 2 0 0 0 -2 2v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-12a2 2 0 0 0 -2 -2h-2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"3\",\"width\":\"6\",\"height\":\"4\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"12\",\"x2\":\"9.01\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"12\",\"x2\":\"15\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"16\",\"x2\":\"9.01\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"16\",\"x2\":\"15\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbClipboardOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.575 5.597a1.994 1.994 0 0 0 -.575 1.403v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2m0 -4v-8a2 2 0 0 0 -2 -2h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5a2 2 0 0 1 2 -2h2a2 2 0 1 1 0 4h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbClipboardPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h-2a2 2 0 0 0 -2 2v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-12a2 2 0 0 0 -2 -2h-2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"3\",\"width\":\"6\",\"height\":\"4\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 14h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v4\"}}]})(props);\n};\nexport function TbClipboardText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h-2a2 2 0 0 0 -2 2v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-12a2 2 0 0 0 -2 -2h-2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"3\",\"width\":\"6\",\"height\":\"4\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 16h6\"}}]})(props);\n};\nexport function TbClipboardX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h-2a2 2 0 0 0 -2 2v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-12a2 2 0 0 0 -2 -2h-2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"3\",\"width\":\"6\",\"height\":\"4\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12l4 4m0 -4l-4 4\"}}]})(props);\n};\nexport function TbClipboard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h-2a2 2 0 0 0 -2 2v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-12a2 2 0 0 0 -2 -2h-2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"3\",\"width\":\"6\",\"height\":\"4\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbClock2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v5l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 12h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 19v1\"}}]})(props);\n};\nexport function TbClockOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.042 16.045a9 9 0 0 0 -12.087 -12.087m-2.318 1.677a9 9 0 1 0 12.725 12.73\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbClock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"12 7 12 12 15 15\"}}]})(props);\n};\nexport function TbCloudComputing (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.657 16c-2.572 0 -4.657 -2.007 -4.657 -4.483c0 -2.475 2.085 -4.482 4.657 -4.482c.393 -1.762 1.794 -3.2 3.675 -3.773c1.88 -.572 3.956 -.193 5.444 .996c1.488 1.19 2.162 3.007 1.77 4.769h.99c1.913 0 3.464 1.56 3.464 3.486c0 1.927 -1.551 3.487 -3.465 3.487h-11.878\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 16v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16v4a1 1 0 0 1 -1 1h-4\"}}]})(props);\n};\nexport function TbCloudDataConnection (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 9.897c0 -1.714 1.46 -3.104 3.26 -3.104c.275 -1.22 1.255 -2.215 2.572 -2.611c1.317 -.397 2.77 -.134 3.811 .69c1.042 .822 1.514 2.08 1.239 3.3h.693a2.42 2.42 0 0 1 2.425 2.414a2.42 2.42 0 0 1 -2.425 2.414h-8.315c-1.8 0 -3.26 -1.39 -3.26 -3.103z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13v3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 18h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 18h7\"}}]})(props);\n};\nexport function TbCloudDownload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 18a3.5 3.5 0 0 0 0 -7h-1a5 4.5 0 0 0 -11 -2a4.6 4.4 0 0 0 -2.1 8.4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"13\",\"x2\":\"12\",\"y2\":\"22\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"9 19 12 22 15 19\"}}]})(props);\n};\nexport function TbCloudFog (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 16a4.6 4.4 0 0 1 0 -9a5 4.5 0 0 1 11 2h1a3.5 3.5 0 0 1 0 7h-12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"20\",\"x2\":\"19\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbCloudLockOpen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 18a3.5 3.5 0 0 0 0 -7h-1c.397 -1.768 -.285 -3.593 -1.788 -4.787c-1.503 -1.193 -3.6 -1.575 -5.5 -1s-3.315 2.019 -3.712 3.787c-2.199 -.088 -4.155 1.326 -4.666 3.373c-.512 2.047 .564 4.154 2.566 5.027\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"15\",\"width\":\"8\",\"height\":\"5\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 15v-2a2 2 0 0 1 3.736 -.994\"}}]})(props);\n};\nexport function TbCloudLock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 18a3.5 3.5 0 0 0 0 -7h-1c.397 -1.768 -.285 -3.593 -1.788 -4.787c-1.503 -1.193 -3.6 -1.575 -5.5 -1s-3.315 2.019 -3.712 3.787c-2.199 -.088 -4.155 1.326 -4.666 3.373c-.512 2.047 .564 4.154 2.566 5.027\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"15\",\"width\":\"8\",\"height\":\"5\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 15v-2a2 2 0 1 1 4 0v2\"}}]})(props);\n};\nexport function TbCloudOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 18h-11c-2.598 0 -4.705 -2.015 -4.705 -4.5s2.107 -4.5 4.705 -4.5c.112 -.5 .305 -.973 .568 -1.408m2.094 -1.948c.329 -.174 .68 -.319 1.05 -.43c1.9 -.576 3.997 -.194 5.5 1c1.503 1.192 2.185 3.017 1.788 4.786h1a3.5 3.5 0 0 1 2.212 6.212\"}}]})(props);\n};\nexport function TbCloudRain (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 18a4.6 4.4 0 0 1 0 -9a5 4.5 0 0 1 11 2h1a3.5 3.5 0 0 1 0 7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 13v2m0 3v2m4 -5v2m0 3v2\"}}]})(props);\n};\nexport function TbCloudSnow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 18a4.6 4.4 0 0 1 0 -9a5 4.5 0 0 1 11 2h1a3.5 3.5 0 0 1 0 7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 15v.01m0 3v.01m0 3v.01m4 -4v.01m0 3v.01\"}}]})(props);\n};\nexport function TbCloudStorm (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 18a4.6 4.4 0 0 1 0 -9a5 4.5 0 0 1 11 2h1a3.5 3.5 0 0 1 0 7h-1\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"13 14 11 18 14 18 12 22\"}}]})(props);\n};\nexport function TbCloudUpload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 18a4.6 4.4 0 0 1 0 -9a5 4.5 0 0 1 11 2h1a3.5 3.5 0 0 1 0 7h-1\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"9 15 12 12 15 15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbCloud (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.657 18c-2.572 0 -4.657 -2.007 -4.657 -4.483c0 -2.475 2.085 -4.482 4.657 -4.482c.393 -1.762 1.794 -3.2 3.675 -3.773c1.88 -.572 3.956 -.193 5.444 .996c1.488 1.19 2.162 3.007 1.77 4.769h.99c1.913 0 3.464 1.56 3.464 3.486c0 1.927 -1.551 3.487 -3.465 3.487h-11.878\"}}]})(props);\n};\nexport function TbClubs (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3a4 4 0 0 1 3.164 6.447a4 4 0 1 1 -1.164 6.198v1.355l1 4h-6l1 -4l.001 -1.355a4 4 0 1 1 -1.164 -6.199a4 4 0 0 1 3.163 -6.446z\"}}]})(props);\n};\nexport function TbCodeMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 19a2 2 0 0 1 -2 -2v-4l-1 -1l1 -1v-4a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 19a2 2 0 0 0 2 -2v-4l1 -1l-1 -1v-4a2 2 0 0 0 -2 -2\"}}]})(props);\n};\nexport function TbCodeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 8l-4 4l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 8l4 4l-2.5 2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4l-1.201 4.805m-.802 3.207l-1.997 7.988\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCodePlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 19a2 2 0 0 1 -2 -2v-4l-1 -1l1 -1v-4a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 19a2 2 0 0 0 2 -2v-4l1 -1l-1 -1v-4a2 2 0 0 0 -2 -2\"}}]})(props);\n};\nexport function TbCode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"7 8 3 12 7 16\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"17 8 21 12 17 16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"4\",\"x2\":\"10\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbCoffeeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 14c.83 .642 2.077 1.017 3.5 1c1.423 .017 2.67 -.358 3.5 -1c.73 -.565 1.783 -.923 2.994 -.99\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 3c-.194 .14 -.364 .305 -.506 .49\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3a2.4 2.4 0 0 0 -1 2a2.4 2.4 0 0 0 1 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10h3v3m-.257 3.743a6.003 6.003 0 0 1 -5.743 4.257h-2a6 6 0 0 1 -6 -6v-5h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.116 16.124a3 3 0 0 0 -3.118 -4.953\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCoffee (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 14c.83 .642 2.077 1.017 3.5 1c1.423 .017 2.67 -.358 3.5 -1c.83 -.642 2.077 -1.017 3.5 -1c1.423 -.017 2.67 .358 3.5 1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 3a2.4 2.4 0 0 0 -1 2a2.4 2.4 0 0 0 1 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3a2.4 2.4 0 0 0 -1 2a2.4 2.4 0 0 0 1 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 10h14v5a6 6 0 0 1 -6 6h-2a6 6 0 0 1 -6 -6v-5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.746 16.726a3 3 0 1 0 .252 -5.555\"}}]})(props);\n};\nexport function TbCoinOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.8 9a2 2 0 0 0 -1.8 -1h-1m-2.82 1.171a2 2 0 0 0 1.82 2.829h1m2.824 2.822a2 2 0 0 1 -1.824 1.178h-2a2 2 0 0 1 -1.8 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.042 16.045a9 9 0 0 0 -12.087 -12.087m-2.318 1.677a9 9 0 1 0 12.725 12.73\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6v2m0 8v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCoin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.8 9a2 2 0 0 0 -1.8 -1h-2a2 2 0 0 0 0 4h2a2 2 0 0 1 0 4h-2a2 2 0 0 1 -1.8 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6v2m0 8v2\"}}]})(props);\n};\nexport function TbColorPickerOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7l6 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.001 7.999l3.699 -3.699a1 1 0 0 1 1.4 0l2.6 2.6a1 1 0 0 1 0 1.4l-3.702 3.702m-1.998 1.998l-6 6h-4v-4l6.002 -6.002\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbColorPicker (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7l6 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16l11.7 -11.7a1 1 0 0 1 1.4 0l2.6 2.6a1 1 0 0 1 0 1.4l-11.7 11.7h-4v-4z\"}}]})(props);\n};\nexport function TbColorSwatchOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 13v4a4 4 0 0 0 6.832 2.825m1.168 -2.825v-12a2 2 0 0 0 -2 -2h-4a2 2 0 0 0 -2 2v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 7.35l-2 -2a2 2 0 0 0 -2.11 -.461m-2.13 1.874l-1.416 1.415a2 2 0 0 0 0 2.828l9 9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.3 13h-2.3a2 2 0 0 0 -2 2v4a2 2 0 0 0 2 2h12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbColorSwatch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 3h-4a2 2 0 0 0 -2 2v12a4 4 0 0 0 8 0v-12a2 2 0 0 0 -2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 7.35l-2 -2a2 2 0 0 0 -2.828 0l-2.828 2.828a2 2 0 0 0 0 2.828l9 9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.3 13h-2.3a2 2 0 0 0 -2 2v4a2 2 0 0 0 2 2h12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"17\",\"x2\":\"17\",\"y2\":\"17.01\"}}]})(props);\n};\nexport function TbColumnInsertLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4h4a1 1 0 0 1 1 1v14a1 1 0 0 1 -1 1h-4a1 1 0 0 1 -1 -1v-14a1 1 0 0 1 1 -1z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"9\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"10\",\"x2\":\"7\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbColumnInsertRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 4h4a1 1 0 0 1 1 1v14a1 1 0 0 1 -1 1h-4a1 1 0 0 1 -1 -1v-14a1 1 0 0 1 1 -1z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"12\",\"x2\":\"19\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"10\",\"x2\":\"17\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbColumnsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 10h5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 14h5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18h5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.5 6h5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.5 10h5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 14h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.5 18h3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbColumns (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"6\",\"x2\":\"9.5\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"10\",\"x2\":\"9.5\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"14\",\"x2\":\"9.5\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"18\",\"x2\":\"9.5\",\"y2\":\"18\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14.5\",\"y1\":\"6\",\"x2\":\"20\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14.5\",\"y1\":\"10\",\"x2\":\"20\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14.5\",\"y1\":\"14\",\"x2\":\"20\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14.5\",\"y1\":\"18\",\"x2\":\"20\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbComet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.5 18.5l-3 1.5l.5 -3.5l-2 -2l3 -.5l1.5 -3l1.5 3l3 .5l-2 2l.5 3.5z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"11\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"4\",\"x2\":\"12.5\",\"y2\":\"7.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"9\",\"x2\":\"7.5\",\"y2\":\"12.5\"}}]})(props);\n};\nexport function TbCommand (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 9a2 2 0 1 1 2 -2v10a2 2 0 1 1 -2 -2h10a2 2 0 1 1 -2 2v-10a2 2 0 1 1 2 2h-10\"}}]})(props);\n};\nexport function TbCompassOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.999 9l3.001 -1l-1.002 3.005m-.998 2.995l-6 2l2 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.042 16.045a9 9 0 0 0 -12.087 -12.087m-2.318 1.677a9 9 0 1 0 12.725 12.73\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 19v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 12h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCompass (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"8 16 10 10 16 8 14 14 8 16\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"19\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"12\",\"x2\":\"5\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"12\",\"x2\":\"21\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbComponentsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12l3 3l3 -3l-3 -3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.5 14.5l2.5 -2.5l-3 -3l-2.5 2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.499 8.501l2.501 -2.501l-3 -3l-2.5 2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18l3 3l3 -3l-3 -3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbComponents (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12l3 3l3 -3l-3 -3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 12l3 3l3 -3l-3 -3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 6l3 3l3 -3l-3 -3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18l3 3l3 -3l-3 -3z\"}}]})(props);\n};\nexport function TbCone2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"ellipse\",\"attr\":{\"cx\":\"12\",\"cy\":\"7\",\"rx\":\"7\",\"ry\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 7v.5l-7 12.5l-7 -12.5v-.5\"}}]})(props);\n};\nexport function TbCone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"ellipse\",\"attr\":{\"transform\":\"matrix(1 0 0 -1 0 34)\",\"cx\":\"12\",\"cy\":\"17\",\"rx\":\"7\",\"ry\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 17v-.5l-7 -12.5l-7 12.5v.5\"}}]})(props);\n};\nexport function TbConfetti (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 5h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.5 4l-.5 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 5h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 4v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 9l-1 1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 13l2 -.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 19h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 18v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 16.518l-6.518 -6.518l-4.39 9.58a1.003 1.003 0 0 0 1.329 1.329l9.579 -4.39z\"}}]})(props);\n};\nexport function TbContainerOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 4v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 20v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 16v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 8v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.297 4.289a0.997 .997 0 0 1 .703 -.289h6a1 1 0 0 1 1 1v7m0 4v3a1 1 0 0 1 -1 1h-6a1 1 0 0 1 -1 -1v-11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbContainer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 4v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 20v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 16v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 8v.01\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"4\",\"width\":\"8\",\"height\":\"16\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8v.01\"}}]})(props);\n};\nexport function TbContrast2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18h2a6 6 0 0 0 6 -6a6 6 0 0 1 6 -6h2\"}}]})(props);\n};\nexport function TbContrast (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17a5 5 0 0 0 0 -10v10\"}}]})(props);\n};\nexport function TbCookieOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.192 18.187a3 3 0 0 1 -.976 .652c-1.048 .263 -1.787 .483 -2.216 .661c-.475 .197 -1.092 .538 -1.852 1.024a3 3 0 0 1 -2.296 0c-.802 -.503 -1.419 -.844 -1.852 -1.024c-.471 -.195 -1.21 -.415 -2.216 -.66a3 3 0 0 1 -1.623 -1.624c-.265 -1.052 -.485 -1.79 -.661 -2.216c-.198 -.479 -.54 -1.096 -1.024 -1.852a3 3 0 0 1 0 -2.296c.48 -.744 .82 -1.361 1.024 -1.852c.171 -.413 .391 -1.152 .66 -2.216a3 3 0 0 1 .649 -.971m2.821 -1.174c.14 -.049 .263 -.095 .37 -.139c.458 -.19 1.075 -.531 1.852 -1.024a3 3 0 0 1 2.296 0l2.667 1.104a4 4 0 0 0 4.656 6.14l.053 .132a3 3 0 0 1 0 2.296c-.497 .786 -.838 1.404 -1.024 1.852a6.579 6.579 0 0 0 -.135 .36\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCookie (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 14v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 8v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.148 3.476l2.667 1.104a4 4 0 0 0 4.656 6.14l.053 .132a3 3 0 0 1 0 2.296c-.497 .786 -.838 1.404 -1.024 1.852c-.189 .456 -.409 1.194 -.66 2.216a3 3 0 0 1 -1.624 1.623c-1.048 .263 -1.787 .483 -2.216 .661c-.475 .197 -1.092 .538 -1.852 1.024a3 3 0 0 1 -2.296 0c-.802 -.503 -1.419 -.844 -1.852 -1.024c-.471 -.195 -1.21 -.415 -2.216 -.66a3 3 0 0 1 -1.623 -1.624c-.265 -1.052 -.485 -1.79 -.661 -2.216c-.198 -.479 -.54 -1.096 -1.024 -1.852a3 3 0 0 1 0 -2.296c.48 -.744 .82 -1.361 1.024 -1.852c.171 -.413 .391 -1.152 .66 -2.216a3 3 0 0 1 1.624 -1.623c1.032 -.256 1.77 -.476 2.216 -.661c.458 -.19 1.075 -.531 1.852 -1.024a3 3 0 0 1 2.296 0z\"}}]})(props);\n};\nexport function TbCopyOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.414 19.415a1.994 1.994 0 0 1 -1.414 .585h-8a2 2 0 0 1 -2 -2v-8c0 -.554 .225 -1.055 .589 -1.417m3.411 -.583h6a2 2 0 0 1 2 2v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8v-2a2 2 0 0 0 -2 -2h-6m-3.418 .59c-.36 .36 -.582 .86 -.582 1.41v8a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCopy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"8\",\"width\":\"12\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2\"}}]})(props);\n};\nexport function TbCopyleftOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.303 9.3a3.01 3.01 0 0 1 1.405 1.406m-.586 3.413a3.016 3.016 0 0 1 -4.122 .131\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.042 16.045a9 9 0 0 0 -12.087 -12.087m-2.318 1.677a9 9 0 1 0 12.725 12.73\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCopyleft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 9.75a3.016 3.016 0 0 1 4.163 .173a2.993 2.993 0 0 1 0 4.154a3.016 3.016 0 0 1 -4.163 .173\"}}]})(props);\n};\nexport function TbCopyrightOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 9.75a3.016 3.016 0 0 0 -.711 -.466m-3.41 .596a2.993 2.993 0 0 0 -.042 4.197a3.016 3.016 0 0 0 4.163 .173\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.042 16.045a9 9 0 0 0 -12.087 -12.087m-2.318 1.677a9 9 0 1 0 12.725 12.73\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCopyright (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 9.75a3.016 3.016 0 0 0 -4.163 .173a2.993 2.993 0 0 0 0 4.154a3.016 3.016 0 0 0 4.163 .173\"}}]})(props);\n};\nexport function TbCornerDownLeftDouble (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 5v6a3 3 0 0 1 -3 3h-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 10l-4 4l4 4m-5 -8l-4 4l4 4\"}}]})(props);\n};\nexport function TbCornerDownLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 6v6a3 3 0 0 1 -3 3h-10l4 -4m0 8l-4 -4\"}}]})(props);\n};\nexport function TbCornerDownRightDouble (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 5v6a3 3 0 0 0 3 3h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10l4 4l-4 4m5 -8l4 4l-4 4\"}}]})(props);\n};\nexport function TbCornerDownRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6v6a3 3 0 0 0 3 3h10l-4 -4m0 8l4 -4\"}}]})(props);\n};\nexport function TbCornerLeftDownDouble (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 4h-6a3 3 0 0 0 -3 3v7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 10l-4 4l-4 -4m8 5l-4 4l-4 -4\"}}]})(props);\n};\nexport function TbCornerLeftDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 6h-6a3 3 0 0 0 -3 3v10l-4 -4m8 0l-4 4\"}}]})(props);\n};\nexport function TbCornerLeftUpDouble (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 19h-6a3 3 0 0 1 -3 -3v-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 13l-4 -4l-4 4m8 -5l-4 -4l-4 4\"}}]})(props);\n};\nexport function TbCornerLeftUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 18h-6a3 3 0 0 1 -3 -3v-10l-4 4m8 0l-4 -4\"}}]})(props);\n};\nexport function TbCornerRightDownDouble (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h6a3 3 0 0 1 3 3v7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10l4 4l4 -4m-8 5l4 4l4 -4\"}}]})(props);\n};\nexport function TbCornerRightDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6h6a3 3 0 0 1 3 3v10l-4 -4m8 0l-4 4\"}}]})(props);\n};\nexport function TbCornerRightUpDouble (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 19h6a3 3 0 0 0 3 -3v-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 13l4 -4l4 4m-8 -5l4 -4l4 4\"}}]})(props);\n};\nexport function TbCornerRightUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 18h6a3 3 0 0 0 3 -3v-10l-4 4m8 0l-4 -4\"}}]})(props);\n};\nexport function TbCornerUpLeftDouble (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 18v-6a3 3 0 0 0 -3 -3h-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 13l-4 -4l4 -4m-5 8l-4 -4l4 -4\"}}]})(props);\n};\nexport function TbCornerUpLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 18v-6a3 3 0 0 0 -3 -3h-10l4 -4m0 8l-4 -4\"}}]})(props);\n};\nexport function TbCornerUpRightDouble (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18v-6a3 3 0 0 1 3 -3h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 13l4 -4l-4 -4m5 8l4 -4l-4 -4\"}}]})(props);\n};\nexport function TbCornerUpRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 18v-6a3 3 0 0 1 3 -3h10l-4 -4m0 8l4 -4\"}}]})(props);\n};\nexport function TbCpu2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"5\",\"width\":\"14\",\"height\":\"14\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 10v-2h2m6 6v2h-2m-4 0h-2v-2m8 -4v-2h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 10h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 14h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 3v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 10h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 14h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 21v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 21v-2\"}}]})(props);\n};\nexport function TbCpuOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h9a1 1 0 0 1 1 1v9m-.292 3.706a0.997 .997 0 0 1 -.708 .294h-12a1 1 0 0 1 -1 -1v-12c0 -.272 .108 -.518 .284 -.698\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 9h2v2m0 4h-6v-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 10h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 14h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 3v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 10h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 14h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 21v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 21v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCpu (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"5\",\"width\":\"14\",\"height\":\"14\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 9h6v6h-6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 10h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 14h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 3v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 10h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 14h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 21v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 21v-2\"}}]})(props);\n};\nexport function TbCraneOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 21h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 21v-12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5v-2l-1.001 1.001\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.005 5.995l-3.005 3.005h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 9h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 3l10 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 9v4a2 2 0 0 1 2 2m-2 2a2 2 0 0 1 -2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCrane (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 21h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 21v-18l-6 6h18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 3l10 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 9v4a2 2 0 1 1 -2 2\"}}]})(props);\n};\nexport function TbCreativeCommonsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.638 5.634a9 9 0 1 0 12.723 12.733m1.686 -2.332a9 9 0 0 0 -12.093 -12.077\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 10.5a2.187 2.187 0 0 0 -2.914 .116a1.928 1.928 0 0 0 0 2.768a2.188 2.188 0 0 0 2.914 .116\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.5 10.5a2.194 2.194 0 0 0 -2.309 -.302\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCreativeCommons (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 10.5c-.847 -.71 -2.132 -.658 -2.914 .116a1.928 1.928 0 0 0 0 2.768c.782 .774 2.067 .825 2.914 .116\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.5 10.5c-.847 -.71 -2.132 -.658 -2.914 .116a1.928 1.928 0 0 0 0 2.768c.782 .774 2.067 .825 2.914 .116\"}}]})(props);\n};\nexport function TbCreditCardOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h9a3 3 0 0 1 3 3v8a3 3 0 0 1 -.128 .87\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.87 18.872a3 3 0 0 1 -.87 .128h-12a3 3 0 0 1 -3 -3v-8c0 -1.352 .894 -2.495 2.124 -2.87\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"11\",\"x2\":\"11\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"11\",\"x2\":\"21\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"15\",\"x2\":\"7.01\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"15\",\"x2\":\"13\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbCreditCard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"5\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"10\",\"x2\":\"21\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"15\",\"x2\":\"7.01\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"15\",\"x2\":\"13\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbCricket (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.105 18.79l-1.006 .992a4.159 4.159 0 0 1 -6.038 -5.715l.157 -.166l8.282 -8.401l1.5 1.5l3.45 -3.391a2.08 2.08 0 0 1 3.057 2.815l-.116 .126l-3.391 3.45l1.5 1.5l-3.668 3.617\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 7.5l6 6\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14\",\"cy\":\"18\",\"r\":\"3\"}}]})(props);\n};\nexport function TbCrop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 5v10a1 1 0 0 0 1 1h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 8h10a1 1 0 0 1 1 1v10\"}}]})(props);\n};\nexport function TbCrossOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12h3v-4h-5v-5h-4v3m-2 2h-3v4h5v9h4v-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCross (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 21h4v-9h5v-4h-5v-5h-4v5h-5v4h5z\"}}]})(props);\n};\nexport function TbCrosshair (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8v-2a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16v2a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2a2 2 0 0 1 2 2v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h2a2 2 0 0 0 2 -2v-2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"12\",\"x2\":\"15\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"9\",\"x2\":\"12\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbCrownOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 18h-13l-1.865 -9.327a0.25 .25 0 0 1 .4 -.244l4.465 3.571l1.6 -2.4m1.596 -2.394l.804 -1.206l4 6l4.464 -3.571a0.25 .25 0 0 1 .401 .244l-1.363 6.818\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbCrown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6l4 6l5 -4l-2 10h-14l-2 -10l5 4z\"}}]})(props);\n};\nexport function TbCrutchesOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.178 4.174a2 2 0 0 1 1.822 -1.174h4a2 2 0 1 1 0 4h-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 21h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-4.092a3 3 0 0 1 .504 -1.664l.992 -1.488a3 3 0 0 0 .097 -.155m.407 -3.601v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-4.092a3 3 0 0 0 -.504 -1.664l-.992 -1.488a3 3 0 0 1 -.504 -1.664v-2.092\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 11h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCrutches (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"3\",\"width\":\"8\",\"height\":\"4\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 21h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-4.092a3 3 0 0 1 .504 -1.664l.992 -1.488a3 3 0 0 0 .504 -1.664v-5.092\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-4.092a3 3 0 0 0 -.504 -1.664l-.992 -1.488a3 3 0 0 1 -.504 -1.664v-5.092\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 11h4\"}}]})(props);\n};\nexport function TbCupOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8h-3v3h6m4 0h4v-3h-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.5 11l-.323 2.154m-.525 3.497l-.652 4.349h-8l-1.5 -10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8v-1c0 -.296 .064 -.577 .18 -.83m2.82 -1.17h7a2 2 0 0 1 2 2v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 5v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCup (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 11h14v-3h-14z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.5 11l-1.5 10h-8l-1.5 -10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8v-1a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 5v-2\"}}]})(props);\n};\nexport function TbCurling (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"9\",\"width\":\"16\",\"height\":\"10\",\"rx\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 14h16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 5h6a2 2 0 0 1 2 2v2\"}}]})(props);\n};\nexport function TbCurlyLoop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 8c-4 0 -7 2 -7 5a3 3 0 0 0 6 0c0 -3 -2.5 -5 -8 -5s-8 2 -8 5a3 3 0 0 0 6 0c0 -3 -3 -5 -7 -5\"}}]})(props);\n};\nexport function TbCurrencyBahraini (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 10v1a4 4 0 0 0 4 4h2a2 2 0 0 0 2 -2v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 19.01v-.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 15.01v-.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 15h2.004a2 2 0 0 0 1.649 -3.131l-2.653 -3.869\"}}]})(props);\n};\nexport function TbCurrencyBaht (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 6h5a3 3 0 0 1 3 3v.143a2.857 2.857 0 0 1 -2.857 2.857h-5.143\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12h5a3 3 0 0 1 3 3v.143a2.857 2.857 0 0 1 -2.857 2.857h-5.143\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 4v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 18v2\"}}]})(props);\n};\nexport function TbCurrencyBitcoin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6h8a3 3 0 0 1 0 6a3 3 0 0 1 0 6h-8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"6\",\"x2\":\"8\",\"y2\":\"18\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"12\",\"x2\":\"14\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"3\",\"x2\":\"9\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"3\",\"x2\":\"13\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"18\",\"x2\":\"9\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"18\",\"x2\":\"13\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbCurrencyCent (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.007 7.54a5.965 5.965 0 0 0 -4.008 -1.54a5.996 5.996 0 0 0 -5.992 6c0 3.314 2.682 6 5.992 6a5.965 5.965 0 0 0 4.004 -1.536\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6v-2\"}}]})(props);\n};\nexport function TbCurrencyDinar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 20.01v-.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 13l2.386 -.9a1 1 0 0 0 -.095 -1.902l-1.514 -.404a1 1 0 0 1 -.102 -1.9l2.325 -.894\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 14v1a3 3 0 0 0 3 3h4.161a3 3 0 0 0 2.983 -3.32l-1.144 -10.68\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 17l1 1h2.004a2 2 0 0 0 1.649 -3.131l-2.653 -3.869\"}}]})(props);\n};\nexport function TbCurrencyDirham (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 19h-3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.599 16.479a1.5 1.5 0 1 0 -1.099 2.521\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 4v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 13h1.888a1.5 1.5 0 0 0 1.296 -2.256l-2.184 -3.744\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 13.01v-.01\"}}]})(props);\n};\nexport function TbCurrencyDogecoin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 18h6a6 6 0 1 0 0 -12h-6\"}}]})(props);\n};\nexport function TbCurrencyDollarAustralian (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 18l3.279 -11.476a0.75 .75 0 0 1 1.442 0l3.279 11.476\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 6h-4a3 3 0 0 0 0 6h1a3 3 0 0 1 0 6h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 20v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 6v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 14h5\"}}]})(props);\n};\nexport function TbCurrencyDollarCanadian (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 6h-4a3 3 0 0 0 0 6h1a3 3 0 0 1 0 6h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 18h-1a6 6 0 1 1 0 -12h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 20v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 6v-2\"}}]})(props);\n};\nexport function TbCurrencyDollarSingapore (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 6h-4a3 3 0 0 0 0 6h1a3 3 0 0 1 0 6h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6h-4a3 3 0 1 0 0 6h1a3 3 0 0 1 0 6h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 20v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 6v-2\"}}]})(props);\n};\nexport function TbCurrencyDollar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.7 8a3 3 0 0 0 -2.7 -2h-4a3 3 0 0 0 0 6h4a3 3 0 0 1 0 6h-4a3 3 0 0 1 -2.7 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v3m0 12v3\"}}]})(props);\n};\nexport function TbCurrencyEthereum (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12l6 -9l6 9l-6 9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12l6 -3l6 3l-6 2z\"}}]})(props);\n};\nexport function TbCurrencyEuro (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.2 7a6 7 0 1 0 0 10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 10h-8m0 4h8\"}}]})(props);\n};\nexport function TbCurrencyForint (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 4h-4a3 3 0 0 0 -3 3v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 11h-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4v13a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 9h-5\"}}]})(props);\n};\nexport function TbCurrencyFrank (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 5h-6a2 2 0 0 0 -2 2v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 15h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 11h7\"}}]})(props);\n};\nexport function TbCurrencyKroneCzech (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12c3.5 0 6 -3 6 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12c3.5 0 6 3 6 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 6l-2 2l-2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 12h-2a3 3 0 0 0 0 6h2\"}}]})(props);\n};\nexport function TbCurrencyKroneDanish (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12c3.5 0 6 -3 6 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12c3.5 0 6 3 6 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 10v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 10a4 4 0 0 0 -4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 18.01v-.01\"}}]})(props);\n};\nexport function TbCurrencyKroneSwedish (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12c3.5 0 6 -3 6 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12c3.5 0 6 3 6 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 10v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 10a4 4 0 0 0 -4 4\"}}]})(props);\n};\nexport function TbCurrencyLeu (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 18h-7a3 3 0 0 1 -3 -3v-10\"}}]})(props);\n};\nexport function TbCurrencyLira (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5v15a7 7 0 0 0 7 -7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15l8 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 7l-8 4\"}}]})(props);\n};\nexport function TbCurrencyLitecoin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 19h-8.194a2 2 0 0 1 -1.98 -2.283l1.674 -11.717\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 9l-9 4\"}}]})(props);\n};\nexport function TbCurrencyNaira (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 18v-10.948a1.05 1.05 0 0 1 1.968 -.51l6.064 10.916a1.05 1.05 0 0 0 1.968 -.51v-10.948\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 10h14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 14h14\"}}]})(props);\n};\nexport function TbCurrencyPound (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 18.5a6 6 0 0 1 -5 0a6 6 0 0 0 -5 .5a3 3 0 0 0 2 -2.5v-7.5a4 4 0 0 1 7.45 -2m-2.55 6h-7\"}}]})(props);\n};\nexport function TbCurrencyReal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 6h-4a3 3 0 0 0 0 6h1a3 3 0 0 1 0 6h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18v-12h3a3 3 0 1 1 0 6h-3c5.5 0 5 4 6 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 6v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 20v-2\"}}]})(props);\n};\nexport function TbCurrencyRenminbi (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 9v8a2 2 0 1 0 4 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 9h-14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 5h-14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 9v4c0 2.5 -.667 4 -2 6\"}}]})(props);\n};\nexport function TbCurrencyRipple (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"7\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"17\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12h3l2 -2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 14.5l-2 -2.5\"}}]})(props);\n};\nexport function TbCurrencyRiyal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 9v2a2 2 0 1 1 -4 0v-1v1a2 2 0 1 1 -4 0v-1v4a2 2 0 1 1 -4 0v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 12.01v-.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 10v1a5 5 0 0 1 -5 5\"}}]})(props);\n};\nexport function TbCurrencyRubel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 19v-14h6a3 3 0 0 1 0 6h-8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 15h-8\"}}]})(props);\n};\nexport function TbCurrencyRupee (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 5h-11h3a4 4 0 0 1 0 8h-3l6 6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"9\",\"x2\":\"18\",\"y2\":\"9\"}}]})(props);\n};\nexport function TbCurrencyShekel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 18v-12h4a4 4 0 0 1 4 4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 6v12h-4a4 4 0 0 1 -4 -4v-4\"}}]})(props);\n};\nexport function TbCurrencyTaka (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16.5\",\"cy\":\"15.5\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7a2 2 0 1 1 4 0v9a3 3 0 0 0 6 0v-.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11h6\"}}]})(props);\n};\nexport function TbCurrencyTugrik (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 6h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6v13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 17l8 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 10l-8 3\"}}]})(props);\n};\nexport function TbCurrencyWon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6l3.245 11.358a0.85 .85 0 0 0 1.624 .035l3.131 -9.393l3.131 9.393a0.85 .85 0 0 0 1.624 -.035l3.245 -11.358\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 10h-18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 14h-18\"}}]})(props);\n};\nexport function TbCurrencyYen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 19v-7l-5 -7m10 0l-5 7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"17\",\"x2\":\"16\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"13\",\"x2\":\"16\",\"y2\":\"13\"}}]})(props);\n};\nexport function TbCurrencyZloty (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18h-7l7 -7h-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 18v-13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14.5l6 -3.5\"}}]})(props);\n};\nexport function TbCurrency (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 4l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 20l-3 -3\"}}]})(props);\n};\nexport function TbCurrentLocationOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.685 10.661c-.3 -.6 -.795 -1.086 -1.402 -1.374m-3.397 .584a3 3 0 1 0 4.24 4.245\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.357 6.33a8 8 0 1 0 11.301 11.326m1.642 -2.378a8 8 0 0 0 -10.597 -10.569\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 2v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 12h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCurrentLocation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"2\",\"x2\":\"12\",\"y2\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"20\",\"x2\":\"12\",\"y2\":\"22\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"12\",\"x2\":\"22\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"2\",\"y1\":\"12\",\"x2\":\"4\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbCursorOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4a3 3 0 0 1 3 3v1m0 9a3 3 0 0 1 -3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 4a3 3 0 0 0 -3 3v1m0 4v5a3 3 0 0 0 3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbCursorText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4a3 3 0 0 1 3 3v10a3 3 0 0 1 -3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 4a3 3 0 0 0 -3 3v10a3 3 0 0 0 3 3\"}}]})(props);\n};\nexport function TbCut (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"17\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"17\",\"r\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9.15\",\"y1\":\"14.85\",\"x2\":\"18\",\"y2\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"4\",\"x2\":\"14.85\",\"y2\":\"14.85\"}}]})(props);\n};\nexport function TbDashboard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"13\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13.45\",\"y1\":\"11.55\",\"x2\":\"15.5\",\"y2\":\"9.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.4 20a9 9 0 1 1 11.2 0z\"}}]})(props);\n};\nexport function TbDatabaseExport (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"ellipse\",\"attr\":{\"cx\":\"12\",\"cy\":\"6\",\"rx\":\"8\",\"ry\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6v6c0 1.657 3.582 3 8 3a19.84 19.84 0 0 0 3.302 -.267m4.698 -2.733v-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12v6c0 1.599 3.335 2.905 7.538 2.995m8.462 -6.995v-2m-6 7h7m-3 -3l3 3l-3 3\"}}]})(props);\n};\nexport function TbDatabaseImport (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"ellipse\",\"attr\":{\"cx\":\"12\",\"cy\":\"6\",\"rx\":\"8\",\"ry\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6v8m5.009 .783c.924 .14 1.933 .217 2.991 .217c4.418 0 8 -1.343 8 -3v-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.252 20.987c.246 .009 .496 .013 .748 .013c4.418 0 8 -1.343 8 -3v-6m-18 7h7m-3 -3l3 3l-3 3\"}}]})(props);\n};\nexport function TbDatabaseOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.983 8.978c3.955 -.182 7.017 -1.446 7.017 -2.978c0 -1.657 -3.582 -3 -8 -3c-1.661 0 -3.204 .19 -4.483 .515m-2.783 1.228c-.471 .382 -.734 .808 -.734 1.257c0 1.22 1.944 2.271 4.734 2.74\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6v6c0 1.657 3.582 3 8 3c.986 0 1.93 -.067 2.802 -.19m3.187 -.82c1.251 -.53 2.011 -1.228 2.011 -1.99v-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12v6c0 1.657 3.582 3 8 3c3.217 0 5.991 -.712 7.261 -1.74m.739 -3.26v-4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbDatabase (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"ellipse\",\"attr\":{\"cx\":\"12\",\"cy\":\"6\",\"rx\":\"8\",\"ry\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6v6a8 3 0 0 0 16 0v-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12v6a8 3 0 0 0 16 0v-6\"}}]})(props);\n};\nexport function TbDentalOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.277 15.281c.463 -1.75 .723 -3.844 .723 -6.281c0 -3.74 -1.908 -4.994 -4 -5c-1.423 -.004 -2.92 .911 -4 1.5c-1.074 -.586 -2.583 -1.5 -4 -1.5m-2.843 1.153c-.707 .784 -1.157 2.017 -1.157 3.847c0 4.899 1.056 8.41 2.671 10.537c.573 .756 1.97 .521 2.567 -.236c.398 -.505 .819 -1.439 1.262 -2.801c.292 -.771 .892 -1.504 1.5 -1.5c.602 .004 1.21 .737 1.5 1.5c.443 1.362 .864 2.295 1.262 2.8c.597 .759 1.994 .993 2.567 .237c.305 -.402 .59 -.853 .852 -1.353\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5.5l3 1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDental (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5.5c-1.074 -.586 -2.583 -1.5 -4 -1.5c-2.1 -.001 -4 1.247 -4 5c0 4.899 1.056 8.41 2.671 10.537c.573 .756 1.97 .521 2.567 -.236c.398 -.505 .819 -1.439 1.262 -2.801c.292 -.771 .892 -1.504 1.5 -1.5c.602 .004 1.21 .737 1.5 1.5c.443 1.362 .864 2.295 1.262 2.8c.597 .759 1.994 .993 2.567 .237c1.615 -2.127 2.671 -5.637 2.671 -10.537c0 -3.74 -1.908 -4.994 -4 -5c-1.423 -.004 -2.92 .911 -4 1.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5.5l3 1.5\"}}]})(props);\n};\nexport function TbDetails (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 19h14a2 2 0 0 0 1.84 -2.75l-7.1 -12.25a2 2 0 0 0 -3.5 0l-7.1 12.25a2 2 0 0 0 1.75 2.75\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v16\"}}]})(props);\n};\nexport function TbDeviceAnalytics (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"4\",\"width\":\"18\",\"height\":\"12\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"20\",\"x2\":\"17\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"16\",\"x2\":\"9\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"16\",\"x2\":\"15\",\"y2\":\"20\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12l3 -3l2 2l3 -3\"}}]})(props);\n};\nexport function TbDeviceAudioTape (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"5\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17l4 -3h10l4 3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7.5\",\"cy\":\"9.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16.5\",\"cy\":\"9.5\",\"r\":\".5\",\"fill\":\"currentColor\"}}]})(props);\n};\nexport function TbDeviceCctv (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"3\",\"width\":\"18\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"14\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 7v7a7 7 0 0 1 -14 0v-7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"14\",\"x2\":\"12.01\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbDeviceComputerCameraOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.15 6.153a7 7 0 0 0 9.696 9.696m2 -2a7 7 0 0 0 -9.699 -9.695\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.13 9.122a3 3 0 0 0 3.743 3.749m2 -2a3 3 0 0 0 -3.737 -3.736\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16l-2.091 3.486a1 1 0 0 0 .857 1.514h10.468a1 1 0 0 0 .857 -1.514l-2.091 -3.486\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbDeviceComputerCamera (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"10\",\"r\":\"7\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"10\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16l-2.091 3.486a1 1 0 0 0 .857 1.514h10.468a1 1 0 0 0 .857 -1.514l-2.091 -3.486\"}}]})(props);\n};\nexport function TbDeviceDesktopAnalytics (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"4\",\"width\":\"18\",\"height\":\"12\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 20h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 16v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 16v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 12v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v-1\"}}]})(props);\n};\nexport function TbDeviceDesktopOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h12a1 1 0 0 1 1 1v10a1 1 0 0 1 -1 1m-4 0h-12a1 1 0 0 1 -1 -1v-10a1 1 0 0 1 1 -1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"20\",\"x2\":\"17\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"16\",\"x2\":\"9\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"16\",\"x2\":\"15\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbDeviceDesktop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"4\",\"width\":\"18\",\"height\":\"12\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"20\",\"x2\":\"17\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"16\",\"x2\":\"9\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"16\",\"x2\":\"15\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbDeviceFloppy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 4h10l4 4v10a2 2 0 0 1 -2 2h-12a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 2 -2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"14\",\"r\":\"2\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"14 4 14 8 8 8 8 4\"}}]})(props);\n};\nexport function TbDeviceGamepad2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5h3.5a5 5 0 0 1 0 10h-5.5l-4.015 4.227a2.3 2.3 0 0 1 -3.923 -2.035l1.634 -8.173a5 5 0 0 1 4.904 -4.019h3.4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 15l4.07 4.284a2.3 2.3 0 0 0 3.925 -2.023l-1.6 -8.232\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 9v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 10h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10h2\"}}]})(props);\n};\nexport function TbDeviceGamepad (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"2\",\"y\":\"6\",\"width\":\"20\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12h4m-2 -2v4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"11\",\"x2\":\"15\",\"y2\":\"11.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"13\",\"x2\":\"18\",\"y2\":\"13.01\"}}]})(props);\n};\nexport function TbDeviceHeartMonitor (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 9h6l1 -2l2 4l1 -2h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 14h16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 17v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v.01\"}}]})(props);\n};\nexport function TbDeviceLaptopOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19h16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6h8a1 1 0 0 1 1 1v8m-3 1h-10a1 1 0 0 1 -1 -1v-8a1 1 0 0 1 1 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDeviceLaptop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"19\",\"x2\":\"21\",\"y2\":\"19\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"6\",\"width\":\"14\",\"height\":\"10\",\"rx\":\"1\"}}]})(props);\n};\nexport function TbDeviceMobileMessage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 3h10v8h-3l-4 2v-2h-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 16v4a1 1 0 0 1 -1 1h-8a1 1 0 0 1 -1 -1v-14a1 1 0 0 1 1 -1h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 18v.01\"}}]})(props);\n};\nexport function TbDeviceMobileOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.174 3.178c.252 -.114 .531 -.178 .826 -.178h8a2 2 0 0 1 2 2v9m0 4v1a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2v-13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 4h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDeviceMobileRotated (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"6\",\"width\":\"18\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 11v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12h-.01\"}}]})(props);\n};\nexport function TbDeviceMobileVibration (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"3\",\"width\":\"12\",\"height\":\"18\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"4\",\"x2\":\"10\",\"y2\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"17\",\"x2\":\"9\",\"y2\":\"17.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 6l-2 3l2 3l-2 3l2 3\"}}]})(props);\n};\nexport function TbDeviceMobile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"6\",\"y\":\"3\",\"width\":\"12\",\"height\":\"18\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"4\",\"x2\":\"13\",\"y2\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"17\",\"x2\":\"12\",\"y2\":\"17.01\"}}]})(props);\n};\nexport function TbDeviceNintendoOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.713 4.718a3.995 3.995 0 0 0 -1.713 3.282v8a4 4 0 0 0 4 4h3v-10m0 -4v-2h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10v-6h3a4 4 0 0 1 4 4v8c0 .308 -.035 .608 -.1 .896m-1.62 2.39a3.982 3.982 0 0 1 -2.28 .714h-3v-6\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6.5\",\"cy\":\"8.5\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDeviceNintendo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 20v-16h-3a4 4 0 0 0 -4 4v8a4 4 0 0 0 4 4h3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 20v-16h3a4 4 0 0 1 4 4v8a4 4 0 0 1 -4 4h-3z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17.5\",\"cy\":\"15.5\",\"r\":\"1\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6.5\",\"cy\":\"8.5\",\"r\":\"1\",\"fill\":\"currentColor\"}}]})(props);\n};\nexport function TbDeviceSpeakerOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 3h10a2 2 0 0 1 2 2v10m0 4a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.114 11.133a3.001 3.001 0 1 0 3.754 3.751\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDeviceSpeaker (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"3\",\"width\":\"14\",\"height\":\"18\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"14\",\"r\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"7\",\"x2\":\"12\",\"y2\":\"7.01\"}}]})(props);\n};\nexport function TbDeviceTabletOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 3h11a1 1 0 0 1 1 1v11m0 4v1a1 1 0 0 1 -1 1h-12a1 1 0 0 1 -1 -1v-15\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"17\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDeviceTablet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"3\",\"width\":\"14\",\"height\":\"18\",\"rx\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"17\",\"r\":\"1\"}}]})(props);\n};\nexport function TbDeviceTvOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7h8a2 2 0 0 1 2 2v8m-1.178 2.824c-.25 .113 -.529 .176 -.822 .176h-14a2 2 0 0 1 -2 -2v-9a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 3l-4 4l-4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDeviceTvOld (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"7\",\"width\":\"18\",\"height\":\"13\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 3l-4 4l-4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 7v13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 12v.01\"}}]})(props);\n};\nexport function TbDeviceTv (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"7\",\"width\":\"18\",\"height\":\"13\",\"rx\":\"2\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 3 12 7 8 3\"}}]})(props);\n};\nexport function TbDeviceWatchOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6h5a3 3 0 0 1 3 3v5m-.882 3.125a2.99 2.99 0 0 1 -2.118 .875h-6a3 3 0 0 1 -3 -3v-6c0 -.828 .336 -1.578 .878 -2.121\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18v3h6v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5v-2h6v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDeviceWatchStats2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"6\",\"y\":\"6\",\"width\":\"12\",\"height\":\"12\",\"rx\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18v3h6v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 6v-3h6v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 10a2 2 0 1 0 2 2\"}}]})(props);\n};\nexport function TbDeviceWatchStats (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"6\",\"y\":\"6\",\"width\":\"12\",\"height\":\"12\",\"rx\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18v3h6v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 6v-3h6v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 14v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 14v-3\"}}]})(props);\n};\nexport function TbDeviceWatch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"6\",\"y\":\"6\",\"width\":\"12\",\"height\":\"12\",\"rx\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18v3h6v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 6v-3h6v3\"}}]})(props);\n};\nexport function TbDevices2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 15h-6a1 1 0 0 1 -1 -1v-8a1 1 0 0 1 1 -1h6\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"13\",\"y\":\"4\",\"width\":\"8\",\"height\":\"16\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"19\",\"x2\":\"10\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"8\",\"x2\":\"17\",\"y2\":\"8.01\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"16\",\"r\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"15\",\"x2\":\"9\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbDevicesOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 9a1 1 0 0 1 1 -1h6a1 1 0 0 1 1 1v8m-1 3h-6a1 1 0 0 1 -1 -1v-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 8v-3a1 1 0 0 0 -1 -1h-9m-4 0a1 1 0 0 0 -1 1v12a1 1 0 0 0 1 1h9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 9h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDevicesPcOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 9v10h-6v-14h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 9h9v7h-2m-4 0h-4v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 19h5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 13v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 16v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDevicesPc (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 5h6v14h-6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9h10v7h-10z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 19h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 16v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 13v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 16v.01\"}}]})(props);\n};\nexport function TbDevices (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"13\",\"y\":\"8\",\"width\":\"8\",\"height\":\"12\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 8v-3a1 1 0 0 0 -1 -1h-13a1 1 0 0 0 -1 1v12a1 1 0 0 0 1 1h9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"9\",\"x2\":\"18\",\"y2\":\"9\"}}]})(props);\n};\nexport function TbDialpadOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7h-4v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 3h4v4h-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6v-3h4v4h-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 10h4v4h-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 13v-3h4v4h-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14h-4v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 17h4v4h-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDialpad (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3h4v4h-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 3h4v4h-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 3h4v4h-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 10h4v4h-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 10h4v4h-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10h4v4h-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 17h4v4h-4z\"}}]})(props);\n};\nexport function TbDiamondOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h9l3 5l-3.308 3.697m-1.883 2.104l-3.309 3.699a0.7 .7 0 0 1 -1 0l-8.5 -9.5l2.62 -4.368\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12l-2 -2.2l.6 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDiamond (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 5h12l3 5l-8.5 9.5a0.7 .7 0 0 1 -1 0l-8.5 -9.5l3 -5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12l-2 -2.2l.6 -1\"}}]})(props);\n};\nexport function TbDiamonds (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.831 20.413l-5.375 -6.91c-.608 -.783 -.608 -2.223 0 -3.005l5.375 -6.911a1.457 1.457 0 0 1 2.338 0l5.375 6.91c.608 .783 .608 2.223 0 3.005l-5.375 6.911a1.457 1.457 0 0 1 -2.338 0z\"}}]})(props);\n};\nexport function TbDice1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\".5\",\"fill\":\"currentColor\"}}]})(props);\n};\nexport function TbDice2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9.5\",\"cy\":\"9.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14.5\",\"cy\":\"14.5\",\"r\":\".5\",\"fill\":\"currentColor\"}}]})(props);\n};\nexport function TbDice3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8.5\",\"cy\":\"8.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15.5\",\"cy\":\"15.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\".5\",\"fill\":\"currentColor\"}}]})(props);\n};\nexport function TbDice4 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8.5\",\"cy\":\"8.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15.5\",\"cy\":\"8.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15.5\",\"cy\":\"15.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8.5\",\"cy\":\"15.5\",\"r\":\".5\",\"fill\":\"currentColor\"}}]})(props);\n};\nexport function TbDice5 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8.5\",\"cy\":\"8.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15.5\",\"cy\":\"8.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15.5\",\"cy\":\"15.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8.5\",\"cy\":\"15.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\".5\",\"fill\":\"currentColor\"}}]})(props);\n};\nexport function TbDice6 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8.5\",\"cy\":\"7.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15.5\",\"cy\":\"7.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8.5\",\"cy\":\"12\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15.5\",\"cy\":\"12\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15.5\",\"cy\":\"16.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8.5\",\"cy\":\"16.5\",\"r\":\".5\",\"fill\":\"currentColor\"}}]})(props);\n};\nexport function TbDice (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8.5\",\"cy\":\"8.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15.5\",\"cy\":\"8.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15.5\",\"cy\":\"15.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8.5\",\"cy\":\"15.5\",\"r\":\".5\",\"fill\":\"currentColor\"}}]})(props);\n};\nexport function TbDimensions (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 5h11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7l2 -2l-2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 3l-2 2l2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 10v11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 19l2 2l2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 12l-2 -2l-2 2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"10\",\"width\":\"11\",\"height\":\"11\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbDirectionHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 9l-3 3l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 9l3 3l-3 3\"}}]})(props);\n};\nexport function TbDirection (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 10l3 -3l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 14l3 3l3 -3\"}}]})(props);\n};\nexport function TbDirectionsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 21h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8v1h1m4 0h6l2 -2l-2 -2h-10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14v3h-8l-2 -2l2 -2h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDirections (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 21h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 5v4h11l2 -2l-2 -2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 13v4h-8l-2 -2l2 -2z\"}}]})(props);\n};\nexport function TbDisabled2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 11a5 5 0 1 0 3.95 7.95\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 20l-4 -5h-4l3 -5l-4 -3l-4 1\"}}]})(props);\n};\nexport function TbDisabledOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7a2 2 0 1 0 -2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 11v4h4l4 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 11h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 11.5a5 5 0 1 0 6 7.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDisabled (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"11\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"11 7 11 15 15 15 19 20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"11\",\"x2\":\"16\",\"y2\":\"11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 11.5a5 5 0 1 0 6 7.5\"}}]})(props);\n};\nexport function TbDiscOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.044 16.04a9 9 0 0 0 -12.082 -12.085m-2.333 1.688a9 9 0 0 0 6.371 15.357c2.491 0 4.73 -.997 6.36 -2.631\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.298 11.288a1 1 0 1 0 1.402 1.427\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12c0 -1.38 .559 -2.629 1.462 -3.534m2.607 -1.38c.302 -.056 .613 -.086 .931 -.086\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17a4.985 4.985 0 0 0 3.551 -1.48m1.362 -2.587c.057 -.302 .087 -.614 .087 -.933\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDisc (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12a5 5 0 0 1 5 -5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17a5 5 0 0 0 5 -5\"}}]})(props);\n};\nexport function TbDiscount2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"15\",\"x2\":\"15\",\"y2\":\"9\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9.5\",\"cy\":\"9.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14.5\",\"cy\":\"14.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7.2a2.2 2.2 0 0 1 2.2 -2.2h1a2.2 2.2 0 0 0 1.55 -.64l.7 -.7a2.2 2.2 0 0 1 3.12 0l.7 .7a2.2 2.2 0 0 0 1.55 .64h1a2.2 2.2 0 0 1 2.2 2.2v1a2.2 2.2 0 0 0 .64 1.55l.7 .7a2.2 2.2 0 0 1 0 3.12l-.7 .7a2.2 2.2 0 0 0 -.64 1.55v1a2.2 2.2 0 0 1 -2.2 2.2h-1a2.2 2.2 0 0 0 -1.55 .64l-.7 .7a2.2 2.2 0 0 1 -3.12 0l-.7 -.7a2.2 2.2 0 0 0 -1.55 -.64h-1a2.2 2.2 0 0 1 -2.2 -2.2v-1a2.2 2.2 0 0 0 -.64 -1.55l-.7 -.7a2.2 2.2 0 0 1 0 -3.12l.7 -.7a2.2 2.2 0 0 0 .64 -1.55v-1\"}}]})(props);\n};\nexport function TbDiscount (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"15\",\"x2\":\"15\",\"y2\":\"9\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9.5\",\"cy\":\"9.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14.5\",\"cy\":\"14.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbDivide (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"fill\":\"currentColor\",\"cx\":\"12\",\"cy\":\"6\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"fill\":\"currentColor\",\"cx\":\"12\",\"cy\":\"18\",\"r\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"19\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbDna2Off (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 3v1c-.007 2.46 -.91 4.554 -2.705 6.281m-2.295 1.719c-3.328 1.99 -4.997 4.662 -5.008 8.014v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21.014v-1c-.004 -1.44 -.315 -2.755 -.932 -3.944m-4.068 -4.07c-1.903 -1.138 -3.263 -2.485 -4.082 -4.068\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 20h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDna2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 3v1c-.01 3.352 -1.68 6.023 -5.008 8.014c-3.328 1.99 3.336 -2.005 .008 -.014c-3.328 1.99 -4.997 4.662 -5.008 8.014v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21.014v-1c-.01 -3.352 -1.68 -6.023 -5.008 -8.014c-3.328 -1.99 3.336 2.005 .008 .014c-3.328 -1.991 -4.997 -4.662 -5.008 -8.014v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 4h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 20h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16h8\"}}]})(props);\n};\nexport function TbDnaOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12a3.898 3.898 0 0 0 -1.172 -2.828a4.027 4.027 0 0 0 -2.828 -1.172m-2.828 1.172a4 4 0 1 0 5.656 5.656\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.172 20.485a4 4 0 1 0 -5.657 -5.657\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.828 3.515a4 4 0 1 0 5.657 5.657\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDna (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"transform\":\"rotate(-45 12 12)\",\"cx\":\"12\",\"cy\":\"12\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.172 20.485a4 4 0 1 0 -5.657 -5.657\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.828 3.515a4 4 0 1 0 5.657 5.657\"}}]})(props);\n};\nexport function TbDogBowl (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 15l5.586 -5.585a2 2 0 1 1 3.414 -1.415a2 2 0 1 1 -1.413 3.414l-3.587 3.586\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13l-3.586 -3.585a2 2 0 1 0 -3.414 -1.415a2 2 0 1 0 1.413 3.414l3.587 3.586\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 20h18c-.175 -1.671 -.046 -3.345 -2 -5h-14c-1.333 1 -2 2.667 -2 5z\"}}]})(props);\n};\nexport function TbDoorEnter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21h18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 21v-16a2 2 0 0 1 2 -2h6m4 10.5v7.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 7h-7m3 -3l-3 3l3 3\"}}]})(props);\n};\nexport function TbDoorExit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21h18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 21v-16a2 2 0 0 1 2 -2h7.5m2.5 10.5v7.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 7h7m-3 -3l3 3l-3 3\"}}]})(props);\n};\nexport function TbDoorOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21h18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 21v-15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.18 3.175c.25 -.112 .528 -.175 .82 -.175h8a2 2 0 0 1 2 2v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 18v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDoor (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21h18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 21v-16a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v16\"}}]})(props);\n};\nexport function TbDotsCircleHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"12\",\"x2\":\"8\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"12\",\"x2\":\"16\",\"y2\":\"12.01\"}}]})(props);\n};\nexport function TbDotsDiagonal2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"7\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"17\",\"r\":\"1\"}}]})(props);\n};\nexport function TbDotsDiagonal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"17\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"7\",\"r\":\"1\"}}]})(props);\n};\nexport function TbDotsVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"19\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"5\",\"r\":\"1\"}}]})(props);\n};\nexport function TbDots (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"12\",\"r\":\"1\"}}]})(props);\n};\nexport function TbDownloadOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 17v2a2 2 0 0 0 2 2h12a2 2 0 0 0 1.83 -1.19\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 11l5 5l2.005 -2.005m1.994 -1.994l1.001 -1.001\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4v4m0 4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDownload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 17v2a2 2 0 0 0 2 2h12a2 2 0 0 0 2 -2v-2\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"7 11 12 16 17 11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbDragDrop2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"8\",\"width\":\"12\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"4\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"4\",\"x2\":\"8\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"4\",\"x2\":\"16\",\"y2\":\"4.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"8\",\"x2\":\"4\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"4\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"16\",\"x2\":\"4\",\"y2\":\"16.01\"}}]})(props);\n};\nexport function TbDragDrop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 11v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 13l9 3l-4 2l-2 4l-3 -9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"3\",\"y2\":\"3.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"3\",\"x2\":\"7\",\"y2\":\"3.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"3\",\"x2\":\"11\",\"y2\":\"3.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"3\",\"x2\":\"15\",\"y2\":\"3.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"7\",\"x2\":\"3\",\"y2\":\"7.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"11\",\"x2\":\"3\",\"y2\":\"11.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"15\",\"x2\":\"3\",\"y2\":\"15.01\"}}]})(props);\n};\nexport function TbDroneOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14h-4v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10l-3.5 -3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.957 5.95a3.503 3.503 0 0 0 -2.917 -2.91m-3.02 .989a3.5 3.5 0 0 0 1.98 5.936\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10l3.5 -3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 9.965a3.5 3.5 0 1 0 -3.966 -3.965\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"14\",\"x2\":\"17.5\",\"y2\":\"17.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.035 18a3.5 3.5 0 0 0 5.936 1.98m.987 -3.026a3.503 3.503 0 0 0 -2.918 -2.913\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"14\",\"x2\":\"6.5\",\"y2\":\"17.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 14.035a3.5 3.5 0 1 0 3.966 3.965\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbDrone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10h4v4h-4z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"10\",\"x2\":\"6.5\",\"y2\":\"6.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.96 6a3.5 3.5 0 1 0 -3.96 3.96\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10l3.5 -3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 9.96a3.5 3.5 0 1 0 -3.96 -3.96\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"14\",\"x2\":\"17.5\",\"y2\":\"17.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.04 18a3.5 3.5 0 1 0 3.96 -3.96\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"14\",\"x2\":\"6.5\",\"y2\":\"17.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 14.04a3.5 3.5 0 1 0 3.96 3.96\"}}]})(props);\n};\nexport function TbDropCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.07 15.34c1.115 .88 2.74 .88 3.855 0c1.115 -.88 1.398 -2.388 .671 -3.575l-2.596 -3.765l-2.602 3.765c-.726 1.187 -.443 2.694 .672 3.575z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbDropletFilled2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.8 11a6 6 0 1 0 10.396 0l-5.197 -8l-5.2 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 14h12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.305 17.695l3.695 -3.695\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.26 19.74l5.74 -5.74l-5.74 5.74z\"}}]})(props);\n};\nexport function TbDropletFilled (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.8 11a6 6 0 1 0 10.396 0l-5.197 -8l-5.2 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l3.544 -3.544\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17.3l5.558 -5.558\"}}]})(props);\n};\nexport function TbDropletHalf2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.8 11a6 6 0 1 0 10.396 0l-5.197 -8l-5.2 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 14h12\"}}]})(props);\n};\nexport function TbDropletHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.8 11a6 6 0 1 0 10.396 0l-5.197 -8l-5.2 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v17\"}}]})(props);\n};\nexport function TbDropletOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.454 8.458l-1.653 2.545a6 6 0 0 0 10.32 6.123\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 14a5.971 5.971 0 0 0 -.803 -3l-5.197 -8l-1.968 3.03\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbDroplet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.8 11a6 6 0 1 0 10.396 0l-5.197 -8l-5.2 8z\"}}]})(props);\n};\nexport function TbEarOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10c0 -1.146 .277 -2.245 .78 -3.219m1.792 -2.208a7 7 0 0 1 10.428 9.027a10 10 0 0 1 -.633 .762m-2.045 1.96a8 8 0 0 0 -1.322 2.278a4.5 4.5 0 0 1 -6.8 1.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.42 7.414a3 3 0 0 1 4.131 4.13\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbEar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10a7 7 0 1 1 13 3.6a10 10 0 0 1 -2 2a8 8 0 0 0 -2 3a4.5 4.5 0 0 1 -6.8 1.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10a3 3 0 1 1 5 2.2\"}}]})(props);\n};\nexport function TbEditCircleOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.507 10.498l-1.507 1.502v3h3l1.493 -1.498m2.002 -2.01l4.89 -4.907a2.1 2.1 0 0 0 -2.97 -2.97l-4.913 4.896\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 5l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.476 7.471a7.002 7.002 0 0 0 2.524 13.529a7.004 7.004 0 0 0 6.53 -4.474\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbEditCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 15l8.385 -8.415a2.1 2.1 0 0 0 -2.97 -2.97l-8.415 8.385v3h3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 5l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 7.07a7.002 7.002 0 0 0 1 13.93a7.002 7.002 0 0 0 6.929 -5.999\"}}]})(props);\n};\nexport function TbEditOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7h-1a2 2 0 0 0 -2 2v9a2 2 0 0 0 2 2h9a2 2 0 0 0 2 -2v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.507 10.498l-1.507 1.502v3h3l1.493 -1.498m2.002 -2.01l4.89 -4.907a2.1 2.1 0 0 0 -2.97 -2.97l-4.913 4.896\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 5l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbEdit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7h-1a2 2 0 0 0 -2 2v9a2 2 0 0 0 2 2h9a2 2 0 0 0 2 -2v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.385 6.585a2.1 2.1 0 0 0 -2.97 -2.97l-8.415 8.385v3h3l8.385 -8.415z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 5l3 3\"}}]})(props);\n};\nexport function TbEggOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.41 7.41a12.574 12.574 0 0 0 -1.896 7.229c0 3.513 2.904 6.361 6.486 6.361a6.504 6.504 0 0 0 5.692 -3.31m.8 -3.192a12.574 12.574 0 0 0 -3.249 -8.871a4.025 4.025 0 0 0 -3.243 -1.627a4.026 4.026 0 0 0 -2.832 1.155\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbEgg (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.514 14.639c0 3.513 2.904 6.361 6.486 6.361s6.486 -2.848 6.486 -6.361a12.574 12.574 0 0 0 -3.243 -9.012a4.025 4.025 0 0 0 -3.243 -1.627a4.025 4.025 0 0 0 -3.243 1.627a12.574 12.574 0 0 0 -3.243 9.012\"}}]})(props);\n};\nexport function TbElevator (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"4\",\"width\":\"14\",\"height\":\"16\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10l2 -2l2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 14l2 2l2 -2\"}}]})(props);\n};\nexport function TbEmergencyBed (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8l2.1 2.8a3 3 0 0 0 2.4 1.2h11.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v2l-2.5 2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.5 16.5l-2.5 -2.5\"}}]})(props);\n};\nexport function TbEmphasis (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 5h-8v10h8m-1 -5h-7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"20\",\"x2\":\"6\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"20\",\"x2\":\"10\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"20\",\"x2\":\"14\",\"y2\":\"20.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"20\",\"x2\":\"18\",\"y2\":\"20.01\"}}]})(props);\n};\nexport function TbEngineOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 10v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 13h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16h-1v2a1 1 0 0 1 -1 1h-3.465a1 1 0 0 1 -.832 -.445l-1.703 -2.555h-2v-6h2l.99 -.99m3.01 -1.01h1.382a1 1 0 0 1 .894 .553l1.448 2.894a1 1 0 0 0 .894 .553h1.382v-2h2a1 1 0 0 1 1 1v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbEngine (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 10v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 13h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10h2l2 -2h3.382a1 1 0 0 1 .894 .553l1.448 2.894a1 1 0 0 0 .894 .553h1.382v-2h2a1 1 0 0 1 1 1v6a1 1 0 0 1 -1 1h-2v-2h-3v2a1 1 0 0 1 -1 1h-3.465a1 1 0 0 1 -.832 -.445l-1.703 -2.555h-2v-6z\"}}]})(props);\n};\nexport function TbEqualNot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 9h14m-14 6h14m0 -10l-14 14\"}}]})(props);\n};\nexport function TbEqual (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 9h14m-14 6h14\"}}]})(props);\n};\nexport function TbEraserOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 20h-10.5l-4.21 -4.3a1 1 0 0 1 0 -1.41l4.995 -4.993m2.009 -2.01l2.997 -2.996a1 1 0 0 1 1.41 0l5 5a1 1 0 0 1 0 1.41c-1.417 1.431 -2.406 2.432 -2.97 3m-2.02 2.043l-4.211 4.256\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 13.3l-6.3 -6.3\"}}]})(props);\n};\nexport function TbEraser (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 20h-10.5l-4.21 -4.3a1 1 0 0 1 0 -1.41l10 -10a1 1 0 0 1 1.41 0l5 5a1 1 0 0 1 0 1.41l-9.2 9.3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 13.3l-6.3 -6.3\"}}]})(props);\n};\nexport function TbError404Off (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7v4a1 1 0 0 0 1 1h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10v6a1 1 0 0 0 1 1h2a1 1 0 0 0 1 -1v-2m0 -4v-2a1 1 0 0 0 -1 -1h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 7v4a1 1 0 0 0 1 1h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 7v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbError404 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7v4a1 1 0 0 0 1 1h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 8v8a1 1 0 0 0 1 1h2a1 1 0 0 0 1 -1v-8a1 1 0 0 0 -1 -1h-2a1 1 0 0 0 -1 1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 7v4a1 1 0 0 0 1 1h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 7v10\"}}]})(props);\n};\nexport function TbExchangeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 8v5c0 .594 -.104 1.164 -.294 1.692m-1.692 2.298a4.978 4.978 0 0 1 -3.014 1.01h-3l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 21l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 16v-5c0 -1.632 .782 -3.082 1.992 -3.995m3.008 -1.005h3l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.501 7.499l1.499 -1.499\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbExchange (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 8v5a5 5 0 0 1 -5 5h-3l3 -3m0 6l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 16v-5a5 5 0 0 1 5 -5h3l-3 -3m0 6l3 -3\"}}]})(props);\n};\nexport function TbExclamationMarkOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 19v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 15v-3m0 -4v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbExclamationMark (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 19v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 15v-10\"}}]})(props);\n};\nexport function TbExposure (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4.6\",\"y1\":\"19.4\",\"x2\":\"19.4\",\"y2\":\"4.6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 9h4m-2 -2v4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"16\",\"x2\":\"17\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbExternalLinkOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7h-1a2 2 0 0 0 -2 2v9a2 2 0 0 0 2 2h9a2 2 0 0 0 2 -2v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 14l1.996 -1.996m2.007 -2.007l5.997 -5.997\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 4h5v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbExternalLink (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7h-5a2 2 0 0 0 -2 2v9a2 2 0 0 0 2 2h9a2 2 0 0 0 2 -2v-5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"14\",\"x2\":\"20\",\"y2\":\"4\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"15 4 20 4 20 9\"}}]})(props);\n};\nexport function TbEyeCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 19c-4 0 -7.333 -2.333 -10 -7c2.667 -4.667 6 -7 10 -7s7.333 2.333 10 7c-.42 .736 -.858 1.414 -1.311 2.033\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 19l2 2l4 -4\"}}]})(props);\n};\nexport function TbEyeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.584 10.587a2 2 0 0 0 2.828 2.83\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.363 5.365a9.466 9.466 0 0 1 2.637 -.365c4 0 7.333 2.333 10 7c-.778 1.361 -1.612 2.524 -2.503 3.488m-2.14 1.861c-1.631 1.1 -3.415 1.651 -5.357 1.651c-4 0 -7.333 -2.333 -10 -7c1.369 -2.395 2.913 -4.175 4.632 -5.341\"}}]})(props);\n};\nexport function TbEyeTable (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.003 18.003h-.011\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.003 18.002h-.011\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.003 18.002h-.011\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 3h16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 3v17a1 1 0 0 0 1 1h12a1 1 0 0 0 1 -1v-17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 7h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 15h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 15h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 11v-4\"}}]})(props);\n};\nexport function TbEye (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 12c-2.667 4.667 -6 7 -10 7s-7.333 -2.333 -10 -7c2.667 -4.667 6 -7 10 -7s7.333 2.333 10 7\"}}]})(props);\n};\nexport function TbEyeglass2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h-2l-3 10v2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2l3 10v2.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"16\",\"x2\":\"14\",\"y2\":\"16\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17.5\",\"cy\":\"16.5\",\"r\":\"3.5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6.5\",\"cy\":\"16.5\",\"r\":\"3.5\"}}]})(props);\n};\nexport function TbEyeglassOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.536 5.546l-2.536 8.454\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2l3 10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 16h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.426 19.423a3.5 3.5 0 0 1 -5.426 -2.923v-2.5m4 0h3v2.5c0 .157 -.01 .312 -.03 .463\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 16.5a3.5 3.5 0 0 1 -7 0v-2.5h7v2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbEyeglass (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h-2l-3 10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2l3 10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"16\",\"x2\":\"14\",\"y2\":\"16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 16.5a3.5 3.5 0 0 1 -7 0v-2.5h7v2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 16.5a3.5 3.5 0 0 1 -7 0v-2.5h7v2.5\"}}]})(props);\n};\nexport function TbFaceIdError (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8v-2a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16v2a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2a2 2 0 0 1 2 2v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h2a2 2 0 0 0 2 -2v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 10h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 10h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 15.05a3.5 3.5 0 0 1 5 0\"}}]})(props);\n};\nexport function TbFaceId (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8v-2a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16v2a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2a2 2 0 0 1 2 2v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h2a2 2 0 0 0 2 -2v-2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"10\",\"x2\":\"9.01\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"10\",\"x2\":\"15.01\",\"y2\":\"10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 15a3.5 3.5 0 0 0 5 0\"}}]})(props);\n};\nexport function TbFaceMaskOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.002 14.5h-.222c-1.535 0 -2.778 -1.12 -2.778 -2.5s1.243 -2.5 2.778 -2.5h.222\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.002 14.5h.222c1.534 0 2.778 -1.12 2.778 -2.5s-1.244 -2.5 -2.778 -2.5h-.222\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 10h1m4 0h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 14h5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 15v-6.49a2 2 0 0 0 -1.45 -1.923l-5 -1.429a2 2 0 0 0 -1.1 0l-1.788 .511m-3.118 .891l-.094 .027a2 2 0 0 0 -1.45 1.922v6.982a2 2 0 0 0 1.45 1.923l5 1.429a2 2 0 0 0 1.1 0l4.899 -1.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbFaceMask (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.002 14.5h-.222c-1.535 0 -2.778 -1.12 -2.778 -2.5s1.243 -2.5 2.778 -2.5h.222\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.002 14.5h.222c1.534 0 2.778 -1.12 2.778 -2.5s-1.244 -2.5 -2.778 -2.5h-.222\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 10h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 14h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.55 18.843l5 -1.429a2 2 0 0 0 1.45 -1.923v-6.981a2 2 0 0 0 -1.45 -1.923l-5 -1.429a2 2 0 0 0 -1.1 0l-5 1.429a2 2 0 0 0 -1.45 1.922v6.982a2 2 0 0 0 1.45 1.923l5 1.429a2 2 0 0 0 1.1 0z\"}}]})(props);\n};\nexport function TbFall (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 21l1 -5l-1 -4l-3 -4h4l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 16l-1 -4l3 -4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"5\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 12h2.5l4 2\"}}]})(props);\n};\nexport function TbFeatherOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20l8 -8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 5v5h5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 11v4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 13v5h5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 13l3.502 -3.502m2.023 -2.023l2.475 -2.475\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 10c.638 -.636 1 -1.515 1 -2.486a3.515 3.515 0 0 0 -3.517 -3.514c-.97 0 -1.847 .367 -2.483 1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 18l3.499 -3.499m2.008 -2.008l2.493 -2.493\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbFeather (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20l10 -10m0 -5v5h5m-9 -1v5h5m-9 -1v5h5m-5 -5l4 -4l4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 10c.638 -.636 1 -1.515 1 -2.486a3.515 3.515 0 0 0 -3.517 -3.514c-.97 0 -1.847 .367 -2.483 1m-3 13l4 -4l4 -4\"}}]})(props);\n};\nexport function TbFenceOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12h-8v4h12m4 0v-4h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 16v4h4v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12v-2m0 -4l-2 -2m-2 2v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 16v4h4v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 12v-6l-2 -2l-2 2v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbFence (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12v4h16v-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 16v4h4v-4m0 -4v-6l-2 -2l-2 2v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 16v4h4v-4m0 -4v-6l-2 -2l-2 2v6\"}}]})(props);\n};\nexport function TbFidgetSpinner (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 17a3 3 0 1 1 -1.543 -2.623l2.087 -3.754a3 3 0 0 1 1.456 -5.623a3 3 0 0 1 1.457 5.623l2.087 3.754a3 3 0 1 1 -1.538 2.8l-.006 -.177h-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 17v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8v.01\"}}]})(props);\n};\nexport function TbFile3D (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13.5l4 -1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11.846l4 1.654v4.5l4 -1.846v-4.308l-4 -1.846z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12v4.2l4 1.8\"}}]})(props);\n};\nexport function TbFileAlert (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"17\",\"x2\":\"12.01\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"11\",\"x2\":\"12\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbFileAnalytics (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"17\",\"x2\":\"9\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"17\",\"x2\":\"12\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"17\",\"x2\":\"15\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbFileArrowLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 15h-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.5 17.5l-2.5 -2.5l2.5 -2.5\"}}]})(props);\n};\nexport function TbFileArrowRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 15h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 17.5l2.5 -2.5l-2.5 -2.5\"}}]})(props);\n};\nexport function TbFileBarcode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13h1v3h-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 13h1v3h-1z\"}}]})(props);\n};\nexport function TbFileCertificate (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 8v-3a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2h-5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"14\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 17l-1.5 5l3 -1.5l3 1.5l-1.5 -5\"}}]})(props);\n};\nexport function TbFileChart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 10v4h4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"14\",\"r\":\"4\"}}]})(props);\n};\nexport function TbFileCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 15l2 2l4 -4\"}}]})(props);\n};\nexport function TbFileCode2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12h-1v5h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 12h1v5h-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}}]})(props);\n};\nexport function TbFileCode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 13l-1 2l1 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 13l1 2l-1 2\"}}]})(props);\n};\nexport function TbFileDatabase (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"ellipse\",\"attr\":{\"cx\":\"12\",\"cy\":\"12.75\",\"rx\":\"4\",\"ry\":\"1.75\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12.5v3.75c0 .966 1.79 1.75 4 1.75s4 -.784 4 -1.75v-3.75\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}}]})(props);\n};\nexport function TbFileDescription (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 13h6\"}}]})(props);\n};\nexport function TbFileDiff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"10\",\"x2\":\"12\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"12\",\"x2\":\"14\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"17\",\"x2\":\"14\",\"y2\":\"17\"}}]})(props);\n};\nexport function TbFileDigit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"12\",\"width\":\"3\",\"height\":\"5\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 12v5\"}}]})(props);\n};\nexport function TbFileDislike (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"14\",\"width\":\"3\",\"height\":\"5\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15a1 1 0 0 1 1 -1h3.756a1 1 0 0 1 .958 .713l1.2 3c.09 .303 .133 .63 -.056 .884c-.188 .254 -.542 .403 -.858 .403h-2v2.467a1.1 1.1 0 0 1 -2.015 .61l-1.985 -3.077v-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 11v-6a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2h-2.5\"}}]})(props);\n};\nexport function TbFileDollar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 11h-2.5a1.5 1.5 0 0 0 0 3h1a1.5 1.5 0 0 1 0 3h-2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17v1m0 -8v1\"}}]})(props);\n};\nexport function TbFileDots (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 14v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 14v.01\"}}]})(props);\n};\nexport function TbFileDownload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17v-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 14.5l2.5 2.5l2.5 -2.5\"}}]})(props);\n};\nexport function TbFileEuro (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14h-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.004 11.172a3 3 0 1 0 -.001 5.656\"}}]})(props);\n};\nexport function TbFileExport (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.5 21h-4.5a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v5m-5 6h7m-3 -3l3 3l-3 3\"}}]})(props);\n};\nexport function TbFileHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 5v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7v10a2 2 0 0 0 2 2h14a2 2 0 0 0 2 -2v-7l-5 -5h-11a2 2 0 0 0 -2 2z\"}}]})(props);\n};\nexport function TbFileImport (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 13v-8a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2h-5.5m-9.5 -2h7m-3 -3l3 3l-3 3\"}}]})(props);\n};\nexport function TbFileInfo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 14h1v4h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 11h.01\"}}]})(props);\n};\nexport function TbFileInvoice (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"7\",\"x2\":\"10\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"13\",\"x2\":\"15\",\"y2\":\"13\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"17\",\"x2\":\"15\",\"y2\":\"17\"}}]})(props);\n};\nexport function TbFileLike (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"16\",\"width\":\"3\",\"height\":\"5\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 20a1 1 0 0 0 1 1h3.756a1 1 0 0 0 .958 -.713l1.2 -3c.09 -.303 .133 -.63 -.056 -.884c-.188 -.254 -.542 -.403 -.858 -.403h-2v-2.467a1.1 1.1 0 0 0 -2.015 -.61l-1.985 3.077v4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12.1v-7.1a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2h-2.3\"}}]})(props);\n};\nexport function TbFileMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"14\",\"x2\":\"15\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbFileMusic (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"11\",\"cy\":\"16\",\"r\":\"1\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"12 16 12 11 14 12\"}}]})(props);\n};\nexport function TbFileOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 3h7l5 5v7m0 4a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-14\"}}]})(props);\n};\nexport function TbFilePencil (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 18l5 -5a1.414 1.414 0 0 0 -2 -2l-5 5v2h2z\"}}]})(props);\n};\nexport function TbFilePhone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12a0.5 .5 0 0 0 1 0v-1a0.5 .5 0 0 0 -1 0v1a5 5 0 0 0 5 5h1a0.5 .5 0 0 0 0 -1h-1a0.5 .5 0 0 0 0 1\"}}]})(props);\n};\nexport function TbFilePlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"11\",\"x2\":\"12\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"14\",\"x2\":\"15\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbFilePower (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 11l-2 3h4l-2 3\"}}]})(props);\n};\nexport function TbFileReport (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"17\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 13v4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.5 21h-6.5a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v2m0 3v4\"}}]})(props);\n};\nexport function TbFileRss (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17a3 3 0 0 0 -3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 17a6 6 0 0 0 -6 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17h.01\"}}]})(props);\n};\nexport function TbFileScissors (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"17\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"17\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17l6 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 17l-6 -6\"}}]})(props);\n};\nexport function TbFileSearch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21h-5a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v4.5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16.5\",\"cy\":\"17.5\",\"r\":\"2.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18.5\",\"y1\":\"19.5\",\"x2\":\"21\",\"y2\":\"22\"}}]})(props);\n};\nexport function TbFileSettings (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"14\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 10.5v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 16v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.031 12.25l-1.299 .75\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.268 15l-1.3 .75\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 15.803l-1.285 -.773\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.285 12.97l-1.285 -.773\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}}]})(props);\n};\nexport function TbFileShredder (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12v-7a2 2 0 0 1 2 -2h7l5 5v4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"12\",\"x2\":\"21\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"16\",\"x2\":\"6\",\"y2\":\"18\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"16\",\"x2\":\"10\",\"y2\":\"22\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"16\",\"x2\":\"14\",\"y2\":\"18\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"16\",\"x2\":\"18\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbFileSignal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.525 11.525a3.5 3.5 0 0 0 0 4.95m4.95 0a3.5 3.5 0 0 0 0 -4.95\"}}]})(props);\n};\nexport function TbFileSpreadsheet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11h8v7h-8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 11v7\"}}]})(props);\n};\nexport function TbFileStar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.8 16.817l-2.172 1.138a0.392 .392 0 0 1 -.568 -.41l.415 -2.411l-1.757 -1.707a0.389 .389 0 0 1 .217 -.665l2.428 -.352l1.086 -2.193a0.392 .392 0 0 1 .702 0l1.086 2.193l2.428 .352a0.39 .39 0 0 1 .217 .665l-1.757 1.707l.414 2.41a0.39 .39 0 0 1 -.567 .411l-2.172 -1.138z\"}}]})(props);\n};\nexport function TbFileSymlink (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 21v-4a3 3 0 0 1 3 -3h5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17l3 -3l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 11v-6a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2h-9.5\"}}]})(props);\n};\nexport function TbFileText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"9\",\"x2\":\"10\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"13\",\"x2\":\"15\",\"y2\":\"13\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"17\",\"x2\":\"15\",\"y2\":\"17\"}}]})(props);\n};\nexport function TbFileTime (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"14\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12.496v1.504l1 1\"}}]})(props);\n};\nexport function TbFileTypography (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 18h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18v-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12v-1h6v1\"}}]})(props);\n};\nexport function TbFileUnknown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14a1.5 1.5 0 1 0 -1.14 -2.474\"}}]})(props);\n};\nexport function TbFileUpload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 11v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 13.5l2.5 -2.5l2.5 2.5\"}}]})(props);\n};\nexport function TbFileVector (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9.5\",\"cy\":\"16.5\",\"r\":\"1.5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14.5\",\"cy\":\"12.5\",\"r\":\"1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 15a2.5 2.5 0 0 1 2.5 -2.5h1\"}}]})(props);\n};\nexport function TbFileX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12l4 4m0 -4l-4 4\"}}]})(props);\n};\nexport function TbFileZip (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 20.735a2 2 0 0 1 -1 -1.735v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2h-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 17a2 2 0 0 1 2 2v2a1 1 0 0 1 -1 1h-2a1 1 0 0 1 -1 -1v-2a2 2 0 0 1 2 -2z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"5\",\"x2\":\"10\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"7\",\"x2\":\"12\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"9\",\"x2\":\"10\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"11\",\"x2\":\"12\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"13\",\"x2\":\"10\",\"y2\":\"13\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"15\",\"x2\":\"12\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbFile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21h-10a2 2 0 0 1 -2 -2v-14a2 2 0 0 1 2 -2h7l5 5v11a2 2 0 0 1 -2 2z\"}}]})(props);\n};\nexport function TbFilesOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17h-6a2 2 0 0 1 -2 -2v-6m0 -4a2 2 0 0 1 2 -2h4l5 5v7c0 .294 -.063 .572 -.177 .823\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 17v2a2 2 0 0 1 -2 2h-7a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbFiles (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 17h-7a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h4l5 5v7a2 2 0 0 1 -2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 17v2a2 2 0 0 1 -2 2h-7a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h2\"}}]})(props);\n};\nexport function TbFilterOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h9.5a1 1 0 0 1 .5 1.5l-4.049 4.454m-.951 3.046v5l-4 -3v-4l-5 -5.5a1 1 0 0 1 .18 -1.316\"}}]})(props);\n};\nexport function TbFilter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 5h13a1 1 0 0 1 .5 1.5l-5 5.5l0 7l-4 -3l0 -4l-5 -5.5a1 1 0 0 1 .5 -1.5\"}}]})(props);\n};\nexport function TbFingerprintOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.9 7a8 8 0 0 1 1.1 5v1a6 6 0 0 0 .8 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11c0 -.848 .264 -1.634 .713 -2.28m2.4 -1.621a4 4 0 0 1 4.887 3.901l-.001 1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v1a14 14 0 0 0 2.5 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15a18 18 0 0 0 1.8 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.9 19a22 22 0 0 1 -.9 -7v-1a8 8 0 0 1 1.854 -5.143m2.176 -1.825a8 8 0 0 1 7.97 .018\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbFingerprint (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.9 7a8 8 0 0 1 1.1 5v1a6 6 0 0 0 .8 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11a4 4 0 0 1 8 0v1a10 10 0 0 0 2 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 11v2a14 14 0 0 0 2.5 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15a18 18 0 0 0 1.8 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.9 19a22 22 0 0 1 -.9 -7v-1a8 8 0 0 1 12 -6.95\"}}]})(props);\n};\nexport function TbFiretruck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 18h8m4 0h2v-6a5 5 0 0 0 -5 -5h-1l1.5 5h4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18v-11h3\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"3 17 3 12 12 12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"9\",\"x2\":\"21\",\"y2\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"12\",\"x2\":\"6\",\"y2\":\"8\"}}]})(props);\n};\nexport function TbFirstAidKit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8v-2a2 2 0 0 1 2 -2h4a2 2 0 0 1 2 2v2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"8\",\"width\":\"16\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 14h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v4\"}}]})(props);\n};\nexport function TbFishOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.69 7.44a6.973 6.973 0 0 0 -1.63 3.635\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 9.504c5.307 5.948 10.293 8.57 14.597 7.1m2.583 -1.449c.988 -.788 1.93 -1.836 2.82 -3.153c-3.005 -4.443 -6.596 -5.812 -10.564 -4.548m-2.764 1.266c-2.145 1.266 -4.378 3.215 -6.672 5.786\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 11v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.153 11.169c-.287 .777 -.171 1.554 .347 2.331\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbFish (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.69 7.44a6.973 6.973 0 0 0 -1.69 4.56c0 1.747 .64 3.345 1.699 4.571\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 9.504c7.715 8.647 14.75 10.265 20 2.498c-5.25 -7.761 -12.285 -6.142 -20 2.504\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 11v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.5 10.5c-.667 1 -.667 2 0 3\"}}]})(props);\n};\nexport function TbFlag2Off (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 14h9m4 0h1v-9h-10m-4 0v16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbFlag2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 14h14v-9h-14v16\"}}]})(props);\n};\nexport function TbFlag3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 14h14l-4.5 -4.5l4.5 -4.5h-14v16\"}}]})(props);\n};\nexport function TbFlagOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 5v16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 5v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.641 3.645a4.994 4.994 0 0 1 4.359 1.355a5 5 0 0 0 7 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 14a5 5 0 0 1 7 0a4.984 4.984 0 0 0 3.437 1.429m3.019 -.966c.19 -.14 .371 -.294 .544 -.463\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbFlag (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"5\",\"x2\":\"5\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"5\",\"x2\":\"19\",\"y2\":\"14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 5a5 5 0 0 1 7 0a5 5 0 0 0 7 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 14a5 5 0 0 1 7 0a5 5 0 0 0 7 0\"}}]})(props);\n};\nexport function TbFlameOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.973 8.974c-.335 .378 -.67 .716 -.973 1.026c-1.226 1.26 -2 3.24 -2 5a6 6 0 0 0 11.472 2.466m.383 -3.597c-.32 -1.409 -1.122 -3.045 -1.855 -3.869c-.281 .472 -.543 .87 -.79 1.202m-2.358 -2.35c-.068 -2.157 -1.182 -4.184 -1.852 -4.852c0 .968 -.18 1.801 -.465 2.527\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbFlame (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12c2 -2.96 0 -7 -1 -8c0 3.038 -1.773 4.741 -3 6c-1.226 1.26 -2 3.24 -2 5a6 6 0 1 0 12 0c0 -1.532 -1.056 -3.94 -2 -5c-1.786 3 -2.791 3 -4 2z\"}}]})(props);\n};\nexport function TbFlare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h4m5 -9v4m5 5h4m-9 5v4m-4.5 -13.5l1 1m8 -1l-1 1m0 7l1 1m-8 -1l-1 1\"}}]})(props);\n};\nexport function TbFlask2Off (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.1 15h8.9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.742 17.741a6 6 0 0 1 -2.424 3.259h-6.635a6.002 6.002 0 0 1 1.317 -10.66v-.326m0 -4.014v-3h4v7m.613 .598a6.004 6.004 0 0 1 2.801 2.817\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 3h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbFlask2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.1 15h11.8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v7.342a6.002 6.002 0 0 1 1.318 10.658h-6.635a6.002 6.002 0 0 1 1.317 -10.66v-7.34h4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 3h6\"}}]})(props);\n};\nexport function TbFlaskOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 3h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 9h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 3v3m-.268 3.736l-3.732 10.264a0.7 .7 0 0 0 .5 1h11a0.7 .7 0 0 0 .5 -1l-1.143 -3.142m-2.288 -6.294l-.569 -1.564v-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbFlask (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"3\",\"x2\":\"15\",\"y2\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"9\",\"x2\":\"14\",\"y2\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 3v6l-4 11a0.7 .7 0 0 0 .5 1h11a0.7 .7 0 0 0 .5 -1l-4 -11v-6\"}}]})(props);\n};\nexport function TbFlipHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"12\",\"x2\":\"21\",\"y2\":\"12\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"7 16 17 16 7 21 7 16\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"7 8 17 8 7 3 7 8\"}}]})(props);\n};\nexport function TbFlipVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 7 16 17 21 17 16 7\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"8 7 8 17 3 17 8 7\"}}]})(props);\n};\nexport function TbFloatCenter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"width\":\"6\",\"height\":\"6\",\"x\":\"9\",\"y\":\"5\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"7\",\"x2\":\"5\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"11\",\"x2\":\"5\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"7\",\"x2\":\"20\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"11\",\"x2\":\"20\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"15\",\"x2\":\"20\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"19\",\"x2\":\"20\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbFloatLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"width\":\"6\",\"height\":\"6\",\"x\":\"4\",\"y\":\"5\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"7\",\"x2\":\"20\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"11\",\"x2\":\"20\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"15\",\"x2\":\"20\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"19\",\"x2\":\"20\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbFloatNone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"width\":\"6\",\"height\":\"6\",\"x\":\"4\",\"y\":\"5\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"15\",\"x2\":\"20\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"19\",\"x2\":\"20\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbFloatRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"width\":\"6\",\"height\":\"6\",\"x\":\"14\",\"y\":\"5\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"7\",\"x2\":\"10\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"11\",\"x2\":\"10\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"15\",\"x2\":\"20\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"19\",\"x2\":\"20\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbFlowerOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.875 9.882a3 3 0 0 0 4.247 4.238m.581 -3.423a3.012 3.012 0 0 0 -1.418 -1.409\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5a3 3 0 0 1 6 0c0 .562 -.259 1.442 -.776 2.64l-.724 1.36l1.76 -1.893c.499 -.6 .922 -1.002 1.27 -1.205a2.968 2.968 0 0 1 4.07 1.099a3.011 3.011 0 0 1 -1.09 4.098c-.374 .217 -.99 .396 -1.846 .535l-1.779 .244m.292 .282l1.223 .166c.995 .145 1.698 .337 2.11 .576a3.011 3.011 0 0 1 1.226 3.832m-2.277 1.733a2.968 2.968 0 0 1 -1.929 -.369c-.348 -.202 -.771 -.604 -1.27 -1.205l-1.76 -1.893l.724 1.36c.516 1.199 .776 2.079 .776 2.64a3 3 0 0 1 -6 0c0 -.562 .259 -1.442 .776 -2.64l.724 -1.36l-1.76 1.893c-.499 .601 -.922 1.003 -1.27 1.205a2.968 2.968 0 0 1 -4.07 -1.098a3.011 3.011 0 0 1 1.09 -4.098c.374 -.218 .99 -.396 1.846 -.536l2.664 -.366l-2.4 -.325c-.995 -.145 -1.698 -.337 -2.11 -.576a3.011 3.011 0 0 1 -1.09 -4.099a2.968 2.968 0 0 1 2.134 -1.467\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbFlower (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 2a3 3 0 0 1 3 3c0 .562 -.259 1.442 -.776 2.64l-.724 1.36l1.76 -1.893c.499 -.6 .922 -1.002 1.27 -1.205a2.968 2.968 0 0 1 4.07 1.099a3.011 3.011 0 0 1 -1.09 4.098c-.374 .217 -.99 .396 -1.846 .535l-2.664 .366l2.4 .326c.995 .145 1.698 .337 2.11 .576a3.011 3.011 0 0 1 1.09 4.098a2.968 2.968 0 0 1 -4.07 1.098c-.348 -.202 -.771 -.604 -1.27 -1.205l-1.76 -1.893l.724 1.36c.516 1.199 .776 2.079 .776 2.64a3 3 0 0 1 -6 0c0 -.562 .259 -1.442 .776 -2.64l.724 -1.36l-1.76 1.893c-.499 .601 -.922 1.003 -1.27 1.205a2.968 2.968 0 0 1 -4.07 -1.098a3.011 3.011 0 0 1 1.09 -4.098c.374 -.218 .99 -.396 1.846 -.536l2.664 -.366l-2.4 -.325c-.995 -.145 -1.698 -.337 -2.11 -.576a3.011 3.011 0 0 1 -1.09 -4.099a2.968 2.968 0 0 1 4.07 -1.099c.348 .203 .771 .604 1.27 1.205l1.76 1.894c-1 -2.292 -1.5 -3.625 -1.5 -4a3 3 0 0 1 3 -3z\"}}]})(props);\n};\nexport function TbFocus2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"12\",\"x2\":\"5\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"19\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"12\",\"x2\":\"21\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbFocusCentered (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8v-2a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16v2a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2a2 2 0 0 1 2 2v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h2a2 2 0 0 0 2 -2v-2\"}}]})(props);\n};\nexport function TbFocus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbFoldDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 11v8l3 -3m-6 0l3 3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"7\",\"x2\":\"10\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"7\",\"x2\":\"15\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"7\",\"x2\":\"20\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"7\",\"x2\":\"5\",\"y2\":\"7\"}}]})(props);\n};\nexport function TbFoldUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13v-8l-3 3m6 0l-3 -3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"17\",\"x2\":\"10\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"17\",\"x2\":\"15\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"17\",\"x2\":\"20\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"17\",\"x2\":\"5\",\"y2\":\"17\"}}]})(props);\n};\nexport function TbFold (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v6l3 -3m-6 0l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-6l3 3m-6 0l3 -3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"5\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"12\",\"x2\":\"10\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"12\",\"x2\":\"15\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbFolderMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h4l3 3h7a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-11a2 2 0 0 1 2 -2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"13\",\"x2\":\"15\",\"y2\":\"13\"}}]})(props);\n};\nexport function TbFolderOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 19h-14a2 2 0 0 1 -2 -2v-11a2 2 0 0 1 1.172 -1.821m3.828 -.179h1l3 3h7a2 2 0 0 1 2 2v8\"}}]})(props);\n};\nexport function TbFolderPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h4l3 3h7a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-11a2 2 0 0 1 2 -2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"10\",\"x2\":\"12\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"13\",\"x2\":\"15\",\"y2\":\"13\"}}]})(props);\n};\nexport function TbFolderX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h4l3 3h7a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-11a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 11l4 4m0 -4l-4 4\"}}]})(props);\n};\nexport function TbFolder (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h4l3 3h7a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-11a2 2 0 0 1 2 -2\"}}]})(props);\n};\nexport function TbFoldersOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17h-8a2 2 0 0 1 -2 -2v-8m1.177 -2.823c.251 -.114 .53 -.177 .823 -.177h3l2 2h5a2 2 0 0 1 2 2v7c0 .55 -.223 1.05 -.583 1.411\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v2a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-9a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbFolders (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4h3l2 2h5a2 2 0 0 1 2 2v7a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-9a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v2a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-9a2 2 0 0 1 2 -2h2\"}}]})(props);\n};\nexport function TbForbid2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"15\",\"x2\":\"15\",\"y2\":\"9\"}}]})(props);\n};\nexport function TbForbid (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"9\",\"x2\":\"15\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbForklift (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"17\",\"x2\":\"12\",\"y2\":\"17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17v-6h13v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 11v-4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 11v-6h4l3 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 15h-3v-10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"13\",\"x2\":\"19\",\"y2\":\"13\"}}]})(props);\n};\nexport function TbForms (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3a3 3 0 0 0 -3 3v12a3 3 0 0 0 3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 3a3 3 0 0 1 3 3v12a3 3 0 0 1 -3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 7h7a1 1 0 0 1 1 1v8a1 1 0 0 1 -1 1h-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7h-1a1 1 0 0 0 -1 1v8a1 1 0 0 0 1 1h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 12h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 12h.01\"}}]})(props);\n};\nexport function TbFountainOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 16v-5a2 2 0 1 0 -4 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 16v-1m0 -4a2 2 0 1 1 4 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 16v-4m0 -4v-2a3 3 0 0 1 6 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.451 3.43a3 3 0 0 1 4.549 2.57\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 16h1v1m-.871 3.114a2.99 2.99 0 0 1 -2.129 .886h-12a3 3 0 0 1 -3 -3v-2h13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbFountain (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 16v-5a2 2 0 1 0 -4 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 16v-5a2 2 0 1 1 4 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 16v-10a3 3 0 0 1 6 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6a3 3 0 0 1 6 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 16h18v2a3 3 0 0 1 -3 3h-12a3 3 0 0 1 -3 -3v-2z\"}}]})(props);\n};\nexport function TbFrameOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 7h3m4 0h9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 17h13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7v13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4v9m0 4v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbFrame (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"7\",\"x2\":\"20\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"17\",\"x2\":\"20\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"4\",\"x2\":\"7\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"4\",\"x2\":\"17\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbFreeRights (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.867 9.75c-.246 -.48 -.708 -.769 -1.2 -.75h-1.334c-.736 0 -1.333 .67 -1.333 1.5c0 .827 .597 1.499 1.333 1.499h1.334c.736 0 1.333 .671 1.333 1.5c0 .828 -.597 1.499 -1.333 1.499h-1.334c-.492 .019 -.954 -.27 -1.2 -.75\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 15v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6l1.5 1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.5 16.5l1.5 1.5\"}}]})(props);\n};\nexport function TbFriendsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 5a2 2 0 0 0 2 2m2 -2a2 2 0 0 0 -2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 22v-5l-1 -1v-4a1 1 0 0 1 1 -1h4a1 1 0 0 1 1 1v4l-1 1v5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 22v-4h-2l1.254 -3.763m1.036 -2.942a0.997 .997 0 0 1 .71 -.295h2a1 1 0 0 1 1 1l1.503 4.508m-1.503 2.492v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbFriends (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 22v-5l-1 -1v-4a1 1 0 0 1 1 -1h4a1 1 0 0 1 1 1v4l-1 1v5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 22v-4h-2l2 -6a1 1 0 0 1 1 -1h2a1 1 0 0 1 1 1l2 6h-2v4\"}}]})(props);\n};\nexport function TbGasStationOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 11a2 2 0 0 1 2 2m3 3v-7l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20v-14c0 -.548 .22 -1.044 .577 -1.405m3.423 -.595h4a2 2 0 0 1 2 2v4m0 4v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 20h12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 7v1a1 1 0 0 0 1 1h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 11h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbGasStation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 11h1a2 2 0 0 1 2 2v3a1.5 1.5 0 0 0 3 0v-7l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20v-14a2 2 0 0 1 2 -2h6a2 2 0 0 1 2 2v14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"20\",\"x2\":\"15\",\"y2\":\"20\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 7v1a1 1 0 0 0 1 1h1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"11\",\"x2\":\"14\",\"y2\":\"11\"}}]})(props);\n};\nexport function TbGaugeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.038 16.052a9 9 0 0 0 -12.067 -12.102m-2.333 1.686a9 9 0 1 0 12.73 12.726\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.283 11.303a1 1 0 0 0 1.419 1.41\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10l2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12c0 -1.386 .564 -2.64 1.475 -3.546m2.619 -1.372c.294 -.054 .597 -.082 .906 -.082\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbGauge (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13.41\",\"y1\":\"10.59\",\"x2\":\"16\",\"y2\":\"8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12a5 5 0 0 1 5 -5\"}}]})(props);\n};\nexport function TbGavel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 10l7.383 7.418c.823 .82 .823 2.148 0 2.967a2.11 2.11 0 0 1 -2.976 0l-7.407 -7.385\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 9l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 10l-4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.793 15.793l-3.586 -3.586a1 1 0 0 1 0 -1.414l2.293 -2.293l.5 .5l3 -3l-.5 -.5l2.293 -2.293a1 1 0 0 1 1.414 0l3.586 3.586a1 1 0 0 1 0 1.414l-2.293 2.293l-.5 -.5l-3 3l.5 .5l-2.293 2.293a1 1 0 0 1 -1.414 0z\"}}]})(props);\n};\nexport function TbGenderAgender (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12h11\"}}]})(props);\n};\nexport function TbGenderAndrogyne (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 11l6 -6\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"15\",\"r\":\"5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 9v-4h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.5 10.5l-3 -3\"}}]})(props);\n};\nexport function TbGenderBigender (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"11\",\"cy\":\"11\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 3l-5 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3h4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 16v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 19h6\"}}]})(props);\n};\nexport function TbGenderDemiboy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"10\",\"cy\":\"14\",\"r\":\"5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 5l-5.4 5.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 5h-5\"}}]})(props);\n};\nexport function TbGenderDemigirl (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"9\",\"r\":\"5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14v7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18h3\"}}]})(props);\n};\nexport function TbGenderEpicene (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"transform\":\"rotate(-45 12 12)\",\"cx\":\"12\",\"cy\":\"12\",\"r\":\"5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.536 15.535l5.464 -5.535\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 14l5.464 -5.535\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12h.01\"}}]})(props);\n};\nexport function TbGenderFemale (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"9\",\"r\":\"5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14v7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18h6\"}}]})(props);\n};\nexport function TbGenderFemme (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"9\",\"r\":\"5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14v7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 18h10\"}}]})(props);\n};\nexport function TbGenderGenderfluid (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"g\",\"attr\":{\"transform\":\"rotate(30 -2.778 22.523)\"},\"child\":[{\"tag\":\"circle\",\"attr\":{\"cx\":\"4.759\",\"cy\":\"6.021\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.758 6.02v-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M.758 12.02v-6\"}}]},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 9l-6 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 8.5l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 21l-6 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 20l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7v-4h4\"}}]})(props);\n};\nexport function TbGenderGenderless (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"transform\":\"matrix(1 0 0 -1 0 30)\",\"cx\":\"12\",\"cy\":\"15\",\"r\":\"5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 10v-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 15h10\"}}]})(props);\n};\nexport function TbGenderGenderqueer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"transform\":\"matrix(1 0 0 -1 0 32)\",\"cx\":\"12\",\"cy\":\"16\",\"r\":\"5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 11v-8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.5 4.5l-5 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 4.5l5 3\"}}]})(props);\n};\nexport function TbGenderHermaphrodite (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14v7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18h6\"}},{\"tag\":\"circle\",\"attr\":{\"transform\":\"matrix(1 0 0 -1 0 20)\",\"cx\":\"12\",\"cy\":\"10\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3a3 3 0 0 1 -6 0\"}}]})(props);\n};\nexport function TbGenderIntergender (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 11.5l6.5 6.5v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.5 13.5l6.5 6.5\"}},{\"tag\":\"circle\",\"attr\":{\"transform\":\"matrix(1 0 0 -1 0 18)\",\"cx\":\"9\",\"cy\":\"9\",\"r\":\"5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 20l2 -2\"}}]})(props);\n};\nexport function TbGenderMale (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"10\",\"cy\":\"14\",\"r\":\"5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 5l-5.4 5.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 5h-5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 5v5\"}}]})(props);\n};\nexport function TbGenderNeutrois (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"transform\":\"matrix(1 0 0 -1 0 30)\",\"cx\":\"12\",\"cy\":\"15\",\"r\":\"5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 10v-7\"}}]})(props);\n};\nexport function TbGenderThird (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"transform\":\"rotate(90 16 12)\",\"cx\":\"16\",\"cy\":\"12\",\"r\":\"5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 12h-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12l-5 -4v8z\"}}]})(props);\n};\nexport function TbGenderTransgender (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 9l6 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 7v-4h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 9l-6 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7v-4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 8.5l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 16v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 19h5\"}}]})(props);\n};\nexport function TbGenderTrasvesti (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 20a5 5 0 1 1 0 -10a5 5 0 0 1 0 10z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6l5.4 5.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8l4 -4\"}}]})(props);\n};\nexport function TbGeometry (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 21l4 -12m2 0l1.48 4.439m.949 2.847l1.571 4.714\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"7\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12c1.526 2.955 4.588 5 8 5c3.41 0 6.473 -2.048 8 -5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5v-2\"}}]})(props);\n};\nexport function TbGhost (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 11a7 7 0 0 1 14 0v7a1.78 1.78 0 0 1 -3.1 1.4a1.65 1.65 0 0 0 -2.6 0a1.65 1.65 0 0 1 -2.6 0a1.65 1.65 0 0 0 -2.6 0a1.78 1.78 0 0 1 -3.1 -1.4v-7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"10\",\"x2\":\"10.01\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"10\",\"x2\":\"14.01\",\"y2\":\"10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 14a3.5 3.5 0 0 0 4 0\"}}]})(props);\n};\nexport function TbGift (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"8\",\"width\":\"18\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 12v7a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 8a2.5 2.5 0 0 1 0 -5a4.8 8 0 0 1 4.5 5a4.8 8 0 0 1 4.5 -5a2.5 2.5 0 0 1 0 5\"}}]})(props);\n};\nexport function TbGitBranch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"8\",\"x2\":\"7\",\"y2\":\"16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18h6a2 2 0 0 0 2 -2v-5\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"14 14 17 11 20 14\"}}]})(props);\n};\nexport function TbGitCommit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"15\",\"x2\":\"12\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbGitCompare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 6h5a2 2 0 0 1 2 2v8\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"14 9 11 6 14 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 18h-5a2 2 0 0 1 -2 -2v-8\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"10 15 13 18 10 21\"}}]})(props);\n};\nexport function TbGitFork (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 8v2a2 2 0 0 0 2 2h6a2 2 0 0 0 2 -2v-2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbGitMerge (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"12\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"8\",\"x2\":\"7\",\"y2\":\"16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 8a4 4 0 0 0 4 4h4\"}}]})(props);\n};\nexport function TbGitPullRequestClosed (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 11v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4l4 4m0 -4l-4 4\"}}]})(props);\n};\nexport function TbGitPullRequestDraft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 11h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 6h.01\"}}]})(props);\n};\nexport function TbGitPullRequest (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"8\",\"x2\":\"6\",\"y2\":\"16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 6h5a2 2 0 0 1 2 2v8\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"14 9 11 6 14 3\"}}]})(props);\n};\nexport function TbGizmo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 19l-8 -5.5l-8 5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4v9.5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"4\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"4\",\"cy\":\"19\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"20\",\"cy\":\"19\",\"r\":\"1\"}}]})(props);\n};\nexport function TbGlassFull (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"21\",\"x2\":\"16\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"15\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 3l1 7c0 3.012 -2.686 5 -6 5s-6 -1.988 -6 -5l1 -7h10z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10a5 5 0 0 1 6 0a5 5 0 0 0 6 0\"}}]})(props);\n};\nexport function TbGlassOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"21\",\"x2\":\"16\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"15\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 3h10l1 7a4.511 4.511 0 0 1 -1.053 2.94m-2.386 1.625a7.48 7.48 0 0 1 -2.561 .435c-3.314 0 -6 -1.988 -6 -5l.5 -3.495\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbGlass (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"21\",\"x2\":\"16\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"15\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 3l1 7c0 3.012 -2.686 5 -6 5s-6 -1.988 -6 -5l1 -7h10z\"}}]})(props);\n};\nexport function TbGlobeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.36 8.339a4 4 0 0 0 5.281 5.31m1.995 -1.98a4 4 0 0 0 -5.262 -5.325\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.75 16a8.015 8.015 0 0 0 9.799 .553m2.016 -1.998a8.015 8.015 0 0 0 -2.565 -11.555\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 22h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbGlobe (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"10\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.75 16a8.015 8.015 0 1 0 9.25 -13\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"18\",\"x2\":\"12\",\"y2\":\"22\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"22\",\"x2\":\"16\",\"y2\":\"22\"}}]})(props);\n};\nexport function TbGolfOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18v-6m0 -4v-5l7 4l-5.07 2.897\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17.67c-.62 .36 -1 .82 -1 1.33c0 1.1 1.8 2 4 2s4 -.9 4 -2c0 -.5 -.38 -.97 -1 -1.33\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbGolf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18v-15l7 4l-7 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17.67c-.62 .36 -1 .82 -1 1.33c0 1.1 1.8 2 4 2s4 -.9 4 -2c0 -.5 -.38 -.97 -1 -1.33\"}}]})(props);\n};\nexport function TbGps (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17l-1 -4l-4 -1l9 -4z\"}}]})(props);\n};\nexport function TbGrain (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"4.5\",\"cy\":\"9.5\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9.5\",\"cy\":\"4.5\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9.5\",\"cy\":\"14.5\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"4.5\",\"cy\":\"19.5\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14.5\",\"cy\":\"9.5\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19.5\",\"cy\":\"4.5\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14.5\",\"cy\":\"19.5\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19.5\",\"cy\":\"14.5\",\"r\":\"1\"}}]})(props);\n};\nexport function TbGridDots (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"5\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"5\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"5\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"19\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"19\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"19\",\"r\":\"1\"}}]})(props);\n};\nexport function TbGridPattern (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 8v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 8v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 10h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 14h8\"}}]})(props);\n};\nexport function TbGrillOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8h-3a6 6 0 0 0 6 6h2c.316 0 .626 -.024 .928 -.071m2.792 -1.22a5.99 5.99 0 0 0 2.276 -4.484l.004 -.225h-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.814 18.844a2 2 0 1 1 -2.64 -2.666\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 14l-3 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 18h-8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 5v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbGrill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 8h-14a6 6 0 0 0 6 6h2a6 6 0 0 0 5.996 -5.775l.004 -.225z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 20a2 2 0 1 1 0 -4a2 2 0 0 1 0 4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 14l1 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 14l-3 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 18h-8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 5v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5v-1\"}}]})(props);\n};\nexport function TbGripHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"9\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"15\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"9\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"15\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"9\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"15\",\"r\":\"1\"}}]})(props);\n};\nexport function TbGripVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"5\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"19\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"5\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"19\",\"r\":\"1\"}}]})(props);\n};\nexport function TbGrowth (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.5 15a4.5 4.5 0 0 0 -4.5 4.5m4.5 -8.5a4.5 4.5 0 0 0 -4.5 4.5m4.5 -8.5a4.5 4.5 0 0 0 -4.5 4.5m-4 3.5c2.21 0 4 2.015 4 4.5m-4 -8.5c2.21 0 4 2.015 4 4.5m-4 -8.5c2.21 0 4 2.015 4 4.5m0 -7.5v6\"}}]})(props);\n};\nexport function TbH1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 18v-8l-2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 18h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 18h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 6h2\"}}]})(props);\n};\nexport function TbH2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 12a2 2 0 1 1 4 0c0 .591 -.417 1.318 -.816 1.858l-3.184 4.143l4 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 18h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 18h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 6h2\"}}]})(props);\n};\nexport function TbH3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 14a2 2 0 1 0 -2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 16a2 2 0 1 0 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 18h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 18h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 6h2\"}}]})(props);\n};\nexport function TbH4 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 18v-8l-4 6h5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 18h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 18h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 6h2\"}}]})(props);\n};\nexport function TbH5 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 18h2a2 2 0 1 0 0 -4h-2v-4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 18h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 18h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 6h2\"}}]})(props);\n};\nexport function TbH6 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"transform\":\"rotate(180 19 16)\",\"cx\":\"19\",\"cy\":\"16\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 12a2 2 0 1 0 -4 0v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 18h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 18h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 6h2\"}}]})(props);\n};\nexport function TbHammerOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.698 10.72l-6.668 6.698a2.091 2.091 0 0 0 0 2.967a2.11 2.11 0 0 0 2.976 0l6.696 -6.676\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.713 14.702l1.994 -1.995a1 1 0 0 0 0 -1.414l-7.586 -7.586a1 1 0 0 0 -1.414 0l-1.999 1.999\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbHammer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.414 10l-7.383 7.418a2.091 2.091 0 0 0 0 2.967a2.11 2.11 0 0 0 2.976 0l7.407 -7.385\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.121 15.293l2.586 -2.586a1 1 0 0 0 0 -1.414l-7.586 -7.586a1 1 0 0 0 -1.414 0l-2.586 2.586a1 1 0 0 0 0 1.414l7.586 7.586a1 1 0 0 0 1.414 0z\"}}]})(props);\n};\nexport function TbHandClick (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13v-8.5a1.5 1.5 0 0 1 3 0v7.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 11.5v-2a1.5 1.5 0 0 1 3 0v2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10.5a1.5 1.5 0 0 1 3 0v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 11.5a1.5 1.5 0 0 1 3 0v4.5a6 6 0 0 1 -6 6h-2h.208a6 6 0 0 1 -5.012 -2.7l-.196 -.3c-.312 -.479 -1.407 -2.388 -3.286 -5.728a1.5 1.5 0 0 1 .536 -2.022a1.867 1.867 0 0 1 2.28 .28l1.47 1.47\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 3l-1 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 7h-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3l1 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 6h1\"}}]})(props);\n};\nexport function TbHandFingerOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13v-5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.06 4.077a1.5 1.5 0 0 1 2.94 .423v2.5m0 4v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.063 8.065a1.5 1.5 0 0 1 1.937 1.435v.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.06 10.082a1.5 1.5 0 0 1 2.94 .418v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 11.5a1.5 1.5 0 0 1 3 0v4.5m-.88 3.129a5.996 5.996 0 0 1 -5.12 2.871h-2h.208a6 6 0 0 1 -5.012 -2.7l-.196 -.3c-.312 -.479 -1.407 -2.388 -3.286 -5.728a1.5 1.5 0 0 1 .536 -2.022a1.867 1.867 0 0 1 2.28 .28l1.47 1.47\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbHandFinger (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13v-8.5a1.5 1.5 0 0 1 3 0v7.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 11.5v-2a1.5 1.5 0 1 1 3 0v2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10.5a1.5 1.5 0 0 1 3 0v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 11.5a1.5 1.5 0 0 1 3 0v4.5a6 6 0 0 1 -6 6h-2h.208a6 6 0 0 1 -5.012 -2.7a69.74 69.74 0 0 1 -.196 -.3c-.312 -.479 -1.407 -2.388 -3.286 -5.728a1.5 1.5 0 0 1 .536 -2.022a1.867 1.867 0 0 1 2.28 .28l1.47 1.47\"}}]})(props);\n};\nexport function TbHandGrab (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11v-3.5a1.5 1.5 0 0 1 3 0v2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 9.5v-3a1.5 1.5 0 0 1 3 0v3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 7.5a1.5 1.5 0 0 1 3 0v2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 9.5a1.5 1.5 0 0 1 3 0v4.5a6 6 0 0 1 -6 6h-2h.208a6 6 0 0 1 -5.012 -2.7l-.196 -.3c-.312 -.479 -1.407 -2.388 -3.286 -5.728a1.5 1.5 0 0 1 .536 -2.022a1.867 1.867 0 0 1 2.28 .28l1.47 1.47\"}}]})(props);\n};\nexport function TbHandLittleFinger (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13v-2.5a1.5 1.5 0 0 1 3 0v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 11.5v-1a1.5 1.5 0 0 1 3 0v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 12v-5.5a1.5 1.5 0 0 1 3 0v9.5a6 6 0 0 1 -6 6h-2h.208a6 6 0 0 1 -5.012 -2.7a69.74 69.74 0 0 1 -.196 -.3c-.312 -.479 -1.407 -2.388 -3.286 -5.728a1.5 1.5 0 0 1 .536 -2.022a1.867 1.867 0 0 1 2.28 .28l1.47 1.47\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10.5a1.5 1.5 0 0 1 3 0v1.5\"}}]})(props);\n};\nexport function TbHandMiddleFinger (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13v-2.5a1.5 1.5 0 0 1 3 0v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10.5a1.5 1.5 0 0 1 3 0v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 11.5a1.5 1.5 0 0 1 3 0v4.5a6 6 0 0 1 -6 6h-2h.208a6 6 0 0 1 -5.012 -2.7a69.74 69.74 0 0 1 -.196 -.3c-.312 -.479 -1.407 -2.388 -3.286 -5.728a1.5 1.5 0 0 1 .536 -2.022a1.867 1.867 0 0 1 2.28 .28l1.47 1.47\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 11.5v-8a1.5 1.5 0 1 1 3 0v8.5\"}}]})(props);\n};\nexport function TbHandMove (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13v-8.5a1.5 1.5 0 0 1 3 0v7.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 11.5v-2a1.5 1.5 0 0 1 3 0v2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10.5a1.5 1.5 0 0 1 3 0v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 11.5a1.5 1.5 0 0 1 3 0v4.5a6 6 0 0 1 -6 6h-2h.208a6 6 0 0 1 -5.012 -2.7l-.196 -.3c-.312 -.479 -1.407 -2.388 -3.286 -5.728a1.5 1.5 0 0 1 .536 -2.022a1.867 1.867 0 0 1 2.28 .28l1.47 1.47\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.541 5.594a13.487 13.487 0 0 1 2.46 -1.427\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3.458c1.32 .354 2.558 .902 3.685 1.612\"}}]})(props);\n};\nexport function TbHandOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13.5v-5.5m.44 -3.562a1.5 1.5 0 0 1 2.56 1.062v1.5m0 4.008v.992m0 -6.5v-2a1.5 1.5 0 1 1 3 0v6.5m0 -4.5a1.5 1.5 0 0 1 3 0v6.5m0 -4.5a1.5 1.5 0 0 1 3 0v8.5a6 6 0 0 1 -6 6h-2c-2.114 -.292 -3.956 -1.397 -5 -3l-2.7 -5.25a1.7 1.7 0 0 1 2.75 -2l.9 1.75\"}}]})(props);\n};\nexport function TbHandRingFinger (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13v-2.5a1.5 1.5 0 0 1 3 0v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 11.5a1.5 1.5 0 0 1 3 0v4.5a6 6 0 0 1 -6 6h-2h.208a6 6 0 0 1 -5.012 -2.7a69.74 69.74 0 0 1 -.196 -.3c-.312 -.479 -1.407 -2.388 -3.286 -5.728a1.5 1.5 0 0 1 .536 -2.022a1.867 1.867 0 0 1 2.28 .28l1.47 1.47\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 11.5v-2a1.5 1.5 0 1 1 3 0v2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 12v-6.5a1.5 1.5 0 0 1 3 0v6.5\"}}]})(props);\n};\nexport function TbHandRock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 11.5v-1a1.5 1.5 0 0 1 3 0v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 12v-6.5a1.5 1.5 0 0 1 3 0v10.5a6 6 0 0 1 -6 6h-2h.208a6 6 0 0 1 -5.012 -2.7a69.74 69.74 0 0 1 -.196 -.3c-.312 -.479 -1.407 -2.388 -3.286 -5.728a1.5 1.5 0 0 1 .536 -2.022a1.867 1.867 0 0 1 2.28 .28l1.47 1.47\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10.5a1.5 1.5 0 0 1 3 0v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13v-8.5a1.5 1.5 0 0 1 3 0v7.5\"}}]})(props);\n};\nexport function TbHandStop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13v-7.5a1.5 1.5 0 0 1 3 0v6.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 5.5v-2a1.5 1.5 0 1 1 3 0v8.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 5.5a1.5 1.5 0 0 1 3 0v6.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 7.5a1.5 1.5 0 0 1 3 0v8.5a6 6 0 0 1 -6 6h-2h.208a6 6 0 0 1 -5.012 -2.7a69.74 69.74 0 0 1 -.196 -.3c-.312 -.479 -1.407 -2.388 -3.286 -5.728a1.5 1.5 0 0 1 .536 -2.022a1.867 1.867 0 0 1 2.28 .28l1.47 1.47\"}}]})(props);\n};\nexport function TbHandThreeFingers (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13v-8.5a1.5 1.5 0 0 1 3 0v7.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 11.5a1.5 1.5 0 0 1 3 0v4.5a6 6 0 0 1 -6 6h-2h.208a6 6 0 0 1 -5.012 -2.7a69.74 69.74 0 0 1 -.196 -.3c-.312 -.479 -1.407 -2.388 -3.286 -5.728a1.5 1.5 0 0 1 .536 -2.022a1.867 1.867 0 0 1 2.28 .28l1.47 1.47\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 5.5v-2a1.5 1.5 0 1 1 3 0v8.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 5.5a1.5 1.5 0 0 1 3 0v6.5\"}}]})(props);\n};\nexport function TbHandTwoFingers (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13v-8.5a1.5 1.5 0 0 1 3 0v7.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 11.5a1.5 1.5 0 0 1 3 0v4.5a6 6 0 0 1 -6 6h-2h.208a6 6 0 0 1 -5.012 -2.7a69.74 69.74 0 0 1 -.196 -.3c-.312 -.479 -1.407 -2.388 -3.286 -5.728a1.5 1.5 0 0 1 .536 -2.022a1.867 1.867 0 0 1 2.28 .28l1.47 1.47\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10.5a1.5 1.5 0 0 1 3 0v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 5.5v-2a1.5 1.5 0 1 1 3 0v8.5\"}}]})(props);\n};\nexport function TbHanger2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9l-7.971 4.428a2 2 0 0 0 -1.029 1.749v.823a2 2 0 0 0 2 2h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 18h1a2 2 0 0 0 2 -2v-.823a2 2 0 0 0 -1.029 -1.749l-7.971 -4.428c-1.457 -.81 -1.993 -2.333 -1.996 -4a2 2 0 1 1 4 0\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"6\",\"y\":\"16\",\"width\":\"12\",\"height\":\"5\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbHangerOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.004 6a2 2 0 1 0 -4 0m6.506 6.506l3.461 1.922a2 2 0 0 1 1.029 1.749v.823m-2 2h-14a2 2 0 0 1 -2 -2v-.823a2 2 0 0 1 1.029 -1.749l6.673 -3.707\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbHanger (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.004 6a2 2 0 1 0 -4 0c.003 1.667 .67 3 2.004 4h-.008l7.971 4.428a2 2 0 0 1 1.029 1.749v.823a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-.823a2 2 0 0 1 1.029 -1.749l7.971 -4.428\"}}]})(props);\n};\nexport function TbHash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"9\",\"x2\":\"19\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"15\",\"x2\":\"19\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"4\",\"x2\":\"7\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"4\",\"x2\":\"13\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbHaze (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.6 5.6l.7 .7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.4 5.6l-.7 .7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12a4 4 0 1 1 8 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 16h18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 20h18\"}}]})(props);\n};\nexport function TbHeadingOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12h5m4 0h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 5v8m0 4v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 19h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 5h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 19h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbHeading (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 5v14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 5v14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 19h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 5h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 19h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 5h4\"}}]})(props);\n};\nexport function TbHeadphonesOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"13\",\"width\":\"5\",\"height\":\"7\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 13h1a2 2 0 0 1 2 2v1m-.589 3.417c-.361 .36 -.86 .583 -1.411 .583h-1a2 2 0 0 1 -2 -2v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 15v-3c0 -2.21 .896 -4.21 2.344 -5.658m2.369 -1.638a8 8 0 0 1 11.287 7.296v3\"}}]})(props);\n};\nexport function TbHeadphones (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"13\",\"rx\":\"2\",\"width\":\"5\",\"height\":\"7\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"15\",\"y\":\"13\",\"rx\":\"2\",\"width\":\"5\",\"height\":\"7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 15v-3a8 8 0 0 1 16 0v3\"}}]})(props);\n};\nexport function TbHeadset (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"13\",\"rx\":\"2\",\"width\":\"4\",\"height\":\"6\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"16\",\"y\":\"13\",\"rx\":\"2\",\"width\":\"4\",\"height\":\"6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 15v-3a8 8 0 0 1 16 0v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 19a6 3 0 0 1 -6 3\"}}]})(props);\n};\nexport function TbHeartBroken (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.5 12.572l-7.5 7.428l-7.5 -7.428a5 5 0 1 1 7.5 -6.566a5 5 0 1 1 7.5 6.572\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6l-2 4l4 3l-2 4v3\"}}]})(props);\n};\nexport function TbHeartHandshake (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.5 12.572l-7.5 7.428l-7.5 -7.428a5 5 0 1 1 7.5 -6.566a5 5 0 1 1 7.5 6.572\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6l-3.293 3.293a1 1 0 0 0 0 1.414l.543 .543c.69 .69 1.81 .69 2.5 0l1 -1a3.182 3.182 0 0 1 4.5 0l2.25 2.25\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 15.5l2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 13l2 2\"}}]})(props);\n};\nexport function TbHeartMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 19l-1 1l-7.5 -7.428a5 5 0 1 1 7.5 -6.566a5 5 0 0 1 8 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 17h6\"}}]})(props);\n};\nexport function TbHeartOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.5 12.572l-1.5 1.428m-2 2l-4 4l-7.5 -7.428m0 0a5 5 0 0 1 -1.288 -5.068a4.976 4.976 0 0 1 1.788 -2.504m3 -1c1.56 .003 3.05 .727 4 2.006a5 5 0 1 1 7.5 6.572\"}}]})(props);\n};\nexport function TbHeartPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 19l-1 1l-7.5 -7.428a5 5 0 1 1 7.5 -6.566a5 5 0 0 1 8.003 5.996\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 16h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 13v6\"}}]})(props);\n};\nexport function TbHeartRateMonitor (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"4\",\"width\":\"18\",\"height\":\"12\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 20h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 16v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 16v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 10h2l2 3l2 -6l1 3h3\"}}]})(props);\n};\nexport function TbHeart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.5 12.572l-7.5 7.428l-7.5 -7.428m0 0a5 5 0 1 1 7.5 -6.566a5 5 0 1 1 7.5 6.572\"}}]})(props);\n};\nexport function TbHeartbeat (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.5 13.572l-7.5 7.428l-2.896 -2.868m-6.117 -8.104a5 5 0 0 1 9.013 -3.022a5 5 0 1 1 7.5 6.572\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 13h2l2 3l2 -6l1 3h3\"}}]})(props);\n};\nexport function TbHelicopterLanding (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"8\",\"x2\":\"9\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"12\",\"x2\":\"15\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"8\",\"x2\":\"15\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbHelicopter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 10l1 2h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9a2 2 0 0 0 -2 2v3c0 1.1 .9 2 2 2h7a2 2 0 0 0 2 -2c0 -3.31 -3.13 -5 -7 -5h-2z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"9\",\"x2\":\"13\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"6\",\"x2\":\"20\",\"y2\":\"6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 9.1v3.9h5.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"19\",\"x2\":\"15\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"19\",\"x2\":\"11\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbHelmetOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.633 4.654a9 9 0 0 1 11.718 11.7m-1.503 2.486a9.008 9.008 0 0 1 -1.192 1.16h-11.312a9 9 0 0 1 -.185 -13.847\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 9h-7m-2.768 1.246c.507 2 1.596 3.418 3.268 4.254c.524 .262 1.07 .49 1.64 .683\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbHelmet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4a9 9 0 0 1 5.656 16h-11.312a9 9 0 0 1 5.656 -16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 9h-8.8a1 1 0 0 0 -.968 1.246c.507 2 1.596 3.418 3.268 4.254c2 1 4.333 1.5 7 1.5\"}}]})(props);\n};\nexport function TbHelp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"17\",\"x2\":\"12\",\"y2\":\"17.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13.5a1.5 1.5 0 0 1 1 -1.5a2.6 2.6 0 1 0 -3 -4\"}}]})(props);\n};\nexport function TbHexagonOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.693 4.69l2.336 -1.39a2.056 2.056 0 0 1 2 0l6 3.573h-.029a2 2 0 0 1 1 1.747v6.536c0 .246 -.045 .485 -.13 .707m-2.16 1.847l-4.739 3.027a2 2 0 0 1 -1.942 0l-6 -3.833a2 2 0 0 1 -1.029 -1.747v-6.537a2 2 0 0 1 1.029 -1.748l1.154 -.687\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbHexagon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 6.873a2 2 0 0 1 1 1.747v6.536a2 2 0 0 1 -1.029 1.748l-6 3.833a2 2 0 0 1 -1.942 0l-6 -3.833a2 2 0 0 1 -1.029 -1.747v-6.537a2 2 0 0 1 1.029 -1.748l6 -3.572a2.056 2.056 0 0 1 2 0l6 3.573z\"}}]})(props);\n};\nexport function TbHexagons (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18v-5l4 -2l4 2v5l-4 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11v-5l4 -2l4 2v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13l4 -2l4 2v5l-4 2l-4 -2\"}}]})(props);\n};\nexport function TbHierarchy2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 3h4v4h-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17h4v4h-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17h4v4h-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 17l5 -4l5 4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"7\",\"x2\":\"12\",\"y2\":\"13\"}}]})(props);\n};\nexport function TbHierarchy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 17.5l5.5 -4.5l5.5 4.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"7\",\"x2\":\"12\",\"y2\":\"13\"}}]})(props);\n};\nexport function TbHighlightOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.998 9.002l-5.998 5.998v4h4l6 -6m1.997 -1.997l2.503 -2.503a2.828 2.828 0 1 0 -4 -4l-2.497 2.497\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 5.5l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 13.5l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 15h2v2m-2 2h-6l3.004 -3.004\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbHighlight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19h4l10.5 -10.5a2.828 2.828 0 1 0 -4 -4l-10.5 10.5v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 5.5l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 13.5l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 15v4h-8l4 -4z\"}}]})(props);\n};\nexport function TbHistory (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"12 8 12 12 14 14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.05 11a9 9 0 1 1 .5 4m-.5 5v-5h5\"}}]})(props);\n};\nexport function TbHome2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"5 12 3 12 12 3 21 12 19 12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12v7a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-7\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"10\",\"y\":\"12\",\"width\":\"4\",\"height\":\"4\"}}]})(props);\n};\nexport function TbHomeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12h-2l4.497 -4.497m1.999 -1.999l2.504 -2.504l9 9h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12v7a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2m0 -4v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 21v-6a2 2 0 0 1 2 -2h2m2 2v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbHome (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"5 12 3 12 12 3 21 12 19 12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12v7a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 21v-6a2 2 0 0 1 2 -2h2a2 2 0 0 1 2 2v6\"}}]})(props);\n};\nexport function TbHotelService (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 10a1.5 1.5 0 0 1 -1.5 -1.5a5.5 5.5 0 0 1 11 0v10.5a2 2 0 0 1 -2 2h-7a2 2 0 0 1 -2 -2v-2c0 -1.38 .71 -2.444 1.88 -3.175l4.424 -2.765c1.055 -.66 1.696 -1.316 1.696 -2.56a2.5 2.5 0 1 0 -5 0a1.5 1.5 0 0 1 -1.5 1.5z\"}}]})(props);\n};\nexport function TbHourglassEmpty (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 20v-2a6 6 0 1 1 12 0v2a1 1 0 0 1 -1 1h-10a1 1 0 0 1 -1 -1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 4v2a6 6 0 1 0 12 0v-2a1 1 0 0 0 -1 -1h-10a1 1 0 0 0 -1 1z\"}}]})(props);\n};\nexport function TbHourglassHigh (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 7h11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 20v-2a6 6 0 1 1 12 0v2a1 1 0 0 1 -1 1h-10a1 1 0 0 1 -1 -1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 4v2a6 6 0 1 0 12 0v-2a1 1 0 0 0 -1 -1h-10a1 1 0 0 0 -1 1z\"}}]})(props);\n};\nexport function TbHourglassLow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 17h11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 20v-2a6 6 0 1 1 12 0v2a1 1 0 0 1 -1 1h-10a1 1 0 0 1 -1 -1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 4v2a6 6 0 1 0 12 0v-2a1 1 0 0 0 -1 -1h-10a1 1 0 0 0 -1 1z\"}}]})(props);\n};\nexport function TbHourglassOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 18v2a1 1 0 0 1 -1 1h-10a1 1 0 0 1 -1 -1v-2a6 6 0 0 1 6 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6a6 6 0 0 0 6 6m3.13 -.88a5.996 5.996 0 0 0 2.87 -5.12v-2a1 1 0 0 0 -1 -1h-10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbHourglass (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 7h11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 17h11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 20v-2a6 6 0 1 1 12 0v2a1 1 0 0 1 -1 1h-10a1 1 0 0 1 -1 -1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 4v2a6 6 0 1 0 12 0v-2a1 1 0 0 0 -1 -1h-10a1 1 0 0 0 -1 1z\"}}]})(props);\n};\nexport function TbIceCream2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.657 11.004a6 6 0 1 0 -11.315 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.342 11l5.658 11l5.657 -10.996z\"}}]})(props);\n};\nexport function TbIceCreamOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21.5v-4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8v9h8v-1m0 -4v-5a4 4 0 0 0 -7.277 -2.294\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 10.5l1.74 -.76m2.79 -1.222l3.47 -1.518\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 14.5l4.488 -1.964\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbIceCream (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21.5v-4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 17h8v-10a4 4 0 1 0 -8 0v10z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 10.5l8 -3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 14.5l8 -3.5\"}}]})(props);\n};\nexport function TbIceSkating (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.905 5h3.418a1 1 0 0 1 .928 .629l1.143 2.856a3 3 0 0 0 2.207 1.83l4.717 .926a2.084 2.084 0 0 1 1.682 2.045v.714a1 1 0 0 1 -1 1h-13.895a1 1 0 0 1 -.995 -1.1l.8 -8a1 1 0 0 1 .995 -.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19h17a1 1 0 0 0 1 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 15v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 15v4\"}}]})(props);\n};\nexport function TbIcons (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6.5\",\"cy\":\"6.5\",\"r\":\"3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 21h8l-4 -7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3l7 7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10l7 -7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14h7v7h-7z\"}}]})(props);\n};\nexport function TbIdBadge2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12h3v4h-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6h-6a1 1 0 0 0 -1 1v12a1 1 0 0 0 1 1h16a1 1 0 0 0 1 -1v-12a1 1 0 0 0 -1 -1h-6\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"10\",\"y\":\"3\",\"width\":\"4\",\"height\":\"5\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 16h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 12h4\"}}]})(props);\n};\nexport function TbIdBadge (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"3\",\"width\":\"14\",\"height\":\"18\",\"rx\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"13\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18h6\"}}]})(props);\n};\nexport function TbIdOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h10a3 3 0 0 1 3 3v10m-1.437 2.561c-.455 .279 -.99 .439 -1.563 .439h-12a3 3 0 0 1 -3 -3v-10c0 -1.083 .573 -2.031 1.433 -2.559\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.175 8.178a2 2 0 1 0 2.646 2.65\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 8h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 16h9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbId (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"4\",\"width\":\"18\",\"height\":\"16\",\"rx\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"10\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"8\",\"x2\":\"17\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"12\",\"x2\":\"17\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"16\",\"x2\":\"17\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbInboxOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h10a2 2 0 0 1 2 2v10m-.593 3.422a1.994 1.994 0 0 1 -1.407 .578h-12a2 2 0 0 1 -2 -2v-12c0 -.554 .225 -1.056 .59 -1.418\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 13h3l3 3h4l.987 -.987m2.013 -2.013h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbInbox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 13h3l3 3h4l3 -3h3\"}}]})(props);\n};\nexport function TbIndentDecrease (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"6\",\"x2\":\"13\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"12\",\"x2\":\"11\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"18\",\"x2\":\"13\",\"y2\":\"18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8l-4 4l4 4\"}}]})(props);\n};\nexport function TbIndentIncrease (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"6\",\"x2\":\"9\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"12\",\"x2\":\"13\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"18\",\"x2\":\"9\",\"y2\":\"18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8l4 4l-4 4\"}}]})(props);\n};\nexport function TbInfinity (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.828 9.172a4 4 0 1 0 0 5.656a10 10 0 0 0 2.172 -2.828a10 10 0 0 1 2.172 -2.828a4 4 0 1 1 0 5.656a10 10 0 0 1 -2.172 -2.828a10 10 0 0 0 -2.172 -2.828\"}}]})(props);\n};\nexport function TbInfoCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12.01\",\"y2\":\"8\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"11 12 12 12 12 16 13 16\"}}]})(props);\n};\nexport function TbInfoSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12.01\",\"y2\":\"8\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"11 12 12 12 12 16 13 16\"}}]})(props);\n};\nexport function TbItalic (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"5\",\"x2\":\"17\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"19\",\"x2\":\"13\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"5\",\"x2\":\"10\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbJewishStar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 2l3 5h6l-3 5l3 5h-6l-3 5l-3 -5h-6l3 -5l-3 -5h6z\"}}]})(props);\n};\nexport function TbJumpRope (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 14v-6a3 3 0 1 1 6 0v8a3 3 0 0 0 6 0v-6\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"16\",\"y\":\"3\",\"width\":\"4\",\"height\":\"7\",\"rx\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"14\",\"width\":\"4\",\"height\":\"7\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbKarate (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"4\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 9l4.5 1l3 2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 21v-8l3 -5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4.5l4 2l4 1l4 3.5l-2 3.5\"}}]})(props);\n};\nexport function TbKayak (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.414 6.414a2 2 0 0 0 0 -2.828l-1.414 -1.414l-2.828 2.828l1.414 1.414a2 2 0 0 0 2.828 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.586 17.586a2 2 0 0 0 0 2.828l1.414 1.414l2.828 -2.828l-1.414 -1.414a2 2 0 0 0 -2.828 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 6.5l11 11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 2.5c-9.983 2.601 -17.627 7.952 -20 19.5c9.983 -2.601 17.627 -7.952 20 -19.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 12.5l5 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 6.5l5 5\"}}]})(props);\n};\nexport function TbKering (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 15v-3.5a2.5 2.5 0 1 1 5 0v3.5m0 -2h-5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 9l3 6l3 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 20l6 -16\"}}]})(props);\n};\nexport function TbKeyOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"15\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.85 12.15l.65 -.65m2 -2l5.5 -5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 5l2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 8l2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbKey (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"15\",\"r\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10.85\",\"y1\":\"12.15\",\"x2\":\"19\",\"y2\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"5\",\"x2\":\"20\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"8\",\"x2\":\"17\",\"y2\":\"10\"}}]})(props);\n};\nexport function TbKeyboardHide (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"2\",\"y\":\"3\",\"width\":\"20\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"7\",\"x2\":\"6\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"7\",\"x2\":\"10\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"7\",\"x2\":\"14\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"7\",\"x2\":\"18\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"11\",\"x2\":\"6\",\"y2\":\"11.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"11\",\"x2\":\"18\",\"y2\":\"11.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"11\",\"x2\":\"14\",\"y2\":\"11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 21l2 -2l2 2\"}}]})(props);\n};\nexport function TbKeyboardOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 18h-14a2 2 0 0 1 -2 -2v-8a2 2 0 0 1 2 -2h2m4 0h10a2 2 0 0 1 2 2v8c0 .554 -.226 1.056 -.59 1.418\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"10\",\"x2\":\"6\",\"y2\":\"10.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"10\",\"x2\":\"10\",\"y2\":\"10.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"10\",\"x2\":\"14\",\"y2\":\"10.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"10\",\"x2\":\"18\",\"y2\":\"10.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"14\",\"x2\":\"6\",\"y2\":\"14.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"14\",\"x2\":\"18\",\"y2\":\"14.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"14\",\"x2\":\"14\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbKeyboardShow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"2\",\"y\":\"3\",\"width\":\"20\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"7\",\"x2\":\"6\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"7\",\"x2\":\"10\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"7\",\"x2\":\"14\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"7\",\"x2\":\"18\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"11\",\"x2\":\"6\",\"y2\":\"11.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"11\",\"x2\":\"18\",\"y2\":\"11.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"11\",\"x2\":\"14\",\"y2\":\"11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 19l2 2l2 -2\"}}]})(props);\n};\nexport function TbKeyboard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"2\",\"y\":\"6\",\"width\":\"20\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"10\",\"x2\":\"6\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"10\",\"x2\":\"10\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"10\",\"x2\":\"14\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"10\",\"x2\":\"18\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"14\",\"x2\":\"6\",\"y2\":\"14.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"14\",\"x2\":\"18\",\"y2\":\"14.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"14\",\"x2\":\"14\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbLadderOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 3v1m0 4v13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 3v9m0 4v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 14h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 10h2m4 0h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 18h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbLadder (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 3v18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 3v18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 14h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 10h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 6h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 18h8\"}}]})(props);\n};\nexport function TbLamp2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 21h9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 21l-7 -8l8.5 -5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 14c-2.148 -2.148 -2.148 -5.852 0 -8c2.088 -2.088 5.842 -1.972 8 0l-8 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.742 7.574l-1.156 -1.156a2 2 0 0 1 2.828 -2.829l1.144 1.144\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.5 11.995l.208 .274a2.527 2.527 0 0 0 3.556 0c.939 -.933 .98 -2.42 .122 -3.4l-.366 -.369\"}}]})(props);\n};\nexport function TbLampOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 20h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20v-8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.325 7.35l-2.325 4.65h7m4 0h3l-4 -8h-6l-.338 .676\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbLamp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 20h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20v-8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12h14l-4 -8h-6z\"}}]})(props);\n};\nexport function TbLanguageHiragana (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 5h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 4c0 4.846 0 7 .5 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 8.5c0 2.286 -2 4.5 -3.5 4.5s-2.5 -1.135 -2.5 -2c0 -2 1 -3 3 -3s5 .57 5 2.857c0 1.524 -.667 2.571 -2 3.143\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20l4 -9l4 9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.1 18h-6.2\"}}]})(props);\n};\nexport function TbLanguageKatakana (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 5h6.586a1 1 0 0 1 .707 1.707l-1.293 1.293\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8c0 1.5 .5 3 -2 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20l4 -9l4 9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.1 18h-6.2\"}}]})(props);\n};\nexport function TbLanguageOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 5h1m4 0h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 3v2m-.508 3.517c-.814 2.655 -2.52 4.483 -4.492 4.483\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 9c-.003 2.144 2.952 3.908 6.7 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20l2.463 -5.541m1.228 -2.764l.309 -.695l.8 1.8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 18h-5.1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbLanguage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 5h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 3v2c0 4.418 -2.239 8 -5 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 9c-.003 2.144 2.952 3.908 6.7 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20l4 -9l4 9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.1 18h-6.2\"}}]})(props);\n};\nexport function TbLassoOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.028 13.252c-.657 -.972 -1.028 -2.078 -1.028 -3.252c0 -1.804 .878 -3.449 2.319 -4.69m2.49 -1.506a11.066 11.066 0 0 1 4.191 -.804c4.97 0 9 3.134 9 7c0 1.799 -.873 3.44 -2.307 4.68m-2.503 1.517a11.066 11.066 0 0 1 -4.19 .803c-1.913 0 -3.686 -.464 -5.144 -1.255\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"15\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 17c0 1.42 .316 2.805 1 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbLasso (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.028 13.252c-.657 -.972 -1.028 -2.078 -1.028 -3.252c0 -3.866 4.03 -7 9 -7s9 3.134 9 7s-4.03 7 -9 7c-1.913 0 -3.686 -.464 -5.144 -1.255\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"15\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 17c0 1.42 .316 2.805 1 4\"}}]})(props);\n};\nexport function TbLayersDifference (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16v2a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2v-8a2 2 0 0 1 2 -2h2v-2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-2\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"10 8 8 8 8 10\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"8 14 8 16 10 16\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"14 8 16 8 16 10\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 14 16 16 14 16\"}}]})(props);\n};\nexport function TbLayersIntersect2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"4\",\"width\":\"12\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"8\",\"width\":\"12\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 15l6 -6\"}}]})(props);\n};\nexport function TbLayersIntersect (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"4\",\"width\":\"12\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"8\",\"width\":\"12\",\"height\":\"12\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbLayersLinked (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 8.268a2 2 0 0 1 1 1.732v8a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2v-8a2 2 0 0 1 2 -2h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.003 15.734a2 2 0 0 1 -1.003 -1.734v-8a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-3\"}}]})(props);\n};\nexport function TbLayersOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.59 4.581c.362 -.359 .86 -.581 1.41 -.581h8a2 2 0 0 1 2 2v8c0 .556 -.227 1.06 -.594 1.422m-3.406 .578h-6a2 2 0 0 1 -2 -2v-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16v2a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2v-8a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbLayersSubtract (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"4\",\"width\":\"12\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16v2a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2v-8a2 2 0 0 1 2 -2h2\"}}]})(props);\n};\nexport function TbLayersUnion (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16v2a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2v-8a2 2 0 0 1 2 -2h2v-2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-2\"}}]})(props);\n};\nexport function TbLayout2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"6\",\"height\":\"5\",\"rx\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"13\",\"width\":\"6\",\"height\":\"7\",\"rx\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"14\",\"y\":\"4\",\"width\":\"6\",\"height\":\"7\",\"rx\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"14\",\"y\":\"15\",\"width\":\"6\",\"height\":\"5\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbLayoutAlignBottom (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"20\",\"y2\":\"20\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"4\",\"width\":\"6\",\"height\":\"12\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbLayoutAlignCenter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"15\",\"x2\":\"12\",\"y2\":\"20\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"6\",\"y\":\"9\",\"width\":\"12\",\"height\":\"6\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbLayoutAlignLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"4\",\"y2\":\"20\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"9\",\"width\":\"12\",\"height\":\"6\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbLayoutAlignMiddle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"9\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"6\",\"width\":\"6\",\"height\":\"12\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbLayoutAlignRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"20\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"9\",\"width\":\"12\",\"height\":\"6\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbLayoutAlignTop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"4\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"8\",\"width\":\"6\",\"height\":\"12\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbLayoutBoardSplit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 15h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4v16\"}}]})(props);\n};\nexport function TbLayoutBoard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 9h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 15h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4v16\"}}]})(props);\n};\nexport function TbLayoutBottombar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"15\",\"x2\":\"20\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbLayoutCards (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"6\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"14\",\"y\":\"4\",\"width\":\"6\",\"height\":\"10\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbLayoutColumns (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbLayoutDashboard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4h6v8h-6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16h6v4h-6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 12h6v8h-6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4h6v4h-6z\"}}]})(props);\n};\nexport function TbLayoutDistributeHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"20\",\"y2\":\"20\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"6\",\"y\":\"9\",\"width\":\"12\",\"height\":\"6\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbLayoutDistributeVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"4\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"20\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"6\",\"width\":\"6\",\"height\":\"12\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbLayoutGridAdd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"14\",\"y\":\"4\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"14\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 17h6m-3 -3v6\"}}]})(props);\n};\nexport function TbLayoutGrid (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"14\",\"y\":\"4\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"14\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"14\",\"y\":\"14\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}}]})(props);\n};\nexport function TbLayoutKanban (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"4\",\"x2\":\"10\",\"y2\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"4\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"8\",\"width\":\"6\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"14\",\"y\":\"8\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbLayoutList (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"6\",\"rx\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"14\",\"width\":\"16\",\"height\":\"6\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbLayoutNavbar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"9\",\"x2\":\"20\",\"y2\":\"9\"}}]})(props);\n};\nexport function TbLayoutOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4a2 2 0 0 1 2 2m-1.162 2.816a1.993 1.993 0 0 1 -.838 .184h-2a2 2 0 0 1 -2 -2v-1c0 -.549 .221 -1.046 .58 -1.407\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"13\",\"width\":\"6\",\"height\":\"7\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10v-4a2 2 0 0 1 2 -2h2a2 2 0 0 1 2 2v10m-.595 3.423a1.994 1.994 0 0 1 -1.405 .577h-2a2 2 0 0 1 -2 -2v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbLayoutRows (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbLayoutSidebarLeftCollapse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4v16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 10l-2 2l2 2\"}}]})(props);\n};\nexport function TbLayoutSidebarLeftExpand (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4v16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10l2 2l-2 2\"}}]})(props);\n};\nexport function TbLayoutSidebarRightCollapse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 4v16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 10l2 2l-2 2\"}}]})(props);\n};\nexport function TbLayoutSidebarRightExpand (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 4v16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10l-2 2l2 2\"}}]})(props);\n};\nexport function TbLayoutSidebarRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"4\",\"x2\":\"15\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbLayoutSidebar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"4\",\"x2\":\"9\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbLayout (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"6\",\"height\":\"5\",\"rx\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"13\",\"width\":\"6\",\"height\":\"7\",\"rx\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"14\",\"y\":\"4\",\"width\":\"6\",\"height\":\"16\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbLeafOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 21c.474 -4.264 2.294 -7.63 6.313 -9.673\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.622 6.62c-1.877 1.625 -2.629 3.877 -2.636 6.38c0 1 0 3 2 5h3.014c2.73 0 5.086 -.633 6.913 -2.081m1.901 -2.098c1.227 -1.871 1.992 -4.437 2.186 -7.821v-2h-4.014c-2.863 0 -5.117 .405 -6.86 1.118\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbLeaf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 21c.5 -4.5 2.5 -8 7 -10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18c6.218 0 10.5 -3.288 11 -12v-2h-4.014c-9 0 -11.986 4 -12 9c0 1 0 3 2 5h3z\"}}]})(props);\n};\nexport function TbLego (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9.5\",\"y1\":\"11\",\"x2\":\"9.51\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14.5\",\"y1\":\"11\",\"x2\":\"14.51\",\"y2\":\"11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 15a3.5 3.5 0 0 0 5 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 5h1v-2h8v2h1a3 3 0 0 1 3 3v9a3 3 0 0 1 -3 3v1h-10v-1a3 3 0 0 1 -3 -3v-9a3 3 0 0 1 3 -3\"}}]})(props);\n};\nexport function TbLemon2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 4a2 2 0 0 1 1.185 3.611c1.55 2.94 .873 6.917 -1.892 9.682c-2.765 2.765 -6.743 3.442 -9.682 1.892a2 2 0 1 1 -2.796 -2.796c-1.55 -2.94 -.873 -6.917 1.892 -9.682c2.765 -2.765 6.743 -3.442 9.682 -1.892a1.999 1.999 0 0 1 1.611 -.815z\"}}]})(props);\n};\nexport function TbLemon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.536 3.393c3.905 3.906 3.905 10.237 0 14.143c-3.906 3.905 -10.237 3.905 -14.143 0l14.143 -14.143\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.868 15.06a6.5 6.5 0 0 0 9.193 -9.192\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.464 10.464l4.597 4.597\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.464 10.464v6.364\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.464 10.464h6.364\"}}]})(props);\n};\nexport function TbLetterA (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 20v-12a4 4 0 0 1 4 -4h2a4 4 0 0 1 4 4v12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"13\",\"x2\":\"17\",\"y2\":\"13\"}}]})(props);\n};\nexport function TbLetterB (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 20v-16h6a4 4 0 0 1 0 8a4 4 0 0 1 0 8h-6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"12\",\"x2\":\"13\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbLetterC (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 9a5 5 0 0 0 -5 -5h-2a5 5 0 0 0 -5 5v6a5 5 0 0 0 5 5h2a5 5 0 0 0 5 -5\"}}]})(props);\n};\nexport function TbLetterCaseLower (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6.5\",\"cy\":\"15.5\",\"r\":\"3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12v7\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17.5\",\"cy\":\"15.5\",\"r\":\"3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 12v7\"}}]})(props);\n};\nexport function TbLetterCaseToggle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6.5\",\"cy\":\"15.5\",\"r\":\"3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 19v-10.5a3.5 3.5 0 0 1 7 0v10.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 13h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12v7\"}}]})(props);\n};\nexport function TbLetterCaseUpper (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19v-10.5a3.5 3.5 0 0 1 7 0v10.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 13h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 19v-10.5a3.5 3.5 0 0 1 7 0v10.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 13h7\"}}]})(props);\n};\nexport function TbLetterCase (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17.5\",\"cy\":\"15.5\",\"r\":\"3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19v-10.5a3.5 3.5 0 0 1 7 0v10.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 13h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 12v7\"}}]})(props);\n};\nexport function TbLetterD (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 4h6a5 5 0 0 1 5 5v6a5 5 0 0 1 -5 5h-6v-16\"}}]})(props);\n};\nexport function TbLetterE (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4h-10v16h10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"12\",\"x2\":\"15\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbLetterF (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4h-10v16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"12\",\"x2\":\"15\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbLetterG (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 9a5 5 0 0 0 -5 -5h-2a5 5 0 0 0 -5 5v6a5 5 0 0 0 5 5h2a5 5 0 0 0 5 -5v-2h-4\"}}]})(props);\n};\nexport function TbLetterH (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"4\",\"x2\":\"17\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"12\",\"x2\":\"17\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"4\",\"x2\":\"7\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbLetterI (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbLetterJ (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4v12a4 4 0 0 1 -4 4h-2a4 4 0 0 1 -4 -4\"}}]})(props);\n};\nexport function TbLetterK (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"4\",\"x2\":\"7\",\"y2\":\"20\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12h2l8 -8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"12\",\"x2\":\"17\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbLetterL (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 4v16h10\"}}]})(props);\n};\nexport function TbLetterM (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 20v-16l6 14l6 -14v16\"}}]})(props);\n};\nexport function TbLetterN (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 20v-16l10 16v-16\"}}]})(props);\n};\nexport function TbLetterO (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 9a5 5 0 0 0 -5 -5h-2a5 5 0 0 0 -5 5v6a5 5 0 0 0 5 5h2a5 5 0 0 0 5 -5v-6\"}}]})(props);\n};\nexport function TbLetterP (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 20v-16h5.5a4 4 0 0 1 0 9h-5.5\"}}]})(props);\n};\nexport function TbLetterQ (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 9a5 5 0 0 0 -5 -5h-2a5 5 0 0 0 -5 5v6a5 5 0 0 0 5 5h2a5 5 0 0 0 5 -5v-6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"15\",\"x2\":\"18\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbLetterR (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 20v-16h5.5a4 4 0 0 1 0 9h-5.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"13\",\"x2\":\"17\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbLetterS (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 8a4 4 0 0 0 -4 -4h-2a4 4 0 0 0 0 8h2a4 4 0 0 1 0 8h-2a4 4 0 0 1 -4 -4\"}}]})(props);\n};\nexport function TbLetterSpacing (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12v-5.5a2.5 2.5 0 0 1 5 0v5.5m0 -4h-5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 4l3 8l3 -8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 18h14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 20l2 -2l-2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 16l-2 2l2 2\"}}]})(props);\n};\nexport function TbLetterT (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"4\",\"x2\":\"18\",\"y2\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbLetterU (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 4v11a5 5 0 0 0 5 5h2a5 5 0 0 0 5 -5v-11\"}}]})(props);\n};\nexport function TbLetterV (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 4l6 16l6 -16\"}}]})(props);\n};\nexport function TbLetterW (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4l4 16l4 -14l4 14l4 -16\"}}]})(props);\n};\nexport function TbLetterX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"4\",\"x2\":\"17\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"4\",\"x2\":\"7\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbLetterY (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 4l5 9l5 -9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"13\",\"x2\":\"12\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbLetterZ (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 4h10l-10 16h10\"}}]})(props);\n};\nexport function TbLicenseOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 21h-9a3 3 0 0 1 -3 -3v-1h10v2a2 2 0 1 0 4 0v-2m0 -4v-8a2 2 0 1 1 2 2h-2m2 -4h-11a3 3 0 0 0 -.864 .126m-2.014 2.025a3 3 0 0 0 -.122 .849v11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 11h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbLicense (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 21h-9a3 3 0 0 1 -3 -3v-1h10v2a2 2 0 0 0 4 0v-14a2 2 0 1 1 2 2h-2m2 -4h-11a3 3 0 0 0 -3 3v11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"7\",\"x2\":\"13\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"11\",\"x2\":\"13\",\"y2\":\"11\"}}]})(props);\n};\nexport function TbLifebuoyOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.171 9.172a4 4 0 0 0 5.65 5.663m1.179 -2.835a4 4 0 0 0 -4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.64 5.632a9 9 0 1 0 12.73 12.725m1.667 -2.301a9 9 0 0 0 -12.077 -12.1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 15l3.35 3.35\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 15l-3.35 3.35\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.65 5.65l3.35 3.35\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.35 5.65l-3.35 3.35\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbLifebuoy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"15\",\"x2\":\"18.35\",\"y2\":\"18.35\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"15\",\"x2\":\"5.65\",\"y2\":\"18.35\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5.65\",\"y1\":\"5.65\",\"x2\":\"9\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18.35\",\"y1\":\"5.65\",\"x2\":\"15\",\"y2\":\"9\"}}]})(props);\n};\nexport function TbLineDashed (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 12h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 12h2\"}}]})(props);\n};\nexport function TbLineDotted (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12v.01\"}}]})(props);\n};\nexport function TbLineHeight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"3 8 6 5 9 8\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"3 16 6 19 9 16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"5\",\"x2\":\"6\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"6\",\"x2\":\"20\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"18\",\"x2\":\"20\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbLine (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7.5\",\"y1\":\"16.5\",\"x2\":\"16.5\",\"y2\":\"7.5\"}}]})(props);\n};\nexport function TbLink (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 14a3.5 3.5 0 0 0 5 0l4 -4a3.5 3.5 0 0 0 -5 -5l-.5 .5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10a3.5 3.5 0 0 0 -5 0l-4 4a3.5 3.5 0 0 0 5 5l.5 -.5\"}}]})(props);\n};\nexport function TbListCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 5.5l1.5 1.5l2.5 -2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 11.5l1.5 1.5l2.5 -2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 17.5l1.5 1.5l2.5 -2.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"6\",\"x2\":\"20\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"18\",\"x2\":\"20\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbListDetails (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 5h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 9h5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 15h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 19h5\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"4\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"14\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}}]})(props);\n};\nexport function TbListNumbers (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 6h9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 12h9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16a2 2 0 1 1 4 0c0 .591 -.5 1 -1 1.5l-3 2.5h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10v-6l-2 2\"}}]})(props);\n};\nexport function TbListSearch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"15\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.5 18.5l2.5 2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6h16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18h4\"}}]})(props);\n};\nexport function TbList (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"6\",\"x2\":\"20\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"18\",\"x2\":\"20\",\"y2\":\"18\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"6\",\"x2\":\"5\",\"y2\":\"6.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"5\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"18\",\"x2\":\"5\",\"y2\":\"18.01\"}}]})(props);\n};\nexport function TbLivePhoto (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15.9\",\"y1\":\"20.11\",\"x2\":\"15.9\",\"y2\":\"20.12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19.04\",\"y1\":\"17.61\",\"x2\":\"19.04\",\"y2\":\"17.62\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20.77\",\"y1\":\"14\",\"x2\":\"20.77\",\"y2\":\"14.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20.77\",\"y1\":\"10\",\"x2\":\"20.77\",\"y2\":\"10.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19.04\",\"y1\":\"6.39\",\"x2\":\"19.04\",\"y2\":\"6.4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15.9\",\"y1\":\"3.89\",\"x2\":\"15.9\",\"y2\":\"3.9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"3.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8.1\",\"y1\":\"3.89\",\"x2\":\"8.1\",\"y2\":\"3.9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4.96\",\"y1\":\"6.39\",\"x2\":\"4.96\",\"y2\":\"6.4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3.23\",\"y1\":\"10\",\"x2\":\"3.23\",\"y2\":\"10.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3.23\",\"y1\":\"14\",\"x2\":\"3.23\",\"y2\":\"14.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4.96\",\"y1\":\"17.61\",\"x2\":\"4.96\",\"y2\":\"17.62\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8.1\",\"y1\":\"20.11\",\"x2\":\"8.1\",\"y2\":\"20.12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"21\",\"x2\":\"12\",\"y2\":\"21.01\"}}]})(props);\n};\nexport function TbLiveView (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8v-2a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16v2a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2a2 2 0 0 1 2 2v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h2a2 2 0 0 0 2 -2v-2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"11\",\"x2\":\"12\",\"y2\":\"11.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18l-3.5 -5a4 4 0 1 1 7 0l-3.5 5\"}}]})(props);\n};\nexport function TbLoaderQuarter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"6\",\"x2\":\"12\",\"y2\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"12\",\"x2\":\"3\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7.75\",\"y1\":\"7.75\",\"x2\":\"5.6\",\"y2\":\"5.6\"}}]})(props);\n};\nexport function TbLoader (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"6\",\"x2\":\"12\",\"y2\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16.25\",\"y1\":\"7.75\",\"x2\":\"18.4\",\"y2\":\"5.6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"12\",\"x2\":\"21\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16.25\",\"y1\":\"16.25\",\"x2\":\"18.4\",\"y2\":\"18.4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"18\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7.75\",\"y1\":\"16.25\",\"x2\":\"5.6\",\"y2\":\"18.4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"12\",\"x2\":\"3\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7.75\",\"y1\":\"7.75\",\"x2\":\"5.6\",\"y2\":\"5.6\"}}]})(props);\n};\nexport function TbLocationOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.72 6.712l10.28 -3.712l-3.724 10.313m-1.056 2.925l-1.72 4.762a0.55 .55 0 0 1 -1 0l-3.5 -7l-7 -3.5a0.55 .55 0 0 1 0 -1l4.775 -1.724\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbLocation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 3l-6.5 18a0.55 .55 0 0 1 -1 0l-3.5 -7l-7 -3.5a0.55 .55 0 0 1 0 -1l18 -6.5\"}}]})(props);\n};\nexport function TbLockAccess (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8v-2a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16v2a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2a2 2 0 0 1 2 2v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h2a2 2 0 0 0 2 -2v-2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"11\",\"width\":\"8\",\"height\":\"5\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 11v-2a2 2 0 1 1 4 0v2\"}}]})(props);\n};\nexport function TbLockOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 19a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-6a2 2 0 0 1 2 -2h4m4 0h2a2 2 0 0 1 2 2v2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"16\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11v-3m.712 -3.278a4 4 0 0 1 7.288 2.278v4\"}}]})(props);\n};\nexport function TbLockOpenOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 11h2a2 2 0 0 1 2 2v2m0 4a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-6a2 2 0 0 1 2 -2h4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"16\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11v-3m.347 -3.631a4 4 0 0 1 7.653 1.631\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbLockOpen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"11\",\"width\":\"14\",\"height\":\"10\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"16\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11v-5a4 4 0 0 1 8 0\"}}]})(props);\n};\nexport function TbLockSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"11\",\"width\":\"8\",\"height\":\"5\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 11v-2a2 2 0 1 1 4 0v2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbLock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"11\",\"width\":\"14\",\"height\":\"10\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"16\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11v-4a4 4 0 0 1 8 0v4\"}}]})(props);\n};\nexport function TbLogin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 8v-2a2 2 0 0 0 -2 -2h-7a2 2 0 0 0 -2 2v12a2 2 0 0 0 2 2h7a2 2 0 0 0 2 -2v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12h-13l3 -3m0 6l-3 -3\"}}]})(props);\n};\nexport function TbLogout (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 8v-2a2 2 0 0 0 -2 -2h-7a2 2 0 0 0 -2 2v12a2 2 0 0 0 2 2h7a2 2 0 0 0 2 -2v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12h14l-3 -3m0 6l3 -3\"}}]})(props);\n};\nexport function TbLollipopOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.462 7.493a7 7 0 0 0 9.06 9.039m2.416 -1.57a7 7 0 1 0 -9.884 -9.915\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 10a3.5 3.5 0 0 0 -7 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.71 12.715a3.5 3.5 0 0 1 -5.71 -2.715\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 17c.838 0 1.607 -.294 2.209 -.785m1.291 -2.715a3.5 3.5 0 0 0 -3.5 -3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3a3.5 3.5 0 0 0 -3.5 3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21l6 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbLollipop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14\",\"cy\":\"10\",\"r\":\"7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 10a3.5 3.5 0 0 0 -7 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10a3.5 3.5 0 0 1 -7 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 17a3.5 3.5 0 0 0 0 -7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3a3.5 3.5 0 0 0 0 7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21l6 -6\"}}]})(props);\n};\nexport function TbLuggageOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6h6a2 2 0 0 1 2 2v6m0 4a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2v-10c0 -.546 .218 -1.04 .573 -1.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5a2 2 0 0 1 2 -2h2a2 2 0 0 1 2 2v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10h4m4 0h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 16h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 20v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 20v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbLuggage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"6\",\"y\":\"6\",\"width\":\"12\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 6v-1a2 2 0 0 1 2 -2h2a2 2 0 0 1 2 2v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10h12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 16h12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 20v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 20v1\"}}]})(props);\n};\nexport function TbLungs (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.081 20c1.612 0 2.919 -1.335 2.919 -2.98v-9.763c0 -.694 -.552 -1.257 -1.232 -1.257c-.205 0 -.405 .052 -.584 .15l-.13 .083c-1.46 1.059 -2.432 2.647 -3.404 5.824c-.42 1.37 -.636 2.962 -.648 4.775c-.012 1.675 1.261 3.054 2.877 3.161l.203 .007z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.92 20c-1.613 0 -2.92 -1.335 -2.92 -2.98v-9.763c0 -.694 .552 -1.257 1.233 -1.257c.204 0 .405 .052 .584 .15l.13 .083c1.46 1.059 2.432 2.647 3.405 5.824c.42 1.37 .636 2.962 .648 4.775c.012 1.675 -1.261 3.054 -2.878 3.161l-.202 .007z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12a3 3 0 0 0 3 -3a3 3 0 0 0 3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4v5\"}}]})(props);\n};\nexport function TbMacro (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15a6 6 0 1 0 12 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15a6 6 0 0 0 -6 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21a6 6 0 0 0 -6 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 11a5 5 0 0 1 -5 -5v-3l3 2l2 -2l2 2l3 -2v3a5 5 0 0 1 -5 5z\"}}]})(props);\n};\nexport function TbMagnetOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 3a2 2 0 0 1 2 2m0 4v4a3 3 0 0 0 5.552 1.578m.448 -3.578v-6a2 2 0 0 1 2 -2h1a2 2 0 0 1 2 2v8a7.99 7.99 0 0 1 -.424 2.577m-1.463 2.584a8 8 0 0 1 -14.113 -5.161v-8.001c0 -.297 .065 -.58 .181 -.833\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 8h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbMagnet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 13v-8a2 2 0 0 1 2 -2h1a2 2 0 0 1 2 2v8a2 2 0 0 0 6 0v-8a2 2 0 0 1 2 -2h1a2 2 0 0 1 2 2v8a8 8 0 0 1 -16 0\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"8\",\"x2\":\"9\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"8\",\"x2\":\"19\",\"y2\":\"8\"}}]})(props);\n};\nexport function TbMailFast (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 11h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.02 8.801l-.6 6a2 2 0 0 0 1.99 2.199h7.98a2 2 0 0 0 1.99 -1.801l.6 -6a2 2 0 0 0 -1.99 -2.199h-7.98a2 2 0 0 0 -1.99 1.801z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.8 7.5l2.982 3.28a3 3 0 0 0 4.238 .202l3.28 -2.982\"}}]})(props);\n};\nexport function TbMailForward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18h-7a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h14a2 2 0 0 1 2 2v7.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6l9 6l9 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 18h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15l3 3l-3 3\"}}]})(props);\n};\nexport function TbMailOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h10a2 2 0 0 1 2 2v10m-2 2h-14a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7l9 6l.598 -.399m2.402 -1.601l6 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbMailOpened (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"3 9 12 15 21 9 12 3 3 9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 9v10a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"19\",\"x2\":\"9\",\"y2\":\"13\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"13\",\"x2\":\"21\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbMail (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"5\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"3 7 12 13 21 7\"}}]})(props);\n};\nexport function TbMailboxOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 21v-6.5a3.5 3.5 0 0 0 -7 0v6.5h18m0 -4v-2a4 4 0 0 0 -4 -4h-2m-4 0h-4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8v-5h4l2 2l-2 2h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbMailbox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 21v-6.5a3.5 3.5 0 0 0 -7 0v6.5h18v-6a4 4 0 0 0 -4 -4h-10.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 11v-8h4l2 2l-2 2h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15h1\"}}]})(props);\n};\nexport function TbMan (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 22v-5l-1 -1v-4a1 1 0 0 1 1 -1h4a1 1 0 0 1 1 1v4l-1 1v5\"}}]})(props);\n};\nexport function TbManualGearbox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"6\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"8\",\"x2\":\"5\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 8v2a2 2 0 0 1 -2 2h-12\"}}]})(props);\n};\nexport function TbMap2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"6\",\"x2\":\"18\",\"y2\":\"6.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 13l-3.5 -5a4 4 0 1 1 7 0l-3.5 5\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"10.5 4.75 9 4 3 7 3 20 9 17 15 20 21 17 21 15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"4\",\"x2\":\"9\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"15\",\"x2\":\"15\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbMapOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.32 4.34l.68 -.34l6 3l6 -3v13m-2.67 1.335l-3.33 1.665l-6 -3l-6 3v-13l2.665 -1.333\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4v1m0 4v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 7v4m0 4v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbMapPinOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.44 9.435a3 3 0 0 0 4.126 4.124m1.434 -2.559a3 3 0 0 0 -3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.048 4.042a8 8 0 0 1 10.912 10.908m-1.8 2.206l-3.745 3.744a2 2 0 0 1 -2.827 0l-4.244 -4.243a8 8 0 0 1 -.48 -10.79\"}}]})(props);\n};\nexport function TbMapPin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"11\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.657 16.657l-4.243 4.243a2 2 0 0 1 -2.827 0l-4.244 -4.243a8 8 0 1 1 11.314 0z\"}}]})(props);\n};\nexport function TbMapPins (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.828 9.828a4 4 0 1 0 -5.656 0l2.828 2.829l2.828 -2.829z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"7\",\"x2\":\"8\",\"y2\":\"7.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.828 17.828a4 4 0 1 0 -5.656 0l2.828 2.829l2.828 -2.829z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"15\",\"x2\":\"16\",\"y2\":\"15.01\"}}]})(props);\n};\nexport function TbMapSearch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 18l-2 -1l-6 3v-13l6 -3l6 3l6 -3v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4v13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 7v5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16.5\",\"cy\":\"17.5\",\"r\":\"2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.5 19.5l2.5 2.5\"}}]})(props);\n};\nexport function TbMap (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"3 7 9 4 15 7 21 4 21 17 15 20 9 17 3 20 3 7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"4\",\"x2\":\"9\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"7\",\"x2\":\"15\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbMarkdown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"5\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 15v-6l2 2l2 -2v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 13l2 2l2 -2m-2 2v-6\"}}]})(props);\n};\nexport function TbMarquee2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6v-1a1 1 0 0 1 1 -1h1m5 0h2m5 0h1a1 1 0 0 1 1 1v1m0 5v2m0 5v1a1 1 0 0 1 -1 1h-1m-5 0h-2m-5 0h-1a1 1 0 0 1 -1 -1v-1m0 -5v-2\"}}]})(props);\n};\nexport function TbMarqueeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6c0 -.556 .227 -1.059 .593 -1.421\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4h1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 4h1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 4a2 2 0 0 1 2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 9v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 13.5v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.402 19.426a1.993 1.993 0 0 1 -1.402 .574\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 20h-1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 20h-1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 20a2 2 0 0 1 -2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 15v-1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 10.5v-1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbMarquee (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6a2 2 0 0 1 2 -2m3 0h1.5m3 0h1.5m3 0a2 2 0 0 1 2 2m0 3v1.5m0 3v1.5m0 3a2 2 0 0 1 -2 2m-3 0h-1.5m-3 0h-1.5m-3 0a2 2 0 0 1 -2 -2m0 -3v-1.5m0 -3v-1.5m0 -3\"}}]})(props);\n};\nexport function TbMars (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"10\",\"cy\":\"14\",\"r\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"5\",\"x2\":\"13.6\",\"y2\":\"10.4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"5\",\"x2\":\"14\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"5\",\"x2\":\"19\",\"y2\":\"10\"}}]})(props);\n};\nexport function TbMaskOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.42 19.41a2 2 0 0 1 -1.42 .59h-12a2 2 0 0 1 -2 -2v-12c0 -.554 .225 -1.055 .588 -1.417m3.412 -.583h10a2 2 0 0 1 2 2v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.885 9.872a3 3 0 1 0 4.245 4.24m.582 -3.396a3.012 3.012 0 0 0 -1.438 -1.433\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbMask (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbMassage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"4\",\"cy\":\"17\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"5\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 22l4 -2v-3h12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 20h9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 14l3 -2l1 -4c3 1 3 4 3 6\"}}]})(props);\n};\nexport function TbMathAvg (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21l18 -18\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"8\"}}]})(props);\n};\nexport function TbMathFunctionOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10h1c.882 0 .986 .777 1.694 2.692\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 17c.864 0 1.727 -.663 2.495 -1.512m1.717 -2.302c.993 -1.45 2.39 -3.186 3.788 -3.186\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19c0 1.5 .5 2 2 2s2 -4 3 -9c.237 -1.186 .446 -2.317 .647 -3.35m.727 -3.248c.423 -1.492 .91 -2.402 1.626 -2.402c1.5 0 2 .5 2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbMathFunction (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10h1c1 0 1 1 2.016 3.527c.984 2.473 .984 3.473 1.984 3.473h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 17c1.5 0 3 -2 4 -3.5s2.5 -3.5 4 -3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19c0 1.5 .5 2 2 2s2 -4 3 -9s1.5 -9 3 -9s2 .5 2 2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"11\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbMathMax (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 20c0 -8.75 4 -14 7 -14.5m4 0c3 .5 7 5.75 7 14.5\"}}]})(props);\n};\nexport function TbMathMin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"transform\":\"matrix(1 0 0 -1 0 38)\",\"cx\":\"12\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 4c0 8.75 4 14 7 14.5m4 0c3 -.5 7 -5.75 7 -14.5\"}}]})(props);\n};\nexport function TbMathSymbols (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"12\",\"x2\":\"21\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16.5\",\"y1\":\"4.5\",\"x2\":\"19.5\",\"y2\":\"7.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19.5\",\"y1\":\"4.5\",\"x2\":\"16.5\",\"y2\":\"7.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"4\",\"x2\":\"6\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"6\",\"x2\":\"8\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"16\",\"x2\":\"18.01\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"20\",\"x2\":\"18.01\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"18\",\"x2\":\"8\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbMath (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 13l4 4m0 -4l-4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 5h-7l-4 14l-3 -6h-2\"}}]})(props);\n};\nexport function TbMaximizeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8v-2c0 -.551 .223 -1.05 .584 -1.412\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16v2a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2a2 2 0 0 1 2 2v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h2c.545 0 1.04 -.218 1.4 -.572\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbMaximize (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8v-2a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16v2a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2a2 2 0 0 1 2 2v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h2a2 2 0 0 0 2 -2v-2\"}}]})(props);\n};\nexport function TbMeat (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.62 8.382l1.966 -1.967a2 2 0 1 1 3.414 -1.415a2 2 0 1 1 -1.413 3.414l-1.82 1.821\"}},{\"tag\":\"ellipse\",\"attr\":{\"transform\":\"rotate(45 8.025 16.475)\",\"cx\":\"8.025\",\"cy\":\"16.475\",\"rx\":\"7\",\"ry\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 16l1 1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.975 21.425c3.905 -3.906 4.855 -9.288 2.121 -12.021c-2.733 -2.734 -8.115 -1.784 -12.02 2.121\"}}]})(props);\n};\nexport function TbMedal2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 3h6l3 7l-6 2l-6 -2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l-3 -9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 11l-3 -8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 19.5l-3 1.5l.5 -3.5l-2 -2l3 -.5l1.5 -3l1.5 3l3 .5l-2 2l.5 3.5z\"}}]})(props);\n};\nexport function TbMedal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4v3m-4 -3v6m8 -6v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18.5l-3 1.5l.5 -3.5l-2 -2l3 -.5l1.5 -3l1.5 3l3 .5l-2 2l.5 3.5z\"}}]})(props);\n};\nexport function TbMedicalCrossOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.928 17.733l-.574 -.331l-3.354 -1.938v4.536a1 1 0 0 1 -1 1h-2a1 1 0 0 1 -1 -1v-4.536l-3.928 2.268a1 1 0 0 1 -1.366 -.366l-1 -1.732a1 1 0 0 1 .366 -1.366l3.927 -2.268l-3.927 -2.268a1 1 0 0 1 -.366 -1.366l1 -1.732a1 1 0 0 1 1.366 -.366l.333 .192m3.595 -.46v-2a1 1 0 0 1 1 -1h2a1 1 0 0 1 1 1v4.535l3.928 -2.267a1 1 0 0 1 1.366 .366l1 1.732a1 1 0 0 1 -.366 1.366l-3.927 2.268l3.927 2.269a1 1 0 0 1 .366 1.366l-.24 .416\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbMedicalCross (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 3a1 1 0 0 1 1 1v4.535l3.928 -2.267a1 1 0 0 1 1.366 .366l1 1.732a1 1 0 0 1 -.366 1.366l-3.927 2.268l3.927 2.269a1 1 0 0 1 .366 1.366l-1 1.732a1 1 0 0 1 -1.366 .366l-3.928 -2.269v4.536a1 1 0 0 1 -1 1h-2a1 1 0 0 1 -1 -1v-4.536l-3.928 2.268a1 1 0 0 1 -1.366 -.366l-1 -1.732a1 1 0 0 1 .366 -1.366l3.927 -2.268l-3.927 -2.268a1 1 0 0 1 -.366 -1.366l1 -1.732a1 1 0 0 1 1.366 -.366l3.928 2.267v-4.535a1 1 0 0 1 1 -1h2z\"}}]})(props);\n};\nexport function TbMedicineSyrup (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 21h8a1 1 0 0 0 1 -1v-10a3 3 0 0 0 -3 -3h-4a3 3 0 0 0 -3 3v10a1 1 0 0 0 1 1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 14h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 7v-3a1 1 0 0 1 1 -1h2a1 1 0 0 1 1 1v3\"}}]})(props);\n};\nexport function TbMenu2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"6\",\"x2\":\"20\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"18\",\"x2\":\"20\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbMenu (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"8\",\"x2\":\"20\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"16\",\"x2\":\"20\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbMessage2Code (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20l-3 -3h-2a3 3 0 0 1 -3 -3v-6a3 3 0 0 1 3 -3h10a3 3 0 0 1 3 3v6a3 3 0 0 1 -3 3h-2l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 9l-2 2l2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 9l2 2l-2 2\"}}]})(props);\n};\nexport function TbMessage2Share (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4h4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 11v3a3 3 0 0 1 -3 3h-2l-3 3l-3 -3h-2a3 3 0 0 1 -3 -3v-6a3 3 0 0 1 3 -3h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 9l5 -5\"}}]})(props);\n};\nexport function TbMessage2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20l-3 -3h-2a3 3 0 0 1 -3 -3v-6a3 3 0 0 1 3 -3h10a3 3 0 0 1 3 3v6a3 3 0 0 1 -3 3h-2l-3 3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"9\",\"x2\":\"16\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"13\",\"x2\":\"14\",\"y2\":\"13\"}}]})(props);\n};\nexport function TbMessageCircle2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 20l1.3 -3.9a9 8 0 1 1 3.4 2.9l-4.7 1\"}}]})(props);\n};\nexport function TbMessageCircleOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.585 4.581c3.225 -1.181 7.032 -.616 9.66 1.626c2.983 2.543 3.602 6.525 1.634 9.662m-1.908 2.108c-2.786 2.19 -6.89 2.665 -10.271 1.023l-4.7 1l1.3 -3.9c-2.237 -3.308 -1.489 -7.54 1.714 -10.084\"}}]})(props);\n};\nexport function TbMessageCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 20l1.3 -3.9a9 8 0 1 1 3.4 2.9l-4.7 1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"12\",\"x2\":\"8\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"12\",\"x2\":\"16\",\"y2\":\"12.01\"}}]})(props);\n};\nexport function TbMessageCode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 21v-13a3 3 0 0 1 3 -3h10a3 3 0 0 1 3 3v6a3 3 0 0 1 -3 3h-9l-4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 9l-2 2l2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 9l2 2l-2 2\"}}]})(props);\n};\nexport function TbMessageDots (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 21v-13a3 3 0 0 1 3 -3h10a3 3 0 0 1 3 3v6a3 3 0 0 1 -3 3h-9l-4 4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"11\",\"x2\":\"12\",\"y2\":\"11.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"11\",\"x2\":\"8\",\"y2\":\"11.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"11\",\"x2\":\"16\",\"y2\":\"11.01\"}}]})(props);\n};\nexport function TbMessageLanguage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 21v-13a3 3 0 0 1 3 -3h10a3 3 0 0 1 3 3v6a3 3 0 0 1 -3 3h-9l-4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 14v-4a2 2 0 1 1 4 0v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 12h-4\"}}]})(props);\n};\nexport function TbMessageOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17h-9l-4 4v-13c0 -1.086 .577 -2.036 1.44 -2.563m3.561 -.437h8a3 3 0 0 1 3 3v6c0 .575 -.162 1.112 -.442 1.568\"}}]})(props);\n};\nexport function TbMessagePlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 21v-13a3 3 0 0 1 3 -3h10a3 3 0 0 1 3 3v6a3 3 0 0 1 -3 3h-9l-4 4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"11\",\"x2\":\"14\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"9\",\"x2\":\"12\",\"y2\":\"13\"}}]})(props);\n};\nexport function TbMessageReport (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 21v-13a3 3 0 0 1 3 -3h10a3 3 0 0 1 3 3v6a3 3 0 0 1 -3 3h-9l-4 4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"14\",\"x2\":\"12\",\"y2\":\"14.01\"}}]})(props);\n};\nexport function TbMessageShare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 11v3a3 3 0 0 1 -3 3h-9l-4 4v-13a3 3 0 0 1 3 -3h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4h4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 9l5 -5\"}}]})(props);\n};\nexport function TbMessage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 21v-13a3 3 0 0 1 3 -3h10a3 3 0 0 1 3 3v6a3 3 0 0 1 -3 3h-9l-4 4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"9\",\"x2\":\"16\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"13\",\"x2\":\"14\",\"y2\":\"13\"}}]})(props);\n};\nexport function TbMessagesOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 11a1 1 0 0 1 -1 -1m0 -3.968v-2.032a1 1 0 0 1 1 -1h9a1 1 0 0 1 1 1v10l-3 -3h-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 15v2a1 1 0 0 1 -1 1h-7l-3 3v-10a1 1 0 0 1 1 -1h2\"}}]})(props);\n};\nexport function TbMessages (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 14l-3 -3h-7a1 1 0 0 1 -1 -1v-6a1 1 0 0 1 1 -1h9a1 1 0 0 1 1 1v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 15v2a1 1 0 0 1 -1 1h-7l-3 3v-10a1 1 0 0 1 1 -1h2\"}}]})(props);\n};\nexport function TbMicrophone2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.002 12.9a5 5 0 1 0 -3.902 -3.9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.002 12.9l-3.902 -3.899l-7.513 8.584a2 2 0 1 0 2.827 2.83l8.588 -7.515z\"}}]})(props);\n};\nexport function TbMicrophoneOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5a3 3 0 0 1 6 0v5a3 3 0 0 1 -.13 .874m-2 2a3 3 0 0 1 -3.87 -2.872v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 10a7 7 0 0 0 10.846 5.85m2.002 -2a6.967 6.967 0 0 0 1.152 -3.85\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"21\",\"x2\":\"16\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"17\",\"x2\":\"12\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbMicrophone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"2\",\"width\":\"6\",\"height\":\"11\",\"rx\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 10a7 7 0 0 0 14 0\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"21\",\"x2\":\"16\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"17\",\"x2\":\"12\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbMicroscope (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 21h14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 18h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 18v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 11l3 3l6 -6l-3 -3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 12.5l-1.5 1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 3l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21a6 6 0 0 0 3.715 -10.712\"}}]})(props);\n};\nexport function TbMilitaryAward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"13\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 10l-1 -2h-5l2.48 5.788a2 2 0 0 0 1.84 1.212h1.18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 10l1 -2h5l-2.48 5.788a2 2 0 0 1 -1.84 1.212h-1.18\"}}]})(props);\n};\nexport function TbMilitaryRank (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 7v13h-10v-13l5 -3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 13l2 -1l2 1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 17l2 -1l2 1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 9l2 -1l2 1\"}}]})(props);\n};\nexport function TbMilk (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 6h8v-2a1 1 0 0 0 -1 -1h-6a1 1 0 0 0 -1 1v2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 6l1.094 1.759a6 6 0 0 1 .906 3.17v8.071a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2v-8.071a6 6 0 0 1 .906 -3.17l1.094 -1.759\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"16\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10h4\"}}]})(props);\n};\nexport function TbMinimize (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 19v-2a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 5v2a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 15h2a2 2 0 0 1 2 2v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 9h2a2 2 0 0 0 2 -2v-2\"}}]})(props);\n};\nexport function TbMinusVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5v14\"}}]})(props);\n};\nexport function TbMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"19\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbMist (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 5h3m4 0h9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 10h11m4 0h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 15h5m4 0h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 20h9m4 0h3\"}}]})(props);\n};\nexport function TbMoodBoy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4.5a9 9 0 0 1 3.864 5.89a2.5 2.5 0 0 1 -.29 4.36a9 9 0 0 1 -17.137 0a2.5 2.5 0 0 1 -.29 -4.36a9 9 0 0 1 3.746 -5.81\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 16a3.5 3.5 0 0 0 5 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 2c1.5 1 2.5 3.5 2.5 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 2c1.5 2 2 3.5 2 5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"12\",\"x2\":\"9.01\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"12\",\"x2\":\"15.01\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbMoodConfuzed (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"10\",\"x2\":\"9.01\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"10\",\"x2\":\"15.01\",\"y2\":\"10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 16a10 10 0 0 1 6 -1.5\"}}]})(props);\n};\nexport function TbMoodCrazyHappy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"8.5\",\"x2\":\"10\",\"y2\":\"11.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 11.5l3 -3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"8.5\",\"x2\":\"17\",\"y2\":\"11.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 11.5l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 15a3.5 3.5 0 0 0 5 0\"}}]})(props);\n};\nexport function TbMoodCry (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"10\",\"x2\":\"9.01\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"10\",\"x2\":\"15.01\",\"y2\":\"10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 15.25a3.5 3.5 0 0 1 5 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.566 17.606a2 2 0 1 0 2.897 .03l-1.463 -1.636l-1.434 1.606z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.865 13.517a8.937 8.937 0 0 0 .135 -1.517a9 9 0 1 0 -9 9c.69 0 1.36 -.076 2 -.222\"}}]})(props);\n};\nexport function TbMoodEmpty (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"10\",\"x2\":\"9.01\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"10\",\"x2\":\"15.01\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"15\",\"x2\":\"15\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbMoodHappy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"9\",\"x2\":\"9.01\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"9\",\"x2\":\"15.01\",\"y2\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13a4 4 0 1 0 8 0m0 0h-8\"}}]})(props);\n};\nexport function TbMoodKid (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"10\",\"x2\":\"9.01\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"10\",\"x2\":\"15.01\",\"y2\":\"10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 15a3.5 3.5 0 0 0 5 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3a2 2 0 0 0 0 4\"}}]})(props);\n};\nexport function TbMoodNervous (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 10h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 10h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16l2 -2l2 2l2 -2l2 2\"}}]})(props);\n};\nexport function TbMoodNeutral (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"10\",\"x2\":\"9.01\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"10\",\"x2\":\"15.01\",\"y2\":\"10\"}}]})(props);\n};\nexport function TbMoodOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.634 5.638a9 9 0 0 0 12.732 12.724m1.679 -2.322a9 9 0 0 0 -12.08 -12.086\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 10h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 10h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 15a3.5 3.5 0 0 0 5 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbMoodSad (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"10\",\"x2\":\"9.01\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"10\",\"x2\":\"15.01\",\"y2\":\"10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 15.25a3.5 3.5 0 0 1 5 0\"}}]})(props);\n};\nexport function TbMoodSmile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"10\",\"x2\":\"9.01\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"10\",\"x2\":\"15.01\",\"y2\":\"10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 15a3.5 3.5 0 0 0 5 0\"}}]})(props);\n};\nexport function TbMoodSuprised (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"9\",\"x2\":\"9.01\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"9\",\"x2\":\"15.01\",\"y2\":\"9\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"15\",\"r\":\"2\"}}]})(props);\n};\nexport function TbMoodTongue (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"10\",\"x2\":\"9.01\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"10\",\"x2\":\"15.01\",\"y2\":\"10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 14v2a2 2 0 0 0 4 0v-2m1.5 0h-7\"}}]})(props);\n};\nexport function TbMoon2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.418 4.157a8 8 0 0 0 0 15.686\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbMoonOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.962 3.949a8.97 8.97 0 0 1 4.038 -.957v.008h.393a7.478 7.478 0 0 0 -2.07 3.308m-.141 3.84c.186 .823 .514 1.626 .989 2.373a7.49 7.49 0 0 0 4.586 3.268m3.893 -.11c.223 -.067 .444 -.144 .663 -.233a9.088 9.088 0 0 1 -.274 .597m-1.695 2.337a9 9 0 0 1 -12.71 -12.749\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbMoonStars (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3c.132 0 .263 0 .393 0a7.5 7.5 0 0 0 7.92 12.446a9 9 0 1 1 -8.313 -12.454z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4a2 2 0 0 0 2 2a2 2 0 0 0 -2 2a2 2 0 0 0 -2 -2a2 2 0 0 0 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 11h2m-1 -1v2\"}}]})(props);\n};\nexport function TbMoon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3c.132 0 .263 0 .393 0a7.5 7.5 0 0 0 7.92 12.446a9 9 0 1 1 -8.313 -12.454z\"}}]})(props);\n};\nexport function TbMoped (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 16v1a2 2 0 0 0 4 0v-5h-3a3 3 0 0 0 -3 3v1h10a6 6 0 0 1 5 -4v-5a2 2 0 0 0 -2 -2h-1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"9\",\"x2\":\"9\",\"y2\":\"9\"}}]})(props);\n};\nexport function TbMotorbike (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"16\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"16\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 14h5l4 -4h-10.5m1.5 4l4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 6h2l1.5 3l2 4\"}}]})(props);\n};\nexport function TbMountain (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 20h18l-6.921 -14.612a2.3 2.3 0 0 0 -4.158 0l-6.921 14.612z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 11l2 2.5l2.5 -2.5l2 3l2.5 -2\"}}]})(props);\n};\nexport function TbMouse2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"6\",\"y\":\"3\",\"width\":\"12\",\"height\":\"18\",\"rx\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10h12\"}}]})(props);\n};\nexport function TbMouseOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.733 3.704a3.982 3.982 0 0 1 2.267 -.704h4a4 4 0 0 1 4 4v7m-.1 3.895a4.002 4.002 0 0 1 -3.9 3.105h-4a4 4 0 0 1 -4 -4v-10c0 -.3 .033 -.593 .096 -.874\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbMouse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"6\",\"y\":\"3\",\"width\":\"12\",\"height\":\"18\",\"rx\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"7\",\"x2\":\"12\",\"y2\":\"11\"}}]})(props);\n};\nexport function TbMovieOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h10a2 2 0 0 1 2 2v10m-.592 3.42c-.362 .359 -.859 .58 -1.408 .58h-12a2 2 0 0 1 -2 -2v-12c0 -.539 .213 -1.028 .56 -1.388\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4v8m0 4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h8m4 0h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbMovie (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"4\",\"x2\":\"8\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"4\",\"x2\":\"16\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"8\",\"x2\":\"8\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"16\",\"x2\":\"8\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"8\",\"x2\":\"20\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"16\",\"x2\":\"20\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbMugOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h5.917a1.08 1.08 0 0 1 1.083 1.077v5.923m-.167 3.88a4.33 4.33 0 0 1 -4.166 3.12h-4.334c-2.393 0 -4.333 -1.929 -4.333 -4.308v-8.615a1.08 1.08 0 0 1 1.083 -1.077h.917\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8h2.5c1.38 0 2.5 1.045 2.5 2.333v2.334c0 1.148 -.89 2.103 -2.06 2.297\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbMug (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.083 5h10.834a1.08 1.08 0 0 1 1.083 1.077v8.615c0 2.38 -1.94 4.308 -4.333 4.308h-4.334c-2.393 0 -4.333 -1.929 -4.333 -4.308v-8.615a1.08 1.08 0 0 1 1.083 -1.077\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8h2.5c1.38 0 2.5 1.045 2.5 2.333v2.334c0 1.288 -1.12 2.333 -2.5 2.333h-2.5\"}}]})(props);\n};\nexport function TbMultiplier05X (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16h2a2 2 0 1 0 0 -4h-2v-4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 16v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 16l4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 16l-4 -4\"}}]})(props);\n};\nexport function TbMultiplier15X (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16v-8l-2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 16h2a2 2 0 1 0 0 -4h-2v-4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 16v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 16l4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 16l-4 -4\"}}]})(props);\n};\nexport function TbMultiplier1X (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 16v-8l-2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 16l4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 16l-4 -4\"}}]})(props);\n};\nexport function TbMultiplier2X (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 16l4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 16l-4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10a2 2 0 1 1 4 0c0 .591 -.417 1.318 -.816 1.858l-3.184 4.143l4 0\"}}]})(props);\n};\nexport function TbMushroom (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 11.1c0 -4.474 -3.582 -8.1 -8 -8.1s-8 3.626 -8 8.1a0.9 .9 0 0 0 .9 .9h14.2a0.9 .9 0 0 0 .9 -.9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12v7a2 2 0 1 0 4 0v-7\"}}]})(props);\n};\nexport function TbMusicOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"17\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.42 14.45a3 3 0 1 0 4.138 4.119\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17v-8m0 -4v-1h10v11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbMusic (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"17\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16\",\"cy\":\"17\",\"r\":\"3\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"9 17 9 4 19 4 19 17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"8\",\"x2\":\"19\",\"y2\":\"8\"}}]})(props);\n};\nexport function TbNetwork (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"9\",\"r\":\"6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3c1.333 .333 2 2.333 2 6s-.667 5.667 -2 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3c-1.333 .333 -2 2.333 -2 6s.667 5.667 2 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 9h12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 19h7\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 15v2\"}}]})(props);\n};\nexport function TbNewSection (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"12\",\"x2\":\"15\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"9\",\"x2\":\"12\",\"y2\":\"15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6v-1a1 1 0 0 1 1 -1h1m5 0h2m5 0h1a1 1 0 0 1 1 1v1m0 5v2m0 5v1a1 1 0 0 1 -1 1h-1m-5 0h-2m-5 0h-1a1 1 0 0 1 -1 -1v-1m0 -5v-2m0 -5\"}}]})(props);\n};\nexport function TbNewsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 6h3a1 1 0 0 1 1 1v9m-.606 3.435a2 2 0 0 1 -3.394 -1.435v-2m0 -4v-7a1 1 0 0 0 -1 -1h-7m-3.735 .321a0.996 .996 0 0 0 -.265 .679v12a3 3 0 0 0 3 3h11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbNews (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 6h3a1 1 0 0 1 1 1v11a2 2 0 0 1 -4 0v-13a1 1 0 0 0 -1 -1h-10a1 1 0 0 0 -1 1v12a3 3 0 0 0 3 3h11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"16\",\"x2\":\"12\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbNfcOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 20a3 3 0 0 1 -3 -3v-9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 4a3 3 0 0 1 3 3v5m0 4v2l-5 -5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h9a3 3 0 0 1 3 3v9m-.873 3.116a2.99 2.99 0 0 1 -2.127 .884h-10a3 3 0 0 1 -3 -3v-10c0 -.83 .337 -1.582 .882 -2.125\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbNfc (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 20a3 3 0 0 1 -3 -3v-11l5 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 4a3 3 0 0 1 3 3v11l-5 -5\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"3\"}}]})(props);\n};\nexport function TbNoCopyright (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 9.75a3.016 3.016 0 0 0 -4.163 .173a2.993 2.993 0 0 0 0 4.154a3.016 3.016 0 0 0 4.163 .173\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6l1.5 1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.5 16.5l1.5 1.5\"}}]})(props);\n};\nexport function TbNoCreativeCommons (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 10.5c-.847 -.71 -2.132 -.658 -2.914 .116a1.928 1.928 0 0 0 0 2.768c.782 .774 2.067 .825 2.914 .116\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.5 10.5c-.847 -.71 -2.132 -.658 -2.914 .116a1.928 1.928 0 0 0 0 2.768c.782 .774 2.067 .825 2.914 .116\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6l1.5 1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.5 16.5l1.5 1.5\"}}]})(props);\n};\nexport function TbNoDerivatives (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 10h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 14h6\"}}]})(props);\n};\nexport function TbNorthStar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 7.5l9 9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 16.5l9 -9\"}}]})(props);\n};\nexport function TbNoteOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 20l3.505 -3.505m1.994 -1.994l1.501 -1.501\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 13h3v-7a2 2 0 0 0 -2 -2h-10m-3.427 .6c-.355 .36 -.573 .853 -.573 1.4v12a2 2 0 0 0 2 2h7v-6c0 -.272 .109 -.519 .285 -.699\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbNote (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"20\",\"x2\":\"20\",\"y2\":\"13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 20v-6a1 1 0 0 1 1 -1h6v-7a2 2 0 0 0 -2 -2h-12a2 2 0 0 0 -2 2v12a2 2 0 0 0 2 2h7\"}}]})(props);\n};\nexport function TbNotebook (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 4h11a2 2 0 0 1 2 2v12a2 2 0 0 1 -2 2h-11a1 1 0 0 1 -1 -1v-14a1 1 0 0 1 1 -1m3 0v18\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"8\",\"x2\":\"15\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"12\",\"x2\":\"15\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbNotesOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 3h10a2 2 0 0 1 2 2v10m0 4a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 11h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 15h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbNotes (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"3\",\"width\":\"14\",\"height\":\"18\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"7\",\"x2\":\"15\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"11\",\"x2\":\"15\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"15\",\"x2\":\"13\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbNotificationOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.154 6.187a2 2 0 0 0 -1.154 1.813v9a2 2 0 0 0 2 2h9a2 2 0 0 0 1.811 -1.151\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"7\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbNotification (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6h-3a2 2 0 0 0 -2 2v9a2 2 0 0 0 2 2h9a2 2 0 0 0 2 -2v-3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"7\",\"r\":\"3\"}}]})(props);\n};\nexport function TbNumber0 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16v-8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20a4 4 0 0 0 4 -4v-8a4 4 0 1 0 -8 0v8a4 4 0 0 0 4 4z\"}}]})(props);\n};\nexport function TbNumber1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 20v-16l-5 5\"}}]})(props);\n};\nexport function TbNumber2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8a4 4 0 1 1 8 0c0 1.098 -.564 2.025 -1.159 2.815l-6.841 9.185h8\"}}]})(props);\n};\nexport function TbNumber3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12a4 4 0 1 0 -4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16a4 4 0 1 0 4 -4\"}}]})(props);\n};\nexport function TbNumber4 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 20v-15l-8 11h10\"}}]})(props);\n};\nexport function TbNumber5 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 20h4a4 4 0 1 0 0 -8h-4v-8h8\"}}]})(props);\n};\nexport function TbNumber6 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16a4 4 0 1 0 8 0v-1a4 4 0 1 0 -8 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8a4 4 0 1 0 -8 0v8\"}}]})(props);\n};\nexport function TbNumber7 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h8l-4 16\"}}]})(props);\n};\nexport function TbNumber8 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"8\",\"r\":\"4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"16\",\"r\":\"4\"}}]})(props);\n};\nexport function TbNumber9 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8a4 4 0 1 0 -8 0v1a4 4 0 1 0 8 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16a4 4 0 1 0 8 0v-8\"}}]})(props);\n};\nexport function TbNumbers (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 10v-7l-2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 16a2 2 0 1 1 4 0c0 .591 -.601 1.46 -1 2l-3 3.001h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 14a2 2 0 1 0 2 -2a2 2 0 1 0 -2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 10h3\"}}]})(props);\n};\nexport function TbNurse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6c2.941 0 5.685 .847 8 2.31l-2 9.69h-12l-2 -9.691a14.93 14.93 0 0 1 8 -2.309z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 10v4\"}}]})(props);\n};\nexport function TbOctagonOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.647 3.653l.353 -.353c.2 -.2 .4 -.3 .7 -.3h6.6c.3 0 .5 .1 .7 .3l4.7 4.7c.2 .2 .3 .4 .3 .7v6.6c0 .3 -.1 .5 -.3 .7l-.35 .35m-1.997 1.997l-2.353 2.353c-.2 .2 -.4 .3 -.7 .3h-6.6c-.3 0 -.5 -.1 -.7 -.3l-4.7 -4.7c-.2 -.2 -.3 -.4 -.3 -.7v-6.6c0 -.3 .1 -.5 .3 -.7l2.35 -2.35\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbOctagon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.7 3h6.6c.3 0 .5 .1 .7 .3l4.7 4.7c.2 .2 .3 .4 .3 .7v6.6c0 .3 -.1 .5 -.3 .7l-4.7 4.7c-.2 .2 -.4 .3 -.7 .3h-6.6c-.3 0 -.5 -.1 -.7 -.3l-4.7 -4.7c-.2 -.2 -.3 -.4 -.3 -.7v-6.6c0 -.3 .1 -.5 .3 -.7l4.7 -4.7c.2 -.2 .4 -.3 .7 -.3z\"}}]})(props);\n};\nexport function TbOld (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 21l-1 -4l-2 -3v-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 14l-1 -3l4 -3l3 2l3 .5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"4\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 17l-2 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 21v-8.5a1.5 1.5 0 0 1 3 0v.5\"}}]})(props);\n};\nexport function TbOlympics (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"9\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"9\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"9\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"15\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"15\",\"r\":\"3\"}}]})(props);\n};\nexport function TbOmega (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 19h5v-1a7.35 7.35 0 1 1 6 0v1h5\"}}]})(props);\n};\nexport function TbOutlet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"12\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"12\",\"r\":\".5\",\"fill\":\"currentColor\"}}]})(props);\n};\nexport function TbOvalVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"ellipse\",\"attr\":{\"transform\":\"matrix(0 -1 -1 0 24 24)\",\"cx\":\"12\",\"cy\":\"12\",\"rx\":\"6\",\"ry\":\"9\"}}]})(props);\n};\nexport function TbOval (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"ellipse\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"rx\":\"6\",\"ry\":\"9\"}}]})(props);\n};\nexport function TbOverline (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 9v5a5 5 0 0 0 10 0v-5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 5h14\"}}]})(props);\n};\nexport function TbPackageOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.812 4.793l3.188 -1.793l8 4.5v8.5m-2.282 1.784l-5.718 3.216l-8 -4.5v-9l2.223 -1.25\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.543 10.57l5.457 -3.07\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l-8 -4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 5.25l-4.35 2.447m-2.564 1.442l-1.086 .611\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPackage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"12 3 20 7.5 20 16.5 12 21 4 16.5 4 7.5 12 3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"7.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"4\",\"y2\":\"7.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"5.25\",\"x2\":\"8\",\"y2\":\"9.75\"}}]})(props);\n};\nexport function TbPackgeExport (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21l-8 -4.5v-9l8 -4.5l8 4.5v4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l8 -4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l-8 -4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 18h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 15l3 3l-3 3\"}}]})(props);\n};\nexport function TbPackgeImport (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21l-8 -4.5v-9l8 -4.5l8 4.5v4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l8 -4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l-8 -4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 18h-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 15l-3 3l3 3\"}}]})(props);\n};\nexport function TbPacman (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.636 5.636a9 9 0 0 1 13.397 .747l-5.619 5.617l5.619 5.617a9 9 0 1 1 -13.397 -11.981z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"11.5\",\"cy\":\"7.5\",\"r\":\"1\",\"fill\":\"currentColor\"}}]})(props);\n};\nexport function TbPageBreak (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3v4a1 1 0 0 0 1 1h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 18v1a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 14h3m4.5 0h3m4.5 0h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 10v-5a2 2 0 0 1 2 -2h7l5 5v2\"}}]})(props);\n};\nexport function TbPaintOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 3h10a2 2 0 0 1 2 2v2a2 2 0 0 1 -2 2h-4m-4 0h-2a2 2 0 0 1 -2 -2v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 6h1a2 2 0 0 1 2 2a5 5 0 0 1 -5 5m-4 0h-1v2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"10\",\"y\":\"15\",\"width\":\"4\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPaint (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"3\",\"width\":\"14\",\"height\":\"6\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 6h1a2 2 0 0 1 2 2a5 5 0 0 1 -5 5l-5 0v2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"10\",\"y\":\"15\",\"width\":\"4\",\"height\":\"6\",\"rx\":\"1\"}}]})(props);\n};\nexport function TbPaletteOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.934 3.97a8.993 8.993 0 0 1 4.066 -.97c4.97 0 9 3.582 9 8c0 1.06 -.474 2.078 -1.318 2.828a4.515 4.515 0 0 1 -1.118 .726m-3.564 .446h-1a2 2 0 0 0 -1 3.75a1.3 1.3 0 0 1 -1 2.25a9 9 0 0 1 -6.372 -15.356\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7.5\",\"cy\":\"10.5\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"7.5\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16.5\",\"cy\":\"10.5\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPalette (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21a9 9 0 1 1 0 -18a9 8 0 0 1 9 8a4.5 4 0 0 1 -4.5 4h-2.5a2 2 0 0 0 -1 3.75a1.3 1.3 0 0 1 -1 2.25\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7.5\",\"cy\":\"10.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"7.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16.5\",\"cy\":\"10.5\",\"r\":\".5\",\"fill\":\"currentColor\"}}]})(props);\n};\nexport function TbPanoramaHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.338 5.53c5.106 1.932 10.211 1.932 15.317 .002a1 1 0 0 1 1.345 .934v11c0 .692 -.692 1.2 -1.34 .962c-5.107 -1.932 -10.214 -1.932 -15.321 0c-.648 .246 -1.339 -.242 -1.339 -.935v-11.027a1 1 0 0 1 1.338 -.935z\"}}]})(props);\n};\nexport function TbPanoramaVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.463 4.338c-1.932 5.106 -1.932 10.211 0 15.317a1 1 0 0 1 -.934 1.345h-11c-.692 0 -1.208 -.692 -.962 -1.34c1.932 -5.107 1.932 -10.214 0 -15.321c-.246 -.648 .243 -1.339 .935 -1.339h11.028c.693 0 1.18 .691 .935 1.338z\"}}]})(props);\n};\nexport function TbPaperBagOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.158 3.185c.256 -.119 .542 -.185 .842 -.185h8a2 2 0 0 1 2 2v1.82a5 5 0 0 0 .528 2.236l.944 1.888a5 5 0 0 1 .528 2.236v2.82m-.177 3.824a2 2 0 0 1 -1.823 1.176h-12a2 2 0 0 1 -2 -2v-5.82a5 5 0 0 1 .528 -2.236l1.472 -2.944v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.185 13.173a2 2 0 1 0 2.64 2.647\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 21a2 2 0 0 0 2 -2v-5.82a5 5 0 0 0 -.528 -2.236l-1.472 -2.944\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPaperBag (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 3h8a2 2 0 0 1 2 2v1.82a5 5 0 0 0 .528 2.236l.944 1.888a5 5 0 0 1 .528 2.236v5.82a2 2 0 0 1 -2 2h-12a2 2 0 0 1 -2 -2v-5.82a5 5 0 0 1 .528 -2.236l1.472 -2.944v-3a2 2 0 0 1 2 -2z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14\",\"cy\":\"15\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 21a2 2 0 0 0 2 -2v-5.82a5 5 0 0 0 -.528 -2.236l-1.472 -2.944\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7h2\"}}]})(props);\n};\nexport function TbPaperclip (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 7l-6.5 6.5a1.5 1.5 0 0 0 3 3l6.5 -6.5a3 3 0 0 0 -6 -6l-6.5 6.5a4.5 4.5 0 0 0 9 9l6.5 -6.5\"}}]})(props);\n};\nexport function TbParachuteOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 12c0 -5.523 -4.477 -10 -10 -10c-1.737 0 -3.37 .443 -4.794 1.222m-2.28 1.71a9.969 9.969 0 0 0 -2.926 7.068\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 12c0 -1.66 -1.46 -3 -3.25 -3c-1.63 0 -2.973 1.099 -3.212 2.54m-.097 -.09c-.23 -1.067 -1.12 -1.935 -2.29 -2.284m-3.445 .568c-.739 .55 -1.206 1.36 -1.206 2.266c0 -1.66 -1.46 -3 -3.25 -3c-1.8 0 -3.25 1.34 -3.25 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 12l10 10l-3.5 -10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.582 14.624l-2.582 7.376l4.992 -4.992m2.014 -2.014l2.994 -2.994\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbParachute (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 12a10 10 0 1 0 -20 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 12c0 -1.66 -1.46 -3 -3.25 -3c-1.8 0 -3.25 1.34 -3.25 3c0 -1.66 -1.57 -3 -3.5 -3s-3.5 1.34 -3.5 3c0 -1.66 -1.46 -3 -3.25 -3c-1.8 0 -3.25 1.34 -3.25 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 12l10 10l-3.5 -10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.5 12l-3.5 10l10 -10\"}}]})(props);\n};\nexport function TbParenthesesOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.743 5.745a12.253 12.253 0 0 0 1.257 14.255\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4a12.25 12.25 0 0 1 2.474 11.467m-1.22 2.794a12.291 12.291 0 0 1 -1.254 1.739\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbParentheses (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 4a12.25 12.25 0 0 0 0 16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4a12.25 12.25 0 0 1 0 16\"}}]})(props);\n};\nexport function TbParkingOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h10a2 2 0 0 1 2 2v10m-.582 3.41c-.362 .365 -.864 .59 -1.418 .59h-12a2 2 0 0 1 -2 -2v-12c0 -.554 .225 -1.056 .59 -1.418\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 16v-7m3 -1h1a2 2 0 0 1 1.817 2.836m-2.817 1.164h-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbParking (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 16v-8h4a2 2 0 0 1 0 4h-4\"}}]})(props);\n};\nexport function TbPaw (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.7 13.5c-1.1 -1.996 -1.441 -2.5 -2.7 -2.5c-1.259 0 -1.736 .755 -2.836 2.747c-.942 1.703 -2.846 1.845 -3.321 3.291c-.097 .265 -.145 .677 -.143 .962c0 1.176 .787 2 1.8 2c1.259 0 3.004 -1 4.5 -1s3.241 1 4.5 1c1.013 0 1.8 -.823 1.8 -2c0 -.285 -.049 -.697 -.146 -.962c-.475 -1.451 -2.512 -1.835 -3.454 -3.538z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.188 8.082a1.039 1.039 0 0 0 -.406 -.082h-.015c-.735 .012 -1.56 .75 -1.993 1.866c-.519 1.335 -.28 2.7 .538 3.052c.129 .055 .267 .082 .406 .082c.739 0 1.575 -.742 2.011 -1.866c.516 -1.335 .273 -2.7 -.54 -3.052z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.474 9c.055 0 .109 -.004 .163 -.011c.944 -.128 1.533 -1.346 1.32 -2.722c-.203 -1.297 -1.047 -2.267 -1.932 -2.267c-.055 0 -.109 .004 -.163 .011c-.944 .128 -1.533 1.346 -1.32 2.722c.204 1.293 1.048 2.267 1.933 2.267z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.456 6.733c.214 -1.376 -.375 -2.594 -1.32 -2.722a1.164 1.164 0 0 0 -.162 -.011c-.885 0 -1.728 .97 -1.93 2.267c-.214 1.376 .375 2.594 1.32 2.722c.054 .007 .108 .011 .162 .011c.885 0 1.73 -.974 1.93 -2.267z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.69 12.918c.816 -.352 1.054 -1.719 .536 -3.052c-.436 -1.124 -1.271 -1.866 -2.009 -1.866c-.14 0 -.277 .027 -.407 .082c-.816 .352 -1.054 1.719 -.536 3.052c.436 1.124 1.271 1.866 2.009 1.866c.14 0 .277 -.027 .407 -.082z\"}}]})(props);\n};\nexport function TbPeace (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"18.3\",\"y2\":\"18.3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"5.7\",\"y2\":\"18.3\"}}]})(props);\n};\nexport function TbPencilOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.003 9.997l-6.003 6.003v4h4l6.006 -6.006m1.99 -1.99l2.504 -2.504a2.828 2.828 0 1 0 -4 -4l-2.5 2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 6.5l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPencil (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20h4l10.5 -10.5a1.5 1.5 0 0 0 -4 -4l-10.5 10.5v4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13.5\",\"y1\":\"6.5\",\"x2\":\"17.5\",\"y2\":\"10.5\"}}]})(props);\n};\nexport function TbPennant2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 21h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 21v-18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4l-9 4l9 4\"}}]})(props);\n};\nexport function TbPennantOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 21h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 21v-11m0 -4v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 4l9 4l-4.858 2.16m-2.764 1.227l-1.378 .613\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPennant (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"21\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"21\",\"x2\":\"10\",\"y2\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 4l9 4l-9 4\"}}]})(props);\n};\nexport function TbPentagon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.2 3.394l7.033 5.237a2 2 0 0 1 .7 2.247l-2.973 8.764a2 2 0 0 1 -1.894 1.358h-8.12a2 2 0 0 1 -1.9 -1.373l-2.896 -8.765a2 2 0 0 1 .696 -2.225l6.958 -5.237a2 2 0 0 1 2.397 -.006z\"}}]})(props);\n};\nexport function TbPepperOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.59 12.59c-.77 1.418 -2.535 2.41 -4.59 2.41c-2.761 0 -5 -1.79 -5 -4a8 8 0 0 0 13.643 5.67m1.64 -2.357a7.97 7.97 0 0 0 .717 -3.313a3 3 0 0 0 -5.545 -1.59\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8c0 -2 2 -4 4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPepper (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 11c0 2.21 -2.239 4 -5 4s-5 -1.79 -5 -4a8 8 0 1 0 16 0a3 3 0 0 0 -6 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8c0 -2 2 -4 4 -4\"}}]})(props);\n};\nexport function TbPercentage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"17\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"7\",\"r\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"18\",\"x2\":\"18\",\"y2\":\"6\"}}]})(props);\n};\nexport function TbPerspectiveOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.511 4.502l9.63 1.375a1 1 0 0 1 .859 .99v8.133m-.859 3.123l-12 1.714a1 1 0 0 1 -1.141 -.99v-13.694a1 1 0 0 1 .01 -.137\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPerspective (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.141 4.163l12 1.714a1 1 0 0 1 .859 .99v10.266a1 1 0 0 1 -.859 .99l-12 1.714a1 1 0 0 1 -1.141 -.99v-13.694a1 1 0 0 1 1.141 -.99z\"}}]})(props);\n};\nexport function TbPhoneCall (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h4l2 5l-2.5 1.5a11 11 0 0 0 5 5l1.5 -2.5l5 2v4a2 2 0 0 1 -2 2a16 16 0 0 1 -15 -15a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 7a2 2 0 0 1 2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3a6 6 0 0 1 6 6\"}}]})(props);\n};\nexport function TbPhoneCalling (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h4l2 5l-2.5 1.5a11 11 0 0 0 5 5l1.5 -2.5l5 2v4a2 2 0 0 1 -2 2a16 16 0 0 1 -15 -15a2 2 0 0 1 2 -2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"7\",\"x2\":\"15\",\"y2\":\"7.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"7\",\"x2\":\"18\",\"y2\":\"7.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"7\",\"x2\":\"21\",\"y2\":\"7.01\"}}]})(props);\n};\nexport function TbPhoneCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h4l2 5l-2.5 1.5a11 11 0 0 0 5 5l1.5 -2.5l5 2v4a2 2 0 0 1 -2 2a16 16 0 0 1 -15 -15a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 6l2 2l4 -4\"}}]})(props);\n};\nexport function TbPhoneIncoming (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h4l2 5l-2.5 1.5a11 11 0 0 0 5 5l1.5 -2.5l5 2v4a2 2 0 0 1 -2 2a16 16 0 0 1 -15 -15a2 2 0 0 1 2 -2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"9\",\"x2\":\"20\",\"y2\":\"4\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"15 5 15 9 19 9\"}}]})(props);\n};\nexport function TbPhoneOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"21\",\"y2\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.831 14.161a15.946 15.946 0 0 1 -2.831 -8.161a2 2 0 0 1 2 -2h4l2 5l-2.5 1.5c.108 .22 .223 .435 .345 .645m1.751 2.277c.843 .84 1.822 1.544 2.904 2.078l1.5 -2.5l5 2v4a2 2 0 0 1 -2 2a15.963 15.963 0 0 1 -10.344 -4.657\"}}]})(props);\n};\nexport function TbPhoneOutgoing (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h4l2 5l-2.5 1.5a11 11 0 0 0 5 5l1.5 -2.5l5 2v4a2 2 0 0 1 -2 2a16 16 0 0 1 -15 -15a2 2 0 0 1 2 -2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"9\",\"x2\":\"20\",\"y2\":\"4\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 4 20 4 20 8\"}}]})(props);\n};\nexport function TbPhonePause (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h4l2 5l-2.5 1.5a11 11 0 0 0 5 5l1.5 -2.5l5 2v4a2 2 0 0 1 -2 2a16 16 0 0 1 -15 -15a2 2 0 0 1 2 -2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"3\",\"x2\":\"20\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"3\",\"x2\":\"16\",\"y2\":\"7\"}}]})(props);\n};\nexport function TbPhonePlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h4l2 5l-2.5 1.5a11 11 0 0 0 5 5l1.5 -2.5l5 2v4a2 2 0 0 1 -2 2a16 16 0 0 1 -15 -15a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 6h6m-3 -3v6\"}}]})(props);\n};\nexport function TbPhoneX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h4l2 5l-2.5 1.5a11 11 0 0 0 5 5l1.5 -2.5l5 2v4a2 2 0 0 1 -2 2a16 16 0 0 1 -15 -15a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4l4 4m0 -4l-4 4\"}}]})(props);\n};\nexport function TbPhone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h4l2 5l-2.5 1.5a11 11 0 0 0 5 5l1.5 -2.5l5 2v4a2 2 0 0 1 -2 2a16 16 0 0 1 -15 -15a2 2 0 0 1 2 -2\"}}]})(props);\n};\nexport function TbPhotoOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"8\",\"x2\":\"15.01\",\"y2\":\"8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.121 19.122a3 3 0 0 1 -2.121 .878h-10a3 3 0 0 1 -3 -3v-10c0 -.833 .34 -1.587 .888 -2.131m3.112 -.869h9a3 3 0 0 1 3 3v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 15l4 -4c.928 -.893 2.072 -.893 3 0l5 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.32 12.34c.577 -.059 1.162 .162 1.68 .66l2 2\"}}]})(props);\n};\nexport function TbPhoto (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"8\",\"x2\":\"15.01\",\"y2\":\"8\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 15l4 -4a3 5 0 0 1 3 0l5 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14l1 -1a3 5 0 0 1 3 0l2 2\"}}]})(props);\n};\nexport function TbPhysotherapist (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 15l-1 -3l4 -2l4 1h3.5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"4\",\"cy\":\"19\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"6\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17v-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 20h7l1 -4l4 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 20h3\"}}]})(props);\n};\nexport function TbPictureInPictureOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 19h-6a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h14a2 2 0 0 1 2 2v4\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"14\",\"y\":\"14\",\"width\":\"7\",\"height\":\"5\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"9\",\"x2\":\"11\",\"y2\":\"13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12v-3h3\"}}]})(props);\n};\nexport function TbPictureInPictureOn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 19h-6a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h14a2 2 0 0 1 2 2v4\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"14\",\"y\":\"14\",\"width\":\"7\",\"height\":\"5\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"9\",\"x2\":\"11\",\"y2\":\"13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13h3v-3\"}}]})(props);\n};\nexport function TbPictureInPictureTop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 5h-6a2 2 0 0 0 -2 2v10a2 2 0 0 0 2 2h14a2 2 0 0 0 2 -2v-4\"}},{\"tag\":\"rect\",\"attr\":{\"transform\":\"matrix(1 0 0 -1 0 15)\",\"x\":\"14\",\"y\":\"5\",\"width\":\"7\",\"height\":\"5\",\"rx\":\"1\"}}]})(props);\n};\nexport function TbPictureInPicture (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 19h-6a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h14a2 2 0 0 1 2 2v4\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"14\",\"y\":\"14\",\"width\":\"7\",\"height\":\"5\",\"rx\":\"1\"}}]})(props);\n};\nexport function TbPigOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 11v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6h1.499l4.5 -3l.001 3.803a6.019 6.019 0 0 1 2.658 3.197h1.341a1 1 0 0 1 1 1v2a1 1 0 0 1 -1 1h-1.342c-.057 .16 -.12 .318 -.19 .472m-1.467 2.528v1.5a1.5 1.5 0 0 1 -3 0v-.583a6.04 6.04 0 0 1 -1 .083h-4a6.04 6.04 0 0 1 -1 -.083v.583a1.5 1.5 0 0 1 -3 0v-2l0 -.027a6 6 0 0 1 1.5 -9.928\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPig (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 11v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 3l0 3.803a6.019 6.019 0 0 1 2.658 3.197h1.341a1 1 0 0 1 1 1v2a1 1 0 0 1 -1 1h-1.342a6.008 6.008 0 0 1 -1.658 2.473v2.027a1.5 1.5 0 0 1 -3 0v-.583a6.04 6.04 0 0 1 -1 .083h-4a6.04 6.04 0 0 1 -1 -.083v.583a1.5 1.5 0 0 1 -3 0v-2l.001 -.027a6 6 0 0 1 3.999 -10.473h2.5l4.5 -3z\"}}]})(props);\n};\nexport function TbPillOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.495 6.505l2.005 -2.005a4.95 4.95 0 0 1 7 7l-1.998 1.998m-2 2l-4.002 4.002a4.95 4.95 0 0 1 -7 -7l4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 8.5l7 7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 12.5l8 -8a4.94 4.94 0 0 1 7 7l-8 8a4.94 4.94 0 0 1 -7 -7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8.5\",\"y1\":\"8.5\",\"x2\":\"15.5\",\"y2\":\"15.5\"}}]})(props);\n};\nexport function TbPills (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"8\",\"r\":\"5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"17\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 4.5l7 7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.5 14.5l-5 5\"}}]})(props);\n};\nexport function TbPin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 4.5l-4 4l-4 1.5l-1.5 1.5l7 7l1.5 -1.5l1.5 -4l4 -4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"15\",\"x2\":\"4.5\",\"y2\":\"19.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14.5\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"9.5\"}}]})(props);\n};\nexport function TbPinnedOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 4.5l-3.249 3.249m-2.57 1.433l-2.181 .818l-1.5 1.5l7 7l1.5 -1.5l.82 -2.186m1.43 -2.563l3.25 -3.251\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"15\",\"x2\":\"4.5\",\"y2\":\"19.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14.5\",\"y1\":\"4\",\"x2\":\"20\",\"y2\":\"9.5\"}}]})(props);\n};\nexport function TbPinned (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4v6l-2 4v2h10v-2l-2 -4v-6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"16\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"4\",\"x2\":\"16\",\"y2\":\"4\"}}]})(props);\n};\nexport function TbPizzaOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.313 6.277l1.687 -3.277l5.34 10.376m2.477 6.463a19.093 19.093 0 0 1 -7.817 1.661c-3.04 0 -5.952 -.714 -8.5 -1.983l5.434 -10.559\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.38 15.866a14.94 14.94 0 0 0 6.815 1.634c1.56 .002 3.105 -.24 4.582 -.713\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 14v-.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPizza (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21.5c-3.04 0 -5.952 -.714 -8.5 -1.983l8.5 -16.517l8.5 16.517a19.09 19.09 0 0 1 -8.5 1.983z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.38 15.866a14.94 14.94 0 0 0 6.815 1.634a14.944 14.944 0 0 0 6.502 -1.479\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 11.01v-.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 14v-.01\"}}]})(props);\n};\nexport function TbPlaneArrival (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 12h5a2 2 0 0 1 0 4h-15l-3 -6h3l2 2h3l-2 -7h3z\",\"transform\":\"rotate(15 12 12) translate(0 -1)\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbPlaneDeparture (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 12h5a2 2 0 0 1 0 4h-15l-3 -6h3l2 2h3l-2 -7h3z\",\"transform\":\"rotate(-15 12 12) translate(0 -1)\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbPlaneInflight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 11.085h5a2 2 0 1 1 0 4h-15l-3 -6h3l2 2h3l-2 -7h3l4 7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21h18\"}}]})(props);\n};\nexport function TbPlaneOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.788 5.758l-.788 -2.758h3l4 7h4a2 2 0 1 1 0 4h-2m-2.718 1.256l-3.282 5.744h-3l2 -7h-4l-2 2h-3l2 -4l-2 -4h3l2 2h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPlane (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 10h4a2 2 0 0 1 0 4h-4l-4 7h-3l2 -7h-4l-2 2h-3l2 -4l-2 -4h3l2 2h4l-2 -7h3z\"}}]})(props);\n};\nexport function TbPlanetOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.816 13.58c1.956 1.825 3.157 3.449 3.184 4.445m-3.428 .593c-2.098 -.634 -4.944 -2.03 -7.919 -3.976c-5.47 -3.579 -9.304 -7.664 -8.56 -9.123c.32 -.628 1.591 -.6 3.294 -.113\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.042 7.059a7 7 0 0 0 9.908 9.89m1.581 -2.425a7 7 0 0 0 -9.057 -9.054\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPlanet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.816 13.58c2.292 2.138 3.546 4 3.092 4.9c-.745 1.46 -5.783 -.259 -11.255 -3.838c-5.47 -3.579 -9.304 -7.664 -8.56 -9.123c.464 -.91 2.926 -.444 5.803 .805\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"7\"}}]})(props);\n};\nexport function TbPlant2Off (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 9c0 5.523 4.477 10 10 10a9.953 9.953 0 0 0 5.418 -1.593m2.137 -1.855a9.961 9.961 0 0 0 2.445 -6.552\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 19c0 -1.988 .58 -3.84 1.58 -5.397m1.878 -2.167a9.961 9.961 0 0 1 6.542 -2.436\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 9a10 10 0 0 1 10 10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4a9.7 9.7 0 0 1 3.002 7.013\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.01 11.5a9.696 9.696 0 0 1 .163 -2.318m1.082 -2.942a9.696 9.696 0 0 1 1.745 -2.24\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPlant2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 9a10 10 0 1 0 20 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 19a10 10 0 0 1 10 -10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 9a10 10 0 0 1 10 10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4a9.7 9.7 0 0 1 2.99 7.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.01 11.5a9.7 9.7 0 0 1 2.99 -7.5\"}}]})(props);\n};\nexport function TbPlantOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v2a2 2 0 0 1 -2 2h-6a2 2 0 0 1 -2 -2v-4h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.9 7.908a6.006 6.006 0 0 0 -4.79 -4.806m-4.11 -.102v2a6 6 0 0 0 6 6h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.531 8.528a6.001 6.001 0 0 1 5.469 -3.528h3v1a6.002 6.002 0 0 1 -5.037 5.923\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 15v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPlant (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 15h10v4a2 2 0 0 1 -2 2h-6a2 2 0 0 1 -2 -2v-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9a6 6 0 0 0 -6 -6h-3v2a6 6 0 0 0 6 6h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 11a6 6 0 0 1 6 -6h3v1a6 6 0 0 1 -6 6h-3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"15\",\"x2\":\"12\",\"y2\":\"9\"}}]})(props);\n};\nexport function TbPlayCardOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 3h10a2 2 0 0 1 2 2v10m0 4a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 18h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.716 13.712l-1.716 2.288l-3 -4l1.29 -1.72\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPlayCard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"transform\":\"rotate(90 12 12)\",\"x\":\"3\",\"y\":\"5\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"6\",\"x2\":\"8.01\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"18\",\"x2\":\"16.01\",\"y2\":\"18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 16l-3 -4l3 -4l3 4z\"}}]})(props);\n};\nexport function TbPlayerEject (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12h14l-7 -8z\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"16\",\"width\":\"14\",\"height\":\"4\",\"rx\":\"1\"}}]})(props);\n};\nexport function TbPlayerPause (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"6\",\"y\":\"5\",\"width\":\"4\",\"height\":\"14\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"14\",\"y\":\"5\",\"width\":\"4\",\"height\":\"14\",\"rx\":\"1\"}}]})(props);\n};\nexport function TbPlayerPlay (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 4v16l13 -8z\"}}]})(props);\n};\nexport function TbPlayerRecord (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"7\"}}]})(props);\n};\nexport function TbPlayerSkipBack (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 5v14l-12 -7z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"5\",\"x2\":\"4\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbPlayerSkipForward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 5v14l12 -7z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"5\",\"x2\":\"20\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbPlayerStop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"5\",\"width\":\"14\",\"height\":\"14\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbPlayerTrackNext (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 5v14l8 -7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 5v14l8 -7z\"}}]})(props);\n};\nexport function TbPlayerTrackPrev (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 5v14l-8 -7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5v14l-8 -7z\"}}]})(props);\n};\nexport function TbPlaylistAdd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 8h-14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12h9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 16h-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 16h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 13v6\"}}]})(props);\n};\nexport function TbPlaylistOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14a3 3 0 1 0 3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 13v-9h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 5h-4m-4 0h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 9h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 13h-6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPlaylistX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 8h-14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 16h-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 14l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 14l-4 4\"}}]})(props);\n};\nexport function TbPlaylist (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14\",\"cy\":\"17\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v-13h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 5h-10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"9\",\"x2\":\"13\",\"y2\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 13h-6\"}}]})(props);\n};\nexport function TbPlugConnectedX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 16l-4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12l5 5l-1.5 1.5a3.536 3.536 0 1 1 -5 -5l1.5 -1.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 12l-5 -5l1.5 -1.5a3.536 3.536 0 1 1 5 5l-1.5 1.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21l2.5 -2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.5 5.5l2.5 -2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 11l-2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 14l-2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16l4 4\"}}]})(props);\n};\nexport function TbPlugConnected (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12l5 5l-1.5 1.5a3.536 3.536 0 1 1 -5 -5l1.5 -1.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 12l-5 -5l1.5 -1.5a3.536 3.536 0 1 1 5 5l-1.5 1.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21l2.5 -2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.5 5.5l2.5 -2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 11l-2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 14l-2 2\"}}]})(props);\n};\nexport function TbPlugOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.123 16.092l-.177 .177a5.81 5.81 0 1 1 -8.215 -8.215l.159 -.159\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20l3.5 -3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 4l-3.5 3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 9l-3.5 3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPlugX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.55 17.733a5.806 5.806 0 0 1 -7.356 -4.052a5.81 5.81 0 0 1 1.537 -5.627l2.054 -2.054l7.165 7.165\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20l3.5 -3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 4l-3.5 3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 9l-3.5 3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 16l-4 4\"}}]})(props);\n};\nexport function TbPlug (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.785 6l8.215 8.215l-2.054 2.054a5.81 5.81 0 1 1 -8.215 -8.215l2.054 -2.054z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20l3.5 -3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 4l-3.5 3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 9l-3.5 3.5\"}}]})(props);\n};\nexport function TbPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"5\",\"x2\":\"12\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"19\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbPodium (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 8h14l-.621 2.485a2 2 0 0 1 -1.94 1.515h-8.878a2 2 0 0 1 -1.94 -1.515l-.621 -2.485z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 8v-2a3 3 0 0 1 3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12l1 9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12l-1 9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 21h10\"}}]})(props);\n};\nexport function TbPointOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.15 9.194a4 4 0 0 0 5.697 5.617m1.153 -2.811a4 4 0 0 0 -4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPoint (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"4\"}}]})(props);\n};\nexport function TbPokeball (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"9\",\"r\":\"9\",\"transform\":\"translate(3 3)\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h6m6 0h6\"}}]})(props);\n};\nexport function TbPolaroid (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"16\",\"x2\":\"20\",\"y2\":\"16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12l3 -3c.928 -.893 2.072 -.893 3 0l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 12l2 -2c.928 -.893 2.072 -.893 3 0l2 2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"7\",\"x2\":\"14.01\",\"y2\":\"7\"}}]})(props);\n};\nexport function TbPolygonOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"8\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"11\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 9.5l1.546 -1.311\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 5.5l3 1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.5 10l-1.185 3.318m-1.062 2.972l-.253 .71\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 17.5l-7 -5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPolygon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"8\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"11\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 9.5l3.5 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 5.5l3 1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.5 10l-2.5 7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 17.5l-7 -5\"}}]})(props);\n};\nexport function TbPool (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 20a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 16a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 12v-7.5a1.5 1.5 0 0 1 3 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12v-7.5a1.5 1.5 0 0 0 -3 0\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"5\",\"x2\":\"9\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"10\",\"x2\":\"15\",\"y2\":\"10\"}}]})(props);\n};\nexport function TbPower (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 6a7.75 7.75 0 1 0 10 0\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbPray (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"5\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 20h8l-4 -4v-7l4 3l2 -2\"}}]})(props);\n};\nexport function TbPremiumRights (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.867 9.75c-.246 -.48 -.708 -.769 -1.2 -.75h-1.334c-.736 0 -1.333 .67 -1.333 1.5c0 .827 .597 1.499 1.333 1.499h1.334c.736 0 1.333 .671 1.333 1.5c0 .828 -.597 1.499 -1.333 1.499h-1.334c-.492 .019 -.954 -.27 -1.2 -.75\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 15v2\"}}]})(props);\n};\nexport function TbPrescription (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 19v-16h4.5a4.5 4.5 0 1 1 0 9h-4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 21l-9 -9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 21l6 -6\"}}]})(props);\n};\nexport function TbPresentationAnalytics (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 12v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 4h18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4v10a2 2 0 0 0 2 2h12a2 2 0 0 0 2 -2v-10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 16v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 20h6\"}}]})(props);\n};\nexport function TbPresentationOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 4h1m4 0h13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4v10a2 2 0 0 0 2 2h10m3.42 -.592c.359 -.362 .58 -.859 .58 -1.408v-10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 16v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 20h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12l2 -2m4 0l2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPresentation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"4\",\"x2\":\"21\",\"y2\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4v10a2 2 0 0 0 2 2h12a2 2 0 0 0 2 -2v-10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"16\",\"x2\":\"12\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"20\",\"x2\":\"15\",\"y2\":\"20\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12l3 -3l2 2l3 -3\"}}]})(props);\n};\nexport function TbPrinterOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.412 16.416c.363 -.362 .588 -.863 .588 -1.416v-4a2 2 0 0 0 -2 -2h-6m-4 0h-4a2 2 0 0 0 -2 2v4a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 9v-4a2 2 0 0 0 -2 -2h-6c-.551 0 -1.05 .223 -1.412 .584m-.588 3.416v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17v2a2 2 0 0 1 -2 2h-6a2 2 0 0 1 -2 -2v-4a2 2 0 0 1 2 -2h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPrinter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17h2a2 2 0 0 0 2 -2v-4a2 2 0 0 0 -2 -2h-14a2 2 0 0 0 -2 2v4a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 9v-4a2 2 0 0 0 -2 -2h-6a2 2 0 0 0 -2 2v4\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"7\",\"y\":\"13\",\"width\":\"10\",\"height\":\"8\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbPrison (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 4v16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4v16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 4v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 4v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 9h-6v6h6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 15v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12h-.01\"}}]})(props);\n};\nexport function TbPrompt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"5 7 10 12 5 17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"17\",\"x2\":\"19\",\"y2\":\"17\"}}]})(props);\n};\nexport function TbPropellerOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.448 10.432a3 3 0 1 0 4.106 4.143\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.272 10.272c.66 -1.459 1.058 -2.888 1.198 -4.286c.22 -1.63 -.762 -2.986 -3.47 -2.986c-1.94 0 -2.994 .696 -3.355 1.69m.697 4.653c.145 .384 .309 .77 .491 1.157\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.169 16.751c.97 1.395 2.057 2.523 3.257 3.386c1.02 .789 2.265 .853 3.408 -.288m1.479 -2.493c.492 -1.634 -.19 -2.726 -1.416 -3.229c-.82 -.37 -1.703 -.654 -2.65 -.852\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.664 12.999c-1.693 .143 -3.213 .52 -4.56 1.128c-1.522 .623 -2.206 2.153 -.852 4.498s3.02 2.517 4.321 1.512c1.2 -.863 2.287 -1.991 3.258 -3.386\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPropeller (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"13\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.167 10.5c.722 -1.538 1.156 -3.043 1.303 -4.514c.22 -1.63 -.762 -2.986 -3.47 -2.986s-3.69 1.357 -3.47 2.986c.147 1.471 .581 2.976 1.303 4.514\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.169 16.751c.97 1.395 2.057 2.523 3.257 3.386c1.3 1.006 2.967 .833 4.321 -1.512c1.354 -2.345 .67 -3.874 -.85 -4.498c-1.348 -.608 -2.868 -.985 -4.562 -1.128\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.664 12.999c-1.693 .143 -3.213 .52 -4.56 1.128c-1.522 .623 -2.206 2.153 -.852 4.498s3.02 2.517 4.321 1.512c1.2 -.863 2.287 -1.991 3.258 -3.386\"}}]})(props);\n};\nexport function TbPuzzle2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4v2.5a0.5 .5 0 0 1 -.5 .5a1.5 1.5 0 0 0 0 3a0.5 .5 0 0 1 .5 .5v1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v1.5a0.5 .5 0 0 0 .5 .5a1.5 1.5 0 0 1 0 3a0.5 .5 0 0 0 -.5 .5v2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12h-2.5a0.5 .5 0 0 1 -.5 -.5a1.5 1.5 0 0 0 -3 0a0.5 .5 0 0 1 -.5 .5h-1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12h-1.5a0.5 .5 0 0 0 -.5 .5a1.5 1.5 0 0 1 -3 0a0.5 .5 0 0 0 -.5 -.5h-2.5\"}}]})(props);\n};\nexport function TbPuzzleOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.18 4.171a2 2 0 0 1 3.82 .829v1a1 1 0 0 0 1 1h3a1 1 0 0 1 1 1v3a1 1 0 0 0 1 1h1a2 2 0 0 1 .819 3.825m-2.819 1.175v3a1 1 0 0 1 -1 1h-3a1 1 0 0 1 -1 -1v-1a2 2 0 1 0 -4 0v1a1 1 0 0 1 -1 1h-3a1 1 0 0 1 -1 -1v-3a1 1 0 0 1 1 -1h1a2 2 0 1 0 0 -4h-1a1 1 0 0 1 -1 -1v-3a1 1 0 0 1 1 -1h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPuzzle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 7h3a1 1 0 0 0 1 -1v-1a2 2 0 0 1 4 0v1a1 1 0 0 0 1 1h3a1 1 0 0 1 1 1v3a1 1 0 0 0 1 1h1a2 2 0 0 1 0 4h-1a1 1 0 0 0 -1 1v3a1 1 0 0 1 -1 1h-3a1 1 0 0 1 -1 -1v-1a2 2 0 0 0 -4 0v1a1 1 0 0 1 -1 1h-3a1 1 0 0 1 -1 -1v-3a1 1 0 0 1 1 -1h1a2 2 0 0 0 0 -4h-1a1 1 0 0 1 -1 -1v-3a1 1 0 0 1 1 -1\"}}]})(props);\n};\nexport function TbPyramidOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.483 8.471l-5.483 8.529l9 4l6.22 -2.764m2.78 -1.236l-9 -14l-1.937 3.014\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v5m0 4v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbPyramid (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17l9 4l9 -4l-9 -14z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v18\"}}]})(props);\n};\nexport function TbQrcode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"17\",\"x2\":\"7\",\"y2\":\"17.01\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"14\",\"y\":\"4\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"7\",\"x2\":\"7\",\"y2\":\"7.01\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"14\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"7\",\"x2\":\"17\",\"y2\":\"7.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"14\",\"x2\":\"17\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"14\",\"x2\":\"20\",\"y2\":\"14.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"14\",\"x2\":\"14\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"20\",\"x2\":\"17\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"17\",\"x2\":\"20\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"17\",\"x2\":\"20\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbQuestionMark (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8a3.5 3 0 0 1 3.5 -3h1a3.5 3 0 0 1 3.5 3a3 3 0 0 1 -2 3a3 4 0 0 0 -2 4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"19\",\"x2\":\"12\",\"y2\":\"19.01\"}}]})(props);\n};\nexport function TbQuoteOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 11h-4a1 1 0 0 1 -1 -1v-3a1 1 0 0 1 1 -1m4 4v3c0 2.667 -1.333 4.333 -4 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 11h-4m-1 -1v-3a1 1 0 0 1 1 -1h3a1 1 0 0 1 1 1v6c0 .66 -.082 1.26 -.245 1.798m-1.653 2.29c-.571 .4 -1.272 .704 -2.102 .912\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbQuote (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 11h-4a1 1 0 0 1 -1 -1v-3a1 1 0 0 1 1 -1h3a1 1 0 0 1 1 1v6c0 2.667 -1.333 4.333 -4 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 11h-4a1 1 0 0 1 -1 -1v-3a1 1 0 0 1 1 -1h3a1 1 0 0 1 1 1v6c0 2.667 -1.333 4.333 -4 5\"}}]})(props);\n};\nexport function TbRadar2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.51 15.56a5 5 0 1 0 -3.51 1.44\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.832 17.86a9 9 0 1 0 -6.832 3.14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v9\"}}]})(props);\n};\nexport function TbRadar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 12h-8a1 1 0 1 0 -1 1v8a9 9 0 0 0 9 -9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.999 8.998a5 5 0 1 0 -6.999 7.003\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.486 8.995a9 9 0 1 0 -11.482 11.495\"}}]})(props);\n};\nexport function TbRadio (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3l-9.371 3.749a1 1 0 0 0 -.629 .928v11.323a1 1 0 0 0 1 1h14a1 1 0 0 0 1 -1v-11a1 1 0 0 0 -1 -1h-14.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 16v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 16v.01\"}}]})(props);\n};\nexport function TbRadioactiveOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.118 14.127c-.182 .181 -.39 .341 -.618 .473l3 5.19a8.994 8.994 0 0 0 1.856 -1.423m1.68 -2.32a8.993 8.993 0 0 0 .964 -4.047h-5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 9.4l3 -5.19a9 9 0 0 0 -8.536 -.25\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 14.6l-3 5.19a9 9 0 0 1 -4.5 -7.79h6a3 3 0 0 0 1.5 2.6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbRadioactive (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 14.6l3 5.19a9 9 0 0 0 4.5 -7.79h-6a3 3 0 0 1 -1.5 2.6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 9.4l3 -5.19a9 9 0 0 0 -9 0l3 5.19a3 3 0 0 1 3 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 14.6l-3 5.19a9 9 0 0 1 -4.5 -7.79h6a3 3 0 0 0 1.5 2.6\"}}]})(props);\n};\nexport function TbRadiusBottomLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 19h-6a8 8 0 0 1 -8 -8v-6\"}}]})(props);\n};\nexport function TbRadiusBottomRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 5v6a8 8 0 0 1 -8 8h-6\"}}]})(props);\n};\nexport function TbRadiusTopLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 19v-6a8 8 0 0 1 8 -8h6\"}}]})(props);\n};\nexport function TbRadiusTopRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 5h6a8 8 0 0 1 8 8v6\"}}]})(props);\n};\nexport function TbRainbowOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 17c0 -5.523 -4.477 -10 -10 -10c-.308 0 -.613 .014 -.914 .041m-3.208 .845a10.002 10.002 0 0 0 -5.878 9.114\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.088 11.069a6.001 6.001 0 0 0 -5.088 5.931\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 17a2 2 0 1 0 -4 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbRainbow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 17c0 -5.523 -4.477 -10 -10 -10s-10 4.477 -10 10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 17a6 6 0 1 0 -12 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 17a2 2 0 1 0 -4 0\"}}]})(props);\n};\nexport function TbReceipt2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 21v-16a2 2 0 0 1 2 -2h10a2 2 0 0 1 2 2v16l-3 -2l-2 2l-2 -2l-2 2l-2 -2l-3 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 8h-2.5a1.5 1.5 0 0 0 0 3h1a1.5 1.5 0 0 1 0 3h-2.5m2 0v1.5m0 -9v1.5\"}}]})(props);\n};\nexport function TbReceiptOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 21v-16m2 -2h10a2 2 0 0 1 2 2v10m0 4.01v1.99l-3 -2l-2 2l-2 -2l-2 2l-2 -2l-3 2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"7\",\"x2\":\"15\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"11\",\"x2\":\"11\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"15\",\"x2\":\"15\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"11\",\"x2\":\"15\",\"y2\":\"11.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbReceiptRefund (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 21v-16a2 2 0 0 1 2 -2h10a2 2 0 0 1 2 2v16l-3 -2l-2 2l-2 -2l-2 2l-2 -2l-3 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 14v-2a2 2 0 0 0 -2 -2h-4l2 -2m0 4l-2 -2\"}}]})(props);\n};\nexport function TbReceiptTax (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"14\",\"x2\":\"15\",\"y2\":\"8\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9.5\",\"cy\":\"8.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"14.5\",\"cy\":\"13.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 21v-16a2 2 0 0 1 2 -2h10a2 2 0 0 1 2 2v16l-3 -2l-2 2l-2 -2l-2 2l-2 -2l-3 2\"}}]})(props);\n};\nexport function TbReceipt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 21v-16a2 2 0 0 1 2 -2h10a2 2 0 0 1 2 2v16l-3 -2l-2 2l-2 -2l-2 2l-2 -2l-3 2m4 -14h6m-6 4h6m-2 4h2\"}}]})(props);\n};\nexport function TbRecharging (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.038 4.5a9 9 0 0 0 -2.495 2.47\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.186 10.209a9 9 0 0 0 0 3.508\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 16.962a9 9 0 0 0 2.47 2.495\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.209 20.814a9 9 0 0 0 3.5 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.962 19.5a9 9 0 0 0 2.495 -2.47\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.814 13.791a9 9 0 0 0 0 -3.508\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.5 7.038a9 9 0 0 0 -2.47 -2.495\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.791 3.186a9 9 0 0 0 -3.508 -.02\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8l-2 4h4l-2 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21a9 9 0 0 0 0 -18\"}}]})(props);\n};\nexport function TbRecordMailOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.569 14.557a3 3 0 1 0 -4.113 -4.149\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 15h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbRecordMail (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"15\",\"x2\":\"17\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbRectangleVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"3\",\"width\":\"14\",\"height\":\"18\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbRectangle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"5\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbRecycleOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17l-2 2l2 2m-2 -2h9m1.896 -2.071a1.999 1.999 0 0 0 -.146 -.679l-.55 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.536 11l-.732 -2.732l-2.732 .732m2.732 -.732l-4.5 7.794a2 2 0 0 0 1.506 2.89l1.141 .024\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.464 11l2.732 .732l.732 -2.732m-.732 2.732l-4.5 -7.794a2 2 0 0 0 -3.256 -.14l-.591 .976\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbRecycle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17l-2 2l2 2m-2 -2h9a2 2 0 0 0 1.75 -2.75l-.55 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17l-2 2l2 2m-2 -2h9a2 2 0 0 0 1.75 -2.75l-.55 -1\",\"transform\":\"rotate(120 12 13)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17l-2 2l2 2m-2 -2h9a2 2 0 0 0 1.75 -2.75l-.55 -1\",\"transform\":\"rotate(240 12 13)\"}}]})(props);\n};\nexport function TbRefreshAlert (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 11a8.1 8.1 0 0 0 -15.5 -2m-.5 -4v4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 13a8.1 8.1 0 0 0 15.5 2m.5 4v-4h-4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"9\",\"x2\":\"12\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"15\",\"x2\":\"12.01\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbRefreshDot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 11a8.1 8.1 0 0 0 -15.5 -2m-.5 -4v4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 13a8.1 8.1 0 0 0 15.5 2m.5 4v-4h-4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}}]})(props);\n};\nexport function TbRefreshOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 11a8.1 8.1 0 0 0 -11.271 -6.305m-2.41 1.624a8.083 8.083 0 0 0 -1.819 2.681m-.5 -4v4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 13a8.1 8.1 0 0 0 13.671 4.691m2.329 -1.691v-1h-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbRefresh (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 11a8.1 8.1 0 0 0 -15.5 -2m-.5 -4v4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 13a8.1 8.1 0 0 0 15.5 2m.5 4v-4h-4\"}}]})(props);\n};\nexport function TbRegistered (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 15v-6h2a2 2 0 1 1 0 4h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 15l-2 -2\"}}]})(props);\n};\nexport function TbRelationManyToMany (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"5\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 14v-4l3 4v-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 14v-4l3 4v-4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"10.5\",\"x2\":\"12\",\"y2\":\"10.51\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"13.5\",\"x2\":\"12\",\"y2\":\"13.51\"}}]})(props);\n};\nexport function TbRelationOneToMany (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"5\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 10h1v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14v-4l3 4v-4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"10.5\",\"x2\":\"11\",\"y2\":\"10.51\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"13.5\",\"x2\":\"11\",\"y2\":\"13.51\"}}]})(props);\n};\nexport function TbRelationOneToOne (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"5\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 10h1v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 10h1v4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"10.5\",\"x2\":\"12\",\"y2\":\"10.51\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"13.5\",\"x2\":\"12\",\"y2\":\"13.51\"}}]})(props);\n};\nexport function TbRepeatOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12v-3c0 -1.336 .873 -2.468 2.08 -2.856m3.92 -.144h10m-3 -3l3 3l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12v3a3 3 0 0 1 -.133 .886m-1.99 1.984a3 3 0 0 1 -.877 .13h-13m3 3l-3 -3l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbRepeatOnce (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12v-3a3 3 0 0 1 3 -3h13m-3 -3l3 3l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12v3a3 3 0 0 1 -3 3h-13m3 3l-3 -3l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 11l1 -1v4\"}}]})(props);\n};\nexport function TbRepeat (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12v-3a3 3 0 0 1 3 -3h13m-3 -3l3 3l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12v3a3 3 0 0 1 -3 3h-13m3 3l-3 -3l3 -3\"}}]})(props);\n};\nexport function TbReplace (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"3\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"15\",\"y\":\"15\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 11v-3a2 2 0 0 0 -2 -2h-6l3 3m0 -6l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 13v3a2 2 0 0 0 2 2h6l-3 -3m0 6l3 -3\"}}]})(props);\n};\nexport function TbReportAnalytics (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h-2a2 2 0 0 0 -2 2v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-12a2 2 0 0 0 -2 -2h-2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"3\",\"width\":\"6\",\"height\":\"4\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 17v-5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 17v-3\"}}]})(props);\n};\nexport function TbReportMedical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h-2a2 2 0 0 0 -2 2v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-12a2 2 0 0 0 -2 -2h-2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"3\",\"width\":\"6\",\"height\":\"4\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"14\",\"x2\":\"14\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbReportMoney (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h-2a2 2 0 0 0 -2 2v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-12a2 2 0 0 0 -2 -2h-2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"3\",\"width\":\"6\",\"height\":\"4\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 11h-2.5a1.5 1.5 0 0 0 0 3h1a1.5 1.5 0 0 1 0 3h-2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17v1m0 -8v1\"}}]})(props);\n};\nexport function TbReportOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.576 5.595a1.994 1.994 0 0 0 -.576 1.405v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2m0 -4v-8a2 2 0 0 0 -2 -2h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5a2 2 0 0 1 2 -2h2a2 2 0 1 1 0 4h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbReportSearch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 5h-2a2 2 0 0 0 -2 2v12a2 2 0 0 0 2 2h5.697\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 12v-5a2 2 0 0 0 -2 -2h-2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"3\",\"width\":\"6\",\"height\":\"4\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15h3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16.5\",\"cy\":\"17.5\",\"r\":\"2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.5 19.5l2.5 2.5\"}}]})(props);\n};\nexport function TbReport (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 5h-2a2 2 0 0 0 -2 2v12a2 2 0 0 0 2 2h5.697\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 14v4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 11v-4a2 2 0 0 0 -2 -2h-2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"3\",\"width\":\"6\",\"height\":\"4\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"18\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15h3\"}}]})(props);\n};\nexport function TbResize (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 11v8a1 1 0 0 0 1 1h8m-9 -14v-1a1 1 0 0 1 1 -1h1m5 0h2m5 0h1a1 1 0 0 1 1 1v1m0 5v2m0 5v1a1 1 0 0 1 -1 1h-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h7a1 1 0 0 1 1 1v7\"}}]})(props);\n};\nexport function TbRippleOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7c.915 -.61 1.83 -1.034 2.746 -1.272m4.212 .22c.68 .247 1.361 .598 2.042 1.052c3 2 6 2 9 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17c3 -2 6 -2 9 0c2.092 1.395 4.184 1.817 6.276 1.266\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12c3 -2 6 -2 9 0m5.482 1.429c1.173 -.171 2.345 -.647 3.518 -1.429\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbRipple (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7c3 -2 6 -2 9 0s6 2 9 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17c3 -2 6 -2 9 0s6 2 9 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12c3 -2 6 -2 9 0s6 2 9 0\"}}]})(props);\n};\nexport function TbRoadOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 19l3.332 -11.661\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 5l2.806 9.823\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbRoadSign (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 20.4l-6.9 -6.9c-.781 -.781 -.781 -2.219 0 -3l6.9 -6.9c.781 -.781 2.219 -.781 3 0l6.9 6.9c.781 .781 .781 2.219 0 3l-6.9 6.9c-.781 .781 -2.219 .781 -3 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 14v-2c0 -.59 .414 -1 1 -1h5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 9l2 2l-2 2\"}}]})(props);\n};\nexport function TbRoad (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 19l4 -14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 5l4 14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18v-2\"}}]})(props);\n};\nexport function TbRobotOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7h6a2 2 0 0 1 2 2v1l1 1v3l-1 1m-.171 3.811a2 2 0 0 1 -1.829 1.189h-10a2 2 0 0 1 -2 -2v-3l-1 -1v-3l1 -1v-1a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 16h4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8.5\",\"cy\":\"11.5\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.854 11.853a0.498 .498 0 0 0 -.354 -.853a0.498 .498 0 0 0 -.356 .149\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.336 4.343l-.336 -1.343\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 7l1 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbRobot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7h10a2 2 0 0 1 2 2v1l1 1v3l-1 1v3a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-3l-1 -1v-3l1 -1v-1a2 2 0 0 1 2 -2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 16h4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8.5\",\"cy\":\"11.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15.5\",\"cy\":\"11.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 7l-1 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 7l1 -4\"}}]})(props);\n};\nexport function TbRocketOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.29 9.275a9.03 9.03 0 0 0 -.29 .725a6 6 0 0 0 -5 3a8 8 0 0 1 7 7a6 6 0 0 0 3 -5c.241 -.085 .478 -.18 .708 -.283m2.428 -1.61a8.998 8.998 0 0 0 2.864 -6.107a3 3 0 0 0 -3 -3a8.998 8.998 0 0 0 -6.107 2.864\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 14a6 6 0 0 0 -3 6a6 6 0 0 0 6 -3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"9\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbRocket (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 13a8 8 0 0 1 7 7a6 6 0 0 0 3 -5a9 9 0 0 0 6 -8a3 3 0 0 0 -3 -3a9 9 0 0 0 -8 6a6 6 0 0 0 -5 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 14a6 6 0 0 0 -3 6a6 6 0 0 0 6 -3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"9\",\"r\":\"1\"}}]})(props);\n};\nexport function TbRollerSkating (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.905 5h3.418a1 1 0 0 1 .928 .629l1.143 2.856a3 3 0 0 0 2.207 1.83l4.717 .926a2.084 2.084 0 0 1 1.682 2.045v.714a1 1 0 0 1 -1 1h-13.895a1 1 0 0 1 -.995 -1.1l.8 -8a1 1 0 0 1 .995 -.9z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16\",\"cy\":\"17\",\"r\":\"2\"}}]})(props);\n};\nexport function TbRollercoaster (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21a5.55 5.55 0 0 0 5.265 -3.795l.735 -2.205a8.775 8.775 0 0 1 8.325 -6h3.675\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 9v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 21v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 9.5v11.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3h5v3h-5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8l4 -3l2 2.5l-4 3l-1.8 -.5z\"}}]})(props);\n};\nexport function TbRotate2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 4.55a8 8 0 0 0 -6 14.9m0 -4.45v5h-5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18.37\",\"y1\":\"7.16\",\"x2\":\"18.37\",\"y2\":\"7.17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"19.94\",\"x2\":\"13\",\"y2\":\"19.95\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16.84\",\"y1\":\"18.37\",\"x2\":\"16.84\",\"y2\":\"18.38\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19.37\",\"y1\":\"15.1\",\"x2\":\"19.37\",\"y2\":\"15.11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19.94\",\"y1\":\"11\",\"x2\":\"19.94\",\"y2\":\"11.01\"}}]})(props);\n};\nexport function TbRotate360 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 16h4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.458 11.042c.86 -2.366 .722 -4.58 -.6 -5.9c-2.272 -2.274 -7.185 -1.045 -10.973 2.743c-3.788 3.788 -5.017 8.701 -2.744 10.974c2.227 2.226 6.987 1.093 10.74 -2.515\"}}]})(props);\n};\nexport function TbRotateClockwise2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4.55a8 8 0 0 1 6 14.9m0 -4.45v5h5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5.63\",\"y1\":\"7.16\",\"x2\":\"5.63\",\"y2\":\"7.17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4.06\",\"y1\":\"11\",\"x2\":\"4.06\",\"y2\":\"11.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4.63\",\"y1\":\"15.1\",\"x2\":\"4.63\",\"y2\":\"15.11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7.16\",\"y1\":\"18.37\",\"x2\":\"7.16\",\"y2\":\"18.38\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"19.94\",\"x2\":\"11\",\"y2\":\"19.95\"}}]})(props);\n};\nexport function TbRotateClockwise (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.05 11a8 8 0 1 1 .5 4m-.5 5v-5h5\"}}]})(props);\n};\nexport function TbRotateDot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.95 11a8 8 0 1 0 -.5 4m.5 5v-5h-5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}}]})(props);\n};\nexport function TbRotateRectangle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.3 5h.7a2 2 0 0 1 2 2v10a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-10a2 2 0 0 1 2 -2h5l-2.82 -2.82m0 5.64l2.82 -2.82\",\"transform\":\"rotate(-45 12 12)\"}}]})(props);\n};\nexport function TbRotate (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.95 11a8 8 0 1 0 -.5 4m.5 5v-5h-5\"}}]})(props);\n};\nexport function TbRouteOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 19h4.5c.71 0 1.372 -.212 1.924 -.576m1.545 -2.459a3.5 3.5 0 0 0 -3.469 -3.965h-.499m-4 0h-3.501a3.5 3.5 0 0 1 -2.477 -5.972m2.477 -1.028h3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbRoute (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 19h4.5a3.5 3.5 0 0 0 0 -7h-8a3.5 3.5 0 0 1 0 -7h3.5\"}}]})(props);\n};\nexport function TbRouter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"13\",\"width\":\"18\",\"height\":\"8\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"17\",\"x2\":\"17\",\"y2\":\"17.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"17\",\"x2\":\"13\",\"y2\":\"17.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"13\",\"x2\":\"15\",\"y2\":\"11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.75 8.75a4 4 0 0 1 6.5 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 6.5a8 8 0 0 1 13 0\"}}]})(props);\n};\nexport function TbRowInsertBottom (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 6v4a1 1 0 0 1 -1 1h-14a1 1 0 0 1 -1 -1v-4a1 1 0 0 1 1 -1h14a1 1 0 0 1 1 1z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"15\",\"x2\":\"12\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"17\",\"x2\":\"10\",\"y2\":\"17\"}}]})(props);\n};\nexport function TbRowInsertTop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18v-4a1 1 0 0 1 1 -1h14a1 1 0 0 1 1 1v4a1 1 0 0 1 -1 1h-14a1 1 0 0 1 -1 -1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9v-4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"7\",\"x2\":\"14\",\"y2\":\"7\"}}]})(props);\n};\nexport function TbRss (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"19\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4a16 16 0 0 1 16 16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 11a9 9 0 0 1 9 9\"}}]})(props);\n};\nexport function TbRuler2Off (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.03 7.97l4.97 -4.97l4 4l-5 5m-2 2l-7 7l-4 -4l7 -7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 7l-1.5 -1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 13l-1.5 -1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 16l-1.5 -1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbRuler2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 3l4 4l-14 14l-4 -4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 7l-1.5 -1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 10l-1.5 -1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 13l-1.5 -1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 16l-1.5 -1.5\"}}]})(props);\n};\nexport function TbRulerOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h11a1 1 0 0 1 1 1v5a1 1 0 0 1 -1 1h-4m-3.713 .299a0.997 .997 0 0 0 -.287 .701v7a1 1 0 0 1 -1 1h-5a1 1 0 0 1 -1 -1v-14c0 -.284 .118 -.54 .308 -.722\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbRuler (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h14a1 1 0 0 1 1 1v5a1 1 0 0 1 -1 1h-7a1 1 0 0 0 -1 1v7a1 1 0 0 1 -1 1h-5a1 1 0 0 1 -1 -1v-14a1 1 0 0 1 1 -1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"8\",\"x2\":\"6\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"7\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"16\",\"x2\":\"6\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"4\",\"x2\":\"8\",\"y2\":\"6\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"12 4 12 7 \"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 4 16 6 \"}}]})(props);\n};\nexport function TbRun (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"13\",\"cy\":\"4\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 17l5 1l.75 -1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 21l0 -4l-4 -3l1 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12l0 -3l5 -1l3 3l3 1\"}}]})(props);\n};\nexport function TbSailboat (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 20a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18l-1 -3h18l-1 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 12h7l-7 -9v9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"7\",\"x2\":\"6\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbSalt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 16v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 16v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 8h9l-.281 -2.248a2 2 0 0 0 -1.985 -1.752h-4.468a2 2 0 0 0 -1.986 1.752l-.28 2.248z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 8l-1.612 9.671a2 2 0 0 0 1.973 2.329h8.278a2 2 0 0 0 1.973 -2.329l-1.612 -9.671\"}}]})(props);\n};\nexport function TbSatelliteOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.707 3.707l5.586 5.586m-1.293 2.707l-1.293 1.293a1 1 0 0 1 -1.414 0l-5.586 -5.586a1 1 0 0 1 0 -1.414l1.293 -1.293\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10l-3 3l3 3l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6l3 -3l3 3l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l1.5 1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.5 17c.69 0 1.316 -.28 1.769 -.733\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 21c1.654 0 3.151 -.67 4.237 -1.752m1.507 -2.507a6 6 0 0 0 .256 -1.741\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbSatellite (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.707 6.293l2.586 -2.586a1 1 0 0 1 1.414 0l5.586 5.586a1 1 0 0 1 0 1.414l-2.586 2.586a1 1 0 0 1 -1.414 0l-5.586 -5.586a1 1 0 0 1 0 -1.414z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10l-3 3l3 3l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6l3 -3l3 3l-3 3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"13.5\",\"y2\":\"13.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.5 17a2.5 2.5 0 0 0 2.5 -2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 21a6 6 0 0 0 6 -6\"}}]})(props);\n};\nexport function TbSausage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 5.5a2.5 2.5 0 0 0 -2.5 2.5c0 7.18 5.82 13 13 13a2.5 2.5 0 1 0 0 -5a8 8 0 0 1 -8 -8a2.5 2.5 0 0 0 -2.5 -2.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.195 5.519l-1.243 -1.989a1 1 0 0 1 .848 -1.53h1.392a1 1 0 0 1 .848 1.53l-1.245 1.99\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.482 18.225l1.989 -1.243a1 1 0 0 1 1.53 .848v1.392a1 1 0 0 1 -1.53 .848l-1.991 -1.245\"}}]})(props);\n};\nexport function TbScaleOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 20h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.452 5.425l2.548 -.425l6 1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v5m0 4v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12l-3 -6l-3 6a3 3 0 0 0 6 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.873 14.871a3.001 3.001 0 0 0 2.127 -2.871l-3 -6l-2.677 5.355\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbScaleOutlineOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 3h10a4 4 0 0 1 4 4v10m-1.173 2.83a3.987 3.987 0 0 1 -2.827 1.17h-10a4 4 0 0 1 -4 -4v-10c0 -1.104 .447 -2.103 1.17 -2.827\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.062 7.062c.31 -.041 .622 -.062 .938 -.062c1.956 0 3.724 .802 4.994 2.095a142.85 142.85 0 0 0 -1.994 1.905m-3.723 .288a3 3 0 0 0 -1.315 .71l-2.956 -2.903a6.977 6.977 0 0 1 1.142 -.942\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbScaleOutline (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"3\",\"width\":\"18\",\"height\":\"18\",\"rx\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7c1.956 0 3.724 .802 4.994 2.095l-2.956 2.904a3 3 0 0 0 -2.038 -.799a3 3 0 0 0 -2.038 .798l-2.956 -2.903a6.979 6.979 0 0 1 4.994 -2.095z\"}}]})(props);\n};\nexport function TbScale (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"20\",\"x2\":\"17\",\"y2\":\"20\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6l6 -1l6 1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"20\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12l-3 -6l-3 6a3 3 0 0 0 6 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 12l-3 -6l-3 6a3 3 0 0 0 6 0\"}}]})(props);\n};\nexport function TbScan (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 7v-1a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 17v1a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h2a2 2 0 0 1 2 2v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h2a2 2 0 0 0 2 -2v-1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"19\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbSchoolOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 9l-10 -4l-2.136 .854m-2.864 1.146l-5 2l10 4l.697 -.279m2.878 -1.151l6.425 -2.57v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10.6v5.4c0 1.657 2.686 3 6 3c2.334 0 4.357 -.666 5.35 -1.64m.65 -3.36v-3.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbSchool (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 9l-10 -4l-10 4l10 4l10 -4v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10.6v5.4a6 3 0 0 0 12 0v-5.4\"}}]})(props);\n};\nexport function TbScissorsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.432 4.442a3 3 0 1 0 4.114 4.146\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"17\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.6 15.4l3.4 -3.4m2 -2l5 -5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbScissors (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"7\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"17\",\"r\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8.6\",\"y1\":\"8.6\",\"x2\":\"19\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8.6\",\"y1\":\"15.4\",\"x2\":\"19\",\"y2\":\"5\"}}]})(props);\n};\nexport function TbScooterElectric (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 17h5a6 6 0 0 1 5 -5v-5a2 2 0 0 0 -2 -2h-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 4l-2 4h3l-2 4\"}}]})(props);\n};\nexport function TbScooter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 17h5a6 6 0 0 1 5 -5v-5a2 2 0 0 0 -2 -2h-1\"}}]})(props);\n};\nexport function TbScreenShareOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 12v3a1 1 0 0 1 -1 1h-16a1 1 0 0 1 -1 -1v-10a1 1 0 0 1 1 -1h9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"20\",\"x2\":\"17\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"16\",\"x2\":\"9\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"16\",\"x2\":\"15\",\"y2\":\"20\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 8l4 -4m-4 0l4 4\"}}]})(props);\n};\nexport function TbScreenShare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 12v3a1 1 0 0 1 -1 1h-16a1 1 0 0 1 -1 -1v-10a1 1 0 0 1 1 -1h9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"20\",\"x2\":\"17\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"16\",\"x2\":\"9\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"16\",\"x2\":\"15\",\"y2\":\"20\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4h4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 9l5 -5\"}}]})(props);\n};\nexport function TbScribble (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 15c2 3 4 4 7 4s7 -3 7 -7s-3 -7 -6 -7s-5 1.5 -5 4s2 5 6 5s8.408 -2.453 10 -5\"}}]})(props);\n};\nexport function TbScubaMask (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 7h12a1 1 0 0 1 1 1v4.5a2.5 2.5 0 0 1 -2.5 2.5h-.5a2 2 0 0 1 -2 -2a2 2 0 1 0 -4 0a2 2 0 0 1 -2 2h-.5a2.5 2.5 0 0 1 -2.5 -2.5v-4.5a1 1 0 0 1 1 -1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 17a2 2 0 0 0 2 2h3.5a5.5 5.5 0 0 0 5.5 -5.5v-9.5\"}}]})(props);\n};\nexport function TbSearchOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.039 5.062a7 7 0 0 0 9.91 9.89m1.584 -2.434a7 7 0 0 0 -9.038 -9.057\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbSearch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"10\",\"cy\":\"10\",\"r\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"21\",\"x2\":\"15\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbSectionSign (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.172 19.004a3.001 3.001 0 1 0 2.828 -4.004\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.83 5.002a3.001 3.001 0 1 0 -2.83 3.998\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}}]})(props);\n};\nexport function TbSection (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 20h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 20h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 20h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 4h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4l0 0\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"8\",\"width\":\"16\",\"height\":\"8\",\"rx\":\"1\"}}]})(props);\n};\nexport function TbSeedingOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.412 7.407a6.025 6.025 0 0 0 -2.82 -2.82m-4.592 -.587h-1v2a6 6 0 0 0 6 6h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14a6 6 0 0 1 .255 -1.736m1.51 -2.514a5.981 5.981 0 0 1 4.235 -1.75h3v1c0 2.158 -1.14 4.05 -2.85 5.107m-3.15 .893h-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 20v-8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbSeeding (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 10a6 6 0 0 0 -6 -6h-3v2a6 6 0 0 0 6 6h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14a6 6 0 0 1 6 -6h3v1a6 6 0 0 1 -6 6h-3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"20\",\"x2\":\"12\",\"y2\":\"10\"}}]})(props);\n};\nexport function TbSelect (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 11l3 3l3 -3\"}}]})(props);\n};\nexport function TbSelector (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"8 9 12 5 16 9\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 15 12 19 8 15\"}}]})(props);\n};\nexport function TbSend (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"14\",\"x2\":\"21\",\"y2\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 3l-6.5 18a0.55 .55 0 0 1 -1 0l-3.5 -7l-7 -3.5a0.55 .55 0 0 1 0 -1l18 -6.5\"}}]})(props);\n};\nexport function TbSeparatorHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"8 8 12 4 16 8\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 16 12 20 8 16\"}}]})(props);\n};\nexport function TbSeparatorVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"20\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"8 8 4 12 8 16\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 16 20 12 16 8\"}}]})(props);\n};\nexport function TbSeparator (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"12\",\"x2\":\"3\",\"y2\":\"12.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"12\",\"x2\":\"17\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"12\",\"x2\":\"21\",\"y2\":\"12.01\"}}]})(props);\n};\nexport function TbServer2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"4\",\"width\":\"18\",\"height\":\"8\",\"rx\":\"3\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"12\",\"width\":\"18\",\"height\":\"8\",\"rx\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"8\",\"x2\":\"7\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"16\",\"x2\":\"7\",\"y2\":\"16.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 8h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 16h6\"}}]})(props);\n};\nexport function TbServerOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12h-6a3 3 0 0 1 -3 -3v-2c0 -1.083 .574 -2.033 1.435 -2.56m3.565 -.44h10a3 3 0 0 1 3 3v2a3 3 0 0 1 -3 3h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12h2a3 3 0 0 1 3 3v2m-1.448 2.568a2.986 2.986 0 0 1 -1.552 .432h-12a3 3 0 0 1 -3 -3v-2a3 3 0 0 1 3 -3h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 8v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 16v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbServer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"4\",\"width\":\"18\",\"height\":\"8\",\"rx\":\"3\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"12\",\"width\":\"18\",\"height\":\"8\",\"rx\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"8\",\"x2\":\"7\",\"y2\":\"8.01\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"16\",\"x2\":\"7\",\"y2\":\"16.01\"}}]})(props);\n};\nexport function TbServicemark (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 9h-2.5a1.5 1.5 0 0 0 0 3h1a1.5 1.5 0 0 1 0 3h-2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 15v-6l3 4l3 -4v6\"}}]})(props);\n};\nexport function TbSettingsAutomation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.325 4.317c.426 -1.756 2.924 -1.756 3.35 0a1.724 1.724 0 0 0 2.573 1.066c1.543 -.94 3.31 .826 2.37 2.37a1.724 1.724 0 0 0 1.065 2.572c1.756 .426 1.756 2.924 0 3.35a1.724 1.724 0 0 0 -1.066 2.573c.94 1.543 -.826 3.31 -2.37 2.37a1.724 1.724 0 0 0 -2.572 1.065c-.426 1.756 -2.924 1.756 -3.35 0a1.724 1.724 0 0 0 -2.573 -1.066c-1.543 .94 -3.31 -.826 -2.37 -2.37a1.724 1.724 0 0 0 -1.065 -2.572c-1.756 -.426 -1.756 -2.924 0 -3.35a1.724 1.724 0 0 0 1.066 -2.573c-.94 -1.543 .826 -3.31 2.37 -2.37c1 .608 2.296 .07 2.572 -1.065z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 9v6l5 -3z\"}}]})(props);\n};\nexport function TbSettingsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.456 5.435c.416 -.22 .745 -.609 .869 -1.118c.426 -1.756 2.924 -1.756 3.35 0a1.724 1.724 0 0 0 2.573 1.066c1.543 -.94 3.31 .826 2.37 2.37a1.724 1.724 0 0 0 1.065 2.572c1.756 .426 1.756 2.924 0 3.35a1.724 1.724 0 0 0 -1.187 1.016m-.126 3.666c-.516 .522 -1.348 .733 -2.123 .261a1.724 1.724 0 0 0 -2.572 1.065c-.426 1.756 -2.924 1.756 -3.35 0a1.724 1.724 0 0 0 -2.573 -1.066c-1.543 .94 -3.31 -.826 -2.37 -2.37a1.724 1.724 0 0 0 -1.065 -2.572c-1.756 -.426 -1.756 -2.924 0 -3.35a1.724 1.724 0 0 0 1.066 -2.573c-.468 -.768 -.266 -1.59 .246 -2.108\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.879 9.878a3 3 0 1 0 4.256 4.23m.552 -3.444a3.012 3.012 0 0 0 -1.412 -1.38\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbSettings (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.325 4.317c.426 -1.756 2.924 -1.756 3.35 0a1.724 1.724 0 0 0 2.573 1.066c1.543 -.94 3.31 .826 2.37 2.37a1.724 1.724 0 0 0 1.065 2.572c1.756 .426 1.756 2.924 0 3.35a1.724 1.724 0 0 0 -1.066 2.573c.94 1.543 -.826 3.31 -2.37 2.37a1.724 1.724 0 0 0 -2.572 1.065c-.426 1.756 -2.924 1.756 -3.35 0a1.724 1.724 0 0 0 -2.573 -1.066c-1.543 .94 -3.31 -.826 -2.37 -2.37a1.724 1.724 0 0 0 -1.065 -2.572c-1.756 -.426 -1.756 -2.924 0 -3.35a1.724 1.724 0 0 0 1.066 -2.573c-.94 -1.543 .826 -3.31 2.37 -2.37c1 .608 2.296 .07 2.572 -1.065z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}}]})(props);\n};\nexport function TbShadowOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.634 5.638a9 9 0 0 0 12.728 12.727m1.68 -2.32a9 9 0 0 0 -12.086 -12.088\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 15h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 18h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 9h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 6h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbShadow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 12h5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 15h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 18h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 9h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 6h1\"}}]})(props);\n};\nexport function TbShape2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 17.5l11 -11m-12.5 .5v10m14 -10v10\"}}]})(props);\n};\nexport function TbShape3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 5h10m-12 2v10m14 -10v10\"}}]})(props);\n};\nexport function TbShapeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.575 3.597a2 2 0 0 0 2.849 2.808\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.574 17.598a2 2 0 0 0 2.826 2.83\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 19h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 7v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbShape (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"7\",\"x2\":\"5\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"5\",\"x2\":\"17\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"19\",\"x2\":\"17\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"7\",\"x2\":\"19\",\"y2\":\"17\"}}]})(props);\n};\nexport function TbShareOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"6\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.861 15.896a3 3 0 0 0 4.265 4.22m.578 -3.417a3.012 3.012 0 0 0 -1.507 -1.45\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.7 10.7l1.336 -.688m2.624 -1.352l2.64 -1.36\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.7 13.3l6.6 3.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbShare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"6\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"18\",\"r\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8.7\",\"y1\":\"10.7\",\"x2\":\"15.3\",\"y2\":\"7.3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8.7\",\"y1\":\"13.3\",\"x2\":\"15.3\",\"y2\":\"16.7\"}}]})(props);\n};\nexport function TbShieldCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12l2 2l4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3a12 12 0 0 0 8.5 3a12 12 0 0 1 -8.5 15a12 12 0 0 1 -8.5 -15a12 12 0 0 0 8.5 -3\"}}]})(props);\n};\nexport function TbShieldCheckered (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3a12 12 0 0 0 8.5 3a12 12 0 0 1 -8.5 15a12 12 0 0 1 -8.5 -15a12 12 0 0 0 8.5 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 12h17\"}}]})(props);\n};\nexport function TbShieldChevron (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3a12 12 0 0 0 8.5 3a12 12 0 0 1 -8.5 15a12 12 0 0 1 -8.5 -15a12 12 0 0 0 8.5 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 14l8 -3l8 3\"}}]})(props);\n};\nexport function TbShieldLock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3a12 12 0 0 0 8.5 3a12 12 0 0 1 -8.5 15a12 12 0 0 1 -8.5 -15a12 12 0 0 0 8.5 -3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"11\",\"r\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"14.5\"}}]})(props);\n};\nexport function TbShieldOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.669 17.669a12 12 0 0 1 -5.669 3.331a12 12 0 0 1 -8.5 -15c.797 .036 1.589 0 2.366 -.126m3.092 -.912a12 12 0 0 0 3.042 -1.962a12 12 0 0 0 8.5 3a12 12 0 0 1 -1.117 9.379\"}}]})(props);\n};\nexport function TbShieldX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3a12 12 0 0 0 8.5 3a12 12 0 0 1 -8.5 15a12 12 0 0 1 -8.5 -15a12 12 0 0 0 8.5 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10l4 4m0 -4l-4 4\"}}]})(props);\n};\nexport function TbShield (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3a12 12 0 0 0 8.5 3a12 12 0 0 1 -8.5 15a12 12 0 0 1 -8.5 -15a12 12 0 0 0 8.5 -3\"}}]})(props);\n};\nexport function TbShip (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 20a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18l-1 -5h18l-2 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 13v-6h8l4 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7v-4h-1\"}}]})(props);\n};\nexport function TbShirtOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.243 4.252l.757 -.252c0 .43 .09 .837 .252 1.206m1.395 1.472a3 3 0 0 0 4.353 -2.678l6 2v5h-3v3m0 4v1a1 1 0 0 1 -1 1h-10a1 1 0 0 1 -1 -1v-8h-3v-5l2.26 -.753\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbShirt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 4l6 2v5h-3v8a1 1 0 0 1 -1 1h-10a1 1 0 0 1 -1 -1v-8h-3v-5l6 -2a3 3 0 0 0 6 0\"}}]})(props);\n};\nexport function TbShoeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.846 9.868l4.08 .972a4 4 0 0 1 3.074 3.89v2.27m-3 1h-14a1 1 0 0 1 -1 -1v-10a1 1 0 0 1 1 -1h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 18v-1a4 4 0 0 0 -4 -4h-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12l.663 -1.327\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbShoe (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6h5.426a1 1 0 0 1 .863 .496l1.064 1.823a3 3 0 0 0 1.896 1.407l4.677 1.114a4 4 0 0 1 3.074 3.89v2.27a1 1 0 0 1 -1 1h-16a1 1 0 0 1 -1 -1v-10a1 1 0 0 1 1 -1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 13l1 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 18v-1a4 4 0 0 0 -4 -4h-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12l1.5 -3\"}}]})(props);\n};\nexport function TbShoppingCartDiscount (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17h-11v-14h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 6l-1 7h-13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10l6 -6\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"10.5\",\"cy\":\"4.5\",\"r\":\".5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15.5\",\"cy\":\"9.5\",\"r\":\".5\"}}]})(props);\n};\nexport function TbShoppingCartOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17a2 2 0 1 0 2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17h-11v-11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.239 5.231l10.761 .769l-1 7h-2m-4 0h-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbShoppingCartPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17h-11v-14h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 5l6.005 .429m7.138 6.573l-.143 .998h-13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 6h6m-3 -3v6\"}}]})(props);\n};\nexport function TbShoppingCartX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17h-11v-14h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 5l7.999 .571m5.43 4.43l-.429 2.999h-13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 3l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 3l-4 4\"}}]})(props);\n};\nexport function TbShoppingCart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17h-11v-14h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 5l14 1l-1 7h-13\"}}]})(props);\n};\nexport function TbShovel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.5 5.5l-8 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.276 11.284l4.44 4.44a0.968 .968 0 0 1 0 1.369l-2.704 2.704a4.108 4.108 0 0 1 -5.809 -5.81l2.704 -2.703a0.968 .968 0 0 1 1.37 0z\"}}]})(props);\n};\nexport function TbShredder (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"10\",\"width\":\"16\",\"height\":\"5\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 10v-4a2 2 0 0 0 -2 -2h-6a2 2 0 0 0 -2 2v4m5 5v5m4 -5v2m-8 -2v3\"}}]})(props);\n};\nexport function TbSignLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 21h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 21v-10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 6v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 6h-10l-2 2.5l2 2.5h10z\"}}]})(props);\n};\nexport function TbSignRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 21h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 21v-10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6h10l2 2.5l-2 2.5h-10z\"}}]})(props);\n};\nexport function TbSignatureOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17c3.333 -3.333 5 -6 5 -8c0 -.394 -.017 -.735 -.05 -1.033m-1.95 -1.967c-1 0 -2.032 1.085 -2 3c.034 2.048 1.658 4.877 2.5 6c1.5 2 2.5 2.5 3.5 1l2 -3c.333 2.667 1.333 4 3 4c.219 0 .708 -.341 1.231 -.742m3.769 -.258c.303 .245 .64 .677 1 1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbSignature (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17c3.333 -3.333 5 -6 5 -8c0 -3 -1 -3 -2 -3s-2.032 1.085 -2 3c.034 2.048 1.658 4.877 2.5 6c1.5 2 2.5 2.5 3.5 1l2 -3c.333 2.667 1.333 4 3 4c.53 0 2.639 -2 3 -2c.517 0 1.517 .667 3 2\"}}]})(props);\n};\nexport function TbSitemapOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"15\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 15a2 2 0 0 1 2 2m-.591 3.42c-.362 .358 -.86 .58 -1.409 .58h-2a2 2 0 0 1 -2 -2v-2c0 -.549 .221 -1.046 .579 -1.407\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5a2 2 0 0 1 2 -2h2a2 2 0 0 1 2 2v2a2 2 0 0 1 -2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15v-1a2 2 0 0 1 2 -2h4m4 0a2 2 0 0 1 2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbSitemap (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"15\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"15\",\"y\":\"15\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"3\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15v-1a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"9\",\"x2\":\"12\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbSkateboard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"15\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"15\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 9a2 1 0 0 0 2 1h14a2 1 0 0 0 2 -1\"}}]})(props);\n};\nexport function TbSleigh (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19h15a4 4 0 0 0 4 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 15h-9a4 4 0 0 1 -4 -4v-6l1.243 1.243a6 6 0 0 0 4.242 1.757h3.515v2a2 2 0 0 0 2 2h.5a1.5 1.5 0 0 0 1.5 -1.5a1.5 1.5 0 0 1 3 0v1.5a3 3 0 0 1 -3 3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 15v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 15v4\"}}]})(props);\n};\nexport function TbSlice (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19l15 -15l3 3l-6 6l2 2a14 14 0 0 1 -14 4\"}}]})(props);\n};\nexport function TbSlideshow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"6\",\"x2\":\"15.01\",\"y2\":\"6\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"3\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 13l4 -4a3 5 0 0 1 3 0l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 12l2 -2a3 5 0 0 1 3 0l3 3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"21\",\"x2\":\"8.01\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"21\",\"x2\":\"12.01\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"21\",\"x2\":\"16.01\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbSmartHomeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.097 7.125l-2.037 1.585a2.665 2.665 0 0 0 -1.029 2.105v7.2a2 2 0 0 0 2 2h12c.559 0 1.064 -.229 1.427 -.598m.572 -3.417v-5.185c0 -.823 -.38 -1.6 -1.03 -2.105l-5.333 -4.148a2.666 2.666 0 0 0 -3.274 0l-1.029 .8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.332 15.345c-2.213 .976 -5.335 .86 -7.332 -.345\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbSmartHome (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 8.71l-5.333 -4.148a2.666 2.666 0 0 0 -3.274 0l-5.334 4.148a2.665 2.665 0 0 0 -1.029 2.105v7.2a2 2 0 0 0 2 2h12a2 2 0 0 0 2 -2v-7.2c0 -.823 -.38 -1.6 -1.03 -2.105\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 15c-2.21 1.333 -5.792 1.333 -8 0\"}}]})(props);\n};\nexport function TbSmokingNo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"13\",\"x2\":\"8\",\"y2\":\"17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 5v.5a2 2 0 0 0 2 2a2 2 0 0 1 2 2v.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 13h3a1 1 0 0 1 1 1v2c0 .28 -.115 .533 -.3 .714m-3.7 .286h-13a1 1 0 0 1 -1 -1v-2a1 1 0 0 1 1 -1h9\"}}]})(props);\n};\nexport function TbSmoking (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"13\",\"width\":\"18\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"13\",\"x2\":\"8\",\"y2\":\"17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 5v.5a2 2 0 0 0 2 2a2 2 0 0 1 2 2v.5\"}}]})(props);\n};\nexport function TbSnowflakeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 4l2 1l2 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 2v6m1.196 1.186l1.804 1.034\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.928 6.268l.134 2.232l1.866 1.232\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.66 7l-5.629 3.25l-.031 .75\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19.928 14.268l-1.015 .67\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.212 14.226l-2.171 1.262\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 20l-2 -1l-2 1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 22v-6.5l-3 -1.72\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.072 17.732l-.134 -2.232l-1.866 -1.232\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.34 17l5.629 -3.25l-.01 -3.458\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.072 9.732l1.866 -1.232l.134 -2.232\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.34 7l5.629 3.25l.802 -.466\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbSnowflake (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 4l2 1l2 -1m-2 -2v6.5l3 1.72\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 4l2 1l2 -1m-2 -2v6.5l3 1.72\",\"transform\":\"rotate(60 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 4l2 1l2 -1m-2 -2v6.5l3 1.72\",\"transform\":\"rotate(120 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 4l2 1l2 -1m-2 -2v6.5l3 1.72\",\"transform\":\"rotate(180 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 4l2 1l2 -1m-2 -2v6.5l3 1.72\",\"transform\":\"rotate(240 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 4l2 1l2 -1m-2 -2v6.5l3 1.72\",\"transform\":\"rotate(300 12 12)\"}}]})(props);\n};\nexport function TbSoccerField (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 9h3v6h-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 9h3v6h-3z\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"5\",\"width\":\"18\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"5\",\"x2\":\"12\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbSocialOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.57 17.602a2 2 0 0 0 2.83 2.827\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.113 11.133a3.001 3.001 0 1 0 3.765 3.715\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.7 17.8l2.8 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.3 17.8l-2.8 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbSocial (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"14\",\"r\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"7\",\"x2\":\"12\",\"y2\":\"11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6.7\",\"y1\":\"17.8\",\"x2\":\"9.5\",\"y2\":\"15.8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17.3\",\"y1\":\"17.8\",\"x2\":\"14.5\",\"y2\":\"15.8\"}}]})(props);\n};\nexport function TbSock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 3v6l4.798 5.142a4 4 0 0 1 -5.441 5.86l-6.736 -6.41a2 2 0 0 1 -.621 -1.451v-9.141h8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.895 15.768c.708 -.721 1.105 -1.677 1.105 -2.768a4 4 0 0 0 -4 -4\"}}]})(props);\n};\nexport function TbSofa (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 11a2 2 0 0 1 2 2v1h12v-1a2 2 0 1 1 4 0v5a1 1 0 0 1 -1 1h-18a1 1 0 0 1 -1 -1v-5a2 2 0 0 1 2 -2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 11v-3a3 3 0 0 1 3 -3h10a3 3 0 0 1 3 3v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5v9\"}}]})(props);\n};\nexport function TbSortAscending2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 9l3 -3l3 3\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"5\",\"width\":\"5\",\"height\":\"5\",\"rx\":\".5\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"14\",\"width\":\"5\",\"height\":\"5\",\"rx\":\".5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 6v12\"}}]})(props);\n};\nexport function TbSortAscendingLetters (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 10v-5c0 -1.38 .62 -2 2 -2s2 .62 2 2v5m0 -3h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 21h-4l4 -7h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 15l3 3l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 6v12\"}}]})(props);\n};\nexport function TbSortAscendingNumbers (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 15l3 3l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 3a2 2 0 0 1 2 2v3a2 2 0 1 1 -4 0v-3a2 2 0 0 1 2 -2z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"16\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 16v3a2 2 0 0 1 -2 2h-1.5\"}}]})(props);\n};\nexport function TbSortAscending (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"6\",\"x2\":\"11\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"11\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"18\",\"x2\":\"13\",\"y2\":\"18\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"15 9 18 6 21 9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"6\",\"x2\":\"18\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbSortDescending2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"5\",\"width\":\"5\",\"height\":\"5\",\"rx\":\".5\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"5\",\"y\":\"14\",\"width\":\"5\",\"height\":\"5\",\"rx\":\".5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 15l3 3l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 18v-12\"}}]})(props);\n};\nexport function TbSortDescendingLetters (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 21v-5c0 -1.38 .62 -2 2 -2s2 .62 2 2v5m0 -3h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 10h-4l4 -7h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 15l3 3l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 6v12\"}}]})(props);\n};\nexport function TbSortDescendingNumbers (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 15l3 3l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 6v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 14a2 2 0 0 1 2 2v3a2 2 0 1 1 -4 0v-3a2 2 0 0 1 2 -2z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 5v3a2 2 0 0 1 -2 2h-1.5\"}}]})(props);\n};\nexport function TbSortDescending (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"6\",\"x2\":\"13\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"11\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"18\",\"x2\":\"11\",\"y2\":\"18\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"15 15 18 18 21 15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"6\",\"x2\":\"18\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbSoup (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19h18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 11h18a8 8 0 0 1 -8 8h-2a8 8 0 0 1 -8 -8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 8v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 5v3\"}}]})(props);\n};\nexport function TbSpaceOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 10v3a1 1 0 0 0 1 1h9m4 0h1a1 1 0 0 0 1 -1v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbSpace (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 10v3a1 1 0 0 0 1 1h14a1 1 0 0 0 1 -1v-3\"}}]})(props);\n};\nexport function TbSpacingHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 20h-2a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 2 -2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20h2a2 2 0 0 0 2 -2v-12a2 2 0 0 0 -2 -2h-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8v8\"}}]})(props);\n};\nexport function TbSpacingVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20v-2a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4v2a2 2 0 0 0 2 2h12a2 2 0 0 0 2 -2v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12h-8\"}}]})(props);\n};\nexport function TbSpade (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3l4.919 4.5c.61 .587 1.177 1.177 1.703 1.771a5.527 5.527 0 0 1 .264 6.979c-1.18 1.56 -3.338 1.92 -4.886 .75v1l1 3h-6l1 -3v-1c-1.54 1.07 -3.735 .772 -4.886 -.75a5.527 5.527 0 0 1 .264 -6.979a30.883 30.883 0 0 1 1.703 -1.771a1541.72 1541.72 0 0 1 4.919 -4.5z\"}}]})(props);\n};\nexport function TbSpeakerphone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 8a3 3 0 0 1 0 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 8v11a1 1 0 0 1 -1 1h-1a1 1 0 0 1 -1 -1v-5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8h0l4.524 -3.77a0.9 .9 0 0 1 1.476 .692v12.156a0.9 .9 0 0 1 -1.476 .692l-4.524 -3.77h-8a1 1 0 0 1 -1 -1v-4a1 1 0 0 1 1 -1h8\"}}]})(props);\n};\nexport function TbSpeedboat (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17h13.4a3 3 0 0 0 2.5 -1.34l3.1 -4.66h0h-6.23a4 4 0 0 0 -1.49 .29l-3.56 1.42a4 4 0 0 1 -1.49 .29h-3.73h0h-1l-1.5 4z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"13\",\"x2\":\"7.5\",\"y2\":\"8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8h8l2 3\"}}]})(props);\n};\nexport function TbSportBillard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"10\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"14\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"8\"}}]})(props);\n};\nexport function TbSquare0 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8a2 2 0 0 1 2 2v4a2 2 0 1 1 -4 0v-4a2 2 0 0 1 2 -2z\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbSquare1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 16v-8l-2 2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbSquare2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10a2 2 0 1 1 4 0c0 .591 -.417 1.318 -.816 1.858l-3.184 4.143l4 0\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbSquare3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12a2 2 0 1 0 -2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 14a2 2 0 1 0 2 -2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbSquare4 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 16v-8l-4 6h5\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbSquare5 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 16h2a2 2 0 1 0 0 -4h-2v-4h4\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbSquare6 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"transform\":\"rotate(180 12 14)\",\"cx\":\"12\",\"cy\":\"14\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10a2 2 0 1 0 -4 0v4\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbSquare7 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 8h4l-2 8\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbSquare8 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"10\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"14\",\"r\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbSquare9 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"10\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 14a2 2 0 1 0 4 0v-4\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbSquareAsterisk (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8.5v7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 10l6 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 14l6 -4\"}}]})(props);\n};\nexport function TbSquareCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12l2 2l4 -4\"}}]})(props);\n};\nexport function TbSquareDot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}}]})(props);\n};\nexport function TbSquareForbid2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"15\",\"x2\":\"15\",\"y2\":\"9\"}}]})(props);\n};\nexport function TbSquareForbid (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"9\",\"x2\":\"15\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbSquareHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 4v16\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13l7.5 -7.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18l8 -8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 20l5 -5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8l4 -4\"}}]})(props);\n};\nexport function TbSquareMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"12\",\"x2\":\"15\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbSquareOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h10a2 2 0 0 1 2 2v10m-.584 3.412a1.994 1.994 0 0 1 -1.416 .588h-12a2 2 0 0 1 -2 -2v-12c0 -.552 .224 -1.052 .586 -1.414\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbSquarePlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"12\",\"x2\":\"15\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"9\",\"x2\":\"12\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbSquareRoot2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 12h1c1 0 1 1 2.016 3.527c.984 2.473 .984 3.473 1.984 3.473h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 19c1.5 0 3 -2 4 -3.5s2.5 -3.5 4 -3.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h1l3 8l3 -16h10\"}}]})(props);\n};\nexport function TbSquareRoot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h2l4 8l4 -16h8\"}}]})(props);\n};\nexport function TbSquareRotatedForbid2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 20.4l-6.9 -6.9c-.781 -.781 -.781 -2.219 0 -3l6.9 -6.9c.781 -.781 2.219 -.781 3 0l6.9 6.9c.781 .781 .781 2.219 0 3l-6.9 6.9c-.781 .781 -2.219 .781 -3 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 9.5l5 5\"}}]})(props);\n};\nexport function TbSquareRotatedForbid (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 20.4l-6.9 -6.9c-.781 -.781 -.781 -2.219 0 -3l6.9 -6.9c.781 -.781 2.219 -.781 3 0l6.9 6.9c.781 .781 .781 2.219 0 3l-6.9 6.9c-.781 .781 -2.219 .781 -3 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 14.5l5 -5\"}}]})(props);\n};\nexport function TbSquareRotatedOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.964 16.952l-3.462 3.461c-.782 .783 -2.222 .783 -3.004 0l-6.911 -6.91c-.783 -.783 -.783 -2.223 0 -3.005l3.455 -3.456m2.003 -2.003l1.453 -1.452c.782 -.783 2.222 -.783 3.004 0l6.911 6.91c.783 .783 .783 2.223 0 3.005l-1.448 1.45\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbSquareRotated (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 20.4l-6.9 -6.9c-.781 -.781 -.781 -2.219 0 -3l6.9 -6.9c.781 -.781 2.219 -.781 3 0l6.9 6.9c.781 .781 .781 2.219 0 3l-6.9 6.9c-.781 .781 -2.219 .781 -3 0z\"}}]})(props);\n};\nexport function TbSquareToggleHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 12h-20\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 14v-8a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 20a2 2 0 0 0 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18a2 2 0 0 0 2 2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"20\",\"x2\":\"10\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbSquareToggle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"2\",\"x2\":\"12\",\"y2\":\"22\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 20h-8a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 2 -2h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 6a2 2 0 0 0 -2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 20a2 2 0 0 0 2 -2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"10\",\"x2\":\"20\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbSquareX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10l4 4m0 -4l-4 4\"}}]})(props);\n};\nexport function TbSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbSquaresDiagonal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"8\",\"width\":\"12\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.586 19.414l10.827 -10.827\"}}]})(props);\n};\nexport function TbSquaresFilled (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"8\",\"y\":\"8\",\"width\":\"12\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 14.5l6.492 -6.492\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.496 20.004l6.504 -6.504l-6.504 6.504z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.586 19.414l10.827 -10.827\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2\"}}]})(props);\n};\nexport function TbStack2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"12 4 4 8 12 12 20 8 12 4\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"4 12 12 16 20 12\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"4 16 12 20 20 16\"}}]})(props);\n};\nexport function TbStack3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 2l-8 4l8 4l8 -4l-8 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 10l8 4l8 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18l8 4l8 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 14l8 4l8 -4\"}}]})(props);\n};\nexport function TbStack (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6l-8 4l8 4l8 -4l-8 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 14l8 4l8 -4\"}}]})(props);\n};\nexport function TbStairsDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20h4v-4h4v-4h4v-4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 4l-7 7v-4m4 4h-4\"}}]})(props);\n};\nexport function TbStairsUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20h4v-4h4v-4h4v-4h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 11l7 -7v4m-4 -4h4\"}}]})(props);\n};\nexport function TbStairs (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18h4v-4h4v-4h4v-4h4\"}}]})(props);\n};\nexport function TbStarHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17.75l-6.172 3.245l1.179 -6.873l-5 -4.867l6.9 -1l3.086 -6.253z\"}}]})(props);\n};\nexport function TbStarOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.012 6.016l1.981 -4.014l3.086 6.253l6.9 1l-4.421 4.304m.012 4.01l.588 3.426l-6.158 -3.245l-6.172 3.245l1.179 -6.873l-5 -4.867l6.327 -.917\"}}]})(props);\n};\nexport function TbStar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17.75l-6.172 3.245l1.179 -6.873l-5 -4.867l6.9 -1l3.086 -6.253l3.086 6.253l6.9 1l-5 4.867l1.179 6.873z\"}}]})(props);\n};\nexport function TbStars (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.8 19.817l-2.172 1.138a0.392 .392 0 0 1 -.568 -.41l.415 -2.411l-1.757 -1.707a0.389 .389 0 0 1 .217 -.665l2.428 -.352l1.086 -2.193a0.392 .392 0 0 1 .702 0l1.086 2.193l2.428 .352a0.39 .39 0 0 1 .217 .665l-1.757 1.707l.414 2.41a0.39 .39 0 0 1 -.567 .411l-2.172 -1.138z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.2 19.817l-2.172 1.138a0.392 .392 0 0 1 -.568 -.41l.415 -2.411l-1.757 -1.707a0.389 .389 0 0 1 .217 -.665l2.428 -.352l1.086 -2.193a0.392 .392 0 0 1 .702 0l1.086 2.193l2.428 .352a0.39 .39 0 0 1 .217 .665l-1.757 1.707l.414 2.41a0.39 .39 0 0 1 -.567 .411l-2.172 -1.138z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9.817l-2.172 1.138a0.392 .392 0 0 1 -.568 -.41l.415 -2.411l-1.757 -1.707a0.389 .389 0 0 1 .217 -.665l2.428 -.352l1.086 -2.193a0.392 .392 0 0 1 .702 0l1.086 2.193l2.428 .352a0.39 .39 0 0 1 .217 .665l-1.757 1.707l.414 2.41a0.39 .39 0 0 1 -.567 .411l-2.172 -1.138z\"}}]})(props);\n};\nexport function TbSteeringWheel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"14\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"12\",\"x2\":\"3.25\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"12\",\"x2\":\"20.75\",\"y2\":\"10\"}}]})(props);\n};\nexport function TbStepInto (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"11\",\"x2\":\"12\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"11\",\"x2\":\"12\",\"y2\":\"15\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"20\",\"r\":\"1\"}}]})(props);\n};\nexport function TbStepOut (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"7\",\"x2\":\"12\",\"y2\":\"3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"7\",\"x2\":\"12\",\"y2\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"20\",\"r\":\"1\"}}]})(props);\n};\nexport function TbStethoscope (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 4h-1a2 2 0 0 0 -2 2v3.5h0a5.5 5.5 0 0 0 11 0v-3.5a2 2 0 0 0 -2 -2h-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15a6 6 0 1 0 12 0v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 3v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 3v2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"20\",\"cy\":\"10\",\"r\":\"2\"}}]})(props);\n};\nexport function TbSticker (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12l-2 .5a6 6 0 0 1 -6.5 -6.5l.5 -2l8 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12a8 8 0 1 1 -8 -8\"}}]})(props);\n};\nexport function TbStrikethrough (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"19\",\"y2\":\"12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 6.5a4 2 0 0 0 -4 -1.5h-1a3.5 3.5 0 0 0 0 7h2a3.5 3.5 0 0 1 0 7h-1.5a4 2 0 0 1 -4 -1.5\"}}]})(props);\n};\nexport function TbSubmarine (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 11v6h2l1 -1.5l3 1.5h10a3 3 0 0 0 0 -6h-10h0l-3 1.5l-1 -1.5h-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 11l-1 -3h-5l-1 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 8v-2a1 1 0 0 1 1 -1h1\"}}]})(props);\n};\nexport function TbSubscript (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7l8 10m-8 0l8 -10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 20h-4l3.5 -4a1.73 1.73 0 0 0 -3.5 -2\"}}]})(props);\n};\nexport function TbSubtask (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"9\",\"x2\":\"12\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"5\",\"x2\":\"8\",\"y2\":\"5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 5v11a1 1 0 0 0 1 1h5\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"12\",\"y\":\"7\",\"width\":\"8\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"12\",\"y\":\"15\",\"width\":\"8\",\"height\":\"4\",\"rx\":\"1\"}}]})(props);\n};\nexport function TbSumOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 18a1 1 0 0 1 -1 1h-11l6 -7m-3 -7h8a1 1 0 0 1 1 1v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbSum (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 16v2a1 1 0 0 1 -1 1h-11l6 -7l-6 -7h11a1 1 0 0 1 1 1v2\"}}]})(props);\n};\nexport function TbSunOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12a4 4 0 0 0 -4 -4m-2.834 1.177a4 4 0 0 0 5.66 5.654\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h1m8 -9v1m8 8h1m-9 8v1m-6.4 -15.4l.7 .7m12.1 -.7l-.7 .7m0 11.4l.7 .7m-12.1 -.7l-.7 .7\"}}]})(props);\n};\nexport function TbSun (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h1m8 -9v1m8 8h1m-9 8v1m-6.4 -15.4l.7 .7m12.1 -.7l-.7 .7m0 11.4l.7 .7m-12.1 -.7l-.7 .7\"}}]})(props);\n};\nexport function TbSunrise (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17h1m16 0h1m-15.4 -6.4l.7 .7m12.1 -.7l-.7 .7m-9.7 5.7a4 4 0 0 1 8 0\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 9v-6l3 3m-6 0l3 -3\"}}]})(props);\n};\nexport function TbSunset (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17h1m16 0h1m-15.4 -6.4l.7 .7m12.1 -.7l-.7 .7m-9.7 5.7a4 4 0 0 1 8 0\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"21\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v6l3 -3m-6 0l3 3\"}}]})(props);\n};\nexport function TbSuperscript (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7l8 10m-8 0l8 -10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 11h-4l3.5 -4a1.73 1.73 0 0 0 -3.5 -2\"}}]})(props);\n};\nexport function TbSwimming (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16\",\"cy\":\"9\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 11l4 -2l3.5 3l-1.5 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 16.75a2.4 2.4 0 0 0 1 .25a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 2 -1a2.4 2.4 0 0 1 2 -1a2.4 2.4 0 0 1 2 1a2.4 2.4 0 0 0 2 1a2.4 2.4 0 0 0 1 -.25\"}}]})(props);\n};\nexport function TbSwitch2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17h5l1.67 -2.386m3.66 -5.227l1.67 -2.387h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 4l3 3l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7h5l7 10h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 20l3 -3l-3 -3\"}}]})(props);\n};\nexport function TbSwitch3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17h2.397a5 5 0 0 0 4.096 -2.133l.177 -.253m3.66 -5.227l.177 -.254a5 5 0 0 1 4.096 -2.133h3.397\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 4l3 3l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7h2.397a5 5 0 0 1 4.096 2.133l4.014 5.734a5 5 0 0 0 4.096 2.133h3.397\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 20l3 -3l-3 -3\"}}]})(props);\n};\nexport function TbSwitchHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 3 20 7 16 11\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"7\",\"x2\":\"20\",\"y2\":\"7\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"8 13 4 17 8 21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"17\",\"x2\":\"13\",\"y2\":\"17\"}}]})(props);\n};\nexport function TbSwitchVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"3 8 7 4 11 8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"4\",\"x2\":\"7\",\"y2\":\"13\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"13 16 17 20 21 16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"10\",\"x2\":\"17\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbSwitch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"15 4 19 4 19 8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14.75\",\"y1\":\"9.25\",\"x2\":\"19\",\"y2\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"19\",\"x2\":\"9\",\"y2\":\"15\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"15 19 19 19 19 15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"5\",\"x2\":\"19\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbSwordOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.934 7.942l3.066 -3.942h5v5l-3.93 3.057m-2.253 1.752l-2.817 2.191l-4 4l-3 -3l4 -4l2.174 -2.795\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 11.5l6 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbSword (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 4v5l-9 7l-4 4l-3 -3l4 -4l7 -9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 11.5l6 6\"}}]})(props);\n};\nexport function TbSwords (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 3v5l-11 9l-4 4l-3 -3l4 -4l9 -11z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 13l6 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.32 17.32l3.68 3.68l3 -3l-3.365 -3.365\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5.5l-2 -2.5h-5v5l3 2.5\"}}]})(props);\n};\nexport function TbTableExport (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.5 20h-5.5a2 2 0 0 1 -2 -2v-12a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v7.5m-16 -3.5h16m-10 -6v16m4 -1h7m-3 -3l3 3l-3 3\"}}]})(props);\n};\nexport function TbTableImport (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 13.5v-7.5a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v12a2 2 0 0 1 -2 2h-6m-8 -10h16m-10 -6v11.5m-8 3.5h7m-3 -3l3 3l-3 3\"}}]})(props);\n};\nexport function TbTableOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h10a2 2 0 0 1 2 2v10m-.588 3.417c-.362 .36 -.86 .583 -1.412 .583h-12a2 2 0 0 1 -2 -2v-12c0 -.552 .224 -1.053 .586 -1.414\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 10h6m4 0h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 4v2m0 4v10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbTable (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"10\",\"x2\":\"20\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"4\",\"x2\":\"10\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbTagOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.792 7.793a1 1 0 0 0 1.414 1.414\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.88 4.877a2.99 2.99 0 0 0 -.88 2.123v3.859c0 .537 .213 1.052 .593 1.432l8.116 8.116a2.025 2.025 0 0 0 2.864 0l2.416 -2.416m2.002 -2.002l.416 -.416a2.025 2.025 0 0 0 0 -2.864l-8.117 -8.116a2.025 2.025 0 0 0 -1.431 -.593h-2.859\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbTag (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8.5\",\"cy\":\"8.5\",\"r\":\"1\",\"fill\":\"currentColor\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 7v3.859c0 .537 .213 1.052 .593 1.432l8.116 8.116a2.025 2.025 0 0 0 2.864 0l4.834 -4.834a2.025 2.025 0 0 0 0 -2.864l-8.117 -8.116a2.025 2.025 0 0 0 -1.431 -.593h-3.859a3 3 0 0 0 -3 3z\"}}]})(props);\n};\nexport function TbTagsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6h-.975a2.025 2.025 0 0 0 -2.025 2.025v2.834c0 .537 .213 1.052 .593 1.432l6.116 6.116a2.025 2.025 0 0 0 2.864 0l2.834 -2.834c.028 -.028 .055 -.056 .08 -.085\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.573 18.407l.418 -.418m1.997 -1.997l.419 -.419a2.025 2.025 0 0 0 0 -2.864l-7.117 -7.116\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 9h-.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbTags (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.859 6h-2.834a2.025 2.025 0 0 0 -2.025 2.025v2.834c0 .537 .213 1.052 .593 1.432l6.116 6.116a2.025 2.025 0 0 0 2.864 0l2.834 -2.834a2.025 2.025 0 0 0 0 -2.864l-6.117 -6.116a2.025 2.025 0 0 0 -1.431 -.593z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.573 18.407l2.834 -2.834a2.025 2.025 0 0 0 0 -2.864l-7.117 -7.116\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 9h-.01\"}}]})(props);\n};\nexport function TbTallymark1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"5\",\"x2\":\"12\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbTallymark2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"5\",\"x2\":\"10\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"5\",\"x2\":\"14\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbTallymark3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"5\",\"x2\":\"8\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"5\",\"x2\":\"12\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"5\",\"x2\":\"16\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbTallymark4 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"5\",\"x2\":\"6\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"5\",\"x2\":\"10\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"5\",\"x2\":\"14\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"5\",\"x2\":\"18\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbTallymarks (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"5\",\"x2\":\"6\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"5\",\"x2\":\"10\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"5\",\"x2\":\"14\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"5\",\"x2\":\"18\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"17\",\"x2\":\"21\",\"y2\":\"7\"}}]})(props);\n};\nexport function TbTank (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"2\",\"y\":\"12\",\"width\":\"18\",\"height\":\"6\",\"rx\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12l1 -5h5l3 5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"9\",\"x2\":\"13.2\",\"y2\":\"9\"}}]})(props);\n};\nexport function TbTargetOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.286 11.3a1 1 0 0 0 1.41 1.419\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.44 8.49a5 5 0 0 0 7.098 7.044m1.377 -2.611a5 5 0 0 0 -5.846 -5.836\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.649 5.623a9 9 0 1 0 12.698 12.758m1.683 -2.313a9 9 0 0 0 -12.076 -12.11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbTarget (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}}]})(props);\n};\nexport function TbTelescopeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 21.002l6 -5l6 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13.002v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.238 8.264l-4.183 2.51c-1.02 .614 -1.357 1.898 -.76 2.906l.165 .28c.52 .88 1.624 1.266 2.605 .91l6.457 -2.34m2.907 -1.055l4.878 -1.77a1.023 1.023 0 0 0 .565 -1.455l-2.62 -4.705a1.087 1.087 0 0 0 -1.447 -.42l-.056 .032l-6.016 3.61\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 5.002l3 5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbTelescope (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 21l6 -5l6 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.294 13.678l.166 .281c.52 .88 1.624 1.265 2.605 .91l14.242 -5.165a1.023 1.023 0 0 0 .565 -1.456l-2.62 -4.705a1.087 1.087 0 0 0 -1.447 -.42l-.056 .032l-12.694 7.618c-1.02 .613 -1.357 1.897 -.76 2.905z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 5l3 5.5\"}}]})(props);\n};\nexport function TbTemperatureCelsius (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"8\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 9a3 3 0 0 0 -3 -3h-1a3 3 0 0 0 -3 3v6a3 3 0 0 0 3 3h1a3 3 0 0 0 3 -3\"}}]})(props);\n};\nexport function TbTemperatureFahrenheit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"8\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"12\",\"x2\":\"18\",\"y2\":\"12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 6h-6a1 1 0 0 0 -1 1v11\"}}]})(props);\n};\nexport function TbTemperatureMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13.5a4 4 0 1 0 4 0v-8.5a2 2 0 0 0 -4 0v8.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"9\",\"x2\":\"12\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"9\",\"x2\":\"22\",\"y2\":\"9\"}}]})(props);\n};\nexport function TbTemperatureOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10v3.5a4 4 0 1 0 5.836 2.33m-1.836 -5.83v-5a2 2 0 1 0 -4 0v1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 9h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbTemperaturePlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13.5a4 4 0 1 0 4 0v-8.5a2 2 0 0 0 -4 0v8.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"9\",\"x2\":\"12\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"9\",\"x2\":\"22\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"6\",\"x2\":\"19\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbTemperature (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 13.5a4 4 0 1 0 4 0v-8.5a2 2 0 0 0 -4 0v8.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"9\",\"x2\":\"14\",\"y2\":\"9\"}}]})(props);\n};\nexport function TbTemplateOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4h11a1 1 0 0 1 1 1v2a1 1 0 0 1 -1 1h-7m-4 0h-3a1 1 0 0 1 -1 -1v-2c0 -.271 .108 -.517 .283 -.697\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"12\",\"width\":\"6\",\"height\":\"8\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 16h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 20h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbTemplate (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"12\",\"width\":\"6\",\"height\":\"8\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"16\",\"x2\":\"20\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"20\",\"x2\":\"20\",\"y2\":\"20\"}}]})(props);\n};\nexport function TbTent (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 14l4 6h6l-9 -16l-9 16h6l4 -6\"}}]})(props);\n};\nexport function TbTerminal2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 9l3 3l-3 3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"15\",\"x2\":\"16\",\"y2\":\"15\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"4\",\"width\":\"18\",\"height\":\"16\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbTerminal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7l5 5l-5 5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"19\",\"x2\":\"19\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbTestPipe2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3v15a3 3 0 0 1 -6 0v-15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 12h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 3h8\"}}]})(props);\n};\nexport function TbTestPipeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 8.04a803.533 803.533 0 0 0 -4 3.96m-2 2c-1.085 1.085 -3.125 3.14 -6.122 6.164a2.857 2.857 0 0 1 -4.041 -4.04c3.018 -2.996 5.073 -5.037 6.163 -6.124m2 -2c.872 -.872 2.191 -2.205 3.959 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 13h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 15l1.5 1.6m-.74 3.173a2 2 0 0 1 -2.612 -2.608\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3l6 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbTestPipe (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 8.04l-12.122 12.124a2.857 2.857 0 1 1 -4.041 -4.04l12.122 -12.124\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 13h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 15l1.5 1.6a2 2 0 1 1 -3 0l1.5 -1.6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3l6 6\"}}]})(props);\n};\nexport function TbTextDirectionLtr (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 19h14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 21l2 -2l-2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h-6.5a3.5 3.5 0 0 0 0 7h.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 15v-11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 15v-11\"}}]})(props);\n};\nexport function TbTextDirectionRtl (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 4h-6.5a3.5 3.5 0 0 0 0 7h.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 15v-11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 15v-11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 19h14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 21l-2 -2l2 -2\"}}]})(props);\n};\nexport function TbTextResize (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 5h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 19h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 7v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14v-4\"}}]})(props);\n};\nexport function TbTextWrapDisabled (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"6\",\"x2\":\"14\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"18\",\"x2\":\"14\",\"y2\":\"18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h17l-3 -3m0 6l3 -3\"}}]})(props);\n};\nexport function TbTextWrap (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"6\",\"x2\":\"20\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"18\",\"x2\":\"9\",\"y2\":\"18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12h13a3 3 0 0 1 0 6h-4l2 -2m0 4l-2 -2\"}}]})(props);\n};\nexport function TbThermometer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 5a2.828 2.828 0 0 1 0 4l-8 8h-4v-4l8 -8a2.828 2.828 0 0 1 4 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 7l-1.5 -1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 10l-1.5 -1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 13l-1.5 -1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 17l-3 3\"}}]})(props);\n};\nexport function TbThumbDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 13v-8a1 1 0 0 0 -1 -1h-2a1 1 0 0 0 -1 1v7a1 1 0 0 0 1 1h3a4 4 0 0 1 4 4v1a2 2 0 0 0 4 0v-5h3a2 2 0 0 0 2 -2l-1 -5a2 3 0 0 0 -2 -2h-7a3 3 0 0 0 -3 3\"}}]})(props);\n};\nexport function TbThumbUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 11v8a1 1 0 0 1 -1 1h-2a1 1 0 0 1 -1 -1v-7a1 1 0 0 1 1 -1h3a4 4 0 0 0 4 -4v-1a2 2 0 0 1 4 0v5h3a2 2 0 0 1 2 2l-1 5a2 3 0 0 1 -2 2h-7a3 3 0 0 1 -3 -3\"}}]})(props);\n};\nexport function TbTicketOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 5v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 17v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h10a2 2 0 0 1 2 2v3a2 2 0 1 0 0 4v3m-2 2h-14a2 2 0 0 1 -2 -2v-3a2 2 0 1 0 0 -4v-3a2 2 0 0 1 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbTicket (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"5\",\"x2\":\"15\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"11\",\"x2\":\"15\",\"y2\":\"13\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"17\",\"x2\":\"15\",\"y2\":\"19\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 5h14a2 2 0 0 1 2 2v3a2 2 0 0 0 0 4v3a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-3a2 2 0 0 0 0 -4v-3a2 2 0 0 1 2 -2\"}}]})(props);\n};\nexport function TbTie (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 22l4 -4l-2.5 -11l.993 -2.649a1 1 0 0 0 -.936 -1.351h-3.114a1 1 0 0 0 -.936 1.351l.993 2.649l-2.5 11l4 4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 7h3l5 5.5\"}}]})(props);\n};\nexport function TbTiltShiftOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.56 3.69a9 9 0 0 0 -.577 .263\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.69 8.56a9 9 0 0 0 -.69 3.44\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.69 15.44a9 9 0 0 0 1.95 2.92\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.56 20.31a9 9 0 0 0 3.44 .69\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.44 20.31a9 9 0 0 0 2.92 -1.95\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.31 15.44a9 9 0 0 0 .69 -3.44\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.31 8.56a9 9 0 0 0 -1.95 -2.92\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.44 3.69a9 9 0 0 0 -3.44 -.69\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.57 10.602a2 2 0 0 0 2.862 2.795\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbTiltShift (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.56 3.69a9 9 0 0 0 -2.92 1.95\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.69 8.56a9 9 0 0 0 -.69 3.44\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.69 15.44a9 9 0 0 0 1.95 2.92\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.56 20.31a9 9 0 0 0 3.44 .69\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.44 20.31a9 9 0 0 0 2.92 -1.95\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.31 15.44a9 9 0 0 0 .69 -3.44\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.31 8.56a9 9 0 0 0 -1.95 -2.92\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.44 3.69a9 9 0 0 0 -3.44 -.69\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"2\"}}]})(props);\n};\nexport function TbTimeline (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16l6 -7l5 5l5 -6\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"14\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"10\",\"cy\":\"9\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"4\",\"cy\":\"16\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"20\",\"cy\":\"8\",\"r\":\"1\"}}]})(props);\n};\nexport function TbTir (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 18h8m4 0h2v-6a5 7 0 0 0 -5 -7h-1l1.5 7h4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 18v-13h3\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"3 17 3 12 12 12\"}}]})(props);\n};\nexport function TbToggleLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"12\",\"r\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"2\",\"y\":\"6\",\"width\":\"20\",\"height\":\"12\",\"rx\":\"6\"}}]})(props);\n};\nexport function TbToggleRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16\",\"cy\":\"12\",\"r\":\"2\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"2\",\"y\":\"6\",\"width\":\"20\",\"height\":\"12\",\"rx\":\"6\"}}]})(props);\n};\nexport function TbToiletPaperOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.27 4.28c-.768 1.27 -1.27 3.359 -1.27 5.72c0 3.866 1.343 7 3 7s3 -3.134 3 -7c0 -.34 -.01 -.672 -.03 -.999\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 10c0 -3.866 -1.343 -7 -3 -7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 3h11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 10v7m-1.513 2.496l-1.487 -.496l-3 2l-3 -3l-3 2v-10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10h.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbToiletPaper (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"ellipse\",\"attr\":{\"cx\":\"6\",\"cy\":\"10\",\"rx\":\"3\",\"ry\":\"7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 10c0 -3.866 -1.343 -7 -3 -7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 3h12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 10v10l-3 -1l-3 2l-3 -3l-3 2v-10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10h.01\"}}]})(props);\n};\nexport function TbTool (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 10h3v-3l-3.5 -3.5a6 6 0 0 1 8 8l6 6a2 2 0 0 1 -3 3l-6 -6a6 6 0 0 1 -8 -8l3.5 3.5\"}}]})(props);\n};\nexport function TbToolsKitchen2Off (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.386 10.409c.53 -2.28 1.766 -4.692 4.614 -7.409v12m-4 0h-1c-.002 -.313 -.002 -.627 .002 -.941\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 19v2h-1v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8v13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 5v2a3 3 0 0 0 4.546 2.572m1.454 -2.572v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbToolsKitchen2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 3v12h-5c-.023 -3.681 .184 -7.406 5 -12zm0 12v6h-1v-3m-10 -14v17m-3 -17v3a3 3 0 1 0 6 0v-3\"}}]})(props);\n};\nexport function TbToolsKitchenOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 3h5l-.5 4.5m-.4 3.595l-.1 .905h-6l-.875 -7.874\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 18h2v3h-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.225 11.216c.42 -2.518 1.589 -5.177 4.775 -8.216v12h-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 15v1m0 4v1h-1v-2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbToolsKitchen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 3h8l-1 9h-6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 18h2v3h-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 3v12h-5c-.023 -3.681 .184 -7.406 5 -12z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 15v6h-1v-3\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"12\",\"x2\":\"8\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbToolsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12l4 -4a2.828 2.828 0 1 0 -4 -4l-4 4m-2 2l-7 7v4h4l7 -7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.5 5.5l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8l-5 -5m-2.004 2.004l-1.996 1.996l5 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 8l-1.5 1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12l5 5m-2 2l-2 2l-5 -5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 17l-1.5 1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbTools (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21h4l13 -13a1.5 1.5 0 0 0 -4 -4l-13 13v4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14.5\",\"y1\":\"5.5\",\"x2\":\"18.5\",\"y2\":\"9.5\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"12 8 7 3 3 7 8 12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"8\",\"x2\":\"5.5\",\"y2\":\"9.5\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"16 12 21 17 17 21 12 16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"17\",\"x2\":\"14.5\",\"y2\":\"18.5\"}}]})(props);\n};\nexport function TbTornado (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"4\",\"x2\":\"3\",\"y2\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"16\",\"x2\":\"7\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"11\",\"y1\":\"20\",\"x2\":\"15\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"8\",\"x2\":\"20\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"12\",\"x2\":\"16\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbTournament (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h4a1 1 0 0 1 1 1v4a1 1 0 0 1 -1 1h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 14h4a1 1 0 0 1 1 1v4a1 1 0 0 1 -1 1h-4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 7h4a1 1 0 0 1 1 1v8a1 1 0 0 1 -1 1h-4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"12\",\"x2\":\"20\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbTrack (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 15l11 -11m5 5l-11 11m-4 -8l7 7m-3.5 -10.5l7 7m-3.5 -10.5l7 7\"}}]})(props);\n};\nexport function TbTractor (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"15\",\"r\":\"4\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"15\",\"x2\":\"7\",\"y2\":\"15.01\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10.5\",\"y1\":\"17\",\"x2\":\"17\",\"y2\":\"17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 15.2v-4.2a1 1 0 0 0 -1 -1h-6l-2 -5h-6v6.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 5h-1a1 1 0 0 0 -1 1v4\"}}]})(props);\n};\nexport function TbTrademark (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 9h5m-2.5 0v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 15v-6l3 4l3 -4v6\"}}]})(props);\n};\nexport function TbTrafficConeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20h16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.4 10h.6m4 0h.6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.8 15h7.2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 20l3.5 -10.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 6.5l.5 -1.5h2l2 6m2 6l1 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbTrafficCone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"20\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9.4\",\"y1\":\"10\",\"x2\":\"14.6\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7.8\",\"y1\":\"15\",\"x2\":\"16.2\",\"y2\":\"15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 20l5 -15h2l5 15\"}}]})(props);\n};\nexport function TbTrafficLightsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4c.912 -1.219 2.36 -2 4 -2a5 5 0 0 1 5 5v6m0 4a5 5 0 0 1 -10 0v-10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8a1 1 0 1 0 -1 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.291 11.295a1 1 0 0 0 1.418 1.41\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"17\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbTrafficLights (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"7\",\"y\":\"2\",\"width\":\"10\",\"height\":\"20\",\"rx\":\"5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"7\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"17\",\"r\":\"1\"}}]})(props);\n};\nexport function TbTrain (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 13c0 -3.87 -3.37 -7 -10 -7h-8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 15h16a2 2 0 0 0 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6v5h17.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"10\",\"x2\":\"3\",\"y2\":\"14\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"11\",\"x2\":\"8\",\"y2\":\"6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"11\",\"x2\":\"13\",\"y2\":\"6.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"19\",\"x2\":\"21\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbTransferIn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 18v3h16v-14l-8 -4l-8 4v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 14h9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 11l3 3l-3 3\"}}]})(props);\n};\nexport function TbTransferOut (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 19v2h16v-14l-8 -4l-8 4v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 14h-9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 11l-3 3l3 3\"}}]})(props);\n};\nexport function TbTrashOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 7h3m4 0h9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"11\",\"x2\":\"10\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"14\",\"x2\":\"14\",\"y2\":\"17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7l1 12a2 2 0 0 0 2 2h8a2 2 0 0 0 2 -2l.077 -.923\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18.384\",\"y1\":\"14.373\",\"x2\":\"19\",\"y2\":\"7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5v-1a1 1 0 0 1 1 -1h4a1 1 0 0 1 1 1v3\"}}]})(props);\n};\nexport function TbTrashX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 7h16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7l1 12a2 2 0 0 0 2 2h8a2 2 0 0 0 2 -2l1 -12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 7v-3a1 1 0 0 1 1 -1h4a1 1 0 0 1 1 1v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12l4 4m0 -4l-4 4\"}}]})(props);\n};\nexport function TbTrash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"7\",\"x2\":\"20\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"11\",\"x2\":\"10\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"11\",\"x2\":\"14\",\"y2\":\"17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7l1 12a2 2 0 0 0 2 2h8a2 2 0 0 0 2 -2l1 -12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 7v-3a1 1 0 0 1 1 -1h4a1 1 0 0 1 1 1v3\"}}]})(props);\n};\nexport function TbTree (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13l-2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12l2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.824 15.995a3 3 0 0 1 -2.743 -3.69a2.998 2.998 0 0 1 .304 -4.833a3 3 0 0 1 4.615 -3.707a3 3 0 0 1 4.614 3.707a2.997 2.997 0 0 1 .305 4.833a3 3 0 0 1 -2.919 3.695h-4z\"}}]})(props);\n};\nexport function TbTrees (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 5l3 3l-2 1l4 4l-3 1l4 4h-9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"21\",\"x2\":\"15\",\"y2\":\"18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13l-2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12l2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 21v-13\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.824 15.995a3 3 0 0 1 -2.743 -3.69a2.998 2.998 0 0 1 .304 -4.833a3 3 0 0 1 4.615 -3.707a3 3 0 0 1 4.614 3.707a2.997 2.997 0 0 1 .305 4.833a3 3 0 0 1 -2.919 3.695h-4z\"}}]})(props);\n};\nexport function TbTrendingDown2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6h5l7 10h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 19l3 -3l-3 -3\"}}]})(props);\n};\nexport function TbTrendingDown3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6h2.397a5 5 0 0 1 4.096 2.133l4.014 5.734a5 5 0 0 0 4.096 2.133h3.397\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 19l3 -3l-3 -3\"}}]})(props);\n};\nexport function TbTrendingDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"3 7 9 13 13 9 21 17\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"21 10 21 17 14 17\"}}]})(props);\n};\nexport function TbTrendingUp2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 5l3 3l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 18h5l7 -10h6\"}}]})(props);\n};\nexport function TbTrendingUp3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 5l3 3l-3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 18h2.397a5 5 0 0 0 4.096 -2.133l4.014 -5.734a5 5 0 0 1 4.096 -2.133h3.397\"}}]})(props);\n};\nexport function TbTrendingUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"3 17 9 11 13 15 21 7\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"14 7 21 7 21 14\"}}]})(props);\n};\nexport function TbTriangleInverted (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4h14a2 2 0 0 1 1.84 2.75l-7.1 12.25a2 2 0 0 1 -3.5 0l-7.1 -12.25a2 2 0 0 1 1.75 -2.75\"}}]})(props);\n};\nexport function TbTriangleOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 19h14m1.986 -2.014a2 2 0 0 0 -.146 -.736l-7.1 -12.25a2 2 0 0 0 -3.5 0l-.825 1.424m-1.467 2.53l-4.808 8.296a2 2 0 0 0 1.75 2.75\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbTriangleSquareCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3l-4 7h8z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"17\",\"r\":\"3\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"14\",\"width\":\"6\",\"height\":\"6\",\"rx\":\"1\"}}]})(props);\n};\nexport function TbTriangle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 19h14a2 2 0 0 0 1.84 -2.75l-7.1 -12.25a2 2 0 0 0 -3.5 0l-7.1 12.25a2 2 0 0 0 1.75 2.75\"}}]})(props);\n};\nexport function TbTriangles (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.974 21h8.052a0.975 .975 0 0 0 .81 -1.517l-4.025 -6.048a0.973 .973 0 0 0 -1.622 0l-4.025 6.048a0.977 .977 0 0 0 .81 1.517z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.98 16h14.04c.542 0 .98 -.443 .98 -.989a0.995 .995 0 0 0 -.156 -.534l-7.02 -11.023a0.974 .974 0 0 0 -1.648 0l-7.02 11.023a0.994 .994 0 0 0 .294 1.366a0.973 .973 0 0 0 .53 .157z\"}}]})(props);\n};\nexport function TbTrident (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6l2 -2v3a7 7 0 0 0 14 0v-3l2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-18l-2 2m4 0l-2 -2\"}}]})(props);\n};\nexport function TbTrophy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"21\",\"x2\":\"16\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"17\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"4\",\"x2\":\"17\",\"y2\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 4v8a5 5 0 0 1 -10 0v-8\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"5\",\"cy\":\"9\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"9\",\"r\":\"2\"}}]})(props);\n};\nexport function TbTruckDelivery (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 17h-2v-4m-1 -8h11v12m-4 0h6m4 0h2v-6h-8m0 -5h5l3 5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"9\",\"x2\":\"7\",\"y2\":\"9\"}}]})(props);\n};\nexport function TbTruckLoading (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 3h1a2 2 0 0 1 2 2v10a2 2 0 0 0 2 2h15\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"6\",\"width\":\"10\",\"height\":\"8\",\"rx\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"19\",\"r\":\"2\"}}]})(props);\n};\nexport function TbTruckOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.585 15.586a2 2 0 0 0 2.826 2.831\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 17h-2v-11a1 1 0 0 1 1 -1h1m3.96 0h4.04v4m0 4v4m-4 0h6m6 0v-6h-6m-2 -5h5l3 5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbTruckReturn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 17h-2v-11a1 1 0 0 1 1 -1h9v6h-5l2 2m0 -4l-2 2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"17\",\"x2\":\"15\",\"y2\":\"17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 6h5l3 5v6h-2\"}}]})(props);\n};\nexport function TbTruck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 17h-2v-11a1 1 0 0 1 1 -1h9v12m-4 0h6m4 0h2v-6h-8m0 -5h5l3 5\"}}]})(props);\n};\nexport function TbTypographyOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20h3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 20h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.9 15h6.9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 13l3 7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 20l4.09 -10.906\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.181 6.183l.819 -2.183h2l3.904 8.924\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbTypography (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"7\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"14\",\"y1\":\"20\",\"x2\":\"21\",\"y2\":\"20\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6.9\",\"y1\":\"15\",\"x2\":\"13.8\",\"y2\":\"15\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10.2\",\"y1\":\"6.3\",\"x2\":\"16\",\"y2\":\"20\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"5 20 11 4 13 4 20 20\"}}]})(props);\n};\nexport function TbUmbrellaOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12h-8c0 -2.209 .895 -4.208 2.342 -5.656m2.382 -1.645a8 8 0 0 1 11.276 7.301l-4 .001\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v6a2 2 0 1 0 4 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbUmbrella (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 12a8 8 0 0 1 16 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v6a2 2 0 0 0 4 0\"}}]})(props);\n};\nexport function TbUnderline (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 5v5a5 5 0 0 0 10 0v-5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 19h14\"}}]})(props);\n};\nexport function TbUnlink (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 14a3.5 3.5 0 0 0 5 0l4 -4a3.5 3.5 0 0 0 -5 -5l-.5 .5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10a3.5 3.5 0 0 0 -5 0l-4 4a3.5 3.5 0 0 0 5 5l.5 -.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"21\",\"x2\":\"16\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"16\",\"x2\":\"21\",\"y2\":\"16\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"8\",\"x2\":\"5\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"3\",\"x2\":\"8\",\"y2\":\"5\"}}]})(props);\n};\nexport function TbUpload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 17v2a2 2 0 0 0 2 2h12a2 2 0 0 0 2 -2v-2\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"7 9 12 4 17 9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"4\",\"x2\":\"12\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbUrgent (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16v-4a4 4 0 0 1 8 0v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h1m8 -9v1m8 8h1m-15.4 -6.4l.7 .7m12.1 -.7l-.7 .7\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"6\",\"y\":\"16\",\"width\":\"12\",\"height\":\"4\",\"rx\":\"1\"}}]})(props);\n};\nexport function TbUsb (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 17v-11.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 10v3l5 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 14.5l5 -2v-2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 10h2v-2h-2z\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"7\",\"cy\":\"9\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5.5h4l-2 -2.5z\"}}]})(props);\n};\nexport function TbUserCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"7\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 11l2 2l4 -4\"}}]})(props);\n};\nexport function TbUserCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"10\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.168 18.849a4 4 0 0 1 3.832 -2.849h4a4 4 0 0 1 3.834 2.855\"}}]})(props);\n};\nexport function TbUserExclamation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"7\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"7\",\"x2\":\"19\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"14\",\"x2\":\"19\",\"y2\":\"14.01\"}}]})(props);\n};\nexport function TbUserMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"7\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"16\",\"y1\":\"11\",\"x2\":\"22\",\"y2\":\"11\"}}]})(props);\n};\nexport function TbUserOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.274 10.291a4 4 0 1 0 -5.554 -5.58m-.548 3.453a4.01 4.01 0 0 0 2.62 2.65\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 1.147 .167m2.685 2.681a4 4 0 0 1 .168 1.152v2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbUserPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"7\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 11h6m-3 -3v6\"}}]})(props);\n};\nexport function TbUserSearch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"7\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 21v-2a4 4 0 0 1 4 -4h1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16.5\",\"cy\":\"17.5\",\"r\":\"2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.5 19.5l2.5 2.5\"}}]})(props);\n};\nexport function TbUserX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"7\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 9l4 4m0 -4l-4 4\"}}]})(props);\n};\nexport function TbUser (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"7\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2\"}}]})(props);\n};\nexport function TbUsers (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"7\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 3.13a4 4 0 0 1 0 7.75\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 21v-2a4 4 0 0 0 -3 -3.85\"}}]})(props);\n};\nexport function TbVaccineBottle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"9\",\"y\":\"3\",\"width\":\"6\",\"height\":\"3\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6v.98c0 .877 -.634 1.626 -1.5 1.77c-.866 .144 -1.5 .893 -1.5 1.77v8.48a2 2 0 0 0 2 2h6a2 2 0 0 0 2 -2v-8.48c0 -.877 -.634 -1.626 -1.5 -1.77a1.795 1.795 0 0 1 -1.5 -1.77v-.98\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 12h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 18h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 15h2\"}}]})(props);\n};\nexport function TbVaccineOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 3l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 5l-4.5 4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.5 6.5l6 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.5 11.5l-.5 .5m-2 2l-4 4h-4v-4l4 -4m2 -2l.5 -.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 12.5l1.5 1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbVaccine (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 3l4 4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 5l-4.5 4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.5 6.5l6 6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.5 11.5l-6.5 6.5h-4v-4l6.5 -6.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 12.5l1.5 1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 9.5l1.5 1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21l3 -3\"}}]})(props);\n};\nexport function TbVariableOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.675 4.68c-2.17 4.776 -2.062 9.592 .325 15.32\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 4c1.959 3.917 2.383 7.834 1.272 12.232m-.983 3.051c-.093 .238 -.189 .477 -.289 .717\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.696 11.696c.095 .257 .2 .533 .32 .831c.984 2.473 .984 3.473 1.984 3.473h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16c1.5 0 3 -2 4 -3.5m2.022 -2.514c.629 -.582 1.304 -.986 1.978 -.986\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbVariable (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4c-2.5 5 -2.5 10 0 16m14 -16c2.5 5 2.5 10 0 16m-10 -11h1c1 0 1 1 2.016 3.527c.984 2.473 .984 3.473 1.984 3.473h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16c1.5 0 3 -2 4 -3.5s2.5 -3.5 4 -3.5\"}}]})(props);\n};\nexport function TbVectorBezier2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"3\",\"width\":\"4\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"17\",\"y\":\"17\",\"width\":\"4\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"5\",\"x2\":\"14\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"19\",\"x2\":\"17\",\"y2\":\"19\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"9\",\"cy\":\"19\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"5\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 5.5a5 6.5 0 0 1 5 6.5a5 6.5 0 0 0 5 6.5\"}}]})(props);\n};\nexport function TbVectorBezier (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"14\",\"width\":\"4\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"17\",\"y\":\"14\",\"width\":\"4\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"10\",\"y\":\"6\",\"width\":\"4\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 8.5a6 6 0 0 0 -5 5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 8.5a6 6 0 0 1 5 5.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"8\",\"x2\":\"4\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"20\",\"y1\":\"8\",\"x2\":\"14\",\"y2\":\"8\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"3\",\"cy\":\"8\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"21\",\"cy\":\"8\",\"r\":\"1\"}}]})(props);\n};\nexport function TbVectorOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.68 6.733a0.996 .996 0 0 1 -.68 .267h-2a1 1 0 0 1 -1 -1v-2c0 -.276 .112 -.527 .293 -.708\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"17\",\"y\":\"3\",\"width\":\"4\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.72 20.693a0.997 .997 0 0 1 -.72 .307h-2a1 1 0 0 1 -1 -1v-2c0 -.282 .116 -.536 .304 -.718\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"17\",\"width\":\"4\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 7v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5h8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 19h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbVectorTriangleOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6v-1a1 1 0 0 1 1 -1h2a1 1 0 0 1 1 1v2a1 1 0 0 1 -1 1h-1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"17\",\"width\":\"4\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20.705 20.709a0.997 .997 0 0 1 -.705 .291h-2a1 1 0 0 1 -1 -1v-2c0 -.28 .115 -.532 .3 -.714\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 17.1l3.749 -6.823\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.158 9.197l-.658 -1.197\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 19h10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbVectorTriangle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"10\",\"y\":\"4\",\"width\":\"4\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"17\",\"width\":\"4\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"17\",\"y\":\"17\",\"width\":\"4\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6.5\",\"y1\":\"17.1\",\"x2\":\"11.5\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17.5\",\"y1\":\"17.1\",\"x2\":\"12.5\",\"y2\":\"8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"19\",\"x2\":\"17\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbVector (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"3\",\"width\":\"4\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"17\",\"y\":\"3\",\"width\":\"4\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"17\",\"y\":\"17\",\"width\":\"4\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"17\",\"width\":\"4\",\"height\":\"4\",\"rx\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"7\",\"x2\":\"5\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19\",\"y1\":\"7\",\"x2\":\"19\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"5\",\"x2\":\"17\",\"y2\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"19\",\"x2\":\"17\",\"y2\":\"19\"}}]})(props);\n};\nexport function TbVenus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"9\",\"r\":\"5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"14\",\"x2\":\"12\",\"y2\":\"21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"18\",\"x2\":\"15\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbVersionsOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.184 6.162a2 2 0 0 1 1.816 -1.162h6a2 2 0 0 1 2 2v9m-1.185 2.827a1.993 1.993 0 0 1 -.815 .173h-6a2 2 0 0 1 -2 -2v-7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7v10\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8v8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbVersions (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"10\",\"y\":\"5\",\"width\":\"10\",\"height\":\"14\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"7\",\"x2\":\"7\",\"y2\":\"17\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"8\",\"x2\":\"4\",\"y2\":\"16\"}}]})(props);\n};\nexport function TbVideoMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 10l4.553 -2.276a1 1 0 0 1 1.447 .894v6.764a1 1 0 0 1 -1.447 .894l-4.553 -2.276v-4z\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"6\",\"width\":\"12\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"12\",\"x2\":\"11\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbVideoOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 11v-1l4.553 -2.276a1 1 0 0 1 1.447 .894v6.764a1 1 0 0 1 -.675 .946\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6h3a2 2 0 0 1 2 2v3m0 4v1a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2v-8a2 2 0 0 1 2 -2h1\"}}]})(props);\n};\nexport function TbVideoPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 10l4.553 -2.276a1 1 0 0 1 1.447 .894v6.764a1 1 0 0 1 -1.447 .894l-4.553 -2.276v-4z\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"6\",\"width\":\"12\",\"height\":\"12\",\"rx\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"12\",\"x2\":\"11\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"9\",\"y1\":\"10\",\"x2\":\"9\",\"y2\":\"14\"}}]})(props);\n};\nexport function TbVideo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 10l4.553 -2.276a1 1 0 0 1 1.447 .894v6.764a1 1 0 0 1 -1.447 .894l-4.553 -2.276v-4z\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"3\",\"y\":\"6\",\"width\":\"12\",\"height\":\"12\",\"rx\":\"2\"}}]})(props);\n};\nexport function TbView360Off (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.335 8.388a18.998 18.998 0 0 0 -.335 3.612c0 4.97 1.79 9 4 9c1.622 0 3.018 -2.172 3.646 -5.294m.354 -3.706c0 -4.97 -1.79 -9 -4 -9c-1.035 0 -1.979 .885 -2.689 2.337\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.65 5.623a9 9 0 1 0 12.71 12.745m1.684 -2.328a9 9 0 0 0 -12.094 -12.08\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.32 8.349c-3.136 .625 -5.32 2.025 -5.32 3.651c0 2.21 4.03 4 9 4c1.286 0 2.51 -.12 3.616 -.336m3.059 -.98c1.445 -.711 2.325 -1.653 2.325 -2.684c0 -2.21 -4.03 -4 -9 -4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbView360 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"ellipse\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"rx\":\"4\",\"ry\":\"9\"}},{\"tag\":\"ellipse\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"rx\":\"4\",\"ry\":\"9\",\"transform\":\"rotate(90 12 12)\"}}]})(props);\n};\nexport function TbViewfinderOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.65 5.623a9 9 0 1 0 12.71 12.745m1.684 -2.328a9 9 0 0 0 -12.094 -12.08\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21v-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 12h-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbViewfinder (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"21\",\"x2\":\"12\",\"y2\":\"18\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"12\",\"x2\":\"7\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"12\",\"x2\":\"18\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"12\",\"x2\":\"12\",\"y2\":\"12.01\"}}]})(props);\n};\nexport function TbViewportNarrow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h7l-3 -3m0 6l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 12h-7l3 -3m0 6l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 6v-3h6v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 18v3h6v-3\"}}]})(props);\n};\nexport function TbViewportWide (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12h-7l3 -3m0 6l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 12h7l-3 -3m0 6l3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6v-3h18v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 18v3h18v-3\"}}]})(props);\n};\nexport function TbVinyl (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16.004 3.937a9 9 0 1 0 4.996 8.063\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"1\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"20\",\"cy\":\"4\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 4l-3.5 10l-2.5 2\"}}]})(props);\n};\nexport function TbVirusOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.469 8.46a5 5 0 0 0 7.058 7.084m1.386 -2.608a5 5 0 0 0 -5.826 -5.853\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(45 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(90 12 12)\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"13\",\"y2\":\"3\",\"transform\":\"rotate(135 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(180 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(225 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(270 12 12)\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"11\",\"y2\":\"3\",\"transform\":\"rotate(315 12 12)\"}}]})(props);\n};\nexport function TbVirusSearch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 12a5 5 0 1 0 -5 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(45 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(90 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(180 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(225 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(270 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(315 12 12)\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"17.5\",\"cy\":\"17.5\",\"r\":\"2.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"19.5\",\"y1\":\"19.5\",\"x2\":\"22\",\"y2\":\"22\"}}]})(props);\n};\nexport function TbVirus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(45 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(90 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(135 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(180 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(225 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(270 12 12)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7v-4m-1 0h2\",\"transform\":\"rotate(315 12 12)\"}}]})(props);\n};\nexport function TbVocabulary (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 19h-6a1 1 0 0 1 -1 -1v-14a1 1 0 0 1 1 -1h6a2 2 0 0 1 2 2a2 2 0 0 1 2 -2h6a1 1 0 0 1 1 1v14a1 1 0 0 1 -1 1h-6a2 2 0 0 0 -2 2a2 2 0 0 0 -2 -2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5v16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 11h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 7h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 11h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 15h1\"}}]})(props);\n};\nexport function TbVolume2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 8a5 5 0 0 1 0 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15h-2a1 1 0 0 1 -1 -1v-4a1 1 0 0 1 1 -1h2l3.5 -4.5a0.8 .8 0 0 1 1.5 .5v14a0.8 .8 0 0 1 -1.5 .5l-3.5 -4.5\"}}]})(props);\n};\nexport function TbVolume3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15h-2a1 1 0 0 1 -1 -1v-4a1 1 0 0 1 1 -1h2l3.5 -4.5a0.8 .8 0 0 1 1.5 .5v14a0.8 .8 0 0 1 -1.5 .5l-3.5 -4.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 10l4 4m0 -4l-4 4\"}}]})(props);\n};\nexport function TbVolumeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 8a5 5 0 0 1 1.912 4.934m-1.377 2.602a5.001 5.001 0 0 1 -.535 .464\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.7 5a9 9 0 0 1 2.362 11.086m-1.676 2.299a9.005 9.005 0 0 1 -.686 .615\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.069 5.054l.431 -.554a0.8 .8 0 0 1 1.5 .5v2m0 4v8a0.8 .8 0 0 1 -1.5 .5l-3.5 -4.5h-2a1 1 0 0 1 -1 -1v-4a1 1 0 0 1 1 -1h2l1.294 -1.664\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbVolume (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 8a5 5 0 0 1 0 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17.7 5a9 9 0 0 1 0 14\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15h-2a1 1 0 0 1 -1 -1v-4a1 1 0 0 1 1 -1h2l3.5 -4.5a0.8 .8 0 0 1 1.5 .5v14a0.8 .8 0 0 1 -1.5 .5l-3.5 -4.5\"}}]})(props);\n};\nexport function TbWalk (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"13\",\"cy\":\"4\",\"r\":\"1\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"21\",\"x2\":\"10\",\"y2\":\"17\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 21l-2 -4l-3 -3l1 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12l2 -3l4 -1l3 3l3 1\"}}]})(props);\n};\nexport function TbWall (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"rect\",\"attr\":{\"x\":\"4\",\"y\":\"4\",\"width\":\"16\",\"height\":\"16\",\"rx\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8h16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12h-16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16h16\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 8v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 16v4\"}}]})(props);\n};\nexport function TbWalletOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 8v-3a1 1 0 0 0 -1 -1h-8m-3.413 .584a2 2 0 0 0 1.413 3.416h2m4 0h6a1 1 0 0 1 1 1v3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 19a1 1 0 0 1 -1 1h-12a2 2 0 0 1 -2 -2v-12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12h4v4m-4 0a2 2 0 0 1 -2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbWallet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 8v-3a1 1 0 0 0 -1 -1h-10a2 2 0 0 0 0 4h12a1 1 0 0 1 1 1v3m0 4v3a1 1 0 0 1 -1 1h-12a2 2 0 0 1 -2 -2v-12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 12v4h-4a2 2 0 0 1 0 -4h4\"}}]})(props);\n};\nexport function TbWallpaperOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 6h8a2 2 0 0 1 2 2v8m-.58 3.409a1.994 1.994 0 0 1 -1.42 .591h-12\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 18v-10m-3.427 -3.402c-.353 .362 -.573 .856 -.573 1.402v12\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbWallpaper (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 6h10a2 2 0 0 1 2 2v10a2 2 0 0 1 -2 2h-12\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"18\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 18v-12a2 2 0 1 0 -4 0v12\"}}]})(props);\n};\nexport function TbWandOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 10.5l-7.5 7.5l3 3l7.5 -7.5m2 -2l5.5 -5.5l-3 -3l-5.5 5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 6l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.433 4.395c.35 -.36 .567 -.852 .567 -1.395a2 2 0 0 0 2 2c-.554 0 -1.055 .225 -1.417 .589\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18.418 14.41c.36 -.36 .582 -.86 .582 -1.41a2 2 0 0 0 2 2c-.555 0 -1.056 .226 -1.419 .59\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbWand (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"polyline\",\"attr\":{\"points\":\"6 21 21 6 18 3 3 18 6 21\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"15\",\"y1\":\"6\",\"x2\":\"18\",\"y2\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 3a2 2 0 0 0 2 2a2 2 0 0 0 -2 2a2 2 0 0 0 -2 -2a2 2 0 0 0 2 -2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 13a2 2 0 0 0 2 2a2 2 0 0 0 -2 2a2 2 0 0 0 -2 -2a2 2 0 0 0 2 -2\"}}]})(props);\n};\nexport function TbWaveSawTool (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h5l4 8v-16l4 8h5\"}}]})(props);\n};\nexport function TbWaveSine (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 12h-2c-.894 0 -1.662 -.857 -1.761 -2c-.296 -3.45 -.749 -6 -2.749 -6s-2.5 3.582 -2.5 8s-.5 8 -2.5 8s-2.452 -2.547 -2.749 -6c-.1 -1.147 -.867 -2 -1.763 -2h-2\"}}]})(props);\n};\nexport function TbWaveSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h5v8h4v-16h4v8h5\"}}]})(props);\n};\nexport function TbWebhook (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.876 13.61a4 4 0 1 0 6.124 3.39h6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.066 20.502a4 4 0 1 0 1.934 -7.502c-.706 0 -1.424 .179 -2 .5l-3 -5.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8a4 4 0 1 0 -8 0c0 1.506 .77 2.818 2 3.5l-3 5.5\"}}]})(props);\n};\nexport function TbWheelchair (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"16\",\"r\":\"5\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"19\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 17a3 3 0 0 0 -3 -3h-3.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3h1a2 2 0 0 1 2 2v6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8h11\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 8v6\"}}]})(props);\n};\nexport function TbWifi0 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"18\",\"x2\":\"12.01\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbWifi1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"18\",\"x2\":\"12.01\",\"y2\":\"18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.172 15.172a4 4 0 0 1 5.656 0\"}}]})(props);\n};\nexport function TbWifi2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"18\",\"x2\":\"12.01\",\"y2\":\"18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.172 15.172a4 4 0 0 1 5.656 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.343 12.343a8 8 0 0 1 11.314 0\"}}]})(props);\n};\nexport function TbWifiOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"18\",\"x2\":\"12.01\",\"y2\":\"18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.172 15.172a4 4 0 0 1 5.656 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.343 12.343a7.963 7.963 0 0 1 3.864 -2.14m4.163 .155a7.965 7.965 0 0 1 3.287 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.515 9.515a12 12 0 0 1 3.544 -2.455m3.101 -.92a12 12 0 0 1 10.325 3.374\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"3\",\"x2\":\"21\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbWifi (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"18\",\"x2\":\"12.01\",\"y2\":\"18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.172 15.172a4 4 0 0 1 5.656 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.343 12.343a8 8 0 0 1 11.314 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.515 9.515c4.686 -4.687 12.284 -4.687 17 0\"}}]})(props);\n};\nexport function TbWindOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 8h3m4 0h1.5a2.5 2.5 0 1 0 -2.34 -3.24\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 12h2.5a2.5 2.5 0 0 1 1.801 4.282\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16h5.5a2.5 2.5 0 1 1 -2.34 3.24\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbWind (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 8h8.5a2.5 2.5 0 1 0 -2.34 -3.24\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12h15.5a2.5 2.5 0 1 1 -2.34 3.24\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 16h5.5a2.5 2.5 0 1 1 -2.34 3.24\"}}]})(props);\n};\nexport function TbWindmillOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.061 11.06c1.18 -.824 1.939 -2.11 1.939 -3.56c0 -2.49 -2.24 -4.5 -5 -4.5v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12c0 2.76 2.01 5 4.5 5c.166 0 .33 -.01 .49 -.03m2.624 -1.36c.856 -.91 1.386 -2.19 1.386 -3.61h-5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12c-2.76 0 -5 2.01 -5 4.5s2.24 4.5 5 4.5v-9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.981 7.033c-2.244 .285 -3.981 2.402 -3.981 4.967h9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbWindmill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12c2.76 0 5 -2.01 5 -4.5s-2.24 -4.5 -5 -4.5v9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12c0 2.76 2.01 5 4.5 5s4.5 -2.24 4.5 -5h-9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12c-2.76 0 -5 2.01 -5 4.5s2.24 4.5 5 4.5v-9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12c0 -2.76 -2.01 -5 -4.5 -5s-4.5 2.24 -4.5 5h9z\"}}]})(props);\n};\nexport function TbWindowOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.166 6.19a6.903 6.903 0 0 0 -1.166 3.81v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1 -1v-1m0 -4v-5c0 -3.728 -3.134 -7 -7 -7a6.86 6.86 0 0 0 -3.804 1.158\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 13h8m4 0h2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3v5m0 4v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbWindow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3c-3.866 0 -7 3.272 -7 7v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1 -1v-10c0 -3.728 -3.134 -7 -7 -7z\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"13\",\"x2\":\"19\",\"y2\":\"13\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbWindsock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 3v18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 11l12 -1v-4l-12 -1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5.5v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 6v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 21h4\"}}]})(props);\n};\nexport function TbWiperWash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"20\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 11l5.5 5.5a5 5 0 0 1 7 0l5.5 -5.5a12 12 0 0 0 -18 0\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"20\",\"x2\":\"12\",\"y2\":\"6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6a4 4 0 0 1 .4 -1.8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 2.1a4 4 0 0 1 2 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6a4 4 0 0 0 -.4 -1.8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 6a4 4 0 0 1 .4 -1.8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 2.1a4 4 0 0 1 2 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 6a4 4 0 0 0 -.4 -1.8\"}}]})(props);\n};\nexport function TbWiper (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"18\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 9l5.5 5.5a5 5 0 0 1 7 0l5.5 -5.5a12 12 0 0 0 -18 0\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"18\",\"x2\":\"9.8\",\"y2\":\"5.2\"}}]})(props);\n};\nexport function TbWoman (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"5\",\"r\":\"2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 22v-4h-2l2 -6a1 1 0 0 1 1 -1h2a1 1 0 0 1 1 1l2 6h-2v4\"}}]})(props);\n};\nexport function TbWorldDownload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 12a9 9 0 1 0 -9 9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.6 9h16.8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.6 15h8.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.578 3a17 17 0 0 0 0 18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 3c1.719 2.755 2.5 5.876 2.5 9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 14v7m-3 -3l3 3l3 -3\"}}]})(props);\n};\nexport function TbWorldLatitude (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4.6\",\"y1\":\"7\",\"x2\":\"19.4\",\"y2\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3\",\"y1\":\"12\",\"x2\":\"21\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4.6\",\"y1\":\"17\",\"x2\":\"19.4\",\"y2\":\"17\"}}]})(props);\n};\nexport function TbWorldLongitude (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.5 3a11.2 11.2 0 0 0 0 18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 3a11.2 11.2 0 0 1 0 18\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"3\",\"x2\":\"12\",\"y2\":\"21\"}}]})(props);\n};\nexport function TbWorldOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.6 9h5.4m4 0h7.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.65 5.623a9 9 0 1 0 12.71 12.745m1.684 -2.328a9 9 0 0 0 -12.094 -12.08\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.6 15h11.4m4 0h1.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.335 8.388a18.998 18.998 0 0 0 -.335 3.612c0 4.97 1.79 9 4 9c1.622 0 3.018 -2.172 3.646 -5.294m.354 -3.706c0 -4.97 -1.79 -9 -4 -9c-1.035 0 -1.979 .885 -2.689 2.337\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbWorldUpload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 12a9 9 0 1 0 -9 9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.6 9h16.8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.6 15h8.4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.578 3a17 17 0 0 0 0 18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 3c1.719 2.755 2.5 5.876 2.5 9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 21v-7m3 3l-3 -3l-3 3\"}}]})(props);\n};\nexport function TbWorld (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3.6\",\"y1\":\"9\",\"x2\":\"20.4\",\"y2\":\"9\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"3.6\",\"y1\":\"15\",\"x2\":\"20.4\",\"y2\":\"15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.5 3a17 17 0 0 0 0 18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 3a17 17 0 0 1 0 18\"}}]})(props);\n};\nexport function TbWreckingBall (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"19\",\"cy\":\"13\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"4\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"13\",\"cy\":\"17\",\"r\":\"2\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"13\",\"y1\":\"19\",\"x2\":\"4\",\"y2\":\"19\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"15\",\"x2\":\"13\",\"y2\":\"15\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12v-5h2a3 3 0 0 1 3 3v5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 15v-2a1 1 0 0 1 1 -1h7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 11v-7l-6 7\"}}]})(props);\n};\nexport function TbWritingOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 7h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16v1l2 2l.5 -.5m1.5 -2.5v-11c0 -1.121 -.879 -2 -2 -2s-2 .879 -2 2v7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 19h-13a2 2 0 1 1 0 -4h4a2 2 0 1 0 0 -4h-3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbWritingSignOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19c3.333 -2 5 -4 5 -6c0 -3 -1 -3 -2 -3s-2.032 1.085 -2 3c.034 2.048 1.658 2.877 2.5 4c1.5 2 2.5 2.5 3.5 1c.667 -1 1.167 -1.833 1.5 -2.5c1 2.333 2.333 3.5 4 3.5h2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 16v1l2 2l.5 -.5m1.5 -2.5v-11c0 -1.121 -.879 -2 -2 -2s-2 .879 -2 2v7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 7h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3l18 18\"}}]})(props);\n};\nexport function TbWritingSign (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 19c3.333 -2 5 -4 5 -6c0 -3 -1 -3 -2 -3s-2.032 1.085 -2 3c.034 2.048 1.658 2.877 2.5 4c1.5 2 2.5 2.5 3.5 1c.667 -1 1.167 -1.833 1.5 -2.5c1 2.333 2.333 3.5 4 3.5h2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 17v-12c0 -1.121 -.879 -2 -2 -2s-2 .879 -2 2v12l2 2l2 -2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 7h4\"}}]})(props);\n};\nexport function TbWriting (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M20 17v-12c0 -1.121 -.879 -2 -2 -2s-2 .879 -2 2v12l2 2l2 -2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 7h4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M18 19h-13a2 2 0 1 1 0 -4h4a2 2 0 1 0 0 -4h-3\"}}]})(props);\n};\nexport function TbX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"18\",\"y1\":\"6\",\"x2\":\"6\",\"y2\":\"18\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6\",\"y1\":\"6\",\"x2\":\"18\",\"y2\":\"18\"}}]})(props);\n};\nexport function TbYinYang (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3a4.5 4.5 0 0 0 0 9a4.5 4.5 0 0 1 0 9\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"7.5\",\"r\":\".5\",\"fill\":\"currentColor\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"16.5\",\"r\":\".5\",\"fill\":\"currentColor\"}}]})(props);\n};\nexport function TbYoga (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"4\",\"r\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 20h4l1.5 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 20l-1 -5h-5l1 -7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 10l4 -1l4 -1l4 1.5l4 1.5\"}}]})(props);\n};\nexport function TbZodiacAquarius (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 10l3 -3l3 3l3 -3l3 3l3 -3l3 3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 17l3 -3l3 3l3 -3l3 3l3 -3l3 3\"}}]})(props);\n};\nexport function TbZodiacAries (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 5a5 5 0 1 0 -4 8\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 13a5 5 0 1 0 -4 -8\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"21\",\"x2\":\"12\",\"y2\":\"5\"}}]})(props);\n};\nexport function TbZodiacCancer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"18\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12a10 6.5 0 0 1 14 -6.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 12a10 6.5 0 0 1 -14 6.5\"}}]})(props);\n};\nexport function TbZodiacCapricorn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4a3 3 0 0 1 3 3v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7a3 3 0 0 1 6 0v11a3 3 0 0 1 -3 3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"16\",\"cy\":\"17\",\"r\":\"3\"}}]})(props);\n};\nexport function TbZodiacGemini (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3a21 21 0 0 0 18 0\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 21a21 21 0 0 1 18 0\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"4.5\",\"x2\":\"7\",\"y2\":\"19.5\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"17\",\"y1\":\"4.5\",\"x2\":\"17\",\"y2\":\"19.5\"}}]})(props);\n};\nexport function TbZodiacLeo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 17a4 4 0 1 0 8 0\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"6\",\"cy\":\"16\",\"r\":\"3\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"11\",\"cy\":\"7\",\"r\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7c0 3 2 5 2 9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 7c0 4 -2 6 -2 10\"}}]})(props);\n};\nexport function TbZodiacLibra (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"20\",\"x2\":\"19\",\"y2\":\"20\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 17h5v-.3a7 7 0 1 1 4 0v.3h5\"}}]})(props);\n};\nexport function TbZodiacPisces (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 3a21 21 0 0 1 0 18\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 3a21 21 0 0 0 0 18\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"5\",\"y1\":\"12\",\"x2\":\"19\",\"y2\":\"12\"}}]})(props);\n};\nexport function TbZodiacSagittarius (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"4\",\"y1\":\"20\",\"x2\":\"20\",\"y2\":\"4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 4h7v7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"6.5\",\"y1\":\"12.5\",\"x2\":\"11.5\",\"y2\":\"17.5\"}}]})(props);\n};\nexport function TbZodiacScorpio (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 4a2 2 0 0 1 2 2v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 6a2 2 0 0 1 4 0v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 6a2 2 0 0 1 4 0v10a3 3 0 0 0 3 3h5l-3 -3m0 6l3 -3\"}}]})(props);\n};\nexport function TbZodiacTaurus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 3a6 6 0 0 0 12 0\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"15\",\"r\":\"6\"}}]})(props);\n};\nexport function TbZodiacVirgo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 4a2 2 0 0 1 2 2v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 6a2 2 0 0 1 4 0v9\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 6a2 2 0 0 1 4 0v10a7 5 0 0 0 7 5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 21a7 5 0 0 0 7 -5v-2a3 3 0 0 0 -6 0\"}}]})(props);\n};\nexport function TbZoomCancel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"10\",\"cy\":\"10\",\"r\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"8\",\"y1\":\"8\",\"x2\":\"12\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"12\",\"y1\":\"8\",\"x2\":\"8\",\"y2\":\"12\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"21\",\"x2\":\"15\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbZoomCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"10\",\"cy\":\"10\",\"r\":\"7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 21l-6 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 10l2 2l4 -4\"}}]})(props);\n};\nexport function TbZoomCode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"10\",\"cy\":\"10\",\"r\":\"7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 21l-6 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8l-2 2l2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8l2 2l-2 2\"}}]})(props);\n};\nexport function TbZoomExclamation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"10\",\"cy\":\"10\",\"r\":\"7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 21l-6 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 13v.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 7v3\"}}]})(props);\n};\nexport function TbZoomInArea (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 13v4\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 15h4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"15\",\"r\":\"5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 22l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 18h-1a2 2 0 0 1 -2 -2v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 11v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6v-1a2 2 0 0 1 2 -2h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 3h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3h1a2 2 0 0 1 2 2v1\"}}]})(props);\n};\nexport function TbZoomIn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"10\",\"cy\":\"10\",\"r\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"10\",\"x2\":\"13\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"7\",\"x2\":\"10\",\"y2\":\"13\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"21\",\"x2\":\"15\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbZoomMoney (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"10\",\"cy\":\"10\",\"r\":\"7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 21l-6 -6\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7h-2.5a1.5 1.5 0 0 0 0 3h1a1.5 1.5 0 0 1 0 3h-2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 13v1m0 -8v1\"}}]})(props);\n};\nexport function TbZoomOutArea (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 15h4\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"15\",\"cy\":\"15\",\"r\":\"5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M22 22l-3 -3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 18h-1a2 2 0 0 1 -2 -2v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 11v-1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6v-1a2 2 0 0 1 2 -2h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 3h1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15 3h1a2 2 0 0 1 2 2v1\"}}]})(props);\n};\nexport function TbZoomOut (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"10\",\"cy\":\"10\",\"r\":\"7\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"7\",\"y1\":\"10\",\"x2\":\"13\",\"y2\":\"10\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"21\",\"y1\":\"21\",\"x2\":\"15\",\"y2\":\"15\"}}]})(props);\n};\nexport function TbZoomPan (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"12\",\"cy\":\"12\",\"r\":\"3\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M17 17l-2.5 -2.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5l2 -2l2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M19 10l2 2l-2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 10l-2 2l2 2\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 19l2 2l2 -2\"}}]})(props);\n};\nexport function TbZoomQuestion (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"viewBox\":\"0 0 24 24\",\"strokeWidth\":\"2\",\"stroke\":\"currentColor\",\"fill\":\"none\",\"strokeLinecap\":\"round\",\"strokeLinejoin\":\"round\"},\"child\":[{\"tag\":\"desc\",\"attr\":{},\"child\":[]},{\"tag\":\"path\",\"attr\":{\"stroke\":\"none\",\"d\":\"M0 0h24v24H0z\",\"fill\":\"none\"}},{\"tag\":\"circle\",\"attr\":{\"cx\":\"10\",\"cy\":\"10\",\"r\":\"7\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M21 21l-6 -6\"}},{\"tag\":\"line\",\"attr\":{\"x1\":\"10\",\"y1\":\"13\",\"x2\":\"10\",\"y2\":\"13.01\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 10a1.5 1.5 0 1 0 -1.14 -2.474\"}}]})(props);\n};\n","import React, { useState, useContext, useEffect, useRef } from 'react'\r\nimport { addDays } from 'date-fns'\r\nimport moment from 'moment'\r\nimport Button from '../components/Button'\r\nimport {NavLink} from 'react-router-dom'\r\nimport DataContext from '../context/DataContext'\r\nimport useErrorHandler from '../hooks/useErrorHandler'\r\nimport useContextCommunicator from '../hooks/useContextCommunicator'\r\nimport {TbArrowBarUp, TbArrowBarDown} from 'react-icons/tb'\r\n\r\nexport default function StockBrowser() {\r\n // context defs\r\n const {scannerState, scanForStocks, setInstrumentShown, categories, countries, setVisitedFrom, updateFromPrice, updateToPrice, scannerFromPrice, scannerToPrice, scannerTypeFilter, scannerTypeOrder, updateType, updateOrder} = useContext(DataContext)\r\n const {errorHandler} = useErrorHandler()\r\n const {quickAddInstrumentCommand} = useContextCommunicator()\r\n // state defs\r\n const [start, setStart] = useState(moment(new Date()).format('yyyy-MM-DD'))\r\n const [end, setEnd] = useState(moment(addDays(new Date(), 7)).format('yyyy-MM-DD'))\r\n const [country, setCountry] = useState(\"USA\")\r\n const [countryDisabled, toggleCountry] = useState(false)\r\n const [category, setCategory] = useState('Financial Services')\r\n const [searchType, setSearchType] = useState('EntryExit')\r\n const [tradeLength, setTradeLength] = useState(\"15\")\r\n const [scannedStocks, setScannedStocks] = useState(scannerState.results)\r\n const [errorMessage, setError] = useState('')\r\n const [searchSubmitted, toggleSearch] = useState(false)\r\n const [requestInProgress, setRequestInProgress] = useState(false)\r\n const [goToPage, setGoToPage] = useState(1)\r\n const [sortType, setSortType] = useState(0)\r\n const [searchParamsHidden, setSearchParamsHidden] = useState(true)\r\n const [searchDisabled, toggleSearchDisabled] = useState(false)\r\n\r\n // Helper functions\r\n const organizeResults = (results=[]) => {\r\n let newState\r\n\r\n if (results.length) {\r\n newState = results\r\n } else {\r\n newState = [...scannedStocks] \r\n }\r\n\r\n newState.sort(function(a,b) {\r\n if (scannerTypeOrder === '-') {\r\n if (scannerTypeFilter === 'Avg') {\r\n return b.average - a.average\r\n } else if (scannerTypeFilter === 'Med') {\r\n return b.median - a.median\r\n }\r\n } else if (scannerTypeOrder === '+') {\r\n if (scannerTypeFilter === 'Avg') {\r\n return a.average - b.average\r\n } else if (scannerTypeFilter === 'Med') {\r\n return a.median - b.median\r\n }\r\n }\r\n })\r\n\r\n if (results.length) {\r\n return newState\r\n } else {\r\n setScannedStocks(newState)\r\n }\r\n }\r\n\r\n const filterPriceHandler = () => {\r\n // Validation\r\n if (scannerToPrice < scannerFromPrice) {\r\n return alert(\"Price range incorrect. From Price must be lower than To Price\")\r\n }\r\n\r\n const filterResults = (array, from, to) => {\r\n return array.filter(el => {\r\n const price = parseFloat(el.lastPrice)\r\n if ((price >= from) && (price <= to)) {\r\n return true\r\n }\r\n })\r\n }\r\n\r\n let filteredResults\r\n if ((scannerToPrice == 0) && (scannerFromPrice == 0)) {\r\n setScannedStocks(scannerState.results)\r\n } else {\r\n \r\n filteredResults = filterResults(scannerState.results, scannerFromPrice, scannerToPrice)\r\n setScannedStocks(filteredResults)\r\n }\r\n }\r\n\r\n // First Init\r\n useEffect(() => {\r\n if (scannerState.results.length>0) {\r\n setStart(scannerState.params.dateRange[0])\r\n setEnd(scannerState.params.dateRange[1])\r\n setCountry(scannerState.params.country)\r\n setCategory(scannerState.params.category)\r\n toggleSearch(true)\r\n organizeResults(scannerState.results)\r\n filterPriceHandler()\r\n // organizeResults()\r\n } else if (scannerState.params.country && scannerState.params.country !== country) {\r\n setCountry(scannerState.params.country)\r\n }\r\n }, [scannerState])\r\n\r\n\r\n // handlers\r\n const scannerSubmit = async (page) => {\r\n // validation\r\n if (start > end) {\r\n return setError('End date cannot be before Start date. Select another range with End date after Start date')\r\n }\r\n\r\n if (tradeLength <= 0) {\r\n return setError('Cannot have trade length less than 1 day')\r\n }\r\n setError('')\r\n\r\n let countrySubmit = country\r\n let categorySubmit = category\r\n \r\n if (countryDisabled) {\r\n countrySubmit = 'None'\r\n } else if (country === 'United Kingdom') {\r\n countrySubmit = 'UK'\r\n }\r\n\r\n // request\r\n try {\r\n const dateRange = [start, end]\r\n setRequestInProgress(true)\r\n setScannedStocks([])\r\n const results = await scanForStocks(dateRange, categorySubmit, countrySubmit, searchType, tradeLength, page, sortType)\r\n const orderedResults = organizeResults(results.results)\r\n setScannedStocks(orderedResults)\r\n toggleSearch(true)\r\n setRequestInProgress(false)\r\n toggleSearchDisabled(true)\r\n } catch (e) {\r\n errorHandler(e)\r\n }\r\n }\r\n\r\n const setCategoryHandler = (e) => {\r\n const cat = e.target.value\r\n if (cat === 'Indexes' || cat === 'International Indexes' || cat === 'Commodities' || cat === 'Treasury' || cat === 'Forex' || cat === 'Futures' || cat === 'Crypto') {\r\n toggleCountry(true)\r\n } else {\r\n toggleCountry(false)\r\n }\r\n toggleSearchDisabled(false)\r\n setCategory(cat)\r\n }\r\n\r\n const setCountryHandler = (e) => {\r\n toggleSearchDisabled(false)\r\n setCountry(e.target.value)\r\n }\r\n\r\n const linkClicked = (item) => {\r\n setInstrumentShown(item)\r\n setVisitedFrom('/scanner')\r\n }\r\n\r\n const quickAddInstrument = (item) => {\r\n quickAddInstrumentCommand(item)\r\n }\r\n\r\n const backHandler = async () => {\r\n const newPage = parseInt(goToPage) - 1\r\n setGoToPage(newPage)\r\n scannerSubmit(newPage)\r\n }\r\n const nextHandler = async () => {\r\n const newPage = parseInt(goToPage) + 1\r\n setGoToPage(newPage)\r\n scannerSubmit(newPage)\r\n }\r\n const scannerSubmitHandler = () => {\r\n setGoToPage(1)\r\n scannerSubmit(1)\r\n }\r\n\r\n const setSortHandler = async (type) => {\r\n setScannedStocks([])\r\n let countrySubmit = country\r\n let categorySubmit = category\r\n \r\n if (countryDisabled) {\r\n countrySubmit = 'None'\r\n } else if (country === 'United Kingdom') {\r\n countrySubmit = 'UK'\r\n }\r\n\r\n const dateRange = [start, end]\r\n const results = await scanForStocks(dateRange, categorySubmit, countrySubmit, searchType, tradeLength, 1, type)\r\n setScannedStocks(results.results)\r\n setSortType(type)\r\n }\r\n\r\n // ----------------- Pre-render -----------------\r\n let scannerDiv = null\r\n const categoryList = categories.map(item => {\r\n return (\r\n \r\n )\r\n })\r\n\r\n const countryList = countries.map(item => {\r\n return (\r\n \r\n )\r\n })\r\n\r\n // ****************************************\r\n let paginationDiv\r\n // if (scannedStocks.totalPages > 1) {\r\n // paginationDiv =
    \r\n // Found: {scannedStocks.totalResults} results. Total Pages: {scannedStocks.totalPages}\r\n //
    \r\n // Showing page: {scannedStocks.page}\r\n //
    \r\n //
    \r\n // Go to page: setGoToPage(parseInt(e.target.value))}\r\n // />\r\n // \r\n //
    \r\n //
    \r\n // {scannedStocks.page === 1 ? null : }\r\n // \r\n //
    \r\n //
    \r\n // }\r\n // ******************************************\r\n\r\n let scanResults\r\n if (scannedStocks && scannedStocks.length) {\r\n const stocksDiv = scannedStocks.map(item => {\r\n if (item.relevance === 1 || item.relevance === 2) {\r\n let itemClass = \"\"\r\n if (item.trend === \"UP\") {\r\n itemClass = \"stockScanner--search-results__result stockScanner--search-results__result--green\"\r\n } else if (item.trend === \"DOWN\") {\r\n itemClass = \"stockScanner--search-results__result stockScanner--search-results__result--red\"\r\n } else {\r\n itemClass = \"stockScanner--search-results__result\"\r\n }\r\n let NavLinkObj\r\n if (item.name) {\r\n NavLinkObj = (\r\n linkClicked(item.instrument)} className=\"stockScanner--search-results__result--description\">\r\n {/*
    quickAddInstrument(item.instrument)}>
    */}\r\n
    {item.name} - {item.range[0]} to {item.range[1]}{item.ups} UP/{item.downs} DOWN. Last Price: {item.lastPrice}
    \r\n
    {item.ups} UP/{item.downs} DOWN - Average Change: {item.average}%. Median: {item.median}%
    \r\n
    \r\n )\r\n } else {\r\n NavLinkObj = (\r\n linkClicked(item.symbol)} className=\"stockScanner--search-results__result--description\">\r\n
    {item.symbol}/{item.instrument}{item.sector? \" - \" + item.sector+\": \"+item.industry : null} - {item.range[0]} to {item.range[1]}. Last Price: {item.lastPrice}
    \r\n
    {item.ups} UP/{item.downs} DOWN - Average Change: {item.average}%. Median: {item.median}%
    \r\n
    \r\n )\r\n }\r\n\r\n let stockSymbol\r\n if (item.name) {\r\n stockSymbol = item.instrument\r\n } else {\r\n stockSymbol = item.symbol\r\n }\r\n\r\n return (\r\n
    \r\n
    quickAddInstrument(stockSymbol)}>
    \r\n {NavLinkObj}\r\n
    \r\n )\r\n } else {\r\n return null\r\n }\r\n })\r\n\r\n scanResults = (\r\n
    \r\n

    Found {scannedStocks.length} Most Relevant Stocks

    \r\n {paginationDiv}\r\n {stocksDiv}\r\n
    \r\n )\r\n } else {\r\n scanResults = (\r\n
    \r\n {requestInProgress?

    Searching. Please wait...

    :

    No Results

    }\r\n \r\n
    \r\n )\r\n }\r\n // Screen load\r\n if (searchSubmitted) {\r\n // results screen\r\n // search button definition\r\n let searchButton = \r\n if (requestInProgress) {\r\n searchButton = \r\n } else if (searchDisabled) {\r\n searchButton = \r\n }\r\n\r\n scannerDiv = (\r\n \r\n
    \r\n

    Scan Parameters

    \r\n
    \r\n
    \r\n {/* Trade Range */}\r\n
    \r\n
    Trade Range
    \r\n From: \r\n {setStart(e.target.value); toggleSearchDisabled(false)}} />\r\n To: \r\n {setEnd(e.target.value); toggleSearchDisabled(false)}} />\r\n
    \r\n {/* Sector */}\r\n
    \r\n
    Sector/Type:
    \r\n \r\n
    \r\n {/* Country */}\r\n
    \r\n
    Country:
    \r\n \r\n
    \r\n
    \r\n
    \r\n {/* Search Type */}\r\n
    \r\n
    Search Type:
    \r\n \r\n
    \r\n {/* Trade Length */}\r\n
    \r\n
    Max Trade length
    \r\n
    \r\n {setTradeLength(e.target.value); toggleSearchDisabled(false)}} />\r\n Days\r\n
    \r\n
    \r\n {/* Sorting Method\r\n
    \r\n
    Sort by:
    \r\n \r\n
    */}\r\n {/* Search Button */}\r\n {searchButton}\r\n
    \r\n
    \r\n
    \r\n {searchParamsHidden ?\r\n setSearchParamsHidden(false)} style={{cursor: 'pointer'}} />\r\n :\r\n setSearchParamsHidden(true)} style={{cursor: 'pointer'}} />\r\n }\r\n
    \r\n
    \r\n

    Sorting Options

    \r\n
    \r\n
    \r\n {/* Price Filter */}\r\n
    \r\n Price Range\r\n Setting both values to 0 will show all results\r\n
    \r\n From:\r\n updateFromPrice(e.target.value)}\r\n style={{maxWidth: '5rem'}}\r\n />\r\n To: \r\n updateToPrice(e.target.value)}\r\n style={{maxWidth: '5rem'}}\r\n />\r\n
    \r\n \r\n Filter\r\n \r\n
    \r\n
    \r\n
    \r\n {/* Order_by */}\r\n
    \r\n Sort By:\r\n  \r\n
    \r\n Type: \r\n \r\n Order: \r\n \r\n
    \r\n \r\n Sort\r\n \r\n
    \r\n
    \r\n
    \r\n
    {errorMessage? {errorMessage} : null}
    \r\n
    \r\n {scanResults}\r\n
    \r\n )\r\n } else {\r\n // console.log(scannerState)\r\n // default screen\r\n scannerDiv = (\r\n
    \r\n

    Let's find what to trade

    \r\n {errorMessage?

    {errorMessage}

    :

    What dates do you want to trade?

    }\r\n
    \r\n {/*
    */}\r\n
    \r\n From: \r\n setStart(e.target.value)} />\r\n
    \r\n {/*
    */}\r\n
    \r\n To: \r\n setEnd(e.target.value)} min={start} />\r\n
    \r\n
    \r\n \r\n Sector/Type: \r\n \r\n \r\n
    \r\n
    \r\n \r\n Country:\r\n \r\n \r\n
    \r\n
    \r\n \r\n Search Type:\r\n \r\n \r\n
    \r\n
    \r\n
    \r\n \r\n Max Trade length:\r\n \r\n
    \r\n \r\n
    \r\n
    \r\n setTradeLength(e.target.value)} />\r\n Days\r\n
    \r\n
    \r\n
    \r\n
    \r\n
    \r\n Max Trade Length is only available if you wish to enter a trade between \"From\" and \"To\" dates.\r\n
    \r\n Select Search Type to \"Entry within set period\" to define Max Trade Length.\r\n
    \r\n {requestInProgress ? : }\r\n
    \r\n
    \r\n

    Enter the planned dates you wish to start and end the trade.

    \r\n

    After clicking the \"Find\" button, we will find instruments that fit your search criteria and have performed reliably in the last 12 years.

    \r\n
    \r\n \r\n
    \r\n
    )\r\n }\r\n\r\n// ----------------------------------------------------------\r\n \r\n// \r\n//
    \r\n// {requestInProgress? : }\r\n//
    \r\n\r\n return (\r\n
    \r\n {scannerDiv}\r\n
    \r\n )\r\n}","import toInteger from \"../_lib/toInteger/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name addDays\n * @category Day Helpers\n * @summary Add the specified number of days to the given date.\n *\n * @description\n * Add the specified number of days to the given date.\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} amount - the amount of days to be added. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.\n * @returns {Date} - the new date with the days added\n * @throws {TypeError} - 2 arguments required\n *\n * @example\n * // Add 10 days to 1 September 2014:\n * const result = addDays(new Date(2014, 8, 1), 10)\n * //=> Thu Sep 11 2014 00:00:00\n */\n\nexport default function addDays(dirtyDate, dirtyAmount) {\n requiredArgs(2, arguments);\n var date = toDate(dirtyDate);\n var amount = toInteger(dirtyAmount);\n\n if (isNaN(amount)) {\n return new Date(NaN);\n }\n\n if (!amount) {\n // If 0 days, no-op to avoid changing times in the hour before end of DST\n return date;\n }\n\n date.setDate(date.getDate() + amount);\n return date;\n}","// THIS FILE IS AUTO GENERATED\nimport { GenIcon } from '../lib';\nexport function BsFillAlarmFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 .5a.5.5 0 0 1 .5-.5h3a.5.5 0 0 1 0 1H9v1.07a7.001 7.001 0 0 1 3.274 12.474l.601.602a.5.5 0 0 1-.707.708l-.746-.746A6.97 6.97 0 0 1 8 16a6.97 6.97 0 0 1-3.422-.892l-.746.746a.5.5 0 0 1-.707-.708l.602-.602A7.001 7.001 0 0 1 7 2.07V1h-.5A.5.5 0 0 1 6 .5zm2.5 5a.5.5 0 0 0-1 0v3.362l-1.429 2.38a.5.5 0 1 0 .858.515l1.5-2.5A.5.5 0 0 0 8.5 9V5.5zM.86 5.387A2.5 2.5 0 1 1 4.387 1.86 8.035 8.035 0 0 0 .86 5.387zM11.613 1.86a2.5 2.5 0 1 1 3.527 3.527 8.035 8.035 0 0 0-3.527-3.527z\"}}]})(props);\n};\nexport function BsFillArchiveFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.643 15C13.979 15 15 13.845 15 12.5V5H1v7.5C1 13.845 2.021 15 3.357 15h9.286zM5.5 7h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1zM.8 1a.8.8 0 0 0-.8.8V3a.8.8 0 0 0 .8.8h14.4A.8.8 0 0 0 16 3V1.8a.8.8 0 0 0-.8-.8H.8z\"}}]})(props);\n};\nexport function BsFillArrowDownCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM8.5 4.5a.5.5 0 0 0-1 0v5.793L5.354 8.146a.5.5 0 1 0-.708.708l3 3a.5.5 0 0 0 .708 0l3-3a.5.5 0 0 0-.708-.708L8.5 10.293V4.5z\"}}]})(props);\n};\nexport function BsFillArrowDownLeftCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 0 0 8a8 8 0 0 0 16 0zm-5.904-2.803a.5.5 0 1 1 .707.707L6.707 10h2.768a.5.5 0 0 1 0 1H5.5a.5.5 0 0 1-.5-.5V6.525a.5.5 0 0 1 1 0v2.768l4.096-4.096z\"}}]})(props);\n};\nexport function BsFillArrowDownLeftSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 16a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2zm8.096-10.803L6 9.293V6.525a.5.5 0 0 0-1 0V10.5a.5.5 0 0 0 .5.5h3.975a.5.5 0 0 0 0-1H6.707l4.096-4.096a.5.5 0 1 0-.707-.707z\"}}]})(props);\n};\nexport function BsFillArrowDownRightCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8zm5.904-2.803a.5.5 0 1 0-.707.707L9.293 10H6.525a.5.5 0 0 0 0 1H10.5a.5.5 0 0 0 .5-.5V6.525a.5.5 0 0 0-1 0v2.768L5.904 5.197z\"}}]})(props);\n};\nexport function BsFillArrowDownRightSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 16a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12zM5.904 5.197 10 9.293V6.525a.5.5 0 0 1 1 0V10.5a.5.5 0 0 1-.5.5H6.525a.5.5 0 0 1 0-1h2.768L5.197 5.904a.5.5 0 0 1 .707-.707z\"}}]})(props);\n};\nexport function BsFillArrowDownSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm6.5 4.5v5.793l2.146-2.147a.5.5 0 0 1 .708.708l-3 3a.5.5 0 0 1-.708 0l-3-3a.5.5 0 1 1 .708-.708L7.5 10.293V4.5a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFillArrowLeftCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a8 8 0 1 0 0 16A8 8 0 0 0 8 0zm3.5 7.5a.5.5 0 0 1 0 1H5.707l2.147 2.146a.5.5 0 0 1-.708.708l-3-3a.5.5 0 0 1 0-.708l3-3a.5.5 0 1 1 .708.708L5.707 7.5H11.5z\"}}]})(props);\n};\nexport function BsFillArrowLeftSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 14a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12zm-4.5-6.5H5.707l2.147-2.146a.5.5 0 1 0-.708-.708l-3 3a.5.5 0 0 0 0 .708l3 3a.5.5 0 0 0 .708-.708L5.707 8.5H11.5a.5.5 0 0 0 0-1z\"}}]})(props);\n};\nexport function BsFillArrowRightCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0zM4.5 7.5a.5.5 0 0 0 0 1h5.793l-2.147 2.146a.5.5 0 0 0 .708.708l3-3a.5.5 0 0 0 0-.708l-3-3a.5.5 0 1 0-.708.708L10.293 7.5H4.5z\"}}]})(props);\n};\nexport function BsFillArrowRightSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 14a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v12zm4.5-6.5h5.793L8.146 5.354a.5.5 0 1 1 .708-.708l3 3a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708-.708L10.293 8.5H4.5a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFillArrowUpCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 0 0 8a8 8 0 0 0 16 0zm-7.5 3.5a.5.5 0 0 1-1 0V5.707L5.354 7.854a.5.5 0 1 1-.708-.708l3-3a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1-.708.708L8.5 5.707V11.5z\"}}]})(props);\n};\nexport function BsFillArrowUpLeftCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-5.904 2.803a.5.5 0 1 0 .707-.707L6.707 6h2.768a.5.5 0 1 0 0-1H5.5a.5.5 0 0 0-.5.5v3.975a.5.5 0 0 0 1 0V6.707l4.096 4.096z\"}}]})(props);\n};\nexport function BsFillArrowUpLeftSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm8.096 10.803L6 6.707v2.768a.5.5 0 0 1-1 0V5.5a.5.5 0 0 1 .5-.5h3.975a.5.5 0 1 1 0 1H6.707l4.096 4.096a.5.5 0 1 1-.707.707z\"}}]})(props);\n};\nexport function BsFillArrowUpRightCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 8a8 8 0 1 0 16 0A8 8 0 0 0 0 8zm5.904 2.803a.5.5 0 1 1-.707-.707L9.293 6H6.525a.5.5 0 1 1 0-1H10.5a.5.5 0 0 1 .5.5v3.975a.5.5 0 0 1-1 0V6.707l-4.096 4.096z\"}}]})(props);\n};\nexport function BsFillArrowUpRightSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 0a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12zM5.904 10.803 10 6.707v2.768a.5.5 0 0 0 1 0V5.5a.5.5 0 0 0-.5-.5H6.525a.5.5 0 1 0 0 1h2.768l-4.096 4.096a.5.5 0 0 0 .707.707z\"}}]})(props);\n};\nexport function BsFillArrowUpSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 16a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2zm6.5-4.5V5.707l2.146 2.147a.5.5 0 0 0 .708-.708l-3-3a.5.5 0 0 0-.708 0l-3 3a.5.5 0 1 0 .708.708L7.5 5.707V11.5a.5.5 0 0 0 1 0z\"}}]})(props);\n};\nexport function BsFillAspectRatioFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12.5v-9A1.5 1.5 0 0 1 1.5 2h13A1.5 1.5 0 0 1 16 3.5v9a1.5 1.5 0 0 1-1.5 1.5h-13A1.5 1.5 0 0 1 0 12.5zM2.5 4a.5.5 0 0 0-.5.5v3a.5.5 0 0 0 1 0V5h2.5a.5.5 0 0 0 0-1h-3zm11 8a.5.5 0 0 0 .5-.5v-3a.5.5 0 0 0-1 0V11h-2.5a.5.5 0 0 0 0 1h3z\"}}]})(props);\n};\nexport function BsFillAwardFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m8 0 1.669.864 1.858.282.842 1.68 1.337 1.32L13.4 6l.306 1.854-1.337 1.32-.842 1.68-1.858.282L8 12l-1.669-.864-1.858-.282-.842-1.68-1.337-1.32L2.6 6l-.306-1.854 1.337-1.32.842-1.68L6.331.864 8 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 11.794V16l4-1 4 1v-4.206l-2.018.306L8 13.126 6.018 12.1 4 11.794z\"}}]})(props);\n};\nexport function BsFillBackspaceFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.683 3a2 2 0 0 0-2-2h-7.08a2 2 0 0 0-1.519.698L.241 7.35a1 1 0 0 0 0 1.302l4.843 5.65A2 2 0 0 0 6.603 15h7.08a2 2 0 0 0 2-2V3zM5.829 5.854a.5.5 0 1 1 .707-.708l2.147 2.147 2.146-2.147a.5.5 0 1 1 .707.708L9.39 8l2.146 2.146a.5.5 0 0 1-.707.708L8.683 8.707l-2.147 2.147a.5.5 0 0 1-.707-.708L7.976 8 5.829 5.854z\"}}]})(props);\n};\nexport function BsFillBackspaceReverseFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 3a2 2 0 0 1 2-2h7.08a2 2 0 0 1 1.519.698l4.843 5.651a1 1 0 0 1 0 1.302L10.6 14.3a2 2 0 0 1-1.52.7H2a2 2 0 0 1-2-2V3zm9.854 2.854a.5.5 0 0 0-.708-.708L7 7.293 4.854 5.146a.5.5 0 1 0-.708.708L6.293 8l-2.147 2.146a.5.5 0 0 0 .708.708L7 8.707l2.146 2.147a.5.5 0 0 0 .708-.708L7.707 8l2.147-2.146z\"}}]})(props);\n};\nexport function BsFillBadge3DFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.157 5.968h-.844v4.06h.844c1.116 0 1.621-.667 1.621-2.02 0-1.354-.51-2.04-1.621-2.04z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm5.184 4.368c.646 0 1.055.378 1.06.9.008.537-.427.919-1.086.919-.598-.004-1.037-.325-1.068-.756H3c.03.914.791 1.688 2.153 1.688 1.24 0 2.285-.66 2.272-1.798-.013-.953-.747-1.38-1.292-1.432v-.062c.44-.07 1.125-.527 1.108-1.375-.013-.906-.8-1.57-2.053-1.565-1.31.005-2.043.734-2.074 1.67h1.103c.022-.391.383-.751.936-.751.532 0 .928.33.928.813.004.479-.383.835-.928.835h-.632v.914h.663zM8.126 11h2.189C12.125 11 13 9.893 13 7.985c0-1.894-.861-2.984-2.685-2.984H8.126V11z\"}}]})(props);\n};\nexport function BsFillBadge4KFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.577 8.9v.03h1.828V5.898h-.062a46.781 46.781 0 0 0-1.766 3.001z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm2.372 3.715.435-.714h1.71v3.93h.733v.957h-.733V11H5.405V9.888H2.5v-.971c.574-1.077 1.225-2.142 1.872-3.202zm7.73-.714h1.306l-2.14 2.584L13.5 11h-1.428l-1.679-2.624-.615.7V11H8.59V5.001h1.187v2.686h.057L12.102 5z\"}}]})(props);\n};\nexport function BsFillBadge8KFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.9 6.605c0 .51.405.866.95.866.545 0 .945-.356.945-.866s-.4-.852-.945-.852c-.545 0-.95.343-.95.852zm-.192 2.668c0 .589.492.984 1.142.984.646 0 1.143-.395 1.143-.984S5.496 8.28 4.85 8.28c-.65 0-1.142.404-1.142.993z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm5.17 7.348c0 1.041-.927 1.766-2.333 1.766-1.406 0-2.312-.72-2.312-1.762 0-.954.712-1.384 1.257-1.494v-.053c-.51-.154-1.02-.558-1.02-1.331 0-.914.831-1.587 2.088-1.587 1.253 0 2.083.673 2.083 1.587 0 .782-.523 1.182-1.02 1.331v.053c.545.11 1.257.545 1.257 1.49zM12.102 5h1.306l-2.14 2.584 2.232 3.415h-1.428l-1.679-2.624-.615.699v1.925H8.59V5h1.187v2.685h.057L12.102 5z\"}}]})(props);\n};\nexport function BsFillBadgeAdFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.35 8.337c0-.699-.42-1.138-1.001-1.138-.584 0-.954.444-.954 1.239v.453c0 .8.374 1.248.972 1.248.588 0 .984-.44.984-1.2v-.602zm-5.413.237-.734-2.426H5.15l-.734 2.426h1.52z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm6.209 6.32c0-1.28.694-2.044 1.753-2.044.655 0 1.156.294 1.336.769h.053v-2.36h1.16V11h-1.138v-.747h-.057c-.145.474-.69.804-1.367.804-1.055 0-1.74-.764-1.74-2.043v-.695zm-4.04 1.138L3.7 11H2.5l2.013-5.999H5.9L7.905 11H6.644l-.47-1.542H4.17z\"}}]})(props);\n};\nexport function BsFillBadgeArFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m6.031 8.574-.734-2.426h-.052L4.51 8.574h1.52zm3.642-2.641v1.938h1.033c.66 0 1.068-.316 1.068-.95 0-.64-.422-.988-1.05-.988h-1.05z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm4.265 5.458h2.004L6.739 11H8L5.996 5.001H4.607L2.595 11h1.2l.47-1.542zM8.5 5v6h1.173V8.763h1.064L11.787 11h1.327L11.91 8.583C12.455 8.373 13 7.779 13 6.9c0-1.147-.773-1.9-2.105-1.9H8.5z\"}}]})(props);\n};\nexport function BsFillBadgeCcFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm3.027 4.002c-.83 0-1.319.642-1.319 1.753v.743c0 1.107.48 1.727 1.319 1.727.69 0 1.138-.435 1.186-1.05H7.36v.114c-.057 1.147-1.028 1.938-2.342 1.938-1.613 0-2.518-1.028-2.518-2.729v-.747C2.5 6.051 3.414 5 5.018 5c1.318 0 2.29.813 2.342 2v.11H6.213c-.048-.638-.505-1.108-1.186-1.108zm6.14 0c-.831 0-1.319.642-1.319 1.753v.743c0 1.107.48 1.727 1.318 1.727.69 0 1.139-.435 1.187-1.05H13.5v.114c-.057 1.147-1.028 1.938-2.342 1.938-1.613 0-2.518-1.028-2.518-2.729v-.747c0-1.7.914-2.751 2.518-2.751 1.318 0 2.29.813 2.342 2v.11h-1.147c-.048-.638-.505-1.108-1.187-1.108z\"}}]})(props);\n};\nexport function BsFillBadgeHdFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.53 5.968h-.843v4.06h.843c1.117 0 1.622-.667 1.622-2.02 0-1.354-.51-2.04-1.622-2.04z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm5.396 3.001V11H6.209V8.43H3.687V11H2.5V5.001h1.187v2.44h2.522V5h1.187zM8.5 11V5.001h2.188c1.824 0 2.685 1.09 2.685 2.984C13.373 9.893 12.5 11 10.69 11H8.5z\"}}]})(props);\n};\nexport function BsFillBadgeTmFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm3.295 3.995V11H4.104V5.995h-1.7V5H7v.994H5.295zM8.692 7.01V11H7.633V5.001h1.209l1.71 3.894h.039l1.71-3.894H13.5V11h-1.072V7.01h-.057l-1.42 3.239h-.773L8.75 7.008h-.058z\"}}]})(props);\n};\nexport function BsFillBadgeVoFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.296 8.394v-.782c0-1.156-.571-1.736-1.362-1.736-.796 0-1.363.58-1.363 1.736v.782c0 1.156.567 1.732 1.363 1.732.79 0 1.362-.576 1.362-1.732z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm11.5 5.62v.77c0 1.691-.962 2.724-2.566 2.724-1.604 0-2.571-1.033-2.571-2.724v-.77c0-1.704.967-2.733 2.57-2.733 1.605 0 2.567 1.037 2.567 2.734zM5.937 11H4.508L2.5 5.001h1.375L5.22 9.708h.057L6.61 5.001h1.318L5.937 11z\"}}]})(props);\n};\nexport function BsFillBadgeVrFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.673 5.933v1.938h1.033c.66 0 1.068-.316 1.068-.95 0-.64-.422-.988-1.05-.988h-1.05z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm5.937 7 1.99-5.999H6.61L5.277 9.708H5.22L3.875 5.001H2.5L4.508 11h1.429zM8.5 5.001V11h1.173V8.763h1.064L11.787 11h1.327L11.91 8.583C12.455 8.373 13 7.779 13 6.9c0-1.147-.773-1.9-2.105-1.9H8.5z\"}}]})(props);\n};\nexport function BsFillBadgeWcFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm11.666 1.89c.682 0 1.139.47 1.187 1.107H14v-.11c-.053-1.187-1.024-2-2.342-2-1.604 0-2.518 1.05-2.518 2.751v.747c0 1.7.905 2.73 2.518 2.73 1.314 0 2.285-.792 2.342-1.939v-.114h-1.147c-.048.615-.497 1.05-1.187 1.05-.839 0-1.318-.62-1.318-1.727v-.742c0-1.112.488-1.754 1.318-1.754zm-6.188.926h.044L6.542 11h1.006L9 5.001H7.818l-.82 4.355h-.056L5.97 5.001h-.94l-.972 4.355h-.053l-.827-4.355H2L3.452 11h1.005l1.02-4.184z\"}}]})(props);\n};\nexport function BsFillBagCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.5 3.5a2.5 2.5 0 0 0-5 0V4h5v-.5zm1 0V4H15v10a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V4h3.5v-.5a3.5 3.5 0 1 1 7 0zm-.646 5.354a.5.5 0 0 0-.708-.708L7.5 10.793 6.354 9.646a.5.5 0 1 0-.708.708l1.5 1.5a.5.5 0 0 0 .708 0l3-3z\"}}]})(props);\n};\nexport function BsFillBagDashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.5 3.5a2.5 2.5 0 0 0-5 0V4h5v-.5zm1 0V4H15v10a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V4h3.5v-.5a3.5 3.5 0 1 1 7 0zM6 9.5a.5.5 0 0 0 0 1h4a.5.5 0 0 0 0-1H6z\"}}]})(props);\n};\nexport function BsFillBagFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a2.5 2.5 0 0 1 2.5 2.5V4h-5v-.5A2.5 2.5 0 0 1 8 1zm3.5 3v-.5a3.5 3.5 0 1 0-7 0V4H1v10a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V4h-3.5z\"}}]})(props);\n};\nexport function BsFillBagPlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.5 3.5a2.5 2.5 0 0 0-5 0V4h5v-.5zm1 0V4H15v10a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V4h3.5v-.5a3.5 3.5 0 1 1 7 0zM8.5 8a.5.5 0 0 0-1 0v1.5H6a.5.5 0 0 0 0 1h1.5V12a.5.5 0 0 0 1 0v-1.5H10a.5.5 0 0 0 0-1H8.5V8z\"}}]})(props);\n};\nexport function BsFillBagXFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.5 3.5a2.5 2.5 0 0 0-5 0V4h5v-.5zm1 0V4H15v10a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V4h3.5v-.5a3.5 3.5 0 1 1 7 0zM6.854 8.146a.5.5 0 1 0-.708.708L7.293 10l-1.147 1.146a.5.5 0 0 0 .708.708L8 10.707l1.146 1.147a.5.5 0 0 0 .708-.708L8.707 10l1.147-1.146a.5.5 0 0 0-.708-.708L8 9.293 6.854 8.146z\"}}]})(props);\n};\nexport function BsFillBarChartFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 11a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1v-3zm5-4a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v7a1 1 0 0 1-1 1H7a1 1 0 0 1-1-1V7zm5-5a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1h-2a1 1 0 0 1-1-1V2z\"}}]})(props);\n};\nexport function BsFillBarChartLineFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 2a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v12h.5a.5.5 0 0 1 0 1H.5a.5.5 0 0 1 0-1H1v-3a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v3h1V7a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v7h1V2z\"}}]})(props);\n};\nexport function BsFillBasketFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.071 1.243a.5.5 0 0 1 .858.514L3.383 6h9.234L10.07 1.757a.5.5 0 1 1 .858-.514L13.783 6H15.5a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5H15v5a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V9H.5a.5.5 0 0 1-.5-.5v-2A.5.5 0 0 1 .5 6h1.717L5.07 1.243zM3.5 10.5a.5.5 0 1 0-1 0v3a.5.5 0 0 0 1 0v-3zm2.5 0a.5.5 0 1 0-1 0v3a.5.5 0 0 0 1 0v-3zm2.5 0a.5.5 0 1 0-1 0v3a.5.5 0 0 0 1 0v-3zm2.5 0a.5.5 0 1 0-1 0v3a.5.5 0 0 0 1 0v-3zm2.5 0a.5.5 0 1 0-1 0v3a.5.5 0 0 0 1 0v-3z\"}}]})(props);\n};\nexport function BsFillBasket2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.929 1.757a.5.5 0 1 0-.858-.514L2.217 6H.5a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h.623l1.844 6.456A.75.75 0 0 0 3.69 15h8.622a.75.75 0 0 0 .722-.544L14.877 8h.623a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1.717L10.93 1.243a.5.5 0 1 0-.858.514L12.617 6H3.383L5.93 1.757zM4 10a1 1 0 0 1 2 0v2a1 1 0 1 1-2 0v-2zm3 0a1 1 0 0 1 2 0v2a1 1 0 1 1-2 0v-2zm4-1a1 1 0 0 1 1 1v2a1 1 0 1 1-2 0v-2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFillBasket3Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.757 1.071a.5.5 0 0 1 .172.686L3.383 6h9.234L10.07 1.757a.5.5 0 1 1 .858-.514L13.783 6H15.5a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5H.5a.5.5 0 0 1-.5-.5v-1A.5.5 0 0 1 .5 6h1.717L5.07 1.243a.5.5 0 0 1 .686-.172zM2.468 15.426.943 9h14.114l-1.525 6.426a.75.75 0 0 1-.729.574H3.197a.75.75 0 0 1-.73-.574z\"}}]})(props);\n};\nexport function BsFillBellFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16a2 2 0 0 0 2-2H6a2 2 0 0 0 2 2zm.995-14.901a1 1 0 1 0-1.99 0A5.002 5.002 0 0 0 3 6c0 1.098-.5 6-2 7h14c-1.5-1-2-5.902-2-7 0-2.42-1.72-4.44-4.005-4.901z\"}}]})(props);\n};\nexport function BsFillBellSlashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.164 14H15c-1.5-1-2-5.902-2-7 0-.264-.02-.523-.06-.776L5.164 14zm6.288-10.617A4.988 4.988 0 0 0 8.995 2.1a1 1 0 1 0-1.99 0A5.002 5.002 0 0 0 3 7c0 .898-.335 4.342-1.278 6.113l9.73-9.73zM10 15a2 2 0 1 1-4 0h4zm-9.375.625a.53.53 0 0 0 .75.75l14.75-14.75a.53.53 0 0 0-.75-.75L.625 15.625z\"}}]})(props);\n};\nexport function BsFillBinocularsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 1A1.5 1.5 0 0 0 3 2.5V3h4v-.5A1.5 1.5 0 0 0 5.5 1h-1zM7 4v1h2V4h4v.882a.5.5 0 0 0 .276.447l.895.447A1.5 1.5 0 0 1 15 7.118V13H9v-1.5a.5.5 0 0 1 .146-.354l.854-.853V9.5a.5.5 0 0 0-.5-.5h-3a.5.5 0 0 0-.5.5v.793l.854.853A.5.5 0 0 1 7 11.5V13H1V7.118a1.5 1.5 0 0 1 .83-1.342l.894-.447A.5.5 0 0 0 3 4.882V4h4zM1 14v.5A1.5 1.5 0 0 0 2.5 16h3A1.5 1.5 0 0 0 7 14.5V14H1zm8 0v.5a1.5 1.5 0 0 0 1.5 1.5h3a1.5 1.5 0 0 0 1.5-1.5V14H9zm4-11H9v-.5A1.5 1.5 0 0 1 10.5 1h1A1.5 1.5 0 0 1 13 2.5V3z\"}}]})(props);\n};\nexport function BsFillBookFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1.783C7.015.936 5.587.81 4.287.94c-1.514.153-3.042.672-3.994 1.105A.5.5 0 0 0 0 2.5v11a.5.5 0 0 0 .707.455c.882-.4 2.303-.881 3.68-1.02 1.409-.142 2.59.087 3.223.877a.5.5 0 0 0 .78 0c.633-.79 1.814-1.019 3.222-.877 1.378.139 2.8.62 3.681 1.02A.5.5 0 0 0 16 13.5v-11a.5.5 0 0 0-.293-.455c-.952-.433-2.48-.952-3.994-1.105C10.413.809 8.985.936 8 1.783z\"}}]})(props);\n};\nexport function BsFillBookmarkCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 15.5V2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.74.439L8 13.069l-5.26 2.87A.5.5 0 0 1 2 15.5zm8.854-9.646a.5.5 0 0 0-.708-.708L7.5 7.793 6.354 6.646a.5.5 0 1 0-.708.708l1.5 1.5a.5.5 0 0 0 .708 0l3-3z\"}}]})(props);\n};\nexport function BsFillBookmarkDashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 15.5V2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.74.439L8 13.069l-5.26 2.87A.5.5 0 0 1 2 15.5zM6 6a.5.5 0 0 0 0 1h4a.5.5 0 0 0 0-1H6z\"}}]})(props);\n};\nexport function BsFillBookmarkFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2v13.5a.5.5 0 0 0 .74.439L8 13.069l5.26 2.87A.5.5 0 0 0 14 15.5V2a2 2 0 0 0-2-2H4a2 2 0 0 0-2 2z\"}}]})(props);\n};\nexport function BsFillBookmarkHeartFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 15.5a.5.5 0 0 0 .74.439L8 13.069l5.26 2.87A.5.5 0 0 0 14 15.5V2a2 2 0 0 0-2-2H4a2 2 0 0 0-2 2v13.5zM8 4.41c1.387-1.425 4.854 1.07 0 4.277C3.146 5.48 6.613 2.986 8 4.412z\"}}]})(props);\n};\nexport function BsFillBookmarkPlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 15.5V2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.74.439L8 13.069l-5.26 2.87A.5.5 0 0 1 2 15.5zm6.5-11a.5.5 0 0 0-1 0V6H6a.5.5 0 0 0 0 1h1.5v1.5a.5.5 0 0 0 1 0V7H10a.5.5 0 0 0 0-1H8.5V4.5z\"}}]})(props);\n};\nexport function BsFillBookmarkStarFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 15.5V2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.74.439L8 13.069l-5.26 2.87A.5.5 0 0 1 2 15.5zM8.16 4.1a.178.178 0 0 0-.32 0l-.634 1.285a.178.178 0 0 1-.134.098l-1.42.206a.178.178 0 0 0-.098.303L6.58 6.993c.042.041.061.1.051.158L6.39 8.565a.178.178 0 0 0 .258.187l1.27-.668a.178.178 0 0 1 .165 0l1.27.668a.178.178 0 0 0 .257-.187L9.368 7.15a.178.178 0 0 1 .05-.158l1.028-1.001a.178.178 0 0 0-.098-.303l-1.42-.206a.178.178 0 0 1-.134-.098L8.16 4.1z\"}}]})(props);\n};\nexport function BsFillBookmarkXFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 15.5V2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.74.439L8 13.069l-5.26 2.87A.5.5 0 0 1 2 15.5zM6.854 5.146a.5.5 0 1 0-.708.708L7.293 7 6.146 8.146a.5.5 0 1 0 .708.708L8 7.707l1.146 1.147a.5.5 0 1 0 .708-.708L8.707 7l1.147-1.146a.5.5 0 0 0-.708-.708L8 6.293 6.854 5.146z\"}}]})(props);\n};\nexport function BsFillBookmarksFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 4a2 2 0 0 1 2-2h6a2 2 0 0 1 2 2v11.5a.5.5 0 0 1-.777.416L7 13.101l-4.223 2.815A.5.5 0 0 1 2 15.5V4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.268 1A2 2 0 0 1 6 0h6a2 2 0 0 1 2 2v11.5a.5.5 0 0 1-.777.416L13 13.768V2a1 1 0 0 0-1-1H4.268z\"}}]})(props);\n};\nexport function BsFillBootstrapFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.375 7.125V4.658h1.78c.973 0 1.542.457 1.542 1.237 0 .802-.604 1.23-1.764 1.23H6.375zm0 3.762h1.898c1.184 0 1.81-.48 1.81-1.377 0-.885-.65-1.348-1.886-1.348H6.375v2.725z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.002 0a4 4 0 0 0-4 4v8a4 4 0 0 0 4 4h8a4 4 0 0 0 4-4V4a4 4 0 0 0-4-4h-8zm1.06 12V3.545h3.399c1.587 0 2.543.809 2.543 2.11 0 .884-.65 1.675-1.483 1.816v.1c1.143.117 1.904.931 1.904 2.033 0 1.488-1.084 2.396-2.888 2.396H5.062z\"}}]})(props);\n};\nexport function BsFillBriefcaseFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 1A1.5 1.5 0 0 0 5 2.5V3H1.5A1.5 1.5 0 0 0 0 4.5v1.384l7.614 2.03a1.5 1.5 0 0 0 .772 0L16 5.884V4.5A1.5 1.5 0 0 0 14.5 3H11v-.5A1.5 1.5 0 0 0 9.5 1h-3zm0 1h3a.5.5 0 0 1 .5.5V3H6v-.5a.5.5 0 0 1 .5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12.5A1.5 1.5 0 0 0 1.5 14h13a1.5 1.5 0 0 0 1.5-1.5V6.85L8.129 8.947a.5.5 0 0 1-.258 0L0 6.85v5.65z\"}}]})(props);\n};\nexport function BsFillBrightnessAltHighFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 3a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 3zm8 8a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2a.5.5 0 0 1 .5.5zm-13.5.5a.5.5 0 0 0 0-1h-2a.5.5 0 0 0 0 1h2zm11.157-6.157a.5.5 0 0 1 0 .707l-1.414 1.414a.5.5 0 1 1-.707-.707l1.414-1.414a.5.5 0 0 1 .707 0zm-9.9 2.121a.5.5 0 0 0 .707-.707L3.05 5.343a.5.5 0 1 0-.707.707l1.414 1.414zM8 7a4 4 0 0 0-4 4 .5.5 0 0 0 .5.5h7a.5.5 0 0 0 .5-.5 4 4 0 0 0-4-4z\"}}]})(props);\n};\nexport function BsFillBrightnessAltLowFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 5.5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm5 6a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zM2 11a.5.5 0 1 0 1 0 .5.5 0 0 0-1 0zm10.243-3.536a.5.5 0 1 1-.707-.707.5.5 0 0 1 .707.707zm-8.486-.707a.5.5 0 1 0 .707.707.5.5 0 0 0-.707-.707zM8 7a4 4 0 0 0-4 4 .5.5 0 0 0 .5.5h7a.5.5 0 0 0 .5-.5 4 4 0 0 0-4-4z\"}}]})(props);\n};\nexport function BsFillBrightnessHighFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8a4 4 0 1 1-8 0 4 4 0 0 1 8 0zM8 0a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 0zm0 13a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 13zm8-5a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2a.5.5 0 0 1 .5.5zM3 8a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2A.5.5 0 0 1 3 8zm10.657-5.657a.5.5 0 0 1 0 .707l-1.414 1.415a.5.5 0 1 1-.707-.708l1.414-1.414a.5.5 0 0 1 .707 0zm-9.193 9.193a.5.5 0 0 1 0 .707L3.05 13.657a.5.5 0 0 1-.707-.707l1.414-1.414a.5.5 0 0 1 .707 0zm9.193 2.121a.5.5 0 0 1-.707 0l-1.414-1.414a.5.5 0 0 1 .707-.707l1.414 1.414a.5.5 0 0 1 0 .707zM4.464 4.465a.5.5 0 0 1-.707 0L2.343 3.05a.5.5 0 1 1 .707-.707l1.414 1.414a.5.5 0 0 1 0 .708z\"}}]})(props);\n};\nexport function BsFillBrightnessLowFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8a4 4 0 1 1-8 0 4 4 0 0 1 8 0zM8.5 2.5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm0 11a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm5-5a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm-11 0a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm9.743-4.036a.5.5 0 1 1-.707-.707.5.5 0 0 1 .707.707zm-7.779 7.779a.5.5 0 1 1-.707-.707.5.5 0 0 1 .707.707zm7.072 0a.5.5 0 1 1 .707-.707.5.5 0 0 1-.707.707zM3.757 4.464a.5.5 0 1 1 .707-.707.5.5 0 0 1-.707.707z\"}}]})(props);\n};\nexport function BsFillBrushFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.825.12a.5.5 0 0 1 .132.584c-1.53 3.43-4.743 8.17-7.095 10.64a6.067 6.067 0 0 1-2.373 1.534c-.018.227-.06.538-.16.868-.201.659-.667 1.479-1.708 1.74a8.118 8.118 0 0 1-3.078.132 3.659 3.659 0 0 1-.562-.135 1.382 1.382 0 0 1-.466-.247.714.714 0 0 1-.204-.288.622.622 0 0 1 .004-.443c.095-.245.316-.38.461-.452.394-.197.625-.453.867-.826.095-.144.184-.297.287-.472l.117-.198c.151-.255.326-.54.546-.848.528-.739 1.201-.925 1.746-.896.126.007.243.025.348.048.062-.172.142-.38.238-.608.261-.619.658-1.419 1.187-2.069 2.176-2.67 6.18-6.206 9.117-8.104a.5.5 0 0 1 .596.04z\"}}]})(props);\n};\nexport function BsFillBucketFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.522 5H2a.5.5 0 0 0-.494.574l1.372 9.149A1.5 1.5 0 0 0 4.36 16h7.278a1.5 1.5 0 0 0 1.483-1.277l1.373-9.149A.5.5 0 0 0 14 5h-.522A5.5 5.5 0 0 0 2.522 5zm1.005 0a4.5 4.5 0 0 1 8.945 0H3.527z\"}}]})(props);\n};\nexport function BsFillBugFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.978.855a.5.5 0 1 0-.956.29l.41 1.352A4.985 4.985 0 0 0 3 6h10a4.985 4.985 0 0 0-1.432-3.503l.41-1.352a.5.5 0 1 0-.956-.29l-.291.956A4.978 4.978 0 0 0 8 1a4.979 4.979 0 0 0-2.731.811l-.29-.956z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 6v1H8.5v8.975A5 5 0 0 0 13 11h.5a.5.5 0 0 1 .5.5v.5a.5.5 0 1 0 1 0v-.5a1.5 1.5 0 0 0-1.5-1.5H13V9h1.5a.5.5 0 0 0 0-1H13V7h.5A1.5 1.5 0 0 0 15 5.5V5a.5.5 0 0 0-1 0v.5a.5.5 0 0 1-.5.5H13zm-5.5 9.975V7H3V6h-.5a.5.5 0 0 1-.5-.5V5a.5.5 0 0 0-1 0v.5A1.5 1.5 0 0 0 2.5 7H3v1H1.5a.5.5 0 0 0 0 1H3v1h-.5A1.5 1.5 0 0 0 1 11.5v.5a.5.5 0 1 0 1 0v-.5a.5.5 0 0 1 .5-.5H3a5 5 0 0 0 4.5 4.975z\"}}]})(props);\n};\nexport function BsFillCalculatorFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm2 .5v2a.5.5 0 0 0 .5.5h7a.5.5 0 0 0 .5-.5v-2a.5.5 0 0 0-.5-.5h-7a.5.5 0 0 0-.5.5zm0 4v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5zM4.5 9a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zM4 12.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5zM7.5 6a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zM7 9.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5zm.5 2.5a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zM10 6.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5zm.5 2.5a.5.5 0 0 0-.5.5v4a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-4a.5.5 0 0 0-.5-.5h-1z\"}}]})(props);\n};\nexport function BsFillCalendarCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM16 14V5H0v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2zm-5.146-5.146-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 0 1 .708-.708L7.5 10.793l2.646-2.647a.5.5 0 0 1 .708.708z\"}}]})(props);\n};\nexport function BsFillCalendarDateFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zm5.402 9.746c.625 0 1.184-.484 1.184-1.18 0-.832-.527-1.23-1.16-1.23-.586 0-1.168.387-1.168 1.21 0 .817.543 1.2 1.144 1.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 14V5H0v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2zm-6.664-1.21c-1.11 0-1.656-.767-1.703-1.407h.683c.043.37.387.82 1.051.82.844 0 1.301-.848 1.305-2.164h-.027c-.153.414-.637.79-1.383.79-.852 0-1.676-.61-1.676-1.77 0-1.137.871-1.809 1.797-1.809 1.172 0 1.953.734 1.953 2.668 0 1.805-.742 2.871-2 2.871zm-2.89-5.435v5.332H5.77V8.079h-.012c-.29.156-.883.52-1.258.777V8.16a12.6 12.6 0 0 1 1.313-.805h.632z\"}}]})(props);\n};\nexport function BsFillCalendarDayFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM16 14a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V5h16v9zm-4.785-6.145a.428.428 0 1 0 0-.855.426.426 0 0 0-.43.43c0 .238.192.425.43.425zm.336.563h-.672v4.105h.672V8.418zm-6.867 4.105v-2.3h2.261v-.61H4.684V7.801h2.464v-.61H4v5.332h.684zm3.296 0h.676V9.98c0-.554.227-1.007.953-1.007.125 0 .258.004.329.015v-.613a1.806 1.806 0 0 0-.254-.02c-.582 0-.891.32-1.012.567h-.02v-.504H7.98v4.105z\"}}]})(props);\n};\nexport function BsFillCalendarEventFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM16 14V5H0v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2zm-3.5-7h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsFillCalendarFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V5h16V4H0V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsFillCalendarMinusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM16 14V5H0v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2zM6 10h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFillCalendarMonthFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zm.104 7.305L4.9 10.18H3.284l.8-2.375h.02zm9.074 2.297c0-.832-.414-1.36-1.062-1.36-.692 0-1.098.492-1.098 1.36v.253c0 .852.406 1.364 1.098 1.364.671 0 1.062-.516 1.062-1.364v-.253z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 14V5H0v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2zM2.56 12.332h-.71L3.748 7h.696l1.898 5.332h-.719l-.539-1.602H3.1l-.54 1.602zm7.29-4.105v4.105h-.668v-.539h-.027c-.145.324-.532.605-1.188.605-.847 0-1.453-.484-1.453-1.425V8.227h.676v2.554c0 .766.441 1.012.98 1.012.59 0 1.004-.371 1.004-1.023V8.227h.676zm1.273 4.41c.075.332.422.636.985.636.648 0 1.07-.378 1.07-1.023v-.605h-.02c-.163.355-.613.648-1.171.648-.957 0-1.64-.672-1.64-1.902v-.34c0-1.207.675-1.887 1.64-1.887.558 0 1.004.293 1.195.64h.02v-.577h.648v4.03c0 1.052-.816 1.579-1.746 1.579-1.043 0-1.574-.516-1.668-1.2h.687z\"}}]})(props);\n};\nexport function BsFillCalendarPlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM16 14V5H0v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2zM8.5 8.5V10H10a.5.5 0 0 1 0 1H8.5v1.5a.5.5 0 0 1-1 0V11H6a.5.5 0 0 1 0-1h1.5V8.5a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFillCalendarRangeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM16 7V5H0v5h5a1 1 0 1 1 0 2H0v2a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V9h-6a1 1 0 1 1 0-2h6z\"}}]})(props);\n};\nexport function BsFillCalendarWeekFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM16 14V5H0v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2zM9.5 7h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5zm3 0h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5zM2 10.5a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm3.5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsFillCalendarXFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM16 14V5H0v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2zM6.854 8.146 8 9.293l1.146-1.147a.5.5 0 1 1 .708.708L8.707 10l1.147 1.146a.5.5 0 0 1-.708.708L8 10.707l-1.146 1.147a.5.5 0 0 1-.708-.708L7.293 10 6.146 8.854a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsFillCalendar2CheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zm-2.6 5.854a.5.5 0 0 0-.708-.708L7.5 10.793 6.354 9.646a.5.5 0 1 0-.708.708l1.5 1.5a.5.5 0 0 0 .708 0l3-3z\"}}]})(props);\n};\nexport function BsFillCalendar2DateFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.402 10.246c.625 0 1.184-.484 1.184-1.18 0-.832-.527-1.23-1.16-1.23-.586 0-1.168.387-1.168 1.21 0 .817.543 1.2 1.144 1.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zm-4.118 9.79c1.258 0 2-1.067 2-2.872 0-1.934-.781-2.668-1.953-2.668-.926 0-1.797.672-1.797 1.809 0 1.16.824 1.77 1.676 1.77.746 0 1.23-.376 1.383-.79h.027c-.004 1.316-.461 2.164-1.305 2.164-.664 0-1.008-.45-1.05-.82h-.684c.047.64.594 1.406 1.703 1.406zm-2.89-5.435h-.633A12.6 12.6 0 0 0 4.5 8.16v.695c.375-.257.969-.62 1.258-.777h.012v4.61h.675V7.354z\"}}]})(props);\n};\nexport function BsFillCalendar2DayFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zm-2.24 4.855a.428.428 0 1 0 0-.855.426.426 0 0 0-.429.43c0 .238.192.425.43.425zm.337.563h-.672v4.105h.672V8.418zm-6.867 4.105v-2.3h2.261v-.61H4.684V7.801h2.464v-.61H4v5.332h.684zm3.296 0h.676V9.98c0-.554.227-1.007.953-1.007.125 0 .258.004.329.015v-.613a1.806 1.806 0 0 0-.254-.02c-.582 0-.891.32-1.012.567h-.02v-.504H7.98v4.105z\"}}]})(props);\n};\nexport function BsFillCalendar2EventFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zM11.5 7a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1z\"}}]})(props);\n};\nexport function BsFillCalendar2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v11a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM2.545 3h10.91c.3 0 .545.224.545.5v1c0 .276-.244.5-.546.5H2.545C2.245 5 2 4.776 2 4.5v-1c0-.276.244-.5.545-.5z\"}}]})(props);\n};\nexport function BsFillCalendar2MinusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zM6 10a.5.5 0 0 0 0 1h4a.5.5 0 0 0 0-1H6z\"}}]})(props);\n};\nexport function BsFillCalendar2MonthFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.104 7.805 4.9 10.18H3.284l.8-2.375h.02zm9.074 2.297c0-.832-.414-1.36-1.062-1.36-.692 0-1.098.492-1.098 1.36v.253c0 .852.406 1.364 1.098 1.364.671 0 1.062-.516 1.062-1.364v-.253z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zM2.561 12.332 3.1 10.73h1.984l.54 1.602h.718L4.444 7h-.696L1.85 12.332h.71zM9.85 8.227h-.676v2.543c0 .652-.414 1.023-1.004 1.023-.539 0-.98-.246-.98-1.012V8.227h-.676v2.746c0 .941.606 1.425 1.453 1.425.656 0 1.043-.28 1.188-.605h.027v.539h.668V8.227zm1.273 4.41h-.687c.094.683.625 1.199 1.668 1.199.93 0 1.746-.527 1.746-1.578V8.227h-.649v.578h-.019c-.191-.348-.637-.64-1.195-.64-.965 0-1.64.679-1.64 1.886v.34c0 1.23.683 1.902 1.64 1.902.558 0 1.008-.293 1.172-.648h.02v.605c0 .645-.423 1.023-1.071 1.023-.563 0-.91-.304-.985-.636z\"}}]})(props);\n};\nexport function BsFillCalendar2PlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 3.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5H2.545c-.3 0-.545.224-.545.5zm6.5 5a.5.5 0 0 0-1 0V10H6a.5.5 0 0 0 0 1h1.5v1.5a.5.5 0 0 0 1 0V11H10a.5.5 0 0 0 0-1H8.5V8.5z\"}}]})(props);\n};\nexport function BsFillCalendar2RangeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zM10 7a1 1 0 0 0 0 2h5V7h-5zm-4 4a1 1 0 0 0-1-1H1v2h4a1 1 0 0 0 1-1z\"}}]})(props);\n};\nexport function BsFillCalendar2WeekFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zM8.5 7a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zm3 0a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zM3 10.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5zm3.5-.5a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1z\"}}]})(props);\n};\nexport function BsFillCalendar2XFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zm-6.6 5.146a.5.5 0 1 0-.708.708L7.293 10l-1.147 1.146a.5.5 0 0 0 .708.708L8 10.707l1.146 1.147a.5.5 0 0 0 .708-.708L8.707 10l1.147-1.146a.5.5 0 0 0-.708-.708L8 9.293 6.854 8.146z\"}}]})(props);\n};\nexport function BsFillCalendar3EventFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 0a2 2 0 0 0-2 2h16a2 2 0 0 0-2-2H2zM0 14V3h16v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm12-8a1 1 0 1 0 2 0 1 1 0 0 0-2 0z\"}}]})(props);\n};\nexport function BsFillCalendar3Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2H0zm0 1v11a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V3H0z\"}}]})(props);\n};\nexport function BsFillCalendar3RangeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 0a2 2 0 0 0-2 2h16a2 2 0 0 0-2-2H2zM0 8V3h16v2h-6a1 1 0 1 0 0 2h6v7a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2v-4h6a1 1 0 1 0 0-2H0z\"}}]})(props);\n};\nexport function BsFillCalendar3WeekFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 0a2 2 0 0 0-2 2h16a2 2 0 0 0-2-2H2zM0 14V3h16v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm12-8a1 1 0 1 0 2 0 1 1 0 0 0-2 0zM5 9a1 1 0 1 0 2 0 1 1 0 0 0-2 0zm5-2a1 1 0 1 1 0-2 1 1 0 0 1 0 2zM2 9a1 1 0 1 0 2 0 1 1 0 0 0-2 0z\"}}]})(props);\n};\nexport function BsFillCameraFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 8.5a2.5 2.5 0 1 1-5 0 2.5 2.5 0 0 1 5 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 4a2 2 0 0 0-2 2v6a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2h-1.172a2 2 0 0 1-1.414-.586l-.828-.828A2 2 0 0 0 9.172 2H6.828a2 2 0 0 0-1.414.586l-.828.828A2 2 0 0 1 3.172 4H2zm.5 2a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm9 2.5a3.5 3.5 0 1 1-7 0 3.5 3.5 0 0 1 7 0z\"}}]})(props);\n};\nexport function BsFillCameraReelsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 3a3 3 0 1 1-6 0 3 3 0 0 1 6 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 6a3 3 0 1 1 0-6 3 3 0 0 1 0 6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 6h.5a2 2 0 0 1 1.983 1.738l3.11-1.382A1 1 0 0 1 16 7.269v7.462a1 1 0 0 1-1.406.913l-3.111-1.382A2 2 0 0 1 9.5 16H2a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h7z\"}}]})(props);\n};\nexport function BsFillCameraVideoFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M0 5a2 2 0 0 1 2-2h7.5a2 2 0 0 1 1.983 1.738l3.11-1.382A1 1 0 0 1 16 4.269v7.462a1 1 0 0 1-1.406.913l-3.111-1.382A2 2 0 0 1 9.5 13H2a2 2 0 0 1-2-2V5z\"}}]})(props);\n};\nexport function BsFillCameraVideoOffFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.961 12.365a1.99 1.99 0 0 0 .522-1.103l3.11 1.382A1 1 0 0 0 16 11.731V4.269a1 1 0 0 0-1.406-.913l-3.111 1.382A2 2 0 0 0 9.5 3H4.272l6.69 9.365zm-10.114-9A2.001 2.001 0 0 0 0 5v6a2 2 0 0 0 2 2h5.728L.847 3.366zm9.746 11.925-10-14 .814-.58 10 14-.814.58z\"}}]})(props);\n};\nexport function BsFillCapslockFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.27 1.047a1 1 0 0 1 1.46 0l6.345 6.77c.6.638.146 1.683-.73 1.683H11.5v1a1 1 0 0 1-1 1h-5a1 1 0 0 1-1-1v-1H1.654C.78 9.5.326 8.455.924 7.816L7.27 1.047zM4.5 13.5a1 1 0 0 1 1-1h5a1 1 0 0 1 1 1v1a1 1 0 0 1-1 1h-5a1 1 0 0 1-1-1v-1z\"}}]})(props);\n};\nexport function BsFillCaretDownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z\"}}]})(props);\n};\nexport function BsFillCaretDownSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm4 4a.5.5 0 0 0-.374.832l4 4.5a.5.5 0 0 0 .748 0l4-4.5A.5.5 0 0 0 12 6H4z\"}}]})(props);\n};\nexport function BsFillCaretLeftFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m3.86 8.753 5.482 4.796c.646.566 1.658.106 1.658-.753V3.204a1 1 0 0 0-1.659-.753l-5.48 4.796a1 1 0 0 0 0 1.506z\"}}]})(props);\n};\nexport function BsFillCaretLeftSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm10.5 10V4a.5.5 0 0 0-.832-.374l-4.5 4a.5.5 0 0 0 0 .748l4.5 4A.5.5 0 0 0 10.5 12z\"}}]})(props);\n};\nexport function BsFillCaretRightFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m12.14 8.753-5.482 4.796c-.646.566-1.658.106-1.658-.753V3.204a1 1 0 0 1 1.659-.753l5.48 4.796a1 1 0 0 1 0 1.506z\"}}]})(props);\n};\nexport function BsFillCaretRightSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm5.5 10a.5.5 0 0 0 .832.374l4.5-4a.5.5 0 0 0 0-.748l-4.5-4A.5.5 0 0 0 5.5 4v8z\"}}]})(props);\n};\nexport function BsFillCaretUpFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m7.247 4.86-4.796 5.481c-.566.647-.106 1.659.753 1.659h9.592a1 1 0 0 0 .753-1.659l-4.796-5.48a1 1 0 0 0-1.506 0z\"}}]})(props);\n};\nexport function BsFillCaretUpSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm4 9h8a.5.5 0 0 0 .374-.832l-4-4.5a.5.5 0 0 0-.748 0l-4 4.5A.5.5 0 0 0 4 11z\"}}]})(props);\n};\nexport function BsFillCartCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 1a.5.5 0 0 0 0 1h1.11l.401 1.607 1.498 7.985A.5.5 0 0 0 4 12h1a2 2 0 1 0 0 4 2 2 0 0 0 0-4h7a2 2 0 1 0 0 4 2 2 0 0 0 0-4h1a.5.5 0 0 0 .491-.408l1.5-8A.5.5 0 0 0 14.5 3H2.89l-.405-1.621A.5.5 0 0 0 2 1H.5zM6 14a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm7 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm-1.646-7.646-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L8 8.293l2.646-2.647a.5.5 0 0 1 .708.708z\"}}]})(props);\n};\nexport function BsFillCartDashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 1a.5.5 0 0 0 0 1h1.11l.401 1.607 1.498 7.985A.5.5 0 0 0 4 12h1a2 2 0 1 0 0 4 2 2 0 0 0 0-4h7a2 2 0 1 0 0 4 2 2 0 0 0 0-4h1a.5.5 0 0 0 .491-.408l1.5-8A.5.5 0 0 0 14.5 3H2.89l-.405-1.621A.5.5 0 0 0 2 1H.5zM6 14a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm7 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zM6.5 7h4a.5.5 0 0 1 0 1h-4a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFillCartFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1.5A.5.5 0 0 1 .5 1H2a.5.5 0 0 1 .485.379L2.89 3H14.5a.5.5 0 0 1 .491.592l-1.5 8A.5.5 0 0 1 13 12H4a.5.5 0 0 1-.491-.408L2.01 3.607 1.61 2H.5a.5.5 0 0 1-.5-.5zM5 12a2 2 0 1 0 0 4 2 2 0 0 0 0-4zm7 0a2 2 0 1 0 0 4 2 2 0 0 0 0-4zm-7 1a1 1 0 1 1 0 2 1 1 0 0 1 0-2zm7 0a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\"}}]})(props);\n};\nexport function BsFillCartPlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 1a.5.5 0 0 0 0 1h1.11l.401 1.607 1.498 7.985A.5.5 0 0 0 4 12h1a2 2 0 1 0 0 4 2 2 0 0 0 0-4h7a2 2 0 1 0 0 4 2 2 0 0 0 0-4h1a.5.5 0 0 0 .491-.408l1.5-8A.5.5 0 0 0 14.5 3H2.89l-.405-1.621A.5.5 0 0 0 2 1H.5zM6 14a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm7 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zM9 5.5V7h1.5a.5.5 0 0 1 0 1H9v1.5a.5.5 0 0 1-1 0V8H6.5a.5.5 0 0 1 0-1H8V5.5a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFillCartXFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 1a.5.5 0 0 0 0 1h1.11l.401 1.607 1.498 7.985A.5.5 0 0 0 4 12h1a2 2 0 1 0 0 4 2 2 0 0 0 0-4h7a2 2 0 1 0 0 4 2 2 0 0 0 0-4h1a.5.5 0 0 0 .491-.408l1.5-8A.5.5 0 0 0 14.5 3H2.89l-.405-1.621A.5.5 0 0 0 2 1H.5zM6 14a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm7 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zM7.354 5.646 8.5 6.793l1.146-1.147a.5.5 0 0 1 .708.708L9.207 7.5l1.147 1.146a.5.5 0 0 1-.708.708L8.5 8.207 7.354 9.354a.5.5 0 1 1-.708-.708L7.793 7.5 6.646 6.354a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsFillChatDotsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8c0 3.866-3.582 7-8 7a9.06 9.06 0 0 1-2.347-.306c-.584.296-1.925.864-4.181 1.234-.2.032-.352-.176-.273-.362.354-.836.674-1.95.77-2.966C.744 11.37 0 9.76 0 8c0-3.866 3.582-7 8-7s8 3.134 8 7zM5 8a1 1 0 1 0-2 0 1 1 0 0 0 2 0zm4 0a1 1 0 1 0-2 0 1 1 0 0 0 2 0zm3 1a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsFillChatFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15c4.418 0 8-3.134 8-7s-3.582-7-8-7-8 3.134-8 7c0 1.76.743 3.37 1.97 4.6-.097 1.016-.417 2.13-.771 2.966-.079.186.074.394.273.362 2.256-.37 3.597-.938 4.18-1.234A9.06 9.06 0 0 0 8 15z\"}}]})(props);\n};\nexport function BsFillChatLeftDotsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H4.414a1 1 0 0 0-.707.293L.854 15.146A.5.5 0 0 1 0 14.793V2zm5 4a1 1 0 1 0-2 0 1 1 0 0 0 2 0zm4 0a1 1 0 1 0-2 0 1 1 0 0 0 2 0zm3 1a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsFillChatLeftFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12.793a.5.5 0 0 0 .854.353l2.853-2.853A1 1 0 0 1 4.414 12H14a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsFillChatLeftQuoteFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H4.414a1 1 0 0 0-.707.293L.854 15.146A.5.5 0 0 1 0 14.793V2zm7.194 2.766a1.688 1.688 0 0 0-.227-.272 1.467 1.467 0 0 0-.469-.324l-.008-.004A1.785 1.785 0 0 0 5.734 4C4.776 4 4 4.746 4 5.667c0 .92.776 1.666 1.734 1.666.343 0 .662-.095.931-.26-.137.389-.39.804-.81 1.22a.405.405 0 0 0 .011.59c.173.16.447.155.614-.01 1.334-1.329 1.37-2.758.941-3.706a2.461 2.461 0 0 0-.227-.4zM11 7.073c-.136.389-.39.804-.81 1.22a.405.405 0 0 0 .012.59c.172.16.446.155.613-.01 1.334-1.329 1.37-2.758.942-3.706a2.466 2.466 0 0 0-.228-.4 1.686 1.686 0 0 0-.227-.273 1.466 1.466 0 0 0-.469-.324l-.008-.004A1.785 1.785 0 0 0 10.07 4c-.957 0-1.734.746-1.734 1.667 0 .92.777 1.666 1.734 1.666.343 0 .662-.095.931-.26z\"}}]})(props);\n};\nexport function BsFillChatLeftTextFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H4.414a1 1 0 0 0-.707.293L.854 15.146A.5.5 0 0 1 0 14.793V2zm3.5 1a.5.5 0 0 0 0 1h9a.5.5 0 0 0 0-1h-9zm0 2.5a.5.5 0 0 0 0 1h9a.5.5 0 0 0 0-1h-9zm0 2.5a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5z\"}}]})(props);\n};\nexport function BsFillChatQuoteFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8c0 3.866-3.582 7-8 7a9.06 9.06 0 0 1-2.347-.306c-.584.296-1.925.864-4.181 1.234-.2.032-.352-.176-.273-.362.354-.836.674-1.95.77-2.966C.744 11.37 0 9.76 0 8c0-3.866 3.582-7 8-7s8 3.134 8 7zM7.194 6.766a1.688 1.688 0 0 0-.227-.272 1.467 1.467 0 0 0-.469-.324l-.008-.004A1.785 1.785 0 0 0 5.734 6C4.776 6 4 6.746 4 7.667c0 .92.776 1.666 1.734 1.666.343 0 .662-.095.931-.26-.137.389-.39.804-.81 1.22a.405.405 0 0 0 .011.59c.173.16.447.155.614-.01 1.334-1.329 1.37-2.758.941-3.706a2.461 2.461 0 0 0-.227-.4zM11 9.073c-.136.389-.39.804-.81 1.22a.405.405 0 0 0 .012.59c.172.16.446.155.613-.01 1.334-1.329 1.37-2.758.942-3.706a2.466 2.466 0 0 0-.228-.4 1.686 1.686 0 0 0-.227-.273 1.466 1.466 0 0 0-.469-.324l-.008-.004A1.785 1.785 0 0 0 10.07 6c-.957 0-1.734.746-1.734 1.667 0 .92.777 1.666 1.734 1.666.343 0 .662-.095.931-.26z\"}}]})(props);\n};\nexport function BsFillChatRightDotsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 2a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h9.586a1 1 0 0 1 .707.293l2.853 2.853a.5.5 0 0 0 .854-.353V2zM5 6a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm4 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm3 1a1 1 0 1 1 0-2 1 1 0 0 1 0 2z\"}}]})(props);\n};\nexport function BsFillChatRightFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 0a2 2 0 0 1 2 2v12.793a.5.5 0 0 1-.854.353l-2.853-2.853a1 1 0 0 0-.707-.293H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12z\"}}]})(props);\n};\nexport function BsFillChatRightQuoteFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 2a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h9.586a1 1 0 0 1 .707.293l2.853 2.853a.5.5 0 0 0 .854-.353V2zM7.194 4.766c.087.124.163.26.227.401.428.948.393 2.377-.942 3.706a.446.446 0 0 1-.612.01.405.405 0 0 1-.011-.59c.419-.416.672-.831.809-1.22-.269.165-.588.26-.93.26C4.775 7.333 4 6.587 4 5.667 4 4.747 4.776 4 5.734 4c.271 0 .528.06.756.166l.008.004c.169.07.327.182.469.324.085.083.161.174.227.272zM11 7.073c-.269.165-.588.26-.93.26-.958 0-1.735-.746-1.735-1.666 0-.92.777-1.667 1.734-1.667.271 0 .528.06.756.166l.008.004c.17.07.327.182.469.324.085.083.161.174.227.272.087.124.164.26.228.401.428.948.392 2.377-.942 3.706a.446.446 0 0 1-.613.01.405.405 0 0 1-.011-.59c.42-.416.672-.831.81-1.22z\"}}]})(props);\n};\nexport function BsFillChatRightTextFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 2a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h9.586a1 1 0 0 1 .707.293l2.853 2.853a.5.5 0 0 0 .854-.353V2zM3.5 3h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1 0-1zm0 2.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1 0-1zm0 2.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFillChatSquareDotsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2h-2.5a1 1 0 0 0-.8.4l-1.9 2.533a1 1 0 0 1-1.6 0L5.3 12.4a1 1 0 0 0-.8-.4H2a2 2 0 0 1-2-2V2zm5 4a1 1 0 1 0-2 0 1 1 0 0 0 2 0zm4 0a1 1 0 1 0-2 0 1 1 0 0 0 2 0zm3 1a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsFillChatSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h2.5a1 1 0 0 1 .8.4l1.9 2.533a1 1 0 0 0 1.6 0l1.9-2.533a1 1 0 0 1 .8-.4H14a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsFillChatSquareQuoteFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2h-2.5a1 1 0 0 0-.8.4l-1.9 2.533a1 1 0 0 1-1.6 0L5.3 12.4a1 1 0 0 0-.8-.4H2a2 2 0 0 1-2-2V2zm7.194 2.766a1.688 1.688 0 0 0-.227-.272 1.467 1.467 0 0 0-.469-.324l-.008-.004A1.785 1.785 0 0 0 5.734 4C4.776 4 4 4.746 4 5.667c0 .92.776 1.666 1.734 1.666.343 0 .662-.095.931-.26-.137.389-.39.804-.81 1.22a.405.405 0 0 0 .011.59c.173.16.447.155.614-.01 1.334-1.329 1.37-2.758.941-3.706a2.461 2.461 0 0 0-.227-.4zM11 7.073c-.136.389-.39.804-.81 1.22a.405.405 0 0 0 .012.59c.172.16.446.155.613-.01 1.334-1.329 1.37-2.758.942-3.706a2.466 2.466 0 0 0-.228-.4 1.686 1.686 0 0 0-.227-.273 1.466 1.466 0 0 0-.469-.324l-.008-.004A1.785 1.785 0 0 0 10.07 4c-.957 0-1.734.746-1.734 1.667 0 .92.777 1.666 1.734 1.666.343 0 .662-.095.931-.26z\"}}]})(props);\n};\nexport function BsFillChatSquareTextFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2h-2.5a1 1 0 0 0-.8.4l-1.9 2.533a1 1 0 0 1-1.6 0L5.3 12.4a1 1 0 0 0-.8-.4H2a2 2 0 0 1-2-2V2zm3.5 1a.5.5 0 0 0 0 1h9a.5.5 0 0 0 0-1h-9zm0 2.5a.5.5 0 0 0 0 1h9a.5.5 0 0 0 0-1h-9zm0 2.5a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5z\"}}]})(props);\n};\nexport function BsFillChatTextFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8c0 3.866-3.582 7-8 7a9.06 9.06 0 0 1-2.347-.306c-.584.296-1.925.864-4.181 1.234-.2.032-.352-.176-.273-.362.354-.836.674-1.95.77-2.966C.744 11.37 0 9.76 0 8c0-3.866 3.582-7 8-7s8 3.134 8 7zM4.5 5a.5.5 0 0 0 0 1h7a.5.5 0 0 0 0-1h-7zm0 2.5a.5.5 0 0 0 0 1h7a.5.5 0 0 0 0-1h-7zm0 2.5a.5.5 0 0 0 0 1h4a.5.5 0 0 0 0-1h-4z\"}}]})(props);\n};\nexport function BsFillCheckCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-3.97-3.03a.75.75 0 0 0-1.08.022L7.477 9.417 5.384 7.323a.75.75 0 0 0-1.06 1.06L6.97 11.03a.75.75 0 0 0 1.079-.02l3.992-4.99a.75.75 0 0 0-.01-1.05z\"}}]})(props);\n};\nexport function BsFillCheckSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm10.03 4.97a.75.75 0 0 1 .011 1.05l-3.992 4.99a.75.75 0 0 1-1.08.02L4.324 8.384a.75.75 0 1 1 1.06-1.06l2.094 2.093 3.473-4.425a.75.75 0 0 1 1.08-.022z\"}}]})(props);\n};\nexport function BsFillCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"8\",\"r\":\"8\"}}]})(props);\n};\nexport function BsFillClockFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM8 3.5a.5.5 0 0 0-1 0V9a.5.5 0 0 0 .252.434l3.5 2a.5.5 0 0 0 .496-.868L8 8.71V3.5z\"}}]})(props);\n};\nexport function BsFillCloudArrowDownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 2a5.53 5.53 0 0 0-3.594 1.342c-.766.66-1.321 1.52-1.464 2.383C1.266 6.095 0 7.555 0 9.318 0 11.366 1.708 13 3.781 13h8.906C14.502 13 16 11.57 16 9.773c0-1.636-1.242-2.969-2.834-3.194C12.923 3.999 10.69 2 8 2zm2.354 6.854-2 2a.5.5 0 0 1-.708 0l-2-2a.5.5 0 1 1 .708-.708L7.5 9.293V5.5a.5.5 0 0 1 1 0v3.793l1.146-1.147a.5.5 0 0 1 .708.708z\"}}]})(props);\n};\nexport function BsFillCloudArrowUpFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 2a5.53 5.53 0 0 0-3.594 1.342c-.766.66-1.321 1.52-1.464 2.383C1.266 6.095 0 7.555 0 9.318 0 11.366 1.708 13 3.781 13h8.906C14.502 13 16 11.57 16 9.773c0-1.636-1.242-2.969-2.834-3.194C12.923 3.999 10.69 2 8 2zm2.354 5.146a.5.5 0 0 1-.708.708L8.5 6.707V10.5a.5.5 0 0 1-1 0V6.707L6.354 7.854a.5.5 0 1 1-.708-.708l2-2a.5.5 0 0 1 .708 0l2 2z\"}}]})(props);\n};\nexport function BsFillCloudCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 2a5.53 5.53 0 0 0-3.594 1.342c-.766.66-1.321 1.52-1.464 2.383C1.266 6.095 0 7.555 0 9.318 0 11.366 1.708 13 3.781 13h8.906C14.502 13 16 11.57 16 9.773c0-1.636-1.242-2.969-2.834-3.194C12.923 3.999 10.69 2 8 2zm2.354 4.854-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7 8.793l2.646-2.647a.5.5 0 0 1 .708.708z\"}}]})(props);\n};\nexport function BsFillCloudDownloadFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 0a5.53 5.53 0 0 0-3.594 1.342c-.766.66-1.321 1.52-1.464 2.383C1.266 4.095 0 5.555 0 7.318 0 9.366 1.708 11 3.781 11H7.5V5.5a.5.5 0 0 1 1 0V11h4.188C14.502 11 16 9.57 16 7.773c0-1.636-1.242-2.969-2.834-3.194C12.923 1.999 10.69 0 8 0zm-.354 15.854a.5.5 0 0 0 .708 0l3-3a.5.5 0 0 0-.708-.708L8.5 14.293V11h-1v3.293l-2.146-2.147a.5.5 0 0 0-.708.708l3 3z\"}}]})(props);\n};\nexport function BsFillCloudDrizzleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.158 12.025a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 0 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm6 0a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 0 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm-3.5 1.5a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 0 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm6 0a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm.747-8.498a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 11H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsFillCloudFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.406 3.342A5.53 5.53 0 0 1 8 2c2.69 0 4.923 2 5.166 4.579C14.758 6.804 16 8.137 16 9.773 16 11.569 14.502 13 12.687 13H3.781C1.708 13 0 11.366 0 9.318c0-1.763 1.266-3.223 2.942-3.593.143-.863.698-1.723 1.464-2.383z\"}}]})(props);\n};\nexport function BsFillCloudFogFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 13.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm10.405-9.473a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 12H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsFillCloudFog2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 3a5.001 5.001 0 0 1 4.905 4.027A3 3 0 0 1 13 13h-1.5a.5.5 0 0 0 0-1H1.05a3.51 3.51 0 0 1-.713-1H9.5a.5.5 0 0 0 0-1H.035a3.53 3.53 0 0 1 0-1H7.5a.5.5 0 0 0 0-1H.337a3.5 3.5 0 0 1 3.57-1.977A5.001 5.001 0 0 1 8.5 3z\"}}]})(props);\n};\nexport function BsFillCloudHailFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.75 15.25a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0zm.408-3.724a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zM7.75 15.25a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0zm.408-3.724a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm3.592 3.724a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0zm.408-3.724a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm1.247-6.999a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10.5H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsFillCloudHazeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 11.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm-3 2a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm2 2a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zM13.405 4.027a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsFillCloudHaze2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 2a5.001 5.001 0 0 1 4.905 4.027A3 3 0 0 1 13 12H3.5A3.5 3.5 0 0 1 .035 9H5.5a.5.5 0 0 0 0-1H.035a3.5 3.5 0 0 1 3.871-2.977A5.001 5.001 0 0 1 8.5 2zm-6 8a.5.5 0 0 0 0 1h9a.5.5 0 0 0 0-1h-9zM0 13.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFillCloudLightningFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.053 11.276A.5.5 0 0 1 7.5 11h1a.5.5 0 0 1 .474.658l-.28.842H9.5a.5.5 0 0 1 .39.812l-2 2.5a.5.5 0 0 1-.875-.433L7.36 14H6.5a.5.5 0 0 1-.447-.724l1-2zm6.352-7.249a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsFillCloudLightningRainFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.658 11.026a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm9.5 0a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 0 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm-7.5 1.5a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm9.5 0a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 0 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm-7.105-1.25A.5.5 0 0 1 7.5 11h1a.5.5 0 0 1 .474.658l-.28.842H9.5a.5.5 0 0 1 .39.812l-2 2.5a.5.5 0 0 1-.875-.433L7.36 14H6.5a.5.5 0 0 1-.447-.724l1-2zm6.352-7.249a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsFillCloudMinusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 2a5.53 5.53 0 0 0-3.594 1.342c-.766.66-1.321 1.52-1.464 2.383C1.266 6.095 0 7.555 0 9.318 0 11.366 1.708 13 3.781 13h8.906C14.502 13 16 11.57 16 9.773c0-1.636-1.242-2.969-2.834-3.194C12.923 3.999 10.69 2 8 2zM6 7.5h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFillCloudMoonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.473 11a4.5 4.5 0 0 0-8.72-.99A3 3 0 0 0 3 16h8.5a2.5 2.5 0 0 0 0-5h-.027z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.286 1.778a.5.5 0 0 0-.565-.755 4.595 4.595 0 0 0-3.18 5.003 5.46 5.46 0 0 1 1.055.209A3.603 3.603 0 0 1 9.83 2.617a4.593 4.593 0 0 0 4.31 5.744 3.576 3.576 0 0 1-2.241.634c.162.317.295.652.394 1a4.59 4.59 0 0 0 3.624-2.04.5.5 0 0 0-.565-.755 3.593 3.593 0 0 1-4.065-5.422z\"}}]})(props);\n};\nexport function BsFillCloudPlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 2a5.53 5.53 0 0 0-3.594 1.342c-.766.66-1.321 1.52-1.464 2.383C1.266 6.095 0 7.555 0 9.318 0 11.366 1.708 13 3.781 13h8.906C14.502 13 16 11.57 16 9.773c0-1.636-1.242-2.969-2.834-3.194C12.923 3.999 10.69 2 8 2zm.5 4v1.5H10a.5.5 0 0 1 0 1H8.5V10a.5.5 0 0 1-1 0V8.5H6a.5.5 0 0 1 0-1h1.5V6a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFillCloudRainFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.158 12.025a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm3 0a.5.5 0 0 1 .316.633l-1 3a.5.5 0 1 1-.948-.316l1-3a.5.5 0 0 1 .632-.317zm3 0a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm3 0a.5.5 0 0 1 .316.633l-1 3a.5.5 0 1 1-.948-.316l1-3a.5.5 0 0 1 .632-.317zm.247-6.998a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 11H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsFillCloudRainHeavyFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.176 11.032a.5.5 0 0 1 .292.643l-1.5 4a.5.5 0 0 1-.936-.35l1.5-4a.5.5 0 0 1 .644-.293zm3 0a.5.5 0 0 1 .292.643l-1.5 4a.5.5 0 0 1-.936-.35l1.5-4a.5.5 0 0 1 .644-.293zm3 0a.5.5 0 0 1 .292.643l-1.5 4a.5.5 0 0 1-.936-.35l1.5-4a.5.5 0 0 1 .644-.293zm3 0a.5.5 0 0 1 .292.643l-1.5 4a.5.5 0 0 1-.936-.35l1.5-4a.5.5 0 0 1 .644-.293zm.229-7.005a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsFillCloudSlashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.112 5.112a3.125 3.125 0 0 0-.17.613C1.266 6.095 0 7.555 0 9.318 0 11.366 1.708 13 3.781 13H11L3.112 5.112zm11.372 7.372L4.937 2.937A5.512 5.512 0 0 1 8 2c2.69 0 4.923 2 5.166 4.579C14.758 6.804 16 8.137 16 9.773a3.2 3.2 0 0 1-1.516 2.711zm-.838 1.87-12-12 .708-.708 12 12-.707.707z\"}}]})(props);\n};\nexport function BsFillCloudSleetFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.375 13.5a.25.25 0 0 1 .25.25v.57l.501-.287a.25.25 0 0 1 .248.434l-.495.283.495.283a.25.25 0 1 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 1 1-.248-.434l.495-.283-.495-.283a.25.25 0 1 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm1.849-2.447a.5.5 0 0 1 .223.67l-.5 1a.5.5 0 0 1-.894-.447l.5-1a.5.5 0 0 1 .67-.223zM6.375 13.5a.25.25 0 0 1 .25.25v.57l.5-.287a.25.25 0 0 1 .249.434l-.495.283.495.283a.25.25 0 1 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 1 1-.248-.434l.495-.283-.495-.283a.25.25 0 1 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm1.849-2.447a.5.5 0 0 1 .223.67l-.5 1a.5.5 0 0 1-.894-.447l.5-1a.5.5 0 0 1 .67-.223zm2.151 2.447a.25.25 0 0 1 .25.25v.57l.5-.287a.25.25 0 0 1 .249.434l-.495.283.495.283a.25.25 0 1 1-.248.434l-.501-.286v.569a.25.25 0 0 1-.5 0v-.57l-.501.287a.25.25 0 1 1-.248-.434l.495-.283-.495-.283a.25.25 0 1 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm1.849-2.447a.5.5 0 0 1 .223.67l-.5 1a.5.5 0 1 1-.894-.447l.5-1a.5.5 0 0 1 .67-.223zm1.181-7.026a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsFillCloudSnowFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.625 11.5a.25.25 0 0 1 .25.25v.57l.501-.287a.25.25 0 0 1 .248.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 0 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm2.75 2a.25.25 0 0 1 .25.25v.57l.5-.287a.25.25 0 0 1 .249.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 0 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm5.5 0a.25.25 0 0 1 .25.25v.57l.5-.287a.25.25 0 0 1 .249.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 0 1-.5 0v-.57l-.501.287a.25.25 0 0 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm-2.75-2a.25.25 0 0 1 .25.25v.57l.5-.287a.25.25 0 0 1 .249.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 0 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm5.5 0a.25.25 0 0 1 .25.25v.57l.5-.287a.25.25 0 0 1 .249.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 0 1-.5 0v-.57l-.501.287a.25.25 0 1 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm-.22-7.223a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10.25H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsFillCloudSunFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.473 11a4.5 4.5 0 0 0-8.72-.99A3 3 0 0 0 3 16h8.5a2.5 2.5 0 0 0 0-5h-.027z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 1.5a.5.5 0 0 0-1 0v1a.5.5 0 0 0 1 0v-1zm3.743 1.964a.5.5 0 1 0-.707-.707l-.708.707a.5.5 0 0 0 .708.708l.707-.708zm-7.779-.707a.5.5 0 0 0-.707.707l.707.708a.5.5 0 1 0 .708-.708l-.708-.707zm1.734 3.374a2 2 0 1 1 3.296 2.198c.199.281.372.582.516.898a3 3 0 1 0-4.84-3.225c.352.011.696.055 1.028.129zm4.484 4.074c.6.215 1.125.59 1.522 1.072a.5.5 0 0 0 .039-.742l-.707-.707a.5.5 0 0 0-.854.377zM14.5 6.5a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1z\"}}]})(props);\n};\nexport function BsFillCloudUploadFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 0a5.53 5.53 0 0 0-3.594 1.342c-.766.66-1.321 1.52-1.464 2.383C1.266 4.095 0 5.555 0 7.318 0 9.366 1.708 11 3.781 11H7.5V5.707L5.354 7.854a.5.5 0 1 1-.708-.708l3-3a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1-.708.708L8.5 5.707V11h4.188C14.502 11 16 9.57 16 7.773c0-1.636-1.242-2.969-2.834-3.194C12.923 1.999 10.69 0 8 0zm-.5 14.5V11h1v3.5a.5.5 0 0 1-1 0z\"}}]})(props);\n};\nexport function BsFillCloudsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.473 9a4.5 4.5 0 0 0-8.72-.99A3 3 0 0 0 3 14h8.5a2.5 2.5 0 1 0-.027-5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.544 9.772a3.506 3.506 0 0 0-2.225-1.676 5.502 5.502 0 0 0-6.337-4.002 4.002 4.002 0 0 1 7.392.91 2.5 2.5 0 0 1 1.17 4.769z\"}}]})(props);\n};\nexport function BsFillCloudyFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.405 7.027a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 13H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsFillCollectionFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 13a1.5 1.5 0 0 0 1.5 1.5h13A1.5 1.5 0 0 0 16 13V6a1.5 1.5 0 0 0-1.5-1.5h-13A1.5 1.5 0 0 0 0 6v7zM2 3a.5.5 0 0 0 .5.5h11a.5.5 0 0 0 0-1h-11A.5.5 0 0 0 2 3zm2-2a.5.5 0 0 0 .5.5h7a.5.5 0 0 0 0-1h-7A.5.5 0 0 0 4 1z\"}}]})(props);\n};\nexport function BsFillCollectionPlayFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 3.5a.5.5 0 0 1 0-1h11a.5.5 0 0 1 0 1h-11zm2-2a.5.5 0 0 1 0-1h7a.5.5 0 0 1 0 1h-7zM0 13a1.5 1.5 0 0 0 1.5 1.5h13A1.5 1.5 0 0 0 16 13V6a1.5 1.5 0 0 0-1.5-1.5h-13A1.5 1.5 0 0 0 0 6v7zm6.258-6.437a.5.5 0 0 1 .507.013l4 2.5a.5.5 0 0 1 0 .848l-4 2.5A.5.5 0 0 1 6 12V7a.5.5 0 0 1 .258-.437z\"}}]})(props);\n};\nexport function BsFillCompassFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.5 8.516a7.5 7.5 0 1 1-9.462-7.24A1 1 0 0 1 7 0h2a1 1 0 0 1 .962 1.276 7.503 7.503 0 0 1 5.538 7.24zm-3.61-3.905L6.94 7.439 4.11 12.39l4.95-2.828 2.828-4.95z\"}}]})(props);\n};\nexport function BsFillCpuFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 6a.5.5 0 0 0-.5.5v3a.5.5 0 0 0 .5.5h3a.5.5 0 0 0 .5-.5v-3a.5.5 0 0 0-.5-.5h-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5.5a.5.5 0 0 0-1 0V2A2.5 2.5 0 0 0 2 4.5H.5a.5.5 0 0 0 0 1H2v1H.5a.5.5 0 0 0 0 1H2v1H.5a.5.5 0 0 0 0 1H2v1H.5a.5.5 0 0 0 0 1H2A2.5 2.5 0 0 0 4.5 14v1.5a.5.5 0 0 0 1 0V14h1v1.5a.5.5 0 0 0 1 0V14h1v1.5a.5.5 0 0 0 1 0V14h1v1.5a.5.5 0 0 0 1 0V14a2.5 2.5 0 0 0 2.5-2.5h1.5a.5.5 0 0 0 0-1H14v-1h1.5a.5.5 0 0 0 0-1H14v-1h1.5a.5.5 0 0 0 0-1H14v-1h1.5a.5.5 0 0 0 0-1H14A2.5 2.5 0 0 0 11.5 2V.5a.5.5 0 0 0-1 0V2h-1V.5a.5.5 0 0 0-1 0V2h-1V.5a.5.5 0 0 0-1 0V2h-1V.5zm1 4.5h3A1.5 1.5 0 0 1 11 6.5v3A1.5 1.5 0 0 1 9.5 11h-3A1.5 1.5 0 0 1 5 9.5v-3A1.5 1.5 0 0 1 6.5 5z\"}}]})(props);\n};\nexport function BsFillCreditCard2BackFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v5H0V4zm11.5 1a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h2a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-2zM0 11v1a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-1H0z\"}}]})(props);\n};\nexport function BsFillCreditCard2FrontFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm2.5 1a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h2a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-2zm0 3a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5zm0 2a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1zm3 0a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1zm3 0a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1zm3 0a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1z\"}}]})(props);\n};\nexport function BsFillCreditCardFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v1H0V4zm0 3v5a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7H0zm3 2h1a1 1 0 0 1 1 1v1a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1v-1a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFillCupFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 2a1 1 0 0 1 1-1h11a1 1 0 0 1 1 1v1h.5A1.5 1.5 0 0 1 16 4.5v7a1.5 1.5 0 0 1-1.5 1.5h-.55a2.5 2.5 0 0 1-2.45 2h-8A2.5 2.5 0 0 1 1 12.5V2zm13 10h.5a.5.5 0 0 0 .5-.5v-7a.5.5 0 0 0-.5-.5H14v8z\"}}]})(props);\n};\nexport function BsFillCursorFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14.082 2.182a.5.5 0 0 1 .103.557L8.528 15.467a.5.5 0 0 1-.917-.007L5.57 10.694.803 8.652a.5.5 0 0 1-.006-.916l12.728-5.657a.5.5 0 0 1 .556.103z\"}}]})(props);\n};\nexport function BsFillDashCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM4.5 7.5a.5.5 0 0 0 0 1h7a.5.5 0 0 0 0-1h-7z\"}}]})(props);\n};\nexport function BsFillDashSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm2.5 7.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFillDiagram2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 3.5A1.5 1.5 0 0 1 7.5 2h1A1.5 1.5 0 0 1 10 3.5v1A1.5 1.5 0 0 1 8.5 6v1H11a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-1 0V8h-5v.5a.5.5 0 0 1-1 0v-1A.5.5 0 0 1 5 7h2.5V6A1.5 1.5 0 0 1 6 4.5v-1zm-3 8A1.5 1.5 0 0 1 4.5 10h1A1.5 1.5 0 0 1 7 11.5v1A1.5 1.5 0 0 1 5.5 14h-1A1.5 1.5 0 0 1 3 12.5v-1zm6 0a1.5 1.5 0 0 1 1.5-1.5h1a1.5 1.5 0 0 1 1.5 1.5v1a1.5 1.5 0 0 1-1.5 1.5h-1A1.5 1.5 0 0 1 9 12.5v-1z\"}}]})(props);\n};\nexport function BsFillDiagram3Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 3.5A1.5 1.5 0 0 1 7.5 2h1A1.5 1.5 0 0 1 10 3.5v1A1.5 1.5 0 0 1 8.5 6v1H14a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-1 0V8h-5v.5a.5.5 0 0 1-1 0V8h-5v.5a.5.5 0 0 1-1 0v-1A.5.5 0 0 1 2 7h5.5V6A1.5 1.5 0 0 1 6 4.5v-1zm-6 8A1.5 1.5 0 0 1 1.5 10h1A1.5 1.5 0 0 1 4 11.5v1A1.5 1.5 0 0 1 2.5 14h-1A1.5 1.5 0 0 1 0 12.5v-1zm6 0A1.5 1.5 0 0 1 7.5 10h1a1.5 1.5 0 0 1 1.5 1.5v1A1.5 1.5 0 0 1 8.5 14h-1A1.5 1.5 0 0 1 6 12.5v-1zm6 0a1.5 1.5 0 0 1 1.5-1.5h1a1.5 1.5 0 0 1 1.5 1.5v1a1.5 1.5 0 0 1-1.5 1.5h-1a1.5 1.5 0 0 1-1.5-1.5v-1z\"}}]})(props);\n};\nexport function BsFillDiamondFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6.95.435c.58-.58 1.52-.58 2.1 0l6.515 6.516c.58.58.58 1.519 0 2.098L9.05 15.565c-.58.58-1.519.58-2.098 0L.435 9.05a1.482 1.482 0 0 1 0-2.098L6.95.435z\"}}]})(props);\n};\nexport function BsFillDice1Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V3a3 3 0 0 0-3-3H3zm5 9.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsFillDice2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 3a3 3 0 0 1 3-3h10a3 3 0 0 1 3 3v10a3 3 0 0 1-3 3H3a3 3 0 0 1-3-3V3zm5.5 1a1.5 1.5 0 1 0-3 0 1.5 1.5 0 0 0 3 0zm6.5 9.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3z\"}}]})(props);\n};\nexport function BsFillDice3Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V3a3 3 0 0 0-3-3H3zm2.5 4a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm8 8a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zM8 9.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsFillDice4Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V3a3 3 0 0 0-3-3H3zm1 5.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm8 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm1.5 6.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zM4 13.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsFillDice5Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V3a3 3 0 0 0-3-3H3zm2.5 4a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm8 0a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zM12 13.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zM5.5 12a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zM8 9.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsFillDice6Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V3a3 3 0 0 0-3-3H3zm1 5.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm8 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm1.5 6.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zM12 9.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zM5.5 12a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zM4 9.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsFillDiscFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-6 0a2 2 0 1 0-4 0 2 2 0 0 0 4 0zM4 8a4 4 0 0 1 4-4 .5.5 0 0 0 0-1 5 5 0 0 0-5 5 .5.5 0 0 0 1 0zm9 0a.5.5 0 1 0-1 0 4 4 0 0 1-4 4 .5.5 0 0 0 0 1 5 5 0 0 0 5-5z\"}}]})(props);\n};\nexport function BsFillDisplayFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12c0 .667-.083 1.167-.25 1.5H5a.5.5 0 0 0 0 1h6a.5.5 0 0 0 0-1h-.75c-.167-.333-.25-.833-.25-1.5h4c2 0 2-2 2-2V4c0-2-2-2-2-2H2C0 2 0 4 0 4v6c0 2 2 2 2 2h4z\"}}]})(props);\n};\nexport function BsFillDoorClosedFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 1a1 1 0 0 1 1 1v13h1.5a.5.5 0 0 1 0 1h-13a.5.5 0 0 1 0-1H3V2a1 1 0 0 1 1-1h8zm-2 9a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsFillDoorOpenFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 15a.5.5 0 0 0 0 1h13a.5.5 0 0 0 0-1H13V2.5A1.5 1.5 0 0 0 11.5 1H11V.5a.5.5 0 0 0-.57-.495l-7 1A.5.5 0 0 0 3 1.5V15H1.5zM11 2h.5a.5.5 0 0 1 .5.5V15h-1V2zm-2.5 8c-.276 0-.5-.448-.5-1s.224-1 .5-1 .5.448.5 1-.224 1-.5 1z\"}}]})(props);\n};\nexport function BsFillDropletFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 16a6 6 0 0 0 6-6c0-1.655-1.122-2.904-2.432-4.362C10.254 4.176 8.75 2.503 8 0c0 0-6 5.686-6 10a6 6 0 0 0 6 6zM6.646 4.646c-.376.377-1.272 1.489-2.093 3.13l.894.448c.78-1.559 1.616-2.58 1.907-2.87l-.708-.708z\"}}]})(props);\n};\nexport function BsFillEaselFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.473.337a.5.5 0 0 0-.946 0L6.954 2H2a1 1 0 0 0-1 1v7a1 1 0 0 0 1 1h1.85l-1.323 3.837a.5.5 0 1 0 .946.326L4.908 11H7.5v2.5a.5.5 0 0 0 1 0V11h2.592l1.435 4.163a.5.5 0 0 0 .946-.326L12.15 11H14a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H9.046L8.473.337z\"}}]})(props);\n};\nexport function BsFillEggFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10a6 6 0 0 1-12 0C2 5.686 5 0 8 0s6 5.686 6 10z\"}}]})(props);\n};\nexport function BsFillEjectFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.27 1.047a1 1 0 0 1 1.46 0l6.345 6.77c.6.638.146 1.683-.73 1.683H1.656C.78 9.5.326 8.455.926 7.816L7.27 1.047zM.5 11.5a1 1 0 0 1 1-1h13a1 1 0 0 1 1 1v1a1 1 0 0 1-1 1h-13a1 1 0 0 1-1-1v-1z\"}}]})(props);\n};\nexport function BsFillEmojiAngryFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM4.053 4.276a.5.5 0 0 1 .67-.223l2 1a.5.5 0 0 1 .166.76c.071.206.111.44.111.687C7 7.328 6.552 8 6 8s-1-.672-1-1.5c0-.408.109-.778.285-1.049l-1.009-.504a.5.5 0 0 1-.223-.67zm.232 8.157a.5.5 0 0 1-.183-.683A4.498 4.498 0 0 1 8 9.5a4.5 4.5 0 0 1 3.898 2.25.5.5 0 1 1-.866.5A3.498 3.498 0 0 0 8 10.5a3.498 3.498 0 0 0-3.032 1.75.5.5 0 0 1-.683.183zM10 8c-.552 0-1-.672-1-1.5 0-.247.04-.48.11-.686a.502.502 0 0 1 .166-.761l2-1a.5.5 0 1 1 .448.894l-1.009.504c.176.27.285.64.285 1.049 0 .828-.448 1.5-1 1.5z\"}}]})(props);\n};\nexport function BsFillEmojiDizzyFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM4.146 5.146a.5.5 0 0 1 .708 0l.646.647.646-.647a.5.5 0 1 1 .708.708l-.647.646.647.646a.5.5 0 1 1-.708.708L5.5 7.207l-.646.647a.5.5 0 1 1-.708-.708l.647-.646-.647-.646a.5.5 0 0 1 0-.708zm5 0a.5.5 0 0 1 .708 0l.646.647.646-.647a.5.5 0 0 1 .708.708l-.647.646.647.646a.5.5 0 0 1-.708.708l-.646-.647-.646.647a.5.5 0 1 1-.708-.708l.647-.646-.647-.646a.5.5 0 0 1 0-.708zM8 13a2 2 0 1 1 0-4 2 2 0 0 1 0 4z\"}}]})(props);\n};\nexport function BsFillEmojiExpressionlessFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM4.5 6h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1zm5 0h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1zm-5 4h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFillEmojiFrownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM7 6.5C7 7.328 6.552 8 6 8s-1-.672-1-1.5S5.448 5 6 5s1 .672 1 1.5zm-2.715 5.933a.5.5 0 0 1-.183-.683A4.498 4.498 0 0 1 8 9.5a4.5 4.5 0 0 1 3.898 2.25.5.5 0 0 1-.866.5A3.498 3.498 0 0 0 8 10.5a3.498 3.498 0 0 0-3.032 1.75.5.5 0 0 1-.683.183zM10 8c-.552 0-1-.672-1-1.5S9.448 5 10 5s1 .672 1 1.5S10.552 8 10 8z\"}}]})(props);\n};\nexport function BsFillEmojiHeartEyesFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a8 8 0 1 0 0 16A8 8 0 0 0 8 0zM4.756 4.566c.763-1.424 4.02-.12.952 3.434-4.496-1.596-2.35-4.298-.952-3.434zm6.559 5.448a.5.5 0 0 1 .548.736A4.498 4.498 0 0 1 7.965 13a4.498 4.498 0 0 1-3.898-2.25.5.5 0 0 1 .548-.736h.005l.017.005.067.015.252.055c.215.046.515.108.857.169.693.124 1.522.242 2.152.242.63 0 1.46-.118 2.152-.242a26.58 26.58 0 0 0 1.109-.224l.067-.015.017-.004.005-.002zm-.07-5.448c1.397-.864 3.543 1.838-.953 3.434-3.067-3.554.19-4.858.952-3.434z\"}}]})(props);\n};\nexport function BsFillEmojiLaughingFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM7 6.5c0 .501-.164.396-.415.235C6.42 6.629 6.218 6.5 6 6.5c-.218 0-.42.13-.585.235C5.164 6.896 5 7 5 6.5 5 5.672 5.448 5 6 5s1 .672 1 1.5zm5.331 3a1 1 0 0 1 0 1A4.998 4.998 0 0 1 8 13a4.998 4.998 0 0 1-4.33-2.5A1 1 0 0 1 4.535 9h6.93a1 1 0 0 1 .866.5zm-1.746-2.765C10.42 6.629 10.218 6.5 10 6.5c-.218 0-.42.13-.585.235C9.164 6.896 9 7 9 6.5c0-.828.448-1.5 1-1.5s1 .672 1 1.5c0 .501-.164.396-.415.235z\"}}]})(props);\n};\nexport function BsFillEmojiNeutralFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM7 6.5C7 7.328 6.552 8 6 8s-1-.672-1-1.5S5.448 5 6 5s1 .672 1 1.5zm-3 4a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zM10 8c-.552 0-1-.672-1-1.5S9.448 5 10 5s1 .672 1 1.5S10.552 8 10 8z\"}}]})(props);\n};\nexport function BsFillEmojiSmileFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM7 6.5C7 7.328 6.552 8 6 8s-1-.672-1-1.5S5.448 5 6 5s1 .672 1 1.5zM4.285 9.567a.5.5 0 0 1 .683.183A3.498 3.498 0 0 0 8 11.5a3.498 3.498 0 0 0 3.032-1.75.5.5 0 1 1 .866.5A4.498 4.498 0 0 1 8 12.5a4.498 4.498 0 0 1-3.898-2.25.5.5 0 0 1 .183-.683zM10 8c-.552 0-1-.672-1-1.5S9.448 5 10 5s1 .672 1 1.5S10.552 8 10 8z\"}}]})(props);\n};\nexport function BsFillEmojiSmileUpsideDownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0zM7 9.5C7 8.672 6.552 8 6 8s-1 .672-1 1.5.448 1.5 1 1.5 1-.672 1-1.5zM4.285 6.433a.5.5 0 0 0 .683-.183A3.498 3.498 0 0 1 8 4.5c1.295 0 2.426.703 3.032 1.75a.5.5 0 0 0 .866-.5A4.498 4.498 0 0 0 8 3.5a4.5 4.5 0 0 0-3.898 2.25.5.5 0 0 0 .183.683zM10 8c-.552 0-1 .672-1 1.5s.448 1.5 1 1.5 1-.672 1-1.5S10.552 8 10 8z\"}}]})(props);\n};\nexport function BsFillEmojiSunglassesFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM2.31 5.243A1 1 0 0 1 3.28 4H6a1 1 0 0 1 1 1v.116A4.22 4.22 0 0 1 8 5c.35 0 .69.04 1 .116V5a1 1 0 0 1 1-1h2.72a1 1 0 0 1 .97 1.243l-.311 1.242A2 2 0 0 1 11.439 8H11a2 2 0 0 1-1.994-1.839A2.99 2.99 0 0 0 8 6c-.393 0-.74.064-1.006.161A2 2 0 0 1 5 8h-.438a2 2 0 0 1-1.94-1.515L2.31 5.243zM4.969 9.75A3.498 3.498 0 0 0 8 11.5a3.498 3.498 0 0 0 3.032-1.75.5.5 0 1 1 .866.5A4.498 4.498 0 0 1 8 12.5a4.498 4.498 0 0 1-3.898-2.25.5.5 0 0 1 .866-.5z\"}}]})(props);\n};\nexport function BsFillEmojiWinkFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0zM7 6.5C7 5.672 6.552 5 6 5s-1 .672-1 1.5S5.448 8 6 8s1-.672 1-1.5zM4.285 9.567a.5.5 0 0 0-.183.683A4.498 4.498 0 0 0 8 12.5a4.5 4.5 0 0 0 3.898-2.25.5.5 0 1 0-.866-.5A3.498 3.498 0 0 1 8 11.5a3.498 3.498 0 0 1-3.032-1.75.5.5 0 0 0-.683-.183zm5.152-3.31a.5.5 0 0 0-.874.486c.33.595.958 1.007 1.687 1.007.73 0 1.356-.412 1.687-1.007a.5.5 0 0 0-.874-.486.934.934 0 0 1-.813.493.934.934 0 0 1-.813-.493z\"}}]})(props);\n};\nexport function BsFillEnvelopeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.05 3.555A2 2 0 0 1 2 2h12a2 2 0 0 1 1.95 1.555L8 8.414.05 3.555zM0 4.697v7.104l5.803-3.558L0 4.697zM6.761 8.83l-6.57 4.027A2 2 0 0 0 2 14h12a2 2 0 0 0 1.808-1.144l-6.57-4.027L8 9.586l-1.239-.757zm3.436-.586L16 11.801V4.697l-5.803 3.546z\"}}]})(props);\n};\nexport function BsFillEnvelopeOpenFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.941.435a2 2 0 0 0-1.882 0l-6 3.2A2 2 0 0 0 0 5.4v.313l6.709 3.933L8 8.928l1.291.717L16 5.715V5.4a2 2 0 0 0-1.059-1.765l-6-3.2zM16 6.873l-5.693 3.337L16 13.372v-6.5zm-.059 7.611L8 10.072.059 14.484A2 2 0 0 0 2 16h12a2 2 0 0 0 1.941-1.516zM0 13.373l5.693-3.163L0 6.873v6.5z\"}}]})(props);\n};\nexport function BsFillEraserFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.086 2.207a2 2 0 0 1 2.828 0l3.879 3.879a2 2 0 0 1 0 2.828l-5.5 5.5A2 2 0 0 1 7.879 15H5.12a2 2 0 0 1-1.414-.586l-2.5-2.5a2 2 0 0 1 0-2.828l6.879-6.879zm.66 11.34L3.453 8.254 1.914 9.793a1 1 0 0 0 0 1.414l2.5 2.5a1 1 0 0 0 .707.293H7.88a1 1 0 0 0 .707-.293l.16-.16z\"}}]})(props);\n};\nexport function BsFillExclamationCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM8 4a.905.905 0 0 0-.9.995l.35 3.507a.552.552 0 0 0 1.1 0l.35-3.507A.905.905 0 0 0 8 4zm.002 6a1 1 0 1 0 0 2 1 1 0 0 0 0-2z\"}}]})(props);\n};\nexport function BsFillExclamationDiamondFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.05.435c-.58-.58-1.52-.58-2.1 0L.436 6.95c-.58.58-.58 1.519 0 2.098l6.516 6.516c.58.58 1.519.58 2.098 0l6.516-6.516c.58-.58.58-1.519 0-2.098L9.05.435zM8 4c.535 0 .954.462.9.995l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 4.995A.905.905 0 0 1 8 4zm.002 6a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\"}}]})(props);\n};\nexport function BsFillExclamationOctagonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.46.146A.5.5 0 0 0 11.107 0H4.893a.5.5 0 0 0-.353.146L.146 4.54A.5.5 0 0 0 0 4.893v6.214a.5.5 0 0 0 .146.353l4.394 4.394a.5.5 0 0 0 .353.146h6.214a.5.5 0 0 0 .353-.146l4.394-4.394a.5.5 0 0 0 .146-.353V4.893a.5.5 0 0 0-.146-.353L11.46.146zM8 4c.535 0 .954.462.9.995l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 4.995A.905.905 0 0 1 8 4zm.002 6a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\"}}]})(props);\n};\nexport function BsFillExclamationSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm6 4c.535 0 .954.462.9.995l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 4.995A.905.905 0 0 1 8 4zm.002 6a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\"}}]})(props);\n};\nexport function BsFillExclamationTriangleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.982 1.566a1.13 1.13 0 0 0-1.96 0L.165 13.233c-.457.778.091 1.767.98 1.767h13.713c.889 0 1.438-.99.98-1.767L8.982 1.566zM8 5c.535 0 .954.462.9.995l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 5.995A.905.905 0 0 1 8 5zm.002 6a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\"}}]})(props);\n};\nexport function BsFillEyeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 8a2.5 2.5 0 1 1-5 0 2.5 2.5 0 0 1 5 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 8s3-5.5 8-5.5S16 8 16 8s-3 5.5-8 5.5S0 8 0 8zm8 3.5a3.5 3.5 0 1 0 0-7 3.5 3.5 0 0 0 0 7z\"}}]})(props);\n};\nexport function BsFillEyeSlashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m10.79 12.912-1.614-1.615a3.5 3.5 0 0 1-4.474-4.474l-2.06-2.06C.938 6.278 0 8 0 8s3 5.5 8 5.5a7.029 7.029 0 0 0 2.79-.588zM5.21 3.088A7.028 7.028 0 0 1 8 2.5c5 0 8 5.5 8 5.5s-.939 1.721-2.641 3.238l-2.062-2.062a3.5 3.5 0 0 0-4.474-4.474L5.21 3.089z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.525 7.646a2.5 2.5 0 0 0 2.829 2.829l-2.83-2.829zm4.95.708-2.829-2.83a2.5 2.5 0 0 1 2.829 2.829zm3.171 6-12-12 .708-.708 12 12-.708.708z\"}}]})(props);\n};\nexport function BsFillFileArrowDownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM8 5a.5.5 0 0 1 .5.5v3.793l1.146-1.147a.5.5 0 0 1 .708.708l-2 2a.5.5 0 0 1-.708 0l-2-2a.5.5 0 1 1 .708-.708L7.5 9.293V5.5A.5.5 0 0 1 8 5z\"}}]})(props);\n};\nexport function BsFillFileArrowUpFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM7.5 6.707 6.354 7.854a.5.5 0 1 1-.708-.708l2-2a.5.5 0 0 1 .708 0l2 2a.5.5 0 0 1-.708.708L8.5 6.707V10.5a.5.5 0 0 1-1 0V6.707z\"}}]})(props);\n};\nexport function BsFillFileBarGraphFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zm-2 11.5v-6a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v6a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5zm-2.5.5a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-.5.5h-1zm-3 0a.5.5 0 0 1-.5-.5v-2a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-1z\"}}]})(props);\n};\nexport function BsFillFileBinaryFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.526 9.273c-.542 0-.832.563-.832 1.612 0 .088.003.173.006.252l1.56-1.143c-.126-.474-.375-.72-.733-.72zm-.732 2.508c.126.472.372.718.732.718.54 0 .83-.563.83-1.614 0-.085-.003-.17-.006-.25l-1.556 1.146z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM7.05 10.885c0 1.415-.548 2.206-1.524 2.206C4.548 13.09 4 12.3 4 10.885c0-1.412.548-2.203 1.526-2.203.976 0 1.524.79 1.524 2.203zm3.805 1.52V13h-3v-.595h1.181V9.5h-.05l-1.136.747v-.688l1.19-.786h.69v3.633h1.125z\"}}]})(props);\n};\nexport function BsFillFileBreakFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0h8a2 2 0 0 1 2 2v7H2V2a2 2 0 0 1 2-2zM2 12h12v2a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2v-2zM.5 10a.5.5 0 0 0 0 1h15a.5.5 0 0 0 0-1H.5z\"}}]})(props);\n};\nexport function BsFillFileCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zm-1.146 6.854-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7.5 8.793l2.646-2.647a.5.5 0 0 1 .708.708z\"}}]})(props);\n};\nexport function BsFillFileCodeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM6.646 5.646a.5.5 0 1 1 .708.708L5.707 8l1.647 1.646a.5.5 0 0 1-.708.708l-2-2a.5.5 0 0 1 0-.708l2-2zm2.708 0 2 2a.5.5 0 0 1 0 .708l-2 2a.5.5 0 0 1-.708-.708L10.293 8 8.646 6.354a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsFillFileDiffFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM8.5 4.5V6H10a.5.5 0 0 1 0 1H8.5v1.5a.5.5 0 0 1-1 0V7H6a.5.5 0 0 1 0-1h1.5V4.5a.5.5 0 0 1 1 0zM6 10h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFillFileEarmarkArrowDownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zm-1 4v3.793l1.146-1.147a.5.5 0 0 1 .708.708l-2 2a.5.5 0 0 1-.708 0l-2-2a.5.5 0 0 1 .708-.708L7.5 11.293V7.5a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFillFileEarmarkArrowUpFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM6.354 9.854a.5.5 0 0 1-.708-.708l2-2a.5.5 0 0 1 .708 0l2 2a.5.5 0 0 1-.708.708L8.5 8.707V12.5a.5.5 0 0 1-1 0V8.707L6.354 9.854z\"}}]})(props);\n};\nexport function BsFillFileEarmarkBarGraphFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zm.5 10v-6a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v6a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5zm-2.5.5a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-.5.5h-1zm-3 0a.5.5 0 0 1-.5-.5v-2a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-1z\"}}]})(props);\n};\nexport function BsFillFileEarmarkBinaryFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.526 10.273c-.542 0-.832.563-.832 1.612 0 .088.003.173.006.252l1.559-1.143c-.126-.474-.375-.72-.733-.72zm-.732 2.508c.126.472.372.718.732.718.54 0 .83-.563.83-1.614 0-.085-.003-.17-.006-.25l-1.556 1.146z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zm-2.45 8.385c0 1.415-.548 2.206-1.524 2.206C4.548 14.09 4 13.3 4 11.885c0-1.412.548-2.203 1.526-2.203.976 0 1.524.79 1.524 2.203zm3.805 1.52V14h-3v-.595h1.181V10.5h-.05l-1.136.747v-.688l1.19-.786h.69v3.633h1.125z\"}}]})(props);\n};\nexport function BsFillFileEarmarkBreakFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0h5.293A1 1 0 0 1 10 .293L13.707 4a1 1 0 0 1 .293.707V9H2V2a2 2 0 0 1 2-2zm5.5 1.5v2a1 1 0 0 0 1 1h2l-3-3zM2 12h12v2a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2v-2zM.5 10a.5.5 0 0 0 0 1h15a.5.5 0 0 0 0-1H.5z\"}}]})(props);\n};\nexport function BsFillFileEarmarkCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zm1.354 4.354-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7.5 9.793l2.646-2.647a.5.5 0 0 1 .708.708z\"}}]})(props);\n};\nexport function BsFillFileEarmarkCodeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM6.646 7.646a.5.5 0 1 1 .708.708L5.707 10l1.647 1.646a.5.5 0 0 1-.708.708l-2-2a.5.5 0 0 1 0-.708l2-2zm2.708 0 2 2a.5.5 0 0 1 0 .708l-2 2a.5.5 0 0 1-.708-.708L10.293 10 8.646 8.354a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsFillFileEarmarkDiffFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM8 6a.5.5 0 0 1 .5.5V8H10a.5.5 0 0 1 0 1H8.5v1.5a.5.5 0 0 1-1 0V9H6a.5.5 0 0 1 0-1h1.5V6.5A.5.5 0 0 1 8 6zm-2.5 6.5A.5.5 0 0 1 6 12h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFillFileEarmarkEaselFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-5a.5.5 0 0 1-.5-.5v-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM8.5 6h2A1.5 1.5 0 0 1 12 7.5v2a1.5 1.5 0 0 1-1.5 1.5h-.473l.447 1.342a.5.5 0 0 1-.948.316L8.973 11H8.5v1a.5.5 0 0 1-1 0v-1h-.473l-.553 1.658a.5.5 0 1 1-.948-.316L5.973 11H5.5A1.5 1.5 0 0 1 4 9.5v-2A1.5 1.5 0 0 1 5.5 6h2a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFillFileEarmarkExcelFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM5.884 6.68 8 9.219l2.116-2.54a.5.5 0 1 1 .768.641L8.651 10l2.233 2.68a.5.5 0 0 1-.768.64L8 10.781l-2.116 2.54a.5.5 0 0 1-.768-.641L7.349 10 5.116 7.32a.5.5 0 1 1 .768-.64z\"}}]})(props);\n};\nexport function BsFillFileEarmarkFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0h5.293A1 1 0 0 1 10 .293L13.707 4a1 1 0 0 1 .293.707V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2zm5.5 1.5v2a1 1 0 0 0 1 1h2l-3-3z\"}}]})(props);\n};\nexport function BsFillFileEarmarkFontFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM5.057 6h5.886L11 8h-.5c-.18-1.096-.356-1.192-1.694-1.235l-.298-.01v5.09c0 .47.1.582.903.655v.5H6.59v-.5c.799-.073.898-.184.898-.654V6.755l-.293.01C5.856 6.808 5.68 6.905 5.5 8H5l.057-2z\"}}]})(props);\n};\nexport function BsFillFileEarmarkImageFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0h5.293A1 1 0 0 1 10 .293L13.707 4a1 1 0 0 1 .293.707v5.586l-2.73-2.73a1 1 0 0 0-1.52.127l-1.889 2.644-1.769-1.062a1 1 0 0 0-1.222.15L2 12.292V2a2 2 0 0 1 2-2zm5.5 1.5v2a1 1 0 0 0 1 1h2l-3-3zm-1.498 4a1.5 1.5 0 1 0-3 0 1.5 1.5 0 0 0 3 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.564 8.27 14 11.708V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2v-.293l3.578-3.577 2.56 1.536 2.426-3.395z\"}}]})(props);\n};\nexport function BsFillFileEarmarkLockFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7a1 1 0 0 1 2 0v1H7V7zM6 9.3c0-.042.02-.107.105-.175A.637.637 0 0 1 6.5 9h3a.64.64 0 0 1 .395.125c.085.068.105.133.105.175v2.4c0 .042-.02.107-.105.175A.637.637 0 0 1 9.5 12h-3a.637.637 0 0 1-.395-.125C6.02 11.807 6 11.742 6 11.7V9.3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM10 7v1.076c.54.166 1 .597 1 1.224v2.4c0 .816-.781 1.3-1.5 1.3h-3c-.719 0-1.5-.484-1.5-1.3V9.3c0-.627.46-1.058 1-1.224V7a2 2 0 1 1 4 0z\"}}]})(props);\n};\nexport function BsFillFileEarmarkLock2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7a1 1 0 0 1 2 0v1H7V7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM10 7v1.076c.54.166 1 .597 1 1.224v2.4c0 .816-.781 1.3-1.5 1.3h-3c-.719 0-1.5-.484-1.5-1.3V9.3c0-.627.46-1.058 1-1.224V7a2 2 0 1 1 4 0z\"}}]})(props);\n};\nexport function BsFillFileEarmarkMedicalFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zm-3 2v.634l.549-.317a.5.5 0 1 1 .5.866L7 7l.549.317a.5.5 0 1 1-.5.866L6.5 7.866V8.5a.5.5 0 0 1-1 0v-.634l-.549.317a.5.5 0 1 1-.5-.866L5 7l-.549-.317a.5.5 0 0 1 .5-.866l.549.317V5.5a.5.5 0 1 1 1 0zm-2 4.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1zm0 2h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFillFileEarmarkMinusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM6 8.5h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFillFileEarmarkMusicFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM11 6.64v1.75l-2 .5v3.61c0 .495-.301.883-.662 1.123C7.974 13.866 7.499 14 7 14c-.5 0-.974-.134-1.338-.377-.36-.24-.662-.628-.662-1.123s.301-.883.662-1.123C6.026 11.134 6.501 11 7 11c.356 0 .7.068 1 .196V6.89a1 1 0 0 1 .757-.97l1-.25A1 1 0 0 1 11 6.64z\"}}]})(props);\n};\nexport function BsFillFileEarmarkPdfFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.523 12.424c.14-.082.293-.162.459-.238a7.878 7.878 0 0 1-.45.606c-.28.337-.498.516-.635.572a.266.266 0 0 1-.035.012.282.282 0 0 1-.026-.044c-.056-.11-.054-.216.04-.36.106-.165.319-.354.647-.548zm2.455-1.647c-.119.025-.237.05-.356.078a21.148 21.148 0 0 0 .5-1.05 12.045 12.045 0 0 0 .51.858c-.217.032-.436.07-.654.114zm2.525.939a3.881 3.881 0 0 1-.435-.41c.228.005.434.022.612.054.317.057.466.147.518.209a.095.095 0 0 1 .026.064.436.436 0 0 1-.06.2.307.307 0 0 1-.094.124.107.107 0 0 1-.069.015c-.09-.003-.258-.066-.498-.256zM8.278 6.97c-.04.244-.108.524-.2.829a4.86 4.86 0 0 1-.089-.346c-.076-.353-.087-.63-.046-.822.038-.177.11-.248.196-.283a.517.517 0 0 1 .145-.04c.013.03.028.092.032.198.005.122-.007.277-.038.465z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4 0h5.293A1 1 0 0 1 10 .293L13.707 4a1 1 0 0 1 .293.707V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2zm5.5 1.5v2a1 1 0 0 0 1 1h2l-3-3zM4.165 13.668c.09.18.23.343.438.419.207.075.412.04.58-.03.318-.13.635-.436.926-.786.333-.401.683-.927 1.021-1.51a11.651 11.651 0 0 1 1.997-.406c.3.383.61.713.91.95.28.22.603.403.934.417a.856.856 0 0 0 .51-.138c.155-.101.27-.247.354-.416.09-.181.145-.37.138-.563a.844.844 0 0 0-.2-.518c-.226-.27-.596-.4-.96-.465a5.76 5.76 0 0 0-1.335-.05 10.954 10.954 0 0 1-.98-1.686c.25-.66.437-1.284.52-1.794.036-.218.055-.426.048-.614a1.238 1.238 0 0 0-.127-.538.7.7 0 0 0-.477-.365c-.202-.043-.41 0-.601.077-.377.15-.576.47-.651.823-.073.34-.04.736.046 1.136.088.406.238.848.43 1.295a19.697 19.697 0 0 1-1.062 2.227 7.662 7.662 0 0 0-1.482.645c-.37.22-.699.48-.897.787-.21.326-.275.714-.08 1.103z\"}}]})(props);\n};\nexport function BsFillFileEarmarkPersonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM11 8a3 3 0 1 1-6 0 3 3 0 0 1 6 0zm2 5.755V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1v-.245S4 12 8 12s5 1.755 5 1.755z\"}}]})(props);\n};\nexport function BsFillFileEarmarkPlayFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM6 6.883a.5.5 0 0 1 .757-.429l3.528 2.117a.5.5 0 0 1 0 .858l-3.528 2.117a.5.5 0 0 1-.757-.43V6.884z\"}}]})(props);\n};\nexport function BsFillFileEarmarkPlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM8.5 7v1.5H10a.5.5 0 0 1 0 1H8.5V11a.5.5 0 0 1-1 0V9.5H6a.5.5 0 0 1 0-1h1.5V7a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFillFileEarmarkPostFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zm-5-.5H7a.5.5 0 0 1 0 1H4.5a.5.5 0 0 1 0-1zm0 3h7a.5.5 0 0 1 .5.5v7a.5.5 0 0 1-.5.5h-7a.5.5 0 0 1-.5-.5v-7a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsFillFileEarmarkPptFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.188 10H7V6.5h1.188a1.75 1.75 0 1 1 0 3.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0h5.293A1 1 0 0 1 10 .293L13.707 4a1 1 0 0 1 .293.707V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2zm5.5 1.5v2a1 1 0 0 0 1 1h2l-3-3zM7 5.5a1 1 0 0 0-1 1V13a.5.5 0 0 0 1 0v-2h1.188a2.75 2.75 0 0 0 0-5.5H7z\"}}]})(props);\n};\nexport function BsFillFileEarmarkRichtextFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM7 6.25a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0zm-.861 1.542 1.33.886 1.854-1.855a.25.25 0 0 1 .289-.047l1.888.974V9.5a.5.5 0 0 1-.5.5H5a.5.5 0 0 1-.5-.5V9s1.54-1.274 1.639-1.208zM5 11h6a.5.5 0 0 1 0 1H5a.5.5 0 0 1 0-1zm0 2h3a.5.5 0 0 1 0 1H5a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFillFileEarmarkRuledFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM3 9h10v1H6v2h7v1H6v2H5v-2H3v-1h2v-2H3V9z\"}}]})(props);\n};\nexport function BsFillFileEarmarkSlidesFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 9.78V7.22c0-.096.106-.156.19-.106l2.13 1.279a.125.125 0 0 1 0 .214l-2.13 1.28A.125.125 0 0 1 7 9.778z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM5 6h6a.5.5 0 0 1 .496.438l.5 4A.5.5 0 0 1 11.5 11h-3v2.016c.863.055 1.5.251 1.5.484 0 .276-.895.5-2 .5s-2-.224-2-.5c0-.233.637-.429 1.5-.484V11h-3a.5.5 0 0 1-.496-.562l.5-4A.5.5 0 0 1 5 6z\"}}]})(props);\n};\nexport function BsFillFileEarmarkSpreadsheetFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12v-2h3v2H6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM3 9h10v1h-3v2h3v1h-3v2H9v-2H6v2H5v-2H3v-1h2v-2H3V9z\"}}]})(props);\n};\nexport function BsFillFileEarmarkTextFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM4.5 9a.5.5 0 0 1 0-1h7a.5.5 0 0 1 0 1h-7zM4 10.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm.5 2.5a.5.5 0 0 1 0-1h4a.5.5 0 0 1 0 1h-4z\"}}]})(props);\n};\nexport function BsFillFileEarmarkWordFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM5.485 6.879l1.036 4.144.997-3.655a.5.5 0 0 1 .964 0l.997 3.655 1.036-4.144a.5.5 0 0 1 .97.242l-1.5 6a.5.5 0 0 1-.967.01L8 9.402l-1.018 3.73a.5.5 0 0 1-.967-.01l-1.5-6a.5.5 0 1 1 .97-.242z\"}}]})(props);\n};\nexport function BsFillFileEarmarkXFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM6.854 7.146 8 8.293l1.146-1.147a.5.5 0 1 1 .708.708L8.707 9l1.147 1.146a.5.5 0 0 1-.708.708L8 9.707l-1.146 1.147a.5.5 0 0 1-.708-.708L7.293 9 6.146 7.854a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsFillFileEarmarkZipFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 9.438V8.5h1v.938a1 1 0 0 0 .03.243l.4 1.598-.93.62-.93-.62.4-1.598a1 1 0 0 0 .03-.243z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zm-4-.5V2h-1V1H6v1h1v1H6v1h1v1H6v1h1v1H5.5V6h-1V5h1V4h-1V3h1zm0 4.5h1a1 1 0 0 1 1 1v.938l.4 1.599a1 1 0 0 1-.416 1.074l-.93.62a1 1 0 0 1-1.109 0l-.93-.62a1 1 0 0 1-.415-1.074l.4-1.599V8.5a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFillFileEaselFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 6.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-5a.5.5 0 0 1-.5-.5v-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM8.5 5h2A1.5 1.5 0 0 1 12 6.5v2a1.5 1.5 0 0 1-1.5 1.5h-.473l.447 1.342a.5.5 0 0 1-.948.316L8.973 10H8.5v1a.5.5 0 0 1-1 0v-1h-.473l-.553 1.658a.5.5 0 1 1-.948-.316L5.973 10H5.5A1.5 1.5 0 0 1 4 8.5v-2A1.5 1.5 0 0 1 5.5 5h2a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFillFileExcelFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM5.884 4.68 8 7.219l2.116-2.54a.5.5 0 1 1 .768.641L8.651 8l2.233 2.68a.5.5 0 0 1-.768.64L8 8.781l-2.116 2.54a.5.5 0 0 1-.768-.641L7.349 8 5.116 5.32a.5.5 0 1 1 .768-.64z\"}}]})(props);\n};\nexport function BsFillFileFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4 0h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2z\"}}]})(props);\n};\nexport function BsFillFileFontFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM5.057 4h5.886L11 6h-.5c-.18-1.096-.356-1.192-1.694-1.235l-.298-.01v6.09c0 .47.1.582.903.655v.5H6.59v-.5c.799-.073.898-.184.898-.654V4.755l-.293.01C5.856 4.808 5.68 4.905 5.5 6H5l.057-2z\"}}]})(props);\n};\nexport function BsFillFileImageFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0h8a2 2 0 0 1 2 2v8.293l-2.73-2.73a1 1 0 0 0-1.52.127l-1.889 2.644-1.769-1.062a1 1 0 0 0-1.222.15L2 12.292V2a2 2 0 0 1 2-2zm4.002 5.5a1.5 1.5 0 1 0-3 0 1.5 1.5 0 0 0 3 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.564 8.27 14 11.708V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2v-.293l3.578-3.577 2.56 1.536 2.426-3.395z\"}}]})(props);\n};\nexport function BsFillFileLockFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 6a1 1 0 0 1 2 0v1H7V6zM6 8.3c0-.042.02-.107.105-.175A.637.637 0 0 1 6.5 8h3a.64.64 0 0 1 .395.125c.085.068.105.133.105.175v2.4c0 .042-.02.107-.105.175A.637.637 0 0 1 9.5 11h-3a.637.637 0 0 1-.395-.125C6.02 10.807 6 10.742 6 10.7V8.3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zm-2 6v1.076c.54.166 1 .597 1 1.224v2.4c0 .816-.781 1.3-1.5 1.3h-3c-.719 0-1.5-.484-1.5-1.3V8.3c0-.627.46-1.058 1-1.224V6a2 2 0 1 1 4 0z\"}}]})(props);\n};\nexport function BsFillFileLock2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 6a1 1 0 0 1 2 0v1H7V6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zm-2 6v1.076c.54.166 1 .597 1 1.224v2.4c0 .816-.781 1.3-1.5 1.3h-3c-.719 0-1.5-.484-1.5-1.3V8.3c0-.627.46-1.058 1-1.224V6a2 2 0 1 1 4 0z\"}}]})(props);\n};\nexport function BsFillFileMedicalFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM8.5 4.5v.634l.549-.317a.5.5 0 1 1 .5.866L9 6l.549.317a.5.5 0 1 1-.5.866L8.5 6.866V7.5a.5.5 0 0 1-1 0v-.634l-.549.317a.5.5 0 1 1-.5-.866L7 6l-.549-.317a.5.5 0 0 1 .5-.866l.549.317V4.5a.5.5 0 1 1 1 0zM5.5 9h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1zm0 2h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFillFileMinusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM6 7.5h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFillFileMusicFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zm-.5 4.11v1.8l-2.5.5v5.09c0 .495-.301.883-.662 1.123C7.974 12.866 7.499 13 7 13c-.5 0-.974-.134-1.338-.377-.36-.24-.662-.628-.662-1.123s.301-.883.662-1.123C6.026 10.134 6.501 10 7 10c.356 0 .7.068 1 .196V4.41a1 1 0 0 1 .804-.98l1.5-.3a1 1 0 0 1 1.196.98z\"}}]})(props);\n};\nexport function BsFillFilePdfFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.523 10.424c.14-.082.293-.162.459-.238a7.878 7.878 0 0 1-.45.606c-.28.337-.498.516-.635.572a.266.266 0 0 1-.035.012.282.282 0 0 1-.026-.044c-.056-.11-.054-.216.04-.36.106-.165.319-.354.647-.548zm2.455-1.647c-.119.025-.237.05-.356.078a21.035 21.035 0 0 0 .5-1.05 11.96 11.96 0 0 0 .51.858c-.217.032-.436.07-.654.114zm2.525.939a3.888 3.888 0 0 1-.435-.41c.228.005.434.022.612.054.317.057.466.147.518.209a.095.095 0 0 1 .026.064.436.436 0 0 1-.06.2.307.307 0 0 1-.094.124.107.107 0 0 1-.069.015c-.09-.003-.258-.066-.498-.256zM8.278 4.97c-.04.244-.108.524-.2.829a4.86 4.86 0 0 1-.089-.346c-.076-.353-.087-.63-.046-.822.038-.177.11-.248.196-.283a.517.517 0 0 1 .145-.04c.013.03.028.092.032.198.005.122-.007.277-.038.465z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4 0h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2zm.165 11.668c.09.18.23.343.438.419.207.075.412.04.58-.03.318-.13.635-.436.926-.786.333-.401.683-.927 1.021-1.51a11.64 11.64 0 0 1 1.997-.406c.3.383.61.713.91.95.28.22.603.403.934.417a.856.856 0 0 0 .51-.138c.155-.101.27-.247.354-.416.09-.181.145-.37.138-.563a.844.844 0 0 0-.2-.518c-.226-.27-.596-.4-.96-.465a5.76 5.76 0 0 0-1.335-.05 10.954 10.954 0 0 1-.98-1.686c.25-.66.437-1.284.52-1.794.036-.218.055-.426.048-.614a1.238 1.238 0 0 0-.127-.538.7.7 0 0 0-.477-.365c-.202-.043-.41 0-.601.077-.377.15-.576.47-.651.823-.073.34-.04.736.046 1.136.088.406.238.848.43 1.295a19.707 19.707 0 0 1-1.062 2.227 7.662 7.662 0 0 0-1.482.645c-.37.22-.699.48-.897.787-.21.326-.275.714-.08 1.103z\"}}]})(props);\n};\nexport function BsFillFilePersonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zm-1 7a3 3 0 1 1-6 0 3 3 0 0 1 6 0zm-3 4c2.623 0 4.146.826 5 1.755V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1v-1.245C3.854 11.825 5.377 11 8 11z\"}}]})(props);\n};\nexport function BsFillFilePlayFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM6 5.883a.5.5 0 0 1 .757-.429l3.528 2.117a.5.5 0 0 1 0 .858l-3.528 2.117a.5.5 0 0 1-.757-.43V5.884z\"}}]})(props);\n};\nexport function BsFillFilePlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM8.5 6v1.5H10a.5.5 0 0 1 0 1H8.5V10a.5.5 0 0 1-1 0V8.5H6a.5.5 0 0 1 0-1h1.5V6a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFillFilePostFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM4.5 3h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1zm0 2h7a.5.5 0 0 1 .5.5v8a.5.5 0 0 1-.5.5h-7a.5.5 0 0 1-.5-.5v-8a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsFillFilePptFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.188 8.5H7V5h1.188a1.75 1.75 0 1 1 0 3.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2zm3 4a1 1 0 0 0-1 1v6.5a.5.5 0 0 0 1 0v-2h1.188a2.75 2.75 0 0 0 0-5.5H7z\"}}]})(props);\n};\nexport function BsFillFileRichtextFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM7 4.25a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0zm-.861 1.542 1.33.886 1.854-1.855a.25.25 0 0 1 .289-.047l1.888.974V7.5a.5.5 0 0 1-.5.5H5a.5.5 0 0 1-.5-.5V7s1.54-1.274 1.639-1.208zM5 9h6a.5.5 0 0 1 0 1H5a.5.5 0 0 1 0-1zm0 2h3a.5.5 0 0 1 0 1H5a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFillFileRuledFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v4h12V2a2 2 0 0 0-2-2zm2 7H6v2h8V7zm0 3H6v2h8v-2zm0 3H6v3h6a2 2 0 0 0 2-2v-1zm-9 3v-3H2v1a2 2 0 0 0 2 2h1zm-3-4h3v-2H2v2zm0-3h3V7H2v2z\"}}]})(props);\n};\nexport function BsFillFileSlidesFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7.78V5.22c0-.096.106-.156.19-.106l2.13 1.279a.125.125 0 0 1 0 .214l-2.13 1.28A.125.125 0 0 1 7 7.778z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM5 4h6a.5.5 0 0 1 .496.438l.5 4A.5.5 0 0 1 11.5 9h-3v2.016c.863.055 1.5.251 1.5.484 0 .276-.895.5-2 .5s-2-.224-2-.5c0-.233.637-.429 1.5-.484V9h-3a.5.5 0 0 1-.496-.562l.5-4A.5.5 0 0 1 5 4z\"}}]})(props);\n};\nexport function BsFillFileSpreadsheetFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v4h12V2a2 2 0 0 0-2-2zm2 7h-4v2h4V7zm0 3h-4v2h4v-2zm0 3h-4v3h2a2 2 0 0 0 2-2v-1zm-5 3v-3H6v3h3zm-4 0v-3H2v1a2 2 0 0 0 2 2h1zm-3-4h3v-2H2v2zm0-3h3V7H2v2zm4 0V7h3v2H6zm0 1h3v2H6v-2z\"}}]})(props);\n};\nexport function BsFillFileTextFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM5 4h6a.5.5 0 0 1 0 1H5a.5.5 0 0 1 0-1zm-.5 2.5A.5.5 0 0 1 5 6h6a.5.5 0 0 1 0 1H5a.5.5 0 0 1-.5-.5zM5 8h6a.5.5 0 0 1 0 1H5a.5.5 0 0 1 0-1zm0 2h3a.5.5 0 0 1 0 1H5a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFillFileWordFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM5.485 4.879l1.036 4.144.997-3.655a.5.5 0 0 1 .964 0l.997 3.655 1.036-4.144a.5.5 0 0 1 .97.242l-1.5 6a.5.5 0 0 1-.967.01L8 7.402l-1.018 3.73a.5.5 0 0 1-.967-.01l-1.5-6a.5.5 0 1 1 .97-.242z\"}}]})(props);\n};\nexport function BsFillFileXFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM6.854 6.146 8 7.293l1.146-1.147a.5.5 0 1 1 .708.708L8.707 8l1.147 1.146a.5.5 0 0 1-.708.708L8 8.707 6.854 9.854a.5.5 0 0 1-.708-.708L7.293 8 6.146 6.854a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsFillFileZipFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 9.438V8.5h-1v.938a1 1 0 0 1-.03.243l-.4 1.598.93.62.93-.62-.4-1.598a1 1 0 0 1-.03-.243z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2zm2.5 8.5v.938l-.4 1.599a1 1 0 0 0 .416 1.074l.93.62a1 1 0 0 0 1.109 0l.93-.62a1 1 0 0 0 .415-1.074l-.4-1.599V8.5a1 1 0 0 0-1-1h-1a1 1 0 0 0-1 1zm1-5.5h-1v1h1v1h-1v1h1v1H9V6H8V5h1V4H8V3h1V2H8V1H6.5v1h1v1z\"}}]})(props);\n};\nexport function BsFillFilterCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM3.5 5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1 0-1zM5 8.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm2 3a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 0 1h-1a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFillFilterSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm.5 5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1 0-1zM4 8.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm2 3a.5.5 0 0 1 .5-.5h3a.5.5 0 0 1 0 1h-3a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFillFlagFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14.778.085A.5.5 0 0 1 15 .5V8a.5.5 0 0 1-.314.464L14.5 8l.186.464-.003.001-.006.003-.023.009a12.435 12.435 0 0 1-.397.15c-.264.095-.631.223-1.047.35-.816.252-1.879.523-2.71.523-.847 0-1.548-.28-2.158-.525l-.028-.01C7.68 8.71 7.14 8.5 6.5 8.5c-.7 0-1.638.23-2.437.477A19.626 19.626 0 0 0 3 9.342V15.5a.5.5 0 0 1-1 0V.5a.5.5 0 0 1 1 0v.282c.226-.079.496-.17.79-.26C4.606.272 5.67 0 6.5 0c.84 0 1.524.277 2.121.519l.043.018C9.286.788 9.828 1 10.5 1c.7 0 1.638-.23 2.437-.477a19.587 19.587 0 0 0 1.349-.476l.019-.007.004-.002h.001\"}}]})(props);\n};\nexport function BsFillFolderFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.828 3h3.982a2 2 0 0 1 1.992 2.181l-.637 7A2 2 0 0 1 13.174 14H2.825a2 2 0 0 1-1.991-1.819l-.637-7a1.99 1.99 0 0 1 .342-1.31L.5 3a2 2 0 0 1 2-2h3.672a2 2 0 0 1 1.414.586l.828.828A2 2 0 0 0 9.828 3zm-8.322.12C1.72 3.042 1.95 3 2.19 3h5.396l-.707-.707A1 1 0 0 0 6.172 2H2.5a1 1 0 0 0-1 .981l.006.139z\"}}]})(props);\n};\nexport function BsFillFolderSymlinkFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.81 3H9.828a2 2 0 0 1-1.414-.586l-.828-.828A2 2 0 0 0 6.172 1H2.5a2 2 0 0 0-2 2l.04.87a1.99 1.99 0 0 0-.342 1.311l.637 7A2 2 0 0 0 2.826 14h10.348a2 2 0 0 0 1.991-1.819l.637-7A2 2 0 0 0 13.81 3zM2.19 3c-.24 0-.47.042-.683.12L1.5 2.98a1 1 0 0 1 1-.98h3.672a1 1 0 0 1 .707.293L7.586 3H2.19zm9.608 5.271-3.182 1.97c-.27.166-.616-.036-.616-.372V9.1s-2.571-.3-4 2.4c.571-4.8 3.143-4.8 4-4.8v-.769c0-.336.346-.538.616-.371l3.182 1.969c.27.166.27.576 0 .742z\"}}]})(props);\n};\nexport function BsFillForwardFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m9.77 12.11 4.012-2.953a.647.647 0 0 0 0-1.114L9.771 5.09a.644.644 0 0 0-.971.557V6.65H2v3.9h6.8v1.003c0 .505.545.808.97.557z\"}}]})(props);\n};\nexport function BsFillFunnelFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 1.5A.5.5 0 0 1 2 1h12a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.128.334L10 8.692V13.5a.5.5 0 0 1-.342.474l-3 1A.5.5 0 0 1 6 14.5V8.692L1.628 3.834A.5.5 0 0 1 1.5 3.5v-2z\"}}]})(props);\n};\nexport function BsFillGearFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.405 1.05c-.413-1.4-2.397-1.4-2.81 0l-.1.34a1.464 1.464 0 0 1-2.105.872l-.31-.17c-1.283-.698-2.686.705-1.987 1.987l.169.311c.446.82.023 1.841-.872 2.105l-.34.1c-1.4.413-1.4 2.397 0 2.81l.34.1a1.464 1.464 0 0 1 .872 2.105l-.17.31c-.698 1.283.705 2.686 1.987 1.987l.311-.169a1.464 1.464 0 0 1 2.105.872l.1.34c.413 1.4 2.397 1.4 2.81 0l.1-.34a1.464 1.464 0 0 1 2.105-.872l.31.17c1.283.698 2.686-.705 1.987-1.987l-.169-.311a1.464 1.464 0 0 1 .872-2.105l.34-.1c1.4-.413 1.4-2.397 0-2.81l-.34-.1a1.464 1.464 0 0 1-.872-2.105l.17-.31c.698-1.283-.705-2.686-1.987-1.987l-.311.169a1.464 1.464 0 0 1-2.105-.872l-.1-.34zM8 10.93a2.929 2.929 0 1 1 0-5.86 2.929 2.929 0 0 1 0 5.858z\"}}]})(props);\n};\nexport function BsFillGeoAltFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16s6-5.686 6-10A6 6 0 0 0 2 6c0 4.314 6 10 6 10zm0-7a3 3 0 1 1 0-6 3 3 0 0 1 0 6z\"}}]})(props);\n};\nexport function BsFillGeoFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4 4a4 4 0 1 1 4.5 3.969V13.5a.5.5 0 0 1-1 0V7.97A4 4 0 0 1 4 3.999zm2.493 8.574a.5.5 0 0 1-.411.575c-.712.118-1.28.295-1.655.493a1.319 1.319 0 0 0-.37.265.301.301 0 0 0-.057.09V14l.002.008a.147.147 0 0 0 .016.033.617.617 0 0 0 .145.15c.165.13.435.27.813.395.751.25 1.82.414 3.024.414s2.273-.163 3.024-.414c.378-.126.648-.265.813-.395a.619.619 0 0 0 .146-.15.148.148 0 0 0 .015-.033L12 14v-.004a.301.301 0 0 0-.057-.09 1.318 1.318 0 0 0-.37-.264c-.376-.198-.943-.375-1.655-.493a.5.5 0 1 1 .164-.986c.77.127 1.452.328 1.957.594C12.5 13 13 13.4 13 14c0 .426-.26.752-.544.977-.29.228-.68.413-1.116.558-.878.293-2.059.465-3.34.465-1.281 0-2.462-.172-3.34-.465-.436-.145-.826-.33-1.116-.558C3.26 14.752 3 14.426 3 14c0-.599.5-1 .961-1.243.505-.266 1.187-.467 1.957-.594a.5.5 0 0 1 .575.411z\"}}]})(props);\n};\nexport function BsFillGiftFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 2.5a2.5 2.5 0 0 1 5 0 2.5 2.5 0 0 1 5 0v.006c0 .07 0 .27-.038.494H15a1 1 0 0 1 1 1v1a1 1 0 0 1-1 1H1a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h2.038A2.968 2.968 0 0 1 3 2.506V2.5zm1.068.5H7v-.5a1.5 1.5 0 1 0-3 0c0 .085.002.274.045.43a.522.522 0 0 0 .023.07zM9 3h2.932a.56.56 0 0 0 .023-.07c.043-.156.045-.345.045-.43a1.5 1.5 0 0 0-3 0V3zm6 4v7.5a1.5 1.5 0 0 1-1.5 1.5H9V7h6zM2.5 16A1.5 1.5 0 0 1 1 14.5V7h6v9H2.5z\"}}]})(props);\n};\nexport function BsFillGrid1X2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1a1 1 0 0 1 1-1h5a1 1 0 0 1 1 1v14a1 1 0 0 1-1 1H1a1 1 0 0 1-1-1V1zm9 0a1 1 0 0 1 1-1h5a1 1 0 0 1 1 1v5a1 1 0 0 1-1 1h-5a1 1 0 0 1-1-1V1zm0 9a1 1 0 0 1 1-1h5a1 1 0 0 1 1 1v5a1 1 0 0 1-1 1h-5a1 1 0 0 1-1-1v-5z\"}}]})(props);\n};\nexport function BsFillGrid3X2GapFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 4a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H7a1 1 0 0 1-1-1V4zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1h-2a1 1 0 0 1-1-1V4zM1 9a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V9zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H7a1 1 0 0 1-1-1V9zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1h-2a1 1 0 0 1-1-1V9z\"}}]})(props);\n};\nexport function BsFillGrid3X3GapFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 2a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H7a1 1 0 0 1-1-1V2zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1h-2a1 1 0 0 1-1-1V2zM1 7a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V7zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H7a1 1 0 0 1-1-1V7zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1h-2a1 1 0 0 1-1-1V7zM1 12a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1v-2zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H7a1 1 0 0 1-1-1v-2zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1h-2a1 1 0 0 1-1-1v-2z\"}}]})(props);\n};\nexport function BsFillGridFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 2.5A1.5 1.5 0 0 1 2.5 1h3A1.5 1.5 0 0 1 7 2.5v3A1.5 1.5 0 0 1 5.5 7h-3A1.5 1.5 0 0 1 1 5.5v-3zm8 0A1.5 1.5 0 0 1 10.5 1h3A1.5 1.5 0 0 1 15 2.5v3A1.5 1.5 0 0 1 13.5 7h-3A1.5 1.5 0 0 1 9 5.5v-3zm-8 8A1.5 1.5 0 0 1 2.5 9h3A1.5 1.5 0 0 1 7 10.5v3A1.5 1.5 0 0 1 5.5 15h-3A1.5 1.5 0 0 1 1 13.5v-3zm8 0A1.5 1.5 0 0 1 10.5 9h3a1.5 1.5 0 0 1 1.5 1.5v3a1.5 1.5 0 0 1-1.5 1.5h-3A1.5 1.5 0 0 1 9 13.5v-3z\"}}]})(props);\n};\nexport function BsFillHandIndexFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 4.466V1.75a1.75 1.75 0 1 0-3.5 0v5.34l-1.2.24a1.5 1.5 0 0 0-1.196 1.636l.345 3.106a2.5 2.5 0 0 0 .405 1.11l1.433 2.15A1.5 1.5 0 0 0 6.035 16h6.385a1.5 1.5 0 0 0 1.302-.756l1.395-2.441a3.5 3.5 0 0 0 .444-1.389l.271-2.715a2 2 0 0 0-1.99-2.199h-.581a5.114 5.114 0 0 0-.195-.248c-.191-.229-.51-.568-.88-.716-.364-.146-.846-.132-1.158-.108l-.132.012a1.26 1.26 0 0 0-.56-.642 2.632 2.632 0 0 0-.738-.288c-.31-.062-.739-.058-1.05-.046l-.048.002z\"}}]})(props);\n};\nexport function BsFillHandIndexThumbFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 1.75v2.716l.047-.002c.312-.012.742-.016 1.051.046.28.056.543.18.738.288.273.152.456.385.56.642l.132-.012c.312-.024.794-.038 1.158.108.37.148.689.487.88.716.075.09.141.175.195.248h.582a2 2 0 0 1 1.99 2.199l-.272 2.715a3.5 3.5 0 0 1-.444 1.389l-1.395 2.441A1.5 1.5 0 0 1 12.42 16H6.118a1.5 1.5 0 0 1-1.342-.83l-1.215-2.43L1.07 8.589a1.517 1.517 0 0 1 2.373-1.852L5 8.293V1.75a1.75 1.75 0 0 1 3.5 0z\"}}]})(props);\n};\nexport function BsFillHandThumbsDownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.956 14.534c.065.936.952 1.659 1.908 1.42l.261-.065a1.378 1.378 0 0 0 1.012-.965c.22-.816.533-2.512.062-4.51.136.02.285.037.443.051.713.065 1.669.071 2.516-.211.518-.173.994-.68 1.2-1.272a1.896 1.896 0 0 0-.234-1.734c.058-.118.103-.242.138-.362.077-.27.113-.568.113-.856 0-.29-.036-.586-.113-.857a2.094 2.094 0 0 0-.16-.403c.169-.387.107-.82-.003-1.149a3.162 3.162 0 0 0-.488-.9c.054-.153.076-.313.076-.465a1.86 1.86 0 0 0-.253-.912C13.1.757 12.437.28 11.5.28H8c-.605 0-1.07.08-1.466.217a4.823 4.823 0 0 0-.97.485l-.048.029c-.504.308-.999.61-2.068.723C2.682 1.815 2 2.434 2 3.279v4c0 .851.685 1.433 1.357 1.616.849.232 1.574.787 2.132 1.41.56.626.914 1.28 1.039 1.638.199.575.356 1.54.428 2.591z\"}}]})(props);\n};\nexport function BsFillHandThumbsUpFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.956 1.745C7.021.81 7.908.087 8.864.325l.261.066c.463.116.874.456 1.012.965.22.816.533 2.511.062 4.51a9.84 9.84 0 0 1 .443-.051c.713-.065 1.669-.072 2.516.21.518.173.994.681 1.2 1.273.184.532.16 1.162-.234 1.733.058.119.103.242.138.363.077.27.113.567.113.856 0 .289-.036.586-.113.856-.039.135-.09.273-.16.404.169.387.107.819-.003 1.148a3.163 3.163 0 0 1-.488.901c.054.152.076.312.076.465 0 .305-.089.625-.253.912C13.1 15.522 12.437 16 11.5 16H8c-.605 0-1.07-.081-1.466-.218a4.82 4.82 0 0 1-.97-.484l-.048-.03c-.504-.307-.999-.609-2.068-.722C2.682 14.464 2 13.846 2 13V9c0-.85.685-1.432 1.357-1.615.849-.232 1.574-.787 2.132-1.41.56-.627.914-1.28 1.039-1.639.199-.575.356-1.539.428-2.59z\"}}]})(props);\n};\nexport function BsFillHandbagFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a2 2 0 0 0-2 2v2H5V3a3 3 0 1 1 6 0v2h-1V3a2 2 0 0 0-2-2zM5 5H3.36a1.5 1.5 0 0 0-1.483 1.277L.85 13.13A2.5 2.5 0 0 0 3.322 16h9.355a2.5 2.5 0 0 0 2.473-2.87l-1.028-6.853A1.5 1.5 0 0 0 12.64 5H11v1.5a.5.5 0 0 1-1 0V5H6v1.5a.5.5 0 0 1-1 0V5z\"}}]})(props);\n};\nexport function BsFillHddFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 10a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v1a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2v-1zm2.5 1a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1zm2 0a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1zM.91 7.204A2.993 2.993 0 0 1 2 7h12c.384 0 .752.072 1.09.204l-1.867-3.422A1.5 1.5 0 0 0 11.906 3H4.094a1.5 1.5 0 0 0-1.317.782L.91 7.204z\"}}]})(props);\n};\nexport function BsFillHddNetworkFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v1a2 2 0 0 0 2 2h5.5v3A1.5 1.5 0 0 0 6 11.5H.5a.5.5 0 0 0 0 1H6A1.5 1.5 0 0 0 7.5 14h1a1.5 1.5 0 0 0 1.5-1.5h5.5a.5.5 0 0 0 0-1H10A1.5 1.5 0 0 0 8.5 10V7H14a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm.5 3a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm2 0a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1z\"}}]})(props);\n};\nexport function BsFillHddRackFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v1a2 2 0 0 0 2 2h1v2H2a2 2 0 0 0-2 2v1a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-1a2 2 0 0 0-2-2h-1V7h1a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm.5 3a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm2 0a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm-2 7a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm2 0a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zM12 7v2H4V7h8z\"}}]})(props);\n};\nexport function BsFillHddStackFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 9a2 2 0 0 0-2 2v1a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-1a2 2 0 0 0-2-2H2zm.5 3a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm2 0a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zM2 2a2 2 0 0 0-2 2v1a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm.5 3a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm2 0a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1z\"}}]})(props);\n};\nexport function BsFillHeartFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 1.314C12.438-3.248 23.534 4.735 8 15-7.534 4.736 3.562-3.248 8 1.314z\"}}]})(props);\n};\nexport function BsFillHeptagonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.779.052a.5.5 0 0 1 .442 0l6.015 2.97a.5.5 0 0 1 .267.34l1.485 6.676a.5.5 0 0 1-.093.415l-4.162 5.354a.5.5 0 0 1-.395.193H4.662a.5.5 0 0 1-.395-.193L.105 10.453a.5.5 0 0 1-.093-.415l1.485-6.676a.5.5 0 0 1 .267-.34L7.779.053z\"}}]})(props);\n};\nexport function BsFillHexagonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8.5.134a1 1 0 0 0-1 0l-6 3.577a1 1 0 0 0-.5.866v6.846a1 1 0 0 0 .5.866l6 3.577a1 1 0 0 0 1 0l6-3.577a1 1 0 0 0 .5-.866V4.577a1 1 0 0 0-.5-.866L8.5.134z\"}}]})(props);\n};\nexport function BsFillHouseDoorFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 14.5v-3.505c0-.245.25-.495.5-.495h2c.25 0 .5.25.5.5v3.5a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5v-7a.5.5 0 0 0-.146-.354L13 5.793V2.5a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5v1.293L8.354 1.146a.5.5 0 0 0-.708 0l-6 6A.5.5 0 0 0 1.5 7.5v7a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5z\"}}]})(props);\n};\nexport function BsFillHouseFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"m8 3.293 6 6V13.5a1.5 1.5 0 0 1-1.5 1.5h-9A1.5 1.5 0 0 1 2 13.5V9.293l6-6zm5-.793V6l-2-2V2.5a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.293 1.5a1 1 0 0 1 1.414 0l6.647 6.646a.5.5 0 0 1-.708.708L8 2.207 1.354 8.854a.5.5 0 1 1-.708-.708L7.293 1.5z\"}}]})(props);\n};\nexport function BsFillImageFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.002 3a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2h-12a2 2 0 0 1-2-2V3zm1 9v1a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V9.5l-3.777-1.947a.5.5 0 0 0-.577.093l-3.71 3.71-2.66-1.772a.5.5 0 0 0-.63.062L1.002 12zm5-6.5a1.5 1.5 0 1 0-3 0 1.5 1.5 0 0 0 3 0z\"}}]})(props);\n};\nexport function BsFillInboxFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.98 4a.5.5 0 0 0-.39.188L1.54 8H6a.5.5 0 0 1 .5.5 1.5 1.5 0 1 0 3 0A.5.5 0 0 1 10 8h4.46l-3.05-3.812A.5.5 0 0 0 11.02 4H4.98zm-1.17-.437A1.5 1.5 0 0 1 4.98 3h6.04a1.5 1.5 0 0 1 1.17.563l3.7 4.625a.5.5 0 0 1 .106.374l-.39 3.124A1.5 1.5 0 0 1 14.117 13H1.883a1.5 1.5 0 0 1-1.489-1.314l-.39-3.124a.5.5 0 0 1 .106-.374l3.7-4.625z\"}}]})(props);\n};\nexport function BsFillInboxesFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.98 1a.5.5 0 0 0-.39.188L1.54 5H6a.5.5 0 0 1 .5.5 1.5 1.5 0 0 0 3 0A.5.5 0 0 1 10 5h4.46l-3.05-3.812A.5.5 0 0 0 11.02 1H4.98zM3.81.563A1.5 1.5 0 0 1 4.98 0h6.04a1.5 1.5 0 0 1 1.17.563l3.7 4.625a.5.5 0 0 1 .106.374l-.39 3.124A1.5 1.5 0 0 1 14.117 10H1.883A1.5 1.5 0 0 1 .394 8.686l-.39-3.124a.5.5 0 0 1 .106-.374L3.81.563zM.125 11.17A.5.5 0 0 1 .5 11H6a.5.5 0 0 1 .5.5 1.5 1.5 0 0 0 3 0 .5.5 0 0 1 .5-.5h5.5a.5.5 0 0 1 .496.562l-.39 3.124A1.5 1.5 0 0 1 14.117 16H1.883a1.5 1.5 0 0 1-1.489-1.314l-.39-3.124a.5.5 0 0 1 .121-.393z\"}}]})(props);\n};\nexport function BsFillInfoCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zm.93-9.412-1 4.705c-.07.34.029.533.304.533.194 0 .487-.07.686-.246l-.088.416c-.287.346-.92.598-1.465.598-.703 0-1.002-.422-.808-1.319l.738-3.468c.064-.293.006-.399-.287-.47l-.451-.081.082-.381 2.29-.287zM8 5.5a1 1 0 1 1 0-2 1 1 0 0 1 0 2z\"}}]})(props);\n};\nexport function BsFillInfoSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm8.93 4.588-2.29.287-.082.38.45.083c.294.07.352.176.288.469l-.738 3.468c-.194.897.105 1.319.808 1.319.545 0 1.178-.252 1.465-.598l.088-.416c-.2.176-.492.246-.686.246-.275 0-.375-.193-.304-.533L8.93 6.588zM8 5.5a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsFillJournalBookmarkFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 1h6v7a.5.5 0 0 1-.757.429L9 7.083 6.757 8.43A.5.5 0 0 1 6 8V1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0h10a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-1h1v1a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H3a1 1 0 0 0-1 1v1H1V2a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 5v-.5a.5.5 0 0 1 1 0V5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0V8h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0v.5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1z\"}}]})(props);\n};\nexport function BsFillKanbanFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h11a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2h-11zm5 2h1a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1h-1a1 1 0 0 1-1-1V3a1 1 0 0 1 1-1zm-5 1a1 1 0 0 1 1-1h1a1 1 0 0 1 1 1v7a1 1 0 0 1-1 1h-1a1 1 0 0 1-1-1V3zm9-1h1a1 1 0 0 1 1 1v10a1 1 0 0 1-1 1h-1a1 1 0 0 1-1-1V3a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFillKeyFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 11.5a3.5 3.5 0 1 1 3.163-5H14L15.5 8 14 9.5l-1-1-1 1-1-1-1 1-1-1-1 1H6.663a3.5 3.5 0 0 1-3.163 2zM2.5 9a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsFillKeyboardFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 6a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V6zm13 .25v.5c0 .138.112.25.25.25h.5a.25.25 0 0 0 .25-.25v-.5a.25.25 0 0 0-.25-.25h-.5a.25.25 0 0 0-.25.25zM2.25 8a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h.5A.25.25 0 0 0 3 8.75v-.5A.25.25 0 0 0 2.75 8h-.5zM4 8.25v.5c0 .138.112.25.25.25h.5A.25.25 0 0 0 5 8.75v-.5A.25.25 0 0 0 4.75 8h-.5a.25.25 0 0 0-.25.25zM6.25 8a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h.5A.25.25 0 0 0 7 8.75v-.5A.25.25 0 0 0 6.75 8h-.5zM8 8.25v.5c0 .138.112.25.25.25h.5A.25.25 0 0 0 9 8.75v-.5A.25.25 0 0 0 8.75 8h-.5a.25.25 0 0 0-.25.25zM13.25 8a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h.5a.25.25 0 0 0 .25-.25v-.5a.25.25 0 0 0-.25-.25h-.5zm0 2a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h.5a.25.25 0 0 0 .25-.25v-.5a.25.25 0 0 0-.25-.25h-.5zm-3-2a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h1.5a.25.25 0 0 0 .25-.25v-.5a.25.25 0 0 0-.25-.25h-1.5zm.75 2.25v.5c0 .138.112.25.25.25h.5a.25.25 0 0 0 .25-.25v-.5a.25.25 0 0 0-.25-.25h-.5a.25.25 0 0 0-.25.25zM11.25 6a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h.5a.25.25 0 0 0 .25-.25v-.5a.25.25 0 0 0-.25-.25h-.5zM9 6.25v.5c0 .138.112.25.25.25h.5a.25.25 0 0 0 .25-.25v-.5A.25.25 0 0 0 9.75 6h-.5a.25.25 0 0 0-.25.25zM7.25 6a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h.5A.25.25 0 0 0 8 6.75v-.5A.25.25 0 0 0 7.75 6h-.5zM5 6.25v.5c0 .138.112.25.25.25h.5A.25.25 0 0 0 6 6.75v-.5A.25.25 0 0 0 5.75 6h-.5a.25.25 0 0 0-.25.25zM2.25 6a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h1.5A.25.25 0 0 0 4 6.75v-.5A.25.25 0 0 0 3.75 6h-1.5zM2 10.25v.5c0 .138.112.25.25.25h.5a.25.25 0 0 0 .25-.25v-.5a.25.25 0 0 0-.25-.25h-.5a.25.25 0 0 0-.25.25zM4.25 10a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h5.5a.25.25 0 0 0 .25-.25v-.5a.25.25 0 0 0-.25-.25h-5.5z\"}}]})(props);\n};\nexport function BsFillLampFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 3a1 1 0 0 1 1-1h10a1 1 0 0 1 1 1v4a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V3zm5.5-2 .276-.553a.25.25 0 0 1 .448 0L8.5 1h-1zm-.615 8h2.23C9.968 10.595 11 12.69 11 13.5c0 1.38-1.343 2.5-3 2.5s-3-1.12-3-2.5c0-.81 1.032-2.905 1.885-4.5z\"}}]})(props);\n};\nexport function BsFillLaptopFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 2A1.5 1.5 0 0 0 1 3.5V12h14V3.5A1.5 1.5 0 0 0 13.5 2h-11zM0 12.5h16a1.5 1.5 0 0 1-1.5 1.5h-13A1.5 1.5 0 0 1 0 12.5z\"}}]})(props);\n};\nexport function BsFillLayersFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.765 1.559a.5.5 0 0 1 .47 0l7.5 4a.5.5 0 0 1 0 .882l-7.5 4a.5.5 0 0 1-.47 0l-7.5-4a.5.5 0 0 1 0-.882l7.5-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m2.125 8.567-1.86.992a.5.5 0 0 0 0 .882l7.5 4a.5.5 0 0 0 .47 0l7.5-4a.5.5 0 0 0 0-.882l-1.86-.992-5.17 2.756a1.5 1.5 0 0 1-1.41 0l-5.17-2.756z\"}}]})(props);\n};\nexport function BsFillLightbulbFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 6a6 6 0 1 1 10.174 4.31c-.203.196-.359.4-.453.619l-.762 1.769A.5.5 0 0 1 10.5 13h-5a.5.5 0 0 1-.46-.302l-.761-1.77a1.964 1.964 0 0 0-.453-.618A5.984 5.984 0 0 1 2 6zm3 8.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1l-.224.447a1 1 0 0 1-.894.553H6.618a1 1 0 0 1-.894-.553L5.5 15a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFillLightbulbOffFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 6c0-.572.08-1.125.23-1.65l8.558 8.559A.5.5 0 0 1 10.5 13h-5a.5.5 0 0 1-.46-.302l-.761-1.77a1.964 1.964 0 0 0-.453-.618A5.984 5.984 0 0 1 2 6zm10.303 4.181L3.818 1.697a6 6 0 0 1 8.484 8.484zM5 14.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1l-.224.447a1 1 0 0 1-.894.553H6.618a1 1 0 0 1-.894-.553L5.5 15a.5.5 0 0 1-.5-.5zM2.354 1.646a.5.5 0 1 0-.708.708l12 12a.5.5 0 0 0 .708-.708l-12-12z\"}}]})(props);\n};\nexport function BsFillLightningChargeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.251.068a.5.5 0 0 1 .227.58L9.677 6.5H13a.5.5 0 0 1 .364.843l-8 8.5a.5.5 0 0 1-.842-.49L6.323 9.5H3a.5.5 0 0 1-.364-.843l8-8.5a.5.5 0 0 1 .615-.09z\"}}]})(props);\n};\nexport function BsFillLightningFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.52.359A.5.5 0 0 1 6 0h4a.5.5 0 0 1 .474.658L8.694 6H12.5a.5.5 0 0 1 .395.807l-7 9a.5.5 0 0 1-.873-.454L6.823 9.5H3.5a.5.5 0 0 1-.48-.641l2.5-8.5z\"}}]})(props);\n};\nexport function BsFillLockFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a2 2 0 0 1 2 2v4H6V3a2 2 0 0 1 2-2zm3 6V3a3 3 0 0 0-6 0v4a2 2 0 0 0-2 2v5a2 2 0 0 0 2 2h6a2 2 0 0 0 2-2V9a2 2 0 0 0-2-2z\"}}]})(props);\n};\nexport function BsFillMapFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M16 .5a.5.5 0 0 0-.598-.49L10.5.99 5.598.01a.5.5 0 0 0-.196 0l-5 1A.5.5 0 0 0 0 1.5v14a.5.5 0 0 0 .598.49l4.902-.98 4.902.98a.502.502 0 0 0 .196 0l5-1A.5.5 0 0 0 16 14.5V.5zM5 14.09V1.11l.5-.1.5.1v12.98l-.402-.08a.498.498 0 0 0-.196 0L5 14.09zm5 .8V1.91l.402.08a.5.5 0 0 0 .196 0L11 1.91v12.98l-.5.1-.5-.1z\"}}]})(props);\n};\nexport function BsFillMarkdownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm11.5 1a.5.5 0 0 0-.5.5v3.793L9.854 8.146a.5.5 0 1 0-.708.708l2 2a.5.5 0 0 0 .708 0l2-2a.5.5 0 0 0-.708-.708L12 9.293V5.5a.5.5 0 0 0-.5-.5zM3.56 7.01h.056l1.428 3.239h.774l1.42-3.24h.056V11h1.073V5.001h-1.2l-1.71 3.894h-.039l-1.71-3.894H2.5V11h1.06V7.01z\"}}]})(props);\n};\nexport function BsFillMegaphoneFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13 2.5a1.5 1.5 0 0 1 3 0v11a1.5 1.5 0 0 1-3 0v-11zm-1 .724c-2.067.95-4.539 1.481-7 1.656v6.237a25.222 25.222 0 0 1 1.088.085c2.053.204 4.038.668 5.912 1.56V3.224zm-8 7.841V4.934c-.68.027-1.399.043-2.008.053A2.02 2.02 0 0 0 0 7v2c0 1.106.896 1.996 1.994 2.009a68.14 68.14 0 0 1 .496.008 64 64 0 0 1 1.51.048zm1.39 1.081c.285.021.569.047.85.078l.253 1.69a1 1 0 0 1-.983 1.187h-.548a1 1 0 0 1-.916-.599l-1.314-2.48a65.81 65.81 0 0 1 1.692.064c.327.017.65.037.966.06z\"}}]})(props);\n};\nexport function BsFillMenuAppFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1.5A1.5 1.5 0 0 1 1.5 0h2A1.5 1.5 0 0 1 5 1.5v2A1.5 1.5 0 0 1 3.5 5h-2A1.5 1.5 0 0 1 0 3.5v-2zM0 8a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V8zm1 3v2a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2H1zm14-1V8a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v2h14zM2 8.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0 4a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFillMenuButtonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 0A1.5 1.5 0 0 0 0 1.5v2A1.5 1.5 0 0 0 1.5 5h8A1.5 1.5 0 0 0 11 3.5v-2A1.5 1.5 0 0 0 9.5 0h-8zm5.927 2.427A.25.25 0 0 1 7.604 2h.792a.25.25 0 0 1 .177.427l-.396.396a.25.25 0 0 1-.354 0l-.396-.396zM0 8a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V8zm1 3v2a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2H1zm14-1V8a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v2h14zM2 8.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0 4a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFillMenuButtonWideFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 0A1.5 1.5 0 0 0 0 1.5v2A1.5 1.5 0 0 0 1.5 5h13A1.5 1.5 0 0 0 16 3.5v-2A1.5 1.5 0 0 0 14.5 0h-13zm1 2h3a.5.5 0 0 1 0 1h-3a.5.5 0 0 1 0-1zm9.927.427A.25.25 0 0 1 12.604 2h.792a.25.25 0 0 1 .177.427l-.396.396a.25.25 0 0 1-.354 0l-.396-.396zM0 8a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V8zm1 3v2a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2H1zm14-1V8a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v2h14zM2 8.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0 4a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFillMicFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 3a3 3 0 0 1 6 0v5a3 3 0 0 1-6 0V3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 6.5A.5.5 0 0 1 4 7v1a4 4 0 0 0 8 0V7a.5.5 0 0 1 1 0v1a5 5 0 0 1-4.5 4.975V15h3a.5.5 0 0 1 0 1h-7a.5.5 0 0 1 0-1h3v-2.025A5 5 0 0 1 3 8V7a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsFillMicMuteFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13 8c0 .564-.094 1.107-.266 1.613l-.814-.814A4.02 4.02 0 0 0 12 8V7a.5.5 0 0 1 1 0v1zm-5 4c.818 0 1.578-.245 2.212-.667l.718.719a4.973 4.973 0 0 1-2.43.923V15h3a.5.5 0 0 1 0 1h-7a.5.5 0 0 1 0-1h3v-2.025A5 5 0 0 1 3 8V7a.5.5 0 0 1 1 0v1a4 4 0 0 0 4 4zm3-9v4.879L5.158 2.037A3.001 3.001 0 0 1 11 3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.486 10.607 5 6.12V8a3 3 0 0 0 4.486 2.607zm-7.84-9.253 12 12 .708-.708-12-12-.708.708z\"}}]})(props);\n};\nexport function BsFillMoonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 .278a.768.768 0 0 1 .08.858 7.208 7.208 0 0 0-.878 3.46c0 4.021 3.278 7.277 7.318 7.277.527 0 1.04-.055 1.533-.16a.787.787 0 0 1 .81.316.733.733 0 0 1-.031.893A8.349 8.349 0 0 1 8.344 16C3.734 16 0 12.286 0 7.71 0 4.266 2.114 1.312 5.124.06A.752.752 0 0 1 6 .278z\"}}]})(props);\n};\nexport function BsFillMoonStarsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 .278a.768.768 0 0 1 .08.858 7.208 7.208 0 0 0-.878 3.46c0 4.021 3.278 7.277 7.318 7.277.527 0 1.04-.055 1.533-.16a.787.787 0 0 1 .81.316.733.733 0 0 1-.031.893A8.349 8.349 0 0 1 8.344 16C3.734 16 0 12.286 0 7.71 0 4.266 2.114 1.312 5.124.06A.752.752 0 0 1 6 .278z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.794 3.148a.217.217 0 0 1 .412 0l.387 1.162c.173.518.579.924 1.097 1.097l1.162.387a.217.217 0 0 1 0 .412l-1.162.387a1.734 1.734 0 0 0-1.097 1.097l-.387 1.162a.217.217 0 0 1-.412 0l-.387-1.162A1.734 1.734 0 0 0 9.31 6.593l-1.162-.387a.217.217 0 0 1 0-.412l1.162-.387a1.734 1.734 0 0 0 1.097-1.097l.387-1.162zM13.863.099a.145.145 0 0 1 .274 0l.258.774c.115.346.386.617.732.732l.774.258a.145.145 0 0 1 0 .274l-.774.258a1.156 1.156 0 0 0-.732.732l-.258.774a.145.145 0 0 1-.274 0l-.258-.774a1.156 1.156 0 0 0-.732-.732l-.774-.258a.145.145 0 0 1 0-.274l.774-.258c.346-.115.617-.386.732-.732L13.863.1z\"}}]})(props);\n};\nexport function BsFillMouseFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 5a5 5 0 0 1 10 0v6a5 5 0 0 1-10 0V5zm5.5-1.5a.5.5 0 0 0-1 0v2a.5.5 0 0 0 1 0v-2z\"}}]})(props);\n};\nexport function BsFillMouse2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5.026C4.958.286 3 2.515 3 5.188V5.5h4.5V.026zm1 0V5.5H13v-.312C13 2.515 11.042.286 8.5.026zM13 6.5H3v4.313C3 13.658 5.22 16 8 16s5-2.342 5-5.188V6.5z\"}}]})(props);\n};\nexport function BsFillMouse3Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5.069A15.328 15.328 0 0 0 7 0c-.593 0-1.104.157-1.527.463-.418.302-.717.726-.93 1.208-.386.873-.522 2.01-.54 3.206l4.497 1V.069zM3.71 5.836 3.381 6A2.5 2.5 0 0 0 2 8.236v2.576C2 13.659 4.22 16 7 16h2c2.78 0 5-2.342 5-5.188V8.123l-9-2v.003l.008.353c.007.3.023.715.053 1.175.063.937.186 2.005.413 2.688a.5.5 0 1 1-.948.316c-.273-.817-.4-2-.462-2.937A30.16 30.16 0 0 1 4 6.003c0-.034.003-.067.01-.1l-.3-.067zM14 7.1V5.187c0-1.13-.272-2.044-.748-2.772-.474-.726-1.13-1.235-1.849-1.59A7.495 7.495 0 0 0 9.5.212v5.887l4.5 1z\"}}]})(props);\n};\nexport function BsFillMusicPlayerFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm1 2h6a1 1 0 0 1 1 1v2.5a1 1 0 0 1-1 1H5a1 1 0 0 1-1-1V3a1 1 0 0 1 1-1zm3 12a3 3 0 1 1 0-6 3 3 0 0 1 0 6z\"}}]})(props);\n};\nexport function BsFillNodeMinusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M16 8a5 5 0 0 1-9.975.5H4A1.5 1.5 0 0 1 2.5 10h-1A1.5 1.5 0 0 1 0 8.5v-1A1.5 1.5 0 0 1 1.5 6h1A1.5 1.5 0 0 1 4 7.5h2.025A5 5 0 0 1 16 8zm-2 0a.5.5 0 0 0-.5-.5h-5a.5.5 0 0 0 0 1h5A.5.5 0 0 0 14 8z\"}}]})(props);\n};\nexport function BsFillNodePlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 13a5 5 0 1 0-4.975-5.5H4A1.5 1.5 0 0 0 2.5 6h-1A1.5 1.5 0 0 0 0 7.5v1A1.5 1.5 0 0 0 1.5 10h1A1.5 1.5 0 0 0 4 8.5h2.025A5 5 0 0 0 11 13zm.5-7.5v2h2a.5.5 0 0 1 0 1h-2v2a.5.5 0 0 1-1 0v-2h-2a.5.5 0 0 1 0-1h2v-2a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFillNutFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.58 1a1 1 0 0 0-.868.504l-3.428 6a1 1 0 0 0 0 .992l3.428 6A1 1 0 0 0 4.58 15h6.84a1 1 0 0 0 .868-.504l3.429-6a1 1 0 0 0 0-.992l-3.429-6A1 1 0 0 0 11.42 1H4.58zm5.018 9.696a3 3 0 1 1-3-5.196 3 3 0 0 1 3 5.196z\"}}]})(props);\n};\nexport function BsFillOctagonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.107 0a.5.5 0 0 1 .353.146l4.394 4.394a.5.5 0 0 1 .146.353v6.214a.5.5 0 0 1-.146.353l-4.394 4.394a.5.5 0 0 1-.353.146H4.893a.5.5 0 0 1-.353-.146L.146 11.46A.5.5 0 0 1 0 11.107V4.893a.5.5 0 0 1 .146-.353L4.54.146A.5.5 0 0 1 4.893 0h6.214z\"}}]})(props);\n};\nexport function BsFillPaletteFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.433 10.07C14.133 10.585 16 11.15 16 8a8 8 0 1 0-8 8c1.996 0 1.826-1.504 1.649-3.08-.124-1.101-.252-2.237.351-2.92.465-.527 1.42-.237 2.433.07zM8 5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm4.5 3a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zM5 6.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm.5 6.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsFillPatchCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.067.87a2.89 2.89 0 0 0-4.134 0l-.622.638-.89-.011a2.89 2.89 0 0 0-2.924 2.924l.01.89-.636.622a2.89 2.89 0 0 0 0 4.134l.637.622-.011.89a2.89 2.89 0 0 0 2.924 2.924l.89-.01.622.636a2.89 2.89 0 0 0 4.134 0l.622-.637.89.011a2.89 2.89 0 0 0 2.924-2.924l-.01-.89.636-.622a2.89 2.89 0 0 0 0-4.134l-.637-.622.011-.89a2.89 2.89 0 0 0-2.924-2.924l-.89.01-.622-.636zm.287 5.984-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7 8.793l2.646-2.647a.5.5 0 0 1 .708.708z\"}}]})(props);\n};\nexport function BsFillPatchExclamationFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.067.87a2.89 2.89 0 0 0-4.134 0l-.622.638-.89-.011a2.89 2.89 0 0 0-2.924 2.924l.01.89-.636.622a2.89 2.89 0 0 0 0 4.134l.637.622-.011.89a2.89 2.89 0 0 0 2.924 2.924l.89-.01.622.636a2.89 2.89 0 0 0 4.134 0l.622-.637.89.011a2.89 2.89 0 0 0 2.924-2.924l-.01-.89.636-.622a2.89 2.89 0 0 0 0-4.134l-.637-.622.011-.89a2.89 2.89 0 0 0-2.924-2.924l-.89.01-.622-.636zM8 4c.535 0 .954.462.9.995l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 4.995A.905.905 0 0 1 8 4zm.002 6a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\"}}]})(props);\n};\nexport function BsFillPatchMinusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.067.87a2.89 2.89 0 0 0-4.134 0l-.622.638-.89-.011a2.89 2.89 0 0 0-2.924 2.924l.01.89-.636.622a2.89 2.89 0 0 0 0 4.134l.637.622-.011.89a2.89 2.89 0 0 0 2.924 2.924l.89-.01.622.636a2.89 2.89 0 0 0 4.134 0l.622-.637.89.011a2.89 2.89 0 0 0 2.924-2.924l-.01-.89.636-.622a2.89 2.89 0 0 0 0-4.134l-.637-.622.011-.89a2.89 2.89 0 0 0-2.924-2.924l-.89.01-.622-.636zM6 7.5h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFillPatchPlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.067.87a2.89 2.89 0 0 0-4.134 0l-.622.638-.89-.011a2.89 2.89 0 0 0-2.924 2.924l.01.89-.636.622a2.89 2.89 0 0 0 0 4.134l.637.622-.011.89a2.89 2.89 0 0 0 2.924 2.924l.89-.01.622.636a2.89 2.89 0 0 0 4.134 0l.622-.637.89.011a2.89 2.89 0 0 0 2.924-2.924l-.01-.89.636-.622a2.89 2.89 0 0 0 0-4.134l-.637-.622.011-.89a2.89 2.89 0 0 0-2.924-2.924l-.89.01-.622-.636zM8.5 6v1.5H10a.5.5 0 0 1 0 1H8.5V10a.5.5 0 0 1-1 0V8.5H6a.5.5 0 0 1 0-1h1.5V6a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFillPatchQuestionFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.933.87a2.89 2.89 0 0 1 4.134 0l.622.638.89-.011a2.89 2.89 0 0 1 2.924 2.924l-.01.89.636.622a2.89 2.89 0 0 1 0 4.134l-.637.622.011.89a2.89 2.89 0 0 1-2.924 2.924l-.89-.01-.622.636a2.89 2.89 0 0 1-4.134 0l-.622-.637-.89.011a2.89 2.89 0 0 1-2.924-2.924l.01-.89-.636-.622a2.89 2.89 0 0 1 0-4.134l.637-.622-.011-.89a2.89 2.89 0 0 1 2.924-2.924l.89.01.622-.636zM7.002 11a1 1 0 1 0 2 0 1 1 0 0 0-2 0zm1.602-2.027c.04-.534.198-.815.846-1.26.674-.475 1.05-1.09 1.05-1.986 0-1.325-.92-2.227-2.262-2.227-1.02 0-1.792.492-2.1 1.29A1.71 1.71 0 0 0 6 5.48c0 .393.203.64.545.64.272 0 .455-.147.564-.51.158-.592.525-.915 1.074-.915.61 0 1.03.446 1.03 1.084 0 .563-.208.885-.822 1.325-.619.433-.926.914-.926 1.64v.111c0 .428.208.745.585.745.336 0 .504-.24.554-.627z\"}}]})(props);\n};\nexport function BsFillPauseBtnFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12V4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm6.25-7C5.56 5 5 5.56 5 6.25v3.5a1.25 1.25 0 1 0 2.5 0v-3.5C7.5 5.56 6.94 5 6.25 5zm3.5 0c-.69 0-1.25.56-1.25 1.25v3.5a1.25 1.25 0 1 0 2.5 0v-3.5C11 5.56 10.44 5 9.75 5z\"}}]})(props);\n};\nexport function BsFillPauseCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM6.25 5C5.56 5 5 5.56 5 6.25v3.5a1.25 1.25 0 1 0 2.5 0v-3.5C7.5 5.56 6.94 5 6.25 5zm3.5 0c-.69 0-1.25.56-1.25 1.25v3.5a1.25 1.25 0 1 0 2.5 0v-3.5C11 5.56 10.44 5 9.75 5z\"}}]})(props);\n};\nexport function BsFillPauseFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 3.5A1.5 1.5 0 0 1 7 5v6a1.5 1.5 0 0 1-3 0V5a1.5 1.5 0 0 1 1.5-1.5zm5 0A1.5 1.5 0 0 1 12 5v6a1.5 1.5 0 0 1-3 0V5a1.5 1.5 0 0 1 1.5-1.5z\"}}]})(props);\n};\nexport function BsFillPeaceFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 13.292A8 8 0 0 0 8.5.015v7.778l5.5 5.5zm-.708.708L8.5 9.206v6.778a7.967 7.967 0 0 0 4.792-1.986zM7.5 15.985V9.207L2.708 14A7.967 7.967 0 0 0 7.5 15.985zM2 13.292A8 8 0 0 1 7.5.015v7.778l-5.5 5.5z\"}}]})(props);\n};\nexport function BsFillPenFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m13.498.795.149-.149a1.207 1.207 0 1 1 1.707 1.708l-.149.148a1.5 1.5 0 0 1-.059 2.059L4.854 14.854a.5.5 0 0 1-.233.131l-4 1a.5.5 0 0 1-.606-.606l1-4a.5.5 0 0 1 .131-.232l9.642-9.642a.5.5 0 0 0-.642.056L6.854 4.854a.5.5 0 1 1-.708-.708L9.44.854A1.5 1.5 0 0 1 11.5.796a1.5 1.5 0 0 1 1.998-.001z\"}}]})(props);\n};\nexport function BsFillPencilFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.854.146a.5.5 0 0 0-.707 0L10.5 1.793 14.207 5.5l1.647-1.646a.5.5 0 0 0 0-.708l-3-3zm.646 6.061L9.793 2.5 3.293 9H3.5a.5.5 0 0 1 .5.5v.5h.5a.5.5 0 0 1 .5.5v.5h.5a.5.5 0 0 1 .5.5v.5h.5a.5.5 0 0 1 .5.5v.207l6.5-6.5zm-7.468 7.468A.5.5 0 0 1 6 13.5V13h-.5a.5.5 0 0 1-.5-.5V12h-.5a.5.5 0 0 1-.5-.5V11h-.5a.5.5 0 0 1-.5-.5V10h-.5a.499.499 0 0 1-.175-.032l-.179.178a.5.5 0 0 0-.11.168l-2 5a.5.5 0 0 0 .65.65l5-2a.5.5 0 0 0 .168-.11l.178-.178z\"}}]})(props);\n};\nexport function BsFillPentagonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m8 0 8 6.5-3 9.5H3L0 6.5 8 0z\"}}]})(props);\n};\nexport function BsFillPeopleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 14s-1 0-1-1 1-4 5-4 5 3 5 4-1 1-1 1H7zm4-6a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5.216 14A2.238 2.238 0 0 1 5 13c0-1.355.68-2.75 1.936-3.72A6.325 6.325 0 0 0 5 9c-4 0-5 3-5 4s1 1 1 1h4.216z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 8a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5z\"}}]})(props);\n};\nexport function BsFillPersonBadgeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm4.5 0a.5.5 0 0 0 0 1h3a.5.5 0 0 0 0-1h-3zM8 11a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm5 2.755C12.146 12.825 10.623 12 8 12s-4.146.826-5 1.755V14a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1v-.245z\"}}]})(props);\n};\nexport function BsFillPersonCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M15.854 5.146a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 0 1 .708-.708L12.5 7.793l2.646-2.647a.5.5 0 0 1 .708 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 14s-1 0-1-1 1-4 6-4 6 3 6 4-1 1-1 1H1zm5-6a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}}]})(props);\n};\nexport function BsFillPersonDashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11 7.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 14s-1 0-1-1 1-4 6-4 6 3 6 4-1 1-1 1H1zm5-6a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}}]})(props);\n};\nexport function BsFillPersonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 14s-1 0-1-1 1-4 6-4 6 3 6 4-1 1-1 1H3zm5-6a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}}]})(props);\n};\nexport function BsFillPersonLinesFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-5 6s-1 0-1-1 1-4 6-4 6 3 6 4-1 1-1 1H1zM11 3.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5zm.5 2.5a.5.5 0 0 0 0 1h4a.5.5 0 0 0 0-1h-4zm2 3a.5.5 0 0 0 0 1h2a.5.5 0 0 0 0-1h-2zm0 3a.5.5 0 0 0 0 1h2a.5.5 0 0 0 0-1h-2z\"}}]})(props);\n};\nexport function BsFillPersonPlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 14s-1 0-1-1 1-4 6-4 6 3 6 4-1 1-1 1H1zm5-6a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M13.5 5a.5.5 0 0 1 .5.5V7h1.5a.5.5 0 0 1 0 1H14v1.5a.5.5 0 0 1-1 0V8h-1.5a.5.5 0 0 1 0-1H13V5.5a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsFillPersonXFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 14s-1 0-1-1 1-4 6-4 6 3 6 4-1 1-1 1H1zm5-6a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm6.146-2.854a.5.5 0 0 1 .708 0L14 6.293l1.146-1.147a.5.5 0 0 1 .708.708L14.707 7l1.147 1.146a.5.5 0 0 1-.708.708L14 7.707l-1.146 1.147a.5.5 0 0 1-.708-.708L13.293 7l-1.147-1.146a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsFillPhoneFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 2a2 2 0 0 1 2-2h6a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V2zm6 11a1 1 0 1 0-2 0 1 1 0 0 0 2 0z\"}}]})(props);\n};\nexport function BsFillPhoneLandscapeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 12.5a2 2 0 0 1-2-2v-6a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v6a2 2 0 0 1-2 2H2zm11-6a1 1 0 1 0 0 2 1 1 0 0 0 0-2z\"}}]})(props);\n};\nexport function BsFillPhoneVibrateFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V4zm5 7a1 1 0 1 0-2 0 1 1 0 0 0 2 0zM1.807 4.734a.5.5 0 1 0-.884-.468A7.967 7.967 0 0 0 0 8c0 1.347.334 2.618.923 3.734a.5.5 0 1 0 .884-.468A6.967 6.967 0 0 1 1 8c0-1.18.292-2.292.807-3.266zm13.27-.468a.5.5 0 0 0-.884.468C14.708 5.708 15 6.819 15 8c0 1.18-.292 2.292-.807 3.266a.5.5 0 0 0 .884.468A7.967 7.967 0 0 0 16 8a7.967 7.967 0 0 0-.923-3.734zM3.34 6.182a.5.5 0 1 0-.93-.364A5.986 5.986 0 0 0 2 8c0 .769.145 1.505.41 2.182a.5.5 0 1 0 .93-.364A4.986 4.986 0 0 1 3 8c0-.642.12-1.255.34-1.818zm10.25-.364a.5.5 0 0 0-.93.364c.22.563.34 1.176.34 1.818 0 .642-.12 1.255-.34 1.818a.5.5 0 0 0 .93.364C13.856 9.505 14 8.769 14 8c0-.769-.145-1.505-.41-2.182z\"}}]})(props);\n};\nexport function BsFillPieChartFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.985 8.5H8.207l-5.5 5.5a8 8 0 0 0 13.277-5.5zM2 13.292A8 8 0 0 1 7.5.015v7.778l-5.5 5.5zM8.5.015V7.5h7.485A8.001 8.001 0 0 0 8.5.015z\"}}]})(props);\n};\nexport function BsFillPiggyBankFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.964 1.527c-2.977 0-5.571 1.704-6.32 4.125h-.55A1 1 0 0 0 .11 6.824l.254 1.46a1.5 1.5 0 0 0 1.478 1.243h.263c.3.513.688.978 1.145 1.382l-.729 2.477a.5.5 0 0 0 .48.641h2a.5.5 0 0 0 .471-.332l.482-1.351c.635.173 1.31.267 2.011.267.707 0 1.388-.095 2.028-.272l.543 1.372a.5.5 0 0 0 .465.316h2a.5.5 0 0 0 .478-.645l-.761-2.506C13.81 9.895 14.5 8.559 14.5 7.069c0-.145-.007-.29-.02-.431.261-.11.508-.266.705-.444.315.306.815.306.815-.417 0 .223-.5.223-.461-.026a.95.95 0 0 0 .09-.255.7.7 0 0 0-.202-.645.58.58 0 0 0-.707-.098.735.735 0 0 0-.375.562c-.024.243.082.48.32.654a2.112 2.112 0 0 1-.259.153c-.534-2.664-3.284-4.595-6.442-4.595zm7.173 3.876a.565.565 0 0 1-.098.21.704.704 0 0 1-.044-.025c-.146-.09-.157-.175-.152-.223a.236.236 0 0 1 .117-.173c.049-.027.08-.021.113.012a.202.202 0 0 1 .064.199zm-8.999-.65A6.613 6.613 0 0 1 7.964 4.5c.666 0 1.303.097 1.893.273a.5.5 0 1 0 .286-.958A7.601 7.601 0 0 0 7.964 3.5c-.734 0-1.441.103-2.102.292a.5.5 0 1 0 .276.962zM5 6.25a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0z\"}}]})(props);\n};\nexport function BsFillPinAngleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.828.722a.5.5 0 0 1 .354.146l4.95 4.95a.5.5 0 0 1 0 .707c-.48.48-1.072.588-1.503.588-.177 0-.335-.018-.46-.039l-3.134 3.134a5.927 5.927 0 0 1 .16 1.013c.046.702-.032 1.687-.72 2.375a.5.5 0 0 1-.707 0l-2.829-2.828-3.182 3.182c-.195.195-1.219.902-1.414.707-.195-.195.512-1.22.707-1.414l3.182-3.182-2.828-2.829a.5.5 0 0 1 0-.707c.688-.688 1.673-.767 2.375-.72a5.922 5.922 0 0 1 1.013.16l3.134-3.133a2.772 2.772 0 0 1-.04-.461c0-.43.108-1.022.589-1.503a.5.5 0 0 1 .353-.146z\"}}]})(props);\n};\nexport function BsFillPinFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.146.146A.5.5 0 0 1 4.5 0h7a.5.5 0 0 1 .5.5c0 .68-.342 1.174-.646 1.479-.126.125-.25.224-.354.298v4.431l.078.048c.203.127.476.314.751.555C12.36 7.775 13 8.527 13 9.5a.5.5 0 0 1-.5.5h-4v4.5c0 .276-.224 1.5-.5 1.5s-.5-1.224-.5-1.5V10h-4a.5.5 0 0 1-.5-.5c0-.973.64-1.725 1.17-2.189A5.921 5.921 0 0 1 5 6.708V2.277a2.77 2.77 0 0 1-.354-.298C4.342 1.674 4 1.179 4 .5a.5.5 0 0 1 .146-.354z\"}}]})(props);\n};\nexport function BsFillPinMapFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.1 11.2a.5.5 0 0 1 .4-.2H6a.5.5 0 0 1 0 1H3.75L1.5 15h13l-2.25-3H10a.5.5 0 0 1 0-1h2.5a.5.5 0 0 1 .4.2l3 4a.5.5 0 0 1-.4.8H.5a.5.5 0 0 1-.4-.8l3-4z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4 4a4 4 0 1 1 4.5 3.969V13.5a.5.5 0 0 1-1 0V7.97A4 4 0 0 1 4 3.999z\"}}]})(props);\n};\nexport function BsFillPipFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 2A1.5 1.5 0 0 0 0 3.5v9A1.5 1.5 0 0 0 1.5 14h13a1.5 1.5 0 0 0 1.5-1.5v-9A1.5 1.5 0 0 0 14.5 2h-13zm7 6h5a.5.5 0 0 1 .5.5v3a.5.5 0 0 1-.5.5h-5a.5.5 0 0 1-.5-.5v-3a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsFillPlayBtnFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12V4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm6.79-6.907A.5.5 0 0 0 6 5.5v5a.5.5 0 0 0 .79.407l3.5-2.5a.5.5 0 0 0 0-.814l-3.5-2.5z\"}}]})(props);\n};\nexport function BsFillPlayCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM6.79 5.093A.5.5 0 0 0 6 5.5v5a.5.5 0 0 0 .79.407l3.5-2.5a.5.5 0 0 0 0-.814l-3.5-2.5z\"}}]})(props);\n};\nexport function BsFillPlayFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m11.596 8.697-6.363 3.692c-.54.313-1.233-.066-1.233-.697V4.308c0-.63.692-1.01 1.233-.696l6.363 3.692a.802.802 0 0 1 0 1.393z\"}}]})(props);\n};\nexport function BsFillPlugFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 0a.5.5 0 0 1 .5.5V3h3V.5a.5.5 0 0 1 1 0V3h1a.5.5 0 0 1 .5.5v3A3.5 3.5 0 0 1 8.5 10c-.002.434-.01.845-.04 1.22-.041.514-.126 1.003-.317 1.424a2.083 2.083 0 0 1-.97 1.028C6.725 13.9 6.169 14 5.5 14c-.998 0-1.61.33-1.974.718A1.922 1.922 0 0 0 3 16H2c0-.616.232-1.367.797-1.968C3.374 13.42 4.261 13 5.5 13c.581 0 .962-.088 1.218-.219.241-.123.4-.3.514-.55.121-.266.193-.621.23-1.09.027-.34.035-.718.037-1.141A3.5 3.5 0 0 1 4 6.5v-3a.5.5 0 0 1 .5-.5h1V.5A.5.5 0 0 1 6 0z\"}}]})(props);\n};\nexport function BsFillPlusCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM8.5 4.5a.5.5 0 0 0-1 0v3h-3a.5.5 0 0 0 0 1h3v3a.5.5 0 0 0 1 0v-3h3a.5.5 0 0 0 0-1h-3v-3z\"}}]})(props);\n};\nexport function BsFillPlusSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm6.5 4.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFillPrinterFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 1a2 2 0 0 0-2 2v1h10V3a2 2 0 0 0-2-2H5zm6 8H5a1 1 0 0 0-1 1v3a1 1 0 0 0 1 1h6a1 1 0 0 0 1-1v-3a1 1 0 0 0-1-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 7a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v3a2 2 0 0 1-2 2h-1v-2a2 2 0 0 0-2-2H5a2 2 0 0 0-2 2v2H2a2 2 0 0 1-2-2V7zm2.5 1a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1z\"}}]})(props);\n};\nexport function BsFillPuzzleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.112 3.645A1.5 1.5 0 0 1 4.605 2H7a.5.5 0 0 1 .5.5v.382c0 .696-.497 1.182-.872 1.469a.459.459 0 0 0-.115.118.113.113 0 0 0-.012.025L6.5 4.5v.003l.003.01c.004.01.014.028.036.053a.86.86 0 0 0 .27.194C7.09 4.9 7.51 5 8 5c.492 0 .912-.1 1.19-.24a.86.86 0 0 0 .271-.194.213.213 0 0 0 .036-.054l.003-.01v-.008a.112.112 0 0 0-.012-.025.459.459 0 0 0-.115-.118c-.375-.287-.872-.773-.872-1.469V2.5A.5.5 0 0 1 9 2h2.395a1.5 1.5 0 0 1 1.493 1.645L12.645 6.5h.237c.195 0 .42-.147.675-.48.21-.274.528-.52.943-.52.568 0 .947.447 1.154.862C15.877 6.807 16 7.387 16 8s-.123 1.193-.346 1.638c-.207.415-.586.862-1.154.862-.415 0-.733-.246-.943-.52-.255-.333-.48-.48-.675-.48h-.237l.243 2.855A1.5 1.5 0 0 1 11.395 14H9a.5.5 0 0 1-.5-.5v-.382c0-.696.497-1.182.872-1.469a.459.459 0 0 0 .115-.118.113.113 0 0 0 .012-.025L9.5 11.5v-.003l-.003-.01a.214.214 0 0 0-.036-.053.859.859 0 0 0-.27-.194C8.91 11.1 8.49 11 8 11c-.491 0-.912.1-1.19.24a.859.859 0 0 0-.271.194.214.214 0 0 0-.036.054l-.003.01v.002l.001.006a.113.113 0 0 0 .012.025c.016.027.05.068.115.118.375.287.872.773.872 1.469v.382a.5.5 0 0 1-.5.5H4.605a1.5 1.5 0 0 1-1.493-1.645L3.356 9.5h-.238c-.195 0-.42.147-.675.48-.21.274-.528.52-.943.52-.568 0-.947-.447-1.154-.862C.123 9.193 0 8.613 0 8s.123-1.193.346-1.638C.553 5.947.932 5.5 1.5 5.5c.415 0 .733.246.943.52.255.333.48.48.675.48h.238l-.244-2.855z\"}}]})(props);\n};\nexport function BsFillQuestionCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM5.496 6.033h.825c.138 0 .248-.113.266-.25.09-.656.54-1.134 1.342-1.134.686 0 1.314.343 1.314 1.168 0 .635-.374.927-.965 1.371-.673.489-1.206 1.06-1.168 1.987l.003.217a.25.25 0 0 0 .25.246h.811a.25.25 0 0 0 .25-.25v-.105c0-.718.273-.927 1.01-1.486.609-.463 1.244-.977 1.244-2.056 0-1.511-1.276-2.241-2.673-2.241-1.267 0-2.655.59-2.75 2.286a.237.237 0 0 0 .241.247zm2.325 6.443c.61 0 1.029-.394 1.029-.927 0-.552-.42-.94-1.029-.94-.584 0-1.009.388-1.009.94 0 .533.425.927 1.01.927z\"}}]})(props);\n};\nexport function BsFillQuestionDiamondFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.05.435c-.58-.58-1.52-.58-2.1 0L.436 6.95c-.58.58-.58 1.519 0 2.098l6.516 6.516c.58.58 1.519.58 2.098 0l6.516-6.516c.58-.58.58-1.519 0-2.098L9.05.435zM5.495 6.033a.237.237 0 0 1-.24-.247C5.35 4.091 6.737 3.5 8.005 3.5c1.396 0 2.672.73 2.672 2.24 0 1.08-.635 1.594-1.244 2.057-.737.559-1.01.768-1.01 1.486v.105a.25.25 0 0 1-.25.25h-.81a.25.25 0 0 1-.25-.246l-.004-.217c-.038-.927.495-1.498 1.168-1.987.59-.444.965-.736.965-1.371 0-.825-.628-1.168-1.314-1.168-.803 0-1.253.478-1.342 1.134-.018.137-.128.25-.266.25h-.825zm2.325 6.443c-.584 0-1.009-.394-1.009-.927 0-.552.425-.94 1.01-.94.609 0 1.028.388 1.028.94 0 .533-.42.927-1.029.927z\"}}]})(props);\n};\nexport function BsFillQuestionOctagonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.46.146A.5.5 0 0 0 11.107 0H4.893a.5.5 0 0 0-.353.146L.146 4.54A.5.5 0 0 0 0 4.893v6.214a.5.5 0 0 0 .146.353l4.394 4.394a.5.5 0 0 0 .353.146h6.214a.5.5 0 0 0 .353-.146l4.394-4.394a.5.5 0 0 0 .146-.353V4.893a.5.5 0 0 0-.146-.353L11.46.146zM5.496 6.033a.237.237 0 0 1-.24-.247C5.35 4.091 6.737 3.5 8.005 3.5c1.396 0 2.672.73 2.672 2.24 0 1.08-.635 1.594-1.244 2.057-.737.559-1.01.768-1.01 1.486v.105a.25.25 0 0 1-.25.25h-.81a.25.25 0 0 1-.25-.246l-.004-.217c-.038-.927.495-1.498 1.168-1.987.59-.444.965-.736.965-1.371 0-.825-.628-1.168-1.314-1.168-.803 0-1.253.478-1.342 1.134-.018.137-.128.25-.266.25h-.825zm2.325 6.443c-.584 0-1.009-.394-1.009-.927 0-.552.425-.94 1.01-.94.609 0 1.028.388 1.028.94 0 .533-.42.927-1.029.927z\"}}]})(props);\n};\nexport function BsFillQuestionSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm3.496 6.033a.237.237 0 0 1-.24-.247C5.35 4.091 6.737 3.5 8.005 3.5c1.396 0 2.672.73 2.672 2.24 0 1.08-.635 1.594-1.244 2.057-.737.559-1.01.768-1.01 1.486v.105a.25.25 0 0 1-.25.25h-.81a.25.25 0 0 1-.25-.246l-.004-.217c-.038-.927.495-1.498 1.168-1.987.59-.444.965-.736.965-1.371 0-.825-.628-1.168-1.314-1.168-.803 0-1.253.478-1.342 1.134-.018.137-.128.25-.266.25h-.825zm2.325 6.443c-.584 0-1.009-.394-1.009-.927 0-.552.425-.94 1.01-.94.609 0 1.028.388 1.028.94 0 .533-.42.927-1.029.927z\"}}]})(props);\n};\nexport function BsFillRecordBtnFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12V4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm8-1a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}}]})(props);\n};\nexport function BsFillRecordCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-8 3a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}}]})(props);\n};\nexport function BsFillRecordFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 13A5 5 0 1 0 8 3a5 5 0 0 0 0 10z\"}}]})(props);\n};\nexport function BsFillRecord2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10 8a2 2 0 1 1-4 0 2 2 0 0 1 4 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13A5 5 0 1 0 8 3a5 5 0 0 0 0 10zm0-2a3 3 0 1 1 0-6 3 3 0 0 1 0 6z\"}}]})(props);\n};\nexport function BsFillReplyAllFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.021 11.9 3.453 8.62a.719.719 0 0 1 0-1.238L8.021 4.1a.716.716 0 0 1 1.079.619V6c1.5 0 6 0 7 8-2.5-4.5-7-4-7-4v1.281c0 .56-.606.898-1.079.62z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.232 4.293a.5.5 0 0 1-.106.7L1.114 7.945a.5.5 0 0 1-.042.028.147.147 0 0 0 0 .252.503.503 0 0 1 .042.028l4.012 2.954a.5.5 0 1 1-.593.805L.539 9.073a1.147 1.147 0 0 1 0-1.946l3.994-2.94a.5.5 0 0 1 .699.106z\"}}]})(props);\n};\nexport function BsFillReplyFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.921 11.9 1.353 8.62a.719.719 0 0 1 0-1.238L5.921 4.1A.716.716 0 0 1 7 4.719V6c1.5 0 6 0 7 8-2.5-4.5-7-4-7-4v1.281c0 .56-.606.898-1.079.62z\"}}]})(props);\n};\nexport function BsFillRssFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm1.5 2.5c5.523 0 10 4.477 10 10a1 1 0 1 1-2 0 8 8 0 0 0-8-8 1 1 0 0 1 0-2zm0 4a6 6 0 0 1 6 6 1 1 0 1 1-2 0 4 4 0 0 0-4-4 1 1 0 0 1 0-2zm.5 7a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsFillSafeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.778 9.414A2 2 0 1 1 6.95 6.586a2 2 0 0 1 2.828 2.828z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 0A1.5 1.5 0 0 0 1 1.5V3H.5a.5.5 0 0 0 0 1H1v3.5H.5a.5.5 0 0 0 0 1H1V12H.5a.5.5 0 0 0 0 1H1v1.5A1.5 1.5 0 0 0 2.5 16h12a1.5 1.5 0 0 0 1.5-1.5v-13A1.5 1.5 0 0 0 14.5 0h-12zm3.036 4.464 1.09 1.09a3.003 3.003 0 0 1 3.476 0l1.09-1.09a.5.5 0 1 1 .707.708l-1.09 1.09c.74 1.037.74 2.44 0 3.476l1.09 1.09a.5.5 0 1 1-.707.708l-1.09-1.09a3.002 3.002 0 0 1-3.476 0l-1.09 1.09a.5.5 0 1 1-.708-.708l1.09-1.09a3.003 3.003 0 0 1 0-3.476l-1.09-1.09a.5.5 0 1 1 .708-.708zM14 6.5v3a.5.5 0 0 1-1 0v-3a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFillSafe2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.563 8H5.035a3.482 3.482 0 0 1 .662-1.596l1.08 1.08c-.094.16-.167.332-.214.516zm.921-1.223-1.08-1.08A3.482 3.482 0 0 1 8 5.035v1.528c-.184.047-.357.12-.516.214zM9 6.563V5.035a3.482 3.482 0 0 1 1.596.662l-1.08 1.08A1.988 1.988 0 0 0 9 6.563zm1.223.921 1.08-1.08c.343.458.577 1.003.662 1.596h-1.528a1.989 1.989 0 0 0-.214-.516zM10.437 9h1.528a3.483 3.483 0 0 1-.662 1.596l-1.08-1.08c.094-.16.167-.332.214-.516zm-.921 1.223 1.08 1.08A3.483 3.483 0 0 1 9 11.965v-1.528c.184-.047.357-.12.516-.214zM8 10.437v1.528a3.483 3.483 0 0 1-1.596-.662l1.08-1.08c.16.094.332.167.516.214zm-1.223-.921-1.08 1.08A3.482 3.482 0 0 1 5.035 9h1.528c.047.184.12.357.214.516zM7.5 8.5a1 1 0 1 1 2 0 1 1 0 0 1-2 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 1A1.5 1.5 0 0 0 1 2.5V3H.5a.5.5 0 0 0 0 1H1v4H.5a.5.5 0 0 0 0 1H1v4H.5a.5.5 0 0 0 0 1H1v.5A1.5 1.5 0 0 0 2.5 16h12a1.5 1.5 0 0 0 1.5-1.5v-12A1.5 1.5 0 0 0 14.5 1h-12zm6 3a4.5 4.5 0 1 1 0 9 4.5 4.5 0 0 1 0-9z\"}}]})(props);\n};\nexport function BsFillSaveFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 1.5A1.5 1.5 0 0 1 10 0h4a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h6c-.314.418-.5.937-.5 1.5v7.793L4.854 6.646a.5.5 0 1 0-.708.708l3.5 3.5a.5.5 0 0 0 .708 0l3.5-3.5a.5.5 0 0 0-.708-.708L8.5 9.293V1.5z\"}}]})(props);\n};\nexport function BsFillSave2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 1.5A1.5 1.5 0 0 1 10 0h4a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h6c-.314.418-.5.937-.5 1.5v6h-2a.5.5 0 0 0-.354.854l2.5 2.5a.5.5 0 0 0 .708 0l2.5-2.5A.5.5 0 0 0 10.5 7.5h-2v-6z\"}}]})(props);\n};\nexport function BsFillSdCardFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M12.5 0H5.914a1.5 1.5 0 0 0-1.06.44L2.439 2.853A1.5 1.5 0 0 0 2 3.914V14.5A1.5 1.5 0 0 0 3.5 16h9a1.5 1.5 0 0 0 1.5-1.5v-13A1.5 1.5 0 0 0 12.5 0zm-7 2.75a.75.75 0 0 1 .75.75v2a.75.75 0 0 1-1.5 0v-2a.75.75 0 0 1 .75-.75zm2 0a.75.75 0 0 1 .75.75v2a.75.75 0 0 1-1.5 0v-2a.75.75 0 0 1 .75-.75zm2.75.75a.75.75 0 0 0-1.5 0v2a.75.75 0 0 0 1.5 0v-2zm1.25-.75a.75.75 0 0 1 .75.75v2a.75.75 0 0 1-1.5 0v-2a.75.75 0 0 1 .75-.75z\"}}]})(props);\n};\nexport function BsFillShareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 2.5a2.5 2.5 0 1 1 .603 1.628l-6.718 3.12a2.499 2.499 0 0 1 0 1.504l6.718 3.12a2.5 2.5 0 1 1-.488.876l-6.718-3.12a2.5 2.5 0 1 1 0-3.256l6.718-3.12A2.5 2.5 0 0 1 11 2.5z\"}}]})(props);\n};\nexport function BsFillShieldFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.072.56C6.157.265 7.31 0 8 0s1.843.265 2.928.56c1.11.3 2.229.655 2.887.87a1.54 1.54 0 0 1 1.044 1.262c.596 4.477-.787 7.795-2.465 9.99a11.775 11.775 0 0 1-2.517 2.453 7.159 7.159 0 0 1-1.048.625c-.28.132-.581.24-.829.24s-.548-.108-.829-.24a7.158 7.158 0 0 1-1.048-.625 11.777 11.777 0 0 1-2.517-2.453C1.928 10.487.545 7.169 1.141 2.692A1.54 1.54 0 0 1 2.185 1.43 62.456 62.456 0 0 1 5.072.56z\"}}]})(props);\n};\nexport function BsFillShieldLockFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 0c-.69 0-1.843.265-2.928.56-1.11.3-2.229.655-2.887.87a1.54 1.54 0 0 0-1.044 1.262c-.596 4.477.787 7.795 2.465 9.99a11.777 11.777 0 0 0 2.517 2.453c.386.273.744.482 1.048.625.28.132.581.24.829.24s.548-.108.829-.24a7.159 7.159 0 0 0 1.048-.625 11.775 11.775 0 0 0 2.517-2.453c1.678-2.195 3.061-5.513 2.465-9.99a1.541 1.541 0 0 0-1.044-1.263 62.467 62.467 0 0 0-2.887-.87C9.843.266 8.69 0 8 0zm0 5a1.5 1.5 0 0 1 .5 2.915l.385 1.99a.5.5 0 0 1-.491.595h-.788a.5.5 0 0 1-.49-.595l.384-1.99A1.5 1.5 0 0 1 8 5z\"}}]})(props);\n};\nexport function BsFillShieldSlashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.093 3.093c-.465 4.275.885 7.46 2.513 9.589a11.777 11.777 0 0 0 2.517 2.453c.386.273.744.482 1.048.625.28.132.581.24.829.24s.548-.108.829-.24a7.159 7.159 0 0 0 1.048-.625 11.32 11.32 0 0 0 1.733-1.525L1.093 3.093zm12.215 8.215L3.128 1.128A61.369 61.369 0 0 1 5.073.56C6.157.265 7.31 0 8 0s1.843.265 2.928.56c1.11.3 2.229.655 2.887.87a1.54 1.54 0 0 1 1.044 1.262c.483 3.626-.332 6.491-1.551 8.616zm.338 3.046-13-13 .708-.708 13 13-.707.707z\"}}]})(props);\n};\nexport function BsFillShiftFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.27 2.047a1 1 0 0 1 1.46 0l6.345 6.77c.6.638.146 1.683-.73 1.683H11.5v3a1 1 0 0 1-1 1h-5a1 1 0 0 1-1-1v-3H1.654C.78 10.5.326 9.455.924 8.816L7.27 2.047z\"}}]})(props);\n};\nexport function BsFillSignpost2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.293.707A1 1 0 0 0 7 1.414V2H2a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h5v1H2.5a1 1 0 0 0-.8.4L.725 8.7a.5.5 0 0 0 0 .6l.975 1.3a1 1 0 0 0 .8.4H7v5h2v-5h5a1 1 0 0 0 1-1V8a1 1 0 0 0-1-1H9V6h4.5a1 1 0 0 0 .8-.4l.975-1.3a.5.5 0 0 0 0-.6L14.3 2.4a1 1 0 0 0-.8-.4H9v-.586A1 1 0 0 0 7.293.707z\"}}]})(props);\n};\nexport function BsFillSignpostFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.293.707A1 1 0 0 0 7 1.414V4H2a1 1 0 0 0-1 1v4a1 1 0 0 0 1 1h5v6h2v-6h3.532a1 1 0 0 0 .768-.36l1.933-2.32a.5.5 0 0 0 0-.64L13.3 4.36a1 1 0 0 0-.768-.36H9V1.414A1 1 0 0 0 7.293.707z\"}}]})(props);\n};\nexport function BsFillSignpostSplitFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 16h2V6h5a1 1 0 0 0 .8-.4l.975-1.3a.5.5 0 0 0 0-.6L14.8 2.4A1 1 0 0 0 14 2H9v-.586a1 1 0 0 0-2 0V7H2a1 1 0 0 0-.8.4L.225 8.7a.5.5 0 0 0 0 .6l.975 1.3a1 1 0 0 0 .8.4h5v5z\"}}]})(props);\n};\nexport function BsFillSimFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4.5a.5.5 0 0 1 .5-.5h2v2H5V4.5zM8.5 6V4h2a.5.5 0 0 1 .5.5V6H8.5zM5 7h6v2H5V7zm3.5 3H11v1.5a.5.5 0 0 1-.5.5h-2v-2zm-1 0v2h-2a.5.5 0 0 1-.5-.5V10h2.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0A1.5 1.5 0 0 0 2 1.5v13A1.5 1.5 0 0 0 3.5 16h9a1.5 1.5 0 0 0 1.5-1.5V3.414a1.5 1.5 0 0 0-.44-1.06L11.647.439A1.5 1.5 0 0 0 10.586 0H3.5zm2 3h5A1.5 1.5 0 0 1 12 4.5v7a1.5 1.5 0 0 1-1.5 1.5h-5A1.5 1.5 0 0 1 4 11.5v-7A1.5 1.5 0 0 1 5.5 3z\"}}]})(props);\n};\nexport function BsFillSkipBackwardBtnFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12V4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm11.21-6.907L8.5 7.028V5.5a.5.5 0 0 0-.79-.407L5 7.028V5.5a.5.5 0 0 0-1 0v5a.5.5 0 0 0 1 0V8.972l2.71 1.935a.5.5 0 0 0 .79-.407V8.972l2.71 1.935A.5.5 0 0 0 12 10.5v-5a.5.5 0 0 0-.79-.407z\"}}]})(props);\n};\nexport function BsFillSkipBackwardCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-4.79-2.907L8.5 7.028V5.5a.5.5 0 0 0-.79-.407L5 7.028V5.5a.5.5 0 0 0-1 0v5a.5.5 0 0 0 1 0V8.972l2.71 1.935a.5.5 0 0 0 .79-.407V8.972l2.71 1.935A.5.5 0 0 0 12 10.5v-5a.5.5 0 0 0-.79-.407z\"}}]})(props);\n};\nexport function BsFillSkipBackwardFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 3.5A.5.5 0 0 0 0 4v8a.5.5 0 0 0 1 0V8.753l6.267 3.636c.54.313 1.233-.066 1.233-.697v-2.94l6.267 3.636c.54.314 1.233-.065 1.233-.696V4.308c0-.63-.693-1.01-1.233-.696L8.5 7.248v-2.94c0-.63-.692-1.01-1.233-.696L1 7.248V4a.5.5 0 0 0-.5-.5z\"}}]})(props);\n};\nexport function BsFillSkipEndBtnFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12V4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm6.79-6.907A.5.5 0 0 0 6 5.5v5a.5.5 0 0 0 .79.407L9.5 8.972V10.5a.5.5 0 0 0 1 0v-5a.5.5 0 0 0-1 0v1.528L6.79 5.093z\"}}]})(props);\n};\nexport function BsFillSkipEndCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM6.79 5.093A.5.5 0 0 0 6 5.5v5a.5.5 0 0 0 .79.407L9.5 8.972V10.5a.5.5 0 0 0 1 0v-5a.5.5 0 0 0-1 0v1.528L6.79 5.093z\"}}]})(props);\n};\nexport function BsFillSkipEndFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 4a.5.5 0 0 0-1 0v3.248L5.233 3.612C4.693 3.3 4 3.678 4 4.308v7.384c0 .63.692 1.01 1.233.697L11.5 8.753V12a.5.5 0 0 0 1 0V4z\"}}]})(props);\n};\nexport function BsFillSkipForwardBtnFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 10V2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm4.79-6.907A.5.5 0 0 0 4 3.5v5a.5.5 0 0 0 .79.407L7.5 6.972V8.5a.5.5 0 0 0 .79.407L11 6.972V8.5a.5.5 0 0 0 1 0v-5a.5.5 0 0 0-1 0v1.528L8.29 3.093a.5.5 0 0 0-.79.407v1.528L4.79 3.093z\"}}]})(props);\n};\nexport function BsFillSkipForwardCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM4.79 5.093A.5.5 0 0 0 4 5.5v5a.5.5 0 0 0 .79.407L7.5 8.972V10.5a.5.5 0 0 0 .79.407L11 8.972V10.5a.5.5 0 0 0 1 0v-5a.5.5 0 0 0-1 0v1.528L8.29 5.093a.5.5 0 0 0-.79.407v1.528L4.79 5.093z\"}}]})(props);\n};\nexport function BsFillSkipForwardFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.5 3.5a.5.5 0 0 1 .5.5v8a.5.5 0 0 1-1 0V8.753l-6.267 3.636c-.54.313-1.233-.066-1.233-.697v-2.94l-6.267 3.636C.693 12.703 0 12.324 0 11.693V4.308c0-.63.693-1.01 1.233-.696L7.5 7.248v-2.94c0-.63.693-1.01 1.233-.696L15 7.248V4a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsFillSkipStartBtnFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12V4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm9.71-6.907L7 7.028V5.5a.5.5 0 0 0-1 0v5a.5.5 0 0 0 1 0V8.972l2.71 1.935a.5.5 0 0 0 .79-.407v-5a.5.5 0 0 0-.79-.407z\"}}]})(props);\n};\nexport function BsFillSkipStartCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM9.71 5.093 7 7.028V5.5a.5.5 0 0 0-1 0v5a.5.5 0 0 0 1 0V8.972l2.71 1.935a.5.5 0 0 0 .79-.407v-5a.5.5 0 0 0-.79-.407z\"}}]})(props);\n};\nexport function BsFillSkipStartFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4a.5.5 0 0 1 1 0v3.248l6.267-3.636c.54-.313 1.232.066 1.232.696v7.384c0 .63-.692 1.01-1.232.697L5 8.753V12a.5.5 0 0 1-1 0V4z\"}}]})(props);\n};\nexport function BsFillSlashCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-4.646-2.646a.5.5 0 0 0-.708-.708l-6 6a.5.5 0 0 0 .708.708l6-6z\"}}]})(props);\n};\nexport function BsFillSlashSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm9.354 5.354-6 6a.5.5 0 0 1-.708-.708l6-6a.5.5 0 0 1 .708.708z\"}}]})(props);\n};\nexport function BsFillSpeakerFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm-2.5 6.5a1.5 1.5 0 1 1 3 0 1.5 1.5 0 0 1-3 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm6 4a2 2 0 1 1-4 0 2 2 0 0 1 4 0zM8 7a3.5 3.5 0 1 1 0 7 3.5 3.5 0 0 1 0-7z\"}}]})(props);\n};\nexport function BsFillSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2z\"}}]})(props);\n};\nexport function BsFillStarFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.612 15.443c-.386.198-.824-.149-.746-.592l.83-4.73L.173 6.765c-.329-.314-.158-.888.283-.95l4.898-.696L7.538.792c.197-.39.73-.39.927 0l2.184 4.327 4.898.696c.441.062.612.636.282.95l-3.522 3.356.83 4.73c.078.443-.36.79-.746.592L8 13.187l-4.389 2.256z\"}}]})(props);\n};\nexport function BsFillStickiesFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1.5V13a1 1 0 0 0 1 1V1.5a.5.5 0 0 1 .5-.5H14a1 1 0 0 0-1-1H1.5A1.5 1.5 0 0 0 0 1.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 2A1.5 1.5 0 0 0 2 3.5v11A1.5 1.5 0 0 0 3.5 16h6.086a1.5 1.5 0 0 0 1.06-.44l4.915-4.914A1.5 1.5 0 0 0 16 9.586V3.5A1.5 1.5 0 0 0 14.5 2h-11zm6 8.5a1 1 0 0 1 1-1h4.396a.25.25 0 0 1 .177.427l-5.146 5.146a.25.25 0 0 1-.427-.177V10.5z\"}}]})(props);\n};\nexport function BsFillStickyFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 1A1.5 1.5 0 0 0 1 2.5v11A1.5 1.5 0 0 0 2.5 15h6.086a1.5 1.5 0 0 0 1.06-.44l4.915-4.914A1.5 1.5 0 0 0 15 8.586V2.5A1.5 1.5 0 0 0 13.5 1h-11zm6 8.5a1 1 0 0 1 1-1h4.396a.25.25 0 0 1 .177.427l-5.146 5.146a.25.25 0 0 1-.427-.177V9.5z\"}}]})(props);\n};\nexport function BsFillStopBtnFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12V4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm6.5-7A1.5 1.5 0 0 0 5 6.5v3A1.5 1.5 0 0 0 6.5 11h3A1.5 1.5 0 0 0 11 9.5v-3A1.5 1.5 0 0 0 9.5 5h-3z\"}}]})(props);\n};\nexport function BsFillStopCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM6.5 5A1.5 1.5 0 0 0 5 6.5v3A1.5 1.5 0 0 0 6.5 11h3A1.5 1.5 0 0 0 11 9.5v-3A1.5 1.5 0 0 0 9.5 5h-3z\"}}]})(props);\n};\nexport function BsFillStopFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 3.5h6A1.5 1.5 0 0 1 12.5 5v6a1.5 1.5 0 0 1-1.5 1.5H5A1.5 1.5 0 0 1 3.5 11V5A1.5 1.5 0 0 1 5 3.5z\"}}]})(props);\n};\nexport function BsFillStoplightsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 0a2 2 0 0 0-2 2H2c.167.5.8 1.6 2 2v2H2c.167.5.8 1.6 2 2v2H2c.167.5.8 1.6 2 2v1a2 2 0 0 0 2 2h4a2 2 0 0 0 2-2v-1c1.2-.4 1.833-1.5 2-2h-2V8c1.2-.4 1.833-1.5 2-2h-2V4c1.2-.4 1.833-1.5 2-2h-2a2 2 0 0 0-2-2H6zm3.5 3.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm0 4a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zM8 13a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsFillStopwatchFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 0a.5.5 0 0 0 0 1H7v1.07A7.001 7.001 0 0 0 8 16a7 7 0 0 0 5.29-11.584.531.531 0 0 0 .013-.012l.354-.354.353.354a.5.5 0 1 0 .707-.707l-1.414-1.415a.5.5 0 1 0-.707.707l.354.354-.354.354a.717.717 0 0 0-.012.012A6.973 6.973 0 0 0 9 2.071V1h.5a.5.5 0 0 0 0-1h-3zm2 5.6V9a.5.5 0 0 1-.5.5H4.5a.5.5 0 0 1 0-1h3V5.6a.5.5 0 1 1 1 0z\"}}]})(props);\n};\nexport function BsFillSuitClubFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.5 12.5a3.493 3.493 0 0 1-2.684-1.254 19.92 19.92 0 0 0 1.582 2.907c.231.35-.02.847-.438.847H6.04c-.419 0-.67-.497-.438-.847a19.919 19.919 0 0 0 1.582-2.907 3.5 3.5 0 1 1-2.538-5.743 3.5 3.5 0 1 1 6.708 0A3.5 3.5 0 1 1 11.5 12.5z\"}}]})(props);\n};\nexport function BsFillSuitDiamondFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.45 7.4 7.2 1.067a1 1 0 0 1 1.6 0L13.55 7.4a1 1 0 0 1 0 1.2L8.8 14.933a1 1 0 0 1-1.6 0L2.45 8.6a1 1 0 0 1 0-1.2z\"}}]})(props);\n};\nexport function BsFillSuitHeartFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 1c2.21 0 4 1.755 4 3.92C8 2.755 9.79 1 12 1s4 1.755 4 3.92c0 3.263-3.234 4.414-7.608 9.608a.513.513 0 0 1-.784 0C3.234 9.334 0 8.183 0 4.92 0 2.755 1.79 1 4 1z\"}}]})(props);\n};\nexport function BsFillSuitSpadeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.184 11.246A3.5 3.5 0 0 1 1 9c0-1.602 1.14-2.633 2.66-4.008C4.986 3.792 6.602 2.33 8 0c1.398 2.33 3.014 3.792 4.34 4.992C13.86 6.367 15 7.398 15 9a3.5 3.5 0 0 1-6.184 2.246 19.92 19.92 0 0 0 1.582 2.907c.231.35-.02.847-.438.847H6.04c-.419 0-.67-.497-.438-.847a19.919 19.919 0 0 0 1.582-2.907z\"}}]})(props);\n};\nexport function BsFillSunFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12a4 4 0 1 0 0-8 4 4 0 0 0 0 8zM8 0a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 0zm0 13a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 13zm8-5a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2a.5.5 0 0 1 .5.5zM3 8a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2A.5.5 0 0 1 3 8zm10.657-5.657a.5.5 0 0 1 0 .707l-1.414 1.415a.5.5 0 1 1-.707-.708l1.414-1.414a.5.5 0 0 1 .707 0zm-9.193 9.193a.5.5 0 0 1 0 .707L3.05 13.657a.5.5 0 0 1-.707-.707l1.414-1.414a.5.5 0 0 1 .707 0zm9.193 2.121a.5.5 0 0 1-.707 0l-1.414-1.414a.5.5 0 0 1 .707-.707l1.414 1.414a.5.5 0 0 1 0 .707zM4.464 4.465a.5.5 0 0 1-.707 0L2.343 3.05a.5.5 0 1 1 .707-.707l1.414 1.414a.5.5 0 0 1 0 .708z\"}}]})(props);\n};\nexport function BsFillSunriseFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.646 1.146a.5.5 0 0 1 .708 0l1.5 1.5a.5.5 0 0 1-.708.708L8.5 2.707V4.5a.5.5 0 0 1-1 0V2.707l-.646.647a.5.5 0 1 1-.708-.708l1.5-1.5zM2.343 4.343a.5.5 0 0 1 .707 0l1.414 1.414a.5.5 0 0 1-.707.707L2.343 5.05a.5.5 0 0 1 0-.707zm11.314 0a.5.5 0 0 1 0 .707l-1.414 1.414a.5.5 0 1 1-.707-.707l1.414-1.414a.5.5 0 0 1 .707 0zM11.709 11.5a4 4 0 1 0-7.418 0H.5a.5.5 0 0 0 0 1h15a.5.5 0 0 0 0-1h-3.79zM0 10a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2A.5.5 0 0 1 0 10zm13 0a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFillSunsetFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.646 4.854a.5.5 0 0 0 .708 0l1.5-1.5a.5.5 0 0 0-.708-.708l-.646.647V1.5a.5.5 0 0 0-1 0v1.793l-.646-.647a.5.5 0 1 0-.708.708l1.5 1.5zm-5.303-.51a.5.5 0 0 1 .707 0l1.414 1.413a.5.5 0 0 1-.707.707L2.343 5.05a.5.5 0 0 1 0-.707zm11.314 0a.5.5 0 0 1 0 .706l-1.414 1.414a.5.5 0 1 1-.707-.707l1.414-1.414a.5.5 0 0 1 .707 0zM11.709 11.5a4 4 0 1 0-7.418 0H.5a.5.5 0 0 0 0 1h15a.5.5 0 0 0 0-1h-3.79zM0 10a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2A.5.5 0 0 1 0 10zm13 0a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFillTabletFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm7 11a1 1 0 1 0-2 0 1 1 0 0 0 2 0z\"}}]})(props);\n};\nexport function BsFillTabletLandscapeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 14a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2zm11-7a1 1 0 1 0 0 2 1 1 0 0 0 0-2z\"}}]})(props);\n};\nexport function BsFillTagFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1a1 1 0 0 0-1 1v4.586a1 1 0 0 0 .293.707l7 7a1 1 0 0 0 1.414 0l4.586-4.586a1 1 0 0 0 0-1.414l-7-7A1 1 0 0 0 6.586 1H2zm4 3.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0z\"}}]})(props);\n};\nexport function BsFillTagsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a1 1 0 0 1 1-1h4.586a1 1 0 0 1 .707.293l7 7a1 1 0 0 1 0 1.414l-4.586 4.586a1 1 0 0 1-1.414 0l-7-7A1 1 0 0 1 2 6.586V2zm3.5 4a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1.293 7.793A1 1 0 0 1 1 7.086V2a1 1 0 0 0-1 1v4.586a1 1 0 0 0 .293.707l7 7a1 1 0 0 0 1.414 0l.043-.043-7.457-7.457z\"}}]})(props);\n};\nexport function BsFillTelephoneFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.885.511a1.745 1.745 0 0 1 2.61.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511z\"}}]})(props);\n};\nexport function BsFillTelephoneForwardFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.885.511a1.745 1.745 0 0 1 2.61.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511zm10.761.135a.5.5 0 0 1 .708 0l2.5 2.5a.5.5 0 0 1 0 .708l-2.5 2.5a.5.5 0 0 1-.708-.708L14.293 4H9.5a.5.5 0 0 1 0-1h4.793l-1.647-1.646a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsFillTelephoneInboundFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.885.511a1.745 1.745 0 0 1 2.61.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511zM15.854.146a.5.5 0 0 1 0 .708L11.707 5H14.5a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 1 0v2.793L15.146.146a.5.5 0 0 1 .708 0z\"}}]})(props);\n};\nexport function BsFillTelephoneMinusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.885.511a1.745 1.745 0 0 1 2.61.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511zM10 3.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFillTelephoneOutboundFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.885.511a1.745 1.745 0 0 1 2.61.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511zM11 .5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-1 0V1.707l-4.146 4.147a.5.5 0 0 1-.708-.708L14.293 1H11.5a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFillTelephonePlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.885.511a1.745 1.745 0 0 1 2.61.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511zM12.5 1a.5.5 0 0 1 .5.5V3h1.5a.5.5 0 0 1 0 1H13v1.5a.5.5 0 0 1-1 0V4h-1.5a.5.5 0 0 1 0-1H12V1.5a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsFillTelephoneXFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.885.511a1.745 1.745 0 0 1 2.61.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511zm9.261 1.135a.5.5 0 0 1 .708 0L13 2.793l1.146-1.147a.5.5 0 0 1 .708.708L13.707 3.5l1.147 1.146a.5.5 0 0 1-.708.708L13 4.207l-1.146 1.147a.5.5 0 0 1-.708-.708L12.293 3.5l-1.147-1.146a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsFillTerminalFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 3a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3zm9.5 5.5h-3a.5.5 0 0 0 0 1h3a.5.5 0 0 0 0-1zm-6.354-.354a.5.5 0 1 0 .708.708l2-2a.5.5 0 0 0 0-.708l-2-2a.5.5 0 1 0-.708.708L4.793 6.5 3.146 8.146z\"}}]})(props);\n};\nexport function BsFillTrashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 1a1 1 0 0 0-1 1v1a1 1 0 0 0 1 1H3v9a2 2 0 0 0 2 2h6a2 2 0 0 0 2-2V4h.5a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H10a1 1 0 0 0-1-1H7a1 1 0 0 0-1 1H2.5zm3 4a.5.5 0 0 1 .5.5v7a.5.5 0 0 1-1 0v-7a.5.5 0 0 1 .5-.5zM8 5a.5.5 0 0 1 .5.5v7a.5.5 0 0 1-1 0v-7A.5.5 0 0 1 8 5zm3 .5v7a.5.5 0 0 1-1 0v-7a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFillTrash2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.037 3.225A.703.703 0 0 1 2 3c0-1.105 2.686-2 6-2s6 .895 6 2a.702.702 0 0 1-.037.225l-1.684 10.104A2 2 0 0 1 10.305 15H5.694a2 2 0 0 1-1.973-1.671L2.037 3.225zm9.89-.69C10.966 2.214 9.578 2 8 2c-1.58 0-2.968.215-3.926.534-.477.16-.795.327-.975.466.18.14.498.307.975.466C5.032 3.786 6.42 4 8 4s2.967-.215 3.926-.534c.477-.16.795-.327.975-.466-.18-.14-.498-.307-.975-.466z\"}}]})(props);\n};\nexport function BsFillTreeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.416.223a.5.5 0 0 0-.832 0l-3 4.5A.5.5 0 0 0 5 5.5h.098L3.076 8.735A.5.5 0 0 0 3.5 9.5h.191l-1.638 3.276a.5.5 0 0 0 .447.724H7V16h2v-2.5h4.5a.5.5 0 0 0 .447-.724L12.31 9.5h.191a.5.5 0 0 0 .424-.765L10.902 5.5H11a.5.5 0 0 0 .416-.777l-3-4.5z\"}}]})(props);\n};\nexport function BsFillTriangleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.022 1.566a1.13 1.13 0 0 1 1.96 0l6.857 11.667c.457.778-.092 1.767-.98 1.767H1.144c-.889 0-1.437-.99-.98-1.767L7.022 1.566z\"}}]})(props);\n};\nexport function BsFillTrophyFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5.5A.5.5 0 0 1 3 0h10a.5.5 0 0 1 .5.5c0 .538-.012 1.05-.034 1.536a3 3 0 1 1-1.133 5.89c-.79 1.865-1.878 2.777-2.833 3.011v2.173l1.425.356c.194.048.377.135.537.255L13.3 15.1a.5.5 0 0 1-.3.9H3a.5.5 0 0 1-.3-.9l1.838-1.379c.16-.12.343-.207.537-.255L6.5 13.11v-2.173c-.955-.234-2.043-1.146-2.833-3.012a3 3 0 1 1-1.132-5.89A33.076 33.076 0 0 1 2.5.5zm.099 2.54a2 2 0 0 0 .72 3.935c-.333-1.05-.588-2.346-.72-3.935zm10.083 3.935a2 2 0 0 0 .72-3.935c-.133 1.59-.388 2.885-.72 3.935z\"}}]})(props);\n};\nexport function BsFillTvFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 13.5A.5.5 0 0 1 3 13h10a.5.5 0 0 1 0 1H3a.5.5 0 0 1-.5-.5zM2 2h12s2 0 2 2v6s0 2-2 2H2s-2 0-2-2V4s0-2 2-2z\"}}]})(props);\n};\nexport function BsFillUmbrellaFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 0a.5.5 0 0 1 .5.5v.514C12.625 1.238 16 4.22 16 8c0 0 0 .5-.5.5-.149 0-.352-.145-.352-.145l-.004-.004-.025-.023a3.484 3.484 0 0 0-.555-.394A3.166 3.166 0 0 0 13 7.5c-.638 0-1.178.213-1.564.434a3.484 3.484 0 0 0-.555.394l-.025.023-.003.003s-.204.146-.353.146-.352-.145-.352-.145l-.004-.004-.025-.023a3.484 3.484 0 0 0-.555-.394 3.3 3.3 0 0 0-1.064-.39V13.5H8h.5v.039l-.005.083a2.958 2.958 0 0 1-.298 1.102 2.257 2.257 0 0 1-.763.88C7.06 15.851 6.587 16 6 16s-1.061-.148-1.434-.396a2.255 2.255 0 0 1-.763-.88 2.958 2.958 0 0 1-.302-1.185v-.025l-.001-.009v-.003s0-.002.5-.002h-.5V13a.5.5 0 0 1 1 0v.506l.003.044a1.958 1.958 0 0 0 .195.726c.095.191.23.367.423.495.19.127.466.229.879.229s.689-.102.879-.229c.193-.128.328-.304.424-.495a1.958 1.958 0 0 0 .197-.77V7.544a3.3 3.3 0 0 0-1.064.39 3.482 3.482 0 0 0-.58.417l-.004.004S5.65 8.5 5.5 8.5c-.149 0-.352-.145-.352-.145l-.004-.004a3.482 3.482 0 0 0-.58-.417A3.166 3.166 0 0 0 3 7.5c-.638 0-1.177.213-1.564.434a3.482 3.482 0 0 0-.58.417l-.004.004S.65 8.5.5 8.5C0 8.5 0 8 0 8c0-3.78 3.375-6.762 7.5-6.986V.5A.5.5 0 0 1 8 0z\"}}]})(props);\n};\nexport function BsFillUnlockFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 1a2 2 0 0 0-2 2v4a2 2 0 0 1 2 2v5a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V9a2 2 0 0 1 2-2h5V3a3 3 0 0 1 6 0v4a.5.5 0 0 1-1 0V3a2 2 0 0 0-2-2z\"}}]})(props);\n};\nexport function BsFillVinylFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 6a2 2 0 1 0 0 4 2 2 0 0 0 0-4zm0 3a1 1 0 1 1 0-2 1 1 0 0 1 0 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM4 8a4 4 0 1 0 8 0 4 4 0 0 0-8 0z\"}}]})(props);\n};\nexport function BsFillVolumeDownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4a.5.5 0 0 0-.812-.39L5.825 5.5H3.5A.5.5 0 0 0 3 6v4a.5.5 0 0 0 .5.5h2.325l2.363 1.89A.5.5 0 0 0 9 12V4zm3.025 4a4.486 4.486 0 0 1-1.318 3.182L10 10.475A3.489 3.489 0 0 0 11.025 8 3.49 3.49 0 0 0 10 5.525l.707-.707A4.486 4.486 0 0 1 12.025 8z\"}}]})(props);\n};\nexport function BsFillVolumeMuteFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.717 3.55A.5.5 0 0 1 7 4v8a.5.5 0 0 1-.812.39L3.825 10.5H1.5A.5.5 0 0 1 1 10V6a.5.5 0 0 1 .5-.5h2.325l2.363-1.89a.5.5 0 0 1 .529-.06zm7.137 2.096a.5.5 0 0 1 0 .708L12.207 8l1.647 1.646a.5.5 0 0 1-.708.708L11.5 8.707l-1.646 1.647a.5.5 0 0 1-.708-.708L10.793 8 9.146 6.354a.5.5 0 1 1 .708-.708L11.5 7.293l1.646-1.647a.5.5 0 0 1 .708 0z\"}}]})(props);\n};\nexport function BsFillVolumeOffFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.717 3.55A.5.5 0 0 1 11 4v8a.5.5 0 0 1-.812.39L7.825 10.5H5.5A.5.5 0 0 1 5 10V6a.5.5 0 0 1 .5-.5h2.325l2.363-1.89a.5.5 0 0 1 .529-.06z\"}}]})(props);\n};\nexport function BsFillVolumeUpFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.536 14.01A8.473 8.473 0 0 0 14.026 8a8.473 8.473 0 0 0-2.49-6.01l-.708.707A7.476 7.476 0 0 1 13.025 8c0 2.071-.84 3.946-2.197 5.303l.708.707z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.121 12.596A6.48 6.48 0 0 0 12.025 8a6.48 6.48 0 0 0-1.904-4.596l-.707.707A5.483 5.483 0 0 1 11.025 8a5.483 5.483 0 0 1-1.61 3.89l.706.706z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.707 11.182A4.486 4.486 0 0 0 10.025 8a4.486 4.486 0 0 0-1.318-3.182L8 5.525A3.489 3.489 0 0 1 9.025 8 3.49 3.49 0 0 1 8 10.475l.707.707zM6.717 3.55A.5.5 0 0 1 7 4v8a.5.5 0 0 1-.812.39L3.825 10.5H1.5A.5.5 0 0 1 1 10V6a.5.5 0 0 1 .5-.5h2.325l2.363-1.89a.5.5 0 0 1 .529-.06z\"}}]})(props);\n};\nexport function BsFillWalletFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 2A1.5 1.5 0 0 0 0 3.5v2h6a.5.5 0 0 1 .5.5c0 .253.08.644.306.958.207.288.557.542 1.194.542.637 0 .987-.254 1.194-.542.226-.314.306-.705.306-.958a.5.5 0 0 1 .5-.5h6v-2A1.5 1.5 0 0 0 14.5 2h-13z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 6.5h-5.551a2.678 2.678 0 0 1-.443 1.042C9.613 8.088 8.963 8.5 8 8.5c-.963 0-1.613-.412-2.006-.958A2.679 2.679 0 0 1 5.551 6.5H0v6A1.5 1.5 0 0 0 1.5 14h13a1.5 1.5 0 0 0 1.5-1.5v-6z\"}}]})(props);\n};\nexport function BsFillXCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM5.354 4.646a.5.5 0 1 0-.708.708L7.293 8l-2.647 2.646a.5.5 0 0 0 .708.708L8 8.707l2.646 2.647a.5.5 0 0 0 .708-.708L8.707 8l2.647-2.646a.5.5 0 0 0-.708-.708L8 7.293 5.354 4.646z\"}}]})(props);\n};\nexport function BsFillXDiamondFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.05.435c-.58-.58-1.52-.58-2.1 0L4.047 3.339 8 7.293l3.954-3.954L9.049.435zm3.61 3.611L8.708 8l3.954 3.954 2.904-2.905c.58-.58.58-1.519 0-2.098l-2.904-2.905zm-.706 8.614L8 8.708l-3.954 3.954 2.905 2.904c.58.58 1.519.58 2.098 0l2.905-2.904zm-8.614-.706L7.292 8 3.339 4.046.435 6.951c-.58.58-.58 1.519 0 2.098l2.904 2.905z\"}}]})(props);\n};\nexport function BsFillXOctagonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.46.146A.5.5 0 0 0 11.107 0H4.893a.5.5 0 0 0-.353.146L.146 4.54A.5.5 0 0 0 0 4.893v6.214a.5.5 0 0 0 .146.353l4.394 4.394a.5.5 0 0 0 .353.146h6.214a.5.5 0 0 0 .353-.146l4.394-4.394a.5.5 0 0 0 .146-.353V4.893a.5.5 0 0 0-.146-.353L11.46.146zm-6.106 4.5L8 7.293l2.646-2.647a.5.5 0 0 1 .708.708L8.707 8l2.647 2.646a.5.5 0 0 1-.708.708L8 8.707l-2.646 2.647a.5.5 0 0 1-.708-.708L7.293 8 4.646 5.354a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsFillXSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm3.354 4.646L8 7.293l2.646-2.647a.5.5 0 0 1 .708.708L8.707 8l2.647 2.646a.5.5 0 0 1-.708.708L8 8.707l-2.646 2.647a.5.5 0 0 1-.708-.708L7.293 8 4.646 5.354a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsReverseBackspaceReverse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.854 5.146a.5.5 0 0 1 0 .708L7.707 8l2.147 2.146a.5.5 0 0 1-.708.708L7 8.707l-2.146 2.147a.5.5 0 0 1-.708-.708L6.293 8 4.146 5.854a.5.5 0 1 1 .708-.708L7 7.293l2.146-2.147a.5.5 0 0 1 .708 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h7.08a2 2 0 0 0 1.519-.698l4.843-5.651a1 1 0 0 0 0-1.302L10.6 1.7A2 2 0 0 0 9.08 1H2zm7.08 1a1 1 0 0 1 .76.35L14.682 8l-4.844 5.65a1 1 0 0 1-.759.35H2a1 1 0 0 1-1-1V3a1 1 0 0 1 1-1h7.08z\"}}]})(props);\n};\nexport function BsReverseLayoutSidebarInsetReverse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a1 1 0 0 0-1 1v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H2zm12-1a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h12z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 4a1 1 0 0 0-1-1h-2a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1V4z\"}}]})(props);\n};\nexport function BsReverseLayoutSidebarReverse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 3a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V3zm-5-1v12H2a1 1 0 0 1-1-1V3a1 1 0 0 1 1-1h9zm1 0h2a1 1 0 0 1 1 1v10a1 1 0 0 1-1 1h-2V2z\"}}]})(props);\n};\nexport function BsReverseLayoutTextSidebarReverse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 3a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1h5zm0 3a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1h5zm.5 3.5a.5.5 0 0 0-.5-.5h-5a.5.5 0 0 0 0 1h5a.5.5 0 0 0 .5-.5zm-.5 2.5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1h5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 2a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2zM4 1v14H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h2zm1 0h9a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H5V1z\"}}]})(props);\n};\nexport function BsReverseLayoutTextWindowReverse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13 6.5a.5.5 0 0 0-.5-.5h-5a.5.5 0 0 0 0 1h5a.5.5 0 0 0 .5-.5zm0 3a.5.5 0 0 0-.5-.5h-5a.5.5 0 0 0 0 1h5a.5.5 0 0 0 .5-.5zm-.5 2.5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1h5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 0a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12zM2 1a1 1 0 0 0-1 1v1h14V2a1 1 0 0 0-1-1H2zM1 4v10a1 1 0 0 0 1 1h2V4H1zm4 0v11h9a1 1 0 0 0 1-1V4H5z\"}}]})(props);\n};\nexport function BsAlarmFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 .5a.5.5 0 0 1 .5-.5h3a.5.5 0 0 1 0 1H9v1.07a7.001 7.001 0 0 1 3.274 12.474l.601.602a.5.5 0 0 1-.707.708l-.746-.746A6.97 6.97 0 0 1 8 16a6.97 6.97 0 0 1-3.422-.892l-.746.746a.5.5 0 0 1-.707-.708l.602-.602A7.001 7.001 0 0 1 7 2.07V1h-.5A.5.5 0 0 1 6 .5zm2.5 5a.5.5 0 0 0-1 0v3.362l-1.429 2.38a.5.5 0 1 0 .858.515l1.5-2.5A.5.5 0 0 0 8.5 9V5.5zM.86 5.387A2.5 2.5 0 1 1 4.387 1.86 8.035 8.035 0 0 0 .86 5.387zM11.613 1.86a2.5 2.5 0 1 1 3.527 3.527 8.035 8.035 0 0 0-3.527-3.527z\"}}]})(props);\n};\nexport function BsAlarm (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 5.5a.5.5 0 0 0-1 0v3.362l-1.429 2.38a.5.5 0 1 0 .858.515l1.5-2.5A.5.5 0 0 0 8.5 9V5.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 0a.5.5 0 0 0 0 1H7v1.07a7.001 7.001 0 0 0-3.273 12.474l-.602.602a.5.5 0 0 0 .707.708l.746-.746A6.97 6.97 0 0 0 8 16a6.97 6.97 0 0 0 3.422-.892l.746.746a.5.5 0 0 0 .707-.708l-.601-.602A7.001 7.001 0 0 0 9 2.07V1h.5a.5.5 0 0 0 0-1h-3zm1.038 3.018a6.093 6.093 0 0 1 .924 0 6 6 0 1 1-.924 0zM0 3.5c0 .753.333 1.429.86 1.887A8.035 8.035 0 0 1 4.387 1.86 2.5 2.5 0 0 0 0 3.5zM13.5 1c-.753 0-1.429.333-1.887.86a8.035 8.035 0 0 1 3.527 3.527A2.5 2.5 0 0 0 13.5 1z\"}}]})(props);\n};\nexport function BsAlignBottom (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"rect\",\"attr\":{\"width\":\"4\",\"height\":\"12\",\"x\":\"6\",\"y\":\"1\",\"rx\":\"1\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 14a.5.5 0 0 0 0 1v-1zm13 1a.5.5 0 0 0 0-1v1zm-13 0h13v-1h-13v1z\"}}]})(props);\n};\nexport function BsAlignCenter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a.5.5 0 0 1 .5.5V6h-1V1.5A.5.5 0 0 1 8 1zm0 14a.5.5 0 0 1-.5-.5V10h1v4.5a.5.5 0 0 1-.5.5zM2 7a1 1 0 0 1 1-1h10a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V7z\"}}]})(props);\n};\nexport function BsAlignEnd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M14.5 1a.5.5 0 0 0-.5.5v13a.5.5 0 0 0 1 0v-13a.5.5 0 0 0-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 7a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V7z\"}}]})(props);\n};\nexport function BsAlignMiddle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 13a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H7a1 1 0 0 0-1 1v10zM1 8a.5.5 0 0 0 .5.5H6v-1H1.5A.5.5 0 0 0 1 8zm14 0a.5.5 0 0 1-.5.5H10v-1h4.5a.5.5 0 0 1 .5.5z\"}}]})(props);\n};\nexport function BsAlignStart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.5 1a.5.5 0 0 1 .5.5v13a.5.5 0 0 1-1 0v-13a.5.5 0 0 1 .5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 7a1 1 0 0 1 1-1h10a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V7z\"}}]})(props);\n};\nexport function BsAlignTop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"rect\",\"attr\":{\"width\":\"4\",\"height\":\"12\",\"rx\":\"1\",\"transform\":\"matrix(1 0 0 -1 6 15)\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 2a.5.5 0 0 1 0-1v1zm13-1a.5.5 0 0 1 0 1V1zm-13 0h13v1h-13V1z\"}}]})(props);\n};\nexport function BsAlt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 13.5a.5.5 0 0 0 .5.5h3.797a.5.5 0 0 0 .439-.26L11 3h3.5a.5.5 0 0 0 0-1h-3.797a.5.5 0 0 0-.439.26L5 13H1.5a.5.5 0 0 0-.5.5zm10 0a.5.5 0 0 0 .5.5h3a.5.5 0 0 0 0-1h-3a.5.5 0 0 0-.5.5z\"}}]})(props);\n};\nexport function BsAppIndicator (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 2A3.5 3.5 0 0 0 2 5.5v5A3.5 3.5 0 0 0 5.5 14h5a3.5 3.5 0 0 0 3.5-3.5V8a.5.5 0 0 1 1 0v2.5a4.5 4.5 0 0 1-4.5 4.5h-5A4.5 4.5 0 0 1 1 10.5v-5A4.5 4.5 0 0 1 5.5 1H8a.5.5 0 0 1 0 1H5.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 3a3 3 0 1 1-6 0 3 3 0 0 1 6 0z\"}}]})(props);\n};\nexport function BsApp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 2a3 3 0 0 1 3 3v6a3 3 0 0 1-3 3H5a3 3 0 0 1-3-3V5a3 3 0 0 1 3-3h6zM5 1a4 4 0 0 0-4 4v6a4 4 0 0 0 4 4h6a4 4 0 0 0 4-4V5a4 4 0 0 0-4-4H5z\"}}]})(props);\n};\nexport function BsApple (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.182.008C11.148-.03 9.923.023 8.857 1.18c-1.066 1.156-.902 2.482-.878 2.516.024.034 1.52.087 2.475-1.258.955-1.345.762-2.391.728-2.43zm3.314 11.733c-.048-.096-2.325-1.234-2.113-3.422.212-2.189 1.675-2.789 1.698-2.854.023-.065-.597-.79-1.254-1.157a3.692 3.692 0 0 0-1.563-.434c-.108-.003-.483-.095-1.254.116-.508.139-1.653.589-1.968.607-.316.018-1.256-.522-2.267-.665-.647-.125-1.333.131-1.824.328-.49.196-1.422.754-2.074 2.237-.652 1.482-.311 3.83-.067 4.56.244.729.625 1.924 1.273 2.796.576.984 1.34 1.667 1.659 1.899.319.232 1.219.386 1.843.067.502-.308 1.408-.485 1.766-.472.357.013 1.061.154 1.782.539.571.197 1.111.115 1.652-.105.541-.221 1.324-1.059 2.238-2.758.347-.79.505-1.217.473-1.282z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.182.008C11.148-.03 9.923.023 8.857 1.18c-1.066 1.156-.902 2.482-.878 2.516.024.034 1.52.087 2.475-1.258.955-1.345.762-2.391.728-2.43zm3.314 11.733c-.048-.096-2.325-1.234-2.113-3.422.212-2.189 1.675-2.789 1.698-2.854.023-.065-.597-.79-1.254-1.157a3.692 3.692 0 0 0-1.563-.434c-.108-.003-.483-.095-1.254.116-.508.139-1.653.589-1.968.607-.316.018-1.256-.522-2.267-.665-.647-.125-1.333.131-1.824.328-.49.196-1.422.754-2.074 2.237-.652 1.482-.311 3.83-.067 4.56.244.729.625 1.924 1.273 2.796.576.984 1.34 1.667 1.659 1.899.319.232 1.219.386 1.843.067.502-.308 1.408-.485 1.766-.472.357.013 1.061.154 1.782.539.571.197 1.111.115 1.652-.105.541-.221 1.324-1.059 2.238-2.758.347-.79.505-1.217.473-1.282z\"}}]})(props);\n};\nexport function BsArchiveFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.643 15C13.979 15 15 13.845 15 12.5V5H1v7.5C1 13.845 2.021 15 3.357 15h9.286zM5.5 7h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1zM.8 1a.8.8 0 0 0-.8.8V3a.8.8 0 0 0 .8.8h14.4A.8.8 0 0 0 16 3V1.8a.8.8 0 0 0-.8-.8H.8z\"}}]})(props);\n};\nexport function BsArchive (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a1 1 0 0 1 1-1h14a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1v7.5a2.5 2.5 0 0 1-2.5 2.5h-9A2.5 2.5 0 0 1 1 12.5V5a1 1 0 0 1-1-1V2zm2 3v7.5A1.5 1.5 0 0 0 3.5 14h9a1.5 1.5 0 0 0 1.5-1.5V5H2zm13-3H1v2h14V2zM5 7.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsArrow90DegDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4.854 14.854a.5.5 0 0 1-.708 0l-4-4a.5.5 0 0 1 .708-.708L4 13.293V3.5A2.5 2.5 0 0 1 6.5 1h8a.5.5 0 0 1 0 1h-8A1.5 1.5 0 0 0 5 3.5v9.793l3.146-3.147a.5.5 0 0 1 .708.708l-4 4z\"}}]})(props);\n};\nexport function BsArrow90DegLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.146 4.854a.5.5 0 0 1 0-.708l4-4a.5.5 0 1 1 .708.708L2.707 4H12.5A2.5 2.5 0 0 1 15 6.5v8a.5.5 0 0 1-1 0v-8A1.5 1.5 0 0 0 12.5 5H2.707l3.147 3.146a.5.5 0 1 1-.708.708l-4-4z\"}}]})(props);\n};\nexport function BsArrow90DegRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M14.854 4.854a.5.5 0 0 0 0-.708l-4-4a.5.5 0 0 0-.708.708L13.293 4H3.5A2.5 2.5 0 0 0 1 6.5v8a.5.5 0 0 0 1 0v-8A1.5 1.5 0 0 1 3.5 5h9.793l-3.147 3.146a.5.5 0 0 0 .708.708l4-4z\"}}]})(props);\n};\nexport function BsArrow90DegUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4.854 1.146a.5.5 0 0 0-.708 0l-4 4a.5.5 0 1 0 .708.708L4 2.707V12.5A2.5 2.5 0 0 0 6.5 15h8a.5.5 0 0 0 0-1h-8A1.5 1.5 0 0 1 5 12.5V2.707l3.146 3.147a.5.5 0 1 0 .708-.708l-4-4z\"}}]})(props);\n};\nexport function BsArrowBarDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 3.5a.5.5 0 0 1 .5-.5h13a.5.5 0 0 1 0 1h-13a.5.5 0 0 1-.5-.5zM8 6a.5.5 0 0 1 .5.5v5.793l2.146-2.147a.5.5 0 0 1 .708.708l-3 3a.5.5 0 0 1-.708 0l-3-3a.5.5 0 0 1 .708-.708L7.5 12.293V6.5A.5.5 0 0 1 8 6z\"}}]})(props);\n};\nexport function BsArrowBarLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M12.5 15a.5.5 0 0 1-.5-.5v-13a.5.5 0 0 1 1 0v13a.5.5 0 0 1-.5.5zM10 8a.5.5 0 0 1-.5.5H3.707l2.147 2.146a.5.5 0 0 1-.708.708l-3-3a.5.5 0 0 1 0-.708l3-3a.5.5 0 1 1 .708.708L3.707 7.5H9.5a.5.5 0 0 1 .5.5z\"}}]})(props);\n};\nexport function BsArrowBarRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 8a.5.5 0 0 0 .5.5h5.793l-2.147 2.146a.5.5 0 0 0 .708.708l3-3a.5.5 0 0 0 0-.708l-3-3a.5.5 0 0 0-.708.708L12.293 7.5H6.5A.5.5 0 0 0 6 8zm-2.5 7a.5.5 0 0 1-.5-.5v-13a.5.5 0 0 1 1 0v13a.5.5 0 0 1-.5.5z\"}}]})(props);\n};\nexport function BsArrowBarUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 10a.5.5 0 0 0 .5-.5V3.707l2.146 2.147a.5.5 0 0 0 .708-.708l-3-3a.5.5 0 0 0-.708 0l-3 3a.5.5 0 1 0 .708.708L7.5 3.707V9.5a.5.5 0 0 0 .5.5zm-7 2.5a.5.5 0 0 1 .5-.5h13a.5.5 0 0 1 0 1h-13a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsArrowClockwise (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 3a5 5 0 1 0 4.546 2.914.5.5 0 0 1 .908-.417A6 6 0 1 1 8 2v1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4.466V.534a.25.25 0 0 1 .41-.192l2.36 1.966c.12.1.12.284 0 .384L8.41 4.658A.25.25 0 0 1 8 4.466z\"}}]})(props);\n};\nexport function BsArrowCounterclockwise (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 3a5 5 0 1 1-4.546 2.914.5.5 0 0 0-.908-.417A6 6 0 1 0 8 2v1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4.466V.534a.25.25 0 0 0-.41-.192L5.23 2.308a.25.25 0 0 0 0 .384l2.36 1.966A.25.25 0 0 0 8 4.466z\"}}]})(props);\n};\nexport function BsArrowDownCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM8.5 4.5a.5.5 0 0 0-1 0v5.793L5.354 8.146a.5.5 0 1 0-.708.708l3 3a.5.5 0 0 0 .708 0l3-3a.5.5 0 0 0-.708-.708L8.5 10.293V4.5z\"}}]})(props);\n};\nexport function BsArrowDownCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 8a7 7 0 1 0 14 0A7 7 0 0 0 1 8zm15 0A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM8.5 4.5a.5.5 0 0 0-1 0v5.793L5.354 8.146a.5.5 0 1 0-.708.708l3 3a.5.5 0 0 0 .708 0l3-3a.5.5 0 0 0-.708-.708L8.5 10.293V4.5z\"}}]})(props);\n};\nexport function BsArrowDownLeftCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 0 0 8a8 8 0 0 0 16 0zm-5.904-2.803a.5.5 0 1 1 .707.707L6.707 10h2.768a.5.5 0 0 1 0 1H5.5a.5.5 0 0 1-.5-.5V6.525a.5.5 0 0 1 1 0v2.768l4.096-4.096z\"}}]})(props);\n};\nexport function BsArrowDownLeftCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 8a7 7 0 1 0 14 0A7 7 0 0 0 1 8zm15 0A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-5.904-2.854a.5.5 0 1 1 .707.708L6.707 9.95h2.768a.5.5 0 1 1 0 1H5.5a.5.5 0 0 1-.5-.5V6.475a.5.5 0 1 1 1 0v2.768l4.096-4.097z\"}}]})(props);\n};\nexport function BsArrowDownLeftSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 16a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2zm8.096-10.803L6 9.293V6.525a.5.5 0 0 0-1 0V10.5a.5.5 0 0 0 .5.5h3.975a.5.5 0 0 0 0-1H6.707l4.096-4.096a.5.5 0 1 0-.707-.707z\"}}]})(props);\n};\nexport function BsArrowDownLeftSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M15 2a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V2zM0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm10.096 3.146a.5.5 0 1 1 .707.708L6.707 9.95h2.768a.5.5 0 1 1 0 1H5.5a.5.5 0 0 1-.5-.5V6.475a.5.5 0 1 1 1 0v2.768l4.096-4.097z\"}}]})(props);\n};\nexport function BsArrowDownLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 13.5a.5.5 0 0 0 .5.5h6a.5.5 0 0 0 0-1H3.707L13.854 2.854a.5.5 0 0 0-.708-.708L3 12.293V7.5a.5.5 0 0 0-1 0v6z\"}}]})(props);\n};\nexport function BsArrowDownRightCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8zm5.904-2.803a.5.5 0 1 0-.707.707L9.293 10H6.525a.5.5 0 0 0 0 1H10.5a.5.5 0 0 0 .5-.5V6.525a.5.5 0 0 0-1 0v2.768L5.904 5.197z\"}}]})(props);\n};\nexport function BsArrowDownRightCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 8a7 7 0 1 0 14 0A7 7 0 0 0 1 8zm15 0A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM5.854 5.146a.5.5 0 1 0-.708.708L9.243 9.95H6.475a.5.5 0 1 0 0 1h3.975a.5.5 0 0 0 .5-.5V6.475a.5.5 0 1 0-1 0v2.768L5.854 5.146z\"}}]})(props);\n};\nexport function BsArrowDownRightSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 16a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12zM5.904 5.197 10 9.293V6.525a.5.5 0 0 1 1 0V10.5a.5.5 0 0 1-.5.5H6.525a.5.5 0 0 1 0-1h2.768L5.197 5.904a.5.5 0 0 1 .707-.707z\"}}]})(props);\n};\nexport function BsArrowDownRightSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M15 2a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V2zM0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm5.854 3.146a.5.5 0 1 0-.708.708L9.243 9.95H6.475a.5.5 0 1 0 0 1h3.975a.5.5 0 0 0 .5-.5V6.475a.5.5 0 1 0-1 0v2.768L5.854 5.146z\"}}]})(props);\n};\nexport function BsArrowDownRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M14 13.5a.5.5 0 0 1-.5.5h-6a.5.5 0 0 1 0-1h4.793L2.146 2.854a.5.5 0 1 1 .708-.708L13 12.293V7.5a.5.5 0 0 1 1 0v6z\"}}]})(props);\n};\nexport function BsArrowDownShort (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 4a.5.5 0 0 1 .5.5v5.793l2.146-2.147a.5.5 0 0 1 .708.708l-3 3a.5.5 0 0 1-.708 0l-3-3a.5.5 0 1 1 .708-.708L7.5 10.293V4.5A.5.5 0 0 1 8 4z\"}}]})(props);\n};\nexport function BsArrowDownSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm6.5 4.5v5.793l2.146-2.147a.5.5 0 0 1 .708.708l-3 3a.5.5 0 0 1-.708 0l-3-3a.5.5 0 1 1 .708-.708L7.5 10.293V4.5a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsArrowDownSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M15 2a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V2zM0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm8.5 2.5a.5.5 0 0 0-1 0v5.793L5.354 8.146a.5.5 0 1 0-.708.708l3 3a.5.5 0 0 0 .708 0l3-3a.5.5 0 0 0-.708-.708L8.5 10.293V4.5z\"}}]})(props);\n};\nexport function BsArrowDownUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11.5 15a.5.5 0 0 0 .5-.5V2.707l3.146 3.147a.5.5 0 0 0 .708-.708l-4-4a.5.5 0 0 0-.708 0l-4 4a.5.5 0 1 0 .708.708L11 2.707V14.5a.5.5 0 0 0 .5.5zm-7-14a.5.5 0 0 1 .5.5v11.793l3.146-3.147a.5.5 0 0 1 .708.708l-4 4a.5.5 0 0 1-.708 0l-4-4a.5.5 0 0 1 .708-.708L4 13.293V1.5a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsArrowDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 1a.5.5 0 0 1 .5.5v11.793l3.146-3.147a.5.5 0 0 1 .708.708l-4 4a.5.5 0 0 1-.708 0l-4-4a.5.5 0 0 1 .708-.708L7.5 13.293V1.5A.5.5 0 0 1 8 1z\"}}]})(props);\n};\nexport function BsArrowLeftCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a8 8 0 1 0 0 16A8 8 0 0 0 8 0zm3.5 7.5a.5.5 0 0 1 0 1H5.707l2.147 2.146a.5.5 0 0 1-.708.708l-3-3a.5.5 0 0 1 0-.708l3-3a.5.5 0 1 1 .708.708L5.707 7.5H11.5z\"}}]})(props);\n};\nexport function BsArrowLeftCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 8a7 7 0 1 0 14 0A7 7 0 0 0 1 8zm15 0A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-4.5-.5a.5.5 0 0 1 0 1H5.707l2.147 2.146a.5.5 0 0 1-.708.708l-3-3a.5.5 0 0 1 0-.708l3-3a.5.5 0 1 1 .708.708L5.707 7.5H11.5z\"}}]})(props);\n};\nexport function BsArrowLeftRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 11.5a.5.5 0 0 0 .5.5h11.793l-3.147 3.146a.5.5 0 0 0 .708.708l4-4a.5.5 0 0 0 0-.708l-4-4a.5.5 0 0 0-.708.708L13.293 11H1.5a.5.5 0 0 0-.5.5zm14-7a.5.5 0 0 1-.5.5H2.707l3.147 3.146a.5.5 0 1 1-.708.708l-4-4a.5.5 0 0 1 0-.708l4-4a.5.5 0 1 1 .708.708L2.707 4H14.5a.5.5 0 0 1 .5.5z\"}}]})(props);\n};\nexport function BsArrowLeftShort (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M12 8a.5.5 0 0 1-.5.5H5.707l2.147 2.146a.5.5 0 0 1-.708.708l-3-3a.5.5 0 0 1 0-.708l3-3a.5.5 0 1 1 .708.708L5.707 7.5H11.5a.5.5 0 0 1 .5.5z\"}}]})(props);\n};\nexport function BsArrowLeftSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 14a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12zm-4.5-6.5H5.707l2.147-2.146a.5.5 0 1 0-.708-.708l-3 3a.5.5 0 0 0 0 .708l3 3a.5.5 0 0 0 .708-.708L5.707 8.5H11.5a.5.5 0 0 0 0-1z\"}}]})(props);\n};\nexport function BsArrowLeftSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M15 2a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V2zM0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm11.5 5.5a.5.5 0 0 1 0 1H5.707l2.147 2.146a.5.5 0 0 1-.708.708l-3-3a.5.5 0 0 1 0-.708l3-3a.5.5 0 1 1 .708.708L5.707 7.5H11.5z\"}}]})(props);\n};\nexport function BsArrowLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M15 8a.5.5 0 0 0-.5-.5H2.707l3.147-3.146a.5.5 0 1 0-.708-.708l-4 4a.5.5 0 0 0 0 .708l4 4a.5.5 0 0 0 .708-.708L2.707 8.5H14.5A.5.5 0 0 0 15 8z\"}}]})(props);\n};\nexport function BsArrowRepeat (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.534 7h3.932a.25.25 0 0 1 .192.41l-1.966 2.36a.25.25 0 0 1-.384 0l-1.966-2.36a.25.25 0 0 1 .192-.41zm-11 2h3.932a.25.25 0 0 0 .192-.41L2.692 6.23a.25.25 0 0 0-.384 0L.342 8.59A.25.25 0 0 0 .534 9z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 3c-1.552 0-2.94.707-3.857 1.818a.5.5 0 1 1-.771-.636A6.002 6.002 0 0 1 13.917 7H12.9A5.002 5.002 0 0 0 8 3zM3.1 9a5.002 5.002 0 0 0 8.757 2.182.5.5 0 1 1 .771.636A6.002 6.002 0 0 1 2.083 9H3.1z\"}}]})(props);\n};\nexport function BsArrowReturnLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M14.5 1.5a.5.5 0 0 1 .5.5v4.8a2.5 2.5 0 0 1-2.5 2.5H2.707l3.347 3.346a.5.5 0 0 1-.708.708l-4.2-4.2a.5.5 0 0 1 0-.708l4-4a.5.5 0 1 1 .708.708L2.707 8.3H12.5A1.5 1.5 0 0 0 14 6.8V2a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsArrowReturnRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.5 1.5A.5.5 0 0 0 1 2v4.8a2.5 2.5 0 0 0 2.5 2.5h9.793l-3.347 3.346a.5.5 0 0 0 .708.708l4.2-4.2a.5.5 0 0 0 0-.708l-4-4a.5.5 0 0 0-.708.708L13.293 8.3H3.5A1.5 1.5 0 0 1 2 6.8V2a.5.5 0 0 0-.5-.5z\"}}]})(props);\n};\nexport function BsArrowRightCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0zM4.5 7.5a.5.5 0 0 0 0 1h5.793l-2.147 2.146a.5.5 0 0 0 .708.708l3-3a.5.5 0 0 0 0-.708l-3-3a.5.5 0 1 0-.708.708L10.293 7.5H4.5z\"}}]})(props);\n};\nexport function BsArrowRightCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 8a7 7 0 1 0 14 0A7 7 0 0 0 1 8zm15 0A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM4.5 7.5a.5.5 0 0 0 0 1h5.793l-2.147 2.146a.5.5 0 0 0 .708.708l3-3a.5.5 0 0 0 0-.708l-3-3a.5.5 0 1 0-.708.708L10.293 7.5H4.5z\"}}]})(props);\n};\nexport function BsArrowRightShort (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4 8a.5.5 0 0 1 .5-.5h5.793L8.146 5.354a.5.5 0 1 1 .708-.708l3 3a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708-.708L10.293 8.5H4.5A.5.5 0 0 1 4 8z\"}}]})(props);\n};\nexport function BsArrowRightSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 14a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v12zm4.5-6.5h5.793L8.146 5.354a.5.5 0 1 1 .708-.708l3 3a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708-.708L10.293 8.5H4.5a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsArrowRightSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M15 2a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V2zM0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm4.5 5.5a.5.5 0 0 0 0 1h5.793l-2.147 2.146a.5.5 0 0 0 .708.708l3-3a.5.5 0 0 0 0-.708l-3-3a.5.5 0 1 0-.708.708L10.293 7.5H4.5z\"}}]})(props);\n};\nexport function BsArrowRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 8a.5.5 0 0 1 .5-.5h11.793l-3.147-3.146a.5.5 0 0 1 .708-.708l4 4a.5.5 0 0 1 0 .708l-4 4a.5.5 0 0 1-.708-.708L13.293 8.5H1.5A.5.5 0 0 1 1 8z\"}}]})(props);\n};\nexport function BsArrowUpCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 0 0 8a8 8 0 0 0 16 0zm-7.5 3.5a.5.5 0 0 1-1 0V5.707L5.354 7.854a.5.5 0 1 1-.708-.708l3-3a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1-.708.708L8.5 5.707V11.5z\"}}]})(props);\n};\nexport function BsArrowUpCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 8a7 7 0 1 0 14 0A7 7 0 0 0 1 8zm15 0A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-7.5 3.5a.5.5 0 0 1-1 0V5.707L5.354 7.854a.5.5 0 1 1-.708-.708l3-3a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1-.708.708L8.5 5.707V11.5z\"}}]})(props);\n};\nexport function BsArrowUpLeftCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-5.904 2.803a.5.5 0 1 0 .707-.707L6.707 6h2.768a.5.5 0 1 0 0-1H5.5a.5.5 0 0 0-.5.5v3.975a.5.5 0 0 0 1 0V6.707l4.096 4.096z\"}}]})(props);\n};\nexport function BsArrowUpLeftCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 8a7 7 0 1 0 14 0A7 7 0 0 0 1 8zm15 0A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-5.904 2.803a.5.5 0 1 0 .707-.707L6.707 6h2.768a.5.5 0 1 0 0-1H5.5a.5.5 0 0 0-.5.5v3.975a.5.5 0 0 0 1 0V6.707l4.096 4.096z\"}}]})(props);\n};\nexport function BsArrowUpLeftSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm8.096 10.803L6 6.707v2.768a.5.5 0 0 1-1 0V5.5a.5.5 0 0 1 .5-.5h3.975a.5.5 0 1 1 0 1H6.707l4.096 4.096a.5.5 0 1 1-.707.707z\"}}]})(props);\n};\nexport function BsArrowUpLeftSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M15 2a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V2zM0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm10.096 8.803a.5.5 0 1 0 .707-.707L6.707 6h2.768a.5.5 0 1 0 0-1H5.5a.5.5 0 0 0-.5.5v3.975a.5.5 0 0 0 1 0V6.707l4.096 4.096z\"}}]})(props);\n};\nexport function BsArrowUpLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 2.5a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1H3.707l10.147 10.146a.5.5 0 0 1-.708.708L3 3.707V8.5a.5.5 0 0 1-1 0v-6z\"}}]})(props);\n};\nexport function BsArrowUpRightCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 8a8 8 0 1 0 16 0A8 8 0 0 0 0 8zm5.904 2.803a.5.5 0 1 1-.707-.707L9.293 6H6.525a.5.5 0 1 1 0-1H10.5a.5.5 0 0 1 .5.5v3.975a.5.5 0 0 1-1 0V6.707l-4.096 4.096z\"}}]})(props);\n};\nexport function BsArrowUpRightCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 8a7 7 0 1 0 14 0A7 7 0 0 0 1 8zm15 0A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM5.854 10.803a.5.5 0 1 1-.708-.707L9.243 6H6.475a.5.5 0 1 1 0-1h3.975a.5.5 0 0 1 .5.5v3.975a.5.5 0 1 1-1 0V6.707l-4.096 4.096z\"}}]})(props);\n};\nexport function BsArrowUpRightSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 0a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12zM5.904 10.803 10 6.707v2.768a.5.5 0 0 0 1 0V5.5a.5.5 0 0 0-.5-.5H6.525a.5.5 0 1 0 0 1h2.768l-4.096 4.096a.5.5 0 0 0 .707.707z\"}}]})(props);\n};\nexport function BsArrowUpRightSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M15 2a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V2zM0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm5.854 8.803a.5.5 0 1 1-.708-.707L9.243 6H6.475a.5.5 0 1 1 0-1h3.975a.5.5 0 0 1 .5.5v3.975a.5.5 0 1 1-1 0V6.707l-4.096 4.096z\"}}]})(props);\n};\nexport function BsArrowUpRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M14 2.5a.5.5 0 0 0-.5-.5h-6a.5.5 0 0 0 0 1h4.793L2.146 13.146a.5.5 0 0 0 .708.708L13 3.707V8.5a.5.5 0 0 0 1 0v-6z\"}}]})(props);\n};\nexport function BsArrowUpShort (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 12a.5.5 0 0 0 .5-.5V5.707l2.146 2.147a.5.5 0 0 0 .708-.708l-3-3a.5.5 0 0 0-.708 0l-3 3a.5.5 0 1 0 .708.708L7.5 5.707V11.5a.5.5 0 0 0 .5.5z\"}}]})(props);\n};\nexport function BsArrowUpSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 16a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2zm6.5-4.5V5.707l2.146 2.147a.5.5 0 0 0 .708-.708l-3-3a.5.5 0 0 0-.708 0l-3 3a.5.5 0 1 0 .708.708L7.5 5.707V11.5a.5.5 0 0 0 1 0z\"}}]})(props);\n};\nexport function BsArrowUpSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M15 2a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V2zM0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm8.5 9.5a.5.5 0 0 1-1 0V5.707L5.354 7.854a.5.5 0 1 1-.708-.708l3-3a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1-.708.708L8.5 5.707V11.5z\"}}]})(props);\n};\nexport function BsArrowUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 15a.5.5 0 0 0 .5-.5V2.707l3.146 3.147a.5.5 0 0 0 .708-.708l-4-4a.5.5 0 0 0-.708 0l-4 4a.5.5 0 1 0 .708.708L7.5 2.707V14.5a.5.5 0 0 0 .5.5z\"}}]})(props);\n};\nexport function BsArrowsAngleContract (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M.172 15.828a.5.5 0 0 0 .707 0l4.096-4.096V14.5a.5.5 0 1 0 1 0v-3.975a.5.5 0 0 0-.5-.5H1.5a.5.5 0 0 0 0 1h2.768L.172 15.121a.5.5 0 0 0 0 .707zM15.828.172a.5.5 0 0 0-.707 0l-4.096 4.096V1.5a.5.5 0 1 0-1 0v3.975a.5.5 0 0 0 .5.5H14.5a.5.5 0 0 0 0-1h-2.768L15.828.879a.5.5 0 0 0 0-.707z\"}}]})(props);\n};\nexport function BsArrowsAngleExpand (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5.828 10.172a.5.5 0 0 0-.707 0l-4.096 4.096V11.5a.5.5 0 0 0-1 0v3.975a.5.5 0 0 0 .5.5H4.5a.5.5 0 0 0 0-1H1.732l4.096-4.096a.5.5 0 0 0 0-.707zm4.344-4.344a.5.5 0 0 0 .707 0l4.096-4.096V4.5a.5.5 0 1 0 1 0V.525a.5.5 0 0 0-.5-.5H11.5a.5.5 0 0 0 0 1h2.768l-4.096 4.096a.5.5 0 0 0 0 .707z\"}}]})(props);\n};\nexport function BsArrowsCollapse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 8a.5.5 0 0 1 .5-.5h13a.5.5 0 0 1 0 1h-13A.5.5 0 0 1 1 8zm7-8a.5.5 0 0 1 .5.5v3.793l1.146-1.147a.5.5 0 0 1 .708.708l-2 2a.5.5 0 0 1-.708 0l-2-2a.5.5 0 1 1 .708-.708L7.5 4.293V.5A.5.5 0 0 1 8 0zm-.5 11.707-1.146 1.147a.5.5 0 0 1-.708-.708l2-2a.5.5 0 0 1 .708 0l2 2a.5.5 0 0 1-.708.708L8.5 11.707V15.5a.5.5 0 0 1-1 0v-3.793z\"}}]})(props);\n};\nexport function BsArrowsExpand (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 8a.5.5 0 0 1 .5-.5h13a.5.5 0 0 1 0 1h-13A.5.5 0 0 1 1 8zM7.646.146a.5.5 0 0 1 .708 0l2 2a.5.5 0 0 1-.708.708L8.5 1.707V5.5a.5.5 0 0 1-1 0V1.707L6.354 2.854a.5.5 0 1 1-.708-.708l2-2zM8 10a.5.5 0 0 1 .5.5v3.793l1.146-1.147a.5.5 0 0 1 .708.708l-2 2a.5.5 0 0 1-.708 0l-2-2a.5.5 0 0 1 .708-.708L7.5 14.293V10.5A.5.5 0 0 1 8 10z\"}}]})(props);\n};\nexport function BsArrowsFullscreen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5.828 10.172a.5.5 0 0 0-.707 0l-4.096 4.096V11.5a.5.5 0 0 0-1 0v3.975a.5.5 0 0 0 .5.5H4.5a.5.5 0 0 0 0-1H1.732l4.096-4.096a.5.5 0 0 0 0-.707zm4.344 0a.5.5 0 0 1 .707 0l4.096 4.096V11.5a.5.5 0 1 1 1 0v3.975a.5.5 0 0 1-.5.5H11.5a.5.5 0 0 1 0-1h2.768l-4.096-4.096a.5.5 0 0 1 0-.707zm0-4.344a.5.5 0 0 0 .707 0l4.096-4.096V4.5a.5.5 0 1 0 1 0V.525a.5.5 0 0 0-.5-.5H11.5a.5.5 0 0 0 0 1h2.768l-4.096 4.096a.5.5 0 0 0 0 .707zm-4.344 0a.5.5 0 0 1-.707 0L1.025 1.732V4.5a.5.5 0 0 1-1 0V.525a.5.5 0 0 1 .5-.5H4.5a.5.5 0 0 1 0 1H1.732l4.096 4.096a.5.5 0 0 1 0 .707z\"}}]})(props);\n};\nexport function BsArrowsMove (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.646.146a.5.5 0 0 1 .708 0l2 2a.5.5 0 0 1-.708.708L8.5 1.707V5.5a.5.5 0 0 1-1 0V1.707L6.354 2.854a.5.5 0 1 1-.708-.708l2-2zM8 10a.5.5 0 0 1 .5.5v3.793l1.146-1.147a.5.5 0 0 1 .708.708l-2 2a.5.5 0 0 1-.708 0l-2-2a.5.5 0 0 1 .708-.708L7.5 14.293V10.5A.5.5 0 0 1 8 10zM.146 8.354a.5.5 0 0 1 0-.708l2-2a.5.5 0 1 1 .708.708L1.707 7.5H5.5a.5.5 0 0 1 0 1H1.707l1.147 1.146a.5.5 0 0 1-.708.708l-2-2zM10 8a.5.5 0 0 1 .5-.5h3.793l-1.147-1.146a.5.5 0 0 1 .708-.708l2 2a.5.5 0 0 1 0 .708l-2 2a.5.5 0 0 1-.708-.708L14.293 8.5H10.5A.5.5 0 0 1 10 8z\"}}]})(props);\n};\nexport function BsAspectRatioFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12.5v-9A1.5 1.5 0 0 1 1.5 2h13A1.5 1.5 0 0 1 16 3.5v9a1.5 1.5 0 0 1-1.5 1.5h-13A1.5 1.5 0 0 1 0 12.5zM2.5 4a.5.5 0 0 0-.5.5v3a.5.5 0 0 0 1 0V5h2.5a.5.5 0 0 0 0-1h-3zm11 8a.5.5 0 0 0 .5-.5v-3a.5.5 0 0 0-1 0V11h-2.5a.5.5 0 0 0 0 1h3z\"}}]})(props);\n};\nexport function BsAspectRatio (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 3.5A1.5 1.5 0 0 1 1.5 2h13A1.5 1.5 0 0 1 16 3.5v9a1.5 1.5 0 0 1-1.5 1.5h-13A1.5 1.5 0 0 1 0 12.5v-9zM1.5 3a.5.5 0 0 0-.5.5v9a.5.5 0 0 0 .5.5h13a.5.5 0 0 0 .5-.5v-9a.5.5 0 0 0-.5-.5h-13z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 4.5a.5.5 0 0 1 .5-.5h3a.5.5 0 0 1 0 1H3v2.5a.5.5 0 0 1-1 0v-3zm12 7a.5.5 0 0 1-.5.5h-3a.5.5 0 0 1 0-1H13V8.5a.5.5 0 0 1 1 0v3z\"}}]})(props);\n};\nexport function BsAsterisk (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a1 1 0 0 1 1 1v5.268l4.562-2.634a1 1 0 1 1 1 1.732L10 8l4.562 2.634a1 1 0 1 1-1 1.732L9 9.732V15a1 1 0 1 1-2 0V9.732l-4.562 2.634a1 1 0 1 1-1-1.732L6 8 1.438 5.366a1 1 0 0 1 1-1.732L7 6.268V1a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsAt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.106 7.222c0-2.967-2.249-5.032-5.482-5.032-3.35 0-5.646 2.318-5.646 5.702 0 3.493 2.235 5.708 5.762 5.708.862 0 1.689-.123 2.304-.335v-.862c-.43.199-1.354.328-2.29.328-2.926 0-4.813-1.88-4.813-4.798 0-2.844 1.921-4.881 4.594-4.881 2.735 0 4.608 1.688 4.608 4.156 0 1.682-.554 2.769-1.416 2.769-.492 0-.772-.28-.772-.76V5.206H8.923v.834h-.11c-.266-.595-.881-.964-1.6-.964-1.4 0-2.378 1.162-2.378 2.823 0 1.737.957 2.906 2.379 2.906.8 0 1.415-.39 1.709-1.087h.11c.081.67.703 1.148 1.503 1.148 1.572 0 2.57-1.415 2.57-3.643zm-7.177.704c0-1.197.54-1.907 1.456-1.907.93 0 1.524.738 1.524 1.907S8.308 9.84 7.371 9.84c-.895 0-1.442-.725-1.442-1.914z\"}}]})(props);\n};\nexport function BsAwardFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m8 0 1.669.864 1.858.282.842 1.68 1.337 1.32L13.4 6l.306 1.854-1.337 1.32-.842 1.68-1.858.282L8 12l-1.669-.864-1.858-.282-.842-1.68-1.337-1.32L2.6 6l-.306-1.854 1.337-1.32.842-1.68L6.331.864 8 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 11.794V16l4-1 4 1v-4.206l-2.018.306L8 13.126 6.018 12.1 4 11.794z\"}}]})(props);\n};\nexport function BsAward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.669.864 8 0 6.331.864l-1.858.282-.842 1.68-1.337 1.32L2.6 6l-.306 1.854 1.337 1.32.842 1.68 1.858.282L8 12l1.669-.864 1.858-.282.842-1.68 1.337-1.32L13.4 6l.306-1.854-1.337-1.32-.842-1.68L9.669.864zm1.196 1.193.684 1.365 1.086 1.072L12.387 6l.248 1.506-1.086 1.072-.684 1.365-1.51.229L8 10.874l-1.355-.702-1.51-.229-.684-1.365-1.086-1.072L3.614 6l-.25-1.506 1.087-1.072.684-1.365 1.51-.229L8 1.126l1.356.702 1.509.229z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 11.794V16l4-1 4 1v-4.206l-2.018.306L8 13.126 6.018 12.1 4 11.794z\"}}]})(props);\n};\nexport function BsBack (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v2h2a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2v-2H2a2 2 0 0 1-2-2V2zm2-1a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H2z\"}}]})(props);\n};\nexport function BsBackspaceFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.683 3a2 2 0 0 0-2-2h-7.08a2 2 0 0 0-1.519.698L.241 7.35a1 1 0 0 0 0 1.302l4.843 5.65A2 2 0 0 0 6.603 15h7.08a2 2 0 0 0 2-2V3zM5.829 5.854a.5.5 0 1 1 .707-.708l2.147 2.147 2.146-2.147a.5.5 0 1 1 .707.708L9.39 8l2.146 2.146a.5.5 0 0 1-.707.708L8.683 8.707l-2.147 2.147a.5.5 0 0 1-.707-.708L7.976 8 5.829 5.854z\"}}]})(props);\n};\nexport function BsBackspaceReverseFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 3a2 2 0 0 1 2-2h7.08a2 2 0 0 1 1.519.698l4.843 5.651a1 1 0 0 1 0 1.302L10.6 14.3a2 2 0 0 1-1.52.7H2a2 2 0 0 1-2-2V3zm9.854 2.854a.5.5 0 0 0-.708-.708L7 7.293 4.854 5.146a.5.5 0 1 0-.708.708L6.293 8l-2.147 2.146a.5.5 0 0 0 .708.708L7 8.707l2.146 2.147a.5.5 0 0 0 .708-.708L7.707 8l2.147-2.146z\"}}]})(props);\n};\nexport function BsBackspaceReverse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.854 5.146a.5.5 0 0 1 0 .708L7.707 8l2.147 2.146a.5.5 0 0 1-.708.708L7 8.707l-2.146 2.147a.5.5 0 0 1-.708-.708L6.293 8 4.146 5.854a.5.5 0 1 1 .708-.708L7 7.293l2.146-2.147a.5.5 0 0 1 .708 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h7.08a2 2 0 0 0 1.519-.698l4.843-5.651a1 1 0 0 0 0-1.302L10.6 1.7A2 2 0 0 0 9.08 1H2zm7.08 1a1 1 0 0 1 .76.35L14.682 8l-4.844 5.65a1 1 0 0 1-.759.35H2a1 1 0 0 1-1-1V3a1 1 0 0 1 1-1h7.08z\"}}]})(props);\n};\nexport function BsBackspace (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.83 5.146a.5.5 0 0 0 0 .708L7.975 8l-2.147 2.146a.5.5 0 0 0 .707.708l2.147-2.147 2.146 2.147a.5.5 0 0 0 .707-.708L9.39 8l2.146-2.146a.5.5 0 0 0-.707-.708L8.683 7.293 6.536 5.146a.5.5 0 0 0-.707 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.683 1a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2h-7.08a2 2 0 0 1-1.519-.698L.241 8.65a1 1 0 0 1 0-1.302L5.084 1.7A2 2 0 0 1 6.603 1h7.08zm-7.08 1a1 1 0 0 0-.76.35L1 8l4.844 5.65a1 1 0 0 0 .759.35h7.08a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1h-7.08z\"}}]})(props);\n};\nexport function BsBadge3DFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.157 5.968h-.844v4.06h.844c1.116 0 1.621-.667 1.621-2.02 0-1.354-.51-2.04-1.621-2.04z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm5.184 4.368c.646 0 1.055.378 1.06.9.008.537-.427.919-1.086.919-.598-.004-1.037-.325-1.068-.756H3c.03.914.791 1.688 2.153 1.688 1.24 0 2.285-.66 2.272-1.798-.013-.953-.747-1.38-1.292-1.432v-.062c.44-.07 1.125-.527 1.108-1.375-.013-.906-.8-1.57-2.053-1.565-1.31.005-2.043.734-2.074 1.67h1.103c.022-.391.383-.751.936-.751.532 0 .928.33.928.813.004.479-.383.835-.928.835h-.632v.914h.663zM8.126 11h2.189C12.125 11 13 9.893 13 7.985c0-1.894-.861-2.984-2.685-2.984H8.126V11z\"}}]})(props);\n};\nexport function BsBadge3D (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.52 8.368h.664c.646 0 1.055.378 1.06.9.008.537-.427.919-1.086.919-.598-.004-1.037-.325-1.068-.756H3c.03.914.791 1.688 2.153 1.688 1.24 0 2.285-.66 2.272-1.798-.013-.953-.747-1.38-1.292-1.432v-.062c.44-.07 1.125-.527 1.108-1.375-.013-.906-.8-1.57-2.053-1.565-1.31.005-2.043.734-2.074 1.67h1.103c.022-.391.383-.751.936-.751.532 0 .928.33.928.813.004.479-.383.835-.928.835h-.632v.914zm3.606-3.367V11h2.189C12.125 11 13 9.893 13 7.985c0-1.894-.861-2.984-2.685-2.984H8.126zm1.187.967h.844c1.112 0 1.621.686 1.621 2.04 0 1.353-.505 2.02-1.621 2.02h-.844v-4.06z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h12zM2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsBadge4KFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.577 8.9v.03h1.828V5.898h-.062a46.781 46.781 0 0 0-1.766 3.001z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm2.372 3.715.435-.714h1.71v3.93h.733v.957h-.733V11H5.405V9.888H2.5v-.971c.574-1.077 1.225-2.142 1.872-3.202zm7.73-.714h1.306l-2.14 2.584L13.5 11h-1.428l-1.679-2.624-.615.7V11H8.59V5.001h1.187v2.686h.057L12.102 5z\"}}]})(props);\n};\nexport function BsBadge4K (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.807 5.001C4.021 6.298 3.203 7.6 2.5 8.917v.971h2.905V11h1.112V9.888h.733V8.93h-.733V5.001h-1.71zm-1.23 3.93v-.032a46.781 46.781 0 0 1 1.766-3.001h.062V8.93H3.577zm9.831-3.93h-1.306L9.835 7.687h-.057V5H8.59v6h1.187V9.075l.615-.699L12.072 11H13.5l-2.232-3.415 2.14-2.584z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h12zM2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsBadge8KFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.9 6.605c0 .51.405.866.95.866.545 0 .945-.356.945-.866s-.4-.852-.945-.852c-.545 0-.95.343-.95.852zm-.192 2.668c0 .589.492.984 1.142.984.646 0 1.143-.395 1.143-.984S5.496 8.28 4.85 8.28c-.65 0-1.142.404-1.142.993z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm5.17 7.348c0 1.041-.927 1.766-2.333 1.766-1.406 0-2.312-.72-2.312-1.762 0-.954.712-1.384 1.257-1.494v-.053c-.51-.154-1.02-.558-1.02-1.331 0-.914.831-1.587 2.088-1.587 1.253 0 2.083.673 2.083 1.587 0 .782-.523 1.182-1.02 1.331v.053c.545.11 1.257.545 1.257 1.49zM12.102 5h1.306l-2.14 2.584 2.232 3.415h-1.428l-1.679-2.624-.615.699v1.925H8.59V5h1.187v2.685h.057L12.102 5z\"}}]})(props);\n};\nexport function BsBadge8K (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.837 11.114c1.406 0 2.333-.725 2.333-1.766 0-.945-.712-1.38-1.256-1.49v-.053c.496-.15 1.02-.55 1.02-1.331 0-.914-.831-1.587-2.084-1.587-1.257 0-2.087.673-2.087 1.587 0 .773.51 1.177 1.02 1.331v.053c-.546.11-1.258.54-1.258 1.494 0 1.042.906 1.762 2.312 1.762zm.013-3.643c-.545 0-.95-.356-.95-.866s.405-.852.95-.852c.545 0 .945.343.945.852 0 .51-.4.866-.945.866zm0 2.786c-.65 0-1.142-.395-1.142-.984S4.2 8.28 4.85 8.28c.646 0 1.143.404 1.143.993s-.497.984-1.143.984zM13.408 5h-1.306L9.835 7.685h-.057V5H8.59v5.998h1.187V9.075l.615-.699 1.679 2.623H13.5l-2.232-3.414L13.408 5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h12zM2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsBadgeAdFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.35 8.337c0-.699-.42-1.138-1.001-1.138-.584 0-.954.444-.954 1.239v.453c0 .8.374 1.248.972 1.248.588 0 .984-.44.984-1.2v-.602zm-5.413.237-.734-2.426H5.15l-.734 2.426h1.52z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm6.209 6.32c0-1.28.694-2.044 1.753-2.044.655 0 1.156.294 1.336.769h.053v-2.36h1.16V11h-1.138v-.747h-.057c-.145.474-.69.804-1.367.804-1.055 0-1.74-.764-1.74-2.043v-.695zm-4.04 1.138L3.7 11H2.5l2.013-5.999H5.9L7.905 11H6.644l-.47-1.542H4.17z\"}}]})(props);\n};\nexport function BsBadgeAd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m3.7 11 .47-1.542h2.004L6.644 11h1.261L5.901 5.001H4.513L2.5 11h1.2zm1.503-4.852.734 2.426H4.416l.734-2.426h.053zm4.759.128c-1.059 0-1.753.765-1.753 2.043v.695c0 1.279.685 2.043 1.74 2.043.677 0 1.222-.33 1.367-.804h.057V11h1.138V4.685h-1.16v2.36h-.053c-.18-.475-.68-.77-1.336-.77zm.387.923c.58 0 1.002.44 1.002 1.138v.602c0 .76-.396 1.2-.984 1.2-.598 0-.972-.449-.972-1.248v-.453c0-.795.37-1.24.954-1.24z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h12zM2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsBadgeArFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m6.031 8.574-.734-2.426h-.052L4.51 8.574h1.52zm3.642-2.641v1.938h1.033c.66 0 1.068-.316 1.068-.95 0-.64-.422-.988-1.05-.988h-1.05z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm4.265 5.458h2.004L6.739 11H8L5.996 5.001H4.607L2.595 11h1.2l.47-1.542zM8.5 5v6h1.173V8.763h1.064L11.787 11h1.327L11.91 8.583C12.455 8.373 13 7.779 13 6.9c0-1.147-.773-1.9-2.105-1.9H8.5z\"}}]})(props);\n};\nexport function BsBadgeAr (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m3.794 11 .47-1.542H6.27L6.739 11H8L5.996 5.001H4.607L2.595 11h1.2zm1.503-4.852.734 2.426h-1.52l.734-2.426h.052zm5.598-1.147H8.5V11h1.173V8.763h1.064L11.787 11h1.327L11.91 8.583C12.455 8.373 13 7.779 13 6.9c0-1.147-.773-1.9-2.105-1.9zm-1.222 2.87V5.933h1.05c.63 0 1.05.347 1.05.989 0 .633-.408.95-1.067.95H9.673z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h12zM2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsBadgeCcFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm3.027 4.002c-.83 0-1.319.642-1.319 1.753v.743c0 1.107.48 1.727 1.319 1.727.69 0 1.138-.435 1.186-1.05H7.36v.114c-.057 1.147-1.028 1.938-2.342 1.938-1.613 0-2.518-1.028-2.518-2.729v-.747C2.5 6.051 3.414 5 5.018 5c1.318 0 2.29.813 2.342 2v.11H6.213c-.048-.638-.505-1.108-1.186-1.108zm6.14 0c-.831 0-1.319.642-1.319 1.753v.743c0 1.107.48 1.727 1.318 1.727.69 0 1.139-.435 1.187-1.05H13.5v.114c-.057 1.147-1.028 1.938-2.342 1.938-1.613 0-2.518-1.028-2.518-2.729v-.747c0-1.7.914-2.751 2.518-2.751 1.318 0 2.29.813 2.342 2v.11h-1.147c-.048-.638-.505-1.108-1.187-1.108z\"}}]})(props);\n};\nexport function BsBadgeCc (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.708 7.755c0-1.111.488-1.753 1.319-1.753.681 0 1.138.47 1.186 1.107H7.36V7c-.052-1.186-1.024-2-2.342-2C3.414 5 2.5 6.05 2.5 7.751v.747c0 1.7.905 2.73 2.518 2.73 1.314 0 2.285-.792 2.342-1.939v-.114H6.213c-.048.615-.496 1.05-1.186 1.05-.84 0-1.319-.62-1.319-1.727v-.743zm6.14 0c0-1.111.488-1.753 1.318-1.753.682 0 1.139.47 1.187 1.107H13.5V7c-.053-1.186-1.024-2-2.342-2C9.554 5 8.64 6.05 8.64 7.751v.747c0 1.7.905 2.73 2.518 2.73 1.314 0 2.285-.792 2.342-1.939v-.114h-1.147c-.048.615-.497 1.05-1.187 1.05-.839 0-1.318-.62-1.318-1.727v-.743z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h12zM2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsBadgeHdFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.53 5.968h-.843v4.06h.843c1.117 0 1.622-.667 1.622-2.02 0-1.354-.51-2.04-1.622-2.04z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm5.396 3.001V11H6.209V8.43H3.687V11H2.5V5.001h1.187v2.44h2.522V5h1.187zM8.5 11V5.001h2.188c1.824 0 2.685 1.09 2.685 2.984C13.373 9.893 12.5 11 10.69 11H8.5z\"}}]})(props);\n};\nexport function BsBadgeHd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.396 11V5.001H6.209v2.44H3.687V5H2.5v6h1.187V8.43h2.522V11h1.187zM8.5 5.001V11h2.188c1.811 0 2.685-1.107 2.685-3.015 0-1.894-.86-2.984-2.684-2.984H8.5zm1.187.967h.843c1.112 0 1.622.686 1.622 2.04 0 1.353-.505 2.02-1.622 2.02h-.843v-4.06z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h12zM2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsBadgeTmFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm3.295 3.995V11H4.104V5.995h-1.7V5H7v.994H5.295zM8.692 7.01V11H7.633V5.001h1.209l1.71 3.894h.039l1.71-3.894H13.5V11h-1.072V7.01h-.057l-1.42 3.239h-.773L8.75 7.008h-.058z\"}}]})(props);\n};\nexport function BsBadgeTm (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.295 11V5.995H7V5H2.403v.994h1.701V11h1.19zm3.397 0V7.01h.058l1.428 3.239h.773l1.42-3.24h.057V11H13.5V5.001h-1.2l-1.71 3.894h-.039l-1.71-3.894H7.634V11h1.06z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h12zM2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsBadgeVoFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.296 8.394v-.782c0-1.156-.571-1.736-1.362-1.736-.796 0-1.363.58-1.363 1.736v.782c0 1.156.567 1.732 1.363 1.732.79 0 1.362-.576 1.362-1.732z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm11.5 5.62v.77c0 1.691-.962 2.724-2.566 2.724-1.604 0-2.571-1.033-2.571-2.724v-.77c0-1.704.967-2.733 2.57-2.733 1.605 0 2.567 1.037 2.567 2.734zM5.937 11H4.508L2.5 5.001h1.375L5.22 9.708h.057L6.61 5.001h1.318L5.937 11z\"}}]})(props);\n};\nexport function BsBadgeVo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.508 11h1.429l1.99-5.999H6.61L5.277 9.708H5.22L3.875 5.001H2.5L4.508 11zM13.5 8.39v-.77c0-1.696-.962-2.733-2.566-2.733-1.604 0-2.571 1.029-2.571 2.734v.769c0 1.691.967 2.724 2.57 2.724 1.605 0 2.567-1.033 2.567-2.724zm-1.204-.778v.782c0 1.156-.571 1.732-1.362 1.732-.796 0-1.363-.576-1.363-1.732v-.782c0-1.156.567-1.736 1.363-1.736.79 0 1.362.58 1.362 1.736z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h12zM2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsBadgeVrFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.673 5.933v1.938h1.033c.66 0 1.068-.316 1.068-.95 0-.64-.422-.988-1.05-.988h-1.05z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm5.937 7 1.99-5.999H6.61L5.277 9.708H5.22L3.875 5.001H2.5L4.508 11h1.429zM8.5 5.001V11h1.173V8.763h1.064L11.787 11h1.327L11.91 8.583C12.455 8.373 13 7.779 13 6.9c0-1.147-.773-1.9-2.105-1.9H8.5z\"}}]})(props);\n};\nexport function BsBadgeVr (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h12zM2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.508 11h1.429l1.99-5.999H6.61L5.277 9.708H5.22L3.875 5.001H2.5L4.508 11zm6.387-5.999H8.5V11h1.173V8.763h1.064L11.787 11h1.327L11.91 8.583C12.455 8.373 13 7.779 13 6.9c0-1.147-.773-1.9-2.105-1.9zm-1.222 2.87V5.933h1.05c.63 0 1.05.347 1.05.989 0 .633-.408.95-1.067.95H9.673z\"}}]})(props);\n};\nexport function BsBadgeWcFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm11.666 1.89c.682 0 1.139.47 1.187 1.107H14v-.11c-.053-1.187-1.024-2-2.342-2-1.604 0-2.518 1.05-2.518 2.751v.747c0 1.7.905 2.73 2.518 2.73 1.314 0 2.285-.792 2.342-1.939v-.114h-1.147c-.048.615-.497 1.05-1.187 1.05-.839 0-1.318-.62-1.318-1.727v-.742c0-1.112.488-1.754 1.318-1.754zm-6.188.926h.044L6.542 11h1.006L9 5.001H7.818l-.82 4.355h-.056L5.97 5.001h-.94l-.972 4.355h-.053l-.827-4.355H2L3.452 11h1.005l1.02-4.184z\"}}]})(props);\n};\nexport function BsBadgeWc (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.348 7.643c0-1.112.488-1.754 1.318-1.754.682 0 1.139.47 1.187 1.108H14v-.11c-.053-1.187-1.024-2-2.342-2-1.604 0-2.518 1.05-2.518 2.751v.747c0 1.7.905 2.73 2.518 2.73 1.314 0 2.285-.792 2.342-1.939v-.114h-1.147c-.048.615-.497 1.05-1.187 1.05-.839 0-1.318-.62-1.318-1.727v-.742zM4.457 11l1.02-4.184h.045L6.542 11h1.006L9 5.001H7.818l-.82 4.355h-.056L5.97 5.001h-.94l-.972 4.355h-.053l-.827-4.355H2L3.452 11h1.005z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h12zM2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsBagCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.5 3.5a2.5 2.5 0 0 0-5 0V4h5v-.5zm1 0V4H15v10a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V4h3.5v-.5a3.5 3.5 0 1 1 7 0zm-.646 5.354a.5.5 0 0 0-.708-.708L7.5 10.793 6.354 9.646a.5.5 0 1 0-.708.708l1.5 1.5a.5.5 0 0 0 .708 0l3-3z\"}}]})(props);\n};\nexport function BsBagCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.854 8.146a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 0 1 .708-.708L7.5 10.793l2.646-2.647a.5.5 0 0 1 .708 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a2.5 2.5 0 0 1 2.5 2.5V4h-5v-.5A2.5 2.5 0 0 1 8 1zm3.5 3v-.5a3.5 3.5 0 1 0-7 0V4H1v10a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V4h-3.5zM2 5h12v9a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V5z\"}}]})(props);\n};\nexport function BsBagDashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.5 3.5a2.5 2.5 0 0 0-5 0V4h5v-.5zm1 0V4H15v10a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V4h3.5v-.5a3.5 3.5 0 1 1 7 0zM6 9.5a.5.5 0 0 0 0 1h4a.5.5 0 0 0 0-1H6z\"}}]})(props);\n};\nexport function BsBagDash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5.5 10a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a2.5 2.5 0 0 1 2.5 2.5V4h-5v-.5A2.5 2.5 0 0 1 8 1zm3.5 3v-.5a3.5 3.5 0 1 0-7 0V4H1v10a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V4h-3.5zM2 5h12v9a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V5z\"}}]})(props);\n};\nexport function BsBagFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a2.5 2.5 0 0 1 2.5 2.5V4h-5v-.5A2.5 2.5 0 0 1 8 1zm3.5 3v-.5a3.5 3.5 0 1 0-7 0V4H1v10a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V4h-3.5z\"}}]})(props);\n};\nexport function BsBagPlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.5 3.5a2.5 2.5 0 0 0-5 0V4h5v-.5zm1 0V4H15v10a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V4h3.5v-.5a3.5 3.5 0 1 1 7 0zM8.5 8a.5.5 0 0 0-1 0v1.5H6a.5.5 0 0 0 0 1h1.5V12a.5.5 0 0 0 1 0v-1.5H10a.5.5 0 0 0 0-1H8.5V8z\"}}]})(props);\n};\nexport function BsBagPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 7.5a.5.5 0 0 1 .5.5v1.5H10a.5.5 0 0 1 0 1H8.5V12a.5.5 0 0 1-1 0v-1.5H6a.5.5 0 0 1 0-1h1.5V8a.5.5 0 0 1 .5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a2.5 2.5 0 0 1 2.5 2.5V4h-5v-.5A2.5 2.5 0 0 1 8 1zm3.5 3v-.5a3.5 3.5 0 1 0-7 0V4H1v10a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V4h-3.5zM2 5h12v9a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V5z\"}}]})(props);\n};\nexport function BsBagXFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.5 3.5a2.5 2.5 0 0 0-5 0V4h5v-.5zm1 0V4H15v10a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V4h3.5v-.5a3.5 3.5 0 1 1 7 0zM6.854 8.146a.5.5 0 1 0-.708.708L7.293 10l-1.147 1.146a.5.5 0 0 0 .708.708L8 10.707l1.146 1.147a.5.5 0 0 0 .708-.708L8.707 10l1.147-1.146a.5.5 0 0 0-.708-.708L8 9.293 6.854 8.146z\"}}]})(props);\n};\nexport function BsBagX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6.146 8.146a.5.5 0 0 1 .708 0L8 9.293l1.146-1.147a.5.5 0 1 1 .708.708L8.707 10l1.147 1.146a.5.5 0 0 1-.708.708L8 10.707l-1.146 1.147a.5.5 0 0 1-.708-.708L7.293 10 6.146 8.854a.5.5 0 0 1 0-.708z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a2.5 2.5 0 0 1 2.5 2.5V4h-5v-.5A2.5 2.5 0 0 1 8 1zm3.5 3v-.5a3.5 3.5 0 1 0-7 0V4H1v10a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V4h-3.5zM2 5h12v9a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V5z\"}}]})(props);\n};\nexport function BsBag (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a2.5 2.5 0 0 1 2.5 2.5V4h-5v-.5A2.5 2.5 0 0 1 8 1zm3.5 3v-.5a3.5 3.5 0 1 0-7 0V4H1v10a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V4h-3.5zM2 5h12v9a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V5z\"}}]})(props);\n};\nexport function BsBank (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 .95 14.61 4h.89a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5H15v7a.5.5 0 0 1 .485.379l.5 2A.5.5 0 0 1 15.5 17H.5a.5.5 0 0 1-.485-.621l.5-2A.5.5 0 0 1 1 14V7H.5a.5.5 0 0 1-.5-.5v-2A.5.5 0 0 1 .5 4h.89L8 .95zM3.776 4h8.447L8 2.05 3.776 4zM2 7v7h1V7H2zm2 0v7h2.5V7H4zm3.5 0v7h1V7h-1zm2 0v7H12V7H9.5zM13 7v7h1V7h-1zm2-1V5H1v1h14zm-.39 9H1.39l-.25 1h13.72l-.25-1z\"}}]})(props);\n};\nexport function BsBank2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.277.084a.5.5 0 0 0-.554 0l-7.5 5A.5.5 0 0 0 .5 6h1.875v7H1.5a.5.5 0 0 0 0 1h13a.5.5 0 1 0 0-1h-.875V6H15.5a.5.5 0 0 0 .277-.916l-7.5-5zM12.375 6v7h-1.25V6h1.25zm-2.5 0v7h-1.25V6h1.25zm-2.5 0v7h-1.25V6h1.25zm-2.5 0v7h-1.25V6h1.25zM8 4a1 1 0 1 1 0-2 1 1 0 0 1 0 2zM.5 15a.5.5 0 0 0 0 1h15a.5.5 0 1 0 0-1H.5z\"}}]})(props);\n};\nexport function BsBarChartFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 11a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1v-3zm5-4a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v7a1 1 0 0 1-1 1H7a1 1 0 0 1-1-1V7zm5-5a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1h-2a1 1 0 0 1-1-1V2z\"}}]})(props);\n};\nexport function BsBarChartLineFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 2a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v12h.5a.5.5 0 0 1 0 1H.5a.5.5 0 0 1 0-1H1v-3a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v3h1V7a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v7h1V2z\"}}]})(props);\n};\nexport function BsBarChartLine (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 2a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v12h.5a.5.5 0 0 1 0 1H.5a.5.5 0 0 1 0-1H1v-3a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v3h1V7a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v7h1V2zm1 12h2V2h-2v12zm-3 0V7H7v7h2zm-5 0v-3H2v3h2z\"}}]})(props);\n};\nexport function BsBarChartSteps (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 0a.5.5 0 0 1 .5.5v15a.5.5 0 0 1-1 0V.5A.5.5 0 0 1 .5 0zM2 1.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-4a.5.5 0 0 1-.5-.5v-1zm2 4a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-7a.5.5 0 0 1-.5-.5v-1zm2 4a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-6a.5.5 0 0 1-.5-.5v-1zm2 4a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-7a.5.5 0 0 1-.5-.5v-1z\"}}]})(props);\n};\nexport function BsBarChart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 11H2v3h2v-3zm5-4H7v7h2V7zm5-5v12h-2V2h2zm-2-1a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1h-2zM6 7a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v7a1 1 0 0 1-1 1H7a1 1 0 0 1-1-1V7zm-5 4a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1v-3z\"}}]})(props);\n};\nexport function BsBasketFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.071 1.243a.5.5 0 0 1 .858.514L3.383 6h9.234L10.07 1.757a.5.5 0 1 1 .858-.514L13.783 6H15.5a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5H15v5a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V9H.5a.5.5 0 0 1-.5-.5v-2A.5.5 0 0 1 .5 6h1.717L5.07 1.243zM3.5 10.5a.5.5 0 1 0-1 0v3a.5.5 0 0 0 1 0v-3zm2.5 0a.5.5 0 1 0-1 0v3a.5.5 0 0 0 1 0v-3zm2.5 0a.5.5 0 1 0-1 0v3a.5.5 0 0 0 1 0v-3zm2.5 0a.5.5 0 1 0-1 0v3a.5.5 0 0 0 1 0v-3zm2.5 0a.5.5 0 1 0-1 0v3a.5.5 0 0 0 1 0v-3z\"}}]})(props);\n};\nexport function BsBasket (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.757 1.071a.5.5 0 0 1 .172.686L3.383 6h9.234L10.07 1.757a.5.5 0 1 1 .858-.514L13.783 6H15a1 1 0 0 1 1 1v1a1 1 0 0 1-1 1v4.5a2.5 2.5 0 0 1-2.5 2.5h-9A2.5 2.5 0 0 1 1 13.5V9a1 1 0 0 1-1-1V7a1 1 0 0 1 1-1h1.217L5.07 1.243a.5.5 0 0 1 .686-.172zM2 9v4.5A1.5 1.5 0 0 0 3.5 15h9a1.5 1.5 0 0 0 1.5-1.5V9H2zM1 7v1h14V7H1zm3 3a.5.5 0 0 1 .5.5v3a.5.5 0 0 1-1 0v-3A.5.5 0 0 1 4 10zm2 0a.5.5 0 0 1 .5.5v3a.5.5 0 0 1-1 0v-3A.5.5 0 0 1 6 10zm2 0a.5.5 0 0 1 .5.5v3a.5.5 0 0 1-1 0v-3A.5.5 0 0 1 8 10zm2 0a.5.5 0 0 1 .5.5v3a.5.5 0 0 1-1 0v-3a.5.5 0 0 1 .5-.5zm2 0a.5.5 0 0 1 .5.5v3a.5.5 0 0 1-1 0v-3a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsBasket2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.929 1.757a.5.5 0 1 0-.858-.514L2.217 6H.5a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h.623l1.844 6.456A.75.75 0 0 0 3.69 15h8.622a.75.75 0 0 0 .722-.544L14.877 8h.623a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1.717L10.93 1.243a.5.5 0 1 0-.858.514L12.617 6H3.383L5.93 1.757zM4 10a1 1 0 0 1 2 0v2a1 1 0 1 1-2 0v-2zm3 0a1 1 0 0 1 2 0v2a1 1 0 1 1-2 0v-2zm4-1a1 1 0 0 1 1 1v2a1 1 0 1 1-2 0v-2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsBasket2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 10a1 1 0 0 1 2 0v2a1 1 0 0 1-2 0v-2zm3 0a1 1 0 0 1 2 0v2a1 1 0 0 1-2 0v-2zm3 0a1 1 0 1 1 2 0v2a1 1 0 0 1-2 0v-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.757 1.071a.5.5 0 0 1 .172.686L3.383 6h9.234L10.07 1.757a.5.5 0 1 1 .858-.514L13.783 6H15.5a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-.623l-1.844 6.456a.75.75 0 0 1-.722.544H3.69a.75.75 0 0 1-.722-.544L1.123 8H.5a.5.5 0 0 1-.5-.5v-1A.5.5 0 0 1 .5 6h1.717L5.07 1.243a.5.5 0 0 1 .686-.172zM2.163 8l1.714 6h8.246l1.714-6H2.163z\"}}]})(props);\n};\nexport function BsBasket3Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.757 1.071a.5.5 0 0 1 .172.686L3.383 6h9.234L10.07 1.757a.5.5 0 1 1 .858-.514L13.783 6H15.5a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5H.5a.5.5 0 0 1-.5-.5v-1A.5.5 0 0 1 .5 6h1.717L5.07 1.243a.5.5 0 0 1 .686-.172zM2.468 15.426.943 9h14.114l-1.525 6.426a.75.75 0 0 1-.729.574H3.197a.75.75 0 0 1-.73-.574z\"}}]})(props);\n};\nexport function BsBasket3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.757 1.071a.5.5 0 0 1 .172.686L3.383 6h9.234L10.07 1.757a.5.5 0 1 1 .858-.514L13.783 6H15.5a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5H.5a.5.5 0 0 1-.5-.5v-1A.5.5 0 0 1 .5 6h1.717L5.07 1.243a.5.5 0 0 1 .686-.172zM3.394 15l-1.48-6h-.97l1.525 6.426a.75.75 0 0 0 .729.574h9.606a.75.75 0 0 0 .73-.574L15.056 9h-.972l-1.479 6h-9.21z\"}}]})(props);\n};\nexport function BsBatteryCharging (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.585 2.568a.5.5 0 0 1 .226.58L8.677 6.832h1.99a.5.5 0 0 1 .364.843l-5.334 5.667a.5.5 0 0 1-.842-.49L5.99 9.167H4a.5.5 0 0 1-.364-.843l5.333-5.667a.5.5 0 0 1 .616-.09z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 4h4.332l-.94 1H2a1 1 0 0 0-1 1v4a1 1 0 0 0 1 1h2.38l-.308 1H2a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 6h2.45L2.908 7.639A1.5 1.5 0 0 0 3.313 10H2V6zm8.595-2-.308 1H12a1 1 0 0 1 1 1v4a1 1 0 0 1-1 1H9.276l-.942 1H12a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2h-1.405z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 10h-1.783l1.542-1.639c.097-.103.178-.218.241-.34V10zm0-3.354V6h-.646a1.5 1.5 0 0 1 .646.646zM16 8a1.5 1.5 0 0 1-1.5 1.5v-3A1.5 1.5 0 0 1 16 8z\"}}]})(props);\n};\nexport function BsBatteryFull (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 6h10v4H2V6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 4a2 2 0 0 0-2 2v4a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2H2zm10 1a1 1 0 0 1 1 1v4a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V6a1 1 0 0 1 1-1h10zm4 3a1.5 1.5 0 0 1-1.5 1.5v-3A1.5 1.5 0 0 1 16 8z\"}}]})(props);\n};\nexport function BsBatteryHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 6h5v4H2V6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 4a2 2 0 0 0-2 2v4a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2H2zm10 1a1 1 0 0 1 1 1v4a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V6a1 1 0 0 1 1-1h10zm4 3a1.5 1.5 0 0 1-1.5 1.5v-3A1.5 1.5 0 0 1 16 8z\"}}]})(props);\n};\nexport function BsBattery (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 6a2 2 0 0 1 2-2h10a2 2 0 0 1 2 2v4a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V6zm2-1a1 1 0 0 0-1 1v4a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V6a1 1 0 0 0-1-1H2zm14 3a1.5 1.5 0 0 1-1.5 1.5v-3A1.5 1.5 0 0 1 16 8z\"}}]})(props);\n};\nexport function BsBehance (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.654 3c.461 0 .887.035 1.278.14.39.07.711.216.996.391.286.176.497.426.641.747.14.32.216.711.216 1.137 0 .496-.106.922-.356 1.242-.215.32-.566.606-.997.817.606.176 1.067.496 1.348.922.281.426.461.957.461 1.563 0 .496-.105.922-.285 1.278a2.317 2.317 0 0 1-.782.887c-.32.215-.711.39-1.137.496a5.329 5.329 0 0 1-1.278.176L0 12.803V3h4.654zm-.285 3.978c.39 0 .71-.105.957-.285.246-.18.355-.497.355-.887 0-.216-.035-.426-.105-.567a.981.981 0 0 0-.32-.355 1.84 1.84 0 0 0-.461-.176c-.176-.035-.356-.035-.567-.035H2.17v2.31c0-.005 2.2-.005 2.2-.005zm.105 4.193c.215 0 .426-.035.606-.07.176-.035.356-.106.496-.216s.25-.215.356-.39c.07-.176.14-.391.14-.641 0-.496-.14-.852-.426-1.102-.285-.215-.676-.32-1.137-.32H2.17v2.734h2.305v.005zm6.858-.035c.286.285.711.426 1.278.426.39 0 .746-.106 1.032-.286.285-.215.46-.426.53-.64h1.74c-.286.851-.712 1.457-1.278 1.848-.566.355-1.243.566-2.06.566a4.135 4.135 0 0 1-1.527-.285 2.827 2.827 0 0 1-1.137-.782 2.851 2.851 0 0 1-.712-1.172c-.175-.461-.25-.957-.25-1.528 0-.531.07-1.032.25-1.493.18-.46.426-.852.747-1.207.32-.32.711-.606 1.137-.782a4.018 4.018 0 0 1 1.493-.285c.606 0 1.137.105 1.598.355.46.25.817.532 1.102.958.285.39.496.851.641 1.348.07.496.105.996.07 1.563h-5.15c0 .58.21 1.11.496 1.396zm2.24-3.732c-.25-.25-.642-.391-1.103-.391-.32 0-.566.07-.781.176-.215.105-.356.25-.496.39a.957.957 0 0 0-.25.497c-.036.175-.07.32-.07.46h3.196c-.07-.526-.25-.882-.497-1.132zm-3.127-3.728h3.978v.957h-3.978v-.957z\"}}]})(props);\n};\nexport function BsBellFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16a2 2 0 0 0 2-2H6a2 2 0 0 0 2 2zm.995-14.901a1 1 0 1 0-1.99 0A5.002 5.002 0 0 0 3 6c0 1.098-.5 6-2 7h14c-1.5-1-2-5.902-2-7 0-2.42-1.72-4.44-4.005-4.901z\"}}]})(props);\n};\nexport function BsBellSlashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.164 14H15c-1.5-1-2-5.902-2-7 0-.264-.02-.523-.06-.776L5.164 14zm6.288-10.617A4.988 4.988 0 0 0 8.995 2.1a1 1 0 1 0-1.99 0A5.002 5.002 0 0 0 3 7c0 .898-.335 4.342-1.278 6.113l9.73-9.73zM10 15a2 2 0 1 1-4 0h4zm-9.375.625a.53.53 0 0 0 .75.75l14.75-14.75a.53.53 0 0 0-.75-.75L.625 15.625z\"}}]})(props);\n};\nexport function BsBellSlash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.164 14H15c-.299-.199-.557-.553-.78-1-.9-1.8-1.22-5.12-1.22-6 0-.264-.02-.523-.06-.776l-.938.938c.02.708.157 2.154.457 3.58.161.767.377 1.566.663 2.258H6.164l-1 1zm5.581-9.91a3.986 3.986 0 0 0-1.948-1.01L8 2.917l-.797.161A4.002 4.002 0 0 0 4 7c0 .628-.134 2.197-.459 3.742-.05.238-.105.479-.166.718l-1.653 1.653c.02-.037.04-.074.059-.113C2.679 11.2 3 7.88 3 7c0-2.42 1.72-4.44 4.005-4.901a1 1 0 1 1 1.99 0c.942.19 1.788.645 2.457 1.284l-.707.707zM10 15a2 2 0 1 1-4 0h4zm-9.375.625a.53.53 0 0 0 .75.75l14.75-14.75a.53.53 0 0 0-.75-.75L.625 15.625z\"}}]})(props);\n};\nexport function BsBell (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16a2 2 0 0 0 2-2H6a2 2 0 0 0 2 2zM8 1.918l-.797.161A4.002 4.002 0 0 0 4 6c0 .628-.134 2.197-.459 3.742-.16.767-.376 1.566-.663 2.258h10.244c-.287-.692-.502-1.49-.663-2.258C12.134 8.197 12 6.628 12 6a4.002 4.002 0 0 0-3.203-3.92L8 1.917zM14.22 12c.223.447.481.801.78 1H1c.299-.199.557-.553.78-1C2.68 10.2 3 6.88 3 6c0-2.42 1.72-4.44 4.005-4.901a1 1 0 1 1 1.99 0A5.002 5.002 0 0 1 13 6c0 .88.32 4.2 1.22 6z\"}}]})(props);\n};\nexport function BsBezier (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M0 10.5A1.5 1.5 0 0 1 1.5 9h1A1.5 1.5 0 0 1 4 10.5v1A1.5 1.5 0 0 1 2.5 13h-1A1.5 1.5 0 0 1 0 11.5v-1zm1.5-.5a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zm10.5.5A1.5 1.5 0 0 1 13.5 9h1a1.5 1.5 0 0 1 1.5 1.5v1a1.5 1.5 0 0 1-1.5 1.5h-1a1.5 1.5 0 0 1-1.5-1.5v-1zm1.5-.5a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zM6 4.5A1.5 1.5 0 0 1 7.5 3h1A1.5 1.5 0 0 1 10 4.5v1A1.5 1.5 0 0 1 8.5 7h-1A1.5 1.5 0 0 1 6 5.5v-1zM7.5 4a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 4.5H1.866a1 1 0 1 0 0 1h2.668A6.517 6.517 0 0 0 1.814 9H2.5c.123 0 .244.015.358.043a5.517 5.517 0 0 1 3.185-3.185A1.503 1.503 0 0 1 6 5.5v-1zm3.957 1.358A1.5 1.5 0 0 0 10 5.5v-1h4.134a1 1 0 1 1 0 1h-2.668a6.517 6.517 0 0 1 2.72 3.5H13.5c-.123 0-.243.015-.358.043a5.517 5.517 0 0 0-3.185-3.185z\"}}]})(props);\n};\nexport function BsBezier2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 2.5A1.5 1.5 0 0 1 2.5 1h1A1.5 1.5 0 0 1 5 2.5h4.134a1 1 0 1 1 0 1h-2.01c.18.18.34.381.484.605.638.992.892 2.354.892 3.895 0 1.993.257 3.092.713 3.7.356.476.895.721 1.787.784A1.5 1.5 0 0 1 12.5 11h1a1.5 1.5 0 0 1 1.5 1.5v1a1.5 1.5 0 0 1-1.5 1.5h-1a1.5 1.5 0 0 1-1.5-1.5H6.866a1 1 0 1 1 0-1h1.711a2.839 2.839 0 0 1-.165-.2C7.743 11.407 7.5 10.007 7.5 8c0-1.46-.246-2.597-.733-3.355-.39-.605-.952-1-1.767-1.112A1.5 1.5 0 0 1 3.5 5h-1A1.5 1.5 0 0 1 1 3.5v-1zM2.5 2a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zm10 10a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1z\"}}]})(props);\n};\nexport function BsBicycle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4.5a.5.5 0 0 1 .5-.5H6a.5.5 0 0 1 0 1v.5h4.14l.386-1.158A.5.5 0 0 1 11 4h1a.5.5 0 0 1 0 1h-.64l-.311.935.807 1.29a3 3 0 1 1-.848.53l-.508-.812-2.076 3.322A.5.5 0 0 1 8 10.5H5.959a3 3 0 1 1-1.815-3.274L5 5.856V5h-.5a.5.5 0 0 1-.5-.5zm1.5 2.443-.508.814c.5.444.85 1.054.967 1.743h1.139L5.5 6.943zM8 9.057 9.598 6.5H6.402L8 9.057zM4.937 9.5a1.997 1.997 0 0 0-.487-.877l-.548.877h1.035zM3.603 8.092A2 2 0 1 0 4.937 10.5H3a.5.5 0 0 1-.424-.765l1.027-1.643zm7.947.53a2 2 0 1 0 .848-.53l1.026 1.643a.5.5 0 1 1-.848.53L11.55 8.623z\"}}]})(props);\n};\nexport function BsBinocularsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 1A1.5 1.5 0 0 0 3 2.5V3h4v-.5A1.5 1.5 0 0 0 5.5 1h-1zM7 4v1h2V4h4v.882a.5.5 0 0 0 .276.447l.895.447A1.5 1.5 0 0 1 15 7.118V13H9v-1.5a.5.5 0 0 1 .146-.354l.854-.853V9.5a.5.5 0 0 0-.5-.5h-3a.5.5 0 0 0-.5.5v.793l.854.853A.5.5 0 0 1 7 11.5V13H1V7.118a1.5 1.5 0 0 1 .83-1.342l.894-.447A.5.5 0 0 0 3 4.882V4h4zM1 14v.5A1.5 1.5 0 0 0 2.5 16h3A1.5 1.5 0 0 0 7 14.5V14H1zm8 0v.5a1.5 1.5 0 0 0 1.5 1.5h3a1.5 1.5 0 0 0 1.5-1.5V14H9zm4-11H9v-.5A1.5 1.5 0 0 1 10.5 1h1A1.5 1.5 0 0 1 13 2.5V3z\"}}]})(props);\n};\nexport function BsBinoculars (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 2.5A1.5 1.5 0 0 1 4.5 1h1A1.5 1.5 0 0 1 7 2.5V5h2V2.5A1.5 1.5 0 0 1 10.5 1h1A1.5 1.5 0 0 1 13 2.5v2.382a.5.5 0 0 0 .276.447l.895.447A1.5 1.5 0 0 1 15 7.118V14.5a1.5 1.5 0 0 1-1.5 1.5h-3A1.5 1.5 0 0 1 9 14.5v-3a.5.5 0 0 1 .146-.354l.854-.853V9.5a.5.5 0 0 0-.5-.5h-3a.5.5 0 0 0-.5.5v.793l.854.853A.5.5 0 0 1 7 11.5v3A1.5 1.5 0 0 1 5.5 16h-3A1.5 1.5 0 0 1 1 14.5V7.118a1.5 1.5 0 0 1 .83-1.342l.894-.447A.5.5 0 0 0 3 4.882V2.5zM4.5 2a.5.5 0 0 0-.5.5V3h2v-.5a.5.5 0 0 0-.5-.5h-1zM6 4H4v.882a1.5 1.5 0 0 1-.83 1.342l-.894.447A.5.5 0 0 0 2 7.118V13h4v-1.293l-.854-.853A.5.5 0 0 1 5 10.5v-1A1.5 1.5 0 0 1 6.5 8h3A1.5 1.5 0 0 1 11 9.5v1a.5.5 0 0 1-.146.354l-.854.853V13h4V7.118a.5.5 0 0 0-.276-.447l-.895-.447A1.5 1.5 0 0 1 12 4.882V4h-2v1.5a.5.5 0 0 1-.5.5h-3a.5.5 0 0 1-.5-.5V4zm4-1h2v-.5a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5V3zm4 11h-4v.5a.5.5 0 0 0 .5.5h3a.5.5 0 0 0 .5-.5V14zm-8 0H2v.5a.5.5 0 0 0 .5.5h3a.5.5 0 0 0 .5-.5V14z\"}}]})(props);\n};\nexport function BsBlockquoteLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 3a.5.5 0 0 0 0 1h11a.5.5 0 0 0 0-1h-11zm5 3a.5.5 0 0 0 0 1h6a.5.5 0 0 0 0-1h-6zm0 3a.5.5 0 0 0 0 1h6a.5.5 0 0 0 0-1h-6zm-5 3a.5.5 0 0 0 0 1h11a.5.5 0 0 0 0-1h-11zm.79-5.373c.112-.078.26-.17.444-.275L3.524 6c-.122.074-.272.17-.452.287-.18.117-.35.26-.51.428a2.425 2.425 0 0 0-.398.562c-.11.207-.164.438-.164.692 0 .36.072.65.217.873.144.219.385.328.72.328.215 0 .383-.07.504-.211a.697.697 0 0 0 .188-.463c0-.23-.07-.404-.211-.521-.137-.121-.326-.182-.568-.182h-.282c.024-.203.065-.37.123-.498a1.38 1.38 0 0 1 .252-.37 1.94 1.94 0 0 1 .346-.298zm2.167 0c.113-.078.262-.17.445-.275L5.692 6c-.122.074-.272.17-.452.287-.18.117-.35.26-.51.428a2.425 2.425 0 0 0-.398.562c-.11.207-.164.438-.164.692 0 .36.072.65.217.873.144.219.385.328.72.328.215 0 .383-.07.504-.211a.697.697 0 0 0 .188-.463c0-.23-.07-.404-.211-.521-.137-.121-.326-.182-.568-.182h-.282a1.75 1.75 0 0 1 .118-.492c.058-.13.144-.254.257-.375a1.94 1.94 0 0 1 .346-.3z\"}}]})(props);\n};\nexport function BsBlockquoteRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 3a.5.5 0 0 0 0 1h11a.5.5 0 0 0 0-1h-11zm0 3a.5.5 0 0 0 0 1h6a.5.5 0 0 0 0-1h-6zm0 3a.5.5 0 0 0 0 1h6a.5.5 0 0 0 0-1h-6zm0 3a.5.5 0 0 0 0 1h11a.5.5 0 0 0 0-1h-11zm10.113-5.373a6.59 6.59 0 0 0-.445-.275l.21-.352c.122.074.272.17.452.287.18.117.35.26.51.428.156.164.289.351.398.562.11.207.164.438.164.692 0 .36-.072.65-.216.873-.145.219-.385.328-.721.328-.215 0-.383-.07-.504-.211a.697.697 0 0 1-.188-.463c0-.23.07-.404.211-.521.137-.121.326-.182.569-.182h.281a1.686 1.686 0 0 0-.123-.498 1.379 1.379 0 0 0-.252-.37 1.94 1.94 0 0 0-.346-.298zm-2.168 0A6.59 6.59 0 0 0 10 6.352L10.21 6c.122.074.272.17.452.287.18.117.35.26.51.428.156.164.289.351.398.562.11.207.164.438.164.692 0 .36-.072.65-.216.873-.145.219-.385.328-.721.328-.215 0-.383-.07-.504-.211a.697.697 0 0 1-.188-.463c0-.23.07-.404.211-.521.137-.121.327-.182.569-.182h.281a1.749 1.749 0 0 0-.117-.492 1.402 1.402 0 0 0-.258-.375 1.94 1.94 0 0 0-.346-.3z\"}}]})(props);\n};\nexport function BsBookFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1.783C7.015.936 5.587.81 4.287.94c-1.514.153-3.042.672-3.994 1.105A.5.5 0 0 0 0 2.5v11a.5.5 0 0 0 .707.455c.882-.4 2.303-.881 3.68-1.02 1.409-.142 2.59.087 3.223.877a.5.5 0 0 0 .78 0c.633-.79 1.814-1.019 3.222-.877 1.378.139 2.8.62 3.681 1.02A.5.5 0 0 0 16 13.5v-11a.5.5 0 0 0-.293-.455c-.952-.433-2.48-.952-3.994-1.105C10.413.809 8.985.936 8 1.783z\"}}]})(props);\n};\nexport function BsBookHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 2.687c.654-.689 1.782-.886 3.112-.752 1.234.124 2.503.523 3.388.893v9.923c-.918-.35-2.107-.692-3.287-.81-1.094-.111-2.278-.039-3.213.492V2.687zM8 1.783C7.015.936 5.587.81 4.287.94c-1.514.153-3.042.672-3.994 1.105A.5.5 0 0 0 0 2.5v11a.5.5 0 0 0 .707.455c.882-.4 2.303-.881 3.68-1.02 1.409-.142 2.59.087 3.223.877a.5.5 0 0 0 .78 0c.633-.79 1.814-1.019 3.222-.877 1.378.139 2.8.62 3.681 1.02A.5.5 0 0 0 16 13.5v-11a.5.5 0 0 0-.293-.455c-.952-.433-2.48-.952-3.994-1.105C10.413.809 8.985.936 8 1.783z\"}}]})(props);\n};\nexport function BsBook (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 2.828c.885-.37 2.154-.769 3.388-.893 1.33-.134 2.458.063 3.112.752v9.746c-.935-.53-2.12-.603-3.213-.493-1.18.12-2.37.461-3.287.811V2.828zm7.5-.141c.654-.689 1.782-.886 3.112-.752 1.234.124 2.503.523 3.388.893v9.923c-.918-.35-2.107-.692-3.287-.81-1.094-.111-2.278-.039-3.213.492V2.687zM8 1.783C7.015.936 5.587.81 4.287.94c-1.514.153-3.042.672-3.994 1.105A.5.5 0 0 0 0 2.5v11a.5.5 0 0 0 .707.455c.882-.4 2.303-.881 3.68-1.02 1.409-.142 2.59.087 3.223.877a.5.5 0 0 0 .78 0c.633-.79 1.814-1.019 3.222-.877 1.378.139 2.8.62 3.681 1.02A.5.5 0 0 0 16 13.5v-11a.5.5 0 0 0-.293-.455c-.952-.433-2.48-.952-3.994-1.105C10.413.809 8.985.936 8 1.783z\"}}]})(props);\n};\nexport function BsBookmarkCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 15.5V2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.74.439L8 13.069l-5.26 2.87A.5.5 0 0 1 2 15.5zm8.854-9.646a.5.5 0 0 0-.708-.708L7.5 7.793 6.354 6.646a.5.5 0 1 0-.708.708l1.5 1.5a.5.5 0 0 0 .708 0l3-3z\"}}]})(props);\n};\nexport function BsBookmarkCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.854 5.146a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7.5 7.793l2.646-2.647a.5.5 0 0 1 .708 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.777.416L8 13.101l-5.223 2.815A.5.5 0 0 1 2 15.5V2zm2-1a1 1 0 0 0-1 1v12.566l4.723-2.482a.5.5 0 0 1 .554 0L13 14.566V2a1 1 0 0 0-1-1H4z\"}}]})(props);\n};\nexport function BsBookmarkDashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 15.5V2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.74.439L8 13.069l-5.26 2.87A.5.5 0 0 1 2 15.5zM6 6a.5.5 0 0 0 0 1h4a.5.5 0 0 0 0-1H6z\"}}]})(props);\n};\nexport function BsBookmarkDash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5.5 6.5A.5.5 0 0 1 6 6h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.777.416L8 13.101l-5.223 2.815A.5.5 0 0 1 2 15.5V2zm2-1a1 1 0 0 0-1 1v12.566l4.723-2.482a.5.5 0 0 1 .554 0L13 14.566V2a1 1 0 0 0-1-1H4z\"}}]})(props);\n};\nexport function BsBookmarkFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2v13.5a.5.5 0 0 0 .74.439L8 13.069l5.26 2.87A.5.5 0 0 0 14 15.5V2a2 2 0 0 0-2-2H4a2 2 0 0 0-2 2z\"}}]})(props);\n};\nexport function BsBookmarkHeartFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 15.5a.5.5 0 0 0 .74.439L8 13.069l5.26 2.87A.5.5 0 0 0 14 15.5V2a2 2 0 0 0-2-2H4a2 2 0 0 0-2 2v13.5zM8 4.41c1.387-1.425 4.854 1.07 0 4.277C3.146 5.48 6.613 2.986 8 4.412z\"}}]})(props);\n};\nexport function BsBookmarkHeart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 4.41c1.387-1.425 4.854 1.07 0 4.277C3.146 5.48 6.613 2.986 8 4.412z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.777.416L8 13.101l-5.223 2.815A.5.5 0 0 1 2 15.5V2zm2-1a1 1 0 0 0-1 1v12.566l4.723-2.482a.5.5 0 0 1 .554 0L13 14.566V2a1 1 0 0 0-1-1H4z\"}}]})(props);\n};\nexport function BsBookmarkPlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 15.5V2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.74.439L8 13.069l-5.26 2.87A.5.5 0 0 1 2 15.5zm6.5-11a.5.5 0 0 0-1 0V6H6a.5.5 0 0 0 0 1h1.5v1.5a.5.5 0 0 0 1 0V7H10a.5.5 0 0 0 0-1H8.5V4.5z\"}}]})(props);\n};\nexport function BsBookmarkPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.777.416L8 13.101l-5.223 2.815A.5.5 0 0 1 2 15.5V2zm2-1a1 1 0 0 0-1 1v12.566l4.723-2.482a.5.5 0 0 1 .554 0L13 14.566V2a1 1 0 0 0-1-1H4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4a.5.5 0 0 1 .5.5V6H10a.5.5 0 0 1 0 1H8.5v1.5a.5.5 0 0 1-1 0V7H6a.5.5 0 0 1 0-1h1.5V4.5A.5.5 0 0 1 8 4z\"}}]})(props);\n};\nexport function BsBookmarkStarFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 15.5V2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.74.439L8 13.069l-5.26 2.87A.5.5 0 0 1 2 15.5zM8.16 4.1a.178.178 0 0 0-.32 0l-.634 1.285a.178.178 0 0 1-.134.098l-1.42.206a.178.178 0 0 0-.098.303L6.58 6.993c.042.041.061.1.051.158L6.39 8.565a.178.178 0 0 0 .258.187l1.27-.668a.178.178 0 0 1 .165 0l1.27.668a.178.178 0 0 0 .257-.187L9.368 7.15a.178.178 0 0 1 .05-.158l1.028-1.001a.178.178 0 0 0-.098-.303l-1.42-.206a.178.178 0 0 1-.134-.098L8.16 4.1z\"}}]})(props);\n};\nexport function BsBookmarkStar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.84 4.1a.178.178 0 0 1 .32 0l.634 1.285a.178.178 0 0 0 .134.098l1.42.206c.145.021.204.2.098.303L9.42 6.993a.178.178 0 0 0-.051.158l.242 1.414a.178.178 0 0 1-.258.187l-1.27-.668a.178.178 0 0 0-.165 0l-1.27.668a.178.178 0 0 1-.257-.187l.242-1.414a.178.178 0 0 0-.05-.158l-1.03-1.001a.178.178 0 0 1 .098-.303l1.42-.206a.178.178 0 0 0 .134-.098L7.84 4.1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.777.416L8 13.101l-5.223 2.815A.5.5 0 0 1 2 15.5V2zm2-1a1 1 0 0 0-1 1v12.566l4.723-2.482a.5.5 0 0 1 .554 0L13 14.566V2a1 1 0 0 0-1-1H4z\"}}]})(props);\n};\nexport function BsBookmarkXFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 15.5V2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.74.439L8 13.069l-5.26 2.87A.5.5 0 0 1 2 15.5zM6.854 5.146a.5.5 0 1 0-.708.708L7.293 7 6.146 8.146a.5.5 0 1 0 .708.708L8 7.707l1.146 1.147a.5.5 0 1 0 .708-.708L8.707 7l1.147-1.146a.5.5 0 0 0-.708-.708L8 6.293 6.854 5.146z\"}}]})(props);\n};\nexport function BsBookmarkX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6.146 5.146a.5.5 0 0 1 .708 0L8 6.293l1.146-1.147a.5.5 0 1 1 .708.708L8.707 7l1.147 1.146a.5.5 0 0 1-.708.708L8 7.707 6.854 8.854a.5.5 0 1 1-.708-.708L7.293 7 6.146 5.854a.5.5 0 0 1 0-.708z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.777.416L8 13.101l-5.223 2.815A.5.5 0 0 1 2 15.5V2zm2-1a1 1 0 0 0-1 1v12.566l4.723-2.482a.5.5 0 0 1 .554 0L13 14.566V2a1 1 0 0 0-1-1H4z\"}}]})(props);\n};\nexport function BsBookmark (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v13.5a.5.5 0 0 1-.777.416L8 13.101l-5.223 2.815A.5.5 0 0 1 2 15.5V2zm2-1a1 1 0 0 0-1 1v12.566l4.723-2.482a.5.5 0 0 1 .554 0L13 14.566V2a1 1 0 0 0-1-1H4z\"}}]})(props);\n};\nexport function BsBookmarksFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 4a2 2 0 0 1 2-2h6a2 2 0 0 1 2 2v11.5a.5.5 0 0 1-.777.416L7 13.101l-4.223 2.815A.5.5 0 0 1 2 15.5V4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.268 1A2 2 0 0 1 6 0h6a2 2 0 0 1 2 2v11.5a.5.5 0 0 1-.777.416L13 13.768V2a1 1 0 0 0-1-1H4.268z\"}}]})(props);\n};\nexport function BsBookmarks (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 4a2 2 0 0 1 2-2h6a2 2 0 0 1 2 2v11.5a.5.5 0 0 1-.777.416L7 13.101l-4.223 2.815A.5.5 0 0 1 2 15.5V4zm2-1a1 1 0 0 0-1 1v10.566l3.723-2.482a.5.5 0 0 1 .554 0L11 14.566V4a1 1 0 0 0-1-1H4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.268 1H12a1 1 0 0 1 1 1v11.768l.223.148A.5.5 0 0 0 14 13.5V2a2 2 0 0 0-2-2H6a2 2 0 0 0-1.732 1z\"}}]})(props);\n};\nexport function BsBookshelf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 0a.5.5 0 0 1 .5.5V2h10V.5a.5.5 0 0 1 1 0v15a.5.5 0 0 1-1 0V15H3v.5a.5.5 0 0 1-1 0V.5a.5.5 0 0 1 .5-.5zM3 14h10v-3H3v3zm0-4h10V7H3v3zm0-4h10V3H3v3z\"}}]})(props);\n};\nexport function BsBootstrapFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.375 7.125V4.658h1.78c.973 0 1.542.457 1.542 1.237 0 .802-.604 1.23-1.764 1.23H6.375zm0 3.762h1.898c1.184 0 1.81-.48 1.81-1.377 0-.885-.65-1.348-1.886-1.348H6.375v2.725z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.002 0a4 4 0 0 0-4 4v8a4 4 0 0 0 4 4h8a4 4 0 0 0 4-4V4a4 4 0 0 0-4-4h-8zm1.06 12V3.545h3.399c1.587 0 2.543.809 2.543 2.11 0 .884-.65 1.675-1.483 1.816v.1c1.143.117 1.904.931 1.904 2.033 0 1.488-1.084 2.396-2.888 2.396H5.062z\"}}]})(props);\n};\nexport function BsBootstrapReboot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.161 8a6.84 6.84 0 1 0 6.842-6.84.58.58 0 1 1 0-1.16 8 8 0 1 1-6.556 3.412l-.663-.577a.58.58 0 0 1 .227-.997l2.52-.69a.58.58 0 0 1 .728.633l-.332 2.592a.58.58 0 0 1-.956.364l-.643-.56A6.812 6.812 0 0 0 1.16 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.641 11.671V8.843h1.57l1.498 2.828h1.314L9.377 8.665c.897-.3 1.427-1.106 1.427-2.1 0-1.37-.943-2.246-2.456-2.246H5.5v7.352h1.141zm0-3.75V5.277h1.57c.881 0 1.416.499 1.416 1.32 0 .84-.504 1.324-1.386 1.324h-1.6z\"}}]})(props);\n};\nexport function BsBootstrap (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.062 12h3.475c1.804 0 2.888-.908 2.888-2.396 0-1.102-.761-1.916-1.904-2.034v-.1c.832-.14 1.482-.93 1.482-1.816 0-1.3-.955-2.11-2.542-2.11H5.062V12zm1.313-4.875V4.658h1.78c.973 0 1.542.457 1.542 1.237 0 .802-.604 1.23-1.764 1.23H6.375zm0 3.762V8.162h1.822c1.236 0 1.887.463 1.887 1.348 0 .896-.627 1.377-1.811 1.377H6.375z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a4 4 0 0 1 4-4h8a4 4 0 0 1 4 4v8a4 4 0 0 1-4 4H4a4 4 0 0 1-4-4V4zm4-3a3 3 0 0 0-3 3v8a3 3 0 0 0 3 3h8a3 3 0 0 0 3-3V4a3 3 0 0 0-3-3H4z\"}}]})(props);\n};\nexport function BsBorderAll (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 0h16v16H0V0zm1 1v6.5h6.5V1H1zm7.5 0v6.5H15V1H8.5zM15 8.5H8.5V15H15V8.5zM7.5 15V8.5H1V15h6.5z\"}}]})(props);\n};\nexport function BsBorderBottom (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.969 0H0v.969h.5V1h.469V.969H1V.5H.969V0zm.937 1h.938V0h-.938v1zm1.875 0h.938V0H3.78v1zm1.875 0h.938V0h-.938v1zM7.531.969V1h.938V.969H8.5V.5h-.031V0H7.53v.5H7.5v.469h.031zM9.406 1h.938V0h-.938v1zm1.875 0h.938V0h-.938v1zm1.875 0h.938V0h-.938v1zm1.875 0h.469V.969h.5V0h-.969v.5H15v.469h.031V1zM1 2.844v-.938H0v.938h1zm6.5-.938v.938h1v-.938h-1zm7.5 0v.938h1v-.938h-1zM1 4.719V3.78H0v.938h1zm6.5-.938v.938h1V3.78h-1zm7.5 0v.938h1V3.78h-1zM1 6.594v-.938H0v.938h1zm6.5-.938v.938h1v-.938h-1zm7.5 0v.938h1v-.938h-1zM.5 8.5h.469v-.031H1V7.53H.969V7.5H.5v.031H0v.938h.5V8.5zm1.406 0h.938v-1h-.938v1zm1.875 0h.938v-1H3.78v1zm1.875 0h.938v-1h-.938v1zm2.813 0v-.031H8.5V7.53h-.031V7.5H7.53v.031H7.5v.938h.031V8.5h.938zm.937 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875 0h.469v-.031h.5V7.53h-.5V7.5h-.469v.031H15v.938h.031V8.5zM0 9.406v.938h1v-.938H0zm7.5 0v.938h1v-.938h-1zm8.5.938v-.938h-1v.938h1zm-16 .937v.938h1v-.938H0zm7.5 0v.938h1v-.938h-1zm8.5.938v-.938h-1v.938h1zm-16 .937v.938h1v-.938H0zm7.5 0v.938h1v-.938h-1zm8.5.938v-.938h-1v.938h1zM0 15h16v1H0v-1z\"}}]})(props);\n};\nexport function BsBorderCenter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.969 0H0v.969h.5V1h.469V.969H1V.5H.969V0zm.937 1h.938V0h-.938v1zm1.875 0h.938V0H3.78v1zm1.875 0h.938V0h-.938v1zM7.531.969V1h.938V.969H8.5V.5h-.031V0H7.53v.5H7.5v.469h.031zM9.406 1h.938V0h-.938v1zm1.875 0h.938V0h-.938v1zm1.875 0h.938V0h-.938v1zm1.875 0h.469V.969h.5V0h-.969v.5H15v.469h.031V1zM1 2.844v-.938H0v.938h1zm6.5-.938v.938h1v-.938h-1zm7.5 0v.938h1v-.938h-1zM1 4.719V3.78H0v.938h1zm6.5-.938v.938h1V3.78h-1zm7.5 0v.938h1V3.78h-1zM1 6.594v-.938H0v.938h1zm6.5-.938v.938h1v-.938h-1zm7.5 0v.938h1v-.938h-1zM0 8.5v-1h16v1H0zm0 .906v.938h1v-.938H0zm7.5 0v.938h1v-.938h-1zm8.5.938v-.938h-1v.938h1zm-16 .937v.938h1v-.938H0zm7.5 0v.938h1v-.938h-1zm8.5.938v-.938h-1v.938h1zm-16 .937v.938h1v-.938H0zm7.5 0v.938h1v-.938h-1zm8.5.938v-.938h-1v.938h1zM0 16h.969v-.5H1v-.469H.969V15H.5v.031H0V16zm1.906 0h.938v-1h-.938v1zm1.875 0h.938v-1H3.78v1zm1.875 0h.938v-1h-.938v1zm1.875-.5v.5h.938v-.5H8.5v-.469h-.031V15H7.53v.031H7.5v.469h.031zm1.875.5h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875-.5v.5H16v-.969h-.5V15h-.469v.031H15v.469h.031z\"}}]})(props);\n};\nexport function BsBorderInner (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.969 0H0v.969h.5V1h.469V.969H1V.5H.969V0zm.937 1h.938V0h-.938v1zm1.875 0h.938V0H3.78v1zm1.875 0h.938V0h-.938v1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 7.5H16v1H8.5V16h-1V8.5H0v-1h7.5V0h1v7.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.406 1h.938V0h-.938v1zm1.875 0h.938V0h-.938v1zm1.875 0h.938V0h-.938v1zm1.875 0h.469V.969h.5V0h-.969v.5H15v.469h.031V1zM1 2.844v-.938H0v.938h1zm14-.938v.938h1v-.938h-1zM1 4.719V3.78H0v.938h1zm14-.938v.938h1V3.78h-1zM1 6.594v-.938H0v.938h1zm14-.938v.938h1v-.938h-1zM0 9.406v.938h1v-.938H0zm16 .938v-.938h-1v.938h1zm-16 .937v.938h1v-.938H0zm16 .938v-.938h-1v.938h1zm-16 .937v.938h1v-.938H0zm16 .938v-.938h-1v.938h1zM0 16h.969v-.5H1v-.469H.969V15H.5v.031H0V16zm1.906 0h.938v-1h-.938v1zm1.875 0h.938v-1H3.78v1zm1.875 0h.938v-1h-.938v1zm3.75 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875-.5v.5H16v-.969h-.5V15h-.469v.031H15v.469h.031z\"}}]})(props);\n};\nexport function BsBorderLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 0v16h1V0H0zm1.906 1h.938V0h-.938v1zm1.875 0h.938V0H3.78v1zm1.875 0h.938V0h-.938v1zM7.531.969V1h.938V.969H8.5V.5h-.031V0H7.53v.5H7.5v.469h.031zM9.406 1h.938V0h-.938v1zm1.875 0h.938V0h-.938v1zm1.875 0h.938V0h-.938v1zm1.875 0h.469V.969h.5V0h-.969v.5H15v.469h.031V1zM7.5 1.906v.938h1v-.938h-1zm7.5 0v.938h1v-.938h-1zM7.5 3.781v.938h1V3.78h-1zm7.5 0v.938h1V3.78h-1zM7.5 5.656v.938h1v-.938h-1zm7.5 0v.938h1v-.938h-1zM1.906 8.5h.938v-1h-.938v1zm1.875 0h.938v-1H3.78v1zm1.875 0h.938v-1h-.938v1zm2.813 0v-.031H8.5V7.53h-.031V7.5H7.53v.031H7.5v.938h.031V8.5h.938zm.937 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875 0h.469v-.031h.5V7.53h-.5V7.5h-.469v.031H15v.938h.031V8.5zM7.5 9.406v.938h1v-.938h-1zm8.5.938v-.938h-1v.938h1zm-8.5.937v.938h1v-.938h-1zm8.5.938v-.938h-1v.938h1zm-8.5.937v.938h1v-.938h-1zm8.5.938v-.938h-1v.938h1zM1.906 16h.938v-1h-.938v1zm1.875 0h.938v-1H3.78v1zm1.875 0h.938v-1h-.938v1zm1.875-.5v.5h.938v-.5H8.5v-.469h-.031V15H7.53v.031H7.5v.469h.031zm1.875.5h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875-.5v.5H16v-.969h-.5V15h-.469v.031H15v.469h.031z\"}}]})(props);\n};\nexport function BsBorderMiddle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.969 0H0v.969h.5V1h.469V.969H1V.5H.969V0zm.937 1h.938V0h-.938v1zm1.875 0h.938V0H3.78v1zm1.875 0h.938V0h-.938v1zM8.5 16h-1V0h1v16zm.906-15h.938V0h-.938v1zm1.875 0h.938V0h-.938v1zm1.875 0h.938V0h-.938v1zm1.875 0h.469V.969h.5V0h-.969v.5H15v.469h.031V1zM1 2.844v-.938H0v.938h1zm14-.938v.938h1v-.938h-1zM1 4.719V3.78H0v.938h1zm14-.938v.938h1V3.78h-1zM1 6.594v-.938H0v.938h1zm14-.938v.938h1v-.938h-1zM.5 8.5h.469v-.031H1V7.53H.969V7.5H.5v.031H0v.938h.5V8.5zm1.406 0h.938v-1h-.938v1zm1.875 0h.938v-1H3.78v1zm1.875 0h.938v-1h-.938v1zm3.75 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875 0h.469v-.031h.5V7.53h-.5V7.5h-.469v.031H15v.938h.031V8.5zM0 9.406v.938h1v-.938H0zm16 .938v-.938h-1v.938h1zm-16 .937v.938h1v-.938H0zm16 .938v-.938h-1v.938h1zm-16 .937v.938h1v-.938H0zm16 .938v-.938h-1v.938h1zM0 16h.969v-.5H1v-.469H.969V15H.5v.031H0V16zm1.906 0h.938v-1h-.938v1zm1.875 0h.938v-1H3.78v1zm1.875 0h.938v-1h-.938v1zm3.75 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875-.5v.5H16v-.969h-.5V15h-.469v.031H15v.469h.031z\"}}]})(props);\n};\nexport function BsBorderOuter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 1.906v.938h1v-.938h-1zm0 1.875v.938h1V3.78h-1zm0 1.875v.938h1v-.938h-1zM1.906 8.5h.938v-1h-.938v1zm1.875 0h.938v-1H3.78v1zm1.875 0h.938v-1h-.938v1zm2.813 0v-.031H8.5V7.53h-.031V7.5H7.53v.031H7.5v.938h.031V8.5h.938zm.937 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zM7.5 9.406v.938h1v-.938h-1zm0 1.875v.938h1v-.938h-1zm0 1.875v.938h1v-.938h-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 0v16h16V0H0zm1 1h14v14H1V1z\"}}]})(props);\n};\nexport function BsBorderRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.969 0H0v.969h.5V1h.469V.969H1V.5H.969V0zm.937 1h.938V0h-.938v1zm1.875 0h.938V0H3.78v1zm1.875 0h.938V0h-.938v1zM7.531.969V1h.938V.969H8.5V.5h-.031V0H7.53v.5H7.5v.469h.031zM9.406 1h.938V0h-.938v1zm1.875 0h.938V0h-.938v1zm1.875 0h.938V0h-.938v1zM16 0h-1v16h1V0zM1 2.844v-.938H0v.938h1zm6.5-.938v.938h1v-.938h-1zM1 4.719V3.78H0v.938h1zm6.5-.938v.938h1V3.78h-1zM1 6.594v-.938H0v.938h1zm6.5-.938v.938h1v-.938h-1zM.5 8.5h.469v-.031H1V7.53H.969V7.5H.5v.031H0v.938h.5V8.5zm1.406 0h.938v-1h-.938v1zm1.875 0h.938v-1H3.78v1zm1.875 0h.938v-1h-.938v1zm2.813 0v-.031H8.5V7.53h-.031V7.5H7.53v.031H7.5v.938h.031V8.5h.938zm.937 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zM0 9.406v.938h1v-.938H0zm7.5 0v.938h1v-.938h-1zM0 11.281v.938h1v-.938H0zm7.5 0v.938h1v-.938h-1zM0 13.156v.938h1v-.938H0zm7.5 0v.938h1v-.938h-1zM0 16h.969v-.5H1v-.469H.969V15H.5v.031H0V16zm1.906 0h.938v-1h-.938v1zm1.875 0h.938v-1H3.78v1zm1.875 0h.938v-1h-.938v1zm1.875-.5v.5h.938v-.5H8.5v-.469h-.031V15H7.53v.031H7.5v.469h.031zm1.875.5h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1z\"}}]})(props);\n};\nexport function BsBorderStyle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 3.5a.5.5 0 0 1 .5-.5h13a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-13a.5.5 0 0 1-.5-.5v-1zm0 4a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-5a.5.5 0 0 1-.5-.5v-1zm0 4a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm8 0a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm-4 0a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm8 0a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm-4-4a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-5a.5.5 0 0 1-.5-.5v-1z\"}}]})(props);\n};\nexport function BsBorderTop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 0v1h16V0H0zm1 2.844v-.938H0v.938h1zm6.5-.938v.938h1v-.938h-1zm7.5 0v.938h1v-.938h-1zM1 4.719V3.78H0v.938h1zm6.5-.938v.938h1V3.78h-1zm7.5 0v.938h1V3.78h-1zM1 6.594v-.938H0v.938h1zm6.5-.938v.938h1v-.938h-1zm7.5 0v.938h1v-.938h-1zM.5 8.5h.469v-.031H1V7.53H.969V7.5H.5v.031H0v.938h.5V8.5zm1.406 0h.938v-1h-.938v1zm1.875 0h.938v-1H3.78v1zm1.875 0h.938v-1h-.938v1zm2.813 0v-.031H8.5V7.53h-.031V7.5H7.53v.031H7.5v.938h.031V8.5h.938zm.937 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875 0h.469v-.031h.5V7.53h-.5V7.5h-.469v.031H15v.938h.031V8.5zM0 9.406v.938h1v-.938H0zm7.5 0v.938h1v-.938h-1zm8.5.938v-.938h-1v.938h1zm-16 .937v.938h1v-.938H0zm7.5 0v.938h1v-.938h-1zm8.5.938v-.938h-1v.938h1zm-16 .937v.938h1v-.938H0zm7.5 0v.938h1v-.938h-1zm8.5.938v-.938h-1v.938h1zM0 16h.969v-.5H1v-.469H.969V15H.5v.031H0V16zm1.906 0h.938v-1h-.938v1zm1.875 0h.938v-1H3.78v1zm1.875 0h.938v-1h-.938v1zm1.875-.5v.5h.938v-.5H8.5v-.469h-.031V15H7.53v.031H7.5v.469h.031zm1.875.5h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875 0h.938v-1h-.938v1zm1.875-.5v.5H16v-.969h-.5V15h-.469v.031H15v.469h.031z\"}}]})(props);\n};\nexport function BsBorderWidth (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 3.5A.5.5 0 0 1 .5 3h15a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5H.5a.5.5 0 0 1-.5-.5v-2zm0 5A.5.5 0 0 1 .5 8h15a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5H.5a.5.5 0 0 1-.5-.5v-1zm0 4a.5.5 0 0 1 .5-.5h15a.5.5 0 0 1 0 1H.5a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsBorder (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 0h.969v.5H1v.469H.969V1H.5V.969H0V0zm2.844 1h-.938V0h.938v1zm1.875 0H3.78V0h.938v1zm1.875 0h-.938V0h.938v1zm.937 0V.969H7.5V.5h.031V0h.938v.5H8.5v.469h-.031V1H7.53zm2.813 0h-.938V0h.938v1zm1.875 0h-.938V0h.938v1zm1.875 0h-.938V0h.938v1zM15.5 1h-.469V.969H15V.5h.031V0H16v.969h-.5V1zM1 1.906v.938H0v-.938h1zm6.5.938v-.938h1v.938h-1zm7.5 0v-.938h1v.938h-1zM1 3.78v.938H0V3.78h1zm6.5.938V3.78h1v.938h-1zm7.5 0V3.78h1v.938h-1zM1 5.656v.938H0v-.938h1zm6.5.938v-.938h1v.938h-1zm7.5 0v-.938h1v.938h-1zM.969 8.5H.5v-.031H0V7.53h.5V7.5h.469v.031H1v.938H.969V8.5zm1.875 0h-.938v-1h.938v1zm1.875 0H3.78v-1h.938v1zm1.875 0h-.938v-1h.938v1zm1.875-.031V8.5H7.53v-.031H7.5V7.53h.031V7.5h.938v.031H8.5v.938h-.031zm1.875.031h-.938v-1h.938v1zm1.875 0h-.938v-1h.938v1zm1.875 0h-.938v-1h.938v1zm1.406 0h-.469v-.031H15V7.53h.031V7.5h.469v.031h.5v.938h-.5V8.5zM0 10.344v-.938h1v.938H0zm7.5 0v-.938h1v.938h-1zm8.5-.938v.938h-1v-.938h1zM0 12.22v-.938h1v.938H0zm7.5 0v-.938h1v.938h-1zm8.5-.938v.938h-1v-.938h1zM0 14.094v-.938h1v.938H0zm7.5 0v-.938h1v.938h-1zm8.5-.938v.938h-1v-.938h1zM.969 16H0v-.969h.5V15h.469v.031H1v.469H.969v.5zm1.875 0h-.938v-1h.938v1zm1.875 0H3.78v-1h.938v1zm1.875 0h-.938v-1h.938v1zm.937 0v-.5H7.5v-.469h.031V15h.938v.031H8.5v.469h-.031v.5H7.53zm2.813 0h-.938v-1h.938v1zm1.875 0h-.938v-1h.938v1zm1.875 0h-.938v-1h.938v1zm.937 0v-.5H15v-.469h.031V15h.469v.031h.5V16h-.969z\"}}]})(props);\n};\nexport function BsBoundingBoxCircles (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1a1 1 0 1 0 0 2 1 1 0 0 0 0-2zM0 2a2 2 0 0 1 3.937-.5h8.126A2 2 0 1 1 14.5 3.937v8.126a2 2 0 1 1-2.437 2.437H3.937A2 2 0 1 1 1.5 12.063V3.937A2 2 0 0 1 0 2zm2.5 1.937v8.126c.703.18 1.256.734 1.437 1.437h8.126a2.004 2.004 0 0 1 1.437-1.437V3.937A2.004 2.004 0 0 1 12.063 2.5H3.937A2.004 2.004 0 0 1 2.5 3.937zM14 1a1 1 0 1 0 0 2 1 1 0 0 0 0-2zM2 13a1 1 0 1 0 0 2 1 1 0 0 0 0-2zm12 0a1 1 0 1 0 0 2 1 1 0 0 0 0-2z\"}}]})(props);\n};\nexport function BsBoundingBox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 2V0H0v5h2v6H0v5h5v-2h6v2h5v-5h-2V5h2V0h-5v2H5zm6 1v2h2v6h-2v2H5v-2H3V5h2V3h6zm1-2h3v3h-3V1zm3 11v3h-3v-3h3zM4 15H1v-3h3v3zM1 4V1h3v3H1z\"}}]})(props);\n};\nexport function BsBoxArrowDownLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.364 12.5a.5.5 0 0 0 .5.5H14.5a1.5 1.5 0 0 0 1.5-1.5v-10A1.5 1.5 0 0 0 14.5 0h-10A1.5 1.5 0 0 0 3 1.5v6.636a.5.5 0 1 0 1 0V1.5a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 .5.5v10a.5.5 0 0 1-.5.5H7.864a.5.5 0 0 0-.5.5z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M0 15.5a.5.5 0 0 0 .5.5h5a.5.5 0 0 0 0-1H1.707l8.147-8.146a.5.5 0 0 0-.708-.708L1 14.293V10.5a.5.5 0 0 0-1 0v5z\"}}]})(props);\n};\nexport function BsBoxArrowDownRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8.636 12.5a.5.5 0 0 1-.5.5H1.5A1.5 1.5 0 0 1 0 11.5v-10A1.5 1.5 0 0 1 1.5 0h10A1.5 1.5 0 0 1 13 1.5v6.636a.5.5 0 0 1-1 0V1.5a.5.5 0 0 0-.5-.5h-10a.5.5 0 0 0-.5.5v10a.5.5 0 0 0 .5.5h6.636a.5.5 0 0 1 .5.5z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M16 15.5a.5.5 0 0 1-.5.5h-5a.5.5 0 0 1 0-1h3.793L6.146 6.854a.5.5 0 1 1 .708-.708L15 14.293V10.5a.5.5 0 0 1 1 0v5z\"}}]})(props);\n};\nexport function BsBoxArrowDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.5 10a.5.5 0 0 1-.5-.5v-8a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 .5.5v8a.5.5 0 0 1-.5.5h-2a.5.5 0 0 0 0 1h2A1.5 1.5 0 0 0 14 9.5v-8A1.5 1.5 0 0 0 12.5 0h-9A1.5 1.5 0 0 0 2 1.5v8A1.5 1.5 0 0 0 3.5 11h2a.5.5 0 0 0 0-1h-2z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.646 15.854a.5.5 0 0 0 .708 0l3-3a.5.5 0 0 0-.708-.708L8.5 14.293V5.5a.5.5 0 0 0-1 0v8.793l-2.146-2.147a.5.5 0 0 0-.708.708l3 3z\"}}]})(props);\n};\nexport function BsBoxArrowInDownLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M9.636 2.5a.5.5 0 0 0-.5-.5H2.5A1.5 1.5 0 0 0 1 3.5v10A1.5 1.5 0 0 0 2.5 15h10a1.5 1.5 0 0 0 1.5-1.5V6.864a.5.5 0 0 0-1 0V13.5a.5.5 0 0 1-.5.5h-10a.5.5 0 0 1-.5-.5v-10a.5.5 0 0 1 .5-.5h6.636a.5.5 0 0 0 .5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5 10.5a.5.5 0 0 0 .5.5h5a.5.5 0 0 0 0-1H6.707l8.147-8.146a.5.5 0 0 0-.708-.708L6 9.293V5.5a.5.5 0 0 0-1 0v5z\"}}]})(props);\n};\nexport function BsBoxArrowInDownRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6.364 2.5a.5.5 0 0 1 .5-.5H13.5A1.5 1.5 0 0 1 15 3.5v10a1.5 1.5 0 0 1-1.5 1.5h-10A1.5 1.5 0 0 1 2 13.5V6.864a.5.5 0 1 1 1 0V13.5a.5.5 0 0 0 .5.5h10a.5.5 0 0 0 .5-.5v-10a.5.5 0 0 0-.5-.5H6.864a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11 10.5a.5.5 0 0 1-.5.5h-5a.5.5 0 0 1 0-1h3.793L1.146 1.854a.5.5 0 1 1 .708-.708L10 9.293V5.5a.5.5 0 0 1 1 0v5z\"}}]})(props);\n};\nexport function BsBoxArrowInDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.5 6a.5.5 0 0 0-.5.5v8a.5.5 0 0 0 .5.5h9a.5.5 0 0 0 .5-.5v-8a.5.5 0 0 0-.5-.5h-2a.5.5 0 0 1 0-1h2A1.5 1.5 0 0 1 14 6.5v8a1.5 1.5 0 0 1-1.5 1.5h-9A1.5 1.5 0 0 1 2 14.5v-8A1.5 1.5 0 0 1 3.5 5h2a.5.5 0 0 1 0 1h-2z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.646 11.854a.5.5 0 0 0 .708 0l3-3a.5.5 0 0 0-.708-.708L8.5 10.293V1.5a.5.5 0 0 0-1 0v8.793L5.354 8.146a.5.5 0 1 0-.708.708l3 3z\"}}]})(props);\n};\nexport function BsBoxArrowInLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10 3.5a.5.5 0 0 0-.5-.5h-8a.5.5 0 0 0-.5.5v9a.5.5 0 0 0 .5.5h8a.5.5 0 0 0 .5-.5v-2a.5.5 0 0 1 1 0v2A1.5 1.5 0 0 1 9.5 14h-8A1.5 1.5 0 0 1 0 12.5v-9A1.5 1.5 0 0 1 1.5 2h8A1.5 1.5 0 0 1 11 3.5v2a.5.5 0 0 1-1 0v-2z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4.146 8.354a.5.5 0 0 1 0-.708l3-3a.5.5 0 1 1 .708.708L5.707 7.5H14.5a.5.5 0 0 1 0 1H5.707l2.147 2.146a.5.5 0 0 1-.708.708l-3-3z\"}}]})(props);\n};\nexport function BsBoxArrowInRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 3.5a.5.5 0 0 1 .5-.5h8a.5.5 0 0 1 .5.5v9a.5.5 0 0 1-.5.5h-8a.5.5 0 0 1-.5-.5v-2a.5.5 0 0 0-1 0v2A1.5 1.5 0 0 0 6.5 14h8a1.5 1.5 0 0 0 1.5-1.5v-9A1.5 1.5 0 0 0 14.5 2h-8A1.5 1.5 0 0 0 5 3.5v2a.5.5 0 0 0 1 0v-2z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11.854 8.354a.5.5 0 0 0 0-.708l-3-3a.5.5 0 1 0-.708.708L10.293 7.5H1.5a.5.5 0 0 0 0 1h8.793l-2.147 2.146a.5.5 0 0 0 .708.708l3-3z\"}}]})(props);\n};\nexport function BsBoxArrowInUpLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M9.636 13.5a.5.5 0 0 1-.5.5H2.5A1.5 1.5 0 0 1 1 12.5v-10A1.5 1.5 0 0 1 2.5 1h10A1.5 1.5 0 0 1 14 2.5v6.636a.5.5 0 0 1-1 0V2.5a.5.5 0 0 0-.5-.5h-10a.5.5 0 0 0-.5.5v10a.5.5 0 0 0 .5.5h6.636a.5.5 0 0 1 .5.5z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5 5.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1H6.707l8.147 8.146a.5.5 0 0 1-.708.708L6 6.707V10.5a.5.5 0 0 1-1 0v-5z\"}}]})(props);\n};\nexport function BsBoxArrowInUpRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6.364 13.5a.5.5 0 0 0 .5.5H13.5a1.5 1.5 0 0 0 1.5-1.5v-10A1.5 1.5 0 0 0 13.5 1h-10A1.5 1.5 0 0 0 2 2.5v6.636a.5.5 0 1 0 1 0V2.5a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 .5.5v10a.5.5 0 0 1-.5.5H6.864a.5.5 0 0 0-.5.5z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11 5.5a.5.5 0 0 0-.5-.5h-5a.5.5 0 0 0 0 1h3.793l-8.147 8.146a.5.5 0 0 0 .708.708L10 6.707V10.5a.5.5 0 0 0 1 0v-5z\"}}]})(props);\n};\nexport function BsBoxArrowInUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.5 10a.5.5 0 0 1-.5-.5v-8a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 .5.5v8a.5.5 0 0 1-.5.5h-2a.5.5 0 0 0 0 1h2A1.5 1.5 0 0 0 14 9.5v-8A1.5 1.5 0 0 0 12.5 0h-9A1.5 1.5 0 0 0 2 1.5v8A1.5 1.5 0 0 0 3.5 11h2a.5.5 0 0 0 0-1h-2z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.646 4.146a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1-.708.708L8.5 5.707V14.5a.5.5 0 0 1-1 0V5.707L5.354 7.854a.5.5 0 1 1-.708-.708l3-3z\"}}]})(props);\n};\nexport function BsBoxArrowLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 12.5a.5.5 0 0 0 .5.5h8a.5.5 0 0 0 .5-.5v-9a.5.5 0 0 0-.5-.5h-8a.5.5 0 0 0-.5.5v2a.5.5 0 0 1-1 0v-2A1.5 1.5 0 0 1 6.5 2h8A1.5 1.5 0 0 1 16 3.5v9a1.5 1.5 0 0 1-1.5 1.5h-8A1.5 1.5 0 0 1 5 12.5v-2a.5.5 0 0 1 1 0v2z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M.146 8.354a.5.5 0 0 1 0-.708l3-3a.5.5 0 1 1 .708.708L1.707 7.5H10.5a.5.5 0 0 1 0 1H1.707l2.147 2.146a.5.5 0 0 1-.708.708l-3-3z\"}}]})(props);\n};\nexport function BsBoxArrowRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10 12.5a.5.5 0 0 1-.5.5h-8a.5.5 0 0 1-.5-.5v-9a.5.5 0 0 1 .5-.5h8a.5.5 0 0 1 .5.5v2a.5.5 0 0 0 1 0v-2A1.5 1.5 0 0 0 9.5 2h-8A1.5 1.5 0 0 0 0 3.5v9A1.5 1.5 0 0 0 1.5 14h8a1.5 1.5 0 0 0 1.5-1.5v-2a.5.5 0 0 0-1 0v2z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M15.854 8.354a.5.5 0 0 0 0-.708l-3-3a.5.5 0 0 0-.708.708L14.293 7.5H5.5a.5.5 0 0 0 0 1h8.793l-2.147 2.146a.5.5 0 0 0 .708.708l3-3z\"}}]})(props);\n};\nexport function BsBoxArrowUpLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.364 3.5a.5.5 0 0 1 .5-.5H14.5A1.5 1.5 0 0 1 16 4.5v10a1.5 1.5 0 0 1-1.5 1.5h-10A1.5 1.5 0 0 1 3 14.5V7.864a.5.5 0 1 1 1 0V14.5a.5.5 0 0 0 .5.5h10a.5.5 0 0 0 .5-.5v-10a.5.5 0 0 0-.5-.5H7.864a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M0 .5A.5.5 0 0 1 .5 0h5a.5.5 0 0 1 0 1H1.707l8.147 8.146a.5.5 0 0 1-.708.708L1 1.707V5.5a.5.5 0 0 1-1 0v-5z\"}}]})(props);\n};\nexport function BsBoxArrowUpRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8.636 3.5a.5.5 0 0 0-.5-.5H1.5A1.5 1.5 0 0 0 0 4.5v10A1.5 1.5 0 0 0 1.5 16h10a1.5 1.5 0 0 0 1.5-1.5V7.864a.5.5 0 0 0-1 0V14.5a.5.5 0 0 1-.5.5h-10a.5.5 0 0 1-.5-.5v-10a.5.5 0 0 1 .5-.5h6.636a.5.5 0 0 0 .5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M16 .5a.5.5 0 0 0-.5-.5h-5a.5.5 0 0 0 0 1h3.793L6.146 9.146a.5.5 0 1 0 .708.708L15 1.707V5.5a.5.5 0 0 0 1 0v-5z\"}}]})(props);\n};\nexport function BsBoxArrowUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.5 6a.5.5 0 0 0-.5.5v8a.5.5 0 0 0 .5.5h9a.5.5 0 0 0 .5-.5v-8a.5.5 0 0 0-.5-.5h-2a.5.5 0 0 1 0-1h2A1.5 1.5 0 0 1 14 6.5v8a1.5 1.5 0 0 1-1.5 1.5h-9A1.5 1.5 0 0 1 2 14.5v-8A1.5 1.5 0 0 1 3.5 5h2a.5.5 0 0 1 0 1h-2z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.646.146a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1-.708.708L8.5 1.707V10.5a.5.5 0 0 1-1 0V1.707L5.354 3.854a.5.5 0 1 1-.708-.708l3-3z\"}}]})(props);\n};\nexport function BsBoxSeam (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.186 1.113a.5.5 0 0 0-.372 0L1.846 3.5l2.404.961L10.404 2l-2.218-.887zm3.564 1.426L5.596 5 8 5.961 14.154 3.5l-2.404-.961zm3.25 1.7-6.5 2.6v7.922l6.5-2.6V4.24zM7.5 14.762V6.838L1 4.239v7.923l6.5 2.6zM7.443.184a1.5 1.5 0 0 1 1.114 0l7.129 2.852A.5.5 0 0 1 16 3.5v8.662a1 1 0 0 1-.629.928l-7.185 2.874a.5.5 0 0 1-.372 0L.63 13.09a1 1 0 0 1-.63-.928V3.5a.5.5 0 0 1 .314-.464L7.443.184z\"}}]})(props);\n};\nexport function BsBox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.186 1.113a.5.5 0 0 0-.372 0L1.846 3.5 8 5.961 14.154 3.5 8.186 1.113zM15 4.239l-6.5 2.6v7.922l6.5-2.6V4.24zM7.5 14.762V6.838L1 4.239v7.923l6.5 2.6zM7.443.184a1.5 1.5 0 0 1 1.114 0l7.129 2.852A.5.5 0 0 1 16 3.5v8.662a1 1 0 0 1-.629.928l-7.185 2.874a.5.5 0 0 1-.372 0L.63 13.09a1 1 0 0 1-.63-.928V3.5a.5.5 0 0 1 .314-.464L7.443.184z\"}}]})(props);\n};\nexport function BsBraces (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.114 8.063V7.9c1.005-.102 1.497-.615 1.497-1.6V4.503c0-1.094.39-1.538 1.354-1.538h.273V2h-.376C3.25 2 2.49 2.759 2.49 4.352v1.524c0 1.094-.376 1.456-1.49 1.456v1.299c1.114 0 1.49.362 1.49 1.456v1.524c0 1.593.759 2.352 2.372 2.352h.376v-.964h-.273c-.964 0-1.354-.444-1.354-1.538V9.663c0-.984-.492-1.497-1.497-1.6zM13.886 7.9v.163c-1.005.103-1.497.616-1.497 1.6v1.798c0 1.094-.39 1.538-1.354 1.538h-.273v.964h.376c1.613 0 2.372-.759 2.372-2.352v-1.524c0-1.094.376-1.456 1.49-1.456V7.332c-1.114 0-1.49-.362-1.49-1.456V4.352C13.51 2.759 12.75 2 11.138 2h-.376v.964h.273c.964 0 1.354.444 1.354 1.538V6.3c0 .984.492 1.497 1.497 1.6z\"}}]})(props);\n};\nexport function BsBricks (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 .5A.5.5 0 0 1 .5 0h15a.5.5 0 0 1 .5.5v3a.5.5 0 0 1-.5.5H14v2h1.5a.5.5 0 0 1 .5.5v3a.5.5 0 0 1-.5.5H14v2h1.5a.5.5 0 0 1 .5.5v3a.5.5 0 0 1-.5.5H.5a.5.5 0 0 1-.5-.5v-3a.5.5 0 0 1 .5-.5H2v-2H.5a.5.5 0 0 1-.5-.5v-3A.5.5 0 0 1 .5 6H2V4H.5a.5.5 0 0 1-.5-.5v-3zM3 4v2h4.5V4H3zm5.5 0v2H13V4H8.5zM3 10v2h4.5v-2H3zm5.5 0v2H13v-2H8.5zM1 1v2h3.5V1H1zm4.5 0v2h5V1h-5zm6 0v2H15V1h-3.5zM1 7v2h3.5V7H1zm4.5 0v2h5V7h-5zm6 0v2H15V7h-3.5zM1 13v2h3.5v-2H1zm4.5 0v2h5v-2h-5zm6 0v2H15v-2h-3.5z\"}}]})(props);\n};\nexport function BsBriefcaseFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 1A1.5 1.5 0 0 0 5 2.5V3H1.5A1.5 1.5 0 0 0 0 4.5v1.384l7.614 2.03a1.5 1.5 0 0 0 .772 0L16 5.884V4.5A1.5 1.5 0 0 0 14.5 3H11v-.5A1.5 1.5 0 0 0 9.5 1h-3zm0 1h3a.5.5 0 0 1 .5.5V3H6v-.5a.5.5 0 0 1 .5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12.5A1.5 1.5 0 0 0 1.5 14h13a1.5 1.5 0 0 0 1.5-1.5V6.85L8.129 8.947a.5.5 0 0 1-.258 0L0 6.85v5.65z\"}}]})(props);\n};\nexport function BsBriefcase (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 1A1.5 1.5 0 0 0 5 2.5V3H1.5A1.5 1.5 0 0 0 0 4.5v8A1.5 1.5 0 0 0 1.5 14h13a1.5 1.5 0 0 0 1.5-1.5v-8A1.5 1.5 0 0 0 14.5 3H11v-.5A1.5 1.5 0 0 0 9.5 1h-3zm0 1h3a.5.5 0 0 1 .5.5V3H6v-.5a.5.5 0 0 1 .5-.5zm1.886 6.914L15 7.151V12.5a.5.5 0 0 1-.5.5h-13a.5.5 0 0 1-.5-.5V7.15l6.614 1.764a1.5 1.5 0 0 0 .772 0zM1.5 4h13a.5.5 0 0 1 .5.5v1.616L8.129 7.948a.5.5 0 0 1-.258 0L1 6.116V4.5a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsBrightnessAltHighFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 3a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 3zm8 8a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2a.5.5 0 0 1 .5.5zm-13.5.5a.5.5 0 0 0 0-1h-2a.5.5 0 0 0 0 1h2zm11.157-6.157a.5.5 0 0 1 0 .707l-1.414 1.414a.5.5 0 1 1-.707-.707l1.414-1.414a.5.5 0 0 1 .707 0zm-9.9 2.121a.5.5 0 0 0 .707-.707L3.05 5.343a.5.5 0 1 0-.707.707l1.414 1.414zM8 7a4 4 0 0 0-4 4 .5.5 0 0 0 .5.5h7a.5.5 0 0 0 .5-.5 4 4 0 0 0-4-4z\"}}]})(props);\n};\nexport function BsBrightnessAltHigh (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 3a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 3zm8 8a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2a.5.5 0 0 1 .5.5zm-13.5.5a.5.5 0 0 0 0-1h-2a.5.5 0 0 0 0 1h2zm11.157-6.157a.5.5 0 0 1 0 .707l-1.414 1.414a.5.5 0 1 1-.707-.707l1.414-1.414a.5.5 0 0 1 .707 0zm-9.9 2.121a.5.5 0 0 0 .707-.707L3.05 5.343a.5.5 0 1 0-.707.707l1.414 1.414zM8 7a4 4 0 0 0-4 4 .5.5 0 0 0 .5.5h7a.5.5 0 0 0 .5-.5 4 4 0 0 0-4-4zm0 1a3 3 0 0 1 2.959 2.5H5.04A3 3 0 0 1 8 8z\"}}]})(props);\n};\nexport function BsBrightnessAltLowFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 5.5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm5 6a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zM2 11a.5.5 0 1 0 1 0 .5.5 0 0 0-1 0zm10.243-3.536a.5.5 0 1 1-.707-.707.5.5 0 0 1 .707.707zm-8.486-.707a.5.5 0 1 0 .707.707.5.5 0 0 0-.707-.707zM8 7a4 4 0 0 0-4 4 .5.5 0 0 0 .5.5h7a.5.5 0 0 0 .5-.5 4 4 0 0 0-4-4z\"}}]})(props);\n};\nexport function BsBrightnessAltLow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 5.5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm5 6a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zM2 11a.5.5 0 1 0 1 0 .5.5 0 0 0-1 0zm10.243-3.536a.5.5 0 1 1-.707-.707.5.5 0 0 1 .707.707zm-8.486-.707a.5.5 0 1 0 .707.707.5.5 0 0 0-.707-.707zM8 7a4 4 0 0 0-4 4 .5.5 0 0 0 .5.5h7a.5.5 0 0 0 .5-.5 4 4 0 0 0-4-4zm0 1a3 3 0 0 1 2.959 2.5H5.04A3 3 0 0 1 8 8z\"}}]})(props);\n};\nexport function BsBrightnessHighFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8a4 4 0 1 1-8 0 4 4 0 0 1 8 0zM8 0a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 0zm0 13a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 13zm8-5a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2a.5.5 0 0 1 .5.5zM3 8a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2A.5.5 0 0 1 3 8zm10.657-5.657a.5.5 0 0 1 0 .707l-1.414 1.415a.5.5 0 1 1-.707-.708l1.414-1.414a.5.5 0 0 1 .707 0zm-9.193 9.193a.5.5 0 0 1 0 .707L3.05 13.657a.5.5 0 0 1-.707-.707l1.414-1.414a.5.5 0 0 1 .707 0zm9.193 2.121a.5.5 0 0 1-.707 0l-1.414-1.414a.5.5 0 0 1 .707-.707l1.414 1.414a.5.5 0 0 1 0 .707zM4.464 4.465a.5.5 0 0 1-.707 0L2.343 3.05a.5.5 0 1 1 .707-.707l1.414 1.414a.5.5 0 0 1 0 .708z\"}}]})(props);\n};\nexport function BsBrightnessHigh (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11a3 3 0 1 1 0-6 3 3 0 0 1 0 6zm0 1a4 4 0 1 0 0-8 4 4 0 0 0 0 8zM8 0a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 0zm0 13a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 13zm8-5a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2a.5.5 0 0 1 .5.5zM3 8a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2A.5.5 0 0 1 3 8zm10.657-5.657a.5.5 0 0 1 0 .707l-1.414 1.415a.5.5 0 1 1-.707-.708l1.414-1.414a.5.5 0 0 1 .707 0zm-9.193 9.193a.5.5 0 0 1 0 .707L3.05 13.657a.5.5 0 0 1-.707-.707l1.414-1.414a.5.5 0 0 1 .707 0zm9.193 2.121a.5.5 0 0 1-.707 0l-1.414-1.414a.5.5 0 0 1 .707-.707l1.414 1.414a.5.5 0 0 1 0 .707zM4.464 4.465a.5.5 0 0 1-.707 0L2.343 3.05a.5.5 0 1 1 .707-.707l1.414 1.414a.5.5 0 0 1 0 .708z\"}}]})(props);\n};\nexport function BsBrightnessLowFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 8a4 4 0 1 1-8 0 4 4 0 0 1 8 0zM8.5 2.5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm0 11a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm5-5a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm-11 0a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm9.743-4.036a.5.5 0 1 1-.707-.707.5.5 0 0 1 .707.707zm-7.779 7.779a.5.5 0 1 1-.707-.707.5.5 0 0 1 .707.707zm7.072 0a.5.5 0 1 1 .707-.707.5.5 0 0 1-.707.707zM3.757 4.464a.5.5 0 1 1 .707-.707.5.5 0 0 1-.707.707z\"}}]})(props);\n};\nexport function BsBrightnessLow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11a3 3 0 1 1 0-6 3 3 0 0 1 0 6zm0 1a4 4 0 1 0 0-8 4 4 0 0 0 0 8zm.5-9.5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm0 11a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm5-5a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm-11 0a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm9.743-4.036a.5.5 0 1 1-.707-.707.5.5 0 0 1 .707.707zm-7.779 7.779a.5.5 0 1 1-.707-.707.5.5 0 0 1 .707.707zm7.072 0a.5.5 0 1 1 .707-.707.5.5 0 0 1-.707.707zM3.757 4.464a.5.5 0 1 1 .707-.707.5.5 0 0 1-.707.707z\"}}]})(props);\n};\nexport function BsBroadcastPin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.05 3.05a7 7 0 0 0 0 9.9.5.5 0 0 1-.707.707 8 8 0 0 1 0-11.314.5.5 0 0 1 .707.707zm2.122 2.122a4 4 0 0 0 0 5.656.5.5 0 1 1-.708.708 5 5 0 0 1 0-7.072.5.5 0 0 1 .708.708zm5.656-.708a.5.5 0 0 1 .708 0 5 5 0 0 1 0 7.072.5.5 0 1 1-.708-.708 4 4 0 0 0 0-5.656.5.5 0 0 1 0-.708zm2.122-2.12a.5.5 0 0 1 .707 0 8 8 0 0 1 0 11.313.5.5 0 0 1-.707-.707 7 7 0 0 0 0-9.9.5.5 0 0 1 0-.707zM6 8a2 2 0 1 1 2.5 1.937V15.5a.5.5 0 0 1-1 0V9.937A2 2 0 0 1 6 8z\"}}]})(props);\n};\nexport function BsBroadcast (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.05 3.05a7 7 0 0 0 0 9.9.5.5 0 0 1-.707.707 8 8 0 0 1 0-11.314.5.5 0 0 1 .707.707zm2.122 2.122a4 4 0 0 0 0 5.656.5.5 0 1 1-.708.708 5 5 0 0 1 0-7.072.5.5 0 0 1 .708.708zm5.656-.708a.5.5 0 0 1 .708 0 5 5 0 0 1 0 7.072.5.5 0 1 1-.708-.708 4 4 0 0 0 0-5.656.5.5 0 0 1 0-.708zm2.122-2.12a.5.5 0 0 1 .707 0 8 8 0 0 1 0 11.313.5.5 0 0 1-.707-.707 7 7 0 0 0 0-9.9.5.5 0 0 1 0-.707zM10 8a2 2 0 1 1-4 0 2 2 0 0 1 4 0z\"}}]})(props);\n};\nexport function BsBrushFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.825.12a.5.5 0 0 1 .132.584c-1.53 3.43-4.743 8.17-7.095 10.64a6.067 6.067 0 0 1-2.373 1.534c-.018.227-.06.538-.16.868-.201.659-.667 1.479-1.708 1.74a8.118 8.118 0 0 1-3.078.132 3.659 3.659 0 0 1-.562-.135 1.382 1.382 0 0 1-.466-.247.714.714 0 0 1-.204-.288.622.622 0 0 1 .004-.443c.095-.245.316-.38.461-.452.394-.197.625-.453.867-.826.095-.144.184-.297.287-.472l.117-.198c.151-.255.326-.54.546-.848.528-.739 1.201-.925 1.746-.896.126.007.243.025.348.048.062-.172.142-.38.238-.608.261-.619.658-1.419 1.187-2.069 2.176-2.67 6.18-6.206 9.117-8.104a.5.5 0 0 1 .596.04z\"}}]})(props);\n};\nexport function BsBrush (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.825.12a.5.5 0 0 1 .132.584c-1.53 3.43-4.743 8.17-7.095 10.64a6.067 6.067 0 0 1-2.373 1.534c-.018.227-.06.538-.16.868-.201.659-.667 1.479-1.708 1.74a8.118 8.118 0 0 1-3.078.132 3.659 3.659 0 0 1-.562-.135 1.382 1.382 0 0 1-.466-.247.714.714 0 0 1-.204-.288.622.622 0 0 1 .004-.443c.095-.245.316-.38.461-.452.394-.197.625-.453.867-.826.095-.144.184-.297.287-.472l.117-.198c.151-.255.326-.54.546-.848.528-.739 1.201-.925 1.746-.896.126.007.243.025.348.048.062-.172.142-.38.238-.608.261-.619.658-1.419 1.187-2.069 2.176-2.67 6.18-6.206 9.117-8.104a.5.5 0 0 1 .596.04zM4.705 11.912a1.23 1.23 0 0 0-.419-.1c-.246-.013-.573.05-.879.479-.197.275-.355.532-.5.777l-.105.177c-.106.181-.213.362-.32.528a3.39 3.39 0 0 1-.76.861c.69.112 1.736.111 2.657-.12.559-.139.843-.569.993-1.06a3.122 3.122 0 0 0 .126-.75l-.793-.792zm1.44.026c.12-.04.277-.1.458-.183a5.068 5.068 0 0 0 1.535-1.1c1.9-1.996 4.412-5.57 6.052-8.631-2.59 1.927-5.566 4.66-7.302 6.792-.442.543-.795 1.243-1.042 1.826-.121.288-.214.54-.275.72v.001l.575.575zm-4.973 3.04.007-.005a.031.031 0 0 1-.007.004zm3.582-3.043.002.001h-.002z\"}}]})(props);\n};\nexport function BsBucketFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.522 5H2a.5.5 0 0 0-.494.574l1.372 9.149A1.5 1.5 0 0 0 4.36 16h7.278a1.5 1.5 0 0 0 1.483-1.277l1.373-9.149A.5.5 0 0 0 14 5h-.522A5.5 5.5 0 0 0 2.522 5zm1.005 0a4.5 4.5 0 0 1 8.945 0H3.527z\"}}]})(props);\n};\nexport function BsBucket (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.522 5H2a.5.5 0 0 0-.494.574l1.372 9.149A1.5 1.5 0 0 0 4.36 16h7.278a1.5 1.5 0 0 0 1.483-1.277l1.373-9.149A.5.5 0 0 0 14 5h-.522A5.5 5.5 0 0 0 2.522 5zm1.005 0a4.5 4.5 0 0 1 8.945 0H3.527zm9.892 1-1.286 8.574a.5.5 0 0 1-.494.426H4.36a.5.5 0 0 1-.494-.426L2.58 6h10.838z\"}}]})(props);\n};\nexport function BsBugFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.978.855a.5.5 0 1 0-.956.29l.41 1.352A4.985 4.985 0 0 0 3 6h10a4.985 4.985 0 0 0-1.432-3.503l.41-1.352a.5.5 0 1 0-.956-.29l-.291.956A4.978 4.978 0 0 0 8 1a4.979 4.979 0 0 0-2.731.811l-.29-.956z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 6v1H8.5v8.975A5 5 0 0 0 13 11h.5a.5.5 0 0 1 .5.5v.5a.5.5 0 1 0 1 0v-.5a1.5 1.5 0 0 0-1.5-1.5H13V9h1.5a.5.5 0 0 0 0-1H13V7h.5A1.5 1.5 0 0 0 15 5.5V5a.5.5 0 0 0-1 0v.5a.5.5 0 0 1-.5.5H13zm-5.5 9.975V7H3V6h-.5a.5.5 0 0 1-.5-.5V5a.5.5 0 0 0-1 0v.5A1.5 1.5 0 0 0 2.5 7H3v1H1.5a.5.5 0 0 0 0 1H3v1h-.5A1.5 1.5 0 0 0 1 11.5v.5a.5.5 0 1 0 1 0v-.5a.5.5 0 0 1 .5-.5H3a5 5 0 0 0 4.5 4.975z\"}}]})(props);\n};\nexport function BsBug (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.355.522a.5.5 0 0 1 .623.333l.291.956A4.979 4.979 0 0 1 8 1c1.007 0 1.946.298 2.731.811l.29-.956a.5.5 0 1 1 .957.29l-.41 1.352A4.985 4.985 0 0 1 13 6h.5a.5.5 0 0 0 .5-.5V5a.5.5 0 0 1 1 0v.5A1.5 1.5 0 0 1 13.5 7H13v1h1.5a.5.5 0 0 1 0 1H13v1h.5a1.5 1.5 0 0 1 1.5 1.5v.5a.5.5 0 1 1-1 0v-.5a.5.5 0 0 0-.5-.5H13a5 5 0 0 1-10 0h-.5a.5.5 0 0 0-.5.5v.5a.5.5 0 1 1-1 0v-.5A1.5 1.5 0 0 1 2.5 10H3V9H1.5a.5.5 0 0 1 0-1H3V7h-.5A1.5 1.5 0 0 1 1 5.5V5a.5.5 0 0 1 1 0v.5a.5.5 0 0 0 .5.5H3c0-1.364.547-2.601 1.432-3.503l-.41-1.352a.5.5 0 0 1 .333-.623zM4 7v4a4 4 0 0 0 3.5 3.97V7H4zm4.5 0v7.97A4 4 0 0 0 12 11V7H8.5zM12 6a3.989 3.989 0 0 0-1.334-2.982A3.983 3.983 0 0 0 8 2a3.983 3.983 0 0 0-2.667 1.018A3.989 3.989 0 0 0 4 6h8z\"}}]})(props);\n};\nexport function BsBuilding (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M14.763.075A.5.5 0 0 1 15 .5v15a.5.5 0 0 1-.5.5h-3a.5.5 0 0 1-.5-.5V14h-1v1.5a.5.5 0 0 1-.5.5h-9a.5.5 0 0 1-.5-.5V10a.5.5 0 0 1 .342-.474L6 7.64V4.5a.5.5 0 0 1 .276-.447l8-4a.5.5 0 0 1 .487.022zM6 8.694 1 10.36V15h5V8.694zM7 15h2v-1.5a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 .5.5V15h2V1.309l-7 3.5V15z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 11h1v1H2v-1zm2 0h1v1H4v-1zm-2 2h1v1H2v-1zm2 0h1v1H4v-1zm4-4h1v1H8V9zm2 0h1v1h-1V9zm-2 2h1v1H8v-1zm2 0h1v1h-1v-1zm2-2h1v1h-1V9zm0 2h1v1h-1v-1zM8 7h1v1H8V7zm2 0h1v1h-1V7zm2 0h1v1h-1V7zM8 5h1v1H8V5zm2 0h1v1h-1V5zm2 0h1v1h-1V5zm0-2h1v1h-1V3z\"}}]})(props);\n};\nexport function BsBullseye (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13A5 5 0 1 1 8 3a5 5 0 0 1 0 10zm0 1A6 6 0 1 0 8 2a6 6 0 0 0 0 12z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11a3 3 0 1 1 0-6 3 3 0 0 1 0 6zm0 1a4 4 0 1 0 0-8 4 4 0 0 0 0 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 8a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0z\"}}]})(props);\n};\nexport function BsCalculatorFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm2 .5v2a.5.5 0 0 0 .5.5h7a.5.5 0 0 0 .5-.5v-2a.5.5 0 0 0-.5-.5h-7a.5.5 0 0 0-.5.5zm0 4v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5zM4.5 9a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zM4 12.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5zM7.5 6a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zM7 9.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5zm.5 2.5a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zM10 6.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5zm.5 2.5a.5.5 0 0 0-.5.5v4a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-4a.5.5 0 0 0-.5-.5h-1z\"}}]})(props);\n};\nexport function BsCalculator (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h8zM4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 2.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-7a.5.5 0 0 1-.5-.5v-2zm0 4a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm0 3a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm0 3a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm3-6a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm0 3a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm0 3a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm3-6a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm0 3a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-4z\"}}]})(props);\n};\nexport function BsCalendarCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM16 14V5H0v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2zm-5.146-5.146-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 0 1 .708-.708L7.5 10.793l2.646-2.647a.5.5 0 0 1 .708.708z\"}}]})(props);\n};\nexport function BsCalendarCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.854 7.146a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7.5 9.793l2.646-2.647a.5.5 0 0 1 .708 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM1 4v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4H1z\"}}]})(props);\n};\nexport function BsCalendarDateFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zm5.402 9.746c.625 0 1.184-.484 1.184-1.18 0-.832-.527-1.23-1.16-1.23-.586 0-1.168.387-1.168 1.21 0 .817.543 1.2 1.144 1.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 14V5H0v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2zm-6.664-1.21c-1.11 0-1.656-.767-1.703-1.407h.683c.043.37.387.82 1.051.82.844 0 1.301-.848 1.305-2.164h-.027c-.153.414-.637.79-1.383.79-.852 0-1.676-.61-1.676-1.77 0-1.137.871-1.809 1.797-1.809 1.172 0 1.953.734 1.953 2.668 0 1.805-.742 2.871-2 2.871zm-2.89-5.435v5.332H5.77V8.079h-.012c-.29.156-.883.52-1.258.777V8.16a12.6 12.6 0 0 1 1.313-.805h.632z\"}}]})(props);\n};\nexport function BsCalendarDate (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.445 11.688V6.354h-.633A12.6 12.6 0 0 0 4.5 7.16v.695c.375-.257.969-.62 1.258-.777h.012v4.61h.675zm1.188-1.305c.047.64.594 1.406 1.703 1.406 1.258 0 2-1.066 2-2.871 0-1.934-.781-2.668-1.953-2.668-.926 0-1.797.672-1.797 1.809 0 1.16.824 1.77 1.676 1.77.746 0 1.23-.376 1.383-.79h.027c-.004 1.316-.461 2.164-1.305 2.164-.664 0-1.008-.45-1.05-.82h-.684zm2.953-2.317c0 .696-.559 1.18-1.184 1.18-.601 0-1.144-.383-1.144-1.2 0-.823.582-1.21 1.168-1.21.633 0 1.16.398 1.16 1.23z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM1 4v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4H1z\"}}]})(props);\n};\nexport function BsCalendarDayFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM16 14a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V5h16v9zm-4.785-6.145a.428.428 0 1 0 0-.855.426.426 0 0 0-.43.43c0 .238.192.425.43.425zm.336.563h-.672v4.105h.672V8.418zm-6.867 4.105v-2.3h2.261v-.61H4.684V7.801h2.464v-.61H4v5.332h.684zm3.296 0h.676V9.98c0-.554.227-1.007.953-1.007.125 0 .258.004.329.015v-.613a1.806 1.806 0 0 0-.254-.02c-.582 0-.891.32-1.012.567h-.02v-.504H7.98v4.105z\"}}]})(props);\n};\nexport function BsCalendarDay (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.684 11.523v-2.3h2.261v-.61H4.684V6.801h2.464v-.61H4v5.332h.684zm3.296 0h.676V8.98c0-.554.227-1.007.953-1.007.125 0 .258.004.329.015v-.613a1.806 1.806 0 0 0-.254-.02c-.582 0-.891.32-1.012.567h-.02v-.504H7.98v4.105zm2.805-5.093c0 .238.192.425.43.425a.428.428 0 1 0 0-.855.426.426 0 0 0-.43.43zm.094 5.093h.672V7.418h-.672v4.105z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM1 4v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4H1z\"}}]})(props);\n};\nexport function BsCalendarEventFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM16 14V5H0v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2zm-3.5-7h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsCalendarEvent (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 6.5a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM1 4v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4H1z\"}}]})(props);\n};\nexport function BsCalendarFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V5h16V4H0V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsCalendarMinusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM16 14V5H0v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2zM6 10h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsCalendarMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 9.5A.5.5 0 0 1 6 9h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM1 4v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4H1z\"}}]})(props);\n};\nexport function BsCalendarMonthFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zm.104 7.305L4.9 10.18H3.284l.8-2.375h.02zm9.074 2.297c0-.832-.414-1.36-1.062-1.36-.692 0-1.098.492-1.098 1.36v.253c0 .852.406 1.364 1.098 1.364.671 0 1.062-.516 1.062-1.364v-.253z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 14V5H0v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2zM2.56 12.332h-.71L3.748 7h.696l1.898 5.332h-.719l-.539-1.602H3.1l-.54 1.602zm7.29-4.105v4.105h-.668v-.539h-.027c-.145.324-.532.605-1.188.605-.847 0-1.453-.484-1.453-1.425V8.227h.676v2.554c0 .766.441 1.012.98 1.012.59 0 1.004-.371 1.004-1.023V8.227h.676zm1.273 4.41c.075.332.422.636.985.636.648 0 1.07-.378 1.07-1.023v-.605h-.02c-.163.355-.613.648-1.171.648-.957 0-1.64-.672-1.64-1.902v-.34c0-1.207.675-1.887 1.64-1.887.558 0 1.004.293 1.195.64h.02v-.577h.648v4.03c0 1.052-.816 1.579-1.746 1.579-1.043 0-1.574-.516-1.668-1.2h.687z\"}}]})(props);\n};\nexport function BsCalendarMonth (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.56 11.332 3.1 9.73h1.984l.54 1.602h.718L4.444 6h-.696L1.85 11.332h.71zm1.544-4.527L4.9 9.18H3.284l.8-2.375h.02zm5.746.422h-.676V9.77c0 .652-.414 1.023-1.004 1.023-.539 0-.98-.246-.98-1.012V7.227h-.676v2.746c0 .941.606 1.425 1.453 1.425.656 0 1.043-.28 1.188-.605h.027v.539h.668V7.227zm2.258 5.046c-.563 0-.91-.304-.985-.636h-.687c.094.683.625 1.199 1.668 1.199.93 0 1.746-.527 1.746-1.578V7.227h-.649v.578h-.019c-.191-.348-.637-.64-1.195-.64-.965 0-1.64.679-1.64 1.886v.34c0 1.23.683 1.902 1.64 1.902.558 0 1.008-.293 1.172-.648h.02v.605c0 .645-.423 1.023-1.071 1.023zm.008-4.53c.648 0 1.062.527 1.062 1.359v.253c0 .848-.39 1.364-1.062 1.364-.692 0-1.098-.512-1.098-1.364v-.253c0-.868.406-1.36 1.098-1.36z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM1 4v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4H1z\"}}]})(props);\n};\nexport function BsCalendarPlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM16 14V5H0v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2zM8.5 8.5V10H10a.5.5 0 0 1 0 1H8.5v1.5a.5.5 0 0 1-1 0V11H6a.5.5 0 0 1 0-1h1.5V8.5a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsCalendarPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 7a.5.5 0 0 1 .5.5V9H10a.5.5 0 0 1 0 1H8.5v1.5a.5.5 0 0 1-1 0V10H6a.5.5 0 0 1 0-1h1.5V7.5A.5.5 0 0 1 8 7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM1 4v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4H1z\"}}]})(props);\n};\nexport function BsCalendarRangeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM16 7V5H0v5h5a1 1 0 1 1 0 2H0v2a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V9h-6a1 1 0 1 1 0-2h6z\"}}]})(props);\n};\nexport function BsCalendarRange (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9 7a1 1 0 0 1 1-1h5v2h-5a1 1 0 0 1-1-1zM1 9h4a1 1 0 0 1 0 2H1V9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM1 4v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4H1z\"}}]})(props);\n};\nexport function BsCalendarWeekFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM16 14V5H0v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2zM9.5 7h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5zm3 0h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5zM2 10.5a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm3.5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsCalendarWeek (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 6.5a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm-3 0a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm-5 3a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm3 0a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM1 4v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4H1z\"}}]})(props);\n};\nexport function BsCalendarXFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v1h16V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM16 14V5H0v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2zM6.854 8.146 8 9.293l1.146-1.147a.5.5 0 1 1 .708.708L8.707 10l1.147 1.146a.5.5 0 0 1-.708.708L8 10.707l-1.146 1.147a.5.5 0 0 1-.708-.708L7.293 10 6.146 8.854a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsCalendarX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.146 7.146a.5.5 0 0 1 .708 0L8 8.293l1.146-1.147a.5.5 0 1 1 .708.708L8.707 9l1.147 1.146a.5.5 0 0 1-.708.708L8 9.707l-1.146 1.147a.5.5 0 0 1-.708-.708L7.293 9 6.146 7.854a.5.5 0 0 1 0-.708z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM1 4v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4H1z\"}}]})(props);\n};\nexport function BsCalendar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM1 4v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4H1z\"}}]})(props);\n};\nexport function BsCalendar2CheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zm-2.6 5.854a.5.5 0 0 0-.708-.708L7.5 10.793 6.354 9.646a.5.5 0 1 0-.708.708l1.5 1.5a.5.5 0 0 0 .708 0l3-3z\"}}]})(props);\n};\nexport function BsCalendar2Check (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.854 8.146a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 0 1 .708-.708L7.5 10.793l2.646-2.647a.5.5 0 0 1 .708 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 2a1 1 0 0 0-1 1v11a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 4a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5H3a.5.5 0 0 1-.5-.5V4z\"}}]})(props);\n};\nexport function BsCalendar2DateFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.402 10.246c.625 0 1.184-.484 1.184-1.18 0-.832-.527-1.23-1.16-1.23-.586 0-1.168.387-1.168 1.21 0 .817.543 1.2 1.144 1.2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zm-4.118 9.79c1.258 0 2-1.067 2-2.872 0-1.934-.781-2.668-1.953-2.668-.926 0-1.797.672-1.797 1.809 0 1.16.824 1.77 1.676 1.77.746 0 1.23-.376 1.383-.79h.027c-.004 1.316-.461 2.164-1.305 2.164-.664 0-1.008-.45-1.05-.82h-.684c.047.64.594 1.406 1.703 1.406zm-2.89-5.435h-.633A12.6 12.6 0 0 0 4.5 8.16v.695c.375-.257.969-.62 1.258-.777h.012v4.61h.675V7.354z\"}}]})(props);\n};\nexport function BsCalendar2Date (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.445 12.688V7.354h-.633A12.6 12.6 0 0 0 4.5 8.16v.695c.375-.257.969-.62 1.258-.777h.012v4.61h.675zm1.188-1.305c.047.64.594 1.406 1.703 1.406 1.258 0 2-1.066 2-2.871 0-1.934-.781-2.668-1.953-2.668-.926 0-1.797.672-1.797 1.809 0 1.16.824 1.77 1.676 1.77.746 0 1.23-.376 1.383-.79h.027c-.004 1.316-.461 2.164-1.305 2.164-.664 0-1.008-.45-1.05-.82h-.684zm2.953-2.317c0 .696-.559 1.18-1.184 1.18-.601 0-1.144-.383-1.144-1.2 0-.823.582-1.21 1.168-1.21.633 0 1.16.398 1.16 1.23z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 2a1 1 0 0 0-1 1v11a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 4a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5H3a.5.5 0 0 1-.5-.5V4z\"}}]})(props);\n};\nexport function BsCalendar2DayFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zm-2.24 4.855a.428.428 0 1 0 0-.855.426.426 0 0 0-.429.43c0 .238.192.425.43.425zm.337.563h-.672v4.105h.672V8.418zm-6.867 4.105v-2.3h2.261v-.61H4.684V7.801h2.464v-.61H4v5.332h.684zm3.296 0h.676V9.98c0-.554.227-1.007.953-1.007.125 0 .258.004.329.015v-.613a1.806 1.806 0 0 0-.254-.02c-.582 0-.891.32-1.012.567h-.02v-.504H7.98v4.105z\"}}]})(props);\n};\nexport function BsCalendar2Day (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.684 12.523v-2.3h2.261v-.61H4.684V7.801h2.464v-.61H4v5.332h.684zm3.296 0h.676V9.98c0-.554.227-1.007.953-1.007.125 0 .258.004.329.015v-.613a1.806 1.806 0 0 0-.254-.02c-.582 0-.891.32-1.012.567h-.02v-.504H7.98v4.105zm2.805-5.093c0 .238.192.425.43.425a.428.428 0 1 0 0-.855.426.426 0 0 0-.43.43zm.094 5.093h.672V8.418h-.672v4.105z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 2a1 1 0 0 0-1 1v11a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 4a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5H3a.5.5 0 0 1-.5-.5V4z\"}}]})(props);\n};\nexport function BsCalendar2EventFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zM11.5 7a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1z\"}}]})(props);\n};\nexport function BsCalendar2Event (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7.5a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 2a1 1 0 0 0-1 1v11a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 4a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5H3a.5.5 0 0 1-.5-.5V4z\"}}]})(props);\n};\nexport function BsCalendar2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 .5a.5.5 0 0 0-1 0V1H2a2 2 0 0 0-2 2v11a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V3a2 2 0 0 0-2-2h-1V.5a.5.5 0 0 0-1 0V1H4V.5zM2.545 3h10.91c.3 0 .545.224.545.5v1c0 .276-.244.5-.546.5H2.545C2.245 5 2 4.776 2 4.5v-1c0-.276.244-.5.545-.5z\"}}]})(props);\n};\nexport function BsCalendar2MinusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zM6 10a.5.5 0 0 0 0 1h4a.5.5 0 0 0 0-1H6z\"}}]})(props);\n};\nexport function BsCalendar2Minus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 10.5A.5.5 0 0 1 6 10h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 2a1 1 0 0 0-1 1v11a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 4a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5H3a.5.5 0 0 1-.5-.5V4z\"}}]})(props);\n};\nexport function BsCalendar2MonthFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.104 7.805 4.9 10.18H3.284l.8-2.375h.02zm9.074 2.297c0-.832-.414-1.36-1.062-1.36-.692 0-1.098.492-1.098 1.36v.253c0 .852.406 1.364 1.098 1.364.671 0 1.062-.516 1.062-1.364v-.253z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zM2.561 12.332 3.1 10.73h1.984l.54 1.602h.718L4.444 7h-.696L1.85 12.332h.71zM9.85 8.227h-.676v2.543c0 .652-.414 1.023-1.004 1.023-.539 0-.98-.246-.98-1.012V8.227h-.676v2.746c0 .941.606 1.425 1.453 1.425.656 0 1.043-.28 1.188-.605h.027v.539h.668V8.227zm1.273 4.41h-.687c.094.683.625 1.199 1.668 1.199.93 0 1.746-.527 1.746-1.578V8.227h-.649v.578h-.019c-.191-.348-.637-.64-1.195-.64-.965 0-1.64.679-1.64 1.886v.34c0 1.23.683 1.902 1.64 1.902.558 0 1.008-.293 1.172-.648h.02v.605c0 .645-.423 1.023-1.071 1.023-.563 0-.91-.304-.985-.636z\"}}]})(props);\n};\nexport function BsCalendar2Month (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m2.56 12.332.54-1.602h1.984l.54 1.602h.718L4.444 7h-.696L1.85 12.332h.71zm1.544-4.527L4.9 10.18H3.284l.8-2.375h.02zm5.746.422h-.676v2.543c0 .652-.414 1.023-1.004 1.023-.539 0-.98-.246-.98-1.012V8.227h-.676v2.746c0 .941.606 1.425 1.453 1.425.656 0 1.043-.28 1.188-.605h.027v.539h.668V8.227zm2.258 5.046c-.563 0-.91-.304-.985-.636h-.687c.094.683.625 1.199 1.668 1.199.93 0 1.746-.527 1.746-1.578V8.227h-.649v.578h-.019c-.191-.348-.637-.64-1.195-.64-.965 0-1.64.679-1.64 1.886v.34c0 1.23.683 1.902 1.64 1.902.558 0 1.008-.293 1.172-.648h.02v.605c0 .645-.423 1.023-1.071 1.023zm.008-4.53c.648 0 1.062.527 1.062 1.359v.253c0 .848-.39 1.364-1.062 1.364-.692 0-1.098-.512-1.098-1.364v-.253c0-.868.406-1.36 1.098-1.36z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 2a1 1 0 0 0-1 1v11a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 4a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5H3a.5.5 0 0 1-.5-.5V4z\"}}]})(props);\n};\nexport function BsCalendar2PlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 3.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5H2.545c-.3 0-.545.224-.545.5zm6.5 5a.5.5 0 0 0-1 0V10H6a.5.5 0 0 0 0 1h1.5v1.5a.5.5 0 0 0 1 0V11H10a.5.5 0 0 0 0-1H8.5V8.5z\"}}]})(props);\n};\nexport function BsCalendar2Plus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 2a1 1 0 0 0-1 1v11a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 4a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5H3a.5.5 0 0 1-.5-.5V4zM8 8a.5.5 0 0 1 .5.5V10H10a.5.5 0 0 1 0 1H8.5v1.5a.5.5 0 0 1-1 0V11H6a.5.5 0 0 1 0-1h1.5V8.5A.5.5 0 0 1 8 8z\"}}]})(props);\n};\nexport function BsCalendar2RangeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zM10 7a1 1 0 0 0 0 2h5V7h-5zm-4 4a1 1 0 0 0-1-1H1v2h4a1 1 0 0 0 1-1z\"}}]})(props);\n};\nexport function BsCalendar2Range (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 2a1 1 0 0 0-1 1v11a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 4a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5H3a.5.5 0 0 1-.5-.5V4zM9 8a1 1 0 0 1 1-1h5v2h-5a1 1 0 0 1-1-1zm-8 2h4a1 1 0 1 1 0 2H1v-2z\"}}]})(props);\n};\nexport function BsCalendar2WeekFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zM8.5 7a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zm3 0a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zM3 10.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5zm3.5-.5a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1z\"}}]})(props);\n};\nexport function BsCalendar2Week (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 2a1 1 0 0 0-1 1v11a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 4a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5H3a.5.5 0 0 1-.5-.5V4zM11 7.5a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm-3 0a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm-5 3a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm3 0a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1z\"}}]})(props);\n};\nexport function BsCalendar2XFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zm9.954 3H2.545c-.3 0-.545.224-.545.5v1c0 .276.244.5.545.5h10.91c.3 0 .545-.224.545-.5v-1c0-.276-.244-.5-.546-.5zm-6.6 5.146a.5.5 0 1 0-.708.708L7.293 10l-1.147 1.146a.5.5 0 0 0 .708.708L8 10.707l1.146 1.147a.5.5 0 0 0 .708-.708L8.707 10l1.147-1.146a.5.5 0 0 0-.708-.708L8 9.293 6.854 8.146z\"}}]})(props);\n};\nexport function BsCalendar2X (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.146 8.146a.5.5 0 0 1 .708 0L8 9.293l1.146-1.147a.5.5 0 1 1 .708.708L8.707 10l1.147 1.146a.5.5 0 0 1-.708.708L8 10.707l-1.146 1.147a.5.5 0 0 1-.708-.708L7.293 10 6.146 8.854a.5.5 0 0 1 0-.708z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 2a1 1 0 0 0-1 1v11a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 4a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5H3a.5.5 0 0 1-.5-.5V4z\"}}]})(props);\n};\nexport function BsCalendar2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 2a1 1 0 0 0-1 1v11a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 4a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5H3a.5.5 0 0 1-.5-.5V4z\"}}]})(props);\n};\nexport function BsCalendar3EventFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 0a2 2 0 0 0-2 2h16a2 2 0 0 0-2-2H2zM0 14V3h16v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm12-8a1 1 0 1 0 2 0 1 1 0 0 0-2 0z\"}}]})(props);\n};\nexport function BsCalendar3Event (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 0H2a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM1 3.857C1 3.384 1.448 3 2 3h12c.552 0 1 .384 1 .857v10.286c0 .473-.448.857-1 .857H2c-.552 0-1-.384-1-.857V3.857z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsCalendar3Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2H0zm0 1v11a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V3H0z\"}}]})(props);\n};\nexport function BsCalendar3RangeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 0a2 2 0 0 0-2 2h16a2 2 0 0 0-2-2H2zM0 8V3h16v2h-6a1 1 0 1 0 0 2h6v7a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2v-4h6a1 1 0 1 0 0-2H0z\"}}]})(props);\n};\nexport function BsCalendar3Range (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 0H2a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM1 3.857C1 3.384 1.448 3 2 3h12c.552 0 1 .384 1 .857v10.286c0 .473-.448.857-1 .857H2c-.552 0-1-.384-1-.857V3.857z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 10a1 1 0 0 0 0-2H1v2h6zm2-3h6V5H9a1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsCalendar3WeekFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 0a2 2 0 0 0-2 2h16a2 2 0 0 0-2-2H2zM0 14V3h16v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm12-8a1 1 0 1 0 2 0 1 1 0 0 0-2 0zM5 9a1 1 0 1 0 2 0 1 1 0 0 0-2 0zm5-2a1 1 0 1 1 0-2 1 1 0 0 1 0 2zM2 9a1 1 0 1 0 2 0 1 1 0 0 0-2 0z\"}}]})(props);\n};\nexport function BsCalendar3Week (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 0H2a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM1 3.857C1 3.384 1.448 3 2 3h12c.552 0 1 .384 1 .857v10.286c0 .473-.448.857-1 .857H2c-.552 0-1-.384-1-.857V3.857z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 7a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm-5 3a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm2-3a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm-5 3a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsCalendar3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 0H2a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM1 3.857C1 3.384 1.448 3 2 3h12c.552 0 1 .384 1 .857v10.286c0 .473-.448.857-1 .857H2c-.552 0-1-.384-1-.857V3.857z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 7a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm3 0a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm3 0a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm-9 3a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm3 0a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm3 0a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm3 0a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm-9 3a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm3 0a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm3 0a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsCalendar4Event (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 2a1 1 0 0 0-1 1v1h14V3a1 1 0 0 0-1-1H2zm13 3H1v9a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7.5a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1z\"}}]})(props);\n};\nexport function BsCalendar4Range (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 2a1 1 0 0 0-1 1v1h14V3a1 1 0 0 0-1-1H2zm13 3H1v9a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 7.5a.5.5 0 0 1 .5-.5H15v2H9.5a.5.5 0 0 1-.5-.5v-1zm-2 3v1a.5.5 0 0 1-.5.5H1v-2h5.5a.5.5 0 0 1 .5.5z\"}}]})(props);\n};\nexport function BsCalendar4Week (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 2a1 1 0 0 0-1 1v1h14V3a1 1 0 0 0-1-1H2zm13 3H1v9a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 7.5a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm-3 0a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm-2 3a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm-3 0a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1z\"}}]})(props);\n};\nexport function BsCalendar4 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM2 2a1 1 0 0 0-1 1v1h14V3a1 1 0 0 0-1-1H2zm13 3H1v9a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V5z\"}}]})(props);\n};\nexport function BsCameraFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 8.5a2.5 2.5 0 1 1-5 0 2.5 2.5 0 0 1 5 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 4a2 2 0 0 0-2 2v6a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2h-1.172a2 2 0 0 1-1.414-.586l-.828-.828A2 2 0 0 0 9.172 2H6.828a2 2 0 0 0-1.414.586l-.828.828A2 2 0 0 1 3.172 4H2zm.5 2a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm9 2.5a3.5 3.5 0 1 1-7 0 3.5 3.5 0 0 1 7 0z\"}}]})(props);\n};\nexport function BsCameraReelsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 3a3 3 0 1 1-6 0 3 3 0 0 1 6 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 6a3 3 0 1 1 0-6 3 3 0 0 1 0 6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 6h.5a2 2 0 0 1 1.983 1.738l3.11-1.382A1 1 0 0 1 16 7.269v7.462a1 1 0 0 1-1.406.913l-3.111-1.382A2 2 0 0 1 9.5 16H2a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h7z\"}}]})(props);\n};\nexport function BsCameraReels (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 3a3 3 0 1 1-6 0 3 3 0 0 1 6 0zM1 3a2 2 0 1 0 4 0 2 2 0 0 0-4 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 6h.5a2 2 0 0 1 1.983 1.738l3.11-1.382A1 1 0 0 1 16 7.269v7.462a1 1 0 0 1-1.406.913l-3.111-1.382A2 2 0 0 1 9.5 16H2a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h7zm6 8.73V7.27l-3.5 1.555v4.35l3.5 1.556zM1 8v6a1 1 0 0 0 1 1h7.5a1 1 0 0 0 1-1V8a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 6a3 3 0 1 0 0-6 3 3 0 0 0 0 6zM7 3a2 2 0 1 1 4 0 2 2 0 0 1-4 0z\"}}]})(props);\n};\nexport function BsCameraVideoFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M0 5a2 2 0 0 1 2-2h7.5a2 2 0 0 1 1.983 1.738l3.11-1.382A1 1 0 0 1 16 4.269v7.462a1 1 0 0 1-1.406.913l-3.111-1.382A2 2 0 0 1 9.5 13H2a2 2 0 0 1-2-2V5z\"}}]})(props);\n};\nexport function BsCameraVideoOffFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.961 12.365a1.99 1.99 0 0 0 .522-1.103l3.11 1.382A1 1 0 0 0 16 11.731V4.269a1 1 0 0 0-1.406-.913l-3.111 1.382A2 2 0 0 0 9.5 3H4.272l6.69 9.365zm-10.114-9A2.001 2.001 0 0 0 0 5v6a2 2 0 0 0 2 2h5.728L.847 3.366zm9.746 11.925-10-14 .814-.58 10 14-.814.58z\"}}]})(props);\n};\nexport function BsCameraVideoOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.961 12.365a1.99 1.99 0 0 0 .522-1.103l3.11 1.382A1 1 0 0 0 16 11.731V4.269a1 1 0 0 0-1.406-.913l-3.111 1.382A2 2 0 0 0 9.5 3H4.272l.714 1H9.5a1 1 0 0 1 1 1v6a1 1 0 0 1-.144.518l.605.847zM1.428 4.18A.999.999 0 0 0 1 5v6a1 1 0 0 0 1 1h5.014l.714 1H2a2 2 0 0 1-2-2V5c0-.675.334-1.272.847-1.634l.58.814zM15 11.73l-3.5-1.555v-4.35L15 4.269v7.462zm-4.407 3.56-10-14 .814-.58 10 14-.814.58z\"}}]})(props);\n};\nexport function BsCameraVideo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M0 5a2 2 0 0 1 2-2h7.5a2 2 0 0 1 1.983 1.738l3.11-1.382A1 1 0 0 1 16 4.269v7.462a1 1 0 0 1-1.406.913l-3.111-1.382A2 2 0 0 1 9.5 13H2a2 2 0 0 1-2-2V5zm11.5 5.175 3.5 1.556V4.269l-3.5 1.556v4.35zM2 4a1 1 0 0 0-1 1v6a1 1 0 0 0 1 1h7.5a1 1 0 0 0 1-1V5a1 1 0 0 0-1-1H2z\"}}]})(props);\n};\nexport function BsCamera (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15 12a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V6a1 1 0 0 1 1-1h1.172a3 3 0 0 0 2.12-.879l.83-.828A1 1 0 0 1 6.827 3h2.344a1 1 0 0 1 .707.293l.828.828A3 3 0 0 0 12.828 5H14a1 1 0 0 1 1 1v6zM2 4a2 2 0 0 0-2 2v6a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2h-1.172a2 2 0 0 1-1.414-.586l-.828-.828A2 2 0 0 0 9.172 2H6.828a2 2 0 0 0-1.414.586l-.828.828A2 2 0 0 1 3.172 4H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11a2.5 2.5 0 1 1 0-5 2.5 2.5 0 0 1 0 5zm0 1a3.5 3.5 0 1 0 0-7 3.5 3.5 0 0 0 0 7zM3 6.5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsCamera2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 8c0-1.657 2.343-3 4-3V4a4 4 0 0 0-4 4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.318 3h2.015C15.253 3 16 3.746 16 4.667v6.666c0 .92-.746 1.667-1.667 1.667h-2.015A5.97 5.97 0 0 1 9 14a5.972 5.972 0 0 1-3.318-1H1.667C.747 13 0 12.254 0 11.333V4.667C0 3.747.746 3 1.667 3H2a1 1 0 0 1 1-1h1a1 1 0 0 1 1 1h.682A5.97 5.97 0 0 1 9 2c1.227 0 2.367.368 3.318 1zM2 4.5a.5.5 0 1 0-1 0 .5.5 0 0 0 1 0zM14 8A5 5 0 1 0 4 8a5 5 0 0 0 10 0z\"}}]})(props);\n};\nexport function BsCapslockFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.27 1.047a1 1 0 0 1 1.46 0l6.345 6.77c.6.638.146 1.683-.73 1.683H11.5v1a1 1 0 0 1-1 1h-5a1 1 0 0 1-1-1v-1H1.654C.78 9.5.326 8.455.924 7.816L7.27 1.047zM4.5 13.5a1 1 0 0 1 1-1h5a1 1 0 0 1 1 1v1a1 1 0 0 1-1 1h-5a1 1 0 0 1-1-1v-1z\"}}]})(props);\n};\nexport function BsCapslock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.27 1.047a1 1 0 0 1 1.46 0l6.345 6.77c.6.638.146 1.683-.73 1.683H11.5v1a1 1 0 0 1-1 1h-5a1 1 0 0 1-1-1v-1H1.654C.78 9.5.326 8.455.924 7.816L7.27 1.047zM14.346 8.5 8 1.731 1.654 8.5H4.5a1 1 0 0 1 1 1v1h5v-1a1 1 0 0 1 1-1h2.846zm-9.846 5a1 1 0 0 1 1-1h5a1 1 0 0 1 1 1v1a1 1 0 0 1-1 1h-5a1 1 0 0 1-1-1v-1zm6 0h-5v1h5v-1z\"}}]})(props);\n};\nexport function BsCardChecklist (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14.5 3a.5.5 0 0 1 .5.5v9a.5.5 0 0 1-.5.5h-13a.5.5 0 0 1-.5-.5v-9a.5.5 0 0 1 .5-.5h13zm-13-1A1.5 1.5 0 0 0 0 3.5v9A1.5 1.5 0 0 0 1.5 14h13a1.5 1.5 0 0 0 1.5-1.5v-9A1.5 1.5 0 0 0 14.5 2h-13z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 5.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm-1.496-.854a.5.5 0 0 1 0 .708l-1.5 1.5a.5.5 0 0 1-.708 0l-.5-.5a.5.5 0 1 1 .708-.708l.146.147 1.146-1.147a.5.5 0 0 1 .708 0zM7 9.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm-1.496-.854a.5.5 0 0 1 0 .708l-1.5 1.5a.5.5 0 0 1-.708 0l-.5-.5a.5.5 0 0 1 .708-.708l.146.147 1.146-1.147a.5.5 0 0 1 .708 0z\"}}]})(props);\n};\nexport function BsCardHeading (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14.5 3a.5.5 0 0 1 .5.5v9a.5.5 0 0 1-.5.5h-13a.5.5 0 0 1-.5-.5v-9a.5.5 0 0 1 .5-.5h13zm-13-1A1.5 1.5 0 0 0 0 3.5v9A1.5 1.5 0 0 0 1.5 14h13a1.5 1.5 0 0 0 1.5-1.5v-9A1.5 1.5 0 0 0 14.5 2h-13z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 8.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5zm0-5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-9a.5.5 0 0 1-.5-.5v-1z\"}}]})(props);\n};\nexport function BsCardImage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.002 5.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 2A1.5 1.5 0 0 0 0 3.5v9A1.5 1.5 0 0 0 1.5 14h13a1.5 1.5 0 0 0 1.5-1.5v-9A1.5 1.5 0 0 0 14.5 2h-13zm13 1a.5.5 0 0 1 .5.5v6l-3.775-1.947a.5.5 0 0 0-.577.093l-3.71 3.71-2.66-1.772a.5.5 0 0 0-.63.062L1.002 12v.54A.505.505 0 0 1 1 12.5v-9a.5.5 0 0 1 .5-.5h13z\"}}]})(props);\n};\nexport function BsCardList (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14.5 3a.5.5 0 0 1 .5.5v9a.5.5 0 0 1-.5.5h-13a.5.5 0 0 1-.5-.5v-9a.5.5 0 0 1 .5-.5h13zm-13-1A1.5 1.5 0 0 0 0 3.5v9A1.5 1.5 0 0 0 1.5 14h13a1.5 1.5 0 0 0 1.5-1.5v-9A1.5 1.5 0 0 0 14.5 2h-13z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 8a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7A.5.5 0 0 1 5 8zm0-2.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm0 5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm-1-5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zM4 8a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm0 2.5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsCardText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14.5 3a.5.5 0 0 1 .5.5v9a.5.5 0 0 1-.5.5h-13a.5.5 0 0 1-.5-.5v-9a.5.5 0 0 1 .5-.5h13zm-13-1A1.5 1.5 0 0 0 0 3.5v9A1.5 1.5 0 0 0 1.5 14h13a1.5 1.5 0 0 0 1.5-1.5v-9A1.5 1.5 0 0 0 14.5 2h-13z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 5.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zM3 8a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9A.5.5 0 0 1 3 8zm0 2.5a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsCaretDownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z\"}}]})(props);\n};\nexport function BsCaretDownSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm4 4a.5.5 0 0 0-.374.832l4 4.5a.5.5 0 0 0 .748 0l4-4.5A.5.5 0 0 0 12 6H4z\"}}]})(props);\n};\nexport function BsCaretDownSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.626 6.832A.5.5 0 0 1 4 6h8a.5.5 0 0 1 .374.832l-4 4.5a.5.5 0 0 1-.748 0l-4-4.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm15 0a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V2z\"}}]})(props);\n};\nexport function BsCaretDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.204 5h9.592L8 10.481 3.204 5zm-.753.659 4.796 5.48a1 1 0 0 0 1.506 0l4.796-5.48c.566-.647.106-1.659-.753-1.659H3.204a1 1 0 0 0-.753 1.659z\"}}]})(props);\n};\nexport function BsCaretLeftFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m3.86 8.753 5.482 4.796c.646.566 1.658.106 1.658-.753V3.204a1 1 0 0 0-1.659-.753l-5.48 4.796a1 1 0 0 0 0 1.506z\"}}]})(props);\n};\nexport function BsCaretLeftSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm10.5 10V4a.5.5 0 0 0-.832-.374l-4.5 4a.5.5 0 0 0 0 .748l4.5 4A.5.5 0 0 0 10.5 12z\"}}]})(props);\n};\nexport function BsCaretLeftSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.205 12.456A.5.5 0 0 0 10.5 12V4a.5.5 0 0 0-.832-.374l-4.5 4a.5.5 0 0 0 0 .748l4.5 4a.5.5 0 0 0 .537.082z\"}}]})(props);\n};\nexport function BsCaretLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10 12.796V3.204L4.519 8 10 12.796zm-.659.753-5.48-4.796a1 1 0 0 1 0-1.506l5.48-4.796A1 1 0 0 1 11 3.204v9.592a1 1 0 0 1-1.659.753z\"}}]})(props);\n};\nexport function BsCaretRightFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m12.14 8.753-5.482 4.796c-.646.566-1.658.106-1.658-.753V3.204a1 1 0 0 1 1.659-.753l5.48 4.796a1 1 0 0 1 0 1.506z\"}}]})(props);\n};\nexport function BsCaretRightSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm5.5 10a.5.5 0 0 0 .832.374l4.5-4a.5.5 0 0 0 0-.748l-4.5-4A.5.5 0 0 0 5.5 4v8z\"}}]})(props);\n};\nexport function BsCaretRightSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.795 12.456A.5.5 0 0 1 5.5 12V4a.5.5 0 0 1 .832-.374l4.5 4a.5.5 0 0 1 0 .748l-4.5 4a.5.5 0 0 1-.537.082z\"}}]})(props);\n};\nexport function BsCaretRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12.796V3.204L11.481 8 6 12.796zm.659.753 5.48-4.796a1 1 0 0 0 0-1.506L6.66 2.451C6.011 1.885 5 2.345 5 3.204v9.592a1 1 0 0 0 1.659.753z\"}}]})(props);\n};\nexport function BsCaretUpFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m7.247 4.86-4.796 5.481c-.566.647-.106 1.659.753 1.659h9.592a1 1 0 0 0 .753-1.659l-4.796-5.48a1 1 0 0 0-1.506 0z\"}}]})(props);\n};\nexport function BsCaretUpSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm4 9h8a.5.5 0 0 0 .374-.832l-4-4.5a.5.5 0 0 0-.748 0l-4 4.5A.5.5 0 0 0 4 11z\"}}]})(props);\n};\nexport function BsCaretUpSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.544 10.705A.5.5 0 0 0 4 11h8a.5.5 0 0 0 .374-.832l-4-4.5a.5.5 0 0 0-.748 0l-4 4.5a.5.5 0 0 0-.082.537z\"}}]})(props);\n};\nexport function BsCaretUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.204 11h9.592L8 5.519 3.204 11zm-.753-.659 4.796-5.48a1 1 0 0 1 1.506 0l4.796 5.48c.566.647.106 1.659-.753 1.659H3.204a1 1 0 0 1-.753-1.659z\"}}]})(props);\n};\nexport function BsCartCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 1a.5.5 0 0 0 0 1h1.11l.401 1.607 1.498 7.985A.5.5 0 0 0 4 12h1a2 2 0 1 0 0 4 2 2 0 0 0 0-4h7a2 2 0 1 0 0 4 2 2 0 0 0 0-4h1a.5.5 0 0 0 .491-.408l1.5-8A.5.5 0 0 0 14.5 3H2.89l-.405-1.621A.5.5 0 0 0 2 1H.5zM6 14a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm7 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm-1.646-7.646-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L8 8.293l2.646-2.647a.5.5 0 0 1 .708.708z\"}}]})(props);\n};\nexport function BsCartCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.354 6.354a.5.5 0 0 0-.708-.708L8 8.293 6.854 7.146a.5.5 0 1 0-.708.708l1.5 1.5a.5.5 0 0 0 .708 0l3-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 1a.5.5 0 0 0 0 1h1.11l.401 1.607 1.498 7.985A.5.5 0 0 0 4 12h1a2 2 0 1 0 0 4 2 2 0 0 0 0-4h7a2 2 0 1 0 0 4 2 2 0 0 0 0-4h1a.5.5 0 0 0 .491-.408l1.5-8A.5.5 0 0 0 14.5 3H2.89l-.405-1.621A.5.5 0 0 0 2 1H.5zm3.915 10L3.102 4h10.796l-1.313 7h-8.17zM6 14a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm7 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0z\"}}]})(props);\n};\nexport function BsCartDashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 1a.5.5 0 0 0 0 1h1.11l.401 1.607 1.498 7.985A.5.5 0 0 0 4 12h1a2 2 0 1 0 0 4 2 2 0 0 0 0-4h7a2 2 0 1 0 0 4 2 2 0 0 0 0-4h1a.5.5 0 0 0 .491-.408l1.5-8A.5.5 0 0 0 14.5 3H2.89l-.405-1.621A.5.5 0 0 0 2 1H.5zM6 14a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm7 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zM6.5 7h4a.5.5 0 0 1 0 1h-4a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsCartDash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 7a.5.5 0 0 0 0 1h4a.5.5 0 0 0 0-1h-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 1a.5.5 0 0 0 0 1h1.11l.401 1.607 1.498 7.985A.5.5 0 0 0 4 12h1a2 2 0 1 0 0 4 2 2 0 0 0 0-4h7a2 2 0 1 0 0 4 2 2 0 0 0 0-4h1a.5.5 0 0 0 .491-.408l1.5-8A.5.5 0 0 0 14.5 3H2.89l-.405-1.621A.5.5 0 0 0 2 1H.5zm3.915 10L3.102 4h10.796l-1.313 7h-8.17zM6 14a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm7 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0z\"}}]})(props);\n};\nexport function BsCartFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1.5A.5.5 0 0 1 .5 1H2a.5.5 0 0 1 .485.379L2.89 3H14.5a.5.5 0 0 1 .491.592l-1.5 8A.5.5 0 0 1 13 12H4a.5.5 0 0 1-.491-.408L2.01 3.607 1.61 2H.5a.5.5 0 0 1-.5-.5zM5 12a2 2 0 1 0 0 4 2 2 0 0 0 0-4zm7 0a2 2 0 1 0 0 4 2 2 0 0 0 0-4zm-7 1a1 1 0 1 1 0 2 1 1 0 0 1 0-2zm7 0a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\"}}]})(props);\n};\nexport function BsCartPlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 1a.5.5 0 0 0 0 1h1.11l.401 1.607 1.498 7.985A.5.5 0 0 0 4 12h1a2 2 0 1 0 0 4 2 2 0 0 0 0-4h7a2 2 0 1 0 0 4 2 2 0 0 0 0-4h1a.5.5 0 0 0 .491-.408l1.5-8A.5.5 0 0 0 14.5 3H2.89l-.405-1.621A.5.5 0 0 0 2 1H.5zM6 14a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm7 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zM9 5.5V7h1.5a.5.5 0 0 1 0 1H9v1.5a.5.5 0 0 1-1 0V8H6.5a.5.5 0 0 1 0-1H8V5.5a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsCartPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5.5a.5.5 0 0 0-1 0V7H6.5a.5.5 0 0 0 0 1H8v1.5a.5.5 0 0 0 1 0V8h1.5a.5.5 0 0 0 0-1H9V5.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 1a.5.5 0 0 0 0 1h1.11l.401 1.607 1.498 7.985A.5.5 0 0 0 4 12h1a2 2 0 1 0 0 4 2 2 0 0 0 0-4h7a2 2 0 1 0 0 4 2 2 0 0 0 0-4h1a.5.5 0 0 0 .491-.408l1.5-8A.5.5 0 0 0 14.5 3H2.89l-.405-1.621A.5.5 0 0 0 2 1H.5zm3.915 10L3.102 4h10.796l-1.313 7h-8.17zM6 14a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm7 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0z\"}}]})(props);\n};\nexport function BsCartXFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 1a.5.5 0 0 0 0 1h1.11l.401 1.607 1.498 7.985A.5.5 0 0 0 4 12h1a2 2 0 1 0 0 4 2 2 0 0 0 0-4h7a2 2 0 1 0 0 4 2 2 0 0 0 0-4h1a.5.5 0 0 0 .491-.408l1.5-8A.5.5 0 0 0 14.5 3H2.89l-.405-1.621A.5.5 0 0 0 2 1H.5zM6 14a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm7 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zM7.354 5.646 8.5 6.793l1.146-1.147a.5.5 0 0 1 .708.708L9.207 7.5l1.147 1.146a.5.5 0 0 1-.708.708L8.5 8.207 7.354 9.354a.5.5 0 1 1-.708-.708L7.793 7.5 6.646 6.354a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsCartX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.354 5.646a.5.5 0 1 0-.708.708L7.793 7.5 6.646 8.646a.5.5 0 1 0 .708.708L8.5 8.207l1.146 1.147a.5.5 0 0 0 .708-.708L9.207 7.5l1.147-1.146a.5.5 0 0 0-.708-.708L8.5 6.793 7.354 5.646z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 1a.5.5 0 0 0 0 1h1.11l.401 1.607 1.498 7.985A.5.5 0 0 0 4 12h1a2 2 0 1 0 0 4 2 2 0 0 0 0-4h7a2 2 0 1 0 0 4 2 2 0 0 0 0-4h1a.5.5 0 0 0 .491-.408l1.5-8A.5.5 0 0 0 14.5 3H2.89l-.405-1.621A.5.5 0 0 0 2 1H.5zm3.915 10L3.102 4h10.796l-1.313 7h-8.17zM6 14a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm7 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0z\"}}]})(props);\n};\nexport function BsCart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1.5A.5.5 0 0 1 .5 1H2a.5.5 0 0 1 .485.379L2.89 3H14.5a.5.5 0 0 1 .491.592l-1.5 8A.5.5 0 0 1 13 12H4a.5.5 0 0 1-.491-.408L2.01 3.607 1.61 2H.5a.5.5 0 0 1-.5-.5zM3.102 4l1.313 7h8.17l1.313-7H3.102zM5 12a2 2 0 1 0 0 4 2 2 0 0 0 0-4zm7 0a2 2 0 1 0 0 4 2 2 0 0 0 0-4zm-7 1a1 1 0 1 1 0 2 1 1 0 0 1 0-2zm7 0a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\"}}]})(props);\n};\nexport function BsCart2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2.5A.5.5 0 0 1 .5 2H2a.5.5 0 0 1 .485.379L2.89 4H14.5a.5.5 0 0 1 .485.621l-1.5 6A.5.5 0 0 1 13 11H4a.5.5 0 0 1-.485-.379L1.61 3H.5a.5.5 0 0 1-.5-.5zM3.14 5l1.25 5h8.22l1.25-5H3.14zM5 13a1 1 0 1 0 0 2 1 1 0 0 0 0-2zm-2 1a2 2 0 1 1 4 0 2 2 0 0 1-4 0zm9-1a1 1 0 1 0 0 2 1 1 0 0 0 0-2zm-2 1a2 2 0 1 1 4 0 2 2 0 0 1-4 0z\"}}]})(props);\n};\nexport function BsCart3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1.5A.5.5 0 0 1 .5 1H2a.5.5 0 0 1 .485.379L2.89 3H14.5a.5.5 0 0 1 .49.598l-1 5a.5.5 0 0 1-.465.401l-9.397.472L4.415 11H13a.5.5 0 0 1 0 1H4a.5.5 0 0 1-.491-.408L2.01 3.607 1.61 2H.5a.5.5 0 0 1-.5-.5zM3.102 4l.84 4.479 9.144-.459L13.89 4H3.102zM5 12a2 2 0 1 0 0 4 2 2 0 0 0 0-4zm7 0a2 2 0 1 0 0 4 2 2 0 0 0 0-4zm-7 1a1 1 0 1 1 0 2 1 1 0 0 1 0-2zm7 0a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\"}}]})(props);\n};\nexport function BsCart4 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2.5A.5.5 0 0 1 .5 2H2a.5.5 0 0 1 .485.379L2.89 4H14.5a.5.5 0 0 1 .485.621l-1.5 6A.5.5 0 0 1 13 11H4a.5.5 0 0 1-.485-.379L1.61 3H.5a.5.5 0 0 1-.5-.5zM3.14 5l.5 2H5V5H3.14zM6 5v2h2V5H6zm3 0v2h2V5H9zm3 0v2h1.36l.5-2H12zm1.11 3H12v2h.61l.5-2zM11 8H9v2h2V8zM8 8H6v2h2V8zM5 8H3.89l.5 2H5V8zm0 5a1 1 0 1 0 0 2 1 1 0 0 0 0-2zm-2 1a2 2 0 1 1 4 0 2 2 0 0 1-4 0zm9-1a1 1 0 1 0 0 2 1 1 0 0 0 0-2zm-2 1a2 2 0 1 1 4 0 2 2 0 0 1-4 0z\"}}]})(props);\n};\nexport function BsCashCoin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11 15a4 4 0 1 0 0-8 4 4 0 0 0 0 8zm5-4a5 5 0 1 1-10 0 5 5 0 0 1 10 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.438 11.944c.047.596.518 1.06 1.363 1.116v.44h.375v-.443c.875-.061 1.386-.529 1.386-1.207 0-.618-.39-.936-1.09-1.1l-.296-.07v-1.2c.376.043.614.248.671.532h.658c-.047-.575-.54-1.024-1.329-1.073V8.5h-.375v.45c-.747.073-1.255.522-1.255 1.158 0 .562.378.92 1.007 1.066l.248.061v1.272c-.384-.058-.639-.27-.696-.563h-.668zm1.36-1.354c-.369-.085-.569-.26-.569-.522 0-.294.216-.514.572-.578v1.1h-.003zm.432.746c.449.104.655.272.655.569 0 .339-.257.571-.709.614v-1.195l.054.012z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 0a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h4.083c.058-.344.145-.678.258-1H3a2 2 0 0 0-2-2V3a2 2 0 0 0 2-2h10a2 2 0 0 0 2 2v3.528c.38.34.717.728 1 1.154V1a1 1 0 0 0-1-1H1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.998 5.083 10 5a2 2 0 1 0-3.132 1.65 5.982 5.982 0 0 1 3.13-1.567z\"}}]})(props);\n};\nexport function BsCashStack (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 3a1 1 0 0 1 1-1h12a1 1 0 0 1 1 1H1zm7 8a2 2 0 1 0 0-4 2 2 0 0 0 0 4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 5a1 1 0 0 1 1-1h14a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H1a1 1 0 0 1-1-1V5zm3 0a2 2 0 0 1-2 2v4a2 2 0 0 1 2 2h10a2 2 0 0 1 2-2V7a2 2 0 0 1-2-2H3z\"}}]})(props);\n};\nexport function BsCash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 10a2 2 0 1 0 0-4 2 2 0 0 0 0 4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a1 1 0 0 1 1-1h14a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H1a1 1 0 0 1-1-1V4zm3 0a2 2 0 0 1-2 2v4a2 2 0 0 1 2 2h10a2 2 0 0 1 2-2V6a2 2 0 0 1-2-2H3z\"}}]})(props);\n};\nexport function BsCast (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m7.646 9.354-3.792 3.792a.5.5 0 0 0 .353.854h7.586a.5.5 0 0 0 .354-.854L8.354 9.354a.5.5 0 0 0-.708 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.414 11H14.5a.5.5 0 0 0 .5-.5v-7a.5.5 0 0 0-.5-.5h-13a.5.5 0 0 0-.5.5v7a.5.5 0 0 0 .5.5h3.086l-1 1H1.5A1.5 1.5 0 0 1 0 10.5v-7A1.5 1.5 0 0 1 1.5 2h13A1.5 1.5 0 0 1 16 3.5v7a1.5 1.5 0 0 1-1.5 1.5h-2.086l-1-1z\"}}]})(props);\n};\nexport function BsChatDotsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8c0 3.866-3.582 7-8 7a9.06 9.06 0 0 1-2.347-.306c-.584.296-1.925.864-4.181 1.234-.2.032-.352-.176-.273-.362.354-.836.674-1.95.77-2.966C.744 11.37 0 9.76 0 8c0-3.866 3.582-7 8-7s8 3.134 8 7zM5 8a1 1 0 1 0-2 0 1 1 0 0 0 2 0zm4 0a1 1 0 1 0-2 0 1 1 0 0 0 2 0zm3 1a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsChatDots (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 8a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm4 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm3 1a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m2.165 15.803.02-.004c1.83-.363 2.948-.842 3.468-1.105A9.06 9.06 0 0 0 8 15c4.418 0 8-3.134 8-7s-3.582-7-8-7-8 3.134-8 7c0 1.76.743 3.37 1.97 4.6a10.437 10.437 0 0 1-.524 2.318l-.003.011a10.722 10.722 0 0 1-.244.637c-.079.186.074.394.273.362a21.673 21.673 0 0 0 .693-.125zm.8-3.108a1 1 0 0 0-.287-.801C1.618 10.83 1 9.468 1 8c0-3.192 3.004-6 7-6s7 2.808 7 6c0 3.193-3.004 6-7 6a8.06 8.06 0 0 1-2.088-.272 1 1 0 0 0-.711.074c-.387.196-1.24.57-2.634.893a10.97 10.97 0 0 0 .398-2z\"}}]})(props);\n};\nexport function BsChatFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15c4.418 0 8-3.134 8-7s-3.582-7-8-7-8 3.134-8 7c0 1.76.743 3.37 1.97 4.6-.097 1.016-.417 2.13-.771 2.966-.079.186.074.394.273.362 2.256-.37 3.597-.938 4.18-1.234A9.06 9.06 0 0 0 8 15z\"}}]})(props);\n};\nexport function BsChatLeftDotsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H4.414a1 1 0 0 0-.707.293L.854 15.146A.5.5 0 0 1 0 14.793V2zm5 4a1 1 0 1 0-2 0 1 1 0 0 0 2 0zm4 0a1 1 0 1 0-2 0 1 1 0 0 0 2 0zm3 1a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsChatLeftDots (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H4.414A2 2 0 0 0 3 11.586l-2 2V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12.793a.5.5 0 0 0 .854.353l2.853-2.853A1 1 0 0 1 4.414 12H14a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 6a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm4 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm4 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0z\"}}]})(props);\n};\nexport function BsChatLeftFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12.793a.5.5 0 0 0 .854.353l2.853-2.853A1 1 0 0 1 4.414 12H14a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsChatLeftQuoteFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H4.414a1 1 0 0 0-.707.293L.854 15.146A.5.5 0 0 1 0 14.793V2zm7.194 2.766a1.688 1.688 0 0 0-.227-.272 1.467 1.467 0 0 0-.469-.324l-.008-.004A1.785 1.785 0 0 0 5.734 4C4.776 4 4 4.746 4 5.667c0 .92.776 1.666 1.734 1.666.343 0 .662-.095.931-.26-.137.389-.39.804-.81 1.22a.405.405 0 0 0 .011.59c.173.16.447.155.614-.01 1.334-1.329 1.37-2.758.941-3.706a2.461 2.461 0 0 0-.227-.4zM11 7.073c-.136.389-.39.804-.81 1.22a.405.405 0 0 0 .012.59c.172.16.446.155.613-.01 1.334-1.329 1.37-2.758.942-3.706a2.466 2.466 0 0 0-.228-.4 1.686 1.686 0 0 0-.227-.273 1.466 1.466 0 0 0-.469-.324l-.008-.004A1.785 1.785 0 0 0 10.07 4c-.957 0-1.734.746-1.734 1.667 0 .92.777 1.666 1.734 1.666.343 0 .662-.095.931-.26z\"}}]})(props);\n};\nexport function BsChatLeftQuote (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H4.414A2 2 0 0 0 3 11.586l-2 2V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12.793a.5.5 0 0 0 .854.353l2.853-2.853A1 1 0 0 1 4.414 12H14a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.066 4.76A1.665 1.665 0 0 0 4 5.668a1.667 1.667 0 0 0 2.561 1.406c-.131.389-.375.804-.777 1.22a.417.417 0 1 0 .6.58c1.486-1.54 1.293-3.214.682-4.112zm4 0A1.665 1.665 0 0 0 8 5.668a1.667 1.667 0 0 0 2.561 1.406c-.131.389-.375.804-.777 1.22a.417.417 0 1 0 .6.58c1.486-1.54 1.293-3.214.682-4.112z\"}}]})(props);\n};\nexport function BsChatLeftTextFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H4.414a1 1 0 0 0-.707.293L.854 15.146A.5.5 0 0 1 0 14.793V2zm3.5 1a.5.5 0 0 0 0 1h9a.5.5 0 0 0 0-1h-9zm0 2.5a.5.5 0 0 0 0 1h9a.5.5 0 0 0 0-1h-9zm0 2.5a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5z\"}}]})(props);\n};\nexport function BsChatLeftText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H4.414A2 2 0 0 0 3 11.586l-2 2V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12.793a.5.5 0 0 0 .854.353l2.853-2.853A1 1 0 0 1 4.414 12H14a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zM3 6a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9A.5.5 0 0 1 3 6zm0 2.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsChatLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H4.414A2 2 0 0 0 3 11.586l-2 2V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12.793a.5.5 0 0 0 .854.353l2.853-2.853A1 1 0 0 1 4.414 12H14a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsChatQuoteFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8c0 3.866-3.582 7-8 7a9.06 9.06 0 0 1-2.347-.306c-.584.296-1.925.864-4.181 1.234-.2.032-.352-.176-.273-.362.354-.836.674-1.95.77-2.966C.744 11.37 0 9.76 0 8c0-3.866 3.582-7 8-7s8 3.134 8 7zM7.194 6.766a1.688 1.688 0 0 0-.227-.272 1.467 1.467 0 0 0-.469-.324l-.008-.004A1.785 1.785 0 0 0 5.734 6C4.776 6 4 6.746 4 7.667c0 .92.776 1.666 1.734 1.666.343 0 .662-.095.931-.26-.137.389-.39.804-.81 1.22a.405.405 0 0 0 .011.59c.173.16.447.155.614-.01 1.334-1.329 1.37-2.758.941-3.706a2.461 2.461 0 0 0-.227-.4zM11 9.073c-.136.389-.39.804-.81 1.22a.405.405 0 0 0 .012.59c.172.16.446.155.613-.01 1.334-1.329 1.37-2.758.942-3.706a2.466 2.466 0 0 0-.228-.4 1.686 1.686 0 0 0-.227-.273 1.466 1.466 0 0 0-.469-.324l-.008-.004A1.785 1.785 0 0 0 10.07 6c-.957 0-1.734.746-1.734 1.667 0 .92.777 1.666 1.734 1.666.343 0 .662-.095.931-.26z\"}}]})(props);\n};\nexport function BsChatQuote (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.678 11.894a1 1 0 0 1 .287.801 10.97 10.97 0 0 1-.398 2c1.395-.323 2.247-.697 2.634-.893a1 1 0 0 1 .71-.074A8.06 8.06 0 0 0 8 14c3.996 0 7-2.807 7-6 0-3.192-3.004-6-7-6S1 4.808 1 8c0 1.468.617 2.83 1.678 3.894zm-.493 3.905a21.682 21.682 0 0 1-.713.129c-.2.032-.352-.176-.273-.362a9.68 9.68 0 0 0 .244-.637l.003-.01c.248-.72.45-1.548.524-2.319C.743 11.37 0 9.76 0 8c0-3.866 3.582-7 8-7s8 3.134 8 7-3.582 7-8 7a9.06 9.06 0 0 1-2.347-.306c-.52.263-1.639.742-3.468 1.105z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.066 6.76A1.665 1.665 0 0 0 4 7.668a1.667 1.667 0 0 0 2.561 1.406c-.131.389-.375.804-.777 1.22a.417.417 0 0 0 .6.58c1.486-1.54 1.293-3.214.682-4.112zm4 0A1.665 1.665 0 0 0 8 7.668a1.667 1.667 0 0 0 2.561 1.406c-.131.389-.375.804-.777 1.22a.417.417 0 0 0 .6.58c1.486-1.54 1.293-3.214.682-4.112z\"}}]})(props);\n};\nexport function BsChatRightDotsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 2a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h9.586a1 1 0 0 1 .707.293l2.853 2.853a.5.5 0 0 0 .854-.353V2zM5 6a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm4 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm3 1a1 1 0 1 1 0-2 1 1 0 0 1 0 2z\"}}]})(props);\n};\nexport function BsChatRightDots (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h9.586a2 2 0 0 1 1.414.586l2 2V2a1 1 0 0 0-1-1H2zm12-1a2 2 0 0 1 2 2v12.793a.5.5 0 0 1-.854.353l-2.853-2.853a1 1 0 0 0-.707-.293H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 6a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm4 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm4 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0z\"}}]})(props);\n};\nexport function BsChatRightFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 0a2 2 0 0 1 2 2v12.793a.5.5 0 0 1-.854.353l-2.853-2.853a1 1 0 0 0-.707-.293H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12z\"}}]})(props);\n};\nexport function BsChatRightQuoteFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 2a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h9.586a1 1 0 0 1 .707.293l2.853 2.853a.5.5 0 0 0 .854-.353V2zM7.194 4.766c.087.124.163.26.227.401.428.948.393 2.377-.942 3.706a.446.446 0 0 1-.612.01.405.405 0 0 1-.011-.59c.419-.416.672-.831.809-1.22-.269.165-.588.26-.93.26C4.775 7.333 4 6.587 4 5.667 4 4.747 4.776 4 5.734 4c.271 0 .528.06.756.166l.008.004c.169.07.327.182.469.324.085.083.161.174.227.272zM11 7.073c-.269.165-.588.26-.93.26-.958 0-1.735-.746-1.735-1.666 0-.92.777-1.667 1.734-1.667.271 0 .528.06.756.166l.008.004c.17.07.327.182.469.324.085.083.161.174.227.272.087.124.164.26.228.401.428.948.392 2.377-.942 3.706a.446.446 0 0 1-.613.01.405.405 0 0 1-.011-.59c.42-.416.672-.831.81-1.22z\"}}]})(props);\n};\nexport function BsChatRightQuote (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h9.586a2 2 0 0 1 1.414.586l2 2V2a1 1 0 0 0-1-1H2zm12-1a2 2 0 0 1 2 2v12.793a.5.5 0 0 1-.854.353l-2.853-2.853a1 1 0 0 0-.707-.293H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.066 4.76A1.665 1.665 0 0 0 4 5.668a1.667 1.667 0 0 0 2.561 1.406c-.131.389-.375.804-.777 1.22a.417.417 0 1 0 .6.58c1.486-1.54 1.293-3.214.682-4.112zm4 0A1.665 1.665 0 0 0 8 5.668a1.667 1.667 0 0 0 2.561 1.406c-.131.389-.375.804-.777 1.22a.417.417 0 1 0 .6.58c1.486-1.54 1.293-3.214.682-4.112z\"}}]})(props);\n};\nexport function BsChatRightTextFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 2a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h9.586a1 1 0 0 1 .707.293l2.853 2.853a.5.5 0 0 0 .854-.353V2zM3.5 3h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1 0-1zm0 2.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1 0-1zm0 2.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsChatRightText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h9.586a2 2 0 0 1 1.414.586l2 2V2a1 1 0 0 0-1-1H2zm12-1a2 2 0 0 1 2 2v12.793a.5.5 0 0 1-.854.353l-2.853-2.853a1 1 0 0 0-.707-.293H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zM3 6a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9A.5.5 0 0 1 3 6zm0 2.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsChatRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h9.586a2 2 0 0 1 1.414.586l2 2V2a1 1 0 0 0-1-1H2zm12-1a2 2 0 0 1 2 2v12.793a.5.5 0 0 1-.854.353l-2.853-2.853a1 1 0 0 0-.707-.293H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12z\"}}]})(props);\n};\nexport function BsChatSquareDotsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2h-2.5a1 1 0 0 0-.8.4l-1.9 2.533a1 1 0 0 1-1.6 0L5.3 12.4a1 1 0 0 0-.8-.4H2a2 2 0 0 1-2-2V2zm5 4a1 1 0 1 0-2 0 1 1 0 0 0 2 0zm4 0a1 1 0 1 0-2 0 1 1 0 0 0 2 0zm3 1a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsChatSquareDots (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1h-2.5a2 2 0 0 0-1.6.8L8 14.333 6.1 11.8a2 2 0 0 0-1.6-.8H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h2.5a1 1 0 0 1 .8.4l1.9 2.533a1 1 0 0 0 1.6 0l1.9-2.533a1 1 0 0 1 .8-.4H14a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 6a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm4 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm4 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0z\"}}]})(props);\n};\nexport function BsChatSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h2.5a1 1 0 0 1 .8.4l1.9 2.533a1 1 0 0 0 1.6 0l1.9-2.533a1 1 0 0 1 .8-.4H14a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsChatSquareQuoteFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2h-2.5a1 1 0 0 0-.8.4l-1.9 2.533a1 1 0 0 1-1.6 0L5.3 12.4a1 1 0 0 0-.8-.4H2a2 2 0 0 1-2-2V2zm7.194 2.766a1.688 1.688 0 0 0-.227-.272 1.467 1.467 0 0 0-.469-.324l-.008-.004A1.785 1.785 0 0 0 5.734 4C4.776 4 4 4.746 4 5.667c0 .92.776 1.666 1.734 1.666.343 0 .662-.095.931-.26-.137.389-.39.804-.81 1.22a.405.405 0 0 0 .011.59c.173.16.447.155.614-.01 1.334-1.329 1.37-2.758.941-3.706a2.461 2.461 0 0 0-.227-.4zM11 7.073c-.136.389-.39.804-.81 1.22a.405.405 0 0 0 .012.59c.172.16.446.155.613-.01 1.334-1.329 1.37-2.758.942-3.706a2.466 2.466 0 0 0-.228-.4 1.686 1.686 0 0 0-.227-.273 1.466 1.466 0 0 0-.469-.324l-.008-.004A1.785 1.785 0 0 0 10.07 4c-.957 0-1.734.746-1.734 1.667 0 .92.777 1.666 1.734 1.666.343 0 .662-.095.931-.26z\"}}]})(props);\n};\nexport function BsChatSquareQuote (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1h-2.5a2 2 0 0 0-1.6.8L8 14.333 6.1 11.8a2 2 0 0 0-1.6-.8H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h2.5a1 1 0 0 1 .8.4l1.9 2.533a1 1 0 0 0 1.6 0l1.9-2.533a1 1 0 0 1 .8-.4H14a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.066 4.76A1.665 1.665 0 0 0 4 5.668a1.667 1.667 0 0 0 2.561 1.406c-.131.389-.375.804-.777 1.22a.417.417 0 1 0 .6.58c1.486-1.54 1.293-3.214.682-4.112zm4 0A1.665 1.665 0 0 0 8 5.668a1.667 1.667 0 0 0 2.561 1.406c-.131.389-.375.804-.777 1.22a.417.417 0 1 0 .6.58c1.486-1.54 1.293-3.214.682-4.112z\"}}]})(props);\n};\nexport function BsChatSquareTextFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2h-2.5a1 1 0 0 0-.8.4l-1.9 2.533a1 1 0 0 1-1.6 0L5.3 12.4a1 1 0 0 0-.8-.4H2a2 2 0 0 1-2-2V2zm3.5 1a.5.5 0 0 0 0 1h9a.5.5 0 0 0 0-1h-9zm0 2.5a.5.5 0 0 0 0 1h9a.5.5 0 0 0 0-1h-9zm0 2.5a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5z\"}}]})(props);\n};\nexport function BsChatSquareText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1h-2.5a2 2 0 0 0-1.6.8L8 14.333 6.1 11.8a2 2 0 0 0-1.6-.8H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h2.5a1 1 0 0 1 .8.4l1.9 2.533a1 1 0 0 0 1.6 0l1.9-2.533a1 1 0 0 1 .8-.4H14a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 3.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zM3 6a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9A.5.5 0 0 1 3 6zm0 2.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsChatSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1h-2.5a2 2 0 0 0-1.6.8L8 14.333 6.1 11.8a2 2 0 0 0-1.6-.8H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h2.5a1 1 0 0 1 .8.4l1.9 2.533a1 1 0 0 0 1.6 0l1.9-2.533a1 1 0 0 1 .8-.4H14a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsChatTextFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8c0 3.866-3.582 7-8 7a9.06 9.06 0 0 1-2.347-.306c-.584.296-1.925.864-4.181 1.234-.2.032-.352-.176-.273-.362.354-.836.674-1.95.77-2.966C.744 11.37 0 9.76 0 8c0-3.866 3.582-7 8-7s8 3.134 8 7zM4.5 5a.5.5 0 0 0 0 1h7a.5.5 0 0 0 0-1h-7zm0 2.5a.5.5 0 0 0 0 1h7a.5.5 0 0 0 0-1h-7zm0 2.5a.5.5 0 0 0 0 1h4a.5.5 0 0 0 0-1h-4z\"}}]})(props);\n};\nexport function BsChatText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.678 11.894a1 1 0 0 1 .287.801 10.97 10.97 0 0 1-.398 2c1.395-.323 2.247-.697 2.634-.893a1 1 0 0 1 .71-.074A8.06 8.06 0 0 0 8 14c3.996 0 7-2.807 7-6 0-3.192-3.004-6-7-6S1 4.808 1 8c0 1.468.617 2.83 1.678 3.894zm-.493 3.905a21.682 21.682 0 0 1-.713.129c-.2.032-.352-.176-.273-.362a9.68 9.68 0 0 0 .244-.637l.003-.01c.248-.72.45-1.548.524-2.319C.743 11.37 0 9.76 0 8c0-3.866 3.582-7 8-7s8 3.134 8 7-3.582 7-8 7a9.06 9.06 0 0 1-2.347-.306c-.52.263-1.639.742-3.468 1.105z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 5.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zM4 8a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7A.5.5 0 0 1 4 8zm0 2.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsChat (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.678 11.894a1 1 0 0 1 .287.801 10.97 10.97 0 0 1-.398 2c1.395-.323 2.247-.697 2.634-.893a1 1 0 0 1 .71-.074A8.06 8.06 0 0 0 8 14c3.996 0 7-2.807 7-6 0-3.192-3.004-6-7-6S1 4.808 1 8c0 1.468.617 2.83 1.678 3.894zm-.493 3.905a21.682 21.682 0 0 1-.713.129c-.2.032-.352-.176-.273-.362a9.68 9.68 0 0 0 .244-.637l.003-.01c.248-.72.45-1.548.524-2.319C.743 11.37 0 9.76 0 8c0-3.866 3.582-7 8-7s8 3.134 8 7-3.582 7-8 7a9.06 9.06 0 0 1-2.347-.306c-.52.263-1.639.742-3.468 1.105z\"}}]})(props);\n};\nexport function BsCheckAll (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.97 4.97a.75.75 0 0 1 1.07 1.05l-3.99 4.99a.75.75 0 0 1-1.08.02L2.324 8.384a.75.75 0 1 1 1.06-1.06l2.094 2.093L8.95 4.992a.252.252 0 0 1 .02-.022zm-.92 5.14.92.92a.75.75 0 0 0 1.079-.02l3.992-4.99a.75.75 0 1 0-1.091-1.028L9.477 9.417l-.485-.486-.943 1.179z\"}}]})(props);\n};\nexport function BsCheckCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-3.97-3.03a.75.75 0 0 0-1.08.022L7.477 9.417 5.384 7.323a.75.75 0 0 0-1.06 1.06L6.97 11.03a.75.75 0 0 0 1.079-.02l3.992-4.99a.75.75 0 0 0-.01-1.05z\"}}]})(props);\n};\nexport function BsCheckCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.97 4.97a.235.235 0 0 0-.02.022L7.477 9.417 5.384 7.323a.75.75 0 0 0-1.06 1.06L6.97 11.03a.75.75 0 0 0 1.079-.02l3.992-4.99a.75.75 0 0 0-1.071-1.05z\"}}]})(props);\n};\nexport function BsCheckLg (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.485 1.431a1.473 1.473 0 0 1 2.104 2.062l-7.84 9.801a1.473 1.473 0 0 1-2.12.04L.431 8.138a1.473 1.473 0 0 1 2.084-2.083l4.111 4.112 6.82-8.69a.486.486 0 0 1 .04-.045z\"}}]})(props);\n};\nexport function BsCheckSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm10.03 4.97a.75.75 0 0 1 .011 1.05l-3.992 4.99a.75.75 0 0 1-1.08.02L4.324 8.384a.75.75 0 1 1 1.06-1.06l2.094 2.093 3.473-4.425a.75.75 0 0 1 1.08-.022z\"}}]})(props);\n};\nexport function BsCheckSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.97 4.97a.75.75 0 0 1 1.071 1.05l-3.992 4.99a.75.75 0 0 1-1.08.02L4.324 8.384a.75.75 0 1 1 1.06-1.06l2.094 2.093 3.473-4.425a.235.235 0 0 1 .02-.022z\"}}]})(props);\n};\nexport function BsCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.97 4.97a.75.75 0 0 1 1.07 1.05l-3.99 4.99a.75.75 0 0 1-1.08.02L4.324 8.384a.75.75 0 1 1 1.06-1.06l2.094 2.093 3.473-4.425a.267.267 0 0 1 .02-.022z\"}}]})(props);\n};\nexport function BsCheck2All (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.354 4.354a.5.5 0 0 0-.708-.708L5 10.293 1.854 7.146a.5.5 0 1 0-.708.708l3.5 3.5a.5.5 0 0 0 .708 0l7-7zm-4.208 7-.896-.897.707-.707.543.543 6.646-6.647a.5.5 0 0 1 .708.708l-7 7a.5.5 0 0 1-.708 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m5.354 7.146.896.897-.707.707-.897-.896a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsCheck2Circle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 8a5.5 5.5 0 0 1 8.25-4.764.5.5 0 0 0 .5-.866A6.5 6.5 0 1 0 14.5 8a.5.5 0 0 0-1 0 5.5 5.5 0 1 1-11 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.354 3.354a.5.5 0 0 0-.708-.708L8 9.293 5.354 6.646a.5.5 0 1 0-.708.708l3 3a.5.5 0 0 0 .708 0l7-7z\"}}]})(props);\n};\nexport function BsCheck2Square (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 14.5A1.5 1.5 0 0 1 1.5 13V3A1.5 1.5 0 0 1 3 1.5h8a.5.5 0 0 1 0 1H3a.5.5 0 0 0-.5.5v10a.5.5 0 0 0 .5.5h10a.5.5 0 0 0 .5-.5V8a.5.5 0 0 1 1 0v5a1.5 1.5 0 0 1-1.5 1.5H3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m8.354 10.354 7-7a.5.5 0 0 0-.708-.708L8 9.293 5.354 6.646a.5.5 0 1 0-.708.708l3 3a.5.5 0 0 0 .708 0z\"}}]})(props);\n};\nexport function BsCheck2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.854 3.646a.5.5 0 0 1 0 .708l-7 7a.5.5 0 0 1-.708 0l-3.5-3.5a.5.5 0 1 1 .708-.708L6.5 10.293l6.646-6.647a.5.5 0 0 1 .708 0z\"}}]})(props);\n};\nexport function BsChevronBarContract (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.646 14.854a.5.5 0 0 0 .708 0L8 11.207l3.646 3.647a.5.5 0 0 0 .708-.708l-4-4a.5.5 0 0 0-.708 0l-4 4a.5.5 0 0 0 0 .708zm0-13.708a.5.5 0 0 1 .708 0L8 4.793l3.646-3.647a.5.5 0 0 1 .708.708l-4 4a.5.5 0 0 1-.708 0l-4-4a.5.5 0 0 1 0-.708zM1 8a.5.5 0 0 1 .5-.5h13a.5.5 0 0 1 0 1h-13A.5.5 0 0 1 1 8z\"}}]})(props);\n};\nexport function BsChevronBarDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.646 4.146a.5.5 0 0 1 .708 0L8 7.793l3.646-3.647a.5.5 0 0 1 .708.708l-4 4a.5.5 0 0 1-.708 0l-4-4a.5.5 0 0 1 0-.708zM1 11.5a.5.5 0 0 1 .5-.5h13a.5.5 0 0 1 0 1h-13a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsChevronBarExpand (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.646 10.146a.5.5 0 0 1 .708 0L8 13.793l3.646-3.647a.5.5 0 0 1 .708.708l-4 4a.5.5 0 0 1-.708 0l-4-4a.5.5 0 0 1 0-.708zm0-4.292a.5.5 0 0 0 .708 0L8 2.207l3.646 3.647a.5.5 0 0 0 .708-.708l-4-4a.5.5 0 0 0-.708 0l-4 4a.5.5 0 0 0 0 .708zM1 8a.5.5 0 0 1 .5-.5h13a.5.5 0 0 1 0 1h-13A.5.5 0 0 1 1 8z\"}}]})(props);\n};\nexport function BsChevronBarLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11.854 3.646a.5.5 0 0 1 0 .708L8.207 8l3.647 3.646a.5.5 0 0 1-.708.708l-4-4a.5.5 0 0 1 0-.708l4-4a.5.5 0 0 1 .708 0zM4.5 1a.5.5 0 0 0-.5.5v13a.5.5 0 0 0 1 0v-13a.5.5 0 0 0-.5-.5z\"}}]})(props);\n};\nexport function BsChevronBarRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4.146 3.646a.5.5 0 0 0 0 .708L7.793 8l-3.647 3.646a.5.5 0 0 0 .708.708l4-4a.5.5 0 0 0 0-.708l-4-4a.5.5 0 0 0-.708 0zM11.5 1a.5.5 0 0 1 .5.5v13a.5.5 0 0 1-1 0v-13a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsChevronBarUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.646 11.854a.5.5 0 0 0 .708 0L8 8.207l3.646 3.647a.5.5 0 0 0 .708-.708l-4-4a.5.5 0 0 0-.708 0l-4 4a.5.5 0 0 0 0 .708zM2.4 5.2c0 .22.18.4.4.4h10.4a.4.4 0 0 0 0-.8H2.8a.4.4 0 0 0-.4.4z\"}}]})(props);\n};\nexport function BsChevronCompactDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.553 6.776a.5.5 0 0 1 .67-.223L8 9.44l5.776-2.888a.5.5 0 1 1 .448.894l-6 3a.5.5 0 0 1-.448 0l-6-3a.5.5 0 0 1-.223-.67z\"}}]})(props);\n};\nexport function BsChevronCompactLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M9.224 1.553a.5.5 0 0 1 .223.67L6.56 8l2.888 5.776a.5.5 0 1 1-.894.448l-3-6a.5.5 0 0 1 0-.448l3-6a.5.5 0 0 1 .67-.223z\"}}]})(props);\n};\nexport function BsChevronCompactRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6.776 1.553a.5.5 0 0 1 .671.223l3 6a.5.5 0 0 1 0 .448l-3 6a.5.5 0 1 1-.894-.448L9.44 8 6.553 2.224a.5.5 0 0 1 .223-.671z\"}}]})(props);\n};\nexport function BsChevronCompactUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.776 5.553a.5.5 0 0 1 .448 0l6 3a.5.5 0 1 1-.448.894L8 6.56 2.224 9.447a.5.5 0 1 1-.448-.894l6-3z\"}}]})(props);\n};\nexport function BsChevronContract (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.646 13.854a.5.5 0 0 0 .708 0L8 10.207l3.646 3.647a.5.5 0 0 0 .708-.708l-4-4a.5.5 0 0 0-.708 0l-4 4a.5.5 0 0 0 0 .708zm0-11.708a.5.5 0 0 1 .708 0L8 5.793l3.646-3.647a.5.5 0 0 1 .708.708l-4 4a.5.5 0 0 1-.708 0l-4-4a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsChevronDoubleDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.646 6.646a.5.5 0 0 1 .708 0L8 12.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.646 2.646a.5.5 0 0 1 .708 0L8 8.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsChevronDoubleLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8.354 1.646a.5.5 0 0 1 0 .708L2.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M12.354 1.646a.5.5 0 0 1 0 .708L6.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z\"}}]})(props);\n};\nexport function BsChevronDoubleRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L9.293 8 3.646 2.354a.5.5 0 0 1 0-.708z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L13.293 8 7.646 2.354a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsChevronDoubleUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.646 2.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1-.708.708L8 3.707 2.354 9.354a.5.5 0 1 1-.708-.708l6-6z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.646 6.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1-.708.708L8 7.707l-5.646 5.647a.5.5 0 0 1-.708-.708l6-6z\"}}]})(props);\n};\nexport function BsChevronDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsChevronExpand (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.646 9.146a.5.5 0 0 1 .708 0L8 12.793l3.646-3.647a.5.5 0 0 1 .708.708l-4 4a.5.5 0 0 1-.708 0l-4-4a.5.5 0 0 1 0-.708zm0-2.292a.5.5 0 0 0 .708 0L8 3.207l3.646 3.647a.5.5 0 0 0 .708-.708l-4-4a.5.5 0 0 0-.708 0l-4 4a.5.5 0 0 0 0 .708z\"}}]})(props);\n};\nexport function BsChevronLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z\"}}]})(props);\n};\nexport function BsChevronRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsChevronUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.646 4.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1-.708.708L8 5.707l-5.646 5.647a.5.5 0 0 1-.708-.708l6-6z\"}}]})(props);\n};\nexport function BsCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"8\",\"r\":\"8\"}}]})(props);\n};\nexport function BsCircleHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 0 8 1v14zm0 1A8 8 0 1 1 8 0a8 8 0 0 1 0 16z\"}}]})(props);\n};\nexport function BsCircleSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 6a6 6 0 1 1 12 0A6 6 0 0 1 0 6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.93 5h1.57a.5.5 0 0 1 .5.5v9a.5.5 0 0 1-.5.5h-9a.5.5 0 0 1-.5-.5v-1.57a6.953 6.953 0 0 1-1-.22v1.79A1.5 1.5 0 0 0 5.5 16h9a1.5 1.5 0 0 0 1.5-1.5v-9A1.5 1.5 0 0 0 14.5 4h-1.79c.097.324.17.658.22 1z\"}}]})(props);\n};\nexport function BsCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}}]})(props);\n};\nexport function BsClipboardCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.854 7.146a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7.5 9.793l2.646-2.647a.5.5 0 0 1 .708 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 1.5H3a2 2 0 0 0-2 2V14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V3.5a2 2 0 0 0-2-2h-1v1h1a1 1 0 0 1 1 1V14a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V3.5a1 1 0 0 1 1-1h1v-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-3a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5h3zm-3-1A1.5 1.5 0 0 0 5 1.5v1A1.5 1.5 0 0 0 6.5 4h3A1.5 1.5 0 0 0 11 2.5v-1A1.5 1.5 0 0 0 9.5 0h-3z\"}}]})(props);\n};\nexport function BsClipboardData (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 11a1 1 0 1 1 2 0v1a1 1 0 1 1-2 0v-1zm6-4a1 1 0 1 1 2 0v5a1 1 0 1 1-2 0V7zM7 9a1 1 0 0 1 2 0v3a1 1 0 1 1-2 0V9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 1.5H3a2 2 0 0 0-2 2V14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V3.5a2 2 0 0 0-2-2h-1v1h1a1 1 0 0 1 1 1V14a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V3.5a1 1 0 0 1 1-1h1v-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-3a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5h3zm-3-1A1.5 1.5 0 0 0 5 1.5v1A1.5 1.5 0 0 0 6.5 4h3A1.5 1.5 0 0 0 11 2.5v-1A1.5 1.5 0 0 0 9.5 0h-3z\"}}]})(props);\n};\nexport function BsClipboardMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5.5 9.5A.5.5 0 0 1 6 9h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 1.5H3a2 2 0 0 0-2 2V14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V3.5a2 2 0 0 0-2-2h-1v1h1a1 1 0 0 1 1 1V14a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V3.5a1 1 0 0 1 1-1h1v-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-3a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5h3zm-3-1A1.5 1.5 0 0 0 5 1.5v1A1.5 1.5 0 0 0 6.5 4h3A1.5 1.5 0 0 0 11 2.5v-1A1.5 1.5 0 0 0 9.5 0h-3z\"}}]})(props);\n};\nexport function BsClipboardPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 7a.5.5 0 0 1 .5.5V9H10a.5.5 0 0 1 0 1H8.5v1.5a.5.5 0 0 1-1 0V10H6a.5.5 0 0 1 0-1h1.5V7.5A.5.5 0 0 1 8 7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 1.5H3a2 2 0 0 0-2 2V14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V3.5a2 2 0 0 0-2-2h-1v1h1a1 1 0 0 1 1 1V14a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V3.5a1 1 0 0 1 1-1h1v-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-3a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5h3zm-3-1A1.5 1.5 0 0 0 5 1.5v1A1.5 1.5 0 0 0 6.5 4h3A1.5 1.5 0 0 0 11 2.5v-1A1.5 1.5 0 0 0 9.5 0h-3z\"}}]})(props);\n};\nexport function BsClipboardX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6.146 7.146a.5.5 0 0 1 .708 0L8 8.293l1.146-1.147a.5.5 0 1 1 .708.708L8.707 9l1.147 1.146a.5.5 0 0 1-.708.708L8 9.707l-1.146 1.147a.5.5 0 0 1-.708-.708L7.293 9 6.146 7.854a.5.5 0 0 1 0-.708z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 1.5H3a2 2 0 0 0-2 2V14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V3.5a2 2 0 0 0-2-2h-1v1h1a1 1 0 0 1 1 1V14a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V3.5a1 1 0 0 1 1-1h1v-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-3a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5h3zm-3-1A1.5 1.5 0 0 0 5 1.5v1A1.5 1.5 0 0 0 6.5 4h3A1.5 1.5 0 0 0 11 2.5v-1A1.5 1.5 0 0 0 9.5 0h-3z\"}}]})(props);\n};\nexport function BsClipboard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 1.5H3a2 2 0 0 0-2 2V14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V3.5a2 2 0 0 0-2-2h-1v1h1a1 1 0 0 1 1 1V14a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V3.5a1 1 0 0 1 1-1h1v-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-3a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5h3zm-3-1A1.5 1.5 0 0 0 5 1.5v1A1.5 1.5 0 0 0 6.5 4h3A1.5 1.5 0 0 0 11 2.5v-1A1.5 1.5 0 0 0 9.5 0h-3z\"}}]})(props);\n};\nexport function BsClockFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM8 3.5a.5.5 0 0 0-1 0V9a.5.5 0 0 0 .252.434l3.5 2a.5.5 0 0 0 .496-.868L8 8.71V3.5z\"}}]})(props);\n};\nexport function BsClockHistory (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.515 1.019A7 7 0 0 0 8 1V0a8 8 0 0 1 .589.022l-.074.997zm2.004.45a7.003 7.003 0 0 0-.985-.299l.219-.976c.383.086.76.2 1.126.342l-.36.933zm1.37.71a7.01 7.01 0 0 0-.439-.27l.493-.87a8.025 8.025 0 0 1 .979.654l-.615.789a6.996 6.996 0 0 0-.418-.302zm1.834 1.79a6.99 6.99 0 0 0-.653-.796l.724-.69c.27.285.52.59.747.91l-.818.576zm.744 1.352a7.08 7.08 0 0 0-.214-.468l.893-.45a7.976 7.976 0 0 1 .45 1.088l-.95.313a7.023 7.023 0 0 0-.179-.483zm.53 2.507a6.991 6.991 0 0 0-.1-1.025l.985-.17c.067.386.106.778.116 1.17l-1 .025zm-.131 1.538c.033-.17.06-.339.081-.51l.993.123a7.957 7.957 0 0 1-.23 1.155l-.964-.267c.046-.165.086-.332.12-.501zm-.952 2.379c.184-.29.346-.594.486-.908l.914.405c-.16.36-.345.706-.555 1.038l-.845-.535zm-.964 1.205c.122-.122.239-.248.35-.378l.758.653a8.073 8.073 0 0 1-.401.432l-.707-.707z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a7 7 0 1 0 4.95 11.95l.707.707A8.001 8.001 0 1 1 8 0v1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 3a.5.5 0 0 1 .5.5v5.21l3.248 1.856a.5.5 0 0 1-.496.868l-3.5-2A.5.5 0 0 1 7 9V3.5a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsClock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 3.5a.5.5 0 0 0-1 0V9a.5.5 0 0 0 .252.434l3.5 2a.5.5 0 0 0 .496-.868L8 8.71V3.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zm7-8A7 7 0 1 1 1 8a7 7 0 0 1 14 0z\"}}]})(props);\n};\nexport function BsCloudArrowDownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 2a5.53 5.53 0 0 0-3.594 1.342c-.766.66-1.321 1.52-1.464 2.383C1.266 6.095 0 7.555 0 9.318 0 11.366 1.708 13 3.781 13h8.906C14.502 13 16 11.57 16 9.773c0-1.636-1.242-2.969-2.834-3.194C12.923 3.999 10.69 2 8 2zm2.354 6.854-2 2a.5.5 0 0 1-.708 0l-2-2a.5.5 0 1 1 .708-.708L7.5 9.293V5.5a.5.5 0 0 1 1 0v3.793l1.146-1.147a.5.5 0 0 1 .708.708z\"}}]})(props);\n};\nexport function BsCloudArrowDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.646 10.854a.5.5 0 0 0 .708 0l2-2a.5.5 0 0 0-.708-.708L8.5 9.293V5.5a.5.5 0 0 0-1 0v3.793L6.354 8.146a.5.5 0 1 0-.708.708l2 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.406 3.342A5.53 5.53 0 0 1 8 2c2.69 0 4.923 2 5.166 4.579C14.758 6.804 16 8.137 16 9.773 16 11.569 14.502 13 12.687 13H3.781C1.708 13 0 11.366 0 9.318c0-1.763 1.266-3.223 2.942-3.593.143-.863.698-1.723 1.464-2.383zm.653.757c-.757.653-1.153 1.44-1.153 2.056v.448l-.445.049C2.064 6.805 1 7.952 1 9.318 1 10.785 2.23 12 3.781 12h8.906C13.98 12 15 10.988 15 9.773c0-1.216-1.02-2.228-2.313-2.228h-.5v-.5C12.188 4.825 10.328 3 8 3a4.53 4.53 0 0 0-2.941 1.1z\"}}]})(props);\n};\nexport function BsCloudArrowUpFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 2a5.53 5.53 0 0 0-3.594 1.342c-.766.66-1.321 1.52-1.464 2.383C1.266 6.095 0 7.555 0 9.318 0 11.366 1.708 13 3.781 13h8.906C14.502 13 16 11.57 16 9.773c0-1.636-1.242-2.969-2.834-3.194C12.923 3.999 10.69 2 8 2zm2.354 5.146a.5.5 0 0 1-.708.708L8.5 6.707V10.5a.5.5 0 0 1-1 0V6.707L6.354 7.854a.5.5 0 1 1-.708-.708l2-2a.5.5 0 0 1 .708 0l2 2z\"}}]})(props);\n};\nexport function BsCloudArrowUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.646 5.146a.5.5 0 0 1 .708 0l2 2a.5.5 0 0 1-.708.708L8.5 6.707V10.5a.5.5 0 0 1-1 0V6.707L6.354 7.854a.5.5 0 1 1-.708-.708l2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.406 3.342A5.53 5.53 0 0 1 8 2c2.69 0 4.923 2 5.166 4.579C14.758 6.804 16 8.137 16 9.773 16 11.569 14.502 13 12.687 13H3.781C1.708 13 0 11.366 0 9.318c0-1.763 1.266-3.223 2.942-3.593.143-.863.698-1.723 1.464-2.383zm.653.757c-.757.653-1.153 1.44-1.153 2.056v.448l-.445.049C2.064 6.805 1 7.952 1 9.318 1 10.785 2.23 12 3.781 12h8.906C13.98 12 15 10.988 15 9.773c0-1.216-1.02-2.228-2.313-2.228h-.5v-.5C12.188 4.825 10.328 3 8 3a4.53 4.53 0 0 0-2.941 1.1z\"}}]})(props);\n};\nexport function BsCloudCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 2a5.53 5.53 0 0 0-3.594 1.342c-.766.66-1.321 1.52-1.464 2.383C1.266 6.095 0 7.555 0 9.318 0 11.366 1.708 13 3.781 13h8.906C14.502 13 16 11.57 16 9.773c0-1.636-1.242-2.969-2.834-3.194C12.923 3.999 10.69 2 8 2zm2.354 4.854-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7 8.793l2.646-2.647a.5.5 0 0 1 .708.708z\"}}]})(props);\n};\nexport function BsCloudCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.354 6.146a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7 8.793l2.646-2.647a.5.5 0 0 1 .708 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.406 3.342A5.53 5.53 0 0 1 8 2c2.69 0 4.923 2 5.166 4.579C14.758 6.804 16 8.137 16 9.773 16 11.569 14.502 13 12.687 13H3.781C1.708 13 0 11.366 0 9.318c0-1.763 1.266-3.223 2.942-3.593.143-.863.698-1.723 1.464-2.383zm.653.757c-.757.653-1.153 1.44-1.153 2.056v.448l-.445.049C2.064 6.805 1 7.952 1 9.318 1 10.785 2.23 12 3.781 12h8.906C13.98 12 15 10.988 15 9.773c0-1.216-1.02-2.228-2.313-2.228h-.5v-.5C12.188 4.825 10.328 3 8 3a4.53 4.53 0 0 0-2.941 1.1z\"}}]})(props);\n};\nexport function BsCloudDownloadFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 0a5.53 5.53 0 0 0-3.594 1.342c-.766.66-1.321 1.52-1.464 2.383C1.266 4.095 0 5.555 0 7.318 0 9.366 1.708 11 3.781 11H7.5V5.5a.5.5 0 0 1 1 0V11h4.188C14.502 11 16 9.57 16 7.773c0-1.636-1.242-2.969-2.834-3.194C12.923 1.999 10.69 0 8 0zm-.354 15.854a.5.5 0 0 0 .708 0l3-3a.5.5 0 0 0-.708-.708L8.5 14.293V11h-1v3.293l-2.146-2.147a.5.5 0 0 0-.708.708l3 3z\"}}]})(props);\n};\nexport function BsCloudDownload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.406 1.342A5.53 5.53 0 0 1 8 0c2.69 0 4.923 2 5.166 4.579C14.758 4.804 16 6.137 16 7.773 16 9.569 14.502 11 12.687 11H10a.5.5 0 0 1 0-1h2.688C13.979 10 15 8.988 15 7.773c0-1.216-1.02-2.228-2.313-2.228h-.5v-.5C12.188 2.825 10.328 1 8 1a4.53 4.53 0 0 0-2.941 1.1c-.757.652-1.153 1.438-1.153 2.055v.448l-.445.049C2.064 4.805 1 5.952 1 7.318 1 8.785 2.23 10 3.781 10H6a.5.5 0 0 1 0 1H3.781C1.708 11 0 9.366 0 7.318c0-1.763 1.266-3.223 2.942-3.593.143-.863.698-1.723 1.464-2.383z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.646 15.854a.5.5 0 0 0 .708 0l3-3a.5.5 0 0 0-.708-.708L8.5 14.293V5.5a.5.5 0 0 0-1 0v8.793l-2.146-2.147a.5.5 0 0 0-.708.708l3 3z\"}}]})(props);\n};\nexport function BsCloudDrizzleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.158 12.025a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 0 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm6 0a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 0 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm-3.5 1.5a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 0 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm6 0a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm.747-8.498a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 11H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsCloudDrizzle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.158 12.025a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 0 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm6 0a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 0 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm-3.5 1.5a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 0 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm6 0a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm.747-8.498a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 11H13a3 3 0 0 0 .405-5.973zM8.5 2a4 4 0 0 1 3.976 3.555.5.5 0 0 0 .5.445H13a2 2 0 0 1 0 4H3.5a2.5 2.5 0 1 1 .605-4.926.5.5 0 0 0 .596-.329A4.002 4.002 0 0 1 8.5 2z\"}}]})(props);\n};\nexport function BsCloudFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.406 3.342A5.53 5.53 0 0 1 8 2c2.69 0 4.923 2 5.166 4.579C14.758 6.804 16 8.137 16 9.773 16 11.569 14.502 13 12.687 13H3.781C1.708 13 0 11.366 0 9.318c0-1.763 1.266-3.223 2.942-3.593.143-.863.698-1.723 1.464-2.383z\"}}]})(props);\n};\nexport function BsCloudFogFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 13.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm10.405-9.473a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 12H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsCloudFog (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 13.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm10.405-9.473a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 12H13a3 3 0 0 0 .405-5.973zM8.5 3a4 4 0 0 1 3.976 3.555.5.5 0 0 0 .5.445H13a2 2 0 0 1 0 4H3.5a2.5 2.5 0 1 1 .605-4.926.5.5 0 0 0 .596-.329A4.002 4.002 0 0 1 8.5 3z\"}}]})(props);\n};\nexport function BsCloudFog2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 3a5.001 5.001 0 0 1 4.905 4.027A3 3 0 0 1 13 13h-1.5a.5.5 0 0 0 0-1H1.05a3.51 3.51 0 0 1-.713-1H9.5a.5.5 0 0 0 0-1H.035a3.53 3.53 0 0 1 0-1H7.5a.5.5 0 0 0 0-1H.337a3.5 3.5 0 0 1 3.57-1.977A5.001 5.001 0 0 1 8.5 3z\"}}]})(props);\n};\nexport function BsCloudFog2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 4a4.002 4.002 0 0 0-3.8 2.745.5.5 0 1 1-.949-.313 5.002 5.002 0 0 1 9.654.595A3 3 0 0 1 13 13H.5a.5.5 0 0 1 0-1H13a2 2 0 0 0 .001-4h-.026a.5.5 0 0 1-.5-.445A4 4 0 0 0 8.5 4zM0 8.5A.5.5 0 0 1 .5 8h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsCloudHailFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.75 15.25a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0zm.408-3.724a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zM7.75 15.25a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0zm.408-3.724a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm3.592 3.724a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0zm.408-3.724a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm1.247-6.999a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10.5H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsCloudHail (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.405 4.527a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10.5H13a3 3 0 0 0 .405-5.973zM8.5 1.5a4 4 0 0 1 3.976 3.555.5.5 0 0 0 .5.445H13a2 2 0 0 1-.001 4H3.5a2.5 2.5 0 1 1 .605-4.926.5.5 0 0 0 .596-.329A4.002 4.002 0 0 1 8.5 1.5zM3.75 15.25a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0zm.408-3.724a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zM7.75 15.25a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0zm.408-3.724a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm3.592 3.724a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0zm.408-3.724a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316z\"}}]})(props);\n};\nexport function BsCloudHaze1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 11.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm-3 2a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm2 2a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zM13.405 4.027a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10H13a3 3 0 0 0 .405-5.973zM8.5 1a4 4 0 0 1 3.976 3.555.5.5 0 0 0 .5.445H13a2 2 0 0 1 0 4H3.5a2.5 2.5 0 1 1 .605-4.926.5.5 0 0 0 .596-.329A4.002 4.002 0 0 1 8.5 1z\"}}]})(props);\n};\nexport function BsCloudHazeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 11.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm-3 2a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm2 2a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zM13.405 4.027a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsCloudHaze (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 3a4.002 4.002 0 0 0-3.8 2.745.5.5 0 1 1-.949-.313 5.002 5.002 0 0 1 9.654.595A3 3 0 0 1 13 12H4.5a.5.5 0 0 1 0-1H13a2 2 0 0 0 .001-4h-.026a.5.5 0 0 1-.5-.445A4 4 0 0 0 8.5 3zM0 7.5A.5.5 0 0 1 .5 7h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm2 2a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm-2 4a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsCloudHaze2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 2a5.001 5.001 0 0 1 4.905 4.027A3 3 0 0 1 13 12H3.5A3.5 3.5 0 0 1 .035 9H5.5a.5.5 0 0 0 0-1H.035a3.5 3.5 0 0 1 3.871-2.977A5.001 5.001 0 0 1 8.5 2zm-6 8a.5.5 0 0 0 0 1h9a.5.5 0 0 0 0-1h-9zM0 13.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsCloudLightningFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.053 11.276A.5.5 0 0 1 7.5 11h1a.5.5 0 0 1 .474.658l-.28.842H9.5a.5.5 0 0 1 .39.812l-2 2.5a.5.5 0 0 1-.875-.433L7.36 14H6.5a.5.5 0 0 1-.447-.724l1-2zm6.352-7.249a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsCloudLightningRainFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.658 11.026a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm9.5 0a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 0 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm-7.5 1.5a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm9.5 0a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 0 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm-7.105-1.25A.5.5 0 0 1 7.5 11h1a.5.5 0 0 1 .474.658l-.28.842H9.5a.5.5 0 0 1 .39.812l-2 2.5a.5.5 0 0 1-.875-.433L7.36 14H6.5a.5.5 0 0 1-.447-.724l1-2zm6.352-7.249a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsCloudLightningRain (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.658 11.026a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm9.5 0a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm-7.5 1.5a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm9.5 0a.5.5 0 0 1 .316.632l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.316zm-.753-8.499a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10H13a3 3 0 0 0 .405-5.973zM8.5 1a4 4 0 0 1 3.976 3.555.5.5 0 0 0 .5.445H13a2 2 0 0 1 0 4H3.5a2.5 2.5 0 1 1 .605-4.926.5.5 0 0 0 .596-.329A4.002 4.002 0 0 1 8.5 1zM7.053 11.276A.5.5 0 0 1 7.5 11h1a.5.5 0 0 1 .474.658l-.28.842H9.5a.5.5 0 0 1 .39.812l-2 2.5a.5.5 0 0 1-.875-.433L7.36 14H6.5a.5.5 0 0 1-.447-.724l1-2z\"}}]})(props);\n};\nexport function BsCloudLightning (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.405 4.027a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10H13a3 3 0 0 0 .405-5.973zM8.5 1a4 4 0 0 1 3.976 3.555.5.5 0 0 0 .5.445H13a2 2 0 0 1 0 4H3.5a2.5 2.5 0 1 1 .605-4.926.5.5 0 0 0 .596-.329A4.002 4.002 0 0 1 8.5 1zM7.053 11.276A.5.5 0 0 1 7.5 11h1a.5.5 0 0 1 .474.658l-.28.842H9.5a.5.5 0 0 1 .39.812l-2 2.5a.5.5 0 0 1-.875-.433L7.36 14H6.5a.5.5 0 0 1-.447-.724l1-2z\"}}]})(props);\n};\nexport function BsCloudMinusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 2a5.53 5.53 0 0 0-3.594 1.342c-.766.66-1.321 1.52-1.464 2.383C1.266 6.095 0 7.555 0 9.318 0 11.366 1.708 13 3.781 13h8.906C14.502 13 16 11.57 16 9.773c0-1.636-1.242-2.969-2.834-3.194C12.923 3.999 10.69 2 8 2zM6 7.5h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsCloudMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.406 3.342A5.53 5.53 0 0 1 8 2c2.69 0 4.923 2 5.166 4.579C14.758 6.804 16 8.137 16 9.773 16 11.569 14.502 13 12.687 13H3.781C1.708 13 0 11.366 0 9.318c0-1.763 1.266-3.223 2.942-3.593.143-.863.698-1.723 1.464-2.383zm.653.757c-.757.653-1.153 1.44-1.153 2.056v.448l-.445.049C2.064 6.805 1 7.952 1 9.318 1 10.785 2.23 12 3.781 12h8.906C13.98 12 15 10.988 15 9.773c0-1.216-1.02-2.228-2.313-2.228h-.5v-.5C12.188 4.825 10.328 3 8 3a4.53 4.53 0 0 0-2.941 1.1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 7.5a.5.5 0 0 0 0 1h4a.5.5 0 0 0 0-1H6z\"}}]})(props);\n};\nexport function BsCloudMoonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.473 11a4.5 4.5 0 0 0-8.72-.99A3 3 0 0 0 3 16h8.5a2.5 2.5 0 0 0 0-5h-.027z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.286 1.778a.5.5 0 0 0-.565-.755 4.595 4.595 0 0 0-3.18 5.003 5.46 5.46 0 0 1 1.055.209A3.603 3.603 0 0 1 9.83 2.617a4.593 4.593 0 0 0 4.31 5.744 3.576 3.576 0 0 1-2.241.634c.162.317.295.652.394 1a4.59 4.59 0 0 0 3.624-2.04.5.5 0 0 0-.565-.755 3.593 3.593 0 0 1-4.065-5.422z\"}}]})(props);\n};\nexport function BsCloudMoon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 8a3.5 3.5 0 0 1 3.5 3.555.5.5 0 0 0 .625.492A1.503 1.503 0 0 1 13 13.5a1.5 1.5 0 0 1-1.5 1.5H3a2 2 0 1 1 .1-3.998.5.5 0 0 0 .509-.375A3.502 3.502 0 0 1 7 8zm4.473 3a4.5 4.5 0 0 0-8.72-.99A3 3 0 0 0 3 16h8.5a2.5 2.5 0 0 0 0-5h-.027z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.286 1.778a.5.5 0 0 0-.565-.755 4.595 4.595 0 0 0-3.18 5.003 5.46 5.46 0 0 1 1.055.209A3.603 3.603 0 0 1 9.83 2.617a4.593 4.593 0 0 0 4.31 5.744 3.576 3.576 0 0 1-2.241.634c.162.317.295.652.394 1a4.59 4.59 0 0 0 3.624-2.04.5.5 0 0 0-.565-.755 3.593 3.593 0 0 1-4.065-5.422z\"}}]})(props);\n};\nexport function BsCloudPlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 2a5.53 5.53 0 0 0-3.594 1.342c-.766.66-1.321 1.52-1.464 2.383C1.266 6.095 0 7.555 0 9.318 0 11.366 1.708 13 3.781 13h8.906C14.502 13 16 11.57 16 9.773c0-1.636-1.242-2.969-2.834-3.194C12.923 3.999 10.69 2 8 2zm.5 4v1.5H10a.5.5 0 0 1 0 1H8.5V10a.5.5 0 0 1-1 0V8.5H6a.5.5 0 0 1 0-1h1.5V6a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsCloudPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 5.5a.5.5 0 0 1 .5.5v1.5H10a.5.5 0 0 1 0 1H8.5V10a.5.5 0 0 1-1 0V8.5H6a.5.5 0 0 1 0-1h1.5V6a.5.5 0 0 1 .5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.406 3.342A5.53 5.53 0 0 1 8 2c2.69 0 4.923 2 5.166 4.579C14.758 6.804 16 8.137 16 9.773 16 11.569 14.502 13 12.687 13H3.781C1.708 13 0 11.366 0 9.318c0-1.763 1.266-3.223 2.942-3.593.143-.863.698-1.723 1.464-2.383zm.653.757c-.757.653-1.153 1.44-1.153 2.056v.448l-.445.049C2.064 6.805 1 7.952 1 9.318 1 10.785 2.23 12 3.781 12h8.906C13.98 12 15 10.988 15 9.773c0-1.216-1.02-2.228-2.313-2.228h-.5v-.5C12.188 4.825 10.328 3 8 3a4.53 4.53 0 0 0-2.941 1.1z\"}}]})(props);\n};\nexport function BsCloudRainFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.158 12.025a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm3 0a.5.5 0 0 1 .316.633l-1 3a.5.5 0 1 1-.948-.316l1-3a.5.5 0 0 1 .632-.317zm3 0a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 1 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm3 0a.5.5 0 0 1 .316.633l-1 3a.5.5 0 1 1-.948-.316l1-3a.5.5 0 0 1 .632-.317zm.247-6.998a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 11H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsCloudRainHeavyFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.176 11.032a.5.5 0 0 1 .292.643l-1.5 4a.5.5 0 0 1-.936-.35l1.5-4a.5.5 0 0 1 .644-.293zm3 0a.5.5 0 0 1 .292.643l-1.5 4a.5.5 0 0 1-.936-.35l1.5-4a.5.5 0 0 1 .644-.293zm3 0a.5.5 0 0 1 .292.643l-1.5 4a.5.5 0 0 1-.936-.35l1.5-4a.5.5 0 0 1 .644-.293zm3 0a.5.5 0 0 1 .292.643l-1.5 4a.5.5 0 0 1-.936-.35l1.5-4a.5.5 0 0 1 .644-.293zm.229-7.005a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsCloudRainHeavy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.176 11.032a.5.5 0 0 1 .292.643l-1.5 4a.5.5 0 1 1-.936-.35l1.5-4a.5.5 0 0 1 .644-.293zm3 0a.5.5 0 0 1 .292.643l-1.5 4a.5.5 0 1 1-.936-.35l1.5-4a.5.5 0 0 1 .644-.293zm3 0a.5.5 0 0 1 .292.643l-1.5 4a.5.5 0 1 1-.936-.35l1.5-4a.5.5 0 0 1 .644-.293zm3 0a.5.5 0 0 1 .292.643l-1.5 4a.5.5 0 0 1-.936-.35l1.5-4a.5.5 0 0 1 .644-.293zm.229-7.005a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10H13a3 3 0 0 0 .405-5.973zM8.5 1a4 4 0 0 1 3.976 3.555.5.5 0 0 0 .5.445H13a2 2 0 0 1 0 4H3.5a2.5 2.5 0 1 1 .605-4.926.5.5 0 0 0 .596-.329A4.002 4.002 0 0 1 8.5 1z\"}}]})(props);\n};\nexport function BsCloudRain (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.158 12.025a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 0 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm3 0a.5.5 0 0 1 .316.633l-1 3a.5.5 0 0 1-.948-.316l1-3a.5.5 0 0 1 .632-.317zm3 0a.5.5 0 0 1 .316.633l-.5 1.5a.5.5 0 0 1-.948-.316l.5-1.5a.5.5 0 0 1 .632-.317zm3 0a.5.5 0 0 1 .316.633l-1 3a.5.5 0 1 1-.948-.316l1-3a.5.5 0 0 1 .632-.317zm.247-6.998a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 11H13a3 3 0 0 0 .405-5.973zM8.5 2a4 4 0 0 1 3.976 3.555.5.5 0 0 0 .5.445H13a2 2 0 0 1 0 4H3.5a2.5 2.5 0 1 1 .605-4.926.5.5 0 0 0 .596-.329A4.002 4.002 0 0 1 8.5 2z\"}}]})(props);\n};\nexport function BsCloudSlashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.112 5.112a3.125 3.125 0 0 0-.17.613C1.266 6.095 0 7.555 0 9.318 0 11.366 1.708 13 3.781 13H11L3.112 5.112zm11.372 7.372L4.937 2.937A5.512 5.512 0 0 1 8 2c2.69 0 4.923 2 5.166 4.579C14.758 6.804 16 8.137 16 9.773a3.2 3.2 0 0 1-1.516 2.711zm-.838 1.87-12-12 .708-.708 12 12-.707.707z\"}}]})(props);\n};\nexport function BsCloudSlash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.112 5.112a3.125 3.125 0 0 0-.17.613C1.266 6.095 0 7.555 0 9.318 0 11.366 1.708 13 3.781 13H11l-1-1H3.781C2.231 12 1 10.785 1 9.318c0-1.365 1.064-2.513 2.46-2.666l.446-.05v-.447c0-.075.006-.152.018-.231l-.812-.812zm2.55-1.45-.725-.725A5.512 5.512 0 0 1 8 2c2.69 0 4.923 2 5.166 4.579C14.758 6.804 16 8.137 16 9.773a3.2 3.2 0 0 1-1.516 2.711l-.733-.733C14.498 11.378 15 10.626 15 9.773c0-1.216-1.02-2.228-2.313-2.228h-.5v-.5C12.188 4.825 10.328 3 8 3c-.875 0-1.678.26-2.339.661z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m13.646 14.354-12-12 .708-.708 12 12-.707.707z\"}}]})(props);\n};\nexport function BsCloudSleetFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.375 13.5a.25.25 0 0 1 .25.25v.57l.501-.287a.25.25 0 0 1 .248.434l-.495.283.495.283a.25.25 0 1 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 1 1-.248-.434l.495-.283-.495-.283a.25.25 0 1 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm1.849-2.447a.5.5 0 0 1 .223.67l-.5 1a.5.5 0 0 1-.894-.447l.5-1a.5.5 0 0 1 .67-.223zM6.375 13.5a.25.25 0 0 1 .25.25v.57l.5-.287a.25.25 0 0 1 .249.434l-.495.283.495.283a.25.25 0 1 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 1 1-.248-.434l.495-.283-.495-.283a.25.25 0 1 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm1.849-2.447a.5.5 0 0 1 .223.67l-.5 1a.5.5 0 0 1-.894-.447l.5-1a.5.5 0 0 1 .67-.223zm2.151 2.447a.25.25 0 0 1 .25.25v.57l.5-.287a.25.25 0 0 1 .249.434l-.495.283.495.283a.25.25 0 1 1-.248.434l-.501-.286v.569a.25.25 0 0 1-.5 0v-.57l-.501.287a.25.25 0 1 1-.248-.434l.495-.283-.495-.283a.25.25 0 1 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm1.849-2.447a.5.5 0 0 1 .223.67l-.5 1a.5.5 0 1 1-.894-.447l.5-1a.5.5 0 0 1 .67-.223zm1.181-7.026a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsCloudSleet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.405 4.027a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10H13a3 3 0 0 0 .405-5.973zM8.5 1a4 4 0 0 1 3.976 3.555.5.5 0 0 0 .5.445H13a2 2 0 0 1 0 4H3.5a2.5 2.5 0 1 1 .605-4.926.5.5 0 0 0 .596-.329A4.002 4.002 0 0 1 8.5 1zM2.375 13.5a.25.25 0 0 1 .25.25v.57l.501-.287a.25.25 0 0 1 .248.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 0 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm1.849-2.447a.5.5 0 0 1 .223.67l-.5 1a.5.5 0 1 1-.894-.447l.5-1a.5.5 0 0 1 .67-.223zM6.375 13.5a.25.25 0 0 1 .25.25v.57l.501-.287a.25.25 0 0 1 .248.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 0 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm1.849-2.447a.5.5 0 0 1 .223.67l-.5 1a.5.5 0 1 1-.894-.447l.5-1a.5.5 0 0 1 .67-.223zm2.151 2.447a.25.25 0 0 1 .25.25v.57l.501-.287a.25.25 0 0 1 .248.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 0 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm1.849-2.447a.5.5 0 0 1 .223.67l-.5 1a.5.5 0 1 1-.894-.447l.5-1a.5.5 0 0 1 .67-.223z\"}}]})(props);\n};\nexport function BsCloudSnowFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.625 11.5a.25.25 0 0 1 .25.25v.57l.501-.287a.25.25 0 0 1 .248.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 0 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm2.75 2a.25.25 0 0 1 .25.25v.57l.5-.287a.25.25 0 0 1 .249.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 0 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm5.5 0a.25.25 0 0 1 .25.25v.57l.5-.287a.25.25 0 0 1 .249.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 0 1-.5 0v-.57l-.501.287a.25.25 0 0 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm-2.75-2a.25.25 0 0 1 .25.25v.57l.5-.287a.25.25 0 0 1 .249.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 0 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm5.5 0a.25.25 0 0 1 .25.25v.57l.5-.287a.25.25 0 0 1 .249.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 0 1-.5 0v-.57l-.501.287a.25.25 0 1 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm-.22-7.223a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10.25H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsCloudSnow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.405 4.277a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 10.25H13a3 3 0 0 0 .405-5.973zM8.5 1.25a4 4 0 0 1 3.976 3.555.5.5 0 0 0 .5.445H13a2 2 0 0 1-.001 4H3.5a2.5 2.5 0 1 1 .605-4.926.5.5 0 0 0 .596-.329A4.002 4.002 0 0 1 8.5 1.25zM2.625 11.5a.25.25 0 0 1 .25.25v.57l.501-.287a.25.25 0 0 1 .248.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 0 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm2.75 2a.25.25 0 0 1 .25.25v.57l.501-.287a.25.25 0 0 1 .248.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 0 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm5.5 0a.25.25 0 0 1 .25.25v.57l.501-.287a.25.25 0 0 1 .248.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 0 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm-2.75-2a.25.25 0 0 1 .25.25v.57l.501-.287a.25.25 0 0 1 .248.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 0 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25zm5.5 0a.25.25 0 0 1 .25.25v.57l.501-.287a.25.25 0 0 1 .248.434l-.495.283.495.283a.25.25 0 0 1-.248.434l-.501-.286v.569a.25.25 0 1 1-.5 0v-.57l-.501.287a.25.25 0 0 1-.248-.434l.495-.283-.495-.283a.25.25 0 0 1 .248-.434l.501.286v-.569a.25.25 0 0 1 .25-.25z\"}}]})(props);\n};\nexport function BsCloudSunFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.473 11a4.5 4.5 0 0 0-8.72-.99A3 3 0 0 0 3 16h8.5a2.5 2.5 0 0 0 0-5h-.027z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 1.5a.5.5 0 0 0-1 0v1a.5.5 0 0 0 1 0v-1zm3.743 1.964a.5.5 0 1 0-.707-.707l-.708.707a.5.5 0 0 0 .708.708l.707-.708zm-7.779-.707a.5.5 0 0 0-.707.707l.707.708a.5.5 0 1 0 .708-.708l-.708-.707zm1.734 3.374a2 2 0 1 1 3.296 2.198c.199.281.372.582.516.898a3 3 0 1 0-4.84-3.225c.352.011.696.055 1.028.129zm4.484 4.074c.6.215 1.125.59 1.522 1.072a.5.5 0 0 0 .039-.742l-.707-.707a.5.5 0 0 0-.854.377zM14.5 6.5a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1z\"}}]})(props);\n};\nexport function BsCloudSun (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 8a3.5 3.5 0 0 1 3.5 3.555.5.5 0 0 0 .624.492A1.503 1.503 0 0 1 13 13.5a1.5 1.5 0 0 1-1.5 1.5H3a2 2 0 1 1 .1-3.998.5.5 0 0 0 .51-.375A3.502 3.502 0 0 1 7 8zm4.473 3a4.5 4.5 0 0 0-8.72-.99A3 3 0 0 0 3 16h8.5a2.5 2.5 0 0 0 0-5h-.027z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 1.5a.5.5 0 0 0-1 0v1a.5.5 0 0 0 1 0v-1zm3.743 1.964a.5.5 0 1 0-.707-.707l-.708.707a.5.5 0 0 0 .708.708l.707-.708zm-7.779-.707a.5.5 0 0 0-.707.707l.707.708a.5.5 0 1 0 .708-.708l-.708-.707zm1.734 3.374a2 2 0 1 1 3.296 2.198c.199.281.372.582.516.898a3 3 0 1 0-4.84-3.225c.352.011.696.055 1.028.129zm4.484 4.074c.6.215 1.125.59 1.522 1.072a.5.5 0 0 0 .039-.742l-.707-.707a.5.5 0 0 0-.854.377zM14.5 6.5a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1z\"}}]})(props);\n};\nexport function BsCloudUploadFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 0a5.53 5.53 0 0 0-3.594 1.342c-.766.66-1.321 1.52-1.464 2.383C1.266 4.095 0 5.555 0 7.318 0 9.366 1.708 11 3.781 11H7.5V5.707L5.354 7.854a.5.5 0 1 1-.708-.708l3-3a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1-.708.708L8.5 5.707V11h4.188C14.502 11 16 9.57 16 7.773c0-1.636-1.242-2.969-2.834-3.194C12.923 1.999 10.69 0 8 0zm-.5 14.5V11h1v3.5a.5.5 0 0 1-1 0z\"}}]})(props);\n};\nexport function BsCloudUpload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4.406 1.342A5.53 5.53 0 0 1 8 0c2.69 0 4.923 2 5.166 4.579C14.758 4.804 16 6.137 16 7.773 16 9.569 14.502 11 12.687 11H10a.5.5 0 0 1 0-1h2.688C13.979 10 15 8.988 15 7.773c0-1.216-1.02-2.228-2.313-2.228h-.5v-.5C12.188 2.825 10.328 1 8 1a4.53 4.53 0 0 0-2.941 1.1c-.757.652-1.153 1.438-1.153 2.055v.448l-.445.049C2.064 4.805 1 5.952 1 7.318 1 8.785 2.23 10 3.781 10H6a.5.5 0 0 1 0 1H3.781C1.708 11 0 9.366 0 7.318c0-1.763 1.266-3.223 2.942-3.593.143-.863.698-1.723 1.464-2.383z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.646 4.146a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1-.708.708L8.5 5.707V14.5a.5.5 0 0 1-1 0V5.707L5.354 7.854a.5.5 0 1 1-.708-.708l3-3z\"}}]})(props);\n};\nexport function BsCloud (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.406 3.342A5.53 5.53 0 0 1 8 2c2.69 0 4.923 2 5.166 4.579C14.758 6.804 16 8.137 16 9.773 16 11.569 14.502 13 12.687 13H3.781C1.708 13 0 11.366 0 9.318c0-1.763 1.266-3.223 2.942-3.593.143-.863.698-1.723 1.464-2.383zm.653.757c-.757.653-1.153 1.44-1.153 2.056v.448l-.445.049C2.064 6.805 1 7.952 1 9.318 1 10.785 2.23 12 3.781 12h8.906C13.98 12 15 10.988 15 9.773c0-1.216-1.02-2.228-2.313-2.228h-.5v-.5C12.188 4.825 10.328 3 8 3a4.53 4.53 0 0 0-2.941 1.1z\"}}]})(props);\n};\nexport function BsCloudsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.473 9a4.5 4.5 0 0 0-8.72-.99A3 3 0 0 0 3 14h8.5a2.5 2.5 0 1 0-.027-5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.544 9.772a3.506 3.506 0 0 0-2.225-1.676 5.502 5.502 0 0 0-6.337-4.002 4.002 4.002 0 0 1 7.392.91 2.5 2.5 0 0 1 1.17 4.769z\"}}]})(props);\n};\nexport function BsClouds (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 7.5a2.5 2.5 0 0 1-1.456 2.272 3.513 3.513 0 0 0-.65-.824 1.5 1.5 0 0 0-.789-2.896.5.5 0 0 1-.627-.421 3 3 0 0 0-5.22-1.625 5.587 5.587 0 0 0-1.276.088 4.002 4.002 0 0 1 7.392.91A2.5 2.5 0 0 1 16 7.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 5a4.5 4.5 0 0 1 4.473 4h.027a2.5 2.5 0 0 1 0 5H3a3 3 0 0 1-.247-5.99A4.502 4.502 0 0 1 7 5zm3.5 4.5a3.5 3.5 0 0 0-6.89-.873.5.5 0 0 1-.51.375A2 2 0 1 0 3 13h8.5a1.5 1.5 0 1 0-.376-2.953.5.5 0 0 1-.624-.492V9.5z\"}}]})(props);\n};\nexport function BsCloudyFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.405 7.027a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 13H13a3 3 0 0 0 .405-5.973z\"}}]})(props);\n};\nexport function BsCloudy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.405 8.527a5.001 5.001 0 0 0-9.499-1.004A3.5 3.5 0 1 0 3.5 14.5H13a3 3 0 0 0 .405-5.973zM8.5 5.5a4 4 0 0 1 3.976 3.555.5.5 0 0 0 .5.445H13a2 2 0 0 1-.001 4H3.5a2.5 2.5 0 1 1 .605-4.926.5.5 0 0 0 .596-.329A4.002 4.002 0 0 1 8.5 5.5z\"}}]})(props);\n};\nexport function BsCodeSlash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.478 1.647a.5.5 0 1 0-.956-.294l-4 13a.5.5 0 0 0 .956.294l4-13zM4.854 4.146a.5.5 0 0 1 0 .708L1.707 8l3.147 3.146a.5.5 0 0 1-.708.708l-3.5-3.5a.5.5 0 0 1 0-.708l3.5-3.5a.5.5 0 0 1 .708 0zm6.292 0a.5.5 0 0 0 0 .708L14.293 8l-3.147 3.146a.5.5 0 0 0 .708.708l3.5-3.5a.5.5 0 0 0 0-.708l-3.5-3.5a.5.5 0 0 0-.708 0z\"}}]})(props);\n};\nexport function BsCodeSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.854 4.646a.5.5 0 0 1 0 .708L4.207 8l2.647 2.646a.5.5 0 0 1-.708.708l-3-3a.5.5 0 0 1 0-.708l3-3a.5.5 0 0 1 .708 0zm2.292 0a.5.5 0 0 0 0 .708L11.793 8l-2.647 2.646a.5.5 0 0 0 .708.708l3-3a.5.5 0 0 0 0-.708l-3-3a.5.5 0 0 0-.708 0z\"}}]})(props);\n};\nexport function BsCode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.854 4.854a.5.5 0 1 0-.708-.708l-3.5 3.5a.5.5 0 0 0 0 .708l3.5 3.5a.5.5 0 0 0 .708-.708L2.707 8l3.147-3.146zm4.292 0a.5.5 0 0 1 .708-.708l3.5 3.5a.5.5 0 0 1 0 .708l-3.5 3.5a.5.5 0 0 1-.708-.708L13.293 8l-3.147-3.146z\"}}]})(props);\n};\nexport function BsCoin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 9.511c.076.954.83 1.697 2.182 1.785V12h.6v-.709c1.4-.098 2.218-.846 2.218-1.932 0-.987-.626-1.496-1.745-1.76l-.473-.112V5.57c.6.068.982.396 1.074.85h1.052c-.076-.919-.864-1.638-2.126-1.716V4h-.6v.719c-1.195.117-2.01.836-2.01 1.853 0 .9.606 1.472 1.613 1.707l.397.098v2.034c-.615-.093-1.022-.43-1.114-.9H5.5zm2.177-2.166c-.59-.137-.91-.416-.91-.836 0-.47.345-.822.915-.925v1.76h-.005zm.692 1.193c.717.166 1.048.435 1.048.91 0 .542-.412.914-1.135.982V8.518l.087.02z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13.5a5.5 5.5 0 1 1 0-11 5.5 5.5 0 0 1 0 11zm0 .5A6 6 0 1 0 8 2a6 6 0 0 0 0 12z\"}}]})(props);\n};\nexport function BsCollectionFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 13a1.5 1.5 0 0 0 1.5 1.5h13A1.5 1.5 0 0 0 16 13V6a1.5 1.5 0 0 0-1.5-1.5h-13A1.5 1.5 0 0 0 0 6v7zM2 3a.5.5 0 0 0 .5.5h11a.5.5 0 0 0 0-1h-11A.5.5 0 0 0 2 3zm2-2a.5.5 0 0 0 .5.5h7a.5.5 0 0 0 0-1h-7A.5.5 0 0 0 4 1z\"}}]})(props);\n};\nexport function BsCollectionPlayFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 3.5a.5.5 0 0 1 0-1h11a.5.5 0 0 1 0 1h-11zm2-2a.5.5 0 0 1 0-1h7a.5.5 0 0 1 0 1h-7zM0 13a1.5 1.5 0 0 0 1.5 1.5h13A1.5 1.5 0 0 0 16 13V6a1.5 1.5 0 0 0-1.5-1.5h-13A1.5 1.5 0 0 0 0 6v7zm6.258-6.437a.5.5 0 0 1 .507.013l4 2.5a.5.5 0 0 1 0 .848l-4 2.5A.5.5 0 0 1 6 12V7a.5.5 0 0 1 .258-.437z\"}}]})(props);\n};\nexport function BsCollectionPlay (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 3a.5.5 0 0 0 .5.5h11a.5.5 0 0 0 0-1h-11A.5.5 0 0 0 2 3zm2-2a.5.5 0 0 0 .5.5h7a.5.5 0 0 0 0-1h-7A.5.5 0 0 0 4 1zm2.765 5.576A.5.5 0 0 0 6 7v5a.5.5 0 0 0 .765.424l4-2.5a.5.5 0 0 0 0-.848l-4-2.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 14.5A1.5 1.5 0 0 1 0 13V6a1.5 1.5 0 0 1 1.5-1.5h13A1.5 1.5 0 0 1 16 6v7a1.5 1.5 0 0 1-1.5 1.5h-13zm13-1a.5.5 0 0 0 .5-.5V6a.5.5 0 0 0-.5-.5h-13A.5.5 0 0 0 1 6v7a.5.5 0 0 0 .5.5h13z\"}}]})(props);\n};\nexport function BsCollection (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 3.5a.5.5 0 0 1 0-1h11a.5.5 0 0 1 0 1h-11zm2-2a.5.5 0 0 1 0-1h7a.5.5 0 0 1 0 1h-7zM0 13a1.5 1.5 0 0 0 1.5 1.5h13A1.5 1.5 0 0 0 16 13V6a1.5 1.5 0 0 0-1.5-1.5h-13A1.5 1.5 0 0 0 0 6v7zm1.5.5A.5.5 0 0 1 1 13V6a.5.5 0 0 1 .5-.5h13a.5.5 0 0 1 .5.5v7a.5.5 0 0 1-.5.5h-13z\"}}]})(props);\n};\nexport function BsColumnsGap (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 1v3H1V1h5zM1 0a1 1 0 0 0-1 1v3a1 1 0 0 0 1 1h5a1 1 0 0 0 1-1V1a1 1 0 0 0-1-1H1zm14 12v3h-5v-3h5zm-5-1a1 1 0 0 0-1 1v3a1 1 0 0 0 1 1h5a1 1 0 0 0 1-1v-3a1 1 0 0 0-1-1h-5zM6 8v7H1V8h5zM1 7a1 1 0 0 0-1 1v7a1 1 0 0 0 1 1h5a1 1 0 0 0 1-1V8a1 1 0 0 0-1-1H1zm14-6v7h-5V1h5zm-5-1a1 1 0 0 0-1 1v7a1 1 0 0 0 1 1h5a1 1 0 0 0 1-1V1a1 1 0 0 0-1-1h-5z\"}}]})(props);\n};\nexport function BsColumns (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a1 1 0 0 1 1-1h14a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H1a1 1 0 0 1-1-1V2zm8.5 0v8H15V2H8.5zm0 9v3H15v-3H8.5zm-1-9H1v3h6.5V2zM1 14h6.5V6H1v8z\"}}]})(props);\n};\nexport function BsCommand (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 2A1.5 1.5 0 0 1 5 3.5V5H3.5a1.5 1.5 0 1 1 0-3zM6 5V3.5A2.5 2.5 0 1 0 3.5 6H5v4H3.5A2.5 2.5 0 1 0 6 12.5V11h4v1.5a2.5 2.5 0 1 0 2.5-2.5H11V6h1.5A2.5 2.5 0 1 0 10 3.5V5H6zm4 1v4H6V6h4zm1-1V3.5A1.5 1.5 0 1 1 12.5 5H11zm0 6h1.5a1.5 1.5 0 1 1-1.5 1.5V11zm-6 0v1.5A1.5 1.5 0 1 1 3.5 11H5z\"}}]})(props);\n};\nexport function BsCompassFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.5 8.516a7.5 7.5 0 1 1-9.462-7.24A1 1 0 0 1 7 0h2a1 1 0 0 1 .962 1.276 7.503 7.503 0 0 1 5.538 7.24zm-3.61-3.905L6.94 7.439 4.11 12.39l4.95-2.828 2.828-4.95z\"}}]})(props);\n};\nexport function BsCompass (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16.016a7.5 7.5 0 0 0 1.962-14.74A1 1 0 0 0 9 0H7a1 1 0 0 0-.962 1.276A7.5 7.5 0 0 0 8 16.016zm6.5-7.5a6.5 6.5 0 1 1-13 0 6.5 6.5 0 0 1 13 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m6.94 7.44 4.95-2.83-2.83 4.95-4.949 2.83 2.828-4.95z\"}}]})(props);\n};\nexport function BsConeStriped (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m9.97 4.88.953 3.811C10.159 8.878 9.14 9 8 9c-1.14 0-2.158-.122-2.923-.309L6.03 4.88C6.635 4.957 7.3 5 8 5s1.365-.043 1.97-.12zm-.245-.978L8.97.88C8.718-.13 7.282-.13 7.03.88L6.275 3.9C6.8 3.965 7.382 4 8 4c.618 0 1.2-.036 1.725-.098zm4.396 8.613a.5.5 0 0 1 .037.96l-6 2a.5.5 0 0 1-.316 0l-6-2a.5.5 0 0 1 .037-.96l2.391-.598.565-2.257c.862.212 1.964.339 3.165.339s2.303-.127 3.165-.339l.565 2.257 2.391.598z\"}}]})(props);\n};\nexport function BsCone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.03 1.88c.252-1.01 1.688-1.01 1.94 0l2.905 11.62H14a.5.5 0 0 1 0 1H2a.5.5 0 0 1 0-1h2.125L7.03 1.88z\"}}]})(props);\n};\nexport function BsController (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.5 6.027a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm-1.5 1.5a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1zm2.5-.5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm-1.5 1.5a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1zm-6.5-3h1v1h1v1h-1v1h-1v-1h-1v-1h1v-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.051 3.26a.5.5 0 0 1 .354-.613l1.932-.518a.5.5 0 0 1 .62.39c.655-.079 1.35-.117 2.043-.117.72 0 1.443.041 2.12.126a.5.5 0 0 1 .622-.399l1.932.518a.5.5 0 0 1 .306.729c.14.09.266.19.373.297.408.408.78 1.05 1.095 1.772.32.733.599 1.591.805 2.466.206.875.34 1.78.364 2.606.024.816-.059 1.602-.328 2.21a1.42 1.42 0 0 1-1.445.83c-.636-.067-1.115-.394-1.513-.773-.245-.232-.496-.526-.739-.808-.126-.148-.25-.292-.368-.423-.728-.804-1.597-1.527-3.224-1.527-1.627 0-2.496.723-3.224 1.527-.119.131-.242.275-.368.423-.243.282-.494.575-.739.808-.398.38-.877.706-1.513.773a1.42 1.42 0 0 1-1.445-.83c-.27-.608-.352-1.395-.329-2.21.024-.826.16-1.73.365-2.606.206-.875.486-1.733.805-2.466.315-.722.687-1.364 1.094-1.772a2.34 2.34 0 0 1 .433-.335.504.504 0 0 1-.028-.079zm2.036.412c-.877.185-1.469.443-1.733.708-.276.276-.587.783-.885 1.465a13.748 13.748 0 0 0-.748 2.295 12.351 12.351 0 0 0-.339 2.406c-.022.755.062 1.368.243 1.776a.42.42 0 0 0 .426.24c.327-.034.61-.199.929-.502.212-.202.4-.423.615-.674.133-.156.276-.323.44-.504C4.861 9.969 5.978 9.027 8 9.027s3.139.942 3.965 1.855c.164.181.307.348.44.504.214.251.403.472.615.674.318.303.601.468.929.503a.42.42 0 0 0 .426-.241c.18-.408.265-1.02.243-1.776a12.354 12.354 0 0 0-.339-2.406 13.753 13.753 0 0 0-.748-2.295c-.298-.682-.61-1.19-.885-1.465-.264-.265-.856-.523-1.733-.708-.85-.179-1.877-.27-2.913-.27-1.036 0-2.063.091-2.913.27z\"}}]})(props);\n};\nexport function BsCpuFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 6a.5.5 0 0 0-.5.5v3a.5.5 0 0 0 .5.5h3a.5.5 0 0 0 .5-.5v-3a.5.5 0 0 0-.5-.5h-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5.5a.5.5 0 0 0-1 0V2A2.5 2.5 0 0 0 2 4.5H.5a.5.5 0 0 0 0 1H2v1H.5a.5.5 0 0 0 0 1H2v1H.5a.5.5 0 0 0 0 1H2v1H.5a.5.5 0 0 0 0 1H2A2.5 2.5 0 0 0 4.5 14v1.5a.5.5 0 0 0 1 0V14h1v1.5a.5.5 0 0 0 1 0V14h1v1.5a.5.5 0 0 0 1 0V14h1v1.5a.5.5 0 0 0 1 0V14a2.5 2.5 0 0 0 2.5-2.5h1.5a.5.5 0 0 0 0-1H14v-1h1.5a.5.5 0 0 0 0-1H14v-1h1.5a.5.5 0 0 0 0-1H14v-1h1.5a.5.5 0 0 0 0-1H14A2.5 2.5 0 0 0 11.5 2V.5a.5.5 0 0 0-1 0V2h-1V.5a.5.5 0 0 0-1 0V2h-1V.5a.5.5 0 0 0-1 0V2h-1V.5zm1 4.5h3A1.5 1.5 0 0 1 11 6.5v3A1.5 1.5 0 0 1 9.5 11h-3A1.5 1.5 0 0 1 5 9.5v-3A1.5 1.5 0 0 1 6.5 5z\"}}]})(props);\n};\nexport function BsCpu (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 0a.5.5 0 0 1 .5.5V2h1V.5a.5.5 0 0 1 1 0V2h1V.5a.5.5 0 0 1 1 0V2h1V.5a.5.5 0 0 1 1 0V2A2.5 2.5 0 0 1 14 4.5h1.5a.5.5 0 0 1 0 1H14v1h1.5a.5.5 0 0 1 0 1H14v1h1.5a.5.5 0 0 1 0 1H14v1h1.5a.5.5 0 0 1 0 1H14a2.5 2.5 0 0 1-2.5 2.5v1.5a.5.5 0 0 1-1 0V14h-1v1.5a.5.5 0 0 1-1 0V14h-1v1.5a.5.5 0 0 1-1 0V14h-1v1.5a.5.5 0 0 1-1 0V14A2.5 2.5 0 0 1 2 11.5H.5a.5.5 0 0 1 0-1H2v-1H.5a.5.5 0 0 1 0-1H2v-1H.5a.5.5 0 0 1 0-1H2v-1H.5a.5.5 0 0 1 0-1H2A2.5 2.5 0 0 1 4.5 2V.5A.5.5 0 0 1 5 0zm-.5 3A1.5 1.5 0 0 0 3 4.5v7A1.5 1.5 0 0 0 4.5 13h7a1.5 1.5 0 0 0 1.5-1.5v-7A1.5 1.5 0 0 0 11.5 3h-7zM5 6.5A1.5 1.5 0 0 1 6.5 5h3A1.5 1.5 0 0 1 11 6.5v3A1.5 1.5 0 0 1 9.5 11h-3A1.5 1.5 0 0 1 5 9.5v-3zM6.5 6a.5.5 0 0 0-.5.5v3a.5.5 0 0 0 .5.5h3a.5.5 0 0 0 .5-.5v-3a.5.5 0 0 0-.5-.5h-3z\"}}]})(props);\n};\nexport function BsCreditCard2BackFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v5H0V4zm11.5 1a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h2a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-2zM0 11v1a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-1H0z\"}}]})(props);\n};\nexport function BsCreditCard2Back (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 5.5a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1-.5-.5v-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm13 2v5H1V4a1 1 0 0 1 1-1h12a1 1 0 0 1 1 1zm-1 9H2a1 1 0 0 1-1-1v-1h14v1a1 1 0 0 1-1 1z\"}}]})(props);\n};\nexport function BsCreditCard2FrontFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm2.5 1a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h2a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-2zm0 3a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5zm0 2a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1zm3 0a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1zm3 0a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1zm3 0a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1z\"}}]})(props);\n};\nexport function BsCreditCard2Front (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h12zM2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 5.5a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1-.5-.5v-1zm0 3a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 0 1h-1a.5.5 0 0 1-.5-.5zm3 0a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 0 1h-1a.5.5 0 0 1-.5-.5zm3 0a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 0 1h-1a.5.5 0 0 1-.5-.5zm3 0a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 0 1h-1a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsCreditCardFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v1H0V4zm0 3v5a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7H0zm3 2h1a1 1 0 0 1 1 1v1a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1v-1a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsCreditCard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm2-1a1 1 0 0 0-1 1v1h14V4a1 1 0 0 0-1-1H2zm13 4H1v5a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 10a1 1 0 0 1 1-1h1a1 1 0 0 1 1 1v1a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1v-1z\"}}]})(props);\n};\nexport function BsCrop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5.5A.5.5 0 0 1 4 1v13h13a.5.5 0 0 1 0 1h-2v2a.5.5 0 0 1-1 0v-2H3.5a.5.5 0 0 1-.5-.5V4H1a.5.5 0 0 1 0-1h2V1a.5.5 0 0 1 .5-.5zm2.5 3a.5.5 0 0 1 .5-.5h8a.5.5 0 0 1 .5.5v8a.5.5 0 0 1-1 0V4H6.5a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsCupFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 2a1 1 0 0 1 1-1h11a1 1 0 0 1 1 1v1h.5A1.5 1.5 0 0 1 16 4.5v7a1.5 1.5 0 0 1-1.5 1.5h-.55a2.5 2.5 0 0 1-2.45 2h-8A2.5 2.5 0 0 1 1 12.5V2zm13 10h.5a.5.5 0 0 0 .5-.5v-7a.5.5 0 0 0-.5-.5H14v8z\"}}]})(props);\n};\nexport function BsCupStraw (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.902.334a.5.5 0 0 1-.28.65l-2.254.902-.4 1.927c.376.095.715.215.972.367.228.135.56.396.56.82 0 .046-.004.09-.011.132l-.962 9.068a1.28 1.28 0 0 1-.524.93c-.488.34-1.494.87-3.01.87-1.516 0-2.522-.53-3.01-.87a1.28 1.28 0 0 1-.524-.93L3.51 5.132A.78.78 0 0 1 3.5 5c0-.424.332-.685.56-.82.262-.154.607-.276.99-.372C5.824 3.614 6.867 3.5 8 3.5c.712 0 1.389.045 1.985.127l.464-2.215a.5.5 0 0 1 .303-.356l2.5-1a.5.5 0 0 1 .65.278zM9.768 4.607A13.991 13.991 0 0 0 8 4.5c-1.076 0-2.033.11-2.707.278A3.284 3.284 0 0 0 4.645 5c.146.073.362.15.648.222C5.967 5.39 6.924 5.5 8 5.5c.571 0 1.109-.03 1.588-.085l.18-.808zm.292 1.756C9.445 6.45 8.742 6.5 8 6.5c-1.133 0-2.176-.114-2.95-.308a5.514 5.514 0 0 1-.435-.127l.838 8.03c.013.121.06.186.102.215.357.249 1.168.69 2.438.69 1.27 0 2.081-.441 2.438-.69.042-.029.09-.094.102-.215l.852-8.03a5.517 5.517 0 0 1-.435.127 8.88 8.88 0 0 1-.89.17zM4.467 4.884s.003.002.005.006l-.005-.006zm7.066 0-.005.006c.002-.004.005-.006.005-.006zM11.354 5a3.174 3.174 0 0 0-.604-.21l-.099.445.055-.013c.286-.072.502-.149.648-.222z\"}}]})(props);\n};\nexport function BsCup (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 2a1 1 0 0 1 1-1h11a1 1 0 0 1 1 1v1h.5A1.5 1.5 0 0 1 16 4.5v7a1.5 1.5 0 0 1-1.5 1.5h-.55a2.5 2.5 0 0 1-2.45 2h-8A2.5 2.5 0 0 1 1 12.5V2zm13 10h.5a.5.5 0 0 0 .5-.5v-7a.5.5 0 0 0-.5-.5H14v8zM13 2H2v10.5A1.5 1.5 0 0 0 3.5 14h8a1.5 1.5 0 0 0 1.5-1.5V2z\"}}]})(props);\n};\nexport function BsCurrencyBitcoin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 13v1.25c0 .138.112.25.25.25h1a.25.25 0 0 0 .25-.25V13h.5v1.25c0 .138.112.25.25.25h1a.25.25 0 0 0 .25-.25V13h.084c1.992 0 3.416-1.033 3.416-2.82 0-1.502-1.007-2.323-2.186-2.44v-.088c.97-.242 1.683-.974 1.683-2.19C11.997 3.93 10.847 3 9.092 3H9V1.75a.25.25 0 0 0-.25-.25h-1a.25.25 0 0 0-.25.25V3h-.573V1.75a.25.25 0 0 0-.25-.25H5.75a.25.25 0 0 0-.25.25V3l-1.998.011a.25.25 0 0 0-.25.25v.989c0 .137.11.25.248.25l.755-.005a.75.75 0 0 1 .745.75v5.505a.75.75 0 0 1-.75.75l-.748.011a.25.25 0 0 0-.25.25v1c0 .138.112.25.25.25L5.5 13zm1.427-8.513h1.719c.906 0 1.438.498 1.438 1.312 0 .871-.575 1.362-1.877 1.362h-1.28V4.487zm0 4.051h1.84c1.137 0 1.756.58 1.756 1.524 0 .953-.626 1.45-2.158 1.45H6.927V8.539z\"}}]})(props);\n};\nexport function BsCurrencyDollar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 10.781c.148 1.667 1.513 2.85 3.591 3.003V15h1.043v-1.216c2.27-.179 3.678-1.438 3.678-3.3 0-1.59-.947-2.51-2.956-3.028l-.722-.187V3.467c1.122.11 1.879.714 2.07 1.616h1.47c-.166-1.6-1.54-2.748-3.54-2.875V1H7.591v1.233c-1.939.23-3.27 1.472-3.27 3.156 0 1.454.966 2.483 2.661 2.917l.61.162v4.031c-1.149-.17-1.94-.8-2.131-1.718H4zm3.391-3.836c-1.043-.263-1.6-.825-1.6-1.616 0-.944.704-1.641 1.8-1.828v3.495l-.2-.05zm1.591 1.872c1.287.323 1.852.859 1.852 1.769 0 1.097-.826 1.828-2.2 1.939V8.73l.348.086z\"}}]})(props);\n};\nexport function BsCurrencyEuro (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 9.42h1.063C5.4 12.323 7.317 14 10.34 14c.622 0 1.167-.068 1.659-.185v-1.3c-.484.119-1.045.17-1.659.17-2.1 0-3.455-1.198-3.775-3.264h4.017v-.928H6.497v-.936c0-.11 0-.219.008-.329h4.078v-.927H6.618c.388-1.898 1.719-2.985 3.723-2.985.614 0 1.175.05 1.659.177V2.194A6.617 6.617 0 0 0 10.341 2c-2.928 0-4.82 1.569-5.244 4.3H4v.928h1.01v1.265H4v.928z\"}}]})(props);\n};\nexport function BsCurrencyExchange (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 5a5.002 5.002 0 0 0 4.027 4.905 6.46 6.46 0 0 1 .544-2.073C3.695 7.536 3.132 6.864 3 5.91h-.5v-.426h.466V5.05c0-.046 0-.093.004-.135H2.5v-.427h.511C3.236 3.24 4.213 2.5 5.681 2.5c.316 0 .59.031.819.085v.733a3.46 3.46 0 0 0-.815-.082c-.919 0-1.538.466-1.734 1.252h1.917v.427h-1.98c-.003.046-.003.097-.003.147v.422h1.983v.427H3.93c.118.602.468 1.03 1.005 1.229a6.5 6.5 0 0 1 4.97-3.113A5.002 5.002 0 0 0 0 5zm16 5.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0zm-7.75 1.322c.069.835.746 1.485 1.964 1.562V14h.54v-.62c1.259-.086 1.996-.74 1.996-1.69 0-.865-.563-1.31-1.57-1.54l-.426-.1V8.374c.54.06.884.347.966.745h.948c-.07-.804-.779-1.433-1.914-1.502V7h-.54v.629c-1.076.103-1.808.732-1.808 1.622 0 .787.544 1.288 1.45 1.493l.358.085v1.78c-.554-.08-.92-.376-1.003-.787H8.25zm1.96-1.895c-.532-.12-.82-.364-.82-.732 0-.41.311-.719.824-.809v1.54h-.005zm.622 1.044c.645.145.943.38.943.796 0 .474-.37.8-1.02.86v-1.674l.077.018z\"}}]})(props);\n};\nexport function BsCurrencyPound (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8.585h1.969c.115.465.186.939.186 1.43 0 1.385-.736 2.496-2.075 2.771V14H12v-1.24H6.492v-.129c.825-.525 1.135-1.446 1.135-2.694 0-.465-.07-.913-.168-1.352h3.29v-.972H7.22c-.186-.723-.372-1.455-.372-2.247 0-1.274 1.047-2.066 2.58-2.066a5.32 5.32 0 0 1 2.103.465V2.456A5.629 5.629 0 0 0 9.348 2C6.865 2 5.322 3.291 5.322 5.366c0 .775.195 1.515.399 2.247H4v.972z\"}}]})(props);\n};\nexport function BsCurrencyYen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.75 14v-2.629h2.446v-.967H8.75v-1.31h2.445v-.967H9.128L12.5 2h-1.699L8.047 7.327h-.086L5.207 2H3.5l3.363 6.127H4.778v.968H7.25v1.31H4.78v.966h2.47V14h1.502z\"}}]})(props);\n};\nexport function BsCursorFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14.082 2.182a.5.5 0 0 1 .103.557L8.528 15.467a.5.5 0 0 1-.917-.007L5.57 10.694.803 8.652a.5.5 0 0 1-.006-.916l12.728-5.657a.5.5 0 0 1 .556.103z\"}}]})(props);\n};\nexport function BsCursorText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 2a.5.5 0 0 1 .5-.5c.862 0 1.573.287 2.06.566.174.099.321.198.44.286.119-.088.266-.187.44-.286A4.165 4.165 0 0 1 10.5 1.5a.5.5 0 0 1 0 1c-.638 0-1.177.213-1.564.434a3.49 3.49 0 0 0-.436.294V7.5H9a.5.5 0 0 1 0 1h-.5v4.272c.1.08.248.187.436.294.387.221.926.434 1.564.434a.5.5 0 0 1 0 1 4.165 4.165 0 0 1-2.06-.566A4.561 4.561 0 0 1 8 13.65a4.561 4.561 0 0 1-.44.285 4.165 4.165 0 0 1-2.06.566.5.5 0 0 1 0-1c.638 0 1.177-.213 1.564-.434.188-.107.335-.214.436-.294V8.5H7a.5.5 0 0 1 0-1h.5V3.228a3.49 3.49 0 0 0-.436-.294A3.166 3.166 0 0 0 5.5 2.5.5.5 0 0 1 5 2zm3.352 1.355zm-.704 9.29z\"}}]})(props);\n};\nexport function BsCursor (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14.082 2.182a.5.5 0 0 1 .103.557L8.528 15.467a.5.5 0 0 1-.917-.007L5.57 10.694.803 8.652a.5.5 0 0 1-.006-.916l12.728-5.657a.5.5 0 0 1 .556.103zM2.25 8.184l3.897 1.67a.5.5 0 0 1 .262.263l1.67 3.897L12.743 3.52 2.25 8.184z\"}}]})(props);\n};\nexport function BsDashCircleDotted (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0c-.176 0-.35.006-.523.017l.064.998a7.117 7.117 0 0 1 .918 0l.064-.998A8.113 8.113 0 0 0 8 0zM6.44.152c-.346.069-.684.16-1.012.27l.321.948c.287-.098.582-.177.884-.237L6.44.153zm4.132.271a7.946 7.946 0 0 0-1.011-.27l-.194.98c.302.06.597.14.884.237l.321-.947zm1.873.925a8 8 0 0 0-.906-.524l-.443.896c.275.136.54.29.793.459l.556-.831zM4.46.824c-.314.155-.616.33-.905.524l.556.83a7.07 7.07 0 0 1 .793-.458L4.46.824zM2.725 1.985c-.262.23-.51.478-.74.74l.752.66c.202-.23.418-.446.648-.648l-.66-.752zm11.29.74a8.058 8.058 0 0 0-.74-.74l-.66.752c.23.202.447.418.648.648l.752-.66zm1.161 1.735a7.98 7.98 0 0 0-.524-.905l-.83.556c.169.253.322.518.458.793l.896-.443zM1.348 3.555c-.194.289-.37.591-.524.906l.896.443c.136-.275.29-.54.459-.793l-.831-.556zM.423 5.428a7.945 7.945 0 0 0-.27 1.011l.98.194c.06-.302.14-.597.237-.884l-.947-.321zM15.848 6.44a7.943 7.943 0 0 0-.27-1.012l-.948.321c.098.287.177.582.237.884l.98-.194zM.017 7.477a8.113 8.113 0 0 0 0 1.046l.998-.064a7.117 7.117 0 0 1 0-.918l-.998-.064zM16 8a8.1 8.1 0 0 0-.017-.523l-.998.064a7.11 7.11 0 0 1 0 .918l.998.064A8.1 8.1 0 0 0 16 8zM.152 9.56c.069.346.16.684.27 1.012l.948-.321a6.944 6.944 0 0 1-.237-.884l-.98.194zm15.425 1.012c.112-.328.202-.666.27-1.011l-.98-.194c-.06.302-.14.597-.237.884l.947.321zM.824 11.54a8 8 0 0 0 .524.905l.83-.556a6.999 6.999 0 0 1-.458-.793l-.896.443zm13.828.905c.194-.289.37-.591.524-.906l-.896-.443c-.136.275-.29.54-.459.793l.831.556zm-12.667.83c.23.262.478.51.74.74l.66-.752a7.047 7.047 0 0 1-.648-.648l-.752.66zm11.29.74c.262-.23.51-.478.74-.74l-.752-.66c-.201.23-.418.447-.648.648l.66.752zm-1.735 1.161c.314-.155.616-.33.905-.524l-.556-.83a7.07 7.07 0 0 1-.793.458l.443.896zm-7.985-.524c.289.194.591.37.906.524l.443-.896a6.998 6.998 0 0 1-.793-.459l-.556.831zm1.873.925c.328.112.666.202 1.011.27l.194-.98a6.953 6.953 0 0 1-.884-.237l-.321.947zm4.132.271a7.944 7.944 0 0 0 1.012-.27l-.321-.948a6.954 6.954 0 0 1-.884.237l.194.98zm-2.083.135a8.1 8.1 0 0 0 1.046 0l-.064-.998a7.11 7.11 0 0 1-.918 0l-.064.998zM4.5 7.5a.5.5 0 0 0 0 1h7a.5.5 0 0 0 0-1h-7z\"}}]})(props);\n};\nexport function BsDashCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM4.5 7.5a.5.5 0 0 0 0 1h7a.5.5 0 0 0 0-1h-7z\"}}]})(props);\n};\nexport function BsDashCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7A.5.5 0 0 1 4 8z\"}}]})(props);\n};\nexport function BsDashLg (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 8a1 1 0 0 1 1-1h14a1 1 0 1 1 0 2H1a1 1 0 0 1-1-1z\"}}]})(props);\n};\nexport function BsDashSquareDotted (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 0c-.166 0-.33.016-.487.048l.194.98A1.51 1.51 0 0 1 2.5 1h.458V0H2.5zm2.292 0h-.917v1h.917V0zm1.833 0h-.917v1h.917V0zm1.833 0h-.916v1h.916V0zm1.834 0h-.917v1h.917V0zm1.833 0h-.917v1h.917V0zM13.5 0h-.458v1h.458c.1 0 .199.01.293.029l.194-.981A2.51 2.51 0 0 0 13.5 0zm2.079 1.11a2.511 2.511 0 0 0-.69-.689l-.556.831c.164.11.305.251.415.415l.83-.556zM1.11.421a2.511 2.511 0 0 0-.689.69l.831.556c.11-.164.251-.305.415-.415L1.11.422zM16 2.5c0-.166-.016-.33-.048-.487l-.98.194c.018.094.028.192.028.293v.458h1V2.5zM.048 2.013A2.51 2.51 0 0 0 0 2.5v.458h1V2.5c0-.1.01-.199.029-.293l-.981-.194zM0 3.875v.917h1v-.917H0zm16 .917v-.917h-1v.917h1zM0 5.708v.917h1v-.917H0zm16 .917v-.917h-1v.917h1zM0 7.542v.916h1v-.916H0zm15 .916h1v-.916h-1v.916zM0 9.375v.917h1v-.917H0zm16 .917v-.917h-1v.917h1zm-16 .916v.917h1v-.917H0zm16 .917v-.917h-1v.917h1zm-16 .917v.458c0 .166.016.33.048.487l.98-.194A1.51 1.51 0 0 1 1 13.5v-.458H0zm16 .458v-.458h-1v.458c0 .1-.01.199-.029.293l.981.194c.032-.158.048-.32.048-.487zM.421 14.89c.183.272.417.506.69.689l.556-.831a1.51 1.51 0 0 1-.415-.415l-.83.556zm14.469.689c.272-.183.506-.417.689-.69l-.831-.556c-.11.164-.251.305-.415.415l.556.83zm-12.877.373c.158.032.32.048.487.048h.458v-1H2.5c-.1 0-.199-.01-.293-.029l-.194.981zM13.5 16c.166 0 .33-.016.487-.048l-.194-.98A1.51 1.51 0 0 1 13.5 15h-.458v1h.458zm-9.625 0h.917v-1h-.917v1zm1.833 0h.917v-1h-.917v1zm1.834 0h.916v-1h-.916v1zm1.833 0h.917v-1h-.917v1zm1.833 0h.917v-1h-.917v1zM4.5 7.5a.5.5 0 0 0 0 1h7a.5.5 0 0 0 0-1h-7z\"}}]})(props);\n};\nexport function BsDashSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm2.5 7.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsDashSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7A.5.5 0 0 1 4 8z\"}}]})(props);\n};\nexport function BsDash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7A.5.5 0 0 1 4 8z\"}}]})(props);\n};\nexport function BsDiagram2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 3.5A1.5 1.5 0 0 1 7.5 2h1A1.5 1.5 0 0 1 10 3.5v1A1.5 1.5 0 0 1 8.5 6v1H11a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-1 0V8h-5v.5a.5.5 0 0 1-1 0v-1A.5.5 0 0 1 5 7h2.5V6A1.5 1.5 0 0 1 6 4.5v-1zm-3 8A1.5 1.5 0 0 1 4.5 10h1A1.5 1.5 0 0 1 7 11.5v1A1.5 1.5 0 0 1 5.5 14h-1A1.5 1.5 0 0 1 3 12.5v-1zm6 0a1.5 1.5 0 0 1 1.5-1.5h1a1.5 1.5 0 0 1 1.5 1.5v1a1.5 1.5 0 0 1-1.5 1.5h-1A1.5 1.5 0 0 1 9 12.5v-1z\"}}]})(props);\n};\nexport function BsDiagram2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 3.5A1.5 1.5 0 0 1 7.5 2h1A1.5 1.5 0 0 1 10 3.5v1A1.5 1.5 0 0 1 8.5 6v1H11a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-1 0V8h-5v.5a.5.5 0 0 1-1 0v-1A.5.5 0 0 1 5 7h2.5V6A1.5 1.5 0 0 1 6 4.5v-1zM8.5 5a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1zM3 11.5A1.5 1.5 0 0 1 4.5 10h1A1.5 1.5 0 0 1 7 11.5v1A1.5 1.5 0 0 1 5.5 14h-1A1.5 1.5 0 0 1 3 12.5v-1zm1.5-.5a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zm4.5.5a1.5 1.5 0 0 1 1.5-1.5h1a1.5 1.5 0 0 1 1.5 1.5v1a1.5 1.5 0 0 1-1.5 1.5h-1A1.5 1.5 0 0 1 9 12.5v-1zm1.5-.5a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1z\"}}]})(props);\n};\nexport function BsDiagram3Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 3.5A1.5 1.5 0 0 1 7.5 2h1A1.5 1.5 0 0 1 10 3.5v1A1.5 1.5 0 0 1 8.5 6v1H14a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-1 0V8h-5v.5a.5.5 0 0 1-1 0V8h-5v.5a.5.5 0 0 1-1 0v-1A.5.5 0 0 1 2 7h5.5V6A1.5 1.5 0 0 1 6 4.5v-1zm-6 8A1.5 1.5 0 0 1 1.5 10h1A1.5 1.5 0 0 1 4 11.5v1A1.5 1.5 0 0 1 2.5 14h-1A1.5 1.5 0 0 1 0 12.5v-1zm6 0A1.5 1.5 0 0 1 7.5 10h1a1.5 1.5 0 0 1 1.5 1.5v1A1.5 1.5 0 0 1 8.5 14h-1A1.5 1.5 0 0 1 6 12.5v-1zm6 0a1.5 1.5 0 0 1 1.5-1.5h1a1.5 1.5 0 0 1 1.5 1.5v1a1.5 1.5 0 0 1-1.5 1.5h-1a1.5 1.5 0 0 1-1.5-1.5v-1z\"}}]})(props);\n};\nexport function BsDiagram3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 3.5A1.5 1.5 0 0 1 7.5 2h1A1.5 1.5 0 0 1 10 3.5v1A1.5 1.5 0 0 1 8.5 6v1H14a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-1 0V8h-5v.5a.5.5 0 0 1-1 0V8h-5v.5a.5.5 0 0 1-1 0v-1A.5.5 0 0 1 2 7h5.5V6A1.5 1.5 0 0 1 6 4.5v-1zM8.5 5a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1zM0 11.5A1.5 1.5 0 0 1 1.5 10h1A1.5 1.5 0 0 1 4 11.5v1A1.5 1.5 0 0 1 2.5 14h-1A1.5 1.5 0 0 1 0 12.5v-1zm1.5-.5a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zm4.5.5A1.5 1.5 0 0 1 7.5 10h1a1.5 1.5 0 0 1 1.5 1.5v1A1.5 1.5 0 0 1 8.5 14h-1A1.5 1.5 0 0 1 6 12.5v-1zm1.5-.5a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zm4.5.5a1.5 1.5 0 0 1 1.5-1.5h1a1.5 1.5 0 0 1 1.5 1.5v1a1.5 1.5 0 0 1-1.5 1.5h-1a1.5 1.5 0 0 1-1.5-1.5v-1zm1.5-.5a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1z\"}}]})(props);\n};\nexport function BsDiamondFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6.95.435c.58-.58 1.52-.58 2.1 0l6.515 6.516c.58.58.58 1.519 0 2.098L9.05 15.565c-.58.58-1.519.58-2.098 0L.435 9.05a1.482 1.482 0 0 1 0-2.098L6.95.435z\"}}]})(props);\n};\nexport function BsDiamondHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.05.435c-.58-.58-1.52-.58-2.1 0L.436 6.95c-.58.58-.58 1.519 0 2.098l6.516 6.516c.58.58 1.519.58 2.098 0l6.516-6.516c.58-.58.58-1.519 0-2.098L9.05.435zM8 .989c.127 0 .253.049.35.145l6.516 6.516a.495.495 0 0 1 0 .7L8.35 14.866a.493.493 0 0 1-.35.145V.989z\"}}]})(props);\n};\nexport function BsDiamond (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.95.435c.58-.58 1.52-.58 2.1 0l6.515 6.516c.58.58.58 1.519 0 2.098L9.05 15.565c-.58.58-1.519.58-2.098 0L.435 9.05a1.482 1.482 0 0 1 0-2.098L6.95.435zm1.4.7a.495.495 0 0 0-.7 0L1.134 7.65a.495.495 0 0 0 0 .7l6.516 6.516a.495.495 0 0 0 .7 0l6.516-6.516a.495.495 0 0 0 0-.7L8.35 1.134z\"}}]})(props);\n};\nexport function BsDice1Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V3a3 3 0 0 0-3-3H3zm5 9.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsDice1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"circle\",\"attr\":{\"cx\":\"8\",\"cy\":\"8\",\"r\":\"1.5\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 1a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h10zM3 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V3a3 3 0 0 0-3-3H3z\"}}]})(props);\n};\nexport function BsDice2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 3a3 3 0 0 1 3-3h10a3 3 0 0 1 3 3v10a3 3 0 0 1-3 3H3a3 3 0 0 1-3-3V3zm5.5 1a1.5 1.5 0 1 0-3 0 1.5 1.5 0 0 0 3 0zm6.5 9.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3z\"}}]})(props);\n};\nexport function BsDice2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13 1a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h10zM3 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V3a3 3 0 0 0-3-3H3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 4a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm8 8a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0z\"}}]})(props);\n};\nexport function BsDice3Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V3a3 3 0 0 0-3-3H3zm2.5 4a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm8 8a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zM8 9.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsDice3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13 1a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h10zM3 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V3a3 3 0 0 0-3-3H3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 4a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm8 8a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm-4-4a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0z\"}}]})(props);\n};\nexport function BsDice4Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V3a3 3 0 0 0-3-3H3zm1 5.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm8 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm1.5 6.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zM4 13.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsDice4 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13 1a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h10zM3 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V3a3 3 0 0 0-3-3H3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 4a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm8 0a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm0 8a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm-8 0a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0z\"}}]})(props);\n};\nexport function BsDice5Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V3a3 3 0 0 0-3-3H3zm2.5 4a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm8 0a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zM12 13.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zM5.5 12a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zM8 9.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsDice5 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13 1a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h10zM3 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V3a3 3 0 0 0-3-3H3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 4a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm8 0a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm0 8a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm-8 0a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm4-4a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0z\"}}]})(props);\n};\nexport function BsDice6Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V3a3 3 0 0 0-3-3H3zm1 5.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm8 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm1.5 6.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zM12 9.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zM5.5 12a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zM4 9.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsDice6 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13 1a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h10zM3 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V3a3 3 0 0 0-3-3H3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 4a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm8 0a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm0 8a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm0-4a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm-8 4a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm0-4a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0z\"}}]})(props);\n};\nexport function BsDiscFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-6 0a2 2 0 1 0-4 0 2 2 0 0 0 4 0zM4 8a4 4 0 0 1 4-4 .5.5 0 0 0 0-1 5 5 0 0 0-5 5 .5.5 0 0 0 1 0zm9 0a.5.5 0 1 0-1 0 4 4 0 0 1-4 4 .5.5 0 0 0 0 1 5 5 0 0 0 5-5z\"}}]})(props);\n};\nexport function BsDisc (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 8a2 2 0 1 1-4 0 2 2 0 0 1 4 0zM8 4a4 4 0 0 0-4 4 .5.5 0 0 1-1 0 5 5 0 0 1 5-5 .5.5 0 0 1 0 1zm4.5 3.5a.5.5 0 0 1 .5.5 5 5 0 0 1-5 5 .5.5 0 0 1 0-1 4 4 0 0 0 4-4 .5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsDiscord (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.552 6.712c-.456 0-.816.4-.816.888s.368.888.816.888c.456 0 .816-.4.816-.888.008-.488-.36-.888-.816-.888zm2.92 0c-.456 0-.816.4-.816.888s.368.888.816.888c.456 0 .816-.4.816-.888s-.36-.888-.816-.888z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.36 0H2.64C1.736 0 1 .736 1 1.648v10.816c0 .912.736 1.648 1.64 1.648h9.072l-.424-1.48 1.024.952.968.896L15 16V1.648C15 .736 14.264 0 13.36 0zm-3.088 10.448s-.288-.344-.528-.648c1.048-.296 1.448-.952 1.448-.952-.328.216-.64.368-.92.472-.4.168-.784.28-1.16.344a5.604 5.604 0 0 1-2.072-.008 6.716 6.716 0 0 1-1.176-.344 4.688 4.688 0 0 1-.584-.272c-.024-.016-.048-.024-.072-.04-.016-.008-.024-.016-.032-.024-.144-.08-.224-.136-.224-.136s.384.64 1.4.944c-.24.304-.536.664-.536.664-1.768-.056-2.44-1.216-2.44-1.216 0-2.576 1.152-4.664 1.152-4.664 1.152-.864 2.248-.84 2.248-.84l.08.096c-1.44.416-2.104 1.048-2.104 1.048s.176-.096.472-.232c.856-.376 1.536-.48 1.816-.504.048-.008.088-.016.136-.016a6.521 6.521 0 0 1 4.024.752s-.632-.6-1.992-1.016l.112-.128s1.096-.024 2.248.84c0 0 1.152 2.088 1.152 4.664 0 0-.68 1.16-2.448 1.216z\"}}]})(props);\n};\nexport function BsDisplayFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12c0 .667-.083 1.167-.25 1.5H5a.5.5 0 0 0 0 1h6a.5.5 0 0 0 0-1h-.75c-.167-.333-.25-.833-.25-1.5h4c2 0 2-2 2-2V4c0-2-2-2-2-2H2C0 2 0 4 0 4v6c0 2 2 2 2 2h4z\"}}]})(props);\n};\nexport function BsDisplay (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4s0-2 2-2h12s2 0 2 2v6s0 2-2 2h-4c0 .667.083 1.167.25 1.5H11a.5.5 0 0 1 0 1H5a.5.5 0 0 1 0-1h.75c.167-.333.25-.833.25-1.5H2s-2 0-2-2V4zm1.398-.855a.758.758 0 0 0-.254.302A1.46 1.46 0 0 0 1 4.01V10c0 .325.078.502.145.602.07.105.17.188.302.254a1.464 1.464 0 0 0 .538.143L2.01 11H14c.325 0 .502-.078.602-.145a.758.758 0 0 0 .254-.302 1.464 1.464 0 0 0 .143-.538L15 9.99V4c0-.325-.078-.502-.145-.602a.757.757 0 0 0-.302-.254A1.46 1.46 0 0 0 13.99 3H2c-.325 0-.502.078-.602.145z\"}}]})(props);\n};\nexport function BsDistributeHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M14.5 1a.5.5 0 0 0-.5.5v13a.5.5 0 0 0 1 0v-13a.5.5 0 0 0-.5-.5zm-13 0a.5.5 0 0 0-.5.5v13a.5.5 0 0 0 1 0v-13a.5.5 0 0 0-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 13a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H7a1 1 0 0 0-1 1v10z\"}}]})(props);\n};\nexport function BsDistributeVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 1.5a.5.5 0 0 0 .5.5h13a.5.5 0 0 0 0-1h-13a.5.5 0 0 0-.5.5zm0 13a.5.5 0 0 0 .5.5h13a.5.5 0 0 0 0-1h-13a.5.5 0 0 0-.5.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 7a1 1 0 0 1 1-1h10a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V7z\"}}]})(props);\n};\nexport function BsDoorClosedFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 1a1 1 0 0 1 1 1v13h1.5a.5.5 0 0 1 0 1h-13a.5.5 0 0 1 0-1H3V2a1 1 0 0 1 1-1h8zm-2 9a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsDoorClosed (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 2a1 1 0 0 1 1-1h8a1 1 0 0 1 1 1v13h1.5a.5.5 0 0 1 0 1h-13a.5.5 0 0 1 0-1H3V2zm1 13h8V2H4v13z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 9a1 1 0 1 0 2 0 1 1 0 0 0-2 0z\"}}]})(props);\n};\nexport function BsDoorOpenFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 15a.5.5 0 0 0 0 1h13a.5.5 0 0 0 0-1H13V2.5A1.5 1.5 0 0 0 11.5 1H11V.5a.5.5 0 0 0-.57-.495l-7 1A.5.5 0 0 0 3 1.5V15H1.5zM11 2h.5a.5.5 0 0 1 .5.5V15h-1V2zm-2.5 8c-.276 0-.5-.448-.5-1s.224-1 .5-1 .5.448.5 1-.224 1-.5 1z\"}}]})(props);\n};\nexport function BsDoorOpen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 10c-.276 0-.5-.448-.5-1s.224-1 .5-1 .5.448.5 1-.224 1-.5 1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.828.122A.5.5 0 0 1 11 .5V1h.5A1.5 1.5 0 0 1 13 2.5V15h1.5a.5.5 0 0 1 0 1h-13a.5.5 0 0 1 0-1H3V1.5a.5.5 0 0 1 .43-.495l7-1a.5.5 0 0 1 .398.117zM11.5 2H11v13h1V2.5a.5.5 0 0 0-.5-.5zM4 1.934V15h6V1.077l-6 .857z\"}}]})(props);\n};\nexport function BsDot (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 9.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3z\"}}]})(props);\n};\nexport function BsDownload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 9.9a.5.5 0 0 1 .5.5v2.5a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2.5a.5.5 0 0 1 1 0v2.5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2v-2.5a.5.5 0 0 1 .5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.646 11.854a.5.5 0 0 0 .708 0l3-3a.5.5 0 0 0-.708-.708L8.5 10.293V1.5a.5.5 0 0 0-1 0v8.793L5.354 8.146a.5.5 0 1 0-.708.708l3 3z\"}}]})(props);\n};\nexport function BsDribbble (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 0C3.584 0 0 3.584 0 8s3.584 8 8 8c4.408 0 8-3.584 8-8s-3.592-8-8-8zm5.284 3.688a6.802 6.802 0 0 1 1.545 4.251c-.226-.043-2.482-.503-4.755-.217-.052-.112-.096-.234-.148-.355-.139-.33-.295-.668-.451-.99 2.516-1.023 3.662-2.498 3.81-2.69zM8 1.18c1.735 0 3.323.65 4.53 1.718-.122.174-1.155 1.553-3.584 2.464-1.12-2.056-2.36-3.74-2.551-4A6.95 6.95 0 0 1 8 1.18zm-2.907.642A43.123 43.123 0 0 1 7.627 5.77c-3.193.85-6.013.833-6.317.833a6.865 6.865 0 0 1 3.783-4.78zM1.163 8.01V7.8c.295.01 3.61.053 7.02-.971.199.381.381.772.555 1.162l-.27.078c-3.522 1.137-5.396 4.243-5.553 4.504a6.817 6.817 0 0 1-1.752-4.564zM8 14.837a6.785 6.785 0 0 1-4.19-1.44c.12-.252 1.509-2.924 5.361-4.269.018-.009.026-.009.044-.017a28.246 28.246 0 0 1 1.457 5.18A6.722 6.722 0 0 1 8 14.837zm3.81-1.171c-.07-.417-.435-2.412-1.328-4.868 2.143-.338 4.017.217 4.251.295a6.774 6.774 0 0 1-2.924 4.573z\"}}]})(props);\n};\nexport function BsDropletFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 16a6 6 0 0 0 6-6c0-1.655-1.122-2.904-2.432-4.362C10.254 4.176 8.75 2.503 8 0c0 0-6 5.686-6 10a6 6 0 0 0 6 6zM6.646 4.646c-.376.377-1.272 1.489-2.093 3.13l.894.448c.78-1.559 1.616-2.58 1.907-2.87l-.708-.708z\"}}]})(props);\n};\nexport function BsDropletHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.21.8C7.69.295 8 0 8 0c.109.363.234.708.371 1.038.812 1.946 2.073 3.35 3.197 4.6C12.878 7.096 14 8.345 14 10a6 6 0 0 1-12 0C2 6.668 5.58 2.517 7.21.8zm.413 1.021A31.25 31.25 0 0 0 5.794 3.99c-.726.95-1.436 2.008-1.96 3.07C3.304 8.133 3 9.138 3 10c0 0 2.5 1.5 5 .5s5-.5 5-.5c0-1.201-.796-2.157-2.181-3.7l-.03-.032C9.75 5.11 8.5 3.72 7.623 1.82z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4.553 7.776c.82-1.641 1.717-2.753 2.093-3.13l.708.708c-.29.29-1.128 1.311-1.907 2.87l-.894-.448z\"}}]})(props);\n};\nexport function BsDroplet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.21.8C7.69.295 8 0 8 0c.109.363.234.708.371 1.038.812 1.946 2.073 3.35 3.197 4.6C12.878 7.096 14 8.345 14 10a6 6 0 0 1-12 0C2 6.668 5.58 2.517 7.21.8zm.413 1.021A31.25 31.25 0 0 0 5.794 3.99c-.726.95-1.436 2.008-1.96 3.07C3.304 8.133 3 9.138 3 10a5 5 0 0 0 10 0c0-1.201-.796-2.157-2.181-3.7l-.03-.032C9.75 5.11 8.5 3.72 7.623 1.82z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4.553 7.776c.82-1.641 1.717-2.753 2.093-3.13l.708.708c-.29.29-1.128 1.311-1.907 2.87l-.894-.448z\"}}]})(props);\n};\nexport function BsEarbuds (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6.825 4.138c.596 2.141-.36 3.593-2.389 4.117a4.432 4.432 0 0 1-2.018.054c-.048-.01.9 2.778 1.522 4.61l.41 1.205a.52.52 0 0 1-.346.659l-.593.19a.548.548 0 0 1-.69-.34L.184 6.99c-.696-2.137.662-4.309 2.564-4.8 2.029-.523 3.402 0 4.076 1.948zm-.868 2.221c.43-.112.561-.993.292-1.969-.269-.975-.836-1.675-1.266-1.563-.43.112-.561.994-.292 1.969.269.975.836 1.675 1.266 1.563zm3.218-2.221c-.596 2.141.36 3.593 2.389 4.117a4.434 4.434 0 0 0 2.018.054c.048-.01-.9 2.778-1.522 4.61l-.41 1.205a.52.52 0 0 0 .346.659l.593.19c.289.092.6-.06.69-.34l2.536-7.643c.696-2.137-.662-4.309-2.564-4.8-2.029-.523-3.402 0-4.076 1.948zm.868 2.221c-.43-.112-.561-.993-.292-1.969.269-.975.836-1.675 1.266-1.563.43.112.561.994.292 1.969-.269.975-.836 1.675-1.266 1.563z\"}}]})(props);\n};\nexport function BsEaselFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.473.337a.5.5 0 0 0-.946 0L6.954 2H2a1 1 0 0 0-1 1v7a1 1 0 0 0 1 1h1.85l-1.323 3.837a.5.5 0 1 0 .946.326L4.908 11H7.5v2.5a.5.5 0 0 0 1 0V11h2.592l1.435 4.163a.5.5 0 0 0 .946-.326L12.15 11H14a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H9.046L8.473.337z\"}}]})(props);\n};\nexport function BsEasel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a.5.5 0 0 1 .473.337L9.046 2H14a1 1 0 0 1 1 1v7a1 1 0 0 1-1 1h-1.85l1.323 3.837a.5.5 0 1 1-.946.326L11.092 11H8.5v3a.5.5 0 0 1-1 0v-3H4.908l-1.435 4.163a.5.5 0 1 1-.946-.326L3.85 11H2a1 1 0 0 1-1-1V3a1 1 0 0 1 1-1h4.954L7.527.337A.5.5 0 0 1 8 0zM2 3v7h12V3H2z\"}}]})(props);\n};\nexport function BsEggFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10a6 6 0 0 1-12 0C2 5.686 5 0 8 0s6 5.686 6 10z\"}}]})(props);\n};\nexport function BsEggFried (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.997 5.17a5 5 0 0 0-8.101-4.09A5 5 0 0 0 1.28 9.342a5 5 0 0 0 8.336 5.109 3.5 3.5 0 0 0 5.201-4.065 3.001 3.001 0 0 0-.822-5.216zm-1-.034a1 1 0 0 0 .668.977 2.001 2.001 0 0 1 .547 3.478 1 1 0 0 0-.341 1.113 2.5 2.5 0 0 1-3.715 2.905 1 1 0 0 0-1.262.152 4 4 0 0 1-6.67-4.087 1 1 0 0 0-.2-1 4 4 0 0 1 3.693-6.61 1 1 0 0 0 .8-.2 4 4 0 0 1 6.48 3.273z\"}}]})(props);\n};\nexport function BsEgg (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15a5 5 0 0 1-5-5c0-1.956.69-4.286 1.742-6.12.524-.913 1.112-1.658 1.704-2.164C7.044 1.206 7.572 1 8 1c.428 0 .956.206 1.554.716.592.506 1.18 1.251 1.704 2.164C12.31 5.714 13 8.044 13 10a5 5 0 0 1-5 5zm0 1a6 6 0 0 0 6-6c0-4.314-3-10-6-10S2 5.686 2 10a6 6 0 0 0 6 6z\"}}]})(props);\n};\nexport function BsEjectFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.27 1.047a1 1 0 0 1 1.46 0l6.345 6.77c.6.638.146 1.683-.73 1.683H1.656C.78 9.5.326 8.455.926 7.816L7.27 1.047zM.5 11.5a1 1 0 0 1 1-1h13a1 1 0 0 1 1 1v1a1 1 0 0 1-1 1h-13a1 1 0 0 1-1-1v-1z\"}}]})(props);\n};\nexport function BsEject (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.27 1.047a1 1 0 0 1 1.46 0l6.345 6.77c.6.638.146 1.683-.73 1.683H1.656C.78 9.5.326 8.455.926 7.816L7.27 1.047zM14.346 8.5 8 1.731 1.654 8.5h12.692zM.5 11.5a1 1 0 0 1 1-1h13a1 1 0 0 1 1 1v1a1 1 0 0 1-1 1h-13a1 1 0 0 1-1-1v-1zm14 0h-13v1h13v-1z\"}}]})(props);\n};\nexport function BsEmojiAngryFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM4.053 4.276a.5.5 0 0 1 .67-.223l2 1a.5.5 0 0 1 .166.76c.071.206.111.44.111.687C7 7.328 6.552 8 6 8s-1-.672-1-1.5c0-.408.109-.778.285-1.049l-1.009-.504a.5.5 0 0 1-.223-.67zm.232 8.157a.5.5 0 0 1-.183-.683A4.498 4.498 0 0 1 8 9.5a4.5 4.5 0 0 1 3.898 2.25.5.5 0 1 1-.866.5A3.498 3.498 0 0 0 8 10.5a3.498 3.498 0 0 0-3.032 1.75.5.5 0 0 1-.683.183zM10 8c-.552 0-1-.672-1-1.5 0-.247.04-.48.11-.686a.502.502 0 0 1 .166-.761l2-1a.5.5 0 1 1 .448.894l-1.009.504c.176.27.285.64.285 1.049 0 .828-.448 1.5-1 1.5z\"}}]})(props);\n};\nexport function BsEmojiAngry (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.285 12.433a.5.5 0 0 0 .683-.183A3.498 3.498 0 0 1 8 10.5c1.295 0 2.426.703 3.032 1.75a.5.5 0 0 0 .866-.5A4.498 4.498 0 0 0 8 9.5a4.5 4.5 0 0 0-3.898 2.25.5.5 0 0 0 .183.683zm6.991-8.38a.5.5 0 1 1 .448.894l-1.009.504c.176.27.285.64.285 1.049 0 .828-.448 1.5-1 1.5s-1-.672-1-1.5c0-.247.04-.48.11-.686a.502.502 0 0 1 .166-.761l2-1zm-6.552 0a.5.5 0 0 0-.448.894l1.009.504A1.94 1.94 0 0 0 5 6.5C5 7.328 5.448 8 6 8s1-.672 1-1.5c0-.247-.04-.48-.11-.686a.502.502 0 0 0-.166-.761l-2-1z\"}}]})(props);\n};\nexport function BsEmojiDizzyFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM4.146 5.146a.5.5 0 0 1 .708 0l.646.647.646-.647a.5.5 0 1 1 .708.708l-.647.646.647.646a.5.5 0 1 1-.708.708L5.5 7.207l-.646.647a.5.5 0 1 1-.708-.708l.647-.646-.647-.646a.5.5 0 0 1 0-.708zm5 0a.5.5 0 0 1 .708 0l.646.647.646-.647a.5.5 0 0 1 .708.708l-.647.646.647.646a.5.5 0 0 1-.708.708l-.646-.647-.646.647a.5.5 0 1 1-.708-.708l.647-.646-.647-.646a.5.5 0 0 1 0-.708zM8 13a2 2 0 1 1 0-4 2 2 0 0 1 0 4z\"}}]})(props);\n};\nexport function BsEmojiDizzy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.146 5.146a.5.5 0 0 1 .708 0l.646.647.646-.647a.5.5 0 0 1 .708.708l-.647.646.647.646a.5.5 0 0 1-.708.708l-.646-.647-.646.647a.5.5 0 1 1-.708-.708l.647-.646-.647-.646a.5.5 0 0 1 0-.708zm-5 0a.5.5 0 0 1 .708 0l.646.647.646-.647a.5.5 0 1 1 .708.708l-.647.646.647.646a.5.5 0 1 1-.708.708L5.5 7.207l-.646.647a.5.5 0 1 1-.708-.708l.647-.646-.647-.646a.5.5 0 0 1 0-.708zM10 11a2 2 0 1 1-4 0 2 2 0 0 1 4 0z\"}}]})(props);\n};\nexport function BsEmojiExpressionlessFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM4.5 6h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1zm5 0h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1zm-5 4h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsEmojiExpressionless (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 10.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm0-4a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5zm5 0a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsEmojiFrownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM7 6.5C7 7.328 6.552 8 6 8s-1-.672-1-1.5S5.448 5 6 5s1 .672 1 1.5zm-2.715 5.933a.5.5 0 0 1-.183-.683A4.498 4.498 0 0 1 8 9.5a4.5 4.5 0 0 1 3.898 2.25.5.5 0 0 1-.866.5A3.498 3.498 0 0 0 8 10.5a3.498 3.498 0 0 0-3.032 1.75.5.5 0 0 1-.683.183zM10 8c-.552 0-1-.672-1-1.5S9.448 5 10 5s1 .672 1 1.5S10.552 8 10 8z\"}}]})(props);\n};\nexport function BsEmojiFrown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.285 12.433a.5.5 0 0 0 .683-.183A3.498 3.498 0 0 1 8 10.5c1.295 0 2.426.703 3.032 1.75a.5.5 0 0 0 .866-.5A4.498 4.498 0 0 0 8 9.5a4.5 4.5 0 0 0-3.898 2.25.5.5 0 0 0 .183.683zM7 6.5C7 7.328 6.552 8 6 8s-1-.672-1-1.5S5.448 5 6 5s1 .672 1 1.5zm4 0c0 .828-.448 1.5-1 1.5s-1-.672-1-1.5S9.448 5 10 5s1 .672 1 1.5z\"}}]})(props);\n};\nexport function BsEmojiHeartEyesFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a8 8 0 1 0 0 16A8 8 0 0 0 8 0zM4.756 4.566c.763-1.424 4.02-.12.952 3.434-4.496-1.596-2.35-4.298-.952-3.434zm6.559 5.448a.5.5 0 0 1 .548.736A4.498 4.498 0 0 1 7.965 13a4.498 4.498 0 0 1-3.898-2.25.5.5 0 0 1 .548-.736h.005l.017.005.067.015.252.055c.215.046.515.108.857.169.693.124 1.522.242 2.152.242.63 0 1.46-.118 2.152-.242a26.58 26.58 0 0 0 1.109-.224l.067-.015.017-.004.005-.002zm-.07-5.448c1.397-.864 3.543 1.838-.953 3.434-3.067-3.554.19-4.858.952-3.434z\"}}]})(props);\n};\nexport function BsEmojiHeartEyes (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.315 10.014a.5.5 0 0 1 .548.736A4.498 4.498 0 0 1 7.965 13a4.498 4.498 0 0 1-3.898-2.25.5.5 0 0 1 .548-.736h.005l.017.005.067.015.252.055c.215.046.515.108.857.169.693.124 1.522.242 2.152.242.63 0 1.46-.118 2.152-.242a26.58 26.58 0 0 0 1.109-.224l.067-.015.017-.004.005-.002zM4.756 4.566c.763-1.424 4.02-.12.952 3.434-4.496-1.596-2.35-4.298-.952-3.434zm6.488 0c1.398-.864 3.544 1.838-.952 3.434-3.067-3.554.19-4.858.952-3.434z\"}}]})(props);\n};\nexport function BsEmojiLaughingFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM7 6.5c0 .501-.164.396-.415.235C6.42 6.629 6.218 6.5 6 6.5c-.218 0-.42.13-.585.235C5.164 6.896 5 7 5 6.5 5 5.672 5.448 5 6 5s1 .672 1 1.5zm5.331 3a1 1 0 0 1 0 1A4.998 4.998 0 0 1 8 13a4.998 4.998 0 0 1-4.33-2.5A1 1 0 0 1 4.535 9h6.93a1 1 0 0 1 .866.5zm-1.746-2.765C10.42 6.629 10.218 6.5 10 6.5c-.218 0-.42.13-.585.235C9.164 6.896 9 7 9 6.5c0-.828.448-1.5 1-1.5s1 .672 1 1.5c0 .501-.164.396-.415.235z\"}}]})(props);\n};\nexport function BsEmojiLaughing (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.331 9.5a1 1 0 0 1 0 1A4.998 4.998 0 0 1 8 13a4.998 4.998 0 0 1-4.33-2.5A1 1 0 0 1 4.535 9h6.93a1 1 0 0 1 .866.5zM7 6.5c0 .828-.448 0-1 0s-1 .828-1 0S5.448 5 6 5s1 .672 1 1.5zm4 0c0 .828-.448 0-1 0s-1 .828-1 0S9.448 5 10 5s1 .672 1 1.5z\"}}]})(props);\n};\nexport function BsEmojiNeutralFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM7 6.5C7 7.328 6.552 8 6 8s-1-.672-1-1.5S5.448 5 6 5s1 .672 1 1.5zm-3 4a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zM10 8c-.552 0-1-.672-1-1.5S9.448 5 10 5s1 .672 1 1.5S10.552 8 10 8z\"}}]})(props);\n};\nexport function BsEmojiNeutral (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 10.5a.5.5 0 0 0 .5.5h7a.5.5 0 0 0 0-1h-7a.5.5 0 0 0-.5.5zm3-4C7 5.672 6.552 5 6 5s-1 .672-1 1.5S5.448 8 6 8s1-.672 1-1.5zm4 0c0-.828-.448-1.5-1-1.5s-1 .672-1 1.5S9.448 8 10 8s1-.672 1-1.5z\"}}]})(props);\n};\nexport function BsEmojiSmileFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM7 6.5C7 7.328 6.552 8 6 8s-1-.672-1-1.5S5.448 5 6 5s1 .672 1 1.5zM4.285 9.567a.5.5 0 0 1 .683.183A3.498 3.498 0 0 0 8 11.5a3.498 3.498 0 0 0 3.032-1.75.5.5 0 1 1 .866.5A4.498 4.498 0 0 1 8 12.5a4.498 4.498 0 0 1-3.898-2.25.5.5 0 0 1 .183-.683zM10 8c-.552 0-1-.672-1-1.5S9.448 5 10 5s1 .672 1 1.5S10.552 8 10 8z\"}}]})(props);\n};\nexport function BsEmojiSmileUpsideDownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0zM7 9.5C7 8.672 6.552 8 6 8s-1 .672-1 1.5.448 1.5 1 1.5 1-.672 1-1.5zM4.285 6.433a.5.5 0 0 0 .683-.183A3.498 3.498 0 0 1 8 4.5c1.295 0 2.426.703 3.032 1.75a.5.5 0 0 0 .866-.5A4.498 4.498 0 0 0 8 3.5a4.5 4.5 0 0 0-3.898 2.25.5.5 0 0 0 .183.683zM10 8c-.552 0-1 .672-1 1.5s.448 1.5 1 1.5 1-.672 1-1.5S10.552 8 10 8z\"}}]})(props);\n};\nexport function BsEmojiSmileUpsideDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a7 7 0 1 0 0 14A7 7 0 0 0 8 1zm0-1a8 8 0 1 1 0 16A8 8 0 0 1 8 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.285 6.433a.5.5 0 0 0 .683-.183A3.498 3.498 0 0 1 8 4.5c1.295 0 2.426.703 3.032 1.75a.5.5 0 0 0 .866-.5A4.498 4.498 0 0 0 8 3.5a4.5 4.5 0 0 0-3.898 2.25.5.5 0 0 0 .183.683zM7 9.5C7 8.672 6.552 8 6 8s-1 .672-1 1.5.448 1.5 1 1.5 1-.672 1-1.5zm4 0c0-.828-.448-1.5-1-1.5s-1 .672-1 1.5.448 1.5 1 1.5 1-.672 1-1.5z\"}}]})(props);\n};\nexport function BsEmojiSmile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.285 9.567a.5.5 0 0 1 .683.183A3.498 3.498 0 0 0 8 11.5a3.498 3.498 0 0 0 3.032-1.75.5.5 0 1 1 .866.5A4.498 4.498 0 0 1 8 12.5a4.498 4.498 0 0 1-3.898-2.25.5.5 0 0 1 .183-.683zM7 6.5C7 7.328 6.552 8 6 8s-1-.672-1-1.5S5.448 5 6 5s1 .672 1 1.5zm4 0c0 .828-.448 1.5-1 1.5s-1-.672-1-1.5S9.448 5 10 5s1 .672 1 1.5z\"}}]})(props);\n};\nexport function BsEmojiSunglassesFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM2.31 5.243A1 1 0 0 1 3.28 4H6a1 1 0 0 1 1 1v.116A4.22 4.22 0 0 1 8 5c.35 0 .69.04 1 .116V5a1 1 0 0 1 1-1h2.72a1 1 0 0 1 .97 1.243l-.311 1.242A2 2 0 0 1 11.439 8H11a2 2 0 0 1-1.994-1.839A2.99 2.99 0 0 0 8 6c-.393 0-.74.064-1.006.161A2 2 0 0 1 5 8h-.438a2 2 0 0 1-1.94-1.515L2.31 5.243zM4.969 9.75A3.498 3.498 0 0 0 8 11.5a3.498 3.498 0 0 0 3.032-1.75.5.5 0 1 1 .866.5A4.498 4.498 0 0 1 8 12.5a4.498 4.498 0 0 1-3.898-2.25.5.5 0 0 1 .866-.5z\"}}]})(props);\n};\nexport function BsEmojiSunglasses (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.968 9.75a.5.5 0 1 0-.866.5A4.498 4.498 0 0 0 8 12.5a4.5 4.5 0 0 0 3.898-2.25.5.5 0 1 0-.866-.5A3.498 3.498 0 0 1 8 11.5a3.498 3.498 0 0 1-3.032-1.75zM7 5.116V5a1 1 0 0 0-1-1H3.28a1 1 0 0 0-.97 1.243l.311 1.242A2 2 0 0 0 4.561 8H5a2 2 0 0 0 1.994-1.839A2.99 2.99 0 0 1 8 6c.393 0 .74.064 1.006.161A2 2 0 0 0 11 8h.438a2 2 0 0 0 1.94-1.515l.311-1.242A1 1 0 0 0 12.72 4H10a1 1 0 0 0-1 1v.116A4.22 4.22 0 0 0 8 5c-.35 0-.69.04-1 .116z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-1 0A7 7 0 1 0 1 8a7 7 0 0 0 14 0z\"}}]})(props);\n};\nexport function BsEmojiWinkFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0zM7 6.5C7 5.672 6.552 5 6 5s-1 .672-1 1.5S5.448 8 6 8s1-.672 1-1.5zM4.285 9.567a.5.5 0 0 0-.183.683A4.498 4.498 0 0 0 8 12.5a4.5 4.5 0 0 0 3.898-2.25.5.5 0 1 0-.866-.5A3.498 3.498 0 0 1 8 11.5a3.498 3.498 0 0 1-3.032-1.75.5.5 0 0 0-.683-.183zm5.152-3.31a.5.5 0 0 0-.874.486c.33.595.958 1.007 1.687 1.007.73 0 1.356-.412 1.687-1.007a.5.5 0 0 0-.874-.486.934.934 0 0 1-.813.493.934.934 0 0 1-.813-.493z\"}}]})(props);\n};\nexport function BsEmojiWink (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.285 9.567a.5.5 0 0 1 .683.183A3.498 3.498 0 0 0 8 11.5a3.498 3.498 0 0 0 3.032-1.75.5.5 0 1 1 .866.5A4.498 4.498 0 0 1 8 12.5a4.498 4.498 0 0 1-3.898-2.25.5.5 0 0 1 .183-.683zM7 6.5C7 7.328 6.552 8 6 8s-1-.672-1-1.5S5.448 5 6 5s1 .672 1 1.5zm1.757-.437a.5.5 0 0 1 .68.194.934.934 0 0 0 .813.493c.339 0 .645-.19.813-.493a.5.5 0 1 1 .874.486A1.934 1.934 0 0 1 10.25 7.75c-.73 0-1.356-.412-1.687-1.007a.5.5 0 0 1 .194-.68z\"}}]})(props);\n};\nexport function BsEnvelopeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.05 3.555A2 2 0 0 1 2 2h12a2 2 0 0 1 1.95 1.555L8 8.414.05 3.555zM0 4.697v7.104l5.803-3.558L0 4.697zM6.761 8.83l-6.57 4.027A2 2 0 0 0 2 14h12a2 2 0 0 0 1.808-1.144l-6.57-4.027L8 9.586l-1.239-.757zm3.436-.586L16 11.801V4.697l-5.803 3.546z\"}}]})(props);\n};\nexport function BsEnvelopeOpenFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.941.435a2 2 0 0 0-1.882 0l-6 3.2A2 2 0 0 0 0 5.4v.313l6.709 3.933L8 8.928l1.291.717L16 5.715V5.4a2 2 0 0 0-1.059-1.765l-6-3.2zM16 6.873l-5.693 3.337L16 13.372v-6.5zm-.059 7.611L8 10.072.059 14.484A2 2 0 0 0 2 16h12a2 2 0 0 0 1.941-1.516zM0 13.373l5.693-3.163L0 6.873v6.5z\"}}]})(props);\n};\nexport function BsEnvelopeOpen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.47 1.318a1 1 0 0 0-.94 0l-6 3.2A1 1 0 0 0 1 5.4v.818l5.724 3.465L8 8.917l1.276.766L15 6.218V5.4a1 1 0 0 0-.53-.882l-6-3.2zM15 7.388l-4.754 2.877L15 13.117v-5.73zm-.035 6.874L8 10.083l-6.965 4.18A1 1 0 0 0 2 15h12a1 1 0 0 0 .965-.738zM1 13.117l4.754-2.852L1 7.387v5.73zM7.059.435a2 2 0 0 1 1.882 0l6 3.2A2 2 0 0 1 16 5.4V14a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V5.4a2 2 0 0 1 1.059-1.765l6-3.2z\"}}]})(props);\n};\nexport function BsEnvelope (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm2-1a1 1 0 0 0-1 1v.217l7 4.2 7-4.2V4a1 1 0 0 0-1-1H2zm13 2.383-4.758 2.855L15 11.114v-5.73zm-.034 6.878L9.271 8.82 8 9.583 6.728 8.82l-5.694 3.44A1 1 0 0 0 2 13h12a1 1 0 0 0 .966-.739zM1 11.114l4.758-2.876L1 5.383v5.73z\"}}]})(props);\n};\nexport function BsEraserFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.086 2.207a2 2 0 0 1 2.828 0l3.879 3.879a2 2 0 0 1 0 2.828l-5.5 5.5A2 2 0 0 1 7.879 15H5.12a2 2 0 0 1-1.414-.586l-2.5-2.5a2 2 0 0 1 0-2.828l6.879-6.879zm.66 11.34L3.453 8.254 1.914 9.793a1 1 0 0 0 0 1.414l2.5 2.5a1 1 0 0 0 .707.293H7.88a1 1 0 0 0 .707-.293l.16-.16z\"}}]})(props);\n};\nexport function BsEraser (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.086 2.207a2 2 0 0 1 2.828 0l3.879 3.879a2 2 0 0 1 0 2.828l-5.5 5.5A2 2 0 0 1 7.879 15H5.12a2 2 0 0 1-1.414-.586l-2.5-2.5a2 2 0 0 1 0-2.828l6.879-6.879zm2.121.707a1 1 0 0 0-1.414 0L4.16 7.547l5.293 5.293 4.633-4.633a1 1 0 0 0 0-1.414l-3.879-3.879zM8.746 13.547 3.453 8.254 1.914 9.793a1 1 0 0 0 0 1.414l2.5 2.5a1 1 0 0 0 .707.293H7.88a1 1 0 0 0 .707-.293l.16-.16z\"}}]})(props);\n};\nexport function BsExclamationCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM8 4a.905.905 0 0 0-.9.995l.35 3.507a.552.552 0 0 0 1.1 0l.35-3.507A.905.905 0 0 0 8 4zm.002 6a1 1 0 1 0 0 2 1 1 0 0 0 0-2z\"}}]})(props);\n};\nexport function BsExclamationCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.002 11a1 1 0 1 1 2 0 1 1 0 0 1-2 0zM7.1 4.995a.905.905 0 1 1 1.8 0l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 4.995z\"}}]})(props);\n};\nexport function BsExclamationDiamondFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.05.435c-.58-.58-1.52-.58-2.1 0L.436 6.95c-.58.58-.58 1.519 0 2.098l6.516 6.516c.58.58 1.519.58 2.098 0l6.516-6.516c.58-.58.58-1.519 0-2.098L9.05.435zM8 4c.535 0 .954.462.9.995l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 4.995A.905.905 0 0 1 8 4zm.002 6a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\"}}]})(props);\n};\nexport function BsExclamationDiamond (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.95.435c.58-.58 1.52-.58 2.1 0l6.515 6.516c.58.58.58 1.519 0 2.098L9.05 15.565c-.58.58-1.519.58-2.098 0L.435 9.05a1.482 1.482 0 0 1 0-2.098L6.95.435zm1.4.7a.495.495 0 0 0-.7 0L1.134 7.65a.495.495 0 0 0 0 .7l6.516 6.516a.495.495 0 0 0 .7 0l6.516-6.516a.495.495 0 0 0 0-.7L8.35 1.134z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.002 11a1 1 0 1 1 2 0 1 1 0 0 1-2 0zM7.1 4.995a.905.905 0 1 1 1.8 0l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 4.995z\"}}]})(props);\n};\nexport function BsExclamationLg (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.002 14a2 2 0 1 1 4 0 2 2 0 0 1-4 0zm.195-12.01a1.81 1.81 0 1 1 3.602 0l-.701 7.015a1.105 1.105 0 0 1-2.2 0l-.7-7.015z\"}}]})(props);\n};\nexport function BsExclamationOctagonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.46.146A.5.5 0 0 0 11.107 0H4.893a.5.5 0 0 0-.353.146L.146 4.54A.5.5 0 0 0 0 4.893v6.214a.5.5 0 0 0 .146.353l4.394 4.394a.5.5 0 0 0 .353.146h6.214a.5.5 0 0 0 .353-.146l4.394-4.394a.5.5 0 0 0 .146-.353V4.893a.5.5 0 0 0-.146-.353L11.46.146zM8 4c.535 0 .954.462.9.995l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 4.995A.905.905 0 0 1 8 4zm.002 6a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\"}}]})(props);\n};\nexport function BsExclamationOctagon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.54.146A.5.5 0 0 1 4.893 0h6.214a.5.5 0 0 1 .353.146l4.394 4.394a.5.5 0 0 1 .146.353v6.214a.5.5 0 0 1-.146.353l-4.394 4.394a.5.5 0 0 1-.353.146H4.893a.5.5 0 0 1-.353-.146L.146 11.46A.5.5 0 0 1 0 11.107V4.893a.5.5 0 0 1 .146-.353L4.54.146zM5.1 1 1 5.1v5.8L5.1 15h5.8l4.1-4.1V5.1L10.9 1H5.1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.002 11a1 1 0 1 1 2 0 1 1 0 0 1-2 0zM7.1 4.995a.905.905 0 1 1 1.8 0l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 4.995z\"}}]})(props);\n};\nexport function BsExclamationSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm6 4c.535 0 .954.462.9.995l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 4.995A.905.905 0 0 1 8 4zm.002 6a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\"}}]})(props);\n};\nexport function BsExclamationSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.002 11a1 1 0 1 1 2 0 1 1 0 0 1-2 0zM7.1 4.995a.905.905 0 1 1 1.8 0l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 4.995z\"}}]})(props);\n};\nexport function BsExclamationTriangleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.982 1.566a1.13 1.13 0 0 0-1.96 0L.165 13.233c-.457.778.091 1.767.98 1.767h13.713c.889 0 1.438-.99.98-1.767L8.982 1.566zM8 5c.535 0 .954.462.9.995l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 5.995A.905.905 0 0 1 8 5zm.002 6a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\"}}]})(props);\n};\nexport function BsExclamationTriangle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.938 2.016A.13.13 0 0 1 8.002 2a.13.13 0 0 1 .063.016.146.146 0 0 1 .054.057l6.857 11.667c.036.06.035.124.002.183a.163.163 0 0 1-.054.06.116.116 0 0 1-.066.017H1.146a.115.115 0 0 1-.066-.017.163.163 0 0 1-.054-.06.176.176 0 0 1 .002-.183L7.884 2.073a.147.147 0 0 1 .054-.057zm1.044-.45a1.13 1.13 0 0 0-1.96 0L.165 13.233c-.457.778.091 1.767.98 1.767h13.713c.889 0 1.438-.99.98-1.767L8.982 1.566z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.002 12a1 1 0 1 1 2 0 1 1 0 0 1-2 0zM7.1 5.995a.905.905 0 1 1 1.8 0l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 5.995z\"}}]})(props);\n};\nexport function BsExclamation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.002 11a1 1 0 1 1 2 0 1 1 0 0 1-2 0zM7.1 4.995a.905.905 0 1 1 1.8 0l-.35 3.507a.553.553 0 0 1-1.1 0L7.1 4.995z\"}}]})(props);\n};\nexport function BsExclude (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v2h2a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2v-2H2a2 2 0 0 1-2-2V2zm12 2H5a1 1 0 0 0-1 1v7h7a1 1 0 0 0 1-1V4z\"}}]})(props);\n};\nexport function BsEyeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 8a2.5 2.5 0 1 1-5 0 2.5 2.5 0 0 1 5 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 8s3-5.5 8-5.5S16 8 16 8s-3 5.5-8 5.5S0 8 0 8zm8 3.5a3.5 3.5 0 1 0 0-7 3.5 3.5 0 0 0 0 7z\"}}]})(props);\n};\nexport function BsEyeSlashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m10.79 12.912-1.614-1.615a3.5 3.5 0 0 1-4.474-4.474l-2.06-2.06C.938 6.278 0 8 0 8s3 5.5 8 5.5a7.029 7.029 0 0 0 2.79-.588zM5.21 3.088A7.028 7.028 0 0 1 8 2.5c5 0 8 5.5 8 5.5s-.939 1.721-2.641 3.238l-2.062-2.062a3.5 3.5 0 0 0-4.474-4.474L5.21 3.089z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.525 7.646a2.5 2.5 0 0 0 2.829 2.829l-2.83-2.829zm4.95.708-2.829-2.83a2.5 2.5 0 0 1 2.829 2.829zm3.171 6-12-12 .708-.708 12 12-.708.708z\"}}]})(props);\n};\nexport function BsEyeSlash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.359 11.238C15.06 9.72 16 8 16 8s-3-5.5-8-5.5a7.028 7.028 0 0 0-2.79.588l.77.771A5.944 5.944 0 0 1 8 3.5c2.12 0 3.879 1.168 5.168 2.457A13.134 13.134 0 0 1 14.828 8c-.058.087-.122.183-.195.288-.335.48-.83 1.12-1.465 1.755-.165.165-.337.328-.517.486l.708.709z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.297 9.176a3.5 3.5 0 0 0-4.474-4.474l.823.823a2.5 2.5 0 0 1 2.829 2.829l.822.822zm-2.943 1.299.822.822a3.5 3.5 0 0 1-4.474-4.474l.823.823a2.5 2.5 0 0 0 2.829 2.829z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.35 5.47c-.18.16-.353.322-.518.487A13.134 13.134 0 0 0 1.172 8l.195.288c.335.48.83 1.12 1.465 1.755C4.121 11.332 5.881 12.5 8 12.5c.716 0 1.39-.133 2.02-.36l.77.772A7.029 7.029 0 0 1 8 13.5C3 13.5 0 8 0 8s.939-1.721 2.641-3.238l.708.709zm10.296 8.884-12-12 .708-.708 12 12-.708.708z\"}}]})(props);\n};\nexport function BsEye (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8s-3-5.5-8-5.5S0 8 0 8s3 5.5 8 5.5S16 8 16 8zM1.173 8a13.133 13.133 0 0 1 1.66-2.043C4.12 4.668 5.88 3.5 8 3.5c2.12 0 3.879 1.168 5.168 2.457A13.133 13.133 0 0 1 14.828 8c-.058.087-.122.183-.195.288-.335.48-.83 1.12-1.465 1.755C11.879 11.332 10.119 12.5 8 12.5c-2.12 0-3.879-1.168-5.168-2.457A13.134 13.134 0 0 1 1.172 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 5.5a2.5 2.5 0 1 0 0 5 2.5 2.5 0 0 0 0-5zM4.5 8a3.5 3.5 0 1 1 7 0 3.5 3.5 0 0 1-7 0z\"}}]})(props);\n};\nexport function BsEyedropper (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.354.646a1.207 1.207 0 0 0-1.708 0L8.5 3.793l-.646-.647a.5.5 0 1 0-.708.708L8.293 5l-7.147 7.146A.5.5 0 0 0 1 12.5v1.793l-.854.853a.5.5 0 1 0 .708.707L1.707 15H3.5a.5.5 0 0 0 .354-.146L11 7.707l1.146 1.147a.5.5 0 0 0 .708-.708l-.647-.646 3.147-3.146a1.207 1.207 0 0 0 0-1.708l-2-2zM2 12.707l7-7L10.293 7l-7 7H2v-1.293z\"}}]})(props);\n};\nexport function BsEyeglasses (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6a2 2 0 1 1 0 4 2 2 0 0 1 0-4zm2.625.547a3 3 0 0 0-5.584.953H.5a.5.5 0 0 0 0 1h.541A3 3 0 0 0 7 8a1 1 0 0 1 2 0 3 3 0 0 0 5.959.5h.541a.5.5 0 0 0 0-1h-.541a3 3 0 0 0-5.584-.953A1.993 1.993 0 0 0 8 6c-.532 0-1.016.208-1.375.547zM14 8a2 2 0 1 1-4 0 2 2 0 0 1 4 0z\"}}]})(props);\n};\nexport function BsFacebook (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8.049c0-4.446-3.582-8.05-8-8.05C3.58 0-.002 3.603-.002 8.05c0 4.017 2.926 7.347 6.75 7.951v-5.625h-2.03V8.05H6.75V6.275c0-2.017 1.195-3.131 3.022-3.131.876 0 1.791.157 1.791.157v1.98h-1.009c-.993 0-1.303.621-1.303 1.258v1.51h2.218l-.354 2.326H9.25V16c3.824-.604 6.75-3.934 6.75-7.951z\"}}]})(props);\n};\nexport function BsFileArrowDownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM8 5a.5.5 0 0 1 .5.5v3.793l1.146-1.147a.5.5 0 0 1 .708.708l-2 2a.5.5 0 0 1-.708 0l-2-2a.5.5 0 1 1 .708-.708L7.5 9.293V5.5A.5.5 0 0 1 8 5z\"}}]})(props);\n};\nexport function BsFileArrowDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 5a.5.5 0 0 1 .5.5v3.793l1.146-1.147a.5.5 0 0 1 .708.708l-2 2a.5.5 0 0 1-.708 0l-2-2a.5.5 0 1 1 .708-.708L7.5 9.293V5.5A.5.5 0 0 1 8 5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm0 1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFileArrowUpFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM7.5 6.707 6.354 7.854a.5.5 0 1 1-.708-.708l2-2a.5.5 0 0 1 .708 0l2 2a.5.5 0 0 1-.708.708L8.5 6.707V10.5a.5.5 0 0 1-1 0V6.707z\"}}]})(props);\n};\nexport function BsFileArrowUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11a.5.5 0 0 0 .5-.5V6.707l1.146 1.147a.5.5 0 0 0 .708-.708l-2-2a.5.5 0 0 0-.708 0l-2 2a.5.5 0 1 0 .708.708L7.5 6.707V10.5a.5.5 0 0 0 .5.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm0 1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFileBarGraphFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zm-2 11.5v-6a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v6a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5zm-2.5.5a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-.5.5h-1zm-3 0a.5.5 0 0 1-.5-.5v-2a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-1z\"}}]})(props);\n};\nexport function BsFileBarGraph (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 12a.5.5 0 0 1-.5-.5v-2a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-1zm3 0a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-.5.5h-1zm3 0a.5.5 0 0 1-.5-.5v-6a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v6a.5.5 0 0 1-.5.5h-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm0 1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFileBinaryFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.526 9.273c-.542 0-.832.563-.832 1.612 0 .088.003.173.006.252l1.56-1.143c-.126-.474-.375-.72-.733-.72zm-.732 2.508c.126.472.372.718.732.718.54 0 .83-.563.83-1.614 0-.085-.003-.17-.006-.25l-1.556 1.146z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM7.05 10.885c0 1.415-.548 2.206-1.524 2.206C4.548 13.09 4 12.3 4 10.885c0-1.412.548-2.203 1.526-2.203.976 0 1.524.79 1.524 2.203zm3.805 1.52V13h-3v-.595h1.181V9.5h-.05l-1.136.747v-.688l1.19-.786h.69v3.633h1.125z\"}}]})(props);\n};\nexport function BsFileBinary (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.526 13.09c.976 0 1.524-.79 1.524-2.205 0-1.412-.548-2.203-1.524-2.203-.978 0-1.526.79-1.526 2.203 0 1.415.548 2.206 1.526 2.206zm-.832-2.205c0-1.05.29-1.612.832-1.612.358 0 .607.247.733.721L4.7 11.137a6.749 6.749 0 0 1-.006-.252zm.832 1.614c-.36 0-.606-.246-.732-.718l1.556-1.145c.003.079.005.164.005.249 0 1.052-.29 1.614-.829 1.614zm5.329.501v-.595H9.73V8.772h-.69l-1.19.786v.688L8.986 9.5h.05v2.906h-1.18V13h3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm0 1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFileBreakFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0h8a2 2 0 0 1 2 2v7H2V2a2 2 0 0 1 2-2zM2 12h12v2a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2v-2zM.5 10a.5.5 0 0 0 0 1h15a.5.5 0 0 0 0-1H.5z\"}}]})(props);\n};\nexport function BsFileBreak (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 10.5a.5.5 0 0 1 .5-.5h15a.5.5 0 0 1 0 1H.5a.5.5 0 0 1-.5-.5zM12 0H4a2 2 0 0 0-2 2v7h1V2a1 1 0 0 1 1-1h8a1 1 0 0 1 1 1v7h1V2a2 2 0 0 0-2-2zm2 12h-1v2a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1v-2H2v2a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2v-2z\"}}]})(props);\n};\nexport function BsFileCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zm-1.146 6.854-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7.5 8.793l2.646-2.647a.5.5 0 0 1 .708.708z\"}}]})(props);\n};\nexport function BsFileCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.854 6.146a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7.5 8.793l2.646-2.647a.5.5 0 0 1 .708 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm0 1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFileCodeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM6.646 5.646a.5.5 0 1 1 .708.708L5.707 8l1.647 1.646a.5.5 0 0 1-.708.708l-2-2a.5.5 0 0 1 0-.708l2-2zm2.708 0 2 2a.5.5 0 0 1 0 .708l-2 2a.5.5 0 0 1-.708-.708L10.293 8 8.646 6.354a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsFileCode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.646 5.646a.5.5 0 1 1 .708.708L5.707 8l1.647 1.646a.5.5 0 0 1-.708.708l-2-2a.5.5 0 0 1 0-.708l2-2zm2.708 0a.5.5 0 1 0-.708.708L10.293 8 8.646 9.646a.5.5 0 0 0 .708.708l2-2a.5.5 0 0 0 0-.708l-2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm10-1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1z\"}}]})(props);\n};\nexport function BsFileDiffFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM8.5 4.5V6H10a.5.5 0 0 1 0 1H8.5v1.5a.5.5 0 0 1-1 0V7H6a.5.5 0 0 1 0-1h1.5V4.5a.5.5 0 0 1 1 0zM6 10h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFileDiff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4a.5.5 0 0 1 .5.5V6H10a.5.5 0 0 1 0 1H8.5v1.5a.5.5 0 0 1-1 0V7H6a.5.5 0 0 1 0-1h1.5V4.5A.5.5 0 0 1 8 4zm-2.5 6.5A.5.5 0 0 1 6 10h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm10-1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1z\"}}]})(props);\n};\nexport function BsFileEarmarkArrowDownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zm-1 4v3.793l1.146-1.147a.5.5 0 0 1 .708.708l-2 2a.5.5 0 0 1-.708 0l-2-2a.5.5 0 0 1 .708-.708L7.5 11.293V7.5a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFileEarmarkArrowDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 6.5a.5.5 0 0 0-1 0v3.793L6.354 9.146a.5.5 0 1 0-.708.708l2 2a.5.5 0 0 0 .708 0l2-2a.5.5 0 0 0-.708-.708L8.5 10.293V6.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkArrowUpFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM6.354 9.854a.5.5 0 0 1-.708-.708l2-2a.5.5 0 0 1 .708 0l2 2a.5.5 0 0 1-.708.708L8.5 8.707V12.5a.5.5 0 0 1-1 0V8.707L6.354 9.854z\"}}]})(props);\n};\nexport function BsFileEarmarkArrowUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 11.5a.5.5 0 0 1-1 0V7.707L6.354 8.854a.5.5 0 1 1-.708-.708l2-2a.5.5 0 0 1 .708 0l2 2a.5.5 0 0 1-.708.708L8.5 7.707V11.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkBarGraphFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zm.5 10v-6a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v6a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5zm-2.5.5a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-.5.5h-1zm-3 0a.5.5 0 0 1-.5-.5v-2a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-1z\"}}]})(props);\n};\nexport function BsFileEarmarkBarGraph (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10 13.5a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-6a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5v6zm-2.5.5a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-.5.5h-1zm-3 0a.5.5 0 0 1-.5-.5v-2a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkBinaryFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.526 10.273c-.542 0-.832.563-.832 1.612 0 .088.003.173.006.252l1.559-1.143c-.126-.474-.375-.72-.733-.72zm-.732 2.508c.126.472.372.718.732.718.54 0 .83-.563.83-1.614 0-.085-.003-.17-.006-.25l-1.556 1.146z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zm-2.45 8.385c0 1.415-.548 2.206-1.524 2.206C4.548 14.09 4 13.3 4 11.885c0-1.412.548-2.203 1.526-2.203.976 0 1.524.79 1.524 2.203zm3.805 1.52V14h-3v-.595h1.181V10.5h-.05l-1.136.747v-.688l1.19-.786h.69v3.633h1.125z\"}}]})(props);\n};\nexport function BsFileEarmarkBinary (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.05 11.885c0 1.415-.548 2.206-1.524 2.206C4.548 14.09 4 13.3 4 11.885c0-1.412.548-2.203 1.526-2.203.976 0 1.524.79 1.524 2.203zm-1.524-1.612c-.542 0-.832.563-.832 1.612 0 .088.003.173.006.252l1.559-1.143c-.126-.474-.375-.72-.733-.72zm-.732 2.508c.126.472.372.718.732.718.54 0 .83-.563.83-1.614 0-.085-.003-.17-.006-.25l-1.556 1.146zm6.061.624V14h-3v-.595h1.181V10.5h-.05l-1.136.747v-.688l1.19-.786h.69v3.633h1.125z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkBreakFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0h5.293A1 1 0 0 1 10 .293L13.707 4a1 1 0 0 1 .293.707V9H2V2a2 2 0 0 1 2-2zm5.5 1.5v2a1 1 0 0 0 1 1h2l-3-3zM2 12h12v2a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2v-2zM.5 10a.5.5 0 0 0 0 1h15a.5.5 0 0 0 0-1H.5z\"}}]})(props);\n};\nexport function BsFileEarmarkBreak (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4.5V9h-1V4.5h-2A1.5 1.5 0 0 1 9.5 3V1H4a1 1 0 0 0-1 1v7H2V2a2 2 0 0 1 2-2h5.5L14 4.5zM13 12h1v2a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2v-2h1v2a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1v-2zM.5 10a.5.5 0 0 0 0 1h15a.5.5 0 0 0 0-1H.5z\"}}]})(props);\n};\nexport function BsFileEarmarkCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zm1.354 4.354-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7.5 9.793l2.646-2.647a.5.5 0 0 1 .708.708z\"}}]})(props);\n};\nexport function BsFileEarmarkCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.854 7.854a.5.5 0 0 0-.708-.708L7.5 9.793 6.354 8.646a.5.5 0 1 0-.708.708l1.5 1.5a.5.5 0 0 0 .708 0l3-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkCodeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM6.646 7.646a.5.5 0 1 1 .708.708L5.707 10l1.647 1.646a.5.5 0 0 1-.708.708l-2-2a.5.5 0 0 1 0-.708l2-2zm2.708 0 2 2a.5.5 0 0 1 0 .708l-2 2a.5.5 0 0 1-.708-.708L10.293 10 8.646 8.354a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsFileEarmarkCode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4.5V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h5.5L14 4.5zm-3 0A1.5 1.5 0 0 1 9.5 3V1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V4.5h-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.646 6.646a.5.5 0 0 1 .708 0l2 2a.5.5 0 0 1 0 .708l-2 2a.5.5 0 0 1-.708-.708L10.293 9 8.646 7.354a.5.5 0 0 1 0-.708zm-1.292 0a.5.5 0 0 0-.708 0l-2 2a.5.5 0 0 0 0 .708l2 2a.5.5 0 0 0 .708-.708L5.707 9l1.647-1.646a.5.5 0 0 0 0-.708z\"}}]})(props);\n};\nexport function BsFileEarmarkDiffFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM8 6a.5.5 0 0 1 .5.5V8H10a.5.5 0 0 1 0 1H8.5v1.5a.5.5 0 0 1-1 0V9H6a.5.5 0 0 1 0-1h1.5V6.5A.5.5 0 0 1 8 6zm-2.5 6.5A.5.5 0 0 1 6 12h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFileEarmarkDiff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 5a.5.5 0 0 1 .5.5V7H10a.5.5 0 0 1 0 1H8.5v1.5a.5.5 0 0 1-1 0V8H6a.5.5 0 0 1 0-1h1.5V5.5A.5.5 0 0 1 8 5zm-2.5 6.5A.5.5 0 0 1 6 11h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkEaselFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-5a.5.5 0 0 1-.5-.5v-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM8.5 6h2A1.5 1.5 0 0 1 12 7.5v2a1.5 1.5 0 0 1-1.5 1.5h-.473l.447 1.342a.5.5 0 0 1-.948.316L8.973 11H8.5v1a.5.5 0 0 1-1 0v-1h-.473l-.553 1.658a.5.5 0 1 1-.948-.316L5.973 11H5.5A1.5 1.5 0 0 1 4 9.5v-2A1.5 1.5 0 0 1 5.5 6h2a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFileEarmarkEasel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 6a.5.5 0 1 0-1 0h-2A1.5 1.5 0 0 0 4 7.5v2A1.5 1.5 0 0 0 5.5 11h.473l-.447 1.342a.5.5 0 1 0 .948.316L7.027 11H7.5v1a.5.5 0 0 0 1 0v-1h.473l.553 1.658a.5.5 0 1 0 .948-.316L10.027 11h.473A1.5 1.5 0 0 0 12 9.5v-2A1.5 1.5 0 0 0 10.5 6h-2zM5 7.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-5a.5.5 0 0 1-.5-.5v-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkExcelFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM5.884 6.68 8 9.219l2.116-2.54a.5.5 0 1 1 .768.641L8.651 10l2.233 2.68a.5.5 0 0 1-.768.64L8 10.781l-2.116 2.54a.5.5 0 0 1-.768-.641L7.349 10 5.116 7.32a.5.5 0 1 1 .768-.64z\"}}]})(props);\n};\nexport function BsFileEarmarkExcel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.884 6.68a.5.5 0 1 0-.768.64L7.349 10l-2.233 2.68a.5.5 0 0 0 .768.64L8 10.781l2.116 2.54a.5.5 0 0 0 .768-.641L8.651 10l2.233-2.68a.5.5 0 0 0-.768-.64L8 9.219l-2.116-2.54z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0h5.293A1 1 0 0 1 10 .293L13.707 4a1 1 0 0 1 .293.707V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2zm5.5 1.5v2a1 1 0 0 0 1 1h2l-3-3z\"}}]})(props);\n};\nexport function BsFileEarmarkFontFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM5.057 6h5.886L11 8h-.5c-.18-1.096-.356-1.192-1.694-1.235l-.298-.01v5.09c0 .47.1.582.903.655v.5H6.59v-.5c.799-.073.898-.184.898-.654V6.755l-.293.01C5.856 6.808 5.68 6.905 5.5 8H5l.057-2z\"}}]})(props);\n};\nexport function BsFileEarmarkFont (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.943 6H5.057L5 8h.5c.18-1.096.356-1.192 1.694-1.235l.293-.01v5.09c0 .47-.1.582-.898.655v.5H9.41v-.5c-.803-.073-.903-.184-.903-.654V6.755l.298.01c1.338.043 1.514.14 1.694 1.235h.5l-.057-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4.5V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h5.5L14 4.5zm-3 0A1.5 1.5 0 0 1 9.5 3V1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V4.5h-2z\"}}]})(props);\n};\nexport function BsFileEarmarkImageFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0h5.293A1 1 0 0 1 10 .293L13.707 4a1 1 0 0 1 .293.707v5.586l-2.73-2.73a1 1 0 0 0-1.52.127l-1.889 2.644-1.769-1.062a1 1 0 0 0-1.222.15L2 12.292V2a2 2 0 0 1 2-2zm5.5 1.5v2a1 1 0 0 0 1 1h2l-3-3zm-1.498 4a1.5 1.5 0 1 0-3 0 1.5 1.5 0 0 0 3 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.564 8.27 14 11.708V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2v-.293l3.578-3.577 2.56 1.536 2.426-3.395z\"}}]})(props);\n};\nexport function BsFileEarmarkImage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.502 7a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h5.5L14 4.5V14zM4 1a1 1 0 0 0-1 1v10l2.224-2.224a.5.5 0 0 1 .61-.075L8 11l2.157-3.02a.5.5 0 0 1 .76-.063L13 10V4.5h-2A1.5 1.5 0 0 1 9.5 3V1H4z\"}}]})(props);\n};\nexport function BsFileEarmarkLockFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7a1 1 0 0 1 2 0v1H7V7zM6 9.3c0-.042.02-.107.105-.175A.637.637 0 0 1 6.5 9h3a.64.64 0 0 1 .395.125c.085.068.105.133.105.175v2.4c0 .042-.02.107-.105.175A.637.637 0 0 1 9.5 12h-3a.637.637 0 0 1-.395-.125C6.02 11.807 6 11.742 6 11.7V9.3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM10 7v1.076c.54.166 1 .597 1 1.224v2.4c0 .816-.781 1.3-1.5 1.3h-3c-.719 0-1.5-.484-1.5-1.3V9.3c0-.627.46-1.058 1-1.224V7a2 2 0 1 1 4 0z\"}}]})(props);\n};\nexport function BsFileEarmarkLock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10 7v1.076c.54.166 1 .597 1 1.224v2.4c0 .816-.781 1.3-1.5 1.3h-3c-.719 0-1.5-.484-1.5-1.3V9.3c0-.627.46-1.058 1-1.224V7a2 2 0 1 1 4 0zM7 7v1h2V7a1 1 0 0 0-2 0zM6 9.3v2.4c0 .042.02.107.105.175A.637.637 0 0 0 6.5 12h3a.64.64 0 0 0 .395-.125c.085-.068.105-.133.105-.175V9.3c0-.042-.02-.107-.105-.175A.637.637 0 0 0 9.5 9h-3a.637.637 0 0 0-.395.125C6.02 9.193 6 9.258 6 9.3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkLock2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7a1 1 0 0 1 2 0v1H7V7z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM10 7v1.076c.54.166 1 .597 1 1.224v2.4c0 .816-.781 1.3-1.5 1.3h-3c-.719 0-1.5-.484-1.5-1.3V9.3c0-.627.46-1.058 1-1.224V7a2 2 0 1 1 4 0z\"}}]})(props);\n};\nexport function BsFileEarmarkLock2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10 7v1.076c.54.166 1 .597 1 1.224v2.4c0 .816-.781 1.3-1.5 1.3h-3c-.719 0-1.5-.484-1.5-1.3V9.3c0-.627.46-1.058 1-1.224V7a2 2 0 1 1 4 0zM7 7v1h2V7a1 1 0 0 0-2 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkMedicalFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zm-3 2v.634l.549-.317a.5.5 0 1 1 .5.866L7 7l.549.317a.5.5 0 1 1-.5.866L6.5 7.866V8.5a.5.5 0 0 1-1 0v-.634l-.549.317a.5.5 0 1 1-.5-.866L5 7l-.549-.317a.5.5 0 0 1 .5-.866l.549.317V5.5a.5.5 0 1 1 1 0zm-2 4.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1zm0 2h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFileEarmarkMedical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 5.5a.5.5 0 0 0-1 0v.634l-.549-.317a.5.5 0 1 0-.5.866L6 7l-.549.317a.5.5 0 1 0 .5.866l.549-.317V8.5a.5.5 0 1 0 1 0v-.634l.549.317a.5.5 0 1 0 .5-.866L8 7l.549-.317a.5.5 0 1 0-.5-.866l-.549.317V5.5zm-2 4.5a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5zm0 2a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkMinusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM6 8.5h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFileEarmarkMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 9a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4.5V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h5.5L14 4.5zm-3 0A1.5 1.5 0 0 1 9.5 3V1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V4.5h-2z\"}}]})(props);\n};\nexport function BsFileEarmarkMusicFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM11 6.64v1.75l-2 .5v3.61c0 .495-.301.883-.662 1.123C7.974 13.866 7.499 14 7 14c-.5 0-.974-.134-1.338-.377-.36-.24-.662-.628-.662-1.123s.301-.883.662-1.123C6.026 11.134 6.501 11 7 11c.356 0 .7.068 1 .196V6.89a1 1 0 0 1 .757-.97l1-.25A1 1 0 0 1 11 6.64z\"}}]})(props);\n};\nexport function BsFileEarmarkMusic (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 6.64a1 1 0 0 0-1.243-.97l-1 .25A1 1 0 0 0 8 6.89v4.306A2.572 2.572 0 0 0 7 11c-.5 0-.974.134-1.338.377-.36.24-.662.628-.662 1.123s.301.883.662 1.123c.364.243.839.377 1.338.377.5 0 .974-.134 1.338-.377.36-.24.662-.628.662-1.123V8.89l2-.5V6.64z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkPdfFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.523 12.424c.14-.082.293-.162.459-.238a7.878 7.878 0 0 1-.45.606c-.28.337-.498.516-.635.572a.266.266 0 0 1-.035.012.282.282 0 0 1-.026-.044c-.056-.11-.054-.216.04-.36.106-.165.319-.354.647-.548zm2.455-1.647c-.119.025-.237.05-.356.078a21.148 21.148 0 0 0 .5-1.05 12.045 12.045 0 0 0 .51.858c-.217.032-.436.07-.654.114zm2.525.939a3.881 3.881 0 0 1-.435-.41c.228.005.434.022.612.054.317.057.466.147.518.209a.095.095 0 0 1 .026.064.436.436 0 0 1-.06.2.307.307 0 0 1-.094.124.107.107 0 0 1-.069.015c-.09-.003-.258-.066-.498-.256zM8.278 6.97c-.04.244-.108.524-.2.829a4.86 4.86 0 0 1-.089-.346c-.076-.353-.087-.63-.046-.822.038-.177.11-.248.196-.283a.517.517 0 0 1 .145-.04c.013.03.028.092.032.198.005.122-.007.277-.038.465z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4 0h5.293A1 1 0 0 1 10 .293L13.707 4a1 1 0 0 1 .293.707V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2zm5.5 1.5v2a1 1 0 0 0 1 1h2l-3-3zM4.165 13.668c.09.18.23.343.438.419.207.075.412.04.58-.03.318-.13.635-.436.926-.786.333-.401.683-.927 1.021-1.51a11.651 11.651 0 0 1 1.997-.406c.3.383.61.713.91.95.28.22.603.403.934.417a.856.856 0 0 0 .51-.138c.155-.101.27-.247.354-.416.09-.181.145-.37.138-.563a.844.844 0 0 0-.2-.518c-.226-.27-.596-.4-.96-.465a5.76 5.76 0 0 0-1.335-.05 10.954 10.954 0 0 1-.98-1.686c.25-.66.437-1.284.52-1.794.036-.218.055-.426.048-.614a1.238 1.238 0 0 0-.127-.538.7.7 0 0 0-.477-.365c-.202-.043-.41 0-.601.077-.377.15-.576.47-.651.823-.073.34-.04.736.046 1.136.088.406.238.848.43 1.295a19.697 19.697 0 0 1-1.062 2.227 7.662 7.662 0 0 0-1.482.645c-.37.22-.699.48-.897.787-.21.326-.275.714-.08 1.103z\"}}]})(props);\n};\nexport function BsFileEarmarkPdf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.603 14.087a.81.81 0 0 1-.438-.42c-.195-.388-.13-.776.08-1.102.198-.307.526-.568.897-.787a7.68 7.68 0 0 1 1.482-.645 19.697 19.697 0 0 0 1.062-2.227 7.269 7.269 0 0 1-.43-1.295c-.086-.4-.119-.796-.046-1.136.075-.354.274-.672.65-.823.192-.077.4-.12.602-.077a.7.7 0 0 1 .477.365c.088.164.12.356.127.538.007.188-.012.396-.047.614-.084.51-.27 1.134-.52 1.794a10.954 10.954 0 0 0 .98 1.686 5.753 5.753 0 0 1 1.334.05c.364.066.734.195.96.465.12.144.193.32.2.518.007.192-.047.382-.138.563a1.04 1.04 0 0 1-.354.416.856.856 0 0 1-.51.138c-.331-.014-.654-.196-.933-.417a5.712 5.712 0 0 1-.911-.95 11.651 11.651 0 0 0-1.997.406 11.307 11.307 0 0 1-1.02 1.51c-.292.35-.609.656-.927.787a.793.793 0 0 1-.58.029zm1.379-1.901c-.166.076-.32.156-.459.238-.328.194-.541.383-.647.547-.094.145-.096.25-.04.361.01.022.02.036.026.044a.266.266 0 0 0 .035-.012c.137-.056.355-.235.635-.572a8.18 8.18 0 0 0 .45-.606zm1.64-1.33a12.71 12.71 0 0 1 1.01-.193 11.744 11.744 0 0 1-.51-.858 20.801 20.801 0 0 1-.5 1.05zm2.446.45c.15.163.296.3.435.41.24.19.407.253.498.256a.107.107 0 0 0 .07-.015.307.307 0 0 0 .094-.125.436.436 0 0 0 .059-.2.095.095 0 0 0-.026-.063c-.052-.062-.2-.152-.518-.209a3.876 3.876 0 0 0-.612-.053zM8.078 7.8a6.7 6.7 0 0 0 .2-.828c.031-.188.043-.343.038-.465a.613.613 0 0 0-.032-.198.517.517 0 0 0-.145.04c-.087.035-.158.106-.196.283-.04.192-.03.469.046.822.024.111.054.227.09.346z\"}}]})(props);\n};\nexport function BsFileEarmarkPersonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM11 8a3 3 0 1 1-6 0 3 3 0 0 1 6 0zm2 5.755V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1v-.245S4 12 8 12s5 1.755 5 1.755z\"}}]})(props);\n};\nexport function BsFileEarmarkPerson (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 8a3 3 0 1 1-6 0 3 3 0 0 1 6 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2v9.255S12 12 8 12s-5 1.755-5 1.755V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkPlayFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM6 6.883a.5.5 0 0 1 .757-.429l3.528 2.117a.5.5 0 0 1 0 .858l-3.528 2.117a.5.5 0 0 1-.757-.43V6.884z\"}}]})(props);\n};\nexport function BsFileEarmarkPlay (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 6.883v4.234a.5.5 0 0 0 .757.429l3.528-2.117a.5.5 0 0 0 0-.858L6.757 6.454a.5.5 0 0 0-.757.43z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkPlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM8.5 7v1.5H10a.5.5 0 0 1 0 1H8.5V11a.5.5 0 0 1-1 0V9.5H6a.5.5 0 0 1 0-1h1.5V7a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFileEarmarkPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 6.5a.5.5 0 0 1 .5.5v1.5H10a.5.5 0 0 1 0 1H8.5V11a.5.5 0 0 1-1 0V9.5H6a.5.5 0 0 1 0-1h1.5V7a.5.5 0 0 1 .5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4.5V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h5.5L14 4.5zm-3 0A1.5 1.5 0 0 1 9.5 3V1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V4.5h-2z\"}}]})(props);\n};\nexport function BsFileEarmarkPostFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zm-5-.5H7a.5.5 0 0 1 0 1H4.5a.5.5 0 0 1 0-1zm0 3h7a.5.5 0 0 1 .5.5v7a.5.5 0 0 1-.5.5h-7a.5.5 0 0 1-.5-.5v-7a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsFileEarmarkPost (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4.5V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h5.5L14 4.5zm-3 0A1.5 1.5 0 0 1 9.5 3V1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V4.5h-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 6.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 .5.5v7a.5.5 0 0 1-.5.5h-7a.5.5 0 0 1-.5-.5v-7zm0-3a.5.5 0 0 1 .5-.5H7a.5.5 0 0 1 0 1H4.5a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFileEarmarkPptFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.188 10H7V6.5h1.188a1.75 1.75 0 1 1 0 3.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0h5.293A1 1 0 0 1 10 .293L13.707 4a1 1 0 0 1 .293.707V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2zm5.5 1.5v2a1 1 0 0 0 1 1h2l-3-3zM7 5.5a1 1 0 0 0-1 1V13a.5.5 0 0 0 1 0v-2h1.188a2.75 2.75 0 0 0 0-5.5H7z\"}}]})(props);\n};\nexport function BsFileEarmarkPpt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 5.5a1 1 0 0 0-1 1V13a.5.5 0 0 0 1 0v-2h1.188a2.75 2.75 0 0 0 0-5.5H7zM8.188 10H7V6.5h1.188a1.75 1.75 0 1 1 0 3.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4.5V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h5.5L14 4.5zm-3 0A1.5 1.5 0 0 1 9.5 3V1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V4.5h-2z\"}}]})(props);\n};\nexport function BsFileEarmarkRichtextFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM7 6.25a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0zm-.861 1.542 1.33.886 1.854-1.855a.25.25 0 0 1 .289-.047l1.888.974V9.5a.5.5 0 0 1-.5.5H5a.5.5 0 0 1-.5-.5V9s1.54-1.274 1.639-1.208zM5 11h6a.5.5 0 0 1 0 1H5a.5.5 0 0 1 0-1zm0 2h3a.5.5 0 0 1 0 1H5a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFileEarmarkRichtext (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4.5V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h5.5L14 4.5zm-3 0A1.5 1.5 0 0 1 9.5 3V1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V4.5h-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 12.5A.5.5 0 0 1 5 12h3a.5.5 0 0 1 0 1H5a.5.5 0 0 1-.5-.5zm0-2A.5.5 0 0 1 5 10h6a.5.5 0 0 1 0 1H5a.5.5 0 0 1-.5-.5zm1.639-3.708 1.33.886 1.854-1.855a.25.25 0 0 1 .289-.047l1.888.974V8.5a.5.5 0 0 1-.5.5H5a.5.5 0 0 1-.5-.5V8s1.54-1.274 1.639-1.208zM6.25 6a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5z\"}}]})(props);\n};\nexport function BsFileEarmarkRuledFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM3 9h10v1H6v2h7v1H6v2H5v-2H3v-1h2v-2H3V9z\"}}]})(props);\n};\nexport function BsFileEarmarkRuled (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V9H3V2a1 1 0 0 1 1-1h5.5v2zM3 12v-2h2v2H3zm0 1h2v2H4a1 1 0 0 1-1-1v-1zm3 2v-2h7v1a1 1 0 0 1-1 1H6zm7-3H6v-2h7v2z\"}}]})(props);\n};\nexport function BsFileEarmarkSlidesFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 9.78V7.22c0-.096.106-.156.19-.106l2.13 1.279a.125.125 0 0 1 0 .214l-2.13 1.28A.125.125 0 0 1 7 9.778z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM5 6h6a.5.5 0 0 1 .496.438l.5 4A.5.5 0 0 1 11.5 11h-3v2.016c.863.055 1.5.251 1.5.484 0 .276-.895.5-2 .5s-2-.224-2-.5c0-.233.637-.429 1.5-.484V11h-3a.5.5 0 0 1-.496-.562l.5-4A.5.5 0 0 1 5 6z\"}}]})(props);\n};\nexport function BsFileEarmarkSlides (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 6a.5.5 0 0 0-.496.438l-.5 4A.5.5 0 0 0 4.5 11h3v2.016c-.863.055-1.5.251-1.5.484 0 .276.895.5 2 .5s2-.224 2-.5c0-.233-.637-.429-1.5-.484V11h3a.5.5 0 0 0 .496-.562l-.5-4A.5.5 0 0 0 11 6H5zm2 3.78V7.22c0-.096.106-.156.19-.106l2.13 1.279a.125.125 0 0 1 0 .214l-2.13 1.28A.125.125 0 0 1 7 9.778z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkSpreadsheetFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 12v-2h3v2H6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM3 9h10v1h-3v2h3v1h-3v2H9v-2H6v2H5v-2H3v-1h2v-2H3V9z\"}}]})(props);\n};\nexport function BsFileEarmarkSpreadsheet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V9H3V2a1 1 0 0 1 1-1h5.5v2zM3 12v-2h2v2H3zm0 1h2v2H4a1 1 0 0 1-1-1v-1zm3 2v-2h3v2H6zm4 0v-2h3v1a1 1 0 0 1-1 1h-2zm3-3h-3v-2h3v2zm-7 0v-2h3v2H6z\"}}]})(props);\n};\nexport function BsFileEarmarkTextFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM4.5 9a.5.5 0 0 1 0-1h7a.5.5 0 0 1 0 1h-7zM4 10.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm.5 2.5a.5.5 0 0 1 0-1h4a.5.5 0 0 1 0 1h-4z\"}}]})(props);\n};\nexport function BsFileEarmarkText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 7a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5zM5 9.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.5L9.5 0zm0 1v2A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5z\"}}]})(props);\n};\nexport function BsFileEarmarkWordFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM5.485 6.879l1.036 4.144.997-3.655a.5.5 0 0 1 .964 0l.997 3.655 1.036-4.144a.5.5 0 0 1 .97.242l-1.5 6a.5.5 0 0 1-.967.01L8 9.402l-1.018 3.73a.5.5 0 0 1-.967-.01l-1.5-6a.5.5 0 1 1 .97-.242z\"}}]})(props);\n};\nexport function BsFileEarmarkWord (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.485 6.879a.5.5 0 1 0-.97.242l1.5 6a.5.5 0 0 0 .967.01L8 9.402l1.018 3.73a.5.5 0 0 0 .967-.01l1.5-6a.5.5 0 0 0-.97-.242l-1.036 4.144-.997-3.655a.5.5 0 0 0-.964 0l-.997 3.655L5.485 6.88z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkXFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zM6.854 7.146 8 8.293l1.146-1.147a.5.5 0 1 1 .708.708L8.707 9l1.147 1.146a.5.5 0 0 1-.708.708L8 9.707l-1.146 1.147a.5.5 0 0 1-.708-.708L7.293 9 6.146 7.854a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsFileEarmarkX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.854 7.146a.5.5 0 1 0-.708.708L7.293 9l-1.147 1.146a.5.5 0 0 0 .708.708L8 9.707l1.146 1.147a.5.5 0 0 0 .708-.708L8.707 9l1.147-1.146a.5.5 0 0 0-.708-.708L8 8.293 6.854 7.146z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 14V4.5L9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2zM9.5 3A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h5.5v2z\"}}]})(props);\n};\nexport function BsFileEarmarkZipFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 9.438V8.5h1v.938a1 1 0 0 0 .03.243l.4 1.598-.93.62-.93-.62.4-1.598a1 1 0 0 0 .03-.243z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.293 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.707A1 1 0 0 0 13.707 4L10 .293A1 1 0 0 0 9.293 0zM9.5 3.5v-2l3 3h-2a1 1 0 0 1-1-1zm-4-.5V2h-1V1H6v1h1v1H6v1h1v1H6v1h1v1H5.5V6h-1V5h1V4h-1V3h1zm0 4.5h1a1 1 0 0 1 1 1v.938l.4 1.599a1 1 0 0 1-.416 1.074l-.93.62a1 1 0 0 1-1.109 0l-.93-.62a1 1 0 0 1-.415-1.074l.4-1.599V8.5a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFileEarmarkZip (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 7.5a1 1 0 0 1 1-1h1a1 1 0 0 1 1 1v.938l.4 1.599a1 1 0 0 1-.416 1.074l-.93.62a1 1 0 0 1-1.11 0l-.929-.62a1 1 0 0 1-.415-1.074L5 8.438V7.5zm2 0H6v.938a1 1 0 0 1-.03.243l-.4 1.598.93.62.929-.62-.4-1.598A1 1 0 0 1 7 8.438V7.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4.5V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h5.5L14 4.5zm-3 0A1.5 1.5 0 0 1 9.5 3V1h-2v1h-1v1h1v1h-1v1h1v1H6V5H5V4h1V3H5V2h1V1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V4.5h-2z\"}}]})(props);\n};\nexport function BsFileEarmark (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4.5V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h5.5L14 4.5zm-3 0A1.5 1.5 0 0 1 9.5 3V1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V4.5h-2z\"}}]})(props);\n};\nexport function BsFileEaselFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 6.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-5a.5.5 0 0 1-.5-.5v-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM8.5 5h2A1.5 1.5 0 0 1 12 6.5v2a1.5 1.5 0 0 1-1.5 1.5h-.473l.447 1.342a.5.5 0 0 1-.948.316L8.973 10H8.5v1a.5.5 0 0 1-1 0v-1h-.473l-.553 1.658a.5.5 0 1 1-.948-.316L5.973 10H5.5A1.5 1.5 0 0 1 4 8.5v-2A1.5 1.5 0 0 1 5.5 5h2a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFileEasel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 5a.5.5 0 1 0-1 0h-2A1.5 1.5 0 0 0 4 6.5v2A1.5 1.5 0 0 0 5.5 10h.473l-.447 1.342a.5.5 0 1 0 .948.316L7.027 10H7.5v1a.5.5 0 0 0 1 0v-1h.473l.553 1.658a.5.5 0 1 0 .948-.316L10.027 10h.473A1.5 1.5 0 0 0 12 8.5v-2A1.5 1.5 0 0 0 10.5 5h-2zM5 6.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-5a.5.5 0 0 1-.5-.5v-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm10-1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1z\"}}]})(props);\n};\nexport function BsFileExcelFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM5.884 4.68 8 7.219l2.116-2.54a.5.5 0 1 1 .768.641L8.651 8l2.233 2.68a.5.5 0 0 1-.768.64L8 8.781l-2.116 2.54a.5.5 0 0 1-.768-.641L7.349 8 5.116 5.32a.5.5 0 1 1 .768-.64z\"}}]})(props);\n};\nexport function BsFileExcel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.18 4.616a.5.5 0 0 1 .704.064L8 7.219l2.116-2.54a.5.5 0 1 1 .768.641L8.651 8l2.233 2.68a.5.5 0 0 1-.768.64L8 8.781l-2.116 2.54a.5.5 0 0 1-.768-.641L7.349 8 5.116 5.32a.5.5 0 0 1 .064-.704z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm0 1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFileFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4 0h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2z\"}}]})(props);\n};\nexport function BsFileFontFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM5.057 4h5.886L11 6h-.5c-.18-1.096-.356-1.192-1.694-1.235l-.298-.01v6.09c0 .47.1.582.903.655v.5H6.59v-.5c.799-.073.898-.184.898-.654V4.755l-.293.01C5.856 4.808 5.68 4.905 5.5 6H5l.057-2z\"}}]})(props);\n};\nexport function BsFileFont (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.943 4H5.057L5 6h.5c.18-1.096.356-1.192 1.694-1.235l.293-.01v6.09c0 .47-.1.582-.898.655v.5H9.41v-.5c-.803-.073-.903-.184-.903-.654V4.755l.298.01c1.338.043 1.514.14 1.694 1.235h.5l-.057-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm0 1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFileImageFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0h8a2 2 0 0 1 2 2v8.293l-2.73-2.73a1 1 0 0 0-1.52.127l-1.889 2.644-1.769-1.062a1 1 0 0 0-1.222.15L2 12.292V2a2 2 0 0 1 2-2zm4.002 5.5a1.5 1.5 0 1 0-3 0 1.5 1.5 0 0 0 3 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.564 8.27 14 11.708V14a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2v-.293l3.578-3.577 2.56 1.536 2.426-3.395z\"}}]})(props);\n};\nexport function BsFileImage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.002 5.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM3 2a1 1 0 0 1 1-1h8a1 1 0 0 1 1 1v8l-2.083-2.083a.5.5 0 0 0-.76.063L8 11 5.835 9.7a.5.5 0 0 0-.611.076L3 12V2z\"}}]})(props);\n};\nexport function BsFileLockFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 6a1 1 0 0 1 2 0v1H7V6zM6 8.3c0-.042.02-.107.105-.175A.637.637 0 0 1 6.5 8h3a.64.64 0 0 1 .395.125c.085.068.105.133.105.175v2.4c0 .042-.02.107-.105.175A.637.637 0 0 1 9.5 11h-3a.637.637 0 0 1-.395-.125C6.02 10.807 6 10.742 6 10.7V8.3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zm-2 6v1.076c.54.166 1 .597 1 1.224v2.4c0 .816-.781 1.3-1.5 1.3h-3c-.719 0-1.5-.484-1.5-1.3V8.3c0-.627.46-1.058 1-1.224V6a2 2 0 1 1 4 0z\"}}]})(props);\n};\nexport function BsFileLock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 5a1 1 0 0 1 1 1v1H7V6a1 1 0 0 1 1-1zm2 2.076V6a2 2 0 1 0-4 0v1.076c-.54.166-1 .597-1 1.224v2.4c0 .816.781 1.3 1.5 1.3h3c.719 0 1.5-.484 1.5-1.3V8.3c0-.627-.46-1.058-1-1.224zM6.105 8.125A.637.637 0 0 1 6.5 8h3a.64.64 0 0 1 .395.125c.085.068.105.133.105.175v2.4c0 .042-.02.107-.105.175A.637.637 0 0 1 9.5 11h-3a.637.637 0 0 1-.395-.125C6.02 10.807 6 10.742 6 10.7V8.3c0-.042.02-.107.105-.175z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm0 1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFileLock2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 6a1 1 0 0 1 2 0v1H7V6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zm-2 6v1.076c.54.166 1 .597 1 1.224v2.4c0 .816-.781 1.3-1.5 1.3h-3c-.719 0-1.5-.484-1.5-1.3V8.3c0-.627.46-1.058 1-1.224V6a2 2 0 1 1 4 0z\"}}]})(props);\n};\nexport function BsFileLock2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 5a1 1 0 0 1 1 1v1H7V6a1 1 0 0 1 1-1zm2 2.076V6a2 2 0 1 0-4 0v1.076c-.54.166-1 .597-1 1.224v2.4c0 .816.781 1.3 1.5 1.3h3c.719 0 1.5-.484 1.5-1.3V8.3c0-.627-.46-1.058-1-1.224z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm0 1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFileMedicalFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM8.5 4.5v.634l.549-.317a.5.5 0 1 1 .5.866L9 6l.549.317a.5.5 0 1 1-.5.866L8.5 6.866V7.5a.5.5 0 0 1-1 0v-.634l-.549.317a.5.5 0 1 1-.5-.866L7 6l-.549-.317a.5.5 0 0 1 .5-.866l.549.317V4.5a.5.5 0 1 1 1 0zM5.5 9h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1zm0 2h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFileMedical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 4.5a.5.5 0 0 0-1 0v.634l-.549-.317a.5.5 0 1 0-.5.866L7 6l-.549.317a.5.5 0 1 0 .5.866l.549-.317V7.5a.5.5 0 1 0 1 0v-.634l.549.317a.5.5 0 1 0 .5-.866L9 6l.549-.317a.5.5 0 1 0-.5-.866l-.549.317V4.5zM5.5 9a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5zm0 2a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm10-1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1z\"}}]})(props);\n};\nexport function BsFileMinusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM6 7.5h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFileMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 8a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm0 1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFileMusicFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zm-.5 4.11v1.8l-2.5.5v5.09c0 .495-.301.883-.662 1.123C7.974 12.866 7.499 13 7 13c-.5 0-.974-.134-1.338-.377-.36-.24-.662-.628-.662-1.123s.301-.883.662-1.123C6.026 10.134 6.501 10 7 10c.356 0 .7.068 1 .196V4.41a1 1 0 0 1 .804-.98l1.5-.3a1 1 0 0 1 1.196.98z\"}}]})(props);\n};\nexport function BsFileMusic (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.304 3.13a1 1 0 0 1 1.196.98v1.8l-2.5.5v5.09c0 .495-.301.883-.662 1.123C7.974 12.866 7.499 13 7 13c-.5 0-.974-.134-1.338-.377-.36-.24-.662-.628-.662-1.123s.301-.883.662-1.123C6.026 10.134 6.501 10 7 10c.356 0 .7.068 1 .196V4.41a1 1 0 0 1 .804-.98l1.5-.3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm0 1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFilePdfFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.523 10.424c.14-.082.293-.162.459-.238a7.878 7.878 0 0 1-.45.606c-.28.337-.498.516-.635.572a.266.266 0 0 1-.035.012.282.282 0 0 1-.026-.044c-.056-.11-.054-.216.04-.36.106-.165.319-.354.647-.548zm2.455-1.647c-.119.025-.237.05-.356.078a21.035 21.035 0 0 0 .5-1.05 11.96 11.96 0 0 0 .51.858c-.217.032-.436.07-.654.114zm2.525.939a3.888 3.888 0 0 1-.435-.41c.228.005.434.022.612.054.317.057.466.147.518.209a.095.095 0 0 1 .026.064.436.436 0 0 1-.06.2.307.307 0 0 1-.094.124.107.107 0 0 1-.069.015c-.09-.003-.258-.066-.498-.256zM8.278 4.97c-.04.244-.108.524-.2.829a4.86 4.86 0 0 1-.089-.346c-.076-.353-.087-.63-.046-.822.038-.177.11-.248.196-.283a.517.517 0 0 1 .145-.04c.013.03.028.092.032.198.005.122-.007.277-.038.465z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4 0h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2zm.165 11.668c.09.18.23.343.438.419.207.075.412.04.58-.03.318-.13.635-.436.926-.786.333-.401.683-.927 1.021-1.51a11.64 11.64 0 0 1 1.997-.406c.3.383.61.713.91.95.28.22.603.403.934.417a.856.856 0 0 0 .51-.138c.155-.101.27-.247.354-.416.09-.181.145-.37.138-.563a.844.844 0 0 0-.2-.518c-.226-.27-.596-.4-.96-.465a5.76 5.76 0 0 0-1.335-.05 10.954 10.954 0 0 1-.98-1.686c.25-.66.437-1.284.52-1.794.036-.218.055-.426.048-.614a1.238 1.238 0 0 0-.127-.538.7.7 0 0 0-.477-.365c-.202-.043-.41 0-.601.077-.377.15-.576.47-.651.823-.073.34-.04.736.046 1.136.088.406.238.848.43 1.295a19.707 19.707 0 0 1-1.062 2.227 7.662 7.662 0 0 0-1.482.645c-.37.22-.699.48-.897.787-.21.326-.275.714-.08 1.103z\"}}]})(props);\n};\nexport function BsFilePdf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm0 1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.603 12.087a.81.81 0 0 1-.438-.42c-.195-.388-.13-.776.08-1.102.198-.307.526-.568.897-.787a7.68 7.68 0 0 1 1.482-.645 19.701 19.701 0 0 0 1.062-2.227 7.269 7.269 0 0 1-.43-1.295c-.086-.4-.119-.796-.046-1.136.075-.354.274-.672.65-.823.192-.077.4-.12.602-.077a.7.7 0 0 1 .477.365c.088.164.12.356.127.538.007.187-.012.395-.047.614-.084.51-.27 1.134-.52 1.794a10.954 10.954 0 0 0 .98 1.686 5.753 5.753 0 0 1 1.334.05c.364.065.734.195.96.465.12.144.193.32.2.518.007.192-.047.382-.138.563a1.04 1.04 0 0 1-.354.416.856.856 0 0 1-.51.138c-.331-.014-.654-.196-.933-.417a5.716 5.716 0 0 1-.911-.95 11.642 11.642 0 0 0-1.997.406 11.311 11.311 0 0 1-1.021 1.51c-.29.35-.608.655-.926.787a.793.793 0 0 1-.58.029zm1.379-1.901c-.166.076-.32.156-.459.238-.328.194-.541.383-.647.547-.094.145-.096.25-.04.361.01.022.02.036.026.044a.27.27 0 0 0 .035-.012c.137-.056.355-.235.635-.572a8.18 8.18 0 0 0 .45-.606zm1.64-1.33a12.647 12.647 0 0 1 1.01-.193 11.666 11.666 0 0 1-.51-.858 20.741 20.741 0 0 1-.5 1.05zm2.446.45c.15.162.296.3.435.41.24.19.407.253.498.256a.107.107 0 0 0 .07-.015.307.307 0 0 0 .094-.125.436.436 0 0 0 .059-.2.095.095 0 0 0-.026-.063c-.052-.062-.2-.152-.518-.209a3.881 3.881 0 0 0-.612-.053zM8.078 5.8a6.7 6.7 0 0 0 .2-.828c.031-.188.043-.343.038-.465a.613.613 0 0 0-.032-.198.517.517 0 0 0-.145.04c-.087.035-.158.106-.196.283-.04.192-.03.469.046.822.024.111.054.227.09.346z\"}}]})(props);\n};\nexport function BsFilePersonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zm-1 7a3 3 0 1 1-6 0 3 3 0 0 1 6 0zm-3 4c2.623 0 4.146.826 5 1.755V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1v-1.245C3.854 11.825 5.377 11 8 11z\"}}]})(props);\n};\nexport function BsFilePerson (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 1a1 1 0 0 1 1 1v10.755S12 11 8 11s-5 1.755-5 1.755V2a1 1 0 0 1 1-1h8zM4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 10a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}}]})(props);\n};\nexport function BsFilePlayFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM6 5.883a.5.5 0 0 1 .757-.429l3.528 2.117a.5.5 0 0 1 0 .858l-3.528 2.117a.5.5 0 0 1-.757-.43V5.884z\"}}]})(props);\n};\nexport function BsFilePlay (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10.117V5.883a.5.5 0 0 1 .757-.429l3.528 2.117a.5.5 0 0 1 0 .858l-3.528 2.117a.5.5 0 0 1-.757-.43z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm0 1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFilePlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM8.5 6v1.5H10a.5.5 0 0 1 0 1H8.5V10a.5.5 0 0 1-1 0V8.5H6a.5.5 0 0 1 0-1h1.5V6a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsFilePlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 6a.5.5 0 0 0-1 0v1.5H6a.5.5 0 0 0 0 1h1.5V10a.5.5 0 0 0 1 0V8.5H10a.5.5 0 0 0 0-1H8.5V6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm10-1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1z\"}}]})(props);\n};\nexport function BsFilePostFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM4.5 3h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1zm0 2h7a.5.5 0 0 1 .5.5v8a.5.5 0 0 1-.5.5h-7a.5.5 0 0 1-.5-.5v-8a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsFilePost (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 3.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 .5.5v8a.5.5 0 0 1-.5.5h-7a.5.5 0 0 1-.5-.5v-8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm10-1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1z\"}}]})(props);\n};\nexport function BsFilePptFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.188 8.5H7V5h1.188a1.75 1.75 0 1 1 0 3.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2zm3 4a1 1 0 0 0-1 1v6.5a.5.5 0 0 0 1 0v-2h1.188a2.75 2.75 0 0 0 0-5.5H7z\"}}]})(props);\n};\nexport function BsFilePpt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm10-1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 5a1 1 0 0 1 1-1h1.188a2.75 2.75 0 0 1 0 5.5H7v2a.5.5 0 0 1-1 0V5zm1 3.5h1.188a1.75 1.75 0 1 0 0-3.5H7v3.5z\"}}]})(props);\n};\nexport function BsFileRichtextFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM7 4.25a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0zm-.861 1.542 1.33.886 1.854-1.855a.25.25 0 0 1 .289-.047l1.888.974V7.5a.5.5 0 0 1-.5.5H5a.5.5 0 0 1-.5-.5V7s1.54-1.274 1.639-1.208zM5 9h6a.5.5 0 0 1 0 1H5a.5.5 0 0 1 0-1zm0 2h3a.5.5 0 0 1 0 1H5a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFileRichtext (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 4.25a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0zm-.861 1.542 1.33.886 1.854-1.855a.25.25 0 0 1 .289-.047l1.888.974V7.5a.5.5 0 0 1-.5.5H5a.5.5 0 0 1-.5-.5V7s1.54-1.274 1.639-1.208zM5 9a.5.5 0 0 0 0 1h6a.5.5 0 0 0 0-1H5zm0 2a.5.5 0 0 0 0 1h3a.5.5 0 0 0 0-1H5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm10-1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1z\"}}]})(props);\n};\nexport function BsFileRuledFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v4h12V2a2 2 0 0 0-2-2zm2 7H6v2h8V7zm0 3H6v2h8v-2zm0 3H6v3h6a2 2 0 0 0 2-2v-1zm-9 3v-3H2v1a2 2 0 0 0 2 2h1zm-3-4h3v-2H2v2zm0-3h3V7H2v2z\"}}]})(props);\n};\nexport function BsFileRuled (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm2-1a1 1 0 0 0-1 1v4h10V2a1 1 0 0 0-1-1H4zm9 6H6v2h7V7zm0 3H6v2h7v-2zm0 3H6v2h6a1 1 0 0 0 1-1v-1zm-8 2v-2H3v1a1 1 0 0 0 1 1h1zm-2-3h2v-2H3v2zm0-3h2V7H3v2z\"}}]})(props);\n};\nexport function BsFileSlidesFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7.78V5.22c0-.096.106-.156.19-.106l2.13 1.279a.125.125 0 0 1 0 .214l-2.13 1.28A.125.125 0 0 1 7 7.778z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM5 4h6a.5.5 0 0 1 .496.438l.5 4A.5.5 0 0 1 11.5 9h-3v2.016c.863.055 1.5.251 1.5.484 0 .276-.895.5-2 .5s-2-.224-2-.5c0-.233.637-.429 1.5-.484V9h-3a.5.5 0 0 1-.496-.562l.5-4A.5.5 0 0 1 5 4z\"}}]})(props);\n};\nexport function BsFileSlides (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4a.5.5 0 0 0-.496.438l-.5 4A.5.5 0 0 0 4.5 9h3v2.016c-.863.055-1.5.251-1.5.484 0 .276.895.5 2 .5s2-.224 2-.5c0-.233-.637-.429-1.5-.484V9h3a.5.5 0 0 0 .496-.562l-.5-4A.5.5 0 0 0 11 4H5zm2 3.78V5.22c0-.096.106-.156.19-.106l2.13 1.279a.125.125 0 0 1 0 .214l-2.13 1.28A.125.125 0 0 1 7 7.778z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm10-1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1z\"}}]})(props);\n};\nexport function BsFileSpreadsheetFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v4h12V2a2 2 0 0 0-2-2zm2 7h-4v2h4V7zm0 3h-4v2h4v-2zm0 3h-4v3h2a2 2 0 0 0 2-2v-1zm-5 3v-3H6v3h3zm-4 0v-3H2v1a2 2 0 0 0 2 2h1zm-3-4h3v-2H2v2zm0-3h3V7H2v2zm4 0V7h3v2H6zm0 1h3v2H6v-2z\"}}]})(props);\n};\nexport function BsFileSpreadsheet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm2-1a1 1 0 0 0-1 1v4h10V2a1 1 0 0 0-1-1H4zm9 6h-3v2h3V7zm0 3h-3v2h3v-2zm0 3h-3v2h2a1 1 0 0 0 1-1v-1zm-4 2v-2H6v2h3zm-4 0v-2H3v1a1 1 0 0 0 1 1h1zm-2-3h2v-2H3v2zm0-3h2V7H3v2zm3-2v2h3V7H6zm3 3H6v2h3v-2z\"}}]})(props);\n};\nexport function BsFileTextFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM5 4h6a.5.5 0 0 1 0 1H5a.5.5 0 0 1 0-1zm-.5 2.5A.5.5 0 0 1 5 6h6a.5.5 0 0 1 0 1H5a.5.5 0 0 1-.5-.5zM5 8h6a.5.5 0 0 1 0 1H5a.5.5 0 0 1 0-1zm0 2h3a.5.5 0 0 1 0 1H5a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsFileText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4a.5.5 0 0 0 0 1h6a.5.5 0 0 0 0-1H5zm-.5 2.5A.5.5 0 0 1 5 6h6a.5.5 0 0 1 0 1H5a.5.5 0 0 1-.5-.5zM5 8a.5.5 0 0 0 0 1h6a.5.5 0 0 0 0-1H5zm0 2a.5.5 0 0 0 0 1h3a.5.5 0 0 0 0-1H5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm10-1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1z\"}}]})(props);\n};\nexport function BsFileWordFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM5.485 4.879l1.036 4.144.997-3.655a.5.5 0 0 1 .964 0l.997 3.655 1.036-4.144a.5.5 0 0 1 .97.242l-1.5 6a.5.5 0 0 1-.967.01L8 7.402l-1.018 3.73a.5.5 0 0 1-.967-.01l-1.5-6a.5.5 0 1 1 .97-.242z\"}}]})(props);\n};\nexport function BsFileWord (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.879 4.515a.5.5 0 0 1 .606.364l1.036 4.144.997-3.655a.5.5 0 0 1 .964 0l.997 3.655 1.036-4.144a.5.5 0 0 1 .97.242l-1.5 6a.5.5 0 0 1-.967.01L8 7.402l-1.018 3.73a.5.5 0 0 1-.967-.01l-1.5-6a.5.5 0 0 1 .364-.606z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm0 1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFileXFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM6.854 6.146 8 7.293l1.146-1.147a.5.5 0 1 1 .708.708L8.707 8l1.147 1.146a.5.5 0 0 1-.708.708L8 8.707 6.854 9.854a.5.5 0 0 1-.708-.708L7.293 8 6.146 6.854a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsFileX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.146 6.146a.5.5 0 0 1 .708 0L8 7.293l1.146-1.147a.5.5 0 1 1 .708.708L8.707 8l1.147 1.146a.5.5 0 0 1-.708.708L8 8.707 6.854 9.854a.5.5 0 0 1-.708-.708L7.293 8 6.146 6.854a.5.5 0 0 1 0-.708z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm0 1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFileZipFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 9.438V8.5h-1v.938a1 1 0 0 1-.03.243l-.4 1.598.93.62.93-.62-.4-1.598a1 1 0 0 1-.03-.243z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2zm2.5 8.5v.938l-.4 1.599a1 1 0 0 0 .416 1.074l.93.62a1 1 0 0 0 1.109 0l.93-.62a1 1 0 0 0 .415-1.074l-.4-1.599V8.5a1 1 0 0 0-1-1h-1a1 1 0 0 0-1 1zm1-5.5h-1v1h1v1h-1v1h1v1H9V6H8V5h1V4H8V3h1V2H8V1H6.5v1h1v1z\"}}]})(props);\n};\nexport function BsFileZip (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 7.5a1 1 0 0 1 1-1h1a1 1 0 0 1 1 1v.938l.4 1.599a1 1 0 0 1-.416 1.074l-.93.62a1 1 0 0 1-1.109 0l-.93-.62a1 1 0 0 1-.415-1.074l.4-1.599V7.5zm2 0h-1v.938a1 1 0 0 1-.03.243l-.4 1.598.93.62.93-.62-.4-1.598a1 1 0 0 1-.03-.243V7.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm5.5-1H4a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H9v1H8v1h1v1H8v1h1v1H7.5V5h-1V4h1V3h-1V2h1V1z\"}}]})(props);\n};\nexport function BsFile (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm0 1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsFilesAlt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 0H3a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2 2 2 0 0 0 2-2V4a2 2 0 0 0-2-2 2 2 0 0 0-2-2zm2 3a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1V3zM2 2a1 1 0 0 1 1-1h8a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V2z\"}}]})(props);\n};\nexport function BsFiles (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13 0H6a2 2 0 0 0-2 2 2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h7a2 2 0 0 0 2-2 2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zm0 13V4a2 2 0 0 0-2-2H5a1 1 0 0 1 1-1h7a1 1 0 0 1 1 1v10a1 1 0 0 1-1 1zM3 4a1 1 0 0 1 1-1h7a1 1 0 0 1 1 1v10a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V4z\"}}]})(props);\n};\nexport function BsFilm (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1a1 1 0 0 1 1-1h14a1 1 0 0 1 1 1v14a1 1 0 0 1-1 1H1a1 1 0 0 1-1-1V1zm4 0v6h8V1H4zm8 8H4v6h8V9zM1 1v2h2V1H1zm2 3H1v2h2V4zM1 7v2h2V7H1zm2 3H1v2h2v-2zm-2 3v2h2v-2H1zM15 1h-2v2h2V1zm-2 3v2h2V4h-2zm2 3h-2v2h2V7zm-2 3v2h2v-2h-2zm2 3h-2v2h2v-2z\"}}]})(props);\n};\nexport function BsFilterCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zM3.5 5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1 0-1zM5 8.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm2 3a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 0 1h-1a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFilterCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7 11.5a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 0 1h-1a.5.5 0 0 1-.5-.5zm-2-3a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm-2-3a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFilterLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 10.5a.5.5 0 0 1 .5-.5h3a.5.5 0 0 1 0 1h-3a.5.5 0 0 1-.5-.5zm0-3a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm0-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFilterRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10.5a.5.5 0 0 0-.5-.5h-3a.5.5 0 0 0 0 1h3a.5.5 0 0 0 .5-.5zm0-3a.5.5 0 0 0-.5-.5h-7a.5.5 0 0 0 0 1h7a.5.5 0 0 0 .5-.5zm0-3a.5.5 0 0 0-.5-.5h-11a.5.5 0 0 0 0 1h11a.5.5 0 0 0 .5-.5z\"}}]})(props);\n};\nexport function BsFilterSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm.5 5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1 0-1zM4 8.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm2 3a.5.5 0 0 1 .5-.5h3a.5.5 0 0 1 0 1h-3a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFilterSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 11.5a.5.5 0 0 1 .5-.5h3a.5.5 0 0 1 0 1h-3a.5.5 0 0 1-.5-.5zm-2-3a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm-2-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFilter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 10.5a.5.5 0 0 1 .5-.5h3a.5.5 0 0 1 0 1h-3a.5.5 0 0 1-.5-.5zm-2-3a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm-2-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFlagFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14.778.085A.5.5 0 0 1 15 .5V8a.5.5 0 0 1-.314.464L14.5 8l.186.464-.003.001-.006.003-.023.009a12.435 12.435 0 0 1-.397.15c-.264.095-.631.223-1.047.35-.816.252-1.879.523-2.71.523-.847 0-1.548-.28-2.158-.525l-.028-.01C7.68 8.71 7.14 8.5 6.5 8.5c-.7 0-1.638.23-2.437.477A19.626 19.626 0 0 0 3 9.342V15.5a.5.5 0 0 1-1 0V.5a.5.5 0 0 1 1 0v.282c.226-.079.496-.17.79-.26C4.606.272 5.67 0 6.5 0c.84 0 1.524.277 2.121.519l.043.018C9.286.788 9.828 1 10.5 1c.7 0 1.638-.23 2.437-.477a19.587 19.587 0 0 0 1.349-.476l.019-.007.004-.002h.001\"}}]})(props);\n};\nexport function BsFlag (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14.778.085A.5.5 0 0 1 15 .5V8a.5.5 0 0 1-.314.464L14.5 8l.186.464-.003.001-.006.003-.023.009a12.435 12.435 0 0 1-.397.15c-.264.095-.631.223-1.047.35-.816.252-1.879.523-2.71.523-.847 0-1.548-.28-2.158-.525l-.028-.01C7.68 8.71 7.14 8.5 6.5 8.5c-.7 0-1.638.23-2.437.477A19.626 19.626 0 0 0 3 9.342V15.5a.5.5 0 0 1-1 0V.5a.5.5 0 0 1 1 0v.282c.226-.079.496-.17.79-.26C4.606.272 5.67 0 6.5 0c.84 0 1.524.277 2.121.519l.043.018C9.286.788 9.828 1 10.5 1c.7 0 1.638-.23 2.437-.477a19.587 19.587 0 0 0 1.349-.476l.019-.007.004-.002h.001M14 1.221c-.22.078-.48.167-.766.255-.81.252-1.872.523-2.734.523-.886 0-1.592-.286-2.203-.534l-.008-.003C7.662 1.21 7.139 1 6.5 1c-.669 0-1.606.229-2.415.478A21.294 21.294 0 0 0 3 1.845v6.433c.22-.078.48-.167.766-.255C4.576 7.77 5.638 7.5 6.5 7.5c.847 0 1.548.28 2.158.525l.028.01C9.32 8.29 9.86 8.5 10.5 8.5c.668 0 1.606-.229 2.415-.478A21.317 21.317 0 0 0 14 7.655V1.222z\"}}]})(props);\n};\nexport function BsFlower1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.174 1.184a2 2 0 0 1 3.652 0A2 2 0 0 1 12.99 3.01a2 2 0 0 1 1.826 3.164 2 2 0 0 1 0 3.652 2 2 0 0 1-1.826 3.164 2 2 0 0 1-3.164 1.826 2 2 0 0 1-3.652 0A2 2 0 0 1 3.01 12.99a2 2 0 0 1-1.826-3.164 2 2 0 0 1 0-3.652A2 2 0 0 1 3.01 3.01a2 2 0 0 1 3.164-1.826zM8 1a1 1 0 0 0-.998 1.03l.01.091c.012.077.029.176.054.296.049.241.122.542.213.887.182.688.428 1.513.676 2.314L8 5.762l.045-.144c.248-.8.494-1.626.676-2.314.091-.345.164-.646.213-.887a4.997 4.997 0 0 0 .064-.386L9 2a1 1 0 0 0-1-1zM2 9l.03-.002.091-.01a4.99 4.99 0 0 0 .296-.054c.241-.049.542-.122.887-.213a60.59 60.59 0 0 0 2.314-.676L5.762 8l-.144-.045a60.59 60.59 0 0 0-2.314-.676 16.705 16.705 0 0 0-.887-.213 4.99 4.99 0 0 0-.386-.064L2 7a1 1 0 1 0 0 2zm7 5-.002-.03a5.005 5.005 0 0 0-.064-.386 16.398 16.398 0 0 0-.213-.888 60.582 60.582 0 0 0-.676-2.314L8 10.238l-.045.144c-.248.8-.494 1.626-.676 2.314-.091.345-.164.646-.213.887a4.996 4.996 0 0 0-.064.386L7 14a1 1 0 1 0 2 0zm-5.696-2.134.025-.017a5.001 5.001 0 0 0 .303-.248c.184-.164.408-.377.661-.629A60.614 60.614 0 0 0 5.96 9.23l.103-.111-.147.033a60.88 60.88 0 0 0-2.343.572c-.344.093-.64.18-.874.258a5.063 5.063 0 0 0-.367.138l-.027.014a1 1 0 1 0 1 1.732zM4.5 14.062a1 1 0 0 0 1.366-.366l.014-.027c.01-.02.021-.048.036-.084a5.09 5.09 0 0 0 .102-.283c.078-.233.165-.53.258-.874a60.6 60.6 0 0 0 .572-2.343l.033-.147-.11.102a60.848 60.848 0 0 0-1.743 1.667 17.07 17.07 0 0 0-.629.66 5.06 5.06 0 0 0-.248.304l-.017.025a1 1 0 0 0 .366 1.366zm9.196-8.196a1 1 0 0 0-1-1.732l-.025.017a4.951 4.951 0 0 0-.303.248 16.69 16.69 0 0 0-.661.629A60.72 60.72 0 0 0 10.04 6.77l-.102.111.147-.033a60.6 60.6 0 0 0 2.342-.572c.345-.093.642-.18.875-.258a4.993 4.993 0 0 0 .367-.138.53.53 0 0 0 .027-.014zM11.5 1.938a1 1 0 0 0-1.366.366l-.014.027c-.01.02-.021.048-.036.084a5.09 5.09 0 0 0-.102.283c-.078.233-.165.53-.258.875a60.62 60.62 0 0 0-.572 2.342l-.033.147.11-.102a60.848 60.848 0 0 0 1.743-1.667c.252-.253.465-.477.629-.66a5.001 5.001 0 0 0 .248-.304l.017-.025a1 1 0 0 0-.366-1.366zM14 9a1 1 0 0 0 0-2l-.03.002a4.996 4.996 0 0 0-.386.064c-.242.049-.543.122-.888.213-.688.182-1.513.428-2.314.676L10.238 8l.144.045c.8.248 1.626.494 2.314.676.345.091.646.164.887.213a4.996 4.996 0 0 0 .386.064L14 9zM1.938 4.5a1 1 0 0 0 .393 1.38l.084.035c.072.03.166.064.283.103.233.078.53.165.874.258a60.88 60.88 0 0 0 2.343.572l.147.033-.103-.111a60.584 60.584 0 0 0-1.666-1.742 16.705 16.705 0 0 0-.66-.629 4.996 4.996 0 0 0-.304-.248l-.025-.017a1 1 0 0 0-1.366.366zm2.196-1.196.017.025a4.996 4.996 0 0 0 .248.303c.164.184.377.408.629.661A60.597 60.597 0 0 0 6.77 5.96l.111.102-.033-.147a60.602 60.602 0 0 0-.572-2.342c-.093-.345-.18-.642-.258-.875a5.006 5.006 0 0 0-.138-.367l-.014-.027a1 1 0 1 0-1.732 1zm9.928 8.196a1 1 0 0 0-.366-1.366l-.027-.014a5 5 0 0 0-.367-.138c-.233-.078-.53-.165-.875-.258a60.619 60.619 0 0 0-2.342-.572l-.147-.033.102.111a60.73 60.73 0 0 0 1.667 1.742c.253.252.477.465.66.629a4.946 4.946 0 0 0 .304.248l.025.017a1 1 0 0 0 1.366-.366zm-3.928 2.196a1 1 0 0 0 1.732-1l-.017-.025a5.065 5.065 0 0 0-.248-.303 16.705 16.705 0 0 0-.629-.661A60.462 60.462 0 0 0 9.23 10.04l-.111-.102.033.147a60.6 60.6 0 0 0 .572 2.342c.093.345.18.642.258.875a4.985 4.985 0 0 0 .138.367.575.575 0 0 0 .014.027zM8 9.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3z\"}}]})(props);\n};\nexport function BsFlower2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16a4 4 0 0 0 4-4 4 4 0 0 0 0-8 4 4 0 0 0-8 0 4 4 0 1 0 0 8 4 4 0 0 0 4 4zm3-12c0 .073-.01.155-.03.247-.544.241-1.091.638-1.598 1.084A2.987 2.987 0 0 0 8 5c-.494 0-.96.12-1.372.331-.507-.446-1.054-.843-1.597-1.084A1.117 1.117 0 0 1 5 4a3 3 0 0 1 6 0zm-.812 6.052A2.99 2.99 0 0 0 11 8a2.99 2.99 0 0 0-.812-2.052c.215-.18.432-.346.647-.487C11.34 5.131 11.732 5 12 5a3 3 0 1 1 0 6c-.268 0-.66-.13-1.165-.461a6.833 6.833 0 0 1-.647-.487zm-3.56.617a3.001 3.001 0 0 0 2.744 0c.507.446 1.054.842 1.598 1.084.02.091.03.174.03.247a3 3 0 1 1-6 0c0-.073.01-.155.03-.247.544-.242 1.091-.638 1.598-1.084zm-.816-4.721A2.99 2.99 0 0 0 5 8c0 .794.308 1.516.812 2.052a6.83 6.83 0 0 1-.647.487C4.66 10.869 4.268 11 4 11a3 3 0 0 1 0-6c.268 0 .66.13 1.165.461.215.141.432.306.647.487zM8 9a1 1 0 1 1 0-2 1 1 0 0 1 0 2z\"}}]})(props);\n};\nexport function BsFlower3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.424 8c.437-.052.811-.136 1.04-.268a2 2 0 0 0-2-3.464c-.229.132-.489.414-.752.767C9.886 4.63 10 4.264 10 4a2 2 0 1 0-4 0c0 .264.114.63.288 1.035-.263-.353-.523-.635-.752-.767a2 2 0 0 0-2 3.464c.229.132.603.216 1.04.268-.437.052-.811.136-1.04.268a2 2 0 1 0 2 3.464c.229-.132.489-.414.752-.767C6.114 11.37 6 11.736 6 12a2 2 0 1 0 4 0c0-.264-.114-.63-.288-1.035.263.353.523.635.752.767a2 2 0 1 0 2-3.464c-.229-.132-.603-.216-1.04-.268zM9 4a1.468 1.468 0 0 1-.045.205c-.039.132-.1.295-.183.484a12.88 12.88 0 0 1-.637 1.223L8 6.142a21.73 21.73 0 0 1-.135-.23 12.88 12.88 0 0 1-.637-1.223 4.216 4.216 0 0 1-.183-.484A1.473 1.473 0 0 1 7 4a1 1 0 1 1 2 0zM3.67 5.5a1 1 0 0 1 1.366-.366 1.472 1.472 0 0 1 .156.142c.094.1.204.233.326.4.245.333.502.747.742 1.163l.13.232a21.86 21.86 0 0 1-.265.002 12.88 12.88 0 0 1-1.379-.06 4.214 4.214 0 0 1-.51-.083 1.47 1.47 0 0 1-.2-.064A1 1 0 0 1 3.67 5.5zm1.366 5.366a1 1 0 0 1-1-1.732c.001 0 .016-.008.047-.02.037-.013.087-.028.153-.044.134-.032.305-.06.51-.083a12.88 12.88 0 0 1 1.379-.06c.09 0 .178 0 .266.002a21.82 21.82 0 0 1-.131.232c-.24.416-.497.83-.742 1.163a4.1 4.1 0 0 1-.327.4 1.483 1.483 0 0 1-.155.142zM9 12a1 1 0 0 1-2 0 1.476 1.476 0 0 1 .045-.206c.039-.131.1-.294.183-.483.166-.378.396-.808.637-1.223L8 9.858l.135.23c.241.415.47.845.637 1.223.083.19.144.352.183.484A1.338 1.338 0 0 1 9 12zm3.33-6.5a1 1 0 0 1-.366 1.366 1.478 1.478 0 0 1-.2.064c-.134.032-.305.06-.51.083-.412.045-.898.061-1.379.06-.09 0-.178 0-.266-.002l.131-.232c.24-.416.497-.83.742-1.163a4.1 4.1 0 0 1 .327-.4c.046-.05.085-.086.114-.11.026-.022.04-.03.041-.032a1 1 0 0 1 1.366.366zm-1.366 5.366a1.494 1.494 0 0 1-.155-.141 4.225 4.225 0 0 1-.327-.4A12.88 12.88 0 0 1 9.74 9.16a22 22 0 0 1-.13-.232l.265-.002c.48-.001.967.015 1.379.06.205.023.376.051.51.083.066.016.116.031.153.044l.048.02a1 1 0 1 1-1 1.732zM8 9a1 1 0 1 1 0-2 1 1 0 0 1 0 2z\"}}]})(props);\n};\nexport function BsFolderCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m.5 3 .04.87a1.99 1.99 0 0 0-.342 1.311l.637 7A2 2 0 0 0 2.826 14H9v-1H2.826a1 1 0 0 1-.995-.91l-.637-7A1 1 0 0 1 2.19 4h11.62a1 1 0 0 1 .996 1.09L14.54 8h1.005l.256-2.819A2 2 0 0 0 13.81 3H9.828a2 2 0 0 1-1.414-.586l-.828-.828A2 2 0 0 0 6.172 1H2.5a2 2 0 0 0-2 2zm5.672-1a1 1 0 0 1 .707.293L7.586 3H2.19c-.24 0-.47.042-.683.12L1.5 2.98a1 1 0 0 1 1-.98h3.672z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M15.854 10.146a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.707 0l-1.5-1.5a.5.5 0 0 1 .707-.708l1.146 1.147 2.646-2.647a.5.5 0 0 1 .708 0z\"}}]})(props);\n};\nexport function BsFolderFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.828 3h3.982a2 2 0 0 1 1.992 2.181l-.637 7A2 2 0 0 1 13.174 14H2.825a2 2 0 0 1-1.991-1.819l-.637-7a1.99 1.99 0 0 1 .342-1.31L.5 3a2 2 0 0 1 2-2h3.672a2 2 0 0 1 1.414.586l.828.828A2 2 0 0 0 9.828 3zm-8.322.12C1.72 3.042 1.95 3 2.19 3h5.396l-.707-.707A1 1 0 0 0 6.172 2H2.5a1 1 0 0 0-1 .981l.006.139z\"}}]})(props);\n};\nexport function BsFolderMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m.5 3 .04.87a1.99 1.99 0 0 0-.342 1.311l.637 7A2 2 0 0 0 2.826 14H9v-1H2.826a1 1 0 0 1-.995-.91l-.637-7A1 1 0 0 1 2.19 4h11.62a1 1 0 0 1 .996 1.09L14.54 8h1.005l.256-2.819A2 2 0 0 0 13.81 3H9.828a2 2 0 0 1-1.414-.586l-.828-.828A2 2 0 0 0 6.172 1H2.5a2 2 0 0 0-2 2zm5.672-1a1 1 0 0 1 .707.293L7.586 3H2.19c-.24 0-.47.042-.683.12L1.5 2.98a1 1 0 0 1 1-.98h3.672z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 11.5a.5.5 0 0 1 .5-.5h4a.5.5 0 1 1 0 1h-4a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsFolderPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m.5 3 .04.87a1.99 1.99 0 0 0-.342 1.311l.637 7A2 2 0 0 0 2.826 14H9v-1H2.826a1 1 0 0 1-.995-.91l-.637-7A1 1 0 0 1 2.19 4h11.62a1 1 0 0 1 .996 1.09L14.54 8h1.005l.256-2.819A2 2 0 0 0 13.81 3H9.828a2 2 0 0 1-1.414-.586l-.828-.828A2 2 0 0 0 6.172 1H2.5a2 2 0 0 0-2 2zm5.672-1a1 1 0 0 1 .707.293L7.586 3H2.19c-.24 0-.47.042-.683.12L1.5 2.98a1 1 0 0 1 1-.98h3.672z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 10a.5.5 0 0 1 .5.5V12h1.5a.5.5 0 1 1 0 1H14v1.5a.5.5 0 1 1-1 0V13h-1.5a.5.5 0 0 1 0-1H13v-1.5a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsFolderSymlinkFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.81 3H9.828a2 2 0 0 1-1.414-.586l-.828-.828A2 2 0 0 0 6.172 1H2.5a2 2 0 0 0-2 2l.04.87a1.99 1.99 0 0 0-.342 1.311l.637 7A2 2 0 0 0 2.826 14h10.348a2 2 0 0 0 1.991-1.819l.637-7A2 2 0 0 0 13.81 3zM2.19 3c-.24 0-.47.042-.683.12L1.5 2.98a1 1 0 0 1 1-.98h3.672a1 1 0 0 1 .707.293L7.586 3H2.19zm9.608 5.271-3.182 1.97c-.27.166-.616-.036-.616-.372V9.1s-2.571-.3-4 2.4c.571-4.8 3.143-4.8 4-4.8v-.769c0-.336.346-.538.616-.371l3.182 1.969c.27.166.27.576 0 .742z\"}}]})(props);\n};\nexport function BsFolderSymlink (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m11.798 8.271-3.182 1.97c-.27.166-.616-.036-.616-.372V9.1s-2.571-.3-4 2.4c.571-4.8 3.143-4.8 4-4.8v-.769c0-.336.346-.538.616-.371l3.182 1.969c.27.166.27.576 0 .742z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m.5 3 .04.87a1.99 1.99 0 0 0-.342 1.311l.637 7A2 2 0 0 0 2.826 14h10.348a2 2 0 0 0 1.991-1.819l.637-7A2 2 0 0 0 13.81 3H9.828a2 2 0 0 1-1.414-.586l-.828-.828A2 2 0 0 0 6.172 1H2.5a2 2 0 0 0-2 2zm.694 2.09A1 1 0 0 1 2.19 4h11.62a1 1 0 0 1 .996 1.09l-.636 7a1 1 0 0 1-.996.91H2.826a1 1 0 0 1-.995-.91l-.637-7zM6.172 2a1 1 0 0 1 .707.293L7.586 3H2.19c-.24 0-.47.042-.683.12L1.5 2.98a1 1 0 0 1 1-.98h3.672z\"}}]})(props);\n};\nexport function BsFolderX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.54 3.87.5 3a2 2 0 0 1 2-2h3.672a2 2 0 0 1 1.414.586l.828.828A2 2 0 0 0 9.828 3h3.982a2 2 0 0 1 1.992 2.181L15.546 8H14.54l.265-2.91A1 1 0 0 0 13.81 4H2.19a1 1 0 0 0-.996 1.09l.637 7a1 1 0 0 0 .995.91H9v1H2.826a2 2 0 0 1-1.991-1.819l-.637-7a1.99 1.99 0 0 1 .342-1.31zm6.339-1.577A1 1 0 0 0 6.172 2H2.5a1 1 0 0 0-1 .981l.006.139C1.72 3.042 1.95 3 2.19 3h5.396l-.707-.707z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.854 10.146a.5.5 0 0 0-.707.708L12.293 12l-1.146 1.146a.5.5 0 0 0 .707.708L13 12.707l1.146 1.147a.5.5 0 0 0 .708-.708L13.707 12l1.147-1.146a.5.5 0 0 0-.707-.708L13 11.293l-1.146-1.147z\"}}]})(props);\n};\nexport function BsFolder (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.54 3.87.5 3a2 2 0 0 1 2-2h3.672a2 2 0 0 1 1.414.586l.828.828A2 2 0 0 0 9.828 3h3.982a2 2 0 0 1 1.992 2.181l-.637 7A2 2 0 0 1 13.174 14H2.826a2 2 0 0 1-1.991-1.819l-.637-7a1.99 1.99 0 0 1 .342-1.31zM2.19 4a1 1 0 0 0-.996 1.09l.637 7a1 1 0 0 0 .995.91h10.348a1 1 0 0 0 .995-.91l.637-7A1 1 0 0 0 13.81 4H2.19zm4.69-1.707A1 1 0 0 0 6.172 2H2.5a1 1 0 0 0-1 .981l.006.139C1.72 3.042 1.95 3 2.19 3h5.396l-.707-.707z\"}}]})(props);\n};\nexport function BsFolder2Open (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 3.5A1.5 1.5 0 0 1 2.5 2h2.764c.958 0 1.76.56 2.311 1.184C7.985 3.648 8.48 4 9 4h4.5A1.5 1.5 0 0 1 15 5.5v.64c.57.265.94.876.856 1.546l-.64 5.124A2.5 2.5 0 0 1 12.733 15H3.266a2.5 2.5 0 0 1-2.481-2.19l-.64-5.124A1.5 1.5 0 0 1 1 6.14V3.5zM2 6h12v-.5a.5.5 0 0 0-.5-.5H9c-.964 0-1.71-.629-2.174-1.154C6.374 3.334 5.82 3 5.264 3H2.5a.5.5 0 0 0-.5.5V6zm-.367 1a.5.5 0 0 0-.496.562l.64 5.124A1.5 1.5 0 0 0 3.266 14h9.468a1.5 1.5 0 0 0 1.489-1.314l.64-5.124A.5.5 0 0 0 14.367 7H1.633z\"}}]})(props);\n};\nexport function BsFolder2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 3.5A1.5 1.5 0 0 1 2.5 2h2.764c.958 0 1.76.56 2.311 1.184C7.985 3.648 8.48 4 9 4h4.5A1.5 1.5 0 0 1 15 5.5v7a1.5 1.5 0 0 1-1.5 1.5h-11A1.5 1.5 0 0 1 1 12.5v-9zM2.5 3a.5.5 0 0 0-.5.5V6h12v-.5a.5.5 0 0 0-.5-.5H9c-.964 0-1.71-.629-2.174-1.154C6.374 3.334 5.82 3 5.264 3H2.5zM14 7H2v5.5a.5.5 0 0 0 .5.5h11a.5.5 0 0 0 .5-.5V7z\"}}]})(props);\n};\nexport function BsFonts (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.258 3h-8.51l-.083 2.46h.479c.26-1.544.758-1.783 2.693-1.845l.424-.013v7.827c0 .663-.144.82-1.3.923v.52h4.082v-.52c-1.162-.103-1.306-.26-1.306-.923V3.602l.431.013c1.934.062 2.434.301 2.693 1.846h.479L12.258 3z\"}}]})(props);\n};\nexport function BsForwardFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m9.77 12.11 4.012-2.953a.647.647 0 0 0 0-1.114L9.771 5.09a.644.644 0 0 0-.971.557V6.65H2v3.9h6.8v1.003c0 .505.545.808.97.557z\"}}]})(props);\n};\nexport function BsForward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.502 5.513a.144.144 0 0 0-.202.134V6.65a.5.5 0 0 1-.5.5H2.5v2.9h6.3a.5.5 0 0 1 .5.5v1.003c0 .108.11.176.202.134l3.984-2.933a.51.51 0 0 1 .042-.028.147.147 0 0 0 0-.252.51.51 0 0 1-.042-.028L9.502 5.513zM8.3 5.647a1.144 1.144 0 0 1 1.767-.96l3.994 2.94a1.147 1.147 0 0 1 0 1.946l-3.994 2.94a1.144 1.144 0 0 1-1.767-.96v-.503H2a.5.5 0 0 1-.5-.5v-3.9a.5.5 0 0 1 .5-.5h6.3v-.503z\"}}]})(props);\n};\nexport function BsFront (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v2h2a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2v-2H2a2 2 0 0 1-2-2V2zm5 10v2a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V6a1 1 0 0 0-1-1h-2v5a2 2 0 0 1-2 2H5z\"}}]})(props);\n};\nexport function BsFullscreenExit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 0a.5.5 0 0 1 .5.5v4A1.5 1.5 0 0 1 4.5 6h-4a.5.5 0 0 1 0-1h4a.5.5 0 0 0 .5-.5v-4a.5.5 0 0 1 .5-.5zm5 0a.5.5 0 0 1 .5.5v4a.5.5 0 0 0 .5.5h4a.5.5 0 0 1 0 1h-4A1.5 1.5 0 0 1 10 4.5v-4a.5.5 0 0 1 .5-.5zM0 10.5a.5.5 0 0 1 .5-.5h4A1.5 1.5 0 0 1 6 11.5v4a.5.5 0 0 1-1 0v-4a.5.5 0 0 0-.5-.5h-4a.5.5 0 0 1-.5-.5zm10 1a1.5 1.5 0 0 1 1.5-1.5h4a.5.5 0 0 1 0 1h-4a.5.5 0 0 0-.5.5v4a.5.5 0 0 1-1 0v-4z\"}}]})(props);\n};\nexport function BsFullscreen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 1a.5.5 0 0 0-.5.5v4a.5.5 0 0 1-1 0v-4A1.5 1.5 0 0 1 1.5 0h4a.5.5 0 0 1 0 1h-4zM10 .5a.5.5 0 0 1 .5-.5h4A1.5 1.5 0 0 1 16 1.5v4a.5.5 0 0 1-1 0v-4a.5.5 0 0 0-.5-.5h-4a.5.5 0 0 1-.5-.5zM.5 10a.5.5 0 0 1 .5.5v4a.5.5 0 0 0 .5.5h4a.5.5 0 0 1 0 1h-4A1.5 1.5 0 0 1 0 14.5v-4a.5.5 0 0 1 .5-.5zm15 0a.5.5 0 0 1 .5.5v4a1.5 1.5 0 0 1-1.5 1.5h-4a.5.5 0 0 1 0-1h4a.5.5 0 0 0 .5-.5v-4a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsFunnelFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 1.5A.5.5 0 0 1 2 1h12a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.128.334L10 8.692V13.5a.5.5 0 0 1-.342.474l-3 1A.5.5 0 0 1 6 14.5V8.692L1.628 3.834A.5.5 0 0 1 1.5 3.5v-2z\"}}]})(props);\n};\nexport function BsFunnel (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 1.5A.5.5 0 0 1 2 1h12a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.128.334L10 8.692V13.5a.5.5 0 0 1-.342.474l-3 1A.5.5 0 0 1 6 14.5V8.692L1.628 3.834A.5.5 0 0 1 1.5 3.5v-2zm1 .5v1.308l4.372 4.858A.5.5 0 0 1 7 8.5v5.306l2-.666V8.5a.5.5 0 0 1 .128-.334L13.5 3.308V2h-11z\"}}]})(props);\n};\nexport function BsGearFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.405 1.05c-.413-1.4-2.397-1.4-2.81 0l-.1.34a1.464 1.464 0 0 1-2.105.872l-.31-.17c-1.283-.698-2.686.705-1.987 1.987l.169.311c.446.82.023 1.841-.872 2.105l-.34.1c-1.4.413-1.4 2.397 0 2.81l.34.1a1.464 1.464 0 0 1 .872 2.105l-.17.31c-.698 1.283.705 2.686 1.987 1.987l.311-.169a1.464 1.464 0 0 1 2.105.872l.1.34c.413 1.4 2.397 1.4 2.81 0l.1-.34a1.464 1.464 0 0 1 2.105-.872l.31.17c1.283.698 2.686-.705 1.987-1.987l-.169-.311a1.464 1.464 0 0 1 .872-2.105l.34-.1c1.4-.413 1.4-2.397 0-2.81l-.34-.1a1.464 1.464 0 0 1-.872-2.105l.17-.31c.698-1.283-.705-2.686-1.987-1.987l-.311.169a1.464 1.464 0 0 1-2.105-.872l-.1-.34zM8 10.93a2.929 2.929 0 1 1 0-5.86 2.929 2.929 0 0 1 0 5.858z\"}}]})(props);\n};\nexport function BsGearWideConnected (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.068.727c.243-.97 1.62-.97 1.864 0l.071.286a.96.96 0 0 0 1.622.434l.205-.211c.695-.719 1.888-.03 1.613.931l-.08.284a.96.96 0 0 0 1.187 1.187l.283-.081c.96-.275 1.65.918.931 1.613l-.211.205a.96.96 0 0 0 .434 1.622l.286.071c.97.243.97 1.62 0 1.864l-.286.071a.96.96 0 0 0-.434 1.622l.211.205c.719.695.03 1.888-.931 1.613l-.284-.08a.96.96 0 0 0-1.187 1.187l.081.283c.275.96-.918 1.65-1.613.931l-.205-.211a.96.96 0 0 0-1.622.434l-.071.286c-.243.97-1.62.97-1.864 0l-.071-.286a.96.96 0 0 0-1.622-.434l-.205.211c-.695.719-1.888.03-1.613-.931l.08-.284a.96.96 0 0 0-1.186-1.187l-.284.081c-.96.275-1.65-.918-.931-1.613l.211-.205a.96.96 0 0 0-.434-1.622l-.286-.071c-.97-.243-.97-1.62 0-1.864l.286-.071a.96.96 0 0 0 .434-1.622l-.211-.205c-.719-.695-.03-1.888.931-1.613l.284.08a.96.96 0 0 0 1.187-1.186l-.081-.284c-.275-.96.918-1.65 1.613-.931l.205.211a.96.96 0 0 0 1.622-.434l.071-.286zM12.973 8.5H8.25l-2.834 3.779A4.998 4.998 0 0 0 12.973 8.5zm0-1a4.998 4.998 0 0 0-7.557-3.779l2.834 3.78h4.723zM5.048 3.967c-.03.021-.058.043-.087.065l.087-.065zm-.431.355A4.984 4.984 0 0 0 3.002 8c0 1.455.622 2.765 1.615 3.678L7.375 8 4.617 4.322zm.344 7.646.087.065-.087-.065z\"}}]})(props);\n};\nexport function BsGearWide (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.932.727c-.243-.97-1.62-.97-1.864 0l-.071.286a.96.96 0 0 1-1.622.434l-.205-.211c-.695-.719-1.888-.03-1.613.931l.08.284a.96.96 0 0 1-1.186 1.187l-.284-.081c-.96-.275-1.65.918-.931 1.613l.211.205a.96.96 0 0 1-.434 1.622l-.286.071c-.97.243-.97 1.62 0 1.864l.286.071a.96.96 0 0 1 .434 1.622l-.211.205c-.719.695-.03 1.888.931 1.613l.284-.08a.96.96 0 0 1 1.187 1.187l-.081.283c-.275.96.918 1.65 1.613.931l.205-.211a.96.96 0 0 1 1.622.434l.071.286c.243.97 1.62.97 1.864 0l.071-.286a.96.96 0 0 1 1.622-.434l.205.211c.695.719 1.888.03 1.613-.931l-.08-.284a.96.96 0 0 1 1.187-1.187l.283.081c.96.275 1.65-.918.931-1.613l-.211-.205a.96.96 0 0 1 .434-1.622l.286-.071c.97-.243.97-1.62 0-1.864l-.286-.071a.96.96 0 0 1-.434-1.622l.211-.205c.719-.695.03-1.888-.931-1.613l-.284.08a.96.96 0 0 1-1.187-1.186l.081-.284c.275-.96-.918-1.65-1.613-.931l-.205.211a.96.96 0 0 1-1.622-.434L8.932.727zM8 12.997a4.998 4.998 0 1 1 0-9.995 4.998 4.998 0 0 1 0 9.996z\"}}]})(props);\n};\nexport function BsGear (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4.754a3.246 3.246 0 1 0 0 6.492 3.246 3.246 0 0 0 0-6.492zM5.754 8a2.246 2.246 0 1 1 4.492 0 2.246 2.246 0 0 1-4.492 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.796 1.343c-.527-1.79-3.065-1.79-3.592 0l-.094.319a.873.873 0 0 1-1.255.52l-.292-.16c-1.64-.892-3.433.902-2.54 2.541l.159.292a.873.873 0 0 1-.52 1.255l-.319.094c-1.79.527-1.79 3.065 0 3.592l.319.094a.873.873 0 0 1 .52 1.255l-.16.292c-.892 1.64.901 3.434 2.541 2.54l.292-.159a.873.873 0 0 1 1.255.52l.094.319c.527 1.79 3.065 1.79 3.592 0l.094-.319a.873.873 0 0 1 1.255-.52l.292.16c1.64.893 3.434-.902 2.54-2.541l-.159-.292a.873.873 0 0 1 .52-1.255l.319-.094c1.79-.527 1.79-3.065 0-3.592l-.319-.094a.873.873 0 0 1-.52-1.255l.16-.292c.893-1.64-.902-3.433-2.541-2.54l-.292.159a.873.873 0 0 1-1.255-.52l-.094-.319zm-2.633.283c.246-.835 1.428-.835 1.674 0l.094.319a1.873 1.873 0 0 0 2.693 1.115l.291-.16c.764-.415 1.6.42 1.184 1.185l-.159.292a1.873 1.873 0 0 0 1.116 2.692l.318.094c.835.246.835 1.428 0 1.674l-.319.094a1.873 1.873 0 0 0-1.115 2.693l.16.291c.415.764-.42 1.6-1.185 1.184l-.291-.159a1.873 1.873 0 0 0-2.693 1.116l-.094.318c-.246.835-1.428.835-1.674 0l-.094-.319a1.873 1.873 0 0 0-2.692-1.115l-.292.16c-.764.415-1.6-.42-1.184-1.185l.159-.291A1.873 1.873 0 0 0 1.945 8.93l-.319-.094c-.835-.246-.835-1.428 0-1.674l.319-.094A1.873 1.873 0 0 0 3.06 4.377l-.16-.292c-.415-.764.42-1.6 1.185-1.184l.292.159a1.873 1.873 0 0 0 2.692-1.115l.094-.319z\"}}]})(props);\n};\nexport function BsGem (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.1.7a.5.5 0 0 1 .4-.2h9a.5.5 0 0 1 .4.2l2.976 3.974c.149.185.156.45.01.644L8.4 15.3a.5.5 0 0 1-.8 0L.1 5.3a.5.5 0 0 1 0-.6l3-4zm11.386 3.785-1.806-2.41-.776 2.413 2.582-.003zm-3.633.004.961-2.989H4.186l.963 2.995 5.704-.006zM5.47 5.495 8 13.366l2.532-7.876-5.062.005zm-1.371-.999-.78-2.422-1.818 2.425 2.598-.003zM1.499 5.5l5.113 6.817-2.192-6.82L1.5 5.5zm7.889 6.817 5.123-6.83-2.928.002-2.195 6.828z\"}}]})(props);\n};\nexport function BsGenderAmbiguous (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11.5 1a.5.5 0 0 1 0-1h4a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-1 0V1.707l-3.45 3.45A4 4 0 0 1 8.5 10.97V13H10a.5.5 0 0 1 0 1H8.5v1.5a.5.5 0 0 1-1 0V14H6a.5.5 0 0 1 0-1h1.5v-2.03a4 4 0 1 1 3.471-6.648L14.293 1H11.5zm-.997 4.346a3 3 0 1 0-5.006 3.309 3 3 0 0 0 5.006-3.31z\"}}]})(props);\n};\nexport function BsGenderFemale (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 1a4 4 0 1 0 0 8 4 4 0 0 0 0-8zM3 5a5 5 0 1 1 5.5 4.975V12h2a.5.5 0 0 1 0 1h-2v2.5a.5.5 0 0 1-1 0V13h-2a.5.5 0 0 1 0-1h2V9.975A5 5 0 0 1 3 5z\"}}]})(props);\n};\nexport function BsGenderMale (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M9.5 2a.5.5 0 0 1 0-1h5a.5.5 0 0 1 .5.5v5a.5.5 0 0 1-1 0V2.707L9.871 6.836a5 5 0 1 1-.707-.707L13.293 2H9.5zM6 6a4 4 0 1 0 0 8 4 4 0 0 0 0-8z\"}}]})(props);\n};\nexport function BsGenderTrans (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M0 .5A.5.5 0 0 1 .5 0h3a.5.5 0 0 1 0 1H1.707L3.5 2.793l.646-.647a.5.5 0 1 1 .708.708l-.647.646.822.822A3.99 3.99 0 0 1 8 3c1.18 0 2.239.51 2.971 1.322L14.293 1H11.5a.5.5 0 0 1 0-1h4a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-1 0V1.707l-3.45 3.45A4 4 0 0 1 8.5 10.97V13H10a.5.5 0 0 1 0 1H8.5v1.5a.5.5 0 0 1-1 0V14H6a.5.5 0 0 1 0-1h1.5v-2.03a4 4 0 0 1-3.05-5.814l-.95-.949-.646.647a.5.5 0 1 1-.708-.708l.647-.646L1 1.707V3.5a.5.5 0 0 1-1 0v-3zm5.49 4.856a3 3 0 1 0 5.02 3.288 3 3 0 0 0-5.02-3.288z\"}}]})(props);\n};\nexport function BsGeoAltFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16s6-5.686 6-10A6 6 0 0 0 2 6c0 4.314 6 10 6 10zm0-7a3 3 0 1 1 0-6 3 3 0 0 1 0 6z\"}}]})(props);\n};\nexport function BsGeoAlt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.166 8.94c-.524 1.062-1.234 2.12-1.96 3.07A31.493 31.493 0 0 1 8 14.58a31.481 31.481 0 0 1-2.206-2.57c-.726-.95-1.436-2.008-1.96-3.07C3.304 7.867 3 6.862 3 6a5 5 0 0 1 10 0c0 .862-.305 1.867-.834 2.94zM8 16s6-5.686 6-10A6 6 0 0 0 2 6c0 4.314 6 10 6 10z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8a2 2 0 1 1 0-4 2 2 0 0 1 0 4zm0 1a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}}]})(props);\n};\nexport function BsGeoFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4 4a4 4 0 1 1 4.5 3.969V13.5a.5.5 0 0 1-1 0V7.97A4 4 0 0 1 4 3.999zm2.493 8.574a.5.5 0 0 1-.411.575c-.712.118-1.28.295-1.655.493a1.319 1.319 0 0 0-.37.265.301.301 0 0 0-.057.09V14l.002.008a.147.147 0 0 0 .016.033.617.617 0 0 0 .145.15c.165.13.435.27.813.395.751.25 1.82.414 3.024.414s2.273-.163 3.024-.414c.378-.126.648-.265.813-.395a.619.619 0 0 0 .146-.15.148.148 0 0 0 .015-.033L12 14v-.004a.301.301 0 0 0-.057-.09 1.318 1.318 0 0 0-.37-.264c-.376-.198-.943-.375-1.655-.493a.5.5 0 1 1 .164-.986c.77.127 1.452.328 1.957.594C12.5 13 13 13.4 13 14c0 .426-.26.752-.544.977-.29.228-.68.413-1.116.558-.878.293-2.059.465-3.34.465-1.281 0-2.462-.172-3.34-.465-.436-.145-.826-.33-1.116-.558C3.26 14.752 3 14.426 3 14c0-.599.5-1 .961-1.243.505-.266 1.187-.467 1.957-.594a.5.5 0 0 1 .575.411z\"}}]})(props);\n};\nexport function BsGeo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 1a3 3 0 1 0 0 6 3 3 0 0 0 0-6zM4 4a4 4 0 1 1 4.5 3.969V13.5a.5.5 0 0 1-1 0V7.97A4 4 0 0 1 4 3.999zm2.493 8.574a.5.5 0 0 1-.411.575c-.712.118-1.28.295-1.655.493a1.319 1.319 0 0 0-.37.265.301.301 0 0 0-.057.09V14l.002.008a.147.147 0 0 0 .016.033.617.617 0 0 0 .145.15c.165.13.435.27.813.395.751.25 1.82.414 3.024.414s2.273-.163 3.024-.414c.378-.126.648-.265.813-.395a.619.619 0 0 0 .146-.15.148.148 0 0 0 .015-.033L12 14v-.004a.301.301 0 0 0-.057-.09 1.318 1.318 0 0 0-.37-.264c-.376-.198-.943-.375-1.655-.493a.5.5 0 1 1 .164-.986c.77.127 1.452.328 1.957.594C12.5 13 13 13.4 13 14c0 .426-.26.752-.544.977-.29.228-.68.413-1.116.558-.878.293-2.059.465-3.34.465-1.281 0-2.462-.172-3.34-.465-.436-.145-.826-.33-1.116-.558C3.26 14.752 3 14.426 3 14c0-.599.5-1 .961-1.243.505-.266 1.187-.467 1.957-.594a.5.5 0 0 1 .575.411z\"}}]})(props);\n};\nexport function BsGiftFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 2.5a2.5 2.5 0 0 1 5 0 2.5 2.5 0 0 1 5 0v.006c0 .07 0 .27-.038.494H15a1 1 0 0 1 1 1v1a1 1 0 0 1-1 1H1a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h2.038A2.968 2.968 0 0 1 3 2.506V2.5zm1.068.5H7v-.5a1.5 1.5 0 1 0-3 0c0 .085.002.274.045.43a.522.522 0 0 0 .023.07zM9 3h2.932a.56.56 0 0 0 .023-.07c.043-.156.045-.345.045-.43a1.5 1.5 0 0 0-3 0V3zm6 4v7.5a1.5 1.5 0 0 1-1.5 1.5H9V7h6zM2.5 16A1.5 1.5 0 0 1 1 14.5V7h6v9H2.5z\"}}]})(props);\n};\nexport function BsGift (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 2.5a2.5 2.5 0 0 1 5 0 2.5 2.5 0 0 1 5 0v.006c0 .07 0 .27-.038.494H15a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1v7.5a1.5 1.5 0 0 1-1.5 1.5h-11A1.5 1.5 0 0 1 1 14.5V7a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h2.038A2.968 2.968 0 0 1 3 2.506V2.5zm1.068.5H7v-.5a1.5 1.5 0 1 0-3 0c0 .085.002.274.045.43a.522.522 0 0 0 .023.07zM9 3h2.932a.56.56 0 0 0 .023-.07c.043-.156.045-.345.045-.43a1.5 1.5 0 0 0-3 0V3zM1 4v2h6V4H1zm8 0v2h6V4H9zm5 3H9v8h4.5a.5.5 0 0 0 .5-.5V7zm-7 8V7H2v7.5a.5.5 0 0 0 .5.5H7z\"}}]})(props);\n};\nexport function BsGithub (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.012 8.012 0 0 0 16 8c0-4.42-3.58-8-8-8z\"}}]})(props);\n};\nexport function BsGlobe (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8zm7.5-6.923c-.67.204-1.335.82-1.887 1.855A7.97 7.97 0 0 0 5.145 4H7.5V1.077zM4.09 4a9.267 9.267 0 0 1 .64-1.539 6.7 6.7 0 0 1 .597-.933A7.025 7.025 0 0 0 2.255 4H4.09zm-.582 3.5c.03-.877.138-1.718.312-2.5H1.674a6.958 6.958 0 0 0-.656 2.5h2.49zM4.847 5a12.5 12.5 0 0 0-.338 2.5H7.5V5H4.847zM8.5 5v2.5h2.99a12.495 12.495 0 0 0-.337-2.5H8.5zM4.51 8.5a12.5 12.5 0 0 0 .337 2.5H7.5V8.5H4.51zm3.99 0V11h2.653c.187-.765.306-1.608.338-2.5H8.5zM5.145 12c.138.386.295.744.468 1.068.552 1.035 1.218 1.65 1.887 1.855V12H5.145zm.182 2.472a6.696 6.696 0 0 1-.597-.933A9.268 9.268 0 0 1 4.09 12H2.255a7.024 7.024 0 0 0 3.072 2.472zM3.82 11a13.652 13.652 0 0 1-.312-2.5h-2.49c.062.89.291 1.733.656 2.5H3.82zm6.853 3.472A7.024 7.024 0 0 0 13.745 12H11.91a9.27 9.27 0 0 1-.64 1.539 6.688 6.688 0 0 1-.597.933zM8.5 12v2.923c.67-.204 1.335-.82 1.887-1.855.173-.324.33-.682.468-1.068H8.5zm3.68-1h2.146c.365-.767.594-1.61.656-2.5h-2.49a13.65 13.65 0 0 1-.312 2.5zm2.802-3.5a6.959 6.959 0 0 0-.656-2.5H12.18c.174.782.282 1.623.312 2.5h2.49zM11.27 2.461c.247.464.462.98.64 1.539h1.835a7.024 7.024 0 0 0-3.072-2.472c.218.284.418.598.597.933zM10.855 4a7.966 7.966 0 0 0-.468-1.068C9.835 1.897 9.17 1.282 8.5 1.077V4h2.355z\"}}]})(props);\n};\nexport function BsGlobe2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8zm7.5-6.923c-.67.204-1.335.82-1.887 1.855-.143.268-.276.56-.395.872.705.157 1.472.257 2.282.287V1.077zM4.249 3.539c.142-.384.304-.744.481-1.078a6.7 6.7 0 0 1 .597-.933A7.01 7.01 0 0 0 3.051 3.05c.362.184.763.349 1.198.49zM3.509 7.5c.036-1.07.188-2.087.436-3.008a9.124 9.124 0 0 1-1.565-.667A6.964 6.964 0 0 0 1.018 7.5h2.49zm1.4-2.741a12.344 12.344 0 0 0-.4 2.741H7.5V5.091c-.91-.03-1.783-.145-2.591-.332zM8.5 5.09V7.5h2.99a12.342 12.342 0 0 0-.399-2.741c-.808.187-1.681.301-2.591.332zM4.51 8.5c.035.987.176 1.914.399 2.741A13.612 13.612 0 0 1 7.5 10.91V8.5H4.51zm3.99 0v2.409c.91.03 1.783.145 2.591.332.223-.827.364-1.754.4-2.741H8.5zm-3.282 3.696c.12.312.252.604.395.872.552 1.035 1.218 1.65 1.887 1.855V11.91c-.81.03-1.577.13-2.282.287zm.11 2.276a6.696 6.696 0 0 1-.598-.933 8.853 8.853 0 0 1-.481-1.079 8.38 8.38 0 0 0-1.198.49 7.01 7.01 0 0 0 2.276 1.522zm-1.383-2.964A13.36 13.36 0 0 1 3.508 8.5h-2.49a6.963 6.963 0 0 0 1.362 3.675c.47-.258.995-.482 1.565-.667zm6.728 2.964a7.009 7.009 0 0 0 2.275-1.521 8.376 8.376 0 0 0-1.197-.49 8.853 8.853 0 0 1-.481 1.078 6.688 6.688 0 0 1-.597.933zM8.5 11.909v3.014c.67-.204 1.335-.82 1.887-1.855.143-.268.276-.56.395-.872A12.63 12.63 0 0 0 8.5 11.91zm3.555-.401c.57.185 1.095.409 1.565.667A6.963 6.963 0 0 0 14.982 8.5h-2.49a13.36 13.36 0 0 1-.437 3.008zM14.982 7.5a6.963 6.963 0 0 0-1.362-3.675c-.47.258-.995.482-1.565.667.248.92.4 1.938.437 3.008h2.49zM11.27 2.461c.177.334.339.694.482 1.078a8.368 8.368 0 0 0 1.196-.49 7.01 7.01 0 0 0-2.275-1.52c.218.283.418.597.597.932zm-.488 1.343a7.765 7.765 0 0 0-.395-.872C9.835 1.897 9.17 1.282 8.5 1.077V4.09c.81-.03 1.577-.13 2.282-.287z\"}}]})(props);\n};\nexport function BsGoogle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.545 6.558a9.42 9.42 0 0 1 .139 1.626c0 2.434-.87 4.492-2.384 5.885h.002C11.978 15.292 10.158 16 8 16A8 8 0 1 1 8 0a7.689 7.689 0 0 1 5.352 2.082l-2.284 2.284A4.347 4.347 0 0 0 8 3.166c-2.087 0-3.86 1.408-4.492 3.304a4.792 4.792 0 0 0 0 3.063h.003c.635 1.893 2.405 3.301 4.492 3.301 1.078 0 2.004-.276 2.722-.764h-.003a3.702 3.702 0 0 0 1.599-2.431H8v-3.08h7.545z\"}}]})(props);\n};\nexport function BsGraphDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M0 0h1v15h15v1H0V0zm10 11.5a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5v-4a.5.5 0 0 0-1 0v2.6l-3.613-4.417a.5.5 0 0 0-.74-.037L7.06 8.233 3.404 3.206a.5.5 0 0 0-.808.588l4 5.5a.5.5 0 0 0 .758.06l2.609-2.61L13.445 11H10.5a.5.5 0 0 0-.5.5z\"}}]})(props);\n};\nexport function BsGraphUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M0 0h1v15h15v1H0V0zm10 3.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-1 0V4.9l-3.613 4.417a.5.5 0 0 1-.74.037L7.06 6.767l-3.656 5.027a.5.5 0 0 1-.808-.588l4-5.5a.5.5 0 0 1 .758-.06l2.609 2.61L13.445 4H10.5a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsGrid1X2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1a1 1 0 0 1 1-1h5a1 1 0 0 1 1 1v14a1 1 0 0 1-1 1H1a1 1 0 0 1-1-1V1zm9 0a1 1 0 0 1 1-1h5a1 1 0 0 1 1 1v5a1 1 0 0 1-1 1h-5a1 1 0 0 1-1-1V1zm0 9a1 1 0 0 1 1-1h5a1 1 0 0 1 1 1v5a1 1 0 0 1-1 1h-5a1 1 0 0 1-1-1v-5z\"}}]})(props);\n};\nexport function BsGrid1X2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 1H1v14h5V1zm9 0h-5v5h5V1zm0 9v5h-5v-5h5zM0 1a1 1 0 0 1 1-1h5a1 1 0 0 1 1 1v14a1 1 0 0 1-1 1H1a1 1 0 0 1-1-1V1zm9 0a1 1 0 0 1 1-1h5a1 1 0 0 1 1 1v5a1 1 0 0 1-1 1h-5a1 1 0 0 1-1-1V1zm1 8a1 1 0 0 0-1 1v5a1 1 0 0 0 1 1h5a1 1 0 0 0 1-1v-5a1 1 0 0 0-1-1h-5z\"}}]})(props);\n};\nexport function BsGrid3X2GapFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 4a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H7a1 1 0 0 1-1-1V4zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1h-2a1 1 0 0 1-1-1V4zM1 9a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V9zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H7a1 1 0 0 1-1-1V9zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1h-2a1 1 0 0 1-1-1V9z\"}}]})(props);\n};\nexport function BsGrid3X2Gap (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4v2H2V4h2zm1 7V9a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1zm0-5V4a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1zm5 5V9a1 1 0 0 0-1-1H7a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1zm0-5V4a1 1 0 0 0-1-1H7a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1zM9 4v2H7V4h2zm5 0h-2v2h2V4zM4 9v2H2V9h2zm5 0v2H7V9h2zm5 0v2h-2V9h2zm-3-5a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1h-2a1 1 0 0 1-1-1V4zm1 4a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1V9a1 1 0 0 0-1-1h-2z\"}}]})(props);\n};\nexport function BsGrid3X2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 3.5A1.5 1.5 0 0 1 1.5 2h13A1.5 1.5 0 0 1 16 3.5v8a1.5 1.5 0 0 1-1.5 1.5h-13A1.5 1.5 0 0 1 0 11.5v-8zM1.5 3a.5.5 0 0 0-.5.5V7h4V3H1.5zM5 8H1v3.5a.5.5 0 0 0 .5.5H5V8zm1 0v4h4V8H6zm4-1V3H6v4h4zm1 1v4h3.5a.5.5 0 0 0 .5-.5V8h-4zm0-1h4V3.5a.5.5 0 0 0-.5-.5H11v4z\"}}]})(props);\n};\nexport function BsGrid3X3GapFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 2a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H7a1 1 0 0 1-1-1V2zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1h-2a1 1 0 0 1-1-1V2zM1 7a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V7zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H7a1 1 0 0 1-1-1V7zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1h-2a1 1 0 0 1-1-1V7zM1 12a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1v-2zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H7a1 1 0 0 1-1-1v-2zm5 0a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1h-2a1 1 0 0 1-1-1v-2z\"}}]})(props);\n};\nexport function BsGrid3X3Gap (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 2v2H2V2h2zm1 12v-2a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1zm0-5V7a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1zm0-5V2a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1zm5 10v-2a1 1 0 0 0-1-1H7a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1zm0-5V7a1 1 0 0 0-1-1H7a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1zm0-5V2a1 1 0 0 0-1-1H7a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1zM9 2v2H7V2h2zm5 0v2h-2V2h2zM4 7v2H2V7h2zm5 0v2H7V7h2zm5 0h-2v2h2V7zM4 12v2H2v-2h2zm5 0v2H7v-2h2zm5 0v2h-2v-2h2zM12 1a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1h-2zm-1 6a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1h-2a1 1 0 0 1-1-1V7zm1 4a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1v-2a1 1 0 0 0-1-1h-2z\"}}]})(props);\n};\nexport function BsGrid3X3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1.5A1.5 1.5 0 0 1 1.5 0h13A1.5 1.5 0 0 1 16 1.5v13a1.5 1.5 0 0 1-1.5 1.5h-13A1.5 1.5 0 0 1 0 14.5v-13zM1.5 1a.5.5 0 0 0-.5.5V5h4V1H1.5zM5 6H1v4h4V6zm1 4h4V6H6v4zm-1 1H1v3.5a.5.5 0 0 0 .5.5H5v-4zm1 0v4h4v-4H6zm5 0v4h3.5a.5.5 0 0 0 .5-.5V11h-4zm0-1h4V6h-4v4zm0-5h4V1.5a.5.5 0 0 0-.5-.5H11v4zm-1 0V1H6v4h4z\"}}]})(props);\n};\nexport function BsGridFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 2.5A1.5 1.5 0 0 1 2.5 1h3A1.5 1.5 0 0 1 7 2.5v3A1.5 1.5 0 0 1 5.5 7h-3A1.5 1.5 0 0 1 1 5.5v-3zm8 0A1.5 1.5 0 0 1 10.5 1h3A1.5 1.5 0 0 1 15 2.5v3A1.5 1.5 0 0 1 13.5 7h-3A1.5 1.5 0 0 1 9 5.5v-3zm-8 8A1.5 1.5 0 0 1 2.5 9h3A1.5 1.5 0 0 1 7 10.5v3A1.5 1.5 0 0 1 5.5 15h-3A1.5 1.5 0 0 1 1 13.5v-3zm8 0A1.5 1.5 0 0 1 10.5 9h3a1.5 1.5 0 0 1 1.5 1.5v3a1.5 1.5 0 0 1-1.5 1.5h-3A1.5 1.5 0 0 1 9 13.5v-3z\"}}]})(props);\n};\nexport function BsGrid (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 2.5A1.5 1.5 0 0 1 2.5 1h3A1.5 1.5 0 0 1 7 2.5v3A1.5 1.5 0 0 1 5.5 7h-3A1.5 1.5 0 0 1 1 5.5v-3zM2.5 2a.5.5 0 0 0-.5.5v3a.5.5 0 0 0 .5.5h3a.5.5 0 0 0 .5-.5v-3a.5.5 0 0 0-.5-.5h-3zm6.5.5A1.5 1.5 0 0 1 10.5 1h3A1.5 1.5 0 0 1 15 2.5v3A1.5 1.5 0 0 1 13.5 7h-3A1.5 1.5 0 0 1 9 5.5v-3zm1.5-.5a.5.5 0 0 0-.5.5v3a.5.5 0 0 0 .5.5h3a.5.5 0 0 0 .5-.5v-3a.5.5 0 0 0-.5-.5h-3zM1 10.5A1.5 1.5 0 0 1 2.5 9h3A1.5 1.5 0 0 1 7 10.5v3A1.5 1.5 0 0 1 5.5 15h-3A1.5 1.5 0 0 1 1 13.5v-3zm1.5-.5a.5.5 0 0 0-.5.5v3a.5.5 0 0 0 .5.5h3a.5.5 0 0 0 .5-.5v-3a.5.5 0 0 0-.5-.5h-3zm6.5.5A1.5 1.5 0 0 1 10.5 9h3a1.5 1.5 0 0 1 1.5 1.5v3a1.5 1.5 0 0 1-1.5 1.5h-3A1.5 1.5 0 0 1 9 13.5v-3zm1.5-.5a.5.5 0 0 0-.5.5v3a.5.5 0 0 0 .5.5h3a.5.5 0 0 0 .5-.5v-3a.5.5 0 0 0-.5-.5h-3z\"}}]})(props);\n};\nexport function BsGripHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 8a1 1 0 1 1 0 2 1 1 0 0 1 0-2zm0-3a1 1 0 1 1 0 2 1 1 0 0 1 0-2zm3 3a1 1 0 1 1 0 2 1 1 0 0 1 0-2zm0-3a1 1 0 1 1 0 2 1 1 0 0 1 0-2zm3 3a1 1 0 1 1 0 2 1 1 0 0 1 0-2zm0-3a1 1 0 1 1 0 2 1 1 0 0 1 0-2zm3 3a1 1 0 1 1 0 2 1 1 0 0 1 0-2zm0-3a1 1 0 1 1 0 2 1 1 0 0 1 0-2zm3 3a1 1 0 1 1 0 2 1 1 0 0 1 0-2zm0-3a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\"}}]})(props);\n};\nexport function BsGripVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 2a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm3 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zM7 5a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm3 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zM7 8a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm3 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm-3 3a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm3 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm-3 3a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm3 0a1 1 0 1 1-2 0 1 1 0 0 1 2 0z\"}}]})(props);\n};\nexport function BsHammer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.972 2.508a.5.5 0 0 0-.16-.556l-.178-.129a5.009 5.009 0 0 0-2.076-.783C6.215.862 4.504 1.229 2.84 3.133H1.786a.5.5 0 0 0-.354.147L.146 4.567a.5.5 0 0 0 0 .706l2.571 2.579a.5.5 0 0 0 .708 0l1.286-1.29a.5.5 0 0 0 .146-.353V5.57l8.387 8.873A.5.5 0 0 0 14 14.5l1.5-1.5a.5.5 0 0 0 .017-.689l-9.129-8.63c.747-.456 1.772-.839 3.112-.839a.5.5 0 0 0 .472-.334z\"}}]})(props);\n};\nexport function BsHandIndexFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 4.466V1.75a1.75 1.75 0 1 0-3.5 0v5.34l-1.2.24a1.5 1.5 0 0 0-1.196 1.636l.345 3.106a2.5 2.5 0 0 0 .405 1.11l1.433 2.15A1.5 1.5 0 0 0 6.035 16h6.385a1.5 1.5 0 0 0 1.302-.756l1.395-2.441a3.5 3.5 0 0 0 .444-1.389l.271-2.715a2 2 0 0 0-1.99-2.199h-.581a5.114 5.114 0 0 0-.195-.248c-.191-.229-.51-.568-.88-.716-.364-.146-.846-.132-1.158-.108l-.132.012a1.26 1.26 0 0 0-.56-.642 2.632 2.632 0 0 0-.738-.288c-.31-.062-.739-.058-1.05-.046l-.048.002z\"}}]})(props);\n};\nexport function BsHandIndexThumbFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 1.75v2.716l.047-.002c.312-.012.742-.016 1.051.046.28.056.543.18.738.288.273.152.456.385.56.642l.132-.012c.312-.024.794-.038 1.158.108.37.148.689.487.88.716.075.09.141.175.195.248h.582a2 2 0 0 1 1.99 2.199l-.272 2.715a3.5 3.5 0 0 1-.444 1.389l-1.395 2.441A1.5 1.5 0 0 1 12.42 16H6.118a1.5 1.5 0 0 1-1.342-.83l-1.215-2.43L1.07 8.589a1.517 1.517 0 0 1 2.373-1.852L5 8.293V1.75a1.75 1.75 0 0 1 3.5 0z\"}}]})(props);\n};\nexport function BsHandIndexThumb (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.75 1a.75.75 0 0 1 .75.75V8a.5.5 0 0 0 1 0V5.467l.086-.004c.317-.012.637-.008.816.027.134.027.294.096.448.182.077.042.15.147.15.314V8a.5.5 0 0 0 1 0V6.435l.106-.01c.316-.024.584-.01.708.04.118.046.3.207.486.43.081.096.15.19.2.259V8.5a.5.5 0 1 0 1 0v-1h.342a1 1 0 0 1 .995 1.1l-.271 2.715a2.5 2.5 0 0 1-.317.991l-1.395 2.442a.5.5 0 0 1-.434.252H6.118a.5.5 0 0 1-.447-.276l-1.232-2.465-2.512-4.185a.517.517 0 0 1 .809-.631l2.41 2.41A.5.5 0 0 0 6 9.5V1.75A.75.75 0 0 1 6.75 1zM8.5 4.466V1.75a1.75 1.75 0 1 0-3.5 0v6.543L3.443 6.736A1.517 1.517 0 0 0 1.07 8.588l2.491 4.153 1.215 2.43A1.5 1.5 0 0 0 6.118 16h6.302a1.5 1.5 0 0 0 1.302-.756l1.395-2.441a3.5 3.5 0 0 0 .444-1.389l.271-2.715a2 2 0 0 0-1.99-2.199h-.581a5.114 5.114 0 0 0-.195-.248c-.191-.229-.51-.568-.88-.716-.364-.146-.846-.132-1.158-.108l-.132.012a1.26 1.26 0 0 0-.56-.642 2.632 2.632 0 0 0-.738-.288c-.31-.062-.739-.058-1.05-.046l-.048.002zm2.094 2.025z\"}}]})(props);\n};\nexport function BsHandIndex (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.75 1a.75.75 0 0 1 .75.75V8a.5.5 0 0 0 1 0V5.467l.086-.004c.317-.012.637-.008.816.027.134.027.294.096.448.182.077.042.15.147.15.314V8a.5.5 0 1 0 1 0V6.435a4.9 4.9 0 0 1 .106-.01c.316-.024.584-.01.708.04.118.046.3.207.486.43.081.096.15.19.2.259V8.5a.5.5 0 0 0 1 0v-1h.342a1 1 0 0 1 .995 1.1l-.271 2.715a2.5 2.5 0 0 1-.317.991l-1.395 2.442a.5.5 0 0 1-.434.252H6.035a.5.5 0 0 1-.416-.223l-1.433-2.15a1.5 1.5 0 0 1-.243-.666l-.345-3.105a.5.5 0 0 1 .399-.546L5 8.11V9a.5.5 0 0 0 1 0V1.75A.75.75 0 0 1 6.75 1zM8.5 4.466V1.75a1.75 1.75 0 1 0-3.5 0v5.34l-1.2.24a1.5 1.5 0 0 0-1.196 1.636l.345 3.106a2.5 2.5 0 0 0 .405 1.11l1.433 2.15A1.5 1.5 0 0 0 6.035 16h6.385a1.5 1.5 0 0 0 1.302-.756l1.395-2.441a3.5 3.5 0 0 0 .444-1.389l.271-2.715a2 2 0 0 0-1.99-2.199h-.581a5.114 5.114 0 0 0-.195-.248c-.191-.229-.51-.568-.88-.716-.364-.146-.846-.132-1.158-.108l-.132.012a1.26 1.26 0 0 0-.56-.642 2.632 2.632 0 0 0-.738-.288c-.31-.062-.739-.058-1.05-.046l-.048.002zm2.094 2.025z\"}}]})(props);\n};\nexport function BsHandThumbsDownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.956 14.534c.065.936.952 1.659 1.908 1.42l.261-.065a1.378 1.378 0 0 0 1.012-.965c.22-.816.533-2.512.062-4.51.136.02.285.037.443.051.713.065 1.669.071 2.516-.211.518-.173.994-.68 1.2-1.272a1.896 1.896 0 0 0-.234-1.734c.058-.118.103-.242.138-.362.077-.27.113-.568.113-.856 0-.29-.036-.586-.113-.857a2.094 2.094 0 0 0-.16-.403c.169-.387.107-.82-.003-1.149a3.162 3.162 0 0 0-.488-.9c.054-.153.076-.313.076-.465a1.86 1.86 0 0 0-.253-.912C13.1.757 12.437.28 11.5.28H8c-.605 0-1.07.08-1.466.217a4.823 4.823 0 0 0-.97.485l-.048.029c-.504.308-.999.61-2.068.723C2.682 1.815 2 2.434 2 3.279v4c0 .851.685 1.433 1.357 1.616.849.232 1.574.787 2.132 1.41.56.626.914 1.28 1.039 1.638.199.575.356 1.54.428 2.591z\"}}]})(props);\n};\nexport function BsHandThumbsDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.864 15.674c-.956.24-1.843-.484-1.908-1.42-.072-1.05-.23-2.015-.428-2.59-.125-.36-.479-1.012-1.04-1.638-.557-.624-1.282-1.179-2.131-1.41C2.685 8.432 2 7.85 2 7V3c0-.845.682-1.464 1.448-1.546 1.07-.113 1.564-.415 2.068-.723l.048-.029c.272-.166.578-.349.97-.484C6.931.08 7.395 0 8 0h3.5c.937 0 1.599.478 1.934 1.064.164.287.254.607.254.913 0 .152-.023.312-.077.464.201.262.38.577.488.9.11.33.172.762.004 1.15.069.13.12.268.159.403.077.27.113.567.113.856 0 .289-.036.586-.113.856-.035.12-.08.244-.138.363.394.571.418 1.2.234 1.733-.206.592-.682 1.1-1.2 1.272-.847.283-1.803.276-2.516.211a9.877 9.877 0 0 1-.443-.05 9.364 9.364 0 0 1-.062 4.51c-.138.508-.55.848-1.012.964l-.261.065zM11.5 1H8c-.51 0-.863.068-1.14.163-.281.097-.506.229-.776.393l-.04.025c-.555.338-1.198.73-2.49.868-.333.035-.554.29-.554.55V7c0 .255.226.543.62.65 1.095.3 1.977.997 2.614 1.709.635.71 1.064 1.475 1.238 1.977.243.7.407 1.768.482 2.85.025.362.36.595.667.518l.262-.065c.16-.04.258-.144.288-.255a8.34 8.34 0 0 0-.145-4.726.5.5 0 0 1 .595-.643h.003l.014.004.058.013a8.912 8.912 0 0 0 1.036.157c.663.06 1.457.054 2.11-.163.175-.059.45-.301.57-.651.107-.308.087-.67-.266-1.021L12.793 7l.353-.354c.043-.042.105-.14.154-.315.048-.167.075-.37.075-.581 0-.211-.027-.414-.075-.581-.05-.174-.111-.273-.154-.315l-.353-.354.353-.354c.047-.047.109-.176.005-.488a2.224 2.224 0 0 0-.505-.804l-.353-.354.353-.354c.006-.005.041-.05.041-.17a.866.866 0 0 0-.121-.415C12.4 1.272 12.063 1 11.5 1z\"}}]})(props);\n};\nexport function BsHandThumbsUpFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.956 1.745C7.021.81 7.908.087 8.864.325l.261.066c.463.116.874.456 1.012.965.22.816.533 2.511.062 4.51a9.84 9.84 0 0 1 .443-.051c.713-.065 1.669-.072 2.516.21.518.173.994.681 1.2 1.273.184.532.16 1.162-.234 1.733.058.119.103.242.138.363.077.27.113.567.113.856 0 .289-.036.586-.113.856-.039.135-.09.273-.16.404.169.387.107.819-.003 1.148a3.163 3.163 0 0 1-.488.901c.054.152.076.312.076.465 0 .305-.089.625-.253.912C13.1 15.522 12.437 16 11.5 16H8c-.605 0-1.07-.081-1.466-.218a4.82 4.82 0 0 1-.97-.484l-.048-.03c-.504-.307-.999-.609-2.068-.722C2.682 14.464 2 13.846 2 13V9c0-.85.685-1.432 1.357-1.615.849-.232 1.574-.787 2.132-1.41.56-.627.914-1.28 1.039-1.639.199-.575.356-1.539.428-2.59z\"}}]})(props);\n};\nexport function BsHandThumbsUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.864.046C7.908-.193 7.02.53 6.956 1.466c-.072 1.051-.23 2.016-.428 2.59-.125.36-.479 1.013-1.04 1.639-.557.623-1.282 1.178-2.131 1.41C2.685 7.288 2 7.87 2 8.72v4.001c0 .845.682 1.464 1.448 1.545 1.07.114 1.564.415 2.068.723l.048.03c.272.165.578.348.97.484.397.136.861.217 1.466.217h3.5c.937 0 1.599-.477 1.934-1.064a1.86 1.86 0 0 0 .254-.912c0-.152-.023-.312-.077-.464.201-.263.38-.578.488-.901.11-.33.172-.762.004-1.149.069-.13.12-.269.159-.403.077-.27.113-.568.113-.857 0-.288-.036-.585-.113-.856a2.144 2.144 0 0 0-.138-.362 1.9 1.9 0 0 0 .234-1.734c-.206-.592-.682-1.1-1.2-1.272-.847-.282-1.803-.276-2.516-.211a9.84 9.84 0 0 0-.443.05 9.365 9.365 0 0 0-.062-4.509A1.38 1.38 0 0 0 9.125.111L8.864.046zM11.5 14.721H8c-.51 0-.863-.069-1.14-.164-.281-.097-.506-.228-.776-.393l-.04-.024c-.555-.339-1.198-.731-2.49-.868-.333-.036-.554-.29-.554-.55V8.72c0-.254.226-.543.62-.65 1.095-.3 1.977-.996 2.614-1.708.635-.71 1.064-1.475 1.238-1.978.243-.7.407-1.768.482-2.85.025-.362.36-.594.667-.518l.262.066c.16.04.258.143.288.255a8.34 8.34 0 0 1-.145 4.725.5.5 0 0 0 .595.644l.003-.001.014-.003.058-.014a8.908 8.908 0 0 1 1.036-.157c.663-.06 1.457-.054 2.11.164.175.058.45.3.57.65.107.308.087.67-.266 1.022l-.353.353.353.354c.043.043.105.141.154.315.048.167.075.37.075.581 0 .212-.027.414-.075.582-.05.174-.111.272-.154.315l-.353.353.353.354c.047.047.109.177.005.488a2.224 2.224 0 0 1-.505.805l-.353.353.353.354c.006.005.041.05.041.17a.866.866 0 0 1-.121.416c-.165.288-.503.56-1.066.56z\"}}]})(props);\n};\nexport function BsHandbagFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a2 2 0 0 0-2 2v2H5V3a3 3 0 1 1 6 0v2h-1V3a2 2 0 0 0-2-2zM5 5H3.36a1.5 1.5 0 0 0-1.483 1.277L.85 13.13A2.5 2.5 0 0 0 3.322 16h9.355a2.5 2.5 0 0 0 2.473-2.87l-1.028-6.853A1.5 1.5 0 0 0 12.64 5H11v1.5a.5.5 0 0 1-1 0V5H6v1.5a.5.5 0 0 1-1 0V5z\"}}]})(props);\n};\nexport function BsHandbag (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a2 2 0 0 1 2 2v2H6V3a2 2 0 0 1 2-2zm3 4V3a3 3 0 1 0-6 0v2H3.36a1.5 1.5 0 0 0-1.483 1.277L.85 13.13A2.5 2.5 0 0 0 3.322 16h9.355a2.5 2.5 0 0 0 2.473-2.87l-1.028-6.853A1.5 1.5 0 0 0 12.64 5H11zm-1 1v1.5a.5.5 0 0 0 1 0V6h1.639a.5.5 0 0 1 .494.426l1.028 6.851A1.5 1.5 0 0 1 12.678 15H3.322a1.5 1.5 0 0 1-1.483-1.723l1.028-6.851A.5.5 0 0 1 3.36 6H5v1.5a.5.5 0 1 0 1 0V6h4z\"}}]})(props);\n};\nexport function BsHash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.39 12.648a1.32 1.32 0 0 0-.015.18c0 .305.21.508.5.508.266 0 .492-.172.555-.477l.554-2.703h1.204c.421 0 .617-.234.617-.547 0-.312-.188-.53-.617-.53h-.985l.516-2.524h1.265c.43 0 .618-.227.618-.547 0-.313-.188-.524-.618-.524h-1.046l.476-2.304a1.06 1.06 0 0 0 .016-.164.51.51 0 0 0-.516-.516.54.54 0 0 0-.539.43l-.523 2.554H7.617l.477-2.304c.008-.04.015-.118.015-.164a.512.512 0 0 0-.523-.516.539.539 0 0 0-.531.43L6.53 5.484H5.414c-.43 0-.617.22-.617.532 0 .312.187.539.617.539h.906l-.515 2.523H4.609c-.421 0-.609.219-.609.531 0 .313.188.547.61.547h.976l-.516 2.492c-.008.04-.015.125-.015.18 0 .305.21.508.5.508.265 0 .492-.172.554-.477l.555-2.703h2.242l-.515 2.492zm-1-6.109h2.266l-.515 2.563H6.859l.532-2.563z\"}}]})(props);\n};\nexport function BsHddFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 10a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v1a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2v-1zm2.5 1a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1zm2 0a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1zM.91 7.204A2.993 2.993 0 0 1 2 7h12c.384 0 .752.072 1.09.204l-1.867-3.422A1.5 1.5 0 0 0 11.906 3H4.094a1.5 1.5 0 0 0-1.317.782L.91 7.204z\"}}]})(props);\n};\nexport function BsHddNetworkFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v1a2 2 0 0 0 2 2h5.5v3A1.5 1.5 0 0 0 6 11.5H.5a.5.5 0 0 0 0 1H6A1.5 1.5 0 0 0 7.5 14h1a1.5 1.5 0 0 0 1.5-1.5h5.5a.5.5 0 0 0 0-1H10A1.5 1.5 0 0 0 8.5 10V7H14a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm.5 3a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm2 0a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1z\"}}]})(props);\n};\nexport function BsHddNetwork (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 5a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1zM3 4.5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v1a2 2 0 0 1-2 2H8.5v3a1.5 1.5 0 0 1 1.5 1.5h5.5a.5.5 0 0 1 0 1H10A1.5 1.5 0 0 1 8.5 14h-1A1.5 1.5 0 0 1 6 12.5H.5a.5.5 0 0 1 0-1H6A1.5 1.5 0 0 1 7.5 10V7H2a2 2 0 0 1-2-2V4zm1 0v1a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1zm6 7.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5z\"}}]})(props);\n};\nexport function BsHddRackFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v1a2 2 0 0 0 2 2h1v2H2a2 2 0 0 0-2 2v1a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-1a2 2 0 0 0-2-2h-1V7h1a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm.5 3a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm2 0a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm-2 7a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm2 0a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zM12 7v2H4V7h8z\"}}]})(props);\n};\nexport function BsHddRack (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 5a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1zM3 4.5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm2 7a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm-2.5.5a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 0-2 2v1a2 2 0 0 0 2 2h1v2H2a2 2 0 0 0-2 2v1a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-1a2 2 0 0 0-2-2h-1V7h1a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm13 2v1a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h12a1 1 0 0 1 1 1zm0 7v1a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1v-1a1 1 0 0 1 1-1h12a1 1 0 0 1 1 1zm-3-4v2H4V7h8z\"}}]})(props);\n};\nexport function BsHddStackFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 9a2 2 0 0 0-2 2v1a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-1a2 2 0 0 0-2-2H2zm.5 3a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm2 0a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zM2 2a2 2 0 0 0-2 2v1a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2zm.5 3a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm2 0a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1z\"}}]})(props);\n};\nexport function BsHddStack (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 10a1 1 0 0 1 1 1v1a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1v-1a1 1 0 0 1 1-1h12zM2 9a2 2 0 0 0-2 2v1a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-1a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 11.5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm-2 0a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zM14 3a1 1 0 0 1 1 1v1a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h12zM2 2a2 2 0 0 0-2 2v1a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4.5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm-2 0a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsHdd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 11a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1zM3 10.5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V9.51c0-.418.105-.83.305-1.197l2.472-4.531A1.5 1.5 0 0 1 4.094 3h7.812a1.5 1.5 0 0 1 1.317.782l2.472 4.53c.2.368.305.78.305 1.198V11zM3.655 4.26 1.592 8.043C1.724 8.014 1.86 8 2 8h12c.14 0 .276.014.408.042L12.345 4.26a.5.5 0 0 0-.439-.26H4.094a.5.5 0 0 0-.44.26zM1 10v1a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-1a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1z\"}}]})(props);\n};\nexport function BsHeadphones (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 3a5 5 0 0 0-5 5v1h1a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V8a6 6 0 1 1 12 0v5a1 1 0 0 1-1 1h-1a1 1 0 0 1-1-1v-3a1 1 0 0 1 1-1h1V8a5 5 0 0 0-5-5z\"}}]})(props);\n};\nexport function BsHeadsetVr (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1.248c1.857 0 3.526.641 4.65 1.794a4.978 4.978 0 0 1 2.518 1.09C13.907 1.482 11.295 0 8 0 4.75 0 2.12 1.48.844 4.122a4.979 4.979 0 0 1 2.289-1.047C4.236 1.872 5.974 1.248 8 1.248z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 12a3.988 3.988 0 0 1-2.786-1.13l-.002-.002a1.612 1.612 0 0 0-.276-.167A2.164 2.164 0 0 0 8 10.5c-.414 0-.729.103-.935.201a1.612 1.612 0 0 0-.277.167l-.002.002A4 4 0 1 1 4 4h8a4 4 0 0 1 0 8z\"}}]})(props);\n};\nexport function BsHeadset (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a5 5 0 0 0-5 5v1h1a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V6a6 6 0 1 1 12 0v6a2.5 2.5 0 0 1-2.5 2.5H9.366a1 1 0 0 1-.866.5h-1a1 1 0 1 1 0-2h1a1 1 0 0 1 .866.5H11.5A1.5 1.5 0 0 0 13 12h-1a1 1 0 0 1-1-1V8a1 1 0 0 1 1-1h1V6a5 5 0 0 0-5-5z\"}}]})(props);\n};\nexport function BsHeartFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 1.314C12.438-3.248 23.534 4.735 8 15-7.534 4.736 3.562-3.248 8 1.314z\"}}]})(props);\n};\nexport function BsHeartHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 2.748v11.047c3.452-2.368 5.365-4.542 6.286-6.357.955-1.886.838-3.362.314-4.385C13.486.878 10.4.28 8.717 2.01L8 2.748zM8 15C-7.333 4.868 3.279-3.04 7.824 1.143c.06.055.119.112.176.171a3.12 3.12 0 0 1 .176-.17C12.72-3.042 23.333 4.867 8 15z\"}}]})(props);\n};\nexport function BsHeart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m8 2.748-.717-.737C5.6.281 2.514.878 1.4 3.053c-.523 1.023-.641 2.5.314 4.385.92 1.815 2.834 3.989 6.286 6.357 3.452-2.368 5.365-4.542 6.286-6.357.955-1.886.838-3.362.314-4.385C13.486.878 10.4.28 8.717 2.01L8 2.748zM8 15C-7.333 4.868 3.279-3.04 7.824 1.143c.06.055.119.112.176.171a3.12 3.12 0 0 1 .176-.17C12.72-3.042 23.333 4.867 8 15z\"}}]})(props);\n};\nexport function BsHeptagonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.779.052a.5.5 0 0 1 .442 0l6.015 2.97a.5.5 0 0 1 .267.34l1.485 6.676a.5.5 0 0 1-.093.415l-4.162 5.354a.5.5 0 0 1-.395.193H4.662a.5.5 0 0 1-.395-.193L.105 10.453a.5.5 0 0 1-.093-.415l1.485-6.676a.5.5 0 0 1 .267-.34L7.779.053z\"}}]})(props);\n};\nexport function BsHeptagonHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.779.052a.5.5 0 0 1 .442 0l6.015 2.97a.5.5 0 0 1 .267.34l1.485 6.676a.5.5 0 0 1-.093.415l-4.162 5.354a.5.5 0 0 1-.395.193H4.662a.5.5 0 0 1-.395-.193L.105 10.453a.5.5 0 0 1-.093-.415l1.485-6.676a.5.5 0 0 1 .267-.34L7.779.053zM8 15h3.093l3.868-4.975-1.383-6.212L8 1.058V15z\"}}]})(props);\n};\nexport function BsHeptagon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.779.052a.5.5 0 0 1 .442 0l6.015 2.97a.5.5 0 0 1 .267.34l1.485 6.676a.5.5 0 0 1-.093.415l-4.162 5.354a.5.5 0 0 1-.395.193H4.662a.5.5 0 0 1-.395-.193L.105 10.453a.5.5 0 0 1-.093-.415l1.485-6.676a.5.5 0 0 1 .267-.34L7.779.053zM2.422 3.813l-1.383 6.212L4.907 15h6.186l3.868-4.975-1.383-6.212L8 1.058 2.422 3.813z\"}}]})(props);\n};\nexport function BsHexagonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8.5.134a1 1 0 0 0-1 0l-6 3.577a1 1 0 0 0-.5.866v6.846a1 1 0 0 0 .5.866l6 3.577a1 1 0 0 0 1 0l6-3.577a1 1 0 0 0 .5-.866V4.577a1 1 0 0 0-.5-.866L8.5.134z\"}}]})(props);\n};\nexport function BsHexagonHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4.577v6.846L8 15V1l6 3.577zM8.5.134a1 1 0 0 0-1 0l-6 3.577a1 1 0 0 0-.5.866v6.846a1 1 0 0 0 .5.866l6 3.577a1 1 0 0 0 1 0l6-3.577a1 1 0 0 0 .5-.866V4.577a1 1 0 0 0-.5-.866L8.5.134z\"}}]})(props);\n};\nexport function BsHexagon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4.577v6.846L8 15l-6-3.577V4.577L8 1l6 3.577zM8.5.134a1 1 0 0 0-1 0l-6 3.577a1 1 0 0 0-.5.866v6.846a1 1 0 0 0 .5.866l6 3.577a1 1 0 0 0 1 0l6-3.577a1 1 0 0 0 .5-.866V4.577a1 1 0 0 0-.5-.866L8.5.134z\"}}]})(props);\n};\nexport function BsHourglassBottom (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1.5a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-1v1a4.5 4.5 0 0 1-2.557 4.06c-.29.139-.443.377-.443.59v.7c0 .213.154.451.443.59A4.5 4.5 0 0 1 12.5 13v1h1a.5.5 0 0 1 0 1h-11a.5.5 0 1 1 0-1h1v-1a4.5 4.5 0 0 1 2.557-4.06c.29-.139.443-.377.443-.59v-.7c0-.213-.154-.451-.443-.59A4.5 4.5 0 0 1 3.5 3V2h-1a.5.5 0 0 1-.5-.5zm2.5.5v1a3.5 3.5 0 0 0 1.989 3.158c.533.256 1.011.791 1.011 1.491v.702s.18.149.5.149.5-.15.5-.15v-.7c0-.701.478-1.236 1.011-1.492A3.5 3.5 0 0 0 11.5 3V2h-7z\"}}]})(props);\n};\nexport function BsHourglassSplit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 15a.5.5 0 1 1 0-1h1v-1a4.5 4.5 0 0 1 2.557-4.06c.29-.139.443-.377.443-.59v-.7c0-.213-.154-.451-.443-.59A4.5 4.5 0 0 1 3.5 3V2h-1a.5.5 0 0 1 0-1h11a.5.5 0 0 1 0 1h-1v1a4.5 4.5 0 0 1-2.557 4.06c-.29.139-.443.377-.443.59v.7c0 .213.154.451.443.59A4.5 4.5 0 0 1 12.5 13v1h1a.5.5 0 0 1 0 1h-11zm2-13v1c0 .537.12 1.045.337 1.5h6.326c.216-.455.337-.963.337-1.5V2h-7zm3 6.35c0 .701-.478 1.236-1.011 1.492A3.5 3.5 0 0 0 4.5 13s.866-1.299 3-1.48V8.35zm1 0v3.17c2.134.181 3 1.48 3 1.48a3.5 3.5 0 0 0-1.989-3.158C8.978 9.586 8.5 9.052 8.5 8.351z\"}}]})(props);\n};\nexport function BsHourglassTop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 14.5a.5.5 0 0 0 .5.5h11a.5.5 0 1 0 0-1h-1v-1a4.5 4.5 0 0 0-2.557-4.06c-.29-.139-.443-.377-.443-.59v-.7c0-.213.154-.451.443-.59A4.5 4.5 0 0 0 12.5 3V2h1a.5.5 0 0 0 0-1h-11a.5.5 0 0 0 0 1h1v1a4.5 4.5 0 0 0 2.557 4.06c.29.139.443.377.443.59v.7c0 .213-.154.451-.443.59A4.5 4.5 0 0 0 3.5 13v1h-1a.5.5 0 0 0-.5.5zm2.5-.5v-1a3.5 3.5 0 0 1 1.989-3.158c.533-.256 1.011-.79 1.011-1.491v-.702s.18.101.5.101.5-.1.5-.1v.7c0 .701.478 1.236 1.011 1.492A3.5 3.5 0 0 1 11.5 13v1h-7z\"}}]})(props);\n};\nexport function BsHourglass (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1.5a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-1v1a4.5 4.5 0 0 1-2.557 4.06c-.29.139-.443.377-.443.59v.7c0 .213.154.451.443.59A4.5 4.5 0 0 1 12.5 13v1h1a.5.5 0 0 1 0 1h-11a.5.5 0 1 1 0-1h1v-1a4.5 4.5 0 0 1 2.557-4.06c.29-.139.443-.377.443-.59v-.7c0-.213-.154-.451-.443-.59A4.5 4.5 0 0 1 3.5 3V2h-1a.5.5 0 0 1-.5-.5zm2.5.5v1a3.5 3.5 0 0 0 1.989 3.158c.533.256 1.011.791 1.011 1.491v.702c0 .7-.478 1.235-1.011 1.491A3.5 3.5 0 0 0 4.5 13v1h7v-1a3.5 3.5 0 0 0-1.989-3.158C8.978 9.586 8.5 9.052 8.5 8.351v-.702c0-.7.478-1.235 1.011-1.491A3.5 3.5 0 0 0 11.5 3V2h-7z\"}}]})(props);\n};\nexport function BsHouseDoorFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 14.5v-3.505c0-.245.25-.495.5-.495h2c.25 0 .5.25.5.5v3.5a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5v-7a.5.5 0 0 0-.146-.354L13 5.793V2.5a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5v1.293L8.354 1.146a.5.5 0 0 0-.708 0l-6 6A.5.5 0 0 0 1.5 7.5v7a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5z\"}}]})(props);\n};\nexport function BsHouseDoor (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.354 1.146a.5.5 0 0 0-.708 0l-6 6A.5.5 0 0 0 1.5 7.5v7a.5.5 0 0 0 .5.5h4.5a.5.5 0 0 0 .5-.5v-4h2v4a.5.5 0 0 0 .5.5H14a.5.5 0 0 0 .5-.5v-7a.5.5 0 0 0-.146-.354L13 5.793V2.5a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5v1.293L8.354 1.146zM2.5 14V7.707l5.5-5.5 5.5 5.5V14H10v-4a.5.5 0 0 0-.5-.5h-3a.5.5 0 0 0-.5.5v4H2.5z\"}}]})(props);\n};\nexport function BsHouseFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"m8 3.293 6 6V13.5a1.5 1.5 0 0 1-1.5 1.5h-9A1.5 1.5 0 0 1 2 13.5V9.293l6-6zm5-.793V6l-2-2V2.5a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.293 1.5a1 1 0 0 1 1.414 0l6.647 6.646a.5.5 0 0 1-.708.708L8 2.207 1.354 8.854a.5.5 0 1 1-.708-.708L7.293 1.5z\"}}]})(props);\n};\nexport function BsHouse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 13.5V7h1v6.5a.5.5 0 0 0 .5.5h9a.5.5 0 0 0 .5-.5V7h1v6.5a1.5 1.5 0 0 1-1.5 1.5h-9A1.5 1.5 0 0 1 2 13.5zm11-11V6l-2-2V2.5a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.293 1.5a1 1 0 0 1 1.414 0l6.647 6.646a.5.5 0 0 1-.708.708L8 2.207 1.354 8.854a.5.5 0 1 1-.708-.708L7.293 1.5z\"}}]})(props);\n};\nexport function BsHr (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3H4a1 1 0 0 0-1 1v2.5H2V4a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v2.5h-1V4a1 1 0 0 0-1-1zM2 9.5h1V12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V9.5h1V12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V9.5zm-1.5-2a.5.5 0 0 0 0 1h15a.5.5 0 0 0 0-1H.5z\"}}]})(props);\n};\nexport function BsHurricane (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.999 2.6A5.5 5.5 0 0 1 15 7.5a.5.5 0 0 0 1 0 6.5 6.5 0 1 0-13 0 5 5 0 0 0 6.001 4.9A5.5 5.5 0 0 1 1 7.5a.5.5 0 0 0-1 0 6.5 6.5 0 1 0 13 0 5 5 0 0 0-6.001-4.9zM10 7.5a2 2 0 1 1-4 0 2 2 0 0 1 4 0z\"}}]})(props);\n};\nexport function BsImageAlt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 2.5a2.5 2.5 0 1 1-5 0 2.5 2.5 0 0 1 5 0zm4.225 4.053a.5.5 0 0 0-.577.093l-3.71 4.71-2.66-2.772a.5.5 0 0 0-.63.062L.002 13v2a1 1 0 0 0 1 1h14a1 1 0 0 0 1-1v-4.5l-4.777-3.947z\"}}]})(props);\n};\nexport function BsImageFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.002 3a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2h-12a2 2 0 0 1-2-2V3zm1 9v1a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V9.5l-3.777-1.947a.5.5 0 0 0-.577.093l-3.71 3.71-2.66-1.772a.5.5 0 0 0-.63.062L1.002 12zm5-6.5a1.5 1.5 0 1 0-3 0 1.5 1.5 0 0 0 3 0z\"}}]})(props);\n};\nexport function BsImage (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.002 5.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.002 1a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V3a2 2 0 0 0-2-2h-12zm12 1a1 1 0 0 1 1 1v6.5l-3.777-1.947a.5.5 0 0 0-.577.093l-3.71 3.71-2.66-1.772a.5.5 0 0 0-.63.062L1.002 12V3a1 1 0 0 1 1-1h12z\"}}]})(props);\n};\nexport function BsImages (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.502 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.002 13a2 2 0 0 1-2 2h-10a2 2 0 0 1-2-2V5A2 2 0 0 1 2 3a2 2 0 0 1 2-2h10a2 2 0 0 1 2 2v8a2 2 0 0 1-1.998 2zM14 2H4a1 1 0 0 0-1 1h9.002a2 2 0 0 1 2 2v7A1 1 0 0 0 15 11V3a1 1 0 0 0-1-1zM2.002 4a1 1 0 0 0-1 1v8l2.646-2.354a.5.5 0 0 1 .63-.062l2.66 1.773 3.71-3.71a.5.5 0 0 1 .577-.094l1.777 1.947V5a1 1 0 0 0-1-1h-10z\"}}]})(props);\n};\nexport function BsInboxFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.98 4a.5.5 0 0 0-.39.188L1.54 8H6a.5.5 0 0 1 .5.5 1.5 1.5 0 1 0 3 0A.5.5 0 0 1 10 8h4.46l-3.05-3.812A.5.5 0 0 0 11.02 4H4.98zm-1.17-.437A1.5 1.5 0 0 1 4.98 3h6.04a1.5 1.5 0 0 1 1.17.563l3.7 4.625a.5.5 0 0 1 .106.374l-.39 3.124A1.5 1.5 0 0 1 14.117 13H1.883a1.5 1.5 0 0 1-1.489-1.314l-.39-3.124a.5.5 0 0 1 .106-.374l3.7-4.625z\"}}]})(props);\n};\nexport function BsInbox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.98 4a.5.5 0 0 0-.39.188L1.54 8H6a.5.5 0 0 1 .5.5 1.5 1.5 0 1 0 3 0A.5.5 0 0 1 10 8h4.46l-3.05-3.812A.5.5 0 0 0 11.02 4H4.98zm9.954 5H10.45a2.5 2.5 0 0 1-4.9 0H1.066l.32 2.562a.5.5 0 0 0 .497.438h12.234a.5.5 0 0 0 .496-.438L14.933 9zM3.809 3.563A1.5 1.5 0 0 1 4.981 3h6.038a1.5 1.5 0 0 1 1.172.563l3.7 4.625a.5.5 0 0 1 .105.374l-.39 3.124A1.5 1.5 0 0 1 14.117 13H1.883a1.5 1.5 0 0 1-1.489-1.314l-.39-3.124a.5.5 0 0 1 .106-.374l3.7-4.625z\"}}]})(props);\n};\nexport function BsInboxesFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.98 1a.5.5 0 0 0-.39.188L1.54 5H6a.5.5 0 0 1 .5.5 1.5 1.5 0 0 0 3 0A.5.5 0 0 1 10 5h4.46l-3.05-3.812A.5.5 0 0 0 11.02 1H4.98zM3.81.563A1.5 1.5 0 0 1 4.98 0h6.04a1.5 1.5 0 0 1 1.17.563l3.7 4.625a.5.5 0 0 1 .106.374l-.39 3.124A1.5 1.5 0 0 1 14.117 10H1.883A1.5 1.5 0 0 1 .394 8.686l-.39-3.124a.5.5 0 0 1 .106-.374L3.81.563zM.125 11.17A.5.5 0 0 1 .5 11H6a.5.5 0 0 1 .5.5 1.5 1.5 0 0 0 3 0 .5.5 0 0 1 .5-.5h5.5a.5.5 0 0 1 .496.562l-.39 3.124A1.5 1.5 0 0 1 14.117 16H1.883a1.5 1.5 0 0 1-1.489-1.314l-.39-3.124a.5.5 0 0 1 .121-.393z\"}}]})(props);\n};\nexport function BsInboxes (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.98 1a.5.5 0 0 0-.39.188L1.54 5H6a.5.5 0 0 1 .5.5 1.5 1.5 0 0 0 3 0A.5.5 0 0 1 10 5h4.46l-3.05-3.812A.5.5 0 0 0 11.02 1H4.98zm9.954 5H10.45a2.5 2.5 0 0 1-4.9 0H1.066l.32 2.562A.5.5 0 0 0 1.884 9h12.234a.5.5 0 0 0 .496-.438L14.933 6zM3.809.563A1.5 1.5 0 0 1 4.981 0h6.038a1.5 1.5 0 0 1 1.172.563l3.7 4.625a.5.5 0 0 1 .105.374l-.39 3.124A1.5 1.5 0 0 1 14.117 10H1.883A1.5 1.5 0 0 1 .394 8.686l-.39-3.124a.5.5 0 0 1 .106-.374L3.81.563zM.125 11.17A.5.5 0 0 1 .5 11H6a.5.5 0 0 1 .5.5 1.5 1.5 0 0 0 3 0 .5.5 0 0 1 .5-.5h5.5a.5.5 0 0 1 .496.562l-.39 3.124A1.5 1.5 0 0 1 14.117 16H1.883a1.5 1.5 0 0 1-1.489-1.314l-.39-3.124a.5.5 0 0 1 .121-.393zm.941.83.32 2.562a.5.5 0 0 0 .497.438h12.234a.5.5 0 0 0 .496-.438l.32-2.562H10.45a2.5 2.5 0 0 1-4.9 0H1.066z\"}}]})(props);\n};\nexport function BsInfoCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zm.93-9.412-1 4.705c-.07.34.029.533.304.533.194 0 .487-.07.686-.246l-.088.416c-.287.346-.92.598-1.465.598-.703 0-1.002-.422-.808-1.319l.738-3.468c.064-.293.006-.399-.287-.47l-.451-.081.082-.381 2.29-.287zM8 5.5a1 1 0 1 1 0-2 1 1 0 0 1 0 2z\"}}]})(props);\n};\nexport function BsInfoCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m8.93 6.588-2.29.287-.082.38.45.083c.294.07.352.176.288.469l-.738 3.468c-.194.897.105 1.319.808 1.319.545 0 1.178-.252 1.465-.598l.088-.416c-.2.176-.492.246-.686.246-.275 0-.375-.193-.304-.533L8.93 6.588zM9 4.5a1 1 0 1 1-2 0 1 1 0 0 1 2 0z\"}}]})(props);\n};\nexport function BsInfoLg (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m10.277 5.433-4.031.505-.145.67.794.145c.516.123.619.309.505.824L6.101 13.68c-.34 1.578.186 2.32 1.423 2.32.959 0 2.072-.443 2.577-1.052l.155-.732c-.35.31-.866.434-1.206.434-.485 0-.66-.34-.536-.939l1.763-8.278zm.122-3.673a1.76 1.76 0 1 1-3.52 0 1.76 1.76 0 0 1 3.52 0z\"}}]})(props);\n};\nexport function BsInfoSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm8.93 4.588-2.29.287-.082.38.45.083c.294.07.352.176.288.469l-.738 3.468c-.194.897.105 1.319.808 1.319.545 0 1.178-.252 1.465-.598l.088-.416c-.2.176-.492.246-.686.246-.275 0-.375-.193-.304-.533L8.93 6.588zM8 5.5a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsInfoSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m8.93 6.588-2.29.287-.082.38.45.083c.294.07.352.176.288.469l-.738 3.468c-.194.897.105 1.319.808 1.319.545 0 1.178-.252 1.465-.598l.088-.416c-.2.176-.492.246-.686.246-.275 0-.375-.193-.304-.533L8.93 6.588zM9 4.5a1 1 0 1 1-2 0 1 1 0 0 1 2 0z\"}}]})(props);\n};\nexport function BsInfo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m8.93 6.588-2.29.287-.082.38.45.083c.294.07.352.176.288.469l-.738 3.468c-.194.897.105 1.319.808 1.319.545 0 1.178-.252 1.465-.598l.088-.416c-.2.176-.492.246-.686.246-.275 0-.375-.193-.304-.533L8.93 6.588zM9 4.5a1 1 0 1 1-2 0 1 1 0 0 1 2 0z\"}}]})(props);\n};\nexport function BsInputCursorText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5 2a.5.5 0 0 1 .5-.5c.862 0 1.573.287 2.06.566.174.099.321.198.44.286.119-.088.266-.187.44-.286A4.165 4.165 0 0 1 10.5 1.5a.5.5 0 0 1 0 1c-.638 0-1.177.213-1.564.434a3.49 3.49 0 0 0-.436.294V7.5H9a.5.5 0 0 1 0 1h-.5v4.272c.1.08.248.187.436.294.387.221.926.434 1.564.434a.5.5 0 0 1 0 1 4.165 4.165 0 0 1-2.06-.566A4.561 4.561 0 0 1 8 13.65a4.561 4.561 0 0 1-.44.285 4.165 4.165 0 0 1-2.06.566.5.5 0 0 1 0-1c.638 0 1.177-.213 1.564-.434.188-.107.335-.214.436-.294V8.5H7a.5.5 0 0 1 0-1h.5V3.228a3.49 3.49 0 0 0-.436-.294A3.166 3.166 0 0 0 5.5 2.5.5.5 0 0 1 5 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5h4a1 1 0 0 1 1 1v4a1 1 0 0 1-1 1h-4v1h4a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2h-4v1zM6 5V4H2a2 2 0 0 0-2 2v4a2 2 0 0 0 2 2h4v-1H2a1 1 0 0 1-1-1V6a1 1 0 0 1 1-1h4z\"}}]})(props);\n};\nexport function BsInputCursor (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10 5h4a1 1 0 0 1 1 1v4a1 1 0 0 1-1 1h-4v1h4a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2h-4v1zM6 5V4H2a2 2 0 0 0-2 2v4a2 2 0 0 0 2 2h4v-1H2a1 1 0 0 1-1-1V6a1 1 0 0 1 1-1h4z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 1a.5.5 0 0 1 .5.5v13a.5.5 0 0 1-1 0v-13A.5.5 0 0 1 8 1z\"}}]})(props);\n};\nexport function BsInstagram (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0C5.829 0 5.556.01 4.703.048 3.85.088 3.269.222 2.76.42a3.917 3.917 0 0 0-1.417.923A3.927 3.927 0 0 0 .42 2.76C.222 3.268.087 3.85.048 4.7.01 5.555 0 5.827 0 8.001c0 2.172.01 2.444.048 3.297.04.852.174 1.433.372 1.942.205.526.478.972.923 1.417.444.445.89.719 1.416.923.51.198 1.09.333 1.942.372C5.555 15.99 5.827 16 8 16s2.444-.01 3.298-.048c.851-.04 1.434-.174 1.943-.372a3.916 3.916 0 0 0 1.416-.923c.445-.445.718-.891.923-1.417.197-.509.332-1.09.372-1.942C15.99 10.445 16 10.173 16 8s-.01-2.445-.048-3.299c-.04-.851-.175-1.433-.372-1.941a3.926 3.926 0 0 0-.923-1.417A3.911 3.911 0 0 0 13.24.42c-.51-.198-1.092-.333-1.943-.372C10.443.01 10.172 0 7.998 0h.003zm-.717 1.442h.718c2.136 0 2.389.007 3.232.046.78.035 1.204.166 1.486.275.373.145.64.319.92.599.28.28.453.546.598.92.11.281.24.705.275 1.485.039.843.047 1.096.047 3.231s-.008 2.389-.047 3.232c-.035.78-.166 1.203-.275 1.485a2.47 2.47 0 0 1-.599.919c-.28.28-.546.453-.92.598-.28.11-.704.24-1.485.276-.843.038-1.096.047-3.232.047s-2.39-.009-3.233-.047c-.78-.036-1.203-.166-1.485-.276a2.478 2.478 0 0 1-.92-.598 2.48 2.48 0 0 1-.6-.92c-.109-.281-.24-.705-.275-1.485-.038-.843-.046-1.096-.046-3.233 0-2.136.008-2.388.046-3.231.036-.78.166-1.204.276-1.486.145-.373.319-.64.599-.92.28-.28.546-.453.92-.598.282-.11.705-.24 1.485-.276.738-.034 1.024-.044 2.515-.045v.002zm4.988 1.328a.96.96 0 1 0 0 1.92.96.96 0 0 0 0-1.92zm-4.27 1.122a4.109 4.109 0 1 0 0 8.217 4.109 4.109 0 0 0 0-8.217zm0 1.441a2.667 2.667 0 1 1 0 5.334 2.667 2.667 0 0 1 0-5.334z\"}}]})(props);\n};\nexport function BsIntersect (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v2h2a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2v-2H2a2 2 0 0 1-2-2V2zm5 10v2a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V6a1 1 0 0 0-1-1h-2v5a2 2 0 0 1-2 2H5zm6-8V2a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h2V6a2 2 0 0 1 2-2h5z\"}}]})(props);\n};\nexport function BsJournalAlbum (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 4a.5.5 0 0 0-.5.5v5a.5.5 0 0 0 .5.5h5a.5.5 0 0 0 .5-.5v-5a.5.5 0 0 0-.5-.5h-5zm1 7a.5.5 0 0 0 0 1h3a.5.5 0 0 0 0-1h-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0h10a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-1h1v1a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H3a1 1 0 0 0-1 1v1H1V2a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 5v-.5a.5.5 0 0 1 1 0V5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0V8h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0v.5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1z\"}}]})(props);\n};\nexport function BsJournalArrowDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 5a.5.5 0 0 1 .5.5v3.793l1.146-1.147a.5.5 0 0 1 .708.708l-2 2a.5.5 0 0 1-.708 0l-2-2a.5.5 0 1 1 .708-.708L7.5 9.293V5.5A.5.5 0 0 1 8 5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0h10a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-1h1v1a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H3a1 1 0 0 0-1 1v1H1V2a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 5v-.5a.5.5 0 0 1 1 0V5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0V8h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0v.5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1z\"}}]})(props);\n};\nexport function BsJournalArrowUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 11a.5.5 0 0 0 .5-.5V6.707l1.146 1.147a.5.5 0 0 0 .708-.708l-2-2a.5.5 0 0 0-.708 0l-2 2a.5.5 0 1 0 .708.708L7.5 6.707V10.5a.5.5 0 0 0 .5.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0h10a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-1h1v1a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H3a1 1 0 0 0-1 1v1H1V2a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 5v-.5a.5.5 0 0 1 1 0V5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0V8h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0v.5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1z\"}}]})(props);\n};\nexport function BsJournalBookmarkFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 1h6v7a.5.5 0 0 1-.757.429L9 7.083 6.757 8.43A.5.5 0 0 1 6 8V1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0h10a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-1h1v1a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H3a1 1 0 0 0-1 1v1H1V2a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 5v-.5a.5.5 0 0 1 1 0V5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0V8h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0v.5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1z\"}}]})(props);\n};\nexport function BsJournalBookmark (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 8V1h1v6.117L8.743 6.07a.5.5 0 0 1 .514 0L11 7.117V1h1v7a.5.5 0 0 1-.757.429L9 7.083 6.757 8.43A.5.5 0 0 1 6 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0h10a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-1h1v1a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H3a1 1 0 0 0-1 1v1H1V2a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 5v-.5a.5.5 0 0 1 1 0V5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0V8h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0v.5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1z\"}}]})(props);\n};\nexport function BsJournalCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.854 6.146a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7.5 8.793l2.646-2.647a.5.5 0 0 1 .708 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0h10a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-1h1v1a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H3a1 1 0 0 0-1 1v1H1V2a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 5v-.5a.5.5 0 0 1 1 0V5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0V8h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0v.5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1z\"}}]})(props);\n};\nexport function BsJournalCode (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8.646 5.646a.5.5 0 0 1 .708 0l2 2a.5.5 0 0 1 0 .708l-2 2a.5.5 0 0 1-.708-.708L10.293 8 8.646 6.354a.5.5 0 0 1 0-.708zm-1.292 0a.5.5 0 0 0-.708 0l-2 2a.5.5 0 0 0 0 .708l2 2a.5.5 0 0 0 .708-.708L5.707 8l1.647-1.646a.5.5 0 0 0 0-.708z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0h10a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-1h1v1a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H3a1 1 0 0 0-1 1v1H1V2a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 5v-.5a.5.5 0 0 1 1 0V5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0V8h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0v.5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1z\"}}]})(props);\n};\nexport function BsJournalMedical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 4a.5.5 0 0 1 .5.5v.634l.549-.317a.5.5 0 1 1 .5.866L9 6l.549.317a.5.5 0 1 1-.5.866L8.5 6.866V7.5a.5.5 0 0 1-1 0v-.634l-.549.317a.5.5 0 1 1-.5-.866L7 6l-.549-.317a.5.5 0 0 1 .5-.866l.549.317V4.5A.5.5 0 0 1 8 4zM5 9.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0h10a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-1h1v1a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H3a1 1 0 0 0-1 1v1H1V2a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 5v-.5a.5.5 0 0 1 1 0V5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0V8h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0v.5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1z\"}}]})(props);\n};\nexport function BsJournalMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5.5 8a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0h10a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-1h1v1a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H3a1 1 0 0 0-1 1v1H1V2a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 5v-.5a.5.5 0 0 1 1 0V5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0V8h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0v.5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1z\"}}]})(props);\n};\nexport function BsJournalPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 5.5a.5.5 0 0 1 .5.5v1.5H10a.5.5 0 0 1 0 1H8.5V10a.5.5 0 0 1-1 0V8.5H6a.5.5 0 0 1 0-1h1.5V6a.5.5 0 0 1 .5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0h10a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-1h1v1a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H3a1 1 0 0 0-1 1v1H1V2a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 5v-.5a.5.5 0 0 1 1 0V5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0V8h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0v.5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1z\"}}]})(props);\n};\nexport function BsJournalRichtext (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 3.75a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0zm-.861 1.542 1.33.886 1.854-1.855a.25.25 0 0 1 .289-.047L11 4.75V7a.5.5 0 0 1-.5.5h-5A.5.5 0 0 1 5 7v-.5s1.54-1.274 1.639-1.208zM5 9.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0h10a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-1h1v1a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H3a1 1 0 0 0-1 1v1H1V2a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 5v-.5a.5.5 0 0 1 1 0V5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0V8h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0v.5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1z\"}}]})(props);\n};\nexport function BsJournalText (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 10.5a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5zm0-2a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm0-2a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm0-2a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0h10a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-1h1v1a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H3a1 1 0 0 0-1 1v1H1V2a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 5v-.5a.5.5 0 0 1 1 0V5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0V8h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0v.5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1z\"}}]})(props);\n};\nexport function BsJournalX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6.146 6.146a.5.5 0 0 1 .708 0L8 7.293l1.146-1.147a.5.5 0 1 1 .708.708L8.707 8l1.147 1.146a.5.5 0 0 1-.708.708L8 8.707 6.854 9.854a.5.5 0 0 1-.708-.708L7.293 8 6.146 6.854a.5.5 0 0 1 0-.708z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0h10a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-1h1v1a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H3a1 1 0 0 0-1 1v1H1V2a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 5v-.5a.5.5 0 0 1 1 0V5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0V8h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0v.5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1z\"}}]})(props);\n};\nexport function BsJournal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0h10a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-1h1v1a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H3a1 1 0 0 0-1 1v1H1V2a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 5v-.5a.5.5 0 0 1 1 0V5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0V8h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0v.5h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1z\"}}]})(props);\n};\nexport function BsJournals (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 0h8a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2 2 2 0 0 1-2 2H3a2 2 0 0 1-2-2h1a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V4a1 1 0 0 0-1-1H3a1 1 0 0 0-1 1H1a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v9a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H5a1 1 0 0 0-1 1H3a2 2 0 0 1 2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 6v-.5a.5.5 0 0 1 1 0V6h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 3v-.5a.5.5 0 0 1 1 0V9h.5a.5.5 0 0 1 0 1h-2a.5.5 0 0 1 0-1H1zm0 2.5v.5H.5a.5.5 0 0 0 0 1h2a.5.5 0 0 0 0-1H2v-.5a.5.5 0 0 0-1 0z\"}}]})(props);\n};\nexport function BsJoystick (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10 2a2 2 0 0 1-1.5 1.937v5.087c.863.083 1.5.377 1.5.726 0 .414-.895.75-2 .75s-2-.336-2-.75c0-.35.637-.643 1.5-.726V3.937A2 2 0 1 1 10 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 9.665v1.717a1 1 0 0 0 .553.894l6.553 3.277a2 2 0 0 0 1.788 0l6.553-3.277a1 1 0 0 0 .553-.894V9.665c0-.1-.06-.19-.152-.23L9.5 6.715v.993l5.227 2.178a.125.125 0 0 1 .001.23l-5.94 2.546a2 2 0 0 1-1.576 0l-5.94-2.546a.125.125 0 0 1 .001-.23L6.5 7.708l-.013-.988L.152 9.435a.25.25 0 0 0-.152.23z\"}}]})(props);\n};\nexport function BsJustifyLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 12.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm0-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5zm0-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5zm0-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsJustifyRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 12.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm-4-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5zm0-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5zm0-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsJustify (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 12.5a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5zm0-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5zm0-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5zm0-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsKanbanFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h11a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2h-11zm5 2h1a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1h-1a1 1 0 0 1-1-1V3a1 1 0 0 1 1-1zm-5 1a1 1 0 0 1 1-1h1a1 1 0 0 1 1 1v7a1 1 0 0 1-1 1h-1a1 1 0 0 1-1-1V3zm9-1h1a1 1 0 0 1 1 1v10a1 1 0 0 1-1 1h-1a1 1 0 0 1-1-1V3a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsKanban (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1h-11a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h11zm-11-1a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h11a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2h-11z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 3a1 1 0 0 1 1-1h1a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1h-1a1 1 0 0 1-1-1V3zm-4 0a1 1 0 0 1 1-1h1a1 1 0 0 1 1 1v7a1 1 0 0 1-1 1h-1a1 1 0 0 1-1-1V3zm8 0a1 1 0 0 1 1-1h1a1 1 0 0 1 1 1v10a1 1 0 0 1-1 1h-1a1 1 0 0 1-1-1V3z\"}}]})(props);\n};\nexport function BsKeyFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 11.5a3.5 3.5 0 1 1 3.163-5H14L15.5 8 14 9.5l-1-1-1 1-1-1-1 1-1-1-1 1H6.663a3.5 3.5 0 0 1-3.163 2zM2.5 9a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsKey (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 8a4 4 0 0 1 7.465-2H14a.5.5 0 0 1 .354.146l1.5 1.5a.5.5 0 0 1 0 .708l-1.5 1.5a.5.5 0 0 1-.708 0L13 9.207l-.646.647a.5.5 0 0 1-.708 0L11 9.207l-.646.647a.5.5 0 0 1-.708 0L9 9.207l-.646.647A.5.5 0 0 1 8 10h-.535A4 4 0 0 1 0 8zm4-3a3 3 0 1 0 2.712 4.285A.5.5 0 0 1 7.163 9h.63l.853-.854a.5.5 0 0 1 .708 0l.646.647.646-.647a.5.5 0 0 1 .708 0l.646.647.646-.647a.5.5 0 0 1 .708 0l.646.647.793-.793-1-1h-6.63a.5.5 0 0 1-.451-.285A3 3 0 0 0 4 5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 8a1 1 0 1 1-2 0 1 1 0 0 1 2 0z\"}}]})(props);\n};\nexport function BsKeyboardFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 6a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V6zm13 .25v.5c0 .138.112.25.25.25h.5a.25.25 0 0 0 .25-.25v-.5a.25.25 0 0 0-.25-.25h-.5a.25.25 0 0 0-.25.25zM2.25 8a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h.5A.25.25 0 0 0 3 8.75v-.5A.25.25 0 0 0 2.75 8h-.5zM4 8.25v.5c0 .138.112.25.25.25h.5A.25.25 0 0 0 5 8.75v-.5A.25.25 0 0 0 4.75 8h-.5a.25.25 0 0 0-.25.25zM6.25 8a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h.5A.25.25 0 0 0 7 8.75v-.5A.25.25 0 0 0 6.75 8h-.5zM8 8.25v.5c0 .138.112.25.25.25h.5A.25.25 0 0 0 9 8.75v-.5A.25.25 0 0 0 8.75 8h-.5a.25.25 0 0 0-.25.25zM13.25 8a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h.5a.25.25 0 0 0 .25-.25v-.5a.25.25 0 0 0-.25-.25h-.5zm0 2a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h.5a.25.25 0 0 0 .25-.25v-.5a.25.25 0 0 0-.25-.25h-.5zm-3-2a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h1.5a.25.25 0 0 0 .25-.25v-.5a.25.25 0 0 0-.25-.25h-1.5zm.75 2.25v.5c0 .138.112.25.25.25h.5a.25.25 0 0 0 .25-.25v-.5a.25.25 0 0 0-.25-.25h-.5a.25.25 0 0 0-.25.25zM11.25 6a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h.5a.25.25 0 0 0 .25-.25v-.5a.25.25 0 0 0-.25-.25h-.5zM9 6.25v.5c0 .138.112.25.25.25h.5a.25.25 0 0 0 .25-.25v-.5A.25.25 0 0 0 9.75 6h-.5a.25.25 0 0 0-.25.25zM7.25 6a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h.5A.25.25 0 0 0 8 6.75v-.5A.25.25 0 0 0 7.75 6h-.5zM5 6.25v.5c0 .138.112.25.25.25h.5A.25.25 0 0 0 6 6.75v-.5A.25.25 0 0 0 5.75 6h-.5a.25.25 0 0 0-.25.25zM2.25 6a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h1.5A.25.25 0 0 0 4 6.75v-.5A.25.25 0 0 0 3.75 6h-1.5zM2 10.25v.5c0 .138.112.25.25.25h.5a.25.25 0 0 0 .25-.25v-.5a.25.25 0 0 0-.25-.25h-.5a.25.25 0 0 0-.25.25zM4.25 10a.25.25 0 0 0-.25.25v.5c0 .138.112.25.25.25h5.5a.25.25 0 0 0 .25-.25v-.5a.25.25 0 0 0-.25-.25h-5.5z\"}}]})(props);\n};\nexport function BsKeyboard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 5a1 1 0 0 1 1 1v5a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V6a1 1 0 0 1 1-1h12zM2 4a2 2 0 0 0-2 2v5a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 10.25a.25.25 0 0 1 .25-.25h.5a.25.25 0 0 1 .25.25v.5a.25.25 0 0 1-.25.25h-.5a.25.25 0 0 1-.25-.25v-.5zm0-2a.25.25 0 0 1 .25-.25h.5a.25.25 0 0 1 .25.25v.5a.25.25 0 0 1-.25.25h-.5a.25.25 0 0 1-.25-.25v-.5zm-5 0A.25.25 0 0 1 8.25 8h.5a.25.25 0 0 1 .25.25v.5a.25.25 0 0 1-.25.25h-.5A.25.25 0 0 1 8 8.75v-.5zm2 0a.25.25 0 0 1 .25-.25h1.5a.25.25 0 0 1 .25.25v.5a.25.25 0 0 1-.25.25h-1.5a.25.25 0 0 1-.25-.25v-.5zm1 2a.25.25 0 0 1 .25-.25h.5a.25.25 0 0 1 .25.25v.5a.25.25 0 0 1-.25.25h-.5a.25.25 0 0 1-.25-.25v-.5zm-5-2A.25.25 0 0 1 6.25 8h.5a.25.25 0 0 1 .25.25v.5a.25.25 0 0 1-.25.25h-.5A.25.25 0 0 1 6 8.75v-.5zm-2 0A.25.25 0 0 1 4.25 8h.5a.25.25 0 0 1 .25.25v.5a.25.25 0 0 1-.25.25h-.5A.25.25 0 0 1 4 8.75v-.5zm-2 0A.25.25 0 0 1 2.25 8h.5a.25.25 0 0 1 .25.25v.5a.25.25 0 0 1-.25.25h-.5A.25.25 0 0 1 2 8.75v-.5zm11-2a.25.25 0 0 1 .25-.25h.5a.25.25 0 0 1 .25.25v.5a.25.25 0 0 1-.25.25h-.5a.25.25 0 0 1-.25-.25v-.5zm-2 0a.25.25 0 0 1 .25-.25h.5a.25.25 0 0 1 .25.25v.5a.25.25 0 0 1-.25.25h-.5a.25.25 0 0 1-.25-.25v-.5zm-2 0A.25.25 0 0 1 9.25 6h.5a.25.25 0 0 1 .25.25v.5a.25.25 0 0 1-.25.25h-.5A.25.25 0 0 1 9 6.75v-.5zm-2 0A.25.25 0 0 1 7.25 6h.5a.25.25 0 0 1 .25.25v.5a.25.25 0 0 1-.25.25h-.5A.25.25 0 0 1 7 6.75v-.5zm-2 0A.25.25 0 0 1 5.25 6h.5a.25.25 0 0 1 .25.25v.5a.25.25 0 0 1-.25.25h-.5A.25.25 0 0 1 5 6.75v-.5zm-3 0A.25.25 0 0 1 2.25 6h1.5a.25.25 0 0 1 .25.25v.5a.25.25 0 0 1-.25.25h-1.5A.25.25 0 0 1 2 6.75v-.5zm0 4a.25.25 0 0 1 .25-.25h.5a.25.25 0 0 1 .25.25v.5a.25.25 0 0 1-.25.25h-.5a.25.25 0 0 1-.25-.25v-.5zm2 0a.25.25 0 0 1 .25-.25h5.5a.25.25 0 0 1 .25.25v.5a.25.25 0 0 1-.25.25h-5.5a.25.25 0 0 1-.25-.25v-.5z\"}}]})(props);\n};\nexport function BsLadder (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 1a.5.5 0 0 1 .5.5V2h6v-.5a.5.5 0 0 1 1 0v14a.5.5 0 0 1-1 0V15H5v.5a.5.5 0 0 1-1 0v-14a.5.5 0 0 1 .5-.5zM5 14h6v-2H5v2zm0-3h6V9H5v2zm0-3h6V6H5v2zm0-3h6V3H5v2z\"}}]})(props);\n};\nexport function BsLampFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 3a1 1 0 0 1 1-1h10a1 1 0 0 1 1 1v4a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V3zm5.5-2 .276-.553a.25.25 0 0 1 .448 0L8.5 1h-1zm-.615 8h2.23C9.968 10.595 11 12.69 11 13.5c0 1.38-1.343 2.5-3 2.5s-3-1.12-3-2.5c0-.81 1.032-2.905 1.885-4.5z\"}}]})(props);\n};\nexport function BsLamp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13 3v4H3V3h10zM3 2a1 1 0 0 0-1 1v4a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H3zm4.5-1 .276-.553a.25.25 0 0 1 .448 0L8.5 1h-1zm-.012 9h1.024c.337.646.677 1.33.95 1.949.176.396.318.75.413 1.042.048.146.081.266.102.36A1.347 1.347 0 0 1 10 13.5c0 .665-.717 1.5-2 1.5s-2-.835-2-1.5c0 0 0-.013.004-.039.003-.027.01-.063.02-.11.02-.094.053-.214.1-.36.096-.291.238-.646.413-1.042.274-.62.614-1.303.95-1.949zm1.627-1h-2.23C6.032 10.595 5 12.69 5 13.5 5 14.88 6.343 16 8 16s3-1.12 3-2.5c0-.81-1.032-2.905-1.885-4.5z\"}}]})(props);\n};\nexport function BsLaptopFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 2A1.5 1.5 0 0 0 1 3.5V12h14V3.5A1.5 1.5 0 0 0 13.5 2h-11zM0 12.5h16a1.5 1.5 0 0 1-1.5 1.5h-13A1.5 1.5 0 0 1 0 12.5z\"}}]})(props);\n};\nexport function BsLaptop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 3a.5.5 0 0 1 .5.5V11H2V3.5a.5.5 0 0 1 .5-.5h11zm-11-1A1.5 1.5 0 0 0 1 3.5V12h14V3.5A1.5 1.5 0 0 0 13.5 2h-11zM0 12.5h16a1.5 1.5 0 0 1-1.5 1.5h-13A1.5 1.5 0 0 1 0 12.5z\"}}]})(props);\n};\nexport function BsLayerBackward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.354 15.854a.5.5 0 0 1-.708 0l-3-3a.5.5 0 0 1 0-.708l1-1a.5.5 0 0 1 .708 0l.646.647V4H1a1 1 0 0 1-1-1V1a1 1 0 0 1 1-1h14a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1H9v7.793l.646-.647a.5.5 0 0 1 .708 0l1 1a.5.5 0 0 1 0 .708l-3 3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 9a1 1 0 0 1-1-1V6a1 1 0 0 1 1-1h4.5a.5.5 0 0 1 0 1H1v2h4.5a.5.5 0 0 1 0 1H1zm9.5 0a.5.5 0 0 1 0-1H15V6h-4.5a.5.5 0 0 1 0-1H15a1 1 0 0 1 1 1v2a1 1 0 0 1-1 1h-4.5z\"}}]})(props);\n};\nexport function BsLayerForward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.354.146a.5.5 0 0 0-.708 0l-3 3a.5.5 0 0 0 0 .708l1 1a.5.5 0 0 0 .708 0L7 4.207V12H1a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h14a1 1 0 0 0 1-1v-2a1 1 0 0 0-1-1H9V4.207l.646.647a.5.5 0 0 0 .708 0l1-1a.5.5 0 0 0 0-.708l-3-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 7a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h4.5a.5.5 0 0 0 0-1H1V8h4.5a.5.5 0 0 0 0-1H1zm9.5 0a.5.5 0 0 0 0 1H15v2h-4.5a.5.5 0 0 0 0 1H15a1 1 0 0 0 1-1V8a1 1 0 0 0-1-1h-4.5z\"}}]})(props);\n};\nexport function BsLayersFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.765 1.559a.5.5 0 0 1 .47 0l7.5 4a.5.5 0 0 1 0 .882l-7.5 4a.5.5 0 0 1-.47 0l-7.5-4a.5.5 0 0 1 0-.882l7.5-4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m2.125 8.567-1.86.992a.5.5 0 0 0 0 .882l7.5 4a.5.5 0 0 0 .47 0l7.5-4a.5.5 0 0 0 0-.882l-1.86-.992-5.17 2.756a1.5 1.5 0 0 1-1.41 0l-5.17-2.756z\"}}]})(props);\n};\nexport function BsLayersHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.235 1.559a.5.5 0 0 0-.47 0l-7.5 4a.5.5 0 0 0 0 .882L3.188 8 .264 9.559a.5.5 0 0 0 0 .882l7.5 4a.5.5 0 0 0 .47 0l7.5-4a.5.5 0 0 0 0-.882L12.813 8l2.922-1.559a.5.5 0 0 0 0-.882l-7.5-4zM8 9.433 1.562 6 8 2.567 14.438 6 8 9.433z\"}}]})(props);\n};\nexport function BsLayers (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.235 1.559a.5.5 0 0 0-.47 0l-7.5 4a.5.5 0 0 0 0 .882L3.188 8 .264 9.559a.5.5 0 0 0 0 .882l7.5 4a.5.5 0 0 0 .47 0l7.5-4a.5.5 0 0 0 0-.882L12.813 8l2.922-1.559a.5.5 0 0 0 0-.882l-7.5-4zm3.515 7.008L14.438 10 8 13.433 1.562 10 4.25 8.567l3.515 1.874a.5.5 0 0 0 .47 0l3.515-1.874zM8 9.433 1.562 6 8 2.567 14.438 6 8 9.433z\"}}]})(props);\n};\nexport function BsLayoutSidebarInsetReverse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a1 1 0 0 0-1 1v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H2zm12-1a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h12z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 4a1 1 0 0 0-1-1h-2a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1V4z\"}}]})(props);\n};\nexport function BsLayoutSidebarInset (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 2a1 1 0 0 1 1 1v10a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V3a1 1 0 0 1 1-1h12zM2 1a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V3a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 4a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V4z\"}}]})(props);\n};\nexport function BsLayoutSidebarReverse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 3a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V3zm-5-1v12H2a1 1 0 0 1-1-1V3a1 1 0 0 1 1-1h9zm1 0h2a1 1 0 0 1 1 1v10a1 1 0 0 1-1 1h-2V2z\"}}]})(props);\n};\nexport function BsLayoutSidebar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 3a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3zm5-1v12h9a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H5zM4 2H2a1 1 0 0 0-1 1v10a1 1 0 0 0 1 1h2V2z\"}}]})(props);\n};\nexport function BsLayoutSplit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 3a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3zm8.5-1v12H14a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1H8.5zm-1 0H2a1 1 0 0 0-1 1v10a1 1 0 0 0 1 1h5.5V2z\"}}]})(props);\n};\nexport function BsLayoutTextSidebarReverse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 3a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1h5zm0 3a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1h5zm.5 3.5a.5.5 0 0 0-.5-.5h-5a.5.5 0 0 0 0 1h5a.5.5 0 0 0 .5-.5zm-.5 2.5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1h5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 2a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2zM4 1v14H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h2zm1 0h9a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H5V1z\"}}]})(props);\n};\nexport function BsLayoutTextSidebar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 3a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5zm0 3a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5zM3 9.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm.5 2.5a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm12-1v14h2a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1h-2zm-1 0H2a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h9V1z\"}}]})(props);\n};\nexport function BsLayoutTextWindowReverse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13 6.5a.5.5 0 0 0-.5-.5h-5a.5.5 0 0 0 0 1h5a.5.5 0 0 0 .5-.5zm0 3a.5.5 0 0 0-.5-.5h-5a.5.5 0 0 0 0 1h5a.5.5 0 0 0 .5-.5zm-.5 2.5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1 0-1h5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 0a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12zM2 1a1 1 0 0 0-1 1v1h14V2a1 1 0 0 0-1-1H2zM1 4v10a1 1 0 0 0 1 1h2V4H1zm4 0v11h9a1 1 0 0 0 1-1V4H5z\"}}]})(props);\n};\nexport function BsLayoutTextWindow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 6.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm0 3a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm.5 2.5a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm12 1a1 1 0 0 1 1 1v1H1V2a1 1 0 0 1 1-1h12zm1 3v10a1 1 0 0 1-1 1h-2V4h3zm-4 0v11H2a1 1 0 0 1-1-1V4h10z\"}}]})(props);\n};\nexport function BsLayoutThreeColumns (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1.5A1.5 1.5 0 0 1 1.5 0h13A1.5 1.5 0 0 1 16 1.5v13a1.5 1.5 0 0 1-1.5 1.5h-13A1.5 1.5 0 0 1 0 14.5v-13zM1.5 1a.5.5 0 0 0-.5.5v13a.5.5 0 0 0 .5.5H5V1H1.5zM10 15V1H6v14h4zm1 0h3.5a.5.5 0 0 0 .5-.5v-13a.5.5 0 0 0-.5-.5H11v14z\"}}]})(props);\n};\nexport function BsLayoutWtf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 1v8H1V1h4zM1 0a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h4a1 1 0 0 0 1-1V1a1 1 0 0 0-1-1H1zm13 2v5H9V2h5zM9 1a1 1 0 0 0-1 1v5a1 1 0 0 0 1 1h5a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H9zM5 13v2H3v-2h2zm-2-1a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h2a1 1 0 0 0 1-1v-2a1 1 0 0 0-1-1H3zm12-1v2H9v-2h6zm-6-1a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h6a1 1 0 0 0 1-1v-2a1 1 0 0 0-1-1H9z\"}}]})(props);\n};\nexport function BsLifePreserver (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zm6.43-5.228a7.025 7.025 0 0 1-3.658 3.658l-1.115-2.788a4.015 4.015 0 0 0 1.985-1.985l2.788 1.115zM5.228 14.43a7.025 7.025 0 0 1-3.658-3.658l2.788-1.115a4.015 4.015 0 0 0 1.985 1.985L5.228 14.43zm9.202-9.202-2.788 1.115a4.015 4.015 0 0 0-1.985-1.985l1.115-2.788a7.025 7.025 0 0 1 3.658 3.658zm-8.087-.87a4.015 4.015 0 0 0-1.985 1.985L1.57 5.228A7.025 7.025 0 0 1 5.228 1.57l1.115 2.788zM8 11a3 3 0 1 1 0-6 3 3 0 0 1 0 6z\"}}]})(props);\n};\nexport function BsLightbulbFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 6a6 6 0 1 1 10.174 4.31c-.203.196-.359.4-.453.619l-.762 1.769A.5.5 0 0 1 10.5 13h-5a.5.5 0 0 1-.46-.302l-.761-1.77a1.964 1.964 0 0 0-.453-.618A5.984 5.984 0 0 1 2 6zm3 8.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1l-.224.447a1 1 0 0 1-.894.553H6.618a1 1 0 0 1-.894-.553L5.5 15a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsLightbulbOffFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 6c0-.572.08-1.125.23-1.65l8.558 8.559A.5.5 0 0 1 10.5 13h-5a.5.5 0 0 1-.46-.302l-.761-1.77a1.964 1.964 0 0 0-.453-.618A5.984 5.984 0 0 1 2 6zm10.303 4.181L3.818 1.697a6 6 0 0 1 8.484 8.484zM5 14.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1l-.224.447a1 1 0 0 1-.894.553H6.618a1 1 0 0 1-.894-.553L5.5 15a.5.5 0 0 1-.5-.5zM2.354 1.646a.5.5 0 1 0-.708.708l12 12a.5.5 0 0 0 .708-.708l-12-12z\"}}]})(props);\n};\nexport function BsLightbulbOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2.23 4.35A6.004 6.004 0 0 0 2 6c0 1.691.7 3.22 1.826 4.31.203.196.359.4.453.619l.762 1.769A.5.5 0 0 0 5.5 13a.5.5 0 0 0 0 1 .5.5 0 0 0 0 1l.224.447a1 1 0 0 0 .894.553h2.764a1 1 0 0 0 .894-.553L10.5 15a.5.5 0 0 0 0-1 .5.5 0 0 0 0-1 .5.5 0 0 0 .288-.091L9.878 12H5.83l-.632-1.467a2.954 2.954 0 0 0-.676-.941 4.984 4.984 0 0 1-1.455-4.405l-.837-.836zm1.588-2.653.708.707a5 5 0 0 1 7.07 7.07l.707.707a6 6 0 0 0-8.484-8.484zm-2.172-.051a.5.5 0 0 1 .708 0l12 12a.5.5 0 0 1-.708.708l-12-12a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsLightbulb (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 6a6 6 0 1 1 10.174 4.31c-.203.196-.359.4-.453.619l-.762 1.769A.5.5 0 0 1 10.5 13a.5.5 0 0 1 0 1 .5.5 0 0 1 0 1l-.224.447a1 1 0 0 1-.894.553H6.618a1 1 0 0 1-.894-.553L5.5 15a.5.5 0 0 1 0-1 .5.5 0 0 1 0-1 .5.5 0 0 1-.46-.302l-.761-1.77a1.964 1.964 0 0 0-.453-.618A5.984 5.984 0 0 1 2 6zm6-5a5 5 0 0 0-3.479 8.592c.263.254.514.564.676.941L5.83 12h4.342l.632-1.467c.162-.377.413-.687.676-.941A5 5 0 0 0 8 1z\"}}]})(props);\n};\nexport function BsLightningChargeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.251.068a.5.5 0 0 1 .227.58L9.677 6.5H13a.5.5 0 0 1 .364.843l-8 8.5a.5.5 0 0 1-.842-.49L6.323 9.5H3a.5.5 0 0 1-.364-.843l8-8.5a.5.5 0 0 1 .615-.09z\"}}]})(props);\n};\nexport function BsLightningCharge (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.251.068a.5.5 0 0 1 .227.58L9.677 6.5H13a.5.5 0 0 1 .364.843l-8 8.5a.5.5 0 0 1-.842-.49L6.323 9.5H3a.5.5 0 0 1-.364-.843l8-8.5a.5.5 0 0 1 .615-.09zM4.157 8.5H7a.5.5 0 0 1 .478.647L6.11 13.59l5.732-6.09H9a.5.5 0 0 1-.478-.647L9.89 2.41 4.157 8.5z\"}}]})(props);\n};\nexport function BsLightningFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.52.359A.5.5 0 0 1 6 0h4a.5.5 0 0 1 .474.658L8.694 6H12.5a.5.5 0 0 1 .395.807l-7 9a.5.5 0 0 1-.873-.454L6.823 9.5H3.5a.5.5 0 0 1-.48-.641l2.5-8.5z\"}}]})(props);\n};\nexport function BsLightning (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.52.359A.5.5 0 0 1 6 0h4a.5.5 0 0 1 .474.658L8.694 6H12.5a.5.5 0 0 1 .395.807l-7 9a.5.5 0 0 1-.873-.454L6.823 9.5H3.5a.5.5 0 0 1-.48-.641l2.5-8.5zM6.374 1 4.168 8.5H7.5a.5.5 0 0 1 .478.647L6.78 13.04 11.478 7H8a.5.5 0 0 1-.474-.658L9.306 1H6.374z\"}}]})(props);\n};\nexport function BsLine (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 0c4.411 0 8 2.912 8 6.492 0 1.433-.555 2.723-1.715 3.994-1.678 1.932-5.431 4.285-6.285 4.645-.83.35-.734-.197-.696-.413l.003-.018.114-.685c.027-.204.055-.521-.026-.723-.09-.223-.444-.339-.704-.395C2.846 12.39 0 9.701 0 6.492 0 2.912 3.59 0 8 0zM5.022 7.686H3.497V4.918a.156.156 0 0 0-.155-.156H2.78a.156.156 0 0 0-.156.156v3.486c0 .041.017.08.044.107v.001l.002.002.002.002a.154.154 0 0 0 .108.043h2.242c.086 0 .155-.07.155-.156v-.56a.156.156 0 0 0-.155-.157zm.791-2.924h.562c.086 0 .155.07.155.156v3.486c0 .086-.07.155-.155.155h-.562a.156.156 0 0 1-.156-.155V4.918c0-.086.07-.156.156-.156zm3.863 0h.56c.087 0 .157.07.157.156v3.486c0 .086-.07.155-.156.155h-.561a.155.155 0 0 1-.04-.005h-.002a.168.168 0 0 1-.011-.004l-.005-.002-.007-.003a.066.066 0 0 1-.008-.004L9.6 8.54l-.01-.006-.001-.001a.154.154 0 0 1-.04-.039l-1.6-2.16v2.07a.155.155 0 0 1-.155.156h-.561a.156.156 0 0 1-.156-.155V4.918c0-.086.07-.156.156-.156H7.8l.005.001h.006l.003.001h.006l.01.003h.002l.002.001.01.003.005.002a.09.09 0 0 1 .009.004l.003.001.002.001a.113.113 0 0 1 .013.008l.003.002.005.003v.001c.002 0 .003.002.004.003a.092.092 0 0 1 .008.006l.003.003a.17.17 0 0 1 .023.026L9.52 6.99V4.918c0-.086.07-.156.156-.156zm3.815.717c0 .086-.07.156-.155.156H11.81v.59h1.525c.086 0 .155.07.155.155v.561c0 .086-.07.156-.155.156H11.81v.59h1.525c.086 0 .155.07.155.155v.561c0 .086-.07.156-.155.156h-2.242a.155.155 0 0 1-.11-.045l-.002-.003a.155.155 0 0 1-.044-.107V4.918c0-.042.017-.08.043-.107l.003-.003.001-.001a.155.155 0 0 1 .109-.045h2.242c.086 0 .155.07.155.156v.561z\"}}]})(props);\n};\nexport function BsLink45Deg (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.715 6.542 3.343 7.914a3 3 0 1 0 4.243 4.243l1.828-1.829A3 3 0 0 0 8.586 5.5L8 6.086a1.002 1.002 0 0 0-.154.199 2 2 0 0 1 .861 3.337L6.88 11.45a2 2 0 1 1-2.83-2.83l.793-.792a4.018 4.018 0 0 1-.128-1.287z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.586 4.672A3 3 0 0 0 7.414 9.5l.775-.776a2 2 0 0 1-.896-3.346L9.12 3.55a2 2 0 1 1 2.83 2.83l-.793.792c.112.42.155.855.128 1.287l1.372-1.372a3 3 0 1 0-4.243-4.243L6.586 4.672z\"}}]})(props);\n};\nexport function BsLink (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.354 5.5H4a3 3 0 0 0 0 6h3a3 3 0 0 0 2.83-4H9c-.086 0-.17.01-.25.031A2 2 0 0 1 7 10.5H4a2 2 0 1 1 0-4h1.535c.218-.376.495-.714.82-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5.5a3 3 0 0 0-2.83 4h1.098A2 2 0 0 1 9 6.5h3a2 2 0 1 1 0 4h-1.535a4.02 4.02 0 0 1-.82 1H12a3 3 0 1 0 0-6H9z\"}}]})(props);\n};\nexport function BsLinkedin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1.146C0 .513.526 0 1.175 0h13.65C15.474 0 16 .513 16 1.146v13.708c0 .633-.526 1.146-1.175 1.146H1.175C.526 16 0 15.487 0 14.854V1.146zm4.943 12.248V6.169H2.542v7.225h2.401zm-1.2-8.212c.837 0 1.358-.554 1.358-1.248-.015-.709-.52-1.248-1.342-1.248-.822 0-1.359.54-1.359 1.248 0 .694.521 1.248 1.327 1.248h.016zm4.908 8.212V9.359c0-.216.016-.432.08-.586.173-.431.568-.878 1.232-.878.869 0 1.216.662 1.216 1.634v3.865h2.401V9.25c0-2.22-1.184-3.252-2.764-3.252-1.274 0-1.845.7-2.165 1.193v.025h-.016a5.54 5.54 0 0 1 .016-.025V6.169h-2.4c.03.678 0 7.225 0 7.225h2.4z\"}}]})(props);\n};\nexport function BsListCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5 11.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0-4a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0-4a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zM3.854 2.146a.5.5 0 0 1 0 .708l-1.5 1.5a.5.5 0 0 1-.708 0l-.5-.5a.5.5 0 1 1 .708-.708L2 3.293l1.146-1.147a.5.5 0 0 1 .708 0zm0 4a.5.5 0 0 1 0 .708l-1.5 1.5a.5.5 0 0 1-.708 0l-.5-.5a.5.5 0 1 1 .708-.708L2 7.293l1.146-1.147a.5.5 0 0 1 .708 0zm0 4a.5.5 0 0 1 0 .708l-1.5 1.5a.5.5 0 0 1-.708 0l-.5-.5a.5.5 0 0 1 .708-.708l.146.147 1.146-1.147a.5.5 0 0 1 .708 0z\"}}]})(props);\n};\nexport function BsListNested (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4.5 11.5A.5.5 0 0 1 5 11h10a.5.5 0 0 1 0 1H5a.5.5 0 0 1-.5-.5zm-2-4A.5.5 0 0 1 3 7h10a.5.5 0 0 1 0 1H3a.5.5 0 0 1-.5-.5zm-2-4A.5.5 0 0 1 1 3h10a.5.5 0 0 1 0 1H1a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsListOl (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5 11.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0-4a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0-4a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1.713 11.865v-.474H2c.217 0 .363-.137.363-.317 0-.185-.158-.31-.361-.31-.223 0-.367.152-.373.31h-.59c.016-.467.373-.787.986-.787.588-.002.954.291.957.703a.595.595 0 0 1-.492.594v.033a.615.615 0 0 1 .569.631c.003.533-.502.8-1.051.8-.656 0-1-.37-1.008-.794h.582c.008.178.186.306.422.309.254 0 .424-.145.422-.35-.002-.195-.155-.348-.414-.348h-.3zm-.004-4.699h-.604v-.035c0-.408.295-.844.958-.844.583 0 .96.326.96.756 0 .389-.257.617-.476.848l-.537.572v.03h1.054V9H1.143v-.395l.957-.99c.138-.142.293-.304.293-.508 0-.18-.147-.32-.342-.32a.33.33 0 0 0-.342.338v.041zM2.564 5h-.635V2.924h-.031l-.598.42v-.567l.629-.443h.635V5z\"}}]})(props);\n};\nexport function BsListStars (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5 11.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0-4a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0-4a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.242 2.194a.27.27 0 0 1 .516 0l.162.53c.035.115.14.194.258.194h.551c.259 0 .37.333.164.493l-.468.363a.277.277 0 0 0-.094.3l.173.569c.078.256-.213.462-.423.3l-.417-.324a.267.267 0 0 0-.328 0l-.417.323c-.21.163-.5-.043-.423-.299l.173-.57a.277.277 0 0 0-.094-.299l-.468-.363c-.206-.16-.095-.493.164-.493h.55a.271.271 0 0 0 .259-.194l.162-.53zm0 4a.27.27 0 0 1 .516 0l.162.53c.035.115.14.194.258.194h.551c.259 0 .37.333.164.493l-.468.363a.277.277 0 0 0-.094.3l.173.569c.078.255-.213.462-.423.3l-.417-.324a.267.267 0 0 0-.328 0l-.417.323c-.21.163-.5-.043-.423-.299l.173-.57a.277.277 0 0 0-.094-.299l-.468-.363c-.206-.16-.095-.493.164-.493h.55a.271.271 0 0 0 .259-.194l.162-.53zm0 4a.27.27 0 0 1 .516 0l.162.53c.035.115.14.194.258.194h.551c.259 0 .37.333.164.493l-.468.363a.277.277 0 0 0-.094.3l.173.569c.078.255-.213.462-.423.3l-.417-.324a.267.267 0 0 0-.328 0l-.417.323c-.21.163-.5-.043-.423-.299l.173-.57a.277.277 0 0 0-.094-.299l-.468-.363c-.206-.16-.095-.493.164-.493h.55a.271.271 0 0 0 .259-.194l.162-.53z\"}}]})(props);\n};\nexport function BsListTask (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 2.5a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5V3a.5.5 0 0 0-.5-.5H2zM3 3H2v1h1V3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 3.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zM5.5 7a.5.5 0 0 0 0 1h9a.5.5 0 0 0 0-1h-9zm0 4a.5.5 0 0 0 0 1h9a.5.5 0 0 0 0-1h-9z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.5 7a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5H2a.5.5 0 0 1-.5-.5V7zM2 7h1v1H2V7zm0 3.5a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5H2zm1 .5H2v1h1v-1z\"}}]})(props);\n};\nexport function BsListUl (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5 11.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0-4a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0-4a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm-3 1a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm0 4a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm0 4a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsList (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2.5 12a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 0 1H3a.5.5 0 0 1-.5-.5zm0-4a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 0 1H3a.5.5 0 0 1-.5-.5zm0-4a.5.5 0 0 1 .5-.5h10a.5.5 0 0 1 0 1H3a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsLockFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a2 2 0 0 1 2 2v4H6V3a2 2 0 0 1 2-2zm3 6V3a3 3 0 0 0-6 0v4a2 2 0 0 0-2 2v5a2 2 0 0 0 2 2h6a2 2 0 0 0 2-2V9a2 2 0 0 0-2-2z\"}}]})(props);\n};\nexport function BsLock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a2 2 0 0 1 2 2v4H6V3a2 2 0 0 1 2-2zm3 6V3a3 3 0 0 0-6 0v4a2 2 0 0 0-2 2v5a2 2 0 0 0 2 2h6a2 2 0 0 0 2-2V9a2 2 0 0 0-2-2zM5 8h6a1 1 0 0 1 1 1v5a1 1 0 0 1-1 1H5a1 1 0 0 1-1-1V9a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsMailbox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4a3 3 0 0 0-3 3v6h6V7a3 3 0 0 0-3-3zm0-1h8a4 4 0 0 1 4 4v6a1 1 0 0 1-1 1H1a1 1 0 0 1-1-1V7a4 4 0 0 1 4-4zm2.646 1A3.99 3.99 0 0 1 8 7v6h7V7a3 3 0 0 0-3-3H6.646z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.793 8.5H9v-1h5a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.354-.146l-.853-.854zM5 7c0 .552-.448 0-1 0s-1 .552-1 0a1 1 0 0 1 2 0z\"}}]})(props);\n};\nexport function BsMailbox2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9 8.5h2.793l.853.854A.5.5 0 0 0 13 9.5h1a.5.5 0 0 0 .5-.5V8a.5.5 0 0 0-.5-.5H9v1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12 3H4a4 4 0 0 0-4 4v6a1 1 0 0 0 1 1h14a1 1 0 0 0 1-1V7a4 4 0 0 0-4-4zM8 7a3.99 3.99 0 0 0-1.354-3H12a3 3 0 0 1 3 3v6H8V7zm-3.415.157C4.42 7.087 4.218 7 4 7c-.218 0-.42.086-.585.157C3.164 7.264 3 7.334 3 7a1 1 0 0 1 2 0c0 .334-.164.264-.415.157z\"}}]})(props);\n};\nexport function BsMapFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M16 .5a.5.5 0 0 0-.598-.49L10.5.99 5.598.01a.5.5 0 0 0-.196 0l-5 1A.5.5 0 0 0 0 1.5v14a.5.5 0 0 0 .598.49l4.902-.98 4.902.98a.502.502 0 0 0 .196 0l5-1A.5.5 0 0 0 16 14.5V.5zM5 14.09V1.11l.5-.1.5.1v12.98l-.402-.08a.498.498 0 0 0-.196 0L5 14.09zm5 .8V1.91l.402.08a.5.5 0 0 0 .196 0L11 1.91v12.98l-.5.1-.5-.1z\"}}]})(props);\n};\nexport function BsMap (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M15.817.113A.5.5 0 0 1 16 .5v14a.5.5 0 0 1-.402.49l-5 1a.502.502 0 0 1-.196 0L5.5 15.01l-4.902.98A.5.5 0 0 1 0 15.5v-14a.5.5 0 0 1 .402-.49l5-1a.5.5 0 0 1 .196 0L10.5.99l4.902-.98a.5.5 0 0 1 .415.103zM10 1.91l-4-.8v12.98l4 .8V1.91zm1 12.98 4-.8V1.11l-4 .8v12.98zm-6-.8V1.11l-4 .8v12.98l4-.8z\"}}]})(props);\n};\nexport function BsMarkdownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm11.5 1a.5.5 0 0 0-.5.5v3.793L9.854 8.146a.5.5 0 1 0-.708.708l2 2a.5.5 0 0 0 .708 0l2-2a.5.5 0 0 0-.708-.708L12 9.293V5.5a.5.5 0 0 0-.5-.5zM3.56 7.01h.056l1.428 3.239h.774l1.42-3.24h.056V11h1.073V5.001h-1.2l-1.71 3.894h-.039l-1.71-3.894H2.5V11h1.06V7.01z\"}}]})(props);\n};\nexport function BsMarkdown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h12zM2 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M9.146 8.146a.5.5 0 0 1 .708 0L11.5 9.793l1.646-1.647a.5.5 0 0 1 .708.708l-2 2a.5.5 0 0 1-.708 0l-2-2a.5.5 0 0 1 0-.708z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11.5 5a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-1 0v-4a.5.5 0 0 1 .5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.56 11V7.01h.056l1.428 3.239h.774l1.42-3.24h.056V11h1.073V5.001h-1.2l-1.71 3.894h-.039l-1.71-3.894H2.5V11h1.06z\"}}]})(props);\n};\nexport function BsMask (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.225 1.227A7.5 7.5 0 0 1 10.5 8a7.5 7.5 0 0 1-4.275 6.773 7 7 0 1 0 0-13.546zM4.187.966a8 8 0 1 1 7.627 14.069A8 8 0 0 1 4.186.964z\"}}]})(props);\n};\nexport function BsMastodon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.19 12.195c2.016-.24 3.77-1.475 3.99-2.603.348-1.778.32-4.339.32-4.339 0-3.47-2.286-4.488-2.286-4.488C12.062.238 10.083.017 8.027 0h-.05C5.92.017 3.942.238 2.79.765c0 0-2.285 1.017-2.285 4.488l-.002.662c-.004.64-.007 1.35.011 2.091.083 3.394.626 6.74 3.78 7.57 1.454.383 2.703.463 3.709.408 1.823-.1 2.847-.647 2.847-.647l-.06-1.317s-1.303.41-2.767.36c-1.45-.05-2.98-.156-3.215-1.928a3.614 3.614 0 0 1-.033-.496s1.424.346 3.228.428c1.103.05 2.137-.064 3.188-.189zm1.613-2.47H11.13v-4.08c0-.859-.364-1.295-1.091-1.295-.804 0-1.207.517-1.207 1.541v2.233H7.168V5.89c0-1.024-.403-1.541-1.207-1.541-.727 0-1.091.436-1.091 1.296v4.079H3.197V5.522c0-.859.22-1.541.66-2.046.456-.505 1.052-.764 1.793-.764.856 0 1.504.328 1.933.983L8 4.39l.417-.695c.429-.655 1.077-.983 1.934-.983.74 0 1.336.259 1.791.764.442.505.661 1.187.661 2.046v4.203z\"}}]})(props);\n};\nexport function BsMedium (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.025 8c0 2.485-2.02 4.5-4.513 4.5A4.506 4.506 0 0 1 0 8c0-2.486 2.02-4.5 4.512-4.5A4.506 4.506 0 0 1 9.025 8zm4.95 0c0 2.34-1.01 4.236-2.256 4.236-1.246 0-2.256-1.897-2.256-4.236 0-2.34 1.01-4.236 2.256-4.236 1.246 0 2.256 1.897 2.256 4.236zM16 8c0 2.096-.355 3.795-.794 3.795-.438 0-.793-1.7-.793-3.795 0-2.096.355-3.795.794-3.795.438 0 .793 1.699.793 3.795z\"}}]})(props);\n};\nexport function BsMegaphoneFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13 2.5a1.5 1.5 0 0 1 3 0v11a1.5 1.5 0 0 1-3 0v-11zm-1 .724c-2.067.95-4.539 1.481-7 1.656v6.237a25.222 25.222 0 0 1 1.088.085c2.053.204 4.038.668 5.912 1.56V3.224zm-8 7.841V4.934c-.68.027-1.399.043-2.008.053A2.02 2.02 0 0 0 0 7v2c0 1.106.896 1.996 1.994 2.009a68.14 68.14 0 0 1 .496.008 64 64 0 0 1 1.51.048zm1.39 1.081c.285.021.569.047.85.078l.253 1.69a1 1 0 0 1-.983 1.187h-.548a1 1 0 0 1-.916-.599l-1.314-2.48a65.81 65.81 0 0 1 1.692.064c.327.017.65.037.966.06z\"}}]})(props);\n};\nexport function BsMegaphone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13 2.5a1.5 1.5 0 0 1 3 0v11a1.5 1.5 0 0 1-3 0v-.214c-2.162-1.241-4.49-1.843-6.912-2.083l.405 2.712A1 1 0 0 1 5.51 15.1h-.548a1 1 0 0 1-.916-.599l-1.85-3.49a68.14 68.14 0 0 0-.202-.003A2.014 2.014 0 0 1 0 9V7a2.02 2.02 0 0 1 1.992-2.013 74.663 74.663 0 0 0 2.483-.075c3.043-.154 6.148-.849 8.525-2.199V2.5zm1 0v11a.5.5 0 0 0 1 0v-11a.5.5 0 0 0-1 0zm-1 1.35c-2.344 1.205-5.209 1.842-8 2.033v4.233c.18.01.359.022.537.036 2.568.189 5.093.744 7.463 1.993V3.85zm-9 6.215v-4.13a95.09 95.09 0 0 1-1.992.052A1.02 1.02 0 0 0 1 7v2c0 .55.448 1.002 1.006 1.009A60.49 60.49 0 0 1 4 10.065zm-.657.975 1.609 3.037.01.024h.548l-.002-.014-.443-2.966a68.019 68.019 0 0 0-1.722-.082z\"}}]})(props);\n};\nexport function BsMenuAppFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1.5A1.5 1.5 0 0 1 1.5 0h2A1.5 1.5 0 0 1 5 1.5v2A1.5 1.5 0 0 1 3.5 5h-2A1.5 1.5 0 0 1 0 3.5v-2zM0 8a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V8zm1 3v2a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2H1zm14-1V8a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v2h14zM2 8.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0 4a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsMenuApp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1.5A1.5 1.5 0 0 1 1.5 0h2A1.5 1.5 0 0 1 5 1.5v2A1.5 1.5 0 0 1 3.5 5h-2A1.5 1.5 0 0 1 0 3.5v-2zM1.5 1a.5.5 0 0 0-.5.5v2a.5.5 0 0 0 .5.5h2a.5.5 0 0 0 .5-.5v-2a.5.5 0 0 0-.5-.5h-2zM0 8a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V8zm1 3v2a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2H1zm14-1V8a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v2h14zM2 8.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0 4a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsMenuButtonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 0A1.5 1.5 0 0 0 0 1.5v2A1.5 1.5 0 0 0 1.5 5h8A1.5 1.5 0 0 0 11 3.5v-2A1.5 1.5 0 0 0 9.5 0h-8zm5.927 2.427A.25.25 0 0 1 7.604 2h.792a.25.25 0 0 1 .177.427l-.396.396a.25.25 0 0 1-.354 0l-.396-.396zM0 8a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V8zm1 3v2a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2H1zm14-1V8a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v2h14zM2 8.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0 4a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsMenuButtonWideFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 0A1.5 1.5 0 0 0 0 1.5v2A1.5 1.5 0 0 0 1.5 5h13A1.5 1.5 0 0 0 16 3.5v-2A1.5 1.5 0 0 0 14.5 0h-13zm1 2h3a.5.5 0 0 1 0 1h-3a.5.5 0 0 1 0-1zm9.927.427A.25.25 0 0 1 12.604 2h.792a.25.25 0 0 1 .177.427l-.396.396a.25.25 0 0 1-.354 0l-.396-.396zM0 8a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V8zm1 3v2a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2H1zm14-1V8a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v2h14zM2 8.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0 4a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsMenuButtonWide (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1.5A1.5 1.5 0 0 1 1.5 0h13A1.5 1.5 0 0 1 16 1.5v2A1.5 1.5 0 0 1 14.5 5h-13A1.5 1.5 0 0 1 0 3.5v-2zM1.5 1a.5.5 0 0 0-.5.5v2a.5.5 0 0 0 .5.5h13a.5.5 0 0 0 .5-.5v-2a.5.5 0 0 0-.5-.5h-13z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2.5a.5.5 0 0 1 .5-.5h3a.5.5 0 0 1 0 1h-3a.5.5 0 0 1-.5-.5zm10.823.323-.396-.396A.25.25 0 0 1 12.604 2h.792a.25.25 0 0 1 .177.427l-.396.396a.25.25 0 0 1-.354 0zM0 8a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V8zm1 3v2a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2H1zm14-1V8a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v2h14zM2 8.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0 4a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsMenuButton (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1.5A1.5 1.5 0 0 1 1.5 0h8A1.5 1.5 0 0 1 11 1.5v2A1.5 1.5 0 0 1 9.5 5h-8A1.5 1.5 0 0 1 0 3.5v-2zM1.5 1a.5.5 0 0 0-.5.5v2a.5.5 0 0 0 .5.5h8a.5.5 0 0 0 .5-.5v-2a.5.5 0 0 0-.5-.5h-8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m7.823 2.823-.396-.396A.25.25 0 0 1 7.604 2h.792a.25.25 0 0 1 .177.427l-.396.396a.25.25 0 0 1-.354 0zM0 8a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V8zm1 3v2a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2H1zm14-1V8a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v2h14zM2 8.5a.5.5 0 0 1 .5-.5h9a.5.5 0 0 1 0 1h-9a.5.5 0 0 1-.5-.5zm0 4a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsMenuDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.646.146a.5.5 0 0 1 .708 0L10.207 2H14a2 2 0 0 1 2 2v9a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h3.793L7.646.146zM1 7v3h14V7H1zm14-1V4a1 1 0 0 0-1-1h-3.793a1 1 0 0 1-.707-.293L8 1.207l-1.5 1.5A1 1 0 0 1 5.793 3H2a1 1 0 0 0-1 1v2h14zm0 5H1v2a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2zM2 4.5a.5.5 0 0 1 .5-.5h8a.5.5 0 0 1 0 1h-8a.5.5 0 0 1-.5-.5zm0 4a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5zm0 4a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsMenuUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.646 15.854a.5.5 0 0 0 .708 0L10.207 14H14a2 2 0 0 0 2-2V3a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v9a2 2 0 0 0 2 2h3.793l1.853 1.854zM1 9V6h14v3H1zm14 1v2a1 1 0 0 1-1 1h-3.793a1 1 0 0 0-.707.293l-1.5 1.5-1.5-1.5A1 1 0 0 0 5.793 13H2a1 1 0 0 1-1-1v-2h14zm0-5H1V3a1 1 0 0 1 1-1h12a1 1 0 0 1 1 1v2zM2 11.5a.5.5 0 0 0 .5.5h8a.5.5 0 0 0 0-1h-8a.5.5 0 0 0-.5.5zm0-4a.5.5 0 0 0 .5.5h11a.5.5 0 0 0 0-1h-11a.5.5 0 0 0-.5.5zm0-4a.5.5 0 0 0 .5.5h6a.5.5 0 0 0 0-1h-6a.5.5 0 0 0-.5.5z\"}}]})(props);\n};\nexport function BsMessenger (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 7.76C0 3.301 3.493 0 8 0s8 3.301 8 7.76-3.493 7.76-8 7.76c-.81 0-1.586-.107-2.316-.307a.639.639 0 0 0-.427.03l-1.588.702a.64.64 0 0 1-.898-.566l-.044-1.423a.639.639 0 0 0-.215-.456C.956 12.108 0 10.092 0 7.76zm5.546-1.459-2.35 3.728c-.225.358.214.761.551.506l2.525-1.916a.48.48 0 0 1 .578-.002l1.869 1.402a1.2 1.2 0 0 0 1.735-.32l2.35-3.728c.226-.358-.214-.761-.551-.506L9.728 7.381a.48.48 0 0 1-.578.002L7.281 5.98a1.2 1.2 0 0 0-1.735.32z\"}}]})(props);\n};\nexport function BsMicFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 3a3 3 0 0 1 6 0v5a3 3 0 0 1-6 0V3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 6.5A.5.5 0 0 1 4 7v1a4 4 0 0 0 8 0V7a.5.5 0 0 1 1 0v1a5 5 0 0 1-4.5 4.975V15h3a.5.5 0 0 1 0 1h-7a.5.5 0 0 1 0-1h3v-2.025A5 5 0 0 1 3 8V7a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsMicMuteFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13 8c0 .564-.094 1.107-.266 1.613l-.814-.814A4.02 4.02 0 0 0 12 8V7a.5.5 0 0 1 1 0v1zm-5 4c.818 0 1.578-.245 2.212-.667l.718.719a4.973 4.973 0 0 1-2.43.923V15h3a.5.5 0 0 1 0 1h-7a.5.5 0 0 1 0-1h3v-2.025A5 5 0 0 1 3 8V7a.5.5 0 0 1 1 0v1a4 4 0 0 0 4 4zm3-9v4.879L5.158 2.037A3.001 3.001 0 0 1 11 3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.486 10.607 5 6.12V8a3 3 0 0 0 4.486 2.607zm-7.84-9.253 12 12 .708-.708-12-12-.708.708z\"}}]})(props);\n};\nexport function BsMicMute (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13 8c0 .564-.094 1.107-.266 1.613l-.814-.814A4.02 4.02 0 0 0 12 8V7a.5.5 0 0 1 1 0v1zm-5 4c.818 0 1.578-.245 2.212-.667l.718.719a4.973 4.973 0 0 1-2.43.923V15h3a.5.5 0 0 1 0 1h-7a.5.5 0 0 1 0-1h3v-2.025A5 5 0 0 1 3 8V7a.5.5 0 0 1 1 0v1a4 4 0 0 0 4 4zm3-9v4.879l-1-1V3a2 2 0 0 0-3.997-.118l-.845-.845A3.001 3.001 0 0 1 11 3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m9.486 10.607-.748-.748A2 2 0 0 1 6 8v-.878l-1-1V8a3 3 0 0 0 4.486 2.607zm-7.84-9.253 12 12 .708-.708-12-12-.708.708z\"}}]})(props);\n};\nexport function BsMic (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 6.5A.5.5 0 0 1 4 7v1a4 4 0 0 0 8 0V7a.5.5 0 0 1 1 0v1a5 5 0 0 1-4.5 4.975V15h3a.5.5 0 0 1 0 1h-7a.5.5 0 0 1 0-1h3v-2.025A5 5 0 0 1 3 8V7a.5.5 0 0 1 .5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 8a2 2 0 1 1-4 0V3a2 2 0 1 1 4 0v5zM8 0a3 3 0 0 0-3 3v5a3 3 0 0 0 6 0V3a3 3 0 0 0-3-3z\"}}]})(props);\n};\nexport function BsMicrosoft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.462 0H0v7.19h7.462V0zM16 0H8.538v7.19H16V0zM7.462 8.211H0V16h7.462V8.211zm8.538 0H8.538V16H16V8.211z\"}}]})(props);\n};\nexport function BsMinecartLoaded (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 15a1 1 0 1 1 0-2 1 1 0 0 1 0 2zm0 1a2 2 0 1 0 0-4 2 2 0 0 0 0 4zm8-1a1 1 0 1 1 0-2 1 1 0 0 1 0 2zm0 1a2 2 0 1 0 0-4 2 2 0 0 0 0 4zM.115 3.18A.5.5 0 0 1 .5 3h15a.5.5 0 0 1 .491.592l-1.5 8A.5.5 0 0 1 14 12H2a.5.5 0 0 1-.491-.408l-1.5-8a.5.5 0 0 1 .106-.411zm.987.82 1.313 7h11.17l1.313-7H1.102z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 1a2.498 2.498 0 0 1 4 0c.818 0 1.545.394 2 1 .67 0 1.552.57 2 1h-2c-.314 0-.611-.15-.8-.4-.274-.365-.71-.6-1.2-.6-.314 0-.611-.15-.8-.4a1.497 1.497 0 0 0-2.4 0c-.189.25-.486.4-.8.4-.507 0-.955.251-1.228.638-.09.13-.194.25-.308.362H3c.13-.147.401-.432.562-.545a1.63 1.63 0 0 0 .393-.393A2.498 2.498 0 0 1 6 1z\"}}]})(props);\n};\nexport function BsMinecart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 15a1 1 0 1 1 0-2 1 1 0 0 1 0 2zm0 1a2 2 0 1 0 0-4 2 2 0 0 0 0 4zm8-1a1 1 0 1 1 0-2 1 1 0 0 1 0 2zm0 1a2 2 0 1 0 0-4 2 2 0 0 0 0 4zM.115 3.18A.5.5 0 0 1 .5 3h15a.5.5 0 0 1 .491.592l-1.5 8A.5.5 0 0 1 14 12H2a.5.5 0 0 1-.491-.408l-1.5-8a.5.5 0 0 1 .106-.411zm.987.82 1.313 7h11.17l1.313-7H1.102z\"}}]})(props);\n};\nexport function BsMoisture (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 0a.5.5 0 0 0 0 1H15v2.75h-.5a.5.5 0 0 0 0 1h.5V7.5h-1.5a.5.5 0 0 0 0 1H15v2.75h-.5a.5.5 0 0 0 0 1h.5V15h-1.5a.5.5 0 0 0 0 1h2a.5.5 0 0 0 .5-.5V.5a.5.5 0 0 0-.5-.5h-2zM7 1.5l.364-.343a.5.5 0 0 0-.728 0l-.002.002-.006.007-.022.023-.08.088a28.458 28.458 0 0 0-1.274 1.517c-.769.983-1.714 2.325-2.385 3.727C2.368 7.564 2 8.682 2 9.733 2 12.614 4.212 15 7 15s5-2.386 5-5.267c0-1.05-.368-2.169-.867-3.212-.671-1.402-1.616-2.744-2.385-3.727a28.458 28.458 0 0 0-1.354-1.605l-.022-.023-.006-.007-.002-.001L7 1.5zm0 0-.364-.343L7 1.5zm-.016.766L7 2.247l.016.019c.24.274.572.667.944 1.144.611.781 1.32 1.776 1.901 2.827H4.14c.58-1.051 1.29-2.046 1.9-2.827.373-.477.706-.87.945-1.144zM3 9.733c0-.755.244-1.612.638-2.496h6.724c.395.884.638 1.741.638 2.496C11 12.117 9.182 14 7 14s-4-1.883-4-4.267z\"}}]})(props);\n};\nexport function BsMoonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 .278a.768.768 0 0 1 .08.858 7.208 7.208 0 0 0-.878 3.46c0 4.021 3.278 7.277 7.318 7.277.527 0 1.04-.055 1.533-.16a.787.787 0 0 1 .81.316.733.733 0 0 1-.031.893A8.349 8.349 0 0 1 8.344 16C3.734 16 0 12.286 0 7.71 0 4.266 2.114 1.312 5.124.06A.752.752 0 0 1 6 .278z\"}}]})(props);\n};\nexport function BsMoonStarsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 .278a.768.768 0 0 1 .08.858 7.208 7.208 0 0 0-.878 3.46c0 4.021 3.278 7.277 7.318 7.277.527 0 1.04-.055 1.533-.16a.787.787 0 0 1 .81.316.733.733 0 0 1-.031.893A8.349 8.349 0 0 1 8.344 16C3.734 16 0 12.286 0 7.71 0 4.266 2.114 1.312 5.124.06A.752.752 0 0 1 6 .278z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.794 3.148a.217.217 0 0 1 .412 0l.387 1.162c.173.518.579.924 1.097 1.097l1.162.387a.217.217 0 0 1 0 .412l-1.162.387a1.734 1.734 0 0 0-1.097 1.097l-.387 1.162a.217.217 0 0 1-.412 0l-.387-1.162A1.734 1.734 0 0 0 9.31 6.593l-1.162-.387a.217.217 0 0 1 0-.412l1.162-.387a1.734 1.734 0 0 0 1.097-1.097l.387-1.162zM13.863.099a.145.145 0 0 1 .274 0l.258.774c.115.346.386.617.732.732l.774.258a.145.145 0 0 1 0 .274l-.774.258a1.156 1.156 0 0 0-.732.732l-.258.774a.145.145 0 0 1-.274 0l-.258-.774a1.156 1.156 0 0 0-.732-.732l-.774-.258a.145.145 0 0 1 0-.274l.774-.258c.346-.115.617-.386.732-.732L13.863.1z\"}}]})(props);\n};\nexport function BsMoonStars (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 .278a.768.768 0 0 1 .08.858 7.208 7.208 0 0 0-.878 3.46c0 4.021 3.278 7.277 7.318 7.277.527 0 1.04-.055 1.533-.16a.787.787 0 0 1 .81.316.733.733 0 0 1-.031.893A8.349 8.349 0 0 1 8.344 16C3.734 16 0 12.286 0 7.71 0 4.266 2.114 1.312 5.124.06A.752.752 0 0 1 6 .278zM4.858 1.311A7.269 7.269 0 0 0 1.025 7.71c0 4.02 3.279 7.276 7.319 7.276a7.316 7.316 0 0 0 5.205-2.162c-.337.042-.68.063-1.029.063-4.61 0-8.343-3.714-8.343-8.29 0-1.167.242-2.278.681-3.286z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.794 3.148a.217.217 0 0 1 .412 0l.387 1.162c.173.518.579.924 1.097 1.097l1.162.387a.217.217 0 0 1 0 .412l-1.162.387a1.734 1.734 0 0 0-1.097 1.097l-.387 1.162a.217.217 0 0 1-.412 0l-.387-1.162A1.734 1.734 0 0 0 9.31 6.593l-1.162-.387a.217.217 0 0 1 0-.412l1.162-.387a1.734 1.734 0 0 0 1.097-1.097l.387-1.162zM13.863.099a.145.145 0 0 1 .274 0l.258.774c.115.346.386.617.732.732l.774.258a.145.145 0 0 1 0 .274l-.774.258a1.156 1.156 0 0 0-.732.732l-.258.774a.145.145 0 0 1-.274 0l-.258-.774a1.156 1.156 0 0 0-.732-.732l-.774-.258a.145.145 0 0 1 0-.274l.774-.258c.346-.115.617-.386.732-.732L13.863.1z\"}}]})(props);\n};\nexport function BsMoon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 .278a.768.768 0 0 1 .08.858 7.208 7.208 0 0 0-.878 3.46c0 4.021 3.278 7.277 7.318 7.277.527 0 1.04-.055 1.533-.16a.787.787 0 0 1 .81.316.733.733 0 0 1-.031.893A8.349 8.349 0 0 1 8.344 16C3.734 16 0 12.286 0 7.71 0 4.266 2.114 1.312 5.124.06A.752.752 0 0 1 6 .278zM4.858 1.311A7.269 7.269 0 0 0 1.025 7.71c0 4.02 3.279 7.276 7.319 7.276a7.316 7.316 0 0 0 5.205-2.162c-.337.042-.68.063-1.029.063-4.61 0-8.343-3.714-8.343-8.29 0-1.167.242-2.278.681-3.286z\"}}]})(props);\n};\nexport function BsMouseFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 5a5 5 0 0 1 10 0v6a5 5 0 0 1-10 0V5zm5.5-1.5a.5.5 0 0 0-1 0v2a.5.5 0 0 0 1 0v-2z\"}}]})(props);\n};\nexport function BsMouse (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 3a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 3zm4 8a4 4 0 0 1-8 0V5a4 4 0 1 1 8 0v6zM8 0a5 5 0 0 0-5 5v6a5 5 0 0 0 10 0V5a5 5 0 0 0-5-5z\"}}]})(props);\n};\nexport function BsMouse2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5.026C4.958.286 3 2.515 3 5.188V5.5h4.5V.026zm1 0V5.5H13v-.312C13 2.515 11.042.286 8.5.026zM13 6.5H3v4.313C3 13.658 5.22 16 8 16s5-2.342 5-5.188V6.5z\"}}]})(props);\n};\nexport function BsMouse2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 5.188C3 2.341 5.22 0 8 0s5 2.342 5 5.188v5.625C13 13.658 10.78 16 8 16s-5-2.342-5-5.188V5.189zm4.5-4.155C5.541 1.289 4 3.035 4 5.188V5.5h3.5V1.033zm1 0V5.5H12v-.313c0-2.152-1.541-3.898-3.5-4.154zM12 6.5H4v4.313C4 13.145 5.81 15 8 15s4-1.855 4-4.188V6.5z\"}}]})(props);\n};\nexport function BsMouse3Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5.069A15.328 15.328 0 0 0 7 0c-.593 0-1.104.157-1.527.463-.418.302-.717.726-.93 1.208-.386.873-.522 2.01-.54 3.206l4.497 1V.069zM3.71 5.836 3.381 6A2.5 2.5 0 0 0 2 8.236v2.576C2 13.659 4.22 16 7 16h2c2.78 0 5-2.342 5-5.188V8.123l-9-2v.003l.008.353c.007.3.023.715.053 1.175.063.937.186 2.005.413 2.688a.5.5 0 1 1-.948.316c-.273-.817-.4-2-.462-2.937A30.16 30.16 0 0 1 4 6.003c0-.034.003-.067.01-.1l-.3-.067zM14 7.1V5.187c0-1.13-.272-2.044-.748-2.772-.474-.726-1.13-1.235-1.849-1.59A7.495 7.495 0 0 0 9.5.212v5.887l4.5 1z\"}}]})(props);\n};\nexport function BsMouse3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 0c-.593 0-1.104.157-1.527.463-.418.302-.717.726-.93 1.208C4.123 2.619 4 3.879 4 5.187v.504L3.382 6A2.5 2.5 0 0 0 2 8.236v2.576C2 13.659 4.22 16 7 16h2c2.78 0 5-2.342 5-5.188V7.51a.71.71 0 0 0 0-.02V5.186c0-1.13-.272-2.044-.748-2.772-.474-.726-1.13-1.235-1.849-1.59C9.981.123 8.26 0 7 0zm2.5 6.099V1.232c.51.11 1.008.267 1.46.49.596.293 1.099.694 1.455 1.24.355.543.585 1.262.585 2.225v1.69l-3.5-.778zm-1-5.025v4.803L5 5.099c.006-1.242.134-2.293.457-3.024.162-.366.363-.63.602-.801C6.292 1.105 6.593 1 7 1c.468 0 .98.018 1.5.074zM5 6.124 13 7.9v2.912C13 13.145 11.19 15 9 15H7c-2.19 0-4-1.855-4-4.188V8.236a1.5 1.5 0 0 1 .83-1.342l.187-.093c.01.265.024.58.047.92.062.938.19 2.12.462 2.937a.5.5 0 1 0 .948-.316c-.227-.683-.35-1.75-.413-2.688a29.17 29.17 0 0 1-.06-1.528v-.002z\"}}]})(props);\n};\nexport function BsMusicNoteBeamed (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 13c0 1.105-1.12 2-2.5 2S1 14.105 1 13c0-1.104 1.12-2 2.5-2s2.5.896 2.5 2zm9-2c0 1.105-1.12 2-2.5 2s-2.5-.895-2.5-2 1.12-2 2.5-2 2.5.895 2.5 2z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M14 11V2h1v9h-1zM6 3v10H5V3h1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 2.905a1 1 0 0 1 .9-.995l8-.8a1 1 0 0 1 1.1.995V3L5 4V2.905z\"}}]})(props);\n};\nexport function BsMusicNoteList (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 13c0 1.105-1.12 2-2.5 2S7 14.105 7 13s1.12-2 2.5-2 2.5.895 2.5 2z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M12 3v10h-1V3h1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 2.82a1 1 0 0 1 .804-.98l3-.6A1 1 0 0 1 16 2.22V4l-5 1V2.82z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M0 11.5a.5.5 0 0 1 .5-.5H4a.5.5 0 0 1 0 1H.5a.5.5 0 0 1-.5-.5zm0-4A.5.5 0 0 1 .5 7H8a.5.5 0 0 1 0 1H.5a.5.5 0 0 1-.5-.5zm0-4A.5.5 0 0 1 .5 3H8a.5.5 0 0 1 0 1H.5a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsMusicNote (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9 13c0 1.105-1.12 2-2.5 2S4 14.105 4 13s1.12-2 2.5-2 2.5.895 2.5 2z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M9 3v10H8V3h1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 2.82a1 1 0 0 1 .804-.98l3-.6A1 1 0 0 1 13 2.22V4L8 5V2.82z\"}}]})(props);\n};\nexport function BsMusicPlayerFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm1 2h6a1 1 0 0 1 1 1v2.5a1 1 0 0 1-1 1H5a1 1 0 0 1-1-1V3a1 1 0 0 1 1-1zm3 12a3 3 0 1 1 0-6 3 3 0 0 1 0 6z\"}}]})(props);\n};\nexport function BsMusicPlayer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 3a1 1 0 0 1 1-1h6a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1H5a1 1 0 0 1-1-1V3zm1 0v3h6V3H5zm3 9a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 11a3 3 0 1 1-6 0 3 3 0 0 1 6 0zm-3 2a2 2 0 1 0 0-4 2 2 0 0 0 0 4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm2-1a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H4z\"}}]})(props);\n};\nexport function BsNewspaper (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2.5A1.5 1.5 0 0 1 1.5 1h11A1.5 1.5 0 0 1 14 2.5v10.528c0 .3-.05.654-.238.972h.738a.5.5 0 0 0 .5-.5v-9a.5.5 0 0 1 1 0v9a1.5 1.5 0 0 1-1.5 1.5H1.497A1.497 1.497 0 0 1 0 13.5v-11zM12 14c.37 0 .654-.211.853-.441.092-.106.147-.279.147-.531V2.5a.5.5 0 0 0-.5-.5h-11a.5.5 0 0 0-.5.5v11c0 .278.223.5.497.5H12z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 3h10v2H2V3zm0 3h4v3H2V6zm0 4h4v1H2v-1zm0 2h4v1H2v-1zm5-6h2v1H7V6zm3 0h2v1h-2V6zM7 8h2v1H7V8zm3 0h2v1h-2V8zm-3 2h2v1H7v-1zm3 0h2v1h-2v-1zm-3 2h2v1H7v-1zm3 0h2v1h-2v-1z\"}}]})(props);\n};\nexport function BsNodeMinusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M16 8a5 5 0 0 1-9.975.5H4A1.5 1.5 0 0 1 2.5 10h-1A1.5 1.5 0 0 1 0 8.5v-1A1.5 1.5 0 0 1 1.5 6h1A1.5 1.5 0 0 1 4 7.5h2.025A5 5 0 0 1 16 8zm-2 0a.5.5 0 0 0-.5-.5h-5a.5.5 0 0 0 0 1h5A.5.5 0 0 0 14 8z\"}}]})(props);\n};\nexport function BsNodeMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11 4a4 4 0 1 0 0 8 4 4 0 0 0 0-8zM6.025 7.5a5 5 0 1 1 0 1H4A1.5 1.5 0 0 1 2.5 10h-1A1.5 1.5 0 0 1 0 8.5v-1A1.5 1.5 0 0 1 1.5 6h1A1.5 1.5 0 0 1 4 7.5h2.025zM1.5 7a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1zM8 8a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5A.5.5 0 0 1 8 8z\"}}]})(props);\n};\nexport function BsNodePlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 13a5 5 0 1 0-4.975-5.5H4A1.5 1.5 0 0 0 2.5 6h-1A1.5 1.5 0 0 0 0 7.5v1A1.5 1.5 0 0 0 1.5 10h1A1.5 1.5 0 0 0 4 8.5h2.025A5 5 0 0 0 11 13zm.5-7.5v2h2a.5.5 0 0 1 0 1h-2v2a.5.5 0 0 1-1 0v-2h-2a.5.5 0 0 1 0-1h2v-2a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsNodePlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11 4a4 4 0 1 0 0 8 4 4 0 0 0 0-8zM6.025 7.5a5 5 0 1 1 0 1H4A1.5 1.5 0 0 1 2.5 10h-1A1.5 1.5 0 0 1 0 8.5v-1A1.5 1.5 0 0 1 1.5 6h1A1.5 1.5 0 0 1 4 7.5h2.025zM11 5a.5.5 0 0 1 .5.5v2h2a.5.5 0 0 1 0 1h-2v2a.5.5 0 0 1-1 0v-2h-2a.5.5 0 0 1 0-1h2v-2A.5.5 0 0 1 11 5zM1.5 7a.5.5 0 0 0-.5.5v1a.5.5 0 0 0 .5.5h1a.5.5 0 0 0 .5-.5v-1a.5.5 0 0 0-.5-.5h-1z\"}}]})(props);\n};\nexport function BsNutFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.58 1a1 1 0 0 0-.868.504l-3.428 6a1 1 0 0 0 0 .992l3.428 6A1 1 0 0 0 4.58 15h6.84a1 1 0 0 0 .868-.504l3.429-6a1 1 0 0 0 0-.992l-3.429-6A1 1 0 0 0 11.42 1H4.58zm5.018 9.696a3 3 0 1 1-3-5.196 3 3 0 0 1 3 5.196z\"}}]})(props);\n};\nexport function BsNut (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m11.42 2 3.428 6-3.428 6H4.58L1.152 8 4.58 2h6.84zM4.58 1a1 1 0 0 0-.868.504l-3.428 6a1 1 0 0 0 0 .992l3.428 6A1 1 0 0 0 4.58 15h6.84a1 1 0 0 0 .868-.504l3.429-6a1 1 0 0 0 0-.992l-3.429-6A1 1 0 0 0 11.42 1H4.58z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.848 5.933a2.5 2.5 0 1 0 2.5 4.33 2.5 2.5 0 0 0-2.5-4.33zm-1.78 3.915a3.5 3.5 0 1 1 6.061-3.5 3.5 3.5 0 0 1-6.062 3.5z\"}}]})(props);\n};\nexport function BsOctagonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.107 0a.5.5 0 0 1 .353.146l4.394 4.394a.5.5 0 0 1 .146.353v6.214a.5.5 0 0 1-.146.353l-4.394 4.394a.5.5 0 0 1-.353.146H4.893a.5.5 0 0 1-.353-.146L.146 11.46A.5.5 0 0 1 0 11.107V4.893a.5.5 0 0 1 .146-.353L4.54.146A.5.5 0 0 1 4.893 0h6.214z\"}}]})(props);\n};\nexport function BsOctagonHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.54.146A.5.5 0 0 1 4.893 0h6.214a.5.5 0 0 1 .353.146l4.394 4.394a.5.5 0 0 1 .146.353v6.214a.5.5 0 0 1-.146.353l-4.394 4.394a.5.5 0 0 1-.353.146H4.893a.5.5 0 0 1-.353-.146L.146 11.46A.5.5 0 0 1 0 11.107V4.893a.5.5 0 0 1 .146-.353L4.54.146zM8 15h2.9l4.1-4.1V5.1L10.9 1H8v14z\"}}]})(props);\n};\nexport function BsOctagon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.54.146A.5.5 0 0 1 4.893 0h6.214a.5.5 0 0 1 .353.146l4.394 4.394a.5.5 0 0 1 .146.353v6.214a.5.5 0 0 1-.146.353l-4.394 4.394a.5.5 0 0 1-.353.146H4.893a.5.5 0 0 1-.353-.146L.146 11.46A.5.5 0 0 1 0 11.107V4.893a.5.5 0 0 1 .146-.353L4.54.146zM5.1 1 1 5.1v5.8L5.1 15h5.8l4.1-4.1V5.1L10.9 1H5.1z\"}}]})(props);\n};\nexport function BsOption (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 2.5a.5.5 0 0 1 .5-.5h3.797a.5.5 0 0 1 .439.26L11 13h3.5a.5.5 0 0 1 0 1h-3.797a.5.5 0 0 1-.439-.26L5 3H1.5a.5.5 0 0 1-.5-.5zm10 0a.5.5 0 0 1 .5-.5h3a.5.5 0 0 1 0 1h-3a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsOutlet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.34 2.994c.275-.338.68-.494 1.074-.494h7.172c.393 0 .798.156 1.074.494.578.708 1.84 2.534 1.84 5.006 0 2.472-1.262 4.297-1.84 5.006-.276.338-.68.494-1.074.494H4.414c-.394 0-.799-.156-1.074-.494C2.762 12.297 1.5 10.472 1.5 8c0-2.472 1.262-4.297 1.84-5.006zm1.074.506a.376.376 0 0 0-.299.126C3.599 4.259 2.5 5.863 2.5 8c0 2.137 1.099 3.74 1.615 4.374.06.073.163.126.3.126h7.17c.137 0 .24-.053.3-.126.516-.633 1.615-2.237 1.615-4.374 0-2.137-1.099-3.74-1.615-4.374a.376.376 0 0 0-.3-.126h-7.17z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 5.5a.5.5 0 0 1 .5.5v1.5a.5.5 0 0 1-1 0V6a.5.5 0 0 1 .5-.5zm4 0a.5.5 0 0 1 .5.5v1.5a.5.5 0 0 1-1 0V6a.5.5 0 0 1 .5-.5zM7 10v1h2v-1a1 1 0 0 0-2 0z\"}}]})(props);\n};\nexport function BsPaintBucket (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.192 2.78c-.458-.677-.927-1.248-1.35-1.643a2.972 2.972 0 0 0-.71-.515c-.217-.104-.56-.205-.882-.02-.367.213-.427.63-.43.896-.003.304.064.664.173 1.044.196.687.556 1.528 1.035 2.402L.752 8.22c-.277.277-.269.656-.218.918.055.283.187.593.36.903.348.627.92 1.361 1.626 2.068.707.707 1.441 1.278 2.068 1.626.31.173.62.305.903.36.262.05.64.059.918-.218l5.615-5.615c.118.257.092.512.05.939-.03.292-.068.665-.073 1.176v.123h.003a1 1 0 0 0 1.993 0H14v-.057a1.01 1.01 0 0 0-.004-.117c-.055-1.25-.7-2.738-1.86-3.494a4.322 4.322 0 0 0-.211-.434c-.349-.626-.92-1.36-1.627-2.067-.707-.707-1.441-1.279-2.068-1.627-.31-.172-.62-.304-.903-.36-.262-.05-.64-.058-.918.219l-.217.216zM4.16 1.867c.381.356.844.922 1.311 1.632l-.704.705c-.382-.727-.66-1.402-.813-1.938a3.283 3.283 0 0 1-.131-.673c.091.061.204.15.337.274zm.394 3.965c.54.852 1.107 1.567 1.607 2.033a.5.5 0 1 0 .682-.732c-.453-.422-1.017-1.136-1.564-2.027l1.088-1.088c.054.12.115.243.183.365.349.627.92 1.361 1.627 2.068.706.707 1.44 1.278 2.068 1.626.122.068.244.13.365.183l-4.861 4.862a.571.571 0 0 1-.068-.01c-.137-.027-.342-.104-.608-.252-.524-.292-1.186-.8-1.846-1.46-.66-.66-1.168-1.32-1.46-1.846-.147-.265-.225-.47-.251-.607a.573.573 0 0 1-.01-.068l3.048-3.047zm2.87-1.935a2.44 2.44 0 0 1-.241-.561c.135.033.324.11.562.241.524.292 1.186.8 1.846 1.46.45.45.83.901 1.118 1.31a3.497 3.497 0 0 0-1.066.091 11.27 11.27 0 0 1-.76-.694c-.66-.66-1.167-1.322-1.458-1.847z\"}}]})(props);\n};\nexport function BsPaletteFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.433 10.07C14.133 10.585 16 11.15 16 8a8 8 0 1 0-8 8c1.996 0 1.826-1.504 1.649-3.08-.124-1.101-.252-2.237.351-2.92.465-.527 1.42-.237 2.433.07zM8 5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm4.5 3a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zM5 6.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm.5 6.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsPalette (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3zm4 3a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3zM5.5 7a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm.5 6a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8c0 3.15-1.866 2.585-3.567 2.07C11.42 9.763 10.465 9.473 10 10c-.603.683-.475 1.819-.351 2.92C9.826 14.495 9.996 16 8 16a8 8 0 1 1 8-8zm-8 7c.611 0 .654-.171.655-.176.078-.146.124-.464.07-1.119-.014-.168-.037-.37-.061-.591-.052-.464-.112-1.005-.118-1.462-.01-.707.083-1.61.704-2.314.369-.417.845-.578 1.272-.618.404-.038.812.026 1.16.104.343.077.702.186 1.025.284l.028.008c.346.105.658.199.953.266.653.148.904.083.991.024C14.717 9.38 15 9.161 15 8a7 7 0 1 0-7 7z\"}}]})(props);\n};\nexport function BsPalette2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 .5A.5.5 0 0 1 .5 0h5a.5.5 0 0 1 .5.5v5.277l4.147-4.131a.5.5 0 0 1 .707 0l3.535 3.536a.5.5 0 0 1 0 .708L10.261 10H15.5a.5.5 0 0 1 .5.5v5a.5.5 0 0 1-.5.5H3a2.99 2.99 0 0 1-2.121-.879A2.99 2.99 0 0 1 0 13.044m6-.21 7.328-7.3-2.829-2.828L6 7.188v5.647zM4.5 13a1.5 1.5 0 1 0-3 0 1.5 1.5 0 0 0 3 0zM15 15v-4H9.258l-4.015 4H15zM0 .5v12.495V.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12.995V13a3.07 3.07 0 0 0 0-.005z\"}}]})(props);\n};\nexport function BsPaperclip (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 3a2.5 2.5 0 0 1 5 0v9a1.5 1.5 0 0 1-3 0V5a.5.5 0 0 1 1 0v7a.5.5 0 0 0 1 0V3a1.5 1.5 0 1 0-3 0v9a2.5 2.5 0 0 0 5 0V5a.5.5 0 0 1 1 0v7a3.5 3.5 0 1 1-7 0V3z\"}}]})(props);\n};\nexport function BsParagraph (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.5 15a.5.5 0 0 1-.5-.5V2H9v12.5a.5.5 0 0 1-1 0V9H7a4 4 0 1 1 0-8h5.5a.5.5 0 0 1 0 1H11v12.5a.5.5 0 0 1-.5.5z\"}}]})(props);\n};\nexport function BsPatchCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.067.87a2.89 2.89 0 0 0-4.134 0l-.622.638-.89-.011a2.89 2.89 0 0 0-2.924 2.924l.01.89-.636.622a2.89 2.89 0 0 0 0 4.134l.637.622-.011.89a2.89 2.89 0 0 0 2.924 2.924l.89-.01.622.636a2.89 2.89 0 0 0 4.134 0l.622-.637.89.011a2.89 2.89 0 0 0 2.924-2.924l-.01-.89.636-.622a2.89 2.89 0 0 0 0-4.134l-.637-.622.011-.89a2.89 2.89 0 0 0-2.924-2.924l-.89.01-.622-.636zm.287 5.984-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7 8.793l2.646-2.647a.5.5 0 0 1 .708.708z\"}}]})(props);\n};\nexport function BsPatchCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.354 6.146a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7 8.793l2.646-2.647a.5.5 0 0 1 .708 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m10.273 2.513-.921-.944.715-.698.622.637.89-.011a2.89 2.89 0 0 1 2.924 2.924l-.01.89.636.622a2.89 2.89 0 0 1 0 4.134l-.637.622.011.89a2.89 2.89 0 0 1-2.924 2.924l-.89-.01-.622.636a2.89 2.89 0 0 1-4.134 0l-.622-.637-.89.011a2.89 2.89 0 0 1-2.924-2.924l.01-.89-.636-.622a2.89 2.89 0 0 1 0-4.134l.637-.622-.011-.89a2.89 2.89 0 0 1 2.924-2.924l.89.01.622-.636a2.89 2.89 0 0 1 4.134 0l-.715.698a1.89 1.89 0 0 0-2.704 0l-.92.944-1.32-.016a1.89 1.89 0 0 0-1.911 1.912l.016 1.318-.944.921a1.89 1.89 0 0 0 0 2.704l.944.92-.016 1.32a1.89 1.89 0 0 0 1.912 1.911l1.318-.016.921.944a1.89 1.89 0 0 0 2.704 0l.92-.944 1.32.016a1.89 1.89 0 0 0 1.911-1.912l-.016-1.318.944-.921a1.89 1.89 0 0 0 0-2.704l-.944-.92.016-1.32a1.89 1.89 0 0 0-1.912-1.911l-1.318.016z\"}}]})(props);\n};\nexport function BsPatchExclamationFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.067.87a2.89 2.89 0 0 0-4.134 0l-.622.638-.89-.011a2.89 2.89 0 0 0-2.924 2.924l.01.89-.636.622a2.89 2.89 0 0 0 0 4.134l.637.622-.011.89a2.89 2.89 0 0 0 2.924 2.924l.89-.01.622.636a2.89 2.89 0 0 0 4.134 0l.622-.637.89.011a2.89 2.89 0 0 0 2.924-2.924l-.01-.89.636-.622a2.89 2.89 0 0 0 0-4.134l-.637-.622.011-.89a2.89 2.89 0 0 0-2.924-2.924l-.89.01-.622-.636zM8 4c.535 0 .954.462.9.995l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 4.995A.905.905 0 0 1 8 4zm.002 6a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\"}}]})(props);\n};\nexport function BsPatchExclamation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.001 11a1 1 0 1 1 2 0 1 1 0 0 1-2 0zM7.1 4.995a.905.905 0 1 1 1.8 0l-.35 3.507a.553.553 0 0 1-1.1 0L7.1 4.995z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m10.273 2.513-.921-.944.715-.698.622.637.89-.011a2.89 2.89 0 0 1 2.924 2.924l-.01.89.636.622a2.89 2.89 0 0 1 0 4.134l-.637.622.011.89a2.89 2.89 0 0 1-2.924 2.924l-.89-.01-.622.636a2.89 2.89 0 0 1-4.134 0l-.622-.637-.89.011a2.89 2.89 0 0 1-2.924-2.924l.01-.89-.636-.622a2.89 2.89 0 0 1 0-4.134l.637-.622-.011-.89a2.89 2.89 0 0 1 2.924-2.924l.89.01.622-.636a2.89 2.89 0 0 1 4.134 0l-.715.698a1.89 1.89 0 0 0-2.704 0l-.92.944-1.32-.016a1.89 1.89 0 0 0-1.911 1.912l.016 1.318-.944.921a1.89 1.89 0 0 0 0 2.704l.944.92-.016 1.32a1.89 1.89 0 0 0 1.912 1.911l1.318-.016.921.944a1.89 1.89 0 0 0 2.704 0l.92-.944 1.32.016a1.89 1.89 0 0 0 1.911-1.912l-.016-1.318.944-.921a1.89 1.89 0 0 0 0-2.704l-.944-.92.016-1.32a1.89 1.89 0 0 0-1.912-1.911l-1.318.016z\"}}]})(props);\n};\nexport function BsPatchMinusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.067.87a2.89 2.89 0 0 0-4.134 0l-.622.638-.89-.011a2.89 2.89 0 0 0-2.924 2.924l.01.89-.636.622a2.89 2.89 0 0 0 0 4.134l.637.622-.011.89a2.89 2.89 0 0 0 2.924 2.924l.89-.01.622.636a2.89 2.89 0 0 0 4.134 0l.622-.637.89.011a2.89 2.89 0 0 0 2.924-2.924l-.01-.89.636-.622a2.89 2.89 0 0 0 0-4.134l-.637-.622.011-.89a2.89 2.89 0 0 0-2.924-2.924l-.89.01-.622-.636zM6 7.5h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1 0-1z\"}}]})(props);\n};\nexport function BsPatchMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5.5 8a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m10.273 2.513-.921-.944.715-.698.622.637.89-.011a2.89 2.89 0 0 1 2.924 2.924l-.01.89.636.622a2.89 2.89 0 0 1 0 4.134l-.637.622.011.89a2.89 2.89 0 0 1-2.924 2.924l-.89-.01-.622.636a2.89 2.89 0 0 1-4.134 0l-.622-.637-.89.011a2.89 2.89 0 0 1-2.924-2.924l.01-.89-.636-.622a2.89 2.89 0 0 1 0-4.134l.637-.622-.011-.89a2.89 2.89 0 0 1 2.924-2.924l.89.01.622-.636a2.89 2.89 0 0 1 4.134 0l-.715.698a1.89 1.89 0 0 0-2.704 0l-.92.944-1.32-.016a1.89 1.89 0 0 0-1.911 1.912l.016 1.318-.944.921a1.89 1.89 0 0 0 0 2.704l.944.92-.016 1.32a1.89 1.89 0 0 0 1.912 1.911l1.318-.016.921.944a1.89 1.89 0 0 0 2.704 0l.92-.944 1.32.016a1.89 1.89 0 0 0 1.911-1.912l-.016-1.318.944-.921a1.89 1.89 0 0 0 0-2.704l-.944-.92.016-1.32a1.89 1.89 0 0 0-1.912-1.911l-1.318.016z\"}}]})(props);\n};\nexport function BsPatchPlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.067.87a2.89 2.89 0 0 0-4.134 0l-.622.638-.89-.011a2.89 2.89 0 0 0-2.924 2.924l.01.89-.636.622a2.89 2.89 0 0 0 0 4.134l.637.622-.011.89a2.89 2.89 0 0 0 2.924 2.924l.89-.01.622.636a2.89 2.89 0 0 0 4.134 0l.622-.637.89.011a2.89 2.89 0 0 0 2.924-2.924l-.01-.89.636-.622a2.89 2.89 0 0 0 0-4.134l-.637-.622.011-.89a2.89 2.89 0 0 0-2.924-2.924l-.89.01-.622-.636zM8.5 6v1.5H10a.5.5 0 0 1 0 1H8.5V10a.5.5 0 0 1-1 0V8.5H6a.5.5 0 0 1 0-1h1.5V6a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsPatchPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 5.5a.5.5 0 0 1 .5.5v1.5H10a.5.5 0 0 1 0 1H8.5V10a.5.5 0 0 1-1 0V8.5H6a.5.5 0 0 1 0-1h1.5V6a.5.5 0 0 1 .5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m10.273 2.513-.921-.944.715-.698.622.637.89-.011a2.89 2.89 0 0 1 2.924 2.924l-.01.89.636.622a2.89 2.89 0 0 1 0 4.134l-.637.622.011.89a2.89 2.89 0 0 1-2.924 2.924l-.89-.01-.622.636a2.89 2.89 0 0 1-4.134 0l-.622-.637-.89.011a2.89 2.89 0 0 1-2.924-2.924l.01-.89-.636-.622a2.89 2.89 0 0 1 0-4.134l.637-.622-.011-.89a2.89 2.89 0 0 1 2.924-2.924l.89.01.622-.636a2.89 2.89 0 0 1 4.134 0l-.715.698a1.89 1.89 0 0 0-2.704 0l-.92.944-1.32-.016a1.89 1.89 0 0 0-1.911 1.912l.016 1.318-.944.921a1.89 1.89 0 0 0 0 2.704l.944.92-.016 1.32a1.89 1.89 0 0 0 1.912 1.911l1.318-.016.921.944a1.89 1.89 0 0 0 2.704 0l.92-.944 1.32.016a1.89 1.89 0 0 0 1.911-1.912l-.016-1.318.944-.921a1.89 1.89 0 0 0 0-2.704l-.944-.92.016-1.32a1.89 1.89 0 0 0-1.912-1.911l-1.318.016z\"}}]})(props);\n};\nexport function BsPatchQuestionFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.933.87a2.89 2.89 0 0 1 4.134 0l.622.638.89-.011a2.89 2.89 0 0 1 2.924 2.924l-.01.89.636.622a2.89 2.89 0 0 1 0 4.134l-.637.622.011.89a2.89 2.89 0 0 1-2.924 2.924l-.89-.01-.622.636a2.89 2.89 0 0 1-4.134 0l-.622-.637-.89.011a2.89 2.89 0 0 1-2.924-2.924l.01-.89-.636-.622a2.89 2.89 0 0 1 0-4.134l.637-.622-.011-.89a2.89 2.89 0 0 1 2.924-2.924l.89.01.622-.636zM7.002 11a1 1 0 1 0 2 0 1 1 0 0 0-2 0zm1.602-2.027c.04-.534.198-.815.846-1.26.674-.475 1.05-1.09 1.05-1.986 0-1.325-.92-2.227-2.262-2.227-1.02 0-1.792.492-2.1 1.29A1.71 1.71 0 0 0 6 5.48c0 .393.203.64.545.64.272 0 .455-.147.564-.51.158-.592.525-.915 1.074-.915.61 0 1.03.446 1.03 1.084 0 .563-.208.885-.822 1.325-.619.433-.926.914-.926 1.64v.111c0 .428.208.745.585.745.336 0 .504-.24.554-.627z\"}}]})(props);\n};\nexport function BsPatchQuestion (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.05 9.6c.336 0 .504-.24.554-.627.04-.534.198-.815.847-1.26.673-.475 1.049-1.09 1.049-1.986 0-1.325-.92-2.227-2.262-2.227-1.02 0-1.792.492-2.1 1.29A1.71 1.71 0 0 0 6 5.48c0 .393.203.64.545.64.272 0 .455-.147.564-.51.158-.592.525-.915 1.074-.915.61 0 1.03.446 1.03 1.084 0 .563-.208.885-.822 1.325-.619.433-.926.914-.926 1.64v.111c0 .428.208.745.585.745z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m10.273 2.513-.921-.944.715-.698.622.637.89-.011a2.89 2.89 0 0 1 2.924 2.924l-.01.89.636.622a2.89 2.89 0 0 1 0 4.134l-.637.622.011.89a2.89 2.89 0 0 1-2.924 2.924l-.89-.01-.622.636a2.89 2.89 0 0 1-4.134 0l-.622-.637-.89.011a2.89 2.89 0 0 1-2.924-2.924l.01-.89-.636-.622a2.89 2.89 0 0 1 0-4.134l.637-.622-.011-.89a2.89 2.89 0 0 1 2.924-2.924l.89.01.622-.636a2.89 2.89 0 0 1 4.134 0l-.715.698a1.89 1.89 0 0 0-2.704 0l-.92.944-1.32-.016a1.89 1.89 0 0 0-1.911 1.912l.016 1.318-.944.921a1.89 1.89 0 0 0 0 2.704l.944.92-.016 1.32a1.89 1.89 0 0 0 1.912 1.911l1.318-.016.921.944a1.89 1.89 0 0 0 2.704 0l.92-.944 1.32.016a1.89 1.89 0 0 0 1.911-1.912l-.016-1.318.944-.921a1.89 1.89 0 0 0 0-2.704l-.944-.92.016-1.32a1.89 1.89 0 0 0-1.912-1.911l-1.318.016z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.001 11a1 1 0 1 1 2 0 1 1 0 0 1-2 0z\"}}]})(props);\n};\nexport function BsPauseBtnFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12V4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm6.25-7C5.56 5 5 5.56 5 6.25v3.5a1.25 1.25 0 1 0 2.5 0v-3.5C7.5 5.56 6.94 5 6.25 5zm3.5 0c-.69 0-1.25.56-1.25 1.25v3.5a1.25 1.25 0 1 0 2.5 0v-3.5C11 5.56 10.44 5 9.75 5z\"}}]})(props);\n};\nexport function BsPauseBtn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.25 5C5.56 5 5 5.56 5 6.25v3.5a1.25 1.25 0 1 0 2.5 0v-3.5C7.5 5.56 6.94 5 6.25 5zm3.5 0c-.69 0-1.25.56-1.25 1.25v3.5a1.25 1.25 0 1 0 2.5 0v-3.5C11 5.56 10.44 5 9.75 5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm15 0a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4z\"}}]})(props);\n};\nexport function BsPauseCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM6.25 5C5.56 5 5 5.56 5 6.25v3.5a1.25 1.25 0 1 0 2.5 0v-3.5C7.5 5.56 6.94 5 6.25 5zm3.5 0c-.69 0-1.25.56-1.25 1.25v3.5a1.25 1.25 0 1 0 2.5 0v-3.5C11 5.56 10.44 5 9.75 5z\"}}]})(props);\n};\nexport function BsPauseCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 6.25a1.25 1.25 0 1 1 2.5 0v3.5a1.25 1.25 0 1 1-2.5 0v-3.5zm3.5 0a1.25 1.25 0 1 1 2.5 0v3.5a1.25 1.25 0 1 1-2.5 0v-3.5z\"}}]})(props);\n};\nexport function BsPauseFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 3.5A1.5 1.5 0 0 1 7 5v6a1.5 1.5 0 0 1-3 0V5a1.5 1.5 0 0 1 1.5-1.5zm5 0A1.5 1.5 0 0 1 12 5v6a1.5 1.5 0 0 1-3 0V5a1.5 1.5 0 0 1 1.5-1.5z\"}}]})(props);\n};\nexport function BsPause (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 3.5a.5.5 0 0 1 .5.5v8a.5.5 0 0 1-1 0V4a.5.5 0 0 1 .5-.5zm4 0a.5.5 0 0 1 .5.5v8a.5.5 0 0 1-1 0V4a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsPaypal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M14.06 3.713c.12-1.071-.093-1.832-.702-2.526C12.628.356 11.312 0 9.626 0H4.734a.7.7 0 0 0-.691.59L2.005 13.509a.42.42 0 0 0 .415.486h2.756l-.202 1.28a.628.628 0 0 0 .62.726H8.14c.429 0 .793-.31.862-.731l.025-.13.48-3.043.03-.164.001-.007a.351.351 0 0 1 .348-.297h.38c1.266 0 2.425-.256 3.345-.91.379-.27.712-.603.993-1.005a4.942 4.942 0 0 0 .88-2.195c.242-1.246.13-2.356-.57-3.154a2.687 2.687 0 0 0-.76-.59l-.094-.061zM6.543 8.82l-.845 5.213v.001l-.208 1.32c-.01.066.04.123.105.123H8.14c.173 0 .32-.125.348-.296v-.005l.026-.129.48-3.043.03-.164a.873.873 0 0 1 .862-.734h.38c1.201 0 2.24-.244 3.043-.815.797-.567 1.39-1.477 1.663-2.874.229-1.175.096-2.087-.45-2.71a2.126 2.126 0 0 0-.548-.438l-.003.016c-.645 3.312-2.853 4.456-5.672 4.456H6.864a.695.695 0 0 0-.321.079z\"}}]})(props);\n};\nexport function BsPeaceFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 13.292A8 8 0 0 0 8.5.015v7.778l5.5 5.5zm-.708.708L8.5 9.206v6.778a7.967 7.967 0 0 0 4.792-1.986zM7.5 15.985V9.207L2.708 14A7.967 7.967 0 0 0 7.5 15.985zM2 13.292A8 8 0 0 1 7.5.015v7.778l-5.5 5.5z\"}}]})(props);\n};\nexport function BsPeace (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 1.018a7 7 0 0 0-4.79 11.566L7.5 7.793V1.018zm1 0v6.775l4.79 4.79A7 7 0 0 0 8.5 1.018zm4.084 12.273L8.5 9.207v5.775a6.97 6.97 0 0 0 4.084-1.691zM7.5 14.982V9.207l-4.084 4.084A6.97 6.97 0 0 0 7.5 14.982zM0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8z\"}}]})(props);\n};\nexport function BsPenFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m13.498.795.149-.149a1.207 1.207 0 1 1 1.707 1.708l-.149.148a1.5 1.5 0 0 1-.059 2.059L4.854 14.854a.5.5 0 0 1-.233.131l-4 1a.5.5 0 0 1-.606-.606l1-4a.5.5 0 0 1 .131-.232l9.642-9.642a.5.5 0 0 0-.642.056L6.854 4.854a.5.5 0 1 1-.708-.708L9.44.854A1.5 1.5 0 0 1 11.5.796a1.5 1.5 0 0 1 1.998-.001z\"}}]})(props);\n};\nexport function BsPen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m13.498.795.149-.149a1.207 1.207 0 1 1 1.707 1.708l-.149.148a1.5 1.5 0 0 1-.059 2.059L4.854 14.854a.5.5 0 0 1-.233.131l-4 1a.5.5 0 0 1-.606-.606l1-4a.5.5 0 0 1 .131-.232l9.642-9.642a.5.5 0 0 0-.642.056L6.854 4.854a.5.5 0 1 1-.708-.708L9.44.854A1.5 1.5 0 0 1 11.5.796a1.5 1.5 0 0 1 1.998-.001zm-.644.766a.5.5 0 0 0-.707 0L1.95 11.756l-.764 3.057 3.057-.764L14.44 3.854a.5.5 0 0 0 0-.708l-1.585-1.585z\"}}]})(props);\n};\nexport function BsPencilFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.854.146a.5.5 0 0 0-.707 0L10.5 1.793 14.207 5.5l1.647-1.646a.5.5 0 0 0 0-.708l-3-3zm.646 6.061L9.793 2.5 3.293 9H3.5a.5.5 0 0 1 .5.5v.5h.5a.5.5 0 0 1 .5.5v.5h.5a.5.5 0 0 1 .5.5v.5h.5a.5.5 0 0 1 .5.5v.207l6.5-6.5zm-7.468 7.468A.5.5 0 0 1 6 13.5V13h-.5a.5.5 0 0 1-.5-.5V12h-.5a.5.5 0 0 1-.5-.5V11h-.5a.5.5 0 0 1-.5-.5V10h-.5a.499.499 0 0 1-.175-.032l-.179.178a.5.5 0 0 0-.11.168l-2 5a.5.5 0 0 0 .65.65l5-2a.5.5 0 0 0 .168-.11l.178-.178z\"}}]})(props);\n};\nexport function BsPencilSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.502 1.94a.5.5 0 0 1 0 .706L14.459 3.69l-2-2L13.502.646a.5.5 0 0 1 .707 0l1.293 1.293zm-1.75 2.456-2-2L4.939 9.21a.5.5 0 0 0-.121.196l-.805 2.414a.25.25 0 0 0 .316.316l2.414-.805a.5.5 0 0 0 .196-.12l6.813-6.814z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 13.5A1.5 1.5 0 0 0 2.5 15h11a1.5 1.5 0 0 0 1.5-1.5v-6a.5.5 0 0 0-1 0v6a.5.5 0 0 1-.5.5h-11a.5.5 0 0 1-.5-.5v-11a.5.5 0 0 1 .5-.5H9a.5.5 0 0 0 0-1H2.5A1.5 1.5 0 0 0 1 2.5v11z\"}}]})(props);\n};\nexport function BsPencil (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.146.146a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1 0 .708l-10 10a.5.5 0 0 1-.168.11l-5 2a.5.5 0 0 1-.65-.65l2-5a.5.5 0 0 1 .11-.168l10-10zM11.207 2.5 13.5 4.793 14.793 3.5 12.5 1.207 11.207 2.5zm1.586 3L10.5 3.207 4 9.707V10h.5a.5.5 0 0 1 .5.5v.5h.5a.5.5 0 0 1 .5.5v.5h.293l6.5-6.5zm-9.761 5.175-.106.106-1.528 3.821 3.821-1.528.106-.106A.5.5 0 0 1 5 12.5V12h-.5a.5.5 0 0 1-.5-.5V11h-.5a.5.5 0 0 1-.468-.325z\"}}]})(props);\n};\nexport function BsPentagonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m8 0 8 6.5-3 9.5H3L0 6.5 8 0z\"}}]})(props);\n};\nexport function BsPentagonHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m8 1.288 6.842 5.56L12.267 15H8V1.288zM16 6.5 8 0 0 6.5 3 16h10l3-9.5z\"}}]})(props);\n};\nexport function BsPentagon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m8 1.288 6.842 5.56L12.267 15H3.733L1.158 6.847 8 1.288zM16 6.5 8 0 0 6.5 3 16h10l3-9.5z\"}}]})(props);\n};\nexport function BsPeopleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 14s-1 0-1-1 1-4 5-4 5 3 5 4-1 1-1 1H7zm4-6a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5.216 14A2.238 2.238 0 0 1 5 13c0-1.355.68-2.75 1.936-3.72A6.325 6.325 0 0 0 5 9c-4 0-5 3-5 4s1 1 1 1h4.216z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 8a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5z\"}}]})(props);\n};\nexport function BsPeople (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15 14s1 0 1-1-1-4-5-4-5 3-5 4 1 1 1 1h8zm-7.978-1A.261.261 0 0 1 7 12.996c.001-.264.167-1.03.76-1.72C8.312 10.629 9.282 10 11 10c1.717 0 2.687.63 3.24 1.276.593.69.758 1.457.76 1.72l-.008.002a.274.274 0 0 1-.014.002H7.022zM11 7a2 2 0 1 0 0-4 2 2 0 0 0 0 4zm3-2a3 3 0 1 1-6 0 3 3 0 0 1 6 0zM6.936 9.28a5.88 5.88 0 0 0-1.23-.247A7.35 7.35 0 0 0 5 9c-4 0-5 3-5 4 0 .667.333 1 1 1h4.216A2.238 2.238 0 0 1 5 13c0-1.01.377-2.042 1.09-2.904.243-.294.526-.569.846-.816zM4.92 10A5.493 5.493 0 0 0 4 13H1c0-.26.164-1.03.76-1.724.545-.636 1.492-1.256 3.16-1.275zM1.5 5.5a3 3 0 1 1 6 0 3 3 0 0 1-6 0zm3-2a2 2 0 1 0 0 4 2 2 0 0 0 0-4z\"}}]})(props);\n};\nexport function BsPercent (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.442 2.558a.625.625 0 0 1 0 .884l-10 10a.625.625 0 1 1-.884-.884l10-10a.625.625 0 0 1 .884 0zM4.5 6a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm0 1a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5zm7 6a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm0 1a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5z\"}}]})(props);\n};\nexport function BsPersonBadgeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm4.5 0a.5.5 0 0 0 0 1h3a.5.5 0 0 0 0-1h-3zM8 11a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm5 2.755C12.146 12.825 10.623 12 8 12s-4.146.826-5 1.755V14a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1v-.245z\"}}]})(props);\n};\nexport function BsPersonBadge (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 2a.5.5 0 0 0 0 1h3a.5.5 0 0 0 0-1h-3zM11 8a3 3 0 1 1-6 0 3 3 0 0 1 6 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 0A2.5 2.5 0 0 0 2 2.5V14a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2.5A2.5 2.5 0 0 0 11.5 0h-7zM3 2.5A1.5 1.5 0 0 1 4.5 1h7A1.5 1.5 0 0 1 13 2.5v10.795a4.2 4.2 0 0 0-.776-.492C11.392 12.387 10.063 12 8 12s-3.392.387-4.224.803a4.2 4.2 0 0 0-.776.492V2.5z\"}}]})(props);\n};\nexport function BsPersonBoundingBox (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 1a.5.5 0 0 0-.5.5v3a.5.5 0 0 1-1 0v-3A1.5 1.5 0 0 1 1.5 0h3a.5.5 0 0 1 0 1h-3zM11 .5a.5.5 0 0 1 .5-.5h3A1.5 1.5 0 0 1 16 1.5v3a.5.5 0 0 1-1 0v-3a.5.5 0 0 0-.5-.5h-3a.5.5 0 0 1-.5-.5zM.5 11a.5.5 0 0 1 .5.5v3a.5.5 0 0 0 .5.5h3a.5.5 0 0 1 0 1h-3A1.5 1.5 0 0 1 0 14.5v-3a.5.5 0 0 1 .5-.5zm15 0a.5.5 0 0 1 .5.5v3a1.5 1.5 0 0 1-1.5 1.5h-3a.5.5 0 0 1 0-1h3a.5.5 0 0 0 .5-.5v-3a.5.5 0 0 1 .5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 14s-1 0-1-1 1-4 6-4 6 3 6 4-1 1-1 1H3zm8-9a3 3 0 1 1-6 0 3 3 0 0 1 6 0z\"}}]})(props);\n};\nexport function BsPersonCheckFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M15.854 5.146a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 0 1 .708-.708L12.5 7.793l2.646-2.647a.5.5 0 0 1 .708 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 14s-1 0-1-1 1-4 6-4 6 3 6 4-1 1-1 1H1zm5-6a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}}]})(props);\n};\nexport function BsPersonCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm2-3a2 2 0 1 1-4 0 2 2 0 0 1 4 0zm4 8c0 1-1 1-1 1H1s-1 0-1-1 1-4 6-4 6 3 6 4zm-1-.004c-.001-.246-.154-.986-.832-1.664C9.516 10.68 8.289 10 6 10c-2.29 0-3.516.68-4.168 1.332-.678.678-.83 1.418-.832 1.664h10z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M15.854 5.146a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 0 1 .708-.708L12.5 7.793l2.646-2.647a.5.5 0 0 1 .708 0z\"}}]})(props);\n};\nexport function BsPersonCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 6a3 3 0 1 1-6 0 3 3 0 0 1 6 0z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8zm8-7a7 7 0 0 0-5.468 11.37C3.242 11.226 4.805 10 8 10s4.757 1.225 5.468 2.37A7 7 0 0 0 8 1z\"}}]})(props);\n};\nexport function BsPersonDashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11 7.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 14s-1 0-1-1 1-4 6-4 6 3 6 4-1 1-1 1H1zm5-6a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}}]})(props);\n};\nexport function BsPersonDash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm2-3a2 2 0 1 1-4 0 2 2 0 0 1 4 0zm4 8c0 1-1 1-1 1H1s-1 0-1-1 1-4 6-4 6 3 6 4zm-1-.004c-.001-.246-.154-.986-.832-1.664C9.516 10.68 8.289 10 6 10c-2.29 0-3.516.68-4.168 1.332-.678.678-.83 1.418-.832 1.664h10z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11 7.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsPersonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 14s-1 0-1-1 1-4 6-4 6 3 6 4-1 1-1 1H3zm5-6a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}}]})(props);\n};\nexport function BsPersonLinesFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-5 6s-1 0-1-1 1-4 6-4 6 3 6 4-1 1-1 1H1zM11 3.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5zm.5 2.5a.5.5 0 0 0 0 1h4a.5.5 0 0 0 0-1h-4zm2 3a.5.5 0 0 0 0 1h2a.5.5 0 0 0 0-1h-2zm0 3a.5.5 0 0 0 0 1h2a.5.5 0 0 0 0-1h-2z\"}}]})(props);\n};\nexport function BsPersonPlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 14s-1 0-1-1 1-4 6-4 6 3 6 4-1 1-1 1H1zm5-6a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M13.5 5a.5.5 0 0 1 .5.5V7h1.5a.5.5 0 0 1 0 1H14v1.5a.5.5 0 0 1-1 0V8h-1.5a.5.5 0 0 1 0-1H13V5.5a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsPersonPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm2-3a2 2 0 1 1-4 0 2 2 0 0 1 4 0zm4 8c0 1-1 1-1 1H1s-1 0-1-1 1-4 6-4 6 3 6 4zm-1-.004c-.001-.246-.154-.986-.832-1.664C9.516 10.68 8.289 10 6 10c-2.29 0-3.516.68-4.168 1.332-.678.678-.83 1.418-.832 1.664h10z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M13.5 5a.5.5 0 0 1 .5.5V7h1.5a.5.5 0 0 1 0 1H14v1.5a.5.5 0 0 1-1 0V8h-1.5a.5.5 0 0 1 0-1H13V5.5a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsPersonSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 6a3 3 0 1 1-6 0 3 3 0 0 1 6 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm12 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1v-1c0-1-1-4-6-4s-6 3-6 4v1a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12z\"}}]})(props);\n};\nexport function BsPersonXFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1 14s-1 0-1-1 1-4 6-4 6 3 6 4-1 1-1 1H1zm5-6a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm6.146-2.854a.5.5 0 0 1 .708 0L14 6.293l1.146-1.147a.5.5 0 0 1 .708.708L14.707 7l1.147 1.146a.5.5 0 0 1-.708.708L14 7.707l-1.146 1.147a.5.5 0 0 1-.708-.708L13.293 7l-1.147-1.146a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsPersonX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 8a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm2-3a2 2 0 1 1-4 0 2 2 0 0 1 4 0zm4 8c0 1-1 1-1 1H1s-1 0-1-1 1-4 6-4 6 3 6 4zm-1-.004c-.001-.246-.154-.986-.832-1.664C9.516 10.68 8.289 10 6 10c-2.29 0-3.516.68-4.168 1.332-.678.678-.83 1.418-.832 1.664h10z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M12.146 5.146a.5.5 0 0 1 .708 0L14 6.293l1.146-1.147a.5.5 0 0 1 .708.708L14.707 7l1.147 1.146a.5.5 0 0 1-.708.708L14 7.707l-1.146 1.147a.5.5 0 0 1-.708-.708L13.293 7l-1.147-1.146a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsPerson (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm2-3a2 2 0 1 1-4 0 2 2 0 0 1 4 0zm4 8c0 1-1 1-1 1H3s-1 0-1-1 1-4 6-4 6 3 6 4zm-1-.004c-.001-.246-.154-.986-.832-1.664C11.516 10.68 10.289 10 8 10c-2.29 0-3.516.68-4.168 1.332-.678.678-.83 1.418-.832 1.664h10z\"}}]})(props);\n};\nexport function BsPhoneFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 2a2 2 0 0 1 2-2h6a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V2zm6 11a1 1 0 1 0-2 0 1 1 0 0 0 2 0z\"}}]})(props);\n};\nexport function BsPhoneLandscapeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 12.5a2 2 0 0 1-2-2v-6a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v6a2 2 0 0 1-2 2H2zm11-6a1 1 0 1 0 0 2 1 1 0 0 0 0-2z\"}}]})(props);\n};\nexport function BsPhoneLandscape (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 4.5a1 1 0 0 1 1-1h12a1 1 0 0 1 1 1v6a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1v-6zm-1 6a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-6a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 7.5a1 1 0 1 0-2 0 1 1 0 0 0 2 0z\"}}]})(props);\n};\nexport function BsPhoneVibrateFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V4zm5 7a1 1 0 1 0-2 0 1 1 0 0 0 2 0zM1.807 4.734a.5.5 0 1 0-.884-.468A7.967 7.967 0 0 0 0 8c0 1.347.334 2.618.923 3.734a.5.5 0 1 0 .884-.468A6.967 6.967 0 0 1 1 8c0-1.18.292-2.292.807-3.266zm13.27-.468a.5.5 0 0 0-.884.468C14.708 5.708 15 6.819 15 8c0 1.18-.292 2.292-.807 3.266a.5.5 0 0 0 .884.468A7.967 7.967 0 0 0 16 8a7.967 7.967 0 0 0-.923-3.734zM3.34 6.182a.5.5 0 1 0-.93-.364A5.986 5.986 0 0 0 2 8c0 .769.145 1.505.41 2.182a.5.5 0 1 0 .93-.364A4.986 4.986 0 0 1 3 8c0-.642.12-1.255.34-1.818zm10.25-.364a.5.5 0 0 0-.93.364c.22.563.34 1.176.34 1.818 0 .642-.12 1.255-.34 1.818a.5.5 0 0 0 .93.364C13.856 9.505 14 8.769 14 8c0-.769-.145-1.505-.41-2.182z\"}}]})(props);\n};\nexport function BsPhoneVibrate (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10 3a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H6a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h4zM6 2a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h4a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12a1 1 0 1 0 0-2 1 1 0 0 0 0 2zM1.599 4.058a.5.5 0 0 1 .208.676A6.967 6.967 0 0 0 1 8c0 1.18.292 2.292.807 3.266a.5.5 0 0 1-.884.468A7.968 7.968 0 0 1 0 8c0-1.347.334-2.619.923-3.734a.5.5 0 0 1 .676-.208zm12.802 0a.5.5 0 0 1 .676.208A7.967 7.967 0 0 1 16 8a7.967 7.967 0 0 1-.923 3.734.5.5 0 0 1-.884-.468A6.967 6.967 0 0 0 15 8c0-1.18-.292-2.292-.807-3.266a.5.5 0 0 1 .208-.676zM3.057 5.534a.5.5 0 0 1 .284.648A4.986 4.986 0 0 0 3 8c0 .642.12 1.255.34 1.818a.5.5 0 1 1-.93.364A5.986 5.986 0 0 1 2 8c0-.769.145-1.505.41-2.182a.5.5 0 0 1 .647-.284zm9.886 0a.5.5 0 0 1 .648.284C13.855 6.495 14 7.231 14 8c0 .769-.145 1.505-.41 2.182a.5.5 0 0 1-.93-.364C12.88 9.255 13 8.642 13 8c0-.642-.12-1.255-.34-1.818a.5.5 0 0 1 .283-.648z\"}}]})(props);\n};\nexport function BsPhone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H5a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h6zM5 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h6a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 14a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsPieChartFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.985 8.5H8.207l-5.5 5.5a8 8 0 0 0 13.277-5.5zM2 13.292A8 8 0 0 1 7.5.015v7.778l-5.5 5.5zM8.5.015V7.5h7.485A8.001 8.001 0 0 0 8.5.015z\"}}]})(props);\n};\nexport function BsPieChart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 1.018a7 7 0 0 0-4.79 11.566L7.5 7.793V1.018zm1 0V7.5h6.482A7.001 7.001 0 0 0 8.5 1.018zM14.982 8.5H8.207l-4.79 4.79A7 7 0 0 0 14.982 8.5zM0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8z\"}}]})(props);\n};\nexport function BsPiggyBankFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.964 1.527c-2.977 0-5.571 1.704-6.32 4.125h-.55A1 1 0 0 0 .11 6.824l.254 1.46a1.5 1.5 0 0 0 1.478 1.243h.263c.3.513.688.978 1.145 1.382l-.729 2.477a.5.5 0 0 0 .48.641h2a.5.5 0 0 0 .471-.332l.482-1.351c.635.173 1.31.267 2.011.267.707 0 1.388-.095 2.028-.272l.543 1.372a.5.5 0 0 0 .465.316h2a.5.5 0 0 0 .478-.645l-.761-2.506C13.81 9.895 14.5 8.559 14.5 7.069c0-.145-.007-.29-.02-.431.261-.11.508-.266.705-.444.315.306.815.306.815-.417 0 .223-.5.223-.461-.026a.95.95 0 0 0 .09-.255.7.7 0 0 0-.202-.645.58.58 0 0 0-.707-.098.735.735 0 0 0-.375.562c-.024.243.082.48.32.654a2.112 2.112 0 0 1-.259.153c-.534-2.664-3.284-4.595-6.442-4.595zm7.173 3.876a.565.565 0 0 1-.098.21.704.704 0 0 1-.044-.025c-.146-.09-.157-.175-.152-.223a.236.236 0 0 1 .117-.173c.049-.027.08-.021.113.012a.202.202 0 0 1 .064.199zm-8.999-.65A6.613 6.613 0 0 1 7.964 4.5c.666 0 1.303.097 1.893.273a.5.5 0 1 0 .286-.958A7.601 7.601 0 0 0 7.964 3.5c-.734 0-1.441.103-2.102.292a.5.5 0 1 0 .276.962zM5 6.25a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0z\"}}]})(props);\n};\nexport function BsPiggyBank (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 6.25a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0zm1.138-1.496A6.613 6.613 0 0 1 7.964 4.5c.666 0 1.303.097 1.893.273a.5.5 0 0 0 .286-.958A7.602 7.602 0 0 0 7.964 3.5c-.734 0-1.441.103-2.102.292a.5.5 0 1 0 .276.962z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.964 1.527c-2.977 0-5.571 1.704-6.32 4.125h-.55A1 1 0 0 0 .11 6.824l.254 1.46a1.5 1.5 0 0 0 1.478 1.243h.263c.3.513.688.978 1.145 1.382l-.729 2.477a.5.5 0 0 0 .48.641h2a.5.5 0 0 0 .471-.332l.482-1.351c.635.173 1.31.267 2.011.267.707 0 1.388-.095 2.028-.272l.543 1.372a.5.5 0 0 0 .465.316h2a.5.5 0 0 0 .478-.645l-.761-2.506C13.81 9.895 14.5 8.559 14.5 7.069c0-.145-.007-.29-.02-.431.261-.11.508-.266.705-.444.315.306.815.306.815-.417 0 .223-.5.223-.461-.026a.95.95 0 0 0 .09-.255.7.7 0 0 0-.202-.645.58.58 0 0 0-.707-.098.735.735 0 0 0-.375.562c-.024.243.082.48.32.654a2.112 2.112 0 0 1-.259.153c-.534-2.664-3.284-4.595-6.442-4.595zM2.516 6.26c.455-2.066 2.667-3.733 5.448-3.733 3.146 0 5.536 2.114 5.536 4.542 0 1.254-.624 2.41-1.67 3.248a.5.5 0 0 0-.165.535l.66 2.175h-.985l-.59-1.487a.5.5 0 0 0-.629-.288c-.661.23-1.39.359-2.157.359a6.558 6.558 0 0 1-2.157-.359.5.5 0 0 0-.635.304l-.525 1.471h-.979l.633-2.15a.5.5 0 0 0-.17-.534 4.649 4.649 0 0 1-1.284-1.541.5.5 0 0 0-.446-.275h-.56a.5.5 0 0 1-.492-.414l-.254-1.46h.933a.5.5 0 0 0 .488-.393zm12.621-.857a.565.565 0 0 1-.098.21.704.704 0 0 1-.044-.025c-.146-.09-.157-.175-.152-.223a.236.236 0 0 1 .117-.173c.049-.027.08-.021.113.012a.202.202 0 0 1 .064.199z\"}}]})(props);\n};\nexport function BsPinAngleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.828.722a.5.5 0 0 1 .354.146l4.95 4.95a.5.5 0 0 1 0 .707c-.48.48-1.072.588-1.503.588-.177 0-.335-.018-.46-.039l-3.134 3.134a5.927 5.927 0 0 1 .16 1.013c.046.702-.032 1.687-.72 2.375a.5.5 0 0 1-.707 0l-2.829-2.828-3.182 3.182c-.195.195-1.219.902-1.414.707-.195-.195.512-1.22.707-1.414l3.182-3.182-2.828-2.829a.5.5 0 0 1 0-.707c.688-.688 1.673-.767 2.375-.72a5.922 5.922 0 0 1 1.013.16l3.134-3.133a2.772 2.772 0 0 1-.04-.461c0-.43.108-1.022.589-1.503a.5.5 0 0 1 .353-.146z\"}}]})(props);\n};\nexport function BsPinAngle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.828.722a.5.5 0 0 1 .354.146l4.95 4.95a.5.5 0 0 1 0 .707c-.48.48-1.072.588-1.503.588-.177 0-.335-.018-.46-.039l-3.134 3.134a5.927 5.927 0 0 1 .16 1.013c.046.702-.032 1.687-.72 2.375a.5.5 0 0 1-.707 0l-2.829-2.828-3.182 3.182c-.195.195-1.219.902-1.414.707-.195-.195.512-1.22.707-1.414l3.182-3.182-2.828-2.829a.5.5 0 0 1 0-.707c.688-.688 1.673-.767 2.375-.72a5.922 5.922 0 0 1 1.013.16l3.134-3.133a2.772 2.772 0 0 1-.04-.461c0-.43.108-1.022.589-1.503a.5.5 0 0 1 .353-.146zm.122 2.112v-.002.002zm0-.002v.002a.5.5 0 0 1-.122.51L6.293 6.878a.5.5 0 0 1-.511.12H5.78l-.014-.004a4.507 4.507 0 0 0-.288-.076 4.922 4.922 0 0 0-.765-.116c-.422-.028-.836.008-1.175.15l5.51 5.509c.141-.34.177-.753.149-1.175a4.924 4.924 0 0 0-.192-1.054l-.004-.013v-.001a.5.5 0 0 1 .12-.512l3.536-3.535a.5.5 0 0 1 .532-.115l.096.022c.087.017.208.034.344.034.114 0 .23-.011.343-.04L9.927 2.028c-.029.113-.04.23-.04.343a1.779 1.779 0 0 0 .062.46z\"}}]})(props);\n};\nexport function BsPinFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.146.146A.5.5 0 0 1 4.5 0h7a.5.5 0 0 1 .5.5c0 .68-.342 1.174-.646 1.479-.126.125-.25.224-.354.298v4.431l.078.048c.203.127.476.314.751.555C12.36 7.775 13 8.527 13 9.5a.5.5 0 0 1-.5.5h-4v4.5c0 .276-.224 1.5-.5 1.5s-.5-1.224-.5-1.5V10h-4a.5.5 0 0 1-.5-.5c0-.973.64-1.725 1.17-2.189A5.921 5.921 0 0 1 5 6.708V2.277a2.77 2.77 0 0 1-.354-.298C4.342 1.674 4 1.179 4 .5a.5.5 0 0 1 .146-.354z\"}}]})(props);\n};\nexport function BsPinMapFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.1 11.2a.5.5 0 0 1 .4-.2H6a.5.5 0 0 1 0 1H3.75L1.5 15h13l-2.25-3H10a.5.5 0 0 1 0-1h2.5a.5.5 0 0 1 .4.2l3 4a.5.5 0 0 1-.4.8H.5a.5.5 0 0 1-.4-.8l3-4z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4 4a4 4 0 1 1 4.5 3.969V13.5a.5.5 0 0 1-1 0V7.97A4 4 0 0 1 4 3.999z\"}}]})(props);\n};\nexport function BsPinMap (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3.1 11.2a.5.5 0 0 1 .4-.2H6a.5.5 0 0 1 0 1H3.75L1.5 15h13l-2.25-3H10a.5.5 0 0 1 0-1h2.5a.5.5 0 0 1 .4.2l3 4a.5.5 0 0 1-.4.8H.5a.5.5 0 0 1-.4-.8l3-4z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 1a3 3 0 1 0 0 6 3 3 0 0 0 0-6zM4 4a4 4 0 1 1 4.5 3.969V13.5a.5.5 0 0 1-1 0V7.97A4 4 0 0 1 4 3.999z\"}}]})(props);\n};\nexport function BsPin (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.146.146A.5.5 0 0 1 4.5 0h7a.5.5 0 0 1 .5.5c0 .68-.342 1.174-.646 1.479-.126.125-.25.224-.354.298v4.431l.078.048c.203.127.476.314.751.555C12.36 7.775 13 8.527 13 9.5a.5.5 0 0 1-.5.5h-4v4.5c0 .276-.224 1.5-.5 1.5s-.5-1.224-.5-1.5V10h-4a.5.5 0 0 1-.5-.5c0-.973.64-1.725 1.17-2.189A5.921 5.921 0 0 1 5 6.708V2.277a2.77 2.77 0 0 1-.354-.298C4.342 1.674 4 1.179 4 .5a.5.5 0 0 1 .146-.354zm1.58 1.408-.002-.001.002.001zm-.002-.001.002.001A.5.5 0 0 1 6 2v5a.5.5 0 0 1-.276.447h-.002l-.012.007-.054.03a4.922 4.922 0 0 0-.827.58c-.318.278-.585.596-.725.936h7.792c-.14-.34-.407-.658-.725-.936a4.915 4.915 0 0 0-.881-.61l-.012-.006h-.002A.5.5 0 0 1 10 7V2a.5.5 0 0 1 .295-.458 1.775 1.775 0 0 0 .351-.271c.08-.08.155-.17.214-.271H5.14c.06.1.133.191.214.271a1.78 1.78 0 0 0 .37.282z\"}}]})(props);\n};\nexport function BsPinterest (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a8 8 0 0 0-2.915 15.452c-.07-.633-.134-1.606.027-2.297.146-.625.938-3.977.938-3.977s-.239-.479-.239-1.187c0-1.113.645-1.943 1.448-1.943.682 0 1.012.512 1.012 1.127 0 .686-.437 1.712-.663 2.663-.188.796.4 1.446 1.185 1.446 1.422 0 2.515-1.5 2.515-3.664 0-1.915-1.377-3.254-3.342-3.254-2.276 0-3.612 1.707-3.612 3.471 0 .688.265 1.425.595 1.826a.24.24 0 0 1 .056.23c-.061.252-.196.796-.222.907-.035.146-.116.177-.268.107-1-.465-1.624-1.926-1.624-3.1 0-2.523 1.834-4.84 5.286-4.84 2.775 0 4.932 1.977 4.932 4.62 0 2.757-1.739 4.976-4.151 4.976-.811 0-1.573-.421-1.834-.919l-.498 1.902c-.181.695-.669 1.566-.995 2.097A8 8 0 1 0 8 0z\"}}]})(props);\n};\nexport function BsPipFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 2A1.5 1.5 0 0 0 0 3.5v9A1.5 1.5 0 0 0 1.5 14h13a1.5 1.5 0 0 0 1.5-1.5v-9A1.5 1.5 0 0 0 14.5 2h-13zm7 6h5a.5.5 0 0 1 .5.5v3a.5.5 0 0 1-.5.5h-5a.5.5 0 0 1-.5-.5v-3a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsPip (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 3.5A1.5 1.5 0 0 1 1.5 2h13A1.5 1.5 0 0 1 16 3.5v9a1.5 1.5 0 0 1-1.5 1.5h-13A1.5 1.5 0 0 1 0 12.5v-9zM1.5 3a.5.5 0 0 0-.5.5v9a.5.5 0 0 0 .5.5h13a.5.5 0 0 0 .5-.5v-9a.5.5 0 0 0-.5-.5h-13z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 8.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 .5.5v3a.5.5 0 0 1-.5.5h-5a.5.5 0 0 1-.5-.5v-3z\"}}]})(props);\n};\nexport function BsPlayBtnFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12V4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm6.79-6.907A.5.5 0 0 0 6 5.5v5a.5.5 0 0 0 .79.407l3.5-2.5a.5.5 0 0 0 0-.814l-3.5-2.5z\"}}]})(props);\n};\nexport function BsPlayBtn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.79 5.093A.5.5 0 0 0 6 5.5v5a.5.5 0 0 0 .79.407l3.5-2.5a.5.5 0 0 0 0-.814l-3.5-2.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm15 0a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4z\"}}]})(props);\n};\nexport function BsPlayCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM6.79 5.093A.5.5 0 0 0 6 5.5v5a.5.5 0 0 0 .79.407l3.5-2.5a.5.5 0 0 0 0-.814l-3.5-2.5z\"}}]})(props);\n};\nexport function BsPlayCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.271 5.055a.5.5 0 0 1 .52.038l3.5 2.5a.5.5 0 0 1 0 .814l-3.5 2.5A.5.5 0 0 1 6 10.5v-5a.5.5 0 0 1 .271-.445z\"}}]})(props);\n};\nexport function BsPlayFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m11.596 8.697-6.363 3.692c-.54.313-1.233-.066-1.233-.697V4.308c0-.63.692-1.01 1.233-.696l6.363 3.692a.802.802 0 0 1 0 1.393z\"}}]})(props);\n};\nexport function BsPlay (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.804 8 5 4.633v6.734L10.804 8zm.792-.696a.802.802 0 0 1 0 1.392l-6.363 3.692C4.713 12.69 4 12.345 4 11.692V4.308c0-.653.713-.998 1.233-.696l6.363 3.692z\"}}]})(props);\n};\nexport function BsPlugFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 0a.5.5 0 0 1 .5.5V3h3V.5a.5.5 0 0 1 1 0V3h1a.5.5 0 0 1 .5.5v3A3.5 3.5 0 0 1 8.5 10c-.002.434-.01.845-.04 1.22-.041.514-.126 1.003-.317 1.424a2.083 2.083 0 0 1-.97 1.028C6.725 13.9 6.169 14 5.5 14c-.998 0-1.61.33-1.974.718A1.922 1.922 0 0 0 3 16H2c0-.616.232-1.367.797-1.968C3.374 13.42 4.261 13 5.5 13c.581 0 .962-.088 1.218-.219.241-.123.4-.3.514-.55.121-.266.193-.621.23-1.09.027-.34.035-.718.037-1.141A3.5 3.5 0 0 1 4 6.5v-3a.5.5 0 0 1 .5-.5h1V.5A.5.5 0 0 1 6 0z\"}}]})(props);\n};\nexport function BsPlug (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 0a.5.5 0 0 1 .5.5V3h3V.5a.5.5 0 0 1 1 0V3h1a.5.5 0 0 1 .5.5v3A3.5 3.5 0 0 1 8.5 10c-.002.434-.01.845-.04 1.22-.041.514-.126 1.003-.317 1.424a2.083 2.083 0 0 1-.97 1.028C6.725 13.9 6.169 14 5.5 14c-.998 0-1.61.33-1.974.718A1.922 1.922 0 0 0 3 16H2c0-.616.232-1.367.797-1.968C3.374 13.42 4.261 13 5.5 13c.581 0 .962-.088 1.218-.219.241-.123.4-.3.514-.55.121-.266.193-.621.23-1.09.027-.34.035-.718.037-1.141A3.5 3.5 0 0 1 4 6.5v-3a.5.5 0 0 1 .5-.5h1V.5A.5.5 0 0 1 6 0zM5 4v2.5A2.5 2.5 0 0 0 7.5 9h1A2.5 2.5 0 0 0 11 6.5V4H5z\"}}]})(props);\n};\nexport function BsPlusCircleDotted (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0c-.176 0-.35.006-.523.017l.064.998a7.117 7.117 0 0 1 .918 0l.064-.998A8.113 8.113 0 0 0 8 0zM6.44.152c-.346.069-.684.16-1.012.27l.321.948c.287-.098.582-.177.884-.237L6.44.153zm4.132.271a7.946 7.946 0 0 0-1.011-.27l-.194.98c.302.06.597.14.884.237l.321-.947zm1.873.925a8 8 0 0 0-.906-.524l-.443.896c.275.136.54.29.793.459l.556-.831zM4.46.824c-.314.155-.616.33-.905.524l.556.83a7.07 7.07 0 0 1 .793-.458L4.46.824zM2.725 1.985c-.262.23-.51.478-.74.74l.752.66c.202-.23.418-.446.648-.648l-.66-.752zm11.29.74a8.058 8.058 0 0 0-.74-.74l-.66.752c.23.202.447.418.648.648l.752-.66zm1.161 1.735a7.98 7.98 0 0 0-.524-.905l-.83.556c.169.253.322.518.458.793l.896-.443zM1.348 3.555c-.194.289-.37.591-.524.906l.896.443c.136-.275.29-.54.459-.793l-.831-.556zM.423 5.428a7.945 7.945 0 0 0-.27 1.011l.98.194c.06-.302.14-.597.237-.884l-.947-.321zM15.848 6.44a7.943 7.943 0 0 0-.27-1.012l-.948.321c.098.287.177.582.237.884l.98-.194zM.017 7.477a8.113 8.113 0 0 0 0 1.046l.998-.064a7.117 7.117 0 0 1 0-.918l-.998-.064zM16 8a8.1 8.1 0 0 0-.017-.523l-.998.064a7.11 7.11 0 0 1 0 .918l.998.064A8.1 8.1 0 0 0 16 8zM.152 9.56c.069.346.16.684.27 1.012l.948-.321a6.944 6.944 0 0 1-.237-.884l-.98.194zm15.425 1.012c.112-.328.202-.666.27-1.011l-.98-.194c-.06.302-.14.597-.237.884l.947.321zM.824 11.54a8 8 0 0 0 .524.905l.83-.556a6.999 6.999 0 0 1-.458-.793l-.896.443zm13.828.905c.194-.289.37-.591.524-.906l-.896-.443c-.136.275-.29.54-.459.793l.831.556zm-12.667.83c.23.262.478.51.74.74l.66-.752a7.047 7.047 0 0 1-.648-.648l-.752.66zm11.29.74c.262-.23.51-.478.74-.74l-.752-.66c-.201.23-.418.447-.648.648l.66.752zm-1.735 1.161c.314-.155.616-.33.905-.524l-.556-.83a7.07 7.07 0 0 1-.793.458l.443.896zm-7.985-.524c.289.194.591.37.906.524l.443-.896a6.998 6.998 0 0 1-.793-.459l-.556.831zm1.873.925c.328.112.666.202 1.011.27l.194-.98a6.953 6.953 0 0 1-.884-.237l-.321.947zm4.132.271a7.944 7.944 0 0 0 1.012-.27l-.321-.948a6.954 6.954 0 0 1-.884.237l.194.98zm-2.083.135a8.1 8.1 0 0 0 1.046 0l-.064-.998a7.11 7.11 0 0 1-.918 0l-.064.998zM8.5 4.5a.5.5 0 0 0-1 0v3h-3a.5.5 0 0 0 0 1h3v3a.5.5 0 0 0 1 0v-3h3a.5.5 0 0 0 0-1h-3v-3z\"}}]})(props);\n};\nexport function BsPlusCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM8.5 4.5a.5.5 0 0 0-1 0v3h-3a.5.5 0 0 0 0 1h3v3a.5.5 0 0 0 1 0v-3h3a.5.5 0 0 0 0-1h-3v-3z\"}}]})(props);\n};\nexport function BsPlusCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4a.5.5 0 0 1 .5.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3A.5.5 0 0 1 8 4z\"}}]})(props);\n};\nexport function BsPlusLg (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a1 1 0 0 1 1 1v6h6a1 1 0 1 1 0 2H9v6a1 1 0 1 1-2 0V9H1a1 1 0 0 1 0-2h6V1a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsPlusSquareDotted (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 0c-.166 0-.33.016-.487.048l.194.98A1.51 1.51 0 0 1 2.5 1h.458V0H2.5zm2.292 0h-.917v1h.917V0zm1.833 0h-.917v1h.917V0zm1.833 0h-.916v1h.916V0zm1.834 0h-.917v1h.917V0zm1.833 0h-.917v1h.917V0zM13.5 0h-.458v1h.458c.1 0 .199.01.293.029l.194-.981A2.51 2.51 0 0 0 13.5 0zm2.079 1.11a2.511 2.511 0 0 0-.69-.689l-.556.831c.164.11.305.251.415.415l.83-.556zM1.11.421a2.511 2.511 0 0 0-.689.69l.831.556c.11-.164.251-.305.415-.415L1.11.422zM16 2.5c0-.166-.016-.33-.048-.487l-.98.194c.018.094.028.192.028.293v.458h1V2.5zM.048 2.013A2.51 2.51 0 0 0 0 2.5v.458h1V2.5c0-.1.01-.199.029-.293l-.981-.194zM0 3.875v.917h1v-.917H0zm16 .917v-.917h-1v.917h1zM0 5.708v.917h1v-.917H0zm16 .917v-.917h-1v.917h1zM0 7.542v.916h1v-.916H0zm15 .916h1v-.916h-1v.916zM0 9.375v.917h1v-.917H0zm16 .917v-.917h-1v.917h1zm-16 .916v.917h1v-.917H0zm16 .917v-.917h-1v.917h1zm-16 .917v.458c0 .166.016.33.048.487l.98-.194A1.51 1.51 0 0 1 1 13.5v-.458H0zm16 .458v-.458h-1v.458c0 .1-.01.199-.029.293l.981.194c.032-.158.048-.32.048-.487zM.421 14.89c.183.272.417.506.69.689l.556-.831a1.51 1.51 0 0 1-.415-.415l-.83.556zm14.469.689c.272-.183.506-.417.689-.69l-.831-.556c-.11.164-.251.305-.415.415l.556.83zm-12.877.373c.158.032.32.048.487.048h.458v-1H2.5c-.1 0-.199-.01-.293-.029l-.194.981zM13.5 16c.166 0 .33-.016.487-.048l-.194-.98A1.51 1.51 0 0 1 13.5 15h-.458v1h.458zm-9.625 0h.917v-1h-.917v1zm1.833 0h.917v-1h-.917v1zm1.834-1v1h.916v-1h-.916zm1.833 1h.917v-1h-.917v1zm1.833 0h.917v-1h-.917v1zM8.5 4.5a.5.5 0 0 0-1 0v3h-3a.5.5 0 0 0 0 1h3v3a.5.5 0 0 0 1 0v-3h3a.5.5 0 0 0 0-1h-3v-3z\"}}]})(props);\n};\nexport function BsPlusSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm6.5 4.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsPlusSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4a.5.5 0 0 1 .5.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3A.5.5 0 0 1 8 4z\"}}]})(props);\n};\nexport function BsPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4a.5.5 0 0 1 .5.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3A.5.5 0 0 1 8 4z\"}}]})(props);\n};\nexport function BsPower (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.5 1v7h1V1h-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 8.812a4.999 4.999 0 0 1 2.578-4.375l-.485-.874A6 6 0 1 0 11 3.616l-.501.865A5 5 0 1 1 3 8.812z\"}}]})(props);\n};\nexport function BsPrinterFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 1a2 2 0 0 0-2 2v1h10V3a2 2 0 0 0-2-2H5zm6 8H5a1 1 0 0 0-1 1v3a1 1 0 0 0 1 1h6a1 1 0 0 0 1-1v-3a1 1 0 0 0-1-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 7a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v3a2 2 0 0 1-2 2h-1v-2a2 2 0 0 0-2-2H5a2 2 0 0 0-2 2v2H2a2 2 0 0 1-2-2V7zm2.5 1a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1z\"}}]})(props);\n};\nexport function BsPrinter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 8a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 1a2 2 0 0 0-2 2v2H2a2 2 0 0 0-2 2v3a2 2 0 0 0 2 2h1v1a2 2 0 0 0 2 2h6a2 2 0 0 0 2-2v-1h1a2 2 0 0 0 2-2V7a2 2 0 0 0-2-2h-1V3a2 2 0 0 0-2-2H5zM4 3a1 1 0 0 1 1-1h6a1 1 0 0 1 1 1v2H4V3zm1 5a2 2 0 0 0-2 2v1H2a1 1 0 0 1-1-1V7a1 1 0 0 1 1-1h12a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1h-1v-1a2 2 0 0 0-2-2H5zm7 2v3a1 1 0 0 1-1 1H5a1 1 0 0 1-1-1v-3a1 1 0 0 1 1-1h6a1 1 0 0 1 1 1z\"}}]})(props);\n};\nexport function BsPuzzleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.112 3.645A1.5 1.5 0 0 1 4.605 2H7a.5.5 0 0 1 .5.5v.382c0 .696-.497 1.182-.872 1.469a.459.459 0 0 0-.115.118.113.113 0 0 0-.012.025L6.5 4.5v.003l.003.01c.004.01.014.028.036.053a.86.86 0 0 0 .27.194C7.09 4.9 7.51 5 8 5c.492 0 .912-.1 1.19-.24a.86.86 0 0 0 .271-.194.213.213 0 0 0 .036-.054l.003-.01v-.008a.112.112 0 0 0-.012-.025.459.459 0 0 0-.115-.118c-.375-.287-.872-.773-.872-1.469V2.5A.5.5 0 0 1 9 2h2.395a1.5 1.5 0 0 1 1.493 1.645L12.645 6.5h.237c.195 0 .42-.147.675-.48.21-.274.528-.52.943-.52.568 0 .947.447 1.154.862C15.877 6.807 16 7.387 16 8s-.123 1.193-.346 1.638c-.207.415-.586.862-1.154.862-.415 0-.733-.246-.943-.52-.255-.333-.48-.48-.675-.48h-.237l.243 2.855A1.5 1.5 0 0 1 11.395 14H9a.5.5 0 0 1-.5-.5v-.382c0-.696.497-1.182.872-1.469a.459.459 0 0 0 .115-.118.113.113 0 0 0 .012-.025L9.5 11.5v-.003l-.003-.01a.214.214 0 0 0-.036-.053.859.859 0 0 0-.27-.194C8.91 11.1 8.49 11 8 11c-.491 0-.912.1-1.19.24a.859.859 0 0 0-.271.194.214.214 0 0 0-.036.054l-.003.01v.002l.001.006a.113.113 0 0 0 .012.025c.016.027.05.068.115.118.375.287.872.773.872 1.469v.382a.5.5 0 0 1-.5.5H4.605a1.5 1.5 0 0 1-1.493-1.645L3.356 9.5h-.238c-.195 0-.42.147-.675.48-.21.274-.528.52-.943.52-.568 0-.947-.447-1.154-.862C.123 9.193 0 8.613 0 8s.123-1.193.346-1.638C.553 5.947.932 5.5 1.5 5.5c.415 0 .733.246.943.52.255.333.48.48.675.48h.238l-.244-2.855z\"}}]})(props);\n};\nexport function BsPuzzle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.112 3.645A1.5 1.5 0 0 1 4.605 2H7a.5.5 0 0 1 .5.5v.382c0 .696-.497 1.182-.872 1.469a.459.459 0 0 0-.115.118.113.113 0 0 0-.012.025L6.5 4.5v.003l.003.01c.004.01.014.028.036.053a.86.86 0 0 0 .27.194C7.09 4.9 7.51 5 8 5c.492 0 .912-.1 1.19-.24a.86.86 0 0 0 .271-.194.213.213 0 0 0 .039-.063v-.009a.112.112 0 0 0-.012-.025.459.459 0 0 0-.115-.118c-.375-.287-.872-.773-.872-1.469V2.5A.5.5 0 0 1 9 2h2.395a1.5 1.5 0 0 1 1.493 1.645L12.645 6.5h.237c.195 0 .42-.147.675-.48.21-.274.528-.52.943-.52.568 0 .947.447 1.154.862C15.877 6.807 16 7.387 16 8s-.123 1.193-.346 1.638c-.207.415-.586.862-1.154.862-.415 0-.733-.246-.943-.52-.255-.333-.48-.48-.675-.48h-.237l.243 2.855A1.5 1.5 0 0 1 11.395 14H9a.5.5 0 0 1-.5-.5v-.382c0-.696.497-1.182.872-1.469a.459.459 0 0 0 .115-.118.113.113 0 0 0 .012-.025L9.5 11.5v-.003a.214.214 0 0 0-.039-.064.859.859 0 0 0-.27-.193C8.91 11.1 8.49 11 8 11c-.491 0-.912.1-1.19.24a.859.859 0 0 0-.271.194.214.214 0 0 0-.039.063v.003l.001.006a.113.113 0 0 0 .012.025c.016.027.05.068.115.118.375.287.872.773.872 1.469v.382a.5.5 0 0 1-.5.5H4.605a1.5 1.5 0 0 1-1.493-1.645L3.356 9.5h-.238c-.195 0-.42.147-.675.48-.21.274-.528.52-.943.52-.568 0-.947-.447-1.154-.862C.123 9.193 0 8.613 0 8s.123-1.193.346-1.638C.553 5.947.932 5.5 1.5 5.5c.415 0 .733.246.943.52.255.333.48.48.675.48h.238l-.244-2.855zM4.605 3a.5.5 0 0 0-.498.55l.001.007.29 3.4A.5.5 0 0 1 3.9 7.5h-.782c-.696 0-1.182-.497-1.469-.872a.459.459 0 0 0-.118-.115.112.112 0 0 0-.025-.012L1.5 6.5h-.003a.213.213 0 0 0-.064.039.86.86 0 0 0-.193.27C1.1 7.09 1 7.51 1 8c0 .491.1.912.24 1.19.07.14.14.225.194.271a.213.213 0 0 0 .063.039H1.5l.006-.001a.112.112 0 0 0 .025-.012.459.459 0 0 0 .118-.115c.287-.375.773-.872 1.469-.872H3.9a.5.5 0 0 1 .498.542l-.29 3.408a.5.5 0 0 0 .497.55h1.878c-.048-.166-.195-.352-.463-.557-.274-.21-.52-.528-.52-.943 0-.568.447-.947.862-1.154C6.807 10.123 7.387 10 8 10s1.193.123 1.638.346c.415.207.862.586.862 1.154 0 .415-.246.733-.52.943-.268.205-.415.39-.463.557h1.878a.5.5 0 0 0 .498-.55l-.001-.007-.29-3.4A.5.5 0 0 1 12.1 8.5h.782c.696 0 1.182.497 1.469.872.05.065.091.099.118.115.013.008.021.01.025.012a.02.02 0 0 0 .006.001h.003a.214.214 0 0 0 .064-.039.86.86 0 0 0 .193-.27c.14-.28.24-.7.24-1.191 0-.492-.1-.912-.24-1.19a.86.86 0 0 0-.194-.271.215.215 0 0 0-.063-.039H14.5l-.006.001a.113.113 0 0 0-.025.012.459.459 0 0 0-.118.115c-.287.375-.773.872-1.469.872H12.1a.5.5 0 0 1-.498-.543l.29-3.407a.5.5 0 0 0-.497-.55H9.517c.048.166.195.352.463.557.274.21.52.528.52.943 0 .568-.447.947-.862 1.154C9.193 5.877 8.613 6 8 6s-1.193-.123-1.638-.346C5.947 5.447 5.5 5.068 5.5 4.5c0-.415.246-.733.52-.943.268-.205.415-.39.463-.557H4.605z\"}}]})(props);\n};\nexport function BsQuestionCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM5.496 6.033h.825c.138 0 .248-.113.266-.25.09-.656.54-1.134 1.342-1.134.686 0 1.314.343 1.314 1.168 0 .635-.374.927-.965 1.371-.673.489-1.206 1.06-1.168 1.987l.003.217a.25.25 0 0 0 .25.246h.811a.25.25 0 0 0 .25-.25v-.105c0-.718.273-.927 1.01-1.486.609-.463 1.244-.977 1.244-2.056 0-1.511-1.276-2.241-2.673-2.241-1.267 0-2.655.59-2.75 2.286a.237.237 0 0 0 .241.247zm2.325 6.443c.61 0 1.029-.394 1.029-.927 0-.552-.42-.94-1.029-.94-.584 0-1.009.388-1.009.94 0 .533.425.927 1.01.927z\"}}]})(props);\n};\nexport function BsQuestionCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.255 5.786a.237.237 0 0 0 .241.247h.825c.138 0 .248-.113.266-.25.09-.656.54-1.134 1.342-1.134.686 0 1.314.343 1.314 1.168 0 .635-.374.927-.965 1.371-.673.489-1.206 1.06-1.168 1.987l.003.217a.25.25 0 0 0 .25.246h.811a.25.25 0 0 0 .25-.25v-.105c0-.718.273-.927 1.01-1.486.609-.463 1.244-.977 1.244-2.056 0-1.511-1.276-2.241-2.673-2.241-1.267 0-2.655.59-2.75 2.286zm1.557 5.763c0 .533.425.927 1.01.927.609 0 1.028-.394 1.028-.927 0-.552-.42-.94-1.029-.94-.584 0-1.009.388-1.009.94z\"}}]})(props);\n};\nexport function BsQuestionDiamondFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.05.435c-.58-.58-1.52-.58-2.1 0L.436 6.95c-.58.58-.58 1.519 0 2.098l6.516 6.516c.58.58 1.519.58 2.098 0l6.516-6.516c.58-.58.58-1.519 0-2.098L9.05.435zM5.495 6.033a.237.237 0 0 1-.24-.247C5.35 4.091 6.737 3.5 8.005 3.5c1.396 0 2.672.73 2.672 2.24 0 1.08-.635 1.594-1.244 2.057-.737.559-1.01.768-1.01 1.486v.105a.25.25 0 0 1-.25.25h-.81a.25.25 0 0 1-.25-.246l-.004-.217c-.038-.927.495-1.498 1.168-1.987.59-.444.965-.736.965-1.371 0-.825-.628-1.168-1.314-1.168-.803 0-1.253.478-1.342 1.134-.018.137-.128.25-.266.25h-.825zm2.325 6.443c-.584 0-1.009-.394-1.009-.927 0-.552.425-.94 1.01-.94.609 0 1.028.388 1.028.94 0 .533-.42.927-1.029.927z\"}}]})(props);\n};\nexport function BsQuestionDiamond (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.95.435c.58-.58 1.52-.58 2.1 0l6.515 6.516c.58.58.58 1.519 0 2.098L9.05 15.565c-.58.58-1.519.58-2.098 0L.435 9.05a1.482 1.482 0 0 1 0-2.098L6.95.435zm1.4.7a.495.495 0 0 0-.7 0L1.134 7.65a.495.495 0 0 0 0 .7l6.516 6.516a.495.495 0 0 0 .7 0l6.516-6.516a.495.495 0 0 0 0-.7L8.35 1.134z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.255 5.786a.237.237 0 0 0 .241.247h.825c.138 0 .248-.113.266-.25.09-.656.54-1.134 1.342-1.134.686 0 1.314.343 1.314 1.168 0 .635-.374.927-.965 1.371-.673.489-1.206 1.06-1.168 1.987l.003.217a.25.25 0 0 0 .25.246h.811a.25.25 0 0 0 .25-.25v-.105c0-.718.273-.927 1.01-1.486.609-.463 1.244-.977 1.244-2.056 0-1.511-1.276-2.241-2.673-2.241-1.267 0-2.655.59-2.75 2.286zm1.557 5.763c0 .533.425.927 1.01.927.609 0 1.028-.394 1.028-.927 0-.552-.42-.94-1.029-.94-.584 0-1.009.388-1.009.94z\"}}]})(props);\n};\nexport function BsQuestionLg (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 4.075a.423.423 0 0 0 .43.44H4.9c.247 0 .442-.2.475-.445.159-1.17.962-2.022 2.393-2.022 1.222 0 2.342.611 2.342 2.082 0 1.132-.668 1.652-1.72 2.444-1.2.872-2.15 1.89-2.082 3.542l.005.386c.003.244.202.44.446.44h1.445c.247 0 .446-.2.446-.446v-.188c0-1.278.487-1.652 1.8-2.647 1.086-.826 2.217-1.743 2.217-3.667C12.667 1.301 10.393 0 7.903 0 5.645 0 3.17 1.053 3.001 4.075zm2.776 10.273c0 .95.758 1.652 1.8 1.652 1.085 0 1.832-.702 1.832-1.652 0-.985-.747-1.675-1.833-1.675-1.04 0-1.799.69-1.799 1.675z\"}}]})(props);\n};\nexport function BsQuestionOctagonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.46.146A.5.5 0 0 0 11.107 0H4.893a.5.5 0 0 0-.353.146L.146 4.54A.5.5 0 0 0 0 4.893v6.214a.5.5 0 0 0 .146.353l4.394 4.394a.5.5 0 0 0 .353.146h6.214a.5.5 0 0 0 .353-.146l4.394-4.394a.5.5 0 0 0 .146-.353V4.893a.5.5 0 0 0-.146-.353L11.46.146zM5.496 6.033a.237.237 0 0 1-.24-.247C5.35 4.091 6.737 3.5 8.005 3.5c1.396 0 2.672.73 2.672 2.24 0 1.08-.635 1.594-1.244 2.057-.737.559-1.01.768-1.01 1.486v.105a.25.25 0 0 1-.25.25h-.81a.25.25 0 0 1-.25-.246l-.004-.217c-.038-.927.495-1.498 1.168-1.987.59-.444.965-.736.965-1.371 0-.825-.628-1.168-1.314-1.168-.803 0-1.253.478-1.342 1.134-.018.137-.128.25-.266.25h-.825zm2.325 6.443c-.584 0-1.009-.394-1.009-.927 0-.552.425-.94 1.01-.94.609 0 1.028.388 1.028.94 0 .533-.42.927-1.029.927z\"}}]})(props);\n};\nexport function BsQuestionOctagon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.54.146A.5.5 0 0 1 4.893 0h6.214a.5.5 0 0 1 .353.146l4.394 4.394a.5.5 0 0 1 .146.353v6.214a.5.5 0 0 1-.146.353l-4.394 4.394a.5.5 0 0 1-.353.146H4.893a.5.5 0 0 1-.353-.146L.146 11.46A.5.5 0 0 1 0 11.107V4.893a.5.5 0 0 1 .146-.353L4.54.146zM5.1 1 1 5.1v5.8L5.1 15h5.8l4.1-4.1V5.1L10.9 1H5.1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.255 5.786a.237.237 0 0 0 .241.247h.825c.138 0 .248-.113.266-.25.09-.656.54-1.134 1.342-1.134.686 0 1.314.343 1.314 1.168 0 .635-.374.927-.965 1.371-.673.489-1.206 1.06-1.168 1.987l.003.217a.25.25 0 0 0 .25.246h.811a.25.25 0 0 0 .25-.25v-.105c0-.718.273-.927 1.01-1.486.609-.463 1.244-.977 1.244-2.056 0-1.511-1.276-2.241-2.673-2.241-1.267 0-2.655.59-2.75 2.286zm1.557 5.763c0 .533.425.927 1.01.927.609 0 1.028-.394 1.028-.927 0-.552-.42-.94-1.029-.94-.584 0-1.009.388-1.009.94z\"}}]})(props);\n};\nexport function BsQuestionSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm3.496 6.033a.237.237 0 0 1-.24-.247C5.35 4.091 6.737 3.5 8.005 3.5c1.396 0 2.672.73 2.672 2.24 0 1.08-.635 1.594-1.244 2.057-.737.559-1.01.768-1.01 1.486v.105a.25.25 0 0 1-.25.25h-.81a.25.25 0 0 1-.25-.246l-.004-.217c-.038-.927.495-1.498 1.168-1.987.59-.444.965-.736.965-1.371 0-.825-.628-1.168-1.314-1.168-.803 0-1.253.478-1.342 1.134-.018.137-.128.25-.266.25h-.825zm2.325 6.443c-.584 0-1.009-.394-1.009-.927 0-.552.425-.94 1.01-.94.609 0 1.028.388 1.028.94 0 .533-.42.927-1.029.927z\"}}]})(props);\n};\nexport function BsQuestionSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.255 5.786a.237.237 0 0 0 .241.247h.825c.138 0 .248-.113.266-.25.09-.656.54-1.134 1.342-1.134.686 0 1.314.343 1.314 1.168 0 .635-.374.927-.965 1.371-.673.489-1.206 1.06-1.168 1.987l.003.217a.25.25 0 0 0 .25.246h.811a.25.25 0 0 0 .25-.25v-.105c0-.718.273-.927 1.01-1.486.609-.463 1.244-.977 1.244-2.056 0-1.511-1.276-2.241-2.673-2.241-1.267 0-2.655.59-2.75 2.286zm1.557 5.763c0 .533.425.927 1.01.927.609 0 1.028-.394 1.028-.927 0-.552-.42-.94-1.029-.94-.584 0-1.009.388-1.009.94z\"}}]})(props);\n};\nexport function BsQuestion (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.255 5.786a.237.237 0 0 0 .241.247h.825c.138 0 .248-.113.266-.25.09-.656.54-1.134 1.342-1.134.686 0 1.314.343 1.314 1.168 0 .635-.374.927-.965 1.371-.673.489-1.206 1.06-1.168 1.987l.003.217a.25.25 0 0 0 .25.246h.811a.25.25 0 0 0 .25-.25v-.105c0-.718.273-.927 1.01-1.486.609-.463 1.244-.977 1.244-2.056 0-1.511-1.276-2.241-2.673-2.241-1.267 0-2.655.59-2.75 2.286zm1.557 5.763c0 .533.425.927 1.01.927.609 0 1.028-.394 1.028-.927 0-.552-.42-.94-1.029-.94-.584 0-1.009.388-1.009.94z\"}}]})(props);\n};\nexport function BsRainbow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4.5a7 7 0 0 0-7 7 .5.5 0 0 1-1 0 8 8 0 1 1 16 0 .5.5 0 0 1-1 0 7 7 0 0 0-7-7zm0 2a5 5 0 0 0-5 5 .5.5 0 0 1-1 0 6 6 0 1 1 12 0 .5.5 0 0 1-1 0 5 5 0 0 0-5-5zm0 2a3 3 0 0 0-3 3 .5.5 0 0 1-1 0 4 4 0 1 1 8 0 .5.5 0 0 1-1 0 3 3 0 0 0-3-3zm0 2a1 1 0 0 0-1 1 .5.5 0 0 1-1 0 2 2 0 1 1 4 0 .5.5 0 0 1-1 0 1 1 0 0 0-1-1z\"}}]})(props);\n};\nexport function BsReceiptCutoff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 4.5a.5.5 0 0 1 .5-.5h6a.5.5 0 1 1 0 1h-6a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h6a.5.5 0 1 1 0 1h-6a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h6a.5.5 0 1 1 0 1h-6a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5zM11.5 4a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1zm0 2a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1zm0 2a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1zm0 2a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1zm0 2a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.354.646a.5.5 0 0 0-.801.13l-.5 1A.5.5 0 0 0 1 2v13H.5a.5.5 0 0 0 0 1h15a.5.5 0 0 0 0-1H15V2a.5.5 0 0 0-.053-.224l-.5-1a.5.5 0 0 0-.8-.13L13 1.293l-.646-.647a.5.5 0 0 0-.708 0L11 1.293l-.646-.647a.5.5 0 0 0-.708 0L9 1.293 8.354.646a.5.5 0 0 0-.708 0L7 1.293 6.354.646a.5.5 0 0 0-.708 0L5 1.293 4.354.646a.5.5 0 0 0-.708 0L3 1.293 2.354.646zm-.217 1.198.51.51a.5.5 0 0 0 .707 0L4 1.707l.646.647a.5.5 0 0 0 .708 0L6 1.707l.646.647a.5.5 0 0 0 .708 0L8 1.707l.646.647a.5.5 0 0 0 .708 0L10 1.707l.646.647a.5.5 0 0 0 .708 0L12 1.707l.646.647a.5.5 0 0 0 .708 0l.509-.51.137.274V15H2V2.118l.137-.274z\"}}]})(props);\n};\nexport function BsReceipt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.92.506a.5.5 0 0 1 .434.14L3 1.293l.646-.647a.5.5 0 0 1 .708 0L5 1.293l.646-.647a.5.5 0 0 1 .708 0L7 1.293l.646-.647a.5.5 0 0 1 .708 0L9 1.293l.646-.647a.5.5 0 0 1 .708 0l.646.647.646-.647a.5.5 0 0 1 .708 0l.646.647.646-.647a.5.5 0 0 1 .801.13l.5 1A.5.5 0 0 1 15 2v12a.5.5 0 0 1-.053.224l-.5 1a.5.5 0 0 1-.8.13L13 14.707l-.646.647a.5.5 0 0 1-.708 0L11 14.707l-.646.647a.5.5 0 0 1-.708 0L9 14.707l-.646.647a.5.5 0 0 1-.708 0L7 14.707l-.646.647a.5.5 0 0 1-.708 0L5 14.707l-.646.647a.5.5 0 0 1-.708 0L3 14.707l-.646.647a.5.5 0 0 1-.801-.13l-.5-1A.5.5 0 0 1 1 14V2a.5.5 0 0 1 .053-.224l.5-1a.5.5 0 0 1 .367-.27zm.217 1.338L2 2.118v11.764l.137.274.51-.51a.5.5 0 0 1 .707 0l.646.647.646-.646a.5.5 0 0 1 .708 0l.646.646.646-.646a.5.5 0 0 1 .708 0l.646.646.646-.646a.5.5 0 0 1 .708 0l.646.646.646-.646a.5.5 0 0 1 .708 0l.646.646.646-.646a.5.5 0 0 1 .708 0l.509.509.137-.274V2.118l-.137-.274-.51.51a.5.5 0 0 1-.707 0L12 1.707l-.646.647a.5.5 0 0 1-.708 0L10 1.707l-.646.647a.5.5 0 0 1-.708 0L8 1.707l-.646.647a.5.5 0 0 1-.708 0L6 1.707l-.646.647a.5.5 0 0 1-.708 0L4 1.707l-.646.647a.5.5 0 0 1-.708 0l-.509-.51z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 4.5a.5.5 0 0 1 .5-.5h6a.5.5 0 1 1 0 1h-6a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h6a.5.5 0 1 1 0 1h-6a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h6a.5.5 0 1 1 0 1h-6a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5zm8-6a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 0 1h-1a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 0 1h-1a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 0 1h-1a.5.5 0 0 1-.5-.5zm0 2a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 0 1h-1a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsReception0 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 13.5a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5zm4 0a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5zm4 0a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5zm4 0a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsReception1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 11.5a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1-.5-.5v-2zm4 2a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5zm4 0a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5zm4 0a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsReception2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 11.5a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1-.5-.5v-2zm4-3a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 .5.5v5a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1-.5-.5v-5zm4 5a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5zm4 0a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsReception3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 11.5a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1-.5-.5v-2zm4-3a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 .5.5v5a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1-.5-.5v-5zm4-3a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 .5.5v8a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1-.5-.5v-8zm4 8a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsReception4 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 11.5a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1-.5-.5v-2zm4-3a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 .5.5v5a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1-.5-.5v-5zm4-3a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 .5.5v8a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1-.5-.5v-8zm4-3a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 .5.5v11a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1-.5-.5v-11z\"}}]})(props);\n};\nexport function BsRecordBtnFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12V4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm8-1a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}}]})(props);\n};\nexport function BsRecordBtn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm15 0a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4z\"}}]})(props);\n};\nexport function BsRecordCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-8 3a3 3 0 1 0 0-6 3 3 0 0 0 0 6z\"}}]})(props);\n};\nexport function BsRecordCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11 8a3 3 0 1 1-6 0 3 3 0 0 1 6 0z\"}}]})(props);\n};\nexport function BsRecordFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 13A5 5 0 1 0 8 3a5 5 0 0 0 0 10z\"}}]})(props);\n};\nexport function BsRecord (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12a4 4 0 1 1 0-8 4 4 0 0 1 0 8zm0 1A5 5 0 1 0 8 3a5 5 0 0 0 0 10z\"}}]})(props);\n};\nexport function BsRecord2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10 8a2 2 0 1 1-4 0 2 2 0 0 1 4 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 13A5 5 0 1 0 8 3a5 5 0 0 0 0 10zm0-2a3 3 0 1 1 0-6 3 3 0 0 1 0 6z\"}}]})(props);\n};\nexport function BsRecord2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12a4 4 0 1 1 0-8 4 4 0 0 1 0 8zm0 1A5 5 0 1 0 8 3a5 5 0 0 0 0 10z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10 8a2 2 0 1 1-4 0 2 2 0 0 1 4 0z\"}}]})(props);\n};\nexport function BsRecycle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.302 1.256a1.5 1.5 0 0 0-2.604 0l-1.704 2.98a.5.5 0 0 0 .869.497l1.703-2.981a.5.5 0 0 1 .868 0l2.54 4.444-1.256-.337a.5.5 0 1 0-.26.966l2.415.647a.5.5 0 0 0 .613-.353l.647-2.415a.5.5 0 1 0-.966-.259l-.333 1.242-2.532-4.431zM2.973 7.773l-1.255.337a.5.5 0 1 1-.26-.966l2.416-.647a.5.5 0 0 1 .612.353l.647 2.415a.5.5 0 0 1-.966.259l-.333-1.242-2.545 4.454a.5.5 0 0 0 .434.748H5a.5.5 0 0 1 0 1H1.723A1.5 1.5 0 0 1 .421 12.24l2.552-4.467zm10.89 1.463a.5.5 0 1 0-.868.496l1.716 3.004a.5.5 0 0 1-.434.748h-5.57l.647-.646a.5.5 0 1 0-.708-.707l-1.5 1.5a.498.498 0 0 0 0 .707l1.5 1.5a.5.5 0 1 0 .708-.707l-.647-.647h5.57a1.5 1.5 0 0 0 1.302-2.244l-1.716-3.004z\"}}]})(props);\n};\nexport function BsReddit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.167 8a.831.831 0 0 0-.83.83c0 .459.372.84.83.831a.831.831 0 0 0 0-1.661zm1.843 3.647c.315 0 1.403-.038 1.976-.611a.232.232 0 0 0 0-.306.213.213 0 0 0-.306 0c-.353.363-1.126.487-1.67.487-.545 0-1.308-.124-1.671-.487a.213.213 0 0 0-.306 0 .213.213 0 0 0 0 .306c.564.563 1.652.61 1.977.61zm.992-2.807c0 .458.373.83.831.83.458 0 .83-.381.83-.83a.831.831 0 0 0-1.66 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-3.828-1.165c-.315 0-.602.124-.812.325-.801-.573-1.9-.945-3.121-.993l.534-2.501 1.738.372a.83.83 0 1 0 .83-.869.83.83 0 0 0-.744.468l-1.938-.41a.203.203 0 0 0-.153.028.186.186 0 0 0-.086.134l-.592 2.788c-1.24.038-2.358.41-3.17.992-.21-.2-.496-.324-.81-.324a1.163 1.163 0 0 0-.478 2.224c-.02.115-.029.23-.029.353 0 1.795 2.091 3.256 4.669 3.256 2.577 0 4.668-1.451 4.668-3.256 0-.114-.01-.238-.029-.353.401-.181.688-.592.688-1.069 0-.65-.525-1.165-1.165-1.165z\"}}]})(props);\n};\nexport function BsReplyAllFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.021 11.9 3.453 8.62a.719.719 0 0 1 0-1.238L8.021 4.1a.716.716 0 0 1 1.079.619V6c1.5 0 6 0 7 8-2.5-4.5-7-4-7-4v1.281c0 .56-.606.898-1.079.62z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.232 4.293a.5.5 0 0 1-.106.7L1.114 7.945a.5.5 0 0 1-.042.028.147.147 0 0 0 0 .252.503.503 0 0 1 .042.028l4.012 2.954a.5.5 0 1 1-.593.805L.539 9.073a1.147 1.147 0 0 1 0-1.946l3.994-2.94a.5.5 0 0 1 .699.106z\"}}]})(props);\n};\nexport function BsReplyAll (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.098 5.013a.144.144 0 0 1 .202.134V6.3a.5.5 0 0 0 .5.5c.667 0 2.013.005 3.3.822.984.624 1.99 1.76 2.595 3.876-1.02-.983-2.185-1.516-3.205-1.799a8.74 8.74 0 0 0-1.921-.306 7.404 7.404 0 0 0-.798.008h-.013l-.005.001h-.001L8.8 9.9l-.05-.498a.5.5 0 0 0-.45.498v1.153c0 .108-.11.176-.202.134L4.114 8.254a.502.502 0 0 0-.042-.028.147.147 0 0 1 0-.252.497.497 0 0 0 .042-.028l3.984-2.933zM9.3 10.386c.068 0 .143.003.223.006.434.02 1.034.086 1.7.271 1.326.368 2.896 1.202 3.94 3.08a.5.5 0 0 0 .933-.305c-.464-3.71-1.886-5.662-3.46-6.66-1.245-.79-2.527-.942-3.336-.971v-.66a1.144 1.144 0 0 0-1.767-.96l-3.994 2.94a1.147 1.147 0 0 0 0 1.946l3.994 2.94a1.144 1.144 0 0 0 1.767-.96v-.667z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.232 4.293a.5.5 0 0 0-.7-.106L.54 7.127a1.147 1.147 0 0 0 0 1.946l3.994 2.94a.5.5 0 1 0 .593-.805L1.114 8.254a.503.503 0 0 0-.042-.028.147.147 0 0 1 0-.252.5.5 0 0 0 .042-.028l4.012-2.954a.5.5 0 0 0 .106-.699z\"}}]})(props);\n};\nexport function BsReplyFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.921 11.9 1.353 8.62a.719.719 0 0 1 0-1.238L5.921 4.1A.716.716 0 0 1 7 4.719V6c1.5 0 6 0 7 8-2.5-4.5-7-4-7-4v1.281c0 .56-.606.898-1.079.62z\"}}]})(props);\n};\nexport function BsReply (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.598 5.013a.144.144 0 0 1 .202.134V6.3a.5.5 0 0 0 .5.5c.667 0 2.013.005 3.3.822.984.624 1.99 1.76 2.595 3.876-1.02-.983-2.185-1.516-3.205-1.799a8.74 8.74 0 0 0-1.921-.306 7.404 7.404 0 0 0-.798.008h-.013l-.005.001h-.001L7.3 9.9l-.05-.498a.5.5 0 0 0-.45.498v1.153c0 .108-.11.176-.202.134L2.614 8.254a.503.503 0 0 0-.042-.028.147.147 0 0 1 0-.252.499.499 0 0 0 .042-.028l3.984-2.933zM7.8 10.386c.068 0 .143.003.223.006.434.02 1.034.086 1.7.271 1.326.368 2.896 1.202 3.94 3.08a.5.5 0 0 0 .933-.305c-.464-3.71-1.886-5.662-3.46-6.66-1.245-.79-2.527-.942-3.336-.971v-.66a1.144 1.144 0 0 0-1.767-.96l-3.994 2.94a1.147 1.147 0 0 0 0 1.946l3.994 2.94a1.144 1.144 0 0 0 1.767-.96v-.667z\"}}]})(props);\n};\nexport function BsRssFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm1.5 2.5c5.523 0 10 4.477 10 10a1 1 0 1 1-2 0 8 8 0 0 0-8-8 1 1 0 0 1 0-2zm0 4a6 6 0 0 1 6 6 1 1 0 1 1-2 0 4 4 0 0 0-4-4 1 1 0 0 1 0-2zm.5 7a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsRss (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 12a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm-3-8.5a1 1 0 0 1 1-1c5.523 0 10 4.477 10 10a1 1 0 1 1-2 0 8 8 0 0 0-8-8 1 1 0 0 1-1-1zm0 4a1 1 0 0 1 1-1 6 6 0 0 1 6 6 1 1 0 1 1-2 0 4 4 0 0 0-4-4 1 1 0 0 1-1-1z\"}}]})(props);\n};\nexport function BsRulers (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 0a1 1 0 0 0-1 1v14a1 1 0 0 0 1 1h5v-1H2v-1h4v-1H4v-1h2v-1H2v-1h4V9H4V8h2V7H2V6h4V2h1v4h1V4h1v2h1V2h1v4h1V4h1v2h1V2h1v4h1V1a1 1 0 0 0-1-1H1z\"}}]})(props);\n};\nexport function BsSafeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.778 9.414A2 2 0 1 1 6.95 6.586a2 2 0 0 1 2.828 2.828z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 0A1.5 1.5 0 0 0 1 1.5V3H.5a.5.5 0 0 0 0 1H1v3.5H.5a.5.5 0 0 0 0 1H1V12H.5a.5.5 0 0 0 0 1H1v1.5A1.5 1.5 0 0 0 2.5 16h12a1.5 1.5 0 0 0 1.5-1.5v-13A1.5 1.5 0 0 0 14.5 0h-12zm3.036 4.464 1.09 1.09a3.003 3.003 0 0 1 3.476 0l1.09-1.09a.5.5 0 1 1 .707.708l-1.09 1.09c.74 1.037.74 2.44 0 3.476l1.09 1.09a.5.5 0 1 1-.707.708l-1.09-1.09a3.002 3.002 0 0 1-3.476 0l-1.09 1.09a.5.5 0 1 1-.708-.708l1.09-1.09a3.003 3.003 0 0 1 0-3.476l-1.09-1.09a.5.5 0 1 1 .708-.708zM14 6.5v3a.5.5 0 0 1-1 0v-3a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsSafe (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 1.5A1.5 1.5 0 0 1 2.5 0h12A1.5 1.5 0 0 1 16 1.5v13a1.5 1.5 0 0 1-1.5 1.5h-12A1.5 1.5 0 0 1 1 14.5V13H.5a.5.5 0 0 1 0-1H1V8.5H.5a.5.5 0 0 1 0-1H1V4H.5a.5.5 0 0 1 0-1H1V1.5zM2.5 1a.5.5 0 0 0-.5.5v13a.5.5 0 0 0 .5.5h12a.5.5 0 0 0 .5-.5v-13a.5.5 0 0 0-.5-.5h-12z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 6a.5.5 0 0 1 .5.5v3a.5.5 0 0 1-1 0v-3a.5.5 0 0 1 .5-.5zM4.828 4.464a.5.5 0 0 1 .708 0l1.09 1.09a3.003 3.003 0 0 1 3.476 0l1.09-1.09a.5.5 0 1 1 .707.708l-1.09 1.09c.74 1.037.74 2.44 0 3.476l1.09 1.09a.5.5 0 1 1-.707.708l-1.09-1.09a3.002 3.002 0 0 1-3.476 0l-1.09 1.09a.5.5 0 1 1-.708-.708l1.09-1.09a3.003 3.003 0 0 1 0-3.476l-1.09-1.09a.5.5 0 0 1 0-.708zM6.95 6.586a2 2 0 1 0 2.828 2.828A2 2 0 0 0 6.95 6.586z\"}}]})(props);\n};\nexport function BsSafe2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.563 8H5.035a3.482 3.482 0 0 1 .662-1.596l1.08 1.08c-.094.16-.167.332-.214.516zm.921-1.223-1.08-1.08A3.482 3.482 0 0 1 8 5.035v1.528c-.184.047-.357.12-.516.214zM9 6.563V5.035a3.482 3.482 0 0 1 1.596.662l-1.08 1.08A1.988 1.988 0 0 0 9 6.563zm1.223.921 1.08-1.08c.343.458.577 1.003.662 1.596h-1.528a1.989 1.989 0 0 0-.214-.516zM10.437 9h1.528a3.483 3.483 0 0 1-.662 1.596l-1.08-1.08c.094-.16.167-.332.214-.516zm-.921 1.223 1.08 1.08A3.483 3.483 0 0 1 9 11.965v-1.528c.184-.047.357-.12.516-.214zM8 10.437v1.528a3.483 3.483 0 0 1-1.596-.662l1.08-1.08c.16.094.332.167.516.214zm-1.223-.921-1.08 1.08A3.482 3.482 0 0 1 5.035 9h1.528c.047.184.12.357.214.516zM7.5 8.5a1 1 0 1 1 2 0 1 1 0 0 1-2 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 1A1.5 1.5 0 0 0 1 2.5V3H.5a.5.5 0 0 0 0 1H1v4H.5a.5.5 0 0 0 0 1H1v4H.5a.5.5 0 0 0 0 1H1v.5A1.5 1.5 0 0 0 2.5 16h12a1.5 1.5 0 0 0 1.5-1.5v-12A1.5 1.5 0 0 0 14.5 1h-12zm6 3a4.5 4.5 0 1 1 0 9 4.5 4.5 0 0 1 0-9z\"}}]})(props);\n};\nexport function BsSafe2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 2.5A1.5 1.5 0 0 1 2.5 1h12A1.5 1.5 0 0 1 16 2.5v12a1.5 1.5 0 0 1-1.5 1.5h-12A1.5 1.5 0 0 1 1 14.5V14H.5a.5.5 0 0 1 0-1H1V9H.5a.5.5 0 0 1 0-1H1V4H.5a.5.5 0 0 1 0-1H1v-.5zM2.5 2a.5.5 0 0 0-.5.5v12a.5.5 0 0 0 .5.5h12a.5.5 0 0 0 .5-.5v-12a.5.5 0 0 0-.5-.5h-12z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.035 8h1.528c.047-.184.12-.357.214-.516l-1.08-1.08A3.482 3.482 0 0 0 5.035 8zm1.369-2.303 1.08 1.08c.16-.094.332-.167.516-.214V5.035a3.482 3.482 0 0 0-1.596.662zM9 5.035v1.528c.184.047.357.12.516.214l1.08-1.08A3.482 3.482 0 0 0 9 5.035zm2.303 1.369-1.08 1.08c.094.16.167.332.214.516h1.528a3.483 3.483 0 0 0-.662-1.596zM11.965 9h-1.528c-.047.184-.12.357-.214.516l1.08 1.08A3.483 3.483 0 0 0 11.965 9zm-1.369 2.303-1.08-1.08c-.16.094-.332.167-.516.214v1.528a3.483 3.483 0 0 0 1.596-.662zM8 11.965v-1.528a1.989 1.989 0 0 1-.516-.214l-1.08 1.08A3.483 3.483 0 0 0 8 11.965zm-2.303-1.369 1.08-1.08A1.988 1.988 0 0 1 6.563 9H5.035c.085.593.319 1.138.662 1.596zM4 8.5a4.5 4.5 0 1 1 9 0 4.5 4.5 0 0 1-9 0zm4.5-1a1 1 0 1 0 0 2 1 1 0 0 0 0-2z\"}}]})(props);\n};\nexport function BsSaveFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 1.5A1.5 1.5 0 0 1 10 0h4a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h6c-.314.418-.5.937-.5 1.5v7.793L4.854 6.646a.5.5 0 1 0-.708.708l3.5 3.5a.5.5 0 0 0 .708 0l3.5-3.5a.5.5 0 0 0-.708-.708L8.5 9.293V1.5z\"}}]})(props);\n};\nexport function BsSave (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H9.5a1 1 0 0 0-1 1v7.293l2.646-2.647a.5.5 0 0 1 .708.708l-3.5 3.5a.5.5 0 0 1-.708 0l-3.5-3.5a.5.5 0 1 1 .708-.708L7.5 9.293V2a2 2 0 0 1 2-2H14a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h2.5a.5.5 0 0 1 0 1H2z\"}}]})(props);\n};\nexport function BsSave2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 1.5A1.5 1.5 0 0 1 10 0h4a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h6c-.314.418-.5.937-.5 1.5v6h-2a.5.5 0 0 0-.354.854l2.5 2.5a.5.5 0 0 0 .708 0l2.5-2.5A.5.5 0 0 0 10.5 7.5h-2v-6z\"}}]})(props);\n};\nexport function BsSave2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H9.5a1 1 0 0 0-1 1v4.5h2a.5.5 0 0 1 .354.854l-2.5 2.5a.5.5 0 0 1-.708 0l-2.5-2.5A.5.5 0 0 1 5.5 6.5h2V2a2 2 0 0 1 2-2H14a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h2.5a.5.5 0 0 1 0 1H2z\"}}]})(props);\n};\nexport function BsScissors (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 3.5c-.614-.884-.074-1.962.858-2.5L8 7.226 11.642 1c.932.538 1.472 1.616.858 2.5L8.81 8.61l1.556 2.661a2.5 2.5 0 1 1-.794.637L8 9.73l-1.572 2.177a2.5 2.5 0 1 1-.794-.637L7.19 8.61 3.5 3.5zm2.5 10a1.5 1.5 0 1 0-3 0 1.5 1.5 0 0 0 3 0zm7 0a1.5 1.5 0 1 0-3 0 1.5 1.5 0 0 0 3 0z\"}}]})(props);\n};\nexport function BsScrewdriver (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m0 1 1-1 3.081 2.2a1 1 0 0 1 .419.815v.07a1 1 0 0 0 .293.708L10.5 9.5l.914-.305a1 1 0 0 1 1.023.242l3.356 3.356a1 1 0 0 1 0 1.414l-1.586 1.586a1 1 0 0 1-1.414 0l-3.356-3.356a1 1 0 0 1-.242-1.023L9.5 10.5 3.793 4.793a1 1 0 0 0-.707-.293h-.071a1 1 0 0 1-.814-.419L0 1zm11.354 9.646a.5.5 0 0 0-.708.708l3 3a.5.5 0 0 0 .708-.708l-3-3z\"}}]})(props);\n};\nexport function BsSdCardFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M12.5 0H5.914a1.5 1.5 0 0 0-1.06.44L2.439 2.853A1.5 1.5 0 0 0 2 3.914V14.5A1.5 1.5 0 0 0 3.5 16h9a1.5 1.5 0 0 0 1.5-1.5v-13A1.5 1.5 0 0 0 12.5 0zm-7 2.75a.75.75 0 0 1 .75.75v2a.75.75 0 0 1-1.5 0v-2a.75.75 0 0 1 .75-.75zm2 0a.75.75 0 0 1 .75.75v2a.75.75 0 0 1-1.5 0v-2a.75.75 0 0 1 .75-.75zm2.75.75a.75.75 0 0 0-1.5 0v2a.75.75 0 0 0 1.5 0v-2zm1.25-.75a.75.75 0 0 1 .75.75v2a.75.75 0 0 1-1.5 0v-2a.75.75 0 0 1 .75-.75z\"}}]})(props);\n};\nexport function BsSdCard (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.25 3.5a.75.75 0 0 0-1.5 0v2a.75.75 0 0 0 1.5 0v-2zm2 0a.75.75 0 0 0-1.5 0v2a.75.75 0 0 0 1.5 0v-2zm2 0a.75.75 0 0 0-1.5 0v2a.75.75 0 0 0 1.5 0v-2zm2 0a.75.75 0 0 0-1.5 0v2a.75.75 0 0 0 1.5 0v-2z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M5.914 0H12.5A1.5 1.5 0 0 1 14 1.5v13a1.5 1.5 0 0 1-1.5 1.5h-9A1.5 1.5 0 0 1 2 14.5V3.914c0-.398.158-.78.44-1.06L4.853.439A1.5 1.5 0 0 1 5.914 0zM13 1.5a.5.5 0 0 0-.5-.5H5.914a.5.5 0 0 0-.353.146L3.146 3.561A.5.5 0 0 0 3 3.914V14.5a.5.5 0 0 0 .5.5h9a.5.5 0 0 0 .5-.5v-13z\"}}]})(props);\n};\nexport function BsSearch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0z\"}}]})(props);\n};\nexport function BsSegmentedNav (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 6a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v2a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V6zm6 3h4V5H6v4zm9-1V6a1 1 0 0 0-1-1h-3v4h3a1 1 0 0 0 1-1z\"}}]})(props);\n};\nexport function BsServer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.333 2.667C1.333 1.194 4.318 0 8 0s6.667 1.194 6.667 2.667V4c0 1.473-2.985 2.667-6.667 2.667S1.333 5.473 1.333 4V2.667z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1.333 6.334v3C1.333 10.805 4.318 12 8 12s6.667-1.194 6.667-2.667V6.334a6.51 6.51 0 0 1-1.458.79C11.81 7.684 9.967 8 8 8c-1.966 0-3.809-.317-5.208-.876a6.508 6.508 0 0 1-1.458-.79z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.667 11.668a6.51 6.51 0 0 1-1.458.789c-1.4.56-3.242.876-5.21.876-1.966 0-3.809-.316-5.208-.876a6.51 6.51 0 0 1-1.458-.79v1.666C1.333 14.806 4.318 16 8 16s6.667-1.194 6.667-2.667v-1.665z\"}}]})(props);\n};\nexport function BsShareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 2.5a2.5 2.5 0 1 1 .603 1.628l-6.718 3.12a2.499 2.499 0 0 1 0 1.504l6.718 3.12a2.5 2.5 0 1 1-.488.876l-6.718-3.12a2.5 2.5 0 1 1 0-3.256l6.718-3.12A2.5 2.5 0 0 1 11 2.5z\"}}]})(props);\n};\nexport function BsShare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 1a1.5 1.5 0 1 0 0 3 1.5 1.5 0 0 0 0-3zM11 2.5a2.5 2.5 0 1 1 .603 1.628l-6.718 3.12a2.499 2.499 0 0 1 0 1.504l6.718 3.12a2.5 2.5 0 1 1-.488.876l-6.718-3.12a2.5 2.5 0 1 1 0-3.256l6.718-3.12A2.5 2.5 0 0 1 11 2.5zm-8.5 4a1.5 1.5 0 1 0 0 3 1.5 1.5 0 0 0 0-3zm11 5.5a1.5 1.5 0 1 0 0 3 1.5 1.5 0 0 0 0-3z\"}}]})(props);\n};\nexport function BsShieldCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.338 1.59a61.44 61.44 0 0 0-2.837.856.481.481 0 0 0-.328.39c-.554 4.157.726 7.19 2.253 9.188a10.725 10.725 0 0 0 2.287 2.233c.346.244.652.42.893.533.12.057.218.095.293.118a.55.55 0 0 0 .101.025.615.615 0 0 0 .1-.025c.076-.023.174-.061.294-.118.24-.113.547-.29.893-.533a10.726 10.726 0 0 0 2.287-2.233c1.527-1.997 2.807-5.031 2.253-9.188a.48.48 0 0 0-.328-.39c-.651-.213-1.75-.56-2.837-.855C9.552 1.29 8.531 1.067 8 1.067c-.53 0-1.552.223-2.662.524zM5.072.56C6.157.265 7.31 0 8 0s1.843.265 2.928.56c1.11.3 2.229.655 2.887.87a1.54 1.54 0 0 1 1.044 1.262c.596 4.477-.787 7.795-2.465 9.99a11.775 11.775 0 0 1-2.517 2.453 7.159 7.159 0 0 1-1.048.625c-.28.132-.581.24-.829.24s-.548-.108-.829-.24a7.158 7.158 0 0 1-1.048-.625 11.777 11.777 0 0 1-2.517-2.453C1.928 10.487.545 7.169 1.141 2.692A1.54 1.54 0 0 1 2.185 1.43 62.456 62.456 0 0 1 5.072.56z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.854 5.146a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7.5 7.793l2.646-2.647a.5.5 0 0 1 .708 0z\"}}]})(props);\n};\nexport function BsShieldExclamation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.338 1.59a61.44 61.44 0 0 0-2.837.856.481.481 0 0 0-.328.39c-.554 4.157.726 7.19 2.253 9.188a10.725 10.725 0 0 0 2.287 2.233c.346.244.652.42.893.533.12.057.218.095.293.118a.55.55 0 0 0 .101.025.615.615 0 0 0 .1-.025c.076-.023.174-.061.294-.118.24-.113.547-.29.893-.533a10.726 10.726 0 0 0 2.287-2.233c1.527-1.997 2.807-5.031 2.253-9.188a.48.48 0 0 0-.328-.39c-.651-.213-1.75-.56-2.837-.855C9.552 1.29 8.531 1.067 8 1.067c-.53 0-1.552.223-2.662.524zM5.072.56C6.157.265 7.31 0 8 0s1.843.265 2.928.56c1.11.3 2.229.655 2.887.87a1.54 1.54 0 0 1 1.044 1.262c.596 4.477-.787 7.795-2.465 9.99a11.775 11.775 0 0 1-2.517 2.453 7.159 7.159 0 0 1-1.048.625c-.28.132-.581.24-.829.24s-.548-.108-.829-.24a7.158 7.158 0 0 1-1.048-.625 11.777 11.777 0 0 1-2.517-2.453C1.928 10.487.545 7.169 1.141 2.692A1.54 1.54 0 0 1 2.185 1.43 62.456 62.456 0 0 1 5.072.56z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.001 11a1 1 0 1 1 2 0 1 1 0 0 1-2 0zM7.1 4.995a.905.905 0 1 1 1.8 0l-.35 3.507a.553.553 0 0 1-1.1 0L7.1 4.995z\"}}]})(props);\n};\nexport function BsShieldFillCheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 0c-.69 0-1.843.265-2.928.56-1.11.3-2.229.655-2.887.87a1.54 1.54 0 0 0-1.044 1.262c-.596 4.477.787 7.795 2.465 9.99a11.777 11.777 0 0 0 2.517 2.453c.386.273.744.482 1.048.625.28.132.581.24.829.24s.548-.108.829-.24a7.159 7.159 0 0 0 1.048-.625 11.775 11.775 0 0 0 2.517-2.453c1.678-2.195 3.061-5.513 2.465-9.99a1.541 1.541 0 0 0-1.044-1.263 62.467 62.467 0 0 0-2.887-.87C9.843.266 8.69 0 8 0zm2.146 5.146a.5.5 0 0 1 .708.708l-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 1 1 .708-.708L7.5 7.793l2.646-2.647z\"}}]})(props);\n};\nexport function BsShieldFillExclamation (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 0c-.69 0-1.843.265-2.928.56-1.11.3-2.229.655-2.887.87a1.54 1.54 0 0 0-1.044 1.262c-.596 4.477.787 7.795 2.465 9.99a11.777 11.777 0 0 0 2.517 2.453c.386.273.744.482 1.048.625.28.132.581.24.829.24s.548-.108.829-.24a7.159 7.159 0 0 0 1.048-.625 11.775 11.775 0 0 0 2.517-2.453c1.678-2.195 3.061-5.513 2.465-9.99a1.541 1.541 0 0 0-1.044-1.263 62.467 62.467 0 0 0-2.887-.87C9.843.266 8.69 0 8 0zm-.55 8.502L7.1 4.995a.905.905 0 1 1 1.8 0l-.35 3.507a.552.552 0 0 1-1.1 0zM8.002 12a1 1 0 1 1 0-2 1 1 0 0 1 0 2z\"}}]})(props);\n};\nexport function BsShieldFillMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 0c-.69 0-1.843.265-2.928.56-1.11.3-2.229.655-2.887.87a1.54 1.54 0 0 0-1.044 1.262c-.596 4.477.787 7.795 2.465 9.99a11.777 11.777 0 0 0 2.517 2.453c.386.273.744.482 1.048.625.28.132.581.24.829.24s.548-.108.829-.24a7.159 7.159 0 0 0 1.048-.625 11.775 11.775 0 0 0 2.517-2.453c1.678-2.195 3.061-5.513 2.465-9.99a1.541 1.541 0 0 0-1.044-1.263 62.467 62.467 0 0 0-2.887-.87C9.843.266 8.69 0 8 0zM6 7.5a.5.5 0 0 1 0-1h4a.5.5 0 0 1 0 1H6z\"}}]})(props);\n};\nexport function BsShieldFillPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 0c-.69 0-1.843.265-2.928.56-1.11.3-2.229.655-2.887.87a1.54 1.54 0 0 0-1.044 1.262c-.596 4.477.787 7.795 2.465 9.99a11.777 11.777 0 0 0 2.517 2.453c.386.273.744.482 1.048.625.28.132.581.24.829.24s.548-.108.829-.24a7.159 7.159 0 0 0 1.048-.625 11.775 11.775 0 0 0 2.517-2.453c1.678-2.195 3.061-5.513 2.465-9.99a1.541 1.541 0 0 0-1.044-1.263 62.467 62.467 0 0 0-2.887-.87C9.843.266 8.69 0 8 0zm-.5 5a.5.5 0 0 1 1 0v1.5H10a.5.5 0 0 1 0 1H8.5V9a.5.5 0 0 1-1 0V7.5H6a.5.5 0 0 1 0-1h1.5V5z\"}}]})(props);\n};\nexport function BsShieldFillX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0c-.69 0-1.843.265-2.928.56-1.11.3-2.229.655-2.887.87a1.54 1.54 0 0 0-1.044 1.262c-.596 4.477.787 7.795 2.465 9.99a11.777 11.777 0 0 0 2.517 2.453c.386.273.744.482 1.048.625.28.132.581.24.829.24s.548-.108.829-.24a7.159 7.159 0 0 0 1.048-.625 11.775 11.775 0 0 0 2.517-2.453c1.678-2.195 3.061-5.513 2.465-9.99a1.541 1.541 0 0 0-1.044-1.263 62.467 62.467 0 0 0-2.887-.87C9.843.266 8.69 0 8 0zM6.854 5.146 8 6.293l1.146-1.147a.5.5 0 1 1 .708.708L8.707 7l1.147 1.146a.5.5 0 0 1-.708.708L8 7.707 6.854 8.854a.5.5 0 1 1-.708-.708L7.293 7 6.146 5.854a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsShieldFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.072.56C6.157.265 7.31 0 8 0s1.843.265 2.928.56c1.11.3 2.229.655 2.887.87a1.54 1.54 0 0 1 1.044 1.262c.596 4.477-.787 7.795-2.465 9.99a11.775 11.775 0 0 1-2.517 2.453 7.159 7.159 0 0 1-1.048.625c-.28.132-.581.24-.829.24s-.548-.108-.829-.24a7.158 7.158 0 0 1-1.048-.625 11.777 11.777 0 0 1-2.517-2.453C1.928 10.487.545 7.169 1.141 2.692A1.54 1.54 0 0 1 2.185 1.43 62.456 62.456 0 0 1 5.072.56z\"}}]})(props);\n};\nexport function BsShieldLockFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 0c-.69 0-1.843.265-2.928.56-1.11.3-2.229.655-2.887.87a1.54 1.54 0 0 0-1.044 1.262c-.596 4.477.787 7.795 2.465 9.99a11.777 11.777 0 0 0 2.517 2.453c.386.273.744.482 1.048.625.28.132.581.24.829.24s.548-.108.829-.24a7.159 7.159 0 0 0 1.048-.625 11.775 11.775 0 0 0 2.517-2.453c1.678-2.195 3.061-5.513 2.465-9.99a1.541 1.541 0 0 0-1.044-1.263 62.467 62.467 0 0 0-2.887-.87C9.843.266 8.69 0 8 0zm0 5a1.5 1.5 0 0 1 .5 2.915l.385 1.99a.5.5 0 0 1-.491.595h-.788a.5.5 0 0 1-.49-.595l.384-1.99A1.5 1.5 0 0 1 8 5z\"}}]})(props);\n};\nexport function BsShieldLock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.338 1.59a61.44 61.44 0 0 0-2.837.856.481.481 0 0 0-.328.39c-.554 4.157.726 7.19 2.253 9.188a10.725 10.725 0 0 0 2.287 2.233c.346.244.652.42.893.533.12.057.218.095.293.118a.55.55 0 0 0 .101.025.615.615 0 0 0 .1-.025c.076-.023.174-.061.294-.118.24-.113.547-.29.893-.533a10.726 10.726 0 0 0 2.287-2.233c1.527-1.997 2.807-5.031 2.253-9.188a.48.48 0 0 0-.328-.39c-.651-.213-1.75-.56-2.837-.855C9.552 1.29 8.531 1.067 8 1.067c-.53 0-1.552.223-2.662.524zM5.072.56C6.157.265 7.31 0 8 0s1.843.265 2.928.56c1.11.3 2.229.655 2.887.87a1.54 1.54 0 0 1 1.044 1.262c.596 4.477-.787 7.795-2.465 9.99a11.775 11.775 0 0 1-2.517 2.453 7.159 7.159 0 0 1-1.048.625c-.28.132-.581.24-.829.24s-.548-.108-.829-.24a7.158 7.158 0 0 1-1.048-.625 11.777 11.777 0 0 1-2.517-2.453C1.928 10.487.545 7.169 1.141 2.692A1.54 1.54 0 0 1 2.185 1.43 62.456 62.456 0 0 1 5.072.56z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 6.5a1.5 1.5 0 0 1-1 1.415l.385 1.99a.5.5 0 0 1-.491.595h-.788a.5.5 0 0 1-.49-.595l.384-1.99a1.5 1.5 0 1 1 2-1.415z\"}}]})(props);\n};\nexport function BsShieldMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.338 1.59a61.44 61.44 0 0 0-2.837.856.481.481 0 0 0-.328.39c-.554 4.157.726 7.19 2.253 9.188a10.725 10.725 0 0 0 2.287 2.233c.346.244.652.42.893.533.12.057.218.095.293.118a.55.55 0 0 0 .101.025.615.615 0 0 0 .1-.025c.076-.023.174-.061.294-.118.24-.113.547-.29.893-.533a10.726 10.726 0 0 0 2.287-2.233c1.527-1.997 2.807-5.031 2.253-9.188a.48.48 0 0 0-.328-.39c-.651-.213-1.75-.56-2.837-.855C9.552 1.29 8.531 1.067 8 1.067c-.53 0-1.552.223-2.662.524zM5.072.56C6.157.265 7.31 0 8 0s1.843.265 2.928.56c1.11.3 2.229.655 2.887.87a1.54 1.54 0 0 1 1.044 1.262c.596 4.477-.787 7.795-2.465 9.99a11.775 11.775 0 0 1-2.517 2.453 7.159 7.159 0 0 1-1.048.625c-.28.132-.581.24-.829.24s-.548-.108-.829-.24a7.158 7.158 0 0 1-1.048-.625 11.777 11.777 0 0 1-2.517-2.453C1.928 10.487.545 7.169 1.141 2.692A1.54 1.54 0 0 1 2.185 1.43 62.456 62.456 0 0 1 5.072.56z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 7a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1H6a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsShieldPlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.338 1.59a61.44 61.44 0 0 0-2.837.856.481.481 0 0 0-.328.39c-.554 4.157.726 7.19 2.253 9.188a10.725 10.725 0 0 0 2.287 2.233c.346.244.652.42.893.533.12.057.218.095.293.118a.55.55 0 0 0 .101.025.615.615 0 0 0 .1-.025c.076-.023.174-.061.294-.118.24-.113.547-.29.893-.533a10.726 10.726 0 0 0 2.287-2.233c1.527-1.997 2.807-5.031 2.253-9.188a.48.48 0 0 0-.328-.39c-.651-.213-1.75-.56-2.837-.855C9.552 1.29 8.531 1.067 8 1.067c-.53 0-1.552.223-2.662.524zM5.072.56C6.157.265 7.31 0 8 0s1.843.265 2.928.56c1.11.3 2.229.655 2.887.87a1.54 1.54 0 0 1 1.044 1.262c.596 4.477-.787 7.795-2.465 9.99a11.775 11.775 0 0 1-2.517 2.453 7.159 7.159 0 0 1-1.048.625c-.28.132-.581.24-.829.24s-.548-.108-.829-.24a7.158 7.158 0 0 1-1.048-.625 11.777 11.777 0 0 1-2.517-2.453C1.928 10.487.545 7.169 1.141 2.692A1.54 1.54 0 0 1 2.185 1.43 62.456 62.456 0 0 1 5.072.56z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4.5a.5.5 0 0 1 .5.5v1.5H10a.5.5 0 0 1 0 1H8.5V9a.5.5 0 0 1-1 0V7.5H6a.5.5 0 0 1 0-1h1.5V5a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsShieldShaded (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 14.933a.615.615 0 0 0 .1-.025c.076-.023.174-.061.294-.118.24-.113.547-.29.893-.533a10.726 10.726 0 0 0 2.287-2.233c1.527-1.997 2.807-5.031 2.253-9.188a.48.48 0 0 0-.328-.39c-.651-.213-1.75-.56-2.837-.855C9.552 1.29 8.531 1.067 8 1.067v13.866zM5.072.56C6.157.265 7.31 0 8 0s1.843.265 2.928.56c1.11.3 2.229.655 2.887.87a1.54 1.54 0 0 1 1.044 1.262c.596 4.477-.787 7.795-2.465 9.99a11.775 11.775 0 0 1-2.517 2.453 7.159 7.159 0 0 1-1.048.625c-.28.132-.581.24-.829.24s-.548-.108-.829-.24a7.158 7.158 0 0 1-1.048-.625 11.777 11.777 0 0 1-2.517-2.453C1.928 10.487.545 7.169 1.141 2.692A1.54 1.54 0 0 1 2.185 1.43 62.456 62.456 0 0 1 5.072.56z\"}}]})(props);\n};\nexport function BsShieldSlashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.093 3.093c-.465 4.275.885 7.46 2.513 9.589a11.777 11.777 0 0 0 2.517 2.453c.386.273.744.482 1.048.625.28.132.581.24.829.24s.548-.108.829-.24a7.159 7.159 0 0 0 1.048-.625 11.32 11.32 0 0 0 1.733-1.525L1.093 3.093zm12.215 8.215L3.128 1.128A61.369 61.369 0 0 1 5.073.56C6.157.265 7.31 0 8 0s1.843.265 2.928.56c1.11.3 2.229.655 2.887.87a1.54 1.54 0 0 1 1.044 1.262c.483 3.626-.332 6.491-1.551 8.616zm.338 3.046-13-13 .708-.708 13 13-.707.707z\"}}]})(props);\n};\nexport function BsShieldSlash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.093 3.093c-.465 4.275.885 7.46 2.513 9.589a11.777 11.777 0 0 0 2.517 2.453c.386.273.744.482 1.048.625.28.132.581.24.829.24s.548-.108.829-.24a7.159 7.159 0 0 0 1.048-.625 11.32 11.32 0 0 0 1.733-1.525l-.745-.745a10.27 10.27 0 0 1-1.578 1.392c-.346.244-.652.42-.893.533-.12.057-.218.095-.293.118a.55.55 0 0 1-.101.025.615.615 0 0 1-.1-.025 2.348 2.348 0 0 1-.294-.118 6.141 6.141 0 0 1-.893-.533 10.725 10.725 0 0 1-2.287-2.233C3.053 10.228 1.879 7.594 2.06 4.06l-.967-.967zM3.98 1.98l-.852-.852A58.935 58.935 0 0 1 5.072.559C6.157.266 7.31 0 8 0s1.843.265 2.928.56c1.11.3 2.229.655 2.887.87a1.54 1.54 0 0 1 1.044 1.262c.483 3.626-.332 6.491-1.551 8.616l-.77-.77c1.042-1.915 1.72-4.469 1.29-7.702a.48.48 0 0 0-.33-.39c-.65-.213-1.75-.56-2.836-.855C9.552 1.29 8.531 1.067 8 1.067c-.53 0-1.552.223-2.662.524a49.7 49.7 0 0 0-1.357.39zm9.666 12.374-13-13 .708-.708 13 13-.707.707z\"}}]})(props);\n};\nexport function BsShieldX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.338 1.59a61.44 61.44 0 0 0-2.837.856.481.481 0 0 0-.328.39c-.554 4.157.726 7.19 2.253 9.188a10.725 10.725 0 0 0 2.287 2.233c.346.244.652.42.893.533.12.057.218.095.293.118a.55.55 0 0 0 .101.025.615.615 0 0 0 .1-.025c.076-.023.174-.061.294-.118.24-.113.547-.29.893-.533a10.726 10.726 0 0 0 2.287-2.233c1.527-1.997 2.807-5.031 2.253-9.188a.48.48 0 0 0-.328-.39c-.651-.213-1.75-.56-2.837-.855C9.552 1.29 8.531 1.067 8 1.067c-.53 0-1.552.223-2.662.524zM5.072.56C6.157.265 7.31 0 8 0s1.843.265 2.928.56c1.11.3 2.229.655 2.887.87a1.54 1.54 0 0 1 1.044 1.262c.596 4.477-.787 7.795-2.465 9.99a11.775 11.775 0 0 1-2.517 2.453 7.159 7.159 0 0 1-1.048.625c-.28.132-.581.24-.829.24s-.548-.108-.829-.24a7.158 7.158 0 0 1-1.048-.625 11.777 11.777 0 0 1-2.517-2.453C1.928 10.487.545 7.169 1.141 2.692A1.54 1.54 0 0 1 2.185 1.43 62.456 62.456 0 0 1 5.072.56z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.146 5.146a.5.5 0 0 1 .708 0L8 6.293l1.146-1.147a.5.5 0 1 1 .708.708L8.707 7l1.147 1.146a.5.5 0 0 1-.708.708L8 7.707 6.854 8.854a.5.5 0 1 1-.708-.708L7.293 7 6.146 5.854a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsShield (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.338 1.59a61.44 61.44 0 0 0-2.837.856.481.481 0 0 0-.328.39c-.554 4.157.726 7.19 2.253 9.188a10.725 10.725 0 0 0 2.287 2.233c.346.244.652.42.893.533.12.057.218.095.293.118a.55.55 0 0 0 .101.025.615.615 0 0 0 .1-.025c.076-.023.174-.061.294-.118.24-.113.547-.29.893-.533a10.726 10.726 0 0 0 2.287-2.233c1.527-1.997 2.807-5.031 2.253-9.188a.48.48 0 0 0-.328-.39c-.651-.213-1.75-.56-2.837-.855C9.552 1.29 8.531 1.067 8 1.067c-.53 0-1.552.223-2.662.524zM5.072.56C6.157.265 7.31 0 8 0s1.843.265 2.928.56c1.11.3 2.229.655 2.887.87a1.54 1.54 0 0 1 1.044 1.262c.596 4.477-.787 7.795-2.465 9.99a11.775 11.775 0 0 1-2.517 2.453 7.159 7.159 0 0 1-1.048.625c-.28.132-.581.24-.829.24s-.548-.108-.829-.24a7.158 7.158 0 0 1-1.048-.625 11.777 11.777 0 0 1-2.517-2.453C1.928 10.487.545 7.169 1.141 2.692A1.54 1.54 0 0 1 2.185 1.43 62.456 62.456 0 0 1 5.072.56z\"}}]})(props);\n};\nexport function BsShiftFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.27 2.047a1 1 0 0 1 1.46 0l6.345 6.77c.6.638.146 1.683-.73 1.683H11.5v3a1 1 0 0 1-1 1h-5a1 1 0 0 1-1-1v-3H1.654C.78 10.5.326 9.455.924 8.816L7.27 2.047z\"}}]})(props);\n};\nexport function BsShift (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.27 2.047a1 1 0 0 1 1.46 0l6.345 6.77c.6.638.146 1.683-.73 1.683H11.5v3a1 1 0 0 1-1 1h-5a1 1 0 0 1-1-1v-3H1.654C.78 10.5.326 9.455.924 8.816L7.27 2.047zM14.346 9.5 8 2.731 1.654 9.5H4.5a1 1 0 0 1 1 1v3h5v-3a1 1 0 0 1 1-1h2.846z\"}}]})(props);\n};\nexport function BsShopWindow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.97 1.35A1 1 0 0 1 3.73 1h8.54a1 1 0 0 1 .76.35l2.609 3.044A1.5 1.5 0 0 1 16 5.37v.255a2.375 2.375 0 0 1-4.25 1.458A2.371 2.371 0 0 1 9.875 8 2.37 2.37 0 0 1 8 7.083 2.37 2.37 0 0 1 6.125 8a2.37 2.37 0 0 1-1.875-.917A2.375 2.375 0 0 1 0 5.625V5.37a1.5 1.5 0 0 1 .361-.976l2.61-3.045zm1.78 4.275a1.375 1.375 0 0 0 2.75 0 .5.5 0 0 1 1 0 1.375 1.375 0 0 0 2.75 0 .5.5 0 0 1 1 0 1.375 1.375 0 1 0 2.75 0V5.37a.5.5 0 0 0-.12-.325L12.27 2H3.73L1.12 5.045A.5.5 0 0 0 1 5.37v.255a1.375 1.375 0 0 0 2.75 0 .5.5 0 0 1 1 0zM1.5 8.5A.5.5 0 0 1 2 9v6h12V9a.5.5 0 0 1 1 0v6h.5a.5.5 0 0 1 0 1H.5a.5.5 0 0 1 0-1H1V9a.5.5 0 0 1 .5-.5zm2 .5a.5.5 0 0 1 .5.5V13h8V9.5a.5.5 0 0 1 1 0V13a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V9.5a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsShop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.97 1.35A1 1 0 0 1 3.73 1h8.54a1 1 0 0 1 .76.35l2.609 3.044A1.5 1.5 0 0 1 16 5.37v.255a2.375 2.375 0 0 1-4.25 1.458A2.371 2.371 0 0 1 9.875 8 2.37 2.37 0 0 1 8 7.083 2.37 2.37 0 0 1 6.125 8a2.37 2.37 0 0 1-1.875-.917A2.375 2.375 0 0 1 0 5.625V5.37a1.5 1.5 0 0 1 .361-.976l2.61-3.045zm1.78 4.275a1.375 1.375 0 0 0 2.75 0 .5.5 0 0 1 1 0 1.375 1.375 0 0 0 2.75 0 .5.5 0 0 1 1 0 1.375 1.375 0 1 0 2.75 0V5.37a.5.5 0 0 0-.12-.325L12.27 2H3.73L1.12 5.045A.5.5 0 0 0 1 5.37v.255a1.375 1.375 0 0 0 2.75 0 .5.5 0 0 1 1 0zM1.5 8.5A.5.5 0 0 1 2 9v6h1v-5a1 1 0 0 1 1-1h3a1 1 0 0 1 1 1v5h6V9a.5.5 0 0 1 1 0v6h.5a.5.5 0 0 1 0 1H.5a.5.5 0 0 1 0-1H1V9a.5.5 0 0 1 .5-.5zM4 15h3v-5H4v5zm5-5a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1h-2a1 1 0 0 1-1-1v-3zm3 0h-2v3h2v-3z\"}}]})(props);\n};\nexport function BsShuffle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M0 3.5A.5.5 0 0 1 .5 3H1c2.202 0 3.827 1.24 4.874 2.418.49.552.865 1.102 1.126 1.532.26-.43.636-.98 1.126-1.532C9.173 4.24 10.798 3 13 3v1c-1.798 0-3.173 1.01-4.126 2.082A9.624 9.624 0 0 0 7.556 8a9.624 9.624 0 0 0 1.317 1.918C9.828 10.99 11.204 12 13 12v1c-2.202 0-3.827-1.24-4.874-2.418A10.595 10.595 0 0 1 7 9.05c-.26.43-.636.98-1.126 1.532C4.827 11.76 3.202 13 1 13H.5a.5.5 0 0 1 0-1H1c1.798 0 3.173-1.01 4.126-2.082A9.624 9.624 0 0 0 6.444 8a9.624 9.624 0 0 0-1.317-1.918C4.172 5.01 2.796 4 1 4H.5a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13 5.466V1.534a.25.25 0 0 1 .41-.192l2.36 1.966c.12.1.12.284 0 .384l-2.36 1.966a.25.25 0 0 1-.41-.192zm0 9v-3.932a.25.25 0 0 1 .41-.192l2.36 1.966c.12.1.12.284 0 .384l-2.36 1.966a.25.25 0 0 1-.41-.192z\"}}]})(props);\n};\nexport function BsSignal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m6.08.234.179.727a7.264 7.264 0 0 0-2.01.832l-.383-.643A7.9 7.9 0 0 1 6.079.234zm3.84 0L9.742.96a7.265 7.265 0 0 1 2.01.832l.388-.643A7.957 7.957 0 0 0 9.92.234zm-8.77 3.63a7.944 7.944 0 0 0-.916 2.215l.727.18a7.264 7.264 0 0 1 .832-2.01l-.643-.386zM.75 8a7.3 7.3 0 0 1 .081-1.086L.091 6.8a8 8 0 0 0 0 2.398l.74-.112A7.262 7.262 0 0 1 .75 8zm11.384 6.848-.384-.64a7.23 7.23 0 0 1-2.007.831l.18.728a7.965 7.965 0 0 0 2.211-.919zM15.251 8c0 .364-.028.727-.082 1.086l.74.112a7.966 7.966 0 0 0 0-2.398l-.74.114c.054.36.082.722.082 1.086zm.516 1.918-.728-.18a7.252 7.252 0 0 1-.832 2.012l.643.387a7.933 7.933 0 0 0 .917-2.219zm-6.68 5.25c-.72.11-1.453.11-2.173 0l-.112.742a7.99 7.99 0 0 0 2.396 0l-.112-.741zm4.75-2.868a7.229 7.229 0 0 1-1.537 1.534l.446.605a8.07 8.07 0 0 0 1.695-1.689l-.604-.45zM12.3 2.163c.587.432 1.105.95 1.537 1.537l.604-.45a8.06 8.06 0 0 0-1.69-1.691l-.45.604zM2.163 3.7A7.242 7.242 0 0 1 3.7 2.163l-.45-.604a8.06 8.06 0 0 0-1.691 1.69l.604.45zm12.688.163-.644.387c.377.623.658 1.3.832 2.007l.728-.18a7.931 7.931 0 0 0-.916-2.214zM6.913.831a7.254 7.254 0 0 1 2.172 0l.112-.74a7.985 7.985 0 0 0-2.396 0l.112.74zM2.547 14.64 1 15l.36-1.549-.729-.17-.361 1.548a.75.75 0 0 0 .9.902l1.548-.357-.17-.734zM.786 12.612l.732.168.25-1.073A7.187 7.187 0 0 1 .96 9.74l-.727.18a8 8 0 0 0 .736 1.902l-.184.79zm3.5 1.623-1.073.25.17.731.79-.184c.6.327 1.239.574 1.902.737l.18-.728a7.197 7.197 0 0 1-1.962-.811l-.007.005zM8 1.5a6.502 6.502 0 0 0-6.498 6.502 6.516 6.516 0 0 0 .998 3.455l-.625 2.668L4.54 13.5a6.502 6.502 0 0 0 6.93-11A6.516 6.516 0 0 0 8 1.5\"}}]})(props);\n};\nexport function BsSignpost2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.293.707A1 1 0 0 0 7 1.414V2H2a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h5v1H2.5a1 1 0 0 0-.8.4L.725 8.7a.5.5 0 0 0 0 .6l.975 1.3a1 1 0 0 0 .8.4H7v5h2v-5h5a1 1 0 0 0 1-1V8a1 1 0 0 0-1-1H9V6h4.5a1 1 0 0 0 .8-.4l.975-1.3a.5.5 0 0 0 0-.6L14.3 2.4a1 1 0 0 0-.8-.4H9v-.586A1 1 0 0 0 7.293.707z\"}}]})(props);\n};\nexport function BsSignpost2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 1.414V2H2a1 1 0 0 0-1 1v2a1 1 0 0 0 1 1h5v1H2.5a1 1 0 0 0-.8.4L.725 8.7a.5.5 0 0 0 0 .6l.975 1.3a1 1 0 0 0 .8.4H7v5h2v-5h5a1 1 0 0 0 1-1V8a1 1 0 0 0-1-1H9V6h4.5a1 1 0 0 0 .8-.4l.975-1.3a.5.5 0 0 0 0-.6L14.3 2.4a1 1 0 0 0-.8-.4H9v-.586a1 1 0 0 0-2 0zM13.5 3l.75 1-.75 1H2V3h11.5zm.5 5v2H2.5l-.75-1 .75-1H14z\"}}]})(props);\n};\nexport function BsSignpostFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.293.707A1 1 0 0 0 7 1.414V4H2a1 1 0 0 0-1 1v4a1 1 0 0 0 1 1h5v6h2v-6h3.532a1 1 0 0 0 .768-.36l1.933-2.32a.5.5 0 0 0 0-.64L13.3 4.36a1 1 0 0 0-.768-.36H9V1.414A1 1 0 0 0 7.293.707z\"}}]})(props);\n};\nexport function BsSignpostSplitFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 16h2V6h5a1 1 0 0 0 .8-.4l.975-1.3a.5.5 0 0 0 0-.6L14.8 2.4A1 1 0 0 0 14 2H9v-.586a1 1 0 0 0-2 0V7H2a1 1 0 0 0-.8.4L.225 8.7a.5.5 0 0 0 0 .6l.975 1.3a1 1 0 0 0 .8.4h5v5z\"}}]})(props);\n};\nexport function BsSignpostSplit (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 7V1.414a1 1 0 0 1 2 0V2h5a1 1 0 0 1 .8.4l.975 1.3a.5.5 0 0 1 0 .6L14.8 5.6a1 1 0 0 1-.8.4H9v10H7v-5H2a1 1 0 0 1-.8-.4L.225 9.3a.5.5 0 0 1 0-.6L1.2 7.4A1 1 0 0 1 2 7h5zm1 3V8H2l-.75 1L2 10h6zm0-5h6l.75-1L14 3H8v2z\"}}]})(props);\n};\nexport function BsSignpost (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 1.414V4H2a1 1 0 0 0-1 1v4a1 1 0 0 0 1 1h5v6h2v-6h3.532a1 1 0 0 0 .768-.36l1.933-2.32a.5.5 0 0 0 0-.64L13.3 4.36a1 1 0 0 0-.768-.36H9V1.414a1 1 0 0 0-2 0zM12.532 5l1.666 2-1.666 2H2V5h10.532z\"}}]})(props);\n};\nexport function BsSimFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 4.5a.5.5 0 0 1 .5-.5h2v2H5V4.5zM8.5 6V4h2a.5.5 0 0 1 .5.5V6H8.5zM5 7h6v2H5V7zm3.5 3H11v1.5a.5.5 0 0 1-.5.5h-2v-2zm-1 0v2h-2a.5.5 0 0 1-.5-.5V10h2.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 0A1.5 1.5 0 0 0 2 1.5v13A1.5 1.5 0 0 0 3.5 16h9a1.5 1.5 0 0 0 1.5-1.5V3.414a1.5 1.5 0 0 0-.44-1.06L11.647.439A1.5 1.5 0 0 0 10.586 0H3.5zm2 3h5A1.5 1.5 0 0 1 12 4.5v7a1.5 1.5 0 0 1-1.5 1.5h-5A1.5 1.5 0 0 1 4 11.5v-7A1.5 1.5 0 0 1 5.5 3z\"}}]})(props);\n};\nexport function BsSim (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1.5A1.5 1.5 0 0 1 3.5 0h7.086a1.5 1.5 0 0 1 1.06.44l1.915 1.914A1.5 1.5 0 0 1 14 3.414V14.5a1.5 1.5 0 0 1-1.5 1.5h-9A1.5 1.5 0 0 1 2 14.5v-13zM3.5 1a.5.5 0 0 0-.5.5v13a.5.5 0 0 0 .5.5h9a.5.5 0 0 0 .5-.5V3.414a.5.5 0 0 0-.146-.353l-1.915-1.915A.5.5 0 0 0 10.586 1H3.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 4a.5.5 0 0 0-.5.5V6h2.5V4h-2zm3 0v2H11V4.5a.5.5 0 0 0-.5-.5h-2zM11 7H5v2h6V7zm0 3H8.5v2h2a.5.5 0 0 0 .5-.5V10zm-3.5 2v-2H5v1.5a.5.5 0 0 0 .5.5h2zM4 4.5A1.5 1.5 0 0 1 5.5 3h5A1.5 1.5 0 0 1 12 4.5v7a1.5 1.5 0 0 1-1.5 1.5h-5A1.5 1.5 0 0 1 4 11.5v-7z\"}}]})(props);\n};\nexport function BsSkipBackwardBtnFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12V4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm11.21-6.907L8.5 7.028V5.5a.5.5 0 0 0-.79-.407L5 7.028V5.5a.5.5 0 0 0-1 0v5a.5.5 0 0 0 1 0V8.972l2.71 1.935a.5.5 0 0 0 .79-.407V8.972l2.71 1.935A.5.5 0 0 0 12 10.5v-5a.5.5 0 0 0-.79-.407z\"}}]})(props);\n};\nexport function BsSkipBackwardBtn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.21 5.093A.5.5 0 0 1 12 5.5v5a.5.5 0 0 1-.79.407L8.5 8.972V10.5a.5.5 0 0 1-.79.407L5 8.972V10.5a.5.5 0 0 1-1 0v-5a.5.5 0 0 1 1 0v1.528l2.71-1.935a.5.5 0 0 1 .79.407v1.528l2.71-1.935z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm15 0a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4z\"}}]})(props);\n};\nexport function BsSkipBackwardCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-4.79-2.907L8.5 7.028V5.5a.5.5 0 0 0-.79-.407L5 7.028V5.5a.5.5 0 0 0-1 0v5a.5.5 0 0 0 1 0V8.972l2.71 1.935a.5.5 0 0 0 .79-.407V8.972l2.71 1.935A.5.5 0 0 0 12 10.5v-5a.5.5 0 0 0-.79-.407z\"}}]})(props);\n};\nexport function BsSkipBackwardCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.729 5.055a.5.5 0 0 0-.52.038L8.5 7.028V5.5a.5.5 0 0 0-.79-.407L5 7.028V5.5a.5.5 0 0 0-1 0v5a.5.5 0 0 0 1 0V8.972l2.71 1.935a.5.5 0 0 0 .79-.407V8.972l2.71 1.935A.5.5 0 0 0 12 10.5v-5a.5.5 0 0 0-.271-.445z\"}}]})(props);\n};\nexport function BsSkipBackwardFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 3.5A.5.5 0 0 0 0 4v8a.5.5 0 0 0 1 0V8.753l6.267 3.636c.54.313 1.233-.066 1.233-.697v-2.94l6.267 3.636c.54.314 1.233-.065 1.233-.696V4.308c0-.63-.693-1.01-1.233-.696L8.5 7.248v-2.94c0-.63-.692-1.01-1.233-.696L1 7.248V4a.5.5 0 0 0-.5-.5z\"}}]})(props);\n};\nexport function BsSkipBackward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 3.5A.5.5 0 0 1 1 4v3.248l6.267-3.636c.52-.302 1.233.043 1.233.696v2.94l6.267-3.636c.52-.302 1.233.043 1.233.696v7.384c0 .653-.713.998-1.233.696L8.5 8.752v2.94c0 .653-.713.998-1.233.696L1 8.752V12a.5.5 0 0 1-1 0V4a.5.5 0 0 1 .5-.5zm7 1.133L1.696 8 7.5 11.367V4.633zm7.5 0L9.196 8 15 11.367V4.633z\"}}]})(props);\n};\nexport function BsSkipEndBtnFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12V4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm6.79-6.907A.5.5 0 0 0 6 5.5v5a.5.5 0 0 0 .79.407L9.5 8.972V10.5a.5.5 0 0 0 1 0v-5a.5.5 0 0 0-1 0v1.528L6.79 5.093z\"}}]})(props);\n};\nexport function BsSkipEndBtn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.79 5.093 9.5 7.028V5.5a.5.5 0 0 1 1 0v5a.5.5 0 0 1-1 0V8.972l-2.71 1.935A.5.5 0 0 1 6 10.5v-5a.5.5 0 0 1 .79-.407z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm15 0a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4z\"}}]})(props);\n};\nexport function BsSkipEndCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM6.79 5.093A.5.5 0 0 0 6 5.5v5a.5.5 0 0 0 .79.407L9.5 8.972V10.5a.5.5 0 0 0 1 0v-5a.5.5 0 0 0-1 0v1.528L6.79 5.093z\"}}]})(props);\n};\nexport function BsSkipEndCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.271 5.055a.5.5 0 0 1 .52.038L9.5 7.028V5.5a.5.5 0 0 1 1 0v5a.5.5 0 0 1-1 0V8.972l-2.71 1.935A.5.5 0 0 1 6 10.5v-5a.5.5 0 0 1 .271-.445z\"}}]})(props);\n};\nexport function BsSkipEndFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 4a.5.5 0 0 0-1 0v3.248L5.233 3.612C4.693 3.3 4 3.678 4 4.308v7.384c0 .63.692 1.01 1.233.697L11.5 8.753V12a.5.5 0 0 0 1 0V4z\"}}]})(props);\n};\nexport function BsSkipEnd (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 4a.5.5 0 0 0-1 0v3.248L5.233 3.612C4.713 3.31 4 3.655 4 4.308v7.384c0 .653.713.998 1.233.696L11.5 8.752V12a.5.5 0 0 0 1 0V4zM5 4.633 10.804 8 5 11.367V4.633z\"}}]})(props);\n};\nexport function BsSkipForwardBtnFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 10V2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm4.79-6.907A.5.5 0 0 0 4 3.5v5a.5.5 0 0 0 .79.407L7.5 6.972V8.5a.5.5 0 0 0 .79.407L11 6.972V8.5a.5.5 0 0 0 1 0v-5a.5.5 0 0 0-1 0v1.528L8.29 3.093a.5.5 0 0 0-.79.407v1.528L4.79 3.093z\"}}]})(props);\n};\nexport function BsSkipForwardBtn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.79 5.093A.5.5 0 0 0 4 5.5v5a.5.5 0 0 0 .79.407L7.5 8.972V10.5a.5.5 0 0 0 .79.407L11 8.972V10.5a.5.5 0 0 0 1 0v-5a.5.5 0 0 0-1 0v1.528L8.29 5.093a.5.5 0 0 0-.79.407v1.528L4.79 5.093z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm15 0a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4z\"}}]})(props);\n};\nexport function BsSkipForwardCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM4.79 5.093A.5.5 0 0 0 4 5.5v5a.5.5 0 0 0 .79.407L7.5 8.972V10.5a.5.5 0 0 0 .79.407L11 8.972V10.5a.5.5 0 0 0 1 0v-5a.5.5 0 0 0-1 0v1.528L8.29 5.093a.5.5 0 0 0-.79.407v1.528L4.79 5.093z\"}}]})(props);\n};\nexport function BsSkipForwardCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.271 5.055a.5.5 0 0 1 .52.038L7.5 7.028V5.5a.5.5 0 0 1 .79-.407L11 7.028V5.5a.5.5 0 0 1 1 0v5a.5.5 0 0 1-1 0V8.972l-2.71 1.935a.5.5 0 0 1-.79-.407V8.972l-2.71 1.935A.5.5 0 0 1 4 10.5v-5a.5.5 0 0 1 .271-.445z\"}}]})(props);\n};\nexport function BsSkipForwardFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.5 3.5a.5.5 0 0 1 .5.5v8a.5.5 0 0 1-1 0V8.753l-6.267 3.636c-.54.313-1.233-.066-1.233-.697v-2.94l-6.267 3.636C.693 12.703 0 12.324 0 11.693V4.308c0-.63.693-1.01 1.233-.696L7.5 7.248v-2.94c0-.63.693-1.01 1.233-.696L15 7.248V4a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsSkipForward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.5 3.5a.5.5 0 0 1 .5.5v8a.5.5 0 0 1-1 0V8.752l-6.267 3.636c-.52.302-1.233-.043-1.233-.696v-2.94l-6.267 3.636C.713 12.69 0 12.345 0 11.692V4.308c0-.653.713-.998 1.233-.696L7.5 7.248v-2.94c0-.653.713-.998 1.233-.696L15 7.248V4a.5.5 0 0 1 .5-.5zM1 4.633v6.734L6.804 8 1 4.633zm7.5 0v6.734L14.304 8 8.5 4.633z\"}}]})(props);\n};\nexport function BsSkipStartBtnFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12V4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm9.71-6.907L7 7.028V5.5a.5.5 0 0 0-1 0v5a.5.5 0 0 0 1 0V8.972l2.71 1.935a.5.5 0 0 0 .79-.407v-5a.5.5 0 0 0-.79-.407z\"}}]})(props);\n};\nexport function BsSkipStartBtn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.71 5.093a.5.5 0 0 1 .79.407v5a.5.5 0 0 1-.79.407L7 8.972V10.5a.5.5 0 0 1-1 0v-5a.5.5 0 0 1 1 0v1.528l2.71-1.935z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm15 0a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4z\"}}]})(props);\n};\nexport function BsSkipStartCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM9.71 5.093 7 7.028V5.5a.5.5 0 0 0-1 0v5a.5.5 0 0 0 1 0V8.972l2.71 1.935a.5.5 0 0 0 .79-.407v-5a.5.5 0 0 0-.79-.407z\"}}]})(props);\n};\nexport function BsSkipStartCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.229 5.055a.5.5 0 0 0-.52.038L7 7.028V5.5a.5.5 0 0 0-1 0v5a.5.5 0 0 0 1 0V8.972l2.71 1.935a.5.5 0 0 0 .79-.407v-5a.5.5 0 0 0-.271-.445z\"}}]})(props);\n};\nexport function BsSkipStartFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4a.5.5 0 0 1 1 0v3.248l6.267-3.636c.54-.313 1.232.066 1.232.696v7.384c0 .63-.692 1.01-1.232.697L5 8.753V12a.5.5 0 0 1-1 0V4z\"}}]})(props);\n};\nexport function BsSkipStart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 4a.5.5 0 0 1 1 0v3.248l6.267-3.636c.52-.302 1.233.043 1.233.696v7.384c0 .653-.713.998-1.233.696L5 8.752V12a.5.5 0 0 1-1 0V4zm7.5.633L5.696 8l5.804 3.367V4.633z\"}}]})(props);\n};\nexport function BsSkype (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.671 0c.88 0 1.733.247 2.468.702a7.423 7.423 0 0 1 6.02 2.118 7.372 7.372 0 0 1 2.167 5.215c0 .344-.024.687-.072 1.026a4.662 4.662 0 0 1 .6 2.281 4.645 4.645 0 0 1-1.37 3.294A4.673 4.673 0 0 1 11.18 16c-.84 0-1.658-.226-2.37-.644a7.423 7.423 0 0 1-6.114-2.107A7.374 7.374 0 0 1 .529 8.035c0-.363.026-.724.08-1.081a4.644 4.644 0 0 1 .76-5.59A4.68 4.68 0 0 1 4.67 0zm.447 7.01c.18.309.43.572.729.769a7.07 7.07 0 0 0 1.257.653c.492.205.873.38 1.145.523.229.112.437.264.615.448.135.142.21.331.21.528a.872.872 0 0 1-.335.723c-.291.196-.64.289-.99.264a2.618 2.618 0 0 1-1.048-.206 11.44 11.44 0 0 1-.532-.253 1.284 1.284 0 0 0-.587-.15.717.717 0 0 0-.501.176.63.63 0 0 0-.195.491.796.796 0 0 0 .148.482 1.2 1.2 0 0 0 .456.354 5.113 5.113 0 0 0 2.212.419 4.554 4.554 0 0 0 1.624-.265 2.296 2.296 0 0 0 1.08-.801c.267-.39.402-.855.386-1.327a2.09 2.09 0 0 0-.279-1.101 2.53 2.53 0 0 0-.772-.792A7.198 7.198 0 0 0 8.486 7.3a1.05 1.05 0 0 0-.145-.058 18.182 18.182 0 0 1-1.013-.447 1.827 1.827 0 0 1-.54-.387.727.727 0 0 1-.2-.508.805.805 0 0 1 .385-.723 1.76 1.76 0 0 1 .968-.247c.26-.003.52.03.772.096.274.079.542.177.802.293.105.049.22.075.336.076a.6.6 0 0 0 .453-.19.69.69 0 0 0 .18-.496.717.717 0 0 0-.17-.476 1.374 1.374 0 0 0-.556-.354 3.69 3.69 0 0 0-.708-.183 5.963 5.963 0 0 0-1.022-.078 4.53 4.53 0 0 0-1.536.258 2.71 2.71 0 0 0-1.174.784 1.91 1.91 0 0 0-.45 1.287c-.01.37.076.736.25 1.063z\"}}]})(props);\n};\nexport function BsSlack (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.362 10.11c0 .926-.756 1.681-1.681 1.681S0 11.036 0 10.111C0 9.186.756 8.43 1.68 8.43h1.682v1.68zm.846 0c0-.924.756-1.68 1.681-1.68s1.681.756 1.681 1.68v4.21c0 .924-.756 1.68-1.68 1.68a1.685 1.685 0 0 1-1.682-1.68v-4.21zM5.89 3.362c-.926 0-1.682-.756-1.682-1.681S4.964 0 5.89 0s1.68.756 1.68 1.68v1.682H5.89zm0 .846c.924 0 1.68.756 1.68 1.681S6.814 7.57 5.89 7.57H1.68C.757 7.57 0 6.814 0 5.89c0-.926.756-1.682 1.68-1.682h4.21zm6.749 1.682c0-.926.755-1.682 1.68-1.682.925 0 1.681.756 1.681 1.681s-.756 1.681-1.68 1.681h-1.681V5.89zm-.848 0c0 .924-.755 1.68-1.68 1.68A1.685 1.685 0 0 1 8.43 5.89V1.68C8.43.757 9.186 0 10.11 0c.926 0 1.681.756 1.681 1.68v4.21zm-1.681 6.748c.926 0 1.682.756 1.682 1.681S11.036 16 10.11 16s-1.681-.756-1.681-1.68v-1.682h1.68zm0-.847c-.924 0-1.68-.755-1.68-1.68 0-.925.756-1.681 1.68-1.681h4.21c.924 0 1.68.756 1.68 1.68 0 .926-.756 1.681-1.68 1.681h-4.21z\"}}]})(props);\n};\nexport function BsSlashCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-4.646-2.646a.5.5 0 0 0-.708-.708l-6 6a.5.5 0 0 0 .708.708l6-6z\"}}]})(props);\n};\nexport function BsSlashCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.354 4.646a.5.5 0 0 0-.708 0l-6 6a.5.5 0 0 0 .708.708l6-6a.5.5 0 0 0 0-.708z\"}}]})(props);\n};\nexport function BsSlashLg (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14.707 1.293a1 1 0 0 1 0 1.414l-12 12a1 1 0 0 1-1.414-1.414l12-12a1 1 0 0 1 1.414 0z\"}}]})(props);\n};\nexport function BsSlashSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm9.354 5.354-6 6a.5.5 0 0 1-.708-.708l6-6a.5.5 0 0 1 .708.708z\"}}]})(props);\n};\nexport function BsSlashSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.354 4.646a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708l6-6a.5.5 0 0 1 .708 0z\"}}]})(props);\n};\nexport function BsSlash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.354 4.646a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708l6-6a.5.5 0 0 1 .708 0z\"}}]})(props);\n};\nexport function BsSliders (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11.5 2a1.5 1.5 0 1 0 0 3 1.5 1.5 0 0 0 0-3zM9.05 3a2.5 2.5 0 0 1 4.9 0H16v1h-2.05a2.5 2.5 0 0 1-4.9 0H0V3h9.05zM4.5 7a1.5 1.5 0 1 0 0 3 1.5 1.5 0 0 0 0-3zM2.05 8a2.5 2.5 0 0 1 4.9 0H16v1H6.95a2.5 2.5 0 0 1-4.9 0H0V8h2.05zm9.45 4a1.5 1.5 0 1 0 0 3 1.5 1.5 0 0 0 0-3zm-2.45 1a2.5 2.5 0 0 1 4.9 0H16v1h-2.05a2.5 2.5 0 0 1-4.9 0H0v-1h9.05z\"}}]})(props);\n};\nexport function BsSmartwatch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9 5a.5.5 0 0 0-1 0v3H6a.5.5 0 0 0 0 1h2.5a.5.5 0 0 0 .5-.5V5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 1.667v.383A2.5 2.5 0 0 0 2 4.5v7a2.5 2.5 0 0 0 2 2.45v.383C4 15.253 4.746 16 5.667 16h4.666c.92 0 1.667-.746 1.667-1.667v-.383a2.5 2.5 0 0 0 2-2.45V8h.5a.5.5 0 0 0 .5-.5v-2a.5.5 0 0 0-.5-.5H14v-.5a2.5 2.5 0 0 0-2-2.45v-.383C12 .747 11.254 0 10.333 0H5.667C4.747 0 4 .746 4 1.667zM4.5 3h7A1.5 1.5 0 0 1 13 4.5v7a1.5 1.5 0 0 1-1.5 1.5h-7A1.5 1.5 0 0 1 3 11.5v-7A1.5 1.5 0 0 1 4.5 3z\"}}]})(props);\n};\nexport function BsSnapchat (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.98 11.93c-.068-.232-.405-.395-.405-.395l-.082-.044a6.462 6.462 0 0 1-1.466-.96 5.028 5.028 0 0 1-.85-.966 3.775 3.775 0 0 1-.47-.966c-.03-.126-.027-.173 0-.238a.36.36 0 0 1 .116-.13c.187-.132.49-.33.677-.448.16-.106.3-.194.381-.252.262-.184.439-.367.544-.568a.987.987 0 0 0 .048-.827c-.143-.377-.497-.605-.946-.605-.098 0-.204.01-.306.034a4.325 4.325 0 0 0-.707.228c-.014.007-.03-.007-.03-.02.02-.507.043-1.188-.011-1.834-.051-.585-.17-1.078-.368-1.507a4.053 4.053 0 0 0-.656-.983 3.989 3.989 0 0 0-1.037-.833C9.697.207 8.88 0 7.992 0c-.888 0-1.7.207-2.419.616a4.043 4.043 0 0 0-1.037.833c-.2.231-.46.551-.656.983-.198.429-.317.922-.368 1.507-.054.65-.034 1.276-.01 1.833 0 .017-.017.028-.03.02a5.195 5.195 0 0 0-.705-.227 1.34 1.34 0 0 0-.306-.034c-.449 0-.803.228-.946.605a.975.975 0 0 0 .048.827c.105.2.286.388.544.568.082.058.218.146.381.252.18.119.476.31.664.442a.434.434 0 0 1 .129.14c.027.068.03.115-.004.248-.057.194-.19.54-.466.956a4.99 4.99 0 0 1-.85.966 6.468 6.468 0 0 1-1.456.959c-.027.014-.058.027-.092.047 0 0-.333.17-.394.388-.092.323.153.626.405.79.411.265.915.408 1.204.486.081.02.153.04.22.061a.457.457 0 0 1 .191.112c.058.072.065.164.085.266.03.17.102.38.313.527.232.16.527.17.898.187.391.014.878.034 1.432.218.259.085.49.228.762.394.565.347 1.266.78 2.466.78 1.201 0 1.909-.436 2.477-.783.268-.163.5-.306.752-.391.554-.184 1.04-.2 1.432-.218.374-.014.666-.024.898-.187.224-.156.292-.388.32-.565.016-.085.027-.163.078-.228.04-.054.139-.091.183-.108l.228-.065c.293-.078.657-.17 1.099-.422.537-.3.575-.67.517-.854z\"}}]})(props);\n};\nexport function BsSnow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16a.5.5 0 0 1-.5-.5v-1.293l-.646.647a.5.5 0 0 1-.707-.708L7.5 12.793V8.866l-3.4 1.963-.496 1.85a.5.5 0 1 1-.966-.26l.237-.882-1.12.646a.5.5 0 0 1-.5-.866l1.12-.646-.884-.237a.5.5 0 1 1 .26-.966l1.848.495L7 8 3.6 6.037l-1.85.495a.5.5 0 0 1-.258-.966l.883-.237-1.12-.646a.5.5 0 1 1 .5-.866l1.12.646-.237-.883a.5.5 0 1 1 .966-.258l.495 1.849L7.5 7.134V3.207L6.147 1.854a.5.5 0 1 1 .707-.708l.646.647V.5a.5.5 0 1 1 1 0v1.293l.647-.647a.5.5 0 1 1 .707.708L8.5 3.207v3.927l3.4-1.963.496-1.85a.5.5 0 1 1 .966.26l-.236.882 1.12-.646a.5.5 0 0 1 .5.866l-1.12.646.883.237a.5.5 0 1 1-.26.966l-1.848-.495L9 8l3.4 1.963 1.849-.495a.5.5 0 0 1 .259.966l-.883.237 1.12.646a.5.5 0 0 1-.5.866l-1.12-.646.236.883a.5.5 0 1 1-.966.258l-.495-1.849-3.4-1.963v3.927l1.353 1.353a.5.5 0 0 1-.707.708l-.647-.647V15.5a.5.5 0 0 1-.5.5z\"}}]})(props);\n};\nexport function BsSnow2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16a.5.5 0 0 1-.5-.5v-1.293l-.646.647a.5.5 0 0 1-.707-.708L7.5 12.793v-1.086l-.646.647a.5.5 0 0 1-.707-.708L7.5 10.293V8.866l-1.236.713-.495 1.85a.5.5 0 1 1-.966-.26l.237-.882-.94.542-.496 1.85a.5.5 0 1 1-.966-.26l.237-.882-1.12.646a.5.5 0 0 1-.5-.866l1.12-.646-.884-.237a.5.5 0 1 1 .26-.966l1.848.495.94-.542-.882-.237a.5.5 0 1 1 .258-.966l1.85.495L7 8l-1.236-.713-1.849.495a.5.5 0 1 1-.258-.966l.883-.237-.94-.542-1.85.495a.5.5 0 0 1-.258-.966l.883-.237-1.12-.646a.5.5 0 1 1 .5-.866l1.12.646-.237-.883a.5.5 0 0 1 .966-.258l.495 1.849.94.542-.236-.883a.5.5 0 0 1 .966-.258l.495 1.849 1.236.713V5.707L6.147 4.354a.5.5 0 1 1 .707-.708l.646.647V3.207L6.147 1.854a.5.5 0 1 1 .707-.708l.646.647V.5a.5.5 0 0 1 1 0v1.293l.647-.647a.5.5 0 1 1 .707.708L8.5 3.207v1.086l.647-.647a.5.5 0 1 1 .707.708L8.5 5.707v1.427l1.236-.713.495-1.85a.5.5 0 1 1 .966.26l-.236.882.94-.542.495-1.85a.5.5 0 1 1 .966.26l-.236.882 1.12-.646a.5.5 0 0 1 .5.866l-1.12.646.883.237a.5.5 0 1 1-.26.966l-1.848-.495-.94.542.883.237a.5.5 0 1 1-.26.966l-1.848-.495L9 8l1.236.713 1.849-.495a.5.5 0 0 1 .259.966l-.883.237.94.542 1.849-.495a.5.5 0 0 1 .259.966l-.883.237 1.12.646a.5.5 0 0 1-.5.866l-1.12-.646.236.883a.5.5 0 1 1-.966.258l-.495-1.849-.94-.542.236.883a.5.5 0 0 1-.966.258L9.736 9.58 8.5 8.866v1.427l1.354 1.353a.5.5 0 0 1-.707.708l-.647-.647v1.086l1.354 1.353a.5.5 0 0 1-.707.708l-.647-.647V15.5a.5.5 0 0 1-.5.5z\"}}]})(props);\n};\nexport function BsSnow3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 7.5a.5.5 0 1 0 0 1 .5.5 0 0 0 0-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 16a.5.5 0 0 1-.5-.5v-1.293l-.646.647a.5.5 0 0 1-.707-.708L7.5 12.793v-1.51l-2.053-1.232-1.348.778-.495 1.85a.5.5 0 1 1-.966-.26l.237-.882-1.12.646a.5.5 0 0 1-.5-.866l1.12-.646-.883-.237a.5.5 0 1 1 .258-.966l1.85.495L5 9.155v-2.31l-1.4-.808-1.85.495a.5.5 0 1 1-.259-.966l.884-.237-1.12-.646a.5.5 0 0 1 .5-.866l1.12.646-.237-.883a.5.5 0 1 1 .966-.258l.495 1.849 1.348.778L7.5 4.717v-1.51L6.147 1.854a.5.5 0 1 1 .707-.708l.646.647V.5a.5.5 0 0 1 1 0v1.293l.647-.647a.5.5 0 1 1 .707.708L8.5 3.207v1.51l2.053 1.232 1.348-.778.495-1.85a.5.5 0 1 1 .966.26l-.236.882 1.12-.646a.5.5 0 0 1 .5.866l-1.12.646.883.237a.5.5 0 1 1-.26.966l-1.848-.495-1.4.808v2.31l1.4.808 1.849-.495a.5.5 0 1 1 .259.966l-.883.237 1.12.646a.5.5 0 0 1-.5.866l-1.12-.646.236.883a.5.5 0 1 1-.966.258l-.495-1.849-1.348-.778L8.5 11.283v1.51l1.354 1.353a.5.5 0 0 1-.707.708l-.647-.647V15.5a.5.5 0 0 1-.5.5zm2-6.783V6.783l-2-1.2-2 1.2v2.434l2 1.2 2-1.2z\"}}]})(props);\n};\nexport function BsSortAlphaDownAlt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.96 7H9.028v-.691l2.579-3.72v-.054H9.098v-.867h3.785v.691l-2.567 3.72v.054h2.645V7z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.082 12.629 9.664 14H8.598l1.789-5.332h1.234L13.402 14h-1.12l-.419-1.371h-1.781zm1.57-.785L11 9.688h-.047l-.652 2.156h1.351z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 2.5a.5.5 0 0 0-1 0v9.793l-1.146-1.147a.5.5 0 0 0-.708.708l2 1.999.007.007a.497.497 0 0 0 .7-.006l2-2a.5.5 0 0 0-.707-.708L4.5 12.293V2.5z\"}}]})(props);\n};\nexport function BsSortAlphaDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.082 5.629 9.664 7H8.598l1.789-5.332h1.234L13.402 7h-1.12l-.419-1.371h-1.781zm1.57-.785L11 2.687h-.047l-.652 2.157h1.351z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.96 14H9.028v-.691l2.579-3.72v-.054H9.098v-.867h3.785v.691l-2.567 3.72v.054h2.645V14zM4.5 2.5a.5.5 0 0 0-1 0v9.793l-1.146-1.147a.5.5 0 0 0-.708.708l2 1.999.007.007a.497.497 0 0 0 .7-.006l2-2a.5.5 0 0 0-.707-.708L4.5 12.293V2.5z\"}}]})(props);\n};\nexport function BsSortAlphaUpAlt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.96 7H9.028v-.691l2.579-3.72v-.054H9.098v-.867h3.785v.691l-2.567 3.72v.054h2.645V7z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.082 12.629 9.664 14H8.598l1.789-5.332h1.234L13.402 14h-1.12l-.419-1.371h-1.781zm1.57-.785L11 9.688h-.047l-.652 2.156h1.351z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 13.5a.5.5 0 0 1-1 0V3.707L2.354 4.854a.5.5 0 1 1-.708-.708l2-1.999.007-.007a.498.498 0 0 1 .7.006l2 2a.5.5 0 1 1-.707.708L4.5 3.707V13.5z\"}}]})(props);\n};\nexport function BsSortAlphaUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.082 5.629 9.664 7H8.598l1.789-5.332h1.234L13.402 7h-1.12l-.419-1.371h-1.781zm1.57-.785L11 2.687h-.047l-.652 2.157h1.351z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.96 14H9.028v-.691l2.579-3.72v-.054H9.098v-.867h3.785v.691l-2.567 3.72v.054h2.645V14zm-8.46-.5a.5.5 0 0 1-1 0V3.707L2.354 4.854a.5.5 0 1 1-.708-.708l2-1.999.007-.007a.498.498 0 0 1 .7.006l2 2a.5.5 0 1 1-.707.708L4.5 3.707V13.5z\"}}]})(props);\n};\nexport function BsSortDownAlt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 3.5a.5.5 0 0 0-1 0v8.793l-1.146-1.147a.5.5 0 0 0-.708.708l2 1.999.007.007a.497.497 0 0 0 .7-.006l2-2a.5.5 0 0 0-.707-.708L3.5 12.293V3.5zm4 .5a.5.5 0 0 1 0-1h1a.5.5 0 0 1 0 1h-1zm0 3a.5.5 0 0 1 0-1h3a.5.5 0 0 1 0 1h-3zm0 3a.5.5 0 0 1 0-1h5a.5.5 0 0 1 0 1h-5zM7 12.5a.5.5 0 0 0 .5.5h7a.5.5 0 0 0 0-1h-7a.5.5 0 0 0-.5.5z\"}}]})(props);\n};\nexport function BsSortDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 2.5a.5.5 0 0 0-1 0v8.793l-1.146-1.147a.5.5 0 0 0-.708.708l2 1.999.007.007a.497.497 0 0 0 .7-.006l2-2a.5.5 0 0 0-.707-.708L3.5 11.293V2.5zm3.5 1a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zM7.5 6a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5zm0 3a.5.5 0 0 0 0 1h3a.5.5 0 0 0 0-1h-3zm0 3a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1z\"}}]})(props);\n};\nexport function BsSortNumericDownAlt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11.36 7.098c-1.137 0-1.708-.657-1.762-1.278h1.004c.058.223.343.45.773.45.824 0 1.164-.829 1.133-1.856h-.059c-.148.39-.57.742-1.261.742-.91 0-1.72-.613-1.72-1.758 0-1.148.848-1.836 1.973-1.836 1.09 0 2.063.637 2.063 2.688 0 1.867-.723 2.848-2.145 2.848zm.062-2.735c.504 0 .933-.336.933-.972 0-.633-.398-1.008-.94-1.008-.52 0-.927.375-.927 1 0 .64.418.98.934.98z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.438 8.668V14H11.39V9.684h-.051l-1.211.859v-.969l1.262-.906h1.046zM4.5 2.5a.5.5 0 0 0-1 0v9.793l-1.146-1.147a.5.5 0 0 0-.708.708l2 1.999.007.007a.497.497 0 0 0 .7-.006l2-2a.5.5 0 0 0-.707-.708L4.5 12.293V2.5z\"}}]})(props);\n};\nexport function BsSortNumericDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.438 1.668V7H11.39V2.684h-.051l-1.211.859v-.969l1.262-.906h1.046z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11.36 14.098c-1.137 0-1.708-.657-1.762-1.278h1.004c.058.223.343.45.773.45.824 0 1.164-.829 1.133-1.856h-.059c-.148.39-.57.742-1.261.742-.91 0-1.72-.613-1.72-1.758 0-1.148.848-1.835 1.973-1.835 1.09 0 2.063.636 2.063 2.687 0 1.867-.723 2.848-2.145 2.848zm.062-2.735c.504 0 .933-.336.933-.972 0-.633-.398-1.008-.94-1.008-.52 0-.927.375-.927 1 0 .64.418.98.934.98z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 2.5a.5.5 0 0 0-1 0v9.793l-1.146-1.147a.5.5 0 0 0-.708.708l2 1.999.007.007a.497.497 0 0 0 .7-.006l2-2a.5.5 0 0 0-.707-.708L4.5 12.293V2.5z\"}}]})(props);\n};\nexport function BsSortNumericUpAlt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11.36 7.098c-1.137 0-1.708-.657-1.762-1.278h1.004c.058.223.343.45.773.45.824 0 1.164-.829 1.133-1.856h-.059c-.148.39-.57.742-1.261.742-.91 0-1.72-.613-1.72-1.758 0-1.148.848-1.836 1.973-1.836 1.09 0 2.063.637 2.063 2.688 0 1.867-.723 2.848-2.145 2.848zm.062-2.735c.504 0 .933-.336.933-.972 0-.633-.398-1.008-.94-1.008-.52 0-.927.375-.927 1 0 .64.418.98.934.98z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M12.438 8.668V14H11.39V9.684h-.051l-1.211.859v-.969l1.262-.906h1.046zM4.5 13.5a.5.5 0 0 1-1 0V3.707L2.354 4.854a.5.5 0 1 1-.708-.708l2-1.999.007-.007a.498.498 0 0 1 .7.006l2 2a.5.5 0 1 1-.707.708L4.5 3.707V13.5z\"}}]})(props);\n};\nexport function BsSortNumericUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.438 1.668V7H11.39V2.684h-.051l-1.211.859v-.969l1.262-.906h1.046z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11.36 14.098c-1.137 0-1.708-.657-1.762-1.278h1.004c.058.223.343.45.773.45.824 0 1.164-.829 1.133-1.856h-.059c-.148.39-.57.742-1.261.742-.91 0-1.72-.613-1.72-1.758 0-1.148.848-1.835 1.973-1.835 1.09 0 2.063.636 2.063 2.687 0 1.867-.723 2.848-2.145 2.848zm.062-2.735c.504 0 .933-.336.933-.972 0-.633-.398-1.008-.94-1.008-.52 0-.927.375-.927 1 0 .64.418.98.934.98z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 13.5a.5.5 0 0 1-1 0V3.707L2.354 4.854a.5.5 0 1 1-.708-.708l2-1.999.007-.007a.498.498 0 0 1 .7.006l2 2a.5.5 0 1 1-.707.708L4.5 3.707V13.5z\"}}]})(props);\n};\nexport function BsSortUpAlt (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 13.5a.5.5 0 0 1-1 0V4.707L1.354 5.854a.5.5 0 1 1-.708-.708l2-1.999.007-.007a.498.498 0 0 1 .7.006l2 2a.5.5 0 1 1-.707.708L3.5 4.707V13.5zm4-9.5a.5.5 0 0 1 0-1h1a.5.5 0 0 1 0 1h-1zm0 3a.5.5 0 0 1 0-1h3a.5.5 0 0 1 0 1h-3zm0 3a.5.5 0 0 1 0-1h5a.5.5 0 0 1 0 1h-5zM7 12.5a.5.5 0 0 0 .5.5h7a.5.5 0 0 0 0-1h-7a.5.5 0 0 0-.5.5z\"}}]})(props);\n};\nexport function BsSortUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 12.5a.5.5 0 0 1-1 0V3.707L1.354 4.854a.5.5 0 1 1-.708-.708l2-1.999.007-.007a.498.498 0 0 1 .7.006l2 2a.5.5 0 1 1-.707.708L3.5 3.707V12.5zm3.5-9a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zM7.5 6a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1h-5zm0 3a.5.5 0 0 0 0 1h3a.5.5 0 0 0 0-1h-3zm0 3a.5.5 0 0 0 0 1h1a.5.5 0 0 0 0-1h-1z\"}}]})(props);\n};\nexport function BsSoundwave (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8.5 2a.5.5 0 0 1 .5.5v11a.5.5 0 0 1-1 0v-11a.5.5 0 0 1 .5-.5zm-2 2a.5.5 0 0 1 .5.5v7a.5.5 0 0 1-1 0v-7a.5.5 0 0 1 .5-.5zm4 0a.5.5 0 0 1 .5.5v7a.5.5 0 0 1-1 0v-7a.5.5 0 0 1 .5-.5zm-6 1.5A.5.5 0 0 1 5 6v4a.5.5 0 0 1-1 0V6a.5.5 0 0 1 .5-.5zm8 0a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-1 0V6a.5.5 0 0 1 .5-.5zm-10 1A.5.5 0 0 1 3 7v2a.5.5 0 0 1-1 0V7a.5.5 0 0 1 .5-.5zm12 0a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0V7a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsSpeakerFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm-2.5 6.5a1.5 1.5 0 1 1 3 0 1.5 1.5 0 0 1-3 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4zm6 4a2 2 0 1 1-4 0 2 2 0 0 1 4 0zM8 7a3.5 3.5 0 1 1 0 7 3.5 3.5 0 0 1 0-7z\"}}]})(props);\n};\nexport function BsSpeaker (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h8zM4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4.75a.75.75 0 1 1 0-1.5.75.75 0 0 1 0 1.5zM8 6a2 2 0 1 0 0-4 2 2 0 0 0 0 4zm0 3a1.5 1.5 0 1 0 0 3 1.5 1.5 0 0 0 0-3zm-3.5 1.5a3.5 3.5 0 1 1 7 0 3.5 3.5 0 0 1-7 0z\"}}]})(props);\n};\nexport function BsSpeedometer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 2a.5.5 0 0 1 .5.5V4a.5.5 0 0 1-1 0V2.5A.5.5 0 0 1 8 2zM3.732 3.732a.5.5 0 0 1 .707 0l.915.914a.5.5 0 1 1-.708.708l-.914-.915a.5.5 0 0 1 0-.707zM2 8a.5.5 0 0 1 .5-.5h1.586a.5.5 0 0 1 0 1H2.5A.5.5 0 0 1 2 8zm9.5 0a.5.5 0 0 1 .5-.5h1.5a.5.5 0 0 1 0 1H12a.5.5 0 0 1-.5-.5zm.754-4.246a.389.389 0 0 0-.527-.02L7.547 7.31A.91.91 0 1 0 8.85 8.569l3.434-4.297a.389.389 0 0 0-.029-.518z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6.664 15.889A8 8 0 1 1 9.336.11a8 8 0 0 1-2.672 15.78zm-4.665-4.283A11.945 11.945 0 0 1 8 10c2.186 0 4.236.585 6.001 1.606a7 7 0 1 0-12.002 0z\"}}]})(props);\n};\nexport function BsSpeedometer2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 4a.5.5 0 0 1 .5.5V6a.5.5 0 0 1-1 0V4.5A.5.5 0 0 1 8 4zM3.732 5.732a.5.5 0 0 1 .707 0l.915.914a.5.5 0 1 1-.708.708l-.914-.915a.5.5 0 0 1 0-.707zM2 10a.5.5 0 0 1 .5-.5h1.586a.5.5 0 0 1 0 1H2.5A.5.5 0 0 1 2 10zm9.5 0a.5.5 0 0 1 .5-.5h1.5a.5.5 0 0 1 0 1H12a.5.5 0 0 1-.5-.5zm.754-4.246a.389.389 0 0 0-.527-.02L7.547 9.31a.91.91 0 1 0 1.302 1.258l3.434-4.297a.389.389 0 0 0-.029-.518z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M0 10a8 8 0 1 1 15.547 2.661c-.442 1.253-1.845 1.602-2.932 1.25C11.309 13.488 9.475 13 8 13c-1.474 0-3.31.488-4.615.911-1.087.352-2.49.003-2.932-1.25A7.988 7.988 0 0 1 0 10zm8-7a7 7 0 0 0-6.603 9.329c.203.575.923.876 1.68.63C4.397 12.533 6.358 12 8 12s3.604.532 4.923.96c.757.245 1.477-.056 1.68-.631A7 7 0 0 0 8 3z\"}}]})(props);\n};\nexport function BsSpellcheck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.217 11.068c1.216 0 1.948-.869 1.948-2.31v-.702c0-1.44-.727-2.305-1.929-2.305-.742 0-1.328.347-1.499.889h-.063V3.983h-1.29V11h1.27v-.791h.064c.21.532.776.86 1.499.86zm-.43-1.025c-.66 0-1.113-.518-1.113-1.28V8.12c0-.825.42-1.343 1.098-1.343.684 0 1.075.518 1.075 1.416v.45c0 .888-.386 1.401-1.06 1.401zm-5.583 1.035c.767 0 1.201-.356 1.406-.737h.059V11h1.216V7.519c0-1.314-.947-1.783-2.11-1.783C1.355 5.736.75 6.42.69 7.27h1.216c.064-.323.313-.552.84-.552.527 0 .864.249.864.771v.464H2.346C1.145 7.953.5 8.568.5 9.496c0 .977.693 1.582 1.704 1.582zm.42-.947c-.44 0-.845-.235-.845-.718 0-.395.269-.684.84-.684h.991v.538c0 .503-.444.864-.986.864zm8.897.567c-.577-.4-.9-1.088-.9-1.983v-.65c0-1.42.894-2.338 2.305-2.338 1.352 0 2.119.82 2.139 1.806h-1.187c-.04-.351-.283-.776-.918-.776-.674 0-1.045.517-1.045 1.328v.625c0 .468.121.834.343 1.067l-.737.92z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14.469 9.414a.75.75 0 0 1 .117 1.055l-4 5a.75.75 0 0 1-1.116.061l-2.5-2.5a.75.75 0 1 1 1.06-1.06l1.908 1.907 3.476-4.346a.75.75 0 0 1 1.055-.117z\"}}]})(props);\n};\nexport function BsSpotify (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a8 8 0 1 0 0 16A8 8 0 0 0 8 0zm3.669 11.538a.498.498 0 0 1-.686.165c-1.879-1.147-4.243-1.407-7.028-.77a.499.499 0 0 1-.222-.973c3.048-.696 5.662-.397 7.77.892a.5.5 0 0 1 .166.686zm.979-2.178a.624.624 0 0 1-.858.205c-2.15-1.321-5.428-1.704-7.972-.932a.625.625 0 0 1-.362-1.194c2.905-.881 6.517-.454 8.986 1.063a.624.624 0 0 1 .206.858zm.084-2.268C10.154 5.56 5.9 5.419 3.438 6.166a.748.748 0 1 1-.434-1.432c2.825-.857 7.523-.692 10.492 1.07a.747.747 0 1 1-.764 1.288z\"}}]})(props);\n};\nexport function BsSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2z\"}}]})(props);\n};\nexport function BsSquareHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15V1h6a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H8zm6 1a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12z\"}}]})(props);\n};\nexport function BsSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}}]})(props);\n};\nexport function BsStackOverflow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.412 14.572V10.29h1.428V16H1v-5.71h1.428v4.282h9.984z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.857 13.145h7.137v-1.428H3.857v1.428zM10.254 0 9.108.852l4.26 5.727 1.146-.852L10.254 0zm-3.54 3.377 5.484 4.567.913-1.097L7.627 2.28l-.914 1.097zM4.922 6.55l6.47 3.013.603-1.294-6.47-3.013-.603 1.294zm-.925 3.344 6.985 1.469.294-1.398-6.985-1.468-.294 1.397z\"}}]})(props);\n};\nexport function BsStack (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m14.12 10.163 1.715.858c.22.11.22.424 0 .534L8.267 15.34a.598.598 0 0 1-.534 0L.165 11.555a.299.299 0 0 1 0-.534l1.716-.858 5.317 2.659c.505.252 1.1.252 1.604 0l5.317-2.66zM7.733.063a.598.598 0 0 1 .534 0l7.568 3.784a.3.3 0 0 1 0 .535L8.267 8.165a.598.598 0 0 1-.534 0L.165 4.382a.299.299 0 0 1 0-.535L7.733.063z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"m14.12 6.576 1.715.858c.22.11.22.424 0 .534l-7.568 3.784a.598.598 0 0 1-.534 0L.165 7.968a.299.299 0 0 1 0-.534l1.716-.858 5.317 2.659c.505.252 1.1.252 1.604 0l5.317-2.659z\"}}]})(props);\n};\nexport function BsStarFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.612 15.443c-.386.198-.824-.149-.746-.592l.83-4.73L.173 6.765c-.329-.314-.158-.888.283-.95l4.898-.696L7.538.792c.197-.39.73-.39.927 0l2.184 4.327 4.898.696c.441.062.612.636.282.95l-3.522 3.356.83 4.73c.078.443-.36.79-.746.592L8 13.187l-4.389 2.256z\"}}]})(props);\n};\nexport function BsStarHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.354 5.119 7.538.792A.516.516 0 0 1 8 .5c.183 0 .366.097.465.292l2.184 4.327 4.898.696A.537.537 0 0 1 16 6.32a.548.548 0 0 1-.17.445l-3.523 3.356.83 4.73c.078.443-.36.79-.746.592L8 13.187l-4.389 2.256a.52.52 0 0 1-.146.05c-.342.06-.668-.254-.6-.642l.83-4.73L.173 6.765a.55.55 0 0 1-.172-.403.58.58 0 0 1 .085-.302.513.513 0 0 1 .37-.245l4.898-.696zM8 12.027a.5.5 0 0 1 .232.056l3.686 1.894-.694-3.957a.565.565 0 0 1 .162-.505l2.907-2.77-4.052-.576a.525.525 0 0 1-.393-.288L8.001 2.223 8 2.226v9.8z\"}}]})(props);\n};\nexport function BsStar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.866 14.85c-.078.444.36.791.746.593l4.39-2.256 4.389 2.256c.386.198.824-.149.746-.592l-.83-4.73 3.522-3.356c.33-.314.16-.888-.282-.95l-4.898-.696L8.465.792a.513.513 0 0 0-.927 0L5.354 5.12l-4.898.696c-.441.062-.612.636-.283.95l3.523 3.356-.83 4.73zm4.905-2.767-3.686 1.894.694-3.957a.565.565 0 0 0-.163-.505L1.71 6.745l4.052-.576a.525.525 0 0 0 .393-.288L8 2.223l1.847 3.658a.525.525 0 0 0 .393.288l4.052.575-2.906 2.77a.565.565 0 0 0-.163.506l.694 3.957-3.686-1.894a.503.503 0 0 0-.461 0z\"}}]})(props);\n};\nexport function BsStars (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.657 6.247c.11-.33.576-.33.686 0l.645 1.937a2.89 2.89 0 0 0 1.829 1.828l1.936.645c.33.11.33.576 0 .686l-1.937.645a2.89 2.89 0 0 0-1.828 1.829l-.645 1.936a.361.361 0 0 1-.686 0l-.645-1.937a2.89 2.89 0 0 0-1.828-1.828l-1.937-.645a.361.361 0 0 1 0-.686l1.937-.645a2.89 2.89 0 0 0 1.828-1.828l.645-1.937zM3.794 1.148a.217.217 0 0 1 .412 0l.387 1.162c.173.518.579.924 1.097 1.097l1.162.387a.217.217 0 0 1 0 .412l-1.162.387A1.734 1.734 0 0 0 4.593 5.69l-.387 1.162a.217.217 0 0 1-.412 0L3.407 5.69A1.734 1.734 0 0 0 2.31 4.593l-1.162-.387a.217.217 0 0 1 0-.412l1.162-.387A1.734 1.734 0 0 0 3.407 2.31l.387-1.162zM10.863.099a.145.145 0 0 1 .274 0l.258.774c.115.346.386.617.732.732l.774.258a.145.145 0 0 1 0 .274l-.774.258a1.156 1.156 0 0 0-.732.732l-.258.774a.145.145 0 0 1-.274 0l-.258-.774a1.156 1.156 0 0 0-.732-.732L9.1 2.137a.145.145 0 0 1 0-.274l.774-.258c.346-.115.617-.386.732-.732L10.863.1z\"}}]})(props);\n};\nexport function BsStickiesFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 1.5V13a1 1 0 0 0 1 1V1.5a.5.5 0 0 1 .5-.5H14a1 1 0 0 0-1-1H1.5A1.5 1.5 0 0 0 0 1.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 2A1.5 1.5 0 0 0 2 3.5v11A1.5 1.5 0 0 0 3.5 16h6.086a1.5 1.5 0 0 0 1.06-.44l4.915-4.914A1.5 1.5 0 0 0 16 9.586V3.5A1.5 1.5 0 0 0 14.5 2h-11zm6 8.5a1 1 0 0 1 1-1h4.396a.25.25 0 0 1 .177.427l-5.146 5.146a.25.25 0 0 1-.427-.177V10.5z\"}}]})(props);\n};\nexport function BsStickies (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 0A1.5 1.5 0 0 0 0 1.5V13a1 1 0 0 0 1 1V1.5a.5.5 0 0 1 .5-.5H14a1 1 0 0 0-1-1H1.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 2A1.5 1.5 0 0 0 2 3.5v11A1.5 1.5 0 0 0 3.5 16h6.086a1.5 1.5 0 0 0 1.06-.44l4.915-4.914A1.5 1.5 0 0 0 16 9.586V3.5A1.5 1.5 0 0 0 14.5 2h-11zM3 3.5a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 .5.5V9h-4.5A1.5 1.5 0 0 0 9 10.5V15H3.5a.5.5 0 0 1-.5-.5v-11zm7 11.293V10.5a.5.5 0 0 1 .5-.5h4.293L10 14.793z\"}}]})(props);\n};\nexport function BsStickyFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 1A1.5 1.5 0 0 0 1 2.5v11A1.5 1.5 0 0 0 2.5 15h6.086a1.5 1.5 0 0 0 1.06-.44l4.915-4.914A1.5 1.5 0 0 0 15 8.586V2.5A1.5 1.5 0 0 0 13.5 1h-11zm6 8.5a1 1 0 0 1 1-1h4.396a.25.25 0 0 1 .177.427l-5.146 5.146a.25.25 0 0 1-.427-.177V9.5z\"}}]})(props);\n};\nexport function BsSticky (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 1A1.5 1.5 0 0 0 1 2.5v11A1.5 1.5 0 0 0 2.5 15h6.086a1.5 1.5 0 0 0 1.06-.44l4.915-4.914A1.5 1.5 0 0 0 15 8.586V2.5A1.5 1.5 0 0 0 13.5 1h-11zM2 2.5a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 .5.5V8H9.5A1.5 1.5 0 0 0 8 9.5V14H2.5a.5.5 0 0 1-.5-.5v-11zm7 11.293V9.5a.5.5 0 0 1 .5-.5h4.293L9 13.793z\"}}]})(props);\n};\nexport function BsStopBtnFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 12V4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2zm6.5-7A1.5 1.5 0 0 0 5 6.5v3A1.5 1.5 0 0 0 6.5 11h3A1.5 1.5 0 0 0 11 9.5v-3A1.5 1.5 0 0 0 9.5 5h-3z\"}}]})(props);\n};\nexport function BsStopBtn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 5A1.5 1.5 0 0 0 5 6.5v3A1.5 1.5 0 0 0 6.5 11h3A1.5 1.5 0 0 0 11 9.5v-3A1.5 1.5 0 0 0 9.5 5h-3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V4zm15 0a1 1 0 0 0-1-1H2a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4z\"}}]})(props);\n};\nexport function BsStopCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM6.5 5A1.5 1.5 0 0 0 5 6.5v3A1.5 1.5 0 0 0 6.5 11h3A1.5 1.5 0 0 0 11 9.5v-3A1.5 1.5 0 0 0 9.5 5h-3z\"}}]})(props);\n};\nexport function BsStopCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 6.5A1.5 1.5 0 0 1 6.5 5h3A1.5 1.5 0 0 1 11 6.5v3A1.5 1.5 0 0 1 9.5 11h-3A1.5 1.5 0 0 1 5 9.5v-3z\"}}]})(props);\n};\nexport function BsStopFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 3.5h6A1.5 1.5 0 0 1 12.5 5v6a1.5 1.5 0 0 1-1.5 1.5H5A1.5 1.5 0 0 1 3.5 11V5A1.5 1.5 0 0 1 5 3.5z\"}}]})(props);\n};\nexport function BsStop (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 5A1.5 1.5 0 0 1 5 3.5h6A1.5 1.5 0 0 1 12.5 5v6a1.5 1.5 0 0 1-1.5 1.5H5A1.5 1.5 0 0 1 3.5 11V5zM5 4.5a.5.5 0 0 0-.5.5v6a.5.5 0 0 0 .5.5h6a.5.5 0 0 0 .5-.5V5a.5.5 0 0 0-.5-.5H5z\"}}]})(props);\n};\nexport function BsStoplightsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 0a2 2 0 0 0-2 2H2c.167.5.8 1.6 2 2v2H2c.167.5.8 1.6 2 2v2H2c.167.5.8 1.6 2 2v1a2 2 0 0 0 2 2h4a2 2 0 0 0 2-2v-1c1.2-.4 1.833-1.5 2-2h-2V8c1.2-.4 1.833-1.5 2-2h-2V4c1.2-.4 1.833-1.5 2-2h-2a2 2 0 0 0-2-2H6zm3.5 3.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm0 4a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zM8 13a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsStoplights (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3zm0 4a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3zm1.5 2.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4 2a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2h2c-.167.5-.8 1.6-2 2v2h2c-.167.5-.8 1.6-2 2v2h2c-.167.5-.8 1.6-2 2v1a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2v-1c-1.2-.4-1.833-1.5-2-2h2V8c-1.2-.4-1.833-1.5-2-2h2V4c-1.2-.4-1.833-1.5-2-2h2zm2-1a1 1 0 0 0-1 1v11a1 1 0 0 0 1 1h4a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H6z\"}}]})(props);\n};\nexport function BsStopwatchFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 0a.5.5 0 0 0 0 1H7v1.07A7.001 7.001 0 0 0 8 16a7 7 0 0 0 5.29-11.584.531.531 0 0 0 .013-.012l.354-.354.353.354a.5.5 0 1 0 .707-.707l-1.414-1.415a.5.5 0 1 0-.707.707l.354.354-.354.354a.717.717 0 0 0-.012.012A6.973 6.973 0 0 0 9 2.071V1h.5a.5.5 0 0 0 0-1h-3zm2 5.6V9a.5.5 0 0 1-.5.5H4.5a.5.5 0 0 1 0-1h3V5.6a.5.5 0 1 1 1 0z\"}}]})(props);\n};\nexport function BsStopwatch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 5.6a.5.5 0 1 0-1 0v2.9h-3a.5.5 0 0 0 0 1H8a.5.5 0 0 0 .5-.5V5.6z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.5 1A.5.5 0 0 1 7 .5h2a.5.5 0 0 1 0 1v.57c1.36.196 2.594.78 3.584 1.64a.715.715 0 0 1 .012-.013l.354-.354-.354-.353a.5.5 0 0 1 .707-.708l1.414 1.415a.5.5 0 1 1-.707.707l-.353-.354-.354.354a.512.512 0 0 1-.013.012A7 7 0 1 1 7 2.071V1.5a.5.5 0 0 1-.5-.5zM8 3a6 6 0 1 0 .001 12A6 6 0 0 0 8 3z\"}}]})(props);\n};\nexport function BsStrava (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.731 0 2 9.125h2.788L6.73 5.497l1.93 3.628h2.766L6.731 0zm4.694 9.125-1.372 2.756L8.66 9.125H6.547L10.053 16l3.484-6.875h-2.112z\"}}]})(props);\n};\nexport function BsSubtract (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v2h2a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2v-2H2a2 2 0 0 1-2-2V2zm2-1a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H2z\"}}]})(props);\n};\nexport function BsSuitClubFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.5 12.5a3.493 3.493 0 0 1-2.684-1.254 19.92 19.92 0 0 0 1.582 2.907c.231.35-.02.847-.438.847H6.04c-.419 0-.67-.497-.438-.847a19.919 19.919 0 0 0 1.582-2.907 3.5 3.5 0 1 1-2.538-5.743 3.5 3.5 0 1 1 6.708 0A3.5 3.5 0 1 1 11.5 12.5z\"}}]})(props);\n};\nexport function BsSuitClub (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 1a3.25 3.25 0 0 0-3.25 3.25c0 .186 0 .29.016.41.014.12.045.27.12.527l.19.665-.692-.028a3.25 3.25 0 1 0 2.357 5.334.5.5 0 0 1 .844.518l-.003.005-.006.015-.024.055a21.893 21.893 0 0 1-.438.92 22.38 22.38 0 0 1-1.266 2.197c-.013.018-.02.05.001.09.01.02.021.03.03.036A.036.036 0 0 0 5.9 15h4.2c.01 0 .016-.002.022-.006a.092.092 0 0 0 .029-.035c.02-.04.014-.073.001-.091a22.875 22.875 0 0 1-1.704-3.117l-.024-.054-.006-.015-.002-.004a.5.5 0 0 1 .838-.524c.601.7 1.516 1.168 2.496 1.168a3.25 3.25 0 1 0-.139-6.498l-.699.03.199-.671c.14-.47.14-.745.139-.927V4.25A3.25 3.25 0 0 0 8 1zm2.207 12.024c.225.405.487.848.78 1.294C11.437 15 10.975 16 10.1 16H5.9c-.876 0-1.338-1-.887-1.683.291-.442.552-.88.776-1.283a4.25 4.25 0 1 1-2.007-8.187 2.79 2.79 0 0 1-.009-.064c-.023-.187-.023-.348-.023-.52V4.25a4.25 4.25 0 0 1 8.5 0c0 .14 0 .333-.04.596a4.25 4.25 0 0 1-.46 8.476 4.186 4.186 0 0 1-1.543-.298z\"}}]})(props);\n};\nexport function BsSuitDiamondFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.45 7.4 7.2 1.067a1 1 0 0 1 1.6 0L13.55 7.4a1 1 0 0 1 0 1.2L8.8 14.933a1 1 0 0 1-1.6 0L2.45 8.6a1 1 0 0 1 0-1.2z\"}}]})(props);\n};\nexport function BsSuitDiamond (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.384 1.226a.463.463 0 0 0-.768 0l-4.56 6.468a.537.537 0 0 0 0 .612l4.56 6.469a.463.463 0 0 0 .768 0l4.56-6.469a.537.537 0 0 0 0-.612l-4.56-6.468zM6.848.613a1.39 1.39 0 0 1 2.304 0l4.56 6.468a1.61 1.61 0 0 1 0 1.838l-4.56 6.468a1.39 1.39 0 0 1-2.304 0L2.288 8.92a1.61 1.61 0 0 1 0-1.838L6.848.613z\"}}]})(props);\n};\nexport function BsSuitHeartFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4 1c2.21 0 4 1.755 4 3.92C8 2.755 9.79 1 12 1s4 1.755 4 3.92c0 3.263-3.234 4.414-7.608 9.608a.513.513 0 0 1-.784 0C3.234 9.334 0 8.183 0 4.92 0 2.755 1.79 1 4 1z\"}}]})(props);\n};\nexport function BsSuitHeart (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m8 6.236-.894-1.789c-.222-.443-.607-1.08-1.152-1.595C5.418 2.345 4.776 2 4 2 2.324 2 1 3.326 1 4.92c0 1.211.554 2.066 1.868 3.37.337.334.721.695 1.146 1.093C5.122 10.423 6.5 11.717 8 13.447c1.5-1.73 2.878-3.024 3.986-4.064.425-.398.81-.76 1.146-1.093C14.446 6.986 15 6.131 15 4.92 15 3.326 13.676 2 12 2c-.777 0-1.418.345-1.954.852-.545.515-.93 1.152-1.152 1.595L8 6.236zm.392 8.292a.513.513 0 0 1-.784 0c-1.601-1.902-3.05-3.262-4.243-4.381C1.3 8.208 0 6.989 0 4.92 0 2.755 1.79 1 4 1c1.6 0 2.719 1.05 3.404 2.008.26.365.458.716.596.992a7.55 7.55 0 0 1 .596-.992C9.281 2.049 10.4 1 12 1c2.21 0 4 1.755 4 3.92 0 2.069-1.3 3.288-3.365 5.227-1.193 1.12-2.642 2.48-4.243 4.38z\"}}]})(props);\n};\nexport function BsSuitSpadeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.184 11.246A3.5 3.5 0 0 1 1 9c0-1.602 1.14-2.633 2.66-4.008C4.986 3.792 6.602 2.33 8 0c1.398 2.33 3.014 3.792 4.34 4.992C13.86 6.367 15 7.398 15 9a3.5 3.5 0 0 1-6.184 2.246 19.92 19.92 0 0 0 1.582 2.907c.231.35-.02.847-.438.847H6.04c-.419 0-.67-.497-.438-.847a19.919 19.919 0 0 0 1.582-2.907z\"}}]})(props);\n};\nexport function BsSuitSpade (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a.5.5 0 0 1 .429.243c1.359 2.265 2.925 3.682 4.25 4.882.096.086.19.17.282.255C14.308 6.604 15.5 7.747 15.5 9.5a4 4 0 0 1-5.406 3.746c.235.39.491.782.722 1.131.434.659-.01 1.623-.856 1.623H6.04c-.845 0-1.29-.964-.856-1.623.263-.397.51-.777.728-1.134A4 4 0 0 1 .5 9.5c0-1.753 1.192-2.896 2.539-4.12l.281-.255c1.326-1.2 2.892-2.617 4.251-4.882A.5.5 0 0 1 8 0zM3.711 6.12C2.308 7.396 1.5 8.253 1.5 9.5a3 3 0 0 0 5.275 1.956.5.5 0 0 1 .868.43c-.094.438-.33.932-.611 1.428a29.247 29.247 0 0 1-1.013 1.614.03.03 0 0 0-.005.018.074.074 0 0 0 .024.054h3.924a.074.074 0 0 0 .024-.054.03.03 0 0 0-.005-.018c-.3-.455-.658-1.005-.96-1.535-.294-.514-.57-1.064-.664-1.507a.5.5 0 0 1 .868-.43A3 3 0 0 0 14.5 9.5c0-1.247-.808-2.104-2.211-3.38L12 5.86c-1.196-1.084-2.668-2.416-4-4.424-1.332 2.008-2.804 3.34-4 4.422l-.289.261z\"}}]})(props);\n};\nexport function BsSunFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 12a4 4 0 1 0 0-8 4 4 0 0 0 0 8zM8 0a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 0zm0 13a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 13zm8-5a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2a.5.5 0 0 1 .5.5zM3 8a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2A.5.5 0 0 1 3 8zm10.657-5.657a.5.5 0 0 1 0 .707l-1.414 1.415a.5.5 0 1 1-.707-.708l1.414-1.414a.5.5 0 0 1 .707 0zm-9.193 9.193a.5.5 0 0 1 0 .707L3.05 13.657a.5.5 0 0 1-.707-.707l1.414-1.414a.5.5 0 0 1 .707 0zm9.193 2.121a.5.5 0 0 1-.707 0l-1.414-1.414a.5.5 0 0 1 .707-.707l1.414 1.414a.5.5 0 0 1 0 .707zM4.464 4.465a.5.5 0 0 1-.707 0L2.343 3.05a.5.5 0 1 1 .707-.707l1.414 1.414a.5.5 0 0 1 0 .708z\"}}]})(props);\n};\nexport function BsSun (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 11a3 3 0 1 1 0-6 3 3 0 0 1 0 6zm0 1a4 4 0 1 0 0-8 4 4 0 0 0 0 8zM8 0a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 0zm0 13a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 13zm8-5a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2a.5.5 0 0 1 .5.5zM3 8a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2A.5.5 0 0 1 3 8zm10.657-5.657a.5.5 0 0 1 0 .707l-1.414 1.415a.5.5 0 1 1-.707-.708l1.414-1.414a.5.5 0 0 1 .707 0zm-9.193 9.193a.5.5 0 0 1 0 .707L3.05 13.657a.5.5 0 0 1-.707-.707l1.414-1.414a.5.5 0 0 1 .707 0zm9.193 2.121a.5.5 0 0 1-.707 0l-1.414-1.414a.5.5 0 0 1 .707-.707l1.414 1.414a.5.5 0 0 1 0 .707zM4.464 4.465a.5.5 0 0 1-.707 0L2.343 3.05a.5.5 0 1 1 .707-.707l1.414 1.414a.5.5 0 0 1 0 .708z\"}}]})(props);\n};\nexport function BsSunglasses (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 5a2 2 0 0 0-2 2v.5H.5a.5.5 0 0 0 0 1H1V9a2 2 0 0 0 2 2h1a3 3 0 0 0 3-3 1 1 0 1 1 2 0 3 3 0 0 0 3 3h1a2 2 0 0 0 2-2v-.5h.5a.5.5 0 0 0 0-1H15V7a2 2 0 0 0-2-2h-2a2 2 0 0 0-1.888 1.338A1.99 1.99 0 0 0 8 6a1.99 1.99 0 0 0-1.112.338A2 2 0 0 0 5 5H3zm0 1h.941c.264 0 .348.356.112.474l-.457.228a2 2 0 0 0-.894.894l-.228.457C2.356 8.289 2 8.205 2 7.94V7a1 1 0 0 1 1-1z\"}}]})(props);\n};\nexport function BsSunriseFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.646 1.146a.5.5 0 0 1 .708 0l1.5 1.5a.5.5 0 0 1-.708.708L8.5 2.707V4.5a.5.5 0 0 1-1 0V2.707l-.646.647a.5.5 0 1 1-.708-.708l1.5-1.5zM2.343 4.343a.5.5 0 0 1 .707 0l1.414 1.414a.5.5 0 0 1-.707.707L2.343 5.05a.5.5 0 0 1 0-.707zm11.314 0a.5.5 0 0 1 0 .707l-1.414 1.414a.5.5 0 1 1-.707-.707l1.414-1.414a.5.5 0 0 1 .707 0zM11.709 11.5a4 4 0 1 0-7.418 0H.5a.5.5 0 0 0 0 1h15a.5.5 0 0 0 0-1h-3.79zM0 10a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2A.5.5 0 0 1 0 10zm13 0a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsSunrise (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.646 1.146a.5.5 0 0 1 .708 0l1.5 1.5a.5.5 0 0 1-.708.708L8.5 2.707V4.5a.5.5 0 0 1-1 0V2.707l-.646.647a.5.5 0 1 1-.708-.708l1.5-1.5zM2.343 4.343a.5.5 0 0 1 .707 0l1.414 1.414a.5.5 0 0 1-.707.707L2.343 5.05a.5.5 0 0 1 0-.707zm11.314 0a.5.5 0 0 1 0 .707l-1.414 1.414a.5.5 0 1 1-.707-.707l1.414-1.414a.5.5 0 0 1 .707 0zM8 7a3 3 0 0 1 2.599 4.5H5.4A3 3 0 0 1 8 7zm3.71 4.5a4 4 0 1 0-7.418 0H.499a.5.5 0 0 0 0 1h15a.5.5 0 0 0 0-1h-3.79zM0 10a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2A.5.5 0 0 1 0 10zm13 0a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsSunsetFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.646 4.854a.5.5 0 0 0 .708 0l1.5-1.5a.5.5 0 0 0-.708-.708l-.646.647V1.5a.5.5 0 0 0-1 0v1.793l-.646-.647a.5.5 0 1 0-.708.708l1.5 1.5zm-5.303-.51a.5.5 0 0 1 .707 0l1.414 1.413a.5.5 0 0 1-.707.707L2.343 5.05a.5.5 0 0 1 0-.707zm11.314 0a.5.5 0 0 1 0 .706l-1.414 1.414a.5.5 0 1 1-.707-.707l1.414-1.414a.5.5 0 0 1 .707 0zM11.709 11.5a4 4 0 1 0-7.418 0H.5a.5.5 0 0 0 0 1h15a.5.5 0 0 0 0-1h-3.79zM0 10a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2A.5.5 0 0 1 0 10zm13 0a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsSunset (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.646 4.854a.5.5 0 0 0 .708 0l1.5-1.5a.5.5 0 0 0-.708-.708l-.646.647V1.5a.5.5 0 0 0-1 0v1.793l-.646-.647a.5.5 0 1 0-.708.708l1.5 1.5zm-5.303-.51a.5.5 0 0 1 .707 0l1.414 1.413a.5.5 0 0 1-.707.707L2.343 5.05a.5.5 0 0 1 0-.707zm11.314 0a.5.5 0 0 1 0 .706l-1.414 1.414a.5.5 0 1 1-.707-.707l1.414-1.414a.5.5 0 0 1 .707 0zM8 7a3 3 0 0 1 2.599 4.5H5.4A3 3 0 0 1 8 7zm3.71 4.5a4 4 0 1 0-7.418 0H.499a.5.5 0 0 0 0 1h15a.5.5 0 0 0 0-1h-3.79zM0 10a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2A.5.5 0 0 1 0 10zm13 0a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsSymmetryHorizontal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.5 7a.5.5 0 0 0 .24-.939l-11-6A.5.5 0 0 0 2 .5v6a.5.5 0 0 0 .5.5h11zm.485 2.376a.5.5 0 0 1-.246.563l-11 6A.5.5 0 0 1 2 15.5v-6a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 .485.376zM11.539 10H3v4.658L11.54 10z\"}}]})(props);\n};\nexport function BsSymmetryVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 2.5a.5.5 0 0 0-.939-.24l-6 11A.5.5 0 0 0 .5 14h6a.5.5 0 0 0 .5-.5v-11zm2.376-.484a.5.5 0 0 1 .563.245l6 11A.5.5 0 0 1 15.5 14h-6a.5.5 0 0 1-.5-.5v-11a.5.5 0 0 1 .376-.484zM10 4.46V13h4.658L10 4.46z\"}}]})(props);\n};\nexport function BsTable (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm15 2h-4v3h4V4zm0 4h-4v3h4V8zm0 4h-4v3h3a1 1 0 0 0 1-1v-2zm-5 3v-3H6v3h4zm-5 0v-3H1v2a1 1 0 0 0 1 1h3zm-4-4h4V8H1v3zm0-4h4V4H1v3zm5-3v3h4V4H6zm4 4H6v3h4V8z\"}}]})(props);\n};\nexport function BsTabletFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V2zm7 11a1 1 0 1 0-2 0 1 1 0 0 0 2 0z\"}}]})(props);\n};\nexport function BsTabletLandscapeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 14a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H2zm11-7a1 1 0 1 0 0 2 1 1 0 0 0 0-2z\"}}]})(props);\n};\nexport function BsTabletLandscape (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 4a1 1 0 0 1 1-1h12a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V4zm-1 8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 8a1 1 0 1 0-2 0 1 1 0 0 0 2 0z\"}}]})(props);\n};\nexport function BsTablet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h8zM4 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 14a1 1 0 1 0 0-2 1 1 0 0 0 0 2z\"}}]})(props);\n};\nexport function BsTagFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1a1 1 0 0 0-1 1v4.586a1 1 0 0 0 .293.707l7 7a1 1 0 0 0 1.414 0l4.586-4.586a1 1 0 0 0 0-1.414l-7-7A1 1 0 0 0 6.586 1H2zm4 3.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0z\"}}]})(props);\n};\nexport function BsTag (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 4.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm-1 0a.5.5 0 1 0-1 0 .5.5 0 0 0 1 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1h4.586a1 1 0 0 1 .707.293l7 7a1 1 0 0 1 0 1.414l-4.586 4.586a1 1 0 0 1-1.414 0l-7-7A1 1 0 0 1 1 6.586V2a1 1 0 0 1 1-1zm0 5.586 7 7L13.586 9l-7-7H2v4.586z\"}}]})(props);\n};\nexport function BsTagsFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 2a1 1 0 0 1 1-1h4.586a1 1 0 0 1 .707.293l7 7a1 1 0 0 1 0 1.414l-4.586 4.586a1 1 0 0 1-1.414 0l-7-7A1 1 0 0 1 2 6.586V2zm3.5 4a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1.293 7.793A1 1 0 0 1 1 7.086V2a1 1 0 0 0-1 1v4.586a1 1 0 0 0 .293.707l7 7a1 1 0 0 0 1.414 0l.043-.043-7.457-7.457z\"}}]})(props);\n};\nexport function BsTags (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 2v4.586l7 7L14.586 9l-7-7H3zM2 2a1 1 0 0 1 1-1h4.586a1 1 0 0 1 .707.293l7 7a1 1 0 0 1 0 1.414l-4.586 4.586a1 1 0 0 1-1.414 0l-7-7A1 1 0 0 1 2 6.586V2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 5a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1zm0 1a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3zM1 7.086a1 1 0 0 0 .293.707L8.75 15.25l-.043.043a1 1 0 0 1-1.414 0l-7-7A1 1 0 0 1 0 7.586V3a1 1 0 0 1 1-1v5.086z\"}}]})(props);\n};\nexport function BsTelegram (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM8.287 5.906c-.778.324-2.334.994-4.666 2.01-.378.15-.577.298-.595.442-.03.243.275.339.69.47l.175.055c.408.133.958.288 1.243.294.26.006.549-.1.868-.32 2.179-1.471 3.304-2.214 3.374-2.23.05-.012.12-.026.166.016.047.041.042.12.037.141-.03.129-1.227 1.241-1.846 1.817-.193.18-.33.307-.358.336a8.154 8.154 0 0 1-.188.186c-.38.366-.664.64.015 1.088.327.216.589.393.85.571.284.194.568.387.936.629.093.06.183.125.27.187.331.236.63.448.997.414.214-.02.435-.22.547-.82.265-1.417.786-4.486.906-5.751a1.426 1.426 0 0 0-.013-.315.337.337 0 0 0-.114-.217.526.526 0 0 0-.31-.093c-.3.005-.763.166-2.984 1.09z\"}}]})(props);\n};\nexport function BsTelephoneFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.885.511a1.745 1.745 0 0 1 2.61.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511z\"}}]})(props);\n};\nexport function BsTelephoneForwardFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.885.511a1.745 1.745 0 0 1 2.61.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511zm10.761.135a.5.5 0 0 1 .708 0l2.5 2.5a.5.5 0 0 1 0 .708l-2.5 2.5a.5.5 0 0 1-.708-.708L14.293 4H9.5a.5.5 0 0 1 0-1h4.793l-1.647-1.646a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsTelephoneForward (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.654 1.328a.678.678 0 0 0-1.015-.063L1.605 2.3c-.483.484-.661 1.169-.45 1.77a17.568 17.568 0 0 0 4.168 6.608 17.569 17.569 0 0 0 6.608 4.168c.601.211 1.286.033 1.77-.45l1.034-1.034a.678.678 0 0 0-.063-1.015l-2.307-1.794a.678.678 0 0 0-.58-.122l-2.19.547a1.745 1.745 0 0 1-1.657-.459L5.482 8.062a1.745 1.745 0 0 1-.46-1.657l.548-2.19a.678.678 0 0 0-.122-.58L3.654 1.328zM1.884.511a1.745 1.745 0 0 1 2.612.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511zm10.762.135a.5.5 0 0 1 .708 0l2.5 2.5a.5.5 0 0 1 0 .708l-2.5 2.5a.5.5 0 0 1-.708-.708L14.293 4H9.5a.5.5 0 0 1 0-1h4.793l-1.647-1.646a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsTelephoneInboundFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.885.511a1.745 1.745 0 0 1 2.61.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511zM15.854.146a.5.5 0 0 1 0 .708L11.707 5H14.5a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 1 0v2.793L15.146.146a.5.5 0 0 1 .708 0z\"}}]})(props);\n};\nexport function BsTelephoneInbound (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.854.146a.5.5 0 0 1 0 .708L11.707 5H14.5a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 1 0v2.793L15.146.146a.5.5 0 0 1 .708 0zm-12.2 1.182a.678.678 0 0 0-1.015-.063L1.605 2.3c-.483.484-.661 1.169-.45 1.77a17.568 17.568 0 0 0 4.168 6.608 17.569 17.569 0 0 0 6.608 4.168c.601.211 1.286.033 1.77-.45l1.034-1.034a.678.678 0 0 0-.063-1.015l-2.307-1.794a.678.678 0 0 0-.58-.122l-2.19.547a1.745 1.745 0 0 1-1.657-.459L5.482 8.062a1.745 1.745 0 0 1-.46-1.657l.548-2.19a.678.678 0 0 0-.122-.58L3.654 1.328zM1.884.511a1.745 1.745 0 0 1 2.612.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511z\"}}]})(props);\n};\nexport function BsTelephoneMinusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.885.511a1.745 1.745 0 0 1 2.61.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511zM10 3.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsTelephoneMinus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10 3.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3.654 1.328a.678.678 0 0 0-1.015-.063L1.605 2.3c-.483.484-.661 1.169-.45 1.77a17.568 17.568 0 0 0 4.168 6.608 17.569 17.569 0 0 0 6.608 4.168c.601.211 1.286.033 1.77-.45l1.034-1.034a.678.678 0 0 0-.063-1.015l-2.307-1.794a.678.678 0 0 0-.58-.122l-2.19.547a1.745 1.745 0 0 1-1.657-.459L5.482 8.062a1.745 1.745 0 0 1-.46-1.657l.548-2.19a.678.678 0 0 0-.122-.58L3.654 1.328zM1.884.511a1.745 1.745 0 0 1 2.612.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511z\"}}]})(props);\n};\nexport function BsTelephoneOutboundFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.885.511a1.745 1.745 0 0 1 2.61.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511zM11 .5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-1 0V1.707l-4.146 4.147a.5.5 0 0 1-.708-.708L14.293 1H11.5a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsTelephoneOutbound (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.654 1.328a.678.678 0 0 0-1.015-.063L1.605 2.3c-.483.484-.661 1.169-.45 1.77a17.568 17.568 0 0 0 4.168 6.608 17.569 17.569 0 0 0 6.608 4.168c.601.211 1.286.033 1.77-.45l1.034-1.034a.678.678 0 0 0-.063-1.015l-2.307-1.794a.678.678 0 0 0-.58-.122l-2.19.547a1.745 1.745 0 0 1-1.657-.459L5.482 8.062a1.745 1.745 0 0 1-.46-1.657l.548-2.19a.678.678 0 0 0-.122-.58L3.654 1.328zM1.884.511a1.745 1.745 0 0 1 2.612.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511zM11 .5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-1 0V1.707l-4.146 4.147a.5.5 0 0 1-.708-.708L14.293 1H11.5a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsTelephonePlusFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.885.511a1.745 1.745 0 0 1 2.61.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511zM12.5 1a.5.5 0 0 1 .5.5V3h1.5a.5.5 0 0 1 0 1H13v1.5a.5.5 0 0 1-1 0V4h-1.5a.5.5 0 0 1 0-1H12V1.5a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsTelephonePlus (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.654 1.328a.678.678 0 0 0-1.015-.063L1.605 2.3c-.483.484-.661 1.169-.45 1.77a17.568 17.568 0 0 0 4.168 6.608 17.569 17.569 0 0 0 6.608 4.168c.601.211 1.286.033 1.77-.45l1.034-1.034a.678.678 0 0 0-.063-1.015l-2.307-1.794a.678.678 0 0 0-.58-.122l-2.19.547a1.745 1.745 0 0 1-1.657-.459L5.482 8.062a1.745 1.745 0 0 1-.46-1.657l.548-2.19a.678.678 0 0 0-.122-.58L3.654 1.328zM1.884.511a1.745 1.745 0 0 1 2.612.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M12.5 1a.5.5 0 0 1 .5.5V3h1.5a.5.5 0 0 1 0 1H13v1.5a.5.5 0 0 1-1 0V4h-1.5a.5.5 0 0 1 0-1H12V1.5a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsTelephoneXFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M1.885.511a1.745 1.745 0 0 1 2.61.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511zm9.261 1.135a.5.5 0 0 1 .708 0L13 2.793l1.146-1.147a.5.5 0 0 1 .708.708L13.707 3.5l1.147 1.146a.5.5 0 0 1-.708.708L13 4.207l-1.146 1.147a.5.5 0 0 1-.708-.708L12.293 3.5l-1.147-1.146a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsTelephoneX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.654 1.328a.678.678 0 0 0-1.015-.063L1.605 2.3c-.483.484-.661 1.169-.45 1.77a17.568 17.568 0 0 0 4.168 6.608 17.569 17.569 0 0 0 6.608 4.168c.601.211 1.286.033 1.77-.45l1.034-1.034a.678.678 0 0 0-.063-1.015l-2.307-1.794a.678.678 0 0 0-.58-.122l-2.19.547a1.745 1.745 0 0 1-1.657-.459L5.482 8.062a1.745 1.745 0 0 1-.46-1.657l.548-2.19a.678.678 0 0 0-.122-.58L3.654 1.328zM1.884.511a1.745 1.745 0 0 1 2.612.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M11.146 1.646a.5.5 0 0 1 .708 0L13 2.793l1.146-1.147a.5.5 0 0 1 .708.708L13.707 3.5l1.147 1.146a.5.5 0 0 1-.708.708L13 4.207l-1.146 1.147a.5.5 0 0 1-.708-.708L12.293 3.5l-1.147-1.146a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsTelephone (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.654 1.328a.678.678 0 0 0-1.015-.063L1.605 2.3c-.483.484-.661 1.169-.45 1.77a17.568 17.568 0 0 0 4.168 6.608 17.569 17.569 0 0 0 6.608 4.168c.601.211 1.286.033 1.77-.45l1.034-1.034a.678.678 0 0 0-.063-1.015l-2.307-1.794a.678.678 0 0 0-.58-.122l-2.19.547a1.745 1.745 0 0 1-1.657-.459L5.482 8.062a1.745 1.745 0 0 1-.46-1.657l.548-2.19a.678.678 0 0 0-.122-.58L3.654 1.328zM1.884.511a1.745 1.745 0 0 1 2.612.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511z\"}}]})(props);\n};\nexport function BsTerminalFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 3a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3zm9.5 5.5h-3a.5.5 0 0 0 0 1h3a.5.5 0 0 0 0-1zm-6.354-.354a.5.5 0 1 0 .708.708l2-2a.5.5 0 0 0 0-.708l-2-2a.5.5 0 1 0-.708.708L4.793 6.5 3.146 8.146z\"}}]})(props);\n};\nexport function BsTerminal (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6 9a.5.5 0 0 1 .5-.5h3a.5.5 0 0 1 0 1h-3A.5.5 0 0 1 6 9zM3.854 4.146a.5.5 0 1 0-.708.708L4.793 6.5 3.146 8.146a.5.5 0 1 0 .708.708l2-2a.5.5 0 0 0 0-.708l-2-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V3a2 2 0 0 0-2-2H2zm12 1a1 1 0 0 1 1 1v10a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V3a1 1 0 0 1 1-1h12z\"}}]})(props);\n};\nexport function BsTextCenter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M4 12.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm-2-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5zm2-3a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm-2-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsTextIndentLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 3.5a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5zm.646 2.146a.5.5 0 0 1 .708 0l2 2a.5.5 0 0 1 0 .708l-2 2a.5.5 0 0 1-.708-.708L4.293 8 2.646 6.354a.5.5 0 0 1 0-.708zM7 6.5a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5zm0 3a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5zm-5 3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsTextIndentRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 3.5a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5zm10.646 2.146a.5.5 0 0 1 .708.708L11.707 8l1.647 1.646a.5.5 0 0 1-.708.708l-2-2a.5.5 0 0 1 0-.708l2-2zM2 6.5a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5zm0 3a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5zm0 3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsTextLeft (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 12.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm0-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5zm0-3a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm0-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsTextParagraph (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2 12.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm0-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5zm0-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5zm4-3a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsTextRight (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6 12.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm-4-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5zm4-3a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm-4-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsTextareaResize (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 4.5A2.5 2.5 0 0 1 2.5 2h11A2.5 2.5 0 0 1 16 4.5v7a2.5 2.5 0 0 1-2.5 2.5h-11A2.5 2.5 0 0 1 0 11.5v-7zM2.5 3A1.5 1.5 0 0 0 1 4.5v7A1.5 1.5 0 0 0 2.5 13h11a1.5 1.5 0 0 0 1.5-1.5v-7A1.5 1.5 0 0 0 13.5 3h-11zm10.854 4.646a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708-.708l3-3a.5.5 0 0 1 .708 0zm0 2.5a.5.5 0 0 1 0 .708l-.5.5a.5.5 0 0 1-.708-.708l.5-.5a.5.5 0 0 1 .708 0z\"}}]})(props);\n};\nexport function BsTextareaT (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 2.5A1.5 1.5 0 0 1 3 1h10a1.5 1.5 0 0 1 1.5 1.5v3.563a2 2 0 0 1 0 3.874V13.5A1.5 1.5 0 0 1 13 15H3a1.5 1.5 0 0 1-1.5-1.5V9.937a2 2 0 0 1 0-3.874V2.5zm1 3.563a2 2 0 0 1 0 3.874V13.5a.5.5 0 0 0 .5.5h10a.5.5 0 0 0 .5-.5V9.937a2 2 0 0 1 0-3.874V2.5A.5.5 0 0 0 13 2H3a.5.5 0 0 0-.5.5v3.563zM2 7a1 1 0 1 0 0 2 1 1 0 0 0 0-2zm12 0a1 1 0 1 0 0 2 1 1 0 0 0 0-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.434 4H4.566L4.5 5.994h.386c.21-1.252.612-1.446 2.173-1.495l.343-.011v6.343c0 .537-.116.665-1.049.748V12h3.294v-.421c-.938-.083-1.054-.21-1.054-.748V4.488l.348.01c1.56.05 1.963.244 2.173 1.496h.386L11.434 4z\"}}]})(props);\n};\nexport function BsTextarea (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 2.5A1.5 1.5 0 0 1 3 1h10a1.5 1.5 0 0 1 1.5 1.5v3.563a2 2 0 0 1 0 3.874V13.5A1.5 1.5 0 0 1 13 15H3a1.5 1.5 0 0 1-1.5-1.5V9.937a2 2 0 0 1 0-3.874V2.5zm1 3.563a2 2 0 0 1 0 3.874V13.5a.5.5 0 0 0 .5.5h10a.5.5 0 0 0 .5-.5V9.937a2 2 0 0 1 0-3.874V2.5A.5.5 0 0 0 13 2H3a.5.5 0 0 0-.5.5v3.563zM2 7a1 1 0 1 0 0 2 1 1 0 0 0 0-2zm12 0a1 1 0 1 0 0 2 1 1 0 0 0 0-2z\"}}]})(props);\n};\nexport function BsThermometerHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 12.5a1.5 1.5 0 1 1-2-1.415V6.5a.5.5 0 0 1 1 0v4.585a1.5 1.5 0 0 1 1 1.415z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 2.5a2.5 2.5 0 0 1 5 0v7.55a3.5 3.5 0 1 1-5 0V2.5zM8 1a1.5 1.5 0 0 0-1.5 1.5v7.987l-.167.15a2.5 2.5 0 1 0 3.333 0l-.166-.15V2.5A1.5 1.5 0 0 0 8 1z\"}}]})(props);\n};\nexport function BsThermometerHigh (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 12.5a1.5 1.5 0 1 1-2-1.415V2.5a.5.5 0 0 1 1 0v8.585a1.5 1.5 0 0 1 1 1.415z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 2.5a2.5 2.5 0 0 1 5 0v7.55a3.5 3.5 0 1 1-5 0V2.5zM8 1a1.5 1.5 0 0 0-1.5 1.5v7.987l-.167.15a2.5 2.5 0 1 0 3.333 0l-.166-.15V2.5A1.5 1.5 0 0 0 8 1z\"}}]})(props);\n};\nexport function BsThermometerLow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 12.5a1.5 1.5 0 1 1-2-1.415V9.5a.5.5 0 0 1 1 0v1.585a1.5 1.5 0 0 1 1 1.415z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 2.5a2.5 2.5 0 0 1 5 0v7.55a3.5 3.5 0 1 1-5 0V2.5zM8 1a1.5 1.5 0 0 0-1.5 1.5v7.987l-.167.15a2.5 2.5 0 1 0 3.333 0l-.166-.15V2.5A1.5 1.5 0 0 0 8 1z\"}}]})(props);\n};\nexport function BsThermometerSnow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12.5a1.5 1.5 0 1 1-2-1.415V9.5a.5.5 0 0 1 1 0v1.585A1.5 1.5 0 0 1 5 12.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 2.5a2.5 2.5 0 0 1 5 0v7.55a3.5 3.5 0 1 1-5 0V2.5zM3.5 1A1.5 1.5 0 0 0 2 2.5v7.987l-.167.15a2.5 2.5 0 1 0 3.333 0L5 10.486V2.5A1.5 1.5 0 0 0 3.5 1zm5 1a.5.5 0 0 1 .5.5v1.293l.646-.647a.5.5 0 0 1 .708.708L9 5.207v1.927l1.669-.963.495-1.85a.5.5 0 1 1 .966.26l-.237.882 1.12-.646a.5.5 0 0 1 .5.866l-1.12.646.884.237a.5.5 0 1 1-.26.966l-1.848-.495L9.5 8l1.669.963 1.849-.495a.5.5 0 1 1 .258.966l-.883.237 1.12.646a.5.5 0 0 1-.5.866l-1.12-.646.237.883a.5.5 0 1 1-.966.258L10.67 9.83 9 8.866v1.927l1.354 1.353a.5.5 0 0 1-.708.708L9 12.207V13.5a.5.5 0 0 1-1 0v-11a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsThermometerSun (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12.5a1.5 1.5 0 1 1-2-1.415V2.5a.5.5 0 0 1 1 0v8.585A1.5 1.5 0 0 1 5 12.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M1 2.5a2.5 2.5 0 0 1 5 0v7.55a3.5 3.5 0 1 1-5 0V2.5zM3.5 1A1.5 1.5 0 0 0 2 2.5v7.987l-.167.15a2.5 2.5 0 1 0 3.333 0L5 10.486V2.5A1.5 1.5 0 0 0 3.5 1zm5 1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-1 0v-1a.5.5 0 0 1 .5-.5zm4.243 1.757a.5.5 0 0 1 0 .707l-.707.708a.5.5 0 1 1-.708-.708l.708-.707a.5.5 0 0 1 .707 0zM8 5.5a.5.5 0 0 1 .5-.5 3 3 0 1 1 0 6 .5.5 0 0 1 0-1 2 2 0 0 0 0-4 .5.5 0 0 1-.5-.5zM12.5 8a.5.5 0 0 1 .5-.5h1a.5.5 0 1 1 0 1h-1a.5.5 0 0 1-.5-.5zm-1.172 2.828a.5.5 0 0 1 .708 0l.707.708a.5.5 0 0 1-.707.707l-.708-.707a.5.5 0 0 1 0-.708zM8.5 12a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-1 0v-1a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsThermometer (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 14a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a2.5 2.5 0 0 0-2.5 2.5v7.55a3.5 3.5 0 1 0 5 0V2.5A2.5 2.5 0 0 0 8 0zM6.5 2.5a1.5 1.5 0 1 1 3 0v7.987l.167.15a2.5 2.5 0 1 1-3.333 0l.166-.15V2.5z\"}}]})(props);\n};\nexport function BsThreeDotsVertical (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 13a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm0-5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm0-5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0z\"}}]})(props);\n};\nexport function BsThreeDots (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 9.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm5 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm5 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsToggleOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 4a4 4 0 0 1 0 8H8a4.992 4.992 0 0 0 2-4 4.992 4.992 0 0 0-2-4h3zm-6 8a4 4 0 1 1 0-8 4 4 0 0 1 0 8zM0 8a5 5 0 0 0 5 5h6a5 5 0 0 0 0-10H5a5 5 0 0 0-5 5z\"}}]})(props);\n};\nexport function BsToggleOn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5 3a5 5 0 0 0 0 10h6a5 5 0 0 0 0-10H5zm6 9a4 4 0 1 1 0-8 4 4 0 0 1 0 8z\"}}]})(props);\n};\nexport function BsToggle2Off (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9 11c.628-.836 1-1.874 1-3a4.978 4.978 0 0 0-1-3h4a3 3 0 1 1 0 6H9z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5 12a4 4 0 1 1 0-8 4 4 0 0 1 0 8zm0 1A5 5 0 1 0 5 3a5 5 0 0 0 0 10z\"}}]})(props);\n};\nexport function BsToggle2On (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 5H3a3 3 0 0 0 0 6h4a4.995 4.995 0 0 1-.584-1H3a2 2 0 1 1 0-4h3.416c.156-.357.352-.692.584-1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A5 5 0 1 1 6 8a5 5 0 0 1 10 0z\"}}]})(props);\n};\nexport function BsToggles (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.5 9a3.5 3.5 0 1 0 0 7h7a3.5 3.5 0 1 0 0-7h-7zm7 6a2.5 2.5 0 1 1 0-5 2.5 2.5 0 0 1 0 5zm-7-14a2.5 2.5 0 1 0 0 5 2.5 2.5 0 0 0 0-5zm2.45 0A3.49 3.49 0 0 1 8 3.5 3.49 3.49 0 0 1 6.95 6h4.55a2.5 2.5 0 0 0 0-5H6.95zM4.5 0h7a3.5 3.5 0 1 1 0 7h-7a3.5 3.5 0 1 1 0-7z\"}}]})(props);\n};\nexport function BsToggles2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.465 10H12a2 2 0 1 1 0 4H9.465c.34-.588.535-1.271.535-2 0-.729-.195-1.412-.535-2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6 15a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm0 1a4 4 0 1 1 0-8 4 4 0 0 1 0 8zm.535-10a3.975 3.975 0 0 1-.409-1H4a1 1 0 0 1 0-2h2.126c.091-.355.23-.69.41-1H4a2 2 0 1 0 0 4h2.535z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M14 4a4 4 0 1 1-8 0 4 4 0 0 1 8 0z\"}}]})(props);\n};\nexport function BsTools (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1 0 0 1l2.2 3.081a1 1 0 0 0 .815.419h.07a1 1 0 0 1 .708.293l2.675 2.675-2.617 2.654A3.003 3.003 0 0 0 0 13a3 3 0 1 0 5.878-.851l2.654-2.617.968.968-.305.914a1 1 0 0 0 .242 1.023l3.356 3.356a1 1 0 0 0 1.414 0l1.586-1.586a1 1 0 0 0 0-1.414l-3.356-3.356a1 1 0 0 0-1.023-.242L10.5 9.5l-.96-.96 2.68-2.643A3.005 3.005 0 0 0 16 3c0-.269-.035-.53-.102-.777l-2.14 2.141L12 4l-.364-1.757L13.777.102a3 3 0 0 0-3.675 3.68L7.462 6.46 4.793 3.793a1 1 0 0 1-.293-.707v-.071a1 1 0 0 0-.419-.814L1 0zm9.646 10.646a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1-.708.708l-3-3a.5.5 0 0 1 0-.708zM3 11l.471.242.529.026.287.445.445.287.026.529L5 13l-.242.471-.026.529-.445.287-.287.445-.529.026L3 15l-.471-.242L2 14.732l-.287-.445L1.268 14l-.026-.529L1 13l.242-.471.026-.529.445-.287.287-.445.529-.026L3 11z\"}}]})(props);\n};\nexport function BsTornado (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.125 2.45A.892.892 0 0 1 1 2c0-.26.116-.474.258-.634a1.9 1.9 0 0 1 .513-.389c.387-.21.913-.385 1.52-.525C4.514.17 6.18 0 8 0c1.821 0 3.486.17 4.709.452.607.14 1.133.314 1.52.525.193.106.374.233.513.389.141.16.258.374.258.634 0 1.011-.35 1.612-.634 2.102-.04.07-.08.137-.116.203a2.55 2.55 0 0 0-.313.809 2.938 2.938 0 0 0-.011.891.5.5 0 0 1 .428.849c-.06.06-.133.126-.215.195.204 1.116.088 1.99-.3 2.711-.453.84-1.231 1.383-2.02 1.856-.204.123-.412.243-.62.364-1.444.832-2.928 1.689-3.735 3.706a.5.5 0 0 1-.748.226l-.001-.001-.002-.001-.004-.003-.01-.008a2.142 2.142 0 0 1-.147-.115 4.095 4.095 0 0 1-1.179-1.656 3.786 3.786 0 0 1-.247-1.296A.498.498 0 0 1 5 12.5v-.018a.62.62 0 0 1 .008-.079.728.728 0 0 1 .188-.386c.09-.489.272-1.014.573-1.574a.5.5 0 0 1 .073-.918 3.29 3.29 0 0 1 .617-.144l.15-.193c.285-.356.404-.639.437-.861a.948.948 0 0 0-.122-.619c-.249-.455-.815-.903-1.613-1.43-.193-.127-.398-.258-.609-.394l-.119-.076a12.307 12.307 0 0 1-1.241-.334.5.5 0 0 1-.285-.707l-.23-.18C2.117 4.01 1.463 3.32 1.125 2.45zm1.973 1.051c.113.104.233.207.358.308.472.381.99.722 1.515 1.06 1.54.317 3.632.5 5.43.14a.5.5 0 0 1 .197.981c-1.216.244-2.537.26-3.759.157.399.326.744.682.963 1.081.203.373.302.79.233 1.247-.05.33-.182.657-.39.985.075.017.148.035.22.053l.006.002c.481.12.863.213 1.47.01a.5.5 0 1 1 .317.95c-.888.295-1.505.141-2.023.012l-.006-.002a3.894 3.894 0 0 0-.644-.123c-.37.55-.598 1.05-.726 1.497.142.045.296.11.465.194a.5.5 0 1 1-.448.894 3.11 3.11 0 0 0-.148-.07c.012.345.084.643.18.895.14.369.342.666.528.886.992-1.903 2.583-2.814 3.885-3.56.203-.116.399-.228.584-.34.775-.464 1.34-.89 1.653-1.472.212-.393.33-.9.26-1.617A6.74 6.74 0 0 1 10 8.5a.5.5 0 0 1 0-1 5.76 5.76 0 0 0 3.017-.872.515.515 0 0 1-.007-.03c-.135-.673-.14-1.207-.056-1.665.084-.46.253-.81.421-1.113l.131-.23c.065-.112.126-.22.182-.327-.29.107-.62.202-.98.285C11.487 3.83 9.822 4 8 4c-1.821 0-3.486-.17-4.709-.452-.065-.015-.13-.03-.193-.047zM13.964 2a1.12 1.12 0 0 0-.214-.145c-.272-.148-.697-.297-1.266-.428C11.354 1.166 9.769 1 8 1c-1.769 0-3.354.166-4.484.427-.569.13-.994.28-1.266.428A1.12 1.12 0 0 0 2.036 2c.04.038.109.087.214.145.272.148.697.297 1.266.428C4.646 2.834 6.231 3 8 3c1.769 0 3.354-.166 4.484-.427.569-.13.994-.28 1.266-.428A1.12 1.12 0 0 0 13.964 2z\"}}]})(props);\n};\nexport function BsTranslate (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.545 6.714 4.11 8H3l1.862-5h1.284L8 8H6.833l-.435-1.286H4.545zm1.634-.736L5.5 3.956h-.049l-.679 2.022H6.18z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h7a2 2 0 0 1 2 2v3h3a2 2 0 0 1 2 2v7a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2v-3H2a2 2 0 0 1-2-2V2zm2-1a1 1 0 0 0-1 1v7a1 1 0 0 0 1 1h7a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H2zm7.138 9.995c.193.301.402.583.63.846-.748.575-1.673 1.001-2.768 1.292.178.217.451.635.555.867 1.125-.359 2.08-.844 2.886-1.494.777.665 1.739 1.165 2.93 1.472.133-.254.414-.673.629-.89-1.125-.253-2.057-.694-2.82-1.284.681-.747 1.222-1.651 1.621-2.757H14V8h-3v1.047h.765c-.318.844-.74 1.546-1.272 2.13a6.066 6.066 0 0 1-.415-.492 1.988 1.988 0 0 1-.94.31z\"}}]})(props);\n};\nexport function BsTrashFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 1a1 1 0 0 0-1 1v1a1 1 0 0 0 1 1H3v9a2 2 0 0 0 2 2h6a2 2 0 0 0 2-2V4h.5a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H10a1 1 0 0 0-1-1H7a1 1 0 0 0-1 1H2.5zm3 4a.5.5 0 0 1 .5.5v7a.5.5 0 0 1-1 0v-7a.5.5 0 0 1 .5-.5zM8 5a.5.5 0 0 1 .5.5v7a.5.5 0 0 1-1 0v-7A.5.5 0 0 1 8 5zm3 .5v7a.5.5 0 0 1-1 0v-7a.5.5 0 0 1 1 0z\"}}]})(props);\n};\nexport function BsTrash (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.5 5.5A.5.5 0 0 1 6 6v6a.5.5 0 0 1-1 0V6a.5.5 0 0 1 .5-.5zm2.5 0a.5.5 0 0 1 .5.5v6a.5.5 0 0 1-1 0V6a.5.5 0 0 1 .5-.5zm3 .5a.5.5 0 0 0-1 0v6a.5.5 0 0 0 1 0V6z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M14.5 3a1 1 0 0 1-1 1H13v9a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V4h-.5a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1H6a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1h3.5a1 1 0 0 1 1 1v1zM4.118 4 4 4.059V13a1 1 0 0 0 1 1h6a1 1 0 0 0 1-1V4.059L11.882 4H4.118zM2.5 3V2h11v1h-11z\"}}]})(props);\n};\nexport function BsTrash2Fill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.037 3.225A.703.703 0 0 1 2 3c0-1.105 2.686-2 6-2s6 .895 6 2a.702.702 0 0 1-.037.225l-1.684 10.104A2 2 0 0 1 10.305 15H5.694a2 2 0 0 1-1.973-1.671L2.037 3.225zm9.89-.69C10.966 2.214 9.578 2 8 2c-1.58 0-2.968.215-3.926.534-.477.16-.795.327-.975.466.18.14.498.307.975.466C5.032 3.786 6.42 4 8 4s2.967-.215 3.926-.534c.477-.16.795-.327.975-.466-.18-.14-.498-.307-.975-.466z\"}}]})(props);\n};\nexport function BsTrash2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 3a.702.702 0 0 1-.037.225l-1.684 10.104A2 2 0 0 1 10.305 15H5.694a2 2 0 0 1-1.973-1.671L2.037 3.225A.703.703 0 0 1 2 3c0-1.105 2.686-2 6-2s6 .895 6 2zM3.215 4.207l1.493 8.957a1 1 0 0 0 .986.836h4.612a1 1 0 0 0 .986-.836l1.493-8.957C11.69 4.689 9.954 5 8 5c-1.954 0-3.69-.311-4.785-.793z\"}}]})(props);\n};\nexport function BsTreeFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.416.223a.5.5 0 0 0-.832 0l-3 4.5A.5.5 0 0 0 5 5.5h.098L3.076 8.735A.5.5 0 0 0 3.5 9.5h.191l-1.638 3.276a.5.5 0 0 0 .447.724H7V16h2v-2.5h4.5a.5.5 0 0 0 .447-.724L12.31 9.5h.191a.5.5 0 0 0 .424-.765L10.902 5.5H11a.5.5 0 0 0 .416-.777l-3-4.5z\"}}]})(props);\n};\nexport function BsTree (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.416.223a.5.5 0 0 0-.832 0l-3 4.5A.5.5 0 0 0 5 5.5h.098L3.076 8.735A.5.5 0 0 0 3.5 9.5h.191l-1.638 3.276a.5.5 0 0 0 .447.724H7V16h2v-2.5h4.5a.5.5 0 0 0 .447-.724L12.31 9.5h.191a.5.5 0 0 0 .424-.765L10.902 5.5H11a.5.5 0 0 0 .416-.777l-3-4.5zM6.437 4.758A.5.5 0 0 0 6 4.5h-.066L8 1.401 10.066 4.5H10a.5.5 0 0 0-.424.765L11.598 8.5H11.5a.5.5 0 0 0-.447.724L12.69 12.5H3.309l1.638-3.276A.5.5 0 0 0 4.5 8.5h-.098l2.022-3.235a.5.5 0 0 0 .013-.507z\"}}]})(props);\n};\nexport function BsTriangleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M7.022 1.566a1.13 1.13 0 0 1 1.96 0l6.857 11.667c.457.778-.092 1.767-.98 1.767H1.144c-.889 0-1.437-.99-.98-1.767L7.022 1.566z\"}}]})(props);\n};\nexport function BsTriangleHalf (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.065 2.016A.13.13 0 0 0 8.002 2v11.983l6.856.017a.12.12 0 0 0 .066-.017.162.162 0 0 0 .054-.06.176.176 0 0 0-.002-.183L8.12 2.073a.146.146 0 0 0-.054-.057zm-1.043-.45a1.13 1.13 0 0 1 1.96 0l6.856 11.667c.458.778-.091 1.767-.98 1.767H1.146c-.889 0-1.437-.99-.98-1.767L7.022 1.566z\"}}]})(props);\n};\nexport function BsTriangle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.938 2.016A.13.13 0 0 1 8.002 2a.13.13 0 0 1 .063.016.146.146 0 0 1 .054.057l6.857 11.667c.036.06.035.124.002.183a.163.163 0 0 1-.054.06.116.116 0 0 1-.066.017H1.146a.115.115 0 0 1-.066-.017.163.163 0 0 1-.054-.06.176.176 0 0 1 .002-.183L7.884 2.073a.147.147 0 0 1 .054-.057zm1.044-.45a1.13 1.13 0 0 0-1.96 0L.165 13.233c-.457.778.091 1.767.98 1.767h13.713c.889 0 1.438-.99.98-1.767L8.982 1.566z\"}}]})(props);\n};\nexport function BsTrophyFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5.5A.5.5 0 0 1 3 0h10a.5.5 0 0 1 .5.5c0 .538-.012 1.05-.034 1.536a3 3 0 1 1-1.133 5.89c-.79 1.865-1.878 2.777-2.833 3.011v2.173l1.425.356c.194.048.377.135.537.255L13.3 15.1a.5.5 0 0 1-.3.9H3a.5.5 0 0 1-.3-.9l1.838-1.379c.16-.12.343-.207.537-.255L6.5 13.11v-2.173c-.955-.234-2.043-1.146-2.833-3.012a3 3 0 1 1-1.132-5.89A33.076 33.076 0 0 1 2.5.5zm.099 2.54a2 2 0 0 0 .72 3.935c-.333-1.05-.588-2.346-.72-3.935zm10.083 3.935a2 2 0 0 0 .72-3.935c-.133 1.59-.388 2.885-.72 3.935z\"}}]})(props);\n};\nexport function BsTrophy (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5.5A.5.5 0 0 1 3 0h10a.5.5 0 0 1 .5.5c0 .538-.012 1.05-.034 1.536a3 3 0 1 1-1.133 5.89c-.79 1.865-1.878 2.777-2.833 3.011v2.173l1.425.356c.194.048.377.135.537.255L13.3 15.1a.5.5 0 0 1-.3.9H3a.5.5 0 0 1-.3-.9l1.838-1.379c.16-.12.343-.207.537-.255L6.5 13.11v-2.173c-.955-.234-2.043-1.146-2.833-3.012a3 3 0 1 1-1.132-5.89A33.076 33.076 0 0 1 2.5.5zm.099 2.54a2 2 0 0 0 .72 3.935c-.333-1.05-.588-2.346-.72-3.935zm10.083 3.935a2 2 0 0 0 .72-3.935c-.133 1.59-.388 2.885-.72 3.935zM3.504 1c.007.517.026 1.006.056 1.469.13 2.028.457 3.546.87 4.667C5.294 9.48 6.484 10 7 10a.5.5 0 0 1 .5.5v2.61a1 1 0 0 1-.757.97l-1.426.356a.5.5 0 0 0-.179.085L4.5 15h7l-.638-.479a.501.501 0 0 0-.18-.085l-1.425-.356a1 1 0 0 1-.757-.97V10.5A.5.5 0 0 1 9 10c.516 0 1.706-.52 2.57-2.864.413-1.12.74-2.64.87-4.667.03-.463.049-.952.056-1.469H3.504z\"}}]})(props);\n};\nexport function BsTropicalStorm (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 9.5a2 2 0 1 0 0-4 2 2 0 0 0 0 4z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9.5 2c-.9 0-1.75.216-2.501.6A5 5 0 0 1 13 7.5a6.5 6.5 0 1 1-13 0 .5.5 0 0 1 1 0 5.5 5.5 0 0 0 8.001 4.9A5 5 0 0 1 3 7.5a6.5 6.5 0 0 1 13 0 .5.5 0 0 1-1 0A5.5 5.5 0 0 0 9.5 2zM8 3.5a4 4 0 1 0 0 8 4 4 0 0 0 0-8z\"}}]})(props);\n};\nexport function BsTruckFlatbed (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.5 4a.5.5 0 0 1 .5.5V5h1.02a1.5 1.5 0 0 1 1.17.563l1.481 1.85a1.5 1.5 0 0 1 .329.938V10.5a1.5 1.5 0 0 1-1.5 1.5H14a2 2 0 1 1-4 0H5a2 2 0 1 1-4 0 1 1 0 0 1-1-1v-1h11V4.5a.5.5 0 0 1 .5-.5zM3 11a1 1 0 1 0 0 2 1 1 0 0 0 0-2zm9 0a1 1 0 1 0 0 2 1 1 0 0 0 0-2zm1.732 0h.768a.5.5 0 0 0 .5-.5V8.35a.5.5 0 0 0-.11-.312l-1.48-1.85A.5.5 0 0 0 13.02 6H12v4a2 2 0 0 1 1.732 1z\"}}]})(props);\n};\nexport function BsTruck (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 3.5A1.5 1.5 0 0 1 1.5 2h9A1.5 1.5 0 0 1 12 3.5V5h1.02a1.5 1.5 0 0 1 1.17.563l1.481 1.85a1.5 1.5 0 0 1 .329.938V10.5a1.5 1.5 0 0 1-1.5 1.5H14a2 2 0 1 1-4 0H5a2 2 0 1 1-3.998-.085A1.5 1.5 0 0 1 0 10.5v-7zm1.294 7.456A1.999 1.999 0 0 1 4.732 11h5.536a2.01 2.01 0 0 1 .732-.732V3.5a.5.5 0 0 0-.5-.5h-9a.5.5 0 0 0-.5.5v7a.5.5 0 0 0 .294.456zM12 10a2 2 0 0 1 1.732 1h.768a.5.5 0 0 0 .5-.5V8.35a.5.5 0 0 0-.11-.312l-1.48-1.85A.5.5 0 0 0 13.02 6H12v4zm-9 1a1 1 0 1 0 0 2 1 1 0 0 0 0-2zm9 0a1 1 0 1 0 0 2 1 1 0 0 0 0-2z\"}}]})(props);\n};\nexport function BsTsunami (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.036 12.314a.5.5 0 0 1 .65-.278l1.757.703a1.5 1.5 0 0 0 1.114 0l1.014-.406a2.5 2.5 0 0 1 1.857 0l1.015.406a1.5 1.5 0 0 0 1.114 0l1.014-.406a2.5 2.5 0 0 1 1.857 0l1.015.406a1.5 1.5 0 0 0 1.114 0l1.757-.703a.5.5 0 1 1 .372.928l-1.758.703a2.5 2.5 0 0 1-1.857 0l-1.014-.406a1.5 1.5 0 0 0-1.114 0l-1.015.406a2.5 2.5 0 0 1-1.857 0l-1.014-.406a1.5 1.5 0 0 0-1.114 0l-1.015.406a2.5 2.5 0 0 1-1.857 0l-1.757-.703a.5.5 0 0 1-.278-.65zm0 2a.5.5 0 0 1 .65-.278l1.757.703a1.5 1.5 0 0 0 1.114 0l1.014-.406a2.5 2.5 0 0 1 1.857 0l1.015.406a1.5 1.5 0 0 0 1.114 0l1.014-.406a2.5 2.5 0 0 1 1.857 0l1.015.406a1.5 1.5 0 0 0 1.114 0l1.757-.703a.5.5 0 1 1 .372.928l-1.758.703a2.5 2.5 0 0 1-1.857 0l-1.014-.406a1.5 1.5 0 0 0-1.114 0l-1.015.406a2.5 2.5 0 0 1-1.857 0l-1.014-.406a1.5 1.5 0 0 0-1.114 0l-1.015.406a2.5 2.5 0 0 1-1.857 0l-1.757-.703a.5.5 0 0 1-.278-.65zM2.662 8.08c-.456 1.063-.994 2.098-1.842 2.804a.5.5 0 0 1-.64-.768c.652-.544 1.114-1.384 1.564-2.43.14-.328.281-.68.427-1.044.302-.754.624-1.559 1.01-2.308C3.763 3.2 4.528 2.105 5.7 1.299 6.877.49 8.418 0 10.5 0c1.463 0 2.511.4 3.179 1.058.67.66.893 1.518.819 2.302-.074.771-.441 1.516-1.02 1.965a1.878 1.878 0 0 1-1.904.27c-.65.642-.907 1.679-.71 2.614C11.076 9.215 11.784 10 13 10h2.5a.5.5 0 0 1 0 1H13c-1.784 0-2.826-1.215-3.114-2.585-.232-1.1.005-2.373.758-3.284L10.5 5.06l-.777.388a.5.5 0 0 1-.447 0l-1-.5a.5.5 0 0 1 .447-.894l.777.388.776-.388a.5.5 0 0 1 .447 0l1 .5a.493.493 0 0 1 .034.018c.44.264.81.195 1.108-.036.328-.255.586-.729.637-1.27.05-.529-.1-1.076-.525-1.495-.426-.42-1.19-.77-2.477-.77-1.918 0-3.252.448-4.232 1.123C5.283 2.8 4.61 3.738 4.07 4.79c-.365.71-.655 1.433-.945 2.16-.15.376-.301.753-.463 1.13z\"}}]})(props);\n};\nexport function BsTvFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 13.5A.5.5 0 0 1 3 13h10a.5.5 0 0 1 0 1H3a.5.5 0 0 1-.5-.5zM2 2h12s2 0 2 2v6s0 2-2 2H2s-2 0-2-2V4s0-2 2-2z\"}}]})(props);\n};\nexport function BsTv (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 13.5A.5.5 0 0 1 3 13h10a.5.5 0 0 1 0 1H3a.5.5 0 0 1-.5-.5zM13.991 3l.024.001a1.46 1.46 0 0 1 .538.143.757.757 0 0 1 .302.254c.067.1.145.277.145.602v5.991l-.001.024a1.464 1.464 0 0 1-.143.538.758.758 0 0 1-.254.302c-.1.067-.277.145-.602.145H2.009l-.024-.001a1.464 1.464 0 0 1-.538-.143.758.758 0 0 1-.302-.254C1.078 10.502 1 10.325 1 10V4.009l.001-.024a1.46 1.46 0 0 1 .143-.538.758.758 0 0 1 .254-.302C1.498 3.078 1.675 3 2 3h11.991zM14 2H2C0 2 0 4 0 4v6c0 2 2 2 2 2h12c2 0 2-2 2-2V4c0-2-2-2-2-2z\"}}]})(props);\n};\nexport function BsTwitch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.857 0 1 2.857v10.286h3.429V16l2.857-2.857H9.57L14.714 8V0H3.857zm9.714 7.429-2.285 2.285H9l-2 2v-2H4.429V1.143h9.142v6.286z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M11.857 3.143h-1.143V6.57h1.143V3.143zm-3.143 0H7.571V6.57h1.143V3.143z\"}}]})(props);\n};\nexport function BsTwitter (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.026 15c6.038 0 9.341-5.003 9.341-9.334 0-.14 0-.282-.006-.422A6.685 6.685 0 0 0 16 3.542a6.658 6.658 0 0 1-1.889.518 3.301 3.301 0 0 0 1.447-1.817 6.533 6.533 0 0 1-2.087.793A3.286 3.286 0 0 0 7.875 6.03a9.325 9.325 0 0 1-6.767-3.429 3.289 3.289 0 0 0 1.018 4.382A3.323 3.323 0 0 1 .64 6.575v.045a3.288 3.288 0 0 0 2.632 3.218 3.203 3.203 0 0 1-.865.115 3.23 3.23 0 0 1-.614-.057 3.283 3.283 0 0 0 3.067 2.277A6.588 6.588 0 0 1 .78 13.58a6.32 6.32 0 0 1-.78-.045A9.344 9.344 0 0 0 5.026 15z\"}}]})(props);\n};\nexport function BsTypeBold (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.21 13c2.106 0 3.412-1.087 3.412-2.823 0-1.306-.984-2.283-2.324-2.386v-.055a2.176 2.176 0 0 0 1.852-2.14c0-1.51-1.162-2.46-3.014-2.46H3.843V13H8.21zM5.908 4.674h1.696c.963 0 1.517.451 1.517 1.244 0 .834-.629 1.32-1.73 1.32H5.908V4.673zm0 6.788V8.598h1.73c1.217 0 1.88.492 1.88 1.415 0 .943-.643 1.449-1.832 1.449H5.907z\"}}]})(props);\n};\nexport function BsTypeH1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.637 13V3.669H7.379V7.62H2.758V3.67H1.5V13h1.258V8.728h4.62V13h1.259zm5.329 0V3.669h-1.244L10.5 5.316v1.265l2.16-1.565h.062V13h1.244z\"}}]})(props);\n};\nexport function BsTypeH2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.638 13V3.669H6.38V7.62H1.759V3.67H.5V13h1.258V8.728h4.62V13h1.259zm3.022-6.733v-.048c0-.889.63-1.668 1.716-1.668.957 0 1.675.608 1.675 1.572 0 .855-.554 1.504-1.067 2.085l-3.513 3.999V13H15.5v-1.094h-4.245v-.075l2.481-2.844c.875-.998 1.586-1.784 1.586-2.953 0-1.463-1.155-2.556-2.919-2.556-1.941 0-2.966 1.326-2.966 2.74v.049h1.223z\"}}]})(props);\n};\nexport function BsTypeH3 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.637 13V3.669H6.379V7.62H1.758V3.67H.5V13h1.258V8.728h4.62V13h1.259zm3.625-4.272h1.018c1.142 0 1.935.67 1.949 1.674.013 1.005-.78 1.737-2.01 1.73-1.08-.007-1.853-.588-1.935-1.32H9.108c.069 1.327 1.224 2.386 3.083 2.386 1.935 0 3.343-1.155 3.309-2.789-.027-1.51-1.251-2.16-2.037-2.249v-.068c.704-.123 1.764-.91 1.723-2.229-.035-1.353-1.176-2.4-2.954-2.385-1.873.006-2.857 1.162-2.898 2.358h1.196c.062-.69.711-1.299 1.696-1.299.998 0 1.695.622 1.695 1.525.007.922-.718 1.592-1.695 1.592h-.964v1.074z\"}}]})(props);\n};\nexport function BsTypeItalic (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.991 11.674 9.53 4.455c.123-.595.246-.71 1.347-.807l.11-.52H7.211l-.11.52c1.06.096 1.128.212 1.005.807L6.57 11.674c-.123.595-.246.71-1.346.806l-.11.52h3.774l.11-.52c-1.06-.095-1.129-.211-1.006-.806z\"}}]})(props);\n};\nexport function BsTypeStrikethrough (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.333 5.686c0 .31.083.581.27.814H5.166a2.776 2.776 0 0 1-.099-.76c0-1.627 1.436-2.768 3.48-2.768 1.969 0 3.39 1.175 3.445 2.85h-1.23c-.11-1.08-.964-1.743-2.25-1.743-1.23 0-2.18.602-2.18 1.607zm2.194 7.478c-2.153 0-3.589-1.107-3.705-2.81h1.23c.144 1.06 1.129 1.703 2.544 1.703 1.34 0 2.31-.705 2.31-1.675 0-.827-.547-1.374-1.914-1.675L8.046 8.5H1v-1h14v1h-3.504c.468.437.675.994.675 1.697 0 1.826-1.436 2.967-3.644 2.967z\"}}]})(props);\n};\nexport function BsTypeUnderline (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M5.313 3.136h-1.23V9.54c0 2.105 1.47 3.623 3.917 3.623s3.917-1.518 3.917-3.623V3.136h-1.23v6.323c0 1.49-.978 2.57-2.687 2.57-1.709 0-2.687-1.08-2.687-2.57V3.136zM12.5 15h-9v-1h9v1z\"}}]})(props);\n};\nexport function BsType (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"m2.244 13.081.943-2.803H6.66l.944 2.803H8.86L5.54 3.75H4.322L1 13.081h1.244zm2.7-7.923L6.34 9.314H3.51l1.4-4.156h.034zm9.146 7.027h.035v.896h1.128V8.125c0-1.51-1.114-2.345-2.646-2.345-1.736 0-2.59.916-2.666 2.174h1.108c.068-.718.595-1.19 1.517-1.19.971 0 1.518.52 1.518 1.464v.731H12.19c-1.647.007-2.522.8-2.522 2.058 0 1.319.957 2.18 2.345 2.18 1.06 0 1.716-.43 2.078-1.011zm-1.763.035c-.752 0-1.456-.397-1.456-1.244 0-.65.424-1.115 1.408-1.115h1.805v.834c0 .896-.752 1.525-1.757 1.525z\"}}]})(props);\n};\nexport function BsUiChecksGrid (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 10h3a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1v-3a1 1 0 0 1 1-1zm9-9h3a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1h-3a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1zm0 9a1 1 0 0 0-1 1v3a1 1 0 0 0 1 1h3a1 1 0 0 0 1-1v-3a1 1 0 0 0-1-1h-3zm0-10a2 2 0 0 0-2 2v3a2 2 0 0 0 2 2h3a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2h-3zM2 9a2 2 0 0 0-2 2v3a2 2 0 0 0 2 2h3a2 2 0 0 0 2-2v-3a2 2 0 0 0-2-2H2zm7 2a2 2 0 0 1 2-2h3a2 2 0 0 1 2 2v3a2 2 0 0 1-2 2h-3a2 2 0 0 1-2-2v-3zM0 2a2 2 0 0 1 2-2h3a2 2 0 0 1 2 2v3a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2zm5.354.854a.5.5 0 1 0-.708-.708L3 3.793l-.646-.647a.5.5 0 1 0-.708.708l1 1a.5.5 0 0 0 .708 0l2-2z\"}}]})(props);\n};\nexport function BsUiChecks (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 2.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-7a.5.5 0 0 1-.5-.5v-1zM2 1a2 2 0 0 0-2 2v2a2 2 0 0 0 2 2h2a2 2 0 0 0 2-2V3a2 2 0 0 0-2-2H2zm0 8a2 2 0 0 0-2 2v2a2 2 0 0 0 2 2h2a2 2 0 0 0 2-2v-2a2 2 0 0 0-2-2H2zm.854-3.646a.5.5 0 0 1-.708 0l-1-1a.5.5 0 1 1 .708-.708l.646.647 1.646-1.647a.5.5 0 1 1 .708.708l-2 2zm0 8a.5.5 0 0 1-.708 0l-1-1a.5.5 0 0 1 .708-.708l.646.647 1.646-1.647a.5.5 0 0 1 .708.708l-2 2zM7 10.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-7a.5.5 0 0 1-.5-.5v-1zm0-5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm0 8a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsUiRadiosGrid (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3.5 15a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5zm9-9a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5zm0 9a2.5 2.5 0 1 1 0-5 2.5 2.5 0 0 1 0 5zM16 3.5a3.5 3.5 0 1 1-7 0 3.5 3.5 0 0 1 7 0zm-9 9a3.5 3.5 0 1 1-7 0 3.5 3.5 0 0 1 7 0zm5.5 3.5a3.5 3.5 0 1 0 0-7 3.5 3.5 0 0 0 0 7zm-9-11a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm0 2a3.5 3.5 0 1 0 0-7 3.5 3.5 0 0 0 0 7z\"}}]})(props);\n};\nexport function BsUiRadios (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 2.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-7a.5.5 0 0 1-.5-.5v-1zM0 12a3 3 0 1 1 6 0 3 3 0 0 1-6 0zm7-1.5a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-7a.5.5 0 0 1-.5-.5v-1zm0-5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zm0 8a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5zM3 1a3 3 0 1 0 0 6 3 3 0 0 0 0-6zm0 4.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z\"}}]})(props);\n};\nexport function BsUmbrellaFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M8 0a.5.5 0 0 1 .5.5v.514C12.625 1.238 16 4.22 16 8c0 0 0 .5-.5.5-.149 0-.352-.145-.352-.145l-.004-.004-.025-.023a3.484 3.484 0 0 0-.555-.394A3.166 3.166 0 0 0 13 7.5c-.638 0-1.178.213-1.564.434a3.484 3.484 0 0 0-.555.394l-.025.023-.003.003s-.204.146-.353.146-.352-.145-.352-.145l-.004-.004-.025-.023a3.484 3.484 0 0 0-.555-.394 3.3 3.3 0 0 0-1.064-.39V13.5H8h.5v.039l-.005.083a2.958 2.958 0 0 1-.298 1.102 2.257 2.257 0 0 1-.763.88C7.06 15.851 6.587 16 6 16s-1.061-.148-1.434-.396a2.255 2.255 0 0 1-.763-.88 2.958 2.958 0 0 1-.302-1.185v-.025l-.001-.009v-.003s0-.002.5-.002h-.5V13a.5.5 0 0 1 1 0v.506l.003.044a1.958 1.958 0 0 0 .195.726c.095.191.23.367.423.495.19.127.466.229.879.229s.689-.102.879-.229c.193-.128.328-.304.424-.495a1.958 1.958 0 0 0 .197-.77V7.544a3.3 3.3 0 0 0-1.064.39 3.482 3.482 0 0 0-.58.417l-.004.004S5.65 8.5 5.5 8.5c-.149 0-.352-.145-.352-.145l-.004-.004a3.482 3.482 0 0 0-.58-.417A3.166 3.166 0 0 0 3 7.5c-.638 0-1.177.213-1.564.434a3.482 3.482 0 0 0-.58.417l-.004.004S.65 8.5.5 8.5C0 8.5 0 8 0 8c0-3.78 3.375-6.762 7.5-6.986V.5A.5.5 0 0 1 8 0z\"}}]})(props);\n};\nexport function BsUmbrella (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 0a.5.5 0 0 1 .5.5v.514C12.625 1.238 16 4.22 16 8c0 0 0 .5-.5.5-.149 0-.352-.145-.352-.145l-.004-.004-.025-.023a3.484 3.484 0 0 0-.555-.394A3.166 3.166 0 0 0 13 7.5c-.638 0-1.178.213-1.564.434a3.484 3.484 0 0 0-.555.394l-.025.023-.003.003s-.204.146-.353.146-.352-.145-.352-.145l-.004-.004-.025-.023a3.484 3.484 0 0 0-.555-.394 3.3 3.3 0 0 0-1.064-.39V13.5H8h.5v.039l-.005.083a2.958 2.958 0 0 1-.298 1.102 2.257 2.257 0 0 1-.763.88C7.06 15.851 6.587 16 6 16s-1.061-.148-1.434-.396a2.255 2.255 0 0 1-.763-.88 2.958 2.958 0 0 1-.302-1.185v-.025l-.001-.009v-.003s0-.002.5-.002h-.5V13a.5.5 0 0 1 1 0v.506l.003.044a1.958 1.958 0 0 0 .195.726c.095.191.23.367.423.495.19.127.466.229.879.229s.689-.102.879-.229c.193-.128.328-.304.424-.495a1.958 1.958 0 0 0 .197-.77V7.544a3.3 3.3 0 0 0-1.064.39 3.482 3.482 0 0 0-.58.417l-.004.004S5.65 8.5 5.5 8.5c-.149 0-.352-.145-.352-.145l-.004-.004a3.482 3.482 0 0 0-.58-.417A3.166 3.166 0 0 0 3 7.5c-.638 0-1.177.213-1.564.434a3.482 3.482 0 0 0-.58.417l-.004.004S.65 8.5.5 8.5C0 8.5 0 8 0 8c0-3.78 3.375-6.762 7.5-6.986V.5A.5.5 0 0 1 8 0zM6.577 2.123c-2.833.5-4.99 2.458-5.474 4.854A4.124 4.124 0 0 1 3 6.5c.806 0 1.48.25 1.962.511a9.706 9.706 0 0 1 .344-2.358c.242-.868.64-1.765 1.271-2.53zm-.615 4.93A4.16 4.16 0 0 1 8 6.5a4.16 4.16 0 0 1 2.038.553 8.688 8.688 0 0 0-.307-2.13C9.434 3.858 8.898 2.83 8 2.117c-.898.712-1.434 1.74-1.731 2.804a8.687 8.687 0 0 0-.307 2.131zm3.46-4.93c.631.765 1.03 1.662 1.272 2.53.233.833.328 1.66.344 2.358A4.14 4.14 0 0 1 13 6.5c.77 0 1.42.23 1.897.477-.484-2.396-2.641-4.355-5.474-4.854z\"}}]})(props);\n};\nexport function BsUnion (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v2h2a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2v-2H2a2 2 0 0 1-2-2V2z\"}}]})(props);\n};\nexport function BsUnlockFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 1a2 2 0 0 0-2 2v4a2 2 0 0 1 2 2v5a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V9a2 2 0 0 1 2-2h5V3a3 3 0 0 1 6 0v4a.5.5 0 0 1-1 0V3a2 2 0 0 0-2-2z\"}}]})(props);\n};\nexport function BsUnlock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11 1a2 2 0 0 0-2 2v4a2 2 0 0 1 2 2v5a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V9a2 2 0 0 1 2-2h5V3a3 3 0 0 1 6 0v4a.5.5 0 0 1-1 0V3a2 2 0 0 0-2-2zM3 8a1 1 0 0 0-1 1v5a1 1 0 0 0 1 1h6a1 1 0 0 0 1-1V9a1 1 0 0 0-1-1H3z\"}}]})(props);\n};\nexport function BsUpcScan (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 1a.5.5 0 0 0-.5.5v3a.5.5 0 0 1-1 0v-3A1.5 1.5 0 0 1 1.5 0h3a.5.5 0 0 1 0 1h-3zM11 .5a.5.5 0 0 1 .5-.5h3A1.5 1.5 0 0 1 16 1.5v3a.5.5 0 0 1-1 0v-3a.5.5 0 0 0-.5-.5h-3a.5.5 0 0 1-.5-.5zM.5 11a.5.5 0 0 1 .5.5v3a.5.5 0 0 0 .5.5h3a.5.5 0 0 1 0 1h-3A1.5 1.5 0 0 1 0 14.5v-3a.5.5 0 0 1 .5-.5zm15 0a.5.5 0 0 1 .5.5v3a1.5 1.5 0 0 1-1.5 1.5h-3a.5.5 0 0 1 0-1h3a.5.5 0 0 0 .5-.5v-3a.5.5 0 0 1 .5-.5zM3 4.5a.5.5 0 0 1 1 0v7a.5.5 0 0 1-1 0v-7zm2 0a.5.5 0 0 1 1 0v7a.5.5 0 0 1-1 0v-7zm2 0a.5.5 0 0 1 1 0v7a.5.5 0 0 1-1 0v-7zm2 0a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v7a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-7zm3 0a.5.5 0 0 1 1 0v7a.5.5 0 0 1-1 0v-7z\"}}]})(props);\n};\nexport function BsUpc (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 4.5a.5.5 0 0 1 1 0v7a.5.5 0 0 1-1 0v-7zm2 0a.5.5 0 0 1 1 0v7a.5.5 0 0 1-1 0v-7zm2 0a.5.5 0 0 1 1 0v7a.5.5 0 0 1-1 0v-7zm2 0a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v7a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-7zm3 0a.5.5 0 0 1 1 0v7a.5.5 0 0 1-1 0v-7z\"}}]})(props);\n};\nexport function BsUpload (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.5 9.9a.5.5 0 0 1 .5.5v2.5a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2.5a.5.5 0 0 1 1 0v2.5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2v-2.5a.5.5 0 0 1 .5-.5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M7.646 1.146a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1-.708.708L8.5 2.707V11.5a.5.5 0 0 1-1 0V2.707L5.354 4.854a.5.5 0 1 1-.708-.708l3-3z\"}}]})(props);\n};\nexport function BsVectorPen (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M10.646.646a.5.5 0 0 1 .708 0l4 4a.5.5 0 0 1 0 .708l-1.902 1.902-.829 3.313a1.5 1.5 0 0 1-1.024 1.073L1.254 14.746 4.358 4.4A1.5 1.5 0 0 1 5.43 3.377l3.313-.828L10.646.646zm-1.8 2.908-3.173.793a.5.5 0 0 0-.358.342l-2.57 8.565 8.567-2.57a.5.5 0 0 0 .34-.357l.794-3.174-3.6-3.6z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M2.832 13.228 8 9a1 1 0 1 0-1-1l-4.228 5.168-.026.086.086-.026z\"}}]})(props);\n};\nexport function BsViewList (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 4.5h10a2 2 0 0 1 2 2v3a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-3a2 2 0 0 1 2-2zm0 1a1 1 0 0 0-1 1v3a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1v-3a1 1 0 0 0-1-1H3zM1 2a.5.5 0 0 1 .5-.5h13a.5.5 0 0 1 0 1h-13A.5.5 0 0 1 1 2zm0 12a.5.5 0 0 1 .5-.5h13a.5.5 0 0 1 0 1h-13A.5.5 0 0 1 1 14z\"}}]})(props);\n};\nexport function BsViewStacked (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 0h10a2 2 0 0 1 2 2v3a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2zm0 1a1 1 0 0 0-1 1v3a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1H3zm0 8h10a2 2 0 0 1 2 2v3a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2v-3a2 2 0 0 1 2-2zm0 1a1 1 0 0 0-1 1v3a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1v-3a1 1 0 0 0-1-1H3z\"}}]})(props);\n};\nexport function BsVimeo (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.992 4.204c-.071 1.556-1.158 3.687-3.262 6.393-2.175 2.829-4.016 4.243-5.522 4.243-.933 0-1.722-.861-2.367-2.583L3.55 7.523C3.07 5.8 2.556 4.94 2.007 4.94c-.118 0-.537.253-1.254.754L0 4.724a209.56 209.56 0 0 0 2.334-2.081c1.054-.91 1.845-1.388 2.373-1.437 1.243-.123 2.01.728 2.298 2.553.31 1.968.526 3.19.646 3.666.36 1.631.756 2.446 1.186 2.445.334 0 .836-.53 1.508-1.587.671-1.058 1.03-1.863 1.077-2.415.096-.913-.263-1.37-1.077-1.37a3.022 3.022 0 0 0-1.185.261c.789-2.573 2.291-3.825 4.508-3.756 1.644.05 2.419 1.117 2.324 3.2z\"}}]})(props);\n};\nexport function BsVinylFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 6a2 2 0 1 0 0 4 2 2 0 0 0 0-4zm0 3a1 1 0 1 1 0-2 1 1 0 0 1 0 2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM4 8a4 4 0 1 0 8 0 4 4 0 0 0-8 0z\"}}]})(props);\n};\nexport function BsVinyl (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8 6a2 2 0 1 0 0 4 2 2 0 0 0 0-4zM4 8a4 4 0 1 1 8 0 4 4 0 0 1-8 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M9 8a1 1 0 1 1-2 0 1 1 0 0 1 2 0z\"}}]})(props);\n};\nexport function BsVoicemail (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7 8.5A3.49 3.49 0 0 1 5.95 11h4.1a3.5 3.5 0 1 1 2.45 1h-9A3.5 3.5 0 1 1 7 8.5zm-6 0a2.5 2.5 0 1 0 5 0 2.5 2.5 0 0 0-5 0zm14 0a2.5 2.5 0 1 0-5 0 2.5 2.5 0 0 0 5 0z\"}}]})(props);\n};\nexport function BsVolumeDownFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4a.5.5 0 0 0-.812-.39L5.825 5.5H3.5A.5.5 0 0 0 3 6v4a.5.5 0 0 0 .5.5h2.325l2.363 1.89A.5.5 0 0 0 9 12V4zm3.025 4a4.486 4.486 0 0 1-1.318 3.182L10 10.475A3.489 3.489 0 0 0 11.025 8 3.49 3.49 0 0 0 10 5.525l.707-.707A4.486 4.486 0 0 1 12.025 8z\"}}]})(props);\n};\nexport function BsVolumeDown (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9 4a.5.5 0 0 0-.812-.39L5.825 5.5H3.5A.5.5 0 0 0 3 6v4a.5.5 0 0 0 .5.5h2.325l2.363 1.89A.5.5 0 0 0 9 12V4zM6.312 6.39 8 5.04v5.92L6.312 9.61A.5.5 0 0 0 6 9.5H4v-3h2a.5.5 0 0 0 .312-.11zM12.025 8a4.486 4.486 0 0 1-1.318 3.182L10 10.475A3.489 3.489 0 0 0 11.025 8 3.49 3.49 0 0 0 10 5.525l.707-.707A4.486 4.486 0 0 1 12.025 8z\"}}]})(props);\n};\nexport function BsVolumeMuteFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.717 3.55A.5.5 0 0 1 7 4v8a.5.5 0 0 1-.812.39L3.825 10.5H1.5A.5.5 0 0 1 1 10V6a.5.5 0 0 1 .5-.5h2.325l2.363-1.89a.5.5 0 0 1 .529-.06zm7.137 2.096a.5.5 0 0 1 0 .708L12.207 8l1.647 1.646a.5.5 0 0 1-.708.708L11.5 8.707l-1.646 1.647a.5.5 0 0 1-.708-.708L10.793 8 9.146 6.354a.5.5 0 1 1 .708-.708L11.5 7.293l1.646-1.647a.5.5 0 0 1 .708 0z\"}}]})(props);\n};\nexport function BsVolumeMute (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.717 3.55A.5.5 0 0 1 7 4v8a.5.5 0 0 1-.812.39L3.825 10.5H1.5A.5.5 0 0 1 1 10V6a.5.5 0 0 1 .5-.5h2.325l2.363-1.89a.5.5 0 0 1 .529-.06zM6 5.04 4.312 6.39A.5.5 0 0 1 4 6.5H2v3h2a.5.5 0 0 1 .312.11L6 10.96V5.04zm7.854.606a.5.5 0 0 1 0 .708L12.207 8l1.647 1.646a.5.5 0 0 1-.708.708L11.5 8.707l-1.646 1.647a.5.5 0 0 1-.708-.708L10.793 8 9.146 6.354a.5.5 0 1 1 .708-.708L11.5 7.293l1.646-1.647a.5.5 0 0 1 .708 0z\"}}]})(props);\n};\nexport function BsVolumeOffFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.717 3.55A.5.5 0 0 1 11 4v8a.5.5 0 0 1-.812.39L7.825 10.5H5.5A.5.5 0 0 1 5 10V6a.5.5 0 0 1 .5-.5h2.325l2.363-1.89a.5.5 0 0 1 .529-.06z\"}}]})(props);\n};\nexport function BsVolumeOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.717 3.55A.5.5 0 0 1 11 4v8a.5.5 0 0 1-.812.39L7.825 10.5H5.5A.5.5 0 0 1 5 10V6a.5.5 0 0 1 .5-.5h2.325l2.363-1.89a.5.5 0 0 1 .529-.06zM10 5.04 8.312 6.39A.5.5 0 0 1 8 6.5H6v3h2a.5.5 0 0 1 .312.11L10 10.96V5.04z\"}}]})(props);\n};\nexport function BsVolumeUpFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.536 14.01A8.473 8.473 0 0 0 14.026 8a8.473 8.473 0 0 0-2.49-6.01l-.708.707A7.476 7.476 0 0 1 13.025 8c0 2.071-.84 3.946-2.197 5.303l.708.707z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.121 12.596A6.48 6.48 0 0 0 12.025 8a6.48 6.48 0 0 0-1.904-4.596l-.707.707A5.483 5.483 0 0 1 11.025 8a5.483 5.483 0 0 1-1.61 3.89l.706.706z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M8.707 11.182A4.486 4.486 0 0 0 10.025 8a4.486 4.486 0 0 0-1.318-3.182L8 5.525A3.489 3.489 0 0 1 9.025 8 3.49 3.49 0 0 1 8 10.475l.707.707zM6.717 3.55A.5.5 0 0 1 7 4v8a.5.5 0 0 1-.812.39L3.825 10.5H1.5A.5.5 0 0 1 1 10V6a.5.5 0 0 1 .5-.5h2.325l2.363-1.89a.5.5 0 0 1 .529-.06z\"}}]})(props);\n};\nexport function BsVolumeUp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.536 14.01A8.473 8.473 0 0 0 14.026 8a8.473 8.473 0 0 0-2.49-6.01l-.708.707A7.476 7.476 0 0 1 13.025 8c0 2.071-.84 3.946-2.197 5.303l.708.707z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.121 12.596A6.48 6.48 0 0 0 12.025 8a6.48 6.48 0 0 0-1.904-4.596l-.707.707A5.483 5.483 0 0 1 11.025 8a5.483 5.483 0 0 1-1.61 3.89l.706.706z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.025 8a4.486 4.486 0 0 1-1.318 3.182L8 10.475A3.489 3.489 0 0 0 9.025 8c0-.966-.392-1.841-1.025-2.475l.707-.707A4.486 4.486 0 0 1 10.025 8zM7 4a.5.5 0 0 0-.812-.39L3.825 5.5H1.5A.5.5 0 0 0 1 6v4a.5.5 0 0 0 .5.5h2.325l2.363 1.89A.5.5 0 0 0 7 12V4zM4.312 6.39 6 5.04v5.92L4.312 9.61A.5.5 0 0 0 4 9.5H2v-3h2a.5.5 0 0 0 .312-.11z\"}}]})(props);\n};\nexport function BsVr (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M3 12V4a1 1 0 0 1 1-1h2.5V2H4a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h2.5v-1H4a1 1 0 0 1-1-1zm6.5 1v1H12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H9.5v1H12a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1H9.5zM8 16a.5.5 0 0 1-.5-.5V.5a.5.5 0 0 1 1 0v15a.5.5 0 0 1-.5.5z\"}}]})(props);\n};\nexport function BsWalletFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.5 2A1.5 1.5 0 0 0 0 3.5v2h6a.5.5 0 0 1 .5.5c0 .253.08.644.306.958.207.288.557.542 1.194.542.637 0 .987-.254 1.194-.542.226-.314.306-.705.306-.958a.5.5 0 0 1 .5-.5h6v-2A1.5 1.5 0 0 0 14.5 2h-13z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M16 6.5h-5.551a2.678 2.678 0 0 1-.443 1.042C9.613 8.088 8.963 8.5 8 8.5c-.963 0-1.613-.412-2.006-.958A2.679 2.679 0 0 1 5.551 6.5H0v6A1.5 1.5 0 0 0 1.5 14h13a1.5 1.5 0 0 0 1.5-1.5v-6z\"}}]})(props);\n};\nexport function BsWallet (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M0 3a2 2 0 0 1 2-2h13.5a.5.5 0 0 1 0 1H15v2a1 1 0 0 1 1 1v8.5a1.5 1.5 0 0 1-1.5 1.5h-12A2.5 2.5 0 0 1 0 12.5V3zm1 1.732V12.5A1.5 1.5 0 0 0 2.5 14h12a.5.5 0 0 0 .5-.5V5H2a1.99 1.99 0 0 1-1-.268zM1 3a1 1 0 0 0 1 1h12V2H2a1 1 0 0 0-1 1z\"}}]})(props);\n};\nexport function BsWallet2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.136.326A1.5 1.5 0 0 1 14 1.78V3h.5A1.5 1.5 0 0 1 16 4.5v9a1.5 1.5 0 0 1-1.5 1.5h-13A1.5 1.5 0 0 1 0 13.5v-9a1.5 1.5 0 0 1 1.432-1.499L12.136.326zM5.562 3H13V1.78a.5.5 0 0 0-.621-.484L5.562 3zM1.5 4a.5.5 0 0 0-.5.5v9a.5.5 0 0 0 .5.5h13a.5.5 0 0 0 .5-.5v-9a.5.5 0 0 0-.5-.5h-13z\"}}]})(props);\n};\nexport function BsWatch (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.5 5a.5.5 0 0 0-1 0v2.5H6a.5.5 0 0 0 0 1h2a.5.5 0 0 0 .5-.5V5z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M5.667 16C4.747 16 4 15.254 4 14.333v-1.86A5.985 5.985 0 0 1 2 8c0-1.777.772-3.374 2-4.472V1.667C4 .747 4.746 0 5.667 0h4.666C11.253 0 12 .746 12 1.667v1.86a5.99 5.99 0 0 1 1.918 3.48.502.502 0 0 1 .582.493v1a.5.5 0 0 1-.582.493A5.99 5.99 0 0 1 12 12.473v1.86c0 .92-.746 1.667-1.667 1.667H5.667zM13 8A5 5 0 1 0 3 8a5 5 0 0 0 10 0z\"}}]})(props);\n};\nexport function BsWater (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.036 3.314a.5.5 0 0 1 .65-.278l1.757.703a1.5 1.5 0 0 0 1.114 0l1.014-.406a2.5 2.5 0 0 1 1.857 0l1.015.406a1.5 1.5 0 0 0 1.114 0l1.014-.406a2.5 2.5 0 0 1 1.857 0l1.015.406a1.5 1.5 0 0 0 1.114 0l1.757-.703a.5.5 0 1 1 .372.928l-1.758.703a2.5 2.5 0 0 1-1.857 0l-1.014-.406a1.5 1.5 0 0 0-1.114 0l-1.015.406a2.5 2.5 0 0 1-1.857 0l-1.014-.406a1.5 1.5 0 0 0-1.114 0l-1.015.406a2.5 2.5 0 0 1-1.857 0L.314 3.964a.5.5 0 0 1-.278-.65zm0 3a.5.5 0 0 1 .65-.278l1.757.703a1.5 1.5 0 0 0 1.114 0l1.014-.406a2.5 2.5 0 0 1 1.857 0l1.015.406a1.5 1.5 0 0 0 1.114 0l1.014-.406a2.5 2.5 0 0 1 1.857 0l1.015.406a1.5 1.5 0 0 0 1.114 0l1.757-.703a.5.5 0 1 1 .372.928l-1.758.703a2.5 2.5 0 0 1-1.857 0l-1.014-.406a1.5 1.5 0 0 0-1.114 0l-1.015.406a2.5 2.5 0 0 1-1.857 0l-1.014-.406a1.5 1.5 0 0 0-1.114 0l-1.015.406a2.5 2.5 0 0 1-1.857 0L.314 6.964a.5.5 0 0 1-.278-.65zm0 3a.5.5 0 0 1 .65-.278l1.757.703a1.5 1.5 0 0 0 1.114 0l1.014-.406a2.5 2.5 0 0 1 1.857 0l1.015.406a1.5 1.5 0 0 0 1.114 0l1.014-.406a2.5 2.5 0 0 1 1.857 0l1.015.406a1.5 1.5 0 0 0 1.114 0l1.757-.703a.5.5 0 1 1 .372.928l-1.758.703a2.5 2.5 0 0 1-1.857 0l-1.014-.406a1.5 1.5 0 0 0-1.114 0l-1.015.406a2.5 2.5 0 0 1-1.857 0l-1.014-.406a1.5 1.5 0 0 0-1.114 0l-1.015.406a2.5 2.5 0 0 1-1.857 0L.314 9.964a.5.5 0 0 1-.278-.65zm0 3a.5.5 0 0 1 .65-.278l1.757.703a1.5 1.5 0 0 0 1.114 0l1.014-.406a2.5 2.5 0 0 1 1.857 0l1.015.406a1.5 1.5 0 0 0 1.114 0l1.014-.406a2.5 2.5 0 0 1 1.857 0l1.015.406a1.5 1.5 0 0 0 1.114 0l1.757-.703a.5.5 0 1 1 .372.928l-1.758.703a2.5 2.5 0 0 1-1.857 0l-1.014-.406a1.5 1.5 0 0 0-1.114 0l-1.015.406a2.5 2.5 0 0 1-1.857 0l-1.014-.406a1.5 1.5 0 0 0-1.114 0l-1.015.406a2.5 2.5 0 0 1-1.857 0l-1.757-.703a.5.5 0 0 1-.278-.65z\"}}]})(props);\n};\nexport function BsWhatsapp (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.601 2.326A7.854 7.854 0 0 0 7.994 0C3.627 0 .068 3.558.064 7.926c0 1.399.366 2.76 1.057 3.965L0 16l4.204-1.102a7.933 7.933 0 0 0 3.79.965h.004c4.368 0 7.926-3.558 7.93-7.93A7.898 7.898 0 0 0 13.6 2.326zM7.994 14.521a6.573 6.573 0 0 1-3.356-.92l-.24-.144-2.494.654.666-2.433-.156-.251a6.56 6.56 0 0 1-1.007-3.505c0-3.626 2.957-6.584 6.591-6.584a6.56 6.56 0 0 1 4.66 1.931 6.557 6.557 0 0 1 1.928 4.66c-.004 3.639-2.961 6.592-6.592 6.592zm3.615-4.934c-.197-.099-1.17-.578-1.353-.646-.182-.065-.315-.099-.445.099-.133.197-.513.646-.627.775-.114.133-.232.148-.43.05-.197-.1-.836-.308-1.592-.985-.59-.525-.985-1.175-1.103-1.372-.114-.198-.011-.304.088-.403.087-.088.197-.232.296-.346.1-.114.133-.198.198-.33.065-.134.034-.248-.015-.347-.05-.099-.445-1.076-.612-1.47-.16-.389-.323-.335-.445-.34-.114-.007-.247-.007-.38-.007a.729.729 0 0 0-.529.247c-.182.198-.691.677-.691 1.654 0 .977.71 1.916.81 2.049.098.133 1.394 2.132 3.383 2.992.47.205.84.326 1.129.418.475.152.904.129 1.246.08.38-.058 1.171-.48 1.338-.943.164-.464.164-.86.114-.943-.049-.084-.182-.133-.38-.232z\"}}]})(props);\n};\nexport function BsWifi1 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.046 10.454c.226-.226.185-.605-.1-.75A6.473 6.473 0 0 0 8 9c-1.06 0-2.062.254-2.946.704-.285.145-.326.524-.1.75l.015.015c.16.16.407.19.611.09A5.478 5.478 0 0 1 8 10c.868 0 1.69.201 2.42.56.203.1.45.07.611-.091l.015-.015zM9.06 12.44c.196-.196.198-.52-.04-.66A1.99 1.99 0 0 0 8 11.5a1.99 1.99 0 0 0-1.02.28c-.238.14-.236.464-.04.66l.706.706a.5.5 0 0 0 .707 0l.708-.707z\"}}]})(props);\n};\nexport function BsWifi2 (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M13.229 8.271c.216-.216.194-.578-.063-.745A9.456 9.456 0 0 0 8 6c-1.905 0-3.68.56-5.166 1.526a.48.48 0 0 0-.063.745.525.525 0 0 0 .652.065A8.46 8.46 0 0 1 8 7a8.46 8.46 0 0 1 4.577 1.336c.205.132.48.108.652-.065zm-2.183 2.183c.226-.226.185-.605-.1-.75A6.473 6.473 0 0 0 8 9c-1.06 0-2.062.254-2.946.704-.285.145-.326.524-.1.75l.015.015c.16.16.408.19.611.09A5.478 5.478 0 0 1 8 10c.868 0 1.69.201 2.42.56.203.1.45.07.611-.091l.015-.015zM9.06 12.44c.196-.196.198-.52-.04-.66A1.99 1.99 0 0 0 8 11.5a1.99 1.99 0 0 0-1.02.28c-.238.14-.236.464-.04.66l.706.706a.5.5 0 0 0 .708 0l.707-.707z\"}}]})(props);\n};\nexport function BsWifiOff (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M10.706 3.294A12.545 12.545 0 0 0 8 3C5.259 3 2.723 3.882.663 5.379a.485.485 0 0 0-.048.736.518.518 0 0 0 .668.05A11.448 11.448 0 0 1 8 4c.63 0 1.249.05 1.852.148l.854-.854zM8 6c-1.905 0-3.68.56-5.166 1.526a.48.48 0 0 0-.063.745.525.525 0 0 0 .652.065 8.448 8.448 0 0 1 3.51-1.27L8 6zm2.596 1.404.785-.785c.63.24 1.227.545 1.785.907a.482.482 0 0 1 .063.745.525.525 0 0 1-.652.065 8.462 8.462 0 0 0-1.98-.932zM8 10l.933-.933a6.455 6.455 0 0 1 2.013.637c.285.145.326.524.1.75l-.015.015a.532.532 0 0 1-.611.09A5.478 5.478 0 0 0 8 10zm4.905-4.905.747-.747c.59.3 1.153.645 1.685 1.03a.485.485 0 0 1 .047.737.518.518 0 0 1-.668.05 11.493 11.493 0 0 0-1.811-1.07zM9.02 11.78c.238.14.236.464.04.66l-.707.706a.5.5 0 0 1-.707 0l-.707-.707c-.195-.195-.197-.518.04-.66A1.99 1.99 0 0 1 8 11.5c.374 0 .723.102 1.021.28zm4.355-9.905a.53.53 0 0 1 .75.75l-10.75 10.75a.53.53 0 0 1-.75-.75l10.75-10.75z\"}}]})(props);\n};\nexport function BsWifi (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M15.384 6.115a.485.485 0 0 0-.047-.736A12.444 12.444 0 0 0 8 3C5.259 3 2.723 3.882.663 5.379a.485.485 0 0 0-.048.736.518.518 0 0 0 .668.05A11.448 11.448 0 0 1 8 4c2.507 0 4.827.802 6.716 2.164.205.148.49.13.668-.049z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M13.229 8.271a.482.482 0 0 0-.063-.745A9.455 9.455 0 0 0 8 6c-1.905 0-3.68.56-5.166 1.526a.48.48 0 0 0-.063.745.525.525 0 0 0 .652.065A8.46 8.46 0 0 1 8 7a8.46 8.46 0 0 1 4.576 1.336c.206.132.48.108.653-.065zm-2.183 2.183c.226-.226.185-.605-.1-.75A6.473 6.473 0 0 0 8 9c-1.06 0-2.062.254-2.946.704-.285.145-.326.524-.1.75l.015.015c.16.16.407.19.611.09A5.478 5.478 0 0 1 8 10c.868 0 1.69.201 2.42.56.203.1.45.07.61-.091l.016-.015zM9.06 12.44c.196-.196.198-.52-.04-.66A1.99 1.99 0 0 0 8 11.5a1.99 1.99 0 0 0-1.02.28c-.238.14-.236.464-.04.66l.706.706a.5.5 0 0 0 .707 0l.707-.707z\"}}]})(props);\n};\nexport function BsWind (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.5 2A2.5 2.5 0 0 0 10 4.5a.5.5 0 0 1-1 0A3.5 3.5 0 1 1 12.5 8H.5a.5.5 0 0 1 0-1h12a2.5 2.5 0 0 0 0-5zm-7 1a1 1 0 0 0-1 1 .5.5 0 0 1-1 0 2 2 0 1 1 2 2h-5a.5.5 0 0 1 0-1h5a1 1 0 0 0 0-2zM0 9.5A.5.5 0 0 1 .5 9h10.042a3 3 0 1 1-3 3 .5.5 0 0 1 1 0 2 2 0 1 0 2-2H.5a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\nexport function BsWindowDock (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M15 5H1v8a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V5zm0-1H1V3a1 1 0 0 1 1-1h12a1 1 0 0 1 1 1v1zm1-1a2 2 0 0 0-2-2H2a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V3z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M3 11.5a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm4 0a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1zm4 0a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1a.5.5 0 0 1-.5-.5v-1z\"}}]})(props);\n};\nexport function BsWindowSidebar (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 4a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1zm2-.5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm1 .5a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V3a2 2 0 0 0-2-2H2zm12 1a1 1 0 0 1 1 1v2H1V3a1 1 0 0 1 1-1h12zM1 13V6h4v8H2a1 1 0 0 1-1-1zm5 1V6h9v7a1 1 0 0 1-1 1H6z\"}}]})(props);\n};\nexport function BsWindow (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2.5 4a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1zm2-.5a.5.5 0 1 1-1 0 .5.5 0 0 1 1 0zm1 .5a.5.5 0 1 0 0-1 .5.5 0 0 0 0 1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M2 1a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V3a2 2 0 0 0-2-2H2zm13 2v2H1V3a1 1 0 0 1 1-1h12a1 1 0 0 1 1 1zM2 14a1 1 0 0 1-1-1V6h14v7a1 1 0 0 1-1 1H2z\"}}]})(props);\n};\nexport function BsWindows (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M6.555 1.375 0 2.237v5.45h6.555V1.375zM0 13.795l6.555.933V8.313H0v5.482zm7.278-5.4.026 6.378L16 16V8.395H7.278zM16 0 7.33 1.244v6.414H16V0z\"}}]})(props);\n};\nexport function BsWordpress (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M12.633 7.653c0-.848-.305-1.435-.566-1.892l-.08-.13c-.317-.51-.594-.958-.594-1.48 0-.63.478-1.218 1.152-1.218.02 0 .039.002.058.003l.031.003A6.838 6.838 0 0 0 8 1.137 6.855 6.855 0 0 0 2.266 4.23c.16.005.313.009.442.009.717 0 1.828-.087 1.828-.087.37-.022.414.521.044.565 0 0-.371.044-.785.065l2.5 7.434 1.5-4.506-1.07-2.929c-.369-.022-.719-.065-.719-.065-.37-.022-.326-.588.043-.566 0 0 1.134.087 1.808.087.718 0 1.83-.087 1.83-.087.37-.022.413.522.043.566 0 0-.372.043-.785.065l2.48 7.377.684-2.287.054-.173c.27-.86.469-1.495.469-2.046zM1.137 8a6.864 6.864 0 0 0 3.868 6.176L1.73 5.206A6.837 6.837 0 0 0 1.137 8z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M6.061 14.583 8.121 8.6l2.109 5.78c.014.033.03.064.049.094a6.854 6.854 0 0 1-4.218.109zm7.96-9.876c.03.219.047.453.047.706 0 .696-.13 1.479-.522 2.458l-2.096 6.06a6.86 6.86 0 0 0 2.572-9.224z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M0 8c0-4.411 3.589-8 8-8 4.41 0 8 3.589 8 8s-3.59 8-8 8c-4.411 0-8-3.589-8-8zm.367 0c0 4.209 3.424 7.633 7.633 7.633 4.208 0 7.632-3.424 7.632-7.633C15.632 3.79 12.208.367 8 .367 3.79.367.367 3.79.367 8z\"}}]})(props);\n};\nexport function BsWrench (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M.102 2.223A3.004 3.004 0 0 0 3.78 5.897l6.341 6.252A3.003 3.003 0 0 0 13 16a3 3 0 1 0-.851-5.878L5.897 3.781A3.004 3.004 0 0 0 2.223.1l2.141 2.142L4 4l-1.757.364L.102 2.223zm13.37 9.019.528.026.287.445.445.287.026.529L15 13l-.242.471-.026.529-.445.287-.287.445-.529.026L13 15l-.471-.242-.529-.026-.287-.445-.445-.287-.026-.529L11 13l.242-.471.026-.529.445-.287.287-.445.529-.026L13 11l.471.242z\"}}]})(props);\n};\nexport function BsXCircleFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM5.354 4.646a.5.5 0 1 0-.708.708L7.293 8l-2.647 2.646a.5.5 0 0 0 .708.708L8 8.707l2.646 2.647a.5.5 0 0 0 .708-.708L8.707 8l2.647-2.646a.5.5 0 0 0-.708-.708L8 7.293 5.354 4.646z\"}}]})(props);\n};\nexport function BsXCircle (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.646 4.646a.5.5 0 0 1 .708 0L8 7.293l2.646-2.647a.5.5 0 0 1 .708.708L8.707 8l2.647 2.646a.5.5 0 0 1-.708.708L8 8.707l-2.646 2.647a.5.5 0 0 1-.708-.708L7.293 8 4.646 5.354a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsXDiamondFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M9.05.435c-.58-.58-1.52-.58-2.1 0L4.047 3.339 8 7.293l3.954-3.954L9.049.435zm3.61 3.611L8.708 8l3.954 3.954 2.904-2.905c.58-.58.58-1.519 0-2.098l-2.904-2.905zm-.706 8.614L8 8.708l-3.954 3.954 2.905 2.904c.58.58 1.519.58 2.098 0l2.905-2.904zm-8.614-.706L7.292 8 3.339 4.046.435 6.951c-.58.58-.58 1.519 0 2.098l2.904 2.905z\"}}]})(props);\n};\nexport function BsXDiamond (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M7.987 16a1.526 1.526 0 0 1-1.07-.448L.45 9.082a1.531 1.531 0 0 1 0-2.165L6.917.45a1.531 1.531 0 0 1 2.166 0l6.469 6.468A1.526 1.526 0 0 1 16 8.013a1.526 1.526 0 0 1-.448 1.07l-6.47 6.469A1.526 1.526 0 0 1 7.988 16zM7.639 1.17 4.766 4.044 8 7.278l3.234-3.234L8.361 1.17a.51.51 0 0 0-.722 0zM8.722 8l3.234 3.234 2.873-2.873c.2-.2.2-.523 0-.722l-2.873-2.873L8.722 8zM8 8.722l-3.234 3.234 2.873 2.873c.2.2.523.2.722 0l2.873-2.873L8 8.722zM7.278 8 4.044 4.766 1.17 7.639a.511.511 0 0 0 0 .722l2.874 2.873L7.278 8z\"}}]})(props);\n};\nexport function BsXLg (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M1.293 1.293a1 1 0 0 1 1.414 0L8 6.586l5.293-5.293a1 1 0 1 1 1.414 1.414L9.414 8l5.293 5.293a1 1 0 0 1-1.414 1.414L8 9.414l-5.293 5.293a1 1 0 0 1-1.414-1.414L6.586 8 1.293 2.707a1 1 0 0 1 0-1.414z\"}}]})(props);\n};\nexport function BsXOctagonFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M11.46.146A.5.5 0 0 0 11.107 0H4.893a.5.5 0 0 0-.353.146L.146 4.54A.5.5 0 0 0 0 4.893v6.214a.5.5 0 0 0 .146.353l4.394 4.394a.5.5 0 0 0 .353.146h6.214a.5.5 0 0 0 .353-.146l4.394-4.394a.5.5 0 0 0 .146-.353V4.893a.5.5 0 0 0-.146-.353L11.46.146zm-6.106 4.5L8 7.293l2.646-2.647a.5.5 0 0 1 .708.708L8.707 8l2.647 2.646a.5.5 0 0 1-.708.708L8 8.707l-2.646 2.647a.5.5 0 0 1-.708-.708L7.293 8 4.646 5.354a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsXOctagon (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.54.146A.5.5 0 0 1 4.893 0h6.214a.5.5 0 0 1 .353.146l4.394 4.394a.5.5 0 0 1 .146.353v6.214a.5.5 0 0 1-.146.353l-4.394 4.394a.5.5 0 0 1-.353.146H4.893a.5.5 0 0 1-.353-.146L.146 11.46A.5.5 0 0 1 0 11.107V4.893a.5.5 0 0 1 .146-.353L4.54.146zM5.1 1 1 5.1v5.8L5.1 15h5.8l4.1-4.1V5.1L10.9 1H5.1z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.646 4.646a.5.5 0 0 1 .708 0L8 7.293l2.646-2.647a.5.5 0 0 1 .708.708L8.707 8l2.647 2.646a.5.5 0 0 1-.708.708L8 8.707l-2.646 2.647a.5.5 0 0 1-.708-.708L7.293 8 4.646 5.354a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsXSquareFill (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm3.354 4.646L8 7.293l2.646-2.647a.5.5 0 0 1 .708.708L8.707 8l2.647 2.646a.5.5 0 0 1-.708.708L8 8.707l-2.646 2.647a.5.5 0 0 1-.708-.708L7.293 8 4.646 5.354a.5.5 0 1 1 .708-.708z\"}}]})(props);\n};\nexport function BsXSquare (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M14 1a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1h12zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M4.646 4.646a.5.5 0 0 1 .708 0L8 7.293l2.646-2.647a.5.5 0 0 1 .708.708L8.707 8l2.647 2.646a.5.5 0 0 1-.708.708L8 8.707l-2.646 2.647a.5.5 0 0 1-.708-.708L7.293 8 4.646 5.354a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsX (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M4.646 4.646a.5.5 0 0 1 .708 0L8 7.293l2.646-2.647a.5.5 0 0 1 .708.708L8.707 8l2.647 2.646a.5.5 0 0 1-.708.708L8 8.707l-2.646 2.647a.5.5 0 0 1-.708-.708L7.293 8 4.646 5.354a.5.5 0 0 1 0-.708z\"}}]})(props);\n};\nexport function BsYoutube (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"d\":\"M8.051 1.999h.089c.822.003 4.987.033 6.11.335a2.01 2.01 0 0 1 1.415 1.42c.101.38.172.883.22 1.402l.01.104.022.26.008.104c.065.914.073 1.77.074 1.957v.075c-.001.194-.01 1.108-.082 2.06l-.008.105-.009.104c-.05.572-.124 1.14-.235 1.558a2.007 2.007 0 0 1-1.415 1.42c-1.16.312-5.569.334-6.18.335h-.142c-.309 0-1.587-.006-2.927-.052l-.17-.006-.087-.004-.171-.007-.171-.007c-1.11-.049-2.167-.128-2.654-.26a2.007 2.007 0 0 1-1.415-1.419c-.111-.417-.185-.986-.235-1.558L.09 9.82l-.008-.104A31.4 31.4 0 0 1 0 7.68v-.123c.002-.215.01-.958.064-1.778l.007-.103.003-.052.008-.104.022-.26.01-.104c.048-.519.119-1.023.22-1.402a2.007 2.007 0 0 1 1.415-1.42c.487-.13 1.544-.21 2.654-.26l.17-.007.172-.006.086-.003.171-.007A99.788 99.788 0 0 1 7.858 2h.193zM6.4 5.209v4.818l4.157-2.408L6.4 5.209z\"}}]})(props);\n};\nexport function BsZoomIn (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6.5 12a5.5 5.5 0 1 0 0-11 5.5 5.5 0 0 0 0 11zM13 6.5a6.5 6.5 0 1 1-13 0 6.5 6.5 0 0 1 13 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.344 11.742c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1 6.538 6.538 0 0 1-1.398 1.4z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6.5 3a.5.5 0 0 1 .5.5V6h2.5a.5.5 0 0 1 0 1H7v2.5a.5.5 0 0 1-1 0V7H3.5a.5.5 0 0 1 0-1H6V3.5a.5.5 0 0 1 .5-.5z\"}}]})(props);\n};\nexport function BsZoomOut (props) {\n return GenIcon({\"tag\":\"svg\",\"attr\":{\"fill\":\"currentColor\",\"viewBox\":\"0 0 16 16\"},\"child\":[{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M6.5 12a5.5 5.5 0 1 0 0-11 5.5 5.5 0 0 0 0 11zM13 6.5a6.5 6.5 0 1 1-13 0 6.5 6.5 0 0 1 13 0z\"}},{\"tag\":\"path\",\"attr\":{\"d\":\"M10.344 11.742c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1 6.538 6.538 0 0 1-1.398 1.4z\"}},{\"tag\":\"path\",\"attr\":{\"fillRule\":\"evenodd\",\"d\":\"M3 6.5a.5.5 0 0 1 .5-.5h6a.5.5 0 0 1 0 1h-6a.5.5 0 0 1-.5-.5z\"}}]})(props);\n};\n","import React, {useContext} from 'react'\r\nimport {NavLink} from 'react-router-dom'\r\n\r\nimport UserContext from '../context/UserContext'\r\nimport useContexts from '../hooks/useContextCommunicator'\r\n\r\nfunction SearchResults({results, submitClicked}) {\r\n // Hooks def\r\n const {addCustomInstrumentCommand, quickAddInstrumentCommand, browseStocksCommand} = useContexts()\r\n\r\n // Context def\r\n const {stocks, customStocks} = useContext(UserContext)\r\n\r\n // Handlers\r\n const linkClicked = (item) => {\r\n submitClicked(item)\r\n // setVisitedFrom('/search')\r\n }\r\n\r\n let searchResultsDiv\r\n if (results.results && results.results.length) {\r\n searchResultsDiv = results.results.map(item => {\r\n if (item === 'no results') {\r\n return
    \r\n

    No results were found

    \r\n
    \r\n } else {\r\n const itemKey = \"catStock_\"+item.code\r\n return (\r\n
    linkClicked(item.code)}>\r\n
    quickAddInstrumentCommand(item.code)}>
    \r\n \r\n
    {item.code} - {item.name} - Last Price: {item.price} {stocks.includes(item.code)? FAVORITE : ''}
    \r\n
    \r\n
    \r\n )\r\n }\r\n })\r\n }\r\n\r\n return (\r\n <>\r\n {searchResultsDiv}\r\n \r\n )\r\n}\r\n\r\nexport default SearchResults","import React, { useContext, useState, useEffect } from 'react'\r\n// import {NavLink} from 'react-router-dom'\r\n\r\nimport { BsFillCaretRightFill, BsFillCaretLeftFill } from \"react-icons/bs\";\r\n\r\nimport DataContext from '../context/DataContext'\r\nimport StorageContext from '../context/StorageContext'\r\nimport SearchResults from '../components/SearchResults'\r\n\r\nexport default function Search() {\r\n // Constants DEF\r\n const RESULTS_PER_PAGE = 40\r\n\r\n // context def\r\n const {categories, countries, setInstrumentShown, updateSearchParams, searchResults: searchResultParams, setVisitedFrom} = useContext(DataContext)\r\n const {state} = useContext(StorageContext)\r\n\r\n // state def\r\n const [searchResultsState, setSearchResultsState] = useState({\r\n currentPage: 0,\r\n searchResults: 0,\r\n totalPages: 0,\r\n results: []\r\n })\r\n const [selectedCategory, setSelectedCategory] = useState('All')\r\n const [selectedCountry, setSelectedCountry] = useState('All')\r\n const [term, setTerm] = useState('')\r\n const [allResults, setAllResults] = useState([])\r\n const [fromPrice, setFromPrice] = useState(0)\r\n const [toPrice, setToPrice] = useState(0)\r\n const [sectorIndustryPairs, setSectorIndustryPairs] = useState([])\r\n const [selectedIndustry, setSelectedIndustry] = useState('')\r\n\r\n // Helper functions\r\n const newResultElement = (el) => {\r\n let industry = null\r\n if (el.industry) {\r\n industry = el.industry.replaceAll('\"','')\r\n }\r\n\r\n return {\r\n code: el.symbol,\r\n name: el.name,\r\n price: el.price,\r\n industry: industry\r\n }\r\n }\r\n\r\n const collectAllStocksIntoArray = () => {\r\n const newState = []\r\n state.forEach(country => {\r\n country.stocks.forEach((el) => {\r\n newState.push(newResultElement(el))\r\n })\r\n })\r\n setAllResults([])\r\n return newState\r\n }\r\n\r\n const collectStocksOfOneCategory = (category, countryList=[]) => {\r\n const newState = []\r\n\r\n\r\n if (!countryList.length) {\r\n state.forEach(country => {\r\n country.stocks.forEach((el) => {\r\n if (el.category === category) {\r\n newState.push(newResultElement(el))\r\n }\r\n })\r\n })\r\n } else {\r\n countryList[0].stocks.forEach((el) => {\r\n if (el.category === category) {\r\n newState.push(newResultElement(el))\r\n }\r\n })\r\n }\r\n\r\n setAllResults([])\r\n return newState\r\n }\r\n\r\n const setNewSearchResultState = (currentPage=1, searchResults, totalPages=1, originalList) => {\r\n const results = originalList.filter((el, index) => {\r\n if ((currentPage-1)*RESULTS_PER_PAGE <= index && index < (currentPage*RESULTS_PER_PAGE)) {\r\n return true\r\n }\r\n })\r\n\r\n const resultsSorted = results.sort(function(a, b) {\r\n return a.code.length - b.code.length\r\n })\r\n setSearchResultsState({\r\n currentPage,\r\n searchResults,\r\n totalPages,\r\n results: resultsSorted\r\n })\r\n }\r\n\r\n const displayStocksFromList = (category=selectedCategory, country=selectedCountry, updateState=true) => {\r\n // Account for categories that are stored as countries in context\r\n const categoriesAsCountries = ['Crypto', 'Forex', 'Futures', 'Index', 'Government Bonds']\r\n let controlCountry\r\n if (categoriesAsCountries.includes(category)) {\r\n controlCountry = category\r\n } else if (category === 'Indexes') {\r\n controlCountry = 'Index'\r\n } else {\r\n controlCountry = country\r\n }\r\n\r\n const countryObject = state.filter(el => el.country === controlCountry)\r\n\r\n if (!countryObject[0] || !countryObject[0].stocks) {\r\n if (country !== 'All') {\r\n return console.log(\"No Stocks for\", country)\r\n }\r\n }\r\n\r\n // Main search function\r\n if (country === 'All' && category === 'All') {\r\n const results = collectAllStocksIntoArray()\r\n if (updateState) {\r\n setNewSearchResultState(1, results.length, 1, results)\r\n } else {\r\n return results\r\n }\r\n } else if (controlCountry === country && category === 'All') {\r\n const newResults = []\r\n countryObject[0].stocks.forEach(el => {\r\n newResults.push(newResultElement(el))\r\n })\r\n const currentPage = 1\r\n const searchResults = newResults.length\r\n let totalPages = parseInt(searchResults/RESULTS_PER_PAGE)+1\r\n if (updateState) {\r\n setAllResults(newResults)\r\n setNewSearchResultState(currentPage, searchResults, totalPages, newResults)\r\n } else {\r\n return newResults\r\n }\r\n } else if (controlCountry === 'All' && category !== 'All') {\r\n const results = collectStocksOfOneCategory(category)\r\n const searchResults = results.length\r\n const totalPages = parseInt(searchResults/RESULTS_PER_PAGE)+1\r\n\r\n if (updateState) {\r\n setAllResults(results)\r\n setNewSearchResultState(1, searchResults, totalPages, results)\r\n } else {\r\n return results\r\n }\r\n } else if (controlCountry === country && category !== 'All') {\r\n const tempResults = countryObject[0].stocks.filter(el => el.category === category)\r\n const newResults = []\r\n tempResults.forEach(el => {\r\n newResults.push(newResultElement(el))\r\n })\r\n const currentPage = 1\r\n const searchResults = newResults.length\r\n let totalPages = parseInt(searchResults/RESULTS_PER_PAGE)+1\r\n if (updateState) {\r\n setAllResults(newResults)\r\n setNewSearchResultState(currentPage, searchResults, totalPages, newResults)\r\n } else {\r\n return newResults\r\n }\r\n } else if (controlCountry === category || controlCountry === 'Index') {\r\n const newResults = []\r\n countryObject[0].stocks.forEach(el => {\r\n newResults.push(newResultElement(el))\r\n })\r\n const currentPage = 1\r\n const searchResults = newResults.length\r\n let totalPages = parseInt(searchResults/RESULTS_PER_PAGE)+1\r\n if (totalPages === 0) {\r\n totalPages = 1\r\n }\r\n if (updateState) {\r\n setAllResults(newResults)\r\n setNewSearchResultState(currentPage, searchResults, totalPages, newResults)\r\n } else {\r\n return newResults\r\n }\r\n }\r\n }\r\n\r\n const filterStocksByIndustry = (industry=selectedIndustry, country=selectedCountry, stockList=[]) => {\r\n if (!stockList.length) {\r\n const countryObject = state.filter(el => el.country === country)\r\n const results = collectStocksOfOneCategory(selectedCategory, countryObject)\r\n const filteredResults = results.filter(el => el.industry === industry)\r\n \r\n const currentPage = 1\r\n const searchResults = filteredResults.length\r\n setAllResults(filteredResults)\r\n let totalPages = parseInt(searchResults/RESULTS_PER_PAGE)+1\r\n if (totalPages === 0) {\r\n totalPages = 1\r\n }\r\n \r\n setAllResults(filteredResults)\r\n setNewSearchResultState(currentPage, searchResults, totalPages, filteredResults)\r\n } else {\r\n // Stock list has been passed, take it and only return the filtered stocklist\r\n return stockList.filter(el => el.industry === industry)\r\n }\r\n }\r\n\r\n // -------------------- initial load\r\n useEffect(() => {\r\n // 1. SEARCH CODE\r\n // Check if there were any search params before. If yes, load those instead, otherwise load all stocks\r\n if (!searchResultParams.term && !searchResultParams.category && !searchResultParams.country && searchResultParams.page === 1) {\r\n // NO SEARCH PARAMS, LOAD ALL STOCKS\r\n // 1. load all symbols and names from storage\r\n const newState = collectAllStocksIntoArray()\r\n\r\n //2. Take all results and render only a portion of them\r\n const searchResults = newState.length\r\n const totalPages = parseInt(newState.length/RESULTS_PER_PAGE)+1\r\n const currentPage = 1\r\n setNewSearchResultState(currentPage, searchResults, totalPages, newState)\r\n } else {\r\n // SEARCH PARAMS DETECTED. FIRST FILTER BY CATEGORY & COUNTRY, THEN APPLY SEARCH\r\n let newResults = displayStocksFromList(searchResultParams.category, searchResultParams.country, false)\r\n if (searchResultParams.industry) {\r\n newResults = filterStocksByIndustry(searchResultParams.industry, searchResultParams.country, newResults)\r\n }\r\n if (searchResultParams.term) {\r\n const searchedResults = newResults.filter(el => el.code.toLowerCase().includes(searchResultParams.term.toLowerCase()) || el.name.toLowerCase().includes(searchResultParams.term.toLowerCase()))\r\n \r\n const totalPages =parseInt(searchedResults.length/RESULTS_PER_PAGE)+1\r\n setAllResults(searchedResults)\r\n setNewSearchResultState(searchResultParams.page, searchedResults.length, totalPages, searchedResults)\r\n\r\n if (!term) {\r\n setTerm(searchResultParams.term)\r\n }\r\n } else {\r\n const totalPages = parseInt(newResults.length/RESULTS_PER_PAGE)+1\r\n setAllResults(newResults)\r\n setNewSearchResultState(searchResultParams.page, newResults.length, totalPages, newResults)\r\n }\r\n setSelectedCategory(searchResultParams.category)\r\n setSelectedCountry(searchResultParams.country)\r\n if (searchResultParams.industry) {\r\n setSelectedIndustry(searchResultParams.industry)\r\n }\r\n }\r\n\r\n // ------------------------------\r\n // 2. Set Category/Industry Pairs\r\n if (!sectorIndustryPairs.length && state && state.length) {\r\n const allIndustriesRaw = new Set()\r\n state.forEach(el => {\r\n el.stocks.forEach(stock => {\r\n try {\r\n allIndustriesRaw.add(JSON.stringify({sector: stock.category, industry: stock.industry.replaceAll('\"','')}))\r\n } catch {}\r\n })\r\n })\r\n const allIndustries = [...allIndustriesRaw].map((item) => {\r\n if (typeof item === 'string') return JSON.parse(item)\r\n else if (typeof item === 'object') return item\r\n })\r\n setSectorIndustryPairs(allIndustries)\r\n }\r\n }, [state])\r\n\r\n\r\n // -------------------- handlers\r\n const movePageBack = () => {\r\n // If no search results, scan all the stocks to display the next page\r\n // Else display next set from search results\r\n if (!allResults.length) {\r\n const newState = collectAllStocksIntoArray()\r\n\r\n const searchResults = newState.length\r\n let totalPages = searchResultsState.totalPages\r\n const currentPage = searchResultsState.currentPage - 1\r\n setNewSearchResultState(currentPage, searchResults, totalPages, newState)\r\n } else {\r\n const searchResults = allResults.length\r\n let totalPages = searchResultsState.totalPages\r\n const currentPage = searchResultsState.currentPage - 1\r\n setNewSearchResultState(currentPage, searchResults, totalPages, allResults)\r\n }\r\n }\r\n\r\n const movePageForward = () => {\r\n \r\n // If no search results, scan all the stocks to display the next page\r\n // Else display next set from search results\r\n if (!allResults.length) {\r\n const newState = collectAllStocksIntoArray()\r\n\r\n const searchResults = newState.length\r\n let totalPages = searchResultsState.totalPages\r\n const currentPage = searchResultsState.currentPage + 1\r\n setNewSearchResultState(currentPage, searchResults, totalPages, newState)\r\n } else {\r\n const searchResults = allResults.length\r\n let totalPages = searchResultsState.totalPages\r\n const currentPage = searchResultsState.currentPage + 1\r\n setNewSearchResultState(currentPage, searchResults, totalPages, allResults)\r\n }\r\n }\r\n\r\n const searchHandler = (e) => {\r\n e.preventDefault()\r\n if (term) {\r\n // If no search results, look through the entire stock database\r\n // Else filter through search results only\r\n if (selectedCategory === 'All' && selectedCountry === 'All') {\r\n const newState = collectAllStocksIntoArray()\r\n const results = newState.filter(el => el.code.toLowerCase().includes(term.toLowerCase()) || el.name.toLowerCase().includes(term.toLowerCase()))\r\n const currentPage = 1\r\n const searchResults = results.length\r\n let totalPages = parseInt(results.length/RESULTS_PER_PAGE)+1\r\n setAllResults(results)\r\n setNewSearchResultState(currentPage, searchResults, totalPages, results)\r\n } else {\r\n const newResults = displayStocksFromList(selectedCategory, selectedCountry, false)\r\n const results = newResults.filter(el => el.code.toLowerCase().includes(term.toLowerCase()) || el.name.toLowerCase().includes(term.toLowerCase()))\r\n const currentPage = 1\r\n const searchResults = results.length\r\n let totalPages = parseInt(results.length/RESULTS_PER_PAGE)+1\r\n setAllResults(results)\r\n setNewSearchResultState(currentPage, searchResults, totalPages, results)\r\n }\r\n } else {\r\n return alert('Please enter a symbol or name to start search')\r\n }\r\n }\r\n\r\n const categoryChangedHandler = (category) => {\r\n setSelectedCategory(category)\r\n setSelectedIndustry('')\r\n setTerm('')\r\n displayStocksFromList(category)\r\n }\r\n\r\n const countryChangedHandler = (country) => {\r\n setSelectedCountry(country)\r\n setSelectedCategory('All')\r\n setSelectedIndustry('')\r\n setTerm('')\r\n displayStocksFromList('All', country)\r\n }\r\n\r\n const preNavigationHandler = (item) => {\r\n // Save search params to state before navigating away\r\n updateSearchParams(term, selectedCategory, selectedCountry, searchResultsState.currentPage, selectedIndustry)\r\n\r\n // Navigate away\r\n setInstrumentShown(item)\r\n setVisitedFrom('/search')\r\n }\r\n\r\n const filterPriceHandler = () => {\r\n // Validation\r\n if (toPrice < fromPrice) {\r\n return alert(\"Price range incorrect. From Price must be lower than To Price\")\r\n }\r\n\r\n const filterResults = (array, from, to) => {\r\n return array.filter(el => {\r\n const price = parseFloat(el.price)\r\n if ((price >= from) && (price <= to)) {\r\n return true\r\n }\r\n })\r\n }\r\n\r\n let filteredResults\r\n\r\n if ((fromPrice == 0) && (toPrice == 0)) {\r\n console.log('Resetting search')\r\n if (allResults && allResults.length) {\r\n filteredResults = allResults\r\n } else if (selectedCategory === 'All') {\r\n filteredResults = collectAllStocksIntoArray()\r\n } else {\r\n filteredResults = collectStocksOfOneCategory(selectedCategory)\r\n }\r\n } else if (allResults && allResults.length) {\r\n filteredResults = filterResults(allResults, fromPrice, toPrice)\r\n } else if (selectedCategory === 'All') {\r\n const newState = collectAllStocksIntoArray()\r\n filteredResults = filterResults(newState, fromPrice, toPrice)\r\n } else {\r\n const newState = collectStocksOfOneCategory(selectedCategory)\r\n filteredResults = filterResults(newState, fromPrice, toPrice)\r\n }\r\n\r\n let totalPages = parseInt(filteredResults.length/RESULTS_PER_PAGE)+1\r\n setNewSearchResultState(1, filteredResults.length, totalPages, filteredResults)\r\n }\r\n\r\n const industryChangedHandler = (industry) => {\r\n setTerm('')\r\n setSelectedIndustry(industry)\r\n filterStocksByIndustry(industry)\r\n }\r\n\r\n // -------------------- pre-render\r\n // categories\r\n const modifiedCategories = [...categories]\r\n modifiedCategories.unshift('All')\r\n const categoriesDiv = modifiedCategories.map(el => {\r\n let classString = `stockBrowser--rightSide__list-item${el === selectedCategory?' stockBrowser--rightSide__list-item-selected': ''}`\r\n return (\r\n categoryChangedHandler(el)}\r\n >\r\n {el}\r\n \r\n )\r\n })\r\n\r\n let industriesToDisplay \r\n if (selectedCategory !== 'All') {\r\n industriesToDisplay = sectorIndustryPairs.filter(el => el.sector === selectedCategory)\r\n } else {\r\n industriesToDisplay = []\r\n }\r\n\r\n const industriesDiv = industriesToDisplay.map((el, index) => {\r\n let classString = `stockBrowser--rightSide__list-item${el.industry === selectedIndustry?' stockBrowser--rightSide__list-item-selected': ''}`\r\n return (\r\n industryChangedHandler(el.industry)}\r\n >\r\n {el.industry}\r\n \r\n )\r\n })\r\n\r\n // countries\r\n const modifiedCountries = [...countries]\r\n modifiedCountries.unshift('All')\r\n const countriesDiv = modifiedCountries.map(el => {\r\n let classString = `stockBrowser--rightSide__list-item${el === selectedCountry?' stockBrowser--rightSide__list-item-selected': ''}`\r\n return (\r\n countryChangedHandler(el)}\r\n >\r\n {el}\r\n \r\n )\r\n })\r\n\r\n let resultString\r\n if (searchResultsState.currentPage === searchResultsState.totalPages) {\r\n resultString = `${searchResultsState.searchResults}`\r\n } else {\r\n resultString = `${searchResultsState.currentPage*RESULTS_PER_PAGE}`\r\n }\r\n\r\n // ---- DROPDOWNS ------------\r\n const categoryList = modifiedCategories.map(item => {\r\n return (\r\n \r\n )\r\n })\r\n\r\n const countryList = modifiedCountries.map(item => {\r\n return (\r\n \r\n )\r\n })\r\n\r\n const industryList = industriesToDisplay.map(item => {\r\n return (\r\n \r\n )\r\n })\r\n\r\n // final render\r\n return (\r\n
    \r\n {/* Search Bar */}\r\n
    \r\n \r\n
    \r\n setTerm(e.target.value)}\r\n placeholder='Enter Symbol or Name here'\r\n />\r\n searchHandler(e)}\r\n >\r\n Search\r\n \r\n \r\n
    \r\n
    \r\n \r\n
    \r\n {/* Country */}\r\n
    \r\n Country: \r\n \r\n
    \r\n\r\n {/* Price Filter */}\r\n
    \r\n
    \r\n \r\n setFromPrice(e.target.value)}\r\n />\r\n \r\n setToPrice(e.target.value)}\r\n />\r\n \r\n Filter\r\n \r\n
    \r\n Setting both values to 0 will show all results\r\n
    \r\n
    \r\n
    \r\n {/* Category */}\r\n
    \r\n Sector:\r\n \r\n
    \r\n {/* Category */}\r\n
    \r\n Industry:\r\n \r\n
    \r\n
    \r\n
    \r\n\r\n {/* Bottom Area */}\r\n
    \r\n
    \r\n {/* CONTROL BAR HERE */}\r\n
    \r\n \r\n Total Results: {searchResultsState.searchResults}\r\n \r\n \r\n Showing results: {(searchResultsState.currentPage-1)*RESULTS_PER_PAGE+' - '+ resultString}\r\n \r\n \r\n \r\n \r\n
    \r\n \r\n \r\n
    \r\n \r\n
    \r\n {/* Search Results Here */}\r\n
    \r\n preNavigationHandler(e)}\r\n />\r\n
    \r\n
    \r\n
    \r\n {/* Price Filter */}\r\n
    \r\n \r\n

    Setting both values to 0 will show all results

    \r\n
    \r\n \r\n setFromPrice(e.target.value)}\r\n />\r\n \r\n setToPrice(e.target.value)}\r\n />\r\n \r\n Filter\r\n \r\n
    \r\n
    \r\n {/* Countries */}\r\n
    \r\n Country: \r\n \r\n {/* \r\n
    \r\n {countriesDiv}\r\n
    */}\r\n
    \r\n {/* Categories */}\r\n
    \r\n \r\n
    \r\n {categoriesDiv}\r\n
    \r\n
    \r\n {/* Industries */}\r\n
    \r\n \r\n
    \r\n {industriesDiv}\r\n
    \r\n
    \r\n
    \r\n \r\n \r\n )\r\n}","// import { set } from 'date-fns'\r\nimport React, { useState, useEffect } from 'react'\r\nimport Button from '../components/Button'\r\nimport useInstrument from '../hooks/useInstrument'\r\nimport useErrorHandler from '../hooks/useErrorHandler'\r\n\r\nexport default function User() {\r\n const {getUserInfo, updateUserInfoCommand, changePasswordCommand} = useInstrument()\r\n const {errorHandler} = useErrorHandler()\r\n\r\n // local state\r\n const [user, setUser] = useState({\r\n name: '',\r\n email: '',\r\n stocks: [],\r\n portfolios: []\r\n })\r\n\r\n const [editing, setEditing] = useState(false)\r\n const [newUser, setNewUser] = useState('')\r\n const [newEmail, setNewEmail] = useState('')\r\n const [oldPass, setOldPass] = useState('')\r\n const [newPass, setNewPass] = useState('')\r\n\r\n let nameField = null\r\n let emailField = null\r\n let editButton = null\r\n\r\n useEffect(() => {\r\n const loadUserData = async () => {\r\n try {\r\n const userData = await getUserInfo()\r\n setUser(userData)\r\n setNewUser(userData.name)\r\n setNewEmail(userData.email)\r\n } catch (err) {\r\n errorHandler(err)\r\n }\r\n }\r\n loadUserData()\r\n }, [])\r\n\r\n // handlers\r\n const updateUserInfo = async () => {\r\n try {\r\n const response = await updateUserInfoCommand(newUser, newEmail)\r\n let newState = {...user}\r\n newState.name = response.name\r\n newState.email = response.email\r\n setUser(newState)\r\n setEditing(false)\r\n } catch (err) {\r\n errorHandler(err)\r\n }\r\n }\r\n\r\n const changePasswordHandler = async (event) => {\r\n event.preventDefault()\r\n try {\r\n await changePasswordCommand(oldPass, newPass)\r\n setOldPass('')\r\n setNewPass('')\r\n } catch (e) {\r\n errorHandler(e)\r\n }\r\n }\r\n\r\n // pre-render\r\n\r\n const stockList = user.stocks.map(item => {\r\n return (\r\n
  • {item}
  • \r\n )\r\n })\r\n \r\n const portfolioList = user.portfolios.map(item => {\r\n return (\r\n
  • {item.name} - {item.stocks.length} stocks
  • \r\n )\r\n })\r\n\r\n if (editing) {\r\n nameField =

    Name: setNewUser(event.target.value)} placeholder={user.name} />

    \r\n emailField =

    Email: setNewEmail(event.target.value)} placeholder={user.email} />

    \r\n editButton =
    \r\n \r\n \r\n
    \r\n } else {\r\n nameField =

    Name: {user.name}

    \r\n emailField =

    Email: {user.email}

    \r\n editButton = \r\n }\r\n\r\n\r\n\r\n return (\r\n
    \r\n

    User Screen

    \r\n
    \r\n

    My Stocks

    \r\n
      \r\n {stockList}\r\n
    \r\n

    My Portfolios

    \r\n
      \r\n {portfolioList}\r\n
    \r\n
    \r\n
    \r\n

    User Info

    \r\n {nameField}\r\n {emailField}\r\n {editButton}\r\n
    \r\n
    \r\n

    Change password here

    \r\n
    \r\n

    Old Password: setOldPass(event.target.value)} />

    \r\n

    New Password: setNewPass(event.target.value)} />

    \r\n \r\n
    \r\n
    \r\n
    \r\n

    For any issues with your subscription or problems with TS Mobile, please email us at:

    \r\n

    support@timingsolutionmobile

    \r\n
    \r\n
    \r\n )\r\n}\r\n","import React, {useState, useEffect} from 'react'\r\nimport axios from 'axios'\r\nimport {nodeUrl} from '../api/common'\r\n\r\nexport default function Admin() {\r\n // State Definitions\r\n const [inputState, setInputState] = useState(0)\r\n const [firstLastName, setFirstLastName] = useState('')\r\n const [email, setEmail] = useState('')\r\n const [sendEmail, setSendEmail] = useState(true)\r\n const [password, setPassword] = useState('')\r\n const [date, setDate] = useState('')\r\n const [type, setType] = useState('')\r\n const code = 'BsgIfdDiBKogTWd0r6kh'\r\n const [response, setResponse] = useState('')\r\n const [days, setDays] = useState(30)\r\n\r\n useEffect(() => {\r\n\r\n return () => {\r\n setInputState(-1)\r\n }\r\n\r\n }, [])\r\n\r\n const sendRequest = async (object, address) => {\r\n const requestObject = {...object, code}\r\n try {\r\n const response = await axios.post(`${nodeUrl}${address}`, requestObject)\r\n\r\n let responseString = JSON.stringify(response.data)\r\n if (responseString.startsWith('[')) {\r\n responseString = responseString.substring(1, responseString.length-1)\r\n }\r\n responseString = responseString.replaceAll('},{','}\\n\\n{')\r\n responseString = responseString.replaceAll(',','\\n')\r\n setResponse(responseString)\r\n } catch (e) {\r\n try {\r\n setResponse(e.response.data)\r\n } catch {\r\n setResponse(e.message)\r\n }\r\n }\r\n // if (response.)\r\n // setResponse(JSON.stringify(response.data))\r\n }\r\n // -------------\r\n // Handlers\r\n const setInputStateHandler = (input) => {\r\n setInputState(input)\r\n }\r\n\r\n const createUserHandler = (e) => {\r\n e.preventDefault()\r\n // Generate 20-letter long random password\r\n const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\r\n let counter = 0\r\n let result = ''\r\n while (counter < 20) {\r\n result += characters.charAt(Math.floor(Math.random()*(characters.length)))\r\n counter += 1\r\n }\r\n\r\n const requestObject = {\r\n name: firstLastName,\r\n email,\r\n password: result,\r\n sendEmail\r\n }\r\n sendRequest(requestObject, '/node/user/create')\r\n }\r\n\r\n const readUserHandler = (e) => {\r\n e.preventDefault()\r\n const requestObject = {\r\n email\r\n }\r\n sendRequest(requestObject, '/node/user/getUser')\r\n }\r\n\r\n const readAllUsersHandler = (e) => {\r\n e.preventDefault()\r\n sendRequest({}, '/node/user/getUser')\r\n }\r\n\r\n const resetPasswordHandler = (e) => {\r\n e.preventDefault()\r\n const requestObject = {\r\n email,\r\n newPassword: password\r\n }\r\n sendRequest(requestObject, '/node/user/resetUserPassword')\r\n }\r\n\r\n const activateUserHandler = (e) => {\r\n e.preventDefault()\r\n const requestObject = {\r\n email,\r\n expire: date\r\n }\r\n sendRequest(requestObject, '/node/stripe/TSActivateCustomer')\r\n }\r\n\r\n const deactivateUserHandler = (e) => {\r\n e.preventDefault()\r\n const requestObject = {\r\n email\r\n }\r\n sendRequest(requestObject, '/node/stripe/TSDeactivateCustomer')\r\n }\r\n\r\n const changeExpireDateHandler = (e) => {\r\n e.preventDefault()\r\n const requestObject = {\r\n email,\r\n expireAt: date\r\n }\r\n sendRequest(requestObject, '/node/stripe/TSChangeExpireDate')\r\n }\r\n\r\n const addExpectedUserHandler = (e) => {\r\n e.preventDefault()\r\n const requestObject = {\r\n email,\r\n type\r\n }\r\n sendRequest(requestObject, '/node/stripe/TSExpectUser')\r\n }\r\n\r\n const removeExpectedUserHandler = (e) => {\r\n e.preventDefault()\r\n const requestObject = {\r\n email\r\n }\r\n sendRequest(requestObject, '/node/stripe/removeCustomer')\r\n }\r\n\r\n const checkRecentUsersHandler = (e) => {\r\n e.preventDefault()\r\n const requestObject = {\r\n days: days\r\n }\r\n sendRequest(requestObject, '/node/user/checkRecentUsers')\r\n }\r\n // ------------\r\n // Pre-render\r\n // ------------\r\n // Pre-render fucntions\r\n const renderCreateInput = () => {\r\n return
    \r\n \r\n \r\n \r\n \r\n
    \r\n }\r\n\r\n const renderReadUsers = () => {\r\n return
    \r\n \r\n \r\n \r\n
    \r\n }\r\n\r\n const renderResetPassword = () => {\r\n return
    \r\n \r\n \r\n \r\n
    \r\n }\r\n\r\n const renderActivateUser = () => {\r\n return
    \r\n \r\n \r\n \r\n
    \r\n }\r\n\r\n const renderDeactivateUser = () => {\r\n return
    \r\n \r\n \r\n
    \r\n }\r\n\r\n const renderChangeExpireDate = () => {\r\n return
    \r\n \r\n \r\n \r\n
    \r\n }\r\n\r\n const renderAddExpectedUser = () => {\r\n return
    \r\n \r\n \r\n

    Options are:

    \r\n

    Terra

    \r\n

    Scanner

    \r\n

    Primo

    \r\n

    Adv

    \r\n

    ScannerYear

    \r\n \r\n
    \r\n }\r\n\r\n const renderRemoveExpectedUser = () => {\r\n return
    \r\n \r\n \r\n
    \r\n }\r\n\r\n const renderCheckRecentUsers = () => {\r\n return
    \r\n \r\n \r\n
    \r\n }\r\n\r\n\r\n\r\n // Pre-render calls\r\n let inputDiv\r\n switch (inputState) {\r\n case 0:\r\n inputDiv = renderCreateInput()\r\n break\r\n case 1:\r\n inputDiv = renderReadUsers()\r\n break\r\n case 2:\r\n inputDiv = renderResetPassword()\r\n break\r\n case 3:\r\n inputDiv = renderActivateUser()\r\n break\r\n case 4:\r\n inputDiv = renderDeactivateUser()\r\n break\r\n case 5:\r\n inputDiv = renderChangeExpireDate()\r\n break \r\n case 6:\r\n inputDiv = renderAddExpectedUser()\r\n break \r\n case 7:\r\n inputDiv = renderRemoveExpectedUser()\r\n break\r\n case 8:\r\n inputDiv = renderCheckRecentUsers()\r\n break\r\n default:\r\n break\r\n }\r\n\r\n return (\r\n
    \r\n
    \r\n
    Options
    \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

    Input

    \r\n

    {inputDiv}

    \r\n
    \r\n
    \r\n