mirror of
https://github.com/idanoo/GoScrobble
synced 2025-07-04 15:12:20 +00:00
0.2.0 - Mid migration
This commit is contained in:
parent
139e6a915e
commit
7e38fdbd7d
42393 changed files with 5358157 additions and 62 deletions
9
web/node_modules/@popperjs/core/lib/createPopper.d.ts
generated
vendored
Normal file
9
web/node_modules/@popperjs/core/lib/createPopper.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,9 @@
|
|||
import type { OptionsGeneric, Modifier, Instance, VirtualElement } from "./types";
|
||||
import detectOverflow from "./utils/detectOverflow";
|
||||
declare type PopperGeneratorArgs = {
|
||||
defaultModifiers?: Array<Modifier<any, any>>;
|
||||
defaultOptions?: Partial<OptionsGeneric<any>>;
|
||||
};
|
||||
export declare function popperGenerator(generatorOptions?: PopperGeneratorArgs): <TModifier extends Partial<Modifier<any, any>>>(reference: Element | VirtualElement, popper: HTMLElement, options?: Partial<OptionsGeneric<TModifier>>) => Instance;
|
||||
export declare const createPopper: <TModifier extends Partial<Modifier<any, any>>>(reference: Element | VirtualElement, popper: HTMLElement, options?: Partial<OptionsGeneric<TModifier>>) => Instance;
|
||||
export { detectOverflow };
|
258
web/node_modules/@popperjs/core/lib/createPopper.js
generated
vendored
Normal file
258
web/node_modules/@popperjs/core/lib/createPopper.js
generated
vendored
Normal file
|
@ -0,0 +1,258 @@
|
|||
import getCompositeRect from "./dom-utils/getCompositeRect.js";
|
||||
import getLayoutRect from "./dom-utils/getLayoutRect.js";
|
||||
import listScrollParents from "./dom-utils/listScrollParents.js";
|
||||
import getOffsetParent from "./dom-utils/getOffsetParent.js";
|
||||
import getComputedStyle from "./dom-utils/getComputedStyle.js";
|
||||
import orderModifiers from "./utils/orderModifiers.js";
|
||||
import debounce from "./utils/debounce.js";
|
||||
import validateModifiers from "./utils/validateModifiers.js";
|
||||
import uniqueBy from "./utils/uniqueBy.js";
|
||||
import getBasePlacement from "./utils/getBasePlacement.js";
|
||||
import mergeByName from "./utils/mergeByName.js";
|
||||
import detectOverflow from "./utils/detectOverflow.js";
|
||||
import { isElement } from "./dom-utils/instanceOf.js";
|
||||
import { auto } from "./enums.js";
|
||||
var INVALID_ELEMENT_ERROR = 'Popper: Invalid reference or popper argument provided. They must be either a DOM element or virtual element.';
|
||||
var INFINITE_LOOP_ERROR = 'Popper: An infinite loop in the modifiers cycle has been detected! The cycle has been interrupted to prevent a browser crash.';
|
||||
var DEFAULT_OPTIONS = {
|
||||
placement: 'bottom',
|
||||
modifiers: [],
|
||||
strategy: 'absolute'
|
||||
};
|
||||
|
||||
function areValidElements() {
|
||||
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
||||
args[_key] = arguments[_key];
|
||||
}
|
||||
|
||||
return !args.some(function (element) {
|
||||
return !(element && typeof element.getBoundingClientRect === 'function');
|
||||
});
|
||||
}
|
||||
|
||||
export function popperGenerator(generatorOptions) {
|
||||
if (generatorOptions === void 0) {
|
||||
generatorOptions = {};
|
||||
}
|
||||
|
||||
var _generatorOptions = generatorOptions,
|
||||
_generatorOptions$def = _generatorOptions.defaultModifiers,
|
||||
defaultModifiers = _generatorOptions$def === void 0 ? [] : _generatorOptions$def,
|
||||
_generatorOptions$def2 = _generatorOptions.defaultOptions,
|
||||
defaultOptions = _generatorOptions$def2 === void 0 ? DEFAULT_OPTIONS : _generatorOptions$def2;
|
||||
return function createPopper(reference, popper, options) {
|
||||
if (options === void 0) {
|
||||
options = defaultOptions;
|
||||
}
|
||||
|
||||
var state = {
|
||||
placement: 'bottom',
|
||||
orderedModifiers: [],
|
||||
options: Object.assign({}, DEFAULT_OPTIONS, defaultOptions),
|
||||
modifiersData: {},
|
||||
elements: {
|
||||
reference: reference,
|
||||
popper: popper
|
||||
},
|
||||
attributes: {},
|
||||
styles: {}
|
||||
};
|
||||
var effectCleanupFns = [];
|
||||
var isDestroyed = false;
|
||||
var instance = {
|
||||
state: state,
|
||||
setOptions: function setOptions(options) {
|
||||
cleanupModifierEffects();
|
||||
state.options = Object.assign({}, defaultOptions, state.options, options);
|
||||
state.scrollParents = {
|
||||
reference: isElement(reference) ? listScrollParents(reference) : reference.contextElement ? listScrollParents(reference.contextElement) : [],
|
||||
popper: listScrollParents(popper)
|
||||
}; // Orders the modifiers based on their dependencies and `phase`
|
||||
// properties
|
||||
|
||||
var orderedModifiers = orderModifiers(mergeByName([].concat(defaultModifiers, state.options.modifiers))); // Strip out disabled modifiers
|
||||
|
||||
state.orderedModifiers = orderedModifiers.filter(function (m) {
|
||||
return m.enabled;
|
||||
}); // Validate the provided modifiers so that the consumer will get warned
|
||||
// if one of the modifiers is invalid for any reason
|
||||
|
||||
if (process.env.NODE_ENV !== "production") {
|
||||
var modifiers = uniqueBy([].concat(orderedModifiers, state.options.modifiers), function (_ref) {
|
||||
var name = _ref.name;
|
||||
return name;
|
||||
});
|
||||
validateModifiers(modifiers);
|
||||
|
||||
if (getBasePlacement(state.options.placement) === auto) {
|
||||
var flipModifier = state.orderedModifiers.find(function (_ref2) {
|
||||
var name = _ref2.name;
|
||||
return name === 'flip';
|
||||
});
|
||||
|
||||
if (!flipModifier) {
|
||||
console.error(['Popper: "auto" placements require the "flip" modifier be', 'present and enabled to work.'].join(' '));
|
||||
}
|
||||
}
|
||||
|
||||
var _getComputedStyle = getComputedStyle(popper),
|
||||
marginTop = _getComputedStyle.marginTop,
|
||||
marginRight = _getComputedStyle.marginRight,
|
||||
marginBottom = _getComputedStyle.marginBottom,
|
||||
marginLeft = _getComputedStyle.marginLeft; // We no longer take into account `margins` on the popper, and it can
|
||||
// cause bugs with positioning, so we'll warn the consumer
|
||||
|
||||
|
||||
if ([marginTop, marginRight, marginBottom, marginLeft].some(function (margin) {
|
||||
return parseFloat(margin);
|
||||
})) {
|
||||
console.warn(['Popper: CSS "margin" styles cannot be used to apply padding', 'between the popper and its reference element or boundary.', 'To replicate margin, use the `offset` modifier, as well as', 'the `padding` option in the `preventOverflow` and `flip`', 'modifiers.'].join(' '));
|
||||
}
|
||||
}
|
||||
|
||||
runModifierEffects();
|
||||
return instance.update();
|
||||
},
|
||||
// Sync update – it will always be executed, even if not necessary. This
|
||||
// is useful for low frequency updates where sync behavior simplifies the
|
||||
// logic.
|
||||
// For high frequency updates (e.g. `resize` and `scroll` events), always
|
||||
// prefer the async Popper#update method
|
||||
forceUpdate: function forceUpdate() {
|
||||
if (isDestroyed) {
|
||||
return;
|
||||
}
|
||||
|
||||
var _state$elements = state.elements,
|
||||
reference = _state$elements.reference,
|
||||
popper = _state$elements.popper; // Don't proceed if `reference` or `popper` are not valid elements
|
||||
// anymore
|
||||
|
||||
if (!areValidElements(reference, popper)) {
|
||||
if (process.env.NODE_ENV !== "production") {
|
||||
console.error(INVALID_ELEMENT_ERROR);
|
||||
}
|
||||
|
||||
return;
|
||||
} // Store the reference and popper rects to be read by modifiers
|
||||
|
||||
|
||||
state.rects = {
|
||||
reference: getCompositeRect(reference, getOffsetParent(popper), state.options.strategy === 'fixed'),
|
||||
popper: getLayoutRect(popper)
|
||||
}; // Modifiers have the ability to reset the current update cycle. The
|
||||
// most common use case for this is the `flip` modifier changing the
|
||||
// placement, which then needs to re-run all the modifiers, because the
|
||||
// logic was previously ran for the previous placement and is therefore
|
||||
// stale/incorrect
|
||||
|
||||
state.reset = false;
|
||||
state.placement = state.options.placement; // On each update cycle, the `modifiersData` property for each modifier
|
||||
// is filled with the initial data specified by the modifier. This means
|
||||
// it doesn't persist and is fresh on each update.
|
||||
// To ensure persistent data, use `${name}#persistent`
|
||||
|
||||
state.orderedModifiers.forEach(function (modifier) {
|
||||
return state.modifiersData[modifier.name] = Object.assign({}, modifier.data);
|
||||
});
|
||||
var __debug_loops__ = 0;
|
||||
|
||||
for (var index = 0; index < state.orderedModifiers.length; index++) {
|
||||
if (process.env.NODE_ENV !== "production") {
|
||||
__debug_loops__ += 1;
|
||||
|
||||
if (__debug_loops__ > 100) {
|
||||
console.error(INFINITE_LOOP_ERROR);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (state.reset === true) {
|
||||
state.reset = false;
|
||||
index = -1;
|
||||
continue;
|
||||
}
|
||||
|
||||
var _state$orderedModifie = state.orderedModifiers[index],
|
||||
fn = _state$orderedModifie.fn,
|
||||
_state$orderedModifie2 = _state$orderedModifie.options,
|
||||
_options = _state$orderedModifie2 === void 0 ? {} : _state$orderedModifie2,
|
||||
name = _state$orderedModifie.name;
|
||||
|
||||
if (typeof fn === 'function') {
|
||||
state = fn({
|
||||
state: state,
|
||||
options: _options,
|
||||
name: name,
|
||||
instance: instance
|
||||
}) || state;
|
||||
}
|
||||
}
|
||||
},
|
||||
// Async and optimistically optimized update – it will not be executed if
|
||||
// not necessary (debounced to run at most once-per-tick)
|
||||
update: debounce(function () {
|
||||
return new Promise(function (resolve) {
|
||||
instance.forceUpdate();
|
||||
resolve(state);
|
||||
});
|
||||
}),
|
||||
destroy: function destroy() {
|
||||
cleanupModifierEffects();
|
||||
isDestroyed = true;
|
||||
}
|
||||
};
|
||||
|
||||
if (!areValidElements(reference, popper)) {
|
||||
if (process.env.NODE_ENV !== "production") {
|
||||
console.error(INVALID_ELEMENT_ERROR);
|
||||
}
|
||||
|
||||
return instance;
|
||||
}
|
||||
|
||||
instance.setOptions(options).then(function (state) {
|
||||
if (!isDestroyed && options.onFirstUpdate) {
|
||||
options.onFirstUpdate(state);
|
||||
}
|
||||
}); // Modifiers have the ability to execute arbitrary code before the first
|
||||
// update cycle runs. They will be executed in the same order as the update
|
||||
// cycle. This is useful when a modifier adds some persistent data that
|
||||
// other modifiers need to use, but the modifier is run after the dependent
|
||||
// one.
|
||||
|
||||
function runModifierEffects() {
|
||||
state.orderedModifiers.forEach(function (_ref3) {
|
||||
var name = _ref3.name,
|
||||
_ref3$options = _ref3.options,
|
||||
options = _ref3$options === void 0 ? {} : _ref3$options,
|
||||
effect = _ref3.effect;
|
||||
|
||||
if (typeof effect === 'function') {
|
||||
var cleanupFn = effect({
|
||||
state: state,
|
||||
name: name,
|
||||
instance: instance,
|
||||
options: options
|
||||
});
|
||||
|
||||
var noopFn = function noopFn() {};
|
||||
|
||||
effectCleanupFns.push(cleanupFn || noopFn);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function cleanupModifierEffects() {
|
||||
effectCleanupFns.forEach(function (fn) {
|
||||
return fn();
|
||||
});
|
||||
effectCleanupFns = [];
|
||||
}
|
||||
|
||||
return instance;
|
||||
};
|
||||
}
|
||||
export var createPopper = /*#__PURE__*/popperGenerator(); // eslint-disable-next-line import/no-unused-modules
|
||||
|
||||
export { detectOverflow };
|
291
web/node_modules/@popperjs/core/lib/createPopper.js.flow
generated
vendored
Normal file
291
web/node_modules/@popperjs/core/lib/createPopper.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,291 @@
|
|||
// @flow
|
||||
import type {
|
||||
State,
|
||||
OptionsGeneric,
|
||||
Modifier,
|
||||
Instance,
|
||||
VirtualElement,
|
||||
} from './types';
|
||||
import getCompositeRect from './dom-utils/getCompositeRect';
|
||||
import getLayoutRect from './dom-utils/getLayoutRect';
|
||||
import listScrollParents from './dom-utils/listScrollParents';
|
||||
import getOffsetParent from './dom-utils/getOffsetParent';
|
||||
import getComputedStyle from './dom-utils/getComputedStyle';
|
||||
import orderModifiers from './utils/orderModifiers';
|
||||
import debounce from './utils/debounce';
|
||||
import validateModifiers from './utils/validateModifiers';
|
||||
import uniqueBy from './utils/uniqueBy';
|
||||
import getBasePlacement from './utils/getBasePlacement';
|
||||
import mergeByName from './utils/mergeByName';
|
||||
import detectOverflow from './utils/detectOverflow';
|
||||
import { isElement } from './dom-utils/instanceOf';
|
||||
import { auto } from './enums';
|
||||
|
||||
const INVALID_ELEMENT_ERROR =
|
||||
'Popper: Invalid reference or popper argument provided. They must be either a DOM element or virtual element.';
|
||||
const INFINITE_LOOP_ERROR =
|
||||
'Popper: An infinite loop in the modifiers cycle has been detected! The cycle has been interrupted to prevent a browser crash.';
|
||||
|
||||
const DEFAULT_OPTIONS: OptionsGeneric<any> = {
|
||||
placement: 'bottom',
|
||||
modifiers: [],
|
||||
strategy: 'absolute',
|
||||
};
|
||||
|
||||
type PopperGeneratorArgs = {
|
||||
defaultModifiers?: Array<Modifier<any, any>>,
|
||||
defaultOptions?: $Shape<OptionsGeneric<any>>,
|
||||
};
|
||||
|
||||
function areValidElements(...args: Array<any>): boolean {
|
||||
return !args.some(
|
||||
(element) =>
|
||||
!(element && typeof element.getBoundingClientRect === 'function')
|
||||
);
|
||||
}
|
||||
|
||||
export function popperGenerator(generatorOptions: PopperGeneratorArgs = {}) {
|
||||
const {
|
||||
defaultModifiers = [],
|
||||
defaultOptions = DEFAULT_OPTIONS,
|
||||
} = generatorOptions;
|
||||
|
||||
return function createPopper<TModifier: $Shape<Modifier<any, any>>>(
|
||||
reference: Element | VirtualElement,
|
||||
popper: HTMLElement,
|
||||
options: $Shape<OptionsGeneric<TModifier>> = defaultOptions
|
||||
): Instance {
|
||||
let state: $Shape<State> = {
|
||||
placement: 'bottom',
|
||||
orderedModifiers: [],
|
||||
options: { ...DEFAULT_OPTIONS, ...defaultOptions },
|
||||
modifiersData: {},
|
||||
elements: {
|
||||
reference,
|
||||
popper,
|
||||
},
|
||||
attributes: {},
|
||||
styles: {},
|
||||
};
|
||||
|
||||
let effectCleanupFns: Array<() => void> = [];
|
||||
let isDestroyed = false;
|
||||
|
||||
const instance = {
|
||||
state,
|
||||
setOptions(options) {
|
||||
cleanupModifierEffects();
|
||||
|
||||
state.options = {
|
||||
// $FlowFixMe[exponential-spread]
|
||||
...defaultOptions,
|
||||
...state.options,
|
||||
...options,
|
||||
};
|
||||
|
||||
state.scrollParents = {
|
||||
reference: isElement(reference)
|
||||
? listScrollParents(reference)
|
||||
: reference.contextElement
|
||||
? listScrollParents(reference.contextElement)
|
||||
: [],
|
||||
popper: listScrollParents(popper),
|
||||
};
|
||||
|
||||
// Orders the modifiers based on their dependencies and `phase`
|
||||
// properties
|
||||
const orderedModifiers = orderModifiers(
|
||||
mergeByName([...defaultModifiers, ...state.options.modifiers])
|
||||
);
|
||||
|
||||
// Strip out disabled modifiers
|
||||
state.orderedModifiers = orderedModifiers.filter((m) => m.enabled);
|
||||
|
||||
// Validate the provided modifiers so that the consumer will get warned
|
||||
// if one of the modifiers is invalid for any reason
|
||||
if (false) {
|
||||
const modifiers = uniqueBy(
|
||||
[...orderedModifiers, ...state.options.modifiers],
|
||||
({ name }) => name
|
||||
);
|
||||
|
||||
validateModifiers(modifiers);
|
||||
|
||||
if (getBasePlacement(state.options.placement) === auto) {
|
||||
const flipModifier = state.orderedModifiers.find(
|
||||
({ name }) => name === 'flip'
|
||||
);
|
||||
|
||||
if (!flipModifier) {
|
||||
console.error(
|
||||
[
|
||||
'Popper: "auto" placements require the "flip" modifier be',
|
||||
'present and enabled to work.',
|
||||
].join(' ')
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
const {
|
||||
marginTop,
|
||||
marginRight,
|
||||
marginBottom,
|
||||
marginLeft,
|
||||
} = getComputedStyle(popper);
|
||||
|
||||
// We no longer take into account `margins` on the popper, and it can
|
||||
// cause bugs with positioning, so we'll warn the consumer
|
||||
if (
|
||||
[marginTop, marginRight, marginBottom, marginLeft].some((margin) =>
|
||||
parseFloat(margin)
|
||||
)
|
||||
) {
|
||||
console.warn(
|
||||
[
|
||||
'Popper: CSS "margin" styles cannot be used to apply padding',
|
||||
'between the popper and its reference element or boundary.',
|
||||
'To replicate margin, use the `offset` modifier, as well as',
|
||||
'the `padding` option in the `preventOverflow` and `flip`',
|
||||
'modifiers.',
|
||||
].join(' ')
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
runModifierEffects();
|
||||
|
||||
return instance.update();
|
||||
},
|
||||
|
||||
// Sync update – it will always be executed, even if not necessary. This
|
||||
// is useful for low frequency updates where sync behavior simplifies the
|
||||
// logic.
|
||||
// For high frequency updates (e.g. `resize` and `scroll` events), always
|
||||
// prefer the async Popper#update method
|
||||
forceUpdate() {
|
||||
if (isDestroyed) {
|
||||
return;
|
||||
}
|
||||
|
||||
const { reference, popper } = state.elements;
|
||||
|
||||
// Don't proceed if `reference` or `popper` are not valid elements
|
||||
// anymore
|
||||
if (!areValidElements(reference, popper)) {
|
||||
if (false) {
|
||||
console.error(INVALID_ELEMENT_ERROR);
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
// Store the reference and popper rects to be read by modifiers
|
||||
state.rects = {
|
||||
reference: getCompositeRect(
|
||||
reference,
|
||||
getOffsetParent(popper),
|
||||
state.options.strategy === 'fixed'
|
||||
),
|
||||
popper: getLayoutRect(popper),
|
||||
};
|
||||
|
||||
// Modifiers have the ability to reset the current update cycle. The
|
||||
// most common use case for this is the `flip` modifier changing the
|
||||
// placement, which then needs to re-run all the modifiers, because the
|
||||
// logic was previously ran for the previous placement and is therefore
|
||||
// stale/incorrect
|
||||
state.reset = false;
|
||||
|
||||
state.placement = state.options.placement;
|
||||
|
||||
// On each update cycle, the `modifiersData` property for each modifier
|
||||
// is filled with the initial data specified by the modifier. This means
|
||||
// it doesn't persist and is fresh on each update.
|
||||
// To ensure persistent data, use `${name}#persistent`
|
||||
state.orderedModifiers.forEach(
|
||||
(modifier) =>
|
||||
(state.modifiersData[modifier.name] = {
|
||||
...modifier.data,
|
||||
})
|
||||
);
|
||||
|
||||
let __debug_loops__ = 0;
|
||||
for (let index = 0; index < state.orderedModifiers.length; index++) {
|
||||
if (false) {
|
||||
__debug_loops__ += 1;
|
||||
if (__debug_loops__ > 100) {
|
||||
console.error(INFINITE_LOOP_ERROR);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (state.reset === true) {
|
||||
state.reset = false;
|
||||
index = -1;
|
||||
continue;
|
||||
}
|
||||
|
||||
const { fn, options = {}, name } = state.orderedModifiers[index];
|
||||
|
||||
if (typeof fn === 'function') {
|
||||
state = fn({ state, options, name, instance }) || state;
|
||||
}
|
||||
}
|
||||
},
|
||||
|
||||
// Async and optimistically optimized update – it will not be executed if
|
||||
// not necessary (debounced to run at most once-per-tick)
|
||||
update: debounce<$Shape<State>>(
|
||||
() =>
|
||||
new Promise<$Shape<State>>((resolve) => {
|
||||
instance.forceUpdate();
|
||||
resolve(state);
|
||||
})
|
||||
),
|
||||
|
||||
destroy() {
|
||||
cleanupModifierEffects();
|
||||
isDestroyed = true;
|
||||
},
|
||||
};
|
||||
|
||||
if (!areValidElements(reference, popper)) {
|
||||
if (false) {
|
||||
console.error(INVALID_ELEMENT_ERROR);
|
||||
}
|
||||
return instance;
|
||||
}
|
||||
|
||||
instance.setOptions(options).then((state) => {
|
||||
if (!isDestroyed && options.onFirstUpdate) {
|
||||
options.onFirstUpdate(state);
|
||||
}
|
||||
});
|
||||
|
||||
// Modifiers have the ability to execute arbitrary code before the first
|
||||
// update cycle runs. They will be executed in the same order as the update
|
||||
// cycle. This is useful when a modifier adds some persistent data that
|
||||
// other modifiers need to use, but the modifier is run after the dependent
|
||||
// one.
|
||||
function runModifierEffects() {
|
||||
state.orderedModifiers.forEach(({ name, options = {}, effect }) => {
|
||||
if (typeof effect === 'function') {
|
||||
const cleanupFn = effect({ state, name, instance, options });
|
||||
const noopFn = () => {};
|
||||
effectCleanupFns.push(cleanupFn || noopFn);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function cleanupModifierEffects() {
|
||||
effectCleanupFns.forEach((fn) => fn());
|
||||
effectCleanupFns = [];
|
||||
}
|
||||
|
||||
return instance;
|
||||
};
|
||||
}
|
||||
|
||||
export const createPopper = popperGenerator();
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export { detectOverflow };
|
1
web/node_modules/@popperjs/core/lib/dom-utils/contains.d.ts
generated
vendored
Normal file
1
web/node_modules/@popperjs/core/lib/dom-utils/contains.d.ts
generated
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
export default function contains(parent: Element, child: Element): boolean;
|
23
web/node_modules/@popperjs/core/lib/dom-utils/contains.js
generated
vendored
Normal file
23
web/node_modules/@popperjs/core/lib/dom-utils/contains.js
generated
vendored
Normal file
|
@ -0,0 +1,23 @@
|
|||
import { isShadowRoot } from "./instanceOf.js";
|
||||
export default function contains(parent, child) {
|
||||
var rootNode = child.getRootNode && child.getRootNode(); // First, attempt with faster native method
|
||||
|
||||
if (parent.contains(child)) {
|
||||
return true;
|
||||
} // then fallback to custom implementation with Shadow DOM support
|
||||
else if (rootNode && isShadowRoot(rootNode)) {
|
||||
var next = child;
|
||||
|
||||
do {
|
||||
if (next && parent.isSameNode(next)) {
|
||||
return true;
|
||||
} // $FlowFixMe[prop-missing]: need a better way to handle this...
|
||||
|
||||
|
||||
next = next.parentNode || next.host;
|
||||
} while (next);
|
||||
} // Give up, the result is false
|
||||
|
||||
|
||||
return false;
|
||||
}
|
25
web/node_modules/@popperjs/core/lib/dom-utils/contains.js.flow
generated
vendored
Normal file
25
web/node_modules/@popperjs/core/lib/dom-utils/contains.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,25 @@
|
|||
// @flow
|
||||
import { isShadowRoot } from './instanceOf';
|
||||
|
||||
export default function contains(parent: Element, child: Element) {
|
||||
const rootNode = child.getRootNode && child.getRootNode();
|
||||
|
||||
// First, attempt with faster native method
|
||||
if (parent.contains(child)) {
|
||||
return true;
|
||||
}
|
||||
// then fallback to custom implementation with Shadow DOM support
|
||||
else if (rootNode && isShadowRoot(rootNode)) {
|
||||
let next = child;
|
||||
do {
|
||||
if (next && parent.isSameNode(next)) {
|
||||
return true;
|
||||
}
|
||||
// $FlowFixMe[prop-missing]: need a better way to handle this...
|
||||
next = next.parentNode || next.host;
|
||||
} while (next);
|
||||
}
|
||||
|
||||
// Give up, the result is false
|
||||
return false;
|
||||
}
|
2
web/node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.d.ts
generated
vendored
Normal file
2
web/node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,2 @@
|
|||
import type { ClientRectObject, VirtualElement } from "../types";
|
||||
export default function getBoundingClientRect(element: Element | VirtualElement, includeScale?: boolean): ClientRectObject;
|
28
web/node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js
generated
vendored
Normal file
28
web/node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js
generated
vendored
Normal file
|
@ -0,0 +1,28 @@
|
|||
import { isHTMLElement } from "./instanceOf.js";
|
||||
var round = Math.round;
|
||||
export default function getBoundingClientRect(element, includeScale) {
|
||||
if (includeScale === void 0) {
|
||||
includeScale = false;
|
||||
}
|
||||
|
||||
var rect = element.getBoundingClientRect();
|
||||
var scaleX = 1;
|
||||
var scaleY = 1;
|
||||
|
||||
if (isHTMLElement(element) && includeScale) {
|
||||
// Fallback to 1 in case both values are `0`
|
||||
scaleX = rect.width / element.offsetWidth || 1;
|
||||
scaleY = rect.height / element.offsetHeight || 1;
|
||||
}
|
||||
|
||||
return {
|
||||
width: round(rect.width / scaleX),
|
||||
height: round(rect.height / scaleY),
|
||||
top: round(rect.top / scaleY),
|
||||
right: round(rect.right / scaleX),
|
||||
bottom: round(rect.bottom / scaleY),
|
||||
left: round(rect.left / scaleX),
|
||||
x: round(rect.left / scaleX),
|
||||
y: round(rect.top / scaleY)
|
||||
};
|
||||
}
|
31
web/node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js.flow
generated
vendored
Normal file
31
web/node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,31 @@
|
|||
// @flow
|
||||
import type { ClientRectObject, VirtualElement } from '../types';
|
||||
import { isHTMLElement } from './instanceOf';
|
||||
|
||||
const round = Math.round;
|
||||
|
||||
export default function getBoundingClientRect(
|
||||
element: Element | VirtualElement,
|
||||
includeScale: boolean = false
|
||||
): ClientRectObject {
|
||||
const rect = element.getBoundingClientRect();
|
||||
let scaleX = 1;
|
||||
let scaleY = 1;
|
||||
|
||||
if (isHTMLElement(element) && includeScale) {
|
||||
// Fallback to 1 in case both values are `0`
|
||||
scaleX = rect.width / element.offsetWidth || 1;
|
||||
scaleY = rect.height / element.offsetHeight || 1;
|
||||
}
|
||||
|
||||
return {
|
||||
width: round(rect.width / scaleX),
|
||||
height: round(rect.height / scaleY),
|
||||
top: round(rect.top / scaleY),
|
||||
right: round(rect.right / scaleX),
|
||||
bottom: round(rect.bottom / scaleY),
|
||||
left: round(rect.left / scaleX),
|
||||
x: round(rect.left / scaleX),
|
||||
y: round(rect.top / scaleY),
|
||||
};
|
||||
}
|
3
web/node_modules/@popperjs/core/lib/dom-utils/getClippingRect.d.ts
generated
vendored
Normal file
3
web/node_modules/@popperjs/core/lib/dom-utils/getClippingRect.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,3 @@
|
|||
import type { ClientRectObject } from "../types";
|
||||
import type { Boundary, RootBoundary } from "../enums";
|
||||
export default function getClippingRect(element: Element, boundary: Boundary, rootBoundary: RootBoundary): ClientRectObject;
|
70
web/node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js
generated
vendored
Normal file
70
web/node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js
generated
vendored
Normal file
|
@ -0,0 +1,70 @@
|
|||
import { viewport } from "../enums.js";
|
||||
import getViewportRect from "./getViewportRect.js";
|
||||
import getDocumentRect from "./getDocumentRect.js";
|
||||
import listScrollParents from "./listScrollParents.js";
|
||||
import getOffsetParent from "./getOffsetParent.js";
|
||||
import getDocumentElement from "./getDocumentElement.js";
|
||||
import getComputedStyle from "./getComputedStyle.js";
|
||||
import { isElement, isHTMLElement } from "./instanceOf.js";
|
||||
import getBoundingClientRect from "./getBoundingClientRect.js";
|
||||
import getParentNode from "./getParentNode.js";
|
||||
import contains from "./contains.js";
|
||||
import getNodeName from "./getNodeName.js";
|
||||
import rectToClientRect from "../utils/rectToClientRect.js";
|
||||
import { max, min } from "../utils/math.js";
|
||||
|
||||
function getInnerBoundingClientRect(element) {
|
||||
var rect = getBoundingClientRect(element);
|
||||
rect.top = rect.top + element.clientTop;
|
||||
rect.left = rect.left + element.clientLeft;
|
||||
rect.bottom = rect.top + element.clientHeight;
|
||||
rect.right = rect.left + element.clientWidth;
|
||||
rect.width = element.clientWidth;
|
||||
rect.height = element.clientHeight;
|
||||
rect.x = rect.left;
|
||||
rect.y = rect.top;
|
||||
return rect;
|
||||
}
|
||||
|
||||
function getClientRectFromMixedType(element, clippingParent) {
|
||||
return clippingParent === viewport ? rectToClientRect(getViewportRect(element)) : isHTMLElement(clippingParent) ? getInnerBoundingClientRect(clippingParent) : rectToClientRect(getDocumentRect(getDocumentElement(element)));
|
||||
} // A "clipping parent" is an overflowable container with the characteristic of
|
||||
// clipping (or hiding) overflowing elements with a position different from
|
||||
// `initial`
|
||||
|
||||
|
||||
function getClippingParents(element) {
|
||||
var clippingParents = listScrollParents(getParentNode(element));
|
||||
var canEscapeClipping = ['absolute', 'fixed'].indexOf(getComputedStyle(element).position) >= 0;
|
||||
var clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element;
|
||||
|
||||
if (!isElement(clipperElement)) {
|
||||
return [];
|
||||
} // $FlowFixMe[incompatible-return]: https://github.com/facebook/flow/issues/1414
|
||||
|
||||
|
||||
return clippingParents.filter(function (clippingParent) {
|
||||
return isElement(clippingParent) && contains(clippingParent, clipperElement) && getNodeName(clippingParent) !== 'body';
|
||||
});
|
||||
} // Gets the maximum area that the element is visible in due to any number of
|
||||
// clipping parents
|
||||
|
||||
|
||||
export default function getClippingRect(element, boundary, rootBoundary) {
|
||||
var mainClippingParents = boundary === 'clippingParents' ? getClippingParents(element) : [].concat(boundary);
|
||||
var clippingParents = [].concat(mainClippingParents, [rootBoundary]);
|
||||
var firstClippingParent = clippingParents[0];
|
||||
var clippingRect = clippingParents.reduce(function (accRect, clippingParent) {
|
||||
var rect = getClientRectFromMixedType(element, clippingParent);
|
||||
accRect.top = max(rect.top, accRect.top);
|
||||
accRect.right = min(rect.right, accRect.right);
|
||||
accRect.bottom = min(rect.bottom, accRect.bottom);
|
||||
accRect.left = max(rect.left, accRect.left);
|
||||
return accRect;
|
||||
}, getClientRectFromMixedType(element, firstClippingParent));
|
||||
clippingRect.width = clippingRect.right - clippingRect.left;
|
||||
clippingRect.height = clippingRect.bottom - clippingRect.top;
|
||||
clippingRect.x = clippingRect.left;
|
||||
clippingRect.y = clippingRect.top;
|
||||
return clippingRect;
|
||||
}
|
101
web/node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js.flow
generated
vendored
Normal file
101
web/node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,101 @@
|
|||
// @flow
|
||||
import type { ClientRectObject } from '../types';
|
||||
import type { Boundary, RootBoundary } from '../enums';
|
||||
import { viewport } from '../enums';
|
||||
import getViewportRect from './getViewportRect';
|
||||
import getDocumentRect from './getDocumentRect';
|
||||
import listScrollParents from './listScrollParents';
|
||||
import getOffsetParent from './getOffsetParent';
|
||||
import getDocumentElement from './getDocumentElement';
|
||||
import getComputedStyle from './getComputedStyle';
|
||||
import { isElement, isHTMLElement } from './instanceOf';
|
||||
import getBoundingClientRect from './getBoundingClientRect';
|
||||
import getParentNode from './getParentNode';
|
||||
import contains from './contains';
|
||||
import getNodeName from './getNodeName';
|
||||
import rectToClientRect from '../utils/rectToClientRect';
|
||||
import { max, min } from '../utils/math';
|
||||
|
||||
function getInnerBoundingClientRect(element: Element) {
|
||||
const rect = getBoundingClientRect(element);
|
||||
|
||||
rect.top = rect.top + element.clientTop;
|
||||
rect.left = rect.left + element.clientLeft;
|
||||
rect.bottom = rect.top + element.clientHeight;
|
||||
rect.right = rect.left + element.clientWidth;
|
||||
rect.width = element.clientWidth;
|
||||
rect.height = element.clientHeight;
|
||||
rect.x = rect.left;
|
||||
rect.y = rect.top;
|
||||
|
||||
return rect;
|
||||
}
|
||||
|
||||
function getClientRectFromMixedType(
|
||||
element: Element,
|
||||
clippingParent: Element | RootBoundary
|
||||
): ClientRectObject {
|
||||
return clippingParent === viewport
|
||||
? rectToClientRect(getViewportRect(element))
|
||||
: isHTMLElement(clippingParent)
|
||||
? getInnerBoundingClientRect(clippingParent)
|
||||
: rectToClientRect(getDocumentRect(getDocumentElement(element)));
|
||||
}
|
||||
|
||||
// A "clipping parent" is an overflowable container with the characteristic of
|
||||
// clipping (or hiding) overflowing elements with a position different from
|
||||
// `initial`
|
||||
function getClippingParents(element: Element): Array<Element> {
|
||||
const clippingParents = listScrollParents(getParentNode(element));
|
||||
const canEscapeClipping =
|
||||
['absolute', 'fixed'].indexOf(getComputedStyle(element).position) >= 0;
|
||||
const clipperElement =
|
||||
canEscapeClipping && isHTMLElement(element)
|
||||
? getOffsetParent(element)
|
||||
: element;
|
||||
|
||||
if (!isElement(clipperElement)) {
|
||||
return [];
|
||||
}
|
||||
|
||||
// $FlowFixMe[incompatible-return]: https://github.com/facebook/flow/issues/1414
|
||||
return clippingParents.filter(
|
||||
(clippingParent) =>
|
||||
isElement(clippingParent) &&
|
||||
contains(clippingParent, clipperElement) &&
|
||||
getNodeName(clippingParent) !== 'body'
|
||||
);
|
||||
}
|
||||
|
||||
// Gets the maximum area that the element is visible in due to any number of
|
||||
// clipping parents
|
||||
export default function getClippingRect(
|
||||
element: Element,
|
||||
boundary: Boundary,
|
||||
rootBoundary: RootBoundary
|
||||
): ClientRectObject {
|
||||
const mainClippingParents =
|
||||
boundary === 'clippingParents'
|
||||
? getClippingParents(element)
|
||||
: [].concat(boundary);
|
||||
const clippingParents = [...mainClippingParents, rootBoundary];
|
||||
const firstClippingParent = clippingParents[0];
|
||||
|
||||
const clippingRect = clippingParents.reduce((accRect, clippingParent) => {
|
||||
const rect = getClientRectFromMixedType(element, clippingParent);
|
||||
|
||||
accRect.top = max(rect.top, accRect.top);
|
||||
accRect.right = min(rect.right, accRect.right);
|
||||
accRect.bottom = min(rect.bottom, accRect.bottom);
|
||||
accRect.left = max(rect.left, accRect.left);
|
||||
|
||||
return accRect;
|
||||
}, getClientRectFromMixedType(element, firstClippingParent));
|
||||
|
||||
clippingRect.width = clippingRect.right - clippingRect.left;
|
||||
clippingRect.height = clippingRect.bottom - clippingRect.top;
|
||||
clippingRect.x = clippingRect.left;
|
||||
clippingRect.y = clippingRect.top;
|
||||
|
||||
return clippingRect;
|
||||
}
|
2
web/node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.d.ts
generated
vendored
Normal file
2
web/node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,2 @@
|
|||
import type { Rect, VirtualElement, Window } from "../types";
|
||||
export default function getCompositeRect(elementOrVirtualElement: Element | VirtualElement, offsetParent: Element | Window, isFixed?: boolean): Rect;
|
57
web/node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js
generated
vendored
Normal file
57
web/node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js
generated
vendored
Normal file
|
@ -0,0 +1,57 @@
|
|||
import getBoundingClientRect from "./getBoundingClientRect.js";
|
||||
import getNodeScroll from "./getNodeScroll.js";
|
||||
import getNodeName from "./getNodeName.js";
|
||||
import { isHTMLElement } from "./instanceOf.js";
|
||||
import getWindowScrollBarX from "./getWindowScrollBarX.js";
|
||||
import getDocumentElement from "./getDocumentElement.js";
|
||||
import isScrollParent from "./isScrollParent.js";
|
||||
|
||||
function isElementScaled(element) {
|
||||
var rect = element.getBoundingClientRect();
|
||||
var scaleX = rect.width / element.offsetWidth || 1;
|
||||
var scaleY = rect.height / element.offsetHeight || 1;
|
||||
return scaleX !== 1 || scaleY !== 1;
|
||||
} // Returns the composite rect of an element relative to its offsetParent.
|
||||
// Composite means it takes into account transforms as well as layout.
|
||||
|
||||
|
||||
export default function getCompositeRect(elementOrVirtualElement, offsetParent, isFixed) {
|
||||
if (isFixed === void 0) {
|
||||
isFixed = false;
|
||||
}
|
||||
|
||||
var isOffsetParentAnElement = isHTMLElement(offsetParent);
|
||||
var offsetParentIsScaled = isHTMLElement(offsetParent) && isElementScaled(offsetParent);
|
||||
var documentElement = getDocumentElement(offsetParent);
|
||||
var rect = getBoundingClientRect(elementOrVirtualElement, offsetParentIsScaled);
|
||||
var scroll = {
|
||||
scrollLeft: 0,
|
||||
scrollTop: 0
|
||||
};
|
||||
var offsets = {
|
||||
x: 0,
|
||||
y: 0
|
||||
};
|
||||
|
||||
if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {
|
||||
if (getNodeName(offsetParent) !== 'body' || // https://github.com/popperjs/popper-core/issues/1078
|
||||
isScrollParent(documentElement)) {
|
||||
scroll = getNodeScroll(offsetParent);
|
||||
}
|
||||
|
||||
if (isHTMLElement(offsetParent)) {
|
||||
offsets = getBoundingClientRect(offsetParent, true);
|
||||
offsets.x += offsetParent.clientLeft;
|
||||
offsets.y += offsetParent.clientTop;
|
||||
} else if (documentElement) {
|
||||
offsets.x = getWindowScrollBarX(documentElement);
|
||||
}
|
||||
}
|
||||
|
||||
return {
|
||||
x: rect.left + scroll.scrollLeft - offsets.x,
|
||||
y: rect.top + scroll.scrollTop - offsets.y,
|
||||
width: rect.width,
|
||||
height: rect.height
|
||||
};
|
||||
}
|
62
web/node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js.flow
generated
vendored
Normal file
62
web/node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,62 @@
|
|||
// @flow
|
||||
import type { Rect, VirtualElement, Window } from '../types';
|
||||
import getBoundingClientRect from './getBoundingClientRect';
|
||||
import getNodeScroll from './getNodeScroll';
|
||||
import getNodeName from './getNodeName';
|
||||
import { isHTMLElement } from './instanceOf';
|
||||
import getWindowScrollBarX from './getWindowScrollBarX';
|
||||
import getDocumentElement from './getDocumentElement';
|
||||
import isScrollParent from './isScrollParent';
|
||||
|
||||
function isElementScaled(element: HTMLElement) {
|
||||
const rect = element.getBoundingClientRect();
|
||||
const scaleX = rect.width / element.offsetWidth || 1;
|
||||
const scaleY = rect.height / element.offsetHeight || 1;
|
||||
|
||||
return scaleX !== 1 || scaleY !== 1;
|
||||
}
|
||||
|
||||
// Returns the composite rect of an element relative to its offsetParent.
|
||||
// Composite means it takes into account transforms as well as layout.
|
||||
export default function getCompositeRect(
|
||||
elementOrVirtualElement: Element | VirtualElement,
|
||||
offsetParent: Element | Window,
|
||||
isFixed: boolean = false
|
||||
): Rect {
|
||||
const isOffsetParentAnElement = isHTMLElement(offsetParent);
|
||||
const offsetParentIsScaled =
|
||||
isHTMLElement(offsetParent) && isElementScaled(offsetParent);
|
||||
const documentElement = getDocumentElement(offsetParent);
|
||||
const rect = getBoundingClientRect(
|
||||
elementOrVirtualElement,
|
||||
offsetParentIsScaled
|
||||
);
|
||||
|
||||
let scroll = { scrollLeft: 0, scrollTop: 0 };
|
||||
let offsets = { x: 0, y: 0 };
|
||||
|
||||
if (isOffsetParentAnElement || (!isOffsetParentAnElement && !isFixed)) {
|
||||
if (
|
||||
getNodeName(offsetParent) !== 'body' ||
|
||||
// https://github.com/popperjs/popper-core/issues/1078
|
||||
isScrollParent(documentElement)
|
||||
) {
|
||||
scroll = getNodeScroll(offsetParent);
|
||||
}
|
||||
|
||||
if (isHTMLElement(offsetParent)) {
|
||||
offsets = getBoundingClientRect(offsetParent, true);
|
||||
offsets.x += offsetParent.clientLeft;
|
||||
offsets.y += offsetParent.clientTop;
|
||||
} else if (documentElement) {
|
||||
offsets.x = getWindowScrollBarX(documentElement);
|
||||
}
|
||||
}
|
||||
|
||||
return {
|
||||
x: rect.left + scroll.scrollLeft - offsets.x,
|
||||
y: rect.top + scroll.scrollTop - offsets.y,
|
||||
width: rect.width,
|
||||
height: rect.height,
|
||||
};
|
||||
}
|
1
web/node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.d.ts
generated
vendored
Normal file
1
web/node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.d.ts
generated
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
export default function getComputedStyle(element: Element): CSSStyleDeclaration;
|
4
web/node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js
generated
vendored
Normal file
4
web/node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js
generated
vendored
Normal file
|
@ -0,0 +1,4 @@
|
|||
import getWindow from "./getWindow.js";
|
||||
export default function getComputedStyle(element) {
|
||||
return getWindow(element).getComputedStyle(element);
|
||||
}
|
8
web/node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js.flow
generated
vendored
Normal file
8
web/node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,8 @@
|
|||
// @flow
|
||||
import getWindow from './getWindow';
|
||||
|
||||
export default function getComputedStyle(
|
||||
element: Element
|
||||
): CSSStyleDeclaration {
|
||||
return getWindow(element).getComputedStyle(element);
|
||||
}
|
2
web/node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.d.ts
generated
vendored
Normal file
2
web/node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,2 @@
|
|||
import type { Window } from "../types";
|
||||
export default function getDocumentElement(element: Element | Window): HTMLElement;
|
6
web/node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js
generated
vendored
Normal file
6
web/node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js
generated
vendored
Normal file
|
@ -0,0 +1,6 @@
|
|||
import { isElement } from "./instanceOf.js";
|
||||
export default function getDocumentElement(element) {
|
||||
// $FlowFixMe[incompatible-return]: assume body is always available
|
||||
return ((isElement(element) ? element.ownerDocument : // $FlowFixMe[prop-missing]
|
||||
element.document) || window.document).documentElement;
|
||||
}
|
15
web/node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js.flow
generated
vendored
Normal file
15
web/node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,15 @@
|
|||
// @flow
|
||||
import { isElement } from './instanceOf';
|
||||
import type { Window } from '../types';
|
||||
|
||||
export default function getDocumentElement(
|
||||
element: Element | Window
|
||||
): HTMLElement {
|
||||
// $FlowFixMe[incompatible-return]: assume body is always available
|
||||
return (
|
||||
(isElement(element)
|
||||
? element.ownerDocument
|
||||
: // $FlowFixMe[prop-missing]
|
||||
element.document) || window.document
|
||||
).documentElement;
|
||||
}
|
2
web/node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.d.ts
generated
vendored
Normal file
2
web/node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,2 @@
|
|||
import type { Rect } from "../types";
|
||||
export default function getDocumentRect(element: HTMLElement): Rect;
|
29
web/node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js
generated
vendored
Normal file
29
web/node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js
generated
vendored
Normal file
|
@ -0,0 +1,29 @@
|
|||
import getDocumentElement from "./getDocumentElement.js";
|
||||
import getComputedStyle from "./getComputedStyle.js";
|
||||
import getWindowScrollBarX from "./getWindowScrollBarX.js";
|
||||
import getWindowScroll from "./getWindowScroll.js";
|
||||
import { max } from "../utils/math.js"; // Gets the entire size of the scrollable document area, even extending outside
|
||||
// of the `<html>` and `<body>` rect bounds if horizontally scrollable
|
||||
|
||||
export default function getDocumentRect(element) {
|
||||
var _element$ownerDocumen;
|
||||
|
||||
var html = getDocumentElement(element);
|
||||
var winScroll = getWindowScroll(element);
|
||||
var body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body;
|
||||
var width = max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0);
|
||||
var height = max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0);
|
||||
var x = -winScroll.scrollLeft + getWindowScrollBarX(element);
|
||||
var y = -winScroll.scrollTop;
|
||||
|
||||
if (getComputedStyle(body || html).direction === 'rtl') {
|
||||
x += max(html.clientWidth, body ? body.clientWidth : 0) - width;
|
||||
}
|
||||
|
||||
return {
|
||||
width: width,
|
||||
height: height,
|
||||
x: x,
|
||||
y: y
|
||||
};
|
||||
}
|
37
web/node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js.flow
generated
vendored
Normal file
37
web/node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,37 @@
|
|||
// @flow
|
||||
import type { Rect } from '../types';
|
||||
import getDocumentElement from './getDocumentElement';
|
||||
import getComputedStyle from './getComputedStyle';
|
||||
import getWindowScrollBarX from './getWindowScrollBarX';
|
||||
import getWindowScroll from './getWindowScroll';
|
||||
import { max } from '../utils/math';
|
||||
|
||||
// Gets the entire size of the scrollable document area, even extending outside
|
||||
// of the `<html>` and `<body>` rect bounds if horizontally scrollable
|
||||
export default function getDocumentRect(element: HTMLElement): Rect {
|
||||
const html = getDocumentElement(element);
|
||||
const winScroll = getWindowScroll(element);
|
||||
const body = element.ownerDocument?.body;
|
||||
|
||||
const width = max(
|
||||
html.scrollWidth,
|
||||
html.clientWidth,
|
||||
body ? body.scrollWidth : 0,
|
||||
body ? body.clientWidth : 0
|
||||
);
|
||||
const height = max(
|
||||
html.scrollHeight,
|
||||
html.clientHeight,
|
||||
body ? body.scrollHeight : 0,
|
||||
body ? body.clientHeight : 0
|
||||
);
|
||||
|
||||
let x = -winScroll.scrollLeft + getWindowScrollBarX(element);
|
||||
const y = -winScroll.scrollTop;
|
||||
|
||||
if (getComputedStyle(body || html).direction === 'rtl') {
|
||||
x += max(html.clientWidth, body ? body.clientWidth : 0) - width;
|
||||
}
|
||||
|
||||
return { width, height, x, y };
|
||||
}
|
4
web/node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.d.ts
generated
vendored
Normal file
4
web/node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,4 @@
|
|||
export default function getHTMLElementScroll(element: HTMLElement): {
|
||||
scrollLeft: number;
|
||||
scrollTop: number;
|
||||
};
|
6
web/node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js
generated
vendored
Normal file
6
web/node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js
generated
vendored
Normal file
|
@ -0,0 +1,6 @@
|
|||
export default function getHTMLElementScroll(element) {
|
||||
return {
|
||||
scrollLeft: element.scrollLeft,
|
||||
scrollTop: element.scrollTop
|
||||
};
|
||||
}
|
8
web/node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js.flow
generated
vendored
Normal file
8
web/node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,8 @@
|
|||
// @flow
|
||||
|
||||
export default function getHTMLElementScroll(element: HTMLElement) {
|
||||
return {
|
||||
scrollLeft: element.scrollLeft,
|
||||
scrollTop: element.scrollTop,
|
||||
};
|
||||
}
|
2
web/node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.d.ts
generated
vendored
Normal file
2
web/node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,2 @@
|
|||
import type { Rect } from "../types";
|
||||
export default function getLayoutRect(element: HTMLElement): Rect;
|
25
web/node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js
generated
vendored
Normal file
25
web/node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js
generated
vendored
Normal file
|
@ -0,0 +1,25 @@
|
|||
import getBoundingClientRect from "./getBoundingClientRect.js"; // Returns the layout rect of an element relative to its offsetParent. Layout
|
||||
// means it doesn't take into account transforms.
|
||||
|
||||
export default function getLayoutRect(element) {
|
||||
var clientRect = getBoundingClientRect(element); // Use the clientRect sizes if it's not been transformed.
|
||||
// Fixes https://github.com/popperjs/popper-core/issues/1223
|
||||
|
||||
var width = element.offsetWidth;
|
||||
var height = element.offsetHeight;
|
||||
|
||||
if (Math.abs(clientRect.width - width) <= 1) {
|
||||
width = clientRect.width;
|
||||
}
|
||||
|
||||
if (Math.abs(clientRect.height - height) <= 1) {
|
||||
height = clientRect.height;
|
||||
}
|
||||
|
||||
return {
|
||||
x: element.offsetLeft,
|
||||
y: element.offsetTop,
|
||||
width: width,
|
||||
height: height
|
||||
};
|
||||
}
|
29
web/node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js.flow
generated
vendored
Normal file
29
web/node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,29 @@
|
|||
// @flow
|
||||
import type { Rect } from '../types';
|
||||
import getBoundingClientRect from './getBoundingClientRect';
|
||||
|
||||
// Returns the layout rect of an element relative to its offsetParent. Layout
|
||||
// means it doesn't take into account transforms.
|
||||
export default function getLayoutRect(element: HTMLElement): Rect {
|
||||
const clientRect = getBoundingClientRect(element);
|
||||
|
||||
// Use the clientRect sizes if it's not been transformed.
|
||||
// Fixes https://github.com/popperjs/popper-core/issues/1223
|
||||
let width = element.offsetWidth;
|
||||
let height = element.offsetHeight;
|
||||
|
||||
if (Math.abs(clientRect.width - width) <= 1) {
|
||||
width = clientRect.width;
|
||||
}
|
||||
|
||||
if (Math.abs(clientRect.height - height) <= 1) {
|
||||
height = clientRect.height;
|
||||
}
|
||||
|
||||
return {
|
||||
x: element.offsetLeft,
|
||||
y: element.offsetTop,
|
||||
width,
|
||||
height,
|
||||
};
|
||||
}
|
2
web/node_modules/@popperjs/core/lib/dom-utils/getNodeName.d.ts
generated
vendored
Normal file
2
web/node_modules/@popperjs/core/lib/dom-utils/getNodeName.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,2 @@
|
|||
import type { Window } from "../types";
|
||||
export default function getNodeName(element: (Node | null | undefined) | Window): string | null | undefined;
|
3
web/node_modules/@popperjs/core/lib/dom-utils/getNodeName.js
generated
vendored
Normal file
3
web/node_modules/@popperjs/core/lib/dom-utils/getNodeName.js
generated
vendored
Normal file
|
@ -0,0 +1,3 @@
|
|||
export default function getNodeName(element) {
|
||||
return element ? (element.nodeName || '').toLowerCase() : null;
|
||||
}
|
6
web/node_modules/@popperjs/core/lib/dom-utils/getNodeName.js.flow
generated
vendored
Normal file
6
web/node_modules/@popperjs/core/lib/dom-utils/getNodeName.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,6 @@
|
|||
// @flow
|
||||
import type { Window } from '../types';
|
||||
|
||||
export default function getNodeName(element: ?Node | Window): ?string {
|
||||
return element ? (element.nodeName || '').toLowerCase() : null;
|
||||
}
|
5
web/node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.d.ts
generated
vendored
Normal file
5
web/node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,5 @@
|
|||
import type { Window } from "../types";
|
||||
export default function getNodeScroll(node: Node | Window): {
|
||||
scrollLeft: any;
|
||||
scrollTop: any;
|
||||
};
|
11
web/node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js
generated
vendored
Normal file
11
web/node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js
generated
vendored
Normal file
|
@ -0,0 +1,11 @@
|
|||
import getWindowScroll from "./getWindowScroll.js";
|
||||
import getWindow from "./getWindow.js";
|
||||
import { isHTMLElement } from "./instanceOf.js";
|
||||
import getHTMLElementScroll from "./getHTMLElementScroll.js";
|
||||
export default function getNodeScroll(node) {
|
||||
if (node === getWindow(node) || !isHTMLElement(node)) {
|
||||
return getWindowScroll(node);
|
||||
} else {
|
||||
return getHTMLElementScroll(node);
|
||||
}
|
||||
}
|
14
web/node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js.flow
generated
vendored
Normal file
14
web/node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,14 @@
|
|||
// @flow
|
||||
import getWindowScroll from './getWindowScroll';
|
||||
import getWindow from './getWindow';
|
||||
import { isHTMLElement } from './instanceOf';
|
||||
import getHTMLElementScroll from './getHTMLElementScroll';
|
||||
import type { Window } from '../types';
|
||||
|
||||
export default function getNodeScroll(node: Node | Window) {
|
||||
if (node === getWindow(node) || !isHTMLElement(node)) {
|
||||
return getWindowScroll(node);
|
||||
} else {
|
||||
return getHTMLElementScroll(node);
|
||||
}
|
||||
}
|
1
web/node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.d.ts
generated
vendored
Normal file
1
web/node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.d.ts
generated
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
export default function getOffsetParent(element: Element): any;
|
64
web/node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js
generated
vendored
Normal file
64
web/node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js
generated
vendored
Normal file
|
@ -0,0 +1,64 @@
|
|||
import getWindow from "./getWindow.js";
|
||||
import getNodeName from "./getNodeName.js";
|
||||
import getComputedStyle from "./getComputedStyle.js";
|
||||
import { isHTMLElement } from "./instanceOf.js";
|
||||
import isTableElement from "./isTableElement.js";
|
||||
import getParentNode from "./getParentNode.js";
|
||||
|
||||
function getTrueOffsetParent(element) {
|
||||
if (!isHTMLElement(element) || // https://github.com/popperjs/popper-core/issues/837
|
||||
getComputedStyle(element).position === 'fixed') {
|
||||
return null;
|
||||
}
|
||||
|
||||
return element.offsetParent;
|
||||
} // `.offsetParent` reports `null` for fixed elements, while absolute elements
|
||||
// return the containing block
|
||||
|
||||
|
||||
function getContainingBlock(element) {
|
||||
var isFirefox = navigator.userAgent.toLowerCase().indexOf('firefox') !== -1;
|
||||
var isIE = navigator.userAgent.indexOf('Trident') !== -1;
|
||||
|
||||
if (isIE && isHTMLElement(element)) {
|
||||
// In IE 9, 10 and 11 fixed elements containing block is always established by the viewport
|
||||
var elementCss = getComputedStyle(element);
|
||||
|
||||
if (elementCss.position === 'fixed') {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
var currentNode = getParentNode(element);
|
||||
|
||||
while (isHTMLElement(currentNode) && ['html', 'body'].indexOf(getNodeName(currentNode)) < 0) {
|
||||
var css = getComputedStyle(currentNode); // This is non-exhaustive but covers the most common CSS properties that
|
||||
// create a containing block.
|
||||
// https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block
|
||||
|
||||
if (css.transform !== 'none' || css.perspective !== 'none' || css.contain === 'paint' || ['transform', 'perspective'].indexOf(css.willChange) !== -1 || isFirefox && css.willChange === 'filter' || isFirefox && css.filter && css.filter !== 'none') {
|
||||
return currentNode;
|
||||
} else {
|
||||
currentNode = currentNode.parentNode;
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
} // Gets the closest ancestor positioned element. Handles some edge cases,
|
||||
// such as table ancestors and cross browser bugs.
|
||||
|
||||
|
||||
export default function getOffsetParent(element) {
|
||||
var window = getWindow(element);
|
||||
var offsetParent = getTrueOffsetParent(element);
|
||||
|
||||
while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') {
|
||||
offsetParent = getTrueOffsetParent(offsetParent);
|
||||
}
|
||||
|
||||
if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static')) {
|
||||
return window;
|
||||
}
|
||||
|
||||
return offsetParent || getContainingBlock(element) || window;
|
||||
}
|
88
web/node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js.flow
generated
vendored
Normal file
88
web/node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,88 @@
|
|||
// @flow
|
||||
import getWindow from './getWindow';
|
||||
import getNodeName from './getNodeName';
|
||||
import getComputedStyle from './getComputedStyle';
|
||||
import { isHTMLElement } from './instanceOf';
|
||||
import isTableElement from './isTableElement';
|
||||
import getParentNode from './getParentNode';
|
||||
|
||||
function getTrueOffsetParent(element: Element): ?Element {
|
||||
if (
|
||||
!isHTMLElement(element) ||
|
||||
// https://github.com/popperjs/popper-core/issues/837
|
||||
getComputedStyle(element).position === 'fixed'
|
||||
) {
|
||||
return null;
|
||||
}
|
||||
|
||||
return element.offsetParent;
|
||||
}
|
||||
|
||||
// `.offsetParent` reports `null` for fixed elements, while absolute elements
|
||||
// return the containing block
|
||||
function getContainingBlock(element: Element) {
|
||||
const isFirefox = navigator.userAgent.toLowerCase().indexOf('firefox') !== -1;
|
||||
const isIE = navigator.userAgent.indexOf('Trident') !== -1;
|
||||
|
||||
if (isIE && isHTMLElement(element)) {
|
||||
// In IE 9, 10 and 11 fixed elements containing block is always established by the viewport
|
||||
const elementCss = getComputedStyle(element);
|
||||
if (elementCss.position === 'fixed') {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
let currentNode = getParentNode(element);
|
||||
|
||||
while (
|
||||
isHTMLElement(currentNode) &&
|
||||
['html', 'body'].indexOf(getNodeName(currentNode)) < 0
|
||||
) {
|
||||
const css = getComputedStyle(currentNode);
|
||||
|
||||
// This is non-exhaustive but covers the most common CSS properties that
|
||||
// create a containing block.
|
||||
// https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block
|
||||
if (
|
||||
css.transform !== 'none' ||
|
||||
css.perspective !== 'none' ||
|
||||
css.contain === 'paint' ||
|
||||
['transform', 'perspective'].indexOf(css.willChange) !== -1 ||
|
||||
(isFirefox && css.willChange === 'filter') ||
|
||||
(isFirefox && css.filter && css.filter !== 'none')
|
||||
) {
|
||||
return currentNode;
|
||||
} else {
|
||||
currentNode = currentNode.parentNode;
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
// Gets the closest ancestor positioned element. Handles some edge cases,
|
||||
// such as table ancestors and cross browser bugs.
|
||||
export default function getOffsetParent(element: Element) {
|
||||
const window = getWindow(element);
|
||||
|
||||
let offsetParent = getTrueOffsetParent(element);
|
||||
|
||||
while (
|
||||
offsetParent &&
|
||||
isTableElement(offsetParent) &&
|
||||
getComputedStyle(offsetParent).position === 'static'
|
||||
) {
|
||||
offsetParent = getTrueOffsetParent(offsetParent);
|
||||
}
|
||||
|
||||
if (
|
||||
offsetParent &&
|
||||
(getNodeName(offsetParent) === 'html' ||
|
||||
(getNodeName(offsetParent) === 'body' &&
|
||||
getComputedStyle(offsetParent).position === 'static'))
|
||||
) {
|
||||
return window;
|
||||
}
|
||||
|
||||
return offsetParent || getContainingBlock(element) || window;
|
||||
}
|
1
web/node_modules/@popperjs/core/lib/dom-utils/getParentNode.d.ts
generated
vendored
Normal file
1
web/node_modules/@popperjs/core/lib/dom-utils/getParentNode.d.ts
generated
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
export default function getParentNode(element: Node | ShadowRoot): Node;
|
19
web/node_modules/@popperjs/core/lib/dom-utils/getParentNode.js
generated
vendored
Normal file
19
web/node_modules/@popperjs/core/lib/dom-utils/getParentNode.js
generated
vendored
Normal file
|
@ -0,0 +1,19 @@
|
|||
import getNodeName from "./getNodeName.js";
|
||||
import getDocumentElement from "./getDocumentElement.js";
|
||||
import { isShadowRoot } from "./instanceOf.js";
|
||||
export default function getParentNode(element) {
|
||||
if (getNodeName(element) === 'html') {
|
||||
return element;
|
||||
}
|
||||
|
||||
return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle
|
||||
// $FlowFixMe[incompatible-return]
|
||||
// $FlowFixMe[prop-missing]
|
||||
element.assignedSlot || // step into the shadow DOM of the parent of a slotted node
|
||||
element.parentNode || ( // DOM Element detected
|
||||
isShadowRoot(element) ? element.host : null) || // ShadowRoot detected
|
||||
// $FlowFixMe[incompatible-call]: HTMLElement is a Node
|
||||
getDocumentElement(element) // fallback
|
||||
|
||||
);
|
||||
}
|
21
web/node_modules/@popperjs/core/lib/dom-utils/getParentNode.js.flow
generated
vendored
Normal file
21
web/node_modules/@popperjs/core/lib/dom-utils/getParentNode.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,21 @@
|
|||
// @flow
|
||||
import getNodeName from './getNodeName';
|
||||
import getDocumentElement from './getDocumentElement';
|
||||
import { isShadowRoot } from './instanceOf';
|
||||
|
||||
export default function getParentNode(element: Node | ShadowRoot): Node {
|
||||
if (getNodeName(element) === 'html') {
|
||||
return element;
|
||||
}
|
||||
|
||||
return (
|
||||
// this is a quicker (but less type safe) way to save quite some bytes from the bundle
|
||||
// $FlowFixMe[incompatible-return]
|
||||
// $FlowFixMe[prop-missing]
|
||||
element.assignedSlot || // step into the shadow DOM of the parent of a slotted node
|
||||
element.parentNode || // DOM Element detected
|
||||
(isShadowRoot(element) ? element.host : null) || // ShadowRoot detected
|
||||
// $FlowFixMe[incompatible-call]: HTMLElement is a Node
|
||||
getDocumentElement(element) // fallback
|
||||
);
|
||||
}
|
1
web/node_modules/@popperjs/core/lib/dom-utils/getScrollParent.d.ts
generated
vendored
Normal file
1
web/node_modules/@popperjs/core/lib/dom-utils/getScrollParent.d.ts
generated
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
export default function getScrollParent(node: Node): HTMLElement;
|
16
web/node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js
generated
vendored
Normal file
16
web/node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js
generated
vendored
Normal file
|
@ -0,0 +1,16 @@
|
|||
import getParentNode from "./getParentNode.js";
|
||||
import isScrollParent from "./isScrollParent.js";
|
||||
import getNodeName from "./getNodeName.js";
|
||||
import { isHTMLElement } from "./instanceOf.js";
|
||||
export default function getScrollParent(node) {
|
||||
if (['html', 'body', '#document'].indexOf(getNodeName(node)) >= 0) {
|
||||
// $FlowFixMe[incompatible-return]: assume body is always available
|
||||
return node.ownerDocument.body;
|
||||
}
|
||||
|
||||
if (isHTMLElement(node) && isScrollParent(node)) {
|
||||
return node;
|
||||
}
|
||||
|
||||
return getScrollParent(getParentNode(node));
|
||||
}
|
18
web/node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js.flow
generated
vendored
Normal file
18
web/node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,18 @@
|
|||
// @flow
|
||||
import getParentNode from './getParentNode';
|
||||
import isScrollParent from './isScrollParent';
|
||||
import getNodeName from './getNodeName';
|
||||
import { isHTMLElement } from './instanceOf';
|
||||
|
||||
export default function getScrollParent(node: Node): HTMLElement {
|
||||
if (['html', 'body', '#document'].indexOf(getNodeName(node)) >= 0) {
|
||||
// $FlowFixMe[incompatible-return]: assume body is always available
|
||||
return node.ownerDocument.body;
|
||||
}
|
||||
|
||||
if (isHTMLElement(node) && isScrollParent(node)) {
|
||||
return node;
|
||||
}
|
||||
|
||||
return getScrollParent(getParentNode(node));
|
||||
}
|
6
web/node_modules/@popperjs/core/lib/dom-utils/getViewportRect.d.ts
generated
vendored
Normal file
6
web/node_modules/@popperjs/core/lib/dom-utils/getViewportRect.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,6 @@
|
|||
export default function getViewportRect(element: Element): {
|
||||
width: number;
|
||||
height: number;
|
||||
x: number;
|
||||
y: number;
|
||||
};
|
40
web/node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js
generated
vendored
Normal file
40
web/node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js
generated
vendored
Normal file
|
@ -0,0 +1,40 @@
|
|||
import getWindow from "./getWindow.js";
|
||||
import getDocumentElement from "./getDocumentElement.js";
|
||||
import getWindowScrollBarX from "./getWindowScrollBarX.js";
|
||||
export default function getViewportRect(element) {
|
||||
var win = getWindow(element);
|
||||
var html = getDocumentElement(element);
|
||||
var visualViewport = win.visualViewport;
|
||||
var width = html.clientWidth;
|
||||
var height = html.clientHeight;
|
||||
var x = 0;
|
||||
var y = 0; // NB: This isn't supported on iOS <= 12. If the keyboard is open, the popper
|
||||
// can be obscured underneath it.
|
||||
// Also, `html.clientHeight` adds the bottom bar height in Safari iOS, even
|
||||
// if it isn't open, so if this isn't available, the popper will be detected
|
||||
// to overflow the bottom of the screen too early.
|
||||
|
||||
if (visualViewport) {
|
||||
width = visualViewport.width;
|
||||
height = visualViewport.height; // Uses Layout Viewport (like Chrome; Safari does not currently)
|
||||
// In Chrome, it returns a value very close to 0 (+/-) but contains rounding
|
||||
// errors due to floating point numbers, so we need to check precision.
|
||||
// Safari returns a number <= 0, usually < -1 when pinch-zoomed
|
||||
// Feature detection fails in mobile emulation mode in Chrome.
|
||||
// Math.abs(win.innerWidth / visualViewport.scale - visualViewport.width) <
|
||||
// 0.001
|
||||
// Fallback here: "Not Safari" userAgent
|
||||
|
||||
if (!/^((?!chrome|android).)*safari/i.test(navigator.userAgent)) {
|
||||
x = visualViewport.offsetLeft;
|
||||
y = visualViewport.offsetTop;
|
||||
}
|
||||
}
|
||||
|
||||
return {
|
||||
width: width,
|
||||
height: height,
|
||||
x: x + getWindowScrollBarX(element),
|
||||
y: y
|
||||
};
|
||||
}
|
46
web/node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js.flow
generated
vendored
Normal file
46
web/node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,46 @@
|
|||
// @flow
|
||||
import getWindow from './getWindow';
|
||||
import getDocumentElement from './getDocumentElement';
|
||||
import getWindowScrollBarX from './getWindowScrollBarX';
|
||||
|
||||
export default function getViewportRect(element: Element) {
|
||||
const win = getWindow(element);
|
||||
const html = getDocumentElement(element);
|
||||
const visualViewport = win.visualViewport;
|
||||
|
||||
let width = html.clientWidth;
|
||||
let height = html.clientHeight;
|
||||
let x = 0;
|
||||
let y = 0;
|
||||
|
||||
// NB: This isn't supported on iOS <= 12. If the keyboard is open, the popper
|
||||
// can be obscured underneath it.
|
||||
// Also, `html.clientHeight` adds the bottom bar height in Safari iOS, even
|
||||
// if it isn't open, so if this isn't available, the popper will be detected
|
||||
// to overflow the bottom of the screen too early.
|
||||
if (visualViewport) {
|
||||
width = visualViewport.width;
|
||||
height = visualViewport.height;
|
||||
|
||||
// Uses Layout Viewport (like Chrome; Safari does not currently)
|
||||
// In Chrome, it returns a value very close to 0 (+/-) but contains rounding
|
||||
// errors due to floating point numbers, so we need to check precision.
|
||||
// Safari returns a number <= 0, usually < -1 when pinch-zoomed
|
||||
|
||||
// Feature detection fails in mobile emulation mode in Chrome.
|
||||
// Math.abs(win.innerWidth / visualViewport.scale - visualViewport.width) <
|
||||
// 0.001
|
||||
// Fallback here: "Not Safari" userAgent
|
||||
if (!/^((?!chrome|android).)*safari/i.test(navigator.userAgent)) {
|
||||
x = visualViewport.offsetLeft;
|
||||
y = visualViewport.offsetTop;
|
||||
}
|
||||
}
|
||||
|
||||
return {
|
||||
width,
|
||||
height,
|
||||
x: x + getWindowScrollBarX(element),
|
||||
y,
|
||||
};
|
||||
}
|
1
web/node_modules/@popperjs/core/lib/dom-utils/getWindow.d.ts
generated
vendored
Normal file
1
web/node_modules/@popperjs/core/lib/dom-utils/getWindow.d.ts
generated
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
export default function getWindow(node: any): any;
|
12
web/node_modules/@popperjs/core/lib/dom-utils/getWindow.js
generated
vendored
Normal file
12
web/node_modules/@popperjs/core/lib/dom-utils/getWindow.js
generated
vendored
Normal file
|
@ -0,0 +1,12 @@
|
|||
export default function getWindow(node) {
|
||||
if (node == null) {
|
||||
return window;
|
||||
}
|
||||
|
||||
if (node.toString() !== '[object Window]') {
|
||||
var ownerDocument = node.ownerDocument;
|
||||
return ownerDocument ? ownerDocument.defaultView || window : window;
|
||||
}
|
||||
|
||||
return node;
|
||||
}
|
16
web/node_modules/@popperjs/core/lib/dom-utils/getWindow.js.flow
generated
vendored
Normal file
16
web/node_modules/@popperjs/core/lib/dom-utils/getWindow.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,16 @@
|
|||
// @flow
|
||||
import type { Window } from '../types';
|
||||
declare function getWindow(node: Node | Window): Window;
|
||||
|
||||
export default function getWindow(node) {
|
||||
if (node == null) {
|
||||
return window;
|
||||
}
|
||||
|
||||
if (node.toString() !== '[object Window]') {
|
||||
const ownerDocument = node.ownerDocument;
|
||||
return ownerDocument ? ownerDocument.defaultView || window : window;
|
||||
}
|
||||
|
||||
return node;
|
||||
}
|
5
web/node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.d.ts
generated
vendored
Normal file
5
web/node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,5 @@
|
|||
import type { Window } from "../types";
|
||||
export default function getWindowScroll(node: Node | Window): {
|
||||
scrollLeft: any;
|
||||
scrollTop: any;
|
||||
};
|
10
web/node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js
generated
vendored
Normal file
10
web/node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js
generated
vendored
Normal file
|
@ -0,0 +1,10 @@
|
|||
import getWindow from "./getWindow.js";
|
||||
export default function getWindowScroll(node) {
|
||||
var win = getWindow(node);
|
||||
var scrollLeft = win.pageXOffset;
|
||||
var scrollTop = win.pageYOffset;
|
||||
return {
|
||||
scrollLeft: scrollLeft,
|
||||
scrollTop: scrollTop
|
||||
};
|
||||
}
|
14
web/node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js.flow
generated
vendored
Normal file
14
web/node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,14 @@
|
|||
// @flow
|
||||
import getWindow from './getWindow';
|
||||
import type { Window } from '../types';
|
||||
|
||||
export default function getWindowScroll(node: Node | Window) {
|
||||
const win = getWindow(node);
|
||||
const scrollLeft = win.pageXOffset;
|
||||
const scrollTop = win.pageYOffset;
|
||||
|
||||
return {
|
||||
scrollLeft,
|
||||
scrollTop,
|
||||
};
|
||||
}
|
1
web/node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.d.ts
generated
vendored
Normal file
1
web/node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.d.ts
generated
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
export default function getWindowScrollBarX(element: Element): number;
|
13
web/node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js
generated
vendored
Normal file
13
web/node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js
generated
vendored
Normal file
|
@ -0,0 +1,13 @@
|
|||
import getBoundingClientRect from "./getBoundingClientRect.js";
|
||||
import getDocumentElement from "./getDocumentElement.js";
|
||||
import getWindowScroll from "./getWindowScroll.js";
|
||||
export default function getWindowScrollBarX(element) {
|
||||
// If <html> has a CSS width greater than the viewport, then this will be
|
||||
// incorrect for RTL.
|
||||
// Popper 1 is broken in this case and never had a bug report so let's assume
|
||||
// it's not an issue. I don't think anyone ever specifies width on <html>
|
||||
// anyway.
|
||||
// Browsers where the left scrollbar doesn't cause an issue report `0` for
|
||||
// this (e.g. Edge 2019, IE11, Safari)
|
||||
return getBoundingClientRect(getDocumentElement(element)).left + getWindowScroll(element).scrollLeft;
|
||||
}
|
18
web/node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js.flow
generated
vendored
Normal file
18
web/node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,18 @@
|
|||
// @flow
|
||||
import getBoundingClientRect from './getBoundingClientRect';
|
||||
import getDocumentElement from './getDocumentElement';
|
||||
import getWindowScroll from './getWindowScroll';
|
||||
|
||||
export default function getWindowScrollBarX(element: Element): number {
|
||||
// If <html> has a CSS width greater than the viewport, then this will be
|
||||
// incorrect for RTL.
|
||||
// Popper 1 is broken in this case and never had a bug report so let's assume
|
||||
// it's not an issue. I don't think anyone ever specifies width on <html>
|
||||
// anyway.
|
||||
// Browsers where the left scrollbar doesn't cause an issue report `0` for
|
||||
// this (e.g. Edge 2019, IE11, Safari)
|
||||
return (
|
||||
getBoundingClientRect(getDocumentElement(element)).left +
|
||||
getWindowScroll(element).scrollLeft
|
||||
);
|
||||
}
|
4
web/node_modules/@popperjs/core/lib/dom-utils/instanceOf.d.ts
generated
vendored
Normal file
4
web/node_modules/@popperjs/core/lib/dom-utils/instanceOf.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,4 @@
|
|||
declare function isElement(node: unknown): boolean;
|
||||
declare function isHTMLElement(node: unknown): boolean;
|
||||
declare function isShadowRoot(node: unknown): boolean;
|
||||
export { isElement, isHTMLElement, isShadowRoot };
|
23
web/node_modules/@popperjs/core/lib/dom-utils/instanceOf.js
generated
vendored
Normal file
23
web/node_modules/@popperjs/core/lib/dom-utils/instanceOf.js
generated
vendored
Normal file
|
@ -0,0 +1,23 @@
|
|||
import getWindow from "./getWindow.js";
|
||||
|
||||
function isElement(node) {
|
||||
var OwnElement = getWindow(node).Element;
|
||||
return node instanceof OwnElement || node instanceof Element;
|
||||
}
|
||||
|
||||
function isHTMLElement(node) {
|
||||
var OwnElement = getWindow(node).HTMLElement;
|
||||
return node instanceof OwnElement || node instanceof HTMLElement;
|
||||
}
|
||||
|
||||
function isShadowRoot(node) {
|
||||
// IE 11 has no ShadowRoot
|
||||
if (typeof ShadowRoot === 'undefined') {
|
||||
return false;
|
||||
}
|
||||
|
||||
var OwnElement = getWindow(node).ShadowRoot;
|
||||
return node instanceof OwnElement || node instanceof ShadowRoot;
|
||||
}
|
||||
|
||||
export { isElement, isHTMLElement, isShadowRoot };
|
29
web/node_modules/@popperjs/core/lib/dom-utils/instanceOf.js.flow
generated
vendored
Normal file
29
web/node_modules/@popperjs/core/lib/dom-utils/instanceOf.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,29 @@
|
|||
// @flow
|
||||
import getWindow from './getWindow';
|
||||
|
||||
declare function isElement(node: mixed): boolean %checks(node instanceof
|
||||
Element);
|
||||
function isElement(node) {
|
||||
const OwnElement = getWindow(node).Element;
|
||||
return node instanceof OwnElement || node instanceof Element;
|
||||
}
|
||||
|
||||
declare function isHTMLElement(node: mixed): boolean %checks(node instanceof
|
||||
HTMLElement);
|
||||
function isHTMLElement(node) {
|
||||
const OwnElement = getWindow(node).HTMLElement;
|
||||
return node instanceof OwnElement || node instanceof HTMLElement;
|
||||
}
|
||||
|
||||
declare function isShadowRoot(node: mixed): boolean %checks(node instanceof
|
||||
ShadowRoot);
|
||||
function isShadowRoot(node) {
|
||||
// IE 11 has no ShadowRoot
|
||||
if (typeof ShadowRoot === 'undefined') {
|
||||
return false;
|
||||
}
|
||||
const OwnElement = getWindow(node).ShadowRoot;
|
||||
return node instanceof OwnElement || node instanceof ShadowRoot;
|
||||
}
|
||||
|
||||
export { isElement, isHTMLElement, isShadowRoot };
|
1
web/node_modules/@popperjs/core/lib/dom-utils/isScrollParent.d.ts
generated
vendored
Normal file
1
web/node_modules/@popperjs/core/lib/dom-utils/isScrollParent.d.ts
generated
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
export default function isScrollParent(element: HTMLElement): boolean;
|
10
web/node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js
generated
vendored
Normal file
10
web/node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js
generated
vendored
Normal file
|
@ -0,0 +1,10 @@
|
|||
import getComputedStyle from "./getComputedStyle.js";
|
||||
export default function isScrollParent(element) {
|
||||
// Firefox wants us to check `-x` and `-y` variations as well
|
||||
var _getComputedStyle = getComputedStyle(element),
|
||||
overflow = _getComputedStyle.overflow,
|
||||
overflowX = _getComputedStyle.overflowX,
|
||||
overflowY = _getComputedStyle.overflowY;
|
||||
|
||||
return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX);
|
||||
}
|
8
web/node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js.flow
generated
vendored
Normal file
8
web/node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,8 @@
|
|||
// @flow
|
||||
import getComputedStyle from './getComputedStyle';
|
||||
|
||||
export default function isScrollParent(element: HTMLElement): boolean {
|
||||
// Firefox wants us to check `-x` and `-y` variations as well
|
||||
const { overflow, overflowX, overflowY } = getComputedStyle(element);
|
||||
return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX);
|
||||
}
|
1
web/node_modules/@popperjs/core/lib/dom-utils/isTableElement.d.ts
generated
vendored
Normal file
1
web/node_modules/@popperjs/core/lib/dom-utils/isTableElement.d.ts
generated
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
export default function isTableElement(element: Element): boolean;
|
4
web/node_modules/@popperjs/core/lib/dom-utils/isTableElement.js
generated
vendored
Normal file
4
web/node_modules/@popperjs/core/lib/dom-utils/isTableElement.js
generated
vendored
Normal file
|
@ -0,0 +1,4 @@
|
|||
import getNodeName from "./getNodeName.js";
|
||||
export default function isTableElement(element) {
|
||||
return ['table', 'td', 'th'].indexOf(getNodeName(element)) >= 0;
|
||||
}
|
6
web/node_modules/@popperjs/core/lib/dom-utils/isTableElement.js.flow
generated
vendored
Normal file
6
web/node_modules/@popperjs/core/lib/dom-utils/isTableElement.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,6 @@
|
|||
// @flow
|
||||
import getNodeName from './getNodeName';
|
||||
|
||||
export default function isTableElement(element: Element): boolean {
|
||||
return ['table', 'td', 'th'].indexOf(getNodeName(element)) >= 0;
|
||||
}
|
2
web/node_modules/@popperjs/core/lib/dom-utils/listScrollParents.d.ts
generated
vendored
Normal file
2
web/node_modules/@popperjs/core/lib/dom-utils/listScrollParents.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,2 @@
|
|||
import type { Window, VisualViewport } from "../types";
|
||||
export default function listScrollParents(element: Node, list?: Array<Element | Window>): Array<Element | Window | VisualViewport>;
|
26
web/node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js
generated
vendored
Normal file
26
web/node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js
generated
vendored
Normal file
|
@ -0,0 +1,26 @@
|
|||
import getScrollParent from "./getScrollParent.js";
|
||||
import getParentNode from "./getParentNode.js";
|
||||
import getWindow from "./getWindow.js";
|
||||
import isScrollParent from "./isScrollParent.js";
|
||||
/*
|
||||
given a DOM element, return the list of all scroll parents, up the list of ancesors
|
||||
until we get to the top window object. This list is what we attach scroll listeners
|
||||
to, because if any of these parent elements scroll, we'll need to re-calculate the
|
||||
reference element's position.
|
||||
*/
|
||||
|
||||
export default function listScrollParents(element, list) {
|
||||
var _element$ownerDocumen;
|
||||
|
||||
if (list === void 0) {
|
||||
list = [];
|
||||
}
|
||||
|
||||
var scrollParent = getScrollParent(element);
|
||||
var isBody = scrollParent === ((_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body);
|
||||
var win = getWindow(scrollParent);
|
||||
var target = isBody ? [win].concat(win.visualViewport || [], isScrollParent(scrollParent) ? scrollParent : []) : scrollParent;
|
||||
var updatedList = list.concat(target);
|
||||
return isBody ? updatedList : // $FlowFixMe[incompatible-call]: isBody tells us target will be an HTMLElement here
|
||||
updatedList.concat(listScrollParents(getParentNode(target)));
|
||||
}
|
33
web/node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js.flow
generated
vendored
Normal file
33
web/node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,33 @@
|
|||
// @flow
|
||||
import getScrollParent from './getScrollParent';
|
||||
import getParentNode from './getParentNode';
|
||||
import getWindow from './getWindow';
|
||||
import type { Window, VisualViewport } from '../types';
|
||||
import isScrollParent from './isScrollParent';
|
||||
|
||||
/*
|
||||
given a DOM element, return the list of all scroll parents, up the list of ancesors
|
||||
until we get to the top window object. This list is what we attach scroll listeners
|
||||
to, because if any of these parent elements scroll, we'll need to re-calculate the
|
||||
reference element's position.
|
||||
*/
|
||||
export default function listScrollParents(
|
||||
element: Node,
|
||||
list: Array<Element | Window> = []
|
||||
): Array<Element | Window | VisualViewport> {
|
||||
const scrollParent = getScrollParent(element);
|
||||
const isBody = scrollParent === element.ownerDocument?.body;
|
||||
const win = getWindow(scrollParent);
|
||||
const target = isBody
|
||||
? [win].concat(
|
||||
win.visualViewport || [],
|
||||
isScrollParent(scrollParent) ? scrollParent : []
|
||||
)
|
||||
: scrollParent;
|
||||
const updatedList = list.concat(target);
|
||||
|
||||
return isBody
|
||||
? updatedList
|
||||
: // $FlowFixMe[incompatible-call]: isBody tells us target will be an HTMLElement here
|
||||
updatedList.concat(listScrollParents(getParentNode(target)));
|
||||
}
|
34
web/node_modules/@popperjs/core/lib/enums.d.ts
generated
vendored
Normal file
34
web/node_modules/@popperjs/core/lib/enums.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,34 @@
|
|||
export declare const top: "top";
|
||||
export declare const bottom: "bottom";
|
||||
export declare const right: "right";
|
||||
export declare const left: "left";
|
||||
export declare const auto: "auto";
|
||||
export declare type BasePlacement = typeof top | typeof bottom | typeof right | typeof left;
|
||||
export declare const basePlacements: Array<BasePlacement>;
|
||||
export declare const start: "start";
|
||||
export declare const end: "end";
|
||||
export declare type Variation = typeof start | typeof end;
|
||||
export declare const clippingParents: "clippingParents";
|
||||
export declare const viewport: "viewport";
|
||||
export declare type Boundary = HTMLElement | Array<HTMLElement> | typeof clippingParents;
|
||||
export declare type RootBoundary = typeof viewport | "document";
|
||||
export declare const popper: "popper";
|
||||
export declare const reference: "reference";
|
||||
export declare type Context = typeof popper | typeof reference;
|
||||
export declare type VariationPlacement = "top-start" | "top-end" | "bottom-start" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end";
|
||||
export declare type AutoPlacement = "auto" | "auto-start" | "auto-end";
|
||||
export declare type ComputedPlacement = VariationPlacement | BasePlacement;
|
||||
export declare type Placement = AutoPlacement | BasePlacement | VariationPlacement;
|
||||
export declare const variationPlacements: Array<VariationPlacement>;
|
||||
export declare const placements: Array<Placement>;
|
||||
export declare const beforeRead: "beforeRead";
|
||||
export declare const read: "read";
|
||||
export declare const afterRead: "afterRead";
|
||||
export declare const beforeMain: "beforeMain";
|
||||
export declare const main: "main";
|
||||
export declare const afterMain: "afterMain";
|
||||
export declare const beforeWrite: "beforeWrite";
|
||||
export declare const write: "write";
|
||||
export declare const afterWrite: "afterWrite";
|
||||
export declare const modifierPhases: Array<ModifierPhases>;
|
||||
export declare type ModifierPhases = typeof beforeRead | typeof read | typeof afterRead | typeof beforeMain | typeof main | typeof afterMain | typeof beforeWrite | typeof write | typeof afterWrite;
|
31
web/node_modules/@popperjs/core/lib/enums.js
generated
vendored
Normal file
31
web/node_modules/@popperjs/core/lib/enums.js
generated
vendored
Normal file
|
@ -0,0 +1,31 @@
|
|||
export var top = 'top';
|
||||
export var bottom = 'bottom';
|
||||
export var right = 'right';
|
||||
export var left = 'left';
|
||||
export var auto = 'auto';
|
||||
export var basePlacements = [top, bottom, right, left];
|
||||
export var start = 'start';
|
||||
export var end = 'end';
|
||||
export var clippingParents = 'clippingParents';
|
||||
export var viewport = 'viewport';
|
||||
export var popper = 'popper';
|
||||
export var reference = 'reference';
|
||||
export var variationPlacements = /*#__PURE__*/basePlacements.reduce(function (acc, placement) {
|
||||
return acc.concat([placement + "-" + start, placement + "-" + end]);
|
||||
}, []);
|
||||
export var placements = /*#__PURE__*/[].concat(basePlacements, [auto]).reduce(function (acc, placement) {
|
||||
return acc.concat([placement, placement + "-" + start, placement + "-" + end]);
|
||||
}, []); // modifiers that need to read the DOM
|
||||
|
||||
export var beforeRead = 'beforeRead';
|
||||
export var read = 'read';
|
||||
export var afterRead = 'afterRead'; // pure-logic modifiers
|
||||
|
||||
export var beforeMain = 'beforeMain';
|
||||
export var main = 'main';
|
||||
export var afterMain = 'afterMain'; // modifier with the purpose to write to the DOM (or write into a framework state)
|
||||
|
||||
export var beforeWrite = 'beforeWrite';
|
||||
export var write = 'write';
|
||||
export var afterWrite = 'afterWrite';
|
||||
export var modifierPhases = [beforeRead, read, afterRead, beforeMain, main, afterMain, beforeWrite, write, afterWrite];
|
94
web/node_modules/@popperjs/core/lib/enums.js.flow
generated
vendored
Normal file
94
web/node_modules/@popperjs/core/lib/enums.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,94 @@
|
|||
// @flow
|
||||
export const top: 'top' = 'top';
|
||||
export const bottom: 'bottom' = 'bottom';
|
||||
export const right: 'right' = 'right';
|
||||
export const left: 'left' = 'left';
|
||||
export const auto: 'auto' = 'auto';
|
||||
export type BasePlacement =
|
||||
| typeof top
|
||||
| typeof bottom
|
||||
| typeof right
|
||||
| typeof left;
|
||||
export const basePlacements: Array<BasePlacement> = [top, bottom, right, left];
|
||||
|
||||
export const start: 'start' = 'start';
|
||||
export const end: 'end' = 'end';
|
||||
export type Variation = typeof start | typeof end;
|
||||
|
||||
export const clippingParents: 'clippingParents' = 'clippingParents';
|
||||
export const viewport: 'viewport' = 'viewport';
|
||||
export type Boundary =
|
||||
| HTMLElement
|
||||
| Array<HTMLElement>
|
||||
| typeof clippingParents;
|
||||
export type RootBoundary = typeof viewport | 'document';
|
||||
|
||||
export const popper: 'popper' = 'popper';
|
||||
export const reference: 'reference' = 'reference';
|
||||
export type Context = typeof popper | typeof reference;
|
||||
|
||||
export type VariationPlacement =
|
||||
| 'top-start'
|
||||
| 'top-end'
|
||||
| 'bottom-start'
|
||||
| 'bottom-end'
|
||||
| 'right-start'
|
||||
| 'right-end'
|
||||
| 'left-start'
|
||||
| 'left-end';
|
||||
export type AutoPlacement = 'auto' | 'auto-start' | 'auto-end';
|
||||
export type ComputedPlacement = VariationPlacement | BasePlacement;
|
||||
export type Placement = AutoPlacement | BasePlacement | VariationPlacement;
|
||||
|
||||
export const variationPlacements: Array<VariationPlacement> = basePlacements.reduce(
|
||||
(acc: Array<VariationPlacement>, placement: BasePlacement) =>
|
||||
acc.concat([(`${placement}-${start}`: any), (`${placement}-${end}`: any)]),
|
||||
[]
|
||||
);
|
||||
export const placements: Array<Placement> = [...basePlacements, auto].reduce(
|
||||
(
|
||||
acc: Array<Placement>,
|
||||
placement: BasePlacement | typeof auto
|
||||
): Array<Placement> =>
|
||||
acc.concat([
|
||||
placement,
|
||||
(`${placement}-${start}`: any),
|
||||
(`${placement}-${end}`: any),
|
||||
]),
|
||||
[]
|
||||
);
|
||||
|
||||
// modifiers that need to read the DOM
|
||||
export const beforeRead: 'beforeRead' = 'beforeRead';
|
||||
export const read: 'read' = 'read';
|
||||
export const afterRead: 'afterRead' = 'afterRead';
|
||||
// pure-logic modifiers
|
||||
export const beforeMain: 'beforeMain' = 'beforeMain';
|
||||
export const main: 'main' = 'main';
|
||||
export const afterMain: 'afterMain' = 'afterMain';
|
||||
// modifier with the purpose to write to the DOM (or write into a framework state)
|
||||
export const beforeWrite: 'beforeWrite' = 'beforeWrite';
|
||||
export const write: 'write' = 'write';
|
||||
export const afterWrite: 'afterWrite' = 'afterWrite';
|
||||
export const modifierPhases: Array<ModifierPhases> = [
|
||||
beforeRead,
|
||||
read,
|
||||
afterRead,
|
||||
beforeMain,
|
||||
main,
|
||||
afterMain,
|
||||
beforeWrite,
|
||||
write,
|
||||
afterWrite,
|
||||
];
|
||||
|
||||
export type ModifierPhases =
|
||||
| typeof beforeRead
|
||||
| typeof read
|
||||
| typeof afterRead
|
||||
| typeof beforeMain
|
||||
| typeof main
|
||||
| typeof afterMain
|
||||
| typeof beforeWrite
|
||||
| typeof write
|
||||
| typeof afterWrite;
|
6
web/node_modules/@popperjs/core/lib/index.d.ts
generated
vendored
Normal file
6
web/node_modules/@popperjs/core/lib/index.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,6 @@
|
|||
export * from "./types";
|
||||
export * from "./enums";
|
||||
export * from "./modifiers";
|
||||
export { popperGenerator, detectOverflow, createPopper as createPopperBase } from "./createPopper";
|
||||
export { createPopper } from "./popper";
|
||||
export { createPopper as createPopperLite } from "./popper-lite";
|
8
web/node_modules/@popperjs/core/lib/index.js
generated
vendored
Normal file
8
web/node_modules/@popperjs/core/lib/index.js
generated
vendored
Normal file
|
@ -0,0 +1,8 @@
|
|||
export * from "./enums.js";
|
||||
export * from "./modifiers/index.js"; // eslint-disable-next-line import/no-unused-modules
|
||||
|
||||
export { popperGenerator, detectOverflow, createPopper as createPopperBase } from "./createPopper.js"; // eslint-disable-next-line import/no-unused-modules
|
||||
|
||||
export { createPopper } from "./popper.js"; // eslint-disable-next-line import/no-unused-modules
|
||||
|
||||
export { createPopper as createPopperLite } from "./popper-lite.js";
|
13
web/node_modules/@popperjs/core/lib/index.js.flow
generated
vendored
Normal file
13
web/node_modules/@popperjs/core/lib/index.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,13 @@
|
|||
// @flow
|
||||
export type * from './types';
|
||||
export * from './enums';
|
||||
export * from './modifiers';
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export { popperGenerator, detectOverflow, createPopper as createPopperBase } from './createPopper';
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export { createPopper } from './popper';
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export { createPopper as createPopperLite } from './popper-lite';
|
4
web/node_modules/@popperjs/core/lib/modifiers/applyStyles.d.ts
generated
vendored
Normal file
4
web/node_modules/@popperjs/core/lib/modifiers/applyStyles.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,4 @@
|
|||
import type { Modifier } from "../types";
|
||||
export declare type ApplyStylesModifier = Modifier<"applyStyles", {}>;
|
||||
declare const _default: ApplyStylesModifier;
|
||||
export default _default;
|
84
web/node_modules/@popperjs/core/lib/modifiers/applyStyles.js
generated
vendored
Normal file
84
web/node_modules/@popperjs/core/lib/modifiers/applyStyles.js
generated
vendored
Normal file
|
@ -0,0 +1,84 @@
|
|||
import getNodeName from "../dom-utils/getNodeName.js";
|
||||
import { isHTMLElement } from "../dom-utils/instanceOf.js"; // This modifier takes the styles prepared by the `computeStyles` modifier
|
||||
// and applies them to the HTMLElements such as popper and arrow
|
||||
|
||||
function applyStyles(_ref) {
|
||||
var state = _ref.state;
|
||||
Object.keys(state.elements).forEach(function (name) {
|
||||
var style = state.styles[name] || {};
|
||||
var attributes = state.attributes[name] || {};
|
||||
var element = state.elements[name]; // arrow is optional + virtual elements
|
||||
|
||||
if (!isHTMLElement(element) || !getNodeName(element)) {
|
||||
return;
|
||||
} // Flow doesn't support to extend this property, but it's the most
|
||||
// effective way to apply styles to an HTMLElement
|
||||
// $FlowFixMe[cannot-write]
|
||||
|
||||
|
||||
Object.assign(element.style, style);
|
||||
Object.keys(attributes).forEach(function (name) {
|
||||
var value = attributes[name];
|
||||
|
||||
if (value === false) {
|
||||
element.removeAttribute(name);
|
||||
} else {
|
||||
element.setAttribute(name, value === true ? '' : value);
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
function effect(_ref2) {
|
||||
var state = _ref2.state;
|
||||
var initialStyles = {
|
||||
popper: {
|
||||
position: state.options.strategy,
|
||||
left: '0',
|
||||
top: '0',
|
||||
margin: '0'
|
||||
},
|
||||
arrow: {
|
||||
position: 'absolute'
|
||||
},
|
||||
reference: {}
|
||||
};
|
||||
Object.assign(state.elements.popper.style, initialStyles.popper);
|
||||
state.styles = initialStyles;
|
||||
|
||||
if (state.elements.arrow) {
|
||||
Object.assign(state.elements.arrow.style, initialStyles.arrow);
|
||||
}
|
||||
|
||||
return function () {
|
||||
Object.keys(state.elements).forEach(function (name) {
|
||||
var element = state.elements[name];
|
||||
var attributes = state.attributes[name] || {};
|
||||
var styleProperties = Object.keys(state.styles.hasOwnProperty(name) ? state.styles[name] : initialStyles[name]); // Set all values to an empty string to unset them
|
||||
|
||||
var style = styleProperties.reduce(function (style, property) {
|
||||
style[property] = '';
|
||||
return style;
|
||||
}, {}); // arrow is optional + virtual elements
|
||||
|
||||
if (!isHTMLElement(element) || !getNodeName(element)) {
|
||||
return;
|
||||
}
|
||||
|
||||
Object.assign(element.style, style);
|
||||
Object.keys(attributes).forEach(function (attribute) {
|
||||
element.removeAttribute(attribute);
|
||||
});
|
||||
});
|
||||
};
|
||||
} // eslint-disable-next-line import/no-unused-modules
|
||||
|
||||
|
||||
export default {
|
||||
name: 'applyStyles',
|
||||
enabled: true,
|
||||
phase: 'write',
|
||||
fn: applyStyles,
|
||||
effect: effect,
|
||||
requires: ['computeStyles']
|
||||
};
|
98
web/node_modules/@popperjs/core/lib/modifiers/applyStyles.js.flow
generated
vendored
Normal file
98
web/node_modules/@popperjs/core/lib/modifiers/applyStyles.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,98 @@
|
|||
// @flow
|
||||
import type { Modifier, ModifierArguments } from '../types';
|
||||
import getNodeName from '../dom-utils/getNodeName';
|
||||
import { isHTMLElement } from '../dom-utils/instanceOf';
|
||||
|
||||
// This modifier takes the styles prepared by the `computeStyles` modifier
|
||||
// and applies them to the HTMLElements such as popper and arrow
|
||||
|
||||
function applyStyles({ state }: ModifierArguments<{||}>) {
|
||||
Object.keys(state.elements).forEach((name) => {
|
||||
const style = state.styles[name] || {};
|
||||
|
||||
const attributes = state.attributes[name] || {};
|
||||
const element = state.elements[name];
|
||||
|
||||
// arrow is optional + virtual elements
|
||||
if (!isHTMLElement(element) || !getNodeName(element)) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Flow doesn't support to extend this property, but it's the most
|
||||
// effective way to apply styles to an HTMLElement
|
||||
// $FlowFixMe[cannot-write]
|
||||
Object.assign(element.style, style);
|
||||
|
||||
Object.keys(attributes).forEach((name) => {
|
||||
const value = attributes[name];
|
||||
if (value === false) {
|
||||
element.removeAttribute(name);
|
||||
} else {
|
||||
element.setAttribute(name, value === true ? '' : value);
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
function effect({ state }: ModifierArguments<{||}>) {
|
||||
const initialStyles = {
|
||||
popper: {
|
||||
position: state.options.strategy,
|
||||
left: '0',
|
||||
top: '0',
|
||||
margin: '0',
|
||||
},
|
||||
arrow: {
|
||||
position: 'absolute',
|
||||
},
|
||||
reference: {},
|
||||
};
|
||||
|
||||
Object.assign(state.elements.popper.style, initialStyles.popper);
|
||||
state.styles = initialStyles;
|
||||
|
||||
if (state.elements.arrow) {
|
||||
Object.assign(state.elements.arrow.style, initialStyles.arrow);
|
||||
}
|
||||
|
||||
return () => {
|
||||
Object.keys(state.elements).forEach((name) => {
|
||||
const element = state.elements[name];
|
||||
const attributes = state.attributes[name] || {};
|
||||
|
||||
const styleProperties = Object.keys(
|
||||
state.styles.hasOwnProperty(name)
|
||||
? state.styles[name]
|
||||
: initialStyles[name]
|
||||
);
|
||||
|
||||
// Set all values to an empty string to unset them
|
||||
const style = styleProperties.reduce((style, property) => {
|
||||
style[property] = '';
|
||||
return style;
|
||||
}, {});
|
||||
|
||||
// arrow is optional + virtual elements
|
||||
if (!isHTMLElement(element) || !getNodeName(element)) {
|
||||
return;
|
||||
}
|
||||
|
||||
Object.assign(element.style, style);
|
||||
|
||||
Object.keys(attributes).forEach((attribute) => {
|
||||
element.removeAttribute(attribute);
|
||||
});
|
||||
});
|
||||
};
|
||||
}
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export type ApplyStylesModifier = Modifier<'applyStyles', {||}>;
|
||||
export default ({
|
||||
name: 'applyStyles',
|
||||
enabled: true,
|
||||
phase: 'write',
|
||||
fn: applyStyles,
|
||||
effect,
|
||||
requires: ['computeStyles'],
|
||||
}: ApplyStylesModifier);
|
13
web/node_modules/@popperjs/core/lib/modifiers/arrow.d.ts
generated
vendored
Normal file
13
web/node_modules/@popperjs/core/lib/modifiers/arrow.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,13 @@
|
|||
import type { Modifier, Padding, Rect } from "../types";
|
||||
import type { Placement } from "../enums";
|
||||
export declare type Options = {
|
||||
element: HTMLElement | string | null;
|
||||
padding: Padding | ((arg0: {
|
||||
popper: Rect;
|
||||
reference: Rect;
|
||||
placement: Placement;
|
||||
}) => Padding);
|
||||
};
|
||||
export declare type ArrowModifier = Modifier<"arrow", Options>;
|
||||
declare const _default: ArrowModifier;
|
||||
export default _default;
|
101
web/node_modules/@popperjs/core/lib/modifiers/arrow.js
generated
vendored
Normal file
101
web/node_modules/@popperjs/core/lib/modifiers/arrow.js
generated
vendored
Normal file
|
@ -0,0 +1,101 @@
|
|||
import getBasePlacement from "../utils/getBasePlacement.js";
|
||||
import getLayoutRect from "../dom-utils/getLayoutRect.js";
|
||||
import contains from "../dom-utils/contains.js";
|
||||
import getOffsetParent from "../dom-utils/getOffsetParent.js";
|
||||
import getMainAxisFromPlacement from "../utils/getMainAxisFromPlacement.js";
|
||||
import within from "../utils/within.js";
|
||||
import mergePaddingObject from "../utils/mergePaddingObject.js";
|
||||
import expandToHashMap from "../utils/expandToHashMap.js";
|
||||
import { left, right, basePlacements, top, bottom } from "../enums.js";
|
||||
import { isHTMLElement } from "../dom-utils/instanceOf.js"; // eslint-disable-next-line import/no-unused-modules
|
||||
|
||||
var toPaddingObject = function toPaddingObject(padding, state) {
|
||||
padding = typeof padding === 'function' ? padding(Object.assign({}, state.rects, {
|
||||
placement: state.placement
|
||||
})) : padding;
|
||||
return mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements));
|
||||
};
|
||||
|
||||
function arrow(_ref) {
|
||||
var _state$modifiersData$;
|
||||
|
||||
var state = _ref.state,
|
||||
name = _ref.name,
|
||||
options = _ref.options;
|
||||
var arrowElement = state.elements.arrow;
|
||||
var popperOffsets = state.modifiersData.popperOffsets;
|
||||
var basePlacement = getBasePlacement(state.placement);
|
||||
var axis = getMainAxisFromPlacement(basePlacement);
|
||||
var isVertical = [left, right].indexOf(basePlacement) >= 0;
|
||||
var len = isVertical ? 'height' : 'width';
|
||||
|
||||
if (!arrowElement || !popperOffsets) {
|
||||
return;
|
||||
}
|
||||
|
||||
var paddingObject = toPaddingObject(options.padding, state);
|
||||
var arrowRect = getLayoutRect(arrowElement);
|
||||
var minProp = axis === 'y' ? top : left;
|
||||
var maxProp = axis === 'y' ? bottom : right;
|
||||
var endDiff = state.rects.reference[len] + state.rects.reference[axis] - popperOffsets[axis] - state.rects.popper[len];
|
||||
var startDiff = popperOffsets[axis] - state.rects.reference[axis];
|
||||
var arrowOffsetParent = getOffsetParent(arrowElement);
|
||||
var clientSize = arrowOffsetParent ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0;
|
||||
var centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the popper if the center point is
|
||||
// outside of the popper bounds
|
||||
|
||||
var min = paddingObject[minProp];
|
||||
var max = clientSize - arrowRect[len] - paddingObject[maxProp];
|
||||
var center = clientSize / 2 - arrowRect[len] / 2 + centerToReference;
|
||||
var offset = within(min, center, max); // Prevents breaking syntax highlighting...
|
||||
|
||||
var axisProp = axis;
|
||||
state.modifiersData[name] = (_state$modifiersData$ = {}, _state$modifiersData$[axisProp] = offset, _state$modifiersData$.centerOffset = offset - center, _state$modifiersData$);
|
||||
}
|
||||
|
||||
function effect(_ref2) {
|
||||
var state = _ref2.state,
|
||||
options = _ref2.options;
|
||||
var _options$element = options.element,
|
||||
arrowElement = _options$element === void 0 ? '[data-popper-arrow]' : _options$element;
|
||||
|
||||
if (arrowElement == null) {
|
||||
return;
|
||||
} // CSS selector
|
||||
|
||||
|
||||
if (typeof arrowElement === 'string') {
|
||||
arrowElement = state.elements.popper.querySelector(arrowElement);
|
||||
|
||||
if (!arrowElement) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if (process.env.NODE_ENV !== "production") {
|
||||
if (!isHTMLElement(arrowElement)) {
|
||||
console.error(['Popper: "arrow" element must be an HTMLElement (not an SVGElement).', 'To use an SVG arrow, wrap it in an HTMLElement that will be used as', 'the arrow.'].join(' '));
|
||||
}
|
||||
}
|
||||
|
||||
if (!contains(state.elements.popper, arrowElement)) {
|
||||
if (process.env.NODE_ENV !== "production") {
|
||||
console.error(['Popper: "arrow" modifier\'s `element` must be a child of the popper', 'element.'].join(' '));
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
state.elements.arrow = arrowElement;
|
||||
} // eslint-disable-next-line import/no-unused-modules
|
||||
|
||||
|
||||
export default {
|
||||
name: 'arrow',
|
||||
enabled: true,
|
||||
phase: 'main',
|
||||
fn: arrow,
|
||||
effect: effect,
|
||||
requires: ['popperOffsets'],
|
||||
requiresIfExists: ['preventOverflow']
|
||||
};
|
142
web/node_modules/@popperjs/core/lib/modifiers/arrow.js.flow
generated
vendored
Normal file
142
web/node_modules/@popperjs/core/lib/modifiers/arrow.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,142 @@
|
|||
// @flow
|
||||
import type { Modifier, ModifierArguments, Padding, Rect } from '../types';
|
||||
import type { Placement } from '../enums';
|
||||
import getBasePlacement from '../utils/getBasePlacement';
|
||||
import getLayoutRect from '../dom-utils/getLayoutRect';
|
||||
import contains from '../dom-utils/contains';
|
||||
import getOffsetParent from '../dom-utils/getOffsetParent';
|
||||
import getMainAxisFromPlacement from '../utils/getMainAxisFromPlacement';
|
||||
import within from '../utils/within';
|
||||
import mergePaddingObject from '../utils/mergePaddingObject';
|
||||
import expandToHashMap from '../utils/expandToHashMap';
|
||||
import { left, right, basePlacements, top, bottom } from '../enums';
|
||||
import { isHTMLElement } from '../dom-utils/instanceOf';
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export type Options = {
|
||||
element: HTMLElement | string | null,
|
||||
padding:
|
||||
| Padding
|
||||
| (({|
|
||||
popper: Rect,
|
||||
reference: Rect,
|
||||
placement: Placement,
|
||||
|}) => Padding),
|
||||
};
|
||||
|
||||
const toPaddingObject = (padding, state) => {
|
||||
padding =
|
||||
typeof padding === 'function'
|
||||
? padding({ ...state.rects, placement: state.placement })
|
||||
: padding;
|
||||
|
||||
return mergePaddingObject(
|
||||
typeof padding !== 'number'
|
||||
? padding
|
||||
: expandToHashMap(padding, basePlacements)
|
||||
);
|
||||
};
|
||||
|
||||
function arrow({ state, name, options }: ModifierArguments<Options>) {
|
||||
const arrowElement = state.elements.arrow;
|
||||
const popperOffsets = state.modifiersData.popperOffsets;
|
||||
const basePlacement = getBasePlacement(state.placement);
|
||||
const axis = getMainAxisFromPlacement(basePlacement);
|
||||
const isVertical = [left, right].indexOf(basePlacement) >= 0;
|
||||
const len = isVertical ? 'height' : 'width';
|
||||
|
||||
if (!arrowElement || !popperOffsets) {
|
||||
return;
|
||||
}
|
||||
|
||||
const paddingObject = toPaddingObject(options.padding, state);
|
||||
const arrowRect = getLayoutRect(arrowElement);
|
||||
const minProp = axis === 'y' ? top : left;
|
||||
const maxProp = axis === 'y' ? bottom : right;
|
||||
|
||||
const endDiff =
|
||||
state.rects.reference[len] +
|
||||
state.rects.reference[axis] -
|
||||
popperOffsets[axis] -
|
||||
state.rects.popper[len];
|
||||
const startDiff = popperOffsets[axis] - state.rects.reference[axis];
|
||||
|
||||
const arrowOffsetParent = getOffsetParent(arrowElement);
|
||||
const clientSize = arrowOffsetParent
|
||||
? axis === 'y'
|
||||
? arrowOffsetParent.clientHeight || 0
|
||||
: arrowOffsetParent.clientWidth || 0
|
||||
: 0;
|
||||
|
||||
const centerToReference = endDiff / 2 - startDiff / 2;
|
||||
|
||||
// Make sure the arrow doesn't overflow the popper if the center point is
|
||||
// outside of the popper bounds
|
||||
const min = paddingObject[minProp];
|
||||
const max = clientSize - arrowRect[len] - paddingObject[maxProp];
|
||||
const center = clientSize / 2 - arrowRect[len] / 2 + centerToReference;
|
||||
const offset = within(min, center, max);
|
||||
|
||||
// Prevents breaking syntax highlighting...
|
||||
const axisProp: string = axis;
|
||||
state.modifiersData[name] = {
|
||||
[axisProp]: offset,
|
||||
centerOffset: offset - center,
|
||||
};
|
||||
}
|
||||
|
||||
function effect({ state, options }: ModifierArguments<Options>) {
|
||||
let { element: arrowElement = '[data-popper-arrow]' } = options;
|
||||
|
||||
if (arrowElement == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
// CSS selector
|
||||
if (typeof arrowElement === 'string') {
|
||||
arrowElement = state.elements.popper.querySelector(arrowElement);
|
||||
|
||||
if (!arrowElement) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if (false) {
|
||||
if (!isHTMLElement(arrowElement)) {
|
||||
console.error(
|
||||
[
|
||||
'Popper: "arrow" element must be an HTMLElement (not an SVGElement).',
|
||||
'To use an SVG arrow, wrap it in an HTMLElement that will be used as',
|
||||
'the arrow.',
|
||||
].join(' ')
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
if (!contains(state.elements.popper, arrowElement)) {
|
||||
if (false) {
|
||||
console.error(
|
||||
[
|
||||
'Popper: "arrow" modifier\'s `element` must be a child of the popper',
|
||||
'element.',
|
||||
].join(' ')
|
||||
);
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
state.elements.arrow = arrowElement;
|
||||
}
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export type ArrowModifier = Modifier<'arrow', Options>;
|
||||
export default ({
|
||||
name: 'arrow',
|
||||
enabled: true,
|
||||
phase: 'main',
|
||||
fn: arrow,
|
||||
effect,
|
||||
requires: ['popperOffsets'],
|
||||
requiresIfExists: ['preventOverflow'],
|
||||
}: ArrowModifier);
|
36
web/node_modules/@popperjs/core/lib/modifiers/computeStyles.d.ts
generated
vendored
Normal file
36
web/node_modules/@popperjs/core/lib/modifiers/computeStyles.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,36 @@
|
|||
import type { PositioningStrategy, Offsets, Modifier, Rect } from "../types";
|
||||
import { BasePlacement } from "../enums";
|
||||
export declare type RoundOffsets = (offsets: Partial<{
|
||||
x: number;
|
||||
y: number;
|
||||
centerOffset: number;
|
||||
}>) => Offsets;
|
||||
export declare type Options = {
|
||||
gpuAcceleration: boolean;
|
||||
adaptive: boolean;
|
||||
roundOffsets?: boolean | RoundOffsets;
|
||||
};
|
||||
export declare function mapToStyles({ popper, popperRect, placement, offsets, position, gpuAcceleration, adaptive, roundOffsets }: {
|
||||
popper: HTMLElement;
|
||||
popperRect: Rect;
|
||||
placement: BasePlacement;
|
||||
offsets: Partial<{
|
||||
x: number;
|
||||
y: number;
|
||||
centerOffset: number;
|
||||
}>;
|
||||
position: PositioningStrategy;
|
||||
gpuAcceleration: boolean;
|
||||
adaptive: boolean;
|
||||
roundOffsets: boolean | RoundOffsets;
|
||||
}): {
|
||||
transform: string;
|
||||
top: string;
|
||||
right: string;
|
||||
bottom: string;
|
||||
left: string;
|
||||
position: PositioningStrategy;
|
||||
};
|
||||
export declare type ComputeStylesModifier = Modifier<"computeStyles", Options>;
|
||||
declare const _default: ComputeStylesModifier;
|
||||
export default _default;
|
155
web/node_modules/@popperjs/core/lib/modifiers/computeStyles.js
generated
vendored
Normal file
155
web/node_modules/@popperjs/core/lib/modifiers/computeStyles.js
generated
vendored
Normal file
|
@ -0,0 +1,155 @@
|
|||
import { top, left, right, bottom } from "../enums.js";
|
||||
import getOffsetParent from "../dom-utils/getOffsetParent.js";
|
||||
import getWindow from "../dom-utils/getWindow.js";
|
||||
import getDocumentElement from "../dom-utils/getDocumentElement.js";
|
||||
import getComputedStyle from "../dom-utils/getComputedStyle.js";
|
||||
import getBasePlacement from "../utils/getBasePlacement.js";
|
||||
import { round } from "../utils/math.js"; // eslint-disable-next-line import/no-unused-modules
|
||||
|
||||
var unsetSides = {
|
||||
top: 'auto',
|
||||
right: 'auto',
|
||||
bottom: 'auto',
|
||||
left: 'auto'
|
||||
}; // Round the offsets to the nearest suitable subpixel based on the DPR.
|
||||
// Zooming can change the DPR, but it seems to report a value that will
|
||||
// cleanly divide the values into the appropriate subpixels.
|
||||
|
||||
function roundOffsetsByDPR(_ref) {
|
||||
var x = _ref.x,
|
||||
y = _ref.y;
|
||||
var win = window;
|
||||
var dpr = win.devicePixelRatio || 1;
|
||||
return {
|
||||
x: round(round(x * dpr) / dpr) || 0,
|
||||
y: round(round(y * dpr) / dpr) || 0
|
||||
};
|
||||
}
|
||||
|
||||
export function mapToStyles(_ref2) {
|
||||
var _Object$assign2;
|
||||
|
||||
var popper = _ref2.popper,
|
||||
popperRect = _ref2.popperRect,
|
||||
placement = _ref2.placement,
|
||||
offsets = _ref2.offsets,
|
||||
position = _ref2.position,
|
||||
gpuAcceleration = _ref2.gpuAcceleration,
|
||||
adaptive = _ref2.adaptive,
|
||||
roundOffsets = _ref2.roundOffsets;
|
||||
|
||||
var _ref3 = roundOffsets === true ? roundOffsetsByDPR(offsets) : typeof roundOffsets === 'function' ? roundOffsets(offsets) : offsets,
|
||||
_ref3$x = _ref3.x,
|
||||
x = _ref3$x === void 0 ? 0 : _ref3$x,
|
||||
_ref3$y = _ref3.y,
|
||||
y = _ref3$y === void 0 ? 0 : _ref3$y;
|
||||
|
||||
var hasX = offsets.hasOwnProperty('x');
|
||||
var hasY = offsets.hasOwnProperty('y');
|
||||
var sideX = left;
|
||||
var sideY = top;
|
||||
var win = window;
|
||||
|
||||
if (adaptive) {
|
||||
var offsetParent = getOffsetParent(popper);
|
||||
var heightProp = 'clientHeight';
|
||||
var widthProp = 'clientWidth';
|
||||
|
||||
if (offsetParent === getWindow(popper)) {
|
||||
offsetParent = getDocumentElement(popper);
|
||||
|
||||
if (getComputedStyle(offsetParent).position !== 'static') {
|
||||
heightProp = 'scrollHeight';
|
||||
widthProp = 'scrollWidth';
|
||||
}
|
||||
} // $FlowFixMe[incompatible-cast]: force type refinement, we compare offsetParent with window above, but Flow doesn't detect it
|
||||
|
||||
|
||||
offsetParent = offsetParent;
|
||||
|
||||
if (placement === top) {
|
||||
sideY = bottom; // $FlowFixMe[prop-missing]
|
||||
|
||||
y -= offsetParent[heightProp] - popperRect.height;
|
||||
y *= gpuAcceleration ? 1 : -1;
|
||||
}
|
||||
|
||||
if (placement === left) {
|
||||
sideX = right; // $FlowFixMe[prop-missing]
|
||||
|
||||
x -= offsetParent[widthProp] - popperRect.width;
|
||||
x *= gpuAcceleration ? 1 : -1;
|
||||
}
|
||||
}
|
||||
|
||||
var commonStyles = Object.assign({
|
||||
position: position
|
||||
}, adaptive && unsetSides);
|
||||
|
||||
if (gpuAcceleration) {
|
||||
var _Object$assign;
|
||||
|
||||
return Object.assign({}, commonStyles, (_Object$assign = {}, _Object$assign[sideY] = hasY ? '0' : '', _Object$assign[sideX] = hasX ? '0' : '', _Object$assign.transform = (win.devicePixelRatio || 1) < 2 ? "translate(" + x + "px, " + y + "px)" : "translate3d(" + x + "px, " + y + "px, 0)", _Object$assign));
|
||||
}
|
||||
|
||||
return Object.assign({}, commonStyles, (_Object$assign2 = {}, _Object$assign2[sideY] = hasY ? y + "px" : '', _Object$assign2[sideX] = hasX ? x + "px" : '', _Object$assign2.transform = '', _Object$assign2));
|
||||
}
|
||||
|
||||
function computeStyles(_ref4) {
|
||||
var state = _ref4.state,
|
||||
options = _ref4.options;
|
||||
var _options$gpuAccelerat = options.gpuAcceleration,
|
||||
gpuAcceleration = _options$gpuAccelerat === void 0 ? true : _options$gpuAccelerat,
|
||||
_options$adaptive = options.adaptive,
|
||||
adaptive = _options$adaptive === void 0 ? true : _options$adaptive,
|
||||
_options$roundOffsets = options.roundOffsets,
|
||||
roundOffsets = _options$roundOffsets === void 0 ? true : _options$roundOffsets;
|
||||
|
||||
if (process.env.NODE_ENV !== "production") {
|
||||
var transitionProperty = getComputedStyle(state.elements.popper).transitionProperty || '';
|
||||
|
||||
if (adaptive && ['transform', 'top', 'right', 'bottom', 'left'].some(function (property) {
|
||||
return transitionProperty.indexOf(property) >= 0;
|
||||
})) {
|
||||
console.warn(['Popper: Detected CSS transitions on at least one of the following', 'CSS properties: "transform", "top", "right", "bottom", "left".', '\n\n', 'Disable the "computeStyles" modifier\'s `adaptive` option to allow', 'for smooth transitions, or remove these properties from the CSS', 'transition declaration on the popper element if only transitioning', 'opacity or background-color for example.', '\n\n', 'We recommend using the popper element as a wrapper around an inner', 'element that can have any CSS property transitioned for animations.'].join(' '));
|
||||
}
|
||||
}
|
||||
|
||||
var commonStyles = {
|
||||
placement: getBasePlacement(state.placement),
|
||||
popper: state.elements.popper,
|
||||
popperRect: state.rects.popper,
|
||||
gpuAcceleration: gpuAcceleration
|
||||
};
|
||||
|
||||
if (state.modifiersData.popperOffsets != null) {
|
||||
state.styles.popper = Object.assign({}, state.styles.popper, mapToStyles(Object.assign({}, commonStyles, {
|
||||
offsets: state.modifiersData.popperOffsets,
|
||||
position: state.options.strategy,
|
||||
adaptive: adaptive,
|
||||
roundOffsets: roundOffsets
|
||||
})));
|
||||
}
|
||||
|
||||
if (state.modifiersData.arrow != null) {
|
||||
state.styles.arrow = Object.assign({}, state.styles.arrow, mapToStyles(Object.assign({}, commonStyles, {
|
||||
offsets: state.modifiersData.arrow,
|
||||
position: 'absolute',
|
||||
adaptive: false,
|
||||
roundOffsets: roundOffsets
|
||||
})));
|
||||
}
|
||||
|
||||
state.attributes.popper = Object.assign({}, state.attributes.popper, {
|
||||
'data-popper-placement': state.placement
|
||||
});
|
||||
} // eslint-disable-next-line import/no-unused-modules
|
||||
|
||||
|
||||
export default {
|
||||
name: 'computeStyles',
|
||||
enabled: true,
|
||||
phase: 'beforeWrite',
|
||||
fn: computeStyles,
|
||||
data: {}
|
||||
};
|
226
web/node_modules/@popperjs/core/lib/modifiers/computeStyles.js.flow
generated
vendored
Normal file
226
web/node_modules/@popperjs/core/lib/modifiers/computeStyles.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,226 @@
|
|||
// @flow
|
||||
import type {
|
||||
PositioningStrategy,
|
||||
Offsets,
|
||||
Modifier,
|
||||
ModifierArguments,
|
||||
Rect,
|
||||
Window,
|
||||
} from '../types';
|
||||
import { type BasePlacement, top, left, right, bottom } from '../enums';
|
||||
import getOffsetParent from '../dom-utils/getOffsetParent';
|
||||
import getWindow from '../dom-utils/getWindow';
|
||||
import getDocumentElement from '../dom-utils/getDocumentElement';
|
||||
import getComputedStyle from '../dom-utils/getComputedStyle';
|
||||
import getBasePlacement from '../utils/getBasePlacement';
|
||||
import { round } from '../utils/math';
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export type RoundOffsets = (
|
||||
offsets: $Shape<{ x: number, y: number, centerOffset: number }>
|
||||
) => Offsets;
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export type Options = {
|
||||
gpuAcceleration: boolean,
|
||||
adaptive: boolean,
|
||||
roundOffsets?: boolean | RoundOffsets,
|
||||
};
|
||||
|
||||
const unsetSides = {
|
||||
top: 'auto',
|
||||
right: 'auto',
|
||||
bottom: 'auto',
|
||||
left: 'auto',
|
||||
};
|
||||
|
||||
// Round the offsets to the nearest suitable subpixel based on the DPR.
|
||||
// Zooming can change the DPR, but it seems to report a value that will
|
||||
// cleanly divide the values into the appropriate subpixels.
|
||||
function roundOffsetsByDPR({ x, y }): Offsets {
|
||||
const win: Window = window;
|
||||
const dpr = win.devicePixelRatio || 1;
|
||||
|
||||
return {
|
||||
x: round(round(x * dpr) / dpr) || 0,
|
||||
y: round(round(y * dpr) / dpr) || 0,
|
||||
};
|
||||
}
|
||||
|
||||
export function mapToStyles({
|
||||
popper,
|
||||
popperRect,
|
||||
placement,
|
||||
offsets,
|
||||
position,
|
||||
gpuAcceleration,
|
||||
adaptive,
|
||||
roundOffsets,
|
||||
}: {
|
||||
popper: HTMLElement,
|
||||
popperRect: Rect,
|
||||
placement: BasePlacement,
|
||||
offsets: $Shape<{ x: number, y: number, centerOffset: number }>,
|
||||
position: PositioningStrategy,
|
||||
gpuAcceleration: boolean,
|
||||
adaptive: boolean,
|
||||
roundOffsets: boolean | RoundOffsets,
|
||||
}) {
|
||||
let { x = 0, y = 0 } =
|
||||
roundOffsets === true
|
||||
? roundOffsetsByDPR(offsets)
|
||||
: typeof roundOffsets === 'function'
|
||||
? roundOffsets(offsets)
|
||||
: offsets;
|
||||
|
||||
const hasX = offsets.hasOwnProperty('x');
|
||||
const hasY = offsets.hasOwnProperty('y');
|
||||
|
||||
let sideX: string = left;
|
||||
let sideY: string = top;
|
||||
|
||||
const win: Window = window;
|
||||
|
||||
if (adaptive) {
|
||||
let offsetParent = getOffsetParent(popper);
|
||||
let heightProp = 'clientHeight';
|
||||
let widthProp = 'clientWidth';
|
||||
|
||||
if (offsetParent === getWindow(popper)) {
|
||||
offsetParent = getDocumentElement(popper);
|
||||
|
||||
if (getComputedStyle(offsetParent).position !== 'static') {
|
||||
heightProp = 'scrollHeight';
|
||||
widthProp = 'scrollWidth';
|
||||
}
|
||||
}
|
||||
|
||||
// $FlowFixMe[incompatible-cast]: force type refinement, we compare offsetParent with window above, but Flow doesn't detect it
|
||||
offsetParent = (offsetParent: Element);
|
||||
|
||||
if (placement === top) {
|
||||
sideY = bottom;
|
||||
// $FlowFixMe[prop-missing]
|
||||
y -= offsetParent[heightProp] - popperRect.height;
|
||||
y *= gpuAcceleration ? 1 : -1;
|
||||
}
|
||||
|
||||
if (placement === left) {
|
||||
sideX = right;
|
||||
// $FlowFixMe[prop-missing]
|
||||
x -= offsetParent[widthProp] - popperRect.width;
|
||||
x *= gpuAcceleration ? 1 : -1;
|
||||
}
|
||||
}
|
||||
|
||||
const commonStyles = {
|
||||
position,
|
||||
...(adaptive && unsetSides),
|
||||
};
|
||||
|
||||
if (gpuAcceleration) {
|
||||
return {
|
||||
...commonStyles,
|
||||
[sideY]: hasY ? '0' : '',
|
||||
[sideX]: hasX ? '0' : '',
|
||||
// Layer acceleration can disable subpixel rendering which causes slightly
|
||||
// blurry text on low PPI displays, so we want to use 2D transforms
|
||||
// instead
|
||||
transform:
|
||||
(win.devicePixelRatio || 1) < 2
|
||||
? `translate(${x}px, ${y}px)`
|
||||
: `translate3d(${x}px, ${y}px, 0)`,
|
||||
};
|
||||
}
|
||||
|
||||
return {
|
||||
...commonStyles,
|
||||
[sideY]: hasY ? `${y}px` : '',
|
||||
[sideX]: hasX ? `${x}px` : '',
|
||||
transform: '',
|
||||
};
|
||||
}
|
||||
|
||||
function computeStyles({ state, options }: ModifierArguments<Options>) {
|
||||
const {
|
||||
gpuAcceleration = true,
|
||||
adaptive = true,
|
||||
// defaults to use builtin `roundOffsetsByDPR`
|
||||
roundOffsets = true,
|
||||
} = options;
|
||||
|
||||
if (false) {
|
||||
const transitionProperty =
|
||||
getComputedStyle(state.elements.popper).transitionProperty || '';
|
||||
|
||||
if (
|
||||
adaptive &&
|
||||
['transform', 'top', 'right', 'bottom', 'left'].some(
|
||||
(property) => transitionProperty.indexOf(property) >= 0
|
||||
)
|
||||
) {
|
||||
console.warn(
|
||||
[
|
||||
'Popper: Detected CSS transitions on at least one of the following',
|
||||
'CSS properties: "transform", "top", "right", "bottom", "left".',
|
||||
'\n\n',
|
||||
'Disable the "computeStyles" modifier\'s `adaptive` option to allow',
|
||||
'for smooth transitions, or remove these properties from the CSS',
|
||||
'transition declaration on the popper element if only transitioning',
|
||||
'opacity or background-color for example.',
|
||||
'\n\n',
|
||||
'We recommend using the popper element as a wrapper around an inner',
|
||||
'element that can have any CSS property transitioned for animations.',
|
||||
].join(' ')
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
const commonStyles = {
|
||||
placement: getBasePlacement(state.placement),
|
||||
popper: state.elements.popper,
|
||||
popperRect: state.rects.popper,
|
||||
gpuAcceleration,
|
||||
};
|
||||
|
||||
if (state.modifiersData.popperOffsets != null) {
|
||||
state.styles.popper = {
|
||||
...state.styles.popper,
|
||||
...mapToStyles({
|
||||
...commonStyles,
|
||||
offsets: state.modifiersData.popperOffsets,
|
||||
position: state.options.strategy,
|
||||
adaptive,
|
||||
roundOffsets,
|
||||
}),
|
||||
};
|
||||
}
|
||||
|
||||
if (state.modifiersData.arrow != null) {
|
||||
state.styles.arrow = {
|
||||
...state.styles.arrow,
|
||||
...mapToStyles({
|
||||
...commonStyles,
|
||||
offsets: state.modifiersData.arrow,
|
||||
position: 'absolute',
|
||||
adaptive: false,
|
||||
roundOffsets,
|
||||
}),
|
||||
};
|
||||
}
|
||||
|
||||
state.attributes.popper = {
|
||||
...state.attributes.popper,
|
||||
'data-popper-placement': state.placement,
|
||||
};
|
||||
}
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export type ComputeStylesModifier = Modifier<'computeStyles', Options>;
|
||||
export default ({
|
||||
name: 'computeStyles',
|
||||
enabled: true,
|
||||
phase: 'beforeWrite',
|
||||
fn: computeStyles,
|
||||
data: {},
|
||||
}: ComputeStylesModifier);
|
8
web/node_modules/@popperjs/core/lib/modifiers/eventListeners.d.ts
generated
vendored
Normal file
8
web/node_modules/@popperjs/core/lib/modifiers/eventListeners.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,8 @@
|
|||
import type { Modifier } from "../types";
|
||||
export declare type Options = {
|
||||
scroll: boolean;
|
||||
resize: boolean;
|
||||
};
|
||||
export declare type EventListenersModifier = Modifier<"eventListeners", Options>;
|
||||
declare const _default: EventListenersModifier;
|
||||
export default _default;
|
49
web/node_modules/@popperjs/core/lib/modifiers/eventListeners.js
generated
vendored
Normal file
49
web/node_modules/@popperjs/core/lib/modifiers/eventListeners.js
generated
vendored
Normal file
|
@ -0,0 +1,49 @@
|
|||
import getWindow from "../dom-utils/getWindow.js"; // eslint-disable-next-line import/no-unused-modules
|
||||
|
||||
var passive = {
|
||||
passive: true
|
||||
};
|
||||
|
||||
function effect(_ref) {
|
||||
var state = _ref.state,
|
||||
instance = _ref.instance,
|
||||
options = _ref.options;
|
||||
var _options$scroll = options.scroll,
|
||||
scroll = _options$scroll === void 0 ? true : _options$scroll,
|
||||
_options$resize = options.resize,
|
||||
resize = _options$resize === void 0 ? true : _options$resize;
|
||||
var window = getWindow(state.elements.popper);
|
||||
var scrollParents = [].concat(state.scrollParents.reference, state.scrollParents.popper);
|
||||
|
||||
if (scroll) {
|
||||
scrollParents.forEach(function (scrollParent) {
|
||||
scrollParent.addEventListener('scroll', instance.update, passive);
|
||||
});
|
||||
}
|
||||
|
||||
if (resize) {
|
||||
window.addEventListener('resize', instance.update, passive);
|
||||
}
|
||||
|
||||
return function () {
|
||||
if (scroll) {
|
||||
scrollParents.forEach(function (scrollParent) {
|
||||
scrollParent.removeEventListener('scroll', instance.update, passive);
|
||||
});
|
||||
}
|
||||
|
||||
if (resize) {
|
||||
window.removeEventListener('resize', instance.update, passive);
|
||||
}
|
||||
};
|
||||
} // eslint-disable-next-line import/no-unused-modules
|
||||
|
||||
|
||||
export default {
|
||||
name: 'eventListeners',
|
||||
enabled: true,
|
||||
phase: 'write',
|
||||
fn: function fn() {},
|
||||
effect: effect,
|
||||
data: {}
|
||||
};
|
54
web/node_modules/@popperjs/core/lib/modifiers/eventListeners.js.flow
generated
vendored
Normal file
54
web/node_modules/@popperjs/core/lib/modifiers/eventListeners.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,54 @@
|
|||
// @flow
|
||||
import type { ModifierArguments, Modifier } from '../types';
|
||||
import getWindow from '../dom-utils/getWindow';
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export type Options = {
|
||||
scroll: boolean,
|
||||
resize: boolean,
|
||||
};
|
||||
|
||||
const passive = { passive: true };
|
||||
|
||||
function effect({ state, instance, options }: ModifierArguments<Options>) {
|
||||
const { scroll = true, resize = true } = options;
|
||||
|
||||
const window = getWindow(state.elements.popper);
|
||||
const scrollParents = [
|
||||
...state.scrollParents.reference,
|
||||
...state.scrollParents.popper,
|
||||
];
|
||||
|
||||
if (scroll) {
|
||||
scrollParents.forEach(scrollParent => {
|
||||
scrollParent.addEventListener('scroll', instance.update, passive);
|
||||
});
|
||||
}
|
||||
|
||||
if (resize) {
|
||||
window.addEventListener('resize', instance.update, passive);
|
||||
}
|
||||
|
||||
return () => {
|
||||
if (scroll) {
|
||||
scrollParents.forEach(scrollParent => {
|
||||
scrollParent.removeEventListener('scroll', instance.update, passive);
|
||||
});
|
||||
}
|
||||
|
||||
if (resize) {
|
||||
window.removeEventListener('resize', instance.update, passive);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export type EventListenersModifier = Modifier<'eventListeners', Options>;
|
||||
export default ({
|
||||
name: 'eventListeners',
|
||||
enabled: true,
|
||||
phase: 'write',
|
||||
fn: () => {},
|
||||
effect,
|
||||
data: {},
|
||||
}: EventListenersModifier);
|
16
web/node_modules/@popperjs/core/lib/modifiers/flip.d.ts
generated
vendored
Normal file
16
web/node_modules/@popperjs/core/lib/modifiers/flip.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,16 @@
|
|||
import type { Placement, Boundary, RootBoundary } from "../enums";
|
||||
import type { Modifier, Padding } from "../types";
|
||||
export declare type Options = {
|
||||
mainAxis: boolean;
|
||||
altAxis: boolean;
|
||||
fallbackPlacements: Array<Placement>;
|
||||
padding: Padding;
|
||||
boundary: Boundary;
|
||||
rootBoundary: RootBoundary;
|
||||
altBoundary: boolean;
|
||||
flipVariations: boolean;
|
||||
allowedAutoPlacements: Array<Placement>;
|
||||
};
|
||||
export declare type FlipModifier = Modifier<"flip", Options>;
|
||||
declare const _default: FlipModifier;
|
||||
export default _default;
|
147
web/node_modules/@popperjs/core/lib/modifiers/flip.js
generated
vendored
Normal file
147
web/node_modules/@popperjs/core/lib/modifiers/flip.js
generated
vendored
Normal file
|
@ -0,0 +1,147 @@
|
|||
import getOppositePlacement from "../utils/getOppositePlacement.js";
|
||||
import getBasePlacement from "../utils/getBasePlacement.js";
|
||||
import getOppositeVariationPlacement from "../utils/getOppositeVariationPlacement.js";
|
||||
import detectOverflow from "../utils/detectOverflow.js";
|
||||
import computeAutoPlacement from "../utils/computeAutoPlacement.js";
|
||||
import { bottom, top, start, right, left, auto } from "../enums.js";
|
||||
import getVariation from "../utils/getVariation.js"; // eslint-disable-next-line import/no-unused-modules
|
||||
|
||||
function getExpandedFallbackPlacements(placement) {
|
||||
if (getBasePlacement(placement) === auto) {
|
||||
return [];
|
||||
}
|
||||
|
||||
var oppositePlacement = getOppositePlacement(placement);
|
||||
return [getOppositeVariationPlacement(placement), oppositePlacement, getOppositeVariationPlacement(oppositePlacement)];
|
||||
}
|
||||
|
||||
function flip(_ref) {
|
||||
var state = _ref.state,
|
||||
options = _ref.options,
|
||||
name = _ref.name;
|
||||
|
||||
if (state.modifiersData[name]._skip) {
|
||||
return;
|
||||
}
|
||||
|
||||
var _options$mainAxis = options.mainAxis,
|
||||
checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis,
|
||||
_options$altAxis = options.altAxis,
|
||||
checkAltAxis = _options$altAxis === void 0 ? true : _options$altAxis,
|
||||
specifiedFallbackPlacements = options.fallbackPlacements,
|
||||
padding = options.padding,
|
||||
boundary = options.boundary,
|
||||
rootBoundary = options.rootBoundary,
|
||||
altBoundary = options.altBoundary,
|
||||
_options$flipVariatio = options.flipVariations,
|
||||
flipVariations = _options$flipVariatio === void 0 ? true : _options$flipVariatio,
|
||||
allowedAutoPlacements = options.allowedAutoPlacements;
|
||||
var preferredPlacement = state.options.placement;
|
||||
var basePlacement = getBasePlacement(preferredPlacement);
|
||||
var isBasePlacement = basePlacement === preferredPlacement;
|
||||
var fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipVariations ? [getOppositePlacement(preferredPlacement)] : getExpandedFallbackPlacements(preferredPlacement));
|
||||
var placements = [preferredPlacement].concat(fallbackPlacements).reduce(function (acc, placement) {
|
||||
return acc.concat(getBasePlacement(placement) === auto ? computeAutoPlacement(state, {
|
||||
placement: placement,
|
||||
boundary: boundary,
|
||||
rootBoundary: rootBoundary,
|
||||
padding: padding,
|
||||
flipVariations: flipVariations,
|
||||
allowedAutoPlacements: allowedAutoPlacements
|
||||
}) : placement);
|
||||
}, []);
|
||||
var referenceRect = state.rects.reference;
|
||||
var popperRect = state.rects.popper;
|
||||
var checksMap = new Map();
|
||||
var makeFallbackChecks = true;
|
||||
var firstFittingPlacement = placements[0];
|
||||
|
||||
for (var i = 0; i < placements.length; i++) {
|
||||
var placement = placements[i];
|
||||
|
||||
var _basePlacement = getBasePlacement(placement);
|
||||
|
||||
var isStartVariation = getVariation(placement) === start;
|
||||
var isVertical = [top, bottom].indexOf(_basePlacement) >= 0;
|
||||
var len = isVertical ? 'width' : 'height';
|
||||
var overflow = detectOverflow(state, {
|
||||
placement: placement,
|
||||
boundary: boundary,
|
||||
rootBoundary: rootBoundary,
|
||||
altBoundary: altBoundary,
|
||||
padding: padding
|
||||
});
|
||||
var mainVariationSide = isVertical ? isStartVariation ? right : left : isStartVariation ? bottom : top;
|
||||
|
||||
if (referenceRect[len] > popperRect[len]) {
|
||||
mainVariationSide = getOppositePlacement(mainVariationSide);
|
||||
}
|
||||
|
||||
var altVariationSide = getOppositePlacement(mainVariationSide);
|
||||
var checks = [];
|
||||
|
||||
if (checkMainAxis) {
|
||||
checks.push(overflow[_basePlacement] <= 0);
|
||||
}
|
||||
|
||||
if (checkAltAxis) {
|
||||
checks.push(overflow[mainVariationSide] <= 0, overflow[altVariationSide] <= 0);
|
||||
}
|
||||
|
||||
if (checks.every(function (check) {
|
||||
return check;
|
||||
})) {
|
||||
firstFittingPlacement = placement;
|
||||
makeFallbackChecks = false;
|
||||
break;
|
||||
}
|
||||
|
||||
checksMap.set(placement, checks);
|
||||
}
|
||||
|
||||
if (makeFallbackChecks) {
|
||||
// `2` may be desired in some cases – research later
|
||||
var numberOfChecks = flipVariations ? 3 : 1;
|
||||
|
||||
var _loop = function _loop(_i) {
|
||||
var fittingPlacement = placements.find(function (placement) {
|
||||
var checks = checksMap.get(placement);
|
||||
|
||||
if (checks) {
|
||||
return checks.slice(0, _i).every(function (check) {
|
||||
return check;
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
if (fittingPlacement) {
|
||||
firstFittingPlacement = fittingPlacement;
|
||||
return "break";
|
||||
}
|
||||
};
|
||||
|
||||
for (var _i = numberOfChecks; _i > 0; _i--) {
|
||||
var _ret = _loop(_i);
|
||||
|
||||
if (_ret === "break") break;
|
||||
}
|
||||
}
|
||||
|
||||
if (state.placement !== firstFittingPlacement) {
|
||||
state.modifiersData[name]._skip = true;
|
||||
state.placement = firstFittingPlacement;
|
||||
state.reset = true;
|
||||
}
|
||||
} // eslint-disable-next-line import/no-unused-modules
|
||||
|
||||
|
||||
export default {
|
||||
name: 'flip',
|
||||
enabled: true,
|
||||
phase: 'main',
|
||||
fn: flip,
|
||||
requiresIfExists: ['offset'],
|
||||
data: {
|
||||
_skip: false
|
||||
}
|
||||
};
|
177
web/node_modules/@popperjs/core/lib/modifiers/flip.js.flow
generated
vendored
Normal file
177
web/node_modules/@popperjs/core/lib/modifiers/flip.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,177 @@
|
|||
// @flow
|
||||
import type { Placement, Boundary, RootBoundary } from '../enums';
|
||||
import type { ModifierArguments, Modifier, Padding } from '../types';
|
||||
import getOppositePlacement from '../utils/getOppositePlacement';
|
||||
import getBasePlacement from '../utils/getBasePlacement';
|
||||
import getOppositeVariationPlacement from '../utils/getOppositeVariationPlacement';
|
||||
import detectOverflow from '../utils/detectOverflow';
|
||||
import computeAutoPlacement from '../utils/computeAutoPlacement';
|
||||
import { bottom, top, start, right, left, auto } from '../enums';
|
||||
import getVariation from '../utils/getVariation';
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export type Options = {
|
||||
mainAxis: boolean,
|
||||
altAxis: boolean,
|
||||
fallbackPlacements: Array<Placement>,
|
||||
padding: Padding,
|
||||
boundary: Boundary,
|
||||
rootBoundary: RootBoundary,
|
||||
altBoundary: boolean,
|
||||
flipVariations: boolean,
|
||||
allowedAutoPlacements: Array<Placement>,
|
||||
};
|
||||
|
||||
function getExpandedFallbackPlacements(placement: Placement): Array<Placement> {
|
||||
if (getBasePlacement(placement) === auto) {
|
||||
return [];
|
||||
}
|
||||
|
||||
const oppositePlacement = getOppositePlacement(placement);
|
||||
|
||||
return [
|
||||
getOppositeVariationPlacement(placement),
|
||||
oppositePlacement,
|
||||
getOppositeVariationPlacement(oppositePlacement),
|
||||
];
|
||||
}
|
||||
|
||||
function flip({ state, options, name }: ModifierArguments<Options>) {
|
||||
if (state.modifiersData[name]._skip) {
|
||||
return;
|
||||
}
|
||||
|
||||
const {
|
||||
mainAxis: checkMainAxis = true,
|
||||
altAxis: checkAltAxis = true,
|
||||
fallbackPlacements: specifiedFallbackPlacements,
|
||||
padding,
|
||||
boundary,
|
||||
rootBoundary,
|
||||
altBoundary,
|
||||
flipVariations = true,
|
||||
allowedAutoPlacements,
|
||||
} = options;
|
||||
|
||||
const preferredPlacement = state.options.placement;
|
||||
const basePlacement = getBasePlacement(preferredPlacement);
|
||||
const isBasePlacement = basePlacement === preferredPlacement;
|
||||
|
||||
const fallbackPlacements =
|
||||
specifiedFallbackPlacements ||
|
||||
(isBasePlacement || !flipVariations
|
||||
? [getOppositePlacement(preferredPlacement)]
|
||||
: getExpandedFallbackPlacements(preferredPlacement));
|
||||
|
||||
const placements = [preferredPlacement, ...fallbackPlacements].reduce(
|
||||
(acc, placement) => {
|
||||
return acc.concat(
|
||||
getBasePlacement(placement) === auto
|
||||
? computeAutoPlacement(state, {
|
||||
placement,
|
||||
boundary,
|
||||
rootBoundary,
|
||||
padding,
|
||||
flipVariations,
|
||||
allowedAutoPlacements,
|
||||
})
|
||||
: placement
|
||||
);
|
||||
},
|
||||
[]
|
||||
);
|
||||
|
||||
const referenceRect = state.rects.reference;
|
||||
const popperRect = state.rects.popper;
|
||||
|
||||
const checksMap = new Map();
|
||||
let makeFallbackChecks = true;
|
||||
let firstFittingPlacement = placements[0];
|
||||
|
||||
for (let i = 0; i < placements.length; i++) {
|
||||
const placement = placements[i];
|
||||
const basePlacement = getBasePlacement(placement);
|
||||
const isStartVariation = getVariation(placement) === start;
|
||||
const isVertical = [top, bottom].indexOf(basePlacement) >= 0;
|
||||
const len = isVertical ? 'width' : 'height';
|
||||
|
||||
const overflow = detectOverflow(state, {
|
||||
placement,
|
||||
boundary,
|
||||
rootBoundary,
|
||||
altBoundary,
|
||||
padding,
|
||||
});
|
||||
|
||||
let mainVariationSide: any = isVertical
|
||||
? isStartVariation
|
||||
? right
|
||||
: left
|
||||
: isStartVariation
|
||||
? bottom
|
||||
: top;
|
||||
|
||||
if (referenceRect[len] > popperRect[len]) {
|
||||
mainVariationSide = getOppositePlacement(mainVariationSide);
|
||||
}
|
||||
|
||||
const altVariationSide: any = getOppositePlacement(mainVariationSide);
|
||||
|
||||
const checks = [];
|
||||
|
||||
if (checkMainAxis) {
|
||||
checks.push(overflow[basePlacement] <= 0);
|
||||
}
|
||||
|
||||
if (checkAltAxis) {
|
||||
checks.push(
|
||||
overflow[mainVariationSide] <= 0,
|
||||
overflow[altVariationSide] <= 0
|
||||
);
|
||||
}
|
||||
|
||||
if (checks.every((check) => check)) {
|
||||
firstFittingPlacement = placement;
|
||||
makeFallbackChecks = false;
|
||||
break;
|
||||
}
|
||||
|
||||
checksMap.set(placement, checks);
|
||||
}
|
||||
|
||||
if (makeFallbackChecks) {
|
||||
// `2` may be desired in some cases – research later
|
||||
const numberOfChecks = flipVariations ? 3 : 1;
|
||||
|
||||
for (let i = numberOfChecks; i > 0; i--) {
|
||||
const fittingPlacement = placements.find((placement) => {
|
||||
const checks = checksMap.get(placement);
|
||||
if (checks) {
|
||||
return checks.slice(0, i).every((check) => check);
|
||||
}
|
||||
});
|
||||
|
||||
if (fittingPlacement) {
|
||||
firstFittingPlacement = fittingPlacement;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (state.placement !== firstFittingPlacement) {
|
||||
state.modifiersData[name]._skip = true;
|
||||
state.placement = firstFittingPlacement;
|
||||
state.reset = true;
|
||||
}
|
||||
}
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export type FlipModifier = Modifier<'flip', Options>;
|
||||
export default ({
|
||||
name: 'flip',
|
||||
enabled: true,
|
||||
phase: 'main',
|
||||
fn: flip,
|
||||
requiresIfExists: ['offset'],
|
||||
data: { _skip: false },
|
||||
}: FlipModifier);
|
4
web/node_modules/@popperjs/core/lib/modifiers/hide.d.ts
generated
vendored
Normal file
4
web/node_modules/@popperjs/core/lib/modifiers/hide.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,4 @@
|
|||
import type { Modifier } from "../types";
|
||||
export declare type HideModifier = Modifier<"hide", {}>;
|
||||
declare const _default: HideModifier;
|
||||
export default _default;
|
61
web/node_modules/@popperjs/core/lib/modifiers/hide.js
generated
vendored
Normal file
61
web/node_modules/@popperjs/core/lib/modifiers/hide.js
generated
vendored
Normal file
|
@ -0,0 +1,61 @@
|
|||
import { top, bottom, left, right } from "../enums.js";
|
||||
import detectOverflow from "../utils/detectOverflow.js";
|
||||
|
||||
function getSideOffsets(overflow, rect, preventedOffsets) {
|
||||
if (preventedOffsets === void 0) {
|
||||
preventedOffsets = {
|
||||
x: 0,
|
||||
y: 0
|
||||
};
|
||||
}
|
||||
|
||||
return {
|
||||
top: overflow.top - rect.height - preventedOffsets.y,
|
||||
right: overflow.right - rect.width + preventedOffsets.x,
|
||||
bottom: overflow.bottom - rect.height + preventedOffsets.y,
|
||||
left: overflow.left - rect.width - preventedOffsets.x
|
||||
};
|
||||
}
|
||||
|
||||
function isAnySideFullyClipped(overflow) {
|
||||
return [top, right, bottom, left].some(function (side) {
|
||||
return overflow[side] >= 0;
|
||||
});
|
||||
}
|
||||
|
||||
function hide(_ref) {
|
||||
var state = _ref.state,
|
||||
name = _ref.name;
|
||||
var referenceRect = state.rects.reference;
|
||||
var popperRect = state.rects.popper;
|
||||
var preventedOffsets = state.modifiersData.preventOverflow;
|
||||
var referenceOverflow = detectOverflow(state, {
|
||||
elementContext: 'reference'
|
||||
});
|
||||
var popperAltOverflow = detectOverflow(state, {
|
||||
altBoundary: true
|
||||
});
|
||||
var referenceClippingOffsets = getSideOffsets(referenceOverflow, referenceRect);
|
||||
var popperEscapeOffsets = getSideOffsets(popperAltOverflow, popperRect, preventedOffsets);
|
||||
var isReferenceHidden = isAnySideFullyClipped(referenceClippingOffsets);
|
||||
var hasPopperEscaped = isAnySideFullyClipped(popperEscapeOffsets);
|
||||
state.modifiersData[name] = {
|
||||
referenceClippingOffsets: referenceClippingOffsets,
|
||||
popperEscapeOffsets: popperEscapeOffsets,
|
||||
isReferenceHidden: isReferenceHidden,
|
||||
hasPopperEscaped: hasPopperEscaped
|
||||
};
|
||||
state.attributes.popper = Object.assign({}, state.attributes.popper, {
|
||||
'data-popper-reference-hidden': isReferenceHidden,
|
||||
'data-popper-escaped': hasPopperEscaped
|
||||
});
|
||||
} // eslint-disable-next-line import/no-unused-modules
|
||||
|
||||
|
||||
export default {
|
||||
name: 'hide',
|
||||
enabled: true,
|
||||
phase: 'main',
|
||||
requiresIfExists: ['preventOverflow'],
|
||||
fn: hide
|
||||
};
|
76
web/node_modules/@popperjs/core/lib/modifiers/hide.js.flow
generated
vendored
Normal file
76
web/node_modules/@popperjs/core/lib/modifiers/hide.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,76 @@
|
|||
// @flow
|
||||
import type {
|
||||
ModifierArguments,
|
||||
Modifier,
|
||||
Rect,
|
||||
SideObject,
|
||||
Offsets,
|
||||
} from '../types';
|
||||
import { top, bottom, left, right } from '../enums';
|
||||
import detectOverflow from '../utils/detectOverflow';
|
||||
|
||||
function getSideOffsets(
|
||||
overflow: SideObject,
|
||||
rect: Rect,
|
||||
preventedOffsets: Offsets = { x: 0, y: 0 }
|
||||
): SideObject {
|
||||
return {
|
||||
top: overflow.top - rect.height - preventedOffsets.y,
|
||||
right: overflow.right - rect.width + preventedOffsets.x,
|
||||
bottom: overflow.bottom - rect.height + preventedOffsets.y,
|
||||
left: overflow.left - rect.width - preventedOffsets.x,
|
||||
};
|
||||
}
|
||||
|
||||
function isAnySideFullyClipped(overflow: SideObject): boolean {
|
||||
return [top, right, bottom, left].some((side) => overflow[side] >= 0);
|
||||
}
|
||||
|
||||
function hide({ state, name }: ModifierArguments<{||}>) {
|
||||
const referenceRect = state.rects.reference;
|
||||
const popperRect = state.rects.popper;
|
||||
const preventedOffsets = state.modifiersData.preventOverflow;
|
||||
|
||||
const referenceOverflow = detectOverflow(state, {
|
||||
elementContext: 'reference',
|
||||
});
|
||||
const popperAltOverflow = detectOverflow(state, {
|
||||
altBoundary: true,
|
||||
});
|
||||
|
||||
const referenceClippingOffsets = getSideOffsets(
|
||||
referenceOverflow,
|
||||
referenceRect
|
||||
);
|
||||
const popperEscapeOffsets = getSideOffsets(
|
||||
popperAltOverflow,
|
||||
popperRect,
|
||||
preventedOffsets
|
||||
);
|
||||
|
||||
const isReferenceHidden = isAnySideFullyClipped(referenceClippingOffsets);
|
||||
const hasPopperEscaped = isAnySideFullyClipped(popperEscapeOffsets);
|
||||
|
||||
state.modifiersData[name] = {
|
||||
referenceClippingOffsets,
|
||||
popperEscapeOffsets,
|
||||
isReferenceHidden,
|
||||
hasPopperEscaped,
|
||||
};
|
||||
|
||||
state.attributes.popper = {
|
||||
...state.attributes.popper,
|
||||
'data-popper-reference-hidden': isReferenceHidden,
|
||||
'data-popper-escaped': hasPopperEscaped,
|
||||
};
|
||||
}
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export type HideModifier = Modifier<'hide', {||}>;
|
||||
export default ({
|
||||
name: 'hide',
|
||||
enabled: true,
|
||||
phase: 'main',
|
||||
requiresIfExists: ['preventOverflow'],
|
||||
fn: hide,
|
||||
}: HideModifier);
|
9
web/node_modules/@popperjs/core/lib/modifiers/index.d.ts
generated
vendored
Normal file
9
web/node_modules/@popperjs/core/lib/modifiers/index.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,9 @@
|
|||
export { default as applyStyles } from "./applyStyles";
|
||||
export { default as arrow } from "./arrow";
|
||||
export { default as computeStyles } from "./computeStyles";
|
||||
export { default as eventListeners } from "./eventListeners";
|
||||
export { default as flip } from "./flip";
|
||||
export { default as hide } from "./hide";
|
||||
export { default as offset } from "./offset";
|
||||
export { default as popperOffsets } from "./popperOffsets";
|
||||
export { default as preventOverflow } from "./preventOverflow";
|
9
web/node_modules/@popperjs/core/lib/modifiers/index.js
generated
vendored
Normal file
9
web/node_modules/@popperjs/core/lib/modifiers/index.js
generated
vendored
Normal file
|
@ -0,0 +1,9 @@
|
|||
export { default as applyStyles } from "./applyStyles.js";
|
||||
export { default as arrow } from "./arrow.js";
|
||||
export { default as computeStyles } from "./computeStyles.js";
|
||||
export { default as eventListeners } from "./eventListeners.js";
|
||||
export { default as flip } from "./flip.js";
|
||||
export { default as hide } from "./hide.js";
|
||||
export { default as offset } from "./offset.js";
|
||||
export { default as popperOffsets } from "./popperOffsets.js";
|
||||
export { default as preventOverflow } from "./preventOverflow.js";
|
10
web/node_modules/@popperjs/core/lib/modifiers/index.js.flow
generated
vendored
Normal file
10
web/node_modules/@popperjs/core/lib/modifiers/index.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,10 @@
|
|||
// @flow
|
||||
export { default as applyStyles } from './applyStyles';
|
||||
export { default as arrow } from './arrow';
|
||||
export { default as computeStyles } from './computeStyles';
|
||||
export { default as eventListeners } from './eventListeners';
|
||||
export { default as flip } from './flip';
|
||||
export { default as hide } from './hide';
|
||||
export { default as offset } from './offset';
|
||||
export { default as popperOffsets } from './popperOffsets';
|
||||
export { default as preventOverflow } from './preventOverflow';
|
18
web/node_modules/@popperjs/core/lib/modifiers/offset.d.ts
generated
vendored
Normal file
18
web/node_modules/@popperjs/core/lib/modifiers/offset.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,18 @@
|
|||
import type { Placement } from "../enums";
|
||||
import type { Modifier, Rect, Offsets } from "../types";
|
||||
declare type OffsetsFunction = (arg0: {
|
||||
popper: Rect;
|
||||
reference: Rect;
|
||||
placement: Placement;
|
||||
}) => [number | null | undefined, number | null | undefined];
|
||||
declare type Offset = OffsetsFunction | [number | null | undefined, number | null | undefined];
|
||||
export declare type Options = {
|
||||
offset: Offset;
|
||||
};
|
||||
export declare function distanceAndSkiddingToXY(placement: Placement, rects: {
|
||||
popper: Rect;
|
||||
reference: Rect;
|
||||
}, offset: Offset): Offsets;
|
||||
export declare type OffsetModifier = Modifier<"offset", Options>;
|
||||
declare const _default: OffsetModifier;
|
||||
export default _default;
|
53
web/node_modules/@popperjs/core/lib/modifiers/offset.js
generated
vendored
Normal file
53
web/node_modules/@popperjs/core/lib/modifiers/offset.js
generated
vendored
Normal file
|
@ -0,0 +1,53 @@
|
|||
import getBasePlacement from "../utils/getBasePlacement.js";
|
||||
import { top, left, right, placements } from "../enums.js";
|
||||
export function distanceAndSkiddingToXY(placement, rects, offset) {
|
||||
var basePlacement = getBasePlacement(placement);
|
||||
var invertDistance = [left, top].indexOf(basePlacement) >= 0 ? -1 : 1;
|
||||
|
||||
var _ref = typeof offset === 'function' ? offset(Object.assign({}, rects, {
|
||||
placement: placement
|
||||
})) : offset,
|
||||
skidding = _ref[0],
|
||||
distance = _ref[1];
|
||||
|
||||
skidding = skidding || 0;
|
||||
distance = (distance || 0) * invertDistance;
|
||||
return [left, right].indexOf(basePlacement) >= 0 ? {
|
||||
x: distance,
|
||||
y: skidding
|
||||
} : {
|
||||
x: skidding,
|
||||
y: distance
|
||||
};
|
||||
}
|
||||
|
||||
function offset(_ref2) {
|
||||
var state = _ref2.state,
|
||||
options = _ref2.options,
|
||||
name = _ref2.name;
|
||||
var _options$offset = options.offset,
|
||||
offset = _options$offset === void 0 ? [0, 0] : _options$offset;
|
||||
var data = placements.reduce(function (acc, placement) {
|
||||
acc[placement] = distanceAndSkiddingToXY(placement, state.rects, offset);
|
||||
return acc;
|
||||
}, {});
|
||||
var _data$state$placement = data[state.placement],
|
||||
x = _data$state$placement.x,
|
||||
y = _data$state$placement.y;
|
||||
|
||||
if (state.modifiersData.popperOffsets != null) {
|
||||
state.modifiersData.popperOffsets.x += x;
|
||||
state.modifiersData.popperOffsets.y += y;
|
||||
}
|
||||
|
||||
state.modifiersData[name] = data;
|
||||
} // eslint-disable-next-line import/no-unused-modules
|
||||
|
||||
|
||||
export default {
|
||||
name: 'offset',
|
||||
enabled: true,
|
||||
phase: 'main',
|
||||
requires: ['popperOffsets'],
|
||||
fn: offset
|
||||
};
|
70
web/node_modules/@popperjs/core/lib/modifiers/offset.js.flow
generated
vendored
Normal file
70
web/node_modules/@popperjs/core/lib/modifiers/offset.js.flow
generated
vendored
Normal file
|
@ -0,0 +1,70 @@
|
|||
// @flow
|
||||
import type { Placement } from '../enums';
|
||||
import type { ModifierArguments, Modifier, Rect, Offsets } from '../types';
|
||||
import getBasePlacement from '../utils/getBasePlacement';
|
||||
import { top, left, right, placements } from '../enums';
|
||||
|
||||
type OffsetsFunction = ({
|
||||
popper: Rect,
|
||||
reference: Rect,
|
||||
placement: Placement,
|
||||
}) => [?number, ?number];
|
||||
|
||||
type Offset = OffsetsFunction | [?number, ?number];
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export type Options = {
|
||||
offset: Offset,
|
||||
};
|
||||
|
||||
export function distanceAndSkiddingToXY(
|
||||
placement: Placement,
|
||||
rects: { popper: Rect, reference: Rect },
|
||||
offset: Offset
|
||||
): Offsets {
|
||||
const basePlacement = getBasePlacement(placement);
|
||||
const invertDistance = [left, top].indexOf(basePlacement) >= 0 ? -1 : 1;
|
||||
|
||||
let [skidding, distance] =
|
||||
typeof offset === 'function'
|
||||
? offset({
|
||||
...rects,
|
||||
placement,
|
||||
})
|
||||
: offset;
|
||||
|
||||
skidding = skidding || 0;
|
||||
distance = (distance || 0) * invertDistance;
|
||||
|
||||
return [left, right].indexOf(basePlacement) >= 0
|
||||
? { x: distance, y: skidding }
|
||||
: { x: skidding, y: distance };
|
||||
}
|
||||
|
||||
function offset({ state, options, name }: ModifierArguments<Options>) {
|
||||
const { offset = [0, 0] } = options;
|
||||
|
||||
const data = placements.reduce((acc, placement) => {
|
||||
acc[placement] = distanceAndSkiddingToXY(placement, state.rects, offset);
|
||||
return acc;
|
||||
}, {});
|
||||
|
||||
const { x, y } = data[state.placement];
|
||||
|
||||
if (state.modifiersData.popperOffsets != null) {
|
||||
state.modifiersData.popperOffsets.x += x;
|
||||
state.modifiersData.popperOffsets.y += y;
|
||||
}
|
||||
|
||||
state.modifiersData[name] = data;
|
||||
}
|
||||
|
||||
// eslint-disable-next-line import/no-unused-modules
|
||||
export type OffsetModifier = Modifier<'offset', Options>;
|
||||
export default ({
|
||||
name: 'offset',
|
||||
enabled: true,
|
||||
phase: 'main',
|
||||
requires: ['popperOffsets'],
|
||||
fn: offset,
|
||||
}: OffsetModifier);
|
4
web/node_modules/@popperjs/core/lib/modifiers/popperOffsets.d.ts
generated
vendored
Normal file
4
web/node_modules/@popperjs/core/lib/modifiers/popperOffsets.d.ts
generated
vendored
Normal file
|
@ -0,0 +1,4 @@
|
|||
import type { Modifier } from "../types";
|
||||
export declare type PopperOffsetsModifier = Modifier<"popperOffsets", {}>;
|
||||
declare const _default: PopperOffsetsModifier;
|
||||
export default _default;
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Add table
Add a link
Reference in a new issue