-
Notifications
You must be signed in to change notification settings - Fork 55
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Create right-click menu #284
base: master
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Tested in Chromium and Firefox, works for me! Nicely done 🙂
src/background.js
Outdated
|
||
await chrome.contextMenus.create({ | ||
...menuEntryProps, | ||
title: `Browserpass - ${numberOfLoginsForThisHost} ${singularOrPlural}`, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Although it's cool to be able to have a dynamic title, honestly I don't see how it is useful - except to indicate that there are 0 entries, in which case I think it's better to not take up space in context menu at all... I'd just prefer a static minimalistic "Browserpass" title...
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I can live with that :) In combination with the not showing if 0 matches, the presence of the menu entry now indicates that there is at least one match
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Cool :) Would that be too much to ask to rerecord the gif? Not important as you'll change UI in the next PR anyway but if it's super quick for you...
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
src/background.js
Outdated
* @return void | ||
*/ | ||
async function clickMenuEntry(settings, login) { | ||
await handleMessage(settings, { action: "fill", login }, () => {}); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The last parameter to handleMessage
currently does nothing but should at least log some error in background page's console. Above, on line 1186, you throw an error and it does end up in background page's console (easy to test by swapping the condition to == 'ok'
, it's something to test here as well, perhaps just throwing an error would be sufficient?
src/background.js
Outdated
* @since 3.8.0 | ||
* | ||
* @param object settings Full settings object | ||
* @param array login Filtered and sorted list of logins |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I believe this comment is not true, it's not a list of logins right?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, you're right. Btw that reminds me of an idea that I had: what would you think about porting the project to TypeScript, then part of the documentation would become unnecessary and wouldn't need to be manually maintained + it would maybe be a bit easier to understand input/output parameters quickly.
Let me know what you think about that, I'd be interested to look into it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
what would you think about porting the project to TypeScript
I'd prefer not to do that at this point. It's a discussion for another time perhaps, but in the more immediate term I'd rather get the current backlog of stuff cleared and ready for release.
Extracting the question for visibility. @erayd is our main frontend person so I'll let him properly answer this, I can say this was considered back when we created the project, but also I'm led to believe that typescript has improved a lot since 2018, so maybe it's good to spend at least 10 minutes and reconsider again, even if we end up deciding to stick with javascript. Ideally it would be good for him to also review this PR, but he is busy in the next couple of weeks and you are eager to contribute and we all appreciate that and I want to support you, so let's agree that I'll test it later today and if everything works well I'll merge, so that you can continue working on the next improvements, and we might have to fix some additional code review comments in a separate PR later when @erayd gets time to look at your contributions? 😉 |
src/background.js
Outdated
@@ -41,6 +41,8 @@ chrome.browserAction.setBadgeBackgroundColor({ | |||
chrome.tabs.onUpdated.addListener((tabId, info) => { | |||
// unregister any auth listeners for this tab | |||
if (info.status === "complete") { | |||
createContextMenu(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
While testing I managed to get some errors in the console when I was opening a new tab, which is because of concurrent attempts to recreate context menu. Here's what happens:
createContextMenu
is async
, so by calling it here we don't really block browser, there's no way of knowing when the function completes. In the beginning of createContextMenu
we first remove the context menu and then try to recreate it. At the same time, chrome.tabs.onActivated
will get called, in turn calling createContextMenu
in parallel. The previous run has just created the parent menu, this run removes it, and then the previous run tries to create children to a now gone parent, and crashes.
Of course one way to reduce the chances of a crash is to move chrome.contextMenus.removeAll()
from the beginning of the function to as much later as possible - but this will not entirely eliminate the problem, but rather just reduce its chances.
Another problem is that here you actually call createContextMenu
only on complete
event - I understand why you did it, but it presents a problem on slow websites. I open github.com and my context menu is filled with entries. I then go in this tab to some very slow website, which loads a ton of images, and so complete
event will only fire in say 5 seconds. During the first 5 seconds if I right click, I will still see entries for github.
I propose to repeat what updateMatchingPasswordsCount
function does:
- be called on all statuses, not just on
complete
- use some kind of analogue to
isRefreshing
variable to prevent concurrent runs - probably you won't need
chrome.tabs.onActivated
below, because badge seems to not need it...
Let me know if it makes sense and if you have any questions
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the thorough review, I can reproduce but haven't figured out how to solve it completely yet. I'll keep you posted.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think I figured it out 🎉. I call createContextMenu
now on every status, but I need chrome.tabs.onActivated
to "kill" callbacks that are being called from an "old" tab.
It's a bit hard to formulate, so here's an example: I'm in tab A
with a slow page, I switch to tab B
before tab A
finished loading, when tab A
finally finished loading I don't want it to mess up the context menu.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@fkneist Would simply including the origin in the callback be sufficient? That way you can just discard any calls that have a different origin than the currently active one.
Another thing I noticed while testing is, that the order of the child entries is not always the same (multiple accounts per host). I think in the popup this is intended, as to move frequently used entries up, but in the right-click menu I find it a bit confusing. What would you guys think of alphabetical sorting in the right-click menu? |
I think it would be great for instances where there are only a small number of entries - but where there are large numbers, we should stick to frequency. As an example, I know someone who has over 200 microsoft.com accounts in their password manager - in that kind of scenario, alphabetised sorting would render the right-click menu unusable. |
Hi there, it's been a while 😃 I had some time and tinkered on the solution in the last few days:
Some scenarios I tested:
Known limitation:
|
Lovely, thanks for your time and contribution! There are a couple of other items we need to deal with first (e.g. #290 has a lot of work that's been put in and is very close to being merged, #320 has a deadline in June or the extension will be delisted from Chrome Web Store), so I think it's most realistic that we'll look at this PR afterwards. But if we have the time to add additional items in the release, I would love this PR to be one of them! |
* @return void | ||
*/ | ||
async function clickMenuEntry(settings, login) { | ||
await handleMessage(settings, { action: "fill", login }, (response) => { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This just triggers the standard 'fill' action, however given that it's for a context menu, there needs to be additional logic that ensures the field that has been clicked on is the one that gets filled. Some pages have multiple candidate forms, and the one that Browsewrpass picks by default for the fill action may not be the one that the user right-clicked for the context menu.
2nd try, because of messed up git history in last PR