Skip to content

Commit 3d853d8

Browse files
committed
Add clipboard JS
1 parent 68246d7 commit 3d853d8

File tree

6 files changed

+45
-27
lines changed

6 files changed

+45
-27
lines changed

_includes/js-selector.html

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -14,7 +14,7 @@
1414

1515
{% if page.layout == 'post' or page.layout == 'page' %}
1616
<!-- image lazy-loading & popup -->
17-
<script src="https://cdn.jsdelivr.net/combine/npm/lozad/dist/lozad.min.js,npm/magnific-popup@1/dist/jquery.magnific-popup.min.js"></script>
17+
<script src="https://cdn.jsdelivr.net/combine/npm/lozad/dist/lozad.min.js,npm/magnific-popup@1/dist/jquery.magnific-popup.min.js,npm/clipboard@2/dist/clipboard.min.js"></script>
1818
{% endif %}
1919

2020
{% if page.layout == 'home'

_javascript/utils/clipboard.js

Lines changed: 40 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,40 @@
1+
/*
2+
* Initial the clipboard.js object, see: <https://github.com/zenorocha/clipboard.js>
3+
*
4+
* Dependencies:
5+
* - popper.js (https://github.com/popperjs/popper-core)
6+
* - clipboard.js (https://github.com/zenorocha/clipboard.js)
7+
*/
8+
$(function() {
9+
const btnSelector = '.code-header>button';
10+
11+
var clipboard = new ClipboardJS(btnSelector, {
12+
target(trigger) {
13+
return trigger.parentNode.nextElementSibling;
14+
}
15+
});
16+
17+
function setTooltip(btn, msg) {
18+
$(btn).tooltip('hide')
19+
.attr('data-original-title', msg)
20+
.tooltip('show');
21+
}
22+
23+
function hideTooltip(btn) {
24+
setTimeout(function() {
25+
$(btn).tooltip('hide');
26+
}, 1000);
27+
}
28+
29+
$(btnSelector).tooltip({
30+
trigger: 'click',
31+
placement: 'left'
32+
});
33+
34+
clipboard.on('success', function(e) {
35+
e.clearSelection();
36+
setTooltip(e.trigger, 'Copied!');
37+
hideTooltip(e.trigger);
38+
});
39+
40+
});

_javascript/utils/copy-link.js

Lines changed: 0 additions & 22 deletions
This file was deleted.

assets/js/dist/page.min.js

Lines changed: 1 addition & 1 deletion
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

0 commit comments

Comments
 (0)