jiradc-cli 0.0.1

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.
Files changed (157) hide show
  1. package/dist/commands/board/index.d.ts +3 -0
  2. package/dist/commands/board/index.d.ts.map +1 -0
  3. package/dist/commands/board/index.js +8 -0
  4. package/dist/commands/board/index.js.map +1 -0
  5. package/dist/commands/board/issues.d.ts +3 -0
  6. package/dist/commands/board/issues.d.ts.map +1 -0
  7. package/dist/commands/board/issues.js +23 -0
  8. package/dist/commands/board/issues.js.map +1 -0
  9. package/dist/commands/board/list.d.ts +3 -0
  10. package/dist/commands/board/list.d.ts.map +1 -0
  11. package/dist/commands/board/list.js +20 -0
  12. package/dist/commands/board/list.js.map +1 -0
  13. package/dist/commands/field/index.d.ts +3 -0
  14. package/dist/commands/field/index.d.ts.map +1 -0
  15. package/dist/commands/field/index.js +8 -0
  16. package/dist/commands/field/index.js.map +1 -0
  17. package/dist/commands/field/options.d.ts +3 -0
  18. package/dist/commands/field/options.d.ts.map +1 -0
  19. package/dist/commands/field/options.js +19 -0
  20. package/dist/commands/field/options.js.map +1 -0
  21. package/dist/commands/field/search.d.ts +3 -0
  22. package/dist/commands/field/search.d.ts.map +1 -0
  23. package/dist/commands/field/search.js +19 -0
  24. package/dist/commands/field/search.js.map +1 -0
  25. package/dist/commands/issue/attachments.d.ts +3 -0
  26. package/dist/commands/issue/attachments.d.ts.map +1 -0
  27. package/dist/commands/issue/attachments.js +53 -0
  28. package/dist/commands/issue/attachments.js.map +1 -0
  29. package/dist/commands/issue/batch-create.d.ts +3 -0
  30. package/dist/commands/issue/batch-create.d.ts.map +1 -0
  31. package/dist/commands/issue/batch-create.js +30 -0
  32. package/dist/commands/issue/batch-create.js.map +1 -0
  33. package/dist/commands/issue/changelog.d.ts +3 -0
  34. package/dist/commands/issue/changelog.d.ts.map +1 -0
  35. package/dist/commands/issue/changelog.js +20 -0
  36. package/dist/commands/issue/changelog.js.map +1 -0
  37. package/dist/commands/issue/comment-edit.d.ts +3 -0
  38. package/dist/commands/issue/comment-edit.d.ts.map +1 -0
  39. package/dist/commands/issue/comment-edit.js +21 -0
  40. package/dist/commands/issue/comment-edit.js.map +1 -0
  41. package/dist/commands/issue/comment.d.ts +3 -0
  42. package/dist/commands/issue/comment.d.ts.map +1 -0
  43. package/dist/commands/issue/comment.js +20 -0
  44. package/dist/commands/issue/comment.js.map +1 -0
  45. package/dist/commands/issue/create.d.ts +3 -0
  46. package/dist/commands/issue/create.d.ts.map +1 -0
  47. package/dist/commands/issue/create.js +30 -0
  48. package/dist/commands/issue/create.js.map +1 -0
  49. package/dist/commands/issue/delete.d.ts +3 -0
  50. package/dist/commands/issue/delete.d.ts.map +1 -0
  51. package/dist/commands/issue/delete.js +19 -0
  52. package/dist/commands/issue/delete.js.map +1 -0
  53. package/dist/commands/issue/get.d.ts +3 -0
  54. package/dist/commands/issue/get.d.ts.map +1 -0
  55. package/dist/commands/issue/get.js +23 -0
  56. package/dist/commands/issue/get.js.map +1 -0
  57. package/dist/commands/issue/index.d.ts +3 -0
  58. package/dist/commands/issue/index.d.ts.map +1 -0
  59. package/dist/commands/issue/index.js +32 -0
  60. package/dist/commands/issue/index.js.map +1 -0
  61. package/dist/commands/issue/link-epic.d.ts +3 -0
  62. package/dist/commands/issue/link-epic.d.ts.map +1 -0
  63. package/dist/commands/issue/link-epic.js +23 -0
  64. package/dist/commands/issue/link-epic.js.map +1 -0
  65. package/dist/commands/issue/search.d.ts +3 -0
  66. package/dist/commands/issue/search.d.ts.map +1 -0
  67. package/dist/commands/issue/search.js +25 -0
  68. package/dist/commands/issue/search.js.map +1 -0
  69. package/dist/commands/issue/transition.d.ts +3 -0
  70. package/dist/commands/issue/transition.d.ts.map +1 -0
  71. package/dist/commands/issue/transition.js +21 -0
  72. package/dist/commands/issue/transition.js.map +1 -0
  73. package/dist/commands/issue/transitions.d.ts +3 -0
  74. package/dist/commands/issue/transitions.d.ts.map +1 -0
  75. package/dist/commands/issue/transitions.js +19 -0
  76. package/dist/commands/issue/transitions.js.map +1 -0
  77. package/dist/commands/issue/update.d.ts +3 -0
  78. package/dist/commands/issue/update.d.ts.map +1 -0
  79. package/dist/commands/issue/update.js +21 -0
  80. package/dist/commands/issue/update.js.map +1 -0
  81. package/dist/commands/issue/worklog.d.ts +3 -0
  82. package/dist/commands/issue/worklog.d.ts.map +1 -0
  83. package/dist/commands/issue/worklog.js +25 -0
  84. package/dist/commands/issue/worklog.js.map +1 -0
  85. package/dist/commands/link/create.d.ts +3 -0
  86. package/dist/commands/link/create.d.ts.map +1 -0
  87. package/dist/commands/link/create.js +26 -0
  88. package/dist/commands/link/create.js.map +1 -0
  89. package/dist/commands/link/index.d.ts +3 -0
  90. package/dist/commands/link/index.d.ts.map +1 -0
  91. package/dist/commands/link/index.js +10 -0
  92. package/dist/commands/link/index.js.map +1 -0
  93. package/dist/commands/link/remove.d.ts +3 -0
  94. package/dist/commands/link/remove.d.ts.map +1 -0
  95. package/dist/commands/link/remove.js +19 -0
  96. package/dist/commands/link/remove.js.map +1 -0
  97. package/dist/commands/link/types.d.ts +3 -0
  98. package/dist/commands/link/types.d.ts.map +1 -0
  99. package/dist/commands/link/types.js +19 -0
  100. package/dist/commands/link/types.js.map +1 -0
  101. package/dist/commands/project/index.d.ts +3 -0
  102. package/dist/commands/project/index.d.ts.map +1 -0
  103. package/dist/commands/project/index.js +8 -0
  104. package/dist/commands/project/index.js.map +1 -0
  105. package/dist/commands/project/list.d.ts +3 -0
  106. package/dist/commands/project/list.d.ts.map +1 -0
  107. package/dist/commands/project/list.js +19 -0
  108. package/dist/commands/project/list.js.map +1 -0
  109. package/dist/commands/project/versions.d.ts +3 -0
  110. package/dist/commands/project/versions.d.ts.map +1 -0
  111. package/dist/commands/project/versions.js +19 -0
  112. package/dist/commands/project/versions.js.map +1 -0
  113. package/dist/commands/sprint/create.d.ts +3 -0
  114. package/dist/commands/sprint/create.d.ts.map +1 -0
  115. package/dist/commands/sprint/create.js +24 -0
  116. package/dist/commands/sprint/create.js.map +1 -0
  117. package/dist/commands/sprint/index.d.ts +3 -0
  118. package/dist/commands/sprint/index.d.ts.map +1 -0
  119. package/dist/commands/sprint/index.js +12 -0
  120. package/dist/commands/sprint/index.js.map +1 -0
  121. package/dist/commands/sprint/issues.d.ts +3 -0
  122. package/dist/commands/sprint/issues.d.ts.map +1 -0
  123. package/dist/commands/sprint/issues.js +23 -0
  124. package/dist/commands/sprint/issues.js.map +1 -0
  125. package/dist/commands/sprint/list.d.ts +3 -0
  126. package/dist/commands/sprint/list.d.ts.map +1 -0
  127. package/dist/commands/sprint/list.js +20 -0
  128. package/dist/commands/sprint/list.js.map +1 -0
  129. package/dist/commands/sprint/update.d.ts +3 -0
  130. package/dist/commands/sprint/update.d.ts.map +1 -0
  131. package/dist/commands/sprint/update.js +23 -0
  132. package/dist/commands/sprint/update.js.map +1 -0
  133. package/dist/commands/user/index.d.ts +3 -0
  134. package/dist/commands/user/index.d.ts.map +1 -0
  135. package/dist/commands/user/index.js +6 -0
  136. package/dist/commands/user/index.js.map +1 -0
  137. package/dist/commands/user/me.d.ts +3 -0
  138. package/dist/commands/user/me.d.ts.map +1 -0
  139. package/dist/commands/user/me.js +19 -0
  140. package/dist/commands/user/me.js.map +1 -0
  141. package/dist/index.d.ts +3 -0
  142. package/dist/index.d.ts.map +1 -0
  143. package/dist/index.js +21 -0
  144. package/dist/index.js.map +1 -0
  145. package/dist/utils/client.d.ts +3 -0
  146. package/dist/utils/client.d.ts.map +1 -0
  147. package/dist/utils/client.js +11 -0
  148. package/dist/utils/client.js.map +1 -0
  149. package/dist/utils/output.d.ts +3 -0
  150. package/dist/utils/output.d.ts.map +1 -0
  151. package/dist/utils/output.js +10 -0
  152. package/dist/utils/output.js.map +1 -0
  153. package/dist/utils/strip-response.d.ts +6 -0
  154. package/dist/utils/strip-response.d.ts.map +1 -0
  155. package/dist/utils/strip-response.js +29 -0
  156. package/dist/utils/strip-response.js.map +1 -0
  157. package/package.json +38 -0
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function registerBoardCommands(program: Command): void;
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/commands/board/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,OAAO,QAIrD"}
@@ -0,0 +1,8 @@
1
+ import { list } from './list.js';
2
+ import { issues } from './issues.js';
3
+ export function registerBoardCommands(program) {
4
+ const board = program.command('board').description('Board operations');
5
+ list(board);
6
+ issues(board);
7
+ }
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/commands/board/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAErC,MAAM,UAAU,qBAAqB,CAAC,OAAgB;IACpD,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,WAAW,CAAC,kBAAkB,CAAC,CAAC;IACvE,IAAI,CAAC,KAAK,CAAC,CAAC;IACZ,MAAM,CAAC,KAAK,CAAC,CAAC;AAChB,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function issues(parent: Command): void;
3
+ //# sourceMappingURL=issues.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"issues.d.ts","sourceRoot":"","sources":["../../../src/commands/board/issues.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,MAAM,CAAC,MAAM,EAAE,OAAO,QAkBrC"}
@@ -0,0 +1,23 @@
1
+ import { getClient } from '../../utils/client.js';
2
+ import { output, handleError } from '../../utils/output.js';
3
+ export function issues(parent) {
4
+ parent
5
+ .command('issues <id>')
6
+ .description('Get issues for a board')
7
+ .option('--max <number>', 'Max results', parseInt)
8
+ .addHelpText('after', '\nExamples:\n jiradc board issues 42\n jiradc board issues 42 --max 10')
9
+ .action(async (id, opts) => {
10
+ try {
11
+ const client = getClient();
12
+ const result = await client.agile.getBoardIssues({
13
+ boardId: parseInt(id, 10),
14
+ maxResults: opts.max,
15
+ });
16
+ output(result);
17
+ }
18
+ catch (err) {
19
+ handleError(err);
20
+ }
21
+ });
22
+ }
23
+ //# sourceMappingURL=issues.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"issues.js","sourceRoot":"","sources":["../../../src/commands/board/issues.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,UAAU,MAAM,CAAC,MAAe;IACpC,MAAM;SACH,OAAO,CAAC,aAAa,CAAC;SACtB,WAAW,CAAC,wBAAwB,CAAC;SACrC,MAAM,CAAC,gBAAgB,EAAE,aAAa,EAAE,QAAQ,CAAC;SACjD,WAAW,CAAC,OAAO,EAAE,0EAA0E,CAAC;SAChG,MAAM,CAAC,KAAK,EAAE,EAAU,EAAE,IAAsB,EAAE,EAAE;QACnD,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;YAC3B,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC;gBAC/C,OAAO,EAAE,QAAQ,CAAC,EAAE,EAAE,EAAE,CAAC;gBACzB,UAAU,EAAE,IAAI,CAAC,GAAG;aACrB,CAAC,CAAC;YACH,MAAM,CAAC,MAAM,CAAC,CAAC;QACjB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function list(parent: Command): void;
3
+ //# sourceMappingURL=list.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list.d.ts","sourceRoot":"","sources":["../../../src/commands/board/list.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,IAAI,CAAC,MAAM,EAAE,OAAO,QAenC"}
@@ -0,0 +1,20 @@
1
+ import { getClient } from '../../utils/client.js';
2
+ import { output, handleError } from '../../utils/output.js';
3
+ export function list(parent) {
4
+ parent
5
+ .command('list')
6
+ .description('List agile boards')
7
+ .option('--max <number>', 'Max results', parseInt)
8
+ .addHelpText('after', '\nExamples:\n jiradc board list\n jiradc board list --max 10')
9
+ .action(async (opts) => {
10
+ try {
11
+ const client = getClient();
12
+ const result = await client.agile.getBoards({ maxResults: opts.max });
13
+ output(result);
14
+ }
15
+ catch (err) {
16
+ handleError(err);
17
+ }
18
+ });
19
+ }
20
+ //# sourceMappingURL=list.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list.js","sourceRoot":"","sources":["../../../src/commands/board/list.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,UAAU,IAAI,CAAC,MAAe;IAClC,MAAM;SACH,OAAO,CAAC,MAAM,CAAC;SACf,WAAW,CAAC,mBAAmB,CAAC;SAChC,MAAM,CAAC,gBAAgB,EAAE,aAAa,EAAE,QAAQ,CAAC;SACjD,WAAW,CAAC,OAAO,EAAE,gEAAgE,CAAC;SACtF,MAAM,CAAC,KAAK,EAAE,IAAsB,EAAE,EAAE;QACvC,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;YAC3B,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;YACtE,MAAM,CAAC,MAAM,CAAC,CAAC;QACjB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function registerFieldCommands(program: Command): void;
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/commands/field/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,OAAO,QAIrD"}
@@ -0,0 +1,8 @@
1
+ import { search } from './search.js';
2
+ import { options } from './options.js';
3
+ export function registerFieldCommands(program) {
4
+ const field = program.command('field').description('Field operations');
5
+ search(field);
6
+ options(field);
7
+ }
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/commands/field/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAEvC,MAAM,UAAU,qBAAqB,CAAC,OAAgB;IACpD,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,WAAW,CAAC,kBAAkB,CAAC,CAAC;IACvE,MAAM,CAAC,KAAK,CAAC,CAAC;IACd,OAAO,CAAC,KAAK,CAAC,CAAC;AACjB,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function options(parent: Command): void;
3
+ //# sourceMappingURL=options.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"options.d.ts","sourceRoot":"","sources":["../../../src/commands/field/options.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,OAAO,CAAC,MAAM,EAAE,OAAO,QActC"}
@@ -0,0 +1,19 @@
1
+ import { getClient } from '../../utils/client.js';
2
+ import { output, handleError } from '../../utils/output.js';
3
+ export function options(parent) {
4
+ parent
5
+ .command('options <id>')
6
+ .description('Get available options for a custom field')
7
+ .addHelpText('after', '\nExamples:\n jiradc field options 10001')
8
+ .action(async (id) => {
9
+ try {
10
+ const client = getClient();
11
+ const result = await client.fields.getFieldOptions({ fieldId: id });
12
+ output(result);
13
+ }
14
+ catch (err) {
15
+ handleError(err);
16
+ }
17
+ });
18
+ }
19
+ //# sourceMappingURL=options.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"options.js","sourceRoot":"","sources":["../../../src/commands/field/options.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,UAAU,OAAO,CAAC,MAAe;IACrC,MAAM;SACH,OAAO,CAAC,cAAc,CAAC;SACvB,WAAW,CAAC,0CAA0C,CAAC;SACvD,WAAW,CAAC,OAAO,EAAE,2CAA2C,CAAC;SACjE,MAAM,CAAC,KAAK,EAAE,EAAU,EAAE,EAAE;QAC3B,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;YAC3B,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,CAAC;YACpE,MAAM,CAAC,MAAM,CAAC,CAAC;QACjB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function search(parent: Command): void;
3
+ //# sourceMappingURL=search.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search.d.ts","sourceRoot":"","sources":["../../../src/commands/field/search.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,MAAM,CAAC,MAAM,EAAE,OAAO,QAcrC"}
@@ -0,0 +1,19 @@
1
+ import { getClient } from '../../utils/client.js';
2
+ import { output, handleError } from '../../utils/output.js';
3
+ export function search(parent) {
4
+ parent
5
+ .command('search <keyword>')
6
+ .description('Search for fields by name or ID')
7
+ .addHelpText('after', '\nExamples:\n jiradc field search epic\n jiradc field search customfield_10100')
8
+ .action(async (keyword) => {
9
+ try {
10
+ const client = getClient();
11
+ const result = await client.fields.search(keyword);
12
+ output(result);
13
+ }
14
+ catch (err) {
15
+ handleError(err);
16
+ }
17
+ });
18
+ }
19
+ //# sourceMappingURL=search.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search.js","sourceRoot":"","sources":["../../../src/commands/field/search.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,UAAU,MAAM,CAAC,MAAe;IACpC,MAAM;SACH,OAAO,CAAC,kBAAkB,CAAC;SAC3B,WAAW,CAAC,iCAAiC,CAAC;SAC9C,WAAW,CAAC,OAAO,EAAE,kFAAkF,CAAC;SACxG,MAAM,CAAC,KAAK,EAAE,OAAe,EAAE,EAAE;QAChC,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;YAC3B,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;YACnD,MAAM,CAAC,MAAM,CAAC,CAAC;QACjB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function attachments(parent: Command): void;
3
+ //# sourceMappingURL=attachments.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"attachments.d.ts","sourceRoot":"","sources":["../../../src/commands/issue/attachments.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,WAAW,CAAC,MAAM,EAAE,OAAO,QAkD1C"}
@@ -0,0 +1,53 @@
1
+ import { mkdirSync } from 'fs';
2
+ import { join } from 'path';
3
+ import { getClient } from '../../utils/client.js';
4
+ import { output, handleError } from '../../utils/output.js';
5
+ export function attachments(parent) {
6
+ parent
7
+ .command('attachments <key>')
8
+ .description('Download all attachments from an issue')
9
+ .requiredOption('--output <dir>', 'Local directory to save attachments into')
10
+ .addHelpText('after', '\nExamples:\n jiradc issue attachments AI-73 --output ./downloads')
11
+ .action(async (key, opts) => {
12
+ try {
13
+ const client = getClient();
14
+ mkdirSync(opts.output, { recursive: true });
15
+ const issue = await client.issues.get({
16
+ issueKeyOrId: key,
17
+ fields: ['attachment'],
18
+ });
19
+ const atts = issue.fields.attachment ?? [];
20
+ if (atts.length === 0) {
21
+ output({ issueKey: key, downloaded: 0, files: [] });
22
+ return;
23
+ }
24
+ const results = [];
25
+ const failed = [];
26
+ for (const att of atts) {
27
+ if (!att.content) {
28
+ failed.push({ filename: att.filename, error: 'No content URL' });
29
+ continue;
30
+ }
31
+ const destPath = join(opts.output, att.filename);
32
+ try {
33
+ await client.issues.downloadAttachment({ url: att.content, destinationPath: destPath });
34
+ results.push({ filename: att.filename, size: att.size, path: destPath });
35
+ }
36
+ catch (err) {
37
+ failed.push({ filename: att.filename, error: String(err) });
38
+ }
39
+ }
40
+ output({
41
+ issueKey: key,
42
+ downloaded: results.length,
43
+ total: atts.length,
44
+ files: results,
45
+ ...(failed.length > 0 && { failed }),
46
+ });
47
+ }
48
+ catch (err) {
49
+ handleError(err);
50
+ }
51
+ });
52
+ }
53
+ //# sourceMappingURL=attachments.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"attachments.js","sourceRoot":"","sources":["../../../src/commands/issue/attachments.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,IAAI,CAAC;AAC/B,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAE5B,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,UAAU,WAAW,CAAC,MAAe;IACzC,MAAM;SACH,OAAO,CAAC,mBAAmB,CAAC;SAC5B,WAAW,CAAC,wCAAwC,CAAC;SACrD,cAAc,CAAC,gBAAgB,EAAE,0CAA0C,CAAC;SAC5E,WAAW,CAAC,OAAO,EAAE,oEAAoE,CAAC;SAC1F,MAAM,CAAC,KAAK,EAAE,GAAW,EAAE,IAAwB,EAAE,EAAE;QACtD,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;YAC3B,SAAS,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;YAE5C,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC;gBACpC,YAAY,EAAE,GAAG;gBACjB,MAAM,EAAE,CAAC,YAAY,CAAC;aACvB,CAAC,CAAC;YAEH,MAAM,IAAI,GAAG,KAAK,CAAC,MAAM,CAAC,UAAU,IAAI,EAAE,CAAC;YAC3C,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACtB,MAAM,CAAC,EAAE,QAAQ,EAAE,GAAG,EAAE,UAAU,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;gBACpD,OAAO;YACT,CAAC;YAED,MAAM,OAAO,GAAuD,EAAE,CAAC;YACvE,MAAM,MAAM,GAA0C,EAAE,CAAC;YAEzD,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;gBACvB,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;oBACjB,MAAM,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,GAAG,CAAC,QAAQ,EAAE,KAAK,EAAE,gBAAgB,EAAE,CAAC,CAAC;oBACjE,SAAS;gBACX,CAAC;gBACD,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ,CAAC,CAAC;gBACjD,IAAI,CAAC;oBACH,MAAM,MAAM,CAAC,MAAM,CAAC,kBAAkB,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,CAAC,CAAC;oBACxF,OAAO,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,GAAG,CAAC,QAAQ,EAAE,IAAI,EAAE,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC;gBAC3E,CAAC;gBAAC,OAAO,GAAG,EAAE,CAAC;oBACb,MAAM,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,GAAG,CAAC,QAAQ,EAAE,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBAC9D,CAAC;YACH,CAAC;YAED,MAAM,CAAC;gBACL,QAAQ,EAAE,GAAG;gBACb,UAAU,EAAE,OAAO,CAAC,MAAM;gBAC1B,KAAK,EAAE,IAAI,CAAC,MAAM;gBAClB,KAAK,EAAE,OAAO;gBACd,GAAG,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,CAAC;aACrC,CAAC,CAAC;QACL,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function batchCreate(parent: Command): void;
3
+ //# sourceMappingURL=batch-create.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"batch-create.d.ts","sourceRoot":"","sources":["../../../src/commands/issue/batch-create.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,WAAW,CAAC,MAAM,EAAE,OAAO,QAsC1C"}
@@ -0,0 +1,30 @@
1
+ import { getClient } from '../../utils/client.js';
2
+ import { output, handleError } from '../../utils/output.js';
3
+ export function batchCreate(parent) {
4
+ parent
5
+ .command('batch-create')
6
+ .description('Create multiple issues from a JSON array')
7
+ .requiredOption('--issues <json>', 'JSON array of issue objects')
8
+ .addHelpText('after', `\nExamples:\n jiradc issue batch-create --issues '[{"projectKeyOrId":"AI","issueTypeName":"Task","summary":"Task 1"},{"projectKeyOrId":"AI","issueTypeName":"Task","summary":"Task 2"}]'`)
9
+ .action(async (opts) => {
10
+ try {
11
+ const client = getClient();
12
+ const parsed = JSON.parse(opts.issues);
13
+ const results = [];
14
+ for (const issue of parsed) {
15
+ try {
16
+ const result = await client.issues.create(issue);
17
+ results.push({ key: result.key });
18
+ }
19
+ catch (error) {
20
+ results.push({ error: error instanceof Error ? error.message : 'Unknown error' });
21
+ }
22
+ }
23
+ output(results);
24
+ }
25
+ catch (err) {
26
+ handleError(err);
27
+ }
28
+ });
29
+ }
30
+ //# sourceMappingURL=batch-create.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"batch-create.js","sourceRoot":"","sources":["../../../src/commands/issue/batch-create.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,UAAU,WAAW,CAAC,MAAe;IACzC,MAAM;SACH,OAAO,CAAC,cAAc,CAAC;SACvB,WAAW,CAAC,0CAA0C,CAAC;SACvD,cAAc,CAAC,iBAAiB,EAAE,6BAA6B,CAAC;SAChE,WAAW,CACV,OAAO,EACP,2LAA2L,CAC5L;SACA,MAAM,CAAC,KAAK,EAAE,IAAwB,EAAE,EAAE;QACzC,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;YAC3B,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CASlC,CAAC;YAEJ,MAAM,OAAO,GAAuC,EAAE,CAAC;YACvD,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;gBAC3B,IAAI,CAAC;oBACH,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;oBACjD,OAAO,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC;gBACpC,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBACf,OAAO,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,EAAE,CAAC,CAAC;gBACpF,CAAC;YACH,CAAC;YAED,MAAM,CAAC,OAAO,CAAC,CAAC;QAClB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function changelog(parent: Command): void;
3
+ //# sourceMappingURL=changelog.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"changelog.d.ts","sourceRoot":"","sources":["../../../src/commands/issue/changelog.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,SAAS,CAAC,MAAM,EAAE,OAAO,QAexC"}
@@ -0,0 +1,20 @@
1
+ import { getClient } from '../../utils/client.js';
2
+ import { output, handleError } from '../../utils/output.js';
3
+ export function changelog(parent) {
4
+ parent
5
+ .command('changelog <key>')
6
+ .description('Get changelog for an issue')
7
+ .option('--max <number>', 'Max changelog entries (default: 50)', parseInt)
8
+ .addHelpText('after', '\nExamples:\n jiradc issue changelog AI-73\n jiradc issue changelog AI-73 --max 10')
9
+ .action(async (key, opts) => {
10
+ try {
11
+ const client = getClient();
12
+ const result = await client.issues.getChangelog({ issueKeyOrId: key, maxResults: opts.max });
13
+ output(result);
14
+ }
15
+ catch (err) {
16
+ handleError(err);
17
+ }
18
+ });
19
+ }
20
+ //# sourceMappingURL=changelog.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"changelog.js","sourceRoot":"","sources":["../../../src/commands/issue/changelog.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,UAAU,SAAS,CAAC,MAAe;IACvC,MAAM;SACH,OAAO,CAAC,iBAAiB,CAAC;SAC1B,WAAW,CAAC,4BAA4B,CAAC;SACzC,MAAM,CAAC,gBAAgB,EAAE,qCAAqC,EAAE,QAAQ,CAAC;SACzE,WAAW,CAAC,OAAO,EAAE,sFAAsF,CAAC;SAC5G,MAAM,CAAC,KAAK,EAAE,GAAW,EAAE,IAAsB,EAAE,EAAE;QACpD,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;YAC3B,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE,YAAY,EAAE,GAAG,EAAE,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;YAC7F,MAAM,CAAC,MAAM,CAAC,CAAC;QACjB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function commentEdit(parent: Command): void;
3
+ //# sourceMappingURL=comment-edit.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"comment-edit.d.ts","sourceRoot":"","sources":["../../../src/commands/issue/comment-edit.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,WAAW,CAAC,MAAM,EAAE,OAAO,QAgB1C"}
@@ -0,0 +1,21 @@
1
+ import { getClient } from '../../utils/client.js';
2
+ import { output, handleError } from '../../utils/output.js';
3
+ export function commentEdit(parent) {
4
+ parent
5
+ .command('comment-edit <key>')
6
+ .description('Edit an existing comment')
7
+ .requiredOption('--id <commentId>', 'Comment ID to edit')
8
+ .requiredOption('--body <text>', 'Updated comment body in wiki markup')
9
+ .addHelpText('after', '\nExamples:\n jiradc issue comment-edit AI-73 --id 12345 --body "Updated comment text"')
10
+ .action(async (key, opts) => {
11
+ try {
12
+ const client = getClient();
13
+ const result = await client.issues.editComment({ issueKeyOrId: key, commentId: opts.id, body: opts.body });
14
+ output(result);
15
+ }
16
+ catch (err) {
17
+ handleError(err);
18
+ }
19
+ });
20
+ }
21
+ //# sourceMappingURL=comment-edit.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"comment-edit.js","sourceRoot":"","sources":["../../../src/commands/issue/comment-edit.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,UAAU,WAAW,CAAC,MAAe;IACzC,MAAM;SACH,OAAO,CAAC,oBAAoB,CAAC;SAC7B,WAAW,CAAC,0BAA0B,CAAC;SACvC,cAAc,CAAC,kBAAkB,EAAE,oBAAoB,CAAC;SACxD,cAAc,CAAC,eAAe,EAAE,qCAAqC,CAAC;SACtE,WAAW,CAAC,OAAO,EAAE,yFAAyF,CAAC;SAC/G,MAAM,CAAC,KAAK,EAAE,GAAW,EAAE,IAAkC,EAAE,EAAE;QAChE,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;YAC3B,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,YAAY,EAAE,GAAG,EAAE,SAAS,EAAE,IAAI,CAAC,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;YAC3G,MAAM,CAAC,MAAM,CAAC,CAAC;QACjB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function comment(parent: Command): void;
3
+ //# sourceMappingURL=comment.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"comment.d.ts","sourceRoot":"","sources":["../../../src/commands/issue/comment.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,OAAO,CAAC,MAAM,EAAE,OAAO,QAetC"}
@@ -0,0 +1,20 @@
1
+ import { getClient } from '../../utils/client.js';
2
+ import { output, handleError } from '../../utils/output.js';
3
+ export function comment(parent) {
4
+ parent
5
+ .command('comment <key>')
6
+ .description('Add a comment to an issue')
7
+ .requiredOption('--body <text>', 'Comment body in wiki markup')
8
+ .addHelpText('after', '\nExamples:\n jiradc issue comment AI-73 --body "Fixed in latest build"')
9
+ .action(async (key, opts) => {
10
+ try {
11
+ const client = getClient();
12
+ const result = await client.issues.addComment({ issueKeyOrId: key, body: opts.body });
13
+ output(result);
14
+ }
15
+ catch (err) {
16
+ handleError(err);
17
+ }
18
+ });
19
+ }
20
+ //# sourceMappingURL=comment.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"comment.js","sourceRoot":"","sources":["../../../src/commands/issue/comment.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,UAAU,OAAO,CAAC,MAAe;IACrC,MAAM;SACH,OAAO,CAAC,eAAe,CAAC;SACxB,WAAW,CAAC,2BAA2B,CAAC;SACxC,cAAc,CAAC,eAAe,EAAE,6BAA6B,CAAC;SAC9D,WAAW,CAAC,OAAO,EAAE,0EAA0E,CAAC;SAChG,MAAM,CAAC,KAAK,EAAE,GAAW,EAAE,IAAsB,EAAE,EAAE;QACpD,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;YAC3B,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,EAAE,YAAY,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;YACtF,MAAM,CAAC,MAAM,CAAC,CAAC;QACjB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function create(parent: Command): void;
3
+ //# sourceMappingURL=create.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create.d.ts","sourceRoot":"","sources":["../../../src/commands/issue/create.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,MAAM,CAAC,MAAM,EAAE,OAAO,QA4BrC"}
@@ -0,0 +1,30 @@
1
+ import { getClient } from '../../utils/client.js';
2
+ import { output, handleError } from '../../utils/output.js';
3
+ export function create(parent) {
4
+ parent
5
+ .command('create')
6
+ .description('Create a new issue')
7
+ .requiredOption('--project <key>', 'Project key or ID')
8
+ .requiredOption('--type <name>', 'Issue type name (e.g., Task, Bug, Story)')
9
+ .requiredOption('--summary <text>', 'Issue summary/title')
10
+ .option('--description <text>', 'Issue description')
11
+ .option('--assignee <username>', 'Assignee username')
12
+ .addHelpText('after', '\nExamples:\n jiradc issue create --project AI --type Task --summary "Fix login bug"\n jiradc issue create --project AI --type Story --summary "New feature" --assignee jsmith')
13
+ .action(async (opts) => {
14
+ try {
15
+ const client = getClient();
16
+ const result = await client.issues.create({
17
+ projectKeyOrId: opts.project,
18
+ issueTypeName: opts.type,
19
+ summary: opts.summary,
20
+ description: opts.description,
21
+ assignee: opts.assignee,
22
+ });
23
+ output(result);
24
+ }
25
+ catch (err) {
26
+ handleError(err);
27
+ }
28
+ });
29
+ }
30
+ //# sourceMappingURL=create.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create.js","sourceRoot":"","sources":["../../../src/commands/issue/create.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,UAAU,MAAM,CAAC,MAAe;IACpC,MAAM;SACH,OAAO,CAAC,QAAQ,CAAC;SACjB,WAAW,CAAC,oBAAoB,CAAC;SACjC,cAAc,CAAC,iBAAiB,EAAE,mBAAmB,CAAC;SACtD,cAAc,CAAC,eAAe,EAAE,0CAA0C,CAAC;SAC3E,cAAc,CAAC,kBAAkB,EAAE,qBAAqB,CAAC;SACzD,MAAM,CAAC,sBAAsB,EAAE,mBAAmB,CAAC;SACnD,MAAM,CAAC,uBAAuB,EAAE,mBAAmB,CAAC;SACpD,WAAW,CACV,OAAO,EACP,kLAAkL,CACnL;SACA,MAAM,CAAC,KAAK,EAAE,IAAiG,EAAE,EAAE;QAClH,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;YAC3B,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC;gBACxC,cAAc,EAAE,IAAI,CAAC,OAAO;gBAC5B,aAAa,EAAE,IAAI,CAAC,IAAI;gBACxB,OAAO,EAAE,IAAI,CAAC,OAAO;gBACrB,WAAW,EAAE,IAAI,CAAC,WAAW;gBAC7B,QAAQ,EAAE,IAAI,CAAC,QAAQ;aACxB,CAAC,CAAC;YACH,MAAM,CAAC,MAAM,CAAC,CAAC;QACjB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function deleteIssue(parent: Command): void;
3
+ //# sourceMappingURL=delete.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"delete.d.ts","sourceRoot":"","sources":["../../../src/commands/issue/delete.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,WAAW,CAAC,MAAM,EAAE,OAAO,QAc1C"}
@@ -0,0 +1,19 @@
1
+ import { getClient } from '../../utils/client.js';
2
+ import { output, handleError } from '../../utils/output.js';
3
+ export function deleteIssue(parent) {
4
+ parent
5
+ .command('delete <key>')
6
+ .description('Delete an issue')
7
+ .addHelpText('after', '\nExamples:\n jiradc issue delete AI-73')
8
+ .action(async (key) => {
9
+ try {
10
+ const client = getClient();
11
+ await client.issues.delete({ issueKeyOrId: key });
12
+ output({ deleted: true, issueKey: key });
13
+ }
14
+ catch (err) {
15
+ handleError(err);
16
+ }
17
+ });
18
+ }
19
+ //# sourceMappingURL=delete.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"delete.js","sourceRoot":"","sources":["../../../src/commands/issue/delete.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,UAAU,WAAW,CAAC,MAAe;IACzC,MAAM;SACH,OAAO,CAAC,cAAc,CAAC;SACvB,WAAW,CAAC,iBAAiB,CAAC;SAC9B,WAAW,CAAC,OAAO,EAAE,0CAA0C,CAAC;SAChE,MAAM,CAAC,KAAK,EAAE,GAAW,EAAE,EAAE;QAC5B,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;YAC3B,MAAM,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,YAAY,EAAE,GAAG,EAAE,CAAC,CAAC;YAClD,MAAM,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,CAAC;QAC3C,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function get(parent: Command): void;
3
+ //# sourceMappingURL=get.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get.d.ts","sourceRoot":"","sources":["../../../src/commands/issue/get.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,GAAG,CAAC,MAAM,EAAE,OAAO,QAkBlC"}
@@ -0,0 +1,23 @@
1
+ import { getClient } from '../../utils/client.js';
2
+ import { output, handleError } from '../../utils/output.js';
3
+ export function get(parent) {
4
+ parent
5
+ .command('get <key>')
6
+ .description('Get issue details')
7
+ .option('--fields <fields>', 'Comma-separated fields to return')
8
+ .addHelpText('after', '\nExamples:\n jiradc issue get AI-73\n jiradc issue get AI-73 --fields summary,status,assignee')
9
+ .action(async (key, opts) => {
10
+ try {
11
+ const client = getClient();
12
+ const result = await client.issues.get({
13
+ issueKeyOrId: key,
14
+ fields: opts.fields?.split(',').map((f) => f.trim()),
15
+ });
16
+ output(result);
17
+ }
18
+ catch (err) {
19
+ handleError(err);
20
+ }
21
+ });
22
+ }
23
+ //# sourceMappingURL=get.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get.js","sourceRoot":"","sources":["../../../src/commands/issue/get.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,UAAU,GAAG,CAAC,MAAe;IACjC,MAAM;SACH,OAAO,CAAC,WAAW,CAAC;SACpB,WAAW,CAAC,mBAAmB,CAAC;SAChC,MAAM,CAAC,mBAAmB,EAAE,kCAAkC,CAAC;SAC/D,WAAW,CAAC,OAAO,EAAE,kGAAkG,CAAC;SACxH,MAAM,CAAC,KAAK,EAAE,GAAW,EAAE,IAAyB,EAAE,EAAE;QACvD,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;YAC3B,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC;gBACrC,YAAY,EAAE,GAAG;gBACjB,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;aACrD,CAAC,CAAC;YACH,MAAM,CAAC,MAAM,CAAC,CAAC;QACjB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function registerIssueCommands(program: Command): void;
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/commands/issue/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAgBpC,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,OAAO,QAgBrD"}
@@ -0,0 +1,32 @@
1
+ import { get } from './get.js';
2
+ import { search } from './search.js';
3
+ import { create } from './create.js';
4
+ import { update } from './update.js';
5
+ import { deleteIssue } from './delete.js';
6
+ import { transition } from './transition.js';
7
+ import { transitions } from './transitions.js';
8
+ import { comment } from './comment.js';
9
+ import { commentEdit } from './comment-edit.js';
10
+ import { worklog } from './worklog.js';
11
+ import { changelog } from './changelog.js';
12
+ import { linkEpic } from './link-epic.js';
13
+ import { attachments } from './attachments.js';
14
+ import { batchCreate } from './batch-create.js';
15
+ export function registerIssueCommands(program) {
16
+ const issue = program.command('issue').description('Issue operations');
17
+ get(issue);
18
+ search(issue);
19
+ create(issue);
20
+ update(issue);
21
+ deleteIssue(issue);
22
+ transition(issue);
23
+ transitions(issue);
24
+ comment(issue);
25
+ commentEdit(issue);
26
+ worklog(issue);
27
+ changelog(issue);
28
+ linkEpic(issue);
29
+ attachments(issue);
30
+ batchCreate(issue);
31
+ }
32
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/commands/issue/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,MAAM,UAAU,qBAAqB,CAAC,OAAgB;IACpD,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,WAAW,CAAC,kBAAkB,CAAC,CAAC;IACvE,GAAG,CAAC,KAAK,CAAC,CAAC;IACX,MAAM,CAAC,KAAK,CAAC,CAAC;IACd,MAAM,CAAC,KAAK,CAAC,CAAC;IACd,MAAM,CAAC,KAAK,CAAC,CAAC;IACd,WAAW,CAAC,KAAK,CAAC,CAAC;IACnB,UAAU,CAAC,KAAK,CAAC,CAAC;IAClB,WAAW,CAAC,KAAK,CAAC,CAAC;IACnB,OAAO,CAAC,KAAK,CAAC,CAAC;IACf,WAAW,CAAC,KAAK,CAAC,CAAC;IACnB,OAAO,CAAC,KAAK,CAAC,CAAC;IACf,SAAS,CAAC,KAAK,CAAC,CAAC;IACjB,QAAQ,CAAC,KAAK,CAAC,CAAC;IAChB,WAAW,CAAC,KAAK,CAAC,CAAC;IACnB,WAAW,CAAC,KAAK,CAAC,CAAC;AACrB,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function linkEpic(parent: Command): void;
3
+ //# sourceMappingURL=link-epic.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"link-epic.d.ts","sourceRoot":"","sources":["../../../src/commands/issue/link-epic.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,QAAQ,CAAC,MAAM,EAAE,OAAO,QAkBvC"}
@@ -0,0 +1,23 @@
1
+ import { getClient } from '../../utils/client.js';
2
+ import { output, handleError } from '../../utils/output.js';
3
+ export function linkEpic(parent) {
4
+ parent
5
+ .command('link-epic <key>')
6
+ .description('Link an issue to an epic')
7
+ .requiredOption('--epic <epicKey>', 'Epic issue key')
8
+ .addHelpText('after', '\nExamples:\n jiradc issue link-epic AI-100 --epic AI-73')
9
+ .action(async (key, opts) => {
10
+ try {
11
+ const client = getClient();
12
+ await client.issues.update({
13
+ issueKeyOrId: key,
14
+ fields: { customfield_10100: opts.epic },
15
+ });
16
+ output({ linked: true, issue: key, epic: opts.epic });
17
+ }
18
+ catch (err) {
19
+ handleError(err);
20
+ }
21
+ });
22
+ }
23
+ //# sourceMappingURL=link-epic.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"link-epic.js","sourceRoot":"","sources":["../../../src/commands/issue/link-epic.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,UAAU,QAAQ,CAAC,MAAe;IACtC,MAAM;SACH,OAAO,CAAC,iBAAiB,CAAC;SAC1B,WAAW,CAAC,0BAA0B,CAAC;SACvC,cAAc,CAAC,kBAAkB,EAAE,gBAAgB,CAAC;SACpD,WAAW,CAAC,OAAO,EAAE,2DAA2D,CAAC;SACjF,MAAM,CAAC,KAAK,EAAE,GAAW,EAAE,IAAsB,EAAE,EAAE;QACpD,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;YAC3B,MAAM,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC;gBACzB,YAAY,EAAE,GAAG;gBACjB,MAAM,EAAE,EAAE,iBAAiB,EAAE,IAAI,CAAC,IAAI,EAAE;aACzC,CAAC,CAAC;YACH,MAAM,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QACxD,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}