193 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			HTML
		
	
	
			
		
		
	
	
			193 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			HTML
		
	
	
| <!doctype html>
 | |
| <html lang="en">
 | |
|   <head>
 | |
|     <meta charset="utf-8" />
 | |
|     <meta http-equiv="X-UA-Compatible" content="IE=edge" />
 | |
|     <meta
 | |
|       name="viewport"
 | |
|       content="width=device-width, initial-scale=1, user-scalable=no"
 | |
|     />
 | |
| 
 | |
|     <title>File Browser</title>
 | |
| 
 | |
|     <link
 | |
|       rel="icon"
 | |
|       type="image/png"
 | |
|       sizes="32x32"
 | |
|       href="/img/icons/favicon-32x32.png"
 | |
|     />
 | |
|     <link
 | |
|       rel="icon"
 | |
|       type="image/png"
 | |
|       sizes="16x16"
 | |
|       href="/img/icons/favicon-16x16.png"
 | |
|     />
 | |
| 
 | |
|     <!-- Add to home screen for Android and modern mobile browsers -->
 | |
|     <link
 | |
|       rel="manifest"
 | |
|       id="manifestPlaceholder"
 | |
|       crossorigin="use-credentials"
 | |
|     />
 | |
|     <meta name="theme-color" content="#2979ff" />
 | |
| 
 | |
|     <!-- Add to home screen for Safari on iOS/iPadOS -->
 | |
|     <meta name="apple-mobile-web-app-capable" content="yes" />
 | |
|     <meta name="apple-mobile-web-app-status-bar-style" content="black" />
 | |
|     <meta name="apple-mobile-web-app-title" content="assets" />
 | |
|     <link rel="apple-touch-icon" href="/img/icons/apple-touch-icon.png" />
 | |
| 
 | |
|     <!-- Add to home screen for Windows -->
 | |
|     <meta
 | |
|       name="msapplication-TileImage"
 | |
|       content="/img/icons/mstile-144x144.png"
 | |
|     />
 | |
|     <meta name="msapplication-TileColor" content="#2979ff" />
 | |
| 
 | |
|     <!-- Inject Some Variables and generate the manifest json -->
 | |
|     <script>
 | |
|       // We can assign JSON directly
 | |
|       window.FileBrowser = {
 | |
|         AuthMethod: "json",
 | |
|         BaseURL: "",
 | |
|         CSS: false,
 | |
|         Color: "",
 | |
|         DisableExternal: false,
 | |
|         DisableUsedPercentage: false,
 | |
|         EnableExec: true,
 | |
|         EnableThumbs: true,
 | |
|         LoginPage: true,
 | |
|         Name: "",
 | |
|         NoAuth: false,
 | |
|         ReCaptcha: false,
 | |
|         ResizePreview: true,
 | |
|         Signup: false,
 | |
|         StaticURL: "",
 | |
|         Theme: "",
 | |
|         TusSettings: { chunkSize: 10485760, retryCount: 5 },
 | |
|         Version: "(untracked)",
 | |
|       };
 | |
|       // Global function to prepend static url
 | |
|       window.__prependStaticUrl = (url) => {
 | |
|         return `${window.FileBrowser.StaticURL}/${url.replace(/^\/+/, "")}`;
 | |
|       };
 | |
|       var dynamicManifest = {
 | |
|         name: window.FileBrowser.Name || "File Browser",
 | |
|         short_name: window.FileBrowser.Name || "File Browser",
 | |
|         icons: [
 | |
|           {
 | |
|             src: window.__prependStaticUrl(
 | |
|               "/img/icons/android-chrome-192x192.png"
 | |
|             ),
 | |
|             sizes: "192x192",
 | |
|             type: "image/png",
 | |
|           },
 | |
|           {
 | |
|             src: window.__prependStaticUrl(
 | |
|               "/img/icons/android-chrome-512x512.png"
 | |
|             ),
 | |
|             sizes: "512x512",
 | |
|             type: "image/png",
 | |
|           },
 | |
|         ],
 | |
|         start_url: window.location.origin + window.FileBrowser.BaseURL,
 | |
|         display: "standalone",
 | |
|         background_color: "#ffffff",
 | |
|         theme_color: window.FileBrowser.Color || "#455a64",
 | |
|       };
 | |
| 
 | |
|       const stringManifest = JSON.stringify(dynamicManifest);
 | |
|       const blob = new Blob([stringManifest], { type: "application/json" });
 | |
|       const manifestURL = URL.createObjectURL(blob);
 | |
|       document
 | |
|         .querySelector("#manifestPlaceholder")
 | |
|         .setAttribute("href", manifestURL);
 | |
|     </script>
 | |
| 
 | |
|     <style>
 | |
|       #loading {
 | |
|         position: fixed;
 | |
|         top: 0;
 | |
|         left: 0;
 | |
|         width: 100%;
 | |
|         height: 100%;
 | |
|         background: #fff;
 | |
|         z-index: 9999;
 | |
|         transition: 0.1s ease opacity;
 | |
|         -webkit-transition: 0.1s ease opacity;
 | |
|       }
 | |
| 
 | |
|       #loading.done {
 | |
|         opacity: 0;
 | |
|       }
 | |
| 
 | |
|       #loading .spinner {
 | |
|         width: 70px;
 | |
|         text-align: center;
 | |
|         position: fixed;
 | |
|         top: 50%;
 | |
|         left: 50%;
 | |
|         -webkit-transform: translate(-50%, -50%);
 | |
|         transform: translate(-50%, -50%);
 | |
|       }
 | |
| 
 | |
|       #loading .spinner > div {
 | |
|         width: 18px;
 | |
|         height: 18px;
 | |
|         background-color: #333;
 | |
|         border-radius: 100%;
 | |
|         display: inline-block;
 | |
|         -webkit-animation: sk-bouncedelay 1.4s infinite ease-in-out both;
 | |
|         animation: sk-bouncedelay 1.4s infinite ease-in-out both;
 | |
|       }
 | |
| 
 | |
|       #loading .spinner .bounce1 {
 | |
|         -webkit-animation-delay: -0.32s;
 | |
|         animation-delay: -0.32s;
 | |
|       }
 | |
| 
 | |
|       #loading .spinner .bounce2 {
 | |
|         -webkit-animation-delay: -0.16s;
 | |
|         animation-delay: -0.16s;
 | |
|       }
 | |
| 
 | |
|       @-webkit-keyframes sk-bouncedelay {
 | |
|         0%,
 | |
|         80%,
 | |
|         100% {
 | |
|           -webkit-transform: scale(0);
 | |
|         }
 | |
|         40% {
 | |
|           -webkit-transform: scale(1);
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       @keyframes sk-bouncedelay {
 | |
|         0%,
 | |
|         80%,
 | |
|         100% {
 | |
|           -webkit-transform: scale(0);
 | |
|           transform: scale(0);
 | |
|         }
 | |
|         40% {
 | |
|           -webkit-transform: scale(1);
 | |
|           transform: scale(1);
 | |
|         }
 | |
|       }
 | |
|     </style>
 | |
|   </head>
 | |
|   <body>
 | |
|     <div id="app"></div>
 | |
| 
 | |
|     <div id="loading">
 | |
|       <div class="spinner">
 | |
|         <div class="bounce1"></div>
 | |
|         <div class="bounce2"></div>
 | |
|         <div class="bounce3"></div>
 | |
|       </div>
 | |
|     </div>
 | |
| 
 | |
|     <script type="module" src="/src/main.ts"></script>
 | |
|   </body>
 | |
| </html>
 |