2020-07-13 15:21:19 +02:00
import octiconChevronDown from '../../public/img/svg/octicon-chevron-down.svg' ;
import octiconChevronRight from '../../public/img/svg/octicon-chevron-right.svg' ;
2021-11-16 09:16:05 +01:00
import octiconCopy from '../../public/img/svg/octicon-copy.svg' ;
2022-06-11 16:44:20 +02:00
import octiconClock from '../../public/img/svg/octicon-clock.svg' ;
2022-09-27 07:22:19 +02:00
import octiconDiffAdded from '../../public/img/svg/octicon-diff-added.svg' ;
import octiconDiffModified from '../../public/img/svg/octicon-diff-modified.svg' ;
import octiconDiffRemoved from '../../public/img/svg/octicon-diff-removed.svg' ;
import octiconDiffRenamed from '../../public/img/svg/octicon-diff-renamed.svg' ;
import octiconFileDirectoryFill from '../../public/img/svg/octicon-file-directory-fill.svg' ;
2020-07-12 11:10:56 +02:00
import octiconGitMerge from '../../public/img/svg/octicon-git-merge.svg' ;
import octiconGitPullRequest from '../../public/img/svg/octicon-git-pull-request.svg' ;
import octiconIssueClosed from '../../public/img/svg/octicon-issue-closed.svg' ;
import octiconIssueOpened from '../../public/img/svg/octicon-issue-opened.svg' ;
2021-05-19 05:16:02 +02:00
import octiconKebabHorizontal from '../../public/img/svg/octicon-kebab-horizontal.svg' ;
2020-07-12 11:10:56 +02:00
import octiconLink from '../../public/img/svg/octicon-link.svg' ;
2020-07-13 01:48:48 +02:00
import octiconLock from '../../public/img/svg/octicon-lock.svg' ;
2020-11-29 07:22:04 +01:00
import octiconMilestone from '../../public/img/svg/octicon-milestone.svg' ;
2020-07-17 17:15:12 +02:00
import octiconMirror from '../../public/img/svg/octicon-mirror.svg' ;
2020-11-29 07:22:04 +01:00
import octiconProject from '../../public/img/svg/octicon-project.svg' ;
2020-07-13 01:48:48 +02:00
import octiconRepo from '../../public/img/svg/octicon-repo.svg' ;
import octiconRepoForked from '../../public/img/svg/octicon-repo-forked.svg' ;
import octiconRepoTemplate from '../../public/img/svg/octicon-repo-template.svg' ;
2021-10-11 06:40:03 +08:00
import octiconTriangleDown from '../../public/img/svg/octicon-triangle-down.svg' ;
2022-06-09 19:15:08 +08:00
import octiconFile from '../../public/img/svg/octicon-file.svg' ;
2022-09-27 07:22:19 +02:00
import octiconSidebarExpand from '../../public/img/svg/octicon-sidebar-expand.svg' ;
import octiconSidebarCollapse from '../../public/img/svg/octicon-sidebar-collapse.svg' ;
2020-07-12 11:10:56 +02:00
2020-07-13 01:48:48 +02:00
export const svgs = {
2020-07-13 15:21:19 +02:00
'octicon-chevron-down' : octiconChevronDown ,
'octicon-chevron-right' : octiconChevronRight ,
2021-11-16 09:16:05 +01:00
'octicon-copy' : octiconCopy ,
2022-06-11 16:44:20 +02:00
'octicon-clock' : octiconClock ,
2020-07-12 11:10:56 +02:00
'octicon-git-merge' : octiconGitMerge ,
'octicon-git-pull-request' : octiconGitPullRequest ,
'octicon-issue-closed' : octiconIssueClosed ,
'octicon-issue-opened' : octiconIssueOpened ,
2021-05-19 05:16:02 +02:00
'octicon-kebab-horizontal' : octiconKebabHorizontal ,
2020-07-12 11:10:56 +02:00
'octicon-link' : octiconLink ,
2020-07-13 01:48:48 +02:00
'octicon-lock' : octiconLock ,
2020-11-29 07:22:04 +01:00
'octicon-milestone' : octiconMilestone ,
2020-07-17 17:15:12 +02:00
'octicon-mirror' : octiconMirror ,
2020-11-29 07:22:04 +01:00
'octicon-project' : octiconProject ,
2020-07-13 01:48:48 +02:00
'octicon-repo' : octiconRepo ,
'octicon-repo-forked' : octiconRepoForked ,
'octicon-repo-template' : octiconRepoTemplate ,
2021-10-11 06:40:03 +08:00
'octicon-triangle-down' : octiconTriangleDown ,
2022-06-09 19:15:08 +08:00
'octicon-file' : octiconFile ,
2022-09-27 07:22:19 +02:00
'octicon-file-directory-fill' : octiconFileDirectoryFill ,
'octicon-sidebar-expand' : octiconSidebarExpand ,
'octicon-sidebar-collapse' : octiconSidebarCollapse ,
'octicon-diff-added' : octiconDiffAdded ,
'octicon-diff-modified' : octiconDiffModified ,
'octicon-diff-removed' : octiconDiffRemoved ,
'octicon-diff-renamed' : octiconDiffRenamed ,
2020-07-12 11:10:56 +02:00
} ;
2022-09-27 07:22:19 +02:00
2020-07-12 11:10:56 +02:00
const parser = new DOMParser ( ) ;
const serializer = new XMLSerializer ( ) ;
2020-11-29 07:22:04 +01:00
// retrieve a HTML string for given SVG icon name, size and additional classes
export function svg ( name , size = 16 , className = '' ) {
if ( ! ( name in svgs ) ) return '' ;
if ( size === 16 && ! className ) return svgs [ name ] ;
2020-07-12 11:10:56 +02:00
2020-11-29 07:22:04 +01:00
const document = parser . parseFromString ( svgs [ name ] , 'image/svg+xml' ) ;
const svgNode = document . firstChild ;
if ( size !== 16 ) svgNode . setAttribute ( 'width' , String ( size ) ) ;
if ( size !== 16 ) svgNode . setAttribute ( 'height' , String ( size ) ) ;
if ( className ) svgNode . classList . add ( ... className . split ( /\s+/ ) ) ;
return serializer . serializeToString ( svgNode ) ;
2020-07-12 11:10:56 +02:00
}
2021-07-13 21:09:19 +03:00
2022-10-01 16:26:38 +02:00
export const SvgIcon = {
name : 'SvgIcon' ,
2021-07-13 21:09:19 +03:00
props : {
name : { type : String , required : true } ,
size : { type : Number , default : 16 } ,
className : { type : String , default : '' } ,
} ,
computed : {
svg ( ) {
return svg ( this . name , this . size , this . className ) ;
} ,
} ,
template : ` <span v-html="svg" /> `
2022-10-01 16:26:38 +02:00
} ;