mirror of
https://github.com/zenorocha/clipboard.js.git
synced 2023-08-10 21:12:48 +03:00
Release v1.4.3
This commit is contained in:
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "clipboard",
|
"name": "clipboard",
|
||||||
"version": "1.4.2",
|
"version": "1.4.3",
|
||||||
"description": "Modern copy to clipboard. No Flash. Just 2kb",
|
"description": "Modern copy to clipboard. No Flash. Just 2kb",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"main": "dist/clipboard.js",
|
"main": "dist/clipboard.js",
|
||||||
|
178
dist/clipboard.js
vendored
178
dist/clipboard.js
vendored
@ -1,62 +1,10 @@
|
|||||||
/*!
|
/*!
|
||||||
* clipboard.js v1.4.2
|
* clipboard.js v1.4.3
|
||||||
* https://zenorocha.github.io/clipboard.js
|
* https://zenorocha.github.io/clipboard.js
|
||||||
*
|
*
|
||||||
* Licensed MIT © Zeno Rocha
|
* Licensed MIT © Zeno Rocha
|
||||||
*/
|
*/
|
||||||
(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.Clipboard = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
|
(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.Clipboard = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
|
||||||
/**
|
|
||||||
* Module dependencies.
|
|
||||||
*/
|
|
||||||
|
|
||||||
var closest = require('closest')
|
|
||||||
, event = require('component-event');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Delegate event `type` to `selector`
|
|
||||||
* and invoke `fn(e)`. A callback function
|
|
||||||
* is returned which may be passed to `.unbind()`.
|
|
||||||
*
|
|
||||||
* @param {Element} el
|
|
||||||
* @param {String} selector
|
|
||||||
* @param {String} type
|
|
||||||
* @param {Function} fn
|
|
||||||
* @param {Boolean} capture
|
|
||||||
* @return {Function}
|
|
||||||
* @api public
|
|
||||||
*/
|
|
||||||
|
|
||||||
// Some events don't bubble, so we want to bind to the capture phase instead
|
|
||||||
// when delegating.
|
|
||||||
var forceCaptureEvents = ['focus', 'blur'];
|
|
||||||
|
|
||||||
exports.bind = function(el, selector, type, fn, capture){
|
|
||||||
if (forceCaptureEvents.indexOf(type) !== -1) capture = true;
|
|
||||||
|
|
||||||
return event.bind(el, type, function(e){
|
|
||||||
var target = e.target || e.srcElement;
|
|
||||||
e.delegateTarget = closest(target, selector, true, el);
|
|
||||||
if (e.delegateTarget) fn.call(el, e);
|
|
||||||
}, capture);
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unbind event `type`'s callback `fn`.
|
|
||||||
*
|
|
||||||
* @param {Element} el
|
|
||||||
* @param {String} type
|
|
||||||
* @param {Function} fn
|
|
||||||
* @param {Boolean} capture
|
|
||||||
* @api public
|
|
||||||
*/
|
|
||||||
|
|
||||||
exports.unbind = function(el, type, fn, capture){
|
|
||||||
if (forceCaptureEvents.indexOf(type) !== -1) capture = true;
|
|
||||||
|
|
||||||
event.unbind(el, type, fn, capture);
|
|
||||||
};
|
|
||||||
|
|
||||||
},{"closest":2,"component-event":4}],2:[function(require,module,exports){
|
|
||||||
var matches = require('matches-selector')
|
var matches = require('matches-selector')
|
||||||
|
|
||||||
module.exports = function (element, selector, checkYoSelf) {
|
module.exports = function (element, selector, checkYoSelf) {
|
||||||
@ -68,7 +16,7 @@ module.exports = function (element, selector, checkYoSelf) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
},{"matches-selector":3}],3:[function(require,module,exports){
|
},{"matches-selector":2}],2:[function(require,module,exports){
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Element prototype.
|
* Element prototype.
|
||||||
@ -109,42 +57,64 @@ function match(el, selector) {
|
|||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
},{}],4:[function(require,module,exports){
|
},{}],3:[function(require,module,exports){
|
||||||
var bind = window.addEventListener ? 'addEventListener' : 'attachEvent',
|
var closest = require('closest');
|
||||||
unbind = window.removeEventListener ? 'removeEventListener' : 'detachEvent',
|
|
||||||
prefix = bind !== 'addEventListener' ? 'on' : '';
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Bind `el` event `type` to `fn`.
|
* Delegate event `type` to `selector`
|
||||||
|
* and invoke `fn(e)`. A callback function
|
||||||
|
* is returned which may be passed to `.unbind()`.
|
||||||
*
|
*
|
||||||
* @param {Element} el
|
* @param {Element} el
|
||||||
|
* @param {String} selector
|
||||||
* @param {String} type
|
* @param {String} type
|
||||||
* @param {Function} fn
|
* @param {Function} fn
|
||||||
* @param {Boolean} capture
|
* @param {Boolean} capture
|
||||||
* @return {Function}
|
* @return {Function}
|
||||||
* @api public
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
exports.bind = function(el, type, fn, capture){
|
exports.bind = function(el, selector, type, fn, capture){
|
||||||
el[bind](prefix + type, fn, capture || false);
|
return el.addEventListener(type, function(e){
|
||||||
return fn;
|
var target = e.target || e.srcElement;
|
||||||
|
e.delegateTarget = closest(target, selector, true, el);
|
||||||
|
if (e.delegateTarget) fn.call(el, e);
|
||||||
|
}, capture);
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Unbind `el` event `type`'s callback `fn`.
|
* Unbind event `type`'s callback `fn`.
|
||||||
*
|
*
|
||||||
* @param {Element} el
|
* @param {Element} el
|
||||||
* @param {String} type
|
* @param {String} type
|
||||||
* @param {Function} fn
|
* @param {Function} fn
|
||||||
* @param {Boolean} capture
|
* @param {Boolean} capture
|
||||||
* @return {Function}
|
|
||||||
* @api public
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
exports.unbind = function(el, type, fn, capture){
|
exports.unbind = function(el, type, fn, capture){
|
||||||
el[unbind](prefix + type, fn, capture || false);
|
el.removeEventListener(type, fn, capture);
|
||||||
return fn;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
},{"closest":1}],4:[function(require,module,exports){
|
||||||
|
function select(element) {
|
||||||
|
var selection = window.getSelection();
|
||||||
|
|
||||||
|
if (element.nodeName === 'INPUT' || element.nodeName === 'TEXTAREA') {
|
||||||
|
element.selectionStart = 0;
|
||||||
|
element.selectionEnd = element.value.length;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
var range = document.createRange();
|
||||||
|
|
||||||
|
range.selectNodeContents(element);
|
||||||
|
selection.removeAllRanges();
|
||||||
|
selection.addRange(range);
|
||||||
|
}
|
||||||
|
|
||||||
|
return selection.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = select;
|
||||||
|
|
||||||
},{}],5:[function(require,module,exports){
|
},{}],5:[function(require,module,exports){
|
||||||
function E () {
|
function E () {
|
||||||
// Keep this empty so it's easier to inherit from
|
// Keep this empty so it's easier to inherit from
|
||||||
@ -154,23 +124,24 @@ function E () {
|
|||||||
E.prototype = {
|
E.prototype = {
|
||||||
on: function (name, callback, ctx) {
|
on: function (name, callback, ctx) {
|
||||||
var e = this.e || (this.e = {});
|
var e = this.e || (this.e = {});
|
||||||
|
|
||||||
(e[name] || (e[name] = [])).push({
|
(e[name] || (e[name] = [])).push({
|
||||||
fn: callback,
|
fn: callback,
|
||||||
ctx: ctx
|
ctx: ctx
|
||||||
});
|
});
|
||||||
|
|
||||||
return this;
|
return this;
|
||||||
},
|
},
|
||||||
|
|
||||||
once: function (name, callback, ctx) {
|
once: function (name, callback, ctx) {
|
||||||
var self = this;
|
var self = this;
|
||||||
var fn = function () {
|
function listener () {
|
||||||
self.off(name, fn);
|
self.off(name, listener);
|
||||||
callback.apply(ctx, arguments);
|
callback.apply(ctx, arguments);
|
||||||
};
|
};
|
||||||
|
|
||||||
return this.on(name, fn, ctx);
|
listener._ = callback
|
||||||
|
return this.on(name, listener, ctx);
|
||||||
},
|
},
|
||||||
|
|
||||||
emit: function (name) {
|
emit: function (name) {
|
||||||
@ -178,11 +149,11 @@ E.prototype = {
|
|||||||
var evtArr = ((this.e || (this.e = {}))[name] || []).slice();
|
var evtArr = ((this.e || (this.e = {}))[name] || []).slice();
|
||||||
var i = 0;
|
var i = 0;
|
||||||
var len = evtArr.length;
|
var len = evtArr.length;
|
||||||
|
|
||||||
for (i; i < len; i++) {
|
for (i; i < len; i++) {
|
||||||
evtArr[i].fn.apply(evtArr[i].ctx, data);
|
evtArr[i].fn.apply(evtArr[i].ctx, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
return this;
|
return this;
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -190,21 +161,22 @@ E.prototype = {
|
|||||||
var e = this.e || (this.e = {});
|
var e = this.e || (this.e = {});
|
||||||
var evts = e[name];
|
var evts = e[name];
|
||||||
var liveEvents = [];
|
var liveEvents = [];
|
||||||
|
|
||||||
if (evts && callback) {
|
if (evts && callback) {
|
||||||
for (var i = 0, len = evts.length; i < len; i++) {
|
for (var i = 0, len = evts.length; i < len; i++) {
|
||||||
if (evts[i].fn !== callback) liveEvents.push(evts[i]);
|
if (evts[i].fn !== callback && evts[i].fn._ !== callback)
|
||||||
|
liveEvents.push(evts[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Remove event from queue to prevent memory leak
|
// Remove event from queue to prevent memory leak
|
||||||
// Suggested by https://github.com/lazd
|
// Suggested by https://github.com/lazd
|
||||||
// Ref: https://github.com/scottcorgan/tiny-emitter/commit/c6ebfaa9bc973b33d110a84a307742b7cf94c953#commitcomment-5024910
|
// Ref: https://github.com/scottcorgan/tiny-emitter/commit/c6ebfaa9bc973b33d110a84a307742b7cf94c953#commitcomment-5024910
|
||||||
|
|
||||||
(liveEvents.length)
|
(liveEvents.length)
|
||||||
? e[name] = liveEvents
|
? e[name] = liveEvents
|
||||||
: delete e[name];
|
: delete e[name];
|
||||||
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -212,18 +184,25 @@ E.prototype = {
|
|||||||
module.exports = E;
|
module.exports = E;
|
||||||
|
|
||||||
},{}],6:[function(require,module,exports){
|
},{}],6:[function(require,module,exports){
|
||||||
/**
|
|
||||||
* Inner class which performs selection from either `text` or `target`
|
|
||||||
* properties and then executes copy or cut operations.
|
|
||||||
*/
|
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
exports.__esModule = true;
|
exports.__esModule = true;
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
||||||
|
|
||||||
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
||||||
|
|
||||||
|
var _select = require('select');
|
||||||
|
|
||||||
|
var _select2 = _interopRequireDefault(_select);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Inner class which performs selection from either `text` or `target`
|
||||||
|
* properties and then executes copy or cut operations.
|
||||||
|
*/
|
||||||
|
|
||||||
var ClipboardAction = (function () {
|
var ClipboardAction = (function () {
|
||||||
/**
|
/**
|
||||||
* @param {Object} options
|
* @param {Object} options
|
||||||
@ -290,11 +269,10 @@ var ClipboardAction = (function () {
|
|||||||
this.fakeElem.style.top = (window.pageYOffset || document.documentElement.scrollTop) + 'px';
|
this.fakeElem.style.top = (window.pageYOffset || document.documentElement.scrollTop) + 'px';
|
||||||
this.fakeElem.setAttribute('readonly', '');
|
this.fakeElem.setAttribute('readonly', '');
|
||||||
this.fakeElem.value = this.text;
|
this.fakeElem.value = this.text;
|
||||||
this.selectedText = this.text;
|
|
||||||
|
|
||||||
document.body.appendChild(this.fakeElem);
|
document.body.appendChild(this.fakeElem);
|
||||||
|
|
||||||
this.fakeElem.select();
|
this.selectedText = _select2['default'](this.fakeElem);
|
||||||
this.copyText();
|
this.copyText();
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -320,19 +298,7 @@ var ClipboardAction = (function () {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
ClipboardAction.prototype.selectTarget = function selectTarget() {
|
ClipboardAction.prototype.selectTarget = function selectTarget() {
|
||||||
if (this.target.nodeName === 'INPUT' || this.target.nodeName === 'TEXTAREA') {
|
this.selectedText = _select2['default'](this.target);
|
||||||
this.target.select();
|
|
||||||
this.selectedText = this.target.value;
|
|
||||||
} else {
|
|
||||||
var range = document.createRange();
|
|
||||||
var selection = window.getSelection();
|
|
||||||
|
|
||||||
selection.removeAllRanges();
|
|
||||||
range.selectNodeContents(this.target);
|
|
||||||
selection.addRange(range);
|
|
||||||
this.selectedText = selection.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
this.copyText();
|
this.copyText();
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -451,7 +417,7 @@ var ClipboardAction = (function () {
|
|||||||
exports['default'] = ClipboardAction;
|
exports['default'] = ClipboardAction;
|
||||||
module.exports = exports['default'];
|
module.exports = exports['default'];
|
||||||
|
|
||||||
},{}],7:[function(require,module,exports){
|
},{"select":4}],7:[function(require,module,exports){
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
exports.__esModule = true;
|
exports.__esModule = true;
|
||||||
@ -466,9 +432,9 @@ var _clipboardAction = require('./clipboard-action');
|
|||||||
|
|
||||||
var _clipboardAction2 = _interopRequireDefault(_clipboardAction);
|
var _clipboardAction2 = _interopRequireDefault(_clipboardAction);
|
||||||
|
|
||||||
var _delegateEvents = require('delegate-events');
|
var _delegate = require('delegate');
|
||||||
|
|
||||||
var _delegateEvents2 = _interopRequireDefault(_delegateEvents);
|
var _delegate2 = _interopRequireDefault(_delegate);
|
||||||
|
|
||||||
var _tinyEmitter = require('tiny-emitter');
|
var _tinyEmitter = require('tiny-emitter');
|
||||||
|
|
||||||
@ -524,7 +490,7 @@ var Clipboard = (function (_Emitter) {
|
|||||||
Clipboard.prototype.delegateClick = function delegateClick(selector) {
|
Clipboard.prototype.delegateClick = function delegateClick(selector) {
|
||||||
var _this = this;
|
var _this = this;
|
||||||
|
|
||||||
this.binding = _delegateEvents2['default'].bind(document.body, selector, 'click', function (e) {
|
this.binding = _delegate2['default'].bind(document.body, selector, 'click', function (e) {
|
||||||
return _this.onClick(e);
|
return _this.onClick(e);
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
@ -535,7 +501,7 @@ var Clipboard = (function (_Emitter) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
Clipboard.prototype.undelegateClick = function undelegateClick() {
|
Clipboard.prototype.undelegateClick = function undelegateClick() {
|
||||||
_delegateEvents2['default'].unbind(document.body, 'click', this.binding);
|
_delegate2['default'].unbind(document.body, 'click', this.binding);
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -617,5 +583,5 @@ function getAttributeValue(suffix, element) {
|
|||||||
exports['default'] = Clipboard;
|
exports['default'] = Clipboard;
|
||||||
module.exports = exports['default'];
|
module.exports = exports['default'];
|
||||||
|
|
||||||
},{"./clipboard-action":6,"delegate-events":1,"tiny-emitter":5}]},{},[7])(7)
|
},{"./clipboard-action":6,"delegate":3,"tiny-emitter":5}]},{},[7])(7)
|
||||||
});
|
});
|
4
dist/clipboard.min.js
vendored
4
dist/clipboard.min.js
vendored
File diff suppressed because one or more lines are too long
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "clipboard",
|
"name": "clipboard",
|
||||||
"version": "1.4.2",
|
"version": "1.4.3",
|
||||||
"description": "Modern copy to clipboard. No Flash. Just 2kb",
|
"description": "Modern copy to clipboard. No Flash. Just 2kb",
|
||||||
"repository": "zenorocha/clipboard.js",
|
"repository": "zenorocha/clipboard.js",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
Reference in New Issue
Block a user