-
Notifications
You must be signed in to change notification settings - Fork 10
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
Dm 3592 anchor tags #542
Dm 3592 anchor tags #542
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.
Nice work on this Brad! I left a few comments for ya.
app/views/page/show.html.erb
Outdated
@@ -56,6 +55,8 @@ | |||
|
|||
<%# Accordion %> | |||
<% when 'PageAccordionComponent' %> | |||
<% accordion_ctr += 1 %> | |||
<div id="accordion_anchor_<%= accordion_ctr %>"/> |
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.
Do we need to add a div
here? Can't we just use the container div on the next line? Also, would it make sense to add a column in the DB called anchor_link_name
, or something like that, which would allow the user to create their own anchor name, and then we can just .parameterize
it? I'd like to know your thoughts on that.
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 see what you mean.. add the column (anchor_link_name) to the page_components table right? So when we save the page in PB we would just create a guid for the anchor_link_name and then embed that in the PB show page? Only problem I see with that it may be harder for the content creator to create the anchor links in PB instead of just using a convention like "accordion_anchor_1"..etc or "map_anchor_1" ...etc. ? Lets talk through this.
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.
Moved anchor_tag id to div container instead of above div container.. that works.
it 'Should display the accordion component' do | ||
expect(page).to have_content('FAQ 1') | ||
end | ||
|
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 add a test that checks to make sure that when the anchor link name is added to the url, the page jumps to the correct top position?
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 looked in to this... and found https://stackoverflow.com/questions/18948687/capybara-how-to-test-link-to-different-section-of-same-page .. so not sure if this is possible.
}, 300); | ||
} | ||
}); | ||
|
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 does this code do? Removing it didn't seem to affect the desired outcome.
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 is for a work around in chrome... yeah I wasn't expecting to have to add any js but found that the old school anchor links don't work in chrome without this js code in place to find the the anchor. Were you using chrome or safari?
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 was using chrome, and it was working correctly.
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.
We can test without it. This is what I was running in to.. https://stackoverflow.com/questions/51887886/anchor-links-not-working-on-chrome but this may only affect certain versions of chrome.. or may be a chrome/windows thing.. not sure. My version of chrome is 106.0.5249.61.
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 works great for me, Brad!
I have a slight future proofing suggestion: what if instead of using accordion_ctr
, you interpolated the component.id
into <div id="accordion_anchor_
? This might make it easier to implement something like having the anchor link open the specific FAQ in a future iteration. It would also keep the link persistent if content creators rearrange the order of the FAQs.
Hey @camillevilla - I like the way you are thinking on this. I thought about using a unique ID instead of a counter but since the Content Creators will be inputting that ID in the link in PB - how would they know what that ID was? Unless they knew how to inspect the element.. and I didn't want to go there. lol. But your right if they change the order of the elements (FAQs or whatever in the future) the content creator would have to update the links with the correct ID based on it's new order on the page. |
@bradjohnson92008 that's a good point. A future iteration is probably going to need some UX input. If we do a future iteration of this, we might use something like the heading links in the Redux documentation: |
* Dm 3533 (#543) * DM-3533: Added new component and component image models * DM-3533: Started 'Add Image' functionality * DM-3533: Removed TinyMCE code that was messing with WYSIWYG links * DM-3533: Fixed TinyMCE issues * DM-3533: Added more fields and added delete functionality to component images * DM-3533: Finished all backend functionality * DM-3533: Added some front end code for compound body component * DM-3533: Added configurable bottom and top margin. Cleaned up some code * DM-3533: Added admin panel tests for CompoundBodyComponent * DM-3533: Added a bunch of tests * DM-3533: Added unit tests for new models * DM-3533: Cleaned up some code * DM-3533: Fixed some failing tests * DM-3533: Fixed failing tests * DM-3533: Refactored some code and added another test * DM-3533: Reverted data type for paperclip attachments * DM-3533: Added to Pages show page and a few tests * DM-3533: Added mobile styling and another test * DM-3533: Cleaned up some code * DM-3533: Commented out selenium_chrome line from spec_helper * DM-3533: Added outline to images that belong to a CompoundBodyComponent * DM-3533: Removed unnecessary 'validate' call * DM-3533: Added external link styling to WYSIWYG links for compound body component * DM-3533: Removed some unnecessary code * DM-3533: Cleaned up some JS code * DM-3533: Fixed issue with external link styling for PageComponentImages * DM-3533: Added ':thumb' style to PageComponentImage on Page show page * Dm 3592 anchor tags (#542) * dm-3592 add fix for anchor tag/links in chrome. * dm-3592 build out anchor tags for all Accordions/(FAQs) on a page. * dm-3592 test to ensure accordion component displays * dm-3592 spec - add click event to display accordion text. * dm-3592 spec for accordion * dm-3592 * dm-3508 moved anchor tag to div container instead of above div container. * dm-3592 Add test for multiple accordions and anchor tags. * dm-3508 test * dm-3508 * dm-3508 PR fixes for anchor tags. * Dm 3529 (#546) * DM-3533: Added new component and component image models * DM-3533: Started 'Add Image' functionality * DM-3533: Removed TinyMCE code that was messing with WYSIWYG links * DM-3533: Fixed TinyMCE issues * DM-3533: Added more fields and added delete functionality to component images * DM-3533: Finished all backend functionality * DM-3533: Added some front end code for compound body component * DM-3533: Added configurable bottom and top margin. Cleaned up some code * DM-3533: Added admin panel tests for CompoundBodyComponent * DM-3533: Added a bunch of tests * DM-3533: Added unit tests for new models * DM-3533: Cleaned up some code * DM-3533: Fixed some failing tests * DM-3533: Fixed failing tests * DM-3533: Refactored some code and added another test * DM-3533: Reverted data type for paperclip attachments * DM-3533: Added to Pages show page and a few tests * DM-3533: Added mobile styling and another test * DM-3533: Cleaned up some code * DM-3533: Commented out selenium_chrome line from spec_helper * DM-3533: Added outline to images that belong to a CompoundBodyComponent * DM-3533: Removed unnecessary 'validate' call * DM-3533: Added external link styling to WYSIWYG links for compound body component * DM-3533: Removed some unnecessary code * DM-3533: Cleaned up some JS code * DM-3529: Added image and image alt text fields to page * DM-3533: Added ability to add image to a Page in the admin panel * DM-3533: Fixed issue with external link styling for PageComponentImages * DM-3533: Added ':thumb' style to PageComponentImage on Page show page * DM-3529: Working on frontend for header image * DM-3529: Added mobile styles * DM-3529: Adjusted styles based on design's feedback * DM-3529: Finished writing tests and cleaning up styling * DM-3529: Improved a test * DM-3529: Fixed failing tests * DM-3529: Fixed up the schema and uncommented headless chrome * DM-3529: Removed redundant 'private' call and cleaned up a little bit of code * DM-3534 DM-3561: Add Events and News Components (#544) Co-authored-by: Camille Villa <[email protected]> * Dm 3508 map component (#541) * dm-3508 Adding support/dependencies for map component. * dm-3508 Page Builder UI * dm-3508 * dm-3508 documenting page_map_components schema * dm-3508 backend and infrastructure for front end. * dm-3508 * dm-3508 bus logic: fetching diffusion histories for selected practices. * dm-3508 * dm-3508 center map and zoom * dm-3508 styles, zoom level * dm-3508 Fix query for adopting facilities * dm-3508 removed dbg * dm-3508 removed dbgs * dm-3508 marker infowindow * dm-3508 info window * dm-3508 logic for statuses * dm-3508 front end stuff * dm-3508 info window styling text changes. * dm-3508 border radius.. * dm-3508 map zoom * dm-3508 border padding for info window card style * dm-3508 use padding shorthand * dm-3508 add margin between description and map bottom. * dm-3508 info window static size. * dm-3508 infowindow styles... * dm-3508 Added in Abbr Short_name for info window content.. i.e., 23 "XR" innovations.. for a specific Facility. * dm-3508 margin above num innovations in infowindow * dm-3508 schema change * dm-3508 added test. * dm-3508 * dm-3508 fixed issue with text wrapping and ignoring padding. * dm-3508 info window styles * dm-3508 make map component mobile friendly. * dm-3508 more info window and border styles for map component info window. * dm-3508 * dm-3508 * dm-3508 info window styles * dm-3508 addressing testing and PR comments. * dm-3508 refactored some code to use ActiveRecord vs arrays. * dm-3508 Refactored some code in the controller. * dm-3508 renamed infowindow partial to _page_map_infowindow * dm-3508 another slight refactor... * dm-3508 UPdate based on PR comments. * dm-3508 Fixed styling for Info Window Facility Link. * dm-3508 Map and info window styles.. enums for Diffusion History statuses.. etc. * dm-3508 Addend links for innovations within the map component markers info-window * dm-3508 forgot to update these changes in schema.rb * dm-3508 remove commented code and fix margin in info window. * dm-3508 Added model test. * dm-3508 more tests for map * dm-3508 try to fix test. * dm-3508 Fix test. * dm-3508 * dm-3508 ok.. lets try different syntax.. * m-3508 display-none? * dm-3508 forgot the div * dm-3508 * dm-3508 * dm-3508 * dm-3508 info window styles * dm-3508 * dm-3508 info window size and positioning * dm-3508 * dm-3508 * dm-3508 Style changes per design. * dm-3508 spec for clicking map marker and displaying infowindow * dm-3508 err in spec. * dm-3508 Admin Panel test page for creating a map component * dm-3508 removed debuggers * dm-3508 Admin panel spec * dm-3508 Update IDs to match db change for "display_successful_adoptions" for spec. * Revert "dm-3508" This reverts commit 8e352bd * dm-3508 re-factor spec * dm-3508 more refactor for specs * dm-3508 * dm-3508 info window spec * dm-3508 setting ids back to be consistent in map_page_comonent_form.html.arb * dm-3508 find the map marker... * dm-3508 Remove other community features from schema that are in other component branches. * dm-3508 PR updates. * dm-3508 PR updates * dm-3508 pr suggestions * dm-3508 moved helper method to model - refactored method. * dm-3508 * dm-3508 test not working now... * dm-3508 PR Comments * dm-3508 InfoWindow refactors * dm-3508 Update/Refactor short_name column to map_info_window_text * dm-3508 updated page_map_component.short_name field to map_info_window_text. * dm-3508 Update tests for map due to column name change. * dm-3508 update spec for page_map_component field name change. * dm-3508 pr comments. * dm-3508 INfo Window styles. * dm-3508 Decrease maxWidth and maxHeight * dm-3508 removed commented code from spec. * dm-3508 adjustedpixel offset for new maxWidth, maxHeight. * dm-3508 Fix indent for comment headers. * dm-3508 revert back to "if" instead of "unless" * Removed duplicate code in admin/pages.rb Co-authored-by: Joshua Drumm <[email protected]> * Community Feature replace total adoption count with just count of "adopted practices within the community" * Changed '.count' to '.length' for practice_data array * DM-3626: Refactored grid column setup for 'CompoundBody' component (#549) * Dm compound body spacing fix (#550) * Renamed 'margin' columns to 'padding' and refactored the code to reflect those changes * Reverted some schema changes * Fixed a failing test * Fixed a couple of typos * DM 3631: Support /communities URL for Community pages (#551) Co-authored-by: Camille Villa <[email protected]> Co-authored-by: Joshua Drumm <[email protected]> * DM-3627: Adjusted styles to align with DM homepage styles (#553) * Dm 3632 (#552) * dm-3632 Added XR Network dropdown nav in header. * dm-3632 highlighting/bolding for currently selected menu item * dm-3632 add some tests for nav. * dm-3632 update path info based on community/xr-network routes * dm-3632 PR comments adjustments * dm-3632 test for top nav communities. * dm-3632 test for home page. * dm-3632 test for communities about page. * dm-3632 * dm-3632 * dm-3632 * dm-3632 * dm-3632 revert tests - not working. * dm-3632 this test should work.. * dm-3632 slug needs to be 'home' * dm-3632 change slug back to home. * dm-3632 Adding path tests for all xr-network pages. * dm-3632 adding the pages. * Communities redirect fix (#555) * Fixed community redirect issue and added a test * Improved test scenario description * Trying to fix test on CI * Hopefully fixed test on CI Co-authored-by: Brad Johnson <[email protected]> Co-authored-by: Camille Villa <[email protected]> Co-authored-by: Camille Villa <[email protected]> Co-authored-by: bradjohnson92008 <[email protected]>
JIRA issue link
https://agile6.atlassian.net/browse/DM-3592
Description - what does this code do?
Testing done - how did you test it/steps on how can another person can test it
Create anchor # links to jump to a particular element/component on the same page or when a page loads.
Note to Devs: PB show page /app/views/page/show.html.erb must have an element (<div, ..etc) with an id that is generated dynamically for each instance of the component. For example if there are 5 accordion components on the same page a counter can be used to generate unique IDs for each accordion component - i.e.,
So the unique id for each accordion component is "accordion_anchor_1", "accordion_anchor_2", "accordion_anchor_3" ... and so on. See page/show.html.erb for code above. This same technique can be used to create anchor (jump links) for other types of components as well. THIS is already setup for the accordion component so for testing you do not have to do this.
Note: If creating a link to an anchor tag on the same page.. you can either just add the anchor tag as the url i.e., "#accordion_anchor_3" or provide the path and the anchor to the internal url i.e., "/brads-page-group/brads-new-test-page#accordion_anchor_link_3". The first method will open the page in a new tab and scroll to the anchor. The second method - entering the full internal url will not open a new tab - and just scroll to the anchor tag.
TEST
When the user clicks on the link to the accordion page the new page will load and automatically scroll to the anchor element defined in the url.. ie., #accordion_anchor_2 image
Link to mock-ups/mock ups (image file if you have it) (if applicable)
N/A
Acceptance criteria
Definition of done