| 
									
										
										
										
											2018-10-28 15:28:22 -07:00
										 |  |  | <form class="theme-chooser" aria-label="Choose a theme"> | 
					
						
							|  |  |  |   <div class="theme-groups"> | 
					
						
							|  |  |  |     {#each themeGroups as themeGroup} | 
					
						
							|  |  |  |     <div class="theme-group"> | 
					
						
							| 
									
										
										
										
											2019-02-11 21:04:00 -08:00
										 |  |  |       <h3> | 
					
						
							|  |  |  |         {themeGroup.dark ? 'Dark background' : 'Light background' } | 
					
						
							|  |  |  |       </h3> | 
					
						
							| 
									
										
										
										
											2018-10-28 15:28:22 -07:00
										 |  |  |       {#each themeGroup.themes as theme} | 
					
						
							|  |  |  |       <div class="theme-picker"> | 
					
						
							|  |  |  |         <input type="radio" id="choice-theme-{theme.name}" | 
					
						
							|  |  |  |                value={theme.name} checked="$currentTheme === theme.name" | 
					
						
							|  |  |  |                bind:group="selectedTheme" on:change="onThemeChange()"> | 
					
						
							|  |  |  |         <div class="theme-preview theme-preview-{themeGroup.dark ? 'dark' : 'light'}" | 
					
						
							|  |  |  |              style="background-color: {theme.color};" > | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |         <label class="theme-picker-label" for="choice-theme-{theme.name}"> | 
					
						
							| 
									
										
										
										
											2019-02-11 22:36:31 -08:00
										 |  |  |           {theme.label} {theme.name === DEFAULT_THEME ? '(default)' : ''} | 
					
						
							| 
									
										
										
										
											2018-10-28 15:28:22 -07:00
										 |  |  |         </label> | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |       {/each} | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  |     {/each} | 
					
						
							|  |  |  |   </div> | 
					
						
							|  |  |  | </form> | 
					
						
							|  |  |  | <style> | 
					
						
							|  |  |  |   .theme-chooser { | 
					
						
							|  |  |  |     background: var(--form-bg); | 
					
						
							|  |  |  |     border: 1px solid var(--main-border); | 
					
						
							|  |  |  |     border-radius: 4px; | 
					
						
							|  |  |  |     display: block; | 
					
						
							|  |  |  |     padding: 20px; | 
					
						
							|  |  |  |     line-height: 2em; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .theme-groups { | 
					
						
							|  |  |  |     display: grid; | 
					
						
							|  |  |  |     grid-template-columns: 1fr 1fr; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .theme-group { | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     flex-direction: column; | 
					
						
							|  |  |  |     align-items: flex-start; | 
					
						
							|  |  |  |     flex: 1; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .theme-picker { | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     flex-direction: row; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .theme-picker-label { | 
					
						
							|  |  |  |     margin: 2px 10px 0; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .theme-preview { | 
					
						
							|  |  |  |     width: 1.5em; | 
					
						
							|  |  |  |     height: 1.5em; | 
					
						
							|  |  |  |     box-sizing: border-box; | 
					
						
							|  |  |  |     border-radius: 2px; | 
					
						
							|  |  |  |     margin: 0 2px 0 10px; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .theme-preview-dark { | 
					
						
							|  |  |  |     border: 2px solid #000; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .theme-preview-light { | 
					
						
							|  |  |  |     border: 2px solid #dadada; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-11 21:04:00 -08:00
										 |  |  |   h3 { | 
					
						
							|  |  |  |     font-size: 1.4em; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-28 15:28:22 -07:00
										 |  |  |   @media (max-width: 479px) { | 
					
						
							|  |  |  |     .theme-groups { | 
					
						
							|  |  |  |       grid-template-columns: 1fr; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-02-11 21:04:00 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     h3 { | 
					
						
							|  |  |  |       margin-top: 0.5em; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-10-28 15:28:22 -07:00
										 |  |  |   } | 
					
						
							|  |  |  | </style> | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  |   import { changeTheme } from '../../../_actions/instances' | 
					
						
							|  |  |  |   import { store } from '../../../_store/store' | 
					
						
							|  |  |  |   import { themes } from '../../../_static/themes' | 
					
						
							| 
									
										
										
										
											2019-02-11 21:03:51 -08:00
										 |  |  |   import { DEFAULT_THEME } from '../../../_utils/themeEngine' | 
					
						
							| 
									
										
										
										
											2018-10-28 15:28:22 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   export default { | 
					
						
							|  |  |  |     async oncreate () { | 
					
						
							|  |  |  |       let { instanceName } = this.get() | 
					
						
							|  |  |  |       let { instanceThemes } = this.store.get() | 
					
						
							|  |  |  |       this.set({ | 
					
						
							| 
									
										
										
										
											2019-02-11 21:03:51 -08:00
										 |  |  |         selectedTheme: instanceThemes[instanceName] || DEFAULT_THEME | 
					
						
							| 
									
										
										
										
											2018-10-28 15:28:22 -07:00
										 |  |  |       }) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     store: () => store, | 
					
						
							|  |  |  |     data: () => ({ | 
					
						
							|  |  |  |       themes, | 
					
						
							| 
									
										
										
										
											2019-02-11 22:36:31 -08:00
										 |  |  |       DEFAULT_THEME, | 
					
						
							| 
									
										
										
										
											2019-02-11 21:03:51 -08:00
										 |  |  |       selectedTheme: DEFAULT_THEME | 
					
						
							| 
									
										
										
										
											2018-10-28 15:28:22 -07:00
										 |  |  |     }), | 
					
						
							|  |  |  |     computed: { | 
					
						
							|  |  |  |       themeGroups: ({ themes }) => ([ | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |           dark: false, | 
					
						
							|  |  |  |           themes: themes.filter(_ => !_.dark) | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |           dark: true, | 
					
						
							|  |  |  |           themes: themes.filter(_ => _.dark) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       ]) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     methods: { | 
					
						
							|  |  |  |       onThemeChange () { | 
					
						
							|  |  |  |         let { selectedTheme, instanceName } = this.get() | 
					
						
							|  |  |  |         changeTheme(instanceName, selectedTheme) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-02-11 21:03:51 -08:00
										 |  |  | </script> |