Skip to content
This repository has been archived by the owner on Dec 11, 2019. It is now read-only.

Validate bookmark name before creation Fixes #3188 #3190

Merged
merged 1 commit into from
Aug 17, 2016
Merged

Validate bookmark name before creation Fixes #3188 #3190

merged 1 commit into from
Aug 17, 2016

Conversation

Sh1d0w
Copy link

@Sh1d0w Sh1d0w commented Aug 15, 2016

@Sh1d0w
Copy link
Author

Sh1d0w commented Aug 15, 2016

Reviewers: @bbondy @bridiver @bsclifton

@@ -12,7 +11,7 @@ const KeyCodes = require('../constants/keyCodes')
const siteTags = require('../constants/siteTags')
const siteUtil = require('../state/siteUtil')

class AddEditBookmark extends ImmutableComponent {
class AddEditBookmark extends React.Component {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the patch.

Please keep this as ImmutableComponent, and then just determine in render if it's valid or not and render accordingly. Also I think this only styles that it's invalid currently and not stops it from submitting it.

For any visual changes also pls include a screenshot, thanks.

@Sh1d0w
Copy link
Author

Sh1d0w commented Aug 16, 2016

@bbondy Styles are updated and the class as well. The only visual change that I introduce and has to be re rendered is when the state changes to invalid:

Of course it stops the bookmark folder from saving, take a look into the onSave method. :)

Let me know if I have to tweak something else if my approach into this is not correct.

@bbondy
Copy link
Member

bbondy commented Aug 16, 2016

Sorry it doesn't look disabled to me, @bradleyrichter pls provide styling suggestions for the save button. The red around the field is good though.

@Sh1d0w
Copy link
Author

Sh1d0w commented Aug 16, 2016

@bbondy Oh well I am only applying css style to the input, not on the button.

What would you say to gray it out like this, until name is empty?

PS. Updated the PR and fixed an error that was present in master branch as well, which is thrown by React if you pass undefined value as input's value initially.

@bradleyrichter
Copy link
Contributor

@Sh1d0w thanks for working on this.

I would prefer to only use the full-browser grey-out for full-modal dialogs. (needs to be spec'd)

I think your greyed button above combined with the red focus indication will be fine.

This dialog should also have a cancel button so you can give up and start over/leave with no changes.

Later we can style it more like the new BM door hanger: #2894

@Sh1d0w
Copy link
Author

Sh1d0w commented Aug 16, 2016

@bradleyrichter Thanks. No problems, I like the Brave's idea and I am happy to contribute with what I can.

I just didn't get should I implement the cancel button and should I make any further changes in order the PR to be accepted or it is good to go like this? It is just for fixing the currenct functionality, not to introduce new one at first place.

The designs look very cool, btw!

@bbondy
Copy link
Member

bbondy commented Aug 16, 2016

I'll add a few more follow up changes, we really appreciate the PR!

this.state = {
bookmarkNameValid: true,
saveButtonDisabled: true
};
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'd recommend that you have an accessor defined for this instead:

get bookmarkNameValid () {
...
}

Note that there is an onChange handler on the bookmark name so the site data is always known, so you can just check it there in this.props.currentDetail.

I think you don't need to know whether the bookmark name is valid separately from if the save button should be disabled. In particular the save button should be disabled when the bookmark name is invalid.

Copy link
Author

@Sh1d0w Sh1d0w Aug 17, 2016

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The only reason I did this is because if I use only one porperty to check for both the button and the input, is that the input will be highlighted in red intially, which I think should happen only if you submit empty string. However with the disabling of the button if it is empty it is not necessary, so I will refactor.

Thanks for the feedback.

@bbondy
Copy link
Member

bbondy commented Aug 16, 2016

OK submitted the review feedback, pls also shoot me an email at [email protected] and we'll get you on the community slack channel if you want.

@Sh1d0w
Copy link
Author

Sh1d0w commented Aug 17, 2016

@bbondy Thanks for the great feedback. I have refactored the code according to your advices.

@bbondy
Copy link
Member

bbondy commented Aug 17, 2016

super clean, thanks!

@bbondy bbondy merged commit 3757ac5 into brave:master Aug 17, 2016
get isBlankTab () {
return ['about:blank', 'about:newtab'].includes(this.props.currentDetail.get('location'))
}

get bookmarkNameValid () {
return (this.props.currentDetail.get('title') || this.props.currentDetail.get('customTitle'))
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actually I'll ask for a small follow up if you don't mind, I think no title is valid for bookmarks but not bookmark folders. In that case we display as just the URL.
So the follow up PR would just have something like return !this.isFolder || ...

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actually in case of Bookmark this.props.currentDetail.get('title') will always be set as the website's title, so even if you have empty customTItle, you should not see grayed button and if you submit the title will fallback to website's title.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

oh ok great then

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants