mirror of
https://github.com/meta-llama/llama-stack.git
synced 2025-10-24 00:47:00 +00:00
56 lines
1.6 KiB
TypeScript
56 lines
1.6 KiB
TypeScript
import { useFunctionCallGrouping } from "../hooks/function-call-grouping";
|
|
import { ItemRenderer } from "../items/item-renderer";
|
|
import { GroupedFunctionCallItemComponent } from "../items/grouped-function-call-item";
|
|
import {
|
|
isFunctionCallItem,
|
|
isFunctionCallOutputItem,
|
|
AnyResponseItem,
|
|
} from "../utils/item-types";
|
|
|
|
interface GroupedItemsDisplayProps {
|
|
items: AnyResponseItem[];
|
|
keyPrefix: string;
|
|
defaultRole?: string;
|
|
}
|
|
|
|
export function GroupedItemsDisplay({
|
|
items,
|
|
keyPrefix,
|
|
defaultRole = "unknown",
|
|
}: GroupedItemsDisplayProps) {
|
|
const groupedItems = useFunctionCallGrouping(items);
|
|
|
|
return (
|
|
<>
|
|
{groupedItems.map(groupedItem => {
|
|
// If this is a function call with an output, render the grouped component
|
|
if (
|
|
groupedItem.outputItem &&
|
|
isFunctionCallItem(groupedItem.item) &&
|
|
isFunctionCallOutputItem(groupedItem.outputItem)
|
|
) {
|
|
return (
|
|
<GroupedFunctionCallItemComponent
|
|
key={`${keyPrefix}-${groupedItem.index}`}
|
|
functionCall={groupedItem.item}
|
|
output={groupedItem.outputItem}
|
|
index={groupedItem.index}
|
|
keyPrefix={keyPrefix}
|
|
/>
|
|
);
|
|
}
|
|
|
|
// Otherwise, render the individual item
|
|
return (
|
|
<ItemRenderer
|
|
key={`${keyPrefix}-${groupedItem.index}`}
|
|
item={groupedItem.item}
|
|
index={groupedItem.index}
|
|
keyPrefix={keyPrefix}
|
|
defaultRole={defaultRole}
|
|
/>
|
|
);
|
|
})}
|
|
</>
|
|
);
|
|
}
|