aboutsummaryrefslogtreecommitdiff
path: root/js/src/dropdown.js
diff options
context:
space:
mode:
authorjoke2k <[email protected]>2020-12-12 02:54:29 +0200
committerXhmikosR <[email protected]>2021-01-28 12:23:33 +0200
commit881f43a3b928e792185ed388e2589c73ea8c4be6 (patch)
treef37402a50b60bd26be4a94a055e3a8a57f3bb9a3 /js/src/dropdown.js
parent51ca9a9e2f3b19ccdcd2ff4c7d0d8ec42a69d3db (diff)
downloadbootstrap-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.js24
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()
+ }
}]
}