@proletariat/cli 0.3.81 → 0.3.82
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -46
- package/dist/commands/action/run.js +2 -2
- package/dist/commands/action/run.js.map +1 -1
- package/dist/commands/agent/staff/add.d.ts +17 -1
- package/dist/commands/agent/staff/add.js +274 -1
- package/dist/commands/agent/staff/add.js.map +1 -1
- package/dist/commands/agent/staff/list.d.ts +10 -1
- package/dist/commands/agent/staff/list.js +103 -1
- package/dist/commands/agent/staff/list.js.map +1 -1
- package/dist/commands/agent/staff/remove.d.ts +18 -1
- package/dist/commands/agent/staff/remove.js +143 -1
- package/dist/commands/agent/staff/remove.js.map +1 -1
- package/dist/commands/{epic/activate.d.ts → pr/close.d.ts} +8 -2
- package/dist/commands/pr/close.js +157 -0
- package/dist/commands/pr/close.js.map +1 -0
- package/dist/commands/pr/index.js +6 -2
- package/dist/commands/pr/index.js.map +1 -1
- package/dist/commands/pr/list.d.ts +1 -0
- package/dist/commands/pr/list.js +37 -3
- package/dist/commands/pr/list.js.map +1 -1
- package/dist/commands/pr/merge.js +1 -1
- package/dist/commands/pr/merge.js.map +1 -1
- package/dist/commands/pr/status.js +33 -1
- package/dist/commands/pr/status.js.map +1 -1
- package/dist/commands/self-update.d.ts +7 -14
- package/dist/commands/self-update.js +11 -179
- package/dist/commands/self-update.js.map +1 -1
- package/dist/commands/{workflow/switch.d.ts → ticket/cancel.d.ts} +4 -2
- package/dist/commands/ticket/cancel.js +204 -0
- package/dist/commands/ticket/cancel.js.map +1 -0
- package/dist/commands/ticket/link/index.js +0 -12
- package/dist/commands/ticket/link/index.js.map +1 -1
- package/dist/commands/ticket/move.d.ts +1 -0
- package/dist/commands/ticket/move.js +10 -3
- package/dist/commands/ticket/move.js.map +1 -1
- package/dist/commands/update.d.ts +18 -0
- package/dist/commands/update.js +184 -0
- package/dist/commands/update.js.map +1 -0
- package/dist/lib/database/index.js +0 -134
- package/dist/lib/database/index.js.map +1 -1
- package/dist/lib/database/migrations/0006_drop_theme_names_used.d.ts +8 -0
- package/dist/lib/database/migrations/0006_drop_theme_names_used.js +30 -0
- package/dist/lib/database/migrations/0006_drop_theme_names_used.js.map +1 -0
- package/dist/lib/database/migrations/0007_add_worktree_columns.d.ts +8 -0
- package/dist/lib/database/migrations/0007_add_worktree_columns.js +24 -0
- package/dist/lib/database/migrations/0007_add_worktree_columns.js.map +1 -0
- package/dist/lib/database/migrations/0008_add_agent_mount_mode.d.ts +8 -0
- package/dist/lib/database/migrations/0008_add_agent_mount_mode.js +18 -0
- package/dist/lib/database/migrations/0008_add_agent_mount_mode.js.map +1 -0
- package/dist/lib/database/migrations/0009_create_media_items.d.ts +7 -0
- package/dist/lib/database/migrations/0009_create_media_items.js +29 -0
- package/dist/lib/database/migrations/0009_create_media_items.js.map +1 -0
- package/dist/lib/database/migrations/0010_add_ticket_position.d.ts +9 -0
- package/dist/lib/database/migrations/0010_add_ticket_position.js +44 -0
- package/dist/lib/database/migrations/0010_add_ticket_position.js.map +1 -0
- package/dist/lib/database/migrations/index.js +10 -0
- package/dist/lib/database/migrations/index.js.map +1 -1
- package/dist/lib/events/events.d.ts +2 -1
- package/dist/lib/pmo/storage/dependencies.js +45 -21
- package/dist/lib/pmo/storage/dependencies.js.map +1 -1
- package/dist/lib/pmo/storage/statuses.d.ts +2 -0
- package/dist/lib/pmo/storage/statuses.js +209 -150
- package/dist/lib/pmo/storage/statuses.js.map +1 -1
- package/dist/lib/pr/index.d.ts +14 -0
- package/dist/lib/pr/index.js +48 -0
- package/dist/lib/pr/index.js.map +1 -1
- package/dist/lib/update-check.js +1 -1
- package/dist/lib/update-check.js.map +1 -1
- package/dist/lib/update-prompt.js +1 -1
- package/dist/lib/work-lifecycle/events.d.ts +11 -0
- package/oclif.manifest.json +4789 -11452
- package/package.json +1 -1
- package/dist/commands/agents/index.d.ts +0 -11
- package/dist/commands/agents/index.js +0 -105
- package/dist/commands/agents/index.js.map +0 -1
- package/dist/commands/agents/themes/add-names.d.ts +0 -1
- package/dist/commands/agents/themes/add-names.js +0 -2
- package/dist/commands/agents/themes/add-names.js.map +0 -1
- package/dist/commands/agents/themes/create.d.ts +0 -1
- package/dist/commands/agents/themes/create.js +0 -2
- package/dist/commands/agents/themes/create.js.map +0 -1
- package/dist/commands/agents/themes/list.d.ts +0 -1
- package/dist/commands/agents/themes/list.js +0 -2
- package/dist/commands/agents/themes/list.js.map +0 -1
- package/dist/commands/category/create.d.ts +0 -19
- package/dist/commands/category/create.js +0 -130
- package/dist/commands/category/create.js.map +0 -1
- package/dist/commands/category/delete.d.ts +0 -18
- package/dist/commands/category/delete.js +0 -124
- package/dist/commands/category/delete.js.map +0 -1
- package/dist/commands/category/index.d.ts +0 -16
- package/dist/commands/category/index.js +0 -88
- package/dist/commands/category/index.js.map +0 -1
- package/dist/commands/category/list.d.ts +0 -19
- package/dist/commands/category/list.js +0 -111
- package/dist/commands/category/list.js.map +0 -1
- package/dist/commands/category/rename.d.ts +0 -19
- package/dist/commands/category/rename.js +0 -160
- package/dist/commands/category/rename.js.map +0 -1
- package/dist/commands/epic/activate.js +0 -107
- package/dist/commands/epic/activate.js.map +0 -1
- package/dist/commands/epic/archive.d.ts +0 -15
- package/dist/commands/epic/archive.js +0 -118
- package/dist/commands/epic/archive.js.map +0 -1
- package/dist/commands/epic/create.d.ts +0 -17
- package/dist/commands/epic/create.js +0 -179
- package/dist/commands/epic/create.js.map +0 -1
- package/dist/commands/epic/delete.d.ts +0 -15
- package/dist/commands/epic/delete.js +0 -129
- package/dist/commands/epic/delete.js.map +0 -1
- package/dist/commands/epic/index.d.ts +0 -14
- package/dist/commands/epic/index.js +0 -88
- package/dist/commands/epic/index.js.map +0 -1
- package/dist/commands/epic/list.d.ts +0 -13
- package/dist/commands/epic/list.js +0 -103
- package/dist/commands/epic/list.js.map +0 -1
- package/dist/commands/epic/move.d.ts +0 -16
- package/dist/commands/epic/move.js +0 -162
- package/dist/commands/epic/move.js.map +0 -1
- package/dist/commands/epic/progress.d.ts +0 -17
- package/dist/commands/epic/progress.js +0 -170
- package/dist/commands/epic/progress.js.map +0 -1
- package/dist/commands/epic/project.d.ts +0 -16
- package/dist/commands/epic/project.js +0 -199
- package/dist/commands/epic/project.js.map +0 -1
- package/dist/commands/epic/reorder.d.ts +0 -22
- package/dist/commands/epic/reorder.js +0 -152
- package/dist/commands/epic/reorder.js.map +0 -1
- package/dist/commands/epic/show.d.ts +0 -13
- package/dist/commands/epic/show.js +0 -17
- package/dist/commands/epic/show.js.map +0 -1
- package/dist/commands/epic/spec.d.ts +0 -17
- package/dist/commands/epic/spec.js +0 -189
- package/dist/commands/epic/spec.js.map +0 -1
- package/dist/commands/epic/ticket.d.ts +0 -21
- package/dist/commands/epic/ticket.js +0 -300
- package/dist/commands/epic/ticket.js.map +0 -1
- package/dist/commands/epic/view.d.ts +0 -14
- package/dist/commands/epic/view.js +0 -141
- package/dist/commands/epic/view.js.map +0 -1
- package/dist/commands/execution/kill.d.ts +0 -12
- package/dist/commands/execution/kill.js +0 -18
- package/dist/commands/execution/kill.js.map +0 -1
- package/dist/commands/label/create.d.ts +0 -20
- package/dist/commands/label/create.js +0 -58
- package/dist/commands/label/create.js.map +0 -1
- package/dist/commands/label/delete.d.ts +0 -17
- package/dist/commands/label/delete.js +0 -33
- package/dist/commands/label/delete.js.map +0 -1
- package/dist/commands/label/group/create.d.ts +0 -20
- package/dist/commands/label/group/create.js +0 -56
- package/dist/commands/label/group/create.js.map +0 -1
- package/dist/commands/label/group/list.d.ts +0 -14
- package/dist/commands/label/group/list.js +0 -53
- package/dist/commands/label/group/list.js.map +0 -1
- package/dist/commands/label/index.d.ts +0 -15
- package/dist/commands/label/index.js +0 -59
- package/dist/commands/label/index.js.map +0 -1
- package/dist/commands/label/list.d.ts +0 -16
- package/dist/commands/label/list.js +0 -84
- package/dist/commands/label/list.js.map +0 -1
- package/dist/commands/link/create.d.ts +0 -16
- package/dist/commands/link/create.js +0 -136
- package/dist/commands/link/create.js.map +0 -1
- package/dist/commands/link/index.d.ts +0 -14
- package/dist/commands/link/index.js +0 -82
- package/dist/commands/link/index.js.map +0 -1
- package/dist/commands/link/list.d.ts +0 -18
- package/dist/commands/link/list.js +0 -178
- package/dist/commands/link/list.js.map +0 -1
- package/dist/commands/link/remove.d.ts +0 -16
- package/dist/commands/link/remove.js +0 -115
- package/dist/commands/link/remove.js.map +0 -1
- package/dist/commands/media/add.d.ts +0 -19
- package/dist/commands/media/add.js +0 -98
- package/dist/commands/media/add.js.map +0 -1
- package/dist/commands/media/index.d.ts +0 -14
- package/dist/commands/media/index.js +0 -93
- package/dist/commands/media/index.js.map +0 -1
- package/dist/commands/media/list.d.ts +0 -15
- package/dist/commands/media/list.js +0 -94
- package/dist/commands/media/list.js.map +0 -1
- package/dist/commands/media/preprocess.d.ts +0 -19
- package/dist/commands/media/preprocess.js +0 -91
- package/dist/commands/media/preprocess.js.map +0 -1
- package/dist/commands/media/remove.d.ts +0 -18
- package/dist/commands/media/remove.js +0 -105
- package/dist/commands/media/remove.js.map +0 -1
- package/dist/commands/media/show.d.ts +0 -17
- package/dist/commands/media/show.js +0 -122
- package/dist/commands/media/show.js.map +0 -1
- package/dist/commands/phase/create.d.ts +0 -22
- package/dist/commands/phase/create.js +0 -165
- package/dist/commands/phase/create.js.map +0 -1
- package/dist/commands/phase/delete.d.ts +0 -18
- package/dist/commands/phase/delete.js +0 -75
- package/dist/commands/phase/delete.js.map +0 -1
- package/dist/commands/phase/list.d.ts +0 -13
- package/dist/commands/phase/list.js +0 -75
- package/dist/commands/phase/list.js.map +0 -1
- package/dist/commands/phase/move.d.ts +0 -18
- package/dist/commands/phase/move.js +0 -124
- package/dist/commands/phase/move.js.map +0 -1
- package/dist/commands/phase/template/apply.d.ts +0 -26
- package/dist/commands/phase/template/apply.js +0 -15
- package/dist/commands/phase/template/apply.js.map +0 -1
- package/dist/commands/phase/template/create.d.ts +0 -23
- package/dist/commands/phase/template/create.js +0 -15
- package/dist/commands/phase/template/create.js.map +0 -1
- package/dist/commands/phase/template/delete.d.ts +0 -18
- package/dist/commands/phase/template/delete.js +0 -63
- package/dist/commands/phase/template/delete.js.map +0 -1
- package/dist/commands/phase/template/list.d.ts +0 -17
- package/dist/commands/phase/template/list.js +0 -90
- package/dist/commands/phase/template/list.js.map +0 -1
- package/dist/commands/phase/template/update.d.ts +0 -1
- package/dist/commands/phase/template/update.js +0 -2
- package/dist/commands/phase/template/update.js.map +0 -1
- package/dist/commands/phase/update.d.ts +0 -23
- package/dist/commands/phase/update.js +0 -209
- package/dist/commands/phase/update.js.map +0 -1
- package/dist/commands/priority/add.d.ts +0 -16
- package/dist/commands/priority/add.js +0 -71
- package/dist/commands/priority/add.js.map +0 -1
- package/dist/commands/priority/list.d.ts +0 -11
- package/dist/commands/priority/list.js +0 -35
- package/dist/commands/priority/list.js.map +0 -1
- package/dist/commands/priority/remove.d.ts +0 -14
- package/dist/commands/priority/remove.js +0 -55
- package/dist/commands/priority/remove.js.map +0 -1
- package/dist/commands/priority/set.d.ts +0 -15
- package/dist/commands/priority/set.js +0 -61
- package/dist/commands/priority/set.js.map +0 -1
- package/dist/commands/roadmap/add-project.d.ts +0 -19
- package/dist/commands/roadmap/add-project.js +0 -119
- package/dist/commands/roadmap/add-project.js.map +0 -1
- package/dist/commands/roadmap/create.d.ts +0 -22
- package/dist/commands/roadmap/create.js +0 -168
- package/dist/commands/roadmap/create.js.map +0 -1
- package/dist/commands/roadmap/delete.d.ts +0 -18
- package/dist/commands/roadmap/delete.js +0 -96
- package/dist/commands/roadmap/delete.js.map +0 -1
- package/dist/commands/roadmap/generate.d.ts +0 -24
- package/dist/commands/roadmap/generate.js +0 -201
- package/dist/commands/roadmap/generate.js.map +0 -1
- package/dist/commands/roadmap/index.d.ts +0 -14
- package/dist/commands/roadmap/index.js +0 -57
- package/dist/commands/roadmap/index.js.map +0 -1
- package/dist/commands/roadmap/list.d.ts +0 -14
- package/dist/commands/roadmap/list.js +0 -58
- package/dist/commands/roadmap/list.js.map +0 -1
- package/dist/commands/roadmap/remove-project.d.ts +0 -19
- package/dist/commands/roadmap/remove-project.js +0 -124
- package/dist/commands/roadmap/remove-project.js.map +0 -1
- package/dist/commands/roadmap/reorder.d.ts +0 -18
- package/dist/commands/roadmap/reorder.js +0 -147
- package/dist/commands/roadmap/reorder.js.map +0 -1
- package/dist/commands/roadmap/update.d.ts +0 -20
- package/dist/commands/roadmap/update.js +0 -134
- package/dist/commands/roadmap/update.js.map +0 -1
- package/dist/commands/roadmap/view.d.ts +0 -17
- package/dist/commands/roadmap/view.js +0 -93
- package/dist/commands/roadmap/view.js.map +0 -1
- package/dist/commands/staff/add.d.ts +0 -17
- package/dist/commands/staff/add.js +0 -275
- package/dist/commands/staff/add.js.map +0 -1
- package/dist/commands/staff/index.d.ts +0 -15
- package/dist/commands/staff/index.js +0 -88
- package/dist/commands/staff/index.js.map +0 -1
- package/dist/commands/staff/list.d.ts +0 -10
- package/dist/commands/staff/list.js +0 -104
- package/dist/commands/staff/list.js.map +0 -1
- package/dist/commands/staff/remove.d.ts +0 -18
- package/dist/commands/staff/remove.js +0 -144
- package/dist/commands/staff/remove.js.map +0 -1
- package/dist/commands/status/category.d.ts +0 -15
- package/dist/commands/status/category.js +0 -64
- package/dist/commands/status/category.js.map +0 -1
- package/dist/commands/status/create.d.ts +0 -21
- package/dist/commands/status/create.js +0 -161
- package/dist/commands/status/create.js.map +0 -1
- package/dist/commands/status/delete.d.ts +0 -14
- package/dist/commands/status/delete.js +0 -86
- package/dist/commands/status/delete.js.map +0 -1
- package/dist/commands/status/index.d.ts +0 -15
- package/dist/commands/status/index.js +0 -98
- package/dist/commands/status/index.js.map +0 -1
- package/dist/commands/status/list.d.ts +0 -13
- package/dist/commands/status/list.js +0 -97
- package/dist/commands/status/list.js.map +0 -1
- package/dist/commands/status/move.d.ts +0 -15
- package/dist/commands/status/move.js +0 -126
- package/dist/commands/status/move.js.map +0 -1
- package/dist/commands/status/update.d.ts +0 -20
- package/dist/commands/status/update.js +0 -214
- package/dist/commands/status/update.js.map +0 -1
- package/dist/commands/template/apply.d.ts +0 -28
- package/dist/commands/template/apply.js +0 -258
- package/dist/commands/template/apply.js.map +0 -1
- package/dist/commands/template/create.d.ts +0 -28
- package/dist/commands/template/create.js +0 -238
- package/dist/commands/template/create.js.map +0 -1
- package/dist/commands/template/delete.d.ts +0 -16
- package/dist/commands/template/delete.js +0 -141
- package/dist/commands/template/delete.js.map +0 -1
- package/dist/commands/template/index.d.ts +0 -11
- package/dist/commands/template/index.js +0 -65
- package/dist/commands/template/index.js.map +0 -1
- package/dist/commands/template/list.d.ts +0 -19
- package/dist/commands/template/list.js +0 -155
- package/dist/commands/template/list.js.map +0 -1
- package/dist/commands/template/save.d.ts +0 -17
- package/dist/commands/template/save.js +0 -101
- package/dist/commands/template/save.js.map +0 -1
- package/dist/commands/template/update.d.ts +0 -19
- package/dist/commands/template/update.js +0 -94
- package/dist/commands/template/update.js.map +0 -1
- package/dist/commands/ticket/template/apply.d.ts +0 -26
- package/dist/commands/ticket/template/apply.js +0 -15
- package/dist/commands/ticket/template/apply.js.map +0 -1
- package/dist/commands/ticket/template/delete.d.ts +0 -18
- package/dist/commands/ticket/template/delete.js +0 -63
- package/dist/commands/ticket/template/delete.js.map +0 -1
- package/dist/commands/ticket/template/list.d.ts +0 -17
- package/dist/commands/ticket/template/list.js +0 -79
- package/dist/commands/ticket/template/list.js.map +0 -1
- package/dist/commands/ticket/template/save.d.ts +0 -17
- package/dist/commands/ticket/template/save.js +0 -99
- package/dist/commands/ticket/template/save.js.map +0 -1
- package/dist/commands/work/spawn-all.d.ts +0 -19
- package/dist/commands/work/spawn-all.js +0 -64
- package/dist/commands/work/spawn-all.js.map +0 -1
- package/dist/commands/workflow/create.d.ts +0 -19
- package/dist/commands/workflow/create.js +0 -118
- package/dist/commands/workflow/create.js.map +0 -1
- package/dist/commands/workflow/delete.d.ts +0 -18
- package/dist/commands/workflow/delete.js +0 -108
- package/dist/commands/workflow/delete.js.map +0 -1
- package/dist/commands/workflow/index.d.ts +0 -16
- package/dist/commands/workflow/index.js +0 -73
- package/dist/commands/workflow/index.js.map +0 -1
- package/dist/commands/workflow/list.d.ts +0 -16
- package/dist/commands/workflow/list.js +0 -73
- package/dist/commands/workflow/list.js.map +0 -1
- package/dist/commands/workflow/setup.d.ts +0 -24
- package/dist/commands/workflow/setup.js +0 -351
- package/dist/commands/workflow/setup.js.map +0 -1
- package/dist/commands/workflow/show.d.ts +0 -13
- package/dist/commands/workflow/show.js +0 -17
- package/dist/commands/workflow/show.js.map +0 -1
- package/dist/commands/workflow/switch.js +0 -144
- package/dist/commands/workflow/switch.js.map +0 -1
- package/dist/commands/workflow/view.d.ts +0 -17
- package/dist/commands/workflow/view.js +0 -106
- package/dist/commands/workflow/view.js.map +0 -1
- package/dist/commands/workflow-rule/create.d.ts +0 -19
- package/dist/commands/workflow-rule/create.js +0 -141
- package/dist/commands/workflow-rule/create.js.map +0 -1
- package/dist/commands/workflow-rule/delete.d.ts +0 -18
- package/dist/commands/workflow-rule/delete.js +0 -72
- package/dist/commands/workflow-rule/delete.js.map +0 -1
- package/dist/commands/workflow-rule/index.d.ts +0 -16
- package/dist/commands/workflow-rule/index.js +0 -83
- package/dist/commands/workflow-rule/index.js.map +0 -1
- package/dist/commands/workflow-rule/list.d.ts +0 -17
- package/dist/commands/workflow-rule/list.js +0 -72
- package/dist/commands/workflow-rule/list.js.map +0 -1
- package/dist/commands/workflow-rule/update.d.ts +0 -22
- package/dist/commands/workflow-rule/update.js +0 -84
- package/dist/commands/workflow-rule/update.js.map +0 -1
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
import { Args } from '@oclif/core';
|
|
2
|
-
import { PMOCommand, pmoBaseFlags } from '../../lib/pmo/index.js';
|
|
3
|
-
import { shouldOutputJson } from '../../lib/prompt-json.js';
|
|
4
|
-
import { styles } from '../../lib/styles.js';
|
|
5
|
-
export default class LabelDelete extends PMOCommand {
|
|
6
|
-
static description = 'Delete a label (removes from all tickets)';
|
|
7
|
-
static examples = [
|
|
8
|
-
'<%= config.bin %> <%= command.id %> my-label',
|
|
9
|
-
];
|
|
10
|
-
static args = {
|
|
11
|
-
id: Args.string({
|
|
12
|
-
description: 'Label ID to delete',
|
|
13
|
-
required: true,
|
|
14
|
-
}),
|
|
15
|
-
};
|
|
16
|
-
static flags = {
|
|
17
|
-
...pmoBaseFlags,
|
|
18
|
-
};
|
|
19
|
-
getPMOOptions() {
|
|
20
|
-
return { promptIfMultiple: false };
|
|
21
|
-
}
|
|
22
|
-
async execute() {
|
|
23
|
-
const { args, flags } = await this.parse(LabelDelete);
|
|
24
|
-
await this.storage.deleteLabel(args.id);
|
|
25
|
-
if (shouldOutputJson(flags)) {
|
|
26
|
-
this.log(JSON.stringify({ success: true, deleted: args.id }));
|
|
27
|
-
return;
|
|
28
|
-
}
|
|
29
|
-
this.log(styles.success(`\nDeleted label: ${args.id}`));
|
|
30
|
-
this.log('');
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
//# sourceMappingURL=delete.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"delete.js","sourceRoot":"","sources":["../../../src/commands/label/delete.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAS,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAClE,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAE7C,MAAM,CAAC,OAAO,OAAO,WAAY,SAAQ,UAAU;IACjD,MAAM,CAAC,WAAW,GAAG,2CAA2C,CAAC;IAEjE,MAAM,CAAC,QAAQ,GAAG;QAChB,8CAA8C;KAC/C,CAAC;IAEF,MAAM,CAAC,IAAI,GAAG;QACZ,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC;YACd,WAAW,EAAE,oBAAoB;YACjC,QAAQ,EAAE,IAAI;SACf,CAAC;KACH,CAAC;IAEF,MAAM,CAAC,KAAK,GAAG;QACb,GAAG,YAAY;KAChB,CAAC;IAEQ,aAAa;QACrB,OAAO,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC;IACrC,CAAC;IAED,KAAK,CAAC,OAAO;QACX,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QAEtD,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAExC,IAAI,gBAAgB,CAAC,KAAK,CAAC,EAAE,CAAC;YAC5B,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;YAC9D,OAAO;QACT,CAAC;QAED,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,oBAAoB,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;QACxD,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IACf,CAAC"}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { PMOCommand } from '../../../lib/pmo/index.js';
|
|
2
|
-
export default class LabelGroupCreate extends PMOCommand {
|
|
3
|
-
static description: string;
|
|
4
|
-
static examples: string[];
|
|
5
|
-
static args: {
|
|
6
|
-
name: import("@oclif/core/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
-
};
|
|
8
|
-
static flags: {
|
|
9
|
-
description: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
10
|
-
exclusive: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
11
|
-
required: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
12
|
-
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
13
|
-
machine: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
14
|
-
project: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
15
|
-
};
|
|
16
|
-
protected getPMOOptions(): {
|
|
17
|
-
promptIfMultiple: boolean;
|
|
18
|
-
};
|
|
19
|
-
execute(): Promise<void>;
|
|
20
|
-
}
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
import { Args, Flags } from '@oclif/core';
|
|
2
|
-
import { PMOCommand, pmoBaseFlags } from '../../../lib/pmo/index.js';
|
|
3
|
-
import { shouldOutputJson } from '../../../lib/prompt-json.js';
|
|
4
|
-
import { styles } from '../../../lib/styles.js';
|
|
5
|
-
export default class LabelGroupCreate extends PMOCommand {
|
|
6
|
-
static description = 'Create a new label group';
|
|
7
|
-
static examples = [
|
|
8
|
-
'<%= config.bin %> <%= command.id %> Priority',
|
|
9
|
-
'<%= config.bin %> <%= command.id %> Severity --exclusive --required',
|
|
10
|
-
'<%= config.bin %> <%= command.id %> Tags --no-exclusive --description "Free-form tags"',
|
|
11
|
-
];
|
|
12
|
-
static args = {
|
|
13
|
-
name: Args.string({
|
|
14
|
-
description: 'Group name',
|
|
15
|
-
required: true,
|
|
16
|
-
}),
|
|
17
|
-
};
|
|
18
|
-
static flags = {
|
|
19
|
-
...pmoBaseFlags,
|
|
20
|
-
description: Flags.string({
|
|
21
|
-
char: 'd',
|
|
22
|
-
description: 'Group description',
|
|
23
|
-
}),
|
|
24
|
-
exclusive: Flags.boolean({
|
|
25
|
-
description: 'Only one label from this group per ticket (default: true)',
|
|
26
|
-
default: true,
|
|
27
|
-
allowNo: true,
|
|
28
|
-
}),
|
|
29
|
-
required: Flags.boolean({
|
|
30
|
-
description: 'Must have one label from this group',
|
|
31
|
-
default: false,
|
|
32
|
-
}),
|
|
33
|
-
};
|
|
34
|
-
getPMOOptions() {
|
|
35
|
-
return { promptIfMultiple: false };
|
|
36
|
-
}
|
|
37
|
-
async execute() {
|
|
38
|
-
const { args, flags } = await this.parse(LabelGroupCreate);
|
|
39
|
-
const group = await this.storage.createLabelGroup({
|
|
40
|
-
name: args.name,
|
|
41
|
-
description: flags.description,
|
|
42
|
-
isExclusive: flags.exclusive,
|
|
43
|
-
isRequired: flags.required,
|
|
44
|
-
});
|
|
45
|
-
if (shouldOutputJson(flags)) {
|
|
46
|
-
this.log(JSON.stringify(group, null, 2));
|
|
47
|
-
return;
|
|
48
|
-
}
|
|
49
|
-
const exclusive = group.isExclusive ? 'exclusive' : 'non-exclusive';
|
|
50
|
-
const required = group.isRequired ? ', required' : '';
|
|
51
|
-
this.log(styles.success(`\nCreated label group: ${group.name} (${group.id})`));
|
|
52
|
-
this.log(styles.muted(` ${exclusive}${required}`));
|
|
53
|
-
this.log('');
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
//# sourceMappingURL=create.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../../src/commands/label/group/create.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAEhD,MAAM,CAAC,OAAO,OAAO,gBAAiB,SAAQ,UAAU;IACtD,MAAM,CAAC,WAAW,GAAG,0BAA0B,CAAC;IAEhD,MAAM,CAAC,QAAQ,GAAG;QAChB,8CAA8C;QAC9C,qEAAqE;QACrE,wFAAwF;KACzF,CAAC;IAEF,MAAM,CAAC,IAAI,GAAG;QACZ,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC;YAChB,WAAW,EAAE,YAAY;YACzB,QAAQ,EAAE,IAAI;SACf,CAAC;KACH,CAAC;IAEF,MAAM,CAAC,KAAK,GAAG;QACb,GAAG,YAAY;QACf,WAAW,EAAE,KAAK,CAAC,MAAM,CAAC;YACxB,IAAI,EAAE,GAAG;YACT,WAAW,EAAE,mBAAmB;SACjC,CAAC;QACF,SAAS,EAAE,KAAK,CAAC,OAAO,CAAC;YACvB,WAAW,EAAE,2DAA2D;YACxE,OAAO,EAAE,IAAI;YACb,OAAO,EAAE,IAAI;SACd,CAAC;QACF,QAAQ,EAAE,KAAK,CAAC,OAAO,CAAC;YACtB,WAAW,EAAE,qCAAqC;YAClD,OAAO,EAAE,KAAK;SACf,CAAC;KACH,CAAC;IAEQ,aAAa;QACrB,OAAO,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC;IACrC,CAAC;IAED,KAAK,CAAC,OAAO;QACX,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;QAE3D,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC;YAChD,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,WAAW,EAAE,KAAK,CAAC,SAAS;YAC5B,UAAU,EAAE,KAAK,CAAC,QAAQ;SAC3B,CAAC,CAAC;QAEH,IAAI,gBAAgB,CAAC,KAAK,CAAC,EAAE,CAAC;YAC5B,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;YACzC,OAAO;QACT,CAAC;QAED,MAAM,SAAS,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,eAAe,CAAC;QACpE,MAAM,QAAQ,GAAG,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC;QACtD,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,0BAA0B,KAAK,CAAC,IAAI,KAAK,KAAK,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;QAC/E,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,SAAS,GAAG,QAAQ,EAAE,CAAC,CAAC,CAAC;QACpD,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IACf,CAAC"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { PMOCommand } from '../../../lib/pmo/index.js';
|
|
2
|
-
export default class LabelGroupList extends PMOCommand {
|
|
3
|
-
static description: string;
|
|
4
|
-
static examples: string[];
|
|
5
|
-
static flags: {
|
|
6
|
-
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
7
|
-
machine: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
8
|
-
project: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
9
|
-
};
|
|
10
|
-
protected getPMOOptions(): {
|
|
11
|
-
promptIfMultiple: boolean;
|
|
12
|
-
};
|
|
13
|
-
execute(): Promise<void>;
|
|
14
|
-
}
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
import { Flags } from '@oclif/core';
|
|
2
|
-
import { PMOCommand, pmoBaseFlags } from '../../../lib/pmo/index.js';
|
|
3
|
-
import { shouldOutputJson } from '../../../lib/prompt-json.js';
|
|
4
|
-
import { styles } from '../../../lib/styles.js';
|
|
5
|
-
export default class LabelGroupList extends PMOCommand {
|
|
6
|
-
static description = 'List label groups';
|
|
7
|
-
static examples = [
|
|
8
|
-
'<%= config.bin %> <%= command.id %>',
|
|
9
|
-
'<%= config.bin %> <%= command.id %> --json',
|
|
10
|
-
];
|
|
11
|
-
static flags = {
|
|
12
|
-
...pmoBaseFlags,
|
|
13
|
-
json: Flags.boolean({
|
|
14
|
-
description: 'Output as JSON',
|
|
15
|
-
default: false,
|
|
16
|
-
}),
|
|
17
|
-
};
|
|
18
|
-
getPMOOptions() {
|
|
19
|
-
return { promptIfMultiple: false };
|
|
20
|
-
}
|
|
21
|
-
async execute() {
|
|
22
|
-
const { flags } = await this.parse(LabelGroupList);
|
|
23
|
-
const groups = await this.storage.listLabelGroups();
|
|
24
|
-
if (shouldOutputJson(flags)) {
|
|
25
|
-
this.log(JSON.stringify(groups, null, 2));
|
|
26
|
-
return;
|
|
27
|
-
}
|
|
28
|
-
if (groups.length === 0) {
|
|
29
|
-
this.log(styles.muted('\nNo label groups found.'));
|
|
30
|
-
this.log(styles.muted('Create one: prlt label group create <name>'));
|
|
31
|
-
return;
|
|
32
|
-
}
|
|
33
|
-
this.log(`\n${styles.emphasis('Label Groups')}`);
|
|
34
|
-
this.log('═'.repeat(60));
|
|
35
|
-
for (const group of groups) {
|
|
36
|
-
const exclusive = group.isExclusive ? 'exclusive' : 'non-exclusive';
|
|
37
|
-
const required = group.isRequired ? ', required' : '';
|
|
38
|
-
this.log(`\n ${styles.emphasis(group.name)} ${styles.muted(`(${group.id})`)}`);
|
|
39
|
-
this.log(` ${styles.muted(`${exclusive}${required}`)}`);
|
|
40
|
-
if (group.description) {
|
|
41
|
-
this.log(` ${styles.muted(group.description)}`);
|
|
42
|
-
}
|
|
43
|
-
// Show labels in this group
|
|
44
|
-
const labels = await this.storage.listLabels({ groupId: group.id });
|
|
45
|
-
if (labels.length > 0) {
|
|
46
|
-
const labelNames = labels.map(l => l.name).join(', ');
|
|
47
|
-
this.log(` Labels: ${labelNames}`);
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
this.log('');
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
//# sourceMappingURL=list.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"list.js","sourceRoot":"","sources":["../../../../src/commands/label/group/list.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { PMOCommand } from '../../lib/pmo/index.js';
|
|
2
|
-
export default class LabelIndex extends PMOCommand {
|
|
3
|
-
static description: string;
|
|
4
|
-
static aliases: string[];
|
|
5
|
-
static examples: string[];
|
|
6
|
-
static flags: {
|
|
7
|
-
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
8
|
-
machine: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
9
|
-
project: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
10
|
-
};
|
|
11
|
-
protected getPMOOptions(): {
|
|
12
|
-
promptIfMultiple: boolean;
|
|
13
|
-
};
|
|
14
|
-
execute(): Promise<void>;
|
|
15
|
-
}
|
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
import { PMOCommand, pmoBaseFlags } from '../../lib/pmo/index.js';
|
|
2
|
-
import { shouldOutputJson } from '../../lib/prompt-json.js';
|
|
3
|
-
export default class LabelIndex extends PMOCommand {
|
|
4
|
-
static description = 'Manage labels and label groups';
|
|
5
|
-
static aliases = ['labels'];
|
|
6
|
-
static examples = [
|
|
7
|
-
'<%= config.bin %> <%= command.id %>',
|
|
8
|
-
'<%= config.bin %> label list',
|
|
9
|
-
'<%= config.bin %> label create my-label',
|
|
10
|
-
'<%= config.bin %> label group list',
|
|
11
|
-
];
|
|
12
|
-
static flags = {
|
|
13
|
-
...pmoBaseFlags,
|
|
14
|
-
};
|
|
15
|
-
getPMOOptions() {
|
|
16
|
-
return { promptIfMultiple: false };
|
|
17
|
-
}
|
|
18
|
-
async execute() {
|
|
19
|
-
const { flags } = await this.parse(LabelIndex);
|
|
20
|
-
const jsonMode = shouldOutputJson(flags);
|
|
21
|
-
const menuChoices = [
|
|
22
|
-
{ id: 'list', name: 'List all labels', command: 'prlt label list' },
|
|
23
|
-
{ id: 'create', name: 'Create new label', command: 'prlt label create' },
|
|
24
|
-
{ id: 'delete', name: 'Delete label', command: 'prlt label delete' },
|
|
25
|
-
{ id: 'groups', name: 'List label groups', command: 'prlt label group list' },
|
|
26
|
-
{ id: 'create-group', name: 'Create label group', command: 'prlt label group create' },
|
|
27
|
-
{ id: 'cancel', name: 'Cancel', command: '' },
|
|
28
|
-
];
|
|
29
|
-
const action = await this.selectFromList({
|
|
30
|
-
message: 'Labels - What would you like to do?',
|
|
31
|
-
items: menuChoices,
|
|
32
|
-
getName: (c) => c.name,
|
|
33
|
-
getValue: (c) => c.id,
|
|
34
|
-
getCommand: (c) => c.command,
|
|
35
|
-
jsonMode: jsonMode ? { flags, commandName: 'label' } : null,
|
|
36
|
-
});
|
|
37
|
-
if (action === 'cancel' || !action) {
|
|
38
|
-
return;
|
|
39
|
-
}
|
|
40
|
-
switch (action) {
|
|
41
|
-
case 'list':
|
|
42
|
-
await this.config.runCommand('label:list');
|
|
43
|
-
break;
|
|
44
|
-
case 'create':
|
|
45
|
-
await this.config.runCommand('label:create');
|
|
46
|
-
break;
|
|
47
|
-
case 'delete':
|
|
48
|
-
await this.config.runCommand('label:delete');
|
|
49
|
-
break;
|
|
50
|
-
case 'groups':
|
|
51
|
-
await this.config.runCommand('label:group:list');
|
|
52
|
-
break;
|
|
53
|
-
case 'create-group':
|
|
54
|
-
await this.config.runCommand('label:group:create');
|
|
55
|
-
break;
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/commands/label/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAClE,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAE5D,MAAM,CAAC,OAAO,OAAO,UAAW,SAAQ,UAAU;IAChD,MAAM,CAAC,WAAW,GAAG,gCAAgC,CAAC;IAEtD,MAAM,CAAC,OAAO,GAAG,CAAC,QAAQ,CAAC,CAAC;IAE5B,MAAM,CAAC,QAAQ,GAAG;QAChB,qCAAqC;QACrC,8BAA8B;QAC9B,yCAAyC;QACzC,oCAAoC;KACrC,CAAC;IAEF,MAAM,CAAC,KAAK,GAAG;QACb,GAAG,YAAY;KAChB,CAAC;IAEQ,aAAa;QACrB,OAAO,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC;IACrC,CAAC;IAED,KAAK,CAAC,OAAO;QACX,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAC/C,MAAM,QAAQ,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAEzC,MAAM,WAAW,GAAG;YAClB,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,iBAAiB,EAAE,OAAO,EAAE,iBAAiB,EAAE;YACnE,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,kBAAkB,EAAE,OAAO,EAAE,mBAAmB,EAAE;YACxE,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,cAAc,EAAE,OAAO,EAAE,mBAAmB,EAAE;YACpE,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,mBAAmB,EAAE,OAAO,EAAE,uBAAuB,EAAE;YAC7E,EAAE,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,oBAAoB,EAAE,OAAO,EAAE,yBAAyB,EAAE;YACtF,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,EAAE,EAAE;SAC9C,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC;YACvC,OAAO,EAAE,qCAAqC;YAC9C,KAAK,EAAE,WAAW;YAClB,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI;YACtB,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE;YACrB,UAAU,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO;YAC5B,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI;SAC5D,CAAC,CAAC;QAEH,IAAI,MAAM,KAAK,QAAQ,IAAI,CAAC,MAAM,EAAE,CAAC;YACnC,OAAO;QACT,CAAC;QAED,QAAQ,MAAM,EAAE,CAAC;YACf,KAAK,MAAM;gBACT,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;gBAC3C,MAAM;YACR,KAAK,QAAQ;gBACX,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;gBAC7C,MAAM;YACR,KAAK,QAAQ;gBACX,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;gBAC7C,MAAM;YACR,KAAK,QAAQ;gBACX,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,kBAAkB,CAAC,CAAC;gBACjD,MAAM;YACR,KAAK,cAAc;gBACjB,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAC;gBACnD,MAAM;QACV,CAAC;IACH,CAAC"}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { PMOCommand } from '../../lib/pmo/index.js';
|
|
2
|
-
export default class LabelList extends PMOCommand {
|
|
3
|
-
static description: string;
|
|
4
|
-
static examples: string[];
|
|
5
|
-
static flags: {
|
|
6
|
-
group: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
7
|
-
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
8
|
-
machine: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
9
|
-
project: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
10
|
-
};
|
|
11
|
-
protected getPMOOptions(): {
|
|
12
|
-
promptIfMultiple: boolean;
|
|
13
|
-
};
|
|
14
|
-
execute(): Promise<void>;
|
|
15
|
-
private printLabel;
|
|
16
|
-
}
|
|
@@ -1,84 +0,0 @@
|
|
|
1
|
-
import { Flags } from '@oclif/core';
|
|
2
|
-
import { PMOCommand, pmoBaseFlags } from '../../lib/pmo/index.js';
|
|
3
|
-
import { shouldOutputJson } from '../../lib/prompt-json.js';
|
|
4
|
-
import { styles } from '../../lib/styles.js';
|
|
5
|
-
export default class LabelList extends PMOCommand {
|
|
6
|
-
static description = 'List labels, optionally filtered by group';
|
|
7
|
-
static examples = [
|
|
8
|
-
'<%= config.bin %> <%= command.id %>',
|
|
9
|
-
'<%= config.bin %> <%= command.id %> --group function',
|
|
10
|
-
'<%= config.bin %> <%= command.id %> --json',
|
|
11
|
-
];
|
|
12
|
-
static flags = {
|
|
13
|
-
...pmoBaseFlags,
|
|
14
|
-
group: Flags.string({
|
|
15
|
-
char: 'g',
|
|
16
|
-
description: 'Filter by group ID',
|
|
17
|
-
}),
|
|
18
|
-
json: Flags.boolean({
|
|
19
|
-
description: 'Output as JSON',
|
|
20
|
-
default: false,
|
|
21
|
-
}),
|
|
22
|
-
};
|
|
23
|
-
getPMOOptions() {
|
|
24
|
-
return { promptIfMultiple: false };
|
|
25
|
-
}
|
|
26
|
-
async execute() {
|
|
27
|
-
const { flags } = await this.parse(LabelList);
|
|
28
|
-
const labels = await this.storage.listLabels({
|
|
29
|
-
groupId: flags.group,
|
|
30
|
-
});
|
|
31
|
-
if (shouldOutputJson(flags)) {
|
|
32
|
-
this.log(JSON.stringify(labels, null, 2));
|
|
33
|
-
return;
|
|
34
|
-
}
|
|
35
|
-
if (labels.length === 0) {
|
|
36
|
-
this.log(styles.muted('\nNo labels found.'));
|
|
37
|
-
this.log(styles.muted('Create one: prlt label create <name>'));
|
|
38
|
-
return;
|
|
39
|
-
}
|
|
40
|
-
this.log(`\n${styles.emphasis('Labels')}`);
|
|
41
|
-
this.log('═'.repeat(60));
|
|
42
|
-
// Group labels by group
|
|
43
|
-
const grouped = new Map();
|
|
44
|
-
const ungrouped = [];
|
|
45
|
-
for (const label of labels) {
|
|
46
|
-
if (label.groupName) {
|
|
47
|
-
const group = grouped.get(label.groupName) || [];
|
|
48
|
-
group.push(label);
|
|
49
|
-
grouped.set(label.groupName, group);
|
|
50
|
-
}
|
|
51
|
-
else {
|
|
52
|
-
ungrouped.push(label);
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
for (const [groupName, groupLabels] of grouped) {
|
|
56
|
-
// Look up group info
|
|
57
|
-
const group = await this.storage.getLabelGroupByName(groupName);
|
|
58
|
-
const exclusive = group?.isExclusive ? ' (exclusive)' : '';
|
|
59
|
-
const required = group?.isRequired ? ' (required)' : '';
|
|
60
|
-
this.log(`\n${styles.emphasis(groupName)}${styles.muted(exclusive + required)}`);
|
|
61
|
-
this.log('─'.repeat(40));
|
|
62
|
-
for (const label of groupLabels) {
|
|
63
|
-
this.printLabel(label);
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
if (ungrouped.length > 0) {
|
|
67
|
-
this.log(`\n${styles.emphasis('Ungrouped')}`);
|
|
68
|
-
this.log('─'.repeat(40));
|
|
69
|
-
for (const label of ungrouped) {
|
|
70
|
-
this.printLabel(label);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
this.log('');
|
|
74
|
-
}
|
|
75
|
-
printLabel(label) {
|
|
76
|
-
const colorDot = label.color ? `${label.color} ` : '';
|
|
77
|
-
const builtinBadge = label.isBuiltin ? '' : ' [custom]';
|
|
78
|
-
this.log(` ${colorDot}${styles.emphasis(label.name)} ${styles.muted(`(${label.id})`)}${builtinBadge}`);
|
|
79
|
-
if (label.description) {
|
|
80
|
-
this.log(` ${styles.muted(label.description)}`);
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
//# sourceMappingURL=list.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"list.js","sourceRoot":"","sources":["../../../src/commands/label/list.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAElE,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAE7C,MAAM,CAAC,OAAO,OAAO,SAAU,SAAQ,UAAU;IAC/C,MAAM,CAAC,WAAW,GAAG,2CAA2C,CAAC;IAEjE,MAAM,CAAC,QAAQ,GAAG;QAChB,qCAAqC;QACrC,sDAAsD;QACtD,4CAA4C;KAC7C,CAAC;IAEF,MAAM,CAAC,KAAK,GAAG;QACb,GAAG,YAAY;QACf,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC;YAClB,IAAI,EAAE,GAAG;YACT,WAAW,EAAE,oBAAoB;SAClC,CAAC;QACF,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC;YAClB,WAAW,EAAE,gBAAgB;YAC7B,OAAO,EAAE,KAAK;SACf,CAAC;KACH,CAAC;IAEQ,aAAa;QACrB,OAAO,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC;IACrC,CAAC;IAED,KAAK,CAAC,OAAO;QACX,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAE9C,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC;YAC3C,OAAO,EAAE,KAAK,CAAC,KAAK;SACrB,CAAC,CAAC;QAEH,IAAI,gBAAgB,CAAC,KAAK,CAAC,EAAE,CAAC;YAC5B,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;YAC1C,OAAO;QACT,CAAC;QAED,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACxB,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAC,CAAC;YAC7C,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC,CAAC;YAC/D,OAAO;QACT,CAAC;QAED,IAAI,CAAC,GAAG,CAAC,KAAK,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QAC3C,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;QAEzB,wBAAwB;QACxB,MAAM,OAAO,GAAG,IAAI,GAAG,EAAmB,CAAC;QAC3C,MAAM,SAAS,GAAY,EAAE,CAAC;QAE9B,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;YAC3B,IAAI,KAAK,CAAC,SAAS,EAAE,CAAC;gBACpB,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;gBACjD,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAClB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;YACtC,CAAC;iBAAM,CAAC;gBACN,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACxB,CAAC;QACH,CAAC;QAED,KAAK,MAAM,CAAC,SAAS,EAAE,WAAW,CAAC,IAAI,OAAO,EAAE,CAAC;YAC/C,qBAAqB;YACrB,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,SAAS,CAAC,CAAC;YAChE,MAAM,SAAS,GAAG,KAAK,EAAE,WAAW,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,CAAC;YAC3D,MAAM,QAAQ,GAAG,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC;YACxD,IAAI,CAAC,GAAG,CAAC,KAAK,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,SAAS,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;YACjF,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;YACzB,KAAK,MAAM,KAAK,IAAI,WAAW,EAAE,CAAC;gBAChC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;YACzB,CAAC;QACH,CAAC;QAED,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACzB,IAAI,CAAC,GAAG,CAAC,KAAK,MAAM,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;YAC9C,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;YACzB,KAAK,MAAM,KAAK,IAAI,SAAS,EAAE,CAAC;gBAC9B,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;YACzB,CAAC;QACH,CAAC;QAED,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IACf,CAAC;IAEO,UAAU,CAAC,KAAY;QAC7B,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;QACtD,MAAM,YAAY,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC;QACxD,IAAI,CAAC,GAAG,CAAC,KAAK,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,MAAM,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,EAAE,GAAG,CAAC,GAAG,YAAY,EAAE,CAAC,CAAC;QACxG,IAAI,KAAK,CAAC,WAAW,EAAE,CAAC;YACtB,IAAI,CAAC,GAAG,CAAC,OAAO,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QACrD,CAAC;IACH,CAAC"}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { PMOCommand } from '../../lib/pmo/index.js';
|
|
2
|
-
export default class LinkCreate extends PMOCommand {
|
|
3
|
-
static description: string;
|
|
4
|
-
static examples: string[];
|
|
5
|
-
static args: {
|
|
6
|
-
from: import("@oclif/core/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
-
to: import("@oclif/core/interfaces").Arg<string, Record<string, unknown>>;
|
|
8
|
-
};
|
|
9
|
-
static flags: {
|
|
10
|
-
type: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
|
|
11
|
-
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
12
|
-
machine: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
13
|
-
project: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
14
|
-
};
|
|
15
|
-
execute(): Promise<void>;
|
|
16
|
-
}
|
|
@@ -1,136 +0,0 @@
|
|
|
1
|
-
import { Args, Flags } from '@oclif/core';
|
|
2
|
-
import { autoExportToBoard, PMOCommand, pmoBaseFlags } from '../../lib/pmo/index.js';
|
|
3
|
-
import { styles } from '../../lib/styles.js';
|
|
4
|
-
import { shouldOutputJson, outputErrorAsJson, createMetadata, } from '../../lib/prompt-json.js';
|
|
5
|
-
/**
|
|
6
|
-
* Infer entity type from ID prefix
|
|
7
|
-
*/
|
|
8
|
-
function inferEntityType(id) {
|
|
9
|
-
const upper = id.toUpperCase();
|
|
10
|
-
if (upper.startsWith('TKT-'))
|
|
11
|
-
return 'ticket';
|
|
12
|
-
if (upper.startsWith('SPEC-'))
|
|
13
|
-
return 'spec';
|
|
14
|
-
if (upper.startsWith('EPIC-'))
|
|
15
|
-
return 'epic';
|
|
16
|
-
return null;
|
|
17
|
-
}
|
|
18
|
-
export default class LinkCreate extends PMOCommand {
|
|
19
|
-
static description = 'Create a link (dependency) between two entities';
|
|
20
|
-
static examples = [
|
|
21
|
-
'<%= config.bin %> <%= command.id %> TKT-001 TKT-002 --type blocks # TKT-001 is blocked by TKT-002',
|
|
22
|
-
'<%= config.bin %> <%= command.id %> TKT-001 TKT-002 --type relates # TKT-001 relates to TKT-002',
|
|
23
|
-
'<%= config.bin %> <%= command.id %> SPEC-001 SPEC-002 --type depends # SPEC-001 depends on SPEC-002',
|
|
24
|
-
'<%= config.bin %> <%= command.id %> EPIC-001 EPIC-002 --type blocks # EPIC-001 is blocked by EPIC-002',
|
|
25
|
-
];
|
|
26
|
-
static args = {
|
|
27
|
-
from: Args.string({
|
|
28
|
-
description: 'Source entity ID (TKT-xxx, SPEC-xxx, or EPIC-xxx)',
|
|
29
|
-
required: true,
|
|
30
|
-
}),
|
|
31
|
-
to: Args.string({
|
|
32
|
-
description: 'Target entity ID',
|
|
33
|
-
required: true,
|
|
34
|
-
}),
|
|
35
|
-
};
|
|
36
|
-
static flags = {
|
|
37
|
-
...pmoBaseFlags,
|
|
38
|
-
type: Flags.string({
|
|
39
|
-
char: 't',
|
|
40
|
-
description: 'Link type',
|
|
41
|
-
options: ['blocks', 'relates', 'duplicates', 'depends'],
|
|
42
|
-
required: true,
|
|
43
|
-
}),
|
|
44
|
-
};
|
|
45
|
-
async execute() {
|
|
46
|
-
const { args, flags } = await this.parse(LinkCreate);
|
|
47
|
-
const jsonMode = shouldOutputJson(flags);
|
|
48
|
-
const handleError = (code, message) => {
|
|
49
|
-
if (jsonMode) {
|
|
50
|
-
outputErrorAsJson(code, message, createMetadata('link create', flags));
|
|
51
|
-
return;
|
|
52
|
-
}
|
|
53
|
-
this.error(message);
|
|
54
|
-
};
|
|
55
|
-
const fromType = inferEntityType(args.from);
|
|
56
|
-
const toType = inferEntityType(args.to);
|
|
57
|
-
if (!fromType) {
|
|
58
|
-
return handleError('INVALID_FROM_ID', `Cannot infer entity type from "${args.from}". Use TKT-, SPEC-, or EPIC- prefix.`);
|
|
59
|
-
}
|
|
60
|
-
if (!toType) {
|
|
61
|
-
return handleError('INVALID_TO_ID', `Cannot infer entity type from "${args.to}". Use TKT-, SPEC-, or EPIC- prefix.`);
|
|
62
|
-
}
|
|
63
|
-
if (fromType !== toType) {
|
|
64
|
-
return handleError('TYPE_MISMATCH', `Cannot link different entity types: ${fromType} and ${toType}`);
|
|
65
|
-
}
|
|
66
|
-
const linkType = flags.type;
|
|
67
|
-
// Validate link type for entity type
|
|
68
|
-
// Tickets: blocks, relates_to, duplicates
|
|
69
|
-
// Specs: depends_on, relates_to, duplicates (no blocks)
|
|
70
|
-
// Epics: blocks, relates_to, duplicates (no depends)
|
|
71
|
-
if (fromType === 'spec' && linkType === 'blocks') {
|
|
72
|
-
return handleError('INVALID_LINK_TYPE', 'Specs do not support "blocks" link type. Use "depends" instead.');
|
|
73
|
-
}
|
|
74
|
-
if (fromType === 'epic' && linkType === 'depends') {
|
|
75
|
-
return handleError('INVALID_LINK_TYPE', 'Epics do not support "depends" link type. Use "blocks" instead.');
|
|
76
|
-
}
|
|
77
|
-
if (fromType === 'ticket' && linkType === 'depends') {
|
|
78
|
-
return handleError('INVALID_LINK_TYPE', 'Tickets do not support "depends" link type. Use "blocks" instead.');
|
|
79
|
-
}
|
|
80
|
-
// Map the link type to the storage dependency type
|
|
81
|
-
const dependencyType = linkType === 'relates' ? 'relates_to' :
|
|
82
|
-
linkType === 'depends' ? 'depends_on' : linkType;
|
|
83
|
-
try {
|
|
84
|
-
if (fromType === 'ticket') {
|
|
85
|
-
const ticket = await this.storage.getTicket(args.from);
|
|
86
|
-
if (!ticket)
|
|
87
|
-
return handleError('FROM_NOT_FOUND', `Ticket not found: ${args.from}`);
|
|
88
|
-
const targetTicket = await this.storage.getTicket(args.to);
|
|
89
|
-
if (!targetTicket)
|
|
90
|
-
return handleError('TO_NOT_FOUND', `Ticket not found: ${args.to}`);
|
|
91
|
-
await this.storage.createTicketDependency(args.from, args.to, dependencyType);
|
|
92
|
-
await autoExportToBoard(this.pmoPath, this.storage, (msg) => this.log(styles.muted(msg)));
|
|
93
|
-
this.log(styles.success(`\n✅ Link created: ${styles.emphasis(args.from)} → ${styles.emphasis(args.to)} (${linkType})`));
|
|
94
|
-
this.log(styles.muted(` ${ticket.title}`));
|
|
95
|
-
this.log(styles.muted(` ${linkType}: ${targetTicket.title}`));
|
|
96
|
-
}
|
|
97
|
-
else if (fromType === 'spec') {
|
|
98
|
-
const spec = await this.storage.getSpec(args.from);
|
|
99
|
-
if (!spec)
|
|
100
|
-
return handleError('FROM_NOT_FOUND', `Spec not found: ${args.from}`);
|
|
101
|
-
const targetSpec = await this.storage.getSpec(args.to);
|
|
102
|
-
if (!targetSpec)
|
|
103
|
-
return handleError('TO_NOT_FOUND', `Spec not found: ${args.to}`);
|
|
104
|
-
await this.storage.createSpecDependency(args.from, args.to, dependencyType);
|
|
105
|
-
this.log(styles.success(`\n✅ Link created: ${styles.emphasis(args.from)} → ${styles.emphasis(args.to)} (${linkType})`));
|
|
106
|
-
this.log(styles.muted(` ${spec.title}`));
|
|
107
|
-
this.log(styles.muted(` ${linkType}: ${targetSpec.title}`));
|
|
108
|
-
}
|
|
109
|
-
else if (fromType === 'epic') {
|
|
110
|
-
const epic = await this.storage.getEpic(args.from);
|
|
111
|
-
if (!epic)
|
|
112
|
-
return handleError('FROM_NOT_FOUND', `Epic not found: ${args.from}`);
|
|
113
|
-
const targetEpic = await this.storage.getEpic(args.to);
|
|
114
|
-
if (!targetEpic)
|
|
115
|
-
return handleError('TO_NOT_FOUND', `Epic not found: ${args.to}`);
|
|
116
|
-
await this.storage.createEpicDependency(args.from, args.to, dependencyType);
|
|
117
|
-
await autoExportToBoard(this.pmoPath, this.storage, (msg) => this.log(styles.muted(msg)));
|
|
118
|
-
this.log(styles.success(`\n✅ Link created: ${styles.emphasis(args.from)} → ${styles.emphasis(args.to)} (${linkType})`));
|
|
119
|
-
this.log(styles.muted(` ${epic.title}`));
|
|
120
|
-
this.log(styles.muted(` ${linkType}: ${targetEpic.title}`));
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
catch (error) {
|
|
124
|
-
if (error instanceof Error) {
|
|
125
|
-
if (error.message.includes('already exists')) {
|
|
126
|
-
return handleError('ALREADY_EXISTS', 'Link already exists');
|
|
127
|
-
}
|
|
128
|
-
if (error.message.includes('self-dependency')) {
|
|
129
|
-
return handleError('SELF_LINK', 'Cannot create self-link');
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
throw error;
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
//# sourceMappingURL=create.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../src/commands/link/create.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { PMOCommand } from '../../lib/pmo/index.js';
|
|
2
|
-
export default class Link extends PMOCommand {
|
|
3
|
-
static description: string;
|
|
4
|
-
static examples: string[];
|
|
5
|
-
static args: {
|
|
6
|
-
action: import("@oclif/core/interfaces").Arg<string | undefined, Record<string, unknown>>;
|
|
7
|
-
};
|
|
8
|
-
static flags: {
|
|
9
|
-
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
10
|
-
machine: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
11
|
-
project: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
12
|
-
};
|
|
13
|
-
execute(): Promise<void>;
|
|
14
|
-
}
|