| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211 |
- <!doctype html>
- <html lang="en">
- <head>
- <title>Code coverage report for src/components/Button.tsx</title>
- <meta charset="utf-8" />
- <link rel="stylesheet" href="../../prettify.css" />
- <link rel="stylesheet" href="../../base.css" />
- <link rel="shortcut icon" type="image/x-icon" href="../../favicon.png" />
- <meta name="viewport" content="width=device-width, initial-scale=1" />
- <style type='text/css'>
- .coverage-summary .sorter {
- background-image: url(../../sort-arrow-sprite.png);
- }
- </style>
- </head>
-
- <body>
- <div class='wrapper'>
- <div class='pad1'>
- <h1><a href="../../index.html">All files</a> / <a href="index.html">src/components</a> Button.tsx</h1>
- <div class='clearfix'>
-
- <div class='fl pad1y space-right2'>
- <span class="strong">100% </span>
- <span class="quiet">Statements</span>
- <span class='fraction'>30/30</span>
- </div>
-
-
- <div class='fl pad1y space-right2'>
- <span class="strong">100% </span>
- <span class="quiet">Branches</span>
- <span class='fraction'>1/1</span>
- </div>
-
-
- <div class='fl pad1y space-right2'>
- <span class="strong">100% </span>
- <span class="quiet">Functions</span>
- <span class='fraction'>1/1</span>
- </div>
-
-
- <div class='fl pad1y space-right2'>
- <span class="strong">100% </span>
- <span class="quiet">Lines</span>
- <span class='fraction'>30/30</span>
- </div>
-
-
- </div>
- <p class="quiet">
- Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
- </p>
- <template id="filterTemplate">
- <div class="quiet">
- Filter:
- <input type="search" id="fileSearch">
- </div>
- </template>
- </div>
- <div class='status-line high'></div>
- <pre><table class="coverage">
- <tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
- <a name='L2'></a><a href='#L2'>2</a>
- <a name='L3'></a><a href='#L3'>3</a>
- <a name='L4'></a><a href='#L4'>4</a>
- <a name='L5'></a><a href='#L5'>5</a>
- <a name='L6'></a><a href='#L6'>6</a>
- <a name='L7'></a><a href='#L7'>7</a>
- <a name='L8'></a><a href='#L8'>8</a>
- <a name='L9'></a><a href='#L9'>9</a>
- <a name='L10'></a><a href='#L10'>10</a>
- <a name='L11'></a><a href='#L11'>11</a>
- <a name='L12'></a><a href='#L12'>12</a>
- <a name='L13'></a><a href='#L13'>13</a>
- <a name='L14'></a><a href='#L14'>14</a>
- <a name='L15'></a><a href='#L15'>15</a>
- <a name='L16'></a><a href='#L16'>16</a>
- <a name='L17'></a><a href='#L17'>17</a>
- <a name='L18'></a><a href='#L18'>18</a>
- <a name='L19'></a><a href='#L19'>19</a>
- <a name='L20'></a><a href='#L20'>20</a>
- <a name='L21'></a><a href='#L21'>21</a>
- <a name='L22'></a><a href='#L22'>22</a>
- <a name='L23'></a><a href='#L23'>23</a>
- <a name='L24'></a><a href='#L24'>24</a>
- <a name='L25'></a><a href='#L25'>25</a>
- <a name='L26'></a><a href='#L26'>26</a>
- <a name='L27'></a><a href='#L27'>27</a>
- <a name='L28'></a><a href='#L28'>28</a>
- <a name='L29'></a><a href='#L29'>29</a>
- <a name='L30'></a><a href='#L30'>30</a>
- <a name='L31'></a><a href='#L31'>31</a>
- <a name='L32'></a><a href='#L32'>32</a>
- <a name='L33'></a><a href='#L33'>33</a>
- <a name='L34'></a><a href='#L34'>34</a>
- <a name='L35'></a><a href='#L35'>35</a>
- <a name='L36'></a><a href='#L36'>36</a>
- <a name='L37'></a><a href='#L37'>37</a>
- <a name='L38'></a><a href='#L38'>38</a>
- <a name='L39'></a><a href='#L39'>39</a>
- <a name='L40'></a><a href='#L40'>40</a>
- <a name='L41'></a><a href='#L41'>41</a>
- <a name='L42'></a><a href='#L42'>42</a>
- <a name='L43'></a><a href='#L43'>43</a></td><td class="line-coverage quiet"><span class="cline-any cline-yes">1x</span>
- <span class="cline-any cline-neutral"> </span>
- <span class="cline-any cline-neutral"> </span>
- <span class="cline-any cline-neutral"> </span>
- <span class="cline-any cline-neutral"> </span>
- <span class="cline-any cline-neutral"> </span>
- <span class="cline-any cline-neutral"> </span>
- <span class="cline-any cline-neutral"> </span>
- <span class="cline-any cline-yes">1x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-neutral"> </span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-neutral"> </span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-neutral"> </span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-neutral"> </span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-neutral"> </span>
- <span class="cline-any cline-yes">107x</span>
- <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import type { ButtonHTMLAttributes, ReactNode } from 'react';
-
- interface ButtonProps extends ButtonHTMLAttributes<HTMLButtonElement> {
- variant?: 'primary' | 'secondary' | 'danger' | 'ghost';
- size?: 'sm' | 'md' | 'lg';
- children: ReactNode;
- }
-
- export function Button({
- variant = 'primary',
- size = 'md',
- className = '',
- children,
- ...props
- }: ButtonProps) {
- const baseStyles =
- 'inline-flex items-center justify-center font-medium rounded-lg transition-colors focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-offset-bambu-dark disabled:opacity-50 disabled:cursor-not-allowed';
-
- const variants = {
- primary: 'bg-bambu-green hover:bg-bambu-green-light text-white focus:ring-bambu-green',
- secondary:
- 'bg-bambu-dark-tertiary hover:bg-bambu-gray-dark text-white focus:ring-bambu-gray',
- danger: 'bg-red-600 hover:bg-red-700 text-white focus:ring-red-500',
- ghost:
- 'bg-transparent hover:bg-bambu-dark-tertiary text-bambu-gray-light hover:text-white',
- };
-
- const sizes = {
- sm: 'px-3 py-1.5 text-sm gap-1.5 min-h-[44px] md:min-h-0',
- md: 'px-4 py-2 text-sm gap-2 min-h-[44px] md:min-h-0',
- lg: 'px-6 py-3 text-base gap-2 min-h-[48px] md:min-h-0',
- };
-
- return (
- <button
- className={`${baseStyles} ${variants[variant]} ${sizes[size]} ${className}`}
- {...props}
- >
- {children}
- </button>
- );
- }
- </pre></td></tr></table></pre>
- <div class='push'></div><!-- for sticky footer -->
- </div><!-- /wrapper -->
- <div class='footer quiet pad2 space-top1 center small'>
- Code coverage generated by
- <a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
- at 2025-12-11T08:38:30.022Z
- </div>
- <script src="../../prettify.js"></script>
- <script>
- window.onload = function () {
- prettyPrint();
- };
- </script>
- <script src="../../sorter.js"></script>
- <script src="../../block-navigation.js"></script>
- </body>
- </html>
-
|