21128: icon toggles in place Arvados-DCO-1.1-Signed-off-by: Lisa Knox <lisa.knox...
authorLisa Knox <lisaknox83@gmail.com>
Tue, 14 Nov 2023 20:59:54 +0000 (15:59 -0500)
committerLisa Knox <lisaknox83@gmail.com>
Tue, 14 Nov 2023 20:59:54 +0000 (15:59 -0500)
src/components/multiselect-toolbar/MultiselectToolbar.tsx
src/views-components/multiselect-toolbar/ms-menu-action-set.ts
src/views-components/multiselect-toolbar/ms-project-action-set.ts

index 185f8e0f4ad5b6f0aa2cf829a32e545ac40f9595..2d9f3c44840ab76ae39c1247b8dc471036ad1f0c 100644 (file)
@@ -41,8 +41,10 @@ const styles: StyleRulesCallback<CssRules> = (theme: ArvadosTheme) => ({
 
 export type MultiselectToolbarProps = {
     checkedList: TCheckedList;
+    selectedUuid: string | null
     resources: ResourcesState;
     executeMulti: (action: ContextMenuAction, checkedList: TCheckedList, resources: ResourcesState) => void;
+    favorites: any
 };
 
 export const MultiselectToolbar = connect(
@@ -50,15 +52,13 @@ export const MultiselectToolbar = connect(
     mapDispatchToProps
 )(
     withStyles(styles)((props: MultiselectToolbarProps & WithStyles<CssRules>) => {
-        const { classes, checkedList } = props;
+        const { classes, checkedList, resources, selectedUuid, favorites } = props;
         const currentResourceKinds = Array.from(selectedToKindSet(checkedList));
 
-        const currentPathIsTrash = window.location.pathname === "/trash";
-        const buttons =
-            currentPathIsTrash && selectedToKindSet(checkedList).size
-                ? [msToggleTrashAction]
-                : selectActionsByKind(currentResourceKinds, multiselectActionsFilters);
+        const buttons = selectedToKindSet(checkedList).size
+            ? selectActionsByKind(currentResourceKinds, multiselectActionsFilters) : []
 
+console.log(buttons)
         return (
             <React.Fragment>
                 <Toolbar
@@ -67,15 +67,15 @@ export const MultiselectToolbar = connect(
                 >
                     {buttons.length ? (
                         buttons.map((btn, i) =>
-                            btn.defaultText ? (
+                            btn.isDefault ? (
                                 <Tooltip
                                     className={classes.button}
-                                    title={!currentPathIsTrash ? btn.defaultText : btn.altText}
+                                    title={btn.isDefault(selectedUuid, resources, favorites) ? btn.defaultText : btn.altText}
                                     key={i}
                                     disableFocusListener
                                 >
-                                    <IconButton onClick={() => props.executeMulti(btn, checkedList, props.resources)}>
-                                        {!currentPathIsTrash ? btn.icon({}) : btn.altIcon({})}
+                                    <IconButton onClick={() => props.executeMulti(btn, checkedList, resources)}>
+                                        {btn.isDefault(selectedUuid, resources, favorites) ? btn.icon && btn.icon({}) : btn.altIcon && btn.altIcon({})}
                                     </IconButton>
                                 </Tooltip>
                             ) : (
@@ -85,7 +85,7 @@ export const MultiselectToolbar = connect(
                                     key={i}
                                     disableFocusListener
                                 >
-                                    <IconButton onClick={() => props.executeMulti(btn, checkedList, props.resources)}>{btn.icon ? btn.icon({}) : <></>}</IconButton>
+                                    <IconButton onClick={() => props.executeMulti(btn, checkedList, resources)}>{btn.icon ? btn.icon({}) : <></>}</IconButton>
                                 </Tooltip>
                             )
                         )
@@ -175,12 +175,26 @@ function selectActionsByKind(currentResourceKinds: Array<string>, filterSet: TMu
     });
 }
 
+const isExactlyOneSelected = (checkedList: TCheckedList) => {
+    let tally = 0;
+    let current = '';
+    for (const uuid in checkedList) {
+        if (checkedList[uuid] === true) {
+            tally++;
+            current = uuid;
+        }
+    }
+    return tally === 1 ? current : null
+};
+
 //--------------------------------------------------//
 
 function mapStateToProps(state: RootState) {
     return {
         checkedList: state.multiselect.checkedList as TCheckedList,
+        selectedUuid: isExactlyOneSelected(state.multiselect.checkedList),
         resources: state.resources,
+        favorites: state.favorites
     };
 }
 
index c34df023312c8b7f2d3b3973e22ef6ef5ec14338..1cc3c12e8c807711f730e856ddb9814788b2771f 100644 (file)
@@ -4,6 +4,7 @@
 
 import { IconType } from "components/icon/icon";
 import { ContextMenuAction } from "../context-menu/context-menu-action-set";
+import { ResourcesState } from "store/resources/resources";
 
 export const MultiSelectMenuActionNames = {
   MAKE_A_COPY: "Make a copy",
@@ -19,7 +20,7 @@ export interface MultiSelectMenuAction extends ContextMenuAction {
     defaultText?: string;
     altText?: string;
     altIcon?: IconType;
-    isDefault?: () => boolean;
+    isDefault?: (uuid: string | null, resources: ResourcesState, favorites) => boolean;
 }
 
 export type MultiSelectMenuActionSet = Array<Array<MultiSelectMenuAction>>;
index 61e89b1c63918e304b613ec158302b6b7ec5be02..de328a7dcc7fafe04af04560a8ab489710d0f8e9 100644 (file)
@@ -11,8 +11,9 @@ import { toggleFavorite } from "store/favorites/favorites-actions";
 import { favoritePanelActions } from "store/favorite-panel/favorite-panel-action";
 import { AddFavoriteIcon, RemoveFavoriteIcon } from "components/icon/icon";
 import { RestoreFromTrashIcon, TrashIcon } from "components/icon/icon";
-
-
+import { getResource } from "store/resources/resources";
+import { ContextMenuResource } from "store/context-menu/context-menu-actions";
+import { checkFavorite } from "store/favorites/favorites-reducer";
 
 export const msToggleFavoriteAction = {
     name: MultiSelectMenuActionNames.TOGGLE_FAVORITE_ACTION,
@@ -20,6 +21,9 @@ export const msToggleFavoriteAction = {
     altText: 'Remove from Favorites',
     icon: AddFavoriteIcon,
     altIcon: RemoveFavoriteIcon,
+    isDefault: (uuid, resources, favorites)=>{
+        return !checkFavorite(uuid, favorites);
+    },
     execute: (dispatch, resources) => {
         dispatch(toggleFavorite(resources[0])).then(() => {
             dispatch(favoritePanelActions.REQUEST_ITEMS());
@@ -49,6 +53,9 @@ export const msToggleTrashAction = {
     altText: 'Restore from Trash',
     icon: TrashIcon,
     altIcon: RestoreFromTrashIcon,
+    isDefault: (uuid, resources, favorites = []) => {
+        return uuid ? !(getResource(uuid)(resources) as any).isTrashed : true;
+    },
     execute: (dispatch, resources) => {
         for (const resource of [...resources]) {
             dispatch(toggleProjectTrashed(resource.uuid, resource.ownerUuid, resource.isTrashed!!, resources.length > 1));