tooltip.html 40 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486
  1. <!DOCTYPE HTML>
  2. <html lang="" >
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
  6. <title>Tooltip · GitBook</title>
  7. <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  8. <meta name="description" content="">
  9. <meta name="generator" content="GitBook 3.2.2">
  10. <meta name="author" content="chartjs">
  11. <link rel="stylesheet" href="../gitbook/style.css">
  12. <link rel="stylesheet" href="../gitbook/gitbook-plugin-search-plus/search.css">
  13. <link rel="stylesheet" href="../gitbook/gitbook-plugin-highlight/website.css">
  14. <link rel="stylesheet" href="../gitbook/gitbook-plugin-fontsettings/website.css">
  15. <link rel="stylesheet" href="../style.css">
  16. <meta name="HandheldFriendly" content="true"/>
  17. <meta name="viewport" content="width=device-width, initial-scale=1">
  18. <meta name="apple-mobile-web-app-capable" content="yes">
  19. <meta name="apple-mobile-web-app-status-bar-style" content="black">
  20. <link rel="apple-touch-icon-precomposed" sizes="152x152" href="../gitbook/images/apple-touch-icon-precomposed-152.png">
  21. <link rel="shortcut icon" href="../gitbook/images/favicon.ico" type="image/x-icon">
  22. <link rel="next" href="elements.html" />
  23. <link rel="prev" href="title.html" />
  24. <link rel="stylesheet" href="../gitbook/gitbook-plugin-chartjs/style.css">
  25. <script src="../gitbook/gitbook-plugin-chartjs/Chart.bundle.js"></script>
  26. <script src="../gitbook/gitbook-plugin-chartjs/chartjs-plugin-deferred.js"></script>
  27. </head>
  28. <body>
  29. <div class="book">
  30. <div class="book-summary">
  31. <div id="book-search-input" role="search">
  32. <input type="text" placeholder="Type to search" />
  33. </div>
  34. <nav role="navigation">
  35. <ul class="summary">
  36. <li class="chapter " data-level="1.1" data-path="../">
  37. <a href="../">
  38. Chart.js
  39. </a>
  40. </li>
  41. <li class="chapter " data-level="1.2" data-path="../getting-started/">
  42. <a href="../getting-started/">
  43. Getting Started
  44. </a>
  45. <ul class="articles">
  46. <li class="chapter " data-level="1.2.1" data-path="../getting-started/installation.html">
  47. <a href="../getting-started/installation.html">
  48. Installation
  49. </a>
  50. </li>
  51. <li class="chapter " data-level="1.2.2" data-path="../getting-started/integration.html">
  52. <a href="../getting-started/integration.html">
  53. Integration
  54. </a>
  55. </li>
  56. <li class="chapter " data-level="1.2.3" data-path="../getting-started/usage.html">
  57. <a href="../getting-started/usage.html">
  58. Usage
  59. </a>
  60. </li>
  61. </ul>
  62. </li>
  63. <li class="chapter " data-level="1.3" data-path="../general/">
  64. <a href="../general/">
  65. General
  66. </a>
  67. <ul class="articles">
  68. <li class="chapter " data-level="1.3.1" data-path="../general/responsive.html">
  69. <a href="../general/responsive.html">
  70. Responsive
  71. </a>
  72. </li>
  73. <li class="chapter " data-level="1.3.2" data-path="../general/interactions/">
  74. <a href="../general/interactions/">
  75. Interactions
  76. </a>
  77. <ul class="articles">
  78. <li class="chapter " data-level="1.3.2.1" data-path="../general/interactions/events.html">
  79. <a href="../general/interactions/events.html">
  80. Events
  81. </a>
  82. </li>
  83. <li class="chapter " data-level="1.3.2.2" data-path="../general/interactions/modes.html">
  84. <a href="../general/interactions/modes.html">
  85. Modes
  86. </a>
  87. </li>
  88. </ul>
  89. </li>
  90. <li class="chapter " data-level="1.3.3" data-path="../general/options.html">
  91. <a href="../general/options.html">
  92. Options
  93. </a>
  94. </li>
  95. <li class="chapter " data-level="1.3.4" data-path="../general/colors.html">
  96. <a href="../general/colors.html">
  97. Colors
  98. </a>
  99. </li>
  100. <li class="chapter " data-level="1.3.5" data-path="../general/fonts.html">
  101. <a href="../general/fonts.html">
  102. Fonts
  103. </a>
  104. </li>
  105. </ul>
  106. </li>
  107. <li class="chapter " data-level="1.4" data-path="./">
  108. <a href="./">
  109. Configuration
  110. </a>
  111. <ul class="articles">
  112. <li class="chapter " data-level="1.4.1" data-path="animations.html">
  113. <a href="animations.html">
  114. Animations
  115. </a>
  116. </li>
  117. <li class="chapter " data-level="1.4.2" data-path="layout.html">
  118. <a href="layout.html">
  119. Layout
  120. </a>
  121. </li>
  122. <li class="chapter " data-level="1.4.3" data-path="legend.html">
  123. <a href="legend.html">
  124. Legend
  125. </a>
  126. </li>
  127. <li class="chapter " data-level="1.4.4" data-path="title.html">
  128. <a href="title.html">
  129. Title
  130. </a>
  131. </li>
  132. <li class="chapter active" data-level="1.4.5" data-path="tooltip.html">
  133. <a href="tooltip.html">
  134. Tooltip
  135. </a>
  136. </li>
  137. <li class="chapter " data-level="1.4.6" data-path="elements.html">
  138. <a href="elements.html">
  139. Elements
  140. </a>
  141. </li>
  142. </ul>
  143. </li>
  144. <li class="chapter " data-level="1.5" data-path="../charts/">
  145. <a href="../charts/">
  146. Charts
  147. </a>
  148. <ul class="articles">
  149. <li class="chapter " data-level="1.5.1" data-path="../charts/line.html">
  150. <a href="../charts/line.html">
  151. Line
  152. </a>
  153. </li>
  154. <li class="chapter " data-level="1.5.2" data-path="../charts/bar.html">
  155. <a href="../charts/bar.html">
  156. Bar
  157. </a>
  158. </li>
  159. <li class="chapter " data-level="1.5.3" data-path="../charts/radar.html">
  160. <a href="../charts/radar.html">
  161. Radar
  162. </a>
  163. </li>
  164. <li class="chapter " data-level="1.5.4" data-path="../charts/doughnut.html">
  165. <a href="../charts/doughnut.html">
  166. Doughnut & Pie
  167. </a>
  168. </li>
  169. <li class="chapter " data-level="1.5.5" data-path="../charts/polar.html">
  170. <a href="../charts/polar.html">
  171. Polar Area
  172. </a>
  173. </li>
  174. <li class="chapter " data-level="1.5.6" data-path="../charts/bubble.html">
  175. <a href="../charts/bubble.html">
  176. Bubble
  177. </a>
  178. </li>
  179. <li class="chapter " data-level="1.5.7" data-path="../charts/scatter.html">
  180. <a href="../charts/scatter.html">
  181. Scatter
  182. </a>
  183. </li>
  184. <li class="chapter " data-level="1.5.8" data-path="../charts/area.html">
  185. <a href="../charts/area.html">
  186. Area
  187. </a>
  188. </li>
  189. <li class="chapter " data-level="1.5.9" data-path="../charts/mixed.html">
  190. <a href="../charts/mixed.html">
  191. Mixed
  192. </a>
  193. </li>
  194. </ul>
  195. </li>
  196. <li class="chapter " data-level="1.6" data-path="../axes/">
  197. <a href="../axes/">
  198. Axes
  199. </a>
  200. <ul class="articles">
  201. <li class="chapter " data-level="1.6.1" data-path="../axes/cartesian/">
  202. <a href="../axes/cartesian/">
  203. Cartesian
  204. </a>
  205. <ul class="articles">
  206. <li class="chapter " data-level="1.6.1.1" data-path="../axes/cartesian/category.html">
  207. <a href="../axes/cartesian/category.html">
  208. Category
  209. </a>
  210. </li>
  211. <li class="chapter " data-level="1.6.1.2" data-path="../axes/cartesian/linear.html">
  212. <a href="../axes/cartesian/linear.html">
  213. Linear
  214. </a>
  215. </li>
  216. <li class="chapter " data-level="1.6.1.3" data-path="../axes/cartesian/logarithmic.html">
  217. <a href="../axes/cartesian/logarithmic.html">
  218. Logarithmic
  219. </a>
  220. </li>
  221. <li class="chapter " data-level="1.6.1.4" data-path="../axes/cartesian/time.html">
  222. <a href="../axes/cartesian/time.html">
  223. Time
  224. </a>
  225. </li>
  226. </ul>
  227. </li>
  228. <li class="chapter " data-level="1.6.2" data-path="../axes/radial/">
  229. <a href="../axes/radial/">
  230. Radial
  231. </a>
  232. <ul class="articles">
  233. <li class="chapter " data-level="1.6.2.1" data-path="../axes/radial/linear.html">
  234. <a href="../axes/radial/linear.html">
  235. Linear
  236. </a>
  237. </li>
  238. </ul>
  239. </li>
  240. <li class="chapter " data-level="1.6.3" data-path="../axes/labelling.html">
  241. <a href="../axes/labelling.html">
  242. Labelling
  243. </a>
  244. </li>
  245. <li class="chapter " data-level="1.6.4" data-path="../axes/styling.html">
  246. <a href="../axes/styling.html">
  247. Styling
  248. </a>
  249. </li>
  250. </ul>
  251. </li>
  252. <li class="chapter " data-level="1.7" data-path="../developers/">
  253. <a href="../developers/">
  254. Developers
  255. </a>
  256. <ul class="articles">
  257. <li class="chapter " data-level="1.7.1" data-path="../developers/api.html">
  258. <a href="../developers/api.html">
  259. Chart.js API
  260. </a>
  261. </li>
  262. <li class="chapter " data-level="1.7.2" data-path="../developers/updates.html">
  263. <a href="../developers/updates.html">
  264. Updating Charts
  265. </a>
  266. </li>
  267. <li class="chapter " data-level="1.7.3" data-path="../developers/plugins.html">
  268. <a href="../developers/plugins.html">
  269. Plugins
  270. </a>
  271. </li>
  272. <li class="chapter " data-level="1.7.4" data-path="../developers/charts.html">
  273. <a href="../developers/charts.html">
  274. New Charts
  275. </a>
  276. </li>
  277. <li class="chapter " data-level="1.7.5" data-path="../developers/axes.html">
  278. <a href="../developers/axes.html">
  279. New Axes
  280. </a>
  281. </li>
  282. <li class="chapter " data-level="1.7.6" data-path="../developers/contributing.html">
  283. <a href="../developers/contributing.html">
  284. Contributing
  285. </a>
  286. </li>
  287. </ul>
  288. </li>
  289. <li class="chapter " data-level="1.8" data-path="../notes/">
  290. <a href="../notes/">
  291. Additional Notes
  292. </a>
  293. <ul class="articles">
  294. <li class="chapter " data-level="1.8.1" data-path="../notes/comparison.html">
  295. <a href="../notes/comparison.html">
  296. Comparison Table
  297. </a>
  298. </li>
  299. <li class="chapter " data-level="1.8.2" data-path="../notes/extensions.html">
  300. <a href="../notes/extensions.html">
  301. Popular Extensions
  302. </a>
  303. </li>
  304. <li class="chapter " data-level="1.8.3" data-path="../notes/license.html">
  305. <a href="../notes/license.html">
  306. License
  307. </a>
  308. </li>
  309. </ul>
  310. </li>
  311. <li class="divider"></li>
  312. <li>
  313. <a href="https://www.gitbook.com" target="blank" class="gitbook-link">
  314. Published with GitBook
  315. </a>
  316. </li>
  317. </ul>
  318. </nav>
  319. </div>
  320. <div class="book-body">
  321. <div class="body-inner">
  322. <div class="book-header" role="navigation">
  323. <!-- Title -->
  324. <h1>
  325. <i class="fa fa-circle-o-notch fa-spin"></i>
  326. <a href=".." >Tooltip</a>
  327. </h1>
  328. </div>
  329. <div class="page-wrapper" tabindex="-1" role="main">
  330. <div class="page-inner">
  331. <div class="search-plus" id="book-search-results">
  332. <div class="search-noresults">
  333. <section class="normal markdown-section">
  334. <h1 id="tooltips">Tooltips</h1>
  335. <h2 id="tooltip-configuration">Tooltip Configuration</h2>
  336. <p>The tooltip configuration is passed into the <code>options.tooltips</code> namespace. The global options for the chart tooltips is defined in <code>Chart.defaults.global.tooltips</code>.</p>
  337. <table>
  338. <thead>
  339. <tr>
  340. <th>Name</th>
  341. <th>Type</th>
  342. <th>Default</th>
  343. <th>Description</th>
  344. </tr>
  345. </thead>
  346. <tbody>
  347. <tr>
  348. <td><code>enabled</code></td>
  349. <td><code>Boolean</code></td>
  350. <td><code>true</code></td>
  351. <td>Are tooltips enabled</td>
  352. </tr>
  353. <tr>
  354. <td><code>custom</code></td>
  355. <td><code>Function</code></td>
  356. <td><code>null</code></td>
  357. <td>See <a href="#external-custom-tooltips">custom tooltip</a> section.</td>
  358. </tr>
  359. <tr>
  360. <td><code>mode</code></td>
  361. <td><code>String</code></td>
  362. <td><code>&apos;nearest&apos;</code></td>
  363. <td>Sets which elements appear in the tooltip. <a href="../general/interactions/modes.html#interaction-modes">more...</a>.</td>
  364. </tr>
  365. <tr>
  366. <td><code>intersect</code></td>
  367. <td><code>Boolean</code></td>
  368. <td><code>true</code></td>
  369. <td>if true, the tooltip mode applies only when the mouse position intersects with an element. If false, the mode will be applied at all times.</td>
  370. </tr>
  371. <tr>
  372. <td><code>position</code></td>
  373. <td><code>String</code></td>
  374. <td><code>&apos;average&apos;</code></td>
  375. <td>The mode for positioning the tooltip. <a href="#position-modes">more...</a></td>
  376. </tr>
  377. <tr>
  378. <td><code>callbacks</code></td>
  379. <td><code>Object</code></td>
  380. <td></td>
  381. <td>See the <a href="#tooltip-callbacks">callbacks section</a></td>
  382. </tr>
  383. <tr>
  384. <td><code>itemSort</code></td>
  385. <td><code>Function</code></td>
  386. <td></td>
  387. <td>Sort tooltip items. <a href="#sort-callback">more...</a></td>
  388. </tr>
  389. <tr>
  390. <td><code>filter</code></td>
  391. <td><code>Function</code></td>
  392. <td></td>
  393. <td>Filter tooltip items. <a href="#filter-callback">more...</a></td>
  394. </tr>
  395. <tr>
  396. <td><code>backgroundColor</code></td>
  397. <td><code>Color</code></td>
  398. <td><code>&apos;rgba(0,0,0,0.8)&apos;</code></td>
  399. <td>Background color of the tooltip.</td>
  400. </tr>
  401. <tr>
  402. <td><code>titleFontFamily</code></td>
  403. <td><code>String</code></td>
  404. <td><code>&quot;&apos;Helvetica Neue&apos;, &apos;Helvetica&apos;, &apos;Arial&apos;, sans-serif&quot;</code></td>
  405. <td>title font</td>
  406. </tr>
  407. <tr>
  408. <td><code>titleFontSize</code></td>
  409. <td><code>Number</code></td>
  410. <td><code>12</code></td>
  411. <td>Title font size</td>
  412. </tr>
  413. <tr>
  414. <td><code>titleFontStyle</code></td>
  415. <td><code>String</code></td>
  416. <td><code>&apos;bold&apos;</code></td>
  417. <td>Title font style</td>
  418. </tr>
  419. <tr>
  420. <td><code>titleFontColor</code></td>
  421. <td><code>Color</code></td>
  422. <td><code>&apos;#fff&apos;</code></td>
  423. <td>Title font color</td>
  424. </tr>
  425. <tr>
  426. <td><code>titleSpacing</code></td>
  427. <td><code>Number</code></td>
  428. <td><code>2</code></td>
  429. <td>Spacing to add to top and bottom of each title line.</td>
  430. </tr>
  431. <tr>
  432. <td><code>titleMarginBottom</code></td>
  433. <td><code>Number</code></td>
  434. <td><code>6</code></td>
  435. <td>Margin to add on bottom of title section.</td>
  436. </tr>
  437. <tr>
  438. <td><code>bodyFontFamily</code></td>
  439. <td><code>String</code></td>
  440. <td><code>&quot;&apos;Helvetica Neue&apos;, &apos;Helvetica&apos;, &apos;Arial&apos;, sans-serif&quot;</code></td>
  441. <td>body line font</td>
  442. </tr>
  443. <tr>
  444. <td><code>bodyFontSize</code></td>
  445. <td><code>Number</code></td>
  446. <td><code>12</code></td>
  447. <td>Body font size</td>
  448. </tr>
  449. <tr>
  450. <td><code>bodyFontStyle</code></td>
  451. <td><code>String</code></td>
  452. <td><code>&apos;normal&apos;</code></td>
  453. <td>Body font style</td>
  454. </tr>
  455. <tr>
  456. <td><code>bodyFontColor</code></td>
  457. <td><code>Color</code></td>
  458. <td><code>&apos;#fff&apos;</code></td>
  459. <td>Body font color</td>
  460. </tr>
  461. <tr>
  462. <td><code>bodySpacing</code></td>
  463. <td><code>Number</code></td>
  464. <td><code>2</code></td>
  465. <td>Spacing to add to top and bottom of each tooltip item.</td>
  466. </tr>
  467. <tr>
  468. <td><code>footerFontFamily</code></td>
  469. <td><code>String</code></td>
  470. <td><code>&quot;&apos;Helvetica Neue&apos;, &apos;Helvetica&apos;, &apos;Arial&apos;, sans-serif&quot;</code></td>
  471. <td>footer font</td>
  472. </tr>
  473. <tr>
  474. <td><code>footerFontSize</code></td>
  475. <td><code>Number</code></td>
  476. <td><code>12</code></td>
  477. <td>Footer font size</td>
  478. </tr>
  479. <tr>
  480. <td><code>footerFontStyle</code></td>
  481. <td><code>String</code></td>
  482. <td><code>&apos;bold&apos;</code></td>
  483. <td>Footer font style</td>
  484. </tr>
  485. <tr>
  486. <td><code>footerFontColor</code></td>
  487. <td><code>Color</code></td>
  488. <td><code>&apos;#fff&apos;</code></td>
  489. <td>Footer font color</td>
  490. </tr>
  491. <tr>
  492. <td><code>footerSpacing</code></td>
  493. <td><code>Number</code></td>
  494. <td><code>2</code></td>
  495. <td>Spacing to add to top and bottom of each fotter line.</td>
  496. </tr>
  497. <tr>
  498. <td><code>footerMarginTop</code></td>
  499. <td><code>Number</code></td>
  500. <td><code>6</code></td>
  501. <td>Margin to add before drawing the footer.</td>
  502. </tr>
  503. <tr>
  504. <td><code>xPadding</code></td>
  505. <td><code>Number</code></td>
  506. <td><code>6</code></td>
  507. <td>Padding to add on left and right of tooltip.</td>
  508. </tr>
  509. <tr>
  510. <td><code>yPadding</code></td>
  511. <td><code>Number</code></td>
  512. <td><code>6</code></td>
  513. <td>Padding to add on top and bottom of tooltip.</td>
  514. </tr>
  515. <tr>
  516. <td><code>caretPadding</code></td>
  517. <td><code>Number</code></td>
  518. <td><code>2</code></td>
  519. <td>Extra distance to move the end of the tooltip arrow away from the tooltip point.</td>
  520. </tr>
  521. <tr>
  522. <td><code>caretSize</code></td>
  523. <td><code>Number</code></td>
  524. <td><code>5</code></td>
  525. <td>Size, in px, of the tooltip arrow.</td>
  526. </tr>
  527. <tr>
  528. <td><code>cornerRadius</code></td>
  529. <td><code>Number</code></td>
  530. <td><code>6</code></td>
  531. <td>Radius of tooltip corner curves.</td>
  532. </tr>
  533. <tr>
  534. <td><code>multiKeyBackground</code></td>
  535. <td><code>Color</code></td>
  536. <td><code>&apos;#fff&apos;</code></td>
  537. <td>Color to draw behind the colored boxes when multiple items are in the tooltip</td>
  538. </tr>
  539. <tr>
  540. <td><code>displayColors</code></td>
  541. <td><code>Boolean</code></td>
  542. <td><code>true</code></td>
  543. <td>if true, color boxes are shown in the tooltip</td>
  544. </tr>
  545. <tr>
  546. <td><code>borderColor</code></td>
  547. <td><code>Color</code></td>
  548. <td><code>&apos;rgba(0,0,0,0)&apos;</code></td>
  549. <td>Color of the border</td>
  550. </tr>
  551. <tr>
  552. <td><code>borderWidth</code></td>
  553. <td><code>Number</code></td>
  554. <td><code>0</code></td>
  555. <td>Size of the border</td>
  556. </tr>
  557. </tbody>
  558. </table>
  559. <h3 id="position-modes">Position Modes</h3>
  560. <p> Possible modes are:</p>
  561. <ul>
  562. <li>&apos;average&apos;</li>
  563. <li>&apos;nearest&apos;</li>
  564. </ul>
  565. <p>&apos;average&apos; mode will place the tooltip at the average position of the items displayed in the tooltip. &apos;nearest&apos; will place the tooltip at the position of the element closest to the event position.</p>
  566. <p>New modes can be defined by adding functions to the Chart.Tooltip.positioners map.</p>
  567. <p>Example:</p>
  568. <pre><code class="lang-javascript"><span class="hljs-comment">/**
  569. * Custom positioner
  570. * @function Chart.Tooltip.positioners.custom
  571. * @param elements {Chart.Element[]} the tooltip elements
  572. * @param eventPosition {Point} the position of the event in canvas coordinates
  573. * @returns {Point} the tooltip position
  574. */</span>
  575. Chart.Tooltip.positioners.custom = <span class="hljs-function"><span class="hljs-keyword">function</span>(<span class="hljs-params">elements, eventPosition</span>) </span>{
  576. <span class="hljs-comment">/** @type {Chart.Tooltip} */</span>
  577. <span class="hljs-keyword">var</span> tooltip = <span class="hljs-keyword">this</span>;
  578. <span class="hljs-comment">/* ... */</span>
  579. <span class="hljs-keyword">return</span> {
  580. x: <span class="hljs-number">0</span>,
  581. y: <span class="hljs-number">0</span>
  582. };
  583. }
  584. </code></pre>
  585. <h3 id="sort-callback">Sort Callback</h3>
  586. <p>Allows sorting of <a href="#tooltip-item-interface">tooltip items</a>. Must implement at minimum a function that can be passed to <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort" target="_blank">Array.prototype.sort</a>. This function can also accept a third parameter that is the data object passed to the chart.</p>
  587. <h3 id="filter-callback">Filter Callback</h3>
  588. <p>Allows filtering of <a href="#tooltip-item-interface">tooltip items</a>. Must implement at minimum a function that can be passed to <a href="https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Array/filter" target="_blank">Array.prototype.filter</a>. This function can also accept a second parameter that is the data object passed to the chart.</p>
  589. <h2 id="tooltip-callbacks">Tooltip Callbacks</h2>
  590. <p>The tooltip label configuration is nested below the tooltip configuration using the <code>callbacks</code> key. The tooltip has the following callbacks for providing text. For all functions, &apos;this&apos; will be the tooltip object created from the Chart.Tooltip constructor.</p>
  591. <p>All functions are called with the same arguments: a <a href="#tooltip-item-interface">tooltip item</a> and the data object passed to the chart. All functions must return either a string or an array of strings. Arrays of strings are treated as multiple lines of text.</p>
  592. <table>
  593. <thead>
  594. <tr>
  595. <th>Name</th>
  596. <th>Arguments</th>
  597. <th>Description</th>
  598. </tr>
  599. </thead>
  600. <tbody>
  601. <tr>
  602. <td><code>beforeTitle</code></td>
  603. <td><code>Array[tooltipItem], data</code></td>
  604. <td>Returns the text to render before the title.</td>
  605. </tr>
  606. <tr>
  607. <td><code>title</code></td>
  608. <td><code>Array[tooltipItem], data</code></td>
  609. <td>Returns text to render as the title of the tooltip.</td>
  610. </tr>
  611. <tr>
  612. <td><code>afterTitle</code></td>
  613. <td><code>Array[tooltipItem], data</code></td>
  614. <td>Returns text to render after the title.</td>
  615. </tr>
  616. <tr>
  617. <td><code>beforeBody</code></td>
  618. <td><code>Array[tooltipItem], data</code></td>
  619. <td>Returns text to render before the body section.</td>
  620. </tr>
  621. <tr>
  622. <td><code>beforeLabel</code></td>
  623. <td><code>tooltipItem, data</code></td>
  624. <td>Returns text to render before an individual label. This will be called for each item in the tooltip.</td>
  625. </tr>
  626. <tr>
  627. <td><code>label</code></td>
  628. <td><code>tooltipItem, data</code></td>
  629. <td>Returns text to render for an individual item in the tooltip.</td>
  630. </tr>
  631. <tr>
  632. <td><code>labelColor</code></td>
  633. <td><code>tooltipItem, chart</code></td>
  634. <td>Returns the colors to render for the tooltip item. <a href="#label-color-callback">more...</a></td>
  635. </tr>
  636. <tr>
  637. <td><code>labelTextColor</code></td>
  638. <td><code>tooltipItem, chart</code></td>
  639. <td>Returns the colors for the text of the label for the tooltip item.</td>
  640. </tr>
  641. <tr>
  642. <td><code>afterLabel</code></td>
  643. <td><code>tooltipItem, data</code></td>
  644. <td>Returns text to render after an individual label.</td>
  645. </tr>
  646. <tr>
  647. <td><code>afterBody</code></td>
  648. <td><code>Array[tooltipItem], data</code></td>
  649. <td>Returns text to render after the body section</td>
  650. </tr>
  651. <tr>
  652. <td><code>beforeFooter</code></td>
  653. <td><code>Array[tooltipItem], data</code></td>
  654. <td>Returns text to render before the footer section.</td>
  655. </tr>
  656. <tr>
  657. <td><code>footer</code></td>
  658. <td><code>Array[tooltipItem], data</code></td>
  659. <td>Returns text to render as the footer of the tooltip.</td>
  660. </tr>
  661. <tr>
  662. <td><code>afterFooter</code></td>
  663. <td><code>Array[tooltipItem], data</code></td>
  664. <td>Text to render after the footer section</td>
  665. </tr>
  666. </tbody>
  667. </table>
  668. <h3 id="label-color-callback">Label Color Callback</h3>
  669. <p>For example, to return a red box for each item in the tooltip you could do:</p>
  670. <pre><code class="lang-javascript"><span class="hljs-keyword">var</span> chart = <span class="hljs-keyword">new</span> Chart(ctx, {
  671. type: <span class="hljs-string">&apos;line&apos;</span>,
  672. data: data,
  673. options: {
  674. tooltips: {
  675. callbacks: {
  676. labelColor: <span class="hljs-function"><span class="hljs-keyword">function</span>(<span class="hljs-params">tooltipItem, chart</span>) </span>{
  677. <span class="hljs-keyword">return</span> {
  678. borderColor: <span class="hljs-string">&apos;rgb(255, 0, 0)&apos;</span>,
  679. backgroundColor: <span class="hljs-string">&apos;rgb(255, 0, 0)&apos;</span>
  680. }
  681. },
  682. labelTextColor:<span class="hljs-function"><span class="hljs-keyword">function</span>(<span class="hljs-params">tooltipItem, chart</span>)</span>{
  683. <span class="hljs-keyword">return</span> <span class="hljs-string">&apos;#543453&apos;</span>;
  684. }
  685. }
  686. }
  687. }
  688. });
  689. </code></pre>
  690. <h3 id="tooltip-item-interface">Tooltip Item Interface</h3>
  691. <p>The tooltip items passed to the tooltip callbacks implement the following interface.</p>
  692. <pre><code class="lang-javascript">{
  693. <span class="hljs-comment">// X Value of the tooltip as a string</span>
  694. xLabel: <span class="hljs-built_in">String</span>,
  695. <span class="hljs-comment">// Y value of the tooltip as a string</span>
  696. yLabel: <span class="hljs-built_in">String</span>,
  697. <span class="hljs-comment">// Index of the dataset the item comes from</span>
  698. datasetIndex: <span class="hljs-built_in">Number</span>,
  699. <span class="hljs-comment">// Index of this data item in the dataset</span>
  700. index: <span class="hljs-built_in">Number</span>,
  701. <span class="hljs-comment">// X position of matching point</span>
  702. x: <span class="hljs-built_in">Number</span>,
  703. <span class="hljs-comment">// Y position of matching point</span>
  704. y: <span class="hljs-built_in">Number</span>,
  705. }
  706. </code></pre>
  707. <h2 id="external-custom-tooltips">External (Custom) Tooltips</h2>
  708. <p>Custom tooltips allow you to hook into the tooltip rendering process so that you can render the tooltip in your own custom way. Generally this is used to create an HTML tooltip instead of an oncanvas one. You can enable custom tooltips in the global or chart configuration like so:</p>
  709. <pre><code class="lang-javascript"><span class="hljs-keyword">var</span> myPieChart = <span class="hljs-keyword">new</span> Chart(ctx, {
  710. type: <span class="hljs-string">&apos;pie&apos;</span>,
  711. data: data,
  712. options: {
  713. tooltips: {
  714. custom: <span class="hljs-function"><span class="hljs-keyword">function</span>(<span class="hljs-params">tooltipModel</span>) </span>{
  715. <span class="hljs-comment">// Tooltip Element</span>
  716. <span class="hljs-keyword">var</span> tooltipEl = <span class="hljs-built_in">document</span>.getElementById(<span class="hljs-string">&apos;chartjs-tooltip&apos;</span>);
  717. <span class="hljs-comment">// Create element on first render</span>
  718. <span class="hljs-keyword">if</span> (!tooltipEl) {
  719. tooltipEl = <span class="hljs-built_in">document</span>.createElement(<span class="hljs-string">&apos;div&apos;</span>);
  720. tooltipEl.id = <span class="hljs-string">&apos;chartjs-tooltip&apos;</span>;
  721. tooltipEl.innerHTML = <span class="hljs-string">&quot;&lt;table&gt;&lt;/table&gt;&quot;</span>
  722. <span class="hljs-built_in">document</span>.body.appendChild(tooltipEl);
  723. }
  724. <span class="hljs-comment">// Hide if no tooltip</span>
  725. <span class="hljs-keyword">if</span> (tooltipModel.opacity === <span class="hljs-number">0</span>) {
  726. tooltipEl.style.opacity = <span class="hljs-number">0</span>;
  727. <span class="hljs-keyword">return</span>;
  728. }
  729. <span class="hljs-comment">// Set caret Position</span>
  730. tooltipEl.classList.remove(<span class="hljs-string">&apos;above&apos;</span>, <span class="hljs-string">&apos;below&apos;</span>, <span class="hljs-string">&apos;no-transform&apos;</span>);
  731. <span class="hljs-keyword">if</span> (tooltipModel.yAlign) {
  732. tooltipEl.classList.add(tooltipModel.yAlign);
  733. } <span class="hljs-keyword">else</span> {
  734. tooltipEl.classList.add(<span class="hljs-string">&apos;no-transform&apos;</span>);
  735. }
  736. <span class="hljs-function"><span class="hljs-keyword">function</span> <span class="hljs-title">getBody</span>(<span class="hljs-params">bodyItem</span>) </span>{
  737. <span class="hljs-keyword">return</span> bodyItem.lines;
  738. }
  739. <span class="hljs-comment">// Set Text</span>
  740. <span class="hljs-keyword">if</span> (tooltipModel.body) {
  741. <span class="hljs-keyword">var</span> titleLines = tooltipModel.title || [];
  742. <span class="hljs-keyword">var</span> bodyLines = tooltipModel.body.map(getBody);
  743. <span class="hljs-keyword">var</span> innerHtml = <span class="hljs-string">&apos;&lt;thead&gt;&apos;</span>;
  744. titleLines.forEach(<span class="hljs-function"><span class="hljs-keyword">function</span>(<span class="hljs-params">title</span>) </span>{
  745. innerHtml += <span class="hljs-string">&apos;&lt;tr&gt;&lt;th&gt;&apos;</span> + title + <span class="hljs-string">&apos;&lt;/th&gt;&lt;/tr&gt;&apos;</span>;
  746. });
  747. innerHtml += <span class="hljs-string">&apos;&lt;/thead&gt;&lt;tbody&gt;&apos;</span>;
  748. bodyLines.forEach(<span class="hljs-function"><span class="hljs-keyword">function</span>(<span class="hljs-params">body, i</span>) </span>{
  749. <span class="hljs-keyword">var</span> colors = tooltipModel.labelColors[i];
  750. <span class="hljs-keyword">var</span> style = <span class="hljs-string">&apos;background:&apos;</span> + colors.backgroundColor;
  751. style += <span class="hljs-string">&apos;; border-color:&apos;</span> + colors.borderColor;
  752. style += <span class="hljs-string">&apos;; border-width: 2px&apos;</span>;
  753. <span class="hljs-keyword">var</span> span = <span class="hljs-string">&apos;&lt;span class=&quot;chartjs-tooltip-key&quot; style=&quot;&apos;</span> + style + <span class="hljs-string">&apos;&quot;&gt;&lt;/span&gt;&apos;</span>;
  754. innerHtml += <span class="hljs-string">&apos;&lt;tr&gt;&lt;td&gt;&apos;</span> + span + body + <span class="hljs-string">&apos;&lt;/td&gt;&lt;/tr&gt;&apos;</span>;
  755. });
  756. innerHtml += <span class="hljs-string">&apos;&lt;/tbody&gt;&apos;</span>;
  757. <span class="hljs-keyword">var</span> tableRoot = tooltipEl.querySelector(<span class="hljs-string">&apos;table&apos;</span>);
  758. tableRoot.innerHTML = innerHtml;
  759. }
  760. <span class="hljs-comment">// `this` will be the overall tooltip</span>
  761. <span class="hljs-keyword">var</span> position = <span class="hljs-keyword">this</span>._chart.canvas.getBoundingClientRect();
  762. <span class="hljs-comment">// Display, position, and set styles for font</span>
  763. tooltipEl.style.opacity = <span class="hljs-number">1</span>;
  764. tooltipEl.style.left = position.left + tooltipModel.caretX + <span class="hljs-string">&apos;px&apos;</span>;
  765. tooltipEl.style.top = position.top + tooltipModel.caretY + <span class="hljs-string">&apos;px&apos;</span>;
  766. tooltipEl.style.fontFamily = tooltipModel._fontFamily;
  767. tooltipEl.style.fontSize = tooltipModel.fontSize;
  768. tooltipEl.style.fontStyle = tooltipModel._fontStyle;
  769. tooltipEl.style.padding = tooltipModel.yPadding + <span class="hljs-string">&apos;px &apos;</span> + tooltipModel.xPadding + <span class="hljs-string">&apos;px&apos;</span>;
  770. }
  771. }
  772. }
  773. });
  774. </code></pre>
  775. <p>See <code>samples/tooltips/line-customTooltips.html</code> for examples on how to get started.</p>
  776. <h2 id="tooltip-model">Tooltip Model</h2>
  777. <p>The tooltip model contains parameters that can be used to render the tooltip.</p>
  778. <pre><code class="lang-javascript">{
  779. <span class="hljs-comment">// The items that we are rendering in the tooltip. See Tooltip Item Interface section</span>
  780. dataPoints: TooltipItem[],
  781. <span class="hljs-comment">// Positioning</span>
  782. xPadding: <span class="hljs-built_in">Number</span>,
  783. yPadding: <span class="hljs-built_in">Number</span>,
  784. xAlign: <span class="hljs-built_in">String</span>,
  785. yAlign: <span class="hljs-built_in">String</span>,
  786. <span class="hljs-comment">// X and Y properties are the top left of the tooltip</span>
  787. x: <span class="hljs-built_in">Number</span>,
  788. y: <span class="hljs-built_in">Number</span>,
  789. width: <span class="hljs-built_in">Number</span>,
  790. height: <span class="hljs-built_in">Number</span>,
  791. <span class="hljs-comment">// Where the tooltip points to</span>
  792. caretX: <span class="hljs-built_in">Number</span>,
  793. caretY: <span class="hljs-built_in">Number</span>,
  794. <span class="hljs-comment">// Body</span>
  795. <span class="hljs-comment">// The body lines that need to be rendered</span>
  796. <span class="hljs-comment">// Each object contains 3 parameters</span>
  797. <span class="hljs-comment">// before: String[] // lines of text before the line with the color square</span>
  798. <span class="hljs-comment">// lines: String[], // lines of text to render as the main item with color square</span>
  799. <span class="hljs-comment">// after: String[], // lines of text to render after the main lines</span>
  800. body: <span class="hljs-built_in">Object</span>[],
  801. <span class="hljs-comment">// lines of text that appear after the title but before the body</span>
  802. beforeBody: <span class="hljs-built_in">String</span>[],
  803. <span class="hljs-comment">// line of text that appear after the body and before the footer</span>
  804. afterBody: <span class="hljs-built_in">String</span>[],
  805. bodyFontColor: Color,
  806. _bodyFontFamily: <span class="hljs-built_in">String</span>,
  807. _bodyFontStyle: <span class="hljs-built_in">String</span>,
  808. _bodyAlign: <span class="hljs-built_in">String</span>,
  809. bodyFontSize: <span class="hljs-built_in">Number</span>,
  810. bodySpacing: <span class="hljs-built_in">Number</span>,
  811. <span class="hljs-comment">// Title</span>
  812. <span class="hljs-comment">// lines of text that form the title</span>
  813. title: <span class="hljs-built_in">String</span>[],
  814. titleFontColor: Color,
  815. _titleFontFamily: <span class="hljs-built_in">String</span>,
  816. _titleFontStyle: <span class="hljs-built_in">String</span>,
  817. titleFontSize: <span class="hljs-built_in">Number</span>,
  818. _titleAlign: <span class="hljs-built_in">String</span>,
  819. titleSpacing: <span class="hljs-built_in">Number</span>,
  820. titleMarginBottom: <span class="hljs-built_in">Number</span>,
  821. <span class="hljs-comment">// Footer</span>
  822. <span class="hljs-comment">// lines of text that form the footer</span>
  823. footer: <span class="hljs-built_in">String</span>[],
  824. footerFontColor: Color,
  825. _footerFontFamily: <span class="hljs-built_in">String</span>,
  826. _footerFontStyle: <span class="hljs-built_in">String</span>,
  827. footerFontSize: <span class="hljs-built_in">Number</span>,
  828. _footerAlign: <span class="hljs-built_in">String</span>,
  829. footerSpacing: <span class="hljs-built_in">Number</span>,
  830. footerMarginTop: <span class="hljs-built_in">Number</span>,
  831. <span class="hljs-comment">// Appearance</span>
  832. caretSize: <span class="hljs-built_in">Number</span>,
  833. cornerRadius: <span class="hljs-built_in">Number</span>,
  834. backgroundColor: Color,
  835. <span class="hljs-comment">// colors to render for each item in body[]. This is the color of the squares in the tooltip</span>
  836. labelColors: Color[],
  837. <span class="hljs-comment">// 0 opacity is a hidden tooltip</span>
  838. opacity: <span class="hljs-built_in">Number</span>,
  839. legendColorBackground: Color,
  840. displayColors: <span class="hljs-built_in">Boolean</span>,
  841. }
  842. </code></pre>
  843. </section>
  844. </div>
  845. <div class="search-results">
  846. <div class="has-results">
  847. <h1 class="search-results-title"><span class='search-results-count'></span> results matching "<span class='search-query'></span>"</h1>
  848. <ul class="search-results-list"></ul>
  849. </div>
  850. <div class="no-results">
  851. <h1 class="search-results-title">No results matching "<span class='search-query'></span>"</h1>
  852. </div>
  853. </div>
  854. </div>
  855. </div>
  856. </div>
  857. </div>
  858. <a href="title.html" class="navigation navigation-prev " aria-label="Previous page: Title">
  859. <i class="fa fa-angle-left"></i>
  860. </a>
  861. <a href="elements.html" class="navigation navigation-next " aria-label="Next page: Elements">
  862. <i class="fa fa-angle-right"></i>
  863. </a>
  864. </div>
  865. <script>
  866. var gitbook = gitbook || [];
  867. gitbook.push(function() {
  868. gitbook.page.hasChanged({"page":{"title":"Tooltip","level":"1.4.5","depth":2,"next":{"title":"Elements","level":"1.4.6","depth":2,"path":"configuration/elements.md","ref":"configuration/elements.md","articles":[]},"previous":{"title":"Title","level":"1.4.4","depth":2,"path":"configuration/title.md","ref":"configuration/title.md","articles":[]},"dir":"ltr"},"config":{"plugins":["-lunr","-search","search-plus","anchorjs","chartjs","ga"],"root":"./docs","styles":{"website":"style.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"pluginsConfig":{"anchorjs":{"icon":"#","placement":"left","visible":"always"},"ga":{"configuration":"auto","token":"UA-28909194-3"},"theme-default":{"styles":{"website":"style.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"showLevel":false},"search-plus":{},"chartjs":{"defaults":null},"highlight":{},"sharing":{"facebook":true,"twitter":true,"google":false,"weibo":false,"instapaper":false,"vk":false,"all":["facebook","google","twitter","weibo","instapaper"]},"fontsettings":{"theme":"white","family":"sans","size":2}},"theme":"default","author":"chartjs","pdf":{"pageNumbers":true,"fontSize":12,"fontFamily":"Arial","paperSize":"a4","chapterMark":"pagebreak","pageBreaksBefore":"/","margin":{"right":62,"left":62,"top":56,"bottom":56}},"structure":{"langs":"LANGS.md","readme":"README.md","glossary":"GLOSSARY.md","summary":"SUMMARY.md"},"variables":{},"gitbook":"3.2.2"},"file":{"path":"configuration/tooltip.md","mtime":"2017-10-28T15:03:49.266Z","type":"markdown"},"gitbook":{"version":"3.2.2","time":"2017-10-28T15:09:53.587Z"},"basePath":"..","book":{"language":""}});
  869. });
  870. </script>
  871. </div>
  872. <script src="../gitbook/gitbook.js"></script>
  873. <script src="../gitbook/theme.js"></script>
  874. <script src="../gitbook/gitbook-plugin-search-plus/jquery.mark.min.js"></script>
  875. <script src="../gitbook/gitbook-plugin-search-plus/search.js"></script>
  876. <script src="https://cdnjs.cloudflare.com/ajax/libs/anchor-js/3.1.1/anchor.min.js"></script>
  877. <script src="../gitbook/gitbook-plugin-anchorjs/anchor-style.js"></script>
  878. <script src="../gitbook/gitbook-plugin-ga/plugin.js"></script>
  879. <script src="../gitbook/gitbook-plugin-sharing/buttons.js"></script>
  880. <script src="../gitbook/gitbook-plugin-fontsettings/fontsettings.js"></script>
  881. </body>
  882. </html>