tooltip.html 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. <!doctype html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1">
  6. <link href="../../../dist/css/bootstrap.min.css" rel="stylesheet">
  7. <title>Tooltip</title>
  8. <style>
  9. #target {
  10. border: 1px solid;
  11. width: 100px;
  12. height: 50px;
  13. margin-left: 50px;
  14. transform: rotate(270deg);
  15. margin-top: 100px;
  16. }
  17. </style>
  18. </head>
  19. <body>
  20. <div class="container">
  21. <h1>Tooltip <small>Bootstrap Visual Test</small></h1>
  22. <p class="text-muted">Tight pants next level keffiyeh <a href="#" data-bs-toggle="tooltip" title="Default tooltip">you probably</a> haven't heard of them. Photo booth beard raw denim letterpress vegan messenger bag stumptown. Farm-to-table seitan, mcsweeney's fixie sustainable quinoa 8-bit american apparel <a href="#" data-bs-toggle="tooltip" title="Another tooltip">have a</a> terry richardson vinyl chambray. Beard stumptown, cardigans banh mi lomo thundercats. Tofu biodiesel williamsburg marfa, four loko mcsweeney's cleanse vegan chambray. A really ironic artisan <a href="#" data-bs-toggle="tooltip" title="Another one here too">whatever keytar</a>, scenester farm-to-table banksy Austin <a href="#" data-bs-toggle="tooltip" title="The last tip!">twitter handle</a> freegan cred raw denim single-origin coffee viral.</p>
  23. <hr>
  24. <div class="row">
  25. <p>
  26. <button type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-placement="auto" title="Tooltip on auto">
  27. Tooltip on auto
  28. </button>
  29. <button type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-placement="top" title="Tooltip on top">
  30. Tooltip on top
  31. </button>
  32. <button type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-placement="right" title="Tooltip on right">
  33. Tooltip on end
  34. </button>
  35. <button type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-placement="bottom" title="Tooltip on bottom">
  36. Tooltip on bottom
  37. </button>
  38. <button type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-placement="left" title="Tooltip on left">
  39. Tooltip on start
  40. </button>
  41. </p>
  42. </div>
  43. <div class="row">
  44. <p>
  45. <button type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-placement="left" title="Tooltip with XSS" data-bs-container="<img src=1 onerror=alert(123)>">
  46. Tooltip with XSS
  47. </button>
  48. <button type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-placement="left" title="Tooltip with container (selector)" data-bs-container="#customContainer">
  49. Tooltip with container (selector)
  50. </button>
  51. <button id="tooltipElement" type="button" class="btn btn-secondary" data-bs-placement="left" title="Tooltip with container (element)">
  52. Tooltip with container (element)
  53. </button>
  54. <button type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-html="true" title="<em>Tooltip</em> <u>with</u> <b>HTML</b>">
  55. Tooltip with HTML
  56. </button>
  57. </p>
  58. </div>
  59. <div class="row">
  60. <div class="col-sm-3">
  61. <div id="target" title="Test tooltip on transformed element"></div>
  62. </div>
  63. <div id="shadow" class="pt-5"></div>
  64. </div>
  65. <div id="customContainer"></div>
  66. </div>
  67. <script src="../../../node_modules/@popperjs/core/dist/umd/popper.min.js"></script>
  68. <script src="../../dist/dom/selector-engine.js"></script>
  69. <script src="../../dist/dom/event-handler.js"></script>
  70. <script src="../../dist/dom/manipulator.js"></script>
  71. <script src="../../dist/dom/data.js"></script>
  72. <script src="../../dist/base-component.js"></script>
  73. <script src="../../dist/tooltip.js"></script>
  74. <script>
  75. if (typeof document.body.attachShadow === 'function') {
  76. var shadowRoot = document.getElementById('shadow').attachShadow({ mode: 'open' })
  77. shadowRoot.innerHTML =
  78. '<button type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-placement="top" title="Tooltip on top in a shadow dom">' +
  79. ' Tooltip on top in a shadow dom' +
  80. '</button>' +
  81. '<button id="secondTooltip" type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-placement="top" title="Tooltip on top in a shadow dom with container option">' +
  82. ' Tooltip on top in a shadow dom' +
  83. '</button>'
  84. var firstChildTooltip = new Tooltip(shadowRoot.firstChild)
  85. var secondChildTooltip = new Tooltip(shadowRoot.getElementById('secondTooltip'), {
  86. container: shadowRoot
  87. })
  88. }
  89. [].slice.call(document.querySelectorAll('[data-bs-toggle="tooltip"]'))
  90. .forEach(function (tooltip) {
  91. new Tooltip(tooltip)
  92. })
  93. var tooltipElement = document.getElementById('tooltipElement')
  94. var tooltipElementInstance = new Tooltip(tooltipElement, {
  95. container: document.getElementById('customContainer')
  96. })
  97. var target = document.getElementById('target')
  98. var targetTooltip = new Tooltip(target, {
  99. placement : 'top',
  100. trigger : 'manual'
  101. })
  102. targetTooltip.show()
  103. </script>
  104. </body>
  105. </html>