| 
									
										
										
										
											2018-01-13 12:12:17 -08:00
										 |  |  | <:Head> | 
					
						
							|  |  |  |   <title>{{params.instanceName}}</title> | 
					
						
							|  |  |  | </:Head> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <Layout page='settings'> | 
					
						
							|  |  |  |   <SettingsLayout page='settings/instances/{{params.instanceName}}' label="{{params.instanceName}}"> | 
					
						
							|  |  |  |     <h1>{{params.instanceName}}</h1> | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-13 20:07:11 -08:00
										 |  |  |     {{#if instanceUserAccount}} | 
					
						
							| 
									
										
										
										
											2018-01-13 18:59:49 -08:00
										 |  |  |       <h2>Logged in as:</h2> | 
					
						
							|  |  |  |       <div class="current-user"> | 
					
						
							| 
									
										
										
										
											2018-01-13 20:07:11 -08:00
										 |  |  |         <img src="{{instanceUserAccount.avatar}}" /> | 
					
						
							|  |  |  |         <a rel="noopener" target="_blank" href="{{instanceUserAccount.url}}">@{{instanceUserAccount.acct}}</a> | 
					
						
							|  |  |  |         <span class="acct-name">{{instanceUserAccount.display_name}}</span> | 
					
						
							| 
									
										
										
										
											2018-01-13 18:59:49 -08:00
										 |  |  |       </div> | 
					
						
							|  |  |  |       <h2>Theme:</h2> | 
					
						
							|  |  |  |       <form class="theme-chooser"> | 
					
						
							|  |  |  |         {{#each themes as theme}} | 
					
						
							|  |  |  |           <div class="theme-group"> | 
					
						
							|  |  |  |             <input type="radio" id="choice-theme-{{theme.name}}" | 
					
						
							|  |  |  |                    value="{{theme.name}}" checked="$currentTheme === theme.name" | 
					
						
							|  |  |  |                    bind:group="selectedTheme" on:change="onThemeChange()"> | 
					
						
							|  |  |  |             <label for="choice-theme-{{theme.name}}">{{theme.label}}</label> | 
					
						
							|  |  |  |           </div> | 
					
						
							|  |  |  |         {{/each}} | 
					
						
							|  |  |  |       </form> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       <form class="instance-actions"> | 
					
						
							| 
									
										
										
										
											2018-01-13 20:07:11 -08:00
										 |  |  |         <button class="primary" disabled="{{$currentInstance === params.instanceName}}" | 
					
						
							|  |  |  |           on:click="onSwitchToThisInstance()"> | 
					
						
							| 
									
										
										
										
											2018-01-13 18:59:49 -08:00
										 |  |  |           Switch to this instance | 
					
						
							|  |  |  |         </button> | 
					
						
							|  |  |  |         <button>Log out</button> | 
					
						
							|  |  |  |       </form> | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  |     {{/if}} | 
					
						
							| 
									
										
										
										
											2018-01-13 12:12:17 -08:00
										 |  |  |   </SettingsLayout> | 
					
						
							|  |  |  | </Layout> | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  | <style> | 
					
						
							|  |  |  |   .current-user { | 
					
						
							|  |  |  |     padding: 20px; | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							|  |  |  |     font-size: 1.3em; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .current-user img { | 
					
						
							|  |  |  |     width: 64px; | 
					
						
							|  |  |  |     height: 64px; | 
					
						
							|  |  |  |     border-radius: 4px; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .current-user img, .current-user a, .current-user span { | 
					
						
							|  |  |  |     margin-right: 20px; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .theme-chooser { | 
					
						
							|  |  |  |     display: block; | 
					
						
							|  |  |  |     padding: 20px; | 
					
						
							|  |  |  |     line-height: 2em; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .theme-group { | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .theme-chooser label { | 
					
						
							|  |  |  |     margin: 2px 10px 0; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-01-13 18:59:49 -08:00
										 |  |  |   .instance-actions { | 
					
						
							|  |  |  |     width: 100%; | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     justify-content: right; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .instance-actions button { | 
					
						
							| 
									
										
										
										
											2018-01-14 11:22:57 -08:00
										 |  |  |     margin: 0 5px; | 
					
						
							| 
									
										
										
										
											2018-01-13 18:59:49 -08:00
										 |  |  |     flex-basis: 100%; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  | </style> | 
					
						
							| 
									
										
										
										
											2018-01-13 12:12:17 -08:00
										 |  |  | <script> | 
					
						
							|  |  |  |   import { store } from '../../_utils/store' | 
					
						
							|  |  |  |   import Layout from '../../_components/Layout.html' | 
					
						
							|  |  |  |   import SettingsLayout from '../_components/SettingsLayout.html' | 
					
						
							| 
									
										
										
										
											2018-01-13 20:07:11 -08:00
										 |  |  |   import { getThisUserAccount } from '../../_utils/mastodon/user' | 
					
						
							| 
									
										
										
										
											2018-01-13 17:41:15 -08:00
										 |  |  |   import { themes } from '../../_static/themes' | 
					
						
							| 
									
										
										
										
											2018-01-13 18:59:49 -08:00
										 |  |  |   import { switchToTheme } from '../../_utils/themeEngine' | 
					
						
							| 
									
										
										
										
											2018-01-13 12:12:17 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   export default { | 
					
						
							|  |  |  |     components: { | 
					
						
							|  |  |  |       Layout, | 
					
						
							|  |  |  |       SettingsLayout | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  |     store: () => store, | 
					
						
							| 
									
										
										
										
											2018-01-13 17:41:15 -08:00
										 |  |  |     data: () => ({ | 
					
						
							|  |  |  |       themes: themes | 
					
						
							|  |  |  |     }), | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  |     oncreate: async function () { | 
					
						
							| 
									
										
										
										
											2018-01-13 20:07:11 -08:00
										 |  |  |       let instanceName = this.get('params').instanceName | 
					
						
							|  |  |  |       let loggedInInstances = this.store.get('loggedInInstances') | 
					
						
							|  |  |  |       let instanceThemes = this.store.get('instanceThemes') | 
					
						
							|  |  |  |       let instanceData = loggedInInstances[instanceName] | 
					
						
							|  |  |  |       let instanceUserAccount = await getThisUserAccount(instanceName, instanceData.access_token) | 
					
						
							| 
									
										
										
										
											2018-01-13 17:41:15 -08:00
										 |  |  |       this.set({ | 
					
						
							| 
									
										
										
										
											2018-01-13 20:07:11 -08:00
										 |  |  |         instanceUserAccount: instanceUserAccount, | 
					
						
							|  |  |  |         selectedTheme: instanceThemes[instanceName] | 
					
						
							| 
									
										
										
										
											2018-01-13 17:41:15 -08:00
										 |  |  |       }) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     methods: { | 
					
						
							| 
									
										
										
										
											2018-01-13 20:07:11 -08:00
										 |  |  |       onThemeChange() { | 
					
						
							| 
									
										
										
										
											2018-01-13 17:41:15 -08:00
										 |  |  |         let newTheme = this.get('selectedTheme') | 
					
						
							| 
									
										
										
										
											2018-01-13 20:07:11 -08:00
										 |  |  |         let instanceName = this.get('params').instanceName | 
					
						
							| 
									
										
										
										
											2018-01-13 17:41:15 -08:00
										 |  |  |         let instanceThemes = this.store.get('instanceThemes') | 
					
						
							|  |  |  |         instanceThemes[instanceName] = newTheme | 
					
						
							|  |  |  |         this.store.set({instanceThemes: instanceThemes}) | 
					
						
							|  |  |  |         this.store.save() | 
					
						
							| 
									
										
										
										
											2018-01-13 18:59:49 -08:00
										 |  |  |         if (this.get('params').instanceName === this.store.get('currentInstance')) { | 
					
						
							|  |  |  |           switchToTheme(newTheme) | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-01-13 20:07:11 -08:00
										 |  |  |       }, | 
					
						
							|  |  |  |       onSwitchToThisInstance() { | 
					
						
							|  |  |  |         let instanceName = this.get('params').instanceName | 
					
						
							|  |  |  |         let instanceThemes = this.store.get('instanceThemes') | 
					
						
							|  |  |  |         this.store.set({ | 
					
						
							|  |  |  |           currentInstance: instanceName | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         this.store.save() | 
					
						
							|  |  |  |         switchToTheme(instanceThemes[instanceName]) | 
					
						
							| 
									
										
										
										
											2018-01-13 17:41:15 -08:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-01-13 12:12:17 -08:00
										 |  |  |   } | 
					
						
							|  |  |  | </script> |