You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
45 lines
871 B
45 lines
871 B
'use strict';
|
|
|
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
|
|
var vue = require('vue');
|
|
var props = require('../../utils/props.js');
|
|
var index = require('../use-timeout/index.js');
|
|
|
|
const useDelayedToggleProps = props.buildProps({
|
|
showAfter: {
|
|
type: Number,
|
|
default: 0
|
|
},
|
|
hideAfter: {
|
|
type: Number,
|
|
default: 200
|
|
}
|
|
});
|
|
const useDelayedToggle = ({
|
|
showAfter,
|
|
hideAfter,
|
|
open,
|
|
close
|
|
}) => {
|
|
const { registerTimeout } = index.useTimeout();
|
|
const onOpen = () => {
|
|
registerTimeout(() => {
|
|
open();
|
|
}, vue.unref(showAfter));
|
|
};
|
|
const onClose = () => {
|
|
registerTimeout(() => {
|
|
close();
|
|
}, vue.unref(hideAfter));
|
|
};
|
|
return {
|
|
onOpen,
|
|
onClose
|
|
};
|
|
};
|
|
|
|
exports.useDelayedToggle = useDelayedToggle;
|
|
exports.useDelayedToggleProps = useDelayedToggleProps;
|
|
//# sourceMappingURL=index.js.map
|