Skip to content
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

Assign profileID to template in UFNotify, add example #29441

Merged
merged 1 commit into from
Feb 29, 2024

Conversation

eileenmcnaughton
Copy link
Contributor

Overview

Assign profileID to template in UFNotify, add example

Before

Not possible to render example, profileID not available, userDisplayName mixed with the person the profile relates to

After

image

Technical Details

This started out as just a basic alternative to #29439 but I got carried away

Comments

Copy link

civibot bot commented Feb 19, 2024

🤖 Thank you for contributing to CiviCRM! ❤️ We will need to test and review this PR. 👷

Introduction for new contributors...
  • If this is your first PR, an admin will greenlight automated testing with the command ok to test or add to whitelist.
  • A series of tests will automatically run. You can see the results at the bottom of this page (if there are any problems, it will include a link to see what went wrong).
  • A demo site will be built where anyone can try out a version of CiviCRM that includes your changes.
  • If this process needs to be repeated, an admin will issue the command test this please to rerun tests and build a new demo site.
  • Before this PR can be merged, it needs to be reviewed. Please keep in mind that reviewers are volunteers, and their response time can vary from a few hours to a few weeks depending on their availability and their knowledge of this particular part of CiviCRM.
  • A great way to speed up this process is to "trade reviews" with someone - find an open PR that you feel able to review, and leave a comment like "I'm reviewing this now, could you please review mine?" (include a link to yours). You don't have to wait for a response to get started (and you don't have to stop at one!) the more you review, the faster this process goes for everyone 😄
  • To ensure that you are credited properly in the final release notes, please add yourself to contributor-key.yml
  • For more information about contributing, see CONTRIBUTING.md.
Quick links for reviewers...

➡️ Online demo of this PR 🔗

protected $groupTitle;

public function getGroupTitle(): string {
return CRM_Core_DAO::getFieldValue('CRM_Core_DAO_UFGroup', $this->getProfileID(), 'title');
Copy link
Contributor

Choose a reason for hiding this comment

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

@eileenmcnaughton should this be the public title?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

@seamuslee001 yeah that makes sense - it wasn't before but I think it should be

@seamuslee001
Copy link
Contributor

@pradpnayak does this work for you?

protected $groupTitle;

public function getGroupTitle(): string {
return CRM_Core_DAO::getFieldValue('CRM_Core_DAO_UFGroup', $this->getProfileID(), 'frontend_title');
Copy link
Contributor

Choose a reason for hiding this comment

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

I got error because my profile had missing frontend_title

TypeError: CRM_Core_WorkflowMessage_UFNotify::getGroupTitle(): Return value must be of type string, null returned in CRM_Core_WorkflowMessage_UFNotify->getGroupTitle() (line 65 of /Users/pradeep/Sites/drupal7/sites/all/modules/civicrm/CRM/Core/WorkflowMessage/UFNotify.php).


Copy link
Contributor

Choose a reason for hiding this comment

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

How about using
CRM_Core_BAO_UFGroup::getFrontEndTitle($this->getProfileID());

Copy link
Contributor Author

Choose a reason for hiding this comment

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

@pradpnayak did you test this by backporting it - in 5.72 frontend_title should be a required field

Copy link
Contributor

Choose a reason for hiding this comment

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

Hi @eileenmcnaughton

My bad, tested by upgrading to 5.71 beta. The frontend title is not updated with the title field and the field is required through UI.

@pradpnayak
Copy link
Contributor

I did a quick test, i now get profile id and other info in hooks to alter.

Before:
Screenshot 2024-02-26 at 15 06 50

Screenshot 2024-02-26 at 15 10 00

After:

Screenshot 2024-02-26 at 15 04 50 Screenshot 2024-02-26 at 15 09 50

@pradpnayak
Copy link
Contributor

This look good to merge besides the return type fatal error mentioned above.

Thank you so much @eileenmcnaughton for doing a alternate PR.

@pradpnayak
Copy link
Contributor

I have tested the above failure and it seems to work fine. This PR is good to merge.

@eileenmcnaughton
Copy link
Contributor Author

@seamuslee001 any last concerns?

@seamuslee001 seamuslee001 merged commit 11d5e92 into civicrm:master Feb 29, 2024
3 checks passed
@seamuslee001 seamuslee001 deleted the profile branch February 29, 2024 22:29
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants