Claude-skill-registry git-pr-creator
Create Git pull requests and optionally update JIRA tickets with comments and image attachments
git clone https://github.com/majiayu000/claude-skill-registry
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/git-pr-creator" ~/.claude/skills/majiayu000-claude-skill-registry-git-pr-creator && rm -rf "$T"
skills/data/git-pr-creator/SKILL.mdWhat I do
I implement a complete Git PR creation workflow with optional JIRA integration:
- Check JIRA Integration: Ask user if JIRA is used for the project
- Create Pull Request: Create a GitHub/GitLab PR with comprehensive description
- Use git-semantic-commits: Format PR title following Conventional Commits specification
- Scan for Diagrams/Images: Search for workflow-related images and diagrams
- Attach Images to JIRA: Upload local/temporary images directly to JIRA (not just links)
- Add JIRA Comments: Use
to create comments with PR details and attachmentsgit-issue-updater - Update JIRA Status (Optional): Use
to transition ticket status after manual mergejira-status-updater
When to use me
Use this workflow when:
- You've completed work on a feature or fix and need to create a PR
- You want to update JIRA tickets with PR information
- You have diagrams or images that need to be attached to JIRA (not just linked)
- You need to ensure JIRA tickets are updated with actual image files for visibility
- You want to maintain traceability between PRs and JIRA tickets
Prerequisites
- Git repository with commits to push
- GitHub CLI (
) or GitLab CLI (gh
) installed and authenticatedglab - If using JIRA: Atlassian account with appropriate permissions
- JIRA cloud ID and project key
- Existing JIRA ticket(s) to update
Steps
Step 1: Check Git Status
- Verify current git status:
git status - Ensure all changes are committed
- Check for uncommitted changes that need attention
Step 2: Ask About JIRA Integration
- Prompt the user: "Is JIRA used for this project? (yes/no)"
- If yes, proceed with JIRA integration steps
- If no, skip JIRA-related steps and only create the PR
Step 3: Get JIRA Ticket Information (if JIRA is used)
- Ask the user for the JIRA ticket ID (e.g., "IBIS-101")
- Verify the ticket exists using Atlassian MCP tools
- Get the cloud ID if not provided
Step 4: Create Pull Request
- Push the current branch to remote:
git push -u origin <branch-name> - Use git-semantic-commits for PR title formatting:
- Format PR title following Conventional Commits specification
- Examples:
,feat: add login functionality
,fix(auth): resolve session timeoutdocs: update API documentation - Include scope when relevant:
,feat(api): add user authenticationfix(ui): resolve layout issue - Use breaking change indicator if applicable:
orfeat!: change API signaturefeat(api)!: breaking change to authentication
- Create the PR with a comprehensive description:
gh pr create --title "<PR Title>" --body "<PR Description>" - PR description should include:
- Overview of changes
- JIRA ticket reference (if applicable)
- Files changed
- Testing performed
- Screenshots/diagrams (as references)
Step 5: Scan for Diagrams and Images
- Search for image files in the repository:
# Common image locations find . -type f \( -name "*.png" -o -name "*.jpg" -o -name "*.jpeg" -o -name "*.svg" \) -not -path "*/node_modules/*" # Check diagrams directory ls -la diagrams/ # Check tmp directory ls -la /tmp/*.png /tmp/*.jpg /tmp/*.svg 2>/dev/null - Identify workflow-related images:
- Look for files with names like:
,workflow
,diagram
,flow
,processarchitecture - Check recent image creation timestamps
- Ask user to confirm which images are relevant
- Look for files with names like:
Step 6: Categorize Images
- For each image found, determine:
- Accessible images: Hosted on public URLs or cloud storage (can be linked)
- Local/temporary images: Files in
, local directories, or private servers (must be attached)/tmp/
Step 7: Upload Local Images to JIRA (if JIRA is used)
For each local/temporary image that needs to be shared on JIRA:
-
Upload the image to JIRA: Use Atlassian MCP tool
with:atlassian_addAttachmentToJiraIssue- cloudId: The Atlassian cloud ID
- issueIdOrKey: The JIRA ticket key
- attachment: Path to the local image file
-
Get the attachment URL:
- The response will include the attachment URL hosted on JIRA
- This URL is accessible within the JIRA ecosystem
-
Store attachment URLs for use in comments
Step 8: Create JIRA Comments (if JIRA is used)
Create a comprehensive comment on the JIRA ticket with PR details using
atlassian_addCommentToJiraIssue.
Comment Template:
## Pull Request Created **PR**: #<PR_NUMBER> - <PR_TITLE> **URL**: <PR_URL> **Branch**: <branch-name> ### Changes Summary <Brief description of what was implemented> ### Files Modified <list of key files changed> ### Diagrams/Visuals <embed uploaded images using JIRA attachment format> ### Testing Performed <test coverage and results> ### Review Request @reviewer1 @reviewer2
Step 9: Verify and Report
- Verify PR creation:
gh pr view - Verify JIRA comment (if applicable)
- Display summary:
✅ Pull request created successfully! ✅ Branch pushed to remote ✅ JIRA ticket updated (if applicable) ✅ Images attached to JIRA (if applicable) **PR Details**: - PR: #<number> - URL: <pr-url> - Title: <title> **JIRA Update**: - Ticket: <TICKET-KEY> - Comments added: Yes - Images attached: <count>
Step 10: Update JIRA Ticket Status (Optional)
Purpose: Provide option to update JIRA ticket status after manual PR merge
When to use:
- PR was manually merged (not through pr-creation-workflow)
- You want to transition JIRA ticket to "Done" status
- You have merged the PR outside of the automated workflow
Implementation:
# Prompt user for status update if [ "$JIRA_USED" = "yes" ] && [ -n "$JIRA_TICKET" ]; then read -p "Would you like to update JIRA ticket status after merge? (yes/no): " UPDATE_STATUS if [ "$UPDATE_STATUS" = "yes" ]; then echo "" echo "Updating JIRA ticket status..." echo "==========================================" # Use jira-status-updater integration # This provides automated status transitions with error handling # Get cloud ID CLOUD_ID="${ATLASSIAN_CLOUD_ID:-<your-cloud-id>}" # 1. Get available transitions TRANSITIONS=$(atlassian_getTransitionsForJiraIssue \ --cloudId "$CLOUD_ID" \ --issueIdOrKey "$JIRA_TICKET") # 2. Find target status (Done or Closed) TARGET_TRANSITION_ID=$(echo "$TRANSITIONS" | jq -r '.transitions[] | select(.to.name == "Done" or .to.name == "Closed") | .id' | head -1) TARGET_TRANSITION_NAME=$(echo "$TRANSITIONS" | jq -r '.transitions[] | select(.to.name == "Done" or .to.name == "Closed") | .to.name' | head -1) # 3. Get current status TICKET_DETAILS=$(atlassian_getJiraIssue \ --cloudId "$CLOUD_ID" \ --issueIdOrKey "$JIRA_TICKET") CURRENT_STATUS=$(echo "$TICKET_DETAILS" | jq -r '.fields.status.name') echo "Current status: $CURRENT_STATUS" echo "Target status: $TARGET_TRANSITION_NAME" # 4. Execute transition (if not already in target status) if [ "$CURRENT_STATUS" = "$TARGET_TRANSITION_NAME" ]; then echo "✅ Ticket already in target status: $TARGET_TRANSITION_NAME" elif [ -n "$TARGET_TRANSITION_ID" ]; then atlassian_transitionJiraIssue \ --cloudId "$CLOUD_ID" \ --issueIdOrKey "$JIRA_TICKET" \ --transition "{\"id\": \"$TARGET_TRANSITION_ID\"}" if [ $? -eq 0 ]; then echo "✅ Successfully transitioned $JIRA_TICKET from $CURRENT_STATUS to $TARGET_TRANSITION_NAME" # 5. Add merge comment COMMIT_HASH=$(git rev-parse HEAD) COMMIT_AUTHOR=$(git log -1 --pretty=%an) COMMIT_DATE=$(git log -1 --date=iso8601 --pretty=%aI) COMMENT_BODY=$(cat <<EOF ## Pull Request Merged (Manual) **PR**: #$PR_NUMBER - <pr-title> **URL**: $PR_URL **Branch**: $CURRENT_BRANCH ### Status Update ✅ Ticket transitioned from **$CURRENT_STATUS** to **$TARGET_TRANSITION_NAME** ### Merge Details - **Commit**: \`$COMMIT_HASH\` - **Author**: $COMMIT_AUTHOR - **Date**: $COMMIT_DATE ### Files Changed \`\`\` $(git diff --stat HEAD~1 HEAD) \`\`\` ### Work Completed The pull request has been manually merged and the ticket has been closed. EOF ) atlassian_addCommentToJiraIssue \ --cloudId "$CLOUD_ID" \ --issueIdOrKey "$JIRA_TICKET" \ --commentBody "$COMMENT_BODY" if [ $? -eq 0 ]; then echo "✅ Added merge comment to $JIRA_TICKET" fi else echo "❌ Failed to transition $JIRA_TICKET" echo " Check permissions and available transitions" fi else echo "⚠️ No 'Done' or 'Closed' transition available for $JIRA_TICKET" echo " Available transitions:" echo "$TRANSITIONS" | jq -r '.transitions[] | " - \(.to.name)"' fi echo "==========================================" echo "" echo "🔗 JIRA Ticket: https://<company>.atlassian.net/browse/$JIRA_TICKET" fi fi
Example Output:
Would you like to update JIRA ticket status after merge? (yes/no): yes Updating JIRA ticket status... ========================================== Current status: In Progress Target status: Done ✅ Successfully transitioned IBIS-101 from In Progress to Done ✅ Added merge comment to IBIS-101 ========================================== 🔗 JIRA Ticket: https://company.atlassian.net/browse/IBIS-101
Image Handling Strategy
For Accessible Images (Public URLs)
If the image is already hosted on a public URL (e.g., GitHub, S3, cloud storage):
- Embed directly in JIRA comment using markdown:
 - No need to upload as attachment
For Local/Temporary Images
If the image is a local file that won't be accessible from JIRA:
- Must upload as attachment to JIRA
- Use the
toolatlassian_addAttachmentToJiraIssue - Reference the uploaded image in the comment using the attachment URL
Example:
# Upload local image atlassian_addAttachmentToJiraIssue \ --cloudId <CLOUD_ID> \ --issueIdOrKey "IBIS-101" \ --attachment "/tmp/workflow-diagram.png" # Response returns attachment URL: # https://yourcompany.atlassian.net/secure/attachment/12345/workflow-diagram.png # Use this URL in the comment
Correct JIRA Comment with Attachment:
### Workflow Diagram 
Incorrect JIRA Comment (local file path):
### Workflow Diagram 
Examples
Example 1: PR with JIRA Integration and Local Image
User: "Create a PR for the login feature. Yes, JIRA is used. Ticket is IBIS-101."
Execution:
- Push branch
to remotefeature/login - Create PR #42 with title "Implement login feature"
- Scan for images:
- Found:
(local, not accessible)/tmp/login-flow.png - Found:
(local, not accessible)diagrams/architecture.png
- Found:
- Upload images to JIRA:
- Upload
→ Gets attachment URL/tmp/login-flow.png - Upload
→ Gets attachment URLdiagrams/architecture.png
- Upload
- Create JIRA comment with embedded images
JIRA Comment Created:
## Pull Request Created **PR**: #42 - Implement login feature **URL**: https://github.com/org/repo/pull/42 **Branch**: feature/login ### Changes Summary Implemented user authentication with email/password login, session management, and password reset functionality. ### Files Modified - src/auth/login.ts - src/auth/session.ts - src/components/LoginForm.tsx - src/api/auth.ts ### Workflow Diagram  ### Architecture  ### Testing Performed - Unit tests: 100% coverage - Integration tests: All passing - Manual testing: Verified login flow end-to-end ### Review Request @tech-lead @senior-dev
Example 2: PR with Public URL Image
User: "Create a PR for the dashboard. Yes, JIRA is used. Ticket is IBIS-102."
Execution:
- Push branch
to remotefeature/dashboard - Create PR #43
- Scan for images:
- Found:
(public URL)https://cdn.example.com/dashboard-mockup.png - Found:
(local, not accessible)/tmp/notes.png
- Found:
- Upload only local image to JIRA
- Create JIRA comment with both public URL and embedded attachment
JIRA Comment Created:
## Pull Request Created **PR**: #43 - Implement dashboard **URL**: https://github.com/org/repo/pull/43 ### Changes Summary Built responsive dashboard with data visualization and analytics. ### UI Mockup (Design Spec)  ### Technical Implementation Notes 
Example 3: PR without JIRA
User: "Create a PR for the bug fix. No, JIRA is not used."
Execution:
- Push branch
to remotefix/crash-issue - Create PR #44
- Skip JIRA integration
- Display summary
Output:
✅ Pull request created successfully! ✅ Branch pushed to remote **PR Details**: - PR: #44 - URL: https://github.com/org/repo/pull/44 - Title: Fix crash on login page No JIRA integration requested.
Image Detection and Categorization
Detection Patterns
Search for images in these locations:
# Project diagrams ./diagrams/**/*.png ./diagrams/**/*.svg # Recent images in tmp /tmp/*.png /tmp/*.jpg # Documentation images ./docs/images/**/*.png ./assets/images/**/*.png # Workflow-related (by filename pattern) **/*workflow*.png **/*diagram*.png **/*flow*.png **/*architecture*.png **/*sequence*.png
Categorization Logic
# Check if URL is accessible if [[ "$image_path" =~ ^https?:// ]]; then # It's a URL - test if accessible if curl -s -o /dev/null -w "%{http_code}" "$image_path" | grep -q "200"; then TYPE="accessible_url" else TYPE="inaccessible_url" fi else # It's a file path if [[ -f "$image_path" ]]; then TYPE="local_file" else TYPE="not_found" fi fi
Handling Each Type
- accessible_url: Embed directly in JIRA comment
- inaccessible_url: Download and upload as JIRA attachment
- local_file: Upload as JIRA attachment
- not_found: Warn user and skip
Atlassian MCP Tools Reference
atlassian_getAccessibleAtlassianResources
atlassian_getAccessibleAtlassianResources
Returns: List of accessible Atlassian resources with cloud IDs
atlassian_addAttachmentToJiraIssue
atlassian_addAttachmentToJiraIssue \ --cloudId <CLOUD_ID> \ --issueIdOrKey <TICKET_KEY> \ --attachment <file-path>
Returns: Attachment metadata including URL
atlassian_addCommentToJiraIssue
atlassian_addCommentToJiraIssue \ --cloudId <CLOUD_ID> \ --issueIdOrKey <TICKET_KEY> \ --commentBody <markdown-content>
Returns: Comment ID and details
atlassian_getJiraIssue
atlassian_getJiraIssue \ --cloudId <CLOUD_ID> \ --issueIdOrKey <TICKET_KEY>
Returns: Issue details including status, assignee, etc.
Best Practices
- Always confirm JIRA usage with the user before proceeding
- Use git-semantic-commits for PR title formatting to ensure consistent semantic versioning
- Follow Conventional Commits specification: feat, fix, docs, style, refactor, test, chore, perf, ci, build, revert
- Include scopes in PR titles to identify affected components (e.g., feat(api):, fix(ui):)
- Use breaking change indicator (!) when appropriate:
feat!: breaking API change - Upload local/temporary images as JIRA attachments, don't link to local paths
- Use git-issue-updater for consistent JIRA ticket comments with user, date, time, and PR details
- Use descriptive filenames for images before uploading
- Organize images in a
directory for consistencydiagrams/ - Include PR number and brief description in JIRA comments
- Tag relevant team members in JIRA comments using
@username - Verify image accessibility before embedding URLs
- Clean up temporary images after uploading to JIRA
- Keep JIRA comments concise and well-formatted
- Always verify that the PR was created successfully
- Test JIRA attachments by opening the URL in a browser
Common Issues
Image Upload Fails
Issue:
atlassian_addAttachmentToJiraIssue returns an error
Solution:
- Verify file path is correct
- Check file size limits (JIRA typically limits to 10-100MB per attachment)
- Ensure you have permission to add attachments to the issue
- Verify the file is not corrupted
JIRA Comment Not Visible
Issue: Comment added but doesn't display images
Solution:
- Use the attachment URL returned by the upload API
- Don't use local file paths in comments
- Ensure markdown syntax is correct:

Too Many Images
Issue: Too many images found in the repository
Solution:
- Ask user which images are relevant
- Filter by timestamp (e.g., images created in last hour)
- Focus on workflow-related images
- Allow user to select specific images to upload
Branch Not Pushed
Issue: PR creation fails because branch isn't on remote
Solution:
# Push current branch with upstream tracking git push -u origin $(git branch --show-current)
JIRA Ticket Not Found
Issue: Cannot access the specified JIRA ticket
Solution:
- Verify the ticket ID format (e.g., IBIS-101)
- Check that you have access to the JIRA project
- Use
to list accessible ticketsatlassian_getVisibleJiraProjects - Verify the cloud ID is correct
Troubleshooting Checklist
Before creating PR:
- All changes are committed
- Current branch is correct
- Branch name follows conventions
- User confirmed JIRA usage (yes/no)
- PR title follows Conventional Commits format (if applicable)
Before JIRA integration (if yes):
- JIRA ticket ID is valid
- Atlassian MCP tools are available
- User has permissions to comment/attach
- Cloud ID is configured
Before image handling:
- Image files exist and are accessible
- Image sizes are within limits
- User has confirmed which images to include
- Local images will be uploaded as attachments
After completion:
- PR is created and accessible
- PR description is complete
- JIRA comment is added (if applicable)
- Images are properly embedded (not broken links)
- Summary is displayed to user
Related Commands
# Check git status git status # View current branch git branch --show-current # Push branch with upstream git push -u origin $(git branch --show-current) # Create PR gh pr create --title "Title" --body "Description" # View PR gh pr view # List PRs gh pr list # Find recent images find . -type f \( -name "*.png" -o -name "*.jpg" -o -name "*.svg" \) -mtime -1 # Find images by pattern find . -name "*workflow*.png" -o -name "*diagram*.png" # Check file type file workflow.png # Get image dimensions identify workflow.png
Related Skills
- JIRA Integration:
: For JIRA utilities, comments, and image uploadsjira-git-integration
: For automated JIRA ticket status transitions after PR mergejira-status-updater
- Git Frameworks:
: For semantic commit message formatting and PR title conventionsgit-semantic-commits
: For consistent issue/ticket update functionality with user, date, timegit-issue-updater
- PR Workflows:
: For generic PR creation workflowpr-creation-workflow
: For Next.js-specific PR workflowsnextjs-pr-workflow
- Issue Management:
: For creating GitHub issues with branchesgit-issue-creator
- Diagram Creation:
: For creating workflow diagramsascii-diagram-creator