ant-design-vue
Version:
An enterprise-class UI design language and Vue-based implementation
61 lines • 2.03 kB
JavaScript
import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
var _excluded = ["eventFilter"],
_excluded2 = ["debounce"];
// copy from https://github.dev/vueuse/vueuse
import { unref, watch } from 'vue';
var bypassFilter = function bypassFilter(invoke) {
return invoke();
};
/**
* Create an EventFilter that debounce the events
*
* @param ms
*/
export function debounceFilter(ms) {
var timer;
var filter = function filter(invoke) {
var duration = unref(ms);
if (timer) clearTimeout(timer);
if (duration <= 0) return invoke();
timer = setTimeout(invoke, duration);
};
return filter;
}
/**
* @internal
*/
function createFilterWrapper(filter, fn) {
function wrapper() {
var _this = this;
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
filter(function () {
return fn.apply(_this, args);
}, {
fn: fn,
thisArg: this,
args: args
});
}
return wrapper;
}
// implementation
export function watchWithFilter(source, cb) {
var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
var _options$eventFilter = options.eventFilter,
eventFilter = _options$eventFilter === void 0 ? bypassFilter : _options$eventFilter,
watchOptions = _objectWithoutProperties(options, _excluded);
return watch(source, createFilterWrapper(eventFilter, cb), watchOptions);
}
// implementation
export default function debouncedWatch(source, cb) {
var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
var _options$debounce = options.debounce,
debounce = _options$debounce === void 0 ? 0 : _options$debounce,
watchOptions = _objectWithoutProperties(options, _excluded2);
return watchWithFilter(source, cb, _objectSpread(_objectSpread({}, watchOptions), {}, {
eventFilter: debounceFilter(debounce)
}));
}