@qotaq/lalphgram 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/Events/package.json +6 -0
- package/LICENSE +21 -0
- package/Main/package.json +6 -0
- package/README.md +1 -0
- package/dist/cjs/Events.js +55 -0
- package/dist/cjs/Events.js.map +1 -0
- package/dist/cjs/LalphMain.js +59 -0
- package/dist/cjs/LalphMain.js.map +1 -0
- package/dist/cjs/Main.js +115 -0
- package/dist/cjs/Main.js.map +1 -0
- package/dist/cjs/index.js +281 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/lib/AnalysisPrompts.js +61 -0
- package/dist/cjs/lib/AnalysisPrompts.js.map +1 -0
- package/dist/cjs/lib/BranchParser.js +45 -0
- package/dist/cjs/lib/BranchParser.js.map +1 -0
- package/dist/cjs/lib/MermaidToPlantUml.js +96 -0
- package/dist/cjs/lib/MermaidToPlantUml.js.map +1 -0
- package/dist/cjs/lib/SpecHtmlGenerator.js +160 -0
- package/dist/cjs/lib/SpecHtmlGenerator.js.map +1 -0
- package/dist/cjs/lib/StreamJsonParser.js +88 -0
- package/dist/cjs/lib/StreamJsonParser.js.map +1 -0
- package/dist/cjs/lib/TelegramFormatter.js +122 -0
- package/dist/cjs/lib/TelegramFormatter.js.map +1 -0
- package/dist/cjs/lib/TelegraphHtml.js +65 -0
- package/dist/cjs/lib/TelegraphHtml.js.map +1 -0
- package/dist/cjs/lib/TelegraphMarkdown.js +346 -0
- package/dist/cjs/lib/TelegraphMarkdown.js.map +1 -0
- package/dist/cjs/schemas/CredentialSchemas.js +31 -0
- package/dist/cjs/schemas/CredentialSchemas.js.map +1 -0
- package/dist/cjs/schemas/GitHubSchemas.js +60 -0
- package/dist/cjs/schemas/GitHubSchemas.js.map +1 -0
- package/dist/cjs/schemas/LinearSchemas.js +63 -0
- package/dist/cjs/schemas/LinearSchemas.js.map +1 -0
- package/dist/cjs/schemas/ProjectSchemas.js +26 -0
- package/dist/cjs/schemas/ProjectSchemas.js.map +1 -0
- package/dist/cjs/schemas/TrackerSchemas.js +35 -0
- package/dist/cjs/schemas/TrackerSchemas.js.map +1 -0
- package/dist/cjs/services/AppContext.js +57 -0
- package/dist/cjs/services/AppContext.js.map +1 -0
- package/dist/cjs/services/AppRuntimeConfig.js +35 -0
- package/dist/cjs/services/AppRuntimeConfig.js.map +1 -0
- package/dist/cjs/services/AutoMerge.js +140 -0
- package/dist/cjs/services/AutoMerge.js.map +1 -0
- package/dist/cjs/services/ChatMachine.js +873 -0
- package/dist/cjs/services/ChatMachine.js.map +1 -0
- package/dist/cjs/services/CommentTimer.js +81 -0
- package/dist/cjs/services/CommentTimer.js.map +1 -0
- package/dist/cjs/services/CredentialStore.js +68 -0
- package/dist/cjs/services/CredentialStore.js.map +1 -0
- package/dist/cjs/services/CredentialWatcher.js +76 -0
- package/dist/cjs/services/CredentialWatcher.js.map +1 -0
- package/dist/cjs/services/Credentials.js +130 -0
- package/dist/cjs/services/Credentials.js.map +1 -0
- package/dist/cjs/services/EventLoop.js +203 -0
- package/dist/cjs/services/EventLoop.js.map +1 -0
- package/dist/cjs/services/GitHubClient/GitHubClient.js +236 -0
- package/dist/cjs/services/GitHubClient/GitHubClient.js.map +1 -0
- package/dist/cjs/services/GitHubClient/OctokitClient.js +329 -0
- package/dist/cjs/services/GitHubClient/OctokitClient.js.map +1 -0
- package/dist/cjs/services/GitHubClient.js +236 -0
- package/dist/cjs/services/GitHubClient.js.map +1 -0
- package/dist/cjs/services/GitHubEventSource.js +145 -0
- package/dist/cjs/services/GitHubEventSource.js.map +1 -0
- package/dist/cjs/services/GitHubIssueTracker.js +118 -0
- package/dist/cjs/services/GitHubIssueTracker.js.map +1 -0
- package/dist/cjs/services/LalphConfig.js +139 -0
- package/dist/cjs/services/LalphConfig.js.map +1 -0
- package/dist/cjs/services/LalphConfigReader.js +82 -0
- package/dist/cjs/services/LalphConfigReader.js.map +1 -0
- package/dist/cjs/services/LalphDirectory.js +45 -0
- package/dist/cjs/services/LalphDirectory.js.map +1 -0
- package/dist/cjs/services/LinearSdkClient.js +149 -0
- package/dist/cjs/services/LinearSdkClient.js.map +1 -0
- package/dist/cjs/services/LinearTracker.js +89 -0
- package/dist/cjs/services/LinearTracker.js.map +1 -0
- package/dist/cjs/services/MessengerAdapter/MessengerAdapter.js +30 -0
- package/dist/cjs/services/MessengerAdapter/MessengerAdapter.js.map +1 -0
- package/dist/cjs/services/MessengerAdapter/TelegramAdapter.js +131 -0
- package/dist/cjs/services/MessengerAdapter/TelegramAdapter.js.map +1 -0
- package/dist/cjs/services/MessengerAdapter/TelegramConfig.js +81 -0
- package/dist/cjs/services/MessengerAdapter/TelegramConfig.js.map +1 -0
- package/dist/cjs/services/MessengerAdapter.js +30 -0
- package/dist/cjs/services/MessengerAdapter.js.map +1 -0
- package/dist/cjs/services/OctokitClient.js +350 -0
- package/dist/cjs/services/OctokitClient.js.map +1 -0
- package/dist/cjs/services/PlanOverviewUploader.js +119 -0
- package/dist/cjs/services/PlanOverviewUploader.js.map +1 -0
- package/dist/cjs/services/PlanOverviewUploaderMap.js +25 -0
- package/dist/cjs/services/PlanOverviewUploaderMap.js.map +1 -0
- package/dist/cjs/services/PlanSession.js +489 -0
- package/dist/cjs/services/PlanSession.js.map +1 -0
- package/dist/cjs/services/ProjectStore.js +107 -0
- package/dist/cjs/services/ProjectStore.js.map +1 -0
- package/dist/cjs/services/PullRequestTracker.js +186 -0
- package/dist/cjs/services/PullRequestTracker.js.map +1 -0
- package/dist/cjs/services/SpecUploader.js +111 -0
- package/dist/cjs/services/SpecUploader.js.map +1 -0
- package/dist/cjs/services/SpecUploaderMap.js +25 -0
- package/dist/cjs/services/SpecUploaderMap.js.map +1 -0
- package/dist/cjs/services/TaskEventSource.js +58 -0
- package/dist/cjs/services/TaskEventSource.js.map +1 -0
- package/dist/cjs/services/TaskTracker/GitHubIssueTracker.js +155 -0
- package/dist/cjs/services/TaskTracker/GitHubIssueTracker.js.map +1 -0
- package/dist/cjs/services/TaskTracker/LinearSdkClient.js +149 -0
- package/dist/cjs/services/TaskTracker/LinearSdkClient.js.map +1 -0
- package/dist/cjs/services/TaskTracker/LinearTracker.js +126 -0
- package/dist/cjs/services/TaskTracker/LinearTracker.js.map +1 -0
- package/dist/cjs/services/TaskTracker/TaskTracker.js +20 -0
- package/dist/cjs/services/TaskTracker/TaskTracker.js.map +1 -0
- package/dist/cjs/services/TaskTracker/TrackerLayerMap.js +27 -0
- package/dist/cjs/services/TaskTracker/TrackerLayerMap.js.map +1 -0
- package/dist/cjs/services/TaskTracker/buildEventStream.js +55 -0
- package/dist/cjs/services/TaskTracker/buildEventStream.js.map +1 -0
- package/dist/cjs/services/TaskTracker.js +20 -0
- package/dist/cjs/services/TaskTracker.js.map +1 -0
- package/dist/cjs/services/TelegramAdapter.js +125 -0
- package/dist/cjs/services/TelegramAdapter.js.map +1 -0
- package/dist/cjs/services/TelegramConfig.js +81 -0
- package/dist/cjs/services/TelegramConfig.js.map +1 -0
- package/dist/cjs/services/TelegramConfigStore.js +81 -0
- package/dist/cjs/services/TelegramConfigStore.js.map +1 -0
- package/dist/cjs/services/TelegramNotifier.js +50 -0
- package/dist/cjs/services/TelegramNotifier.js.map +1 -0
- package/dist/cjs/services/TrackerLayerMap.js +27 -0
- package/dist/cjs/services/TrackerLayerMap.js.map +1 -0
- package/dist/cjs/services/TrackerResolver.js +45 -0
- package/dist/cjs/services/TrackerResolver.js.map +1 -0
- package/dist/cjs/services/messenger/MessengerAdapter.js +30 -0
- package/dist/cjs/services/messenger/MessengerAdapter.js.map +1 -0
- package/dist/cjs/services/messenger/TelegramAdapter.js +125 -0
- package/dist/cjs/services/messenger/TelegramAdapter.js.map +1 -0
- package/dist/cjs/services/task-tracker/GitHubIssueTracker.js +157 -0
- package/dist/cjs/services/task-tracker/GitHubIssueTracker.js.map +1 -0
- package/dist/cjs/services/task-tracker/LinearTracker.js +127 -0
- package/dist/cjs/services/task-tracker/LinearTracker.js.map +1 -0
- package/dist/cjs/services/task-tracker/TaskTracker.js +20 -0
- package/dist/cjs/services/task-tracker/TaskTracker.js.map +1 -0
- package/dist/cjs/services/task-tracker/TrackerLayerMap.js +27 -0
- package/dist/cjs/services/task-tracker/TrackerLayerMap.js.map +1 -0
- package/dist/cjs/shim/bin.js +31 -0
- package/dist/cjs/shim/bin.js.map +1 -0
- package/dist/cjs/shim/main.js +217 -0
- package/dist/cjs/shim/main.js.map +1 -0
- package/dist/cjs/shim/parseArgs.js +45 -0
- package/dist/cjs/shim/parseArgs.js.map +1 -0
- package/dist/cjs/shim/schemas.js +35 -0
- package/dist/cjs/shim/schemas.js.map +1 -0
- package/dist/dts/Events.d.ts +108 -0
- package/dist/dts/Events.d.ts.map +1 -0
- package/dist/dts/LalphMain.d.ts +2 -0
- package/dist/dts/LalphMain.d.ts.map +1 -0
- package/dist/dts/Main.d.ts +2 -0
- package/dist/dts/Main.d.ts.map +1 -0
- package/dist/dts/index.d.ts +101 -0
- package/dist/dts/index.d.ts.map +1 -0
- package/dist/dts/lib/AnalysisPrompts.d.ts +12 -0
- package/dist/dts/lib/AnalysisPrompts.d.ts.map +1 -0
- package/dist/dts/lib/BranchParser.d.ts +40 -0
- package/dist/dts/lib/BranchParser.d.ts.map +1 -0
- package/dist/dts/lib/MermaidToPlantUml.d.ts +19 -0
- package/dist/dts/lib/MermaidToPlantUml.d.ts.map +1 -0
- package/dist/dts/lib/SpecHtmlGenerator.d.ts +18 -0
- package/dist/dts/lib/SpecHtmlGenerator.d.ts.map +1 -0
- package/dist/dts/lib/StreamJsonParser.d.ts +147 -0
- package/dist/dts/lib/StreamJsonParser.d.ts.map +1 -0
- package/dist/dts/lib/TelegramFormatter.d.ts +35 -0
- package/dist/dts/lib/TelegramFormatter.d.ts.map +1 -0
- package/dist/dts/lib/TelegraphHtml.d.ts +11 -0
- package/dist/dts/lib/TelegraphHtml.d.ts.map +1 -0
- package/dist/dts/lib/TelegraphMarkdown.d.ts +21 -0
- package/dist/dts/lib/TelegraphMarkdown.d.ts.map +1 -0
- package/dist/dts/schemas/CredentialSchemas.d.ts +41 -0
- package/dist/dts/schemas/CredentialSchemas.d.ts.map +1 -0
- package/dist/dts/schemas/GitHubSchemas.d.ts +130 -0
- package/dist/dts/schemas/GitHubSchemas.d.ts.map +1 -0
- package/dist/dts/schemas/LinearSchemas.d.ts +121 -0
- package/dist/dts/schemas/LinearSchemas.d.ts.map +1 -0
- package/dist/dts/schemas/ProjectSchemas.d.ts +40 -0
- package/dist/dts/schemas/ProjectSchemas.d.ts.map +1 -0
- package/dist/dts/schemas/TrackerSchemas.d.ts +57 -0
- package/dist/dts/schemas/TrackerSchemas.d.ts.map +1 -0
- package/dist/dts/services/AppContext.d.ts +40 -0
- package/dist/dts/services/AppContext.d.ts.map +1 -0
- package/dist/dts/services/AppRuntimeConfig.d.ts +51 -0
- package/dist/dts/services/AppRuntimeConfig.d.ts.map +1 -0
- package/dist/dts/services/AutoMerge.d.ts +42 -0
- package/dist/dts/services/AutoMerge.d.ts.map +1 -0
- package/dist/dts/services/ChatMachine.d.ts +478 -0
- package/dist/dts/services/ChatMachine.d.ts.map +1 -0
- package/dist/dts/services/CommentTimer.d.ts +44 -0
- package/dist/dts/services/CommentTimer.d.ts.map +1 -0
- package/dist/dts/services/CredentialStore.d.ts +43 -0
- package/dist/dts/services/CredentialStore.d.ts.map +1 -0
- package/dist/dts/services/CredentialWatcher.d.ts +41 -0
- package/dist/dts/services/CredentialWatcher.d.ts.map +1 -0
- package/dist/dts/services/Credentials.d.ts +44 -0
- package/dist/dts/services/Credentials.d.ts.map +1 -0
- package/dist/dts/services/EventLoop.d.ts +26 -0
- package/dist/dts/services/EventLoop.d.ts.map +1 -0
- package/dist/dts/services/GitHubClient/GitHubClient.d.ts +69 -0
- package/dist/dts/services/GitHubClient/GitHubClient.d.ts.map +1 -0
- package/dist/dts/services/GitHubClient/OctokitClient.d.ts +214 -0
- package/dist/dts/services/GitHubClient/OctokitClient.d.ts.map +1 -0
- package/dist/dts/services/GitHubClient.d.ts +69 -0
- package/dist/dts/services/GitHubClient.d.ts.map +1 -0
- package/dist/dts/services/GitHubEventSource.d.ts +43 -0
- package/dist/dts/services/GitHubEventSource.d.ts.map +1 -0
- package/dist/dts/services/GitHubIssueTracker.d.ts +9 -0
- package/dist/dts/services/GitHubIssueTracker.d.ts.map +1 -0
- package/dist/dts/services/LalphConfig.d.ts +44 -0
- package/dist/dts/services/LalphConfig.d.ts.map +1 -0
- package/dist/dts/services/LalphConfigReader.d.ts +66 -0
- package/dist/dts/services/LalphConfigReader.d.ts.map +1 -0
- package/dist/dts/services/LalphDirectory.d.ts +39 -0
- package/dist/dts/services/LalphDirectory.d.ts.map +1 -0
- package/dist/dts/services/LinearSdkClient.d.ts +71 -0
- package/dist/dts/services/LinearSdkClient.d.ts.map +1 -0
- package/dist/dts/services/LinearTracker.d.ts +9 -0
- package/dist/dts/services/LinearTracker.d.ts.map +1 -0
- package/dist/dts/services/MessengerAdapter/MessengerAdapter.d.ts +69 -0
- package/dist/dts/services/MessengerAdapter/MessengerAdapter.d.ts.map +1 -0
- package/dist/dts/services/MessengerAdapter/TelegramAdapter.d.ts +13 -0
- package/dist/dts/services/MessengerAdapter/TelegramAdapter.d.ts.map +1 -0
- package/dist/dts/services/MessengerAdapter/TelegramConfig.d.ts +58 -0
- package/dist/dts/services/MessengerAdapter/TelegramConfig.d.ts.map +1 -0
- package/dist/dts/services/MessengerAdapter.d.ts +69 -0
- package/dist/dts/services/MessengerAdapter.d.ts.map +1 -0
- package/dist/dts/services/OctokitClient.d.ts +232 -0
- package/dist/dts/services/OctokitClient.d.ts.map +1 -0
- package/dist/dts/services/PlanOverviewUploader.d.ts +55 -0
- package/dist/dts/services/PlanOverviewUploader.d.ts.map +1 -0
- package/dist/dts/services/PlanOverviewUploaderMap.d.ts +14 -0
- package/dist/dts/services/PlanOverviewUploaderMap.d.ts.map +1 -0
- package/dist/dts/services/PlanSession.d.ts +169 -0
- package/dist/dts/services/PlanSession.d.ts.map +1 -0
- package/dist/dts/services/ProjectStore.d.ts +50 -0
- package/dist/dts/services/ProjectStore.d.ts.map +1 -0
- package/dist/dts/services/PullRequestTracker.d.ts +42 -0
- package/dist/dts/services/PullRequestTracker.d.ts.map +1 -0
- package/dist/dts/services/SpecUploader.d.ts +51 -0
- package/dist/dts/services/SpecUploader.d.ts.map +1 -0
- package/dist/dts/services/SpecUploaderMap.d.ts +14 -0
- package/dist/dts/services/SpecUploaderMap.d.ts.map +1 -0
- package/dist/dts/services/TaskEventSource.d.ts +21 -0
- package/dist/dts/services/TaskEventSource.d.ts.map +1 -0
- package/dist/dts/services/TaskTracker/GitHubIssueTracker.d.ts +10 -0
- package/dist/dts/services/TaskTracker/GitHubIssueTracker.d.ts.map +1 -0
- package/dist/dts/services/TaskTracker/LinearSdkClient.d.ts +71 -0
- package/dist/dts/services/TaskTracker/LinearSdkClient.d.ts.map +1 -0
- package/dist/dts/services/TaskTracker/LinearTracker.d.ts +10 -0
- package/dist/dts/services/TaskTracker/LinearTracker.d.ts.map +1 -0
- package/dist/dts/services/TaskTracker/TaskTracker.d.ts +39 -0
- package/dist/dts/services/TaskTracker/TaskTracker.d.ts.map +1 -0
- package/dist/dts/services/TaskTracker/TrackerLayerMap.d.ts +14 -0
- package/dist/dts/services/TaskTracker/TrackerLayerMap.d.ts.map +1 -0
- package/dist/dts/services/TaskTracker/buildEventStream.d.ts +16 -0
- package/dist/dts/services/TaskTracker/buildEventStream.d.ts.map +1 -0
- package/dist/dts/services/TaskTracker.d.ts +38 -0
- package/dist/dts/services/TaskTracker.d.ts.map +1 -0
- package/dist/dts/services/TelegramAdapter.d.ts +13 -0
- package/dist/dts/services/TelegramAdapter.d.ts.map +1 -0
- package/dist/dts/services/TelegramConfig.d.ts +58 -0
- package/dist/dts/services/TelegramConfig.d.ts.map +1 -0
- package/dist/dts/services/TelegramConfigStore.d.ts +57 -0
- package/dist/dts/services/TelegramConfigStore.d.ts.map +1 -0
- package/dist/dts/services/TelegramNotifier.d.ts +40 -0
- package/dist/dts/services/TelegramNotifier.d.ts.map +1 -0
- package/dist/dts/services/TrackerLayerMap.d.ts +14 -0
- package/dist/dts/services/TrackerLayerMap.d.ts.map +1 -0
- package/dist/dts/services/TrackerResolver.d.ts +43 -0
- package/dist/dts/services/TrackerResolver.d.ts.map +1 -0
- package/dist/dts/services/messenger/MessengerAdapter.d.ts +69 -0
- package/dist/dts/services/messenger/MessengerAdapter.d.ts.map +1 -0
- package/dist/dts/services/messenger/TelegramAdapter.d.ts +13 -0
- package/dist/dts/services/messenger/TelegramAdapter.d.ts.map +1 -0
- package/dist/dts/services/task-tracker/GitHubIssueTracker.d.ts +10 -0
- package/dist/dts/services/task-tracker/GitHubIssueTracker.d.ts.map +1 -0
- package/dist/dts/services/task-tracker/LinearTracker.d.ts +10 -0
- package/dist/dts/services/task-tracker/LinearTracker.d.ts.map +1 -0
- package/dist/dts/services/task-tracker/TaskTracker.d.ts +38 -0
- package/dist/dts/services/task-tracker/TaskTracker.d.ts.map +1 -0
- package/dist/dts/services/task-tracker/TrackerLayerMap.d.ts +14 -0
- package/dist/dts/services/task-tracker/TrackerLayerMap.d.ts.map +1 -0
- package/dist/dts/shim/bin.d.ts +3 -0
- package/dist/dts/shim/bin.d.ts.map +1 -0
- package/dist/dts/shim/main.d.ts +36 -0
- package/dist/dts/shim/main.d.ts.map +1 -0
- package/dist/dts/shim/parseArgs.d.ts +11 -0
- package/dist/dts/shim/parseArgs.d.ts.map +1 -0
- package/dist/dts/shim/schemas.d.ts +55 -0
- package/dist/dts/shim/schemas.d.ts.map +1 -0
- package/dist/esm/Events.js +41 -0
- package/dist/esm/Events.js.map +1 -0
- package/dist/esm/LalphMain.js +56 -0
- package/dist/esm/LalphMain.js.map +1 -0
- package/dist/esm/Main.js +112 -0
- package/dist/esm/Main.js.map +1 -0
- package/dist/esm/index.js +101 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/lib/AnalysisPrompts.js +54 -0
- package/dist/esm/lib/AnalysisPrompts.js.map +1 -0
- package/dist/esm/lib/BranchParser.js +36 -0
- package/dist/esm/lib/BranchParser.js.map +1 -0
- package/dist/esm/lib/MermaidToPlantUml.js +89 -0
- package/dist/esm/lib/MermaidToPlantUml.js.map +1 -0
- package/dist/esm/lib/SpecHtmlGenerator.js +153 -0
- package/dist/esm/lib/SpecHtmlGenerator.js.map +1 -0
- package/dist/esm/lib/StreamJsonParser.js +79 -0
- package/dist/esm/lib/StreamJsonParser.js.map +1 -0
- package/dist/esm/lib/TelegramFormatter.js +114 -0
- package/dist/esm/lib/TelegramFormatter.js.map +1 -0
- package/dist/esm/lib/TelegraphHtml.js +57 -0
- package/dist/esm/lib/TelegraphHtml.js.map +1 -0
- package/dist/esm/lib/TelegraphMarkdown.js +338 -0
- package/dist/esm/lib/TelegraphMarkdown.js.map +1 -0
- package/dist/esm/package.json +4 -0
- package/dist/esm/schemas/CredentialSchemas.js +22 -0
- package/dist/esm/schemas/CredentialSchemas.js.map +1 -0
- package/dist/esm/schemas/GitHubSchemas.js +50 -0
- package/dist/esm/schemas/GitHubSchemas.js.map +1 -0
- package/dist/esm/schemas/LinearSchemas.js +52 -0
- package/dist/esm/schemas/LinearSchemas.js.map +1 -0
- package/dist/esm/schemas/ProjectSchemas.js +18 -0
- package/dist/esm/schemas/ProjectSchemas.js.map +1 -0
- package/dist/esm/schemas/TrackerSchemas.js +26 -0
- package/dist/esm/schemas/TrackerSchemas.js.map +1 -0
- package/dist/esm/services/AppContext.js +48 -0
- package/dist/esm/services/AppContext.js.map +1 -0
- package/dist/esm/services/AppRuntimeConfig.js +26 -0
- package/dist/esm/services/AppRuntimeConfig.js.map +1 -0
- package/dist/esm/services/AutoMerge.js +131 -0
- package/dist/esm/services/AutoMerge.js.map +1 -0
- package/dist/esm/services/ChatMachine.js +855 -0
- package/dist/esm/services/ChatMachine.js.map +1 -0
- package/dist/esm/services/CommentTimer.js +72 -0
- package/dist/esm/services/CommentTimer.js.map +1 -0
- package/dist/esm/services/CredentialStore.js +59 -0
- package/dist/esm/services/CredentialStore.js.map +1 -0
- package/dist/esm/services/CredentialWatcher.js +67 -0
- package/dist/esm/services/CredentialWatcher.js.map +1 -0
- package/dist/esm/services/Credentials.js +121 -0
- package/dist/esm/services/Credentials.js.map +1 -0
- package/dist/esm/services/EventLoop.js +128 -0
- package/dist/esm/services/EventLoop.js.map +1 -0
- package/dist/esm/services/GitHubClient/GitHubClient.js +227 -0
- package/dist/esm/services/GitHubClient/GitHubClient.js.map +1 -0
- package/dist/esm/services/GitHubClient/OctokitClient.js +320 -0
- package/dist/esm/services/GitHubClient/OctokitClient.js.map +1 -0
- package/dist/esm/services/GitHubClient.js +227 -0
- package/dist/esm/services/GitHubClient.js.map +1 -0
- package/dist/esm/services/GitHubEventSource.js +136 -0
- package/dist/esm/services/GitHubEventSource.js.map +1 -0
- package/dist/esm/services/GitHubIssueTracker.js +111 -0
- package/dist/esm/services/GitHubIssueTracker.js.map +1 -0
- package/dist/esm/services/LalphConfig.js +130 -0
- package/dist/esm/services/LalphConfig.js.map +1 -0
- package/dist/esm/services/LalphConfigReader.js +71 -0
- package/dist/esm/services/LalphConfigReader.js.map +1 -0
- package/dist/esm/services/LalphDirectory.js +36 -0
- package/dist/esm/services/LalphDirectory.js.map +1 -0
- package/dist/esm/services/LinearSdkClient.js +140 -0
- package/dist/esm/services/LinearSdkClient.js.map +1 -0
- package/dist/esm/services/LinearTracker.js +82 -0
- package/dist/esm/services/LinearTracker.js.map +1 -0
- package/dist/esm/services/MessengerAdapter/MessengerAdapter.js +21 -0
- package/dist/esm/services/MessengerAdapter/MessengerAdapter.js.map +1 -0
- package/dist/esm/services/MessengerAdapter/TelegramAdapter.js +124 -0
- package/dist/esm/services/MessengerAdapter/TelegramAdapter.js.map +1 -0
- package/dist/esm/services/MessengerAdapter/TelegramConfig.js +71 -0
- package/dist/esm/services/MessengerAdapter/TelegramConfig.js.map +1 -0
- package/dist/esm/services/MessengerAdapter.js +21 -0
- package/dist/esm/services/MessengerAdapter.js.map +1 -0
- package/dist/esm/services/OctokitClient.js +341 -0
- package/dist/esm/services/OctokitClient.js.map +1 -0
- package/dist/esm/services/PlanOverviewUploader.js +109 -0
- package/dist/esm/services/PlanOverviewUploader.js.map +1 -0
- package/dist/esm/services/PlanOverviewUploaderMap.js +17 -0
- package/dist/esm/services/PlanOverviewUploaderMap.js.map +1 -0
- package/dist/esm/services/PlanSession.js +471 -0
- package/dist/esm/services/PlanSession.js.map +1 -0
- package/dist/esm/services/ProjectStore.js +98 -0
- package/dist/esm/services/ProjectStore.js.map +1 -0
- package/dist/esm/services/PullRequestTracker.js +177 -0
- package/dist/esm/services/PullRequestTracker.js.map +1 -0
- package/dist/esm/services/SpecUploader.js +101 -0
- package/dist/esm/services/SpecUploader.js.map +1 -0
- package/dist/esm/services/SpecUploaderMap.js +17 -0
- package/dist/esm/services/SpecUploaderMap.js.map +1 -0
- package/dist/esm/services/TaskEventSource.js +50 -0
- package/dist/esm/services/TaskEventSource.js.map +1 -0
- package/dist/esm/services/TaskTracker/GitHubIssueTracker.js +148 -0
- package/dist/esm/services/TaskTracker/GitHubIssueTracker.js.map +1 -0
- package/dist/esm/services/TaskTracker/LinearSdkClient.js +140 -0
- package/dist/esm/services/TaskTracker/LinearSdkClient.js.map +1 -0
- package/dist/esm/services/TaskTracker/LinearTracker.js +119 -0
- package/dist/esm/services/TaskTracker/LinearTracker.js.map +1 -0
- package/dist/esm/services/TaskTracker/TaskTracker.js +12 -0
- package/dist/esm/services/TaskTracker/TaskTracker.js.map +1 -0
- package/dist/esm/services/TaskTracker/TrackerLayerMap.js +19 -0
- package/dist/esm/services/TaskTracker/TrackerLayerMap.js.map +1 -0
- package/dist/esm/services/TaskTracker/buildEventStream.js +47 -0
- package/dist/esm/services/TaskTracker/buildEventStream.js.map +1 -0
- package/dist/esm/services/TaskTracker.js +12 -0
- package/dist/esm/services/TaskTracker.js.map +1 -0
- package/dist/esm/services/TelegramAdapter.js +118 -0
- package/dist/esm/services/TelegramAdapter.js.map +1 -0
- package/dist/esm/services/TelegramConfig.js +71 -0
- package/dist/esm/services/TelegramConfig.js.map +1 -0
- package/dist/esm/services/TelegramConfigStore.js +71 -0
- package/dist/esm/services/TelegramConfigStore.js.map +1 -0
- package/dist/esm/services/TelegramNotifier.js +41 -0
- package/dist/esm/services/TelegramNotifier.js.map +1 -0
- package/dist/esm/services/TrackerLayerMap.js +19 -0
- package/dist/esm/services/TrackerLayerMap.js.map +1 -0
- package/dist/esm/services/TrackerResolver.js +36 -0
- package/dist/esm/services/TrackerResolver.js.map +1 -0
- package/dist/esm/services/messenger/MessengerAdapter.js +21 -0
- package/dist/esm/services/messenger/MessengerAdapter.js.map +1 -0
- package/dist/esm/services/messenger/TelegramAdapter.js +118 -0
- package/dist/esm/services/messenger/TelegramAdapter.js.map +1 -0
- package/dist/esm/services/task-tracker/GitHubIssueTracker.js +150 -0
- package/dist/esm/services/task-tracker/GitHubIssueTracker.js.map +1 -0
- package/dist/esm/services/task-tracker/LinearTracker.js +120 -0
- package/dist/esm/services/task-tracker/LinearTracker.js.map +1 -0
- package/dist/esm/services/task-tracker/TaskTracker.js +12 -0
- package/dist/esm/services/task-tracker/TaskTracker.js.map +1 -0
- package/dist/esm/services/task-tracker/TrackerLayerMap.js +19 -0
- package/dist/esm/services/task-tracker/TrackerLayerMap.js.map +1 -0
- package/dist/esm/shim/bin.js +28 -0
- package/dist/esm/shim/bin.js.map +1 -0
- package/dist/esm/shim/main.js +196 -0
- package/dist/esm/shim/main.js.map +1 -0
- package/dist/esm/shim/parseArgs.js +39 -0
- package/dist/esm/shim/parseArgs.js.map +1 -0
- package/dist/esm/shim/schemas.js +28 -0
- package/dist/esm/shim/schemas.js.map +1 -0
- package/lib/AnalysisPrompts/package.json +6 -0
- package/lib/BranchParser/package.json +6 -0
- package/lib/MermaidToPlantUml/package.json +6 -0
- package/lib/SpecHtmlGenerator/package.json +6 -0
- package/lib/StreamJsonParser/package.json +6 -0
- package/lib/TelegramFormatter/package.json +6 -0
- package/lib/TelegraphMarkdown/package.json +6 -0
- package/package.json +360 -0
- package/schemas/CredentialSchemas/package.json +6 -0
- package/schemas/GitHubSchemas/package.json +6 -0
- package/schemas/LinearSchemas/package.json +6 -0
- package/schemas/ProjectSchemas/package.json +6 -0
- package/schemas/TrackerSchemas/package.json +6 -0
- package/services/AppContext/package.json +6 -0
- package/services/AppRuntimeConfig/package.json +6 -0
- package/services/AutoMerge/package.json +6 -0
- package/services/ChatMachine/package.json +6 -0
- package/services/CommentTimer/package.json +6 -0
- package/services/EventLoop/package.json +6 -0
- package/services/GitHubClient/package.json +6 -0
- package/services/LalphConfig/package.json +6 -0
- package/services/LinearSdkClient/package.json +6 -0
- package/services/MessengerAdapter/MessengerAdapter/package.json +6 -0
- package/services/MessengerAdapter/TelegramAdapter/package.json +6 -0
- package/services/OctokitClient/package.json +6 -0
- package/services/PlanOverviewUploader/package.json +6 -0
- package/services/PlanOverviewUploaderMap/package.json +6 -0
- package/services/PlanSession/package.json +6 -0
- package/services/ProjectStore/package.json +6 -0
- package/services/PullRequestTracker/package.json +6 -0
- package/services/TaskTracker/GitHubIssueTracker/package.json +6 -0
- package/services/TaskTracker/LinearTracker/package.json +6 -0
- package/services/TaskTracker/TaskTracker/package.json +6 -0
- package/services/TelegramConfig/package.json +6 -0
- package/services/TrackerLayerMap/package.json +6 -0
- package/shim/bin/package.json +6 -0
- package/shim/main/package.json +6 -0
- package/shim/parseArgs/package.json +6 -0
- package/shim/schemas/package.json +6 -0
- package/src/Events.ts +98 -0
- package/src/Main.ts +177 -0
- package/src/index.ts +124 -0
- package/src/lib/AnalysisPrompts.ts +54 -0
- package/src/lib/BranchParser.ts +58 -0
- package/src/lib/MermaidToPlantUml.ts +103 -0
- package/src/lib/SpecHtmlGenerator.ts +199 -0
- package/src/lib/StreamJsonParser.ts +99 -0
- package/src/lib/TelegramFormatter.ts +151 -0
- package/src/lib/TelegraphMarkdown.ts +305 -0
- package/src/schemas/CredentialSchemas.ts +23 -0
- package/src/schemas/GitHubSchemas.ts +50 -0
- package/src/schemas/LinearSchemas.ts +57 -0
- package/src/schemas/ProjectSchemas.ts +18 -0
- package/src/schemas/TrackerSchemas.ts +27 -0
- package/src/services/AppContext.ts +72 -0
- package/src/services/AppRuntimeConfig.ts +23 -0
- package/src/services/AutoMerge.ts +198 -0
- package/src/services/ChatMachine.ts +911 -0
- package/src/services/CommentTimer.ts +133 -0
- package/src/services/EventLoop.ts +321 -0
- package/src/services/GitHubClient.ts +282 -0
- package/src/services/LalphConfig.ts +218 -0
- package/src/services/LinearSdkClient.ts +181 -0
- package/src/services/MessengerAdapter/MessengerAdapter.ts +53 -0
- package/src/services/MessengerAdapter/TelegramAdapter.ts +145 -0
- package/src/services/OctokitClient.ts +628 -0
- package/src/services/PlanOverviewUploader.ts +160 -0
- package/src/services/PlanOverviewUploaderMap.ts +17 -0
- package/src/services/PlanSession.ts +589 -0
- package/src/services/ProjectStore.ts +140 -0
- package/src/services/PullRequestTracker.ts +253 -0
- package/src/services/TaskTracker/GitHubIssueTracker.ts +162 -0
- package/src/services/TaskTracker/LinearTracker.ts +141 -0
- package/src/services/TaskTracker/TaskTracker.ts +34 -0
- package/src/services/TelegramConfig.ts +120 -0
- package/src/services/TrackerLayerMap.ts +19 -0
- package/src/shim/bin.ts +36 -0
- package/src/shim/main.ts +255 -0
- package/src/shim/parseArgs.ts +43 -0
- package/src/shim/schemas.ts +38 -0
|
@@ -0,0 +1,305 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Converts markdown directly to Telegraph Node array.
|
|
3
|
+
* Two-phase parser: block-level state machine + recursive inline scanner.
|
|
4
|
+
* Skips the lossy HTML intermediate step for better fidelity.
|
|
5
|
+
* @since 1.0.0
|
|
6
|
+
*/
|
|
7
|
+
import type { Node } from "better-telegraph"
|
|
8
|
+
import { deflateSync } from "node:zlib"
|
|
9
|
+
import { mermaidToPlantUml } from "./MermaidToPlantUml.js"
|
|
10
|
+
import type { SpecFile } from "./SpecHtmlGenerator.js"
|
|
11
|
+
|
|
12
|
+
// ---------------------------------------------------------------------------
|
|
13
|
+
// Block types
|
|
14
|
+
// ---------------------------------------------------------------------------
|
|
15
|
+
|
|
16
|
+
type Block =
|
|
17
|
+
| { readonly _tag: "codeBlock"; readonly lang: string | undefined; readonly code: string }
|
|
18
|
+
| { readonly _tag: "heading"; readonly level: number; readonly text: string }
|
|
19
|
+
| { readonly _tag: "hr" }
|
|
20
|
+
| { readonly _tag: "unorderedList"; readonly items: ReadonlyArray<string> }
|
|
21
|
+
| { readonly _tag: "orderedList"; readonly items: ReadonlyArray<string> }
|
|
22
|
+
| { readonly _tag: "blockquote"; readonly text: string }
|
|
23
|
+
| { readonly _tag: "paragraph"; readonly text: string }
|
|
24
|
+
|
|
25
|
+
// ---------------------------------------------------------------------------
|
|
26
|
+
// Block-level parser
|
|
27
|
+
// ---------------------------------------------------------------------------
|
|
28
|
+
|
|
29
|
+
const isBlockStart = (line: string): boolean =>
|
|
30
|
+
/^#{1,6}\s/.test(line) ||
|
|
31
|
+
/^[-*]\s+/.test(line) ||
|
|
32
|
+
/^\d+\.\s+/.test(line) ||
|
|
33
|
+
/^>/.test(line) ||
|
|
34
|
+
/^```/.test(line) ||
|
|
35
|
+
/^(?:---+|\*\*\*+|___+)\s*$/.test(line)
|
|
36
|
+
|
|
37
|
+
const parseBlocks = (markdown: string): ReadonlyArray<Block> => {
|
|
38
|
+
const lines = markdown.split("\n")
|
|
39
|
+
const blocks: Array<Block> = []
|
|
40
|
+
let i = 0
|
|
41
|
+
|
|
42
|
+
while (i < lines.length) {
|
|
43
|
+
const line = lines[i] ?? ""
|
|
44
|
+
|
|
45
|
+
// Code fence
|
|
46
|
+
const fenceMatch = /^```(\w*)/.exec(line)
|
|
47
|
+
if (fenceMatch) {
|
|
48
|
+
const lang = fenceMatch[1] || undefined
|
|
49
|
+
const codeLines: Array<string> = []
|
|
50
|
+
i++
|
|
51
|
+
while (i < lines.length) {
|
|
52
|
+
const codeLine = lines[i] ?? ""
|
|
53
|
+
if (/^```\s*$/.test(codeLine)) break
|
|
54
|
+
codeLines.push(codeLine)
|
|
55
|
+
i++
|
|
56
|
+
}
|
|
57
|
+
blocks.push({ _tag: "codeBlock", lang, code: codeLines.join("\n") })
|
|
58
|
+
if (i < lines.length) i++ // skip closing ```
|
|
59
|
+
continue
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
// Heading
|
|
63
|
+
const headingMatch = /^(#{1,6})\s+(.+)$/.exec(line)
|
|
64
|
+
if (headingMatch) {
|
|
65
|
+
const hashes = headingMatch[1] ?? "#"
|
|
66
|
+
const text = headingMatch[2] ?? ""
|
|
67
|
+
blocks.push({ _tag: "heading", level: hashes.length, text })
|
|
68
|
+
i++
|
|
69
|
+
continue
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
// HR (must come before list check since *** could look like a list start)
|
|
73
|
+
if (/^(?:---+|\*\*\*+|___+)\s*$/.test(line)) {
|
|
74
|
+
blocks.push({ _tag: "hr" })
|
|
75
|
+
i++
|
|
76
|
+
continue
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
// Unordered list
|
|
80
|
+
const ulMatch = /^[-*]\s+(.+)$/.exec(line)
|
|
81
|
+
if (ulMatch) {
|
|
82
|
+
const items: Array<string> = [ulMatch[1] ?? ""]
|
|
83
|
+
i++
|
|
84
|
+
while (i < lines.length) {
|
|
85
|
+
const nextLine = lines[i] ?? ""
|
|
86
|
+
const nextMatch = /^[-*]\s+(.+)$/.exec(nextLine)
|
|
87
|
+
if (!nextMatch) break
|
|
88
|
+
items.push(nextMatch[1] ?? "")
|
|
89
|
+
i++
|
|
90
|
+
}
|
|
91
|
+
blocks.push({ _tag: "unorderedList", items })
|
|
92
|
+
continue
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
// Ordered list
|
|
96
|
+
const olMatch = /^\d+\.\s+(.+)$/.exec(line)
|
|
97
|
+
if (olMatch) {
|
|
98
|
+
const items: Array<string> = [olMatch[1] ?? ""]
|
|
99
|
+
i++
|
|
100
|
+
while (i < lines.length) {
|
|
101
|
+
const nextLine = lines[i] ?? ""
|
|
102
|
+
const nextMatch = /^\d+\.\s+(.+)$/.exec(nextLine)
|
|
103
|
+
if (!nextMatch) break
|
|
104
|
+
items.push(nextMatch[1] ?? "")
|
|
105
|
+
i++
|
|
106
|
+
}
|
|
107
|
+
blocks.push({ _tag: "orderedList", items })
|
|
108
|
+
continue
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
// Blockquote
|
|
112
|
+
const bqMatch = /^>\s?(.*)$/.exec(line)
|
|
113
|
+
if (bqMatch) {
|
|
114
|
+
const bqLines: Array<string> = [bqMatch[1] ?? ""]
|
|
115
|
+
i++
|
|
116
|
+
while (i < lines.length) {
|
|
117
|
+
const nextLine = lines[i] ?? ""
|
|
118
|
+
const nextBq = /^>\s?(.*)$/.exec(nextLine)
|
|
119
|
+
if (!nextBq) break
|
|
120
|
+
bqLines.push(nextBq[1] ?? "")
|
|
121
|
+
i++
|
|
122
|
+
}
|
|
123
|
+
blocks.push({ _tag: "blockquote", text: bqLines.join(" ") })
|
|
124
|
+
continue
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
// Blank line — skip
|
|
128
|
+
if (line.trim() === "") {
|
|
129
|
+
i++
|
|
130
|
+
continue
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
// Paragraph — accumulate non-blank, non-block-start lines
|
|
134
|
+
const paraLines: Array<string> = [line]
|
|
135
|
+
i++
|
|
136
|
+
while (i < lines.length) {
|
|
137
|
+
const nextLine = lines[i] ?? ""
|
|
138
|
+
if (nextLine.trim() === "" || isBlockStart(nextLine)) break
|
|
139
|
+
paraLines.push(nextLine)
|
|
140
|
+
i++
|
|
141
|
+
}
|
|
142
|
+
blocks.push({ _tag: "paragraph", text: paraLines.join(" ") })
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
return blocks
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
// ---------------------------------------------------------------------------
|
|
149
|
+
// Inline parser — "find earliest match" recursive scanner
|
|
150
|
+
// ---------------------------------------------------------------------------
|
|
151
|
+
|
|
152
|
+
const inlinePatterns = [
|
|
153
|
+
{ type: "code", regex: /`([^`]+)`/ },
|
|
154
|
+
{ type: "link", regex: /\[([^\]]+)\]\(([^)]+)\)/ },
|
|
155
|
+
{ type: "bold_star", regex: /\*\*(.+?)\*\*/ },
|
|
156
|
+
{ type: "bold_under", regex: /__(.+?)__/ },
|
|
157
|
+
{ type: "strike", regex: /~~(.+?)~~/ },
|
|
158
|
+
{ type: "italic_star", regex: /(?<![*])\*(?!\*)(.+?)(?<![*])\*(?!\*)/ },
|
|
159
|
+
{ type: "italic_under", regex: /(?<!\w)_(.+?)_(?!\w)/ }
|
|
160
|
+
] as const
|
|
161
|
+
|
|
162
|
+
const parseInline = (text: string): Array<Node> => {
|
|
163
|
+
if (text === "") return []
|
|
164
|
+
|
|
165
|
+
const nodes: Array<Node> = []
|
|
166
|
+
let remaining = text
|
|
167
|
+
|
|
168
|
+
while (remaining.length > 0) {
|
|
169
|
+
let earliestIndex = remaining.length
|
|
170
|
+
let earliestType: string | undefined
|
|
171
|
+
let earliestMatch: RegExpExecArray | undefined
|
|
172
|
+
|
|
173
|
+
for (const { regex, type } of inlinePatterns) {
|
|
174
|
+
const match = regex.exec(remaining)
|
|
175
|
+
if (match && match.index < earliestIndex) {
|
|
176
|
+
earliestIndex = match.index
|
|
177
|
+
earliestType = type
|
|
178
|
+
earliestMatch = match
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
if (!earliestMatch || !earliestType) {
|
|
183
|
+
nodes.push(remaining)
|
|
184
|
+
break
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
// Text before the match
|
|
188
|
+
if (earliestIndex > 0) {
|
|
189
|
+
nodes.push(remaining.slice(0, earliestIndex))
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
const group1 = earliestMatch[1] ?? ""
|
|
193
|
+
const group2 = earliestMatch[2] ?? ""
|
|
194
|
+
|
|
195
|
+
switch (earliestType) {
|
|
196
|
+
case "code":
|
|
197
|
+
nodes.push({ tag: "code", children: [group1] })
|
|
198
|
+
break
|
|
199
|
+
case "link":
|
|
200
|
+
nodes.push({ tag: "a", attrs: { href: group2 }, children: parseInline(group1) })
|
|
201
|
+
break
|
|
202
|
+
case "bold_star":
|
|
203
|
+
case "bold_under":
|
|
204
|
+
nodes.push({ tag: "strong", children: parseInline(group1) })
|
|
205
|
+
break
|
|
206
|
+
case "italic_star":
|
|
207
|
+
case "italic_under":
|
|
208
|
+
nodes.push({ tag: "em", children: parseInline(group1) })
|
|
209
|
+
break
|
|
210
|
+
case "strike":
|
|
211
|
+
nodes.push({ tag: "s", children: parseInline(group1) })
|
|
212
|
+
break
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
remaining = remaining.slice(earliestIndex + earliestMatch[0].length)
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
return nodes
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
// ---------------------------------------------------------------------------
|
|
222
|
+
// Block → Node conversion
|
|
223
|
+
// ---------------------------------------------------------------------------
|
|
224
|
+
|
|
225
|
+
const codeToChildren = (code: string): Array<Node> => {
|
|
226
|
+
const lines = code.split("\n")
|
|
227
|
+
const children: Array<Node> = []
|
|
228
|
+
for (let i = 0; i < lines.length; i++) {
|
|
229
|
+
if (i > 0) children.push({ tag: "br" })
|
|
230
|
+
children.push(lines[i] ?? "")
|
|
231
|
+
}
|
|
232
|
+
return children
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
const blockToNodes = (block: Block): Array<Node> => {
|
|
236
|
+
switch (block._tag) {
|
|
237
|
+
case "codeBlock":
|
|
238
|
+
return [{ tag: "pre", children: codeToChildren(block.code) }]
|
|
239
|
+
case "heading": {
|
|
240
|
+
const tag = block.level <= 2 ? "h3" : "h4"
|
|
241
|
+
return [{ tag, children: parseInline(block.text) }]
|
|
242
|
+
}
|
|
243
|
+
case "hr":
|
|
244
|
+
return [{ tag: "hr" }]
|
|
245
|
+
case "unorderedList":
|
|
246
|
+
return [{ tag: "ul", children: block.items.map((item) => ({ tag: "li" as const, children: parseInline(item) })) }]
|
|
247
|
+
case "orderedList":
|
|
248
|
+
return [{ tag: "ol", children: block.items.map((item) => ({ tag: "li" as const, children: parseInline(item) })) }]
|
|
249
|
+
case "blockquote":
|
|
250
|
+
return [{ tag: "blockquote", children: parseInline(block.text) }]
|
|
251
|
+
case "paragraph":
|
|
252
|
+
return [{ tag: "p", children: parseInline(block.text) }]
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
|
|
256
|
+
// ---------------------------------------------------------------------------
|
|
257
|
+
// Public API
|
|
258
|
+
// ---------------------------------------------------------------------------
|
|
259
|
+
|
|
260
|
+
/**
|
|
261
|
+
* Convert a markdown string directly to Telegraph Node array.
|
|
262
|
+
* @since 1.0.0
|
|
263
|
+
*/
|
|
264
|
+
export const markdownToTelegraphNodes = (md: string): ReadonlyArray<Node> => parseBlocks(md).flatMap(blockToNodes)
|
|
265
|
+
|
|
266
|
+
/**
|
|
267
|
+
* Encode a PlantUML diagram for the kroki.io API.
|
|
268
|
+
* Uses zlib deflate + base64url encoding.
|
|
269
|
+
*/
|
|
270
|
+
const encodeForKroki = (plantuml: string): string => {
|
|
271
|
+
const compressed = deflateSync(Buffer.from(plantuml, "utf-8"))
|
|
272
|
+
return compressed.toString("base64url")
|
|
273
|
+
}
|
|
274
|
+
|
|
275
|
+
/**
|
|
276
|
+
* Build a kroki.io PlantUML SVG URL from a Mermaid class diagram string.
|
|
277
|
+
*/
|
|
278
|
+
const mermaidToKrokiUrl = (mermaidContent: string): string => {
|
|
279
|
+
const plantuml = mermaidToPlantUml(mermaidContent)
|
|
280
|
+
const encoded = encodeForKroki(plantuml)
|
|
281
|
+
return `https://kroki.io/plantuml/svg/${encoded}`
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
/**
|
|
285
|
+
* Convert spec files to Telegraph Node array.
|
|
286
|
+
* Adds file name as h3 heading per file.
|
|
287
|
+
* Mermaid files become kroki.io PlantUML SVG images.
|
|
288
|
+
* @since 1.0.0
|
|
289
|
+
*/
|
|
290
|
+
export const specFilesToTelegraphNodes = (files: ReadonlyArray<SpecFile>): ReadonlyArray<Node> => {
|
|
291
|
+
const nodes: Array<Node> = []
|
|
292
|
+
for (const file of files) {
|
|
293
|
+
nodes.push({ tag: "h3", children: [file.name] })
|
|
294
|
+
|
|
295
|
+
if (file.mermaid) {
|
|
296
|
+
const url = mermaidToKrokiUrl(file.content)
|
|
297
|
+
nodes.push({ tag: "img", attrs: { src: url } })
|
|
298
|
+
} else {
|
|
299
|
+
for (const node of markdownToTelegraphNodes(file.content)) {
|
|
300
|
+
nodes.push(node)
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
}
|
|
304
|
+
return nodes
|
|
305
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Credential schemas
|
|
3
|
+
* @since 1.0.0
|
|
4
|
+
*/
|
|
5
|
+
import { Schema } from "effect"
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* @since 1.0.0
|
|
9
|
+
* @category schemas
|
|
10
|
+
*/
|
|
11
|
+
export class LalphGithubToken extends Schema.Class<LalphGithubToken>("LalphGithubToken")({
|
|
12
|
+
token: Schema.String
|
|
13
|
+
}) {}
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* @since 1.0.0
|
|
17
|
+
* @category schemas
|
|
18
|
+
*/
|
|
19
|
+
export class LalphLinearToken extends Schema.Class<LalphLinearToken>("LalphLinearToken")({
|
|
20
|
+
token: Schema.String,
|
|
21
|
+
expiresAt: Schema.String,
|
|
22
|
+
refreshToken: Schema.String
|
|
23
|
+
}) {}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GitHub API response schemas
|
|
3
|
+
* @since 1.0.0
|
|
4
|
+
*/
|
|
5
|
+
import { Schema } from "effect"
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* @since 1.0.0
|
|
9
|
+
* @category schemas
|
|
10
|
+
*/
|
|
11
|
+
export class GitHubRepo extends Schema.Class<GitHubRepo>("GitHubRepo")({
|
|
12
|
+
id: Schema.Number,
|
|
13
|
+
name: Schema.String,
|
|
14
|
+
full_name: Schema.String,
|
|
15
|
+
owner: Schema.Struct({
|
|
16
|
+
login: Schema.String
|
|
17
|
+
}),
|
|
18
|
+
html_url: Schema.String
|
|
19
|
+
}) {}
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* @since 1.0.0
|
|
23
|
+
* @category schemas
|
|
24
|
+
*/
|
|
25
|
+
export class GitHubPullRequest extends Schema.Class<GitHubPullRequest>("GitHubPullRequest")({
|
|
26
|
+
id: Schema.Number,
|
|
27
|
+
number: Schema.Number,
|
|
28
|
+
title: Schema.String,
|
|
29
|
+
state: Schema.String,
|
|
30
|
+
html_url: Schema.String,
|
|
31
|
+
headRef: Schema.propertySignature(Schema.String).pipe(Schema.fromKey("head_ref")),
|
|
32
|
+
headSha: Schema.String,
|
|
33
|
+
hasConflicts: Schema.Boolean,
|
|
34
|
+
repo: Schema.String
|
|
35
|
+
}) {}
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* @since 1.0.0
|
|
39
|
+
* @category schemas
|
|
40
|
+
*/
|
|
41
|
+
export class GitHubComment extends Schema.Class<GitHubComment>("GitHubComment")({
|
|
42
|
+
id: Schema.Number,
|
|
43
|
+
body: Schema.String,
|
|
44
|
+
user: Schema.Struct({
|
|
45
|
+
login: Schema.String
|
|
46
|
+
}),
|
|
47
|
+
created_at: Schema.String,
|
|
48
|
+
html_url: Schema.String,
|
|
49
|
+
repo: Schema.optionalWith(Schema.String, { default: () => "" })
|
|
50
|
+
}) {}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Linear API response schemas
|
|
3
|
+
* @since 1.0.0
|
|
4
|
+
*/
|
|
5
|
+
import { Schema } from "effect"
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* @since 1.0.0
|
|
9
|
+
* @category schemas
|
|
10
|
+
*/
|
|
11
|
+
export class LinearIssueNode extends Schema.Class<LinearIssueNode>("LinearIssueNode")({
|
|
12
|
+
id: Schema.String,
|
|
13
|
+
title: Schema.String,
|
|
14
|
+
identifier: Schema.String,
|
|
15
|
+
url: Schema.String,
|
|
16
|
+
createdAt: Schema.String,
|
|
17
|
+
updatedAt: Schema.String,
|
|
18
|
+
state: Schema.Struct({
|
|
19
|
+
name: Schema.String
|
|
20
|
+
})
|
|
21
|
+
}) {}
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* @since 1.0.0
|
|
25
|
+
* @category schemas
|
|
26
|
+
*/
|
|
27
|
+
export class LinearIssuesResponse extends Schema.Class<LinearIssuesResponse>("LinearIssuesResponse")({
|
|
28
|
+
data: Schema.Struct({
|
|
29
|
+
issues: Schema.Struct({
|
|
30
|
+
nodes: Schema.Array(LinearIssueNode)
|
|
31
|
+
})
|
|
32
|
+
})
|
|
33
|
+
}) {}
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* @since 1.0.0
|
|
37
|
+
* @category schemas
|
|
38
|
+
*/
|
|
39
|
+
export class LinearWorkflowState extends Schema.Class<LinearWorkflowState>("LinearWorkflowState")({
|
|
40
|
+
id: Schema.String,
|
|
41
|
+
name: Schema.String,
|
|
42
|
+
type: Schema.String
|
|
43
|
+
}) {}
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* @since 1.0.0
|
|
47
|
+
* @category schemas
|
|
48
|
+
*/
|
|
49
|
+
export class LinearWorkflowStatesResponse extends Schema.Class<LinearWorkflowStatesResponse>(
|
|
50
|
+
"LinearWorkflowStatesResponse"
|
|
51
|
+
)({
|
|
52
|
+
data: Schema.Struct({
|
|
53
|
+
workflowStates: Schema.Struct({
|
|
54
|
+
nodes: Schema.Array(LinearWorkflowState)
|
|
55
|
+
})
|
|
56
|
+
})
|
|
57
|
+
}) {}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Project schemas matching lalph's Project domain
|
|
3
|
+
* @since 1.0.0
|
|
4
|
+
*/
|
|
5
|
+
import { Schema } from "effect"
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* @since 1.0.0
|
|
9
|
+
* @category schemas
|
|
10
|
+
*/
|
|
11
|
+
export class LalphProject extends Schema.Class<LalphProject>("LalphProject")({
|
|
12
|
+
id: Schema.String,
|
|
13
|
+
enabled: Schema.Boolean,
|
|
14
|
+
targetBranch: Schema.Option(Schema.String),
|
|
15
|
+
concurrency: Schema.Int.pipe(Schema.positive()),
|
|
16
|
+
gitFlow: Schema.Literal("pr", "commit"),
|
|
17
|
+
reviewAgent: Schema.Boolean
|
|
18
|
+
}) {}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tracker schemas for task tracking events
|
|
3
|
+
* @since 1.0.0
|
|
4
|
+
*/
|
|
5
|
+
import { Schema } from "effect"
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* @since 1.0.0
|
|
9
|
+
* @category schemas
|
|
10
|
+
*/
|
|
11
|
+
export class TrackerIssue extends Schema.Class<TrackerIssue>("TrackerIssue")({
|
|
12
|
+
id: Schema.String,
|
|
13
|
+
title: Schema.String,
|
|
14
|
+
state: Schema.String,
|
|
15
|
+
url: Schema.String,
|
|
16
|
+
createdAt: Schema.String,
|
|
17
|
+
updatedAt: Schema.String
|
|
18
|
+
}) {}
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* @since 1.0.0
|
|
22
|
+
* @category schemas
|
|
23
|
+
*/
|
|
24
|
+
export class TrackerIssueEvent extends Schema.Class<TrackerIssueEvent>("TrackerIssueEvent")({
|
|
25
|
+
action: Schema.Literal("created", "updated"),
|
|
26
|
+
issue: TrackerIssue
|
|
27
|
+
}) {}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Application context — resolves project root and config directory paths
|
|
3
|
+
* @since 1.0.0
|
|
4
|
+
*/
|
|
5
|
+
import { FileSystem, Path } from "@effect/platform"
|
|
6
|
+
import { Context, Data, Effect, Layer } from "effect"
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* @since 1.0.0
|
|
10
|
+
* @category errors
|
|
11
|
+
*/
|
|
12
|
+
export class AppContextError extends Data.TaggedError("AppContextError")<{
|
|
13
|
+
message: string
|
|
14
|
+
cause: unknown
|
|
15
|
+
}> {}
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* @since 1.0.0
|
|
19
|
+
* @category services
|
|
20
|
+
*/
|
|
21
|
+
export interface AppContextService {
|
|
22
|
+
readonly projectRoot: string
|
|
23
|
+
readonly configDir: string
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* @since 1.0.0
|
|
28
|
+
* @category context
|
|
29
|
+
*/
|
|
30
|
+
export class AppContext extends Context.Tag("AppContext")<
|
|
31
|
+
AppContext,
|
|
32
|
+
AppContextService
|
|
33
|
+
>() {}
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* @since 1.0.0
|
|
37
|
+
* @category layers
|
|
38
|
+
*/
|
|
39
|
+
export const AppContextLive = Layer.effect(
|
|
40
|
+
AppContext,
|
|
41
|
+
Effect.gen(function*() {
|
|
42
|
+
const fs = yield* FileSystem.FileSystem
|
|
43
|
+
const pathService = yield* Path.Path
|
|
44
|
+
|
|
45
|
+
let current = pathService.resolve(".")
|
|
46
|
+
let lalphPath: string | undefined
|
|
47
|
+
|
|
48
|
+
while (true) {
|
|
49
|
+
const candidate = pathService.join(current, ".lalph")
|
|
50
|
+
const exists = yield* fs.exists(candidate)
|
|
51
|
+
if (exists) {
|
|
52
|
+
lalphPath = candidate
|
|
53
|
+
break
|
|
54
|
+
}
|
|
55
|
+
const parent = pathService.dirname(current)
|
|
56
|
+
if (parent === current) break
|
|
57
|
+
current = parent
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
if (lalphPath === undefined) {
|
|
61
|
+
return yield* new AppContextError({
|
|
62
|
+
message: "Could not find .lalph/ directory. Are you inside a lalph project?",
|
|
63
|
+
cause: null
|
|
64
|
+
})
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
return AppContext.of({
|
|
68
|
+
projectRoot: pathService.dirname(lalphPath),
|
|
69
|
+
configDir: pathService.join(lalphPath, "config")
|
|
70
|
+
})
|
|
71
|
+
})
|
|
72
|
+
)
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Runtime configuration schema and service tag
|
|
3
|
+
* @since 1.0.0
|
|
4
|
+
*/
|
|
5
|
+
import { Context, Schema } from "effect"
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* @since 1.0.0
|
|
9
|
+
* @category schemas
|
|
10
|
+
*/
|
|
11
|
+
export class RuntimeConfig extends Schema.Class<RuntimeConfig>("RuntimeConfig")({
|
|
12
|
+
pollIntervalSeconds: Schema.Number,
|
|
13
|
+
triggerKeyword: Schema.String,
|
|
14
|
+
timerDelaySeconds: Schema.Number,
|
|
15
|
+
autoMergeEnabled: Schema.optionalWith(Schema.Boolean, { default: () => false }),
|
|
16
|
+
autoMergeWaitMinutes: Schema.optionalWith(Schema.Number, { default: () => 10 })
|
|
17
|
+
}) {}
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* @since 1.0.0
|
|
21
|
+
* @category context
|
|
22
|
+
*/
|
|
23
|
+
export class AppRuntimeConfig extends Context.Tag("AppRuntimeConfig")<AppRuntimeConfig, RuntimeConfig>() {}
|