| 
									
										
										
										
											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}}"> | 
					
						
							| 
									
										
										
										
											2018-01-20 15:37:40 -08:00
										 |  |  |     <h1 class="instance-name-h1">{{params.instanceName}}</h1> | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-21 17:18:56 -08:00
										 |  |  |     {{#if verifyCredentials}} | 
					
						
							| 
									
										
										
										
											2018-01-13 18:59:49 -08:00
										 |  |  |       <h2>Logged in as:</h2> | 
					
						
							| 
									
										
										
										
											2018-01-14 11:34:53 -08:00
										 |  |  |       <div class="acct-current-user"> | 
					
						
							| 
									
										
										
										
											2018-02-08 17:56:20 -08:00
										 |  |  |         <Avatar account="{{verifyCredentials}}" className="acct-avatar" size="big"/> | 
					
						
							| 
									
										
										
										
											2018-01-28 19:01:51 -08:00
										 |  |  |         <ExternalLink class="acct-handle" | 
					
						
							|  |  |  |                       href="{{verifyCredentials.url}}"> | 
					
						
							|  |  |  |           {{'@' + verifyCredentials.acct}} | 
					
						
							|  |  |  |         </ExternalLink> | 
					
						
							| 
									
										
										
										
											2018-01-21 17:18:56 -08:00
										 |  |  |         <span class="acct-display-name">{{verifyCredentials.display_name}}</span> | 
					
						
							| 
									
										
										
										
											2018-01-13 18:59:49 -08:00
										 |  |  |       </div> | 
					
						
							|  |  |  |       <h2>Theme:</h2> | 
					
						
							| 
									
										
										
										
											2018-01-18 23:37:43 -08:00
										 |  |  |       <form class="theme-chooser" aria-label="Choose a theme"> | 
					
						
							| 
									
										
										
										
											2018-01-13 18:59:49 -08:00
										 |  |  |         {{#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> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-18 23:37:43 -08:00
										 |  |  |       <form class="instance-actions" aria-label="Switch to or log out of this instance"> | 
					
						
							| 
									
										
										
										
											2018-01-21 18:48:21 -08:00
										 |  |  |         {{#if $loggedInInstancesInOrder.length > 1 && $currentInstance !== params.instanceName}} | 
					
						
							|  |  |  |           <button class="primary" | 
					
						
							| 
									
										
										
										
											2018-01-21 18:36:40 -08:00
										 |  |  |             on:click="onSwitchToThisInstance(event)"> | 
					
						
							| 
									
										
										
										
											2018-01-21 18:48:21 -08:00
										 |  |  |             Switch to this instance | 
					
						
							| 
									
										
										
										
											2018-01-14 12:00:22 -08:00
										 |  |  |           </button> | 
					
						
							|  |  |  |         {{/if}} | 
					
						
							| 
									
										
										
										
											2018-01-21 18:36:40 -08:00
										 |  |  |         <button on:click="onLogOut(event)">Log out</button> | 
					
						
							| 
									
										
										
										
											2018-01-13 18:59:49 -08:00
										 |  |  |       </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> | 
					
						
							| 
									
										
										
										
											2018-01-14 11:34:53 -08:00
										 |  |  |   .acct-current-user { | 
					
						
							| 
									
										
										
										
											2018-01-14 12:00:22 -08:00
										 |  |  |     background: var(--form-bg); | 
					
						
							|  |  |  |     border: 1px solid var(--main-border); | 
					
						
							|  |  |  |     border-radius: 4px; | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  |     padding: 20px; | 
					
						
							| 
									
										
										
										
											2018-01-14 11:34:53 -08:00
										 |  |  |     display: grid; | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  |     align-items: center; | 
					
						
							|  |  |  |     font-size: 1.3em; | 
					
						
							| 
									
										
										
										
											2018-01-14 11:34:53 -08:00
										 |  |  |     grid-template-areas: | 
					
						
							|  |  |  |         "avatar handle" | 
					
						
							|  |  |  |         "avatar display-name"; | 
					
						
							| 
									
										
										
										
											2018-02-08 17:56:20 -08:00
										 |  |  |     grid-template-columns: min-content 1fr; | 
					
						
							|  |  |  |     grid-column-gap: 20px; | 
					
						
							|  |  |  |     grid-row-gap: 10px; | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-02-08 17:56:20 -08:00
										 |  |  |   :global(.acct-avatar) { | 
					
						
							| 
									
										
										
										
											2018-01-14 11:34:53 -08:00
										 |  |  |     grid-area: avatar; | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-01-28 19:01:51 -08:00
										 |  |  |   :global(.acct-handle) { | 
					
						
							| 
									
										
										
										
											2018-01-14 11:34:53 -08:00
										 |  |  |     grid-area: handle; | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  |   } | 
					
						
							|  |  |  |   .theme-chooser { | 
					
						
							| 
									
										
										
										
											2018-01-14 12:00:22 -08:00
										 |  |  |     background: var(--form-bg); | 
					
						
							|  |  |  |     border: 1px solid var(--main-border); | 
					
						
							|  |  |  |     border-radius: 4px; | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  |     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; | 
					
						
							| 
									
										
										
										
											2018-01-14 12:00:22 -08:00
										 |  |  |     margin: 20px 0; | 
					
						
							| 
									
										
										
										
											2018-01-13 18:59:49 -08:00
										 |  |  |   } | 
					
						
							|  |  |  |   .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-20 15:37:40 -08:00
										 |  |  |   .instance-name-h1 { | 
					
						
							|  |  |  |     white-space: nowrap; | 
					
						
							|  |  |  |     overflow: hidden; | 
					
						
							|  |  |  |     text-overflow: ellipsis; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  | </style> | 
					
						
							| 
									
										
										
										
											2018-01-13 12:12:17 -08:00
										 |  |  | <script> | 
					
						
							| 
									
										
										
										
											2018-01-28 13:09:39 -08:00
										 |  |  |   import { store } from '../../_store/store' | 
					
						
							| 
									
										
										
										
											2018-01-13 12:12:17 -08:00
										 |  |  |   import Layout from '../../_components/Layout.html' | 
					
						
							|  |  |  |   import SettingsLayout from '../_components/SettingsLayout.html' | 
					
						
							| 
									
										
										
										
											2018-01-28 19:01:51 -08:00
										 |  |  |   import ExternalLink from '../../_components/ExternalLink.html' | 
					
						
							| 
									
										
										
										
											2018-02-08 17:56:20 -08:00
										 |  |  |   import Avatar from '../../_components/Avatar.html' | 
					
						
							| 
									
										
										
										
											2018-02-05 09:43:45 -08:00
										 |  |  |   import { showConfirmationDialog } from '../../_components/dialog/showConfirmationDialog' | 
					
						
							| 
									
										
										
										
											2018-01-27 14:45:51 -08:00
										 |  |  |   import { | 
					
						
							|  |  |  |     changeTheme, | 
					
						
							|  |  |  |     switchToInstance, | 
					
						
							|  |  |  |     logOutOfInstance, | 
					
						
							|  |  |  |     updateVerifyCredentialsForInstance | 
					
						
							| 
									
										
										
										
											2018-02-08 17:51:48 -08:00
										 |  |  |   } from '../../_actions/instances' | 
					
						
							| 
									
										
										
										
											2018-01-13 17:41:15 -08:00
										 |  |  |   import { themes } from '../../_static/themes' | 
					
						
							| 
									
										
										
										
											2018-01-13 12:12:17 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   export default { | 
					
						
							|  |  |  |     components: { | 
					
						
							|  |  |  |       Layout, | 
					
						
							| 
									
										
										
										
											2018-01-28 19:01:51 -08:00
										 |  |  |       SettingsLayout, | 
					
						
							| 
									
										
										
										
											2018-02-08 17:56:20 -08:00
										 |  |  |       ExternalLink, | 
					
						
							|  |  |  |       Avatar | 
					
						
							| 
									
										
										
										
											2018-01-13 12:12:17 -08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2018-01-13 14:19:51 -08:00
										 |  |  |     store: () => store, | 
					
						
							| 
									
										
										
										
											2018-01-13 17:41:15 -08:00
										 |  |  |     data: () => ({ | 
					
						
							| 
									
										
										
										
											2018-01-27 14:45:51 -08:00
										 |  |  |       themes: themes, | 
					
						
							| 
									
										
										
										
											2018-01-13 17:41:15 -08:00
										 |  |  |     }), | 
					
						
							| 
									
										
										
										
											2018-01-27 14:45:51 -08:00
										 |  |  |     async oncreate() { | 
					
						
							|  |  |  |       let instanceName = this.get('instanceName') | 
					
						
							|  |  |  |       await updateVerifyCredentialsForInstance(instanceName) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     computed: { | 
					
						
							|  |  |  |       instanceName: (params) => params.instanceName, | 
					
						
							|  |  |  |       selectedTheme: ($instanceThemes, instanceName) => $instanceThemes[instanceName], | 
					
						
							|  |  |  |       verifyCredentials: ($verifyCredentials, instanceName) => $verifyCredentials && $verifyCredentials[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-27 14:45:51 -08:00
										 |  |  |         let instanceName = this.get('instanceName') | 
					
						
							|  |  |  |         changeTheme(instanceName,  newTheme) | 
					
						
							| 
									
										
										
										
											2018-01-13 20:07:11 -08:00
										 |  |  |       }, | 
					
						
							| 
									
										
										
										
											2018-01-21 18:36:40 -08:00
										 |  |  |       onSwitchToThisInstance(e) { | 
					
						
							|  |  |  |         e.preventDefault() | 
					
						
							| 
									
										
										
										
											2018-01-27 14:45:51 -08:00
										 |  |  |         let instanceName = this.get('instanceName') | 
					
						
							|  |  |  |         switchToInstance(instanceName) | 
					
						
							| 
									
										
										
										
											2018-01-14 12:00:22 -08:00
										 |  |  |       }, | 
					
						
							| 
									
										
										
										
											2018-01-21 18:36:40 -08:00
										 |  |  |       onLogOut(e) { | 
					
						
							|  |  |  |         e.preventDefault() | 
					
						
							| 
									
										
										
										
											2018-01-27 14:45:51 -08:00
										 |  |  |         let instanceName = this.get('instanceName') | 
					
						
							| 
									
										
										
										
											2018-02-05 09:43:45 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         showConfirmationDialog({ | 
					
						
							|  |  |  |           text: `Log out of ${instanceName}?`, | 
					
						
							|  |  |  |           onPositive() { | 
					
						
							|  |  |  |             logOutOfInstance(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> |