Commit Graph

69 Commits

Author SHA1 Message Date
651a487921 Bump package version to 0.1.2 in package.json. 2025-09-13 18:40:32 +02:00
f2df4ce496 🎨 Fix README features section formatting
Add proper newlines between feature items for better readability.
2025-09-13 18:37:07 +02:00
804a63647a 📚 DOCS: Update README for v0.1.0 API changes
- Remove all outdated API examples (sendEmail, scheduleEmail)
- Add comprehensive examples using new payload.create() approach
- Include template engine configuration options (LiquidJS, Mustache, custom)
- Add detailed migration guide from v0.0.x to v0.1.0
- Update feature list to highlight type safety and Payload integration
- Replace old API methods section with helper functions
- Add template syntax reference for all supported engines
- Update Recent Changes section with v0.1.0 breaking changes

The README now accurately reflects the simplified collection-based API
and provides clear migration paths for existing users.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 18:33:21 +02:00
135fddc6fa 🔥 REMOVE: Deprecate outdated documentation for simplified API and template engine
- Delete `simplified-api-guide.md` and `template-syntax-migration.md`
- Content now covered in more streamlined and up-to-date guides
- Declutter repository by removing redundant files

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 18:25:06 +02:00
74f565ab4e 🚀 BREAKING: Simplify API to use Payload collections directly
- Remove complex sendEmail/scheduleEmail methods and SendEmailOptions types
- Add simple renderTemplate() helper for template rendering
- Users now create emails using payload.create() with full type safety
- Leverage Payload's existing collection system instead of duplicating functionality
- Provide comprehensive migration guide and usage examples

BREAKING CHANGES:
- sendEmail() and scheduleEmail() methods removed
- SendEmailOptions type removed
- Use payload.create() with email collection instead
- Use renderTemplate() helper for template rendering

Benefits:
 Full TypeScript support with generated Payload types
 Use any custom fields in your email collection
 Leverage Payload's validation, hooks, and access control
 Simpler, more consistent API
 Less code to maintain

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 18:23:05 +02:00
cfc3ce5a7e IMPROVE: Clean up async initialization pattern
- Remove unnecessary initializeTemplateEngine() from constructor
- Rename initializeLiquidJS() to ensureLiquidJSInitialized() for clarity
- Make template engine loading truly lazy (only on first template render)
- Eliminate potential timing issues with constructor async calls
- Improve code clarity and maintainability

Now template engines are only loaded when actually needed for rendering.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 18:08:10 +02:00
5acf7d52f6 🚀 FINAL FIX: Standard dynamic imports with proper async handling
- Replace Function() constructor imports with standard dynamic imports
- Add proper state management for template engine loading (null | false | Liquid)
- Fix async initialization timing issues with lazy loading
- Add mustache type declarations for TypeScript compatibility
- Prevent retry attempts on failed module loads
- Ensure webpack/bundler compatibility across all environments

All webpack compatibility issues now fully resolved.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 18:02:40 +02:00
b854b17266 🚨 CRITICAL FIX: Replace require() with dynamic imports for webpack compatibility
- Replace require('liquidjs') and require('mustache') with dynamic imports
- Fix webpack compatibility issues and ES module support
- Make template engine initialization lazy and async
- Add proper error handling for optional dependencies
- Use Function('return import(...)') pattern to avoid TypeScript issues
- Maintain backward compatibility with existing configurations

This resolves critical webpack bundling issues in client applications.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 17:57:19 +02:00
dc3c4fdb44 Replace Handlebars with flexible template engine system
- Replace handlebars dependency with optional liquidjs and mustache
- Add templateEngine string configuration ('liquidjs', 'mustache', 'simple')
- Add custom templateRenderer hook for maximum flexibility
- Implement graceful fallbacks when optional dependencies unavailable
- Fix webpack compatibility issues with require.extensions
- Maintain backward compatibility with existing templates
- Add comprehensive template syntax documentation

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 17:51:25 +02:00
243f7c96cf Bump package version to 0.0.8 in package.json. 2025-09-13 16:57:50 +02:00
159a99a1ec Fix race conditions and add validation for job scheduling
- Reuse duplicate prevention logic in rescheduling to prevent race conditions
- Add queueName validation in plugin initialization and helper function
- Enhanced scheduleEmailProcessingJob to return boolean and accept delay parameter
- Improve error handling: rescheduling failures warn but don't fail current job
- Prevent duplicate jobs when multiple handlers complete simultaneously

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 16:56:51 +02:00
860dd7e921 Add automatic job scheduling and rescheduling
- Add scheduleEmailProcessingJob helper to check and schedule jobs on init
- Only schedule if no existing uncompleted job exists
- Update job handler to always reschedule itself after completion (5min interval)
- Job reschedules regardless of success/failure for continuous processing
- Initial job starts 1 minute after init, subsequent jobs every 5 minutes

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 16:51:59 +02:00
fa54c5622c Improve email display name handling with proper escaping
- Add quote escaping in display names to prevent malformed email headers
- Handle empty string defaultFromName by checking trim()
- Prevent formatting when fromName is only whitespace
- Example: John "The Boss" Doe becomes "John \"The Boss\" Doe" <email>

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 16:26:53 +02:00
719b60b9ef Add defaultFromName config option and bump to v0.0.7
- Add defaultFromName to MailingPluginConfig interface
- Update MailingService to format from field with name when available
- Add getDefaultFrom() helper method for consistent formatting
- Format as "Name" <email@domain.com> when both name and email are provided
- Bump version to 0.0.7

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 16:23:39 +02:00
fa028ff540 Bump package version to 0.0.6 in package.json. 2025-09-13 16:18:04 +02:00
428a5f45cd Fix TypeScript build error with payload email adapter
- Update transporter type to handle different email adapter interfaces
- Add type casting for payload.email to resolve compatibility issues
- Build now completes successfully without TypeScript errors

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 16:11:35 +02:00
196aaeab9c Fix critical typo and improve type safety
- Fix typo: nodemailer.createTransporter -> createTransport
- Add type safety check for payload.email with sendMail validation
- Prevent runtime errors from invalid transporter objects

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 16:02:11 +02:00
a32d5688c4 Make mailer transport config optional, use Payload config fallback
- Updated MailingService to check for Payload's email transporter when plugin transport is not configured
- Enhanced error message to indicate transport is required in either plugin or Payload config
- Bump version to 0.0.5

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 15:56:25 +02:00
d672ebace2 ### 🛠 Maintenance
- Bumped version in `package.json` from `0.0.3` to `0.0.4`.
2025-09-13 15:06:26 +02:00
23ce9cc73d ### 🔧 Improvements
- Added steps for automated version tagging in `version-and-publish.yml`
- Configured workflow permissions for writing contents
- Enhanced workflow to include git tag creation and push after build steps
2025-09-13 15:04:38 +02:00
0a7cb37cac ### 🔧 Improvements
- Added `PR Version Check` workflow to validate `package.json` version updates in pull requests against the main branch.
2025-09-13 14:59:58 +02:00
aac6554a40 ### 📚 Documentation
- Enhanced email customization documentation for the `emailWrapper` hook.
- Added examples for basic, advanced, and dynamic email layouts.
- Included guidelines for leveraging external CSS, assets, and template-specific layouts.

### 🔧 Improvements
- Updated `README.md` with detailed usage for consistent branding and responsive design in emails.
- Refined HTML structure and inline styles for improved readability and accessibility.

### 🛠 Maintenance
- Bumped version in `package.json` from `0.0.2` to `0.0.3`.
2025-09-13 14:57:25 +02:00
Bas
d632a8686a Merge pull request #9 from xtr-dev/dev
Dev
2025-09-13 14:38:07 +02:00
cecb9bf1d5 Resolve merge conflict in workflow file
### 🔧 Improvements
- Resolved merge conflict in .github/workflows/version-and-publish.yml
- Maintained simplified NPM publish workflow
- Fixed formatting and newline issues
2025-09-13 14:37:42 +02:00
8d73409e89 Simplify workflow to basic NPM publish only
### 🔧 Improvements
- Removed all version bumping, changelog generation, and git manipulation
- Simplified to core workflow: checkout → setup → install → test → build → publish
- Removed complex conditions, branches, and notifications
- Uses whatever version is currently in package.json

### 🐛 Bug Fixes
- Eliminated potential workflow failures from complex logic
- Removed git force push operations and version conflicts
- Streamlined to reliable, standard publish pattern
2025-09-13 14:34:13 +02:00
7edbf6951d Remove Claude dependency from version workflow
### 🔧 Improvements
- Replaced Claude CLI changelog generation with simple commit-based approach
- Removed external dependency and potential authentication issues
- Simplified changelog generation to list commit messages directly

### 🐛 Bug Fixes
- Eliminated Claude CLI not found errors
- Removed timeout and authentication complexities
- Ensured workflow runs reliably in all environments
2025-09-13 14:32:12 +02:00
Bas
5972824398 Merge pull request #8 from xtr-dev/patch/dev
Patch/dev
2025-09-13 14:29:37 +02:00
111c475de8 Simplify workflow to just publish on main push
### 🔧 Improvements
- Removed complex version management and branch workflows
- Simplified to basic NPM publish on main branch push
- Removed Claude integration and complex version calculation
- Streamlined to: checkout → setup → install → test → build → publish

### 🐛 Bug Fixes
- Eliminated workflow complexity and potential failure points
- Removed dependency on external services and complex logic
- Fixed workflow reliability by using standard publish pattern

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 14:29:06 +02:00
4a3ca0cf9b Remove redundant commit extraction step from workflow
### 🔧 Improvements
- Deleted unnecessary step for collecting commits manually in the `version-and-publish` workflow
- Relied on Claude action for streamlined changelog generation
- Updated API key naming for compatibility with new Claude token system
2025-09-13 14:22:48 +02:00
f72da26cb9 Implement Claude-powered CHANGELOG.md maintenance
### 🚀 Features
- Added Claude action to automatically maintain CHANGELOG.md file
- Claude analyzes git commits and generates categorized changelog entries
- Automatic changelog extraction for use in release commits and PRs

### 🔧 Improvements
- Uses anthropics/claude-code-action@v1 for direct file editing
- Creates or updates CHANGELOG.md with structured release entries
- Maintains persistent changelog history across releases
- Supports fallback if CHANGELOG.md is not generated

### 📚 Documentation
- CHANGELOG.md will be automatically maintained with each release
- Organized entries by features, bug fixes, improvements, docs, and performance
- Uses [Unreleased] format for upcoming releases

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 14:21:54 +02:00
af35603abd Replace Claude CLI with intelligent commit-based changelog generation
### 🔧 Improvements
- Removed complex Claude CLI integration and fallback system
- Implemented smart commit categorization based on conventional commit patterns
- Added pattern matching for features (🚀), bug fixes (🐛), docs (📚), and improvements (🔧)
- Generates structured changelog with proper sections and formatting

### 🐛 Bug Fixes
- Eliminated authentication and integration complexities with external services
- Ensures consistent changelog generation in all CI environments
- Fixed workflow reliability by removing external dependencies

###  Features
- Automatic commit categorization using keywords and emojis
- Support for conventional commit patterns (feat:, fix:, docs:)
- Fallback message when no commits are found
- Detailed logging of changelog generation process

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 14:19:03 +02:00
aaefce8234 Add debug info and fallback for Claude CLI authentication issues
### 🐛 Bug Fixes
- Added debugging information for Claude CLI installation and execution
- Added fallback changelog generation from commit messages
- Uses --dangerously-skip-permissions flag for CI environment

### 🔧 Improvements
- Workflow now continues even if Claude CLI authentication fails
- Provides detailed error information for debugging
- Generates basic changelog from git commits as fallback
- Maintains workflow execution without requiring Claude authentication

### 📚 Documentation
- Added note in fallback changelog about authentication requirements
- Clear messaging about fallback vs AI-generated changelogs

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 14:15:19 +02:00
ddc9df1dba Update Claude CLI command to use correct syntax with print mode
### 🐛 Bug Fixes
- Changed from `claude-code` to `claude -p` for non-interactive execution
- Fixed YAML syntax issues with multiline command arguments
- Used separate PROMPT variable to avoid YAML parsing conflicts

### 🔧 Improvements
- Uses correct Claude CLI syntax with -p/--print flag for automation
- Properly structured command for GitHub Actions environment
- Maintains changelog generation functionality with correct CLI invocation

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 14:12:52 +02:00
6aa6580863 Use npm to install Claude Code CLI instead of curl script
### 🔧 Improvements
- Changed Claude Code CLI installation to use npm package @anthropic-ai/claude-code
- Simpler and more reliable than curl-based installation script
- Leverages existing Node.js environment in GitHub Actions

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 14:10:28 +02:00
da90651e0d Add Claude Code CLI installation to workflow
### 🚀 Features
- Added step to install Claude Code CLI in GitHub Actions workflow
- Uses official installation script from claude.ai
- Adds CLI to PATH for subsequent steps

### 🔧 Improvements
- Enables AI-powered changelog generation in automated workflows
- Fails gracefully if CLI installation fails
- Ensures claude-code command is available for changelog generation

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 14:07:57 +02:00
419ee63a93 Bump package version to 0.0.2 in package.json 2025-09-13 14:06:39 +02:00
4931e5aeca Temporarily disable tests for workflow development
### 🔧 Improvements
- Disabled test execution during workflow development
- Tests will be re-enabled once workflow is stable
- Prevents workflow failures due to test issues during setup phase

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 14:05:21 +02:00
4a46407237 Remove explicit pnpm version to use packageManager from package.json
### 🐛 Bug Fixes
- Removed explicit pnpm version specification in GitHub Actions
- Let pnpm/action-setup@v4 automatically use version from package.json packageManager field
- Resolves version conflict between workflow config and package.json

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 14:03:50 +02:00
49efce43e8 Fix pnpm version to match package.json exactly
### 🐛 Bug Fixes
- Updated pnpm version from 10 to 10.12.4 to match package.json packageManager field exactly
- Resolves ERR_PNPM_BAD_PM_VERSION error in GitHub Actions workflow

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 14:02:56 +02:00
9064d398c0 Implement intelligent version calculation based on branch comparison
### 🚀 Features
- Version bumping now compares source branch vs target branch versions
- Calculates proper increment from version differences between branches
- Applies calculated increment to target branch version for new version

### 🔧 Improvements
- Replaces branch name-based versioning with actual version analysis
- Shows detailed version calculation in workflow logs
- Validates that source version is higher than target version
- Supports increments greater than 1 (e.g., patch increases by 2)

### 🧮 Version Calculation Logic
- **Target (main)**: `1.2.3`, **Source (patch/dev)**: `1.2.5`
- **Calculation**: patch increased by 2, so increment = 1
- **Result**: `1.2.4` (target version + minimum needed increment)

### 📊 Enhanced Validation
- Fails if no version increase detected between branches
- Ensures positive increments for version calculations
- Detailed logging of version comparison and calculation steps

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 14:01:42 +02:00
e0dad848fc Restructure workflow to use merge PRs for release preparation
### 🚀 Features
- Push to version branches (major/*, minor/*, patch/*) now creates merge PRs
- Merge branches (merge/major-*, merge/minor-*, merge/patch-*) contain prepared releases
- Version bump, changelog generation, and validation happen before merge
- Release publishing only occurs after merge PR approval

### 🔧 Improvements
- Separated release preparation from publishing for better review workflow
- Added automatic PR creation/updating for release branches
- Streamlined publishing job that uses pre-prepared version and changelog
- Clear PR descriptions with release checklist and warnings

### 🐛 Bug Fixes
- Fixed workflow timing to allow proper review before publishing
- Eliminated race conditions between version preparation and publishing
- Improved error handling and validation throughout the process

**Workflow Structure:**
1. Push to `patch/feature-name` → Creates/updates `merge/patch-feature-name` → Opens PR to main
2. Review and approve merge PR (version already bumped, changelog included)
3. Merge PR to main → Automatically publishes to NPM and creates GitHub release

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 13:58:19 +02:00
Bas
44a919171e Merge pull request #6 from xtr-dev/patch/dev
Patch/dev
2025-09-13 13:50:38 +02:00
14c03b2143 Fix pnpm version mismatch in GitHub Actions workflow
### 🐛 Bug Fixes
- Updated pnpm version from 8 to 10 to match package.json packageManager field
- Resolves ERR_PNPM_BAD_PM_VERSION error in workflow execution

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 13:49:46 +02:00
b760841e58 Fix workflow to run as required status check before merge
### 🚀 Features
- Added `validate` job that runs on version branch PRs as required status check
- Added pre-merge validation with tests, build, and branch type detection

### 🐛 Bug Fixes
- Fixed workflow timing: now blocks PR merge until validation passes
- Changed trigger from `types: [closed]` to `types: [opened, synchronize, reopened]`
- Separated validation (PR) from publishing (post-merge) workflows

### 🔧 Improvements
- Version publishing only runs after successful merge to main
- Clear messaging about release type during PR validation
- Prevents immediate PR closure before workflow completion

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 13:49:23 +02:00
Bas
caf6398668 Merge pull request #5 from xtr-dev/patch/dev
Fix YAML syntax error in GitHub Actions workflow
2025-09-13 13:47:30 +02:00
dc3f3c6896 Fix YAML syntax error in GitHub Actions workflow
### 🐛 Bug Fixes
- Fixed YAML parsing error on line 146 caused by improper heredoc delimiter indentation
- Removed redundant blank lines for consistent formatting throughout workflow

### 🔧 Improvements
- Ensured CLAUDE_EOF delimiter is properly indented to match YAML context
- Cleaned up workflow formatting for better readability

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-13 13:46:51 +02:00
Bas
eee5a3b637 Merge pull request #4 from xtr-dev/patch/dev
docs: remove outdated Version Management Workflow documentation
2025-09-13 13:44:37 +02:00
ac7688a497 docs: remove outdated Version Management Workflow documentation
- Deleted VERSION_WORKFLOW.md as the content is no longer relevant with the updated branch and versioning structure
- Streamlined repository by removing obsolete documentation to prevent confusion
2025-09-13 13:44:04 +02:00
26fb4891f4 refactor: remove unused version branch validation logic and simplify Claude changelog installation
- Removed version folder branch validation (no longer relevant with new branch structure)
- Simplified Claude CLI integration by removing fallback installation logic
- Streamlined workflow for more concise and focused validation steps
2025-09-13 13:41:28 +02:00
519684e56c refactor: change to folder-based version branches
🗂️ **New Branch Structure:**

Changed from version/ prefixes to folder-based branches:

**Old Structure:**
- version/major
- version/minor
- version/patch

**New Structure:**
- major/ (folder branch)
- minor/ (folder branch)
- patch/ (folder branch)

**Usage Examples:**
- major/breaking-api-changes
- minor/new-email-features
- patch/fix-validation-bug

**Benefits:**
 More intuitive folder structure
 Better organization of related changes
 Clearer semantic meaning
 Multiple features can be worked on in parallel under same type

**Updated Logic:**
- Uses startsWith() instead of contains() for branch detection
- Updated validation to check for folder branches
- Enhanced error messages with examples
2025-09-13 13:39:07 +02:00