-
Notifications
You must be signed in to change notification settings - Fork 124
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
Allow admins to invite other staff #251
Conversation
ff9805e
to
d9c79a1
Compare
if @user.save | ||
@user.staff_account.add_role(user_params[:staff_account_attributes][:roles]) | ||
@user.invite!(current_user) | ||
redirect_to staff_index_path, notice: "Staff saved successfully." |
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.
Can we change the notice to something like "Invite sent!"?
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 both make sense here. The staff account does get saved and the invitation is sent
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 "Invite sent!" makes more sense from the user perspective. Fixed!
I also changed texts in a couple of other places from "Add staff" to "Invite staff".
|
||
<!-- button --> | ||
<div class="col-12 mt-3"> | ||
<%= form.submit 'Save profile', class: 'btn btn-primary' %> |
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.
Can we change button to 'Send Invite' ?
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.
Fixed, thanks!
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.
Looks great! I tested it out locally and I like it.
I know you said you had improvements to follow in another PR, so the following is my thoughts, some which you may already have considered:
- I am guessing the
invite!
call on line 16 ofOrganizations::InvitationsController
is triggering the mailer. I am wondering if we are able to send any params to that? It would be good to send the organization so we can access its name and slug and recreate the Org's Url in the email e.g., https://www.petrescue.com/baja - The redirect after the invited user enters and saves their password to accept the invite, is this coming from registrations_controller def after_sign_in_path_for ? This is another place where it would be good to scope it to the organization's dashboard rather than the root path, if possible.
- I think we could use the invitation_accepted_at column in the staff table to indicate whether or not the staff has accepted the invite in the staff table (not directly related to this work) e.g., in the status column
@@ -0,0 +1,26 @@ | |||
class DeviseInvitableAddToUsers < ActiveRecord::Migration[7.0] |
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.
My initial thought without considering the gem would be to separate Invitations from Users and have an Invitations table/model. This would be more maintainable in the long run.
However, looking at the gem, I see that adding to Users table is a 'normal' practice. I was thinking it doesn't make sense if only Org users use invites, as then we'd have a User class that for adopters has completely irrelevant fields. But, then I thought we could also leverage invitations between adopters as well at some point.
This is not to say this needs to change. I think it works like this and is ok a. But, I think with more time and a bigger budget I'd go for separating those concerns :D
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 totally agree with your point and would love to make those changes too, but sadly, this gem doesn't let us do that (there is even an issue for this: scambra/devise_invitable#888).
Let's go with what we have for now and think about extracting it later on if needed.
someone_invited_you: "Someone has invited you to %{url}, you can accept it through the link below." | ||
accept: "Accept invitation" | ||
accept_until: "This invitation will be due in %{due_date}." | ||
ignore: "If you don't want to accept the invitation, please ignore this email. Your account won't be created until you access the link above and set your password." |
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.
It seems like the account is still created? Or does devise_invitation do something to the User record that gets created?
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.
Hey @nsiwnf, this text was generated by Devise, and TBH I don't know why it says so. The user record will be created in the DB but with a random password so no one can access it. I will remove the Your account won't be created...
sentence.
These are great suggestions! Should we make them into tickets?
|
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.
LGTM!
fa3ed42
to
ee4b667
Compare
Thank you @kasugaijin and @nsiwnf for the review! 💪 I will create separate issues for your suggestions and start working on them soon :) |
🔗 Issue
Fixes #226
✍️ Description
This Pull Request adds the functionality of inviting new staff members to the organization by administrators (staff admins) using the devise_invitable gem. The invitation acceptance flow is currently in a basic form but improvements will be addressed in a subsequent PR.
📷 Screenshots/Demos
Nagranie.z.ekranu.2023-10-11.o.13.25.13.mov