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.
43 lines
1.2 KiB
43 lines
1.2 KiB
1 month ago
|
import { computed, onBeforeMount } from 'vue';
|
||
|
import '../../utils/index.mjs';
|
||
|
import { useGetDerivedNamespace } from '../use-namespace/index.mjs';
|
||
|
import { useIdInjection } from '../use-id/index.mjs';
|
||
|
import { isClient } from '@vueuse/core';
|
||
|
|
||
|
let cachedContainer;
|
||
|
const usePopperContainerId = () => {
|
||
|
const namespace = useGetDerivedNamespace();
|
||
|
const idInjection = useIdInjection();
|
||
|
const id = computed(() => {
|
||
|
return `${namespace.value}-popper-container-${idInjection.prefix}`;
|
||
|
});
|
||
|
const selector = 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();
|
||
|
onBeforeMount(() => {
|
||
|
if (!isClient)
|
||
|
return;
|
||
|
if (process.env.NODE_ENV === "test" || !cachedContainer || !document.body.querySelector(selector.value)) {
|
||
|
cachedContainer = createContainer(id.value);
|
||
|
}
|
||
|
});
|
||
|
return {
|
||
|
id,
|
||
|
selector
|
||
|
};
|
||
|
};
|
||
|
|
||
|
export { usePopperContainer, usePopperContainerId };
|
||
|
//# sourceMappingURL=index.mjs.map
|