mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-30 07:08:50 +01:00
* chore: update package version to 0.7.416 * chore: Update Role.js imports order * refactor: move updateTagsInConvo to tags route, add RBAC for tags * refactor: add updateTagsInConvoOptions * fix: loading state for bookmark form * refactor: update primaryText class in TitleButton component * refactor: remove duplicate bookmarks and theming * refactor: update EditIcon component to use React.forwardRef * refactor: add _id field to tConversationTagSchema * refactor: remove promises * refactor: move mutation logic from BookmarkForm -> BookmarkEditDialog * refactor: update button class in BookmarkForm component * fix: conversation mutations and add better logging to useConversationTagMutation * refactor: update logger message in BookmarkEditDialog component * refactor: improve UI consistency in BookmarkNav and NewChat components * refactor: update logger message in BookmarkEditDialog component * refactor: Add tags prop to BookmarkForm component * refactor: Update BookmarkForm to avoid tag mutation if the tag already exists; also close dialog on submission programmatically * refactor: general role helper function to support updating access permissions for different permission types * refactor: Update getLatestText function to handle undefined values in message.content * refactor: Update useHasAccess hook to handle null role values for authenticated users * feat: toggle bookmarks access * refactor: Update PromptsCommand to handle access permissions for prompts * feat: updateConversationSelector * refactor: rename `vars` to `tagToDelete` for clarity * fix: prevent recreation of deleted tags in BookmarkMenu on Item Click * ci: mock updateBookmarksAccess function * ci: mock updateBookmarksAccess function
29 lines
802 B
TypeScript
29 lines
802 B
TypeScript
import type { FC } from 'react';
|
|
import { useBookmarkContext } from '~/Providers/BookmarkContext';
|
|
import BookmarkItem from './BookmarkItem';
|
|
interface BookmarkItemsProps {
|
|
tags: string[];
|
|
handleSubmit: (tag?: string) => void;
|
|
header: React.ReactNode;
|
|
}
|
|
|
|
const BookmarkItems: FC<BookmarkItemsProps> = ({ tags, handleSubmit, header }) => {
|
|
const { bookmarks } = useBookmarkContext();
|
|
|
|
return (
|
|
<>
|
|
{header}
|
|
{bookmarks.length > 0 && <div className="my-1.5 h-px" role="none" />}
|
|
{bookmarks.map((bookmark, i) => (
|
|
<BookmarkItem
|
|
key={`${bookmark._id ?? bookmark.tag}-${i}`}
|
|
tag={bookmark.tag}
|
|
selected={tags.includes(bookmark.tag)}
|
|
handleSubmit={handleSubmit}
|
|
/>
|
|
))}
|
|
</>
|
|
);
|
|
};
|
|
|
|
export default BookmarkItems;
|