/* * Copyright (c) All respective contributors to the Peridot Project. All rights reserved. * Copyright (c) 2021-2022 Rocky Enterprise Software Foundation, Inc. All rights reserved. * Copyright (c) 2021-2022 Ctrl IQ, Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following disclaimer in the documentation * and/or other materials provided with the distribution. * * 3. Neither the name of the copyright holder nor the names of its contributors * may be used to endorse or promote products derived from this software without * specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */ import React from 'react'; import List from '@mui/material/List'; import ListItemText from '@mui/material/ListItemText'; export interface DenseListEntry { key?: string; value?: string; entries?: DenseListEntry[]; } export interface DenseListProps { entries: DenseListEntry[]; } const listEntry = ( nestLevel: number, key?: string, value?: string, entries?: DenseListEntry[] ): React.ReactNode => { return ( <> <div className="flex justify-between items-center"> {key && ( <ListItemText classes={{ primary: 'text-sm font-bold' }} sx={{ pl: 6 * nestLevel }} primary={key} /> )} {value && ( <ListItemText classes={{ secondary: 'text-sm' }} sx={key ? undefined : { pl: 6 * nestLevel }} secondary={value} /> )} </div> {entries?.map((entry) => listEntry(nestLevel + 1, entry.key, entry.value, entry.entries) )} </> ); }; export const DenseList = (props: DenseListProps) => { return ( <List dense className="w-96 divide-y"> {props.entries.map((entry) => listEntry(0, entry.key, entry.value, entry.entries) )} </List> ); };