| 
									
										
										
										
											2018-03-31 18:46:44 -07:00
										 |  |  | <div class="{{backdropClass}}" | 
					
						
							| 
									
										
										
										
											2018-03-03 16:31:00 -08:00
										 |  |  |      tabindex="-1" | 
					
						
							|  |  |  |      data-a11y-dialog-hide | 
					
						
							|  |  |  | ></div> | 
					
						
							| 
									
										
										
										
											2018-03-31 18:46:44 -07:00
										 |  |  | <div class="{{contentsClass}}" | 
					
						
							| 
									
										
										
										
											2018-03-03 16:31:00 -08:00
										 |  |  |      role="dialog" | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |      aria-label="{{label || ''}}" | 
					
						
							| 
									
										
										
										
											2018-03-03 16:31:00 -08:00
										 |  |  |      ref:node | 
					
						
							|  |  |  | > | 
					
						
							| 
									
										
										
										
											2018-02-04 19:15:35 -08:00
										 |  |  |   <div class="modal-dialog-document" role="document" style="background: {{background || '#000'}};"> | 
					
						
							| 
									
										
										
										
											2018-02-27 23:18:07 -08:00
										 |  |  |     <div class="modal-dialog-header"> | 
					
						
							|  |  |  |       {{#if title}} | 
					
						
							|  |  |  |         <h1 class="modal-dialog-title">{{title}}</h1> | 
					
						
							|  |  |  |       {{/if}} | 
					
						
							|  |  |  |       <div class="close-dialog-button-wrapper"> | 
					
						
							| 
									
										
										
										
											2018-03-20 21:26:53 -07:00
										 |  |  |         <button class="close-dialog-button" | 
					
						
							|  |  |  |                 data-a11y-dialog-hide aria-label="Close dialog"> | 
					
						
							| 
									
										
										
										
											2018-03-28 08:56:35 -07:00
										 |  |  |           <svg class="close-dialog-button-svg"> | 
					
						
							|  |  |  |             <use xlink:href="#fa-times" /> | 
					
						
							|  |  |  |           </svg> | 
					
						
							| 
									
										
										
										
											2018-02-27 23:18:07 -08:00
										 |  |  |         </button> | 
					
						
							|  |  |  |       </div> | 
					
						
							| 
									
										
										
										
											2018-02-04 19:15:35 -08:00
										 |  |  |     </div> | 
					
						
							| 
									
										
										
										
											2018-02-22 20:04:19 -08:00
										 |  |  |     <slot></slot> | 
					
						
							| 
									
										
										
										
											2018-02-04 13:49:43 -08:00
										 |  |  |   </div> | 
					
						
							|  |  |  | </div> | 
					
						
							|  |  |  | <style> | 
					
						
							| 
									
										
										
										
											2018-03-31 18:46:44 -07:00
										 |  |  |   :global(.modal-dialog[aria-hidden='true']) { | 
					
						
							| 
									
										
										
										
											2018-02-04 19:15:35 -08:00
										 |  |  |     display: none; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-04-13 09:46:47 -07:00
										 |  |  |   :global(.modal-dialog) { | 
					
						
							| 
									
										
										
										
											2018-02-04 19:15:35 -08:00
										 |  |  |     position: fixed; | 
					
						
							|  |  |  |     z-index: 10000; | 
					
						
							| 
									
										
										
										
											2018-04-13 09:46:47 -07:00
										 |  |  |     top: 0; | 
					
						
							|  |  |  |     right: 0; | 
					
						
							|  |  |  |     bottom: 0; | 
					
						
							|  |  |  |     left: 0; | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     justify-content: center; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .modal-dialog-backdrop { | 
					
						
							|  |  |  |     position: fixed; | 
					
						
							|  |  |  |     z-index: 10010; | 
					
						
							| 
									
										
										
										
											2018-02-04 19:15:35 -08:00
										 |  |  |     left: 0; | 
					
						
							|  |  |  |     right: 0; | 
					
						
							|  |  |  |     bottom: 0; | 
					
						
							|  |  |  |     top: 0; | 
					
						
							|  |  |  |     background: rgba(51, 51, 51, 0.9); | 
					
						
							| 
									
										
										
										
											2018-03-31 18:46:44 -07:00
										 |  |  |   } | 
					
						
							|  |  |  |   .modal-dialog-backdrop.should-animate { | 
					
						
							| 
									
										
										
										
											2018-03-03 16:31:00 -08:00
										 |  |  |     transition: opacity 0.2s linear; | 
					
						
							| 
									
										
										
										
											2018-02-04 19:15:35 -08:00
										 |  |  |   } | 
					
						
							|  |  |  |   .modal-dialog-contents { | 
					
						
							| 
									
										
										
										
											2018-04-13 09:46:47 -07:00
										 |  |  |     z-index: 10020; | 
					
						
							| 
									
										
										
										
											2018-02-04 13:49:43 -08:00
										 |  |  |     padding: 0; | 
					
						
							| 
									
										
										
										
											2018-02-06 09:09:47 -08:00
										 |  |  |     border: 1px solid var(--main-border); | 
					
						
							|  |  |  |     border-radius: 2px; | 
					
						
							| 
									
										
										
										
											2018-02-22 20:04:19 -08:00
										 |  |  |     display: flex; | 
					
						
							|  |  |  |     flex-direction: row; | 
					
						
							|  |  |  |     max-height: calc(100% - 20px); | 
					
						
							| 
									
										
										
										
											2018-03-31 18:46:44 -07:00
										 |  |  |   } | 
					
						
							|  |  |  |   .modal-dialog-contents.should-animate { | 
					
						
							| 
									
										
										
										
											2018-03-03 16:31:00 -08:00
										 |  |  |     transition: opacity 0.2s linear; | 
					
						
							| 
									
										
										
										
											2018-02-04 13:49:43 -08:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-02-22 20:04:19 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-04 19:15:35 -08:00
										 |  |  |   .modal-dialog-document { | 
					
						
							| 
									
										
										
										
											2018-02-04 13:49:43 -08:00
										 |  |  |     display: flex; | 
					
						
							|  |  |  |     flex-direction: column; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							|  |  |  |     justify-content: center; | 
					
						
							| 
									
										
										
										
											2018-02-06 09:09:47 -08:00
										 |  |  |     max-width: calc(100vw - 20px); | 
					
						
							| 
									
										
										
										
											2018-02-22 20:04:19 -08:00
										 |  |  |     flex: 1; | 
					
						
							| 
									
										
										
										
											2018-02-04 13:49:43 -08:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-02-27 23:18:07 -08:00
										 |  |  |   .modal-dialog-header { | 
					
						
							|  |  |  |     width: 100%; | 
					
						
							|  |  |  |     background: var(--nav-bg); | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .modal-dialog-title { | 
					
						
							|  |  |  |     color: var(--nav-text-color); | 
					
						
							|  |  |  |     padding: 2px 0 2px 10px; | 
					
						
							|  |  |  |     margin: 0; | 
					
						
							|  |  |  |     font-size: 1.5em; | 
					
						
							|  |  |  |     white-space: nowrap; | 
					
						
							|  |  |  |     overflow: hidden; | 
					
						
							|  |  |  |     text-overflow: ellipsis; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-02-04 13:49:43 -08:00
										 |  |  |   .close-dialog-button-wrapper { | 
					
						
							| 
									
										
										
										
											2018-02-27 23:18:07 -08:00
										 |  |  |     flex: 1; | 
					
						
							| 
									
										
										
										
											2018-03-27 17:31:17 -07:00
										 |  |  |     display: flex; | 
					
						
							|  |  |  |     justify-content: flex-end; | 
					
						
							| 
									
										
										
										
											2018-02-04 13:49:43 -08:00
										 |  |  |   } | 
					
						
							|  |  |  |   .close-dialog-button { | 
					
						
							| 
									
										
										
										
											2018-03-27 17:31:17 -07:00
										 |  |  |     padding: 0; | 
					
						
							| 
									
										
										
										
											2018-02-04 13:49:43 -08:00
										 |  |  |     background: none; | 
					
						
							|  |  |  |     border: none; | 
					
						
							| 
									
										
										
										
											2018-03-27 17:31:17 -07:00
										 |  |  |     display: flex; | 
					
						
							|  |  |  |     justify-content: center; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							| 
									
										
										
										
											2018-02-04 13:49:43 -08:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-03-28 08:56:35 -07:00
										 |  |  |   .close-dialog-button-svg { | 
					
						
							|  |  |  |     padding: 10px; | 
					
						
							|  |  |  |     fill: var(--button-primary-text); | 
					
						
							|  |  |  |     width: 24px; | 
					
						
							|  |  |  |     height: 24px; | 
					
						
							| 
									
										
										
										
											2018-03-27 17:31:17 -07:00
										 |  |  |     flex: 1; | 
					
						
							| 
									
										
										
										
											2018-02-04 13:49:43 -08:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-03-20 21:26:53 -07:00
										 |  |  |   .muted-style .modal-dialog-header { | 
					
						
							|  |  |  |     background: var(--muted-modal-bg); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .muted-style .close-dialog-button:focus { | 
					
						
							|  |  |  |     outline: 2px solid var(--muted-modal-focus); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .muted-style .close-dialog-button:hover { | 
					
						
							|  |  |  |     background: var(--muted-modal-hover); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .muted-style.modal-dialog-contents { | 
					
						
							|  |  |  |     border: none; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-02-04 13:49:43 -08:00
										 |  |  | </style> | 
					
						
							|  |  |  | <script> | 
					
						
							| 
									
										
										
										
											2018-02-04 19:15:35 -08:00
										 |  |  |   import A11yDialog from 'a11y-dialog' | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |   import { classname } from '../../../_utils/classname' | 
					
						
							|  |  |  |   import { on, emit } from '../../../_utils/eventBus' | 
					
						
							| 
									
										
										
										
											2018-03-31 18:46:44 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-04 13:49:43 -08:00
										 |  |  |   export default { | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |     oncreate() { | 
					
						
							|  |  |  |       let dialogElement = this.refs.node.parentElement | 
					
						
							|  |  |  |       this._a11yDialog = new A11yDialog(dialogElement) | 
					
						
							|  |  |  |       this._a11yDialog.on('hide', () => { | 
					
						
							|  |  |  |         this._a11yDialog.destroy() | 
					
						
							|  |  |  |         emit('destroyDialog', this.get('id')) | 
					
						
							|  |  |  |         requestAnimationFrame(() => document.body.removeChild(dialogElement)) | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |       on('showDialog', this, this.showDialog) | 
					
						
							|  |  |  |       on('closeDialog', this, this.closeDialog) | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2018-03-31 18:46:44 -07:00
										 |  |  |     data: () => ({ | 
					
						
							|  |  |  |       // don't animate if we're showing a modal dialog on top of another modal dialog. it looks ugly | 
					
						
							|  |  |  |       shouldAnimate: !process.browser || document.getElementsByClassName('modal-dialog').length < 2 | 
					
						
							|  |  |  |     }), | 
					
						
							|  |  |  |     computed: { | 
					
						
							|  |  |  |       backdropClass: (fadedIn, shouldAnimate) => { | 
					
						
							|  |  |  |         return classname( | 
					
						
							|  |  |  |           'modal-dialog-backdrop', | 
					
						
							|  |  |  |           !fadedIn && 'hidden', | 
					
						
							|  |  |  |           shouldAnimate && 'should-animate' | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       contentsClass: (fadedIn, muted, shouldAnimate, className) => { | 
					
						
							|  |  |  |         return classname( | 
					
						
							|  |  |  |           'modal-dialog-contents', | 
					
						
							|  |  |  |           !fadedIn && 'hidden', | 
					
						
							|  |  |  |           muted && 'muted-style', | 
					
						
							|  |  |  |           shouldAnimate && 'should-animate', | 
					
						
							|  |  |  |           className | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |     methods: { | 
					
						
							|  |  |  |       showDialog(id) { | 
					
						
							|  |  |  |         if (this.get('id') !== id) { | 
					
						
							|  |  |  |           return | 
					
						
							| 
									
										
										
										
											2018-02-05 09:43:45 -08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |         this._a11yDialog.show() | 
					
						
							|  |  |  |         requestAnimationFrame(() => { | 
					
						
							|  |  |  |           this.set({ fadedIn: true }) | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       closeDialog(id) { | 
					
						
							|  |  |  |         if (this.get('id') !== id) { | 
					
						
							|  |  |  |           return | 
					
						
							| 
									
										
										
										
											2018-02-04 13:49:43 -08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |         setTimeout(() => { // use setTimeout to workaround svelte timing issue | 
					
						
							|  |  |  |           this._a11yDialog.hide() | 
					
						
							|  |  |  |         }, 0) | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-02-04 13:49:43 -08:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | </script> |