All files / coral-component-actionbar/src/scripts getFirstSelectableWrappedItem.js

100% Statements 16/16
100% Branches 15/15
100% Functions 1/1
100% Lines 16/16

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51                                2944x 42x     2902x   1025x     1877x   1877x 1845x   1845x 1042x         835x 803x   803x 1517x   1517x 25x         810x    
/**
 * Copyright 2019 Adobe. All rights reserved.
 * This file is licensed to you under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License. You may obtain a copy
 * of the License at http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software distributed under
 * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
 * OF ANY KIND, either express or implied. See the License for the specific language
 * governing permissions and limitations under the License.
 */
 
import {commons} from '../../../coral-utils';
 
/** @ignore */
export default function getFirstSelectableWrappedItem(wrapperItem) {
  // util method to get first selectable item inside a wrapper item
  if (!wrapperItem) {
    return null;
  }
 
  if (wrapperItem.hasAttribute('coral-actionbar-more')) {
    // more buttons are no 'real' actionbar items => not wrapped
    return wrapperItem;
  }
 
  let child = null;
  for (let i = 0 ; i < wrapperItem.children.length ; i++) {
    child = wrapperItem.children[i];
 
    // maybe filter even more elements? (opacity, display='none', position='absolute' ...)
    if (child.offsetParent && (child.matches(commons.FOCUSABLE_ELEMENT_SELECTOR) || child.matches('a:not([href])')) && !child.hasAttribute('disabled')) {
      return child;
    }
  }
 
  // search at 2nd level, some elements like coral-fileupload has selectable items inside them
  for (let i = 0 ; i < wrapperItem.children.length ; i++) {
    child = wrapperItem.children[i];
    for (let j = 0 ; j < child.children.length ; j++) {
      let subChild = child.children[j];
      // maybe filter even more elements? (opacity, display='none', position='absolute' ...)
      if (subChild.offsetParent && (subChild.matches(commons.FOCUSABLE_ELEMENT_SELECTOR) || child.matches('a:not([href])'))) {
        return subChild;
      }
    }
  }
 
  return null;
}