devskill 2.0.7 → 2.0.8
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/meta.ts +4 -0
- package/package.json +1 -1
- package/skills/add-educational-comments/LICENSE.md +21 -0
- package/skills/add-educational-comments/SKILL.md +128 -0
- package/skills/add-educational-comments/SYNC.md +5 -0
- package/skills/agent-governance/LICENSE.md +21 -0
- package/skills/agent-governance/SKILL.md +569 -0
- package/skills/agent-governance/SYNC.md +5 -0
- package/skills/agentic-eval/LICENSE.md +21 -0
- package/skills/agentic-eval/SKILL.md +189 -0
- package/skills/agentic-eval/SYNC.md +5 -0
- package/skills/ai-prompt-engineering-safety-review/LICENSE.md +21 -0
- package/skills/ai-prompt-engineering-safety-review/SKILL.md +230 -0
- package/skills/ai-prompt-engineering-safety-review/SYNC.md +5 -0
- package/skills/appinsights-instrumentation/LICENSE.md +21 -0
- package/skills/appinsights-instrumentation/LICENSE.txt +21 -0
- package/skills/appinsights-instrumentation/SKILL.md +48 -0
- package/skills/appinsights-instrumentation/SYNC.md +5 -0
- package/skills/appinsights-instrumentation/examples/appinsights.bicep +30 -0
- package/skills/appinsights-instrumentation/references/ASPNETCORE.md +29 -0
- package/skills/appinsights-instrumentation/references/AUTO.md +13 -0
- package/skills/appinsights-instrumentation/references/NODEJS.md +28 -0
- package/skills/appinsights-instrumentation/references/PYTHON.md +48 -0
- package/skills/appinsights-instrumentation/scripts/appinsights.ps1 +20 -0
- package/skills/apple-appstore-reviewer/LICENSE.md +21 -0
- package/skills/apple-appstore-reviewer/SKILL.md +305 -0
- package/skills/apple-appstore-reviewer/SYNC.md +5 -0
- package/skills/arch-linux-triage/LICENSE.md +21 -0
- package/skills/arch-linux-triage/SKILL.md +31 -0
- package/skills/arch-linux-triage/SYNC.md +5 -0
- package/skills/architecture-blueprint-generator/LICENSE.md +21 -0
- package/skills/architecture-blueprint-generator/SKILL.md +322 -0
- package/skills/architecture-blueprint-generator/SYNC.md +5 -0
- package/skills/aspire/LICENSE.md +21 -0
- package/skills/aspire/SKILL.md +231 -0
- package/skills/aspire/SYNC.md +5 -0
- package/skills/aspire/references/architecture.md +341 -0
- package/skills/aspire/references/cli-reference.md +307 -0
- package/skills/aspire/references/dashboard.md +226 -0
- package/skills/aspire/references/deployment.md +237 -0
- package/skills/aspire/references/integrations-catalog.md +68 -0
- package/skills/aspire/references/mcp-server.md +195 -0
- package/skills/aspire/references/polyglot-apis.md +296 -0
- package/skills/aspire/references/testing.md +281 -0
- package/skills/aspire/references/troubleshooting.md +194 -0
- package/skills/aspnet-minimal-api-openapi/LICENSE.md +21 -0
- package/skills/aspnet-minimal-api-openapi/SKILL.md +41 -0
- package/skills/aspnet-minimal-api-openapi/SYNC.md +5 -0
- package/skills/automate-this/LICENSE.md +21 -0
- package/skills/automate-this/SKILL.md +244 -0
- package/skills/automate-this/SYNC.md +5 -0
- package/skills/autoresearch/LICENSE.md +21 -0
- package/skills/autoresearch/SKILL.md +275 -0
- package/skills/autoresearch/SYNC.md +5 -0
- package/skills/aws-cdk-python-setup/LICENSE.md +21 -0
- package/skills/aws-cdk-python-setup/SKILL.md +111 -0
- package/skills/aws-cdk-python-setup/SYNC.md +5 -0
- package/skills/az-cost-optimize/LICENSE.md +21 -0
- package/skills/az-cost-optimize/SKILL.md +305 -0
- package/skills/az-cost-optimize/SYNC.md +5 -0
- package/skills/azure-deployment-preflight/LICENSE.md +21 -0
- package/skills/azure-deployment-preflight/SKILL.md +216 -0
- package/skills/azure-deployment-preflight/SYNC.md +5 -0
- package/skills/azure-deployment-preflight/references/ERROR-HANDLING.md +392 -0
- package/skills/azure-deployment-preflight/references/REPORT-TEMPLATE.md +352 -0
- package/skills/azure-deployment-preflight/references/VALIDATION-COMMANDS.md +379 -0
- package/skills/azure-devops-cli/LICENSE.md +21 -0
- package/skills/azure-devops-cli/SKILL.md +94 -0
- package/skills/azure-devops-cli/SYNC.md +5 -0
- package/skills/azure-devops-cli/references/advanced-usage.md +197 -0
- package/skills/azure-devops-cli/references/boards-and-iterations.md +258 -0
- package/skills/azure-devops-cli/references/org-and-security.md +469 -0
- package/skills/azure-devops-cli/references/pipelines-and-builds.md +245 -0
- package/skills/azure-devops-cli/references/repos-and-prs.md +333 -0
- package/skills/azure-devops-cli/references/variables-and-agents.md +212 -0
- package/skills/azure-devops-cli/references/workflows-and-patterns.md +668 -0
- package/skills/azure-pricing/LICENSE.md +21 -0
- package/skills/azure-pricing/SKILL.md +189 -0
- package/skills/azure-pricing/SYNC.md +5 -0
- package/skills/azure-pricing/references/COPILOT-STUDIO-RATES.md +135 -0
- package/skills/azure-pricing/references/COST-ESTIMATOR.md +142 -0
- package/skills/azure-pricing/references/REGIONS.md +84 -0
- package/skills/azure-pricing/references/SERVICE-NAMES.md +106 -0
- package/skills/azure-resource-health-diagnose/LICENSE.md +21 -0
- package/skills/azure-resource-health-diagnose/SKILL.md +290 -0
- package/skills/azure-resource-health-diagnose/SYNC.md +5 -0
- package/skills/azure-resource-visualizer/LICENSE.md +21 -0
- package/skills/azure-resource-visualizer/LICENSE.txt +21 -0
- package/skills/azure-resource-visualizer/SKILL.md +233 -0
- package/skills/azure-resource-visualizer/SYNC.md +5 -0
- package/skills/azure-resource-visualizer/assets/template-architecture.md +41 -0
- package/skills/azure-role-selector/LICENSE.md +21 -0
- package/skills/azure-role-selector/LICENSE.txt +21 -0
- package/skills/azure-role-selector/SKILL.md +6 -0
- package/skills/azure-role-selector/SYNC.md +5 -0
- package/skills/azure-static-web-apps/LICENSE.md +21 -0
- package/skills/azure-static-web-apps/SKILL.md +315 -0
- package/skills/azure-static-web-apps/SYNC.md +5 -0
- package/skills/bigquery-pipeline-audit/LICENSE.md +21 -0
- package/skills/bigquery-pipeline-audit/SKILL.md +129 -0
- package/skills/bigquery-pipeline-audit/SYNC.md +5 -0
- package/skills/boost-prompt/LICENSE.md +21 -0
- package/skills/boost-prompt/SKILL.md +25 -0
- package/skills/boost-prompt/SYNC.md +5 -0
- package/skills/breakdown-epic-arch/LICENSE.md +21 -0
- package/skills/breakdown-epic-arch/SKILL.md +66 -0
- package/skills/breakdown-epic-arch/SYNC.md +5 -0
- package/skills/breakdown-epic-pm/LICENSE.md +21 -0
- package/skills/breakdown-epic-pm/SKILL.md +58 -0
- package/skills/breakdown-epic-pm/SYNC.md +5 -0
- package/skills/breakdown-feature-implementation/LICENSE.md +21 -0
- package/skills/breakdown-feature-implementation/SKILL.md +128 -0
- package/skills/breakdown-feature-implementation/SYNC.md +5 -0
- package/skills/breakdown-feature-prd/LICENSE.md +21 -0
- package/skills/breakdown-feature-prd/SKILL.md +61 -0
- package/skills/breakdown-feature-prd/SYNC.md +5 -0
- package/skills/breakdown-plan/LICENSE.md +21 -0
- package/skills/breakdown-plan/SKILL.md +509 -0
- package/skills/breakdown-plan/SYNC.md +5 -0
- package/skills/breakdown-test/LICENSE.md +21 -0
- package/skills/breakdown-test/SKILL.md +365 -0
- package/skills/breakdown-test/SYNC.md +5 -0
- package/skills/centos-linux-triage/LICENSE.md +21 -0
- package/skills/centos-linux-triage/SKILL.md +31 -0
- package/skills/centos-linux-triage/SYNC.md +5 -0
- package/skills/chrome-devtools/LICENSE.md +21 -0
- package/skills/chrome-devtools/SKILL.md +97 -0
- package/skills/chrome-devtools/SYNC.md +5 -0
- package/skills/cli-mastery/LICENSE.md +21 -0
- package/skills/cli-mastery/SKILL.md +43 -0
- package/skills/cli-mastery/SYNC.md +5 -0
- package/skills/cli-mastery/references/final-exam.md +24 -0
- package/skills/cli-mastery/references/module-1-slash-commands.md +88 -0
- package/skills/cli-mastery/references/module-2-keyboard-shortcuts.md +38 -0
- package/skills/cli-mastery/references/module-3-modes.md +33 -0
- package/skills/cli-mastery/references/module-4-agents.md +42 -0
- package/skills/cli-mastery/references/module-5-skills.md +33 -0
- package/skills/cli-mastery/references/module-6-mcp.md +50 -0
- package/skills/cli-mastery/references/module-7-advanced.md +38 -0
- package/skills/cli-mastery/references/module-8-configuration.md +34 -0
- package/skills/cli-mastery/references/scenarios.md +44 -0
- package/skills/cloud-design-patterns/LICENSE.md +21 -0
- package/skills/cloud-design-patterns/SKILL.md +62 -0
- package/skills/cloud-design-patterns/SYNC.md +5 -0
- package/skills/cloud-design-patterns/references/architecture-design.md +127 -0
- package/skills/cloud-design-patterns/references/azure-service-mappings.md +13 -0
- package/skills/cloud-design-patterns/references/best-practices.md +34 -0
- package/skills/cloud-design-patterns/references/deployment-operational.md +91 -0
- package/skills/cloud-design-patterns/references/event-driven.md +21 -0
- package/skills/cloud-design-patterns/references/messaging-integration.md +127 -0
- package/skills/cloud-design-patterns/references/performance.md +180 -0
- package/skills/cloud-design-patterns/references/reliability-resilience.md +156 -0
- package/skills/cloud-design-patterns/references/security.md +55 -0
- package/skills/code-exemplars-blueprint-generator/LICENSE.md +21 -0
- package/skills/code-exemplars-blueprint-generator/SKILL.md +126 -0
- package/skills/code-exemplars-blueprint-generator/SYNC.md +5 -0
- package/skills/codeql/LICENSE.md +21 -0
- package/skills/codeql/SKILL.md +405 -0
- package/skills/codeql/SYNC.md +5 -0
- package/skills/codeql/references/alert-management.md +170 -0
- package/skills/codeql/references/cli-commands.md +283 -0
- package/skills/codeql/references/compiled-languages.md +284 -0
- package/skills/codeql/references/sarif-output.md +265 -0
- package/skills/codeql/references/troubleshooting.md +259 -0
- package/skills/codeql/references/workflow-configuration.md +398 -0
- package/skills/comment-code-generate-a-tutorial/LICENSE.md +21 -0
- package/skills/comment-code-generate-a-tutorial/SKILL.md +26 -0
- package/skills/comment-code-generate-a-tutorial/SYNC.md +5 -0
- package/skills/containerize-aspnet-framework/LICENSE.md +21 -0
- package/skills/containerize-aspnet-framework/SKILL.md +454 -0
- package/skills/containerize-aspnet-framework/SYNC.md +5 -0
- package/skills/containerize-aspnetcore/LICENSE.md +21 -0
- package/skills/containerize-aspnetcore/SKILL.md +392 -0
- package/skills/containerize-aspnetcore/SYNC.md +5 -0
- package/skills/context-map/LICENSE.md +21 -0
- package/skills/context-map/SKILL.md +52 -0
- package/skills/context-map/SYNC.md +5 -0
- package/skills/conventional-commit/LICENSE.md +21 -0
- package/skills/conventional-commit/SKILL.md +72 -0
- package/skills/conventional-commit/SYNC.md +5 -0
- package/skills/convert-plaintext-to-md/LICENSE.md +21 -0
- package/skills/convert-plaintext-to-md/SKILL.md +362 -0
- package/skills/convert-plaintext-to-md/SYNC.md +5 -0
- package/skills/copilot-cli-quickstart/LICENSE.md +21 -0
- package/skills/copilot-cli-quickstart/SKILL.md +774 -0
- package/skills/copilot-cli-quickstart/SYNC.md +5 -0
- package/skills/copilot-instructions-blueprint-generator/LICENSE.md +21 -0
- package/skills/copilot-instructions-blueprint-generator/SKILL.md +294 -0
- package/skills/copilot-instructions-blueprint-generator/SYNC.md +5 -0
- package/skills/copilot-sdk/LICENSE.md +21 -0
- package/skills/copilot-sdk/SKILL.md +914 -0
- package/skills/copilot-sdk/SYNC.md +5 -0
- package/skills/copilot-spaces/LICENSE.md +21 -0
- package/skills/copilot-spaces/SKILL.md +205 -0
- package/skills/copilot-spaces/SYNC.md +5 -0
- package/skills/copilot-usage-metrics/LICENSE.md +21 -0
- package/skills/copilot-usage-metrics/SKILL.md +52 -0
- package/skills/copilot-usage-metrics/SYNC.md +5 -0
- package/skills/copilot-usage-metrics/get-enterprise-metrics.sh +22 -0
- package/skills/copilot-usage-metrics/get-enterprise-user-metrics.sh +22 -0
- package/skills/copilot-usage-metrics/get-org-metrics.sh +22 -0
- package/skills/copilot-usage-metrics/get-org-user-metrics.sh +22 -0
- package/skills/cosmosdb-datamodeling/LICENSE.md +21 -0
- package/skills/cosmosdb-datamodeling/SKILL.md +1045 -0
- package/skills/cosmosdb-datamodeling/SYNC.md +5 -0
- package/skills/create-agentsmd/LICENSE.md +21 -0
- package/skills/create-agentsmd/SKILL.md +249 -0
- package/skills/create-agentsmd/SYNC.md +5 -0
- package/skills/create-architectural-decision-record/LICENSE.md +21 -0
- package/skills/create-architectural-decision-record/SKILL.md +97 -0
- package/skills/create-architectural-decision-record/SYNC.md +5 -0
- package/skills/create-github-action-workflow-specification/LICENSE.md +21 -0
- package/skills/create-github-action-workflow-specification/SKILL.md +276 -0
- package/skills/create-github-action-workflow-specification/SYNC.md +5 -0
- package/skills/create-github-issue-feature-from-specification/LICENSE.md +21 -0
- package/skills/create-github-issue-feature-from-specification/SKILL.md +28 -0
- package/skills/create-github-issue-feature-from-specification/SYNC.md +5 -0
- package/skills/create-github-issues-feature-from-implementation-plan/LICENSE.md +21 -0
- package/skills/create-github-issues-feature-from-implementation-plan/SKILL.md +28 -0
- package/skills/create-github-issues-feature-from-implementation-plan/SYNC.md +5 -0
- package/skills/create-github-issues-for-unmet-specification-requirements/LICENSE.md +21 -0
- package/skills/create-github-issues-for-unmet-specification-requirements/SKILL.md +35 -0
- package/skills/create-github-issues-for-unmet-specification-requirements/SYNC.md +5 -0
- package/skills/create-github-pull-request-from-specification/LICENSE.md +21 -0
- package/skills/create-github-pull-request-from-specification/SKILL.md +24 -0
- package/skills/create-github-pull-request-from-specification/SYNC.md +5 -0
- package/skills/create-implementation-plan/LICENSE.md +21 -0
- package/skills/create-implementation-plan/SKILL.md +157 -0
- package/skills/create-implementation-plan/SYNC.md +5 -0
- package/skills/create-llms/LICENSE.md +21 -0
- package/skills/create-llms/SKILL.md +210 -0
- package/skills/create-llms/SYNC.md +5 -0
- package/skills/create-readme/LICENSE.md +21 -0
- package/skills/create-readme/SKILL.md +21 -0
- package/skills/create-readme/SYNC.md +5 -0
- package/skills/create-specification/LICENSE.md +21 -0
- package/skills/create-specification/SKILL.md +127 -0
- package/skills/create-specification/SYNC.md +5 -0
- package/skills/create-spring-boot-java-project/LICENSE.md +21 -0
- package/skills/create-spring-boot-java-project/SKILL.md +163 -0
- package/skills/create-spring-boot-java-project/SYNC.md +5 -0
- package/skills/create-spring-boot-kotlin-project/LICENSE.md +21 -0
- package/skills/create-spring-boot-kotlin-project/SKILL.md +147 -0
- package/skills/create-spring-boot-kotlin-project/SYNC.md +5 -0
- package/skills/create-technical-spike/LICENSE.md +21 -0
- package/skills/create-technical-spike/SKILL.md +230 -0
- package/skills/create-technical-spike/SYNC.md +5 -0
- package/skills/create-tldr-page/LICENSE.md +21 -0
- package/skills/create-tldr-page/SKILL.md +210 -0
- package/skills/create-tldr-page/SYNC.md +5 -0
- package/skills/creating-oracle-to-postgres-master-migration-plan/LICENSE.md +21 -0
- package/skills/creating-oracle-to-postgres-master-migration-plan/SKILL.md +83 -0
- package/skills/creating-oracle-to-postgres-master-migration-plan/SYNC.md +5 -0
- package/skills/creating-oracle-to-postgres-migration-bug-report/LICENSE.md +21 -0
- package/skills/creating-oracle-to-postgres-migration-bug-report/SKILL.md +43 -0
- package/skills/creating-oracle-to-postgres-migration-bug-report/SYNC.md +5 -0
- package/skills/creating-oracle-to-postgres-migration-bug-report/references/BUG-REPORT-TEMPLATE.md +79 -0
- package/skills/creating-oracle-to-postgres-migration-integration-tests/LICENSE.md +21 -0
- package/skills/creating-oracle-to-postgres-migration-integration-tests/SKILL.md +60 -0
- package/skills/creating-oracle-to-postgres-migration-integration-tests/SYNC.md +5 -0
- package/skills/csharp-async/LICENSE.md +21 -0
- package/skills/csharp-async/SKILL.md +49 -0
- package/skills/csharp-async/SYNC.md +5 -0
- package/skills/csharp-docs/LICENSE.md +21 -0
- package/skills/csharp-docs/SKILL.md +62 -0
- package/skills/csharp-docs/SYNC.md +5 -0
- package/skills/csharp-mcp-server-generator/LICENSE.md +21 -0
- package/skills/csharp-mcp-server-generator/SKILL.md +59 -0
- package/skills/csharp-mcp-server-generator/SYNC.md +5 -0
- package/skills/csharp-mstest/LICENSE.md +21 -0
- package/skills/csharp-mstest/SKILL.md +478 -0
- package/skills/csharp-mstest/SYNC.md +5 -0
- package/skills/csharp-nunit/LICENSE.md +21 -0
- package/skills/csharp-nunit/SKILL.md +71 -0
- package/skills/csharp-nunit/SYNC.md +5 -0
- package/skills/csharp-tunit/LICENSE.md +21 -0
- package/skills/csharp-tunit/SKILL.md +100 -0
- package/skills/csharp-tunit/SYNC.md +5 -0
- package/skills/csharp-xunit/LICENSE.md +21 -0
- package/skills/csharp-xunit/SKILL.md +68 -0
- package/skills/csharp-xunit/SYNC.md +5 -0
- package/skills/datanalysis-credit-risk/LICENSE.md +21 -0
- package/skills/datanalysis-credit-risk/SKILL.md +113 -0
- package/skills/datanalysis-credit-risk/SYNC.md +5 -0
- package/skills/datanalysis-credit-risk/references/analysis.py +1223 -0
- package/skills/datanalysis-credit-risk/references/func.py +228 -0
- package/skills/datanalysis-credit-risk/scripts/example.py +391 -0
- package/skills/dataverse-python-advanced-patterns/LICENSE.md +21 -0
- package/skills/dataverse-python-advanced-patterns/SKILL.md +17 -0
- package/skills/dataverse-python-advanced-patterns/SYNC.md +5 -0
- package/skills/dataverse-python-production-code/LICENSE.md +21 -0
- package/skills/dataverse-python-production-code/SKILL.md +116 -0
- package/skills/dataverse-python-production-code/SYNC.md +5 -0
- package/skills/dataverse-python-quickstart/LICENSE.md +21 -0
- package/skills/dataverse-python-quickstart/SKILL.md +14 -0
- package/skills/dataverse-python-quickstart/SYNC.md +5 -0
- package/skills/dataverse-python-usecase-builder/LICENSE.md +21 -0
- package/skills/dataverse-python-usecase-builder/SKILL.md +246 -0
- package/skills/dataverse-python-usecase-builder/SYNC.md +5 -0
- package/skills/debian-linux-triage/LICENSE.md +21 -0
- package/skills/debian-linux-triage/SKILL.md +31 -0
- package/skills/debian-linux-triage/SYNC.md +5 -0
- package/skills/declarative-agents/LICENSE.md +21 -0
- package/skills/declarative-agents/SKILL.md +94 -0
- package/skills/declarative-agents/SYNC.md +5 -0
- package/skills/dependabot/LICENSE.md +21 -0
- package/skills/dependabot/SKILL.md +422 -0
- package/skills/dependabot/SYNC.md +5 -0
- package/skills/dependabot/references/dependabot-yml-reference.md +374 -0
- package/skills/dependabot/references/example-configs.md +409 -0
- package/skills/dependabot/references/pr-commands.md +91 -0
- package/skills/devops-rollout-plan/LICENSE.md +21 -0
- package/skills/devops-rollout-plan/SKILL.md +117 -0
- package/skills/devops-rollout-plan/SYNC.md +5 -0
- package/skills/documentation-writer/LICENSE.md +21 -0
- package/skills/documentation-writer/SKILL.md +45 -0
- package/skills/documentation-writer/SYNC.md +5 -0
- package/skills/dotnet-best-practices/LICENSE.md +21 -0
- package/skills/dotnet-best-practices/SKILL.md +85 -0
- package/skills/dotnet-best-practices/SYNC.md +5 -0
- package/skills/dotnet-design-pattern-review/LICENSE.md +21 -0
- package/skills/dotnet-design-pattern-review/SKILL.md +42 -0
- package/skills/dotnet-design-pattern-review/SYNC.md +5 -0
- package/skills/dotnet-timezone/LICENSE.md +21 -0
- package/skills/dotnet-timezone/SKILL.md +109 -0
- package/skills/dotnet-timezone/SYNC.md +5 -0
- package/skills/dotnet-timezone/references/code-patterns.md +153 -0
- package/skills/dotnet-timezone/references/timezone-index.md +87 -0
- package/skills/dotnet-upgrade/LICENSE.md +21 -0
- package/skills/dotnet-upgrade/SKILL.md +116 -0
- package/skills/dotnet-upgrade/SYNC.md +5 -0
- package/skills/doublecheck/LICENSE.md +21 -0
- package/skills/doublecheck/SKILL.md +277 -0
- package/skills/doublecheck/SYNC.md +5 -0
- package/skills/doublecheck/assets/verification-report-template.md +92 -0
- package/skills/editorconfig/LICENSE.md +21 -0
- package/skills/editorconfig/SKILL.md +63 -0
- package/skills/editorconfig/SYNC.md +5 -0
- package/skills/ef-core/LICENSE.md +21 -0
- package/skills/ef-core/SKILL.md +75 -0
- package/skills/ef-core/SYNC.md +5 -0
- package/skills/entra-agent-user/LICENSE.md +21 -0
- package/skills/entra-agent-user/SKILL.md +270 -0
- package/skills/entra-agent-user/SYNC.md +5 -0
- package/skills/eval-driven-dev/LICENSE.md +21 -0
- package/skills/eval-driven-dev/SKILL.md +862 -0
- package/skills/eval-driven-dev/SYNC.md +5 -0
- package/skills/eval-driven-dev/references/pixie-api.md +195 -0
- package/skills/excalidraw-diagram-generator/LICENSE.md +21 -0
- package/skills/excalidraw-diagram-generator/SKILL.md +613 -0
- package/skills/excalidraw-diagram-generator/SYNC.md +5 -0
- package/skills/excalidraw-diagram-generator/references/element-types.md +497 -0
- package/skills/excalidraw-diagram-generator/references/excalidraw-schema.md +350 -0
- package/skills/excalidraw-diagram-generator/scripts/README.md +193 -0
- package/skills/excalidraw-diagram-generator/scripts/add-arrow.py +312 -0
- package/skills/excalidraw-diagram-generator/scripts/add-icon-to-diagram.py +404 -0
- package/skills/excalidraw-diagram-generator/scripts/split-excalidraw-library.py +183 -0
- package/skills/excalidraw-diagram-generator/templates/business-flow-swimlane-template.excalidraw +334 -0
- package/skills/excalidraw-diagram-generator/templates/class-diagram-template.excalidraw +558 -0
- package/skills/excalidraw-diagram-generator/templates/data-flow-diagram-template.excalidraw +279 -0
- package/skills/excalidraw-diagram-generator/templates/er-diagram-template.excalidraw +662 -0
- package/skills/excalidraw-diagram-generator/templates/flowchart-template.excalidraw +179 -0
- package/skills/excalidraw-diagram-generator/templates/mindmap-template.excalidraw +244 -0
- package/skills/excalidraw-diagram-generator/templates/relationship-template.excalidraw +145 -0
- package/skills/excalidraw-diagram-generator/templates/sequence-diagram-template.excalidraw +509 -0
- package/skills/fabric-lakehouse/LICENSE.md +21 -0
- package/skills/fabric-lakehouse/SKILL.md +106 -0
- package/skills/fabric-lakehouse/SYNC.md +5 -0
- package/skills/fabric-lakehouse/references/getdata.md +36 -0
- package/skills/fabric-lakehouse/references/pyspark.md +189 -0
- package/skills/fedora-linux-triage/LICENSE.md +21 -0
- package/skills/fedora-linux-triage/SKILL.md +31 -0
- package/skills/fedora-linux-triage/SYNC.md +5 -0
- package/skills/finalize-agent-prompt/LICENSE.md +21 -0
- package/skills/finalize-agent-prompt/SKILL.md +26 -0
- package/skills/finalize-agent-prompt/SYNC.md +5 -0
- package/skills/finnish-humanizer/LICENSE.md +21 -0
- package/skills/finnish-humanizer/SKILL.md +145 -0
- package/skills/finnish-humanizer/SYNC.md +5 -0
- package/skills/finnish-humanizer/references/patterns.md +338 -0
- package/skills/first-ask/LICENSE.md +21 -0
- package/skills/first-ask/SKILL.md +30 -0
- package/skills/first-ask/SYNC.md +5 -0
- package/skills/flowstudio-power-automate-build/LICENSE.md +21 -0
- package/skills/flowstudio-power-automate-build/SKILL.md +460 -0
- package/skills/flowstudio-power-automate-build/SYNC.md +5 -0
- package/skills/flowstudio-power-automate-build/references/action-patterns-connectors.md +542 -0
- package/skills/flowstudio-power-automate-build/references/action-patterns-core.md +542 -0
- package/skills/flowstudio-power-automate-build/references/action-patterns-data.md +735 -0
- package/skills/flowstudio-power-automate-build/references/build-patterns.md +108 -0
- package/skills/flowstudio-power-automate-build/references/flow-schema.md +225 -0
- package/skills/flowstudio-power-automate-build/references/trigger-types.md +211 -0
- package/skills/flowstudio-power-automate-debug/LICENSE.md +21 -0
- package/skills/flowstudio-power-automate-debug/SKILL.md +322 -0
- package/skills/flowstudio-power-automate-debug/SYNC.md +5 -0
- package/skills/flowstudio-power-automate-debug/references/common-errors.md +188 -0
- package/skills/flowstudio-power-automate-debug/references/debug-workflow.md +157 -0
- package/skills/flowstudio-power-automate-mcp/LICENSE.md +21 -0
- package/skills/flowstudio-power-automate-mcp/SKILL.md +450 -0
- package/skills/flowstudio-power-automate-mcp/SYNC.md +5 -0
- package/skills/flowstudio-power-automate-mcp/references/MCP-BOOTSTRAP.md +53 -0
- package/skills/flowstudio-power-automate-mcp/references/action-types.md +79 -0
- package/skills/flowstudio-power-automate-mcp/references/connection-references.md +115 -0
- package/skills/flowstudio-power-automate-mcp/references/tool-reference.md +445 -0
- package/skills/fluentui-blazor/LICENSE.md +21 -0
- package/skills/fluentui-blazor/SKILL.md +231 -0
- package/skills/fluentui-blazor/SYNC.md +5 -0
- package/skills/fluentui-blazor/references/DATAGRID.md +162 -0
- package/skills/fluentui-blazor/references/LAYOUT-AND-NAVIGATION.md +173 -0
- package/skills/fluentui-blazor/references/SETUP.md +129 -0
- package/skills/fluentui-blazor/references/THEMING.md +103 -0
- package/skills/folder-structure-blueprint-generator/LICENSE.md +21 -0
- package/skills/folder-structure-blueprint-generator/SKILL.md +405 -0
- package/skills/folder-structure-blueprint-generator/SYNC.md +5 -0
- package/skills/game-engine/LICENSE.md +21 -0
- package/skills/game-engine/SKILL.md +139 -0
- package/skills/game-engine/SYNC.md +5 -0
- package/skills/game-engine/assets/2d-maze-game.md +528 -0
- package/skills/game-engine/assets/2d-platform-game.md +1855 -0
- package/skills/game-engine/assets/gameBase-template-repo.md +310 -0
- package/skills/game-engine/assets/paddle-game-template.md +1528 -0
- package/skills/game-engine/assets/simple-2d-engine.md +507 -0
- package/skills/game-engine/references/3d-web-games.md +754 -0
- package/skills/game-engine/references/algorithms.md +843 -0
- package/skills/game-engine/references/basics.md +343 -0
- package/skills/game-engine/references/game-control-mechanisms.md +617 -0
- package/skills/game-engine/references/game-engine-core-principles.md +695 -0
- package/skills/game-engine/references/game-publishing.md +352 -0
- package/skills/game-engine/references/techniques.md +894 -0
- package/skills/game-engine/references/terminology.md +354 -0
- package/skills/game-engine/references/web-apis.md +1394 -0
- package/skills/gen-specs-as-issues/LICENSE.md +21 -0
- package/skills/gen-specs-as-issues/SKILL.md +165 -0
- package/skills/gen-specs-as-issues/SYNC.md +5 -0
- package/skills/generate-custom-instructions-from-codebase/LICENSE.md +21 -0
- package/skills/generate-custom-instructions-from-codebase/SKILL.md +240 -0
- package/skills/generate-custom-instructions-from-codebase/SYNC.md +5 -0
- package/skills/geofeed-tuner/LICENSE.md +21 -0
- package/skills/geofeed-tuner/SKILL.md +864 -0
- package/skills/geofeed-tuner/SYNC.md +5 -0
- package/skills/geofeed-tuner/assets/example/01-user-input-rfc8805-feed.csv +5 -0
- package/skills/geofeed-tuner/assets/iso3166-1.json +1249 -0
- package/skills/geofeed-tuner/assets/iso3166-2.json +20188 -0
- package/skills/geofeed-tuner/assets/small-territories.json +106 -0
- package/skills/geofeed-tuner/references/rfc8805.txt +735 -0
- package/skills/geofeed-tuner/references/snippets-python3.md +85 -0
- package/skills/geofeed-tuner/scripts/templates/index.html +2305 -0
- package/skills/gh-cli/LICENSE.md +21 -0
- package/skills/gh-cli/SKILL.md +2187 -0
- package/skills/gh-cli/SYNC.md +5 -0
- package/skills/git-commit/LICENSE.md +21 -0
- package/skills/git-commit/SKILL.md +124 -0
- package/skills/git-commit/SYNC.md +5 -0
- package/skills/git-flow-branch-creator/LICENSE.md +21 -0
- package/skills/git-flow-branch-creator/SKILL.md +292 -0
- package/skills/git-flow-branch-creator/SYNC.md +5 -0
- package/skills/github-copilot-starter/LICENSE.md +21 -0
- package/skills/github-copilot-starter/SKILL.md +402 -0
- package/skills/github-copilot-starter/SYNC.md +5 -0
- package/skills/github-issues/LICENSE.md +21 -0
- package/skills/github-issues/SKILL.md +201 -0
- package/skills/github-issues/SYNC.md +5 -0
- package/skills/github-issues/references/dependencies.md +71 -0
- package/skills/github-issues/references/images.md +116 -0
- package/skills/github-issues/references/issue-fields.md +191 -0
- package/skills/github-issues/references/issue-types.md +72 -0
- package/skills/github-issues/references/projects.md +273 -0
- package/skills/github-issues/references/search.md +231 -0
- package/skills/github-issues/references/sub-issues.md +137 -0
- package/skills/github-issues/references/templates.md +90 -0
- package/skills/go-mcp-server-generator/LICENSE.md +21 -0
- package/skills/go-mcp-server-generator/SKILL.md +334 -0
- package/skills/go-mcp-server-generator/SYNC.md +5 -0
- package/skills/gtm-0-to-1-launch/LICENSE.md +21 -0
- package/skills/gtm-0-to-1-launch/SKILL.md +321 -0
- package/skills/gtm-0-to-1-launch/SYNC.md +5 -0
- package/skills/gtm-ai-gtm/LICENSE.md +21 -0
- package/skills/gtm-ai-gtm/SKILL.md +569 -0
- package/skills/gtm-ai-gtm/SYNC.md +5 -0
- package/skills/gtm-board-and-investor-communication/LICENSE.md +21 -0
- package/skills/gtm-board-and-investor-communication/SKILL.md +456 -0
- package/skills/gtm-board-and-investor-communication/SYNC.md +5 -0
- package/skills/gtm-developer-ecosystem/LICENSE.md +21 -0
- package/skills/gtm-developer-ecosystem/SKILL.md +310 -0
- package/skills/gtm-developer-ecosystem/SYNC.md +5 -0
- package/skills/gtm-enterprise-account-planning/LICENSE.md +21 -0
- package/skills/gtm-enterprise-account-planning/SKILL.md +429 -0
- package/skills/gtm-enterprise-account-planning/SYNC.md +5 -0
- package/skills/gtm-enterprise-onboarding/LICENSE.md +21 -0
- package/skills/gtm-enterprise-onboarding/SKILL.md +457 -0
- package/skills/gtm-enterprise-onboarding/SYNC.md +5 -0
- package/skills/gtm-operating-cadence/LICENSE.md +21 -0
- package/skills/gtm-operating-cadence/SKILL.md +420 -0
- package/skills/gtm-operating-cadence/SYNC.md +5 -0
- package/skills/gtm-partnership-architecture/LICENSE.md +21 -0
- package/skills/gtm-partnership-architecture/SKILL.md +470 -0
- package/skills/gtm-partnership-architecture/SYNC.md +5 -0
- package/skills/gtm-positioning-strategy/LICENSE.md +21 -0
- package/skills/gtm-positioning-strategy/SKILL.md +438 -0
- package/skills/gtm-positioning-strategy/SYNC.md +5 -0
- package/skills/gtm-product-led-growth/LICENSE.md +21 -0
- package/skills/gtm-product-led-growth/SKILL.md +339 -0
- package/skills/gtm-product-led-growth/SYNC.md +5 -0
- package/skills/gtm-technical-product-pricing/LICENSE.md +21 -0
- package/skills/gtm-technical-product-pricing/SKILL.md +353 -0
- package/skills/gtm-technical-product-pricing/SYNC.md +5 -0
- package/skills/image-manipulation-image-magick/LICENSE.md +21 -0
- package/skills/image-manipulation-image-magick/SKILL.md +252 -0
- package/skills/image-manipulation-image-magick/SYNC.md +5 -0
- package/skills/import-infrastructure-as-code/LICENSE.md +21 -0
- package/skills/import-infrastructure-as-code/SKILL.md +367 -0
- package/skills/import-infrastructure-as-code/SYNC.md +5 -0
- package/skills/issue-fields-migration/LICENSE.md +21 -0
- package/skills/issue-fields-migration/SKILL.md +533 -0
- package/skills/issue-fields-migration/SYNC.md +5 -0
- package/skills/issue-fields-migration/references/issue-fields-api.md +129 -0
- package/skills/issue-fields-migration/references/labels-api.md +74 -0
- package/skills/issue-fields-migration/references/projects-api.md +116 -0
- package/skills/java-add-graalvm-native-image-support/LICENSE.md +21 -0
- package/skills/java-add-graalvm-native-image-support/SKILL.md +449 -0
- package/skills/java-add-graalvm-native-image-support/SYNC.md +5 -0
- package/skills/java-docs/LICENSE.md +21 -0
- package/skills/java-docs/SKILL.md +23 -0
- package/skills/java-docs/SYNC.md +5 -0
- package/skills/java-junit/LICENSE.md +21 -0
- package/skills/java-junit/SKILL.md +63 -0
- package/skills/java-junit/SYNC.md +5 -0
- package/skills/java-mcp-server-generator/LICENSE.md +21 -0
- package/skills/java-mcp-server-generator/SKILL.md +756 -0
- package/skills/java-mcp-server-generator/SYNC.md +5 -0
- package/skills/java-refactoring-extract-method/LICENSE.md +21 -0
- package/skills/java-refactoring-extract-method/SKILL.md +104 -0
- package/skills/java-refactoring-extract-method/SYNC.md +5 -0
- package/skills/java-refactoring-remove-parameter/LICENSE.md +21 -0
- package/skills/java-refactoring-remove-parameter/SKILL.md +84 -0
- package/skills/java-refactoring-remove-parameter/SYNC.md +5 -0
- package/skills/java-springboot/LICENSE.md +21 -0
- package/skills/java-springboot/SKILL.md +65 -0
- package/skills/java-springboot/SYNC.md +5 -0
- package/skills/javascript-typescript-jest/LICENSE.md +21 -0
- package/skills/javascript-typescript-jest/SKILL.md +44 -0
- package/skills/javascript-typescript-jest/SYNC.md +5 -0
- package/skills/kotlin-mcp-server-generator/LICENSE.md +21 -0
- package/skills/kotlin-mcp-server-generator/SKILL.md +449 -0
- package/skills/kotlin-mcp-server-generator/SYNC.md +5 -0
- package/skills/kotlin-springboot/LICENSE.md +21 -0
- package/skills/kotlin-springboot/SKILL.md +70 -0
- package/skills/kotlin-springboot/SYNC.md +5 -0
- package/skills/legacy-circuit-mockups/LICENSE.md +21 -0
- package/skills/legacy-circuit-mockups/SKILL.md +276 -0
- package/skills/legacy-circuit-mockups/SYNC.md +5 -0
- package/skills/legacy-circuit-mockups/references/28256-eeprom.md +190 -0
- package/skills/legacy-circuit-mockups/references/555.md +861 -0
- package/skills/legacy-circuit-mockups/references/6502.md +221 -0
- package/skills/legacy-circuit-mockups/references/6522.md +211 -0
- package/skills/legacy-circuit-mockups/references/6C62256.md +177 -0
- package/skills/legacy-circuit-mockups/references/7400-series.md +177 -0
- package/skills/legacy-circuit-mockups/references/assembly-compiler.md +258 -0
- package/skills/legacy-circuit-mockups/references/assembly-language.md +226 -0
- package/skills/legacy-circuit-mockups/references/basic-electronic-components.md +86 -0
- package/skills/legacy-circuit-mockups/references/breadboard.md +214 -0
- package/skills/legacy-circuit-mockups/references/common-breadboard-components.md +281 -0
- package/skills/legacy-circuit-mockups/references/connecting-electronic-components.md +310 -0
- package/skills/legacy-circuit-mockups/references/emulator-28256-eeprom.md +245 -0
- package/skills/legacy-circuit-mockups/references/emulator-6502.md +251 -0
- package/skills/legacy-circuit-mockups/references/emulator-6522.md +288 -0
- package/skills/legacy-circuit-mockups/references/emulator-6C62256.md +233 -0
- package/skills/legacy-circuit-mockups/references/emulator-lcd.md +266 -0
- package/skills/legacy-circuit-mockups/references/lcd.md +208 -0
- package/skills/legacy-circuit-mockups/references/minipro.md +211 -0
- package/skills/legacy-circuit-mockups/references/t48eeprom-programmer.md +174 -0
- package/skills/make-repo-contribution/LICENSE.md +21 -0
- package/skills/make-repo-contribution/SKILL.md +90 -0
- package/skills/make-repo-contribution/SYNC.md +5 -0
- package/skills/make-repo-contribution/assets/issue-template.md +37 -0
- package/skills/make-repo-contribution/assets/pr-template.md +36 -0
- package/skills/make-skill-template/LICENSE.md +21 -0
- package/skills/make-skill-template/SKILL.md +147 -0
- package/skills/make-skill-template/SYNC.md +5 -0
- package/skills/markdown-to-html/LICENSE.md +21 -0
- package/skills/markdown-to-html/SKILL.md +916 -0
- package/skills/markdown-to-html/SYNC.md +5 -0
- package/skills/markdown-to-html/references/basic-markdown-to-html.md +420 -0
- package/skills/markdown-to-html/references/basic-markdown.md +496 -0
- package/skills/markdown-to-html/references/code-blocks-to-html.md +165 -0
- package/skills/markdown-to-html/references/code-blocks.md +70 -0
- package/skills/markdown-to-html/references/collapsed-sections-to-html.md +136 -0
- package/skills/markdown-to-html/references/collapsed-sections.md +48 -0
- package/skills/markdown-to-html/references/gomarkdown.md +253 -0
- package/skills/markdown-to-html/references/hugo.md +394 -0
- package/skills/markdown-to-html/references/jekyll.md +321 -0
- package/skills/markdown-to-html/references/marked.md +121 -0
- package/skills/markdown-to-html/references/pandoc.md +226 -0
- package/skills/markdown-to-html/references/tables-to-html.md +169 -0
- package/skills/markdown-to-html/references/tables.md +72 -0
- package/skills/markdown-to-html/references/writing-mathematical-expressions-to-html.md +350 -0
- package/skills/markdown-to-html/references/writing-mathematical-expressions.md +76 -0
- package/skills/mcp-cli/LICENSE.md +21 -0
- package/skills/mcp-cli/SKILL.md +78 -0
- package/skills/mcp-cli/SYNC.md +5 -0
- package/skills/mcp-copilot-studio-server-generator/LICENSE.md +21 -0
- package/skills/mcp-copilot-studio-server-generator/SKILL.md +118 -0
- package/skills/mcp-copilot-studio-server-generator/SYNC.md +5 -0
- package/skills/mcp-create-adaptive-cards/LICENSE.md +21 -0
- package/skills/mcp-create-adaptive-cards/SKILL.md +532 -0
- package/skills/mcp-create-adaptive-cards/SYNC.md +5 -0
- package/skills/mcp-create-declarative-agent/LICENSE.md +21 -0
- package/skills/mcp-create-declarative-agent/SKILL.md +315 -0
- package/skills/mcp-create-declarative-agent/SYNC.md +5 -0
- package/skills/mcp-deploy-manage-agents/LICENSE.md +21 -0
- package/skills/mcp-deploy-manage-agents/SKILL.md +341 -0
- package/skills/mcp-deploy-manage-agents/SYNC.md +5 -0
- package/skills/meeting-minutes/LICENSE.md +21 -0
- package/skills/meeting-minutes/SKILL.md +235 -0
- package/skills/meeting-minutes/SYNC.md +5 -0
- package/skills/memory-merger/LICENSE.md +21 -0
- package/skills/memory-merger/SKILL.md +108 -0
- package/skills/memory-merger/SYNC.md +5 -0
- package/skills/mentoring-juniors/LICENSE.md +21 -0
- package/skills/mentoring-juniors/SKILL.md +310 -0
- package/skills/mentoring-juniors/SYNC.md +5 -0
- package/skills/microsoft-agent-framework/LICENSE.md +21 -0
- package/skills/microsoft-agent-framework/SKILL.md +65 -0
- package/skills/microsoft-agent-framework/SYNC.md +5 -0
- package/skills/microsoft-agent-framework/references/dotnet.md +24 -0
- package/skills/microsoft-agent-framework/references/python.md +24 -0
- package/skills/microsoft-code-reference/LICENSE.md +21 -0
- package/skills/microsoft-code-reference/SKILL.md +99 -0
- package/skills/microsoft-code-reference/SYNC.md +5 -0
- package/skills/microsoft-docs/LICENSE.md +21 -0
- package/skills/microsoft-docs/SKILL.md +134 -0
- package/skills/microsoft-docs/SYNC.md +5 -0
- package/skills/microsoft-skill-creator/LICENSE.md +21 -0
- package/skills/microsoft-skill-creator/SKILL.md +250 -0
- package/skills/microsoft-skill-creator/SYNC.md +5 -0
- package/skills/microsoft-skill-creator/references/skill-templates.md +345 -0
- package/skills/migrating-oracle-to-postgres-stored-procedures/LICENSE.md +21 -0
- package/skills/migrating-oracle-to-postgres-stored-procedures/SKILL.md +42 -0
- package/skills/migrating-oracle-to-postgres-stored-procedures/SYNC.md +5 -0
- package/skills/mkdocs-translations/LICENSE.md +21 -0
- package/skills/mkdocs-translations/SKILL.md +108 -0
- package/skills/mkdocs-translations/SYNC.md +5 -0
- package/skills/model-recommendation/LICENSE.md +21 -0
- package/skills/model-recommendation/SKILL.md +672 -0
- package/skills/model-recommendation/SYNC.md +5 -0
- package/skills/msstore-cli/LICENSE.md +21 -0
- package/skills/msstore-cli/SKILL.md +600 -0
- package/skills/msstore-cli/SYNC.md +5 -0
- package/skills/multi-stage-dockerfile/LICENSE.md +21 -0
- package/skills/multi-stage-dockerfile/SKILL.md +46 -0
- package/skills/multi-stage-dockerfile/SYNC.md +5 -0
- package/skills/my-issues/LICENSE.md +21 -0
- package/skills/my-issues/SKILL.md +8 -0
- package/skills/my-issues/SYNC.md +5 -0
- package/skills/my-pull-requests/LICENSE.md +21 -0
- package/skills/my-pull-requests/SKILL.md +14 -0
- package/skills/my-pull-requests/SYNC.md +5 -0
- package/skills/nano-banana-pro-openrouter/LICENSE.md +21 -0
- package/skills/nano-banana-pro-openrouter/SKILL.md +74 -0
- package/skills/nano-banana-pro-openrouter/SYNC.md +5 -0
- package/skills/nano-banana-pro-openrouter/assets/SYSTEM_TEMPLATE +14 -0
- package/skills/nano-banana-pro-openrouter/scripts/generate_image.py +191 -0
- package/skills/napkin/LICENSE.md +21 -0
- package/skills/napkin/SKILL.md +154 -0
- package/skills/napkin/SYNC.md +5 -0
- package/skills/napkin/assets/napkin.html +2019 -0
- package/skills/napkin/assets/step1-activate.svg +107 -0
- package/skills/napkin/assets/step2-whiteboard.svg +157 -0
- package/skills/napkin/assets/step3-draw.svg +143 -0
- package/skills/napkin/assets/step4-share.svg +98 -0
- package/skills/napkin/assets/step5-response.svg +112 -0
- package/skills/next-intl-add-language/LICENSE.md +21 -0
- package/skills/next-intl-add-language/SKILL.md +19 -0
- package/skills/next-intl-add-language/SYNC.md +5 -0
- package/skills/noob-mode/LICENSE.md +21 -0
- package/skills/noob-mode/SKILL.md +263 -0
- package/skills/noob-mode/SYNC.md +5 -0
- package/skills/noob-mode/references/examples.md +418 -0
- package/skills/noob-mode/references/glossary.md +368 -0
- package/skills/nuget-manager/LICENSE.md +21 -0
- package/skills/nuget-manager/SKILL.md +68 -0
- package/skills/nuget-manager/SYNC.md +5 -0
- package/skills/oo-component-documentation/LICENSE.md +21 -0
- package/skills/oo-component-documentation/SKILL.md +74 -0
- package/skills/oo-component-documentation/SYNC.md +5 -0
- package/skills/oo-component-documentation/assets/documentation-template.md +97 -0
- package/skills/oo-component-documentation/references/create-mode.md +32 -0
- package/skills/oo-component-documentation/references/update-mode.md +32 -0
- package/skills/openapi-to-application-code/LICENSE.md +21 -0
- package/skills/openapi-to-application-code/SKILL.md +112 -0
- package/skills/openapi-to-application-code/SYNC.md +5 -0
- package/skills/pdftk-server/LICENSE.md +21 -0
- package/skills/pdftk-server/SKILL.md +162 -0
- package/skills/pdftk-server/SYNC.md +5 -0
- package/skills/pdftk-server/references/download.md +75 -0
- package/skills/pdftk-server/references/pdftk-cli-examples.md +193 -0
- package/skills/pdftk-server/references/pdftk-man-page.md +232 -0
- package/skills/pdftk-server/references/pdftk-server-license.md +25 -0
- package/skills/pdftk-server/references/third-party-materials.md +103 -0
- package/skills/penpot-uiux-design/LICENSE.md +21 -0
- package/skills/penpot-uiux-design/SKILL.md +342 -0
- package/skills/penpot-uiux-design/SYNC.md +5 -0
- package/skills/penpot-uiux-design/references/accessibility.md +329 -0
- package/skills/penpot-uiux-design/references/component-patterns.md +339 -0
- package/skills/penpot-uiux-design/references/platform-guidelines.md +367 -0
- package/skills/penpot-uiux-design/references/setup-troubleshooting.md +328 -0
- package/skills/php-mcp-server-generator/LICENSE.md +21 -0
- package/skills/php-mcp-server-generator/SKILL.md +522 -0
- package/skills/php-mcp-server-generator/SYNC.md +5 -0
- package/skills/planning-oracle-to-postgres-migration-integration-testing/LICENSE.md +21 -0
- package/skills/planning-oracle-to-postgres-migration-integration-testing/SKILL.md +44 -0
- package/skills/planning-oracle-to-postgres-migration-integration-testing/SYNC.md +5 -0
- package/skills/plantuml-ascii/LICENSE.md +21 -0
- package/skills/plantuml-ascii/SKILL.md +305 -0
- package/skills/plantuml-ascii/SYNC.md +5 -0
- package/skills/playwright-automation-fill-in-form/LICENSE.md +21 -0
- package/skills/playwright-automation-fill-in-form/SKILL.md +28 -0
- package/skills/playwright-automation-fill-in-form/SYNC.md +5 -0
- package/skills/playwright-explore-website/LICENSE.md +21 -0
- package/skills/playwright-explore-website/SKILL.md +17 -0
- package/skills/playwright-explore-website/SYNC.md +5 -0
- package/skills/playwright-generate-test/LICENSE.md +21 -0
- package/skills/playwright-generate-test/SKILL.md +17 -0
- package/skills/playwright-generate-test/SYNC.md +5 -0
- package/skills/polyglot-test-agent/LICENSE.md +21 -0
- package/skills/polyglot-test-agent/SKILL.md +161 -0
- package/skills/polyglot-test-agent/SYNC.md +5 -0
- package/skills/polyglot-test-agent/unit-test-generation.prompt.md +155 -0
- package/skills/postgresql-code-review/LICENSE.md +21 -0
- package/skills/postgresql-code-review/SKILL.md +212 -0
- package/skills/postgresql-code-review/SYNC.md +5 -0
- package/skills/postgresql-optimization/LICENSE.md +21 -0
- package/skills/postgresql-optimization/SKILL.md +404 -0
- package/skills/postgresql-optimization/SYNC.md +5 -0
- package/skills/power-apps-code-app-scaffold/LICENSE.md +21 -0
- package/skills/power-apps-code-app-scaffold/SKILL.md +146 -0
- package/skills/power-apps-code-app-scaffold/SYNC.md +5 -0
- package/skills/power-bi-dax-optimization/LICENSE.md +21 -0
- package/skills/power-bi-dax-optimization/SKILL.md +173 -0
- package/skills/power-bi-dax-optimization/SYNC.md +5 -0
- package/skills/power-bi-model-design-review/LICENSE.md +21 -0
- package/skills/power-bi-model-design-review/SKILL.md +403 -0
- package/skills/power-bi-model-design-review/SYNC.md +5 -0
- package/skills/power-bi-performance-troubleshooting/LICENSE.md +21 -0
- package/skills/power-bi-performance-troubleshooting/SKILL.md +382 -0
- package/skills/power-bi-performance-troubleshooting/SYNC.md +5 -0
- package/skills/power-bi-report-design-consultation/LICENSE.md +21 -0
- package/skills/power-bi-report-design-consultation/SKILL.md +351 -0
- package/skills/power-bi-report-design-consultation/SYNC.md +5 -0
- package/skills/power-platform-mcp-connector-suite/LICENSE.md +21 -0
- package/skills/power-platform-mcp-connector-suite/SKILL.md +156 -0
- package/skills/power-platform-mcp-connector-suite/SYNC.md +5 -0
- package/skills/powerbi-modeling/LICENSE.md +21 -0
- package/skills/powerbi-modeling/SKILL.md +153 -0
- package/skills/powerbi-modeling/SYNC.md +5 -0
- package/skills/powerbi-modeling/references/MEASURES-DAX.md +195 -0
- package/skills/powerbi-modeling/references/PERFORMANCE.md +215 -0
- package/skills/powerbi-modeling/references/RELATIONSHIPS.md +147 -0
- package/skills/powerbi-modeling/references/RLS.md +226 -0
- package/skills/powerbi-modeling/references/STAR-SCHEMA.md +103 -0
- package/skills/prd/LICENSE.md +21 -0
- package/skills/prd/SKILL.md +143 -0
- package/skills/prd/SYNC.md +5 -0
- package/skills/premium-frontend-ui/LICENSE.md +21 -0
- package/skills/premium-frontend-ui/SKILL.md +110 -0
- package/skills/premium-frontend-ui/SYNC.md +5 -0
- package/skills/project-workflow-analysis-blueprint-generator/LICENSE.md +21 -0
- package/skills/project-workflow-analysis-blueprint-generator/SKILL.md +293 -0
- package/skills/project-workflow-analysis-blueprint-generator/SYNC.md +5 -0
- package/skills/prompt-builder/LICENSE.md +21 -0
- package/skills/prompt-builder/SKILL.md +141 -0
- package/skills/prompt-builder/SYNC.md +5 -0
- package/skills/publish-to-pages/LICENSE.md +21 -0
- package/skills/publish-to-pages/SKILL.md +107 -0
- package/skills/publish-to-pages/SYNC.md +5 -0
- package/skills/publish-to-pages/scripts/convert-pdf.py +176 -0
- package/skills/publish-to-pages/scripts/convert-pptx.py +376 -0
- package/skills/publish-to-pages/scripts/publish.sh +51 -0
- package/skills/pytest-coverage/LICENSE.md +21 -0
- package/skills/pytest-coverage/SKILL.md +28 -0
- package/skills/pytest-coverage/SYNC.md +5 -0
- package/skills/python-mcp-server-generator/LICENSE.md +21 -0
- package/skills/python-mcp-server-generator/SKILL.md +105 -0
- package/skills/python-mcp-server-generator/SYNC.md +5 -0
- package/skills/quasi-coder/LICENSE.md +21 -0
- package/skills/quasi-coder/SKILL.md +369 -0
- package/skills/quasi-coder/SYNC.md +5 -0
- package/skills/readme-blueprint-generator/LICENSE.md +21 -0
- package/skills/readme-blueprint-generator/SKILL.md +78 -0
- package/skills/readme-blueprint-generator/SYNC.md +5 -0
- package/skills/refactor/LICENSE.md +21 -0
- package/skills/refactor/SKILL.md +645 -0
- package/skills/refactor/SYNC.md +5 -0
- package/skills/refactor-method-complexity-reduce/LICENSE.md +21 -0
- package/skills/refactor-method-complexity-reduce/SKILL.md +98 -0
- package/skills/refactor-method-complexity-reduce/SYNC.md +5 -0
- package/skills/refactor-plan/LICENSE.md +21 -0
- package/skills/refactor-plan/SKILL.md +65 -0
- package/skills/refactor-plan/SYNC.md +5 -0
- package/skills/remember/LICENSE.md +21 -0
- package/skills/remember/SKILL.md +126 -0
- package/skills/remember/SYNC.md +5 -0
- package/skills/remember-interactive-programming/LICENSE.md +21 -0
- package/skills/remember-interactive-programming/SKILL.md +13 -0
- package/skills/remember-interactive-programming/SYNC.md +5 -0
- package/skills/repo-story-time/LICENSE.md +21 -0
- package/skills/repo-story-time/SKILL.md +154 -0
- package/skills/repo-story-time/SYNC.md +5 -0
- package/skills/review-and-refactor/LICENSE.md +21 -0
- package/skills/review-and-refactor/SKILL.md +15 -0
- package/skills/review-and-refactor/SYNC.md +5 -0
- package/skills/reviewing-oracle-to-postgres-migration/LICENSE.md +21 -0
- package/skills/reviewing-oracle-to-postgres-migration/SKILL.md +67 -0
- package/skills/reviewing-oracle-to-postgres-migration/SYNC.md +5 -0
- package/skills/reviewing-oracle-to-postgres-migration/references/REFERENCE.md +13 -0
- package/skills/reviewing-oracle-to-postgres-migration/references/empty-strings-handling.md +69 -0
- package/skills/reviewing-oracle-to-postgres-migration/references/no-data-found-exceptions.md +99 -0
- package/skills/reviewing-oracle-to-postgres-migration/references/oracle-parentheses-from-clause.md +190 -0
- package/skills/reviewing-oracle-to-postgres-migration/references/oracle-to-postgres-sorting.md +51 -0
- package/skills/reviewing-oracle-to-postgres-migration/references/oracle-to-postgres-timestamp-timezone.md +187 -0
- package/skills/reviewing-oracle-to-postgres-migration/references/oracle-to-postgres-to-char-numeric.md +145 -0
- package/skills/reviewing-oracle-to-postgres-migration/references/oracle-to-postgres-type-coercion.md +182 -0
- package/skills/reviewing-oracle-to-postgres-migration/references/postgres-concurrent-transactions.md +259 -0
- package/skills/reviewing-oracle-to-postgres-migration/references/postgres-refcursor-handling.md +148 -0
- package/skills/ruby-mcp-server-generator/LICENSE.md +21 -0
- package/skills/ruby-mcp-server-generator/SKILL.md +660 -0
- package/skills/ruby-mcp-server-generator/SYNC.md +5 -0
- package/skills/rust-mcp-server-generator/LICENSE.md +21 -0
- package/skills/rust-mcp-server-generator/SKILL.md +577 -0
- package/skills/rust-mcp-server-generator/SYNC.md +5 -0
- package/skills/sandbox-npm-install/LICENSE.md +21 -0
- package/skills/sandbox-npm-install/SKILL.md +80 -0
- package/skills/sandbox-npm-install/SYNC.md +5 -0
- package/skills/sandbox-npm-install/scripts/install.sh +193 -0
- package/skills/scaffolding-oracle-to-postgres-migration-test-project/LICENSE.md +21 -0
- package/skills/scaffolding-oracle-to-postgres-migration-test-project/SKILL.md +54 -0
- package/skills/scaffolding-oracle-to-postgres-migration-test-project/SYNC.md +5 -0
- package/skills/scoutqa-test/LICENSE.md +21 -0
- package/skills/scoutqa-test/SKILL.md +375 -0
- package/skills/scoutqa-test/SYNC.md +5 -0
- package/skills/secret-scanning/LICENSE.md +21 -0
- package/skills/secret-scanning/SKILL.md +224 -0
- package/skills/secret-scanning/SYNC.md +5 -0
- package/skills/secret-scanning/references/alerts-and-remediation.md +245 -0
- package/skills/secret-scanning/references/custom-patterns.md +158 -0
- package/skills/secret-scanning/references/push-protection.md +164 -0
- package/skills/semantic-kernel/LICENSE.md +21 -0
- package/skills/semantic-kernel/SKILL.md +56 -0
- package/skills/semantic-kernel/SYNC.md +5 -0
- package/skills/semantic-kernel/references/dotnet.md +15 -0
- package/skills/semantic-kernel/references/python.md +15 -0
- package/skills/shuffle-json-data/LICENSE.md +21 -0
- package/skills/shuffle-json-data/SKILL.md +150 -0
- package/skills/shuffle-json-data/SYNC.md +5 -0
- package/skills/snowflake-semanticview/LICENSE.md +21 -0
- package/skills/snowflake-semanticview/SKILL.md +83 -0
- package/skills/snowflake-semanticview/SYNC.md +5 -0
- package/skills/sponsor-finder/LICENSE.md +21 -0
- package/skills/sponsor-finder/SKILL.md +258 -0
- package/skills/sponsor-finder/SYNC.md +5 -0
- package/skills/spring-boot-testing/LICENSE.md +21 -0
- package/skills/spring-boot-testing/SKILL.md +189 -0
- package/skills/spring-boot-testing/SYNC.md +5 -0
- package/skills/spring-boot-testing/references/assertj-basics.md +207 -0
- package/skills/spring-boot-testing/references/assertj-collections.md +183 -0
- package/skills/spring-boot-testing/references/context-caching.md +115 -0
- package/skills/spring-boot-testing/references/datajpatest.md +197 -0
- package/skills/spring-boot-testing/references/instancio.md +230 -0
- package/skills/spring-boot-testing/references/mockitobean.md +232 -0
- package/skills/spring-boot-testing/references/mockmvc-classic.md +206 -0
- package/skills/spring-boot-testing/references/mockmvc-tester.md +311 -0
- package/skills/spring-boot-testing/references/restclienttest.md +227 -0
- package/skills/spring-boot-testing/references/resttestclient.md +278 -0
- package/skills/spring-boot-testing/references/sb4-migration.md +181 -0
- package/skills/spring-boot-testing/references/test-slices-overview.md +203 -0
- package/skills/spring-boot-testing/references/testcontainers-jdbc.md +234 -0
- package/skills/spring-boot-testing/references/webmvctest.md +177 -0
- package/skills/sql-code-review/LICENSE.md +21 -0
- package/skills/sql-code-review/SKILL.md +301 -0
- package/skills/sql-code-review/SYNC.md +5 -0
- package/skills/sql-optimization/LICENSE.md +21 -0
- package/skills/sql-optimization/SKILL.md +296 -0
- package/skills/sql-optimization/SYNC.md +5 -0
- package/skills/structured-autonomy-generate/LICENSE.md +21 -0
- package/skills/structured-autonomy-generate/SKILL.md +125 -0
- package/skills/structured-autonomy-generate/SYNC.md +5 -0
- package/skills/structured-autonomy-implement/LICENSE.md +21 -0
- package/skills/structured-autonomy-implement/SKILL.md +19 -0
- package/skills/structured-autonomy-implement/SYNC.md +5 -0
- package/skills/structured-autonomy-plan/LICENSE.md +21 -0
- package/skills/structured-autonomy-plan/SKILL.md +81 -0
- package/skills/structured-autonomy-plan/SYNC.md +5 -0
- package/skills/suggest-awesome-github-copilot-agents/LICENSE.md +21 -0
- package/skills/suggest-awesome-github-copilot-agents/SKILL.md +106 -0
- package/skills/suggest-awesome-github-copilot-agents/SYNC.md +5 -0
- package/skills/suggest-awesome-github-copilot-instructions/LICENSE.md +21 -0
- package/skills/suggest-awesome-github-copilot-instructions/SKILL.md +122 -0
- package/skills/suggest-awesome-github-copilot-instructions/SYNC.md +5 -0
- package/skills/suggest-awesome-github-copilot-skills/LICENSE.md +21 -0
- package/skills/suggest-awesome-github-copilot-skills/SKILL.md +130 -0
- package/skills/suggest-awesome-github-copilot-skills/SYNC.md +5 -0
- package/skills/swift-mcp-server-generator/LICENSE.md +21 -0
- package/skills/swift-mcp-server-generator/SKILL.md +669 -0
- package/skills/swift-mcp-server-generator/SYNC.md +5 -0
- package/skills/technology-stack-blueprint-generator/LICENSE.md +21 -0
- package/skills/technology-stack-blueprint-generator/SKILL.md +242 -0
- package/skills/technology-stack-blueprint-generator/SYNC.md +5 -0
- package/skills/terraform-azurerm-set-diff-analyzer/LICENSE.md +21 -0
- package/skills/terraform-azurerm-set-diff-analyzer/SKILL.md +48 -0
- package/skills/terraform-azurerm-set-diff-analyzer/SYNC.md +5 -0
- package/skills/terraform-azurerm-set-diff-analyzer/references/azurerm_set_attributes.json +154 -0
- package/skills/terraform-azurerm-set-diff-analyzer/references/azurerm_set_attributes.md +145 -0
- package/skills/terraform-azurerm-set-diff-analyzer/scripts/README.md +205 -0
- package/skills/terraform-azurerm-set-diff-analyzer/scripts/analyze_plan.py +940 -0
- package/skills/tldr-prompt/LICENSE.md +21 -0
- package/skills/tldr-prompt/SKILL.md +304 -0
- package/skills/tldr-prompt/SYNC.md +5 -0
- package/skills/transloadit-media-processing/LICENSE.md +21 -0
- package/skills/transloadit-media-processing/SKILL.md +194 -0
- package/skills/transloadit-media-processing/SYNC.md +5 -0
- package/skills/typescript-mcp-server-generator/LICENSE.md +21 -0
- package/skills/typescript-mcp-server-generator/SKILL.md +90 -0
- package/skills/typescript-mcp-server-generator/SYNC.md +5 -0
- package/skills/typespec-api-operations/LICENSE.md +21 -0
- package/skills/typespec-api-operations/SKILL.md +418 -0
- package/skills/typespec-api-operations/SYNC.md +5 -0
- package/skills/typespec-create-agent/LICENSE.md +21 -0
- package/skills/typespec-create-agent/SKILL.md +91 -0
- package/skills/typespec-create-agent/SYNC.md +5 -0
- package/skills/typespec-create-api-plugin/LICENSE.md +21 -0
- package/skills/typespec-create-api-plugin/SKILL.md +164 -0
- package/skills/typespec-create-api-plugin/SYNC.md +5 -0
- package/skills/unit-test-vue-pinia/LICENSE.md +21 -0
- package/skills/unit-test-vue-pinia/SKILL.md +198 -0
- package/skills/unit-test-vue-pinia/SYNC.md +5 -0
- package/skills/unit-test-vue-pinia/references/pinia-patterns.md +95 -0
- package/skills/update-avm-modules-in-bicep/LICENSE.md +21 -0
- package/skills/update-avm-modules-in-bicep/SKILL.md +60 -0
- package/skills/update-avm-modules-in-bicep/SYNC.md +5 -0
- package/skills/update-implementation-plan/LICENSE.md +21 -0
- package/skills/update-implementation-plan/SKILL.md +157 -0
- package/skills/update-implementation-plan/SYNC.md +5 -0
- package/skills/update-llms/LICENSE.md +21 -0
- package/skills/update-llms/SKILL.md +216 -0
- package/skills/update-llms/SYNC.md +5 -0
- package/skills/update-markdown-file-index/LICENSE.md +21 -0
- package/skills/update-markdown-file-index/SKILL.md +76 -0
- package/skills/update-markdown-file-index/SYNC.md +5 -0
- package/skills/update-specification/LICENSE.md +21 -0
- package/skills/update-specification/SKILL.md +127 -0
- package/skills/update-specification/SYNC.md +5 -0
- package/skills/vscode-ext-commands/LICENSE.md +21 -0
- package/skills/vscode-ext-commands/SKILL.md +21 -0
- package/skills/vscode-ext-commands/SYNC.md +5 -0
- package/skills/vscode-ext-localization/LICENSE.md +21 -0
- package/skills/vscode-ext-localization/SKILL.md +25 -0
- package/skills/vscode-ext-localization/SYNC.md +5 -0
- package/skills/web-coder/LICENSE.md +21 -0
- package/skills/web-coder/SKILL.md +563 -0
- package/skills/web-coder/SYNC.md +5 -0
- package/skills/web-coder/references/accessibility.md +346 -0
- package/skills/web-coder/references/architecture-patterns.md +625 -0
- package/skills/web-coder/references/browsers-engines.md +358 -0
- package/skills/web-coder/references/css-styling.md +696 -0
- package/skills/web-coder/references/data-formats-encoding.md +411 -0
- package/skills/web-coder/references/development-tools.md +502 -0
- package/skills/web-coder/references/glossary.md +649 -0
- package/skills/web-coder/references/html-markup.md +387 -0
- package/skills/web-coder/references/http-networking.md +538 -0
- package/skills/web-coder/references/javascript-programming.md +807 -0
- package/skills/web-coder/references/media-graphics.md +504 -0
- package/skills/web-coder/references/performance-optimization.md +546 -0
- package/skills/web-coder/references/security-authentication.md +603 -0
- package/skills/web-coder/references/servers-infrastructure.md +615 -0
- package/skills/web-coder/references/web-apis-dom.md +654 -0
- package/skills/web-coder/references/web-protocols-standards.md +265 -0
- package/skills/web-design-reviewer/LICENSE.md +21 -0
- package/skills/web-design-reviewer/SKILL.md +368 -0
- package/skills/web-design-reviewer/SYNC.md +5 -0
- package/skills/web-design-reviewer/references/framework-fixes.md +475 -0
- package/skills/web-design-reviewer/references/visual-checklist.md +236 -0
- package/skills/webapp-testing/LICENSE.md +21 -0
- package/skills/webapp-testing/SKILL.md +104 -67
- package/skills/webapp-testing/SYNC.md +2 -2
- package/skills/webapp-testing/assets/test-helper.js +56 -0
- package/skills/what-context-needed/LICENSE.md +21 -0
- package/skills/what-context-needed/SKILL.md +39 -0
- package/skills/what-context-needed/SYNC.md +5 -0
- package/skills/winapp-cli/LICENSE.md +21 -0
- package/skills/winapp-cli/SKILL.md +217 -0
- package/skills/winapp-cli/SYNC.md +5 -0
- package/skills/winmd-api-search/LICENSE.md +21 -0
- package/skills/winmd-api-search/LICENSE.txt +21 -0
- package/skills/winmd-api-search/SKILL.md +192 -0
- package/skills/winmd-api-search/SYNC.md +5 -0
- package/skills/winmd-api-search/scripts/Invoke-WinMdQuery.ps1 +505 -0
- package/skills/winmd-api-search/scripts/Update-WinMdCache.ps1 +208 -0
- package/skills/winmd-api-search/scripts/cache-generator/CacheGenerator.csproj +29 -0
- package/skills/winmd-api-search/scripts/cache-generator/Directory.Build.props +3 -0
- package/skills/winmd-api-search/scripts/cache-generator/Directory.Build.targets +3 -0
- package/skills/winmd-api-search/scripts/cache-generator/Directory.Packages.props +3 -0
- package/skills/winmd-api-search/scripts/cache-generator/Program.cs +1222 -0
- package/skills/winui3-migration-guide/LICENSE.md +21 -0
- package/skills/winui3-migration-guide/SKILL.md +277 -0
- package/skills/winui3-migration-guide/SYNC.md +5 -0
- package/skills/workiq-copilot/LICENSE.md +21 -0
- package/skills/workiq-copilot/SKILL.md +98 -0
- package/skills/workiq-copilot/SYNC.md +5 -0
- package/skills/write-coding-standards-from-file/LICENSE.md +21 -0
- package/skills/write-coding-standards-from-file/SKILL.md +316 -0
- package/skills/write-coding-standards-from-file/SYNC.md +5 -0
- package/skills/webapp-testing/LICENSE.txt +0 -202
- package/skills/webapp-testing/examples/console_logging.py +0 -35
- package/skills/webapp-testing/examples/element_discovery.py +0 -40
- package/skills/webapp-testing/examples/static_html_automation.py +0 -33
- package/skills/webapp-testing/scripts/with_server.py +0 -106
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: powerbi-modeling
|
|
3
|
+
description: 'Power BI semantic modeling assistant for building optimized data models. Use when working with Power BI semantic models, creating measures, designing star schemas, configuring relationships, implementing RLS, or optimizing model performance. Triggers on queries about DAX calculations, table relationships, dimension/fact table design, naming conventions, model documentation, cardinality, cross-filter direction, calculation groups, and data model best practices. Always connects to the active model first using power-bi-modeling MCP tools to understand the data structure before providing guidance.'
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Power BI Semantic Modeling
|
|
7
|
+
|
|
8
|
+
Guide users in building optimized, well-documented Power BI semantic models following Microsoft best practices.
|
|
9
|
+
|
|
10
|
+
## When to Use This Skill
|
|
11
|
+
|
|
12
|
+
Use this skill when users ask about:
|
|
13
|
+
- Creating or optimizing Power BI semantic models
|
|
14
|
+
- Designing star schemas (dimension/fact tables)
|
|
15
|
+
- Writing DAX measures or calculated columns
|
|
16
|
+
- Configuring table relationships (cardinality, cross-filter)
|
|
17
|
+
- Implementing row-level security (RLS)
|
|
18
|
+
- Naming conventions for tables, columns, measures
|
|
19
|
+
- Adding descriptions and documentation to models
|
|
20
|
+
- Performance tuning and optimization
|
|
21
|
+
- Calculation groups and field parameters
|
|
22
|
+
- Model validation and best practice checks
|
|
23
|
+
|
|
24
|
+
**Trigger phrases:** "create a measure", "add relationship", "star schema", "optimize model", "DAX formula", "RLS", "naming convention", "model documentation", "cardinality", "cross-filter"
|
|
25
|
+
|
|
26
|
+
## Prerequisites
|
|
27
|
+
|
|
28
|
+
### Required Tools
|
|
29
|
+
- **Power BI Modeling MCP Server**: Required for connecting to and modifying semantic models
|
|
30
|
+
- Enables: connection_operations, table_operations, measure_operations, relationship_operations, etc.
|
|
31
|
+
- Must be configured and running to interact with models
|
|
32
|
+
|
|
33
|
+
### Optional Dependencies
|
|
34
|
+
- **Microsoft Learn MCP Server**: Recommended for researching latest best practices
|
|
35
|
+
- Enables: microsoft_docs_search, microsoft_docs_fetch
|
|
36
|
+
- Use for complex scenarios, new features, and official documentation
|
|
37
|
+
|
|
38
|
+
## Workflow
|
|
39
|
+
|
|
40
|
+
### 1. Connect and Analyze First
|
|
41
|
+
|
|
42
|
+
Before providing any modeling guidance, always examine the current model state:
|
|
43
|
+
|
|
44
|
+
```
|
|
45
|
+
1. List connections: connection_operations(operation: "ListConnections")
|
|
46
|
+
2. If no connection, check for local instances: connection_operations(operation: "ListLocalInstances")
|
|
47
|
+
3. Connect to the model (Desktop or Fabric)
|
|
48
|
+
4. Get model overview: model_operations(operation: "Get")
|
|
49
|
+
5. List tables: table_operations(operation: "List")
|
|
50
|
+
6. List relationships: relationship_operations(operation: "List")
|
|
51
|
+
7. List measures: measure_operations(operation: "List")
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
### 2. Evaluate Model Health
|
|
55
|
+
|
|
56
|
+
After connecting, assess the model against best practices:
|
|
57
|
+
|
|
58
|
+
- **Star Schema**: Are tables properly classified as dimension or fact?
|
|
59
|
+
- **Relationships**: Correct cardinality? Minimal bidirectional filters?
|
|
60
|
+
- **Naming**: Human-readable, consistent naming conventions?
|
|
61
|
+
- **Documentation**: Do tables, columns, measures have descriptions?
|
|
62
|
+
- **Measures**: Explicit measures for key calculations?
|
|
63
|
+
- **Hidden Fields**: Are technical columns hidden from report view?
|
|
64
|
+
|
|
65
|
+
### 3. Provide Targeted Guidance
|
|
66
|
+
|
|
67
|
+
Based on analysis, guide improvements using references:
|
|
68
|
+
- Star schema design: See [STAR-SCHEMA.md](references/STAR-SCHEMA.md)
|
|
69
|
+
- Relationship configuration: See [RELATIONSHIPS.md](references/RELATIONSHIPS.md)
|
|
70
|
+
- DAX measures and naming: See [MEASURES-DAX.md](references/MEASURES-DAX.md)
|
|
71
|
+
- Performance optimization: See [PERFORMANCE.md](references/PERFORMANCE.md)
|
|
72
|
+
- Row-level security: See [RLS.md](references/RLS.md)
|
|
73
|
+
|
|
74
|
+
## Quick Reference: Model Quality Checklist
|
|
75
|
+
|
|
76
|
+
| Area | Best Practice |
|
|
77
|
+
|------|--------------|
|
|
78
|
+
| Tables | Clear dimension vs fact classification |
|
|
79
|
+
| Naming | Human-readable: `Customer Name` not `CUST_NM` |
|
|
80
|
+
| Descriptions | All tables, columns, measures documented |
|
|
81
|
+
| Measures | Explicit DAX measures for business metrics |
|
|
82
|
+
| Relationships | One-to-many from dimension to fact |
|
|
83
|
+
| Cross-filter | Single direction unless specifically needed |
|
|
84
|
+
| Hidden fields | Hide technical keys, IDs from report view |
|
|
85
|
+
| Date table | Dedicated marked date table |
|
|
86
|
+
|
|
87
|
+
## MCP Tools Reference
|
|
88
|
+
|
|
89
|
+
Use these Power BI Modeling MCP operations:
|
|
90
|
+
|
|
91
|
+
| Operation Category | Key Operations |
|
|
92
|
+
|-------------------|----------------|
|
|
93
|
+
| `connection_operations` | Connect, ListConnections, ListLocalInstances, ConnectFabric |
|
|
94
|
+
| `model_operations` | Get, GetStats, ExportTMDL |
|
|
95
|
+
| `table_operations` | List, Get, Create, Update, GetSchema |
|
|
96
|
+
| `column_operations` | List, Get, Create, Update (descriptions, hidden, format) |
|
|
97
|
+
| `measure_operations` | List, Get, Create, Update, Move |
|
|
98
|
+
| `relationship_operations` | List, Get, Create, Update, Activate, Deactivate |
|
|
99
|
+
| `dax_query_operations` | Execute, Validate |
|
|
100
|
+
| `calculation_group_operations` | List, Create, Update |
|
|
101
|
+
| `security_role_operations` | List, Create, Update, GetEffectivePermissions |
|
|
102
|
+
|
|
103
|
+
## Common Tasks
|
|
104
|
+
|
|
105
|
+
### Add Measure with Description
|
|
106
|
+
```
|
|
107
|
+
measure_operations(
|
|
108
|
+
operation: "Create",
|
|
109
|
+
definitions: [{
|
|
110
|
+
name: "Total Sales",
|
|
111
|
+
tableName: "Sales",
|
|
112
|
+
expression: "SUM(Sales[Amount])",
|
|
113
|
+
formatString: "$#,##0",
|
|
114
|
+
description: "Sum of all sales amounts"
|
|
115
|
+
}]
|
|
116
|
+
)
|
|
117
|
+
```
|
|
118
|
+
|
|
119
|
+
### Update Column Description
|
|
120
|
+
```
|
|
121
|
+
column_operations(
|
|
122
|
+
operation: "Update",
|
|
123
|
+
definitions: [{
|
|
124
|
+
tableName: "Customer",
|
|
125
|
+
name: "CustomerKey",
|
|
126
|
+
description: "Unique identifier for customer dimension",
|
|
127
|
+
isHidden: true
|
|
128
|
+
}]
|
|
129
|
+
)
|
|
130
|
+
```
|
|
131
|
+
|
|
132
|
+
### Create Relationship
|
|
133
|
+
```
|
|
134
|
+
relationship_operations(
|
|
135
|
+
operation: "Create",
|
|
136
|
+
definitions: [{
|
|
137
|
+
fromTable: "Sales",
|
|
138
|
+
fromColumn: "CustomerKey",
|
|
139
|
+
toTable: "Customer",
|
|
140
|
+
toColumn: "CustomerKey",
|
|
141
|
+
crossFilteringBehavior: "OneDirection"
|
|
142
|
+
}]
|
|
143
|
+
)
|
|
144
|
+
```
|
|
145
|
+
|
|
146
|
+
## When to Use Microsoft Learn MCP
|
|
147
|
+
|
|
148
|
+
Research current best practices using `microsoft_docs_search` for:
|
|
149
|
+
- Latest DAX function documentation
|
|
150
|
+
- New Power BI features and capabilities
|
|
151
|
+
- Complex modeling scenarios (SCD Type 2, many-to-many)
|
|
152
|
+
- Performance optimization techniques
|
|
153
|
+
- Security implementation patterns
|
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
# DAX Measures and Naming Conventions
|
|
2
|
+
|
|
3
|
+
## Naming Conventions
|
|
4
|
+
|
|
5
|
+
### General Rules
|
|
6
|
+
- Use human-readable names (spaces allowed)
|
|
7
|
+
- Be descriptive: `Total Sales Amount` not `TSA`
|
|
8
|
+
- Avoid abbreviations unless universally understood
|
|
9
|
+
- Use consistent capitalization (Title Case recommended)
|
|
10
|
+
- Avoid special characters except spaces
|
|
11
|
+
|
|
12
|
+
### Table Naming
|
|
13
|
+
| Type | Convention | Example |
|
|
14
|
+
|------|------------|---------|
|
|
15
|
+
| Dimension | Singular noun | Customer, Product, Date |
|
|
16
|
+
| Fact | Business process | Sales, Orders, Inventory |
|
|
17
|
+
| Bridge | Combined names | CustomerAccount, ProductCategory |
|
|
18
|
+
| Measure Table | Underscore prefix | _Measures, _KPIs |
|
|
19
|
+
|
|
20
|
+
### Column Naming
|
|
21
|
+
| Type | Convention | Example |
|
|
22
|
+
|------|------------|---------|
|
|
23
|
+
| Keys | Suffix with "Key" or "ID" | CustomerKey, ProductID |
|
|
24
|
+
| Dates | Suffix with "Date" | OrderDate, ShipDate |
|
|
25
|
+
| Amounts | Descriptive with unit hint | SalesAmount, QuantitySold |
|
|
26
|
+
| Flags | Prefix with "Is" or "Has" | IsActive, HasDiscount |
|
|
27
|
+
|
|
28
|
+
### Measure Naming
|
|
29
|
+
| Type | Convention | Example |
|
|
30
|
+
|------|------------|---------|
|
|
31
|
+
| Aggregations | Verb + Noun | Total Sales, Count of Orders |
|
|
32
|
+
| Ratios | X per Y or X Rate | Sales per Customer, Conversion Rate |
|
|
33
|
+
| Time Intelligence | Period + Metric | YTD Sales, PY Total Sales |
|
|
34
|
+
| Comparisons | Metric + vs + Baseline | Sales vs Budget, Growth vs PY |
|
|
35
|
+
|
|
36
|
+
## Explicit vs Implicit Measures
|
|
37
|
+
|
|
38
|
+
### Always Create Explicit Measures For:
|
|
39
|
+
1. Key business metrics users will query
|
|
40
|
+
2. Complex calculations with filter manipulation
|
|
41
|
+
3. Measures used in MDX (Excel PivotTables)
|
|
42
|
+
4. Controlled aggregation (prevent sum of averages)
|
|
43
|
+
|
|
44
|
+
### Implicit Measures (Column Aggregations)
|
|
45
|
+
- Acceptable for simple exploration
|
|
46
|
+
- Set correct SummarizeBy property:
|
|
47
|
+
- Amounts: Sum
|
|
48
|
+
- Keys/IDs: None (Do Not Summarize)
|
|
49
|
+
- Rates/Prices: None or Average
|
|
50
|
+
|
|
51
|
+
## Measure Patterns
|
|
52
|
+
|
|
53
|
+
### Basic Aggregations
|
|
54
|
+
```dax
|
|
55
|
+
Total Sales = SUM(Sales[SalesAmount])
|
|
56
|
+
Order Count = COUNTROWS(Sales)
|
|
57
|
+
Average Order Value = DIVIDE([Total Sales], [Order Count])
|
|
58
|
+
Distinct Customers = DISTINCTCOUNT(Sales[CustomerKey])
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
### Time Intelligence (Requires Date Table)
|
|
62
|
+
```dax
|
|
63
|
+
YTD Sales = TOTALYTD([Total Sales], 'Date'[Date])
|
|
64
|
+
MTD Sales = TOTALMTD([Total Sales], 'Date'[Date])
|
|
65
|
+
PY Sales = CALCULATE([Total Sales], SAMEPERIODLASTYEAR('Date'[Date]))
|
|
66
|
+
YoY Growth = DIVIDE([Total Sales] - [PY Sales], [PY Sales])
|
|
67
|
+
```
|
|
68
|
+
|
|
69
|
+
### Percentage Calculations
|
|
70
|
+
```dax
|
|
71
|
+
Sales % of Total =
|
|
72
|
+
DIVIDE(
|
|
73
|
+
[Total Sales],
|
|
74
|
+
CALCULATE([Total Sales], REMOVEFILTERS(Product))
|
|
75
|
+
)
|
|
76
|
+
|
|
77
|
+
Margin % = DIVIDE([Gross Profit], [Total Sales])
|
|
78
|
+
```
|
|
79
|
+
|
|
80
|
+
### Running Totals
|
|
81
|
+
```dax
|
|
82
|
+
Running Total =
|
|
83
|
+
CALCULATE(
|
|
84
|
+
[Total Sales],
|
|
85
|
+
FILTER(
|
|
86
|
+
ALL('Date'),
|
|
87
|
+
'Date'[Date] <= MAX('Date'[Date])
|
|
88
|
+
)
|
|
89
|
+
)
|
|
90
|
+
```
|
|
91
|
+
|
|
92
|
+
## Column References
|
|
93
|
+
|
|
94
|
+
### Best Practice: Always Qualify Column Names
|
|
95
|
+
```dax
|
|
96
|
+
// GOOD - Fully qualified
|
|
97
|
+
Sales Amount = SUM(Sales[SalesAmount])
|
|
98
|
+
|
|
99
|
+
// BAD - Unqualified (can cause ambiguity)
|
|
100
|
+
Sales Amount = SUM([SalesAmount])
|
|
101
|
+
```
|
|
102
|
+
|
|
103
|
+
### Measure References: Never Qualify
|
|
104
|
+
```dax
|
|
105
|
+
// GOOD - Unqualified measure
|
|
106
|
+
YTD Sales = TOTALYTD([Total Sales], 'Date'[Date])
|
|
107
|
+
|
|
108
|
+
// BAD - Qualified measure (breaks if home table changes)
|
|
109
|
+
YTD Sales = TOTALYTD(Sales[Total Sales], 'Date'[Date])
|
|
110
|
+
```
|
|
111
|
+
|
|
112
|
+
## Documentation
|
|
113
|
+
|
|
114
|
+
### Measure Descriptions
|
|
115
|
+
Always add descriptions explaining:
|
|
116
|
+
- What the measure calculates
|
|
117
|
+
- Business context/usage
|
|
118
|
+
- Any important assumptions
|
|
119
|
+
|
|
120
|
+
```
|
|
121
|
+
measure_operations(
|
|
122
|
+
operation: "Update",
|
|
123
|
+
definitions: [{
|
|
124
|
+
name: "Total Sales",
|
|
125
|
+
tableName: "Sales",
|
|
126
|
+
description: "Sum of all completed sales transactions. Excludes returns and cancelled orders."
|
|
127
|
+
}]
|
|
128
|
+
)
|
|
129
|
+
```
|
|
130
|
+
|
|
131
|
+
### Format Strings
|
|
132
|
+
| Data Type | Format String | Example Output |
|
|
133
|
+
|-----------|---------------|----------------|
|
|
134
|
+
| Currency | $#,##0.00 | $1,234.56 |
|
|
135
|
+
| Percentage | 0.0% | 12.3% |
|
|
136
|
+
| Whole Number | #,##0 | 1,234 |
|
|
137
|
+
| Decimal | #,##0.00 | 1,234.56 |
|
|
138
|
+
|
|
139
|
+
## Display Folders
|
|
140
|
+
|
|
141
|
+
Organize measures into logical groups:
|
|
142
|
+
```
|
|
143
|
+
measure_operations(
|
|
144
|
+
operation: "Update",
|
|
145
|
+
definitions: [{
|
|
146
|
+
name: "YTD Sales",
|
|
147
|
+
tableName: "_Measures",
|
|
148
|
+
displayFolder: "Time Intelligence\\Year"
|
|
149
|
+
}]
|
|
150
|
+
)
|
|
151
|
+
```
|
|
152
|
+
|
|
153
|
+
Common folder structure:
|
|
154
|
+
```
|
|
155
|
+
_Measures
|
|
156
|
+
├── Sales
|
|
157
|
+
│ ├── Total Sales
|
|
158
|
+
│ └── Average Sale
|
|
159
|
+
├── Time Intelligence
|
|
160
|
+
│ ├── Year
|
|
161
|
+
│ │ ├── YTD Sales
|
|
162
|
+
│ │ └── PY Sales
|
|
163
|
+
│ └── Month
|
|
164
|
+
│ └── MTD Sales
|
|
165
|
+
└── Ratios
|
|
166
|
+
├── Margin %
|
|
167
|
+
└── Conversion Rate
|
|
168
|
+
```
|
|
169
|
+
|
|
170
|
+
## Variables for Performance
|
|
171
|
+
|
|
172
|
+
Use variables to:
|
|
173
|
+
- Avoid recalculating the same expression
|
|
174
|
+
- Improve readability
|
|
175
|
+
- Enable debugging
|
|
176
|
+
|
|
177
|
+
```dax
|
|
178
|
+
Gross Margin % =
|
|
179
|
+
VAR TotalSales = [Total Sales]
|
|
180
|
+
VAR TotalCost = [Total Cost]
|
|
181
|
+
VAR GrossProfit = TotalSales - TotalCost
|
|
182
|
+
RETURN
|
|
183
|
+
DIVIDE(GrossProfit, TotalSales)
|
|
184
|
+
```
|
|
185
|
+
|
|
186
|
+
## Validation Checklist
|
|
187
|
+
|
|
188
|
+
- [ ] All key business metrics have explicit measures
|
|
189
|
+
- [ ] Measures have clear, descriptive names
|
|
190
|
+
- [ ] Measures have descriptions
|
|
191
|
+
- [ ] Appropriate format strings applied
|
|
192
|
+
- [ ] Display folders organize related measures
|
|
193
|
+
- [ ] Column references are fully qualified
|
|
194
|
+
- [ ] Measure references are not qualified
|
|
195
|
+
- [ ] Variables used for complex calculations
|
|
@@ -0,0 +1,215 @@
|
|
|
1
|
+
# Performance Optimization for Power BI Models
|
|
2
|
+
|
|
3
|
+
## Data Reduction Techniques
|
|
4
|
+
|
|
5
|
+
### 1. Remove Unnecessary Columns
|
|
6
|
+
- Only import columns needed for reporting
|
|
7
|
+
- Remove audit columns (CreatedBy, ModifiedDate) unless required
|
|
8
|
+
- Remove duplicate/redundant columns
|
|
9
|
+
|
|
10
|
+
```
|
|
11
|
+
column_operations(operation: "List", filter: { tableNames: ["Sales"] })
|
|
12
|
+
// Review and remove unneeded columns
|
|
13
|
+
```
|
|
14
|
+
|
|
15
|
+
### 2. Remove Unnecessary Rows
|
|
16
|
+
- Filter historical data to relevant period
|
|
17
|
+
- Exclude cancelled/void transactions if not needed
|
|
18
|
+
- Apply filters in Power Query (not in DAX)
|
|
19
|
+
|
|
20
|
+
### 3. Reduce Cardinality
|
|
21
|
+
High cardinality (many unique values) impacts:
|
|
22
|
+
- Model size
|
|
23
|
+
- Refresh time
|
|
24
|
+
- Query performance
|
|
25
|
+
|
|
26
|
+
**Solutions:**
|
|
27
|
+
| Column Type | Reduction Technique |
|
|
28
|
+
|-------------|---------------------|
|
|
29
|
+
| DateTime | Split into Date and Time columns |
|
|
30
|
+
| Decimal precision | Round to needed precision |
|
|
31
|
+
| Text with patterns | Extract common prefix/suffix |
|
|
32
|
+
| High-precision IDs | Use surrogate integer keys |
|
|
33
|
+
|
|
34
|
+
### 4. Optimize Data Types
|
|
35
|
+
| From | To | Benefit |
|
|
36
|
+
|------|-----|---------|
|
|
37
|
+
| DateTime | Date (if time not needed) | 8 bytes to 4 bytes |
|
|
38
|
+
| Decimal | Fixed Decimal | Better compression |
|
|
39
|
+
| Text with numbers | Whole Number | Much better compression |
|
|
40
|
+
| Long text | Shorter text | Reduces storage |
|
|
41
|
+
|
|
42
|
+
### 5. Group and Summarize
|
|
43
|
+
Pre-aggregate data when detail not needed:
|
|
44
|
+
- Daily instead of transactional
|
|
45
|
+
- Monthly instead of daily
|
|
46
|
+
- Consider aggregation tables for DirectQuery
|
|
47
|
+
|
|
48
|
+
## Column Optimization
|
|
49
|
+
|
|
50
|
+
### Prefer Power Query Columns Over Calculated Columns
|
|
51
|
+
| Approach | When to Use |
|
|
52
|
+
|----------|-------------|
|
|
53
|
+
| Power Query (M) | Can be computed at source, static values |
|
|
54
|
+
| Calculated Column (DAX) | Needs model relationships, dynamic logic |
|
|
55
|
+
|
|
56
|
+
Power Query columns:
|
|
57
|
+
- Load faster
|
|
58
|
+
- Compress better
|
|
59
|
+
- Use less memory
|
|
60
|
+
|
|
61
|
+
### Avoid Calculated Columns on Relationship Keys
|
|
62
|
+
DAX calculated columns in relationships:
|
|
63
|
+
- Cannot use indexes
|
|
64
|
+
- Generate complex SQL for DirectQuery
|
|
65
|
+
- Hurt performance significantly
|
|
66
|
+
|
|
67
|
+
**Use COMBINEVALUES for multi-column relationships:**
|
|
68
|
+
```dax
|
|
69
|
+
// If you must use calculated column for composite key
|
|
70
|
+
CompositeKey = COMBINEVALUES(",", [Country], [City])
|
|
71
|
+
```
|
|
72
|
+
|
|
73
|
+
### Set Appropriate Summarization
|
|
74
|
+
Prevent accidental aggregation of non-additive columns:
|
|
75
|
+
```
|
|
76
|
+
column_operations(
|
|
77
|
+
operation: "Update",
|
|
78
|
+
definitions: [{
|
|
79
|
+
tableName: "Product",
|
|
80
|
+
name: "UnitPrice",
|
|
81
|
+
summarizeBy: "None"
|
|
82
|
+
}]
|
|
83
|
+
)
|
|
84
|
+
```
|
|
85
|
+
|
|
86
|
+
## Relationship Optimization
|
|
87
|
+
|
|
88
|
+
### 1. Minimize Bidirectional Relationships
|
|
89
|
+
Each bidirectional relationship:
|
|
90
|
+
- Increases query complexity
|
|
91
|
+
- Can create ambiguous paths
|
|
92
|
+
- Reduces performance
|
|
93
|
+
|
|
94
|
+
### 2. Avoid Many-to-Many When Possible
|
|
95
|
+
Many-to-many relationships:
|
|
96
|
+
- Generate more complex queries
|
|
97
|
+
- Require more memory
|
|
98
|
+
- Can produce unexpected results
|
|
99
|
+
|
|
100
|
+
### 3. Reduce Relationship Cardinality
|
|
101
|
+
Keep relationship columns low cardinality:
|
|
102
|
+
- Use integer keys over text
|
|
103
|
+
- Consider higher-grain relationships
|
|
104
|
+
|
|
105
|
+
## DAX Optimization
|
|
106
|
+
|
|
107
|
+
### 1. Use Variables
|
|
108
|
+
```dax
|
|
109
|
+
// GOOD - Calculate once, use twice
|
|
110
|
+
Sales Growth =
|
|
111
|
+
VAR CurrentSales = [Total Sales]
|
|
112
|
+
VAR PriorSales = [PY Sales]
|
|
113
|
+
RETURN DIVIDE(CurrentSales - PriorSales, PriorSales)
|
|
114
|
+
|
|
115
|
+
// BAD - Recalculates [Total Sales] and [PY Sales]
|
|
116
|
+
Sales Growth =
|
|
117
|
+
DIVIDE([Total Sales] - [PY Sales], [PY Sales])
|
|
118
|
+
```
|
|
119
|
+
|
|
120
|
+
### 2. Avoid FILTER with Entire Tables
|
|
121
|
+
```dax
|
|
122
|
+
// BAD - Iterates entire table
|
|
123
|
+
Sales High Value =
|
|
124
|
+
CALCULATE([Total Sales], FILTER(Sales, Sales[Amount] > 1000))
|
|
125
|
+
|
|
126
|
+
// GOOD - Uses column reference
|
|
127
|
+
Sales High Value =
|
|
128
|
+
CALCULATE([Total Sales], Sales[Amount] > 1000)
|
|
129
|
+
```
|
|
130
|
+
|
|
131
|
+
### 3. Use KEEPFILTERS Appropriately
|
|
132
|
+
```dax
|
|
133
|
+
// Respects existing filters
|
|
134
|
+
Sales with Filter =
|
|
135
|
+
CALCULATE([Total Sales], KEEPFILTERS(Product[Category] = "Bikes"))
|
|
136
|
+
```
|
|
137
|
+
|
|
138
|
+
### 4. Prefer DIVIDE Over Division Operator
|
|
139
|
+
```dax
|
|
140
|
+
// GOOD - Handles divide by zero
|
|
141
|
+
Margin % = DIVIDE([Profit], [Sales])
|
|
142
|
+
|
|
143
|
+
// BAD - Errors on zero
|
|
144
|
+
Margin % = [Profit] / [Sales]
|
|
145
|
+
```
|
|
146
|
+
|
|
147
|
+
## DirectQuery Optimization
|
|
148
|
+
|
|
149
|
+
### 1. Minimize Columns and Tables
|
|
150
|
+
DirectQuery models:
|
|
151
|
+
- Query source for every visual
|
|
152
|
+
- Performance depends on source
|
|
153
|
+
- Minimize data retrieved
|
|
154
|
+
|
|
155
|
+
### 2. Avoid Complex Power Query Transformations
|
|
156
|
+
- Transforms become subqueries
|
|
157
|
+
- Native queries are faster
|
|
158
|
+
- Materialize at source when possible
|
|
159
|
+
|
|
160
|
+
### 3. Keep Measures Simple Initially
|
|
161
|
+
Complex DAX generates complex SQL:
|
|
162
|
+
- Start with basic aggregations
|
|
163
|
+
- Add complexity gradually
|
|
164
|
+
- Monitor query performance
|
|
165
|
+
|
|
166
|
+
### 4. Disable Auto Date/Time
|
|
167
|
+
For DirectQuery models, disable auto date/time:
|
|
168
|
+
- Creates hidden calculated tables
|
|
169
|
+
- Increases model complexity
|
|
170
|
+
- Use explicit date table instead
|
|
171
|
+
|
|
172
|
+
## Aggregations
|
|
173
|
+
|
|
174
|
+
### User-Defined Aggregations
|
|
175
|
+
Pre-aggregate fact tables for:
|
|
176
|
+
- Very large models (billions of rows)
|
|
177
|
+
- Hybrid DirectQuery/Import
|
|
178
|
+
- Common query patterns
|
|
179
|
+
|
|
180
|
+
```
|
|
181
|
+
table_operations(
|
|
182
|
+
operation: "Create",
|
|
183
|
+
definitions: [{
|
|
184
|
+
name: "SalesAgg",
|
|
185
|
+
mode: "Import",
|
|
186
|
+
mExpression: "..."
|
|
187
|
+
}]
|
|
188
|
+
)
|
|
189
|
+
```
|
|
190
|
+
|
|
191
|
+
## Performance Testing
|
|
192
|
+
|
|
193
|
+
### Use Performance Analyzer
|
|
194
|
+
1. Enable in Power BI Desktop
|
|
195
|
+
2. Start recording
|
|
196
|
+
3. Interact with visuals
|
|
197
|
+
4. Review DAX query times
|
|
198
|
+
|
|
199
|
+
### Monitor with DAX Studio
|
|
200
|
+
External tool for:
|
|
201
|
+
- Query timing
|
|
202
|
+
- Server timings
|
|
203
|
+
- Query plans
|
|
204
|
+
|
|
205
|
+
## Validation Checklist
|
|
206
|
+
|
|
207
|
+
- [ ] Unnecessary columns removed
|
|
208
|
+
- [ ] Appropriate data types used
|
|
209
|
+
- [ ] High-cardinality columns addressed
|
|
210
|
+
- [ ] Bidirectional relationships minimized
|
|
211
|
+
- [ ] DAX uses variables for repeated expressions
|
|
212
|
+
- [ ] No FILTER on entire tables
|
|
213
|
+
- [ ] DIVIDE used instead of division operator
|
|
214
|
+
- [ ] Auto date/time disabled for DirectQuery
|
|
215
|
+
- [ ] Performance tested with representative data
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
# Relationships in Power BI
|
|
2
|
+
|
|
3
|
+
## Relationship Properties
|
|
4
|
+
|
|
5
|
+
### Cardinality
|
|
6
|
+
| Type | Use Case | Notes |
|
|
7
|
+
|------|----------|-------|
|
|
8
|
+
| One-to-Many (*:1) | Dimension to Fact | Most common, preferred |
|
|
9
|
+
| Many-to-One (1:*) | Fact to Dimension | Same as above, direction reversed |
|
|
10
|
+
| One-to-One (1:1) | Dimension extensions | Use sparingly |
|
|
11
|
+
| Many-to-Many (*:*) | Bridge tables, complex scenarios | Requires careful design |
|
|
12
|
+
|
|
13
|
+
### Cross-Filter Direction
|
|
14
|
+
| Setting | Behavior | When to Use |
|
|
15
|
+
|---------|----------|-------------|
|
|
16
|
+
| Single | Filters flow from "one" to "many" | Default, best performance |
|
|
17
|
+
| Both | Filters flow in both directions | Only when necessary |
|
|
18
|
+
|
|
19
|
+
## Best Practices
|
|
20
|
+
|
|
21
|
+
### 1. Prefer One-to-Many Relationships
|
|
22
|
+
```
|
|
23
|
+
Customer (1) --> (*) Sales
|
|
24
|
+
Product (1) --> (*) Sales
|
|
25
|
+
Date (1) --> (*) Sales
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
### 2. Use Single-Direction Cross-Filtering
|
|
29
|
+
Bidirectional filtering:
|
|
30
|
+
- Impacts performance negatively
|
|
31
|
+
- Can create ambiguous filter paths
|
|
32
|
+
- May produce unexpected results
|
|
33
|
+
|
|
34
|
+
**Only use bidirectional when:**
|
|
35
|
+
- Dimension-to-dimension analysis through fact table
|
|
36
|
+
- Specific RLS requirements
|
|
37
|
+
|
|
38
|
+
**Better alternative:** Use CROSSFILTER in DAX measures:
|
|
39
|
+
```dax
|
|
40
|
+
Countries Sold =
|
|
41
|
+
CALCULATE(
|
|
42
|
+
DISTINCTCOUNT(Customer[Country]),
|
|
43
|
+
CROSSFILTER(Customer[CustomerKey], Sales[CustomerKey], BOTH)
|
|
44
|
+
)
|
|
45
|
+
```
|
|
46
|
+
|
|
47
|
+
### 3. One Active Path Between Tables
|
|
48
|
+
- Only one active relationship between any two tables
|
|
49
|
+
- Use USERELATIONSHIP for role-playing dimensions:
|
|
50
|
+
|
|
51
|
+
```dax
|
|
52
|
+
Sales by Ship Date =
|
|
53
|
+
CALCULATE(
|
|
54
|
+
[Total Sales],
|
|
55
|
+
USERELATIONSHIP(Sales[ShipDate], Date[Date])
|
|
56
|
+
)
|
|
57
|
+
```
|
|
58
|
+
|
|
59
|
+
### 4. Avoid Ambiguous Paths
|
|
60
|
+
Circular references cause errors. Solutions:
|
|
61
|
+
- Deactivate one relationship
|
|
62
|
+
- Restructure model
|
|
63
|
+
- Use USERELATIONSHIP in measures
|
|
64
|
+
|
|
65
|
+
## Relationship Patterns
|
|
66
|
+
|
|
67
|
+
### Standard Star Schema
|
|
68
|
+
```
|
|
69
|
+
[Date]
|
|
70
|
+
|
|
|
71
|
+
[Product]--[Sales]--[Customer]
|
|
72
|
+
|
|
|
73
|
+
[Store]
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
### Role-Playing Dimension
|
|
77
|
+
```
|
|
78
|
+
[Date] --(active)-- [Sales.OrderDate]
|
|
79
|
+
|
|
|
80
|
+
+--(inactive)-- [Sales.ShipDate]
|
|
81
|
+
```
|
|
82
|
+
|
|
83
|
+
### Bridge Table (Many-to-Many)
|
|
84
|
+
```
|
|
85
|
+
[Customer]--(*)--[CustomerAccount]--(*)--[Account]
|
|
86
|
+
```
|
|
87
|
+
|
|
88
|
+
### Factless Fact Table
|
|
89
|
+
```
|
|
90
|
+
[Product]--[ProductPromotion]--[Promotion]
|
|
91
|
+
```
|
|
92
|
+
Used to capture relationships without measures.
|
|
93
|
+
|
|
94
|
+
## Creating Relationships via MCP
|
|
95
|
+
|
|
96
|
+
### List Current Relationships
|
|
97
|
+
```
|
|
98
|
+
relationship_operations(operation: "List")
|
|
99
|
+
```
|
|
100
|
+
|
|
101
|
+
### Create New Relationship
|
|
102
|
+
```
|
|
103
|
+
relationship_operations(
|
|
104
|
+
operation: "Create",
|
|
105
|
+
definitions: [{
|
|
106
|
+
fromTable: "Sales",
|
|
107
|
+
fromColumn: "ProductKey",
|
|
108
|
+
toTable: "Product",
|
|
109
|
+
toColumn: "ProductKey",
|
|
110
|
+
crossFilteringBehavior: "OneDirection",
|
|
111
|
+
isActive: true
|
|
112
|
+
}]
|
|
113
|
+
)
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
### Deactivate Relationship
|
|
117
|
+
```
|
|
118
|
+
relationship_operations(
|
|
119
|
+
operation: "Deactivate",
|
|
120
|
+
references: [{ name: "relationship-guid-here" }]
|
|
121
|
+
)
|
|
122
|
+
```
|
|
123
|
+
|
|
124
|
+
## Troubleshooting
|
|
125
|
+
|
|
126
|
+
### "Ambiguous Path" Error
|
|
127
|
+
Multiple active paths exist between tables.
|
|
128
|
+
- Check for: Multiple fact tables sharing dimensions
|
|
129
|
+
- Solution: Deactivate redundant relationships
|
|
130
|
+
|
|
131
|
+
### Bidirectional Not Allowed
|
|
132
|
+
Circular reference would be created.
|
|
133
|
+
- Solution: Restructure or use DAX CROSSFILTER
|
|
134
|
+
|
|
135
|
+
### Relationship Not Detected
|
|
136
|
+
Columns may have different data types.
|
|
137
|
+
- Ensure both columns have identical types
|
|
138
|
+
- Check for trailing spaces in text keys
|
|
139
|
+
|
|
140
|
+
## Validation Checklist
|
|
141
|
+
|
|
142
|
+
- [ ] All relationships are one-to-many where possible
|
|
143
|
+
- [ ] Cross-filter is single direction by default
|
|
144
|
+
- [ ] Only one active path between any two tables
|
|
145
|
+
- [ ] Role-playing dimensions use inactive relationships
|
|
146
|
+
- [ ] No circular reference paths
|
|
147
|
+
- [ ] Key columns have matching data types
|