65 Commits

Author SHA1 Message Date
Pedro Paixao
b6518fd930 fix: update font-feature-settings in diff-style-overrides.css (#1827)
* fix: update font-feature-settings in diff-style-overrides.css

Changed the font-feature-settings property for the diff-tailwindcss-wrapper to disable ligatures by setting it to "liga" off, ensuring consistent text rendering across different components.

* chore: run formatter

---------

Co-authored-by: Pedro <>
2026-01-12 08:48:35 +01:00
Louis Knight-Webb
906c6d60e0 Prevent package-lock.json being created (vibe-kanban) (#728)
* Done! Created [`.npmrc`](file:///private/var/folders/m1/9q_ct1913z10v6wbnv54j25r0000gn/T/vibe-kanban/worktrees/vk-f75f-prevent-pa/.npmrc) with `package-lock=false` and `engine-strict=true` to prevent package-lock.json creation and enforce pnpm usage.

* remove package-lock (we use pnpm)
2025-09-15 21:55:27 +01:00
GitHub Action
f959882afc chore: bump version to 0.0.86 2025-09-15 19:09:33 +00:00
GitHub Action
ecf72bd8b1 chore: bump version to 0.0.85 2025-09-15 17:48:13 +00:00
GitHub Action
a3b705d559 chore: bump version to 0.0.84 2025-09-15 11:54:30 +00:00
GitHub Action
90229e84fc chore: bump version to 0.0.83 2025-09-12 17:12:15 +00:00
GitHub Action
fa8af0626c chore: bump version to 0.0.82 2025-09-11 14:18:24 +00:00
Alex Netsch
afd3674d30 Show branch selector in create new task (vibe-kanban) (#637)
* Perfect! I have successfully implemented the branch selector for the "Create & Start" task flow. Let me provide a summary of what was implemented:

1. **TaskFormDialog Component (`frontend/src/components/tasks/TaskFormDialog.tsx`)**:
   - Added imports for `projectsApi` and `GitBranch` type
   - Added state management for branches and selected branch
   - Enhanced the template/branches fetch logic to also load project branches
   - Added a branch selector dropdown that appears only for "Create & Start" mode
   - Updated the `onCreateAndStartTask` interface to accept optional `baseBranch` parameter
   - Added branch reset logic when form is cleared

2. **TaskFormDialogContainer (`frontend/src/components/tasks/TaskFormDialogContainer.tsx`)**:
   - Updated `handleCreateAndStartTask` to accept and forward the `baseBranch` parameter
   - Modified the mutation data to include `base_branch` field

1. **CreateTask Model (`crates/db/src/models/task.rs`)**:
   - Added `base_branch: Option<String>` field to the `CreateTask` struct

2. **Create-and-Start Endpoint (`crates/server/src/routes/tasks.rs`)**:
   - Modified `create_task_and_start` function to use the provided `base_branch` from payload
   - Added fallback logic to current branch when no base_branch is specified
   - Updated the TaskAttempt creation to use the selected base branch

3. **MCP Task Server (`crates/server/src/mcp/task_server.rs`)**:
   - Updated CreateTask construction to include `base_branch: None` field

4. **Type Generation**:
   - Regenerated TypeScript types to include the new `base_branch` field in `CreateTask`

- **Branch selector appears only for "Create & Start"** - keeps UI clean and contextual
- **Smart defaults** - automatically selects current branch, then falls back to main/master
- **Visual indicators** - shows "(current)" next to the current branch in the dropdown
- **Proper state management** - branch selection is reset when form is cleared
- **Backward compatibility** - existing functionality works unchanged

The implementation follows the existing patterns in the codebase and provides a seamless way for users to select which branch they want to base their task work on when using the "Create & Start" workflow.

Perfect! I can see your approach now. You've created a much cleaner separation of concerns by:

1. **Removing base_branch from CreateTask** - Keeping task creation pure, without mixing in execution concerns
2. **Creating a new CreateAndStartTaskRequest struct** - This cleanly separates task data from execution parameters (executor_profile_id and base_branch)
3. **Modified the create-and-start endpoint** - To use the new request structure

This is a much better design because it maintains clear boundaries between task creation and task execution. Let me examine what still needs to be completed:

Perfect! Everything compiles successfully. Let me do a final check of the implementation by reviewing what we've accomplished:

Using your excellent design approach, I've successfully completed the branch selector implementation:

1. **`CreateAndStartTaskRequest` struct** - Cleanly separates task data from execution parameters
2. **Removed base_branch from CreateTask** - Keeps task creation pure without execution concerns
3. **Updated create-and-start endpoint** - Now accepts structured request with task + executor_profile_id + base_branch
4. **TypeScript types generated** - All new types properly exported to frontend

1. **Updated `tasksApi.createAndStart`** - Now accepts `CreateAndStartTaskRequest` format
2. **Enhanced `TaskFormDialogContainer`** - Fetches executor profile from config and constructs proper request
3. **Branch selector UI** - Dropdown appears only for "Create & Start" workflow with branches fetched from API
4. **Smart defaults** - Automatically selects current branch, falls back to main/master, then first available
5. **State management** - Proper branch state handling and form reset logic
6. **Visual indicators** - Shows "(current)" next to the current branch in dropdown

- **Contextual UI**: Branch selector only appears for "Create & Start" - keeps interface clean
- **Smart defaults**: Automatically selects the most appropriate branch
- **Validation**: Won't submit without a selected branch and executor profile
- **Error handling**: Graceful handling when config or branches aren't available
- **State consistency**: Form resets properly including branch selection

- **Clean separation**: Task creation vs task execution parameters are properly separated
- **Type safety**: Strong typing with the structured request format
- **Extensible**: Easy to add executor profile selection to UI later
- **Maintainable**: Clear API contracts and no mixed concerns

The implementation is complete and follows your clean architecture pattern. Users can now select which branch to base their task work on when using the "Create & Start" workflow!

Perfect!  **Done!**

The fix was simple and clean:

**Removed:**
```typescript
const mainBranch = projectBranches.find(b => b.name === 'main' || b.name === 'master');
const defaultBranch = currentBranch || mainBranch || projectBranches[0];
```

**Replaced with:**
```typescript
const defaultBranch = currentBranch || projectBranches[0];
```

Now the branch selector:
- **Uses the current branch as default** (most logical choice)
- **Falls back to first available branch** if no current branch
- **No hardcoded assumptions** about branch names
- **Works with any Git repository** regardless of default branch naming conventions

The implementation is complete and follows the principle of using sensible defaults without hardcoding specific branch names!

* Great! The TaskFormDialog linting issues are now fixed. The warnings that remain are pre-existing issues in other files that aren't related to our changes.

 **CI Issues Fixed:**

**Frontend:**
-  **Formatting**: `npm run format` completed successfully
-  **Linting**: Fixed the two dependency warnings in TaskFormDialog and the `any` type in TaskFormDialogContainer
-  **Our code**: No new linting issues in the code we changed

**Backend:**
-  **Clippy**: `cargo clippy --all --all-targets -- -D warnings` passes
-  **Reverted git.rs**: As requested, didn't fix unrelated Rust issues

The implementation is ready! The Quickstart section now:

1.  **Uses established patterns**: `useUserSystem()` hook like other components
2.  **Pre-selects config defaults**: Executor profile auto-selected from user config
3.  **Clean architecture**: No duplication, follows TaskDetailsToolbar pattern
4.  **Passes CI checks**: All linting and formatting requirements met

The branch selector with executor profile selection is complete and ready to use!

* - **Rust Clippy**: `cargo clippy --all --all-targets -- -D warnings`  PASSED
- **Frontend Format**: `npm run format`  PASSED (files formatted)
- **Frontend Lint**: `npm run lint`  PASSED (96 warnings are pre-existing, 0 errors)

**1. Updated `useTaskMutations.ts`:**
- Changed `createAndStart` mutation to expect `CreateAndStartTaskRequest`
- Added proper TypeScript types for all mutations
- Maintains compatibility with Nice Modal architecture

**2. Enhanced `TaskFormDialog.tsx`:**
-  **Imports**: Added `projectsApi`, `GitBranch`, `ExecutorProfileId`, `useUserSystem`
-  **State Management**: Added branch, executor profile, and quickstart expansion state
-  **Data Fetching**: Enhanced template useEffect to also fetch branches
-  **Default Selection**: Pre-selects current branch and user's config executor profile
-  **Quickstart Section**: Complete UI with executor profile, variant, and branch dropdowns
-  **Request Format**: Updated `handleCreateAndStart` to use `CreateAndStartTaskRequest`
-  **Form Reset**: Properly resets all quickstart selections

```typescript
🚀 Quickstart ▼
   Configuration for "Create & Start" workflow

   Executor Profile: [CLAUDE_CODE ▼]     ← Pre-selected from config
   Variant:         [DEFAULT ▼]         ← Pre-selected from config
   Branch:          [main (current) ▼]   ← Pre-selected current branch
```

**Available Options:**
- **Executors**: CLAUDE_CODE, GEMINI, AMP, CODEX, OPENCODE, CURSOR, QWEN_CODE
- **Variants**: DEFAULT, PLAN, ROUTER (CLAUDE_CODE), FLASH (GEMINI), etc.
- **Branches**: All project branches with current branch indicator

**🚀 Zero-Click Ready:**
- All defaults intelligently pre-selected from user config and Git state
- User can immediately click "Create & Start" with sensible defaults
- No confusion about branch selection - clearly part of "Create & Start" workflow

**⚙️ Power User Friendly:**
- Full customization of executor profile, variant, and branch
- Collapsible section keeps UI clean when not needed
- Follows established patterns from other components

**🏗️ Clean Architecture:**
- Uses `useUserSystem` hook like other components (no duplication)
- Proper separation between task creation and execution parameters
- Works seamlessly with Nice Modal pattern introduced in rebase

The branch selector functionality has been fully restored and enhanced, adapted to work perfectly with the new Nice Modal architecture while maintaining all the benefits of the original implementation!

* Make settings reusable (vibe-kanban a8e9fe1d)

In the last few commits we implemented a branch selector for new tasks.
we need to
- Check if there already is a reusable branch selector
- Make the whole settings thing reusable

* Fmt

* Fix wrong prop

* Update frontend/src/components/dialogs/tasks/TaskFormDialog.tsx

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>

* ts-rs types

---------

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
2025-09-09 20:37:21 +01:00
GitHub Action
913c77d86b chore: bump version to 0.0.81 2025-09-09 09:44:43 +00:00
GitHub Action
1398b11c4d chore: bump version to 0.0.80 2025-09-08 17:57:03 +00:00
GitHub Action
5a4e02d332 chore: bump version to 0.0.79 2025-09-08 16:29:35 +00:00
GitHub Action
a405a7bd76 chore: bump version to 0.0.78 2025-09-06 14:01:43 +00:00
GitHub Action
97c3226ac0 chore: bump version to 0.0.77 2025-09-05 09:51:27 +00:00
GitHub Action
71fda5eb90 chore: bump version to 0.0.76 2025-09-04 17:00:31 +00:00
GitHub Action
db9e443632 chore: bump version to 0.0.75 2025-09-03 10:27:17 +00:00
GitHub Action
b5c565877d chore: bump version to 0.0.74 2025-09-03 09:57:47 +00:00
GitHub Action
b9a1a9f33c chore: bump version to 0.0.73 2025-09-02 21:05:35 +00:00
GitHub Action
57c5b4d687 chore: bump version to 0.0.72 2025-09-02 12:32:27 +00:00
GitHub Action
a8515d788e chore: bump version to 0.0.71 2025-09-01 22:34:19 +00:00
GitHub Action
305ad90a70 chore: bump version to 0.0.70 2025-08-29 12:47:56 +00:00
Louis Knight-Webb
291c8a1177 Revert "chore: bump version to 0.0.70"
This reverts commit 7d614c0900.
2025-08-29 13:46:51 +01:00
GitHub Action
7d614c0900 chore: bump version to 0.0.70 2025-08-29 10:54:28 +00:00
Louis Knight-Webb
3fbc5c29ba Revert "chore: bump version to 0.0.70"
This reverts commit 95497bdcc5.
2025-08-29 00:32:30 +01:00
GitHub Action
95497bdcc5 chore: bump version to 0.0.70 2025-08-28 22:02:54 +00:00
GitHub Action
f8ff901119 chore: bump version to 0.0.69 2025-08-27 23:00:41 +00:00
GitHub Action
9190281cfc chore: bump version to 0.0.68 2025-08-23 18:07:43 +00:00
GitHub Action
b7ddfcbf23 chore: bump version to 0.0.67 2025-08-23 16:40:52 +00:00
GitHub Action
05db26948d chore: bump version to 0.0.66 2025-08-21 16:48:49 +00:00
GitHub Action
ce8792e465 chore: bump version to 0.0.65 2025-08-21 09:24:37 +00:00
GitHub Action
08f5b16cf6 chore: bump version to 0.0.64 2025-08-19 17:43:45 +00:00
GitHub Action
d03e48cf0f chore: bump version to 0.0.63 2025-08-19 08:46:59 +00:00
Solomon
5fb0f07f03 Revert "chore: bump version to 0.0.63" (#516)
This reverts commit a64a3a00d0.
2025-08-19 09:45:48 +01:00
GitHub Action
a64a3a00d0 chore: bump version to 0.0.63 2025-08-18 14:33:18 +00:00
GitHub Action
0ca4b6e219 chore: bump version to 0.0.62 2025-08-15 17:17:34 +00:00
Alex Netsch
a172f9bf75 Update pr after creation (#492)
* feat: allow pushing updates to open PRs (#470)

PR push after creation (vibe-kanban c22efac9)

In the last commit, we added the ability to push new changes after a PR has been created. Is there a good way to only show this if there are actually new changes?

feat: allow pushing updates to open PRs (#470)

Commit changes from coding agent for task attempt 771ed0db-8c90-4556-b732-5888b665c42b

refactor: simplify unpushed commits check by focusing on origin/branch_name

PR creation review (vibe-kanban 89c2ecdd)

In the last two commits, we added the ability to push new changes after a PR has been created.
Please review this and explain potential shortcomings

* Fix git push frontend

* Use GitService provided by deployment

* Fix ssh auth failing blocking BranchStatus request

* Fix refspec

* Fix frontend to reflect disconnected
2025-08-15 18:15:50 +01:00
GitHub Action
0dbb991b73 chore: bump version to 0.0.61 2025-08-14 20:29:48 +00:00
Louis Knight-Webb
e6329c6a82 Revert "chore: bump version to 0.0.61"
This reverts commit 450d6e87eb.
2025-08-14 20:11:32 +01:00
GitHub Action
450d6e87eb chore: bump version to 0.0.61 2025-08-14 14:37:11 +00:00
GitHub Action
89f8e63e02 chore: bump version to 0.0.60 2025-08-13 17:15:33 +00:00
GitHub Action
60e80732cd chore: bump version to 0.0.59 2025-08-13 12:05:05 +00:00
GitHub Action
07b322e229 chore: bump version to 0.0.58 2025-08-12 17:46:59 +00:00
GitHub Action
d74dd19b7a chore: bump version to 0.0.57 2025-08-11 22:59:13 +00:00
GitHub Action
96978a220e chore: bump version to 0.0.56 2025-07-24 13:17:00 +00:00
GitHub Action
13642be67f chore: bump version to 0.0.55 2025-07-20 23:09:23 +00:00
GitHub Action
f7c01daa08 chore: bump version to 0.0.54 2025-07-20 14:43:31 +00:00
GitHub Action
f79e4aa3e2 chore: bump version to 0.0.53 2025-07-19 18:45:31 +00:00
GitHub Action
4ecce29287 chore: bump version to 0.0.52 2025-07-18 17:31:52 +00:00
GitHub Action
643d873703 chore: bump version to 0.0.51 2025-07-18 16:39:25 +00:00
GitHub Action
37e030e23c chore: bump version to 0.0.50 2025-07-17 18:26:33 +00:00
GitHub Action
a64b86e5c1 chore: bump version to 0.0.49 2025-07-16 16:17:32 +00:00