mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-26 00:01:20 -04:00 
			
		
		
		
	Related: #23590 Reference: https://github.com/webcomponents/polyfills/tree/master/packages/webcomponentsjs It seems that there are some users using old browsers, so the `window.customElements` need polyfill. The Custom Elements would help a lot for Gitea's UI problems, including: * `<span class="js-pretty-number">` * `<time data-format>` So it's worth get polyfill. --------- Co-authored-by: delvh <dev.lh@web.de>
		
			
				
	
	
		
			20 lines
		
	
	
		
			862 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			20 lines
		
	
	
		
			862 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import '@webcomponents/custom-elements'; // automatically adds custom elements for older browsers that don't support it
 | |
| 
 | |
| // this is a Gitea's private HTML component, it converts an absolute or relative URL to an absolute URL with the current origin
 | |
| window.customElements.define('gitea-origin-url', class extends HTMLElement {
 | |
|   connectedCallback() {
 | |
|     const urlStr = this.getAttribute('data-url');
 | |
|     try {
 | |
|       // only process absolute HTTP/HTTPS URL or relative URLs ('/xxx' or '//host/xxx')
 | |
|       if (urlStr.startsWith('http://') || urlStr.startsWith('https://') || urlStr.startsWith('/')) {
 | |
|         const url = new URL(urlStr, window.origin);
 | |
|         url.protocol = window.location.protocol;
 | |
|         url.host = window.location.host;
 | |
|         this.textContent = url.toString();
 | |
|         return;
 | |
|       }
 | |
|     } catch {}
 | |
|     this.textContent = urlStr;
 | |
|   }
 | |
| });
 |