mirror of
https://github.com/XFox111/TabsAsideExtension.git
synced 2026-04-22 07:58:01 +03:00
58d8e864e0
* feat: add ability to hide collections #211 (#213) * feat: add ability to hide collections #211 * fix: hide/unhide collection label is swapped * fix: missing useCallback dependency * fix: add selected tabs to existing collection adds all tabs in current window #215 (#216) * fix: add selected tabs to existing collection adds all tabs in current window #215 * fix: force selected tabs only for adding tabs to groups * feat: compact collection view (#214) * feat: compact collection view #201 * loc: compact view localization * fix(loc): missing "color" translation in edit dialog * feat: add ability to edit saved tabs (#218) * feat: adds option to edit saved tabs #217 * loc: translations for #217 * build(deps): Bump the react group with 2 updates (#221) Bumps the react group with 2 updates: [react](https://github.com/facebook/react/tree/HEAD/packages/react) and [react-dom](https://github.com/facebook/react/tree/HEAD/packages/react-dom). Updates `react` from 19.2.1 to 19.2.3 - [Release notes](https://github.com/facebook/react/releases) - [Changelog](https://github.com/facebook/react/blob/main/CHANGELOG.md) - [Commits](https://github.com/facebook/react/commits/v19.2.3/packages/react) Updates `react-dom` from 19.2.1 to 19.2.3 - [Release notes](https://github.com/facebook/react/releases) - [Changelog](https://github.com/facebook/react/blob/main/CHANGELOG.md) - [Commits](https://github.com/facebook/react/commits/v19.2.3/packages/react-dom) --- updated-dependencies: - dependency-name: react dependency-version: 19.2.3 dependency-type: direct:production update-type: version-update:semver-patch dependency-group: react - dependency-name: react-dom dependency-version: 19.2.3 dependency-type: direct:production update-type: version-update:semver-patch dependency-group: react ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * build(deps): Bump the deps group with 4 updates (#220) Bumps the deps group with 4 updates: [@fluentui/react-components](https://github.com/microsoft/fluentui), [@eslint/js](https://github.com/eslint/eslint/tree/HEAD/packages/js), [eslint](https://github.com/eslint/eslint) and [typescript-eslint](https://github.com/typescript-eslint/typescript-eslint/tree/HEAD/packages/typescript-eslint). Updates `@fluentui/react-components` from 9.72.8 to 9.72.9 - [Release notes](https://github.com/microsoft/fluentui/releases) - [Commits](https://github.com/microsoft/fluentui/compare/@fluentui/react-components_v9.72.8...@fluentui/react-components_v9.72.9) Updates `@eslint/js` from 9.39.1 to 9.39.2 - [Release notes](https://github.com/eslint/eslint/releases) - [Commits](https://github.com/eslint/eslint/commits/v9.39.2/packages/js) Updates `eslint` from 9.39.1 to 9.39.2 - [Release notes](https://github.com/eslint/eslint/releases) - [Commits](https://github.com/eslint/eslint/compare/v9.39.1...v9.39.2) Updates `typescript-eslint` from 8.49.0 to 8.51.0 - [Release notes](https://github.com/typescript-eslint/typescript-eslint/releases) - [Changelog](https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/typescript-eslint/CHANGELOG.md) - [Commits](https://github.com/typescript-eslint/typescript-eslint/commits/v8.51.0/packages/typescript-eslint) --- updated-dependencies: - dependency-name: "@fluentui/react-components" dependency-version: 9.72.9 dependency-type: direct:production update-type: version-update:semver-patch dependency-group: deps - dependency-name: "@eslint/js" dependency-version: 9.39.2 dependency-type: direct:development update-type: version-update:semver-patch dependency-group: deps - dependency-name: eslint dependency-version: 9.39.2 dependency-type: direct:development update-type: version-update:semver-patch dependency-group: deps - dependency-name: typescript-eslint dependency-version: 8.51.0 dependency-type: direct:development update-type: version-update:semver-minor dependency-group: deps ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * chore: Bump version from 3.2.3 to 3.3.0 --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
128 lines
4.0 KiB
TypeScript
128 lines
4.0 KiB
TypeScript
import faviconPlaceholder from "@/assets/FaviconPlaceholder.svg";
|
|
import pagePlaceholder from "@/assets/PagePlaceholder.svg";
|
|
import { useDialog } from "@/contexts/DialogProvider";
|
|
import { useCollections } from "@/entrypoints/sidepanel/contexts/CollectionsProvider";
|
|
import useDndItem from "@/entrypoints/sidepanel/hooks/useDndItem";
|
|
import useSettings from "@/hooks/useSettings";
|
|
import { CollectionItem, GroupItem, TabItem } from "@/models/CollectionModels";
|
|
import { Caption1, Link, mergeClasses, Tooltip } from "@fluentui/react-components";
|
|
import { MouseEventHandler, ReactElement } from "react";
|
|
import { useStyles_TabView } from "./TabView.styles";
|
|
import CollectionContext, { CollectionContextType } from "../contexts/CollectionContext";
|
|
import TabMoreButton from "./TabMoreButton";
|
|
import TabEditDialog from "./TabEditDialog";
|
|
|
|
export default function TabView({ tab, indices, dragOverlay, collectionId }: TabViewProps): ReactElement
|
|
{
|
|
const { removeItem, graphics, tilesView, collections, updateCollection } = useCollections();
|
|
const { collection } = useContext<CollectionContextType>(CollectionContext);
|
|
const {
|
|
setNodeRef, setActivatorNodeRef,
|
|
nodeProps, activatorProps, isBeingDragged
|
|
} = useDndItem({ id: indices.join("/"), data: { indices, item: tab } });
|
|
const dialog = useDialog();
|
|
|
|
const [deletePrompt] = useSettings("deletePrompt");
|
|
const [showToolbar] = useSettings("alwaysShowToolbars");
|
|
|
|
const cls = useStyles_TabView();
|
|
|
|
const handleDelete = (): void =>
|
|
{
|
|
const removeIndex: number[] = [collection.timestamp, ...indices.slice(1)];
|
|
|
|
if (deletePrompt)
|
|
dialog.pushPrompt({
|
|
title: i18n.t("tabs.delete"),
|
|
content: i18n.t("common.delete_prompt"),
|
|
destructive: true,
|
|
confirmText: i18n.t("common.actions.delete"),
|
|
onConfirm: () => removeItem(...removeIndex)
|
|
});
|
|
else
|
|
removeItem(...removeIndex);
|
|
};
|
|
|
|
const handleEdit = (): void =>
|
|
{
|
|
if (collectionId < 0)
|
|
return;
|
|
|
|
const updateTab = async (updatedTab: TabItem): Promise<void> =>
|
|
{
|
|
const collection: CollectionItem = collections!.find(i => i.timestamp === collectionId)!;
|
|
|
|
if (indices.length > 2)
|
|
(collection.items[indices[1]] as GroupItem).items[indices[2]] = updatedTab;
|
|
else
|
|
collection.items[indices[1]] = updatedTab;
|
|
|
|
await updateCollection(collection, collection.timestamp);
|
|
};
|
|
|
|
dialog.pushCustom(<TabEditDialog tab={ tab } onSave={ updateTab } />);
|
|
};
|
|
|
|
const handleClick: MouseEventHandler<HTMLAnchorElement> = (args) =>
|
|
{
|
|
args.preventDefault();
|
|
browser.tabs.create({ url: tab.url, active: true });
|
|
};
|
|
|
|
const handleAuxClick: MouseEventHandler<HTMLAnchorElement> = (args) =>
|
|
{
|
|
args.preventDefault();
|
|
|
|
if (args.button === 1)
|
|
browser.tabs.create({ url: tab.url, active: false });
|
|
};
|
|
|
|
return (
|
|
<Link
|
|
ref={ setNodeRef } { ...nodeProps }
|
|
href={ tab.url }
|
|
onClick={ handleClick } onAuxClick={ handleAuxClick }
|
|
className={ mergeClasses(
|
|
cls.root,
|
|
!tilesView && cls.listView,
|
|
isBeingDragged && cls.dragging,
|
|
dragOverlay && cls.dragOverlay
|
|
) }
|
|
>
|
|
{ tilesView &&
|
|
<img
|
|
src={ graphics[tab.url]?.preview ?? graphics[tab.url]?.capture ?? pagePlaceholder }
|
|
onError={ e => e.currentTarget.src = pagePlaceholder }
|
|
className={ cls.image } draggable={ false } />
|
|
}
|
|
|
|
<div className={ cls.header }>
|
|
<img
|
|
ref={ setActivatorNodeRef } { ...activatorProps }
|
|
src={ graphics[tab.url]?.icon ?? faviconPlaceholder }
|
|
onError={ e => e.currentTarget.src = faviconPlaceholder }
|
|
className={ cls.icon } draggable={ false } />
|
|
|
|
<Tooltip relationship="description" content={ tab.title ?? tab.url }>
|
|
<Caption1 truncate wrap={ false } className={ cls.title }>
|
|
{ tab.title ?? tab.url }
|
|
</Caption1>
|
|
</Tooltip>
|
|
|
|
<TabMoreButton
|
|
className={ mergeClasses(cls.deleteButton, showToolbar === true && cls.showDeleteButton) }
|
|
onEdit={ handleEdit }
|
|
onDelete={ handleDelete } />
|
|
</div>
|
|
</Link>
|
|
);
|
|
}
|
|
|
|
export type TabViewProps =
|
|
{
|
|
tab: TabItem;
|
|
indices: number[];
|
|
dragOverlay?: boolean;
|
|
collectionId: number;
|
|
};
|