UNPKG

@salesforce/design-system-react

Version:

Salesforce Lightning Design System for React

38 lines (31 loc) 1.46 kB
/* eslint-disable fp/no-mutating-methods */ /* Copyright (c) 2015-present, salesforce.com, inc. All rights reserved */ /* Licensed under BSD 3-Clause - see LICENSE.txt or git.io/sfdc-license */ /** * This is a UX pattern recommendation for auto-complete search results that can contain multiple subheadings within the results. It inserts a subheading object based on `option.type === subheading.id` directly before a found option object and only inserts the subheading at the first occurence of that type of option. */ const addSubheadings = ({ subheadings, filteredOptions }) => { // Let's not mutate things we don't own. const subheadingsCopy = [...subheadings]; const sortedOptions = { noSubHeaderType: [] }; // populate an object with subheader ID as the keys subheadingsCopy.forEach((subH) => { if (subH.id) { sortedOptions[subH.id] = [subH]; } }); // sort options into arrays using option type // if option type and subheader ID are equal, add to array, if no option type, add to noSubHeaderType array filteredOptions.forEach((option) => { if (sortedOptions[option.type]) { sortedOptions[option.type].push(option); } else { sortedOptions.noSubHeaderType.push(option); } }); // get object values by dropping keys // flatten and remove child arrays, so that we have one array // `...` operates on each array item, not the array return [].concat(...Object.values(sortedOptions)); }; export default addSubheadings;