Skip to content

Commit

Permalink
Review changes and minor-refactoring in Reveal in Finder feature
Browse files Browse the repository at this point in the history
  • Loading branch information
ramki-bruno committed Jan 13, 2025
1 parent 1b94908 commit f3b2a59
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 28 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { useDrag, useDrop } from 'react-dnd';
import { IconChevronRight, IconDots } from '@tabler/icons';
import { useSelector, useDispatch } from 'react-redux';
import { addTab, focusTab } from 'providers/ReduxStore/slices/tabs';
import { moveItem, revealInFinder, sendRequest } from 'providers/ReduxStore/slices/collections/actions';
import { moveItem, showInFolder, sendRequest } from 'providers/ReduxStore/slices/collections/actions';
import { collectionFolderClicked } from 'providers/ReduxStore/slices/collections';
import Dropdown from 'components/Dropdown';
import NewRequest from 'components/Sidebar/NewRequest';
Expand Down Expand Up @@ -227,9 +227,9 @@ const CollectionItem = ({ item, collection, searchText }) => {
}
};

const handleReveal = () => {
dispatch(revealInFinder(item.pathname)).catch((error) => {
toast.error('Error revealing file:', error);
const handleShowInFolder = () => {
dispatch(showInFolder(item.pathname)).catch((error) => {
toast.error('Error opening the folder:', error);
});
};

Expand Down Expand Up @@ -384,17 +384,15 @@ const CollectionItem = ({ item, collection, searchText }) => {
Generate Code
</div>
)}
{!isFolder && (
<div
className="dropdown-item"
onClick={(e) => {
dropdownTippyRef.current.hide();
handleReveal();
}}
>
Reveal in Finder
</div>
)}
<div
className="dropdown-item"
onClick={(e) => {
dropdownTippyRef.current.hide();
handleShowInFolder();
}}
>
Show in Folder
</div>
<div
className="dropdown-item delete-item"
onClick={(e) => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1194,11 +1194,9 @@ export const hydrateCollectionWithUiStateSnapshot = (payload) => (dispatch, getS
});
};

export const revealInFinder = (collectionPath) => () => {
export const showInFolder = (collectionPath) => () => {
return new Promise((resolve, reject) => {
const { ipcRenderer } = window;

ipcRenderer.invoke('renderer:reveal-in-finder', collectionPath).then(resolve).catch(reject);
ipcRenderer.invoke('renderer:show-in-folder', collectionPath).then(resolve).catch(reject);
});
};

14 changes: 5 additions & 9 deletions packages/bruno-electron/src/ipc/collection.js
Original file line number Diff line number Diff line change
Expand Up @@ -778,20 +778,18 @@ const registerRendererEventHandlers = (mainWindow, watcher, lastOpenedCollection
}
});

ipcMain.handle('renderer:reveal-in-finder', async (event, filePath) => {
ipcMain.handle('renderer:show-in-folder', async (event, filePath) => {
try {
if (!filePath) {
throw new Error('File path is required.');
}

const resolvedPath = path.resolve(filePath);

if (!fs.existsSync(resolvedPath)) {
throw new Error('The specified file does not exist.');
}

console.log(process.platform, "process.platform")

switch (process.platform) {
case 'darwin': // macOS
shell.showItemInFolder(resolvedPath);
Expand All @@ -805,11 +803,9 @@ const registerRendererEventHandlers = (mainWindow, watcher, lastOpenedCollection
default:
throw new Error('Unsupported platform.');
}

return { success: true };
} catch (error) {
console.error('Error in reveal-in-finder:', error);
return { success: false, message: error.message };
console.error('Error in show-in-folder:', error);
throw new Error(error);
}
});
};
Expand Down

0 comments on commit f3b2a59

Please sign in to comment.