| 
									
										
										
										
											2021-05-05 20:55:49 +00:00
										 |  |  | import { | 
					
						
							|  |  |  |   customElement, | 
					
						
							|  |  |  |   html, | 
					
						
							|  |  |  |   DeesElement, | 
					
						
							|  |  |  |   property, | 
					
						
							|  |  |  |   TemplateResult, | 
					
						
							|  |  |  |   cssManager, | 
					
						
							|  |  |  |   css, | 
					
						
							|  |  |  |   unsafeCSS, | 
					
						
							|  |  |  | } from '@designestate/dees-element'; | 
					
						
							| 
									
										
										
										
											2020-09-13 16:24:48 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | import * as domtools from '@designestate/dees-domtools'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-13 21:52:36 +00:00
										 |  |  | declare global { | 
					
						
							|  |  |  |   interface HTMLElementTagNameMap { | 
					
						
							|  |  |  |     'dees-button': DeesButton; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-13 16:24:48 +00:00
										 |  |  | @customElement('dees-button') | 
					
						
							| 
									
										
										
										
											2020-12-09 14:06:24 +00:00
										 |  |  | export class DeesButton extends DeesElement { | 
					
						
							| 
									
										
										
										
											2021-05-05 20:55:49 +00:00
										 |  |  |   public static demo = () => html`<dees-button></dees-button>`; | 
					
						
							| 
									
										
										
										
											2020-12-09 14:06:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-13 16:24:48 +00:00
										 |  |  |   @property() | 
					
						
							| 
									
										
										
										
											2021-08-25 13:51:55 +02:00
										 |  |  |   public text: string; | 
					
						
							| 
									
										
										
										
											2020-09-13 16:24:48 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   @property() | 
					
						
							| 
									
										
										
										
											2021-08-25 13:51:55 +02:00
										 |  |  |   public eventDetailData: string; | 
					
						
							| 
									
										
										
										
											2020-09-13 16:24:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-24 12:41:01 +02:00
										 |  |  |   @property({ | 
					
						
							|  |  |  |     type: Boolean | 
					
						
							|  |  |  |   }) | 
					
						
							| 
									
										
										
										
											2021-08-25 13:51:55 +02:00
										 |  |  |   public disabled = false; | 
					
						
							| 
									
										
										
										
											2020-09-13 16:24:48 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   @property() | 
					
						
							| 
									
										
										
										
											2021-08-25 13:51:55 +02:00
										 |  |  |   public isHidden = false; | 
					
						
							| 
									
										
										
										
											2020-09-13 16:24:48 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   @property() | 
					
						
							|  |  |  |   public type: 'normal' | 'highlighted' | 'discreet' | 'big' = 'normal'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   constructor() { | 
					
						
							|  |  |  |     super(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-05 20:55:49 +00:00
										 |  |  |   public static styles = [ | 
					
						
							|  |  |  |     cssManager.defaultStyles, | 
					
						
							|  |  |  |     css`
 | 
					
						
							|  |  |  |       :host { | 
					
						
							|  |  |  |         display: block; | 
					
						
							|  |  |  |         box-sizing: border-box; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       :host([hidden]) { | 
					
						
							|  |  |  |         display: none; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       .button { | 
					
						
							|  |  |  |         transition: all 0.2s ease; | 
					
						
							|  |  |  |         font-size: 14px; | 
					
						
							|  |  |  |         display: block; | 
					
						
							|  |  |  |         text-align: center; | 
					
						
							|  |  |  |         background: ${cssManager.bdTheme('#eee', '#333')}; | 
					
						
							| 
									
										
										
										
											2021-08-25 13:51:55 +02:00
										 |  |  |         box-shadow: ${cssManager.bdTheme('0px 0px 5px rgba(0,0,0,0.1)', 'none')}; | 
					
						
							| 
									
										
										
										
											2021-05-05 20:55:49 +00:00
										 |  |  |         border-top: ${cssManager.bdTheme('1px solid #eee', '1px solid #444')}; | 
					
						
							|  |  |  |         border-radius: 2px; | 
					
						
							|  |  |  |         line-height: 40px; | 
					
						
							|  |  |  |         padding: 0px 10px; | 
					
						
							|  |  |  |         min-width: 100px; | 
					
						
							|  |  |  |         user-select: none; | 
					
						
							|  |  |  |         color: ${cssManager.bdTheme('#333', ' #ccc')}; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       .button:hover { | 
					
						
							|  |  |  |         cursor: pointer; | 
					
						
							|  |  |  |         background: #039be5; | 
					
						
							| 
									
										
										
										
											2021-08-24 12:41:01 +02:00
										 |  |  |         border: 0px dashed ${cssManager.bdTheme('#eeeff300', '#66666600')}; | 
					
						
							| 
									
										
										
										
											2021-05-05 20:55:49 +00:00
										 |  |  |         border-top: 1px solid #039be5; | 
					
						
							|  |  |  |         color: #ffffff; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       .button:active { | 
					
						
							|  |  |  |         background: #0277bd; | 
					
						
							|  |  |  |         border-top: 1px solid #0277bd; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       .button.disabled { | 
					
						
							| 
									
										
										
										
											2021-08-24 12:41:01 +02:00
										 |  |  |         background: ${cssManager.bdTheme('#ffffff00', '#11111100')}; | 
					
						
							|  |  |  |         border: 1px dashed ${cssManager.bdTheme('#666666', '#666666')}; | 
					
						
							| 
									
										
										
										
											2021-05-05 20:55:49 +00:00
										 |  |  |         color: #9b9b9e; | 
					
						
							|  |  |  |         cursor: default; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       .button.highlighted { | 
					
						
							|  |  |  |         background: #e4002b; | 
					
						
							|  |  |  |         color: #fff; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       .button.discreet { | 
					
						
							|  |  |  |         background: none; | 
					
						
							|  |  |  |         border: 1px solid #9b9b9e; | 
					
						
							|  |  |  |         color: #000; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       .button.discreet:hover { | 
					
						
							|  |  |  |         background: rgba(0, 0, 0, 0.1); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       .hidden { | 
					
						
							|  |  |  |         display: none; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       .big { | 
					
						
							|  |  |  |         display: inline-block; | 
					
						
							|  |  |  |         line-height: 48px; | 
					
						
							|  |  |  |         font-size: 16px; | 
					
						
							|  |  |  |         padding: 0px 48px; | 
					
						
							|  |  |  |         margin-top: 36px; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     `,
 | 
					
						
							|  |  |  |   ]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-13 16:24:48 +00:00
										 |  |  |   public render(): TemplateResult { | 
					
						
							|  |  |  |     return html`
 | 
					
						
							| 
									
										
										
										
											2021-05-05 20:55:49 +00:00
										 |  |  |       <div | 
					
						
							|  |  |  |         class="button ${this.isHidden ? 'hidden' : 'block'}  ${this.type} ${this.disabled | 
					
						
							|  |  |  |           ? 'disabled' | 
					
						
							|  |  |  |           : null}" | 
					
						
							|  |  |  |         @click="${this.dispatchClick}" | 
					
						
							|  |  |  |       > | 
					
						
							| 
									
										
										
										
											2020-09-13 16:24:48 +00:00
										 |  |  |         ${this.text ? this.text : this.textContent} | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     `;
 | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   public async dispatchClick() { | 
					
						
							|  |  |  |     if (this.disabled) { | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-05 20:55:49 +00:00
										 |  |  |     this.dispatchEvent( | 
					
						
							|  |  |  |       new CustomEvent('clicked', { | 
					
						
							|  |  |  |         detail: { | 
					
						
							|  |  |  |           data: this.eventDetailData, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         bubbles: true, | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2020-09-13 16:24:48 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-05 20:55:49 +00:00
										 |  |  |   public async firstUpdated() { | 
					
						
							| 
									
										
										
										
											2020-09-13 16:24:48 +00:00
										 |  |  |     if (!this.textContent) { | 
					
						
							|  |  |  |       this.textContent = 'Button'; | 
					
						
							|  |  |  |       this.performUpdate(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } |