diff options
| author | joke2k <[email protected]> | 2020-12-12 02:54:29 +0200 |
|---|---|---|
| committer | XhmikosR <[email protected]> | 2021-01-28 12:23:33 +0200 |
| commit | 881f43a3b928e792185ed388e2589c73ea8c4be6 (patch) | |
| tree | f37402a50b60bd26be4a94a055e3a8a57f3bb9a3 /js/src/dropdown.js | |
| parent | 51ca9a9e2f3b19ccdcd2ff4c7d0d8ec42a69d3db (diff) | |
| download | bootstrap-881f43a3b928e792185ed388e2589c73ea8c4be6.tar.xz bootstrap-881f43a3b928e792185ed388e2589c73ea8c4be6.zip | |
Restore offset option for dropdown component
Diffstat (limited to 'js/src/dropdown.js')
| -rw-r--r-- | js/src/dropdown.js | 24 |
1 files changed, 22 insertions, 2 deletions
diff --git a/js/src/dropdown.js b/js/src/dropdown.js index bada537c9..66ff8cc4f 100644 --- a/js/src/dropdown.js +++ b/js/src/dropdown.js @@ -72,7 +72,7 @@ const PLACEMENT_RIGHT = isRTL ? 'left-start' : 'right-start' const PLACEMENT_LEFT = isRTL ? 'right-start' : 'left-start' const Default = { - offset: 0, + offset: [0, 0], flip: true, boundary: 'clippingParents', reference: 'toggle', @@ -81,7 +81,7 @@ const Default = { } const DefaultType = { - offset: '(number|string|function)', + offset: '(array|string|function)', flip: 'boolean', boundary: '(string|element)', reference: '(string|element|object)', @@ -298,6 +298,20 @@ class Dropdown extends BaseComponent { return this._element.closest(`.${CLASS_NAME_NAVBAR}`) !== null } + _getOffset() { + const { offset } = this._config + + if (typeof offset === 'string') { + return offset.split(',').map(val => Number.parseInt(val, 10)) + } + + if (typeof offset === 'function') { + return popperData => offset(popperData, this._element) + } + + return offset + } + _getPopperConfig() { const popperConfig = { placement: this._getPlacement(), @@ -313,6 +327,12 @@ class Dropdown extends BaseComponent { options: { fallbackPlacements: ['top', 'right', 'bottom', 'left'] } + }, + { + name: 'offset', + options: { + offset: this._getOffset() + } }] } |
