reviewflow 3.6.0 → 3.8.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/CHANGELOG.md +40 -0
- package/dist/config/projectConfig.d.ts +2 -0
- package/dist/config/projectConfig.d.ts.map +1 -1
- package/dist/config/projectConfig.js +17 -0
- package/dist/config/projectConfig.js.map +1 -1
- package/dist/entities/backfill/backfillProgress.d.ts +7 -0
- package/dist/entities/backfill/backfillProgress.d.ts.map +1 -0
- package/dist/entities/backfill/backfillProgress.js +2 -0
- package/dist/entities/backfill/backfillProgress.js.map +1 -0
- package/dist/entities/cleanup/retentionPolicy.valueObject.d.ts +8 -0
- package/dist/entities/cleanup/retentionPolicy.valueObject.d.ts.map +1 -0
- package/dist/entities/cleanup/retentionPolicy.valueObject.js +21 -0
- package/dist/entities/cleanup/retentionPolicy.valueObject.js.map +1 -0
- package/dist/entities/diffStats/diffStats.d.ts +6 -0
- package/dist/entities/diffStats/diffStats.d.ts.map +1 -0
- package/dist/entities/diffStats/diffStats.js +2 -0
- package/dist/entities/diffStats/diffStats.js.map +1 -0
- package/dist/entities/diffStats/diffStatsFetch.gateway.d.ts +5 -0
- package/dist/entities/diffStats/diffStatsFetch.gateway.d.ts.map +1 -0
- package/dist/entities/diffStats/diffStatsFetch.gateway.js +2 -0
- package/dist/entities/diffStats/diffStatsFetch.gateway.js.map +1 -0
- package/dist/entities/insight/aiInsight.d.ts +6 -0
- package/dist/entities/insight/aiInsight.d.ts.map +1 -0
- package/dist/entities/insight/aiInsight.js +2 -0
- package/dist/entities/insight/aiInsight.js.map +1 -0
- package/dist/entities/insight/aiInsight.schema.d.ts +55 -0
- package/dist/entities/insight/aiInsight.schema.d.ts.map +1 -0
- package/dist/entities/insight/aiInsight.schema.js +25 -0
- package/dist/entities/insight/aiInsight.schema.js.map +1 -0
- package/dist/entities/insight/developerInsight.d.ts +8 -0
- package/dist/entities/insight/developerInsight.d.ts.map +1 -0
- package/dist/entities/insight/developerInsight.guard.d.ts +221 -0
- package/dist/entities/insight/developerInsight.guard.d.ts.map +1 -0
- package/dist/entities/insight/developerInsight.guard.js +13 -0
- package/dist/entities/insight/developerInsight.guard.js.map +1 -0
- package/dist/entities/insight/developerInsight.js +2 -0
- package/dist/entities/insight/developerInsight.js.map +1 -0
- package/dist/entities/insight/developerInsight.schema.d.ts +157 -0
- package/dist/entities/insight/developerInsight.schema.d.ts.map +1 -0
- package/dist/entities/insight/developerInsight.schema.js +43 -0
- package/dist/entities/insight/developerInsight.schema.js.map +1 -0
- package/dist/entities/insight/developerTitle.d.ts +12 -0
- package/dist/entities/insight/developerTitle.d.ts.map +1 -0
- package/dist/entities/insight/developerTitle.js +11 -0
- package/dist/entities/insight/developerTitle.js.map +1 -0
- package/dist/entities/insight/insightCategory.d.ts +10 -0
- package/dist/entities/insight/insightCategory.d.ts.map +1 -0
- package/dist/entities/insight/insightCategory.js +4 -0
- package/dist/entities/insight/insightCategory.js.map +1 -0
- package/dist/entities/insight/insightTrend.d.ts +9 -0
- package/dist/entities/insight/insightTrend.d.ts.map +1 -0
- package/dist/entities/insight/insightTrend.js +4 -0
- package/dist/entities/insight/insightTrend.js.map +1 -0
- package/dist/entities/insight/insights.gateway.d.ts +6 -0
- package/dist/entities/insight/insights.gateway.d.ts.map +1 -0
- package/dist/entities/insight/insights.gateway.js +2 -0
- package/dist/entities/insight/insights.gateway.js.map +1 -0
- package/dist/entities/insight/persistedInsightsData.d.ts +5 -0
- package/dist/entities/insight/persistedInsightsData.d.ts.map +1 -0
- package/dist/entities/insight/persistedInsightsData.guard.d.ts +271 -0
- package/dist/entities/insight/persistedInsightsData.guard.d.ts.map +1 -0
- package/dist/entities/insight/persistedInsightsData.guard.js +13 -0
- package/dist/entities/insight/persistedInsightsData.guard.js.map +1 -0
- package/dist/entities/insight/persistedInsightsData.js +2 -0
- package/dist/entities/insight/persistedInsightsData.js.map +1 -0
- package/dist/entities/insight/persistedInsightsData.schema.d.ts +84 -0
- package/dist/entities/insight/persistedInsightsData.schema.d.ts.map +1 -0
- package/dist/entities/insight/persistedInsightsData.schema.js +40 -0
- package/dist/entities/insight/persistedInsightsData.schema.js.map +1 -0
- package/dist/entities/insight/teamInsight.d.ts +5 -0
- package/dist/entities/insight/teamInsight.d.ts.map +1 -0
- package/dist/entities/insight/teamInsight.guard.d.ts +71 -0
- package/dist/entities/insight/teamInsight.guard.d.ts.map +1 -0
- package/dist/entities/insight/teamInsight.guard.js +13 -0
- package/dist/entities/insight/teamInsight.guard.js.map +1 -0
- package/dist/entities/insight/teamInsight.js +2 -0
- package/dist/entities/insight/teamInsight.js.map +1 -0
- package/dist/entities/insight/teamInsight.schema.d.ts +31 -0
- package/dist/entities/insight/teamInsight.schema.d.ts.map +1 -0
- package/dist/entities/insight/teamInsight.schema.js +17 -0
- package/dist/entities/insight/teamInsight.schema.js.map +1 -0
- package/dist/entities/packageVersion/packageVersion.d.ts +21 -0
- package/dist/entities/packageVersion/packageVersion.d.ts.map +1 -0
- package/dist/entities/packageVersion/packageVersion.gateway.d.ts +4 -0
- package/dist/entities/packageVersion/packageVersion.gateway.d.ts.map +1 -0
- package/dist/entities/packageVersion/packageVersion.gateway.js +2 -0
- package/dist/entities/packageVersion/packageVersion.gateway.js.map +1 -0
- package/dist/entities/packageVersion/packageVersion.guard.d.ts +7 -0
- package/dist/entities/packageVersion/packageVersion.guard.d.ts.map +1 -0
- package/dist/entities/packageVersion/packageVersion.guard.js +13 -0
- package/dist/entities/packageVersion/packageVersion.guard.js.map +1 -0
- package/dist/entities/packageVersion/packageVersion.js +2 -0
- package/dist/entities/packageVersion/packageVersion.js.map +1 -0
- package/dist/entities/packageVersion/packageVersion.schema.d.ts +12 -0
- package/dist/entities/packageVersion/packageVersion.schema.d.ts.map +1 -0
- package/dist/entities/packageVersion/packageVersion.schema.js +11 -0
- package/dist/entities/packageVersion/packageVersion.schema.js.map +1 -0
- package/dist/entities/packageVersion/selfUpdateCommand.gateway.d.ts +9 -0
- package/dist/entities/packageVersion/selfUpdateCommand.gateway.d.ts.map +1 -0
- package/dist/entities/packageVersion/selfUpdateCommand.gateway.js +2 -0
- package/dist/entities/packageVersion/selfUpdateCommand.gateway.js.map +1 -0
- package/dist/entities/packageVersion/versionCache.gateway.d.ts +7 -0
- package/dist/entities/packageVersion/versionCache.gateway.d.ts.map +1 -0
- package/dist/entities/packageVersion/versionCache.gateway.js +2 -0
- package/dist/entities/packageVersion/versionCache.gateway.js.map +1 -0
- package/dist/entities/review/reviewFile.gateway.d.ts +18 -0
- package/dist/entities/review/reviewFile.gateway.d.ts.map +1 -0
- package/dist/entities/review/reviewFile.gateway.js +2 -0
- package/dist/entities/review/reviewFile.gateway.js.map +1 -0
- package/dist/entities/stats/projectStats.d.ts +39 -0
- package/dist/entities/stats/projectStats.d.ts.map +1 -0
- package/dist/entities/stats/projectStats.js +2 -0
- package/dist/entities/stats/projectStats.js.map +1 -0
- package/dist/entities/stats/recalculateBody.guard.d.ts +11 -0
- package/dist/entities/stats/recalculateBody.guard.d.ts.map +1 -0
- package/dist/entities/stats/recalculateBody.guard.js +9 -0
- package/dist/entities/stats/recalculateBody.guard.js.map +1 -0
- package/dist/entities/stats/stats.gateway.d.ts +7 -0
- package/dist/entities/stats/stats.gateway.d.ts.map +1 -0
- package/dist/entities/stats/stats.gateway.js +2 -0
- package/dist/entities/stats/stats.gateway.js.map +1 -0
- package/dist/entities/tracking/reviewEvent.d.ts +2 -0
- package/dist/entities/tracking/reviewEvent.d.ts.map +1 -1
- package/dist/entities/tracking/reviewRequestTracking.gateway.d.ts +19 -0
- package/dist/entities/tracking/reviewRequestTracking.gateway.d.ts.map +1 -0
- package/dist/entities/tracking/reviewRequestTracking.gateway.js +2 -0
- package/dist/entities/tracking/reviewRequestTracking.gateway.js.map +1 -0
- package/dist/frameworks/claude/claudeInsightsInvoker.d.ts +3 -0
- package/dist/frameworks/claude/claudeInsightsInvoker.d.ts.map +1 -0
- package/dist/frameworks/claude/claudeInsightsInvoker.js +58 -0
- package/dist/frameworks/claude/claudeInsightsInvoker.js.map +1 -0
- package/dist/frameworks/claude/claudeInvoker.d.ts.map +1 -1
- package/dist/frameworks/claude/claudeInvoker.js +15 -1
- package/dist/frameworks/claude/claudeInvoker.js.map +1 -1
- package/dist/frameworks/scheduler/cleanupScheduler.d.ts +16 -0
- package/dist/frameworks/scheduler/cleanupScheduler.d.ts.map +1 -0
- package/dist/frameworks/scheduler/cleanupScheduler.js +35 -0
- package/dist/frameworks/scheduler/cleanupScheduler.js.map +1 -0
- package/dist/interface-adapters/controllers/http/cleanup.routes.d.ts +16 -0
- package/dist/interface-adapters/controllers/http/cleanup.routes.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/http/cleanup.routes.js +44 -0
- package/dist/interface-adapters/controllers/http/cleanup.routes.js.map +1 -0
- package/dist/interface-adapters/controllers/http/health.routes.d.ts +3 -1
- package/dist/interface-adapters/controllers/http/health.routes.d.ts.map +1 -1
- package/dist/interface-adapters/controllers/http/health.routes.js +5 -1
- package/dist/interface-adapters/controllers/http/health.routes.js.map +1 -1
- package/dist/interface-adapters/controllers/http/insights.routes.d.ts +20 -0
- package/dist/interface-adapters/controllers/http/insights.routes.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/http/insights.routes.js +73 -0
- package/dist/interface-adapters/controllers/http/insights.routes.js.map +1 -0
- package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.d.ts.map +1 -1
- package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.js +13 -2
- package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.js.map +1 -1
- package/dist/interface-adapters/controllers/http/settings.routes.d.ts.map +1 -1
- package/dist/interface-adapters/controllers/http/settings.routes.js +3 -0
- package/dist/interface-adapters/controllers/http/settings.routes.js.map +1 -1
- package/dist/interface-adapters/controllers/http/stats.routes.d.ts +20 -6
- package/dist/interface-adapters/controllers/http/stats.routes.d.ts.map +1 -1
- package/dist/interface-adapters/controllers/http/stats.routes.js +35 -2
- package/dist/interface-adapters/controllers/http/stats.routes.js.map +1 -1
- package/dist/interface-adapters/controllers/http/version.routes.d.ts +19 -0
- package/dist/interface-adapters/controllers/http/version.routes.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/http/version.routes.js +21 -0
- package/dist/interface-adapters/controllers/http/version.routes.js.map +1 -0
- package/dist/interface-adapters/controllers/webhook/github.controller.d.ts +2 -0
- package/dist/interface-adapters/controllers/webhook/github.controller.d.ts.map +1 -1
- package/dist/interface-adapters/controllers/webhook/github.controller.js +9 -3
- package/dist/interface-adapters/controllers/webhook/github.controller.js.map +1 -1
- package/dist/interface-adapters/controllers/webhook/gitlab.controller.d.ts +2 -0
- package/dist/interface-adapters/controllers/webhook/gitlab.controller.d.ts.map +1 -1
- package/dist/interface-adapters/controllers/webhook/gitlab.controller.js +17 -5
- package/dist/interface-adapters/controllers/webhook/gitlab.controller.js.map +1 -1
- package/dist/interface-adapters/gateways/diffStatsFetch.github.gateway.d.ts +10 -0
- package/dist/interface-adapters/gateways/diffStatsFetch.github.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/diffStatsFetch.github.gateway.js +26 -0
- package/dist/interface-adapters/gateways/diffStatsFetch.github.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.d.ts +10 -0
- package/dist/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.js +28 -0
- package/dist/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/fileSystem/insights.fileSystem.d.ts +7 -0
- package/dist/interface-adapters/gateways/fileSystem/insights.fileSystem.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/fileSystem/insights.fileSystem.js +33 -0
- package/dist/interface-adapters/gateways/fileSystem/insights.fileSystem.js.map +1 -0
- package/dist/interface-adapters/gateways/fileSystem/reviewLogFile.fileSystem.gateway.d.ts +7 -0
- package/dist/interface-adapters/gateways/fileSystem/reviewLogFile.fileSystem.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/fileSystem/reviewLogFile.fileSystem.gateway.js +47 -0
- package/dist/interface-adapters/gateways/fileSystem/reviewLogFile.fileSystem.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/fileSystem/stats.fileSystem.d.ts +2 -2
- package/dist/interface-adapters/gateways/fileSystem/stats.fileSystem.d.ts.map +1 -1
- package/dist/interface-adapters/gateways/packageVersion.npm.gateway.d.ts +7 -0
- package/dist/interface-adapters/gateways/packageVersion.npm.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/packageVersion.npm.gateway.js +25 -0
- package/dist/interface-adapters/gateways/packageVersion.npm.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/reviewFile.gateway.d.ts +1 -17
- package/dist/interface-adapters/gateways/reviewFile.gateway.d.ts.map +1 -1
- package/dist/interface-adapters/gateways/reviewLogFile.gateway.d.ts +12 -0
- package/dist/interface-adapters/gateways/reviewLogFile.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/reviewLogFile.gateway.js +2 -0
- package/dist/interface-adapters/gateways/reviewLogFile.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/reviewRequestTracking.gateway.d.ts +1 -18
- package/dist/interface-adapters/gateways/reviewRequestTracking.gateway.d.ts.map +1 -1
- package/dist/interface-adapters/gateways/selfUpdate.cli.gateway.d.ts +20 -0
- package/dist/interface-adapters/gateways/selfUpdate.cli.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/selfUpdate.cli.gateway.js +58 -0
- package/dist/interface-adapters/gateways/selfUpdate.cli.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/stats.gateway.d.ts +1 -6
- package/dist/interface-adapters/gateways/stats.gateway.d.ts.map +1 -1
- package/dist/interface-adapters/gateways/versionCache.memory.gateway.d.ts +12 -0
- package/dist/interface-adapters/gateways/versionCache.memory.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/versionCache.memory.gateway.js +22 -0
- package/dist/interface-adapters/gateways/versionCache.memory.gateway.js.map +1 -0
- package/dist/interface-adapters/presenters/insights.presenter.d.ts +41 -0
- package/dist/interface-adapters/presenters/insights.presenter.d.ts.map +1 -0
- package/dist/interface-adapters/presenters/insights.presenter.js +36 -0
- package/dist/interface-adapters/presenters/insights.presenter.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/index.html +599 -40
- package/dist/interface-adapters/views/dashboard/modules/cleanup.d.ts +10 -0
- package/dist/interface-adapters/views/dashboard/modules/cleanup.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/cleanup.js +45 -0
- package/dist/interface-adapters/views/dashboard/modules/cleanup.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/collapsibleList.d.ts +13 -0
- package/dist/interface-adapters/views/dashboard/modules/collapsibleList.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/collapsibleList.js +71 -0
- package/dist/interface-adapters/views/dashboard/modules/collapsibleList.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/developerSheet.d.ts +14 -0
- package/dist/interface-adapters/views/dashboard/modules/developerSheet.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/developerSheet.js +359 -0
- package/dist/interface-adapters/views/dashboard/modules/developerSheet.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/i18n.d.ts.map +1 -1
- package/dist/interface-adapters/views/dashboard/modules/i18n.js +296 -0
- package/dist/interface-adapters/views/dashboard/modules/i18n.js.map +1 -1
- package/dist/interface-adapters/views/dashboard/modules/insightsReport.d.ts +7 -0
- package/dist/interface-adapters/views/dashboard/modules/insightsReport.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/insightsReport.js +509 -0
- package/dist/interface-adapters/views/dashboard/modules/insightsReport.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/mrSheet.d.ts +25 -0
- package/dist/interface-adapters/views/dashboard/modules/mrSheet.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/mrSheet.js +414 -0
- package/dist/interface-adapters/views/dashboard/modules/mrSheet.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/sharedViewHelpers.d.ts +40 -0
- package/dist/interface-adapters/views/dashboard/modules/sharedViewHelpers.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/sharedViewHelpers.js +106 -0
- package/dist/interface-adapters/views/dashboard/modules/sharedViewHelpers.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/statsCharts.d.ts +35 -0
- package/dist/interface-adapters/views/dashboard/modules/statsCharts.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/statsCharts.js +476 -0
- package/dist/interface-adapters/views/dashboard/modules/statsCharts.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/teamTab.d.ts +13 -0
- package/dist/interface-adapters/views/dashboard/modules/teamTab.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/teamTab.js +296 -0
- package/dist/interface-adapters/views/dashboard/modules/teamTab.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/versionUpdate.d.ts +16 -0
- package/dist/interface-adapters/views/dashboard/modules/versionUpdate.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/versionUpdate.js +54 -0
- package/dist/interface-adapters/views/dashboard/modules/versionUpdate.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/styles.css +1906 -0
- package/dist/main/dependencies.d.ts +4 -0
- package/dist/main/dependencies.d.ts.map +1 -1
- package/dist/main/dependencies.js +4 -0
- package/dist/main/dependencies.js.map +1 -1
- package/dist/main/routes.d.ts.map +1 -1
- package/dist/main/routes.js +68 -2
- package/dist/main/routes.js.map +1 -1
- package/dist/main/server.d.ts.map +1 -1
- package/dist/main/server.js +8 -0
- package/dist/main/server.js.map +1 -1
- package/dist/main/websocket.d.ts +2 -0
- package/dist/main/websocket.d.ts.map +1 -1
- package/dist/main/websocket.js +13 -0
- package/dist/main/websocket.js.map +1 -1
- package/dist/services/statsService.d.ts +8 -32
- package/dist/services/statsService.d.ts.map +1 -1
- package/dist/services/statsService.js +60 -36
- package/dist/services/statsService.js.map +1 -1
- package/dist/shared/foundation/commandExecutor.d.ts +2 -0
- package/dist/shared/foundation/commandExecutor.d.ts.map +1 -0
- package/dist/shared/foundation/commandExecutor.js +2 -0
- package/dist/shared/foundation/commandExecutor.js.map +1 -0
- package/dist/tests/factories/developerInsight.factory.d.ts +6 -0
- package/dist/tests/factories/developerInsight.factory.d.ts.map +1 -0
- package/dist/tests/factories/developerInsight.factory.js +61 -0
- package/dist/tests/factories/developerInsight.factory.js.map +1 -0
- package/dist/tests/factories/diffStats.factory.d.ts +5 -0
- package/dist/tests/factories/diffStats.factory.d.ts.map +1 -0
- package/dist/tests/factories/diffStats.factory.js +11 -0
- package/dist/tests/factories/diffStats.factory.js.map +1 -0
- package/dist/tests/factories/packageVersion.factory.d.ts +7 -0
- package/dist/tests/factories/packageVersion.factory.d.ts.map +1 -0
- package/dist/tests/factories/packageVersion.factory.js +18 -0
- package/dist/tests/factories/packageVersion.factory.js.map +1 -0
- package/dist/tests/factories/persistedInsightsData.factory.d.ts +11 -0
- package/dist/tests/factories/persistedInsightsData.factory.d.ts.map +1 -0
- package/dist/tests/factories/persistedInsightsData.factory.js +41 -0
- package/dist/tests/factories/persistedInsightsData.factory.js.map +1 -0
- package/dist/tests/factories/projectStats.factory.d.ts +3 -1
- package/dist/tests/factories/projectStats.factory.d.ts.map +1 -1
- package/dist/tests/factories/projectStats.factory.js +17 -3
- package/dist/tests/factories/projectStats.factory.js.map +1 -1
- package/dist/tests/factories/teamInsight.factory.d.ts +6 -0
- package/dist/tests/factories/teamInsight.factory.d.ts.map +1 -0
- package/dist/tests/factories/teamInsight.factory.js +35 -0
- package/dist/tests/factories/teamInsight.factory.js.map +1 -0
- package/dist/tests/stubs/diffStatsFetch.stub.d.ts +11 -0
- package/dist/tests/stubs/diffStatsFetch.stub.d.ts.map +1 -0
- package/dist/tests/stubs/diffStatsFetch.stub.js +19 -0
- package/dist/tests/stubs/diffStatsFetch.stub.js.map +1 -0
- package/dist/tests/stubs/insights.stub.d.ts +9 -0
- package/dist/tests/stubs/insights.stub.d.ts.map +1 -0
- package/dist/tests/stubs/insights.stub.js +13 -0
- package/dist/tests/stubs/insights.stub.js.map +1 -0
- package/dist/tests/stubs/packageVersion.stub.d.ts +7 -0
- package/dist/tests/stubs/packageVersion.stub.d.ts.map +1 -0
- package/dist/tests/stubs/packageVersion.stub.js +10 -0
- package/dist/tests/stubs/packageVersion.stub.js.map +1 -0
- package/dist/tests/stubs/reviewFile.stub.d.ts +1 -1
- package/dist/tests/stubs/reviewFile.stub.d.ts.map +1 -1
- package/dist/tests/stubs/reviewLogFile.stub.d.ts +15 -0
- package/dist/tests/stubs/reviewLogFile.stub.d.ts.map +1 -0
- package/dist/tests/stubs/reviewLogFile.stub.js +35 -0
- package/dist/tests/stubs/reviewLogFile.stub.js.map +1 -0
- package/dist/tests/stubs/reviewRequestTracking.stub.d.ts +1 -1
- package/dist/tests/stubs/reviewRequestTracking.stub.d.ts.map +1 -1
- package/dist/tests/stubs/selfUpdate.stub.d.ts +14 -0
- package/dist/tests/stubs/selfUpdate.stub.d.ts.map +1 -0
- package/dist/tests/stubs/selfUpdate.stub.js +20 -0
- package/dist/tests/stubs/selfUpdate.stub.js.map +1 -0
- package/dist/tests/stubs/stats.stub.d.ts +2 -2
- package/dist/tests/stubs/stats.stub.d.ts.map +1 -1
- package/dist/tests/stubs/versionCache.stub.d.ts +11 -0
- package/dist/tests/stubs/versionCache.stub.d.ts.map +1 -0
- package/dist/tests/stubs/versionCache.stub.js +18 -0
- package/dist/tests/stubs/versionCache.stub.js.map +1 -0
- package/dist/tests/units/config/projectConfig.test.js +60 -1
- package/dist/tests/units/config/projectConfig.test.js.map +1 -1
- package/dist/tests/units/entities/backfill/backfillProgress.test.d.ts +2 -0
- package/dist/tests/units/entities/backfill/backfillProgress.test.d.ts.map +1 -0
- package/dist/tests/units/entities/backfill/backfillProgress.test.js +40 -0
- package/dist/tests/units/entities/backfill/backfillProgress.test.js.map +1 -0
- package/dist/tests/units/entities/cleanup/retentionPolicy.valueObject.test.d.ts +2 -0
- package/dist/tests/units/entities/cleanup/retentionPolicy.valueObject.test.d.ts.map +1 -0
- package/dist/tests/units/entities/cleanup/retentionPolicy.valueObject.test.js +47 -0
- package/dist/tests/units/entities/cleanup/retentionPolicy.valueObject.test.js.map +1 -0
- package/dist/tests/units/entities/diffStats/diffStats.test.d.ts +2 -0
- package/dist/tests/units/entities/diffStats/diffStats.test.d.ts.map +1 -0
- package/dist/tests/units/entities/diffStats/diffStats.test.js +27 -0
- package/dist/tests/units/entities/diffStats/diffStats.test.js.map +1 -0
- package/dist/tests/units/entities/insight/aiInsight.schema.test.d.ts +2 -0
- package/dist/tests/units/entities/insight/aiInsight.schema.test.d.ts.map +1 -0
- package/dist/tests/units/entities/insight/aiInsight.schema.test.js +123 -0
- package/dist/tests/units/entities/insight/aiInsight.schema.test.js.map +1 -0
- package/dist/tests/units/entities/insight/developerInsight.schema.test.d.ts +2 -0
- package/dist/tests/units/entities/insight/developerInsight.schema.test.d.ts.map +1 -0
- package/dist/tests/units/entities/insight/developerInsight.schema.test.js +140 -0
- package/dist/tests/units/entities/insight/developerInsight.schema.test.js.map +1 -0
- package/dist/tests/units/entities/insight/developerTitle.test.d.ts +2 -0
- package/dist/tests/units/entities/insight/developerTitle.test.d.ts.map +1 -0
- package/dist/tests/units/entities/insight/developerTitle.test.js +23 -0
- package/dist/tests/units/entities/insight/developerTitle.test.js.map +1 -0
- package/dist/tests/units/entities/insight/insightCategory.test.d.ts +2 -0
- package/dist/tests/units/entities/insight/insightCategory.test.d.ts.map +1 -0
- package/dist/tests/units/entities/insight/insightCategory.test.js +16 -0
- package/dist/tests/units/entities/insight/insightCategory.test.js.map +1 -0
- package/dist/tests/units/entities/insight/insightTrend.test.d.ts +2 -0
- package/dist/tests/units/entities/insight/insightTrend.test.d.ts.map +1 -0
- package/dist/tests/units/entities/insight/insightTrend.test.js +16 -0
- package/dist/tests/units/entities/insight/insightTrend.test.js.map +1 -0
- package/dist/tests/units/entities/insight/persistedInsightsData.schema.test.d.ts +2 -0
- package/dist/tests/units/entities/insight/persistedInsightsData.schema.test.d.ts.map +1 -0
- package/dist/tests/units/entities/insight/persistedInsightsData.schema.test.js +160 -0
- package/dist/tests/units/entities/insight/persistedInsightsData.schema.test.js.map +1 -0
- package/dist/tests/units/entities/insight/teamInsight.schema.test.d.ts +2 -0
- package/dist/tests/units/entities/insight/teamInsight.schema.test.d.ts.map +1 -0
- package/dist/tests/units/entities/insight/teamInsight.schema.test.js +57 -0
- package/dist/tests/units/entities/insight/teamInsight.schema.test.js.map +1 -0
- package/dist/tests/units/entities/packageVersion/packageVersion.test.d.ts +2 -0
- package/dist/tests/units/entities/packageVersion/packageVersion.test.d.ts.map +1 -0
- package/dist/tests/units/entities/packageVersion/packageVersion.test.js +154 -0
- package/dist/tests/units/entities/packageVersion/packageVersion.test.js.map +1 -0
- package/dist/tests/units/factories/packageVersion.factory.test.d.ts +2 -0
- package/dist/tests/units/factories/packageVersion.factory.test.d.ts.map +1 -0
- package/dist/tests/units/factories/packageVersion.factory.test.js +37 -0
- package/dist/tests/units/factories/packageVersion.factory.test.js.map +1 -0
- package/dist/tests/units/frameworks/scheduler/cleanupScheduler.test.d.ts +2 -0
- package/dist/tests/units/frameworks/scheduler/cleanupScheduler.test.d.ts.map +1 -0
- package/dist/tests/units/frameworks/scheduler/cleanupScheduler.test.js +74 -0
- package/dist/tests/units/frameworks/scheduler/cleanupScheduler.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/cleanup.routes.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/http/cleanup.routes.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/cleanup.routes.test.js +62 -0
- package/dist/tests/units/interface-adapters/controllers/http/cleanup.routes.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/health.routes.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/http/health.routes.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/health.routes.test.js +96 -0
- package/dist/tests/units/interface-adapters/controllers/http/health.routes.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/insights.routes.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/http/insights.routes.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/insights.routes.test.js +390 -0
- package/dist/tests/units/interface-adapters/controllers/http/insights.routes.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/settings.routes.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/http/settings.routes.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/settings.routes.test.js +25 -0
- package/dist/tests/units/interface-adapters/controllers/http/settings.routes.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/statsRecalculate.routes.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/http/statsRecalculate.routes.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/statsRecalculate.routes.test.js +82 -0
- package/dist/tests/units/interface-adapters/controllers/http/statsRecalculate.routes.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/version.routes.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/http/version.routes.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/version.routes.test.js +108 -0
- package/dist/tests/units/interface-adapters/controllers/http/version.routes.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/github.controller.test.js +3 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/github.controller.test.js.map +1 -1
- package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js +1 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js.map +1 -1
- package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.github.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.github.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.github.gateway.test.js +63 -0
- package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.github.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.test.js +94 -0
- package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/insights.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/insights.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/insights.gateway.test.js +117 -0
- package/dist/tests/units/interface-adapters/gateways/insights.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/packageVersion.npm.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/packageVersion.npm.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/packageVersion.npm.gateway.test.js +42 -0
- package/dist/tests/units/interface-adapters/gateways/packageVersion.npm.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewLogFile.fileSystem.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/reviewLogFile.fileSystem.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewLogFile.fileSystem.test.js +65 -0
- package/dist/tests/units/interface-adapters/gateways/reviewLogFile.fileSystem.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewLogFile.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/reviewLogFile.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewLogFile.gateway.test.js +63 -0
- package/dist/tests/units/interface-adapters/gateways/reviewLogFile.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewRequestTracking.gateway.test.js +2 -0
- package/dist/tests/units/interface-adapters/gateways/reviewRequestTracking.gateway.test.js.map +1 -1
- package/dist/tests/units/interface-adapters/gateways/selfUpdate.cli.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/selfUpdate.cli.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/selfUpdate.cli.gateway.test.js +101 -0
- package/dist/tests/units/interface-adapters/gateways/selfUpdate.cli.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/versionCache.memory.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/versionCache.memory.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/versionCache.memory.gateway.test.js +38 -0
- package/dist/tests/units/interface-adapters/gateways/versionCache.memory.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/presenters/insights.presenter.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/presenters/insights.presenter.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/presenters/insights.presenter.test.js +194 -0
- package/dist/tests/units/interface-adapters/presenters/insights.presenter.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/developerSheet.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/developerSheet.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/developerSheet.test.js +224 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/developerSheet.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/i18n.test.js +29 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/i18n.test.js.map +1 -1
- package/dist/tests/units/interface-adapters/views/dashboard/modules/insightsReport.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/insightsReport.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/insightsReport.test.js +326 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/insightsReport.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/teamTab.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/teamTab.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/teamTab.test.js +336 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/teamTab.test.js.map +1 -0
- package/dist/tests/units/services/statsService.addReview.test.d.ts +2 -0
- package/dist/tests/units/services/statsService.addReview.test.d.ts.map +1 -0
- package/dist/tests/units/services/statsService.addReview.test.js +103 -0
- package/dist/tests/units/services/statsService.addReview.test.js.map +1 -0
- package/dist/tests/units/services/statsService.diffStats.test.d.ts +2 -0
- package/dist/tests/units/services/statsService.diffStats.test.d.ts.map +1 -0
- package/dist/tests/units/services/statsService.diffStats.test.js +61 -0
- package/dist/tests/units/services/statsService.diffStats.test.js.map +1 -0
- package/dist/tests/units/stubs/packageVersion.stub.test.d.ts +2 -0
- package/dist/tests/units/stubs/packageVersion.stub.test.d.ts.map +1 -0
- package/dist/tests/units/stubs/packageVersion.stub.test.js +20 -0
- package/dist/tests/units/stubs/packageVersion.stub.test.js.map +1 -0
- package/dist/tests/units/stubs/selfUpdate.stub.test.d.ts +2 -0
- package/dist/tests/units/stubs/selfUpdate.stub.test.d.ts.map +1 -0
- package/dist/tests/units/stubs/selfUpdate.stub.test.js +30 -0
- package/dist/tests/units/stubs/selfUpdate.stub.test.js.map +1 -0
- package/dist/tests/units/stubs/versionCache.stub.test.d.ts +2 -0
- package/dist/tests/units/stubs/versionCache.stub.test.d.ts.map +1 -0
- package/dist/tests/units/stubs/versionCache.stub.test.js +34 -0
- package/dist/tests/units/stubs/versionCache.stub.test.js.map +1 -0
- package/dist/tests/units/usecases/cleanup/cleanupExpiredReviews.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/cleanup/cleanupExpiredReviews.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/cleanup/cleanupExpiredReviews.usecase.test.js +83 -0
- package/dist/tests/units/usecases/cleanup/cleanupExpiredReviews.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/insights/buildAiInsightsPrompt.test.d.ts +2 -0
- package/dist/tests/units/usecases/insights/buildAiInsightsPrompt.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/insights/buildAiInsightsPrompt.test.js +172 -0
- package/dist/tests/units/usecases/insights/buildAiInsightsPrompt.test.js.map +1 -0
- package/dist/tests/units/usecases/insights/computeDeveloperInsights.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/insights/computeDeveloperInsights.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/insights/computeDeveloperInsights.usecase.test.js +449 -0
- package/dist/tests/units/usecases/insights/computeDeveloperInsights.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/insights/computeInsightsWithPersistence.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/insights/computeInsightsWithPersistence.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/insights/computeInsightsWithPersistence.usecase.test.js +326 -0
- package/dist/tests/units/usecases/insights/computeInsightsWithPersistence.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/insights/computeTeamInsights.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/insights/computeTeamInsights.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/insights/computeTeamInsights.usecase.test.js +172 -0
- package/dist/tests/units/usecases/insights/computeTeamInsights.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.js +253 -0
- package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/insights/getInsightsWithAiStatus.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/insights/getInsightsWithAiStatus.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/insights/getInsightsWithAiStatus.usecase.test.js +160 -0
- package/dist/tests/units/usecases/insights/getInsightsWithAiStatus.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/insights/insightLevelComputation.service.test.d.ts +2 -0
- package/dist/tests/units/usecases/insights/insightLevelComputation.service.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/insights/insightLevelComputation.service.test.js +125 -0
- package/dist/tests/units/usecases/insights/insightLevelComputation.service.test.js.map +1 -0
- package/dist/tests/units/usecases/stats/backfillDiffStats.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/stats/backfillDiffStats.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/stats/backfillDiffStats.usecase.test.js +186 -0
- package/dist/tests/units/usecases/stats/backfillDiffStats.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/stats/recalculateProjectStats.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/stats/recalculateProjectStats.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/stats/recalculateProjectStats.usecase.test.js +130 -0
- package/dist/tests/units/usecases/stats/recalculateProjectStats.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/stats/recalculateWithBackfill.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/stats/recalculateWithBackfill.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/stats/recalculateWithBackfill.usecase.test.js +138 -0
- package/dist/tests/units/usecases/stats/recalculateWithBackfill.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/tracking/recordReviewCompletion.usecase.test.js +31 -2
- package/dist/tests/units/usecases/tracking/recordReviewCompletion.usecase.test.js.map +1 -1
- package/dist/tests/units/usecases/version/checkVersion.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/version/checkVersion.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/version/checkVersion.usecase.test.js +63 -0
- package/dist/tests/units/usecases/version/checkVersion.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/version/triggerSelfUpdate.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/version/triggerSelfUpdate.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/version/triggerSelfUpdate.usecase.test.js +26 -0
- package/dist/tests/units/usecases/version/triggerSelfUpdate.usecase.test.js.map +1 -0
- package/dist/usecases/cleanup/cleanupExpiredReviews.usecase.d.ts +13 -0
- package/dist/usecases/cleanup/cleanupExpiredReviews.usecase.d.ts.map +1 -0
- package/dist/usecases/cleanup/cleanupExpiredReviews.usecase.js +41 -0
- package/dist/usecases/cleanup/cleanupExpiredReviews.usecase.js.map +1 -0
- package/dist/usecases/insights/buildAiInsightsPrompt.d.ts +12 -0
- package/dist/usecases/insights/buildAiInsightsPrompt.d.ts.map +1 -0
- package/dist/usecases/insights/buildAiInsightsPrompt.js +220 -0
- package/dist/usecases/insights/buildAiInsightsPrompt.js.map +1 -0
- package/dist/usecases/insights/computeDeveloperInsights.usecase.d.ts +4 -0
- package/dist/usecases/insights/computeDeveloperInsights.usecase.d.ts.map +1 -0
- package/dist/usecases/insights/computeDeveloperInsights.usecase.js +226 -0
- package/dist/usecases/insights/computeDeveloperInsights.usecase.js.map +1 -0
- package/dist/usecases/insights/computeInsightsWithPersistence.usecase.d.ts +12 -0
- package/dist/usecases/insights/computeInsightsWithPersistence.usecase.d.ts.map +1 -0
- package/dist/usecases/insights/computeInsightsWithPersistence.usecase.js +340 -0
- package/dist/usecases/insights/computeInsightsWithPersistence.usecase.js.map +1 -0
- package/dist/usecases/insights/computeTeamInsights.usecase.d.ts +4 -0
- package/dist/usecases/insights/computeTeamInsights.usecase.d.ts.map +1 -0
- package/dist/usecases/insights/computeTeamInsights.usecase.js +111 -0
- package/dist/usecases/insights/computeTeamInsights.usecase.js.map +1 -0
- package/dist/usecases/insights/generateAiInsights.usecase.d.ts +27 -0
- package/dist/usecases/insights/generateAiInsights.usecase.d.ts.map +1 -0
- package/dist/usecases/insights/generateAiInsights.usecase.js +65 -0
- package/dist/usecases/insights/generateAiInsights.usecase.js.map +1 -0
- package/dist/usecases/insights/getInsightsWithAiStatus.usecase.d.ts +18 -0
- package/dist/usecases/insights/getInsightsWithAiStatus.usecase.d.ts.map +1 -0
- package/dist/usecases/insights/getInsightsWithAiStatus.usecase.js +56 -0
- package/dist/usecases/insights/getInsightsWithAiStatus.usecase.js.map +1 -0
- package/dist/usecases/insights/insightLevelComputation.service.d.ts +41 -0
- package/dist/usecases/insights/insightLevelComputation.service.d.ts.map +1 -0
- package/dist/usecases/insights/insightLevelComputation.service.js +313 -0
- package/dist/usecases/insights/insightLevelComputation.service.js.map +1 -0
- package/dist/usecases/stats/backfillDiffStats.usecase.d.ts +18 -0
- package/dist/usecases/stats/backfillDiffStats.usecase.d.ts.map +1 -0
- package/dist/usecases/stats/backfillDiffStats.usecase.js +43 -0
- package/dist/usecases/stats/backfillDiffStats.usecase.js.map +1 -0
- package/dist/usecases/stats/recalculateProjectStats.usecase.d.ts +7 -0
- package/dist/usecases/stats/recalculateProjectStats.usecase.d.ts.map +1 -0
- package/dist/usecases/stats/recalculateProjectStats.usecase.js +47 -0
- package/dist/usecases/stats/recalculateProjectStats.usecase.js.map +1 -0
- package/dist/usecases/stats/recalculateWithBackfill.usecase.d.ts +22 -0
- package/dist/usecases/stats/recalculateWithBackfill.usecase.d.ts.map +1 -0
- package/dist/usecases/stats/recalculateWithBackfill.usecase.js +33 -0
- package/dist/usecases/stats/recalculateWithBackfill.usecase.js.map +1 -0
- package/dist/usecases/tracking/recordReviewCompletion.usecase.d.ts +2 -0
- package/dist/usecases/tracking/recordReviewCompletion.usecase.d.ts.map +1 -1
- package/dist/usecases/tracking/recordReviewCompletion.usecase.js +1 -0
- package/dist/usecases/tracking/recordReviewCompletion.usecase.js.map +1 -1
- package/dist/usecases/version/checkVersion.usecase.d.ts +13 -0
- package/dist/usecases/version/checkVersion.usecase.d.ts.map +1 -0
- package/dist/usecases/version/checkVersion.usecase.js +20 -0
- package/dist/usecases/version/checkVersion.usecase.js.map +1 -0
- package/dist/usecases/version/triggerSelfUpdate.usecase.d.ts +7 -0
- package/dist/usecases/version/triggerSelfUpdate.usecase.d.ts.map +1 -0
- package/dist/usecases/version/triggerSelfUpdate.usecase.js +12 -0
- package/dist/usecases/version/triggerSelfUpdate.usecase.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,296 @@
|
|
|
1
|
+
import { escapeHtml } from './html.js';
|
|
2
|
+
import { icon } from './icons.js';
|
|
3
|
+
import {
|
|
4
|
+
getAvatarBorderClass,
|
|
5
|
+
getTierClass,
|
|
6
|
+
renderLevelRing,
|
|
7
|
+
renderStatBar,
|
|
8
|
+
} from './sharedViewHelpers.js';
|
|
9
|
+
|
|
10
|
+
const CATEGORY_KEYS = ['quality', 'responsiveness', 'codeVolume', 'iteration'];
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* @param {object} developer
|
|
14
|
+
* @param {(key: string, params?: Record<string, string|number>) => string} translate
|
|
15
|
+
* @param {object|null} [aiDeveloper]
|
|
16
|
+
* @returns {string}
|
|
17
|
+
*/
|
|
18
|
+
function renderDeveloperCard(developer, translate, aiDeveloper) {
|
|
19
|
+
const initial = developer.developerName.charAt(0).toUpperCase();
|
|
20
|
+
const avatarBorderClass = getAvatarBorderClass(developer.overallLevel);
|
|
21
|
+
const tierClass = getTierClass(developer.overallLevel);
|
|
22
|
+
const encodedName = encodeURIComponent(developer.developerName);
|
|
23
|
+
|
|
24
|
+
const statBarsHtml = CATEGORY_KEYS.map(
|
|
25
|
+
(key) => renderStatBar(developer.categoryLevels[key], key, translate)
|
|
26
|
+
).join('');
|
|
27
|
+
|
|
28
|
+
const titleHtml = aiDeveloper
|
|
29
|
+
? `<div class="dev-title ai-title">${icon('sparkles', 'ai-sparkle-icon')} ${escapeHtml(aiDeveloper.title)}</div>`
|
|
30
|
+
: `<div class="dev-title">${translate('title.' + developer.title)}</div>`;
|
|
31
|
+
|
|
32
|
+
const metrics = developer.metrics;
|
|
33
|
+
const avgScore = metrics ? Number(metrics.averageScore).toFixed(1) : null;
|
|
34
|
+
const qualityRate = metrics ? Math.round(metrics.firstReviewQualityRate * 100) : null;
|
|
35
|
+
|
|
36
|
+
return `
|
|
37
|
+
<div class="dev-card ${tierClass}" onclick="openDevSheet('${encodedName}')" role="button" tabindex="0">
|
|
38
|
+
<div class="dev-card-header">
|
|
39
|
+
<div class="dev-avatar-placeholder ${avatarBorderClass}">${escapeHtml(initial)}</div>
|
|
40
|
+
<div class="dev-card-identity">
|
|
41
|
+
<div class="dev-name">${escapeHtml(developer.developerName)}</div>
|
|
42
|
+
${titleHtml}
|
|
43
|
+
</div>
|
|
44
|
+
${renderLevelRing(developer.overallLevel, 52, translate('team.overallLevel') + ' ' + developer.overallLevel + '/10')}
|
|
45
|
+
</div>
|
|
46
|
+
<div class="dev-card-chips">
|
|
47
|
+
${avgScore ? `<span class="dev-chip dev-chip-score" title="${translate('devSheet.metrics.averageScore')}">${icon('star', 'dev-chip-icon')} ${avgScore}</span>` : ''}
|
|
48
|
+
${qualityRate !== null ? `<span class="dev-chip dev-chip-quality" title="${translate('devSheet.metrics.firstPassQuality')}">${icon('zap', 'dev-chip-icon')} ${qualityRate}%</span>` : ''}
|
|
49
|
+
<span class="dev-chip dev-chip-count" title="${translate('devSheet.reviewCount', { count: developer.reviewCount })}">${icon('file-search', 'dev-chip-icon')} ${developer.reviewCount}</span>
|
|
50
|
+
</div>
|
|
51
|
+
<div class="dev-card-stats">
|
|
52
|
+
${statBarsHtml}
|
|
53
|
+
</div>
|
|
54
|
+
</div>
|
|
55
|
+
`;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* @param {object} team
|
|
60
|
+
* @param {(key: string, params?: Record<string, string|number>) => string} translate
|
|
61
|
+
* @returns {string}
|
|
62
|
+
*/
|
|
63
|
+
function renderTeamHealthStrip(team, translate) {
|
|
64
|
+
const avgLevel = (
|
|
65
|
+
team.averageLevels.quality +
|
|
66
|
+
team.averageLevels.responsiveness +
|
|
67
|
+
team.averageLevels.codeVolume +
|
|
68
|
+
team.averageLevels.iteration
|
|
69
|
+
) / 4;
|
|
70
|
+
const tierClass = getTierClass(Math.round(avgLevel));
|
|
71
|
+
|
|
72
|
+
return `
|
|
73
|
+
<div class="team-health-strip">
|
|
74
|
+
<div class="team-health-stat" title="${translate('team.healthStrip.developers')}">
|
|
75
|
+
${icon('users', 'team-health-icon')}
|
|
76
|
+
<span class="team-health-value">${team.developerCount}</span>
|
|
77
|
+
</div>
|
|
78
|
+
<div class="team-health-divider"></div>
|
|
79
|
+
<div class="team-health-stat" title="${translate('team.healthStrip.reviews')}">
|
|
80
|
+
${icon('file-search', 'team-health-icon')}
|
|
81
|
+
<span class="team-health-value">${team.totalReviewCount}</span>
|
|
82
|
+
</div>
|
|
83
|
+
<div class="team-health-divider"></div>
|
|
84
|
+
<div class="team-health-stat ${tierClass}" title="${translate('team.healthStrip.avgLevel')}">
|
|
85
|
+
${icon('gauge', 'team-health-icon')}
|
|
86
|
+
<span class="team-health-value">${avgLevel.toFixed(1)}<span class="team-health-unit">/10</span></span>
|
|
87
|
+
</div>
|
|
88
|
+
</div>
|
|
89
|
+
`;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
/**
|
|
93
|
+
* @param {object} team
|
|
94
|
+
* @param {(key: string, params?: Record<string, string|number>) => string} translate
|
|
95
|
+
* @returns {string}
|
|
96
|
+
*/
|
|
97
|
+
function renderTeamInsights(team, translate) {
|
|
98
|
+
const strengthTags = team.strengths.map(
|
|
99
|
+
(category) => `<span class="insight-tag insight-strength">${icon('thumbs-up', 'insight-icon')} ${translate('category.' + category)}</span>`
|
|
100
|
+
).join('');
|
|
101
|
+
|
|
102
|
+
const weaknessTags = team.weaknesses.map(
|
|
103
|
+
(category) => `<span class="insight-tag insight-weakness">${icon('alert-triangle', 'insight-icon')} ${translate('category.' + category)}</span>`
|
|
104
|
+
).join('');
|
|
105
|
+
|
|
106
|
+
const tipsList = team.tips.map(
|
|
107
|
+
(tip) => `<li class="insight-tip-item">${icon('lightbulb', 'insight-icon')} ${escapeHtml(tip)}</li>`
|
|
108
|
+
).join('');
|
|
109
|
+
|
|
110
|
+
return `
|
|
111
|
+
<div class="team-insights">
|
|
112
|
+
<div class="team-insight-group">
|
|
113
|
+
<div class="team-insight-section">
|
|
114
|
+
<div class="team-insight-label">${icon('thumbs-up')} ${translate('team.strengths')}</div>
|
|
115
|
+
<div class="team-insight-tags">${strengthTags || '<span class="team-insight-empty">-</span>'}</div>
|
|
116
|
+
</div>
|
|
117
|
+
<div class="team-insight-section">
|
|
118
|
+
<div class="team-insight-label">${icon('alert-triangle')} ${translate('team.weaknesses')}</div>
|
|
119
|
+
<div class="team-insight-tags">${weaknessTags || '<span class="team-insight-empty">-</span>'}</div>
|
|
120
|
+
</div>
|
|
121
|
+
</div>
|
|
122
|
+
${team.tips.length > 0 ? `
|
|
123
|
+
<div class="team-insight-tips">
|
|
124
|
+
<div class="team-insight-label">${icon('lightbulb')} ${translate('team.tips')}</div>
|
|
125
|
+
<ul class="insight-tips-list">${tipsList}</ul>
|
|
126
|
+
</div>
|
|
127
|
+
` : ''}
|
|
128
|
+
</div>
|
|
129
|
+
`;
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
/**
|
|
133
|
+
* @param {object|null} aiInsights
|
|
134
|
+
* @param {boolean} hasNewReviewsSinceAiGeneration
|
|
135
|
+
* @param {(key: string, params?: Record<string, string|number>) => string} translate
|
|
136
|
+
* @returns {string}
|
|
137
|
+
*/
|
|
138
|
+
function renderAiGenerateButton(aiInsights, hasNewReviewsSinceAiGeneration, translate) {
|
|
139
|
+
if (!aiInsights) {
|
|
140
|
+
return `
|
|
141
|
+
<button class="ai-generate-btn" onclick="generateAiInsights()">
|
|
142
|
+
${icon('sparkles')} ${translate('ai.generate')}
|
|
143
|
+
</button>
|
|
144
|
+
`;
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
if (hasNewReviewsSinceAiGeneration) {
|
|
148
|
+
return `
|
|
149
|
+
<div class="ai-generate-bar">
|
|
150
|
+
<button class="ai-generate-btn" onclick="generateAiInsights()">
|
|
151
|
+
${icon('sparkles')} ${translate('ai.refresh')}
|
|
152
|
+
<span class="ai-badge">${translate('ai.newDataAvailable')}</span>
|
|
153
|
+
</button>
|
|
154
|
+
</div>
|
|
155
|
+
`;
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
const generatedDate = new Date(aiInsights.generatedAt).toLocaleDateString();
|
|
159
|
+
return `
|
|
160
|
+
<div class="ai-generate-bar">
|
|
161
|
+
<span class="ai-last-generated">${translate('ai.lastGenerated', { date: generatedDate })}</span>
|
|
162
|
+
<button class="ai-generate-btn ai-refresh-btn" onclick="generateAiInsights()">
|
|
163
|
+
${icon('refresh-cw')}
|
|
164
|
+
</button>
|
|
165
|
+
</div>
|
|
166
|
+
`;
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
/**
|
|
170
|
+
* @param {object} aiTeam
|
|
171
|
+
* @param {(key: string, params?: Record<string, string|number>) => string} translate
|
|
172
|
+
* @returns {string}
|
|
173
|
+
*/
|
|
174
|
+
function renderAiTeamCard(aiTeam, translate) {
|
|
175
|
+
const strengthsList = aiTeam.strengths.map(
|
|
176
|
+
(strength) => `<li class="ai-list-item">${icon('check-circle', 'ai-list-icon')} ${escapeHtml(strength)}</li>`
|
|
177
|
+
).join('');
|
|
178
|
+
|
|
179
|
+
const weaknessesList = aiTeam.weaknesses.map(
|
|
180
|
+
(weakness) => `<li class="ai-list-item">${icon('alert-circle', 'ai-list-icon')} ${escapeHtml(weakness)}</li>`
|
|
181
|
+
).join('');
|
|
182
|
+
|
|
183
|
+
const recommendationsList = aiTeam.recommendations.map(
|
|
184
|
+
(recommendation) => `<li class="ai-list-item">${icon('lightbulb', 'ai-list-icon')} ${escapeHtml(recommendation)}</li>`
|
|
185
|
+
).join('');
|
|
186
|
+
|
|
187
|
+
return `
|
|
188
|
+
<div class="ai-team-card">
|
|
189
|
+
<div class="ai-team-card-header clickable" onclick="toggleTeamAnalysis()" role="button" tabindex="0">
|
|
190
|
+
${icon('sparkles', 'ai-sparkle-icon')} ${translate('ai.teamAnalysis')}
|
|
191
|
+
<span id="team-analysis-toggle" class="toggle-icon"><i data-lucide="chevron-up"></i></span>
|
|
192
|
+
</div>
|
|
193
|
+
<div id="team-analysis-body" class="ai-team-card-body">
|
|
194
|
+
<div class="ai-summary">${escapeHtml(aiTeam.summary)}</div>
|
|
195
|
+
${aiTeam.strengths.length > 0 ? `
|
|
196
|
+
<div class="ai-section-group">
|
|
197
|
+
<div class="ai-section-label">${icon('check-circle')} ${translate('ai.strengths')}</div>
|
|
198
|
+
<ul class="ai-list">${strengthsList}</ul>
|
|
199
|
+
</div>
|
|
200
|
+
` : ''}
|
|
201
|
+
${aiTeam.weaknesses.length > 0 ? `
|
|
202
|
+
<div class="ai-section-group">
|
|
203
|
+
<div class="ai-section-label">${icon('alert-circle')} ${translate('ai.weaknesses')}</div>
|
|
204
|
+
<ul class="ai-list">${weaknessesList}</ul>
|
|
205
|
+
</div>
|
|
206
|
+
` : ''}
|
|
207
|
+
${aiTeam.recommendations.length > 0 ? `
|
|
208
|
+
<div class="ai-section-group">
|
|
209
|
+
<div class="ai-section-label">${icon('lightbulb')} ${translate('ai.recommendations')}</div>
|
|
210
|
+
<ul class="ai-list">${recommendationsList}</ul>
|
|
211
|
+
</div>
|
|
212
|
+
` : ''}
|
|
213
|
+
<div class="ai-section-group">
|
|
214
|
+
<div class="ai-section-label">${icon('users')} ${translate('ai.dynamics')}</div>
|
|
215
|
+
<div class="ai-summary">${escapeHtml(aiTeam.dynamics)}</div>
|
|
216
|
+
</div>
|
|
217
|
+
</div>
|
|
218
|
+
</div>
|
|
219
|
+
`;
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
/**
|
|
223
|
+
* @param {object} insightsData
|
|
224
|
+
* @param {(key: string, params?: Record<string, string|number>) => string} translate
|
|
225
|
+
* @returns {string}
|
|
226
|
+
*/
|
|
227
|
+
export function renderTeamTab(insightsData, translate) {
|
|
228
|
+
if (insightsData.isEmpty) {
|
|
229
|
+
return `<div class="empty-state">${icon('users')} ${translate('team.noData')}</div>`;
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
const aiInsights = insightsData.aiInsights || null;
|
|
233
|
+
const hasNewReviews = insightsData.hasNewReviewsSinceAiGeneration === true;
|
|
234
|
+
|
|
235
|
+
const aiButtonHtml = renderAiGenerateButton(aiInsights, hasNewReviews, translate);
|
|
236
|
+
const hasAiTeam = aiInsights?.team !== undefined && aiInsights?.team !== null;
|
|
237
|
+
const teamSectionHtml = hasAiTeam
|
|
238
|
+
? renderAiTeamCard(aiInsights.team, translate)
|
|
239
|
+
: renderTeamInsights(insightsData.team, translate);
|
|
240
|
+
|
|
241
|
+
const aiDevelopers = aiInsights?.developers ? aiInsights.developers : [];
|
|
242
|
+
const developerCardsHtml = insightsData.developers.map((developer) => {
|
|
243
|
+
const aiDeveloper = aiDevelopers.find(
|
|
244
|
+
(aiDev) => aiDev.developerName === developer.developerName
|
|
245
|
+
) || null;
|
|
246
|
+
return renderDeveloperCard(developer, translate, aiDeveloper);
|
|
247
|
+
}).join('');
|
|
248
|
+
|
|
249
|
+
const exportButtonHtml = `
|
|
250
|
+
<button class="export-pdf-btn" onclick="exportInsightsPdf()">
|
|
251
|
+
${icon('file-text')} ${translate('export.pdf')}
|
|
252
|
+
</button>
|
|
253
|
+
`;
|
|
254
|
+
|
|
255
|
+
const healthStripHtml = renderTeamHealthStrip(insightsData.team, translate);
|
|
256
|
+
|
|
257
|
+
return `
|
|
258
|
+
<div class="team-tab-actions">
|
|
259
|
+
${aiButtonHtml}
|
|
260
|
+
${exportButtonHtml}
|
|
261
|
+
</div>
|
|
262
|
+
${healthStripHtml}
|
|
263
|
+
${teamSectionHtml}
|
|
264
|
+
<div class="team-grid">
|
|
265
|
+
${developerCardsHtml}
|
|
266
|
+
</div>
|
|
267
|
+
`;
|
|
268
|
+
}
|
|
269
|
+
|
|
270
|
+
/**
|
|
271
|
+
* @param {string} projectPath
|
|
272
|
+
* @param {(key: string, params?: Record<string, string|number>) => string} translate
|
|
273
|
+
* @param {string} apiUrl
|
|
274
|
+
*/
|
|
275
|
+
export async function fetchAndRenderTeamTab(projectPath, translate, apiUrl) {
|
|
276
|
+
const container = document.getElementById('team-tab-content');
|
|
277
|
+
if (!container) return;
|
|
278
|
+
|
|
279
|
+
container.innerHTML = `<div class="empty-state team-loading">${icon('loader-circle', 'spinning')} ${translate('team.loading')}</div>`;
|
|
280
|
+
|
|
281
|
+
try {
|
|
282
|
+
const response = await fetch(`${apiUrl}/api/insights?path=${encodeURIComponent(projectPath)}`);
|
|
283
|
+
const data = await response.json();
|
|
284
|
+
|
|
285
|
+
container.innerHTML = renderTeamTab(data, translate);
|
|
286
|
+
|
|
287
|
+
setTimeout(() => {
|
|
288
|
+
container.querySelectorAll('.stat-bar-fill[data-target-width]').forEach((bar) => {
|
|
289
|
+
bar.style.width = bar.dataset.targetWidth;
|
|
290
|
+
});
|
|
291
|
+
}, 50);
|
|
292
|
+
} catch (error) {
|
|
293
|
+
console.error('Error fetching team insights:', error);
|
|
294
|
+
container.innerHTML = `<div class="empty-state">${translate('team.noData')}</div>`;
|
|
295
|
+
}
|
|
296
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"teamTab.js","sourceRoot":"","sources":["../../../../../src/interface-adapters/views/dashboard/modules/teamTab.js"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @param {{ currentVersion: string, updateAvailable: boolean, latestVersion: string | null }} versionData
|
|
3
|
+
* @param {(key: string, params?: Record<string, string | number>) => string} translate
|
|
4
|
+
* @returns {string}
|
|
5
|
+
*/
|
|
6
|
+
export function renderVersionUpdateArea(versionData: {
|
|
7
|
+
currentVersion: string;
|
|
8
|
+
updateAvailable: boolean;
|
|
9
|
+
latestVersion: string | null;
|
|
10
|
+
}, translate: (key: string, params?: Record<string, string | number>) => string): string;
|
|
11
|
+
/**
|
|
12
|
+
* @param {'idle' | 'checking' | 'updating' | 'restarting'} status
|
|
13
|
+
* @param {(key: string) => string} translate
|
|
14
|
+
*/
|
|
15
|
+
export function setVersionCheckState(status: "idle" | "checking" | "updating" | "restarting", translate: (key: string) => string): void;
|
|
16
|
+
//# sourceMappingURL=versionUpdate.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"versionUpdate.d.ts","sourceRoot":"","sources":["../../../../../src/interface-adapters/views/dashboard/modules/versionUpdate.js"],"names":[],"mappings":"AAEA;;;;GAIG;AACH,qDAJW;IAAE,cAAc,EAAE,MAAM,CAAC;IAAC,eAAe,EAAE,OAAO,CAAC;IAAC,aAAa,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,aAClF,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,KAAK,MAAM,GAC/D,MAAM,CAmBlB;AAED;;;GAGG;AACH,6CAHW,MAAM,GAAG,UAAU,GAAG,UAAU,GAAG,YAAY,aAC/C,CAAC,GAAG,EAAE,MAAM,KAAK,MAAM,QAyBjC"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { escapeHtml } from './html.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @param {{ currentVersion: string, updateAvailable: boolean, latestVersion: string | null }} versionData
|
|
5
|
+
* @param {(key: string, params?: Record<string, string | number>) => string} translate
|
|
6
|
+
* @returns {string}
|
|
7
|
+
*/
|
|
8
|
+
export function renderVersionUpdateArea(versionData, translate) {
|
|
9
|
+
const versionLabel = `<span class="version-label">v${escapeHtml(versionData.currentVersion)}</span>`;
|
|
10
|
+
|
|
11
|
+
const checkButton = `<button id="version-check-btn" class="btn btn-icon" title="${escapeHtml(translate('version.checkTooltip'))}" onclick="checkForUpdates()">
|
|
12
|
+
<i data-lucide="refresh-cw"></i>
|
|
13
|
+
</button>`;
|
|
14
|
+
|
|
15
|
+
if (!versionData.updateAvailable || !versionData.latestVersion) {
|
|
16
|
+
return `${versionLabel}${checkButton}`;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
const label = translate('version.updateAvailable', { version: versionData.latestVersion });
|
|
20
|
+
const updateButton = `<button id="version-update-btn" class="btn btn-update" onclick="triggerVersionUpdate()">
|
|
21
|
+
<i data-lucide="download"></i> <span>${escapeHtml(label)}</span>
|
|
22
|
+
</button>`;
|
|
23
|
+
|
|
24
|
+
return `${versionLabel}${updateButton}${checkButton}`;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* @param {'idle' | 'checking' | 'updating' | 'restarting'} status
|
|
29
|
+
* @param {(key: string) => string} translate
|
|
30
|
+
*/
|
|
31
|
+
export function setVersionCheckState(status, translate) {
|
|
32
|
+
const checkBtn = document.getElementById('version-check-btn');
|
|
33
|
+
const updateBtn = document.getElementById('version-update-btn');
|
|
34
|
+
|
|
35
|
+
if (status === 'checking' && checkBtn) {
|
|
36
|
+
checkBtn.classList.add('spinning');
|
|
37
|
+
checkBtn.disabled = true;
|
|
38
|
+
} else if (checkBtn) {
|
|
39
|
+
checkBtn.classList.remove('spinning');
|
|
40
|
+
checkBtn.disabled = false;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
if (status === 'updating' && updateBtn) {
|
|
44
|
+
updateBtn.disabled = true;
|
|
45
|
+
const span = updateBtn.querySelector('span');
|
|
46
|
+
if (span) span.textContent = translate('version.updating');
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
if (status === 'restarting' && updateBtn) {
|
|
50
|
+
updateBtn.disabled = true;
|
|
51
|
+
const span = updateBtn.querySelector('span');
|
|
52
|
+
if (span) span.textContent = translate('version.restarting');
|
|
53
|
+
}
|
|
54
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"versionUpdate.js","sourceRoot":"","sources":["../../../../../src/interface-adapters/views/dashboard/modules/versionUpdate.js"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAEvC;;;;GAIG;AACH,MAAM,UAAU,uBAAuB,CAAC,WAAW,EAAE,SAAS;IAC5D,MAAM,YAAY,GAAG,gCAAgC,UAAU,CAAC,WAAW,CAAC,cAAc,CAAC,SAAS,CAAC;IAErG,MAAM,WAAW,GAAG,8DAA8D,UAAU,CAAC,SAAS,CAAC,sBAAsB,CAAC,CAAC;;YAErH,CAAC;IAEX,IAAI,CAAC,WAAW,CAAC,eAAe,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,CAAC;QAC/D,OAAO,GAAG,YAAY,GAAG,WAAW,EAAE,CAAC;IACzC,CAAC;IAED,MAAM,KAAK,GAAG,SAAS,CAAC,yBAAyB,EAAE,EAAE,OAAO,EAAE,WAAW,CAAC,aAAa,EAAE,CAAC,CAAC;IAC3F,MAAM,YAAY,GAAG;2CACoB,UAAU,CAAC,KAAK,CAAC;YAChD,CAAC;IAEX,OAAO,GAAG,YAAY,GAAG,YAAY,GAAG,WAAW,EAAE,CAAC;AACxD,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,oBAAoB,CAAC,MAAM,EAAE,SAAS;IACpD,MAAM,QAAQ,GAAG,QAAQ,CAAC,cAAc,CAAC,mBAAmB,CAAC,CAAC;IAC9D,MAAM,SAAS,GAAG,QAAQ,CAAC,cAAc,CAAC,oBAAoB,CAAC,CAAC;IAEhE,IAAI,MAAM,KAAK,UAAU,IAAI,QAAQ,EAAE,CAAC;QACtC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACnC,QAAQ,CAAC,QAAQ,GAAG,IAAI,CAAC;IAC3B,CAAC;SAAM,IAAI,QAAQ,EAAE,CAAC;QACpB,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QACtC,QAAQ,CAAC,QAAQ,GAAG,KAAK,CAAC;IAC5B,CAAC;IAED,IAAI,MAAM,KAAK,UAAU,IAAI,SAAS,EAAE,CAAC;QACvC,SAAS,CAAC,QAAQ,GAAG,IAAI,CAAC;QAC1B,MAAM,IAAI,GAAG,SAAS,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAC7C,IAAI,IAAI;YAAE,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC,kBAAkB,CAAC,CAAC;IAC7D,CAAC;IAED,IAAI,MAAM,KAAK,YAAY,IAAI,SAAS,EAAE,CAAC;QACzC,SAAS,CAAC,QAAQ,GAAG,IAAI,CAAC;QAC1B,MAAM,IAAI,GAAG,SAAS,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAC7C,IAAI,IAAI;YAAE,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC,oBAAoB,CAAC,CAAC;IAC/D,CAAC;AACH,CAAC"}
|