-
Notifications
You must be signed in to change notification settings - Fork 1.3k
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
[PM-13876] replace angular validation with html constraints validation #11816
Conversation
Codecov ReportAttention: Patch coverage is
✅ All tests successful. No failed tests found. Additional details and impacted files@@ Coverage Diff @@
## main #11816 +/- ##
==========================================
- Coverage 33.53% 33.51% -0.02%
==========================================
Files 2814 2817 +3
Lines 87475 87602 +127
Branches 16676 16698 +22
==========================================
+ Hits 29332 29361 +29
- Misses 55836 55931 +95
- Partials 2307 2310 +3 ☔ View full report in Codecov by Sentry. |
/** Splits an email into a username, subaddress, and domain named group. | ||
* Subaddress is optional. | ||
*/ | ||
export const DOMAIN_PARSER = new RegExp("[^@]+@(?<domain>.+)"); | ||
|
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.
catchall-constraints.ts
.
></button> | ||
</div> | ||
</bit-card> | ||
<tools-password-settings | ||
#passwordSettings |
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.
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.
Approving this, so we can merge and let QA start testing. The nits I mentioned will be addressed in a follow-up PR by me, which @audreyality can review.
#11816) * rough-in passphrase validation failure handling * trigger valid change from settings * fix `max` constraint enforcement * add taps for generator validation monitoring/debugging * HTML constraints validation rises like a phoenix * remove min/max boundaries to fix chrome display issue * bind settings components as view children of options components * remove defunct `okSettings$` * extend validationless generator to passwords * extend validationless generator to catchall emails * extend validationless generator to forwarder emails * extend validationless generator to subaddress emails * extend validationless generator to usernames * fix observable cycle * disable generate button when no algorithm is selected * prevent duplicate algorithm emissions * add constraints that assign email address defaults
#11816) * rough-in passphrase validation failure handling * trigger valid change from settings * fix `max` constraint enforcement * add taps for generator validation monitoring/debugging * HTML constraints validation rises like a phoenix * remove min/max boundaries to fix chrome display issue * bind settings components as view children of options components * remove defunct `okSettings$` * extend validationless generator to passwords * extend validationless generator to catchall emails * extend validationless generator to forwarder emails * extend validationless generator to subaddress emails * extend validationless generator to usernames * fix observable cycle * disable generate button when no algorithm is selected * prevent duplicate algorithm emissions * add constraints that assign email address defaults
🎟️ Tracking
https://bitwarden.atlassian.net/browse/PM-13876
📔 Objective
Improve the UX of credential generator validation logic by removing validation.
🕵🏻 What to expect
In all of the above cases, the generator automatically saves and, if necessary, applies policy to the settings. For field edits:
Clicking the generator button has undefined behavior when the settings are incorrect. It may correct the setting, as above, or it may load the settings before your edit.
This branch also fixes the janky behavior of a few settings that validation wasn't handling well:
🦮 Reviewer guidelines
:+1:
) or similar for great changes:memo:
) or ℹ️ (:information_source:
) for notes or general info:question:
) for questions:thinking:
) or 💭 (:thought_balloon:
) for more open inquiry that's not quite a confirmed issue and could potentially benefit from discussion:art:
) for suggestions / improvements:x:
) or:warning:
) for more significant problems or concerns needing attention:seedling:
) or ♻️ (:recycle:
) for future improvements or indications of technical debt:pick:
) for minor or nitpick changes