basic export repository link in settings (#2641)
* basic export repository link in settings Absolutely no prior React experience, and limited TypeScript, so probably doing all kinds of things wrong! I tried to make it a download button instead of link but that didn't work. There is probably a safer way to construct the URL string. I think having the download open in the browser is reasonable, as opposed to an in-app save flow in mobile. But i'm not sure. * Remove appview proxy toggle * Move Settings screen to a subfolder * Add support for the download attribute on links in web * Rewrite ExportRepository modal using ALF * Mobile ui tweaks --------- Co-authored-by: Paul Frazee <pfrazee@gmail.com>
This commit is contained in:
		
							parent
							
								
									b308d7e65d
								
							
						
					
					
						commit
						d7a3246fe3
					
				
					 5 changed files with 161 additions and 96 deletions
				
			
		|  | @ -1,60 +0,0 @@ | |||
| /** | ||||
|  * APP-700 | ||||
|  * | ||||
|  * This is a temporary debug setting we're running on the Web build to | ||||
|  * help the protocol team test some changes. | ||||
|  * | ||||
|  * It should be removed in ~2 weeks. It should only be used on the Web | ||||
|  * version of the app. | ||||
|  */ | ||||
| 
 | ||||
| import {useState, useCallback, useEffect} from 'react' | ||||
| import {BskyAgent} from '@atproto/api' | ||||
| import * as Storage from 'lib/storage' | ||||
| 
 | ||||
| export function useDebugHeaderSetting(agent: BskyAgent): [boolean, () => void] { | ||||
|   const [enabled, setEnabled] = useState<boolean>(false) | ||||
| 
 | ||||
|   useEffect(() => { | ||||
|     async function check() { | ||||
|       if (await isEnabled()) { | ||||
|         setEnabled(true) | ||||
|       } | ||||
|     } | ||||
|     check() | ||||
|   }, []) | ||||
| 
 | ||||
|   const toggle = useCallback(() => { | ||||
|     if (!enabled) { | ||||
|       Storage.saveString('set-header-x-appview-proxy', 'yes') | ||||
|       agent.api.xrpc.setHeader('x-appview-proxy', 'true') | ||||
|       setEnabled(true) | ||||
|     } else { | ||||
|       Storage.remove('set-header-x-appview-proxy') | ||||
|       agent.api.xrpc.unsetHeader('x-appview-proxy') | ||||
|       setEnabled(false) | ||||
|     } | ||||
|   }, [setEnabled, enabled, agent]) | ||||
| 
 | ||||
|   return [enabled, toggle] | ||||
| } | ||||
| 
 | ||||
| export function setDebugHeader(agent: BskyAgent, enabled: boolean) { | ||||
|   if (enabled) { | ||||
|     Storage.saveString('set-header-x-appview-proxy', 'yes') | ||||
|     agent.api.xrpc.setHeader('x-appview-proxy', 'true') | ||||
|   } else { | ||||
|     Storage.remove('set-header-x-appview-proxy') | ||||
|     agent.api.xrpc.unsetHeader('x-appview-proxy') | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| export async function applyDebugHeader(agent: BskyAgent) { | ||||
|   if (await isEnabled()) { | ||||
|     agent.api.xrpc.setHeader('x-appview-proxy', 'true') | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| async function isEnabled() { | ||||
|   return (await Storage.loadString('set-header-x-appview-proxy')) === 'yes' | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue