60 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
<template>
 | 
						|
<a class="mk-url" :href="url" :target="target">
 | 
						|
	<span class="schema">{{ schema }}//</span>
 | 
						|
	<span class="hostname">{{ hostname }}</span>
 | 
						|
	<span class="port" v-if="port != ''">:{{ port }}</span>
 | 
						|
	<span class="pathname" v-if="pathname != ''">{{ pathname }}</span>
 | 
						|
	<span class="query">{{ query }}</span>
 | 
						|
	<span class="hash">{{ hash }}</span>
 | 
						|
	<fa icon="external-link-square-alt"/>
 | 
						|
</a>
 | 
						|
</template>
 | 
						|
 | 
						|
<script lang="ts">
 | 
						|
import Vue from 'vue';
 | 
						|
import { toUnicode as decodePunycode } from 'punycode';
 | 
						|
 | 
						|
export default Vue.extend({
 | 
						|
	props: ['url', 'target'],
 | 
						|
	data() {
 | 
						|
		return {
 | 
						|
			schema: null,
 | 
						|
			hostname: null,
 | 
						|
			port: null,
 | 
						|
			pathname: null,
 | 
						|
			query: null,
 | 
						|
			hash: null
 | 
						|
		};
 | 
						|
	},
 | 
						|
	created() {
 | 
						|
		const url = new URL(this.url);
 | 
						|
		this.schema = url.protocol;
 | 
						|
		this.hostname = decodePunycode(url.hostname);
 | 
						|
		this.port = url.port;
 | 
						|
		this.pathname = decodeURIComponent(url.pathname);
 | 
						|
		this.query = decodeURIComponent(url.search);
 | 
						|
		this.hash = decodeURIComponent(url.hash);
 | 
						|
	}
 | 
						|
});
 | 
						|
</script>
 | 
						|
 | 
						|
<style lang="stylus" scoped>
 | 
						|
.mk-url
 | 
						|
	word-break break-all
 | 
						|
	> [data-icon]
 | 
						|
		padding-left 2px
 | 
						|
		font-size .9em
 | 
						|
		font-weight 400
 | 
						|
		font-style normal
 | 
						|
	> .schema
 | 
						|
		opacity 0.5
 | 
						|
	> .hostname
 | 
						|
		font-weight bold
 | 
						|
	> .pathname
 | 
						|
		opacity 0.8
 | 
						|
	> .query
 | 
						|
		opacity 0.5
 | 
						|
	> .hash
 | 
						|
		font-style italic
 | 
						|
</style>
 |