mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-31 07:17:30 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			195 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			195 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <!DOCTYPE html>
 | |
| <html data-report-errors="{{ $report_errors }}" data-rc="{{ $rc }}" data-user-agent="{{ $user_agent }}" data-login="{{ $login }}" data-signup="{{ $signup }}" data-white-label="{{ $white_label }}">
 | |
| <head>
 | |
|     <!-- Source: https://github.com/invoiceninja/invoiceninja -->
 | |
|     <!-- Version: {{ config('ninja.app_version') }} -->
 | |
|   <meta charset="UTF-8">
 | |
|   <title>{{ $white_label ? "" : config('ninja.app_name')  }}</title>
 | |
|   <meta name="google-signin-client_id" content="{{ config('services.google.client_id') }}">
 | |
|   <link rel="manifest" href="manifest.json?v={{ config('ninja.app_version') }}">
 | |
|   <script src="{{ asset('js/pdf.min.js') }}"></script>
 | |
|   @if(\App\Utils\Ninja::isHosted())
 | |
| 
 | |
|   <!-- Apple OAuth Library -->
 | |
|   <script type="text/javascript" src="https://appleid.cdn-apple.com/appleauth/static/jsapi/appleid/1/en_US/appleid.auth.js"></script>
 | |
| 
 | |
|   <!-- Microsoft OAuth library -->
 | |
|   <script type="text/javascript" 
 | |
|     src="https://alcdn.msauth.net/browser/2.14.2/js/msal-browser.min.js"
 | |
|     integrity="sha384-ggh+EF1aSqm+Y4yvv2n17KpurNcZTeYtUZUvhPziElsstmIEubyEB6AIVpKLuZgr"
 | |
|     crossorigin="anonymous">
 | |
|   </script>
 | |
| 
 | |
|   <!-- G Tag Manager -->
 | |
|   <script>(function(w,d,s,l,i){w[l]=w[l]||[];w[l].push({'gtm.start':
 | |
|   new Date().getTime(),event:'gtm.js'});var f=d.getElementsByTagName(s)[0],
 | |
|   j=d.createElement(s),dl=l!='dataLayer'?'&l='+l:'';j.async=true;j.src=
 | |
|   'https://www.googletagmanager.com/gtm.js?id='+i+dl;f.parentNode.insertBefore(j,f);
 | |
|   })(window,document,'script','dataLayer','GTM-WMJ5W23');</script>
 | |
|   <!-- End G Tag Manager -->
 | |
| 
 | |
|   @endif
 | |
|   <script type="text/javascript">
 | |
|     pdfjsLib.GlobalWorkerOptions.workerSrc = "{{ asset('js/pdf.worker.min.js') }}";
 | |
|   </script>
 | |
|    <script>
 | |
|     window.flutterConfiguration = {
 | |
|       @if(!\App\Utils\Ninja::isHosted())
 | |
|         canvasKitBaseUrl: "{{ $canvas_path }}/canvaskit/"
 | |
|       @endif
 | |
|     };
 | |
|   </script>
 | |
| </head>
 | |
| <body style="background-color:#888888;">
 | |
| 
 | |
|   @if(\App\Utils\Ninja::isHosted())
 | |
|     <!-- Google Tag Manager (noscript) -->
 | |
|     <noscript><iframe src="https://www.googletagmanager.com/ns.html?id=GTM-WMJ5W23"
 | |
|     height="0" width="0" style="display:none;visibility:hidden"></iframe></noscript>
 | |
|     <!-- End Google Tag Manager (noscript) -->
 | |
|   @endif
 | |
| 
 | |
|   <style>
 | |
| 
 | |
|     /* fix for blurry fonts 
 | |
|     flt-glass-pane {
 | |
|         image-rendering: pixelated;
 | |
|     }
 | |
|     */
 | |
|    
 | |
|     /* https://projects.lukehaas.me/css-loaders/ */
 | |
|     .loader,
 | |
|     .loader:before,
 | |
|     .loader:after {
 | |
|       border-radius: 50%;
 | |
|       width: 2.5em;
 | |
|       height: 2.5em;
 | |
|       -webkit-animation-fill-mode: both;
 | |
|       animation-fill-mode: both;
 | |
|       -webkit-animation: load7 1.8s infinite ease-in-out;
 | |
|       animation: load7 1.8s infinite ease-in-out;
 | |
|     }
 | |
|     .loader {
 | |
|       color: #ffffff;
 | |
|       font-size: 10px;
 | |
|       margin: 80px auto;
 | |
|       position: relative;
 | |
|       text-indent: -9999em;
 | |
|       -webkit-transform: translateZ(0);
 | |
|       -ms-transform: translateZ(0);
 | |
|       transform: translateZ(0);
 | |
|       -webkit-animation-delay: -0.40s;
 | |
|       animation-delay: -0.40s;
 | |
|     }
 | |
|     .loader:before,
 | |
|     .loader:after {
 | |
|       content: '';
 | |
|       position: absolute;
 | |
|       top: 0;
 | |
|     }
 | |
|     .loader:before {
 | |
|       left: -3.5em;
 | |
|       -webkit-animation-delay: -0.80s;
 | |
|       animation-delay: -0.80s;
 | |
|     }
 | |
|     .loader:after {
 | |
|       left: 3.5em;
 | |
|     }
 | |
|     @-webkit-keyframes load7 {
 | |
|       0%,
 | |
|       80%,
 | |
|       100% {
 | |
|         box-shadow: 0 2.5em 0 -1.3em;
 | |
|       }
 | |
|       40% {
 | |
|         box-shadow: 0 2.5em 0 0;
 | |
|       }
 | |
|     }
 | |
|     @keyframes load7 {
 | |
|       0%,
 | |
|       80%,
 | |
|       100% {
 | |
|         box-shadow: 0 2.5em 0 -1.3em;
 | |
|       }
 | |
|       40% {
 | |
|         box-shadow: 0 2.5em 0 0;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|   </style>
 | |
| 
 | |
|   <script>
 | |
|     @if (request()->clear_local)
 | |
|       window.onload = function() {
 | |
|         window.localStorage.clear();
 | |
|       }
 | |
|     @endif
 | |
|     
 | |
|     if ('serviceWorker' in navigator) {
 | |
|       window.addEventListener('load', function () {
 | |
|         navigator.serviceWorker.register('flutter_service_worker.js?v={{ config('ninja.app_version') }}');
 | |
|       });
 | |
|     }
 | |
| 
 | |
|     document.addEventListener('DOMContentLoaded', function(event) {
 | |
|       document.getElementById('loader').style.display = 'none';
 | |
|     });
 | |
| 
 | |
|     
 | |
|     function invokeServiceWorkerUpdateFlow() {
 | |
|       // you have a better UI here, reloading is not a great user experince here.
 | |
|       const confirmed = alert('New version of the app is available. Refresh now');
 | |
|       if (confirmed == true) {
 | |
|         window.location.reload();
 | |
|       }
 | |
|     }
 | |
|     async function handleServiceWorker() {
 | |
|       if ('serviceWorker' in navigator) {
 | |
|         // get the ServiceWorkerRegistration instance
 | |
|         const registration = await navigator.serviceWorker.getRegistration();
 | |
|         // (it is also returned from navigator.serviceWorker.register() function)
 | |
| 
 | |
|         if (registration) {
 | |
|           // detect Service Worker update available and wait for it to become installed
 | |
|           registration.addEventListener('updatefound', () => {
 | |
|             if (registration.installing) {
 | |
|               // wait until the new Service worker is actually installed (ready to take over)
 | |
|               registration.installing.addEventListener('statechange', () => {
 | |
|                 if (registration.waiting) {
 | |
|                   // if there's an existing controller (previous Service Worker), show the prompt
 | |
|                   if (navigator.serviceWorker.controller) {
 | |
|                     invokeServiceWorkerUpdateFlow(registration);
 | |
|                   } else {
 | |
|                     // otherwise it's the first install, nothing to do
 | |
|                     console.log('Service Worker initialized for the first time');
 | |
|                   }
 | |
|                 }
 | |
|               });
 | |
|             }
 | |
|           });
 | |
| 
 | |
|           let refreshing = false;
 | |
| 
 | |
|           // detect controller change and refresh the page
 | |
|           navigator.serviceWorker.addEventListener('controllerchange', () => {
 | |
|             if (!refreshing) {
 | |
|               window.location.reload();
 | |
|               refreshing = true;
 | |
|             }
 | |
|           });
 | |
|         }
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     handleServiceWorker();
 | |
|   
 | |
|   </script>
 | |
| 
 | |
|   <script defer src="{{ $path }}?v={{ config('ninja.app_version') }}" type="application/javascript"></script>
 | |
| 
 | |
|   <center style="padding-top: 150px" id="loader">
 | |
|     <div class="loader"></div>
 | |
|   </center>
 | |
| 
 | |
| </body>
 | |
| </html> |