### Description
This PR introduces a heatmap visualization on user profile pages to display 
daily contribution activity over the past year. 

**Key changes include:**
- Added a heatmap container in the user profile view (`users/show.html.erb`).
- Implemented JavaScript logic (`heatmap.js`) using CalHeatmap to render the 
heatmap dynamically based on contribution data.
- Updated localization (`config/locales/en.yml`) to include tooltips and 
month/weekday labels for the heatmap.
- Added tests in `users_controller_test.rb` to validate heatmap data handling.

Screenshots:
<img width="951" alt="Screenshot 2024-12-16 at 16 35 58" 
src="https://github.com/user-attachments/assets/878068ee-c0cd-450d-b3e8-010a9c75575f"
 />
<img width="964" alt="Screenshot 2024-12-16 at 16 37 14" 
src="https://github.com/user-attachments/assets/2ae8ff02-0416-41fe-aeeb-d91cc6584a67"
 />
<img width="426" alt="Screenshot 2024-12-16 at 16 36 25" 
src="https://github.com/user-attachments/assets/ca4d4b80-cdbf-4b20-a5e6-602ef3ec07ce"
 />

### How has this been tested?
- Verified heatmap rendering with mock data for different users and activity 
levels.
- Tested responsiveness and theme support (light/dark mode).
- Checked correct localization of tooltips, month names, and weekday labels.
- Ran automated tests to ensure proper heatmap data handling in the controller.

Let me know if you need further tweaks or enhancements!
You can view, comment on, or merge this pull request online at:

  https://github.com/openstreetmap/openstreetmap-website/pull/5402

-- Commit Summary --

  * Add cal-heatmap lib with plugins and dependencies to 
vendor/assets/javascripts
  * Add manifest and application JS updates for asset linking and heatmap 
functionality
  * Add heatmap data caching and query for user contributions
  * Add heatmap container to user profile view
  * Add heatmap javascript logic, styles and localization
  * Add tests for heatmap data in UsersController

-- File Changes --

    M app/assets/config/manifest.js (5)
    M app/assets/javascripts/application.js (5)
    A app/assets/javascripts/heatmap.js (116)
    A app/assets/stylesheets/heatmap.css (3)
    M app/controllers/users_controller.rb (17)
    M app/views/users/show.html.erb (10)
    M config/locales/en.yml (4)
    M test/controllers/users_controller_test.rb (93)
    A vendor/assets/cal-heatmap/cal-heatmap.css (1)
    A vendor/assets/cal-heatmap/cal-heatmap.js (1)
    A vendor/assets/cal-heatmap/calendar-label.js (1)
    A vendor/assets/cal-heatmap/popper.js (6)
    A vendor/assets/cal-heatmap/tooltip.js (1)
    A vendor/assets/d3/d3.js (2)

-- Patch Links --

https://github.com/openstreetmap/openstreetmap-website/pull/5402.patch
https://github.com/openstreetmap/openstreetmap-website/pull/5402.diff

-- 
Reply to this email directly or view it on GitHub:
https://github.com/openstreetmap/openstreetmap-website/pull/5402
You are receiving this because you are subscribed to this thread.

Message ID: <openstreetmap/openstreetmap-website/pull/5...@github.com>
_______________________________________________
rails-dev mailing list
rails-dev@openstreetmap.org
https://lists.openstreetmap.org/listinfo/rails-dev

Reply via email to