@chief-clancy/core 0.1.0
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/LICENSE +21 -0
- package/README.md +50 -0
- package/dist/board/azdo/api/api.d.ts +95 -0
- package/dist/board/azdo/api/api.d.ts.map +1 -0
- package/dist/board/azdo/api/api.js +173 -0
- package/dist/board/azdo/api/api.js.map +1 -0
- package/dist/board/azdo/api/helpers.d.ts +89 -0
- package/dist/board/azdo/api/helpers.d.ts.map +1 -0
- package/dist/board/azdo/api/helpers.js +133 -0
- package/dist/board/azdo/api/helpers.js.map +1 -0
- package/dist/board/azdo/api/index.d.ts +5 -0
- package/dist/board/azdo/api/index.d.ts.map +1 -0
- package/dist/board/azdo/api/index.js +3 -0
- package/dist/board/azdo/api/index.js.map +1 -0
- package/dist/board/azdo/azdo-board.d.ts +12 -0
- package/dist/board/azdo/azdo-board.d.ts.map +1 -0
- package/dist/board/azdo/azdo-board.js +104 -0
- package/dist/board/azdo/azdo-board.js.map +1 -0
- package/dist/board/azdo/index.d.ts +3 -0
- package/dist/board/azdo/index.d.ts.map +1 -0
- package/dist/board/azdo/index.js +3 -0
- package/dist/board/azdo/index.js.map +1 -0
- package/dist/board/azdo/labels/index.d.ts +2 -0
- package/dist/board/azdo/labels/index.d.ts.map +1 -0
- package/dist/board/azdo/labels/index.js +2 -0
- package/dist/board/azdo/labels/index.js.map +1 -0
- package/dist/board/azdo/labels/labels.d.ts +27 -0
- package/dist/board/azdo/labels/labels.d.ts.map +1 -0
- package/dist/board/azdo/labels/labels.js +64 -0
- package/dist/board/azdo/labels/labels.js.map +1 -0
- package/dist/board/azdo/relations/index.d.ts +2 -0
- package/dist/board/azdo/relations/index.d.ts.map +1 -0
- package/dist/board/azdo/relations/index.js +2 -0
- package/dist/board/azdo/relations/index.js.map +1 -0
- package/dist/board/azdo/relations/relations.d.ts +37 -0
- package/dist/board/azdo/relations/relations.d.ts.map +1 -0
- package/dist/board/azdo/relations/relations.js +109 -0
- package/dist/board/azdo/relations/relations.js.map +1 -0
- package/dist/board/detect-board.d.ts +28 -0
- package/dist/board/detect-board.d.ts.map +1 -0
- package/dist/board/detect-board.js +80 -0
- package/dist/board/detect-board.js.map +1 -0
- package/dist/board/factory/factory.d.ts +18 -0
- package/dist/board/factory/factory.d.ts.map +1 -0
- package/dist/board/factory/factory.js +34 -0
- package/dist/board/factory/factory.js.map +1 -0
- package/dist/board/factory/index.d.ts +2 -0
- package/dist/board/factory/index.d.ts.map +1 -0
- package/dist/board/factory/index.js +2 -0
- package/dist/board/factory/index.js.map +1 -0
- package/dist/board/github/api/api.d.ts +86 -0
- package/dist/board/github/api/api.d.ts.map +1 -0
- package/dist/board/github/api/api.js +161 -0
- package/dist/board/github/api/api.js.map +1 -0
- package/dist/board/github/api/index.d.ts +3 -0
- package/dist/board/github/api/index.d.ts.map +1 -0
- package/dist/board/github/api/index.js +2 -0
- package/dist/board/github/api/index.js.map +1 -0
- package/dist/board/github/github-board.d.ts +19 -0
- package/dist/board/github/github-board.d.ts.map +1 -0
- package/dist/board/github/github-board.js +104 -0
- package/dist/board/github/github-board.js.map +1 -0
- package/dist/board/github/index.d.ts +3 -0
- package/dist/board/github/index.d.ts.map +1 -0
- package/dist/board/github/index.js +3 -0
- package/dist/board/github/index.js.map +1 -0
- package/dist/board/github/labels/index.d.ts +2 -0
- package/dist/board/github/labels/index.d.ts.map +1 -0
- package/dist/board/github/labels/index.js +2 -0
- package/dist/board/github/labels/index.js.map +1 -0
- package/dist/board/github/labels/labels.d.ts +42 -0
- package/dist/board/github/labels/labels.d.ts.map +1 -0
- package/dist/board/github/labels/labels.js +93 -0
- package/dist/board/github/labels/labels.js.map +1 -0
- package/dist/board/github/relations/index.d.ts +2 -0
- package/dist/board/github/relations/index.d.ts.map +1 -0
- package/dist/board/github/relations/index.js +2 -0
- package/dist/board/github/relations/index.js.map +1 -0
- package/dist/board/github/relations/relations.d.ts +54 -0
- package/dist/board/github/relations/relations.d.ts.map +1 -0
- package/dist/board/github/relations/relations.js +152 -0
- package/dist/board/github/relations/relations.js.map +1 -0
- package/dist/board/index.d.ts +2 -0
- package/dist/board/index.d.ts.map +1 -0
- package/dist/board/index.js +2 -0
- package/dist/board/index.js.map +1 -0
- package/dist/board/jira/api/api.d.ts +129 -0
- package/dist/board/jira/api/api.d.ts.map +1 -0
- package/dist/board/jira/api/api.js +207 -0
- package/dist/board/jira/api/api.js.map +1 -0
- package/dist/board/jira/api/index.d.ts +3 -0
- package/dist/board/jira/api/index.d.ts.map +1 -0
- package/dist/board/jira/api/index.js +2 -0
- package/dist/board/jira/api/index.js.map +1 -0
- package/dist/board/jira/index.d.ts +3 -0
- package/dist/board/jira/index.d.ts.map +1 -0
- package/dist/board/jira/index.js +3 -0
- package/dist/board/jira/index.js.map +1 -0
- package/dist/board/jira/jira-board.d.ts +12 -0
- package/dist/board/jira/jira-board.d.ts.map +1 -0
- package/dist/board/jira/jira-board.js +112 -0
- package/dist/board/jira/jira-board.js.map +1 -0
- package/dist/board/jira/labels/index.d.ts +2 -0
- package/dist/board/jira/labels/index.d.ts.map +1 -0
- package/dist/board/jira/labels/index.js +2 -0
- package/dist/board/jira/labels/index.js.map +1 -0
- package/dist/board/jira/labels/labels.d.ts +34 -0
- package/dist/board/jira/labels/labels.d.ts.map +1 -0
- package/dist/board/jira/labels/labels.js +69 -0
- package/dist/board/jira/labels/labels.js.map +1 -0
- package/dist/board/jira/relations/index.d.ts +2 -0
- package/dist/board/jira/relations/index.d.ts.map +1 -0
- package/dist/board/jira/relations/index.js +2 -0
- package/dist/board/jira/relations/index.js.map +1 -0
- package/dist/board/jira/relations/relations.d.ts +44 -0
- package/dist/board/jira/relations/relations.d.ts.map +1 -0
- package/dist/board/jira/relations/relations.js +111 -0
- package/dist/board/jira/relations/relations.js.map +1 -0
- package/dist/board/linear/api/api.d.ts +68 -0
- package/dist/board/linear/api/api.d.ts.map +1 -0
- package/dist/board/linear/api/api.js +179 -0
- package/dist/board/linear/api/api.js.map +1 -0
- package/dist/board/linear/api/index.d.ts +2 -0
- package/dist/board/linear/api/index.d.ts.map +1 -0
- package/dist/board/linear/api/index.js +2 -0
- package/dist/board/linear/api/index.js.map +1 -0
- package/dist/board/linear/index.d.ts +3 -0
- package/dist/board/linear/index.d.ts.map +1 -0
- package/dist/board/linear/index.js +3 -0
- package/dist/board/linear/index.js.map +1 -0
- package/dist/board/linear/labels/index.d.ts +2 -0
- package/dist/board/linear/labels/index.d.ts.map +1 -0
- package/dist/board/linear/labels/index.js +2 -0
- package/dist/board/linear/labels/index.js.map +1 -0
- package/dist/board/linear/labels/labels.d.ts +63 -0
- package/dist/board/linear/labels/labels.d.ts.map +1 -0
- package/dist/board/linear/labels/labels.js +204 -0
- package/dist/board/linear/labels/labels.js.map +1 -0
- package/dist/board/linear/linear-board.d.ts +18 -0
- package/dist/board/linear/linear-board.d.ts.map +1 -0
- package/dist/board/linear/linear-board.js +115 -0
- package/dist/board/linear/linear-board.js.map +1 -0
- package/dist/board/linear/relations/index.d.ts +2 -0
- package/dist/board/linear/relations/index.d.ts.map +1 -0
- package/dist/board/linear/relations/index.js +2 -0
- package/dist/board/linear/relations/index.js.map +1 -0
- package/dist/board/linear/relations/relations.d.ts +67 -0
- package/dist/board/linear/relations/relations.d.ts.map +1 -0
- package/dist/board/linear/relations/relations.js +195 -0
- package/dist/board/linear/relations/relations.js.map +1 -0
- package/dist/board/notion/api/api.d.ts +83 -0
- package/dist/board/notion/api/api.d.ts.map +1 -0
- package/dist/board/notion/api/api.js +124 -0
- package/dist/board/notion/api/api.js.map +1 -0
- package/dist/board/notion/api/helpers.d.ts +105 -0
- package/dist/board/notion/api/helpers.d.ts.map +1 -0
- package/dist/board/notion/api/helpers.js +175 -0
- package/dist/board/notion/api/helpers.js.map +1 -0
- package/dist/board/notion/api/index.d.ts +4 -0
- package/dist/board/notion/api/index.d.ts.map +1 -0
- package/dist/board/notion/api/index.js +3 -0
- package/dist/board/notion/api/index.js.map +1 -0
- package/dist/board/notion/index.d.ts +3 -0
- package/dist/board/notion/index.d.ts.map +1 -0
- package/dist/board/notion/index.js +3 -0
- package/dist/board/notion/index.js.map +1 -0
- package/dist/board/notion/labels/index.d.ts +2 -0
- package/dist/board/notion/labels/index.d.ts.map +1 -0
- package/dist/board/notion/labels/index.js +2 -0
- package/dist/board/notion/labels/index.js.map +1 -0
- package/dist/board/notion/labels/labels.d.ts +30 -0
- package/dist/board/notion/labels/labels.d.ts.map +1 -0
- package/dist/board/notion/labels/labels.js +56 -0
- package/dist/board/notion/labels/labels.js.map +1 -0
- package/dist/board/notion/notion-board.d.ts +12 -0
- package/dist/board/notion/notion-board.d.ts.map +1 -0
- package/dist/board/notion/notion-board.js +156 -0
- package/dist/board/notion/notion-board.js.map +1 -0
- package/dist/board/notion/relations/index.d.ts +2 -0
- package/dist/board/notion/relations/index.d.ts.map +1 -0
- package/dist/board/notion/relations/index.js +2 -0
- package/dist/board/notion/relations/index.js.map +1 -0
- package/dist/board/notion/relations/relations.d.ts +43 -0
- package/dist/board/notion/relations/relations.d.ts.map +1 -0
- package/dist/board/notion/relations/relations.js +127 -0
- package/dist/board/notion/relations/relations.js.map +1 -0
- package/dist/board/shortcut/api/api.d.ts +110 -0
- package/dist/board/shortcut/api/api.d.ts.map +1 -0
- package/dist/board/shortcut/api/api.js +227 -0
- package/dist/board/shortcut/api/api.js.map +1 -0
- package/dist/board/shortcut/api/index.d.ts +2 -0
- package/dist/board/shortcut/api/index.d.ts.map +1 -0
- package/dist/board/shortcut/api/index.js +2 -0
- package/dist/board/shortcut/api/index.js.map +1 -0
- package/dist/board/shortcut/index.d.ts +3 -0
- package/dist/board/shortcut/index.d.ts.map +1 -0
- package/dist/board/shortcut/index.js +3 -0
- package/dist/board/shortcut/index.js.map +1 -0
- package/dist/board/shortcut/labels/index.d.ts +2 -0
- package/dist/board/shortcut/labels/index.d.ts.map +1 -0
- package/dist/board/shortcut/labels/index.js +2 -0
- package/dist/board/shortcut/labels/index.js.map +1 -0
- package/dist/board/shortcut/labels/labels.d.ts +95 -0
- package/dist/board/shortcut/labels/labels.d.ts.map +1 -0
- package/dist/board/shortcut/labels/labels.js +154 -0
- package/dist/board/shortcut/labels/labels.js.map +1 -0
- package/dist/board/shortcut/relations/index.d.ts +2 -0
- package/dist/board/shortcut/relations/index.d.ts.map +1 -0
- package/dist/board/shortcut/relations/index.js +2 -0
- package/dist/board/shortcut/relations/index.js.map +1 -0
- package/dist/board/shortcut/relations/relations.d.ts +44 -0
- package/dist/board/shortcut/relations/relations.d.ts.map +1 -0
- package/dist/board/shortcut/relations/relations.js +118 -0
- package/dist/board/shortcut/relations/relations.js.map +1 -0
- package/dist/board/shortcut/shortcut-board.d.ts +18 -0
- package/dist/board/shortcut/shortcut-board.d.ts.map +1 -0
- package/dist/board/shortcut/shortcut-board.js +143 -0
- package/dist/board/shortcut/shortcut-board.js.map +1 -0
- package/dist/dev/lifecycle/branch/branch.d.ts +35 -0
- package/dist/dev/lifecycle/branch/branch.d.ts.map +1 -0
- package/dist/dev/lifecycle/branch/branch.js +48 -0
- package/dist/dev/lifecycle/branch/branch.js.map +1 -0
- package/dist/dev/lifecycle/branch/index.d.ts +2 -0
- package/dist/dev/lifecycle/branch/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/branch/index.js +2 -0
- package/dist/dev/lifecycle/branch/index.js.map +1 -0
- package/dist/dev/lifecycle/commit-type/commit-type.d.ts +22 -0
- package/dist/dev/lifecycle/commit-type/commit-type.d.ts.map +1 -0
- package/dist/dev/lifecycle/commit-type/commit-type.js +50 -0
- package/dist/dev/lifecycle/commit-type/commit-type.js.map +1 -0
- package/dist/dev/lifecycle/commit-type/index.d.ts +2 -0
- package/dist/dev/lifecycle/commit-type/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/commit-type/index.js +2 -0
- package/dist/dev/lifecycle/commit-type/index.js.map +1 -0
- package/dist/dev/lifecycle/cost/cost.d.ts +28 -0
- package/dist/dev/lifecycle/cost/cost.d.ts.map +1 -0
- package/dist/dev/lifecycle/cost/cost.js +36 -0
- package/dist/dev/lifecycle/cost/cost.js.map +1 -0
- package/dist/dev/lifecycle/deliver-epic/deliver-epic.d.ts +44 -0
- package/dist/dev/lifecycle/deliver-epic/deliver-epic.d.ts.map +1 -0
- package/dist/dev/lifecycle/deliver-epic/deliver-epic.js +75 -0
- package/dist/dev/lifecycle/deliver-epic/deliver-epic.js.map +1 -0
- package/dist/dev/lifecycle/deliver-ticket/deliver-ticket.d.ts +51 -0
- package/dist/dev/lifecycle/deliver-ticket/deliver-ticket.d.ts.map +1 -0
- package/dist/dev/lifecycle/deliver-ticket/deliver-ticket.js +132 -0
- package/dist/dev/lifecycle/deliver-ticket/deliver-ticket.js.map +1 -0
- package/dist/dev/lifecycle/epic/epic.d.ts +66 -0
- package/dist/dev/lifecycle/epic/epic.d.ts.map +1 -0
- package/dist/dev/lifecycle/epic/epic.js +91 -0
- package/dist/dev/lifecycle/epic/epic.js.map +1 -0
- package/dist/dev/lifecycle/epic/index.d.ts +2 -0
- package/dist/dev/lifecycle/epic/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/epic/index.js +2 -0
- package/dist/dev/lifecycle/epic/index.js.map +1 -0
- package/dist/dev/lifecycle/feasibility/feasibility.d.ts +55 -0
- package/dist/dev/lifecycle/feasibility/feasibility.d.ts.map +1 -0
- package/dist/dev/lifecycle/feasibility/feasibility.js +75 -0
- package/dist/dev/lifecycle/feasibility/feasibility.js.map +1 -0
- package/dist/dev/lifecycle/fetch-ticket/fetch-ticket.d.ts +49 -0
- package/dist/dev/lifecycle/fetch-ticket/fetch-ticket.d.ts.map +1 -0
- package/dist/dev/lifecycle/fetch-ticket/fetch-ticket.js +81 -0
- package/dist/dev/lifecycle/fetch-ticket/fetch-ticket.js.map +1 -0
- package/dist/dev/lifecycle/format/format.d.ts +11 -0
- package/dist/dev/lifecycle/format/format.d.ts.map +1 -0
- package/dist/dev/lifecycle/format/format.js +23 -0
- package/dist/dev/lifecycle/format/format.js.map +1 -0
- package/dist/dev/lifecycle/lock/index.d.ts +3 -0
- package/dist/dev/lifecycle/lock/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/lock/index.js +2 -0
- package/dist/dev/lifecycle/lock/index.js.map +1 -0
- package/dist/dev/lifecycle/lock/lock.d.ts +68 -0
- package/dist/dev/lifecycle/lock/lock.d.ts.map +1 -0
- package/dist/dev/lifecycle/lock/lock.js +125 -0
- package/dist/dev/lifecycle/lock/lock.js.map +1 -0
- package/dist/dev/lifecycle/outcome/index.d.ts +2 -0
- package/dist/dev/lifecycle/outcome/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/outcome/index.js +2 -0
- package/dist/dev/lifecycle/outcome/index.js.map +1 -0
- package/dist/dev/lifecycle/outcome/outcome.d.ts +65 -0
- package/dist/dev/lifecycle/outcome/outcome.d.ts.map +1 -0
- package/dist/dev/lifecycle/outcome/outcome.js +61 -0
- package/dist/dev/lifecycle/outcome/outcome.js.map +1 -0
- package/dist/dev/lifecycle/pr-creation/index.d.ts +3 -0
- package/dist/dev/lifecycle/pr-creation/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/pr-creation/index.js +2 -0
- package/dist/dev/lifecycle/pr-creation/index.js.map +1 -0
- package/dist/dev/lifecycle/pr-creation/pr-creation.d.ts +47 -0
- package/dist/dev/lifecycle/pr-creation/pr-creation.d.ts.map +1 -0
- package/dist/dev/lifecycle/pr-creation/pr-creation.js +143 -0
- package/dist/dev/lifecycle/pr-creation/pr-creation.js.map +1 -0
- package/dist/dev/lifecycle/preflight/preflight.d.ts +42 -0
- package/dist/dev/lifecycle/preflight/preflight.d.ts.map +1 -0
- package/dist/dev/lifecycle/preflight/preflight.js +101 -0
- package/dist/dev/lifecycle/preflight/preflight.js.map +1 -0
- package/dist/dev/lifecycle/progress/index.d.ts +3 -0
- package/dist/dev/lifecycle/progress/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/progress/index.js +2 -0
- package/dist/dev/lifecycle/progress/index.js.map +1 -0
- package/dist/dev/lifecycle/progress/progress.d.ts +98 -0
- package/dist/dev/lifecycle/progress/progress.d.ts.map +1 -0
- package/dist/dev/lifecycle/progress/progress.js +212 -0
- package/dist/dev/lifecycle/progress/progress.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/azdo/azdo.d.ts +86 -0
- package/dist/dev/lifecycle/pull-request/azdo/azdo.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/azdo/azdo.js +198 -0
- package/dist/dev/lifecycle/pull-request/azdo/azdo.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/azdo/index.d.ts +2 -0
- package/dist/dev/lifecycle/pull-request/azdo/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/azdo/index.js +2 -0
- package/dist/dev/lifecycle/pull-request/azdo/index.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/cloud.d.ts +85 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/cloud.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/cloud.js +158 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/cloud.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/index.d.ts +3 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/index.js +3 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/index.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/server.d.ts +85 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/server.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/server.js +168 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/server.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/github/github.d.ts +107 -0
- package/dist/dev/lifecycle/pull-request/github/github.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/github/github.js +225 -0
- package/dist/dev/lifecycle/pull-request/github/github.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/github/index.d.ts +2 -0
- package/dist/dev/lifecycle/pull-request/github/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/github/index.js +2 -0
- package/dist/dev/lifecycle/pull-request/github/index.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/gitlab/gitlab.d.ts +103 -0
- package/dist/dev/lifecycle/pull-request/gitlab/gitlab.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/gitlab/gitlab.js +215 -0
- package/dist/dev/lifecycle/pull-request/gitlab/gitlab.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/gitlab/index.d.ts +2 -0
- package/dist/dev/lifecycle/pull-request/gitlab/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/gitlab/index.js +2 -0
- package/dist/dev/lifecycle/pull-request/gitlab/index.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/post-pr/post-pr.d.ts +44 -0
- package/dist/dev/lifecycle/pull-request/post-pr/post-pr.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/post-pr/post-pr.js +64 -0
- package/dist/dev/lifecycle/pull-request/post-pr/post-pr.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/pr-body/index.d.ts +3 -0
- package/dist/dev/lifecycle/pull-request/pr-body/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/pr-body/index.js +2 -0
- package/dist/dev/lifecycle/pull-request/pr-body/index.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/pr-body/pr-body.d.ts +65 -0
- package/dist/dev/lifecycle/pull-request/pr-body/pr-body.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/pr-body/pr-body.js +144 -0
- package/dist/dev/lifecycle/pull-request/pr-body/pr-body.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/rework-comment/rework-comment.d.ts +30 -0
- package/dist/dev/lifecycle/pull-request/rework-comment/rework-comment.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/rework-comment/rework-comment.js +39 -0
- package/dist/dev/lifecycle/pull-request/rework-comment/rework-comment.js.map +1 -0
- package/dist/dev/lifecycle/quality/quality.d.ts +99 -0
- package/dist/dev/lifecycle/quality/quality.d.ts.map +1 -0
- package/dist/dev/lifecycle/quality/quality.js +213 -0
- package/dist/dev/lifecycle/quality/quality.js.map +1 -0
- package/dist/dev/lifecycle/resume/resume.d.ts +64 -0
- package/dist/dev/lifecycle/resume/resume.d.ts.map +1 -0
- package/dist/dev/lifecycle/resume/resume.js +171 -0
- package/dist/dev/lifecycle/resume/resume.js.map +1 -0
- package/dist/dev/lifecycle/rework/rework-builders.d.ts +20 -0
- package/dist/dev/lifecycle/rework/rework-builders.d.ts.map +1 -0
- package/dist/dev/lifecycle/rework/rework-builders.js +203 -0
- package/dist/dev/lifecycle/rework/rework-builders.js.map +1 -0
- package/dist/dev/lifecycle/rework/rework-handlers.d.ts +50 -0
- package/dist/dev/lifecycle/rework/rework-handlers.d.ts.map +1 -0
- package/dist/dev/lifecycle/rework/rework-handlers.js +41 -0
- package/dist/dev/lifecycle/rework/rework-handlers.js.map +1 -0
- package/dist/dev/lifecycle/rework/rework.d.ts +63 -0
- package/dist/dev/lifecycle/rework/rework.d.ts.map +1 -0
- package/dist/dev/lifecycle/rework/rework.js +141 -0
- package/dist/dev/lifecycle/rework/rework.js.map +1 -0
- package/dist/dev/pipeline/context.d.ts +105 -0
- package/dist/dev/pipeline/context.d.ts.map +1 -0
- package/dist/dev/pipeline/context.js +107 -0
- package/dist/dev/pipeline/context.js.map +1 -0
- package/dist/dev/pipeline/index.d.ts +6 -0
- package/dist/dev/pipeline/index.d.ts.map +1 -0
- package/dist/dev/pipeline/index.js +5 -0
- package/dist/dev/pipeline/index.js.map +1 -0
- package/dist/dev/pipeline/phases/branch-setup/branch-setup.d.ts +62 -0
- package/dist/dev/pipeline/phases/branch-setup/branch-setup.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/branch-setup/branch-setup.js +128 -0
- package/dist/dev/pipeline/phases/branch-setup/branch-setup.js.map +1 -0
- package/dist/dev/pipeline/phases/branch-setup/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/branch-setup/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/branch-setup/index.js +2 -0
- package/dist/dev/pipeline/phases/branch-setup/index.js.map +1 -0
- package/dist/dev/pipeline/phases/cleanup-phase/cleanup-phase.d.ts +32 -0
- package/dist/dev/pipeline/phases/cleanup-phase/cleanup-phase.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/cleanup-phase/cleanup-phase.js +32 -0
- package/dist/dev/pipeline/phases/cleanup-phase/cleanup-phase.js.map +1 -0
- package/dist/dev/pipeline/phases/cleanup-phase/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/cleanup-phase/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/cleanup-phase/index.js +2 -0
- package/dist/dev/pipeline/phases/cleanup-phase/index.js.map +1 -0
- package/dist/dev/pipeline/phases/cost-phase/cost-phase.d.ts +40 -0
- package/dist/dev/pipeline/phases/cost-phase/cost-phase.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/cost-phase/cost-phase.js +43 -0
- package/dist/dev/pipeline/phases/cost-phase/cost-phase.js.map +1 -0
- package/dist/dev/pipeline/phases/cost-phase/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/cost-phase/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/cost-phase/index.js +2 -0
- package/dist/dev/pipeline/phases/cost-phase/index.js.map +1 -0
- package/dist/dev/pipeline/phases/deliver-phase/deliver-phase.d.ts +68 -0
- package/dist/dev/pipeline/phases/deliver-phase/deliver-phase.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/deliver-phase/deliver-phase.js +125 -0
- package/dist/dev/pipeline/phases/deliver-phase/deliver-phase.js.map +1 -0
- package/dist/dev/pipeline/phases/deliver-phase/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/deliver-phase/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/deliver-phase/index.js +2 -0
- package/dist/dev/pipeline/phases/deliver-phase/index.js.map +1 -0
- package/dist/dev/pipeline/phases/dry-run/dry-run.d.ts +38 -0
- package/dist/dev/pipeline/phases/dry-run/dry-run.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/dry-run/dry-run.js +33 -0
- package/dist/dev/pipeline/phases/dry-run/dry-run.js.map +1 -0
- package/dist/dev/pipeline/phases/dry-run/index.d.ts +2 -0
- package/dist/dev/pipeline/phases/dry-run/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/dry-run/index.js +2 -0
- package/dist/dev/pipeline/phases/dry-run/index.js.map +1 -0
- package/dist/dev/pipeline/phases/epic-completion/epic-completion.d.ts +48 -0
- package/dist/dev/pipeline/phases/epic-completion/epic-completion.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/epic-completion/epic-completion.js +42 -0
- package/dist/dev/pipeline/phases/epic-completion/epic-completion.js.map +1 -0
- package/dist/dev/pipeline/phases/epic-completion/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/epic-completion/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/epic-completion/index.js +2 -0
- package/dist/dev/pipeline/phases/epic-completion/index.js.map +1 -0
- package/dist/dev/pipeline/phases/feasibility/feasibility.d.ts +52 -0
- package/dist/dev/pipeline/phases/feasibility/feasibility.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/feasibility/feasibility.js +34 -0
- package/dist/dev/pipeline/phases/feasibility/feasibility.js.map +1 -0
- package/dist/dev/pipeline/phases/feasibility/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/feasibility/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/feasibility/index.js +2 -0
- package/dist/dev/pipeline/phases/feasibility/index.js.map +1 -0
- package/dist/dev/pipeline/phases/index.d.ts +26 -0
- package/dist/dev/pipeline/phases/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/index.js +14 -0
- package/dist/dev/pipeline/phases/index.js.map +1 -0
- package/dist/dev/pipeline/phases/lock-check/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/lock-check/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/lock-check/index.js +2 -0
- package/dist/dev/pipeline/phases/lock-check/index.js.map +1 -0
- package/dist/dev/pipeline/phases/lock-check/lock-check.d.ts +55 -0
- package/dist/dev/pipeline/phases/lock-check/lock-check.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/lock-check/lock-check.js +60 -0
- package/dist/dev/pipeline/phases/lock-check/lock-check.js.map +1 -0
- package/dist/dev/pipeline/phases/pr-retry/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/pr-retry/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/pr-retry/index.js +2 -0
- package/dist/dev/pipeline/phases/pr-retry/index.js.map +1 -0
- package/dist/dev/pipeline/phases/pr-retry/pr-retry.d.ts +58 -0
- package/dist/dev/pipeline/phases/pr-retry/pr-retry.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/pr-retry/pr-retry.js +82 -0
- package/dist/dev/pipeline/phases/pr-retry/pr-retry.js.map +1 -0
- package/dist/dev/pipeline/phases/preflight-phase/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/preflight-phase/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/preflight-phase/index.js +2 -0
- package/dist/dev/pipeline/phases/preflight-phase/index.js.map +1 -0
- package/dist/dev/pipeline/phases/preflight-phase/preflight-phase.d.ts +42 -0
- package/dist/dev/pipeline/phases/preflight-phase/preflight-phase.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/preflight-phase/preflight-phase.js +41 -0
- package/dist/dev/pipeline/phases/preflight-phase/preflight-phase.js.map +1 -0
- package/dist/dev/pipeline/phases/rework-detection/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/rework-detection/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/rework-detection/index.js +2 -0
- package/dist/dev/pipeline/phases/rework-detection/index.js.map +1 -0
- package/dist/dev/pipeline/phases/rework-detection/rework-detection.d.ts +40 -0
- package/dist/dev/pipeline/phases/rework-detection/rework-detection.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/rework-detection/rework-detection.js +38 -0
- package/dist/dev/pipeline/phases/rework-detection/rework-detection.js.map +1 -0
- package/dist/dev/pipeline/phases/ticket-fetch/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/ticket-fetch/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/ticket-fetch/index.js +2 -0
- package/dist/dev/pipeline/phases/ticket-fetch/index.js.map +1 -0
- package/dist/dev/pipeline/phases/ticket-fetch/ticket-fetch.d.ts +46 -0
- package/dist/dev/pipeline/phases/ticket-fetch/ticket-fetch.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/ticket-fetch/ticket-fetch.js +64 -0
- package/dist/dev/pipeline/phases/ticket-fetch/ticket-fetch.js.map +1 -0
- package/dist/dev/pipeline/phases/transition/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/transition/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/transition/index.js +2 -0
- package/dist/dev/pipeline/phases/transition/index.js.map +1 -0
- package/dist/dev/pipeline/phases/transition/transition.d.ts +30 -0
- package/dist/dev/pipeline/phases/transition/transition.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/transition/transition.js +27 -0
- package/dist/dev/pipeline/phases/transition/transition.js.map +1 -0
- package/dist/dev/pipeline/run-pipeline.d.ts +98 -0
- package/dist/dev/pipeline/run-pipeline.d.ts.map +1 -0
- package/dist/dev/pipeline/run-pipeline.js +106 -0
- package/dist/dev/pipeline/run-pipeline.js.map +1 -0
- package/dist/index.d.ts +58 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +58 -0
- package/dist/index.js.map +1 -0
- package/dist/schemas/azdo/azdo-pr.d.ts +58 -0
- package/dist/schemas/azdo/azdo-pr.d.ts.map +1 -0
- package/dist/schemas/azdo/azdo-pr.js +48 -0
- package/dist/schemas/azdo/azdo-pr.js.map +1 -0
- package/dist/schemas/azdo/azdo.d.ts +88 -0
- package/dist/schemas/azdo/azdo.d.ts.map +1 -0
- package/dist/schemas/azdo/azdo.js +60 -0
- package/dist/schemas/azdo/azdo.js.map +1 -0
- package/dist/schemas/bitbucket/bitbucket.d.ts +112 -0
- package/dist/schemas/bitbucket/bitbucket.d.ts.map +1 -0
- package/dist/schemas/bitbucket/bitbucket.js +73 -0
- package/dist/schemas/bitbucket/bitbucket.js.map +1 -0
- package/dist/schemas/env/env.d.ts +336 -0
- package/dist/schemas/env/env.d.ts.map +1 -0
- package/dist/schemas/env/env.js +94 -0
- package/dist/schemas/env/env.js.map +1 -0
- package/dist/schemas/github/github.d.ts +128 -0
- package/dist/schemas/github/github.d.ts.map +1 -0
- package/dist/schemas/github/github.js +65 -0
- package/dist/schemas/github/github.js.map +1 -0
- package/dist/schemas/gitlab/gitlab.d.ts +72 -0
- package/dist/schemas/gitlab/gitlab.d.ts.map +1 -0
- package/dist/schemas/gitlab/gitlab.js +38 -0
- package/dist/schemas/gitlab/gitlab.js.map +1 -0
- package/dist/schemas/index.d.ts +15 -0
- package/dist/schemas/index.d.ts.map +1 -0
- package/dist/schemas/index.js +8 -0
- package/dist/schemas/index.js.map +1 -0
- package/dist/schemas/jira/jira.d.ts +79 -0
- package/dist/schemas/jira/jira.d.ts.map +1 -0
- package/dist/schemas/jira/jira.js +69 -0
- package/dist/schemas/jira/jira.js.map +1 -0
- package/dist/schemas/linear/linear.d.ts +178 -0
- package/dist/schemas/linear/linear.d.ts.map +1 -0
- package/dist/schemas/linear/linear.js +136 -0
- package/dist/schemas/linear/linear.js.map +1 -0
- package/dist/schemas/notion/notion.d.ts +131 -0
- package/dist/schemas/notion/notion.d.ts.map +1 -0
- package/dist/schemas/notion/notion.js +102 -0
- package/dist/schemas/notion/notion.js.map +1 -0
- package/dist/schemas/shortcut/shortcut.d.ts +149 -0
- package/dist/schemas/shortcut/shortcut.d.ts.map +1 -0
- package/dist/schemas/shortcut/shortcut.js +68 -0
- package/dist/schemas/shortcut/shortcut.js.map +1 -0
- package/dist/shared/cache/cache.d.ts +14 -0
- package/dist/shared/cache/cache.d.ts.map +1 -0
- package/dist/shared/cache/cache.js +25 -0
- package/dist/shared/cache/cache.js.map +1 -0
- package/dist/shared/cache/index.d.ts +2 -0
- package/dist/shared/cache/index.d.ts.map +1 -0
- package/dist/shared/cache/index.js +2 -0
- package/dist/shared/cache/index.js.map +1 -0
- package/dist/shared/env-parser/env-parser.d.ts +42 -0
- package/dist/shared/env-parser/env-parser.d.ts.map +1 -0
- package/dist/shared/env-parser/env-parser.js +97 -0
- package/dist/shared/env-parser/env-parser.js.map +1 -0
- package/dist/shared/env-parser/index.d.ts +3 -0
- package/dist/shared/env-parser/index.d.ts.map +1 -0
- package/dist/shared/env-parser/index.js +2 -0
- package/dist/shared/env-parser/index.js.map +1 -0
- package/dist/shared/git-ops/git-ops.d.ts +127 -0
- package/dist/shared/git-ops/git-ops.d.ts.map +1 -0
- package/dist/shared/git-ops/git-ops.js +225 -0
- package/dist/shared/git-ops/git-ops.js.map +1 -0
- package/dist/shared/git-ops/index.d.ts +3 -0
- package/dist/shared/git-ops/index.d.ts.map +1 -0
- package/dist/shared/git-ops/index.js +2 -0
- package/dist/shared/git-ops/index.js.map +1 -0
- package/dist/shared/git-token/git-token.d.ts +18 -0
- package/dist/shared/git-token/git-token.d.ts.map +1 -0
- package/dist/shared/git-token/git-token.js +28 -0
- package/dist/shared/git-token/git-token.js.map +1 -0
- package/dist/shared/git-token/index.d.ts +2 -0
- package/dist/shared/git-token/index.d.ts.map +1 -0
- package/dist/shared/git-token/index.js +2 -0
- package/dist/shared/git-token/index.js.map +1 -0
- package/dist/shared/http/fetch-and-parse/fetch-and-parse.d.ts +32 -0
- package/dist/shared/http/fetch-and-parse/fetch-and-parse.d.ts.map +1 -0
- package/dist/shared/http/fetch-and-parse/fetch-and-parse.js +53 -0
- package/dist/shared/http/fetch-and-parse/fetch-and-parse.js.map +1 -0
- package/dist/shared/http/fetch-and-parse/index.d.ts +3 -0
- package/dist/shared/http/fetch-and-parse/index.d.ts.map +1 -0
- package/dist/shared/http/fetch-and-parse/index.js +2 -0
- package/dist/shared/http/fetch-and-parse/index.js.map +1 -0
- package/dist/shared/http/index.d.ts +7 -0
- package/dist/shared/http/index.d.ts.map +1 -0
- package/dist/shared/http/index.js +4 -0
- package/dist/shared/http/index.js.map +1 -0
- package/dist/shared/http/ping-endpoint/index.d.ts +3 -0
- package/dist/shared/http/ping-endpoint/index.d.ts.map +1 -0
- package/dist/shared/http/ping-endpoint/index.js +2 -0
- package/dist/shared/http/ping-endpoint/index.js.map +1 -0
- package/dist/shared/http/ping-endpoint/ping-endpoint.d.ts +29 -0
- package/dist/shared/http/ping-endpoint/ping-endpoint.d.ts.map +1 -0
- package/dist/shared/http/ping-endpoint/ping-endpoint.js +31 -0
- package/dist/shared/http/ping-endpoint/ping-endpoint.js.map +1 -0
- package/dist/shared/http/retry-fetch/index.d.ts +3 -0
- package/dist/shared/http/retry-fetch/index.d.ts.map +1 -0
- package/dist/shared/http/retry-fetch/index.js +2 -0
- package/dist/shared/http/retry-fetch/index.js.map +1 -0
- package/dist/shared/http/retry-fetch/retry-fetch.d.ts +33 -0
- package/dist/shared/http/retry-fetch/retry-fetch.d.ts.map +1 -0
- package/dist/shared/http/retry-fetch/retry-fetch.js +94 -0
- package/dist/shared/http/retry-fetch/retry-fetch.js.map +1 -0
- package/dist/shared/label-helpers/index.d.ts +3 -0
- package/dist/shared/label-helpers/index.d.ts.map +1 -0
- package/dist/shared/label-helpers/index.js +2 -0
- package/dist/shared/label-helpers/index.js.map +1 -0
- package/dist/shared/label-helpers/label-helpers.d.ts +41 -0
- package/dist/shared/label-helpers/label-helpers.d.ts.map +1 -0
- package/dist/shared/label-helpers/label-helpers.js +51 -0
- package/dist/shared/label-helpers/label-helpers.js.map +1 -0
- package/dist/shared/remote/index.d.ts +2 -0
- package/dist/shared/remote/index.d.ts.map +1 -0
- package/dist/shared/remote/index.js +2 -0
- package/dist/shared/remote/index.js.map +1 -0
- package/dist/shared/remote/remote.d.ts +39 -0
- package/dist/shared/remote/remote.d.ts.map +1 -0
- package/dist/shared/remote/remote.js +180 -0
- package/dist/shared/remote/remote.js.map +1 -0
- package/dist/types/board.d.ts +62 -0
- package/dist/types/board.d.ts.map +1 -0
- package/dist/types/board.js +5 -0
- package/dist/types/board.js.map +1 -0
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/progress.d.ts +21 -0
- package/dist/types/progress.d.ts.map +1 -0
- package/dist/types/progress.js +34 -0
- package/dist/types/progress.js.map +1 -0
- package/dist/types/remote.d.ts +77 -0
- package/dist/types/remote.d.ts.map +1 -0
- package/dist/types/remote.js +5 -0
- package/dist/types/remote.js.map +1 -0
- package/package.json +44 -0
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
/** Notion REST API base URL. */
|
|
2
|
+
export const NOTION_API = 'https://api.notion.com/v1';
|
|
3
|
+
/** Notion API version for all requests. */
|
|
4
|
+
const NOTION_VERSION = '2022-06-28';
|
|
5
|
+
/**
|
|
6
|
+
* Build standard Notion request headers.
|
|
7
|
+
*
|
|
8
|
+
* @param token - The Notion integration token.
|
|
9
|
+
* @returns Headers object for Notion API requests.
|
|
10
|
+
*/
|
|
11
|
+
export function notionHeaders(token) {
|
|
12
|
+
return {
|
|
13
|
+
Authorization: `Bearer ${token}`,
|
|
14
|
+
'Notion-Version': NOTION_VERSION,
|
|
15
|
+
'Content-Type': 'application/json',
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
// ─── Property extraction ─────────────────────────────────────────────────────
|
|
19
|
+
/**
|
|
20
|
+
* Extract a single-value property (status, select, title, rich_text).
|
|
21
|
+
*
|
|
22
|
+
* @param page - The Notion page object.
|
|
23
|
+
* @param propName - The property name to look up.
|
|
24
|
+
* @param propType - The expected property type.
|
|
25
|
+
* @returns The extracted string value, or `undefined`.
|
|
26
|
+
*/
|
|
27
|
+
export function getStringProperty(page, propName, propType) {
|
|
28
|
+
const prop = page.properties[propName];
|
|
29
|
+
if (!prop || prop.type !== propType)
|
|
30
|
+
return undefined;
|
|
31
|
+
// Safe casts: type guard on prop.type guarantees the shape
|
|
32
|
+
switch (propType) {
|
|
33
|
+
case 'status': {
|
|
34
|
+
const p = prop;
|
|
35
|
+
return p.status?.name;
|
|
36
|
+
}
|
|
37
|
+
case 'select': {
|
|
38
|
+
const p = prop;
|
|
39
|
+
return p.select?.name;
|
|
40
|
+
}
|
|
41
|
+
case 'title': {
|
|
42
|
+
const p = prop;
|
|
43
|
+
return p.title.map((t) => t.plain_text).join('');
|
|
44
|
+
}
|
|
45
|
+
case 'rich_text': {
|
|
46
|
+
const p = prop;
|
|
47
|
+
return p.rich_text.map((t) => t.plain_text).join('');
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Extract an array-value property (multi_select, relation, people).
|
|
53
|
+
*
|
|
54
|
+
* @param page - The Notion page object.
|
|
55
|
+
* @param propName - The property name to look up.
|
|
56
|
+
* @param propType - The expected property type.
|
|
57
|
+
* @returns Array of string values, or `undefined`.
|
|
58
|
+
*/
|
|
59
|
+
export function getArrayProperty(page, propName, propType) {
|
|
60
|
+
const prop = page.properties[propName];
|
|
61
|
+
if (!prop || prop.type !== propType)
|
|
62
|
+
return undefined;
|
|
63
|
+
// Safe: prop.type === propType narrows the union, but TS can't follow the
|
|
64
|
+
// dynamic propType parameter — each branch casts to the known shape.
|
|
65
|
+
switch (propType) {
|
|
66
|
+
case 'multi_select': {
|
|
67
|
+
const p = prop;
|
|
68
|
+
return p.multi_select.map((o) => o.name);
|
|
69
|
+
}
|
|
70
|
+
case 'relation': {
|
|
71
|
+
const p = prop;
|
|
72
|
+
return p.relation.map((r) => r.id);
|
|
73
|
+
}
|
|
74
|
+
case 'people': {
|
|
75
|
+
const p = prop;
|
|
76
|
+
return p.people.map((u) => u.id);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
// ─── Key helpers ─────────────────────────────────────────────────────────────
|
|
81
|
+
/**
|
|
82
|
+
* Build a short key from a Notion page UUID.
|
|
83
|
+
*
|
|
84
|
+
* @param pageId - The full page UUID.
|
|
85
|
+
* @returns Short key like `notion-ab12cd34`.
|
|
86
|
+
*/
|
|
87
|
+
export function buildNotionKey(pageId) {
|
|
88
|
+
const shortId = pageId.replace(/-/g, '').slice(0, 8);
|
|
89
|
+
return `notion-${shortId}`;
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Extract the short ID from a Notion key.
|
|
93
|
+
*
|
|
94
|
+
* @param key - The key (e.g., `'notion-ab12cd34'`).
|
|
95
|
+
* @returns The 8-char short ID, or `undefined` if invalid.
|
|
96
|
+
*/
|
|
97
|
+
export function parseNotionShortId(key) {
|
|
98
|
+
const shortId = key.replace('notion-', '');
|
|
99
|
+
return shortId.length === 8 ? shortId : undefined;
|
|
100
|
+
}
|
|
101
|
+
// ─── Status helpers ──────────────────────────────────────────────────────────
|
|
102
|
+
/** Done-like status names (case-insensitive). */
|
|
103
|
+
const COMPLETE_STATUSES = new Set(['done', 'complete', 'completed', 'closed']);
|
|
104
|
+
/**
|
|
105
|
+
* Check whether a status name indicates completion.
|
|
106
|
+
*
|
|
107
|
+
* @param statusName - The status name to check.
|
|
108
|
+
* @returns `true` if the status is a done-like state.
|
|
109
|
+
*/
|
|
110
|
+
export function isCompleteStatus(statusName) {
|
|
111
|
+
return COMPLETE_STATUSES.has(statusName.toLowerCase());
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Extract description text from a page's rich_text properties.
|
|
115
|
+
*
|
|
116
|
+
* Tries common property names: Description, description, Body, body.
|
|
117
|
+
*
|
|
118
|
+
* @param page - The Notion page object.
|
|
119
|
+
* @returns The description text, or `undefined`.
|
|
120
|
+
*/
|
|
121
|
+
export function getDescriptionText(page) {
|
|
122
|
+
const names = ['Description', 'description', 'Body', 'body'];
|
|
123
|
+
return names
|
|
124
|
+
.map((name) => getStringProperty(page, name, 'rich_text'))
|
|
125
|
+
.find(Boolean);
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Extract the title from a page (first title-type property).
|
|
129
|
+
*
|
|
130
|
+
* @param page - The Notion page object.
|
|
131
|
+
* @returns The title text, or empty string.
|
|
132
|
+
*/
|
|
133
|
+
export function getPageTitle(page) {
|
|
134
|
+
const titleEntry = Object.entries(page.properties).find(([, prop]) => prop.type === 'title');
|
|
135
|
+
if (!titleEntry)
|
|
136
|
+
return '';
|
|
137
|
+
return getStringProperty(page, titleEntry[0], 'title') ?? '';
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Get the status of a page (tries status type, falls back to select).
|
|
141
|
+
*
|
|
142
|
+
* @param page - The Notion page object.
|
|
143
|
+
* @param statusProp - The property name.
|
|
144
|
+
* @returns The status name, or `undefined`.
|
|
145
|
+
*/
|
|
146
|
+
export function getPageStatus(page, statusProp) {
|
|
147
|
+
return (getStringProperty(page, statusProp, 'status') ??
|
|
148
|
+
getStringProperty(page, statusProp, 'select'));
|
|
149
|
+
}
|
|
150
|
+
/**
|
|
151
|
+
* Check if a page is incomplete (not in a done-like state).
|
|
152
|
+
*
|
|
153
|
+
* @param page - The Notion page object.
|
|
154
|
+
* @param statusProp - The status property name.
|
|
155
|
+
* @returns `true` if incomplete.
|
|
156
|
+
*/
|
|
157
|
+
export function isPageIncomplete(page, statusProp) {
|
|
158
|
+
const status = getPageStatus(page, statusProp);
|
|
159
|
+
return !status || !isCompleteStatus(status);
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* Find a property by name with case-insensitive fallback.
|
|
163
|
+
*
|
|
164
|
+
* @param page - The Notion page object.
|
|
165
|
+
* @param name - The property name to search for.
|
|
166
|
+
* @returns The property value, or `undefined`.
|
|
167
|
+
*/
|
|
168
|
+
export function findPropertyByName(page, name) {
|
|
169
|
+
if (page.properties[name])
|
|
170
|
+
return page.properties[name];
|
|
171
|
+
const lowerName = name.toLowerCase();
|
|
172
|
+
const match = Object.entries(page.properties).find(([key]) => key.toLowerCase() === lowerName);
|
|
173
|
+
return match?.[1];
|
|
174
|
+
}
|
|
175
|
+
//# sourceMappingURL=helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../../../src/board/notion/api/helpers.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { fetchPage, findPageByKey, pingNotion, queryAllPages, queryDatabase, updatePage, } from './api.js';
|
|
2
|
+
export { buildNotionKey, findPropertyByName, getArrayProperty, getDescriptionText, getPageStatus, getPageTitle, isCompleteStatus, isPageIncomplete, } from './helpers.js';
|
|
3
|
+
export type { NotionCtx } from './helpers.js';
|
|
4
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/board/notion/api/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,aAAa,EACb,UAAU,EACV,aAAa,EACb,aAAa,EACb,UAAU,GACX,MAAM,UAAU,CAAC;AAClB,OAAO,EACL,cAAc,EACd,kBAAkB,EAClB,gBAAgB,EAChB,kBAAkB,EAClB,aAAa,EACb,YAAY,EACZ,gBAAgB,EAChB,gBAAgB,GACjB,MAAM,cAAc,CAAC;AACtB,YAAY,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export { fetchPage, findPageByKey, pingNotion, queryAllPages, queryDatabase, updatePage, } from './api.js';
|
|
2
|
+
export { buildNotionKey, findPropertyByName, getArrayProperty, getDescriptionText, getPageStatus, getPageTitle, isCompleteStatus, isPageIncomplete, } from './helpers.js';
|
|
3
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/board/notion/api/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,aAAa,EACb,UAAU,EACV,aAAa,EACb,aAAa,EACb,UAAU,GACX,MAAM,UAAU,CAAC;AAClB,OAAO,EACL,cAAc,EACd,kBAAkB,EAClB,gBAAgB,EAChB,kBAAkB,EAClB,aAAa,EACb,YAAY,EACZ,gBAAgB,EAChB,gBAAgB,GACjB,MAAM,cAAc,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/board/notion/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/board/notion/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/board/notion/labels/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/board/notion/labels/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Notion page label (multi_select) operations.
|
|
3
|
+
*
|
|
4
|
+
* Uses read-modify-write via {@link modifyLabelList}. Labels are stored
|
|
5
|
+
* as multi_select options which auto-create on first PATCH.
|
|
6
|
+
*/
|
|
7
|
+
import type { NotionCtx } from '../api/index.js';
|
|
8
|
+
/** Options for label operations. */
|
|
9
|
+
type LabelOpts = {
|
|
10
|
+
readonly ctx: NotionCtx;
|
|
11
|
+
readonly issueKey: string;
|
|
12
|
+
readonly label: string;
|
|
13
|
+
readonly labelsProp: string;
|
|
14
|
+
};
|
|
15
|
+
/**
|
|
16
|
+
* Add a label to a Notion page (best-effort).
|
|
17
|
+
*
|
|
18
|
+
* @param opts - Connection context, issue key, label, and property name.
|
|
19
|
+
* @returns Resolves when complete (best-effort — never throws).
|
|
20
|
+
*/
|
|
21
|
+
export declare function addLabel(opts: LabelOpts): Promise<void>;
|
|
22
|
+
/**
|
|
23
|
+
* Remove a label from a Notion page (best-effort).
|
|
24
|
+
*
|
|
25
|
+
* @param opts - Connection context, issue key, label, and property name.
|
|
26
|
+
* @returns Resolves when complete (best-effort — never throws).
|
|
27
|
+
*/
|
|
28
|
+
export declare function removeLabel(opts: LabelOpts): Promise<void>;
|
|
29
|
+
export {};
|
|
30
|
+
//# sourceMappingURL=labels.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"labels.d.ts","sourceRoot":"","sources":["../../../../src/board/notion/labels/labels.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAMjD,oCAAoC;AACpC,KAAK,SAAS,GAAG;IACf,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC;IACxB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;CAC7B,CAAC;AAsBF;;;;;GAKG;AACH,wBAAsB,QAAQ,CAAC,IAAI,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAkB7D;AAED;;;;;GAKG;AACH,wBAAsB,WAAW,CAAC,IAAI,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAkBhE"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { modifyLabelList, safeLabel } from '../../../shared/label-helpers/index.js';
|
|
2
|
+
import { findPageByKey, getArrayProperty, updatePage } from '../api/index.js';
|
|
3
|
+
/** Write updated labels to a page via PATCH. */
|
|
4
|
+
async function writeLabels(opts, labels) {
|
|
5
|
+
await updatePage({
|
|
6
|
+
token: opts.ctx.token,
|
|
7
|
+
pageId: opts.pageId,
|
|
8
|
+
properties: {
|
|
9
|
+
[opts.labelsProp]: {
|
|
10
|
+
multi_select: labels.map((name) => ({ name })),
|
|
11
|
+
},
|
|
12
|
+
},
|
|
13
|
+
fetcher: opts.ctx.fetcher,
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Add a label to a Notion page (best-effort).
|
|
18
|
+
*
|
|
19
|
+
* @param opts - Connection context, issue key, label, and property name.
|
|
20
|
+
* @returns Resolves when complete (best-effort — never throws).
|
|
21
|
+
*/
|
|
22
|
+
export async function addLabel(opts) {
|
|
23
|
+
const { ctx, issueKey, label, labelsProp } = opts;
|
|
24
|
+
await safeLabel(async () => {
|
|
25
|
+
const page = await findPageByKey(ctx, issueKey);
|
|
26
|
+
if (!page)
|
|
27
|
+
return;
|
|
28
|
+
await modifyLabelList({
|
|
29
|
+
fetchCurrent: () => Promise.resolve(getArrayProperty(page, labelsProp, 'multi_select') ?? []),
|
|
30
|
+
writeUpdated: (labels) => writeLabels({ ctx, pageId: page.id, labelsProp }, labels),
|
|
31
|
+
target: label,
|
|
32
|
+
mode: 'add',
|
|
33
|
+
});
|
|
34
|
+
}, 'addLabel');
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Remove a label from a Notion page (best-effort).
|
|
38
|
+
*
|
|
39
|
+
* @param opts - Connection context, issue key, label, and property name.
|
|
40
|
+
* @returns Resolves when complete (best-effort — never throws).
|
|
41
|
+
*/
|
|
42
|
+
export async function removeLabel(opts) {
|
|
43
|
+
const { ctx, issueKey, label, labelsProp } = opts;
|
|
44
|
+
await safeLabel(async () => {
|
|
45
|
+
const page = await findPageByKey(ctx, issueKey);
|
|
46
|
+
if (!page)
|
|
47
|
+
return;
|
|
48
|
+
await modifyLabelList({
|
|
49
|
+
fetchCurrent: () => Promise.resolve(getArrayProperty(page, labelsProp, 'multi_select') ?? []),
|
|
50
|
+
writeUpdated: (labels) => writeLabels({ ctx, pageId: page.id, labelsProp }, labels),
|
|
51
|
+
target: label,
|
|
52
|
+
mode: 'remove',
|
|
53
|
+
});
|
|
54
|
+
}, 'removeLabel');
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=labels.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"labels.js","sourceRoot":"","sources":["../../../../src/board/notion/labels/labels.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAC;AAE/E,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAU9E,gDAAgD;AAChD,KAAK,UAAU,WAAW,CACxB,IAGC,EACD,MAAyB;IAEzB,MAAM,UAAU,CAAC;QACf,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,KAAK;QACrB,MAAM,EAAE,IAAI,CAAC,MAAM;QACnB,UAAU,EAAE;YACV,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;gBACjB,YAAY,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;aAC/C;SACF;QACD,OAAO,EAAE,IAAI,CAAC,GAAG,CAAC,OAAO;KAC1B,CAAC,CAAC;AACL,CAAC;AAED;;;;;GAKG;AACH,MAAM,CAAC,KAAK,UAAU,QAAQ,CAAC,IAAe;IAC5C,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC;IAElD,MAAM,SAAS,CAAC,KAAK,IAAI,EAAE;QACzB,MAAM,IAAI,GAAG,MAAM,aAAa,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAChD,IAAI,CAAC,IAAI;YAAE,OAAO;QAElB,MAAM,eAAe,CAAC;YACpB,YAAY,EAAE,GAAG,EAAE,CACjB,OAAO,CAAC,OAAO,CACb,gBAAgB,CAAC,IAAI,EAAE,UAAU,EAAE,cAAc,CAAC,IAAI,EAAE,CACzD;YACH,YAAY,EAAE,CAAC,MAAM,EAAE,EAAE,CACvB,WAAW,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE,UAAU,EAAE,EAAE,MAAM,CAAC;YAC3D,MAAM,EAAE,KAAK;YACb,IAAI,EAAE,KAAK;SACZ,CAAC,CAAC;IACL,CAAC,EAAE,UAAU,CAAC,CAAC;AACjB,CAAC;AAED;;;;;GAKG;AACH,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,IAAe;IAC/C,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC;IAElD,MAAM,SAAS,CAAC,KAAK,IAAI,EAAE;QACzB,MAAM,IAAI,GAAG,MAAM,aAAa,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAChD,IAAI,CAAC,IAAI;YAAE,OAAO;QAElB,MAAM,eAAe,CAAC;YACpB,YAAY,EAAE,GAAG,EAAE,CACjB,OAAO,CAAC,OAAO,CACb,gBAAgB,CAAC,IAAI,EAAE,UAAU,EAAE,cAAc,CAAC,IAAI,EAAE,CACzD;YACH,YAAY,EAAE,CAAC,MAAM,EAAE,EAAE,CACvB,WAAW,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE,UAAU,EAAE,EAAE,MAAM,CAAC;YAC3D,MAAM,EAAE,KAAK;YACb,IAAI,EAAE,QAAQ;SACf,CAAC,CAAC;IACL,CAAC,EAAE,aAAa,CAAC,CAAC;AACpB,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { NotionEnv } from '../../schemas/index.js';
|
|
2
|
+
import type { Fetcher } from '../../shared/http/index.js';
|
|
3
|
+
import type { Board } from '../../types/index.js';
|
|
4
|
+
/**
|
|
5
|
+
* Create a Board implementation for Notion.
|
|
6
|
+
*
|
|
7
|
+
* @param env - The validated Notion environment variables.
|
|
8
|
+
* @param fetcher - Optional custom fetch function for DI in tests.
|
|
9
|
+
* @returns A Board object that delegates to Notion API functions.
|
|
10
|
+
*/
|
|
11
|
+
export declare function createNotionBoard(env: NotionEnv, fetcher?: Fetcher): Board;
|
|
12
|
+
//# sourceMappingURL=notion-board.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"notion-board.d.ts","sourceRoot":"","sources":["../../../src/board/notion/notion-board.ts"],"names":[],"mappings":"AAUA,OAAO,KAAK,EAAE,SAAS,EAAc,MAAM,sBAAsB,CAAC;AAClE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,KAAK,EAAE,KAAK,EAAkC,MAAM,oBAAoB,CAAC;AAqKhF;;;;;;GAMG;AACH,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,SAAS,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,KAAK,CAyD1E"}
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
import { buildNotionKey, getArrayProperty, getDescriptionText, getPageTitle, pingNotion, queryDatabase, updatePage, } from './api/index.js';
|
|
2
|
+
import { addLabel, removeLabel } from './labels/index.js';
|
|
3
|
+
import { fetchBlockerStatus, fetchChildrenStatus } from './relations/index.js';
|
|
4
|
+
/** Default property names for Notion databases. */
|
|
5
|
+
const DEFAULTS = {
|
|
6
|
+
status: 'Status',
|
|
7
|
+
labels: 'Labels',
|
|
8
|
+
parent: 'Epic',
|
|
9
|
+
todo: 'To-do',
|
|
10
|
+
};
|
|
11
|
+
/** UUID pattern for NOTION_DATABASE_ID validation. */
|
|
12
|
+
const UUID_PATTERN = /^[0-9a-f]{8}-?[0-9a-f]{4}-?[0-9a-f]{4}-?[0-9a-f]{4}-?[0-9a-f]{12}$/i;
|
|
13
|
+
/** Convert a Notion page to a FetchedTicket. */
|
|
14
|
+
function pageToFetchedTicket(page, props) {
|
|
15
|
+
const parentRelations = getArrayProperty(page, props.parentProp, 'relation');
|
|
16
|
+
const hasParent = parentRelations && parentRelations.length > 0;
|
|
17
|
+
const parentInfo = hasParent ? buildNotionKey(parentRelations[0]) : 'none';
|
|
18
|
+
return {
|
|
19
|
+
key: buildNotionKey(page.id),
|
|
20
|
+
title: getPageTitle(page),
|
|
21
|
+
description: getDescriptionText(page) ?? '',
|
|
22
|
+
parentInfo,
|
|
23
|
+
blockers: 'None',
|
|
24
|
+
issueId: page.id,
|
|
25
|
+
labels: getArrayProperty(page, props.labelsProp, 'multi_select') ?? [],
|
|
26
|
+
status: props.todoName,
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
/** Fetch and normalise Notion pages into FetchedTickets. */
|
|
30
|
+
async function fetchNotionTickets(opts) {
|
|
31
|
+
const { ctx, fetchOpts, props, defaultLabel } = opts;
|
|
32
|
+
const filter = {
|
|
33
|
+
property: props.statusProp,
|
|
34
|
+
status: { equals: props.todoName },
|
|
35
|
+
};
|
|
36
|
+
const result = await queryDatabase({ ctx, filter });
|
|
37
|
+
if (!result)
|
|
38
|
+
return [];
|
|
39
|
+
const hitlFiltered = fetchOpts.excludeHitl
|
|
40
|
+
? result.results.filter((page) => {
|
|
41
|
+
const labels = getArrayProperty(page, props.labelsProp, 'multi_select');
|
|
42
|
+
return !labels?.includes('clancy:hitl');
|
|
43
|
+
})
|
|
44
|
+
: [...result.results];
|
|
45
|
+
const requiredLabel = fetchOpts.buildLabel ?? defaultLabel;
|
|
46
|
+
const labelFiltered = requiredLabel
|
|
47
|
+
? hitlFiltered.filter((page) => {
|
|
48
|
+
const labels = getArrayProperty(page, props.labelsProp, 'multi_select');
|
|
49
|
+
return labels?.includes(requiredLabel);
|
|
50
|
+
})
|
|
51
|
+
: hitlFiltered;
|
|
52
|
+
return labelFiltered
|
|
53
|
+
.slice(0, 5)
|
|
54
|
+
.map((page) => pageToFetchedTicket(page, props));
|
|
55
|
+
}
|
|
56
|
+
/** Transition a page's status (tries status type, falls back to select). */
|
|
57
|
+
async function doTransition(opts) {
|
|
58
|
+
const { token, ticket, status, statusProp, fetcher } = opts;
|
|
59
|
+
const pageId = ticket.issueId;
|
|
60
|
+
if (!pageId)
|
|
61
|
+
return false;
|
|
62
|
+
const ok = await updatePage({
|
|
63
|
+
token,
|
|
64
|
+
pageId,
|
|
65
|
+
properties: { [statusProp]: { status: { name: status } } },
|
|
66
|
+
fetcher,
|
|
67
|
+
});
|
|
68
|
+
if (ok) {
|
|
69
|
+
console.log(` → Transitioned to ${status}`);
|
|
70
|
+
return true;
|
|
71
|
+
}
|
|
72
|
+
const fallbackOk = await updatePage({
|
|
73
|
+
token,
|
|
74
|
+
pageId,
|
|
75
|
+
properties: { [statusProp]: { select: { name: status } } },
|
|
76
|
+
fetcher,
|
|
77
|
+
});
|
|
78
|
+
if (fallbackOk)
|
|
79
|
+
console.log(` → Transitioned to ${status}`);
|
|
80
|
+
return fallbackOk;
|
|
81
|
+
}
|
|
82
|
+
/** Build transition opts from context and props. */
|
|
83
|
+
function buildTransitionOpts(ctx, props) {
|
|
84
|
+
return {
|
|
85
|
+
token: ctx.token,
|
|
86
|
+
statusProp: props.statusProp,
|
|
87
|
+
fetcher: ctx.fetcher,
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
/** Build connection context from env. */
|
|
91
|
+
function buildCtx(env, fetcher) {
|
|
92
|
+
return {
|
|
93
|
+
token: env.NOTION_TOKEN,
|
|
94
|
+
databaseId: env.NOTION_DATABASE_ID,
|
|
95
|
+
fetcher,
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
/** Resolve property names from env with defaults. */
|
|
99
|
+
function buildProps(env) {
|
|
100
|
+
return {
|
|
101
|
+
statusProp: env.CLANCY_NOTION_STATUS ?? DEFAULTS.status,
|
|
102
|
+
labelsProp: env.CLANCY_NOTION_LABELS ?? DEFAULTS.labels,
|
|
103
|
+
parentProp: env.CLANCY_NOTION_PARENT ?? DEFAULTS.parent,
|
|
104
|
+
todoName: env.CLANCY_NOTION_TODO ?? DEFAULTS.todo,
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
/**
|
|
108
|
+
* Create a Board implementation for Notion.
|
|
109
|
+
*
|
|
110
|
+
* @param env - The validated Notion environment variables.
|
|
111
|
+
* @param fetcher - Optional custom fetch function for DI in tests.
|
|
112
|
+
* @returns A Board object that delegates to Notion API functions.
|
|
113
|
+
*/
|
|
114
|
+
export function createNotionBoard(env, fetcher) {
|
|
115
|
+
const ctx = buildCtx(env, fetcher);
|
|
116
|
+
const props = buildProps(env);
|
|
117
|
+
const transitionOpts = buildTransitionOpts(ctx, props);
|
|
118
|
+
const doFetch = (fetchOpts) => fetchNotionTickets({
|
|
119
|
+
ctx,
|
|
120
|
+
fetchOpts,
|
|
121
|
+
props,
|
|
122
|
+
defaultLabel: env.CLANCY_LABEL,
|
|
123
|
+
});
|
|
124
|
+
return {
|
|
125
|
+
ping: () => pingNotion(ctx.token, ctx.fetcher),
|
|
126
|
+
validateInputs() {
|
|
127
|
+
if (!UUID_PATTERN.test(env.NOTION_DATABASE_ID)) {
|
|
128
|
+
return '✗ NOTION_DATABASE_ID does not look like a valid UUID';
|
|
129
|
+
}
|
|
130
|
+
return undefined;
|
|
131
|
+
},
|
|
132
|
+
fetchTicket: async (opts) => (await doFetch(opts))[0],
|
|
133
|
+
fetchTickets: doFetch,
|
|
134
|
+
fetchBlockerStatus: (ticket) => ticket.issueId
|
|
135
|
+
? fetchBlockerStatus({
|
|
136
|
+
ctx,
|
|
137
|
+
pageId: ticket.issueId,
|
|
138
|
+
statusProp: props.statusProp,
|
|
139
|
+
})
|
|
140
|
+
: Promise.resolve(false),
|
|
141
|
+
fetchChildrenStatus: (parentKey) => fetchChildrenStatus({
|
|
142
|
+
ctx,
|
|
143
|
+
parentKey,
|
|
144
|
+
parentProp: props.parentProp,
|
|
145
|
+
statusProp: props.statusProp,
|
|
146
|
+
}),
|
|
147
|
+
transitionTicket: (ticket, status) => doTransition({ ...transitionOpts, ticket, status }),
|
|
148
|
+
ensureLabel: async () => {
|
|
149
|
+
// No-op — Notion multi_select options auto-create on first PATCH.
|
|
150
|
+
},
|
|
151
|
+
addLabel: (issueKey, label) => addLabel({ ctx, issueKey, label, labelsProp: props.labelsProp }),
|
|
152
|
+
removeLabel: (issueKey, label) => removeLabel({ ctx, issueKey, label, labelsProp: props.labelsProp }),
|
|
153
|
+
sharedEnv: () => env,
|
|
154
|
+
};
|
|
155
|
+
}
|
|
156
|
+
//# sourceMappingURL=notion-board.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"notion-board.js","sourceRoot":"","sources":["../../../src/board/notion/notion-board.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/board/notion/relations/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/board/notion/relations/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Notion page relationship functions.
|
|
3
|
+
*
|
|
4
|
+
* Checks blocker status (via "Blocked by" relation + description text)
|
|
5
|
+
* and children status (dual-mode: description text + relation property).
|
|
6
|
+
*/
|
|
7
|
+
import type { NotionCtx } from '../api/index.js';
|
|
8
|
+
import type { ChildrenStatus } from '../../../types/index.js';
|
|
9
|
+
/** Options for {@link fetchBlockerStatus}. */
|
|
10
|
+
type BlockerStatusOpts = {
|
|
11
|
+
readonly ctx: NotionCtx;
|
|
12
|
+
readonly pageId: string;
|
|
13
|
+
readonly statusProp: string;
|
|
14
|
+
};
|
|
15
|
+
/**
|
|
16
|
+
* Check whether a Notion page is blocked by unresolved blockers.
|
|
17
|
+
*
|
|
18
|
+
* Checks "Blocked by" relation property first, then falls back to
|
|
19
|
+
* description text search for "Blocked by notion-{shortId}" references.
|
|
20
|
+
*
|
|
21
|
+
* @param opts - Connection context, page ID, and status property name.
|
|
22
|
+
* @returns `true` if any blocker is unresolved, `false` otherwise.
|
|
23
|
+
*/
|
|
24
|
+
export declare function fetchBlockerStatus(opts: BlockerStatusOpts): Promise<boolean>;
|
|
25
|
+
/** Options for {@link fetchChildrenStatus}. */
|
|
26
|
+
type ChildrenStatusOpts = {
|
|
27
|
+
readonly ctx: NotionCtx;
|
|
28
|
+
readonly parentKey: string;
|
|
29
|
+
readonly parentProp: string;
|
|
30
|
+
readonly statusProp: string;
|
|
31
|
+
};
|
|
32
|
+
/**
|
|
33
|
+
* Fetch the children status of a parent page (dual-mode).
|
|
34
|
+
*
|
|
35
|
+
* Mode 1: Search descriptions for `Epic: notion-{shortId}` text.
|
|
36
|
+
* Mode 2: Query by parent relation property as fallback.
|
|
37
|
+
*
|
|
38
|
+
* @param opts - Connection context, parent key, and property names.
|
|
39
|
+
* @returns The children status, or `undefined` on failure.
|
|
40
|
+
*/
|
|
41
|
+
export declare function fetchChildrenStatus(opts: ChildrenStatusOpts): Promise<ChildrenStatus | undefined>;
|
|
42
|
+
export {};
|
|
43
|
+
//# sourceMappingURL=relations.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"relations.d.ts","sourceRoot":"","sources":["../../../../src/board/notion/relations/relations.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAEjD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAsBzD,8CAA8C;AAC9C,KAAK,iBAAiB,GAAG;IACvB,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC;IACxB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;CAC7B,CAAC;AAEF;;;;;;;;GAQG;AACH,wBAAsB,kBAAkB,CACtC,IAAI,EAAE,iBAAiB,GACtB,OAAO,CAAC,OAAO,CAAC,CAclB;AAiED,+CAA+C;AAC/C,KAAK,kBAAkB,GAAG;IACxB,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC;IACxB,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;CAC7B,CAAC;AAEF;;;;;;;;GAQG;AACH,wBAAsB,mBAAmB,CACvC,IAAI,EAAE,kBAAkB,GACvB,OAAO,CAAC,cAAc,GAAG,SAAS,CAAC,CAwBrC"}
|