Commit graph

13 commits

Author SHA1 Message Date
cd95a68445 Enhance release message generation in CI workflow
All checks were successful
Build and Publish Docker Image / Build and Validate (pull_request) Successful in 8s
Build and Publish Docker Image / Publish to Registry (pull_request) Has been skipped
- Improved handling of the {{COMMITS}} placeholder to support multi-line content.
- Introduced a while loop for safe replacement of multi-line commit messages.
- Added temporary files for intermediate processing to ensure accurate output.

This change ensures that release notes are generated correctly, even when multiple commits are included.
2025-11-26 12:10:44 -05:00
171be2ef17 Hotfix/Fix push version update (#8)
Some checks failed
Build and Publish Docker Image / Build and Validate (push) Successful in 8s
Build and Publish Docker Image / Publish to Registry (push) Failing after 6s
Reviewed-on: #8
Co-authored-by: Juan Sebastian Montoya <juansmm@outlook.com>
Co-committed-by: Juan Sebastian Montoya <juansmm@outlook.com>
2025-11-26 11:58:12 -05:00
22c16e533e chore: update version to 0.1.6 [skip ci] 2025-11-26 11:31:37 -05:00
28c820488e Feature/Update versioning logic (#7)
All checks were successful
Build and Publish Docker Image / Build and Validate (push) Successful in 8s
Build and Publish Docker Image / Publish to Registry (push) Successful in 7s
Reviewed-on: #7
Co-authored-by: Juan Sebastian Montoya <juansmm@outlook.com>
Co-committed-by: Juan Sebastian Montoya <juansmm@outlook.com>
2025-11-26 11:22:30 -05:00
c933f5f8cc Feature/Add portainer setup (#6)
All checks were successful
Build and Publish Docker Image / Build and Validate (push) Successful in 7s
Build and Publish Docker Image / Publish to Registry (push) Successful in 6s
Reviewed-on: #6
Co-authored-by: Juan Sebastian Montoya <juansmm@outlook.com>
Co-committed-by: Juan Sebastian Montoya <juansmm@outlook.com>
2025-11-26 10:23:45 -05:00
c5a7f160bc Feature/Add movement interpolation (#5)
All checks were successful
Build and Publish Docker Image / Build and Validate (push) Successful in 7s
Build and Publish Docker Image / Publish to Registry (push) Successful in 7s
- Updated Player class to use maxSpeed, acceleration, and deceleration for smoother movement.
- Introduced velocity vector for more responsive control and smoother diagonal movement.
- Enhanced update method to calculate target velocity based on input and apply easing for acceleration and deceleration.
- Implemented boundary checks to stop movement when hitting the edges of the play area.

Reviewed-on: #5
Co-authored-by: Juan Sebastian Montoya <juansmm@outlook.com>
Co-committed-by: Juan Sebastian Montoya <juansmm@outlook.com>
2025-11-26 09:36:39 -05:00
dfe87d63cc Feature/Touch support (#4)
All checks were successful
Build and Publish Docker Image / Build and Validate (push) Successful in 8s
Build and Publish Docker Image / Publish to Registry (push) Successful in 6s
# Add Touch Support and Documentation

## 📋 Summary

This PR adds comprehensive touch support for mobile devices and tablets, enabling players to control the game using touch gestures. Additionally, a complete README.md file has been added to document the game features, controls, and gameplay mechanics.

## 🎯 Changes Made

###  New Features
- **Touch Controls**: Full touch support for smartphones and tablets
  - Touch and drag anywhere on the screen to move the player
  - Movement direction calculated relative to screen center
  - Smooth, responsive touch input handling
  - Multi-touch support with proper touch ID tracking

- **Documentation**: Comprehensive README.md
  - Game overview and features
  - Detailed controls (keyboard and touch)
  - Game mechanics explanation
  - Technical details and architecture
  - Getting started guide
  - Tips for high scores

### 🔧 Technical Implementation

#### Touch Event Handling
- Added touch event listeners (`touchstart`, `touchmove`, `touchend`, `touchcancel`)
- Implemented touch position tracking relative to screen center
- Converted touch input to WASD key states for seamless integration
- Proper touch ID tracking to handle multiple simultaneous touches
- Touch movement threshold (10px) to prevent accidental movements

#### Code Structure
- Added touch-related properties to `Game` class:
  - `touchActive`, `touchStartX/Y`, `touchCurrentX/Y`, `touchId`
- New methods:
  - `setupTouchControls()`: Initializes touch event listeners
  - `handleTouchStart()`: Handles touch initiation
  - `handleTouchMove()`: Updates touch position during drag
  - `handleTouchEnd()`: Resets touch state
  - `updateTouchMovement()`: Converts touch input to movement keys

#### UI Updates
- Updated instructions to mention touch controls
- Responsive design maintained for mobile devices

## 📊 Statistics

- **Files Changed**: 2
  - `index.html`: +123 lines, -1 line
  - `README.md`: +171 lines (new file)
- **Total Changes**: +293 insertions, -1 deletion
- **Commits**: 2

## 🧪 Testing

### Desktop Testing
-  Keyboard controls (WASD and Arrow Keys) still work correctly
-  No regression in existing functionality
-  Game performance unchanged

### Mobile Testing
-  Touch controls work on smartphones
-  Touch controls work on tablets
-  Movement is smooth and responsive
-  Touch input properly resets on touch end
-  Multiple touches handled correctly (only first touch tracked)

## 📱 Mobile Compatibility

The game now fully supports:
- iOS devices (iPhone, iPad)
- Android devices (phones and tablets)
- Other touch-enabled devices

Touch controls use the center of the screen as a reference point, making it intuitive for users to drag in any direction to move.

## 🎮 User Experience Improvements

1. **Accessibility**: Game is now playable on mobile devices without keyboard
2. **Intuitive Controls**: Touch and drag is natural for mobile users
3. **Documentation**: README provides clear instructions for all users
4. **No Visual Clutter**: Touch controls work without on-screen joystick

## 🔍 Code Quality

- Clean, maintainable code structure
- Proper event handling with `preventDefault()` to avoid browser defaults
- Touch events use `{ passive: false }` for proper scroll prevention
- Consistent with existing code style and patterns
- No breaking changes to existing functionality

## 📝 Notes

- Touch controls integrate seamlessly with existing keyboard controls
- Both input methods can work simultaneously (though not recommended)
- Touch movement uses the same movement system as keyboard input
- README includes comprehensive documentation for future developers

##  Checklist

- [x] Touch controls implemented and tested
- [x] Mobile compatibility verified
- [x] README.md created with comprehensive documentation
- [x] No regression in desktop functionality
- [x] Code follows existing patterns and style
- [x] Instructions updated to mention touch controls

---

**Ready for Review** 🚀

Reviewed-on: #4
Co-authored-by: Juan Sebastian Montoya <juansmm@outlook.com>
Co-committed-by: Juan Sebastian Montoya <juansmm@outlook.com>
2025-11-26 01:31:15 -05:00
4bf8897370 Feature/Add workflow summaries (#3)
All checks were successful
Build and Publish Docker Image / Build and Validate (push) Successful in 8s
Build and Publish Docker Image / Publish to Registry (push) Successful in 7s
Reviewed-on: #3
Co-authored-by: Juan Sebastian Montoya <juansmm@outlook.com>
Co-committed-by: Juan Sebastian Montoya <juansmm@outlook.com>
2025-11-25 18:32:17 -05:00
3d78da0228 Merge pull request 'Feature/Enhanced release notes' (#2) from feature/enhanced-release-notes into main
All checks were successful
Build and Publish Docker Image / Build and Validate (push) Successful in 7s
Build and Publish Docker Image / Publish to Registry (push) Successful in 6s
Reviewed-on: #2
2025-11-25 17:33:33 -05:00
3ac719cfb1 Add release notes template with enhanced tag information
All checks were successful
Build and Publish Docker Image / Build and Validate (pull_request) Successful in 8s
Build and Publish Docker Image / Publish to Registry (pull_request) Has been skipped
2025-11-25 17:31:18 -05:00
b21a0e3a39 Feature/CI Workflow (#1)
All checks were successful
Build and Publish Docker Image / Build and Validate (push) Successful in 6s
Build and Publish Docker Image / Publish to Registry (push) Successful in 6s
# Add CI/CD Pipeline with Docker Build and Publish

## Summary
This PR adds a complete CI/CD pipeline for building and publishing Docker images of the Three.js game to the Forgejo container registry. The workflow automatically builds, validates, and publishes Docker images with semantic versioning when code is merged to main.

## Changes

### 🚀 CI/CD Workflow (`.forgejo/workflows/ci.yaml`)
- **Build & Validation**: Automatically builds Docker image on PRs and validates it works
- **Semantic Versioning**: Auto-increments patch version on each merge to main
  - First version: `0.1.0` (when no tags exist)
  - Subsequent merges: Auto-increments patch (e.g., `0.1.0` → `0.1.1` → `0.1.2`)
- **Publishing**: Publishes images to `git.jusemon.com/jusemon/threejs-test:<version>` and `latest` tag
- **Git Tagging**: Automatically creates git tags (e.g., `v0.1.0`) for releases
- **Registry Integration**: Uses Forgejo container registry with secrets-based authentication

### 🐳 Docker Setup
- **Dockerfile**: Custom nginx:alpine image with the game HTML file
- **docker-compose.yml**: Simple orchestration for local development
- **nginx.conf**: Minimal nginx configuration with gzip compression

## Workflow Behavior

### On Pull Requests
-  Builds Docker image
-  Validates image by running container and checking HTTP response
-  Does NOT publish (validation only)

### On Merge to Main
-  Builds Docker image
-  Validates image
-  Publishes to registry with version tag
-  Tags as `latest`
-  Creates git tag for the release

## Required Setup

Before merging, ensure these secrets are configured in the repository:
- `REGISTRY_USERNAME`: Forgejo username
- `REGISTRY_PASSWORD`: Personal Access Token with package write permissions

## Versioning Strategy

- **First Release**: `0.1.0` (when no tags exist)
- **Subsequent Releases**: Auto-increments patch version on each merge
- **Image Tags**:
  - `git.jusemon.com/jusemon/threejs-test:0.1.0`
  - `git.jusemon.com/jusemon/threejs-test:latest` (always points to latest main)

## Testing

The workflow includes validation steps that:
1. Build the Docker image
2. Run a test container
3. Verify the web server responds correctly
4. Only publish if all validations pass

## Benefits

-  Automated builds and deployments
-  Consistent versioning
-  Image validation before publishing
-  Easy rollback using version tags
-  Latest tag for easy deployment

Reviewed-on: #1
Co-authored-by: Juan Sebastian Montoya <juansmm@outlook.com>
Co-committed-by: Juan Sebastian Montoya <juansmm@outlook.com>
2025-11-25 17:21:46 -05:00
fc24028ed9 Refactor to ES6 classes with GameObject inheritance pattern
- Convert from function-based to class-based architecture
- Create GameObject base class with common functionality (position, collision, scene management)
- Implement Player, Coin, and Obstacle classes extending GameObject
- Add Game class to manage game lifecycle and state
- Fix shadow rendering by configuring directional light shadow camera bounds
- Fix player collision to prevent sinking below ground (horizontal push only)
- Improve code organization and maintainability with OOP principles
2025-11-25 14:32:48 -05:00
0bf4afd499 initial commit 2025-11-25 14:21:59 -05:00