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.
47 lines
1.2 KiB
47 lines
1.2 KiB
'use strict';
|
|
|
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
|
|
var vue = require('vue');
|
|
require('../../utils/index.js');
|
|
var index = require('../use-namespace/index.js');
|
|
var index$1 = require('../use-id/index.js');
|
|
var core = require('@vueuse/core');
|
|
|
|
const usePopperContainerId = () => {
|
|
const namespace = index.useGetDerivedNamespace();
|
|
const idInjection = index$1.useIdInjection();
|
|
const id = vue.computed(() => {
|
|
return `${namespace.value}-popper-container-${idInjection.prefix}`;
|
|
});
|
|
const selector = vue.computed(() => `#${id.value}`);
|
|
return {
|
|
id,
|
|
selector
|
|
};
|
|
};
|
|
const createContainer = (id) => {
|
|
const container = document.createElement("div");
|
|
container.id = id;
|
|
document.body.appendChild(container);
|
|
return container;
|
|
};
|
|
const usePopperContainer = () => {
|
|
const { id, selector } = usePopperContainerId();
|
|
vue.onBeforeMount(() => {
|
|
if (!core.isClient)
|
|
return;
|
|
if (process.env.NODE_ENV === "test" || !document.body.querySelector(selector.value)) {
|
|
createContainer(id.value);
|
|
}
|
|
});
|
|
return {
|
|
id,
|
|
selector
|
|
};
|
|
};
|
|
|
|
exports.usePopperContainer = usePopperContainer;
|
|
exports.usePopperContainerId = usePopperContainerId;
|
|
//# sourceMappingURL=index.js.map
|