| 123456789101112131415161718192021222324252627282930313233343536373839404142 |
- 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
|