Skip to content

Instantly share code, notes, and snippets.

@TravisMullen
Created August 5, 2017 17:00
Show Gist options
  • Save TravisMullen/84cd0e7a1ff1ec667a46bacb27fc8448 to your computer and use it in GitHub Desktop.
Save TravisMullen/84cd0e7a1ff1ec667a46bacb27fc8448 to your computer and use it in GitHub Desktop.
Bookmark with inline SVG
<template lang="pug">
a.button.bookmark(
@click.prevent='bookmarkAction',
:href='href',
:rel='rel',
:title='title'
)
.svg-icon(
v-once='',
v-html='icon'
)
</template>
<script>
// REQUIRED: npm install svg-inline-loader pug --save-dev
export default {
name: 'bookmark',
methods: {
bookmarkAction () {
// from: https://gist.github.com/oilvier/70abd45d1f2ffc98b568
if (window.sidebar &&
window.sidebar.addPanel) { // Firefox <23
window.sidebar.addPanel(document.title, window.location.href, '')
} else if (window.external &&
('AddFavorite' in window.external)) { // Internet Explorer
window.external.AddFavorite(location.href, document.title)
} else if (window.opera &&
window.print || window.sidebar &&
!(window.sidebar instanceof Node)) { // Opera <15 and Firefox >23
/**
* For Firefox <23 and Opera <15, no need for JS to add to bookmarks
* The only thing needed is a `title` and a `rel="sidebar"`
* To ensure that the bookmarked URL doesn't have a complementary `#` from our trigger's href
* we force the current URL
*/
this.rel = 'sidebar'
this.title = document.title
this.href = window.location.href
return true
} else { // For the other browsers (mainly WebKit) we use a simple alert to inform users that they can add to bookmarks with ctrl+D/cmd+D
alert('You can add this page to your bookmarks by pressing ' + (navigator.userAgent.toLowerCase().indexOf('mac') !== -1 ? 'Command/Cmd' : 'CTRL') + ' + D on your keyboard.')
}
// If you have something in the `href` of your trigger
return false
}
},
data () {
return {
icon: require(`!svg-inline-loader!@/assets/icons/star-full.svg`),
title: 'Add to bookmarks.',
rel: '',
href: '#bookmark'
}
}
}
</script>
<style lang="scss" scoped>
// call settings for global SCSS access
// @import '~@/styles/settings';
// .bookmark {
// styles
// .button {
// .svg-icon {}
// }
// .bookmark {}
// }
</style>
@TravisMullen
Copy link
Author

Extended from a bookmark gist by @oilvier.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment