]> git.ipfire.org Git - thirdparty/bootstrap.git/commitdiff
Better management of dropdown/dropup with alignment
authorJohann-S <johann.servoire@gmail.com>
Mon, 22 May 2017 14:14:10 +0000 (16:14 +0200)
committerGitHub <noreply@github.com>
Mon, 22 May 2017 14:14:10 +0000 (16:14 +0200)
js/src/dropdown.js
js/tests/visual/dropdown.html

index 846746384b073534188158a8d10ae7d3bdd553b4..acc3ed453a71a961522113f8eb005bfd2f55198e 100644 (file)
@@ -68,8 +68,10 @@ const Dropdown = (($) => {
   }
 
   const AttachmentMap = {
-    TOP    : 'top-start',
-    BOTTOM : 'bottom-start'
+    TOP       : 'top-start',
+    TOPEND    : 'top-end',
+    BOTTOM    : 'bottom-start',
+    BOTTOMEND : 'bottom-end'
   }
 
   const Default = {
@@ -144,21 +146,21 @@ const Dropdown = (($) => {
         return
       }
 
-      // Handle dropup
-      const dropdownPlacement = $(this._element).parent().hasClass(ClassName.DROPUP) ? AttachmentMap.TOP : this._config.placement
-      this._popper = new Popper(this._element, this._menu, {
-        placement : dropdownPlacement,
+      let element = this._element
+      // for dropup with alignment we use the parent as popper container
+      if ($(parent).hasClass(ClassName.DROPUP)) {
+        if ($(this._menu).hasClass(ClassName.MENULEFT) || $(this._menu).hasClass(ClassName.MENURIGHT)) {
+          element = parent
+        }
+      }
+      this._popper = new Popper(element, this._menu, {
+        placement : this._getPlacement(),
         modifiers : {
           offset : {
             offset : this._config.offset
           },
           flip : {
             enabled : this._config.flip
-          },
-          beforeApplyStyle: {
-            order: 899, // 900 is the order of applyStyle
-            enabled: true,
-            fn: this._beforePopperApplyStyle
           }
         }
       })
@@ -238,21 +240,23 @@ const Dropdown = (($) => {
       return this._menu
     }
 
-    _beforePopperApplyStyle(data) {
-      if ($(data.instance.popper).hasClass(ClassName.MENURIGHT)) {
-        data.styles = {
-          right: 0,
-          left: 'auto'
+    _getPlacement() {
+      const $parentDropdown = $(this._element).parent()
+      let placement = this._config.placement
+
+      // Handle dropup
+      if ($parentDropdown.hasClass(ClassName.DROPUP) || this._config.placement === AttachmentMap.TOP) {
+        placement = AttachmentMap.TOP
+        if ($(this._menu).hasClass(ClassName.MENURIGHT)) {
+          placement = AttachmentMap.TOPEND
         }
       }
-
-      if ($(data.instance.popper).hasClass(ClassName.MENULEFT)) {
-        data.styles = {
-          right: 'auto',
-          left: 0
+      else {
+        if ($(this._menu).hasClass(ClassName.MENURIGHT)) {
+          placement = AttachmentMap.BOTTOMEND
         }
       }
-      return data
+      return placement
     }
 
     // static
index 166cbf7259b76470d63445b987a9d388ef50d29e..fee096c6c8677e500088b232cc6dc5571c33bc91 100644 (file)
 
       <div class="row">
         <div class="col-sm-12 mt-4">
-          <!-- Default dropup button -->
           <div class="btn-group dropup">
-            <button type="button" class="btn btn-secondary">Dropup</button>
+            <button type="button" class="btn btn-secondary">Dropup split</button>
             <button type="button" class="btn btn-secondary dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
-              <span class="sr-only">Toggle Dropdown</span>
+              <span class="sr-only">Dropup split</span>
             </button>
             <div class="dropdown-menu">
               <a class="dropdown-item" href="#">Action</a>
             </div>
           </div>
 
+          <div class="btn-group dropup">
+            <button type="button" class="btn btn-secondary dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">Dropup</button>
+            <div class="dropdown-menu">
+              <a class="dropdown-item" href="#">Action</a>
+              <a class="dropdown-item" href="#">Another action</a>
+              <a class="dropdown-item" href="#">Something else here</a>
+            </div>
+          </div>
+
           <div class="btn-group">
             <button type="button" class="btn btn-secondary dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
               This dropdown's menu is right-aligned
               <button class="dropdown-item" type="button">Something else here</button>
             </div>
           </div>
-
-          <div class="btn-group">
-            <button type="button" class="btn btn-secondary dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
-              This dropdown's menu is left-aligned
+        </div>
+        <div class="col-sm-12 mt-4">
+          <div class="btn-group dropup" role="group">
+            <a href="#" class="btn btn-secondary">Dropup split align right</a>
+            <button type="button" id="dropdown-page-subheader-button-3" class="btn btn-secondary dropdown-toggle dropdown-toggle-split" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
+              <span class="sr-only">Product actions</span>
             </button>
-            <div class="dropdown-menu dropdown-menu-left">
+            <div class="dropdown-menu dropdown-menu-right">
               <button class="dropdown-item" type="button">Action</button>
               <button class="dropdown-item" type="button">Another action</button>
-              <button class="dropdown-item" type="button">Something else here</button>
+              <button class="dropdown-item" type="button">Something else here with a long text</button>
             </div>
           </div>
+          <div class="btn-group dropup">
+            <button type="button" class="btn btn-secondary dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">Dropup align right</button>
+            <div class="dropdown-menu dropdown-menu-right">
+              <button class="dropdown-item" type="button">Action</button>
+              <button class="dropdown-item" type="button">Another action</button>
+              <button class="dropdown-item" type="button">Something else here with a long text</button>
+            </div>
+          </div>
+        </div>
         </div>
       </div>
-    </div>
 
     <script src="../../../docs/assets/js/vendor/jquery-slim.min.js"></script>
     <script src="../../../docs/assets/js/vendor/popper.min.js"></script>