| 
									
										
										
										
											2018-02-27 23:18:07 -08:00
										 |  |  | {{#if delegateKey}} | 
					
						
							| 
									
										
										
										
											2018-01-28 12:51:48 -08:00
										 |  |  |   <button type="button" | 
					
						
							|  |  |  |           aria-label="{{label}}" | 
					
						
							| 
									
										
										
										
											2018-02-27 23:18:07 -08:00
										 |  |  |           aria-pressed="{{pressable ? !!pressed : ''}}" | 
					
						
							| 
									
										
										
										
											2018-02-24 14:49:28 -08:00
										 |  |  |           class="{{computedClass}}" | 
					
						
							| 
									
										
										
										
											2018-02-27 23:18:07 -08:00
										 |  |  |           :disabled | 
					
						
							| 
									
										
										
										
											2018-03-16 19:04:48 -07:00
										 |  |  |           delegate-key="{{delegateKey}}" | 
					
						
							|  |  |  |           focus-key="{{focusKey || ''}}" > | 
					
						
							| 
									
										
										
										
											2018-03-16 08:42:10 -07:00
										 |  |  |     <svg class="icon-button-svg"> | 
					
						
							| 
									
										
										
										
											2018-01-28 12:51:48 -08:00
										 |  |  |       <use xlink:href="{{href}}" /> | 
					
						
							|  |  |  |     </svg> | 
					
						
							|  |  |  |   </button> | 
					
						
							|  |  |  | {{else}} | 
					
						
							|  |  |  |   <button type="button" | 
					
						
							|  |  |  |           aria-label="{{label}}" | 
					
						
							| 
									
										
										
										
											2018-02-27 23:18:07 -08:00
										 |  |  |           aria-pressed="{{pressable ? !!pressed : ''}}" | 
					
						
							| 
									
										
										
										
											2018-02-24 14:49:28 -08:00
										 |  |  |           class="{{computedClass}}" | 
					
						
							| 
									
										
										
										
											2018-03-16 19:04:48 -07:00
										 |  |  |           focus-key="{{focusKey || ''}}" | 
					
						
							| 
									
										
										
										
											2018-02-27 23:18:07 -08:00
										 |  |  |           :disabled | 
					
						
							|  |  |  |           on:click > | 
					
						
							| 
									
										
										
										
											2018-03-16 08:42:10 -07:00
										 |  |  |     <svg class="icon-button-svg"> | 
					
						
							| 
									
										
										
										
											2018-01-28 12:51:48 -08:00
										 |  |  |       <use xlink:href="{{href}}" /> | 
					
						
							|  |  |  |     </svg> | 
					
						
							|  |  |  |   </button> | 
					
						
							|  |  |  | {{/if}} | 
					
						
							|  |  |  | <style> | 
					
						
							| 
									
										
										
										
											2018-03-16 08:42:10 -07:00
										 |  |  |   .icon-button { | 
					
						
							| 
									
										
										
										
											2018-01-28 12:51:48 -08:00
										 |  |  |     padding: 6px 10px; | 
					
						
							|  |  |  |     background: none; | 
					
						
							|  |  |  |     border: none; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-16 08:42:10 -07:00
										 |  |  |   .icon-button-svg { | 
					
						
							| 
									
										
										
										
											2018-01-28 12:51:48 -08:00
										 |  |  |     width: 24px; | 
					
						
							|  |  |  |     height: 24px; | 
					
						
							|  |  |  |     fill: var(--action-button-fill-color); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-16 08:42:10 -07:00
										 |  |  |   .icon-button.big-icon .icon-button-svg { | 
					
						
							| 
									
										
										
										
											2018-01-28 12:51:48 -08:00
										 |  |  |     width: 32px; | 
					
						
							|  |  |  |     height: 32px; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-16 08:42:10 -07:00
										 |  |  |   .icon-button:hover .icon-button-svg { | 
					
						
							| 
									
										
										
										
											2018-01-28 12:51:48 -08:00
										 |  |  |     fill: var(--action-button-fill-color-hover); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-16 08:42:10 -07:00
										 |  |  |   .icon-button.not-pressable:active .icon-button-svg { | 
					
						
							| 
									
										
										
										
											2018-01-28 12:51:48 -08:00
										 |  |  |     fill: var(--action-button-fill-color-active); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-16 08:42:10 -07:00
										 |  |  |   .icon-button.pressed .icon-button-svg { | 
					
						
							| 
									
										
										
										
											2018-01-28 12:51:48 -08:00
										 |  |  |     fill: var(--action-button-fill-color-pressed) | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-16 08:42:10 -07:00
										 |  |  |   .icon-button.pressed:hover .icon-button-svg { | 
					
						
							| 
									
										
										
										
											2018-01-28 12:51:48 -08:00
										 |  |  |     fill: var(--action-button-fill-color-pressed-hover); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-16 08:42:10 -07:00
										 |  |  |   .icon-button.pressed:active .icon-button-svg { | 
					
						
							| 
									
										
										
										
											2018-01-28 12:51:48 -08:00
										 |  |  |     fill: var(--action-button-fill-color-pressed-active); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-02-24 14:49:28 -08:00
										 |  |  | </style> | 
					
						
							|  |  |  | <script> | 
					
						
							| 
									
										
										
										
											2018-03-14 18:52:33 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   import { classname } from '../_utils/classname' | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-24 14:49:28 -08:00
										 |  |  |   export default { | 
					
						
							|  |  |  |     computed: { | 
					
						
							| 
									
										
										
										
											2018-03-02 21:55:04 -08:00
										 |  |  |       computedClass: (pressable, pressed, big, className) => { | 
					
						
							| 
									
										
										
										
											2018-03-14 18:52:33 -07:00
										 |  |  |         return classname( | 
					
						
							| 
									
										
										
										
											2018-02-24 14:49:28 -08:00
										 |  |  |           'icon-button', | 
					
						
							|  |  |  |           !pressable && 'not-pressable', | 
					
						
							|  |  |  |           pressed && 'pressed', | 
					
						
							|  |  |  |           big && 'big-icon', | 
					
						
							| 
									
										
										
										
											2018-03-02 21:55:04 -08:00
										 |  |  |           className | 
					
						
							| 
									
										
										
										
											2018-03-14 18:52:33 -07:00
										 |  |  |         ) | 
					
						
							| 
									
										
										
										
											2018-02-24 14:49:28 -08:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | </script> |