@salesforce/afv-skills 1.22.0 → 1.23.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/package.json +1 -1
- package/skills/activating-datacloud/README.md +0 -39
- package/skills/activating-datacloud/SKILL.md +0 -117
- package/skills/analyzing-omnistudio-dependencies/CREDITS.md +0 -5
- package/skills/analyzing-omnistudio-dependencies/SKILL.md +0 -476
- package/skills/analyzing-omnistudio-dependencies/references/dependency-patterns.md +0 -508
- package/skills/analyzing-omnistudio-dependencies/references/namespace-guide.md +0 -300
- package/skills/applying-cms-brand/SKILL.md +0 -170
- package/skills/applying-slds/SKILL.md +0 -322
- package/skills/applying-slds/checklists.md +0 -83
- package/skills/applying-slds/examples.md +0 -283
- package/skills/applying-slds/guidance/README.md +0 -83
- package/skills/applying-slds/guidance/blueprints-index.md +0 -213
- package/skills/applying-slds/guidance/icons-guidance.md +0 -186
- package/skills/applying-slds/guidance/overviews/borders.md +0 -236
- package/skills/applying-slds/guidance/overviews/color.md +0 -266
- package/skills/applying-slds/guidance/overviews/display-density.md +0 -366
- package/skills/applying-slds/guidance/overviews/icons.md +0 -240
- package/skills/applying-slds/guidance/overviews/illustrations.md +0 -235
- package/skills/applying-slds/guidance/overviews/shadows.md +0 -176
- package/skills/applying-slds/guidance/overviews/spacing.md +0 -216
- package/skills/applying-slds/guidance/overviews/typography.md +0 -323
- package/skills/applying-slds/guidance/overviews/utilities.md +0 -542
- package/skills/applying-slds/guidance/slds-development-guide.md +0 -288
- package/skills/applying-slds/guidance/styling-hooks/borders.md +0 -202
- package/skills/applying-slds/guidance/styling-hooks/color/expressive-palette-hooks.md +0 -153
- package/skills/applying-slds/guidance/styling-hooks/color/index.md +0 -171
- package/skills/applying-slds/guidance/styling-hooks/color/semantic/accent-hooks.md +0 -204
- package/skills/applying-slds/guidance/styling-hooks/color/semantic/feedback-hooks.md +0 -768
- package/skills/applying-slds/guidance/styling-hooks/color/semantic/surface-hooks.md +0 -337
- package/skills/applying-slds/guidance/styling-hooks/color/system-hooks.md +0 -132
- package/skills/applying-slds/guidance/styling-hooks/index.md +0 -327
- package/skills/applying-slds/guidance/styling-hooks/shadows.md +0 -238
- package/skills/applying-slds/guidance/styling-hooks/spacing.md +0 -254
- package/skills/applying-slds/guidance/styling-hooks/typography.md +0 -448
- package/skills/applying-slds/guidance/utilities/alignment.md +0 -119
- package/skills/applying-slds/guidance/utilities/borders.md +0 -131
- package/skills/applying-slds/guidance/utilities/box.md +0 -125
- package/skills/applying-slds/guidance/utilities/color.md +0 -165
- package/skills/applying-slds/guidance/utilities/dark-mode.md +0 -111
- package/skills/applying-slds/guidance/utilities/description-list.md +0 -168
- package/skills/applying-slds/guidance/utilities/floats.md +0 -117
- package/skills/applying-slds/guidance/utilities/grid.md +0 -264
- package/skills/applying-slds/guidance/utilities/horizontal-list.md +0 -110
- package/skills/applying-slds/guidance/utilities/hyphenation.md +0 -84
- package/skills/applying-slds/guidance/utilities/index.md +0 -205
- package/skills/applying-slds/guidance/utilities/interactions.md +0 -89
- package/skills/applying-slds/guidance/utilities/layout.md +0 -109
- package/skills/applying-slds/guidance/utilities/line-clamp.md +0 -131
- package/skills/applying-slds/guidance/utilities/margin.md +0 -155
- package/skills/applying-slds/guidance/utilities/media-object.md +0 -161
- package/skills/applying-slds/guidance/utilities/name-value-list.md +0 -152
- package/skills/applying-slds/guidance/utilities/padding.md +0 -155
- package/skills/applying-slds/guidance/utilities/position.md +0 -177
- package/skills/applying-slds/guidance/utilities/print.md +0 -114
- package/skills/applying-slds/guidance/utilities/scrollable.md +0 -126
- package/skills/applying-slds/guidance/utilities/sizing.md +0 -190
- package/skills/applying-slds/guidance/utilities/themes.md +0 -121
- package/skills/applying-slds/guidance/utilities/truncate.md +0 -127
- package/skills/applying-slds/guidance/utilities/typography.md +0 -166
- package/skills/applying-slds/guidance/utilities/vertical-list.md +0 -166
- package/skills/applying-slds/guidance/utilities/visibility.md +0 -228
- package/skills/applying-slds/metadata/README.md +0 -84
- package/skills/applying-slds/metadata/blueprints/components/accordion.yaml +0 -304
- package/skills/applying-slds/metadata/blueprints/components/activity-timeline.yaml +0 -92
- package/skills/applying-slds/metadata/blueprints/components/alert.yaml +0 -103
- package/skills/applying-slds/metadata/blueprints/components/app-launcher.yaml +0 -94
- package/skills/applying-slds/metadata/blueprints/components/avatar-group.yaml +0 -81
- package/skills/applying-slds/metadata/blueprints/components/avatar.yaml +0 -97
- package/skills/applying-slds/metadata/blueprints/components/badges.yaml +0 -102
- package/skills/applying-slds/metadata/blueprints/components/brand-band.yaml +0 -198
- package/skills/applying-slds/metadata/blueprints/components/breadcrumbs.yaml +0 -95
- package/skills/applying-slds/metadata/blueprints/components/builder-header.yaml +0 -192
- package/skills/applying-slds/metadata/blueprints/components/button-groups.yaml +0 -82
- package/skills/applying-slds/metadata/blueprints/components/button-icons.yaml +0 -295
- package/skills/applying-slds/metadata/blueprints/components/buttons.yaml +0 -230
- package/skills/applying-slds/metadata/blueprints/components/cards.yaml +0 -124
- package/skills/applying-slds/metadata/blueprints/components/carousel.yaml +0 -140
- package/skills/applying-slds/metadata/blueprints/components/chat.yaml +0 -179
- package/skills/applying-slds/metadata/blueprints/components/checkbox-button-group.yaml +0 -192
- package/skills/applying-slds/metadata/blueprints/components/checkbox-button.yaml +0 -204
- package/skills/applying-slds/metadata/blueprints/components/checkbox-toggle.yaml +0 -177
- package/skills/applying-slds/metadata/blueprints/components/checkbox.yaml +0 -108
- package/skills/applying-slds/metadata/blueprints/components/color-picker.yaml +0 -172
- package/skills/applying-slds/metadata/blueprints/components/combobox.yaml +0 -136
- package/skills/applying-slds/metadata/blueprints/components/counter.yaml +0 -147
- package/skills/applying-slds/metadata/blueprints/components/data-tables.yaml +0 -157
- package/skills/applying-slds/metadata/blueprints/components/datepickers.yaml +0 -130
- package/skills/applying-slds/metadata/blueprints/components/datetime-picker.yaml +0 -155
- package/skills/applying-slds/metadata/blueprints/components/docked-composer.yaml +0 -201
- package/skills/applying-slds/metadata/blueprints/components/docked-form-footer.yaml +0 -161
- package/skills/applying-slds/metadata/blueprints/components/docked-utility-bar.yaml +0 -175
- package/skills/applying-slds/metadata/blueprints/components/drop-zone.yaml +0 -115
- package/skills/applying-slds/metadata/blueprints/components/dueling-picklist.yaml +0 -196
- package/skills/applying-slds/metadata/blueprints/components/dynamic-icons.yaml +0 -128
- package/skills/applying-slds/metadata/blueprints/components/dynamic-menu.yaml +0 -141
- package/skills/applying-slds/metadata/blueprints/components/expandable-section.yaml +0 -115
- package/skills/applying-slds/metadata/blueprints/components/expression.yaml +0 -143
- package/skills/applying-slds/metadata/blueprints/components/feeds.yaml +0 -125
- package/skills/applying-slds/metadata/blueprints/components/file-selector.yaml +0 -154
- package/skills/applying-slds/metadata/blueprints/components/files.yaml +0 -119
- package/skills/applying-slds/metadata/blueprints/components/form-element.yaml +0 -145
- package/skills/applying-slds/metadata/blueprints/components/global-header.yaml +0 -120
- package/skills/applying-slds/metadata/blueprints/components/global-navigation.yaml +0 -100
- package/skills/applying-slds/metadata/blueprints/components/icons.yaml +0 -138
- package/skills/applying-slds/metadata/blueprints/components/illustration.yaml +0 -205
- package/skills/applying-slds/metadata/blueprints/components/input.yaml +0 -151
- package/skills/applying-slds/metadata/blueprints/components/list-builder.yaml +0 -127
- package/skills/applying-slds/metadata/blueprints/components/lookups.yaml +0 -132
- package/skills/applying-slds/metadata/blueprints/components/map.yaml +0 -118
- package/skills/applying-slds/metadata/blueprints/components/menus.yaml +0 -134
- package/skills/applying-slds/metadata/blueprints/components/modals.yaml +0 -152
- package/skills/applying-slds/metadata/blueprints/components/notifications.yaml +0 -88
- package/skills/applying-slds/metadata/blueprints/components/page-headers.yaml +0 -135
- package/skills/applying-slds/metadata/blueprints/components/panels.yaml +0 -149
- package/skills/applying-slds/metadata/blueprints/components/path.yaml +0 -154
- package/skills/applying-slds/metadata/blueprints/components/picklist.yaml +0 -125
- package/skills/applying-slds/metadata/blueprints/components/pills.yaml +0 -154
- package/skills/applying-slds/metadata/blueprints/components/popovers.yaml +0 -120
- package/skills/applying-slds/metadata/blueprints/components/progress-bar.yaml +0 -110
- package/skills/applying-slds/metadata/blueprints/components/progress-indicator.yaml +0 -133
- package/skills/applying-slds/metadata/blueprints/components/progress-ring.yaml +0 -102
- package/skills/applying-slds/metadata/blueprints/components/prompt.yaml +0 -126
- package/skills/applying-slds/metadata/blueprints/components/publishers.yaml +0 -178
- package/skills/applying-slds/metadata/blueprints/components/radio-button-group.yaml +0 -172
- package/skills/applying-slds/metadata/blueprints/components/radio-group.yaml +0 -112
- package/skills/applying-slds/metadata/blueprints/components/rich-text-editor.yaml +0 -135
- package/skills/applying-slds/metadata/blueprints/components/scoped-notifications.yaml +0 -188
- package/skills/applying-slds/metadata/blueprints/components/scoped-tabs.yaml +0 -97
- package/skills/applying-slds/metadata/blueprints/components/select.yaml +0 -127
- package/skills/applying-slds/metadata/blueprints/components/setup-assistant.yaml +0 -152
- package/skills/applying-slds/metadata/blueprints/components/slider.yaml +0 -111
- package/skills/applying-slds/metadata/blueprints/components/spinners.yaml +0 -135
- package/skills/applying-slds/metadata/blueprints/components/split-view.yaml +0 -112
- package/skills/applying-slds/metadata/blueprints/components/summary-detail.yaml +0 -103
- package/skills/applying-slds/metadata/blueprints/components/tabs.yaml +0 -138
- package/skills/applying-slds/metadata/blueprints/components/textarea.yaml +0 -116
- package/skills/applying-slds/metadata/blueprints/components/tiles.yaml +0 -108
- package/skills/applying-slds/metadata/blueprints/components/timepicker.yaml +0 -111
- package/skills/applying-slds/metadata/blueprints/components/toast.yaml +0 -154
- package/skills/applying-slds/metadata/blueprints/components/tooltips.yaml +0 -107
- package/skills/applying-slds/metadata/blueprints/components/tree-grid.yaml +0 -116
- package/skills/applying-slds/metadata/blueprints/components/trees.yaml +0 -116
- package/skills/applying-slds/metadata/blueprints/components/trial-bar.yaml +0 -112
- package/skills/applying-slds/metadata/blueprints/components/vertical-navigation.yaml +0 -130
- package/skills/applying-slds/metadata/blueprints/components/vertical-tabs.yaml +0 -140
- package/skills/applying-slds/metadata/blueprints/components/visual-picker.yaml +0 -150
- package/skills/applying-slds/metadata/blueprints/components/welcome-mat.yaml +0 -136
- package/skills/applying-slds/metadata/hooks-index.json +0 -6272
- package/skills/applying-slds/metadata/icon-metadata.json +0 -38466
- package/skills/applying-slds/metadata/utilities-index.json +0 -21912
- package/skills/applying-slds/references/component-selection.md +0 -112
- package/skills/applying-slds/references/icons-decision-guide.md +0 -124
- package/skills/applying-slds/references/styling-decision-guide.md +0 -228
- package/skills/applying-slds/references/utilities-quick-ref.md +0 -125
- package/skills/applying-slds/scripts/search-blueprints.cjs +0 -117
- package/skills/applying-slds/scripts/search-hooks.cjs +0 -139
- package/skills/applying-slds/scripts/search-icons.cjs +0 -174
- package/skills/applying-slds/scripts/search-utilities.cjs +0 -161
- package/skills/building-mobile-apps/SKILL.md +0 -69
- package/skills/building-omnistudio-callable-apex/CREDITS.md +0 -9
- package/skills/building-omnistudio-callable-apex/README.md +0 -80
- package/skills/building-omnistudio-callable-apex/SKILL.md +0 -275
- package/skills/building-omnistudio-callable-apex/assets/pattern_callable_openinterface.cls +0 -40
- package/skills/building-omnistudio-callable-apex/assets/pattern_callable_vanilla.cls +0 -32
- package/skills/building-omnistudio-callable-apex/assets/pattern_migration.cls +0 -54
- package/skills/building-omnistudio-callable-apex/assets/pattern_openinterface.cls +0 -45
- package/skills/building-omnistudio-callable-apex/assets/pattern_test_class.cls +0 -65
- package/skills/building-omnistudio-callable-apex/examples/Test_QuoteByProductCallable/IndustriesCallableException.cls +0 -7
- package/skills/building-omnistudio-callable-apex/examples/Test_QuoteByProductCallable/Industries_QuoteByProductCallable.cls +0 -115
- package/skills/building-omnistudio-callable-apex/examples/Test_QuoteByProductCallable/Industries_QuoteByProductCallableTest.cls +0 -189
- package/skills/building-omnistudio-callable-apex/examples/Test_QuoteByProductCallable/TRANSCRIPT.md +0 -115
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterface2Conversion/IndustriesCallableException.cls +0 -7
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterface2Conversion/MyCustomCallable.cls +0 -74
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterface2Conversion/MyCustomCallableTest.cls +0 -146
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterface2Conversion/MyCustomRemoteClass.cls +0 -16
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterface2Conversion/TRANSCRIPT.md +0 -120
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterfaceConversion/IndustriesCallableException.cls +0 -7
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterfaceConversion/MyCustomCallable.cls +0 -73
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterfaceConversion/MyCustomCallableTest.cls +0 -128
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterfaceConversion/MyCustomVlocityOpenInterface2.cls +0 -23
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterfaceConversion/TRANSCRIPT.md +0 -75
- package/skills/building-omnistudio-datamapper/CREDITS.md +0 -5
- package/skills/building-omnistudio-datamapper/SKILL.md +0 -269
- package/skills/building-omnistudio-datamapper/assets/completion-summary-template.md +0 -28
- package/skills/building-omnistudio-datamapper/assets/omni-data-transform-extract.json +0 -6
- package/skills/building-omnistudio-datamapper/assets/omni-data-transform-item.json +0 -12
- package/skills/building-omnistudio-datamapper/assets/omni-data-transform-load.json +0 -6
- package/skills/building-omnistudio-datamapper/assets/omni-data-transform-transform.json +0 -6
- package/skills/building-omnistudio-datamapper/references/best-practices.md +0 -277
- package/skills/building-omnistudio-datamapper/references/naming-conventions.md +0 -145
- package/skills/building-omnistudio-flexcard/CREDITS.md +0 -5
- package/skills/building-omnistudio-flexcard/SKILL.md +0 -324
- package/skills/building-omnistudio-flexcard/assets/omni-ui-card.json +0 -10
- package/skills/building-omnistudio-flexcard/references/best-practices.md +0 -291
- package/skills/building-omnistudio-flexcard/references/data-binding-guide.md +0 -311
- package/skills/building-omnistudio-flexcard/references/scoring-rubric.md +0 -66
- package/skills/building-omnistudio-flexcard/scripts/flexcard-commands.sh +0 -24
- package/skills/building-omnistudio-integration-procedure/CREDITS.md +0 -5
- package/skills/building-omnistudio-integration-procedure/SKILL.md +0 -274
- package/skills/building-omnistudio-integration-procedure/assets/omni-process-element-dr-extract.json +0 -10
- package/skills/building-omnistudio-integration-procedure/assets/omni-process-element-set-values.json +0 -10
- package/skills/building-omnistudio-integration-procedure/assets/omni-process-ip.json +0 -12
- package/skills/building-omnistudio-integration-procedure/assets/scoring-report-format.txt +0 -14
- package/skills/building-omnistudio-integration-procedure/references/best-practices.md +0 -388
- package/skills/building-omnistudio-integration-procedure/references/element-types.md +0 -588
- package/skills/building-omnistudio-integration-procedure/scripts/cli-commands.sh +0 -18
- package/skills/building-omnistudio-omniscript/CREDITS.md +0 -5
- package/skills/building-omnistudio-omniscript/SKILL.md +0 -366
- package/skills/building-omnistudio-omniscript/assets/omni-process-element-step.json +0 -10
- package/skills/building-omnistudio-omniscript/assets/omni-process-element-text-block.json +0 -11
- package/skills/building-omnistudio-omniscript/assets/omni-process-omniscript.json +0 -12
- package/skills/building-omnistudio-omniscript/references/best-practices.md +0 -480
- package/skills/building-omnistudio-omniscript/references/element-types.md +0 -1172
- package/skills/building-omnistudio-omniscript/scripts/check-duplicate-omniscript.sh +0 -13
- package/skills/building-omnistudio-omniscript/scripts/cli-reference.sh +0 -21
- package/skills/building-omnistudio-omniscript/scripts/deploy-omniscript.sh +0 -29
- package/skills/building-sf-integrations/CREDITS.md +0 -5
- package/skills/building-sf-integrations/README.md +0 -95
- package/skills/building-sf-integrations/SKILL.md +0 -191
- package/skills/building-sf-integrations/assets/callouts/callout-retry-handler.cls +0 -167
- package/skills/building-sf-integrations/assets/callouts/http-response-handler.cls +0 -257
- package/skills/building-sf-integrations/assets/callouts/rest-queueable-callout.cls +0 -262
- package/skills/building-sf-integrations/assets/callouts/rest-sync-callout.cls +0 -211
- package/skills/building-sf-integrations/assets/cdc/cdc-handler.cls +0 -246
- package/skills/building-sf-integrations/assets/cdc/cdc-subscriber-trigger.trigger +0 -139
- package/skills/building-sf-integrations/assets/endpoint-security/example.cspTrustedSite-meta.xml +0 -58
- package/skills/building-sf-integrations/assets/endpoint-security/example.remoteSite-meta.xml +0 -39
- package/skills/building-sf-integrations/assets/external-credentials/jwt-external-credential.externalCredential-meta.xml +0 -90
- package/skills/building-sf-integrations/assets/external-credentials/oauth-external-credential.externalCredential-meta.xml +0 -87
- package/skills/building-sf-integrations/assets/external-services/external-service-operations.md +0 -221
- package/skills/building-sf-integrations/assets/external-services/openapi-registration.externalServiceRegistration-meta.xml +0 -193
- package/skills/building-sf-integrations/assets/named-credentials/certificate-auth.namedCredential-meta.xml +0 -62
- package/skills/building-sf-integrations/assets/named-credentials/custom-auth.namedCredential-meta.xml +0 -71
- package/skills/building-sf-integrations/assets/named-credentials/oauth-client-credentials.namedCredential-meta.xml +0 -51
- package/skills/building-sf-integrations/assets/named-credentials/oauth-jwt-bearer.namedCredential-meta.xml +0 -67
- package/skills/building-sf-integrations/assets/platform-events/event-publisher.cls +0 -191
- package/skills/building-sf-integrations/assets/platform-events/event-subscriber-action.cls +0 -295
- package/skills/building-sf-integrations/assets/platform-events/event-subscriber-trigger.trigger +0 -108
- package/skills/building-sf-integrations/assets/platform-events/platform-event-definition.object-meta.xml +0 -124
- package/skills/building-sf-integrations/assets/soap/soap-callout-service.cls +0 -186
- package/skills/building-sf-integrations/assets/soap/wsdl2apex-guide.md +0 -213
- package/skills/building-sf-integrations/hooks/scripts/suggest_credential_setup.py +0 -271
- package/skills/building-sf-integrations/hooks/scripts/validate_integration.py +0 -363
- package/skills/building-sf-integrations/references/callout-patterns.md +0 -719
- package/skills/building-sf-integrations/references/cdc-guide.md +0 -288
- package/skills/building-sf-integrations/references/cli-reference.md +0 -94
- package/skills/building-sf-integrations/references/event-driven-architecture-guide.md +0 -266
- package/skills/building-sf-integrations/references/event-patterns.md +0 -838
- package/skills/building-sf-integrations/references/external-services-guide.md +0 -303
- package/skills/building-sf-integrations/references/messaging-api-v2.md +0 -609
- package/skills/building-sf-integrations/references/named-credentials-automation.md +0 -201
- package/skills/building-sf-integrations/references/named-credentials-guide.md +0 -173
- package/skills/building-sf-integrations/references/platform-events-guide.md +0 -288
- package/skills/building-sf-integrations/references/rest-callout-patterns.md +0 -288
- package/skills/building-sf-integrations/references/scoring-rubric.md +0 -59
- package/skills/building-sf-integrations/references/security-best-practices.md +0 -248
- package/skills/building-sf-integrations/scripts/README.md +0 -100
- package/skills/building-sf-integrations/scripts/configure-named-credential.sh +0 -236
- package/skills/building-sf-integrations/scripts/set-api-credential.sh +0 -146
- package/skills/building-sf-integrations/scripts/templates/setup-credentials-with-csp.sh +0 -158
- package/skills/building-ui-bundle-app/SKILL.md +0 -350
- package/skills/building-ui-bundle-frontend/SKILL.md +0 -135
- package/skills/building-ui-bundle-frontend/implementation/component.md +0 -78
- package/skills/building-ui-bundle-frontend/implementation/header-footer.md +0 -132
- package/skills/building-ui-bundle-frontend/implementation/page.md +0 -93
- package/skills/configuring-code-analyzer/SKILL.md +0 -482
- package/skills/configuring-code-analyzer/examples/apex-project-config.yml +0 -41
- package/skills/configuring-code-analyzer/examples/ci-github-actions.yml +0 -96
- package/skills/configuring-code-analyzer/examples/fullstack-project-config.yml +0 -46
- package/skills/configuring-code-analyzer/examples/lwc-project-config.yml +0 -26
- package/skills/configuring-code-analyzer/references/ci-cd-templates.md +0 -648
- package/skills/configuring-code-analyzer/references/config-schema.md +0 -257
- package/skills/configuring-code-analyzer/references/diagnostic-flow.md +0 -70
- package/skills/configuring-code-analyzer/references/engine-prerequisites.md +0 -276
- package/skills/configuring-code-analyzer/references/rule-name-resolution.md +0 -67
- package/skills/configuring-code-analyzer/references/troubleshooting.md +0 -298
- package/skills/configuring-code-analyzer/scripts/check-prerequisites.sh +0 -189
- package/skills/configuring-code-analyzer/scripts/generate-config.sh +0 -143
- package/skills/configuring-code-analyzer/scripts/validate-config.sh +0 -153
- package/skills/configuring-connected-apps/CREDITS.md +0 -3
- package/skills/configuring-connected-apps/README.md +0 -99
- package/skills/configuring-connected-apps/SKILL.md +0 -223
- package/skills/configuring-connected-apps/assets/connected-app-basic.xml +0 -29
- package/skills/configuring-connected-apps/assets/connected-app-canvas.xml +0 -62
- package/skills/configuring-connected-apps/assets/connected-app-jwt.xml +0 -49
- package/skills/configuring-connected-apps/assets/connected-app-oauth.xml +0 -65
- package/skills/configuring-connected-apps/assets/eca-global-oauth.xml +0 -36
- package/skills/configuring-connected-apps/assets/eca-oauth-settings.xml +0 -36
- package/skills/configuring-connected-apps/assets/eca-policies.xml +0 -36
- package/skills/configuring-connected-apps/assets/external-client-app.xml +0 -35
- package/skills/configuring-connected-apps/references/example-usage.md +0 -256
- package/skills/configuring-connected-apps/references/migration-guide.md +0 -328
- package/skills/configuring-connected-apps/references/oauth-flows-reference.md +0 -660
- package/skills/configuring-connected-apps/references/security-checklist.md +0 -209
- package/skills/configuring-connected-apps/references/testing-validation-guide.md +0 -275
- package/skills/connecting-datacloud/CREDITS.md +0 -5
- package/skills/connecting-datacloud/README.md +0 -59
- package/skills/connecting-datacloud/SKILL.md +0 -154
- package/skills/connecting-datacloud/examples/connections/heroku-postgres.json +0 -15
- package/skills/connecting-datacloud/examples/connections/ingest-api-connection.json +0 -5
- package/skills/connecting-datacloud/examples/connections/ingest-api-schema.json +0 -31
- package/skills/connecting-datacloud/examples/connections/redshift.json +0 -16
- package/skills/connecting-datacloud/examples/connections/sharepoint-unstructured.json +0 -20
- package/skills/connecting-datacloud/examples/connections/snowflake-connection.json +0 -42
- package/skills/creating-b2b-commerce-store/SKILL.md +0 -167
- package/skills/creating-b2b-commerce-store/references/store-vs-storefront.md +0 -169
- package/skills/debugging-apex-logs/CREDITS.md +0 -22
- package/skills/debugging-apex-logs/README.md +0 -74
- package/skills/debugging-apex-logs/SKILL.md +0 -171
- package/skills/debugging-apex-logs/assets/benchmarking-template.cls +0 -327
- package/skills/debugging-apex-logs/assets/cpu-heap-optimization.cls +0 -307
- package/skills/debugging-apex-logs/assets/dml-in-loop-fix.cls +0 -219
- package/skills/debugging-apex-logs/assets/null-pointer-fix.cls +0 -252
- package/skills/debugging-apex-logs/assets/soql-in-loop-fix.cls +0 -157
- package/skills/debugging-apex-logs/references/analysis-playbook.md +0 -53
- package/skills/debugging-apex-logs/references/benchmarking-guide.md +0 -287
- package/skills/debugging-apex-logs/references/cli-commands.md +0 -368
- package/skills/debugging-apex-logs/references/common-issues.md +0 -68
- package/skills/debugging-apex-logs/references/debug-log-reference.md +0 -328
- package/skills/debugging-apex-logs/references/log-analysis-tools.md +0 -248
- package/skills/debugging-apex-logs/references/scoring-rubric.md +0 -21
- package/skills/deploying-metadata/CREDITS.md +0 -25
- package/skills/deploying-metadata/README.md +0 -104
- package/skills/deploying-metadata/SKILL.md +0 -213
- package/skills/deploying-metadata/assets/destructiveChanges.xml +0 -143
- package/skills/deploying-metadata/assets/package.xml +0 -121
- package/skills/deploying-metadata/references/agent-deployment-guide.md +0 -628
- package/skills/deploying-metadata/references/deploy.sh +0 -73
- package/skills/deploying-metadata/references/deployment-report-template.md +0 -89
- package/skills/deploying-metadata/references/deployment-workflows.md +0 -395
- package/skills/deploying-metadata/references/orchestration.md +0 -183
- package/skills/deploying-metadata/references/trigger-deployment-safety.md +0 -376
- package/skills/deploying-omnistudio-datapacks/CREDITS.md +0 -5
- package/skills/deploying-omnistudio-datapacks/README.md +0 -88
- package/skills/deploying-omnistudio-datapacks/SKILL.md +0 -173
- package/skills/deploying-omnistudio-datapacks/examples/business-internet-plus-bundle/TRANSCRIPT.md +0 -124
- package/skills/deploying-omnistudio-datapacks/examples/business-internet-plus-bundle/deploy-business-internet-plus-bundle.yaml +0 -11
- package/skills/deploying-omnistudio-datapacks/examples/business-internet-plus-bundle-deploy/TRANSCRIPT.md +0 -142
- package/skills/deploying-omnistudio-datapacks/examples/business-internet-plus-bundle-deploy/deploy-business-internet-plus-bundle.yaml +0 -10
- package/skills/deploying-omnistudio-datapacks/references/job-file-template.md +0 -42
- package/skills/deploying-omnistudio-datapacks/references/troubleshooting-matrix.md +0 -24
- package/skills/deploying-ui-bundle/SKILL.md +0 -79
- package/skills/developing-agentforce/README.md +0 -112
- package/skills/developing-agentforce/SKILL.md +0 -518
- package/skills/developing-agentforce/assets/README-legacy.md +0 -89
- package/skills/developing-agentforce/assets/agent-spec-template.md +0 -90
- package/skills/developing-agentforce/assets/agents/README.md +0 -45
- package/skills/developing-agentforce/assets/agents/hello-world.agent +0 -60
- package/skills/developing-agentforce/assets/agents/multi-subagent.agent +0 -105
- package/skills/developing-agentforce/assets/agents/order-service.agent +0 -272
- package/skills/developing-agentforce/assets/agents/production-faq.agent +0 -101
- package/skills/developing-agentforce/assets/agents/production-faq.bundle-meta.xml +0 -4
- package/skills/developing-agentforce/assets/agents/simple-qa.agent +0 -72
- package/skills/developing-agentforce/assets/agents/verification-gate.agent +0 -280
- package/skills/developing-agentforce/assets/apex/models-api-queueable.cls +0 -225
- package/skills/developing-agentforce/assets/bundle-meta.xml +0 -23
- package/skills/developing-agentforce/assets/components/apex-action.agent +0 -52
- package/skills/developing-agentforce/assets/components/error-handling.agent +0 -58
- package/skills/developing-agentforce/assets/components/escalation-setup.agent +0 -169
- package/skills/developing-agentforce/assets/components/flow-action.agent +0 -66
- package/skills/developing-agentforce/assets/components/n-ary-conditions.agent +0 -110
- package/skills/developing-agentforce/assets/components/subagent-with-actions.agent +0 -40
- package/skills/developing-agentforce/assets/deterministic-routing.agent +0 -166
- package/skills/developing-agentforce/assets/escalation-pattern.agent +0 -209
- package/skills/developing-agentforce/assets/flow-action-lookup.agent +0 -115
- package/skills/developing-agentforce/assets/hub-and-spoke.agent +0 -104
- package/skills/developing-agentforce/assets/invocable-apex-template.cls +0 -187
- package/skills/developing-agentforce/assets/local-info-agent-annotated.agent +0 -355
- package/skills/developing-agentforce/assets/metadata/basic-prompt-template.promptTemplate-meta.xml +0 -109
- package/skills/developing-agentforce/assets/metadata/genai-function-apex.xml +0 -92
- package/skills/developing-agentforce/assets/metadata/genai-function-flow.xml +0 -57
- package/skills/developing-agentforce/assets/metadata/genai-plugin.xml +0 -72
- package/skills/developing-agentforce/assets/metadata/http-callout-flow.flow-meta.xml +0 -348
- package/skills/developing-agentforce/assets/metadata/record-grounded-prompt.promptTemplate-meta.xml +0 -136
- package/skills/developing-agentforce/assets/minimal-starter.agent +0 -42
- package/skills/developing-agentforce/assets/patterns/README.md +0 -254
- package/skills/developing-agentforce/assets/patterns/action-callbacks.agent +0 -178
- package/skills/developing-agentforce/assets/patterns/advanced-input-bindings.agent +0 -141
- package/skills/developing-agentforce/assets/patterns/bidirectional-routing.agent +0 -156
- package/skills/developing-agentforce/assets/patterns/critical-input-collection.agent +0 -244
- package/skills/developing-agentforce/assets/patterns/delegation-routing.agent +0 -89
- package/skills/developing-agentforce/assets/patterns/lifecycle-events.agent +0 -127
- package/skills/developing-agentforce/assets/patterns/llm-controlled-actions.agent +0 -184
- package/skills/developing-agentforce/assets/patterns/multi-step-workflow.agent +0 -282
- package/skills/developing-agentforce/assets/patterns/open-gate-routing.agent +0 -287
- package/skills/developing-agentforce/assets/patterns/procedural-instructions.agent +0 -273
- package/skills/developing-agentforce/assets/patterns/prompt-template-action.agent +0 -188
- package/skills/developing-agentforce/assets/patterns/system-instruction-overrides.agent +0 -293
- package/skills/developing-agentforce/assets/prompt-rag-search.agent +0 -131
- package/skills/developing-agentforce/assets/template-multi-subagent.agent +0 -160
- package/skills/developing-agentforce/assets/template-single-subagent.agent +0 -81
- package/skills/developing-agentforce/assets/verification-gate.agent +0 -208
- package/skills/developing-agentforce/references/action-prompt-templates.md +0 -164
- package/skills/developing-agentforce/references/actions-reference.md +0 -612
- package/skills/developing-agentforce/references/agent-access-guide.md +0 -72
- package/skills/developing-agentforce/references/agent-design-and-spec-creation.md +0 -1010
- package/skills/developing-agentforce/references/agent-metadata-and-lifecycle.md +0 -575
- package/skills/developing-agentforce/references/agent-script-core-language.md +0 -1255
- package/skills/developing-agentforce/references/agent-subagent-map-diagrams.md +0 -323
- package/skills/developing-agentforce/references/agent-user-setup.md +0 -529
- package/skills/developing-agentforce/references/agent-validation-and-debugging.md +0 -805
- package/skills/developing-agentforce/references/architecture-patterns.md +0 -158
- package/skills/developing-agentforce/references/complex-data-types.md +0 -57
- package/skills/developing-agentforce/references/deploy-reference.md +0 -134
- package/skills/developing-agentforce/references/discover-reference.md +0 -102
- package/skills/developing-agentforce/references/examples.md +0 -350
- package/skills/developing-agentforce/references/feature-validity.md +0 -43
- package/skills/developing-agentforce/references/instruction-resolution.md +0 -545
- package/skills/developing-agentforce/references/known-issues.md +0 -353
- package/skills/developing-agentforce/references/minimal-examples.md +0 -67
- package/skills/developing-agentforce/references/production-gotchas.md +0 -300
- package/skills/developing-agentforce/references/safety-review-reference.md +0 -145
- package/skills/developing-agentforce/references/salesforce-cli-for-agents.md +0 -395
- package/skills/developing-agentforce/references/scaffold-reference.md +0 -153
- package/skills/developing-agentforce/references/scoring-rubric.md +0 -24
- package/skills/developing-agentforce/references/version-history.md +0 -23
- package/skills/dx-app-analytics-use/SKILL.md +0 -135
- package/skills/fetching-salesforce-docs/README.md +0 -66
- package/skills/fetching-salesforce-docs/SKILL.md +0 -208
- package/skills/fetching-salesforce-docs/requirements.txt +0 -2
- package/skills/fetching-salesforce-docs/scripts/extract_help_salesforce.py +0 -497
- package/skills/fetching-salesforce-docs/scripts/extract_salesforce_doc.py +0 -357
- package/skills/fetching-salesforce-docs/scripts/runtime_bootstrap.py +0 -58
- package/skills/generating-apex/CREDITS.md +0 -5
- package/skills/generating-apex/SKILL.md +0 -409
- package/skills/generating-apex/assets/abstract.cls +0 -131
- package/skills/generating-apex/assets/batch.cls +0 -124
- package/skills/generating-apex/assets/domain.cls +0 -101
- package/skills/generating-apex/assets/dto.cls +0 -107
- package/skills/generating-apex/assets/exception.cls +0 -50
- package/skills/generating-apex/assets/interface.cls +0 -24
- package/skills/generating-apex/assets/invocable.cls +0 -114
- package/skills/generating-apex/assets/queueable.cls +0 -91
- package/skills/generating-apex/assets/rest-resource.cls +0 -300
- package/skills/generating-apex/assets/schedulable.cls +0 -74
- package/skills/generating-apex/assets/selector.cls +0 -91
- package/skills/generating-apex/assets/service.cls +0 -68
- package/skills/generating-apex/assets/trigger.cls +0 -45
- package/skills/generating-apex/assets/utility.cls +0 -96
- package/skills/generating-apex/references/AccountDeduplicationBatch.cls +0 -147
- package/skills/generating-apex/references/AccountSelector.cls +0 -192
- package/skills/generating-apex/references/AccountService.cls +0 -200
- package/skills/generating-apex-test/CREDITS.md +0 -5
- package/skills/generating-apex-test/SKILL.md +0 -201
- package/skills/generating-apex-test/assets/test-class-template.cls +0 -93
- package/skills/generating-apex-test/assets/test-data-factory-template.cls +0 -111
- package/skills/generating-apex-test/references/assertion-patterns.md +0 -108
- package/skills/generating-apex-test/references/async-testing.md +0 -193
- package/skills/generating-apex-test/references/mocking-patterns.md +0 -220
- package/skills/generating-apex-test/references/test-data-factory.md +0 -75
- package/skills/generating-custom-application/SKILL.md +0 -211
- package/skills/generating-custom-field/SKILL.md +0 -503
- package/skills/generating-custom-lightning-type/SKILL.md +0 -180
- package/skills/generating-custom-lightning-type/assets/primitive-types-and-constraints.md +0 -41
- package/skills/generating-custom-lightning-type/references/widget-rendition.md +0 -124
- package/skills/generating-custom-object/SKILL.md +0 -240
- package/skills/generating-custom-tab/SKILL.md +0 -156
- package/skills/generating-flexipage/SKILL.md +0 -522
- package/skills/generating-flow/SKILL.md +0 -372
- package/skills/generating-lightning-app/SKILL.md +0 -423
- package/skills/generating-list-view/SKILL.md +0 -218
- package/skills/generating-lwc-components/CREDITS.md +0 -5
- package/skills/generating-lwc-components/README.md +0 -126
- package/skills/generating-lwc-components/SKILL.md +0 -190
- package/skills/generating-lwc-components/assets/apex-controller/LwcController.cls +0 -327
- package/skills/generating-lwc-components/assets/basic-component/basicComponent.css +0 -72
- package/skills/generating-lwc-components/assets/basic-component/basicComponent.html +0 -111
- package/skills/generating-lwc-components/assets/basic-component/basicComponent.js +0 -163
- package/skills/generating-lwc-components/assets/basic-component/basicComponent.js-meta.xml +0 -137
- package/skills/generating-lwc-components/assets/datatable-component/datatableComponent.html +0 -111
- package/skills/generating-lwc-components/assets/datatable-component/datatableComponent.js +0 -367
- package/skills/generating-lwc-components/assets/flow-screen-component/flowScreenComponent.css +0 -63
- package/skills/generating-lwc-components/assets/flow-screen-component/flowScreenComponent.html +0 -154
- package/skills/generating-lwc-components/assets/flow-screen-component/flowScreenComponent.js +0 -348
- package/skills/generating-lwc-components/assets/flow-screen-component/flowScreenComponent.js-meta.xml +0 -87
- package/skills/generating-lwc-components/assets/form-component/formComponent.html +0 -165
- package/skills/generating-lwc-components/assets/form-component/formComponent.js +0 -275
- package/skills/generating-lwc-components/assets/graphql-component/graphqlComponent.html +0 -100
- package/skills/generating-lwc-components/assets/graphql-component/graphqlComponent.js +0 -336
- package/skills/generating-lwc-components/assets/jest-test/componentName.test.js.example +0 -371
- package/skills/generating-lwc-components/assets/message-channel/RecordSelected.messageChannel-meta.xml +0 -71
- package/skills/generating-lwc-components/assets/message-channel/lmsPublisher.js +0 -103
- package/skills/generating-lwc-components/assets/message-channel/lmsSubscriber.js +0 -181
- package/skills/generating-lwc-components/assets/modal-component/modalComponent.html +0 -85
- package/skills/generating-lwc-components/assets/modal-component/modalComponent.js +0 -199
- package/skills/generating-lwc-components/assets/record-picker/recordPicker.html +0 -55
- package/skills/generating-lwc-components/assets/record-picker/recordPicker.js +0 -199
- package/skills/generating-lwc-components/assets/state-store/store.js +0 -282
- package/skills/generating-lwc-components/assets/typescript-component/typescriptComponent.css +0 -65
- package/skills/generating-lwc-components/assets/typescript-component/typescriptComponent.html +0 -95
- package/skills/generating-lwc-components/assets/typescript-component/typescriptComponent.js-meta.xml +0 -75
- package/skills/generating-lwc-components/assets/typescript-component/typescriptComponent.test.ts.example +0 -301
- package/skills/generating-lwc-components/assets/typescript-component/typescriptComponent.ts +0 -295
- package/skills/generating-lwc-components/assets/workspace-api/workspaceComponent.html +0 -71
- package/skills/generating-lwc-components/assets/workspace-api/workspaceComponent.js +0 -316
- package/skills/generating-lwc-components/hooks/scripts/lwc-lsp-validate.py +0 -295
- package/skills/generating-lwc-components/hooks/scripts/post-tool-validate.py +0 -347
- package/skills/generating-lwc-components/hooks/scripts/slds_data/deprecated_patterns.json +0 -74
- package/skills/generating-lwc-components/hooks/scripts/slds_data/styling_hooks.json +0 -111
- package/skills/generating-lwc-components/hooks/scripts/slds_data/valid_slds_classes.json +0 -127
- package/skills/generating-lwc-components/hooks/scripts/slds_linter_wrapper.py +0 -294
- package/skills/generating-lwc-components/hooks/scripts/slds_rules/__init__.py +0 -22
- package/skills/generating-lwc-components/hooks/scripts/template_validator.py +0 -332
- package/skills/generating-lwc-components/hooks/scripts/validate_slds.py +0 -595
- package/skills/generating-lwc-components/references/accessibility-guide.md +0 -843
- package/skills/generating-lwc-components/references/advanced-features.md +0 -108
- package/skills/generating-lwc-components/references/async-notification-patterns.md +0 -661
- package/skills/generating-lwc-components/references/cli-commands.md +0 -545
- package/skills/generating-lwc-components/references/component-patterns.md +0 -1476
- package/skills/generating-lwc-components/references/flow-integration-guide.md +0 -675
- package/skills/generating-lwc-components/references/jest-testing.md +0 -1011
- package/skills/generating-lwc-components/references/lms-guide.md +0 -860
- package/skills/generating-lwc-components/references/lwc-best-practices.md +0 -1310
- package/skills/generating-lwc-components/references/performance-guide.md +0 -861
- package/skills/generating-lwc-components/references/scoring-and-testing.md +0 -116
- package/skills/generating-lwc-components/references/slds-blueprints.json +0 -14389
- package/skills/generating-lwc-components/references/slds-design-guide.md +0 -166
- package/skills/generating-lwc-components/references/state-management.md +0 -642
- package/skills/generating-lwc-components/references/template-anti-patterns.md +0 -948
- package/skills/generating-lwc-components/references/triangle-pattern.md +0 -365
- package/skills/generating-lwc-components/scripts/local-dev-preview.sh +0 -34
- package/skills/generating-mermaid-diagrams/CREDITS.md +0 -46
- package/skills/generating-mermaid-diagrams/README.md +0 -114
- package/skills/generating-mermaid-diagrams/SKILL.md +0 -217
- package/skills/generating-mermaid-diagrams/assets/agentforce/agent-flow.md +0 -313
- package/skills/generating-mermaid-diagrams/assets/architecture/system-landscape.md +0 -351
- package/skills/generating-mermaid-diagrams/assets/datamodel/b2b-commerce-erd.md +0 -317
- package/skills/generating-mermaid-diagrams/assets/datamodel/campaigns-erd.md +0 -195
- package/skills/generating-mermaid-diagrams/assets/datamodel/consent-erd.md +0 -262
- package/skills/generating-mermaid-diagrams/assets/datamodel/files-erd.md +0 -266
- package/skills/generating-mermaid-diagrams/assets/datamodel/forecasting-erd.md +0 -261
- package/skills/generating-mermaid-diagrams/assets/datamodel/fsl-erd.md +0 -332
- package/skills/generating-mermaid-diagrams/assets/datamodel/party-model-erd.md +0 -237
- package/skills/generating-mermaid-diagrams/assets/datamodel/quote-order-erd.md +0 -277
- package/skills/generating-mermaid-diagrams/assets/datamodel/revenue-cloud-erd.md +0 -343
- package/skills/generating-mermaid-diagrams/assets/datamodel/sales-cloud-erd.md +0 -192
- package/skills/generating-mermaid-diagrams/assets/datamodel/salesforce-erd.md +0 -209
- package/skills/generating-mermaid-diagrams/assets/datamodel/scheduler-erd.md +0 -276
- package/skills/generating-mermaid-diagrams/assets/datamodel/service-cloud-erd.md +0 -217
- package/skills/generating-mermaid-diagrams/assets/datamodel/territory-management-erd.md +0 -241
- package/skills/generating-mermaid-diagrams/assets/integration/api-sequence.md +0 -387
- package/skills/generating-mermaid-diagrams/assets/oauth/authorization-code-pkce.md +0 -197
- package/skills/generating-mermaid-diagrams/assets/oauth/authorization-code.md +0 -152
- package/skills/generating-mermaid-diagrams/assets/oauth/client-credentials.md +0 -233
- package/skills/generating-mermaid-diagrams/assets/oauth/device-authorization.md +0 -295
- package/skills/generating-mermaid-diagrams/assets/oauth/jwt-bearer.md +0 -256
- package/skills/generating-mermaid-diagrams/assets/oauth/refresh-token.md +0 -281
- package/skills/generating-mermaid-diagrams/assets/oauth/user-agent-social-sign-on.md +0 -281
- package/skills/generating-mermaid-diagrams/assets/role-hierarchy/user-hierarchy.md +0 -322
- package/skills/generating-mermaid-diagrams/references/color-palette.md +0 -464
- package/skills/generating-mermaid-diagrams/references/diagram-conventions.md +0 -313
- package/skills/generating-mermaid-diagrams/references/erd-conventions.md +0 -320
- package/skills/generating-mermaid-diagrams/references/mermaid-reference.md +0 -434
- package/skills/generating-mermaid-diagrams/references/mermaid-styling.md +0 -81
- package/skills/generating-mermaid-diagrams/references/preview-guide.md +0 -46
- package/skills/generating-mermaid-diagrams/references/usage-examples.md +0 -340
- package/skills/generating-mermaid-diagrams/scripts/README.md +0 -160
- package/skills/generating-mermaid-diagrams/scripts/mermaid_preview.py +0 -654
- package/skills/generating-mermaid-diagrams/scripts/query-org-metadata.py +0 -293
- package/skills/generating-permission-set/SKILL.md +0 -189
- package/skills/generating-ui-bundle-custom-app/SKILL.md +0 -93
- package/skills/generating-ui-bundle-custom-app/docs/configure-metadata-custom-application.md +0 -70
- package/skills/generating-ui-bundle-features/SKILL.md +0 -47
- package/skills/generating-ui-bundle-metadata/SKILL.md +0 -153
- package/skills/generating-ui-bundle-metadata/implementation/csp-metadata-format.md +0 -281
- package/skills/generating-ui-bundle-site/SKILL.md +0 -92
- package/skills/generating-ui-bundle-site/docs/configure-metadata-custom-site.md +0 -41
- package/skills/generating-ui-bundle-site/docs/configure-metadata-digital-experience-bundle.md +0 -17
- package/skills/generating-ui-bundle-site/docs/configure-metadata-digital-experience-config.md +0 -21
- package/skills/generating-ui-bundle-site/docs/configure-metadata-digital-experience.md +0 -40
- package/skills/generating-ui-bundle-site/docs/configure-metadata-network.md +0 -72
- package/skills/generating-ui-bundle-site/docs/update-site-urls.md +0 -100
- package/skills/generating-validation-rule/SKILL.md +0 -74
- package/skills/generating-visual-diagrams/CREDITS.md +0 -80
- package/skills/generating-visual-diagrams/README.md +0 -83
- package/skills/generating-visual-diagrams/SKILL.md +0 -207
- package/skills/generating-visual-diagrams/assets/architecture/integration-flow.md +0 -55
- package/skills/generating-visual-diagrams/assets/erd/core-objects.md +0 -131
- package/skills/generating-visual-diagrams/assets/erd/custom-objects.md +0 -60
- package/skills/generating-visual-diagrams/assets/lwc/dashboard-card.md +0 -45
- package/skills/generating-visual-diagrams/assets/lwc/data-table.md +0 -57
- package/skills/generating-visual-diagrams/assets/lwc/record-form.md +0 -60
- package/skills/generating-visual-diagrams/assets/review/apex-review.md +0 -57
- package/skills/generating-visual-diagrams/assets/review/lwc-review.md +0 -48
- package/skills/generating-visual-diagrams/references/architect-aesthetic-guide.md +0 -257
- package/skills/generating-visual-diagrams/references/examples-index.md +0 -35
- package/skills/generating-visual-diagrams/references/gemini-cli-setup.md +0 -65
- package/skills/generating-visual-diagrams/references/interview-questions.md +0 -529
- package/skills/generating-visual-diagrams/references/iteration-workflow.md +0 -173
- package/skills/generating-visual-diagrams/scripts/check-prerequisites.sh +0 -101
- package/skills/generating-visual-diagrams/scripts/generate_image.py +0 -243
- package/skills/getting-metadata-api-context/README.md +0 -79
- package/skills/getting-metadata-api-context/SKILL.md +0 -466
- package/skills/getting-metadata-api-context/data/metadata_api/AIApplication.json +0 -37
- package/skills/getting-metadata-api-context/data/metadata_api/AIApplicationConfig.json +0 -53
- package/skills/getting-metadata-api-context/data/metadata_api/AIReplyRecommendationsSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/AIScoringModelDefinition.json +0 -87
- package/skills/getting-metadata-api-context/data/metadata_api/AIUsecaseDefinition.json +0 -215
- package/skills/getting-metadata-api-context/data/metadata_api/AccountInsightsSettings.json +0 -30
- package/skills/getting-metadata-api-context/data/metadata_api/AccountIntelligenceSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/AccountPlanObjMeasCalcDef.json +0 -86
- package/skills/getting-metadata-api-context/data/metadata_api/AccountPlanSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/AccountRelationshipShareRule.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/AccountSettings.json +0 -64
- package/skills/getting-metadata-api-context/data/metadata_api/AccountingFieldMapping.json +0 -70
- package/skills/getting-metadata-api-context/data/metadata_api/AccountingModelConfig.json +0 -94
- package/skills/getting-metadata-api-context/data/metadata_api/AccountingSettings.json +0 -53
- package/skills/getting-metadata-api-context/data/metadata_api/ActionLinkGroupTemplate.json +0 -118
- package/skills/getting-metadata-api-context/data/metadata_api/ActionOverride.json +0 -70
- package/skills/getting-metadata-api-context/data/metadata_api/ActionPlanTemplate.json +0 -166
- package/skills/getting-metadata-api-context/data/metadata_api/ActionableListDefinition.json +0 -114
- package/skills/getting-metadata-api-context/data/metadata_api/ActionsSettings.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/ActivationPlatform.json +0 -95
- package/skills/getting-metadata-api-context/data/metadata_api/ActivationPlatformActvAttr.json +0 -8
- package/skills/getting-metadata-api-context/data/metadata_api/ActivationPlatformField.json +0 -55
- package/skills/getting-metadata-api-context/data/metadata_api/ActivitiesSettings.json +0 -136
- package/skills/getting-metadata-api-context/data/metadata_api/ActvPfrmDataConnectorS3.json +0 -41
- package/skills/getting-metadata-api-context/data/metadata_api/ActvPlatformAdncIdentifier.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/ActvPlatformFieldValue.json +0 -50
- package/skills/getting-metadata-api-context/data/metadata_api/AddressSettings.json +0 -90
- package/skills/getting-metadata-api-context/data/metadata_api/AdvAccountForecastSet.json +0 -261
- package/skills/getting-metadata-api-context/data/metadata_api/AffinityScoreDefinition.json +0 -74
- package/skills/getting-metadata-api-context/data/metadata_api/AgentPlatformSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/AgentforceForDevelopersSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/AiAuthoringBundle.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/AiEvaluationDefinition.json +0 -153
- package/skills/getting-metadata-api-context/data/metadata_api/AiPluginUtteranceDef.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/AllOrNoneHeader.json +0 -17
- package/skills/getting-metadata-api-context/data/metadata_api/AnalyticSnapshot.json +0 -80
- package/skills/getting-metadata-api-context/data/metadata_api/AnalyticsDashboard.json +0 -369
- package/skills/getting-metadata-api-context/data/metadata_api/AnalyticsSettings.json +0 -488
- package/skills/getting-metadata-api-context/data/metadata_api/AnalyticsVisualization.json +0 -180
- package/skills/getting-metadata-api-context/data/metadata_api/AnalyticsWorkspace.json +0 -71
- package/skills/getting-metadata-api-context/data/metadata_api/AnimationRule.json +0 -71
- package/skills/getting-metadata-api-context/data/metadata_api/ApexClass.json +0 -70
- package/skills/getting-metadata-api-context/data/metadata_api/ApexComponent.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/ApexEmailNotifications.json +0 -49
- package/skills/getting-metadata-api-context/data/metadata_api/ApexPage.json +0 -64
- package/skills/getting-metadata-api-context/data/metadata_api/ApexSettings.json +0 -96
- package/skills/getting-metadata-api-context/data/metadata_api/ApexTestSuite.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/ApexTrigger.json +0 -52
- package/skills/getting-metadata-api-context/data/metadata_api/AppAnalyticsSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/AppExperienceSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/AppFrameworkTemplateBundle.json +0 -52
- package/skills/getting-metadata-api-context/data/metadata_api/AppMenu.json +0 -10
- package/skills/getting-metadata-api-context/data/metadata_api/AppointmentAssignmentPolicy.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/AppointmentSchedulingPolicy.json +0 -102
- package/skills/getting-metadata-api-context/data/metadata_api/ApprovalProcess.json +0 -234
- package/skills/getting-metadata-api-context/data/metadata_api/ArticleType.json +0 -81
- package/skills/getting-metadata-api-context/data/metadata_api/ArticleType_CustomField.json +0 -88
- package/skills/getting-metadata-api-context/data/metadata_api/ArticleType_Layout.json +0 -63
- package/skills/getting-metadata-api-context/data/metadata_api/AssessmentQuestion.json +0 -117
- package/skills/getting-metadata-api-context/data/metadata_api/AssessmentQuestionSet.json +0 -41
- package/skills/getting-metadata-api-context/data/metadata_api/AssignmentRules.json +0 -87
- package/skills/getting-metadata-api-context/data/metadata_api/AssociationEngineSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/AsyncResult.json +0 -89
- package/skills/getting-metadata-api-context/data/metadata_api/Audience.json +0 -172
- package/skills/getting-metadata-api-context/data/metadata_api/AuraDefinitionBundle.json +0 -94
- package/skills/getting-metadata-api-context/data/metadata_api/AuthProvider.json +0 -169
- package/skills/getting-metadata-api-context/data/metadata_api/AutoResponseRules.json +0 -79
- package/skills/getting-metadata-api-context/data/metadata_api/AutomatedContactsSettings.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/BaseSharingRule.json +0 -24
- package/skills/getting-metadata-api-context/data/metadata_api/BatchCalcJobDefinition.json +0 -849
- package/skills/getting-metadata-api-context/data/metadata_api/BatchProcessJobDefinition.json +0 -175
- package/skills/getting-metadata-api-context/data/metadata_api/BillingSettings.json +0 -152
- package/skills/getting-metadata-api-context/data/metadata_api/BlacklistedConsumer.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/Bot.json +0 -197
- package/skills/getting-metadata-api-context/data/metadata_api/BotBlock.json +0 -86
- package/skills/getting-metadata-api-context/data/metadata_api/BotSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/BotTemplate.json +0 -96
- package/skills/getting-metadata-api-context/data/metadata_api/BotVersion.json +0 -667
- package/skills/getting-metadata-api-context/data/metadata_api/BranchManagementSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/BrandingSet.json +0 -146
- package/skills/getting-metadata-api-context/data/metadata_api/BriefcaseDefinition.json +0 -127
- package/skills/getting-metadata-api-context/data/metadata_api/BusinessHoursSettings.json +0 -175
- package/skills/getting-metadata-api-context/data/metadata_api/BusinessProcess.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/BusinessProcessGroup.json +0 -91
- package/skills/getting-metadata-api-context/data/metadata_api/CMSConnectSource.json +0 -197
- package/skills/getting-metadata-api-context/data/metadata_api/CallCenter.json +0 -124
- package/skills/getting-metadata-api-context/data/metadata_api/CallCenterRoutingMap.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/CallCoachingMediaProvider.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/CallOptions.json +0 -17
- package/skills/getting-metadata-api-context/data/metadata_api/CampaignInfluenceModel.json +0 -59
- package/skills/getting-metadata-api-context/data/metadata_api/CampaignSettings.json +0 -71
- package/skills/getting-metadata-api-context/data/metadata_api/CancelDeployResult.json +0 -10
- package/skills/getting-metadata-api-context/data/metadata_api/CareBenefitVerifySettings.json +0 -70
- package/skills/getting-metadata-api-context/data/metadata_api/CareLimitType.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/CareProviderSearchConfig.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/CareRequestConfiguration.json +0 -57
- package/skills/getting-metadata-api-context/data/metadata_api/CareSystemFieldMapping.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/CaseSettings.json +0 -423
- package/skills/getting-metadata-api-context/data/metadata_api/CaseSubjectParticle.json +0 -35
- package/skills/getting-metadata-api-context/data/metadata_api/CatalogedApi.json +0 -97
- package/skills/getting-metadata-api-context/data/metadata_api/CatalogedApiArtifactVersionInfo.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/CatalogedApiVersion.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/Certificate.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/ChannelLayout.json +0 -63
- package/skills/getting-metadata-api-context/data/metadata_api/ChatterAnswersSettings.json +0 -76
- package/skills/getting-metadata-api-context/data/metadata_api/ChatterEmailsMDSettings.json +0 -68
- package/skills/getting-metadata-api-context/data/metadata_api/ChatterExtension.json +0 -64
- package/skills/getting-metadata-api-context/data/metadata_api/ChatterSettings.json +0 -92
- package/skills/getting-metadata-api-context/data/metadata_api/ChoiceList.json +0 -66
- package/skills/getting-metadata-api-context/data/metadata_api/ClaimFinancialSettings.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/ClauseCatgConfiguration.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/CleanDataService.json +0 -166
- package/skills/getting-metadata-api-context/data/metadata_api/CodeBuilderSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/CollectionsDashboardSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/CommerceSettings.json +0 -80
- package/skills/getting-metadata-api-context/data/metadata_api/CommunitiesSettings.json +0 -116
- package/skills/getting-metadata-api-context/data/metadata_api/Community.json +0 -121
- package/skills/getting-metadata-api-context/data/metadata_api/CommunityTemplateDefinition.json +0 -116
- package/skills/getting-metadata-api-context/data/metadata_api/CommunityThemeDefinition.json +0 -146
- package/skills/getting-metadata-api-context/data/metadata_api/CompactLayout.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/CompanySettings.json +0 -49
- package/skills/getting-metadata-api-context/data/metadata_api/ConnectedApp.json +0 -384
- package/skills/getting-metadata-api-context/data/metadata_api/ConnectedAppSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/ContentAsset.json +0 -121
- package/skills/getting-metadata-api-context/data/metadata_api/ContentSettings.json +0 -116
- package/skills/getting-metadata-api-context/data/metadata_api/ContentTypeBundle.json +0 -64
- package/skills/getting-metadata-api-context/data/metadata_api/ContextDefinition.json +0 -340
- package/skills/getting-metadata-api-context/data/metadata_api/ContractSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/ConvIntelligenceSignalRule.json +0 -106
- package/skills/getting-metadata-api-context/data/metadata_api/ConversationChannelDefinition.json +0 -140
- package/skills/getting-metadata-api-context/data/metadata_api/ConversationMessageDefinition.json +0 -380
- package/skills/getting-metadata-api-context/data/metadata_api/ConversationMessageDefinitionTranslation.json +0 -49
- package/skills/getting-metadata-api-context/data/metadata_api/ConversationVendorInfo.json +0 -148
- package/skills/getting-metadata-api-context/data/metadata_api/ConversationalIntelligenceSettings.json +0 -76
- package/skills/getting-metadata-api-context/data/metadata_api/CorsWhitelistOrigin.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/CriteriaBasedSharingRule.json +0 -206
- package/skills/getting-metadata-api-context/data/metadata_api/CspTrustedSite.json +0 -82
- package/skills/getting-metadata-api-context/data/metadata_api/CurrencySettings.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/CustomAddressFieldSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/CustomApplication.json +0 -453
- package/skills/getting-metadata-api-context/data/metadata_api/CustomApplicationComponent.json +0 -72
- package/skills/getting-metadata-api-context/data/metadata_api/CustomFeedFilter.json +0 -63
- package/skills/getting-metadata-api-context/data/metadata_api/CustomField.json +0 -392
- package/skills/getting-metadata-api-context/data/metadata_api/CustomFieldDisplay.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/CustomHelpMenuSection.json +0 -57
- package/skills/getting-metadata-api-context/data/metadata_api/CustomIndex.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/CustomLabels.json +0 -69
- package/skills/getting-metadata-api-context/data/metadata_api/CustomMetadata.json +0 -90
- package/skills/getting-metadata-api-context/data/metadata_api/CustomNotificationType.json +0 -94
- package/skills/getting-metadata-api-context/data/metadata_api/CustomObject.json +0 -313
- package/skills/getting-metadata-api-context/data/metadata_api/CustomObjectTranslation.json +0 -319
- package/skills/getting-metadata-api-context/data/metadata_api/CustomPageWebLink.json +0 -121
- package/skills/getting-metadata-api-context/data/metadata_api/CustomPermission.json +0 -65
- package/skills/getting-metadata-api-context/data/metadata_api/CustomSite.json +0 -288
- package/skills/getting-metadata-api-context/data/metadata_api/CustomTab.json +0 -97
- package/skills/getting-metadata-api-context/data/metadata_api/CustomValue.json +0 -85
- package/skills/getting-metadata-api-context/data/metadata_api/CustomerDataPlatformSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/Dashboard.json +0 -584
- package/skills/getting-metadata-api-context/data/metadata_api/DataCategoryGroup.json +0 -81
- package/skills/getting-metadata-api-context/data/metadata_api/DataConnector.json +0 -230
- package/skills/getting-metadata-api-context/data/metadata_api/DataConnectorIngestApi.json +0 -41
- package/skills/getting-metadata-api-context/data/metadata_api/DataConnectorS3.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/DataDotComSettings.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/DataImportManagementSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/DataKitObjectDependency.json +0 -49
- package/skills/getting-metadata-api-context/data/metadata_api/DataKitObjectTemplate.json +0 -59
- package/skills/getting-metadata-api-context/data/metadata_api/DataObjectBuildOrgTemplate.json +0 -61
- package/skills/getting-metadata-api-context/data/metadata_api/DataObjectSearchIndexConf.json +0 -62
- package/skills/getting-metadata-api-context/data/metadata_api/DataPackageKitDefinition.json +0 -74
- package/skills/getting-metadata-api-context/data/metadata_api/DataPackageKitObject.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/DataSource.json +0 -29
- package/skills/getting-metadata-api-context/data/metadata_api/DataSourceBundleDefinition.json +0 -57
- package/skills/getting-metadata-api-context/data/metadata_api/DataSourceField.json +0 -115
- package/skills/getting-metadata-api-context/data/metadata_api/DataSourceObject.json +0 -93
- package/skills/getting-metadata-api-context/data/metadata_api/DataSourceTenant.json +0 -8
- package/skills/getting-metadata-api-context/data/metadata_api/DataSrcDataModelFieldMap.json +0 -69
- package/skills/getting-metadata-api-context/data/metadata_api/DataStreamDefinition.json +0 -105
- package/skills/getting-metadata-api-context/data/metadata_api/DataStreamTemplate.json +0 -99
- package/skills/getting-metadata-api-context/data/metadata_api/DataWeaveResource.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/DebuggingHeader.json +0 -20
- package/skills/getting-metadata-api-context/data/metadata_api/DecisionMatrixDefinition.json +0 -140
- package/skills/getting-metadata-api-context/data/metadata_api/DecisionTable.json +0 -211
- package/skills/getting-metadata-api-context/data/metadata_api/DecisionTableDatasetLink.json +0 -72
- package/skills/getting-metadata-api-context/data/metadata_api/DelegateGroup.json +0 -62
- package/skills/getting-metadata-api-context/data/metadata_api/DeleteResult.json +0 -22
- package/skills/getting-metadata-api-context/data/metadata_api/DeployResult.json +0 -253
- package/skills/getting-metadata-api-context/data/metadata_api/DeploymentSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/DescribeMetadataResult.json +0 -31
- package/skills/getting-metadata-api-context/data/metadata_api/DescribeValueTypeResult.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/DevHubSettings.json +0 -60
- package/skills/getting-metadata-api-context/data/metadata_api/DgtAssetMgmtProvider.json +0 -43
- package/skills/getting-metadata-api-context/data/metadata_api/DgtAssetMgmtPrvdLghtCpnt.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/DigitalExperienceBundle.json +0 -102
- package/skills/getting-metadata-api-context/data/metadata_api/DigitalExperienceBundle_Marketing_Workspace_Bundle_and_Folders.json +0 -8
- package/skills/getting-metadata-api-context/data/metadata_api/DigitalExperienceBundle_Site_Workspace_Bundle_and_Folders.json +0 -541
- package/skills/getting-metadata-api-context/data/metadata_api/DigitalExperienceConfig.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/DisclosureDefinition.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/DisclosureDefinitionVersion.json +0 -78
- package/skills/getting-metadata-api-context/data/metadata_api/DisclosureType.json +0 -53
- package/skills/getting-metadata-api-context/data/metadata_api/DiscoveryAIModel.json +0 -263
- package/skills/getting-metadata-api-context/data/metadata_api/DiscoveryGoal.json +0 -361
- package/skills/getting-metadata-api-context/data/metadata_api/DiscoveryStory.json +0 -98
- package/skills/getting-metadata-api-context/data/metadata_api/Document.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/DocumentCategory.json +0 -42
- package/skills/getting-metadata-api-context/data/metadata_api/DocumentCategoryDocumentType.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/DocumentChecklistSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/DocumentGenerationSetting.json +0 -60
- package/skills/getting-metadata-api-context/data/metadata_api/DocumentType.json +0 -43
- package/skills/getting-metadata-api-context/data/metadata_api/DuplicateRule.json +0 -160
- package/skills/getting-metadata-api-context/data/metadata_api/DynamicFormsSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/EACSettings.json +0 -112
- package/skills/getting-metadata-api-context/data/metadata_api/EclairGeoData.json +0 -73
- package/skills/getting-metadata-api-context/data/metadata_api/EinsteinAISettings.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/EinsteinAgentSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/EinsteinGptSettings.json +0 -64
- package/skills/getting-metadata-api-context/data/metadata_api/EmailAdministrationSettings.json +0 -104
- package/skills/getting-metadata-api-context/data/metadata_api/EmailAuthorizationSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/EmailIntegrationSettings.json +0 -92
- package/skills/getting-metadata-api-context/data/metadata_api/EmailServicesFunction.json +0 -116
- package/skills/getting-metadata-api-context/data/metadata_api/EmailTemplate.json +0 -116
- package/skills/getting-metadata-api-context/data/metadata_api/EmailTemplateSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/EmbeddedServiceBranding.json +0 -78
- package/skills/getting-metadata-api-context/data/metadata_api/EmbeddedServiceConfig.json +0 -318
- package/skills/getting-metadata-api-context/data/metadata_api/EmbeddedServiceFieldService.json +0 -73
- package/skills/getting-metadata-api-context/data/metadata_api/EmbeddedServiceFlowConfig.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/EmbeddedServiceLiveAgent.json +0 -141
- package/skills/getting-metadata-api-context/data/metadata_api/EmbeddedServiceMenuSettings.json +0 -165
- package/skills/getting-metadata-api-context/data/metadata_api/EmployeeUserSettings.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/EnablementMeasureDefinition.json +0 -139
- package/skills/getting-metadata-api-context/data/metadata_api/EnablementProgramDefinition.json +0 -241
- package/skills/getting-metadata-api-context/data/metadata_api/EnblProgramTaskSubCategory.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/EncryptionKeySettings.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/EnhancedNotesSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/EntitlementProcess.json +0 -147
- package/skills/getting-metadata-api-context/data/metadata_api/EntitlementSettings.json +0 -80
- package/skills/getting-metadata-api-context/data/metadata_api/EntitlementTemplate.json +0 -52
- package/skills/getting-metadata-api-context/data/metadata_api/Error.json +0 -25
- package/skills/getting-metadata-api-context/data/metadata_api/EscalationRules.json +0 -117
- package/skills/getting-metadata-api-context/data/metadata_api/EventDelivery.json +0 -57
- package/skills/getting-metadata-api-context/data/metadata_api/EventRelayConfig.json +0 -55
- package/skills/getting-metadata-api-context/data/metadata_api/EventSettings.json +0 -76
- package/skills/getting-metadata-api-context/data/metadata_api/EventSubscription.json +0 -62
- package/skills/getting-metadata-api-context/data/metadata_api/ExperienceBundle.json +0 -387
- package/skills/getting-metadata-api-context/data/metadata_api/ExperienceBundleSettings.json +0 -25
- package/skills/getting-metadata-api-context/data/metadata_api/ExperiencePropertyTypeBundle.json +0 -68
- package/skills/getting-metadata-api-context/data/metadata_api/ExplainabilityMsgTemplate.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/ExpressionSetDefinition.json +0 -496
- package/skills/getting-metadata-api-context/data/metadata_api/ExpressionSetMessageToken.json +0 -42
- package/skills/getting-metadata-api-context/data/metadata_api/ExpressionSetObjectAlias.json +0 -61
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalAIModel.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalAuthIdentityProvider.json +0 -79
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalClientAppSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalClientApplication.json +0 -72
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalCredential.json +0 -94
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalDataConnector.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalDataSource.json +0 -162
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalDataTranObject.json +0 -191
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalDataTransportFieldTemplate.json +0 -8
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalDataTransportObjectTemplate.json +0 -8
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalServiceRegistration.json +0 -121
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalServicesSettings.json +0 -34
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppCanvasSettings.json +0 -63
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppConfigurablePolicies.json +0 -75
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppGlobalOauthSettings.json +0 -135
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppMobileConfigurablePolicies.json +0 -34
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppMobileSettings.json +0 -35
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppNotificationSettings.json +0 -49
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppOauthConfigurablePolicies.json +0 -153
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppOauthSettings.json +0 -120
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppPushConfigurablePolicies.json +0 -35
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppPushSettings.json +0 -93
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppSamlConfigurablePolicies.json +0 -119
- package/skills/getting-metadata-api-context/data/metadata_api/FeatureParameterBoolean.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/FeatureParameterDate.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/FeatureParameterInteger.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/FieldMappingConfig.json +0 -43
- package/skills/getting-metadata-api-context/data/metadata_api/FieldRestrictionRule.json +0 -80
- package/skills/getting-metadata-api-context/data/metadata_api/FieldServiceSettings.json +0 -226
- package/skills/getting-metadata-api-context/data/metadata_api/FieldSet.json +0 -60
- package/skills/getting-metadata-api-context/data/metadata_api/FieldSrcTrgtRelationship.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/FileUploadAndDownloadSecuritySettings.json +0 -53
- package/skills/getting-metadata-api-context/data/metadata_api/FilesConnectSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/FlexiPage.json +0 -355
- package/skills/getting-metadata-api-context/data/metadata_api/Flow.json +0 -2377
- package/skills/getting-metadata-api-context/data/metadata_api/FlowCategory.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/FlowDefinition.json +0 -37
- package/skills/getting-metadata-api-context/data/metadata_api/FlowSettings.json +0 -124
- package/skills/getting-metadata-api-context/data/metadata_api/FlowTest.json +0 -205
- package/skills/getting-metadata-api-context/data/metadata_api/FlowValueMap.json +0 -68
- package/skills/getting-metadata-api-context/data/metadata_api/Folder.json +0 -50
- package/skills/getting-metadata-api-context/data/metadata_api/FolderShare.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/ForecastingFilter.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/ForecastingFilterCondition.json +0 -62
- package/skills/getting-metadata-api-context/data/metadata_api/ForecastingObjectListSettings.json +0 -77
- package/skills/getting-metadata-api-context/data/metadata_api/ForecastingSettings.json +0 -303
- package/skills/getting-metadata-api-context/data/metadata_api/ForecastingSourceDefinition.json +0 -62
- package/skills/getting-metadata-api-context/data/metadata_api/ForecastingType.json +0 -100
- package/skills/getting-metadata-api-context/data/metadata_api/ForecastingTypeSource.json +0 -60
- package/skills/getting-metadata-api-context/data/metadata_api/FuelType.json +0 -52
- package/skills/getting-metadata-api-context/data/metadata_api/FuelTypeSustnUom.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/FunctionReference.json +0 -31
- package/skills/getting-metadata-api-context/data/metadata_api/FundraisingConfig.json +0 -86
- package/skills/getting-metadata-api-context/data/metadata_api/GatewayProviderPaymentMethodType.json +0 -50
- package/skills/getting-metadata-api-context/data/metadata_api/GenAiFunction.json +0 -171
- package/skills/getting-metadata-api-context/data/metadata_api/GenAiPlanner.json +0 -215
- package/skills/getting-metadata-api-context/data/metadata_api/GenAiPlannerBundle.json +0 -220
- package/skills/getting-metadata-api-context/data/metadata_api/GenAiPlugin.json +0 -87
- package/skills/getting-metadata-api-context/data/metadata_api/GenAiPluginInstructionDef.json +0 -42
- package/skills/getting-metadata-api-context/data/metadata_api/GenAiPromptTemplate.json +0 -183
- package/skills/getting-metadata-api-context/data/metadata_api/GenAiPromptTemplateActv.json +0 -42
- package/skills/getting-metadata-api-context/data/metadata_api/GiftEntryGridTemplate.json +0 -42
- package/skills/getting-metadata-api-context/data/metadata_api/GlobalPicklist.json +0 -43
- package/skills/getting-metadata-api-context/data/metadata_api/GlobalPicklistValue.json +0 -81
- package/skills/getting-metadata-api-context/data/metadata_api/GlobalValueSet.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/GlobalValueSetTranslation.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/GoogleAppsSettings.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/Group.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/HighVelocitySalesSettings.json +0 -96
- package/skills/getting-metadata-api-context/data/metadata_api/HistoryRetentionPolicy.json +0 -41
- package/skills/getting-metadata-api-context/data/metadata_api/HomePageComponent.json +0 -66
- package/skills/getting-metadata-api-context/data/metadata_api/HomePageLayout.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/IPAddressRange.json +0 -60
- package/skills/getting-metadata-api-context/data/metadata_api/IdeasSettings.json +0 -52
- package/skills/getting-metadata-api-context/data/metadata_api/IdentityProviderSettings.json +0 -39
- package/skills/getting-metadata-api-context/data/metadata_api/IdentityVerificationProcDef.json +0 -173
- package/skills/getting-metadata-api-context/data/metadata_api/IdentityVerificationProcDtl.json +0 -136
- package/skills/getting-metadata-api-context/data/metadata_api/IdentityVerificationProcFld.json +0 -76
- package/skills/getting-metadata-api-context/data/metadata_api/IframeWhiteListUrlSettings.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/InboundCertificate.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/InboundNetworkConnection.json +0 -72
- package/skills/getting-metadata-api-context/data/metadata_api/IncidentMgmtSettings.json +0 -140
- package/skills/getting-metadata-api-context/data/metadata_api/Index.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/IndustriesEinsteinFeatureSettings.json +0 -34
- package/skills/getting-metadata-api-context/data/metadata_api/IndustriesLoyaltySettings.json +0 -108
- package/skills/getting-metadata-api-context/data/metadata_api/IndustriesPricingSettings.json +0 -61
- package/skills/getting-metadata-api-context/data/metadata_api/IndustriesRatingSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/IndustriesSettings.json +0 -731
- package/skills/getting-metadata-api-context/data/metadata_api/IndustriesUnifiedInventorySettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/InsPlcyLimitConsumptionRule.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/InstalledPackage.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/IntegArtifactDef.json +0 -10
- package/skills/getting-metadata-api-context/data/metadata_api/IntegrationProviderDef.json +0 -155
- package/skills/getting-metadata-api-context/data/metadata_api/InterestTaggingSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/InternalDataConnector.json +0 -8
- package/skills/getting-metadata-api-context/data/metadata_api/InvLatePymntRiskCalcSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/InventorySettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/InvocableActionExtension.json +0 -84
- package/skills/getting-metadata-api-context/data/metadata_api/InvocableActionSettings.json +0 -28
- package/skills/getting-metadata-api-context/data/metadata_api/KeywordList.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/KnowledgeSettings.json +0 -280
- package/skills/getting-metadata-api-context/data/metadata_api/LanguageSettings.json +0 -68
- package/skills/getting-metadata-api-context/data/metadata_api/Layout.json +0 -659
- package/skills/getting-metadata-api-context/data/metadata_api/LeadConfigSettings.json +0 -64
- package/skills/getting-metadata-api-context/data/metadata_api/LeadConvertSettings.json +0 -71
- package/skills/getting-metadata-api-context/data/metadata_api/LearningItemType.json +0 -65
- package/skills/getting-metadata-api-context/data/metadata_api/Letterhead.json +0 -119
- package/skills/getting-metadata-api-context/data/metadata_api/LightningBolt.json +0 -103
- package/skills/getting-metadata-api-context/data/metadata_api/LightningComponentBundle.json +0 -109
- package/skills/getting-metadata-api-context/data/metadata_api/LightningExperienceSettings.json +0 -191
- package/skills/getting-metadata-api-context/data/metadata_api/LightningExperienceTheme.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/LightningMessageChannel.json +0 -63
- package/skills/getting-metadata-api-context/data/metadata_api/LightningOnboardingConfig.json +0 -62
- package/skills/getting-metadata-api-context/data/metadata_api/LightningTypeBundle.json +0 -88
- package/skills/getting-metadata-api-context/data/metadata_api/ListMetadataQuery.json +0 -10
- package/skills/getting-metadata-api-context/data/metadata_api/ListView.json +0 -86
- package/skills/getting-metadata-api-context/data/metadata_api/LiveAgentSettings.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/LiveChatAgentConfig.json +0 -188
- package/skills/getting-metadata-api-context/data/metadata_api/LiveChatButton.json +0 -188
- package/skills/getting-metadata-api-context/data/metadata_api/LiveChatDeployment.json +0 -81
- package/skills/getting-metadata-api-context/data/metadata_api/LiveChatSensitiveDataRule.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/LiveMessageSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/LoyaltyProgramSetup.json +0 -297
- package/skills/getting-metadata-api-context/data/metadata_api/MLDataDefinition.json +0 -146
- package/skills/getting-metadata-api-context/data/metadata_api/MLPredictionDefinition.json +0 -67
- package/skills/getting-metadata-api-context/data/metadata_api/MacroSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/MailMergeSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/ManagedContentType.json +0 -86
- package/skills/getting-metadata-api-context/data/metadata_api/ManagedEventSubscription.json +0 -52
- package/skills/getting-metadata-api-context/data/metadata_api/ManagedTopics.json +0 -57
- package/skills/getting-metadata-api-context/data/metadata_api/MapAndLocationSettings.json +0 -34
- package/skills/getting-metadata-api-context/data/metadata_api/MarketSegmentDefinition.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/MarketingAppExtension.json +0 -139
- package/skills/getting-metadata-api-context/data/metadata_api/MatchingRule.json +0 -69
- package/skills/getting-metadata-api-context/data/metadata_api/MeetingsSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/MessagingChannel.json +0 -278
- package/skills/getting-metadata-api-context/data/metadata_api/MetadataWithContent.json +0 -24
- package/skills/getting-metadata-api-context/data/metadata_api/Metadata_Type_Limits.json +0 -8
- package/skills/getting-metadata-api-context/data/metadata_api/MfgProgramTemplate.json +0 -88
- package/skills/getting-metadata-api-context/data/metadata_api/MfgServiceConsoleSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/MilestoneType.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/MktCalcInsightObjectDef.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/MktDataTranObject.json +0 -99
- package/skills/getting-metadata-api-context/data/metadata_api/MlDomain.json +0 -136
- package/skills/getting-metadata-api-context/data/metadata_api/MobSecurityCertPinConfig.json +0 -76
- package/skills/getting-metadata-api-context/data/metadata_api/MobileApplicationDetail.json +0 -71
- package/skills/getting-metadata-api-context/data/metadata_api/MobileSecurityAssignment.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/MobileSecurityPolicy.json +0 -75
- package/skills/getting-metadata-api-context/data/metadata_api/MobileSettings.json +0 -121
- package/skills/getting-metadata-api-context/data/metadata_api/ModerationRule.json +0 -99
- package/skills/getting-metadata-api-context/data/metadata_api/MutingPermissionSet.json +0 -33
- package/skills/getting-metadata-api-context/data/metadata_api/MyDomainDiscoverableLogin.json +0 -41
- package/skills/getting-metadata-api-context/data/metadata_api/MyDomainSettings.json +0 -140
- package/skills/getting-metadata-api-context/data/metadata_api/NameSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/NamedCredential.json +0 -205
- package/skills/getting-metadata-api-context/data/metadata_api/NamedFilter.json +0 -89
- package/skills/getting-metadata-api-context/data/metadata_api/NavigationMenu.json +0 -101
- package/skills/getting-metadata-api-context/data/metadata_api/Network.json +0 -606
- package/skills/getting-metadata-api-context/data/metadata_api/NetworkBranding.json +0 -117
- package/skills/getting-metadata-api-context/data/metadata_api/NotificationTypeConfig.json +0 -75
- package/skills/getting-metadata-api-context/data/metadata_api/NotificationsSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/OauthCustomScope.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/OauthOidcSettings.json +0 -52
- package/skills/getting-metadata-api-context/data/metadata_api/OauthTokenExchangeHandler.json +0 -119
- package/skills/getting-metadata-api-context/data/metadata_api/ObjectHierarchyRelationship.json +0 -108
- package/skills/getting-metadata-api-context/data/metadata_api/ObjectLinkingSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/ObjectSourceTargetMap.json +0 -85
- package/skills/getting-metadata-api-context/data/metadata_api/OcrSampleDocument.json +0 -158
- package/skills/getting-metadata-api-context/data/metadata_api/OcrTemplate.json +0 -180
- package/skills/getting-metadata-api-context/data/metadata_api/OmniChannelSettings.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/OmniExtTrackingDef.json +0 -66
- package/skills/getting-metadata-api-context/data/metadata_api/OmniInteractionAccessConfig.json +0 -90
- package/skills/getting-metadata-api-context/data/metadata_api/OmniInteractionConfig.json +0 -37
- package/skills/getting-metadata-api-context/data/metadata_api/OmniScript.json +0 -204
- package/skills/getting-metadata-api-context/data/metadata_api/OmniSupervisorConfig.json +0 -156
- package/skills/getting-metadata-api-context/data/metadata_api/OmniTrackingGroup.json +0 -77
- package/skills/getting-metadata-api-context/data/metadata_api/OnboardingDataObjectGroup.json +0 -131
- package/skills/getting-metadata-api-context/data/metadata_api/OpportunityInsightsSettings.json +0 -30
- package/skills/getting-metadata-api-context/data/metadata_api/OpportunityScoreSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/OpportunitySettings.json +0 -132
- package/skills/getting-metadata-api-context/data/metadata_api/OrchestrationPlanCtxMapping.json +0 -63
- package/skills/getting-metadata-api-context/data/metadata_api/OrderManagementSettings.json +0 -52
- package/skills/getting-metadata-api-context/data/metadata_api/OrderSettings.json +0 -60
- package/skills/getting-metadata-api-context/data/metadata_api/OrgPreferenceSettings.json +0 -43
- package/skills/getting-metadata-api-context/data/metadata_api/OrgSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/OutboundNetworkConnection.json +0 -71
- package/skills/getting-metadata-api-context/data/metadata_api/OwnerSharingRule.json +0 -206
- package/skills/getting-metadata-api-context/data/metadata_api/Package.json +0 -19
- package/skills/getting-metadata-api-context/data/metadata_api/PardotEinsteinSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/PardotSettings.json +0 -72
- package/skills/getting-metadata-api-context/data/metadata_api/ParticipantRole.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/PartyDataModelSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/PathAssistant.json +0 -74
- package/skills/getting-metadata-api-context/data/metadata_api/PathAssistantSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/PaymentGatewayProvider.json +0 -50
- package/skills/getting-metadata-api-context/data/metadata_api/PaymentsSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/PermissionSet.json +0 -372
- package/skills/getting-metadata-api-context/data/metadata_api/PermissionSetGroup.json +0 -57
- package/skills/getting-metadata-api-context/data/metadata_api/PermissionSetLicenseDefinition.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/PersonAccountOwnerPowerUser.json +0 -38
- package/skills/getting-metadata-api-context/data/metadata_api/Picklist.json +0 -43
- package/skills/getting-metadata-api-context/data/metadata_api/PicklistSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/PipelineInspMetricConfig.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/PlatformCachePartition.json +0 -79
- package/skills/getting-metadata-api-context/data/metadata_api/PlatformEncryptionSettings.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/PlatformEventChannel.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/PlatformEventChannelMember.json +0 -71
- package/skills/getting-metadata-api-context/data/metadata_api/PlatformEventMigration.json +0 -39
- package/skills/getting-metadata-api-context/data/metadata_api/PlatformEventSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/PlatformEventSubscriberConfig.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/Portal.json +0 -137
- package/skills/getting-metadata-api-context/data/metadata_api/PortalDelegablePermissionSet.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/PostTemplate.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/PredictionBuilderSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/PresenceDeclineReason.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/PresenceUserConfig.json +0 -122
- package/skills/getting-metadata-api-context/data/metadata_api/PricingActionParameters.json +0 -64
- package/skills/getting-metadata-api-context/data/metadata_api/PricingRecipe.json +0 -117
- package/skills/getting-metadata-api-context/data/metadata_api/PrivacySettings.json +0 -80
- package/skills/getting-metadata-api-context/data/metadata_api/ProcessFlowMigration.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/ProductAttributeSet.json +0 -33
- package/skills/getting-metadata-api-context/data/metadata_api/ProductSettings.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/Profile.json +0 -492
- package/skills/getting-metadata-api-context/data/metadata_api/ProfileActionOverride.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/ProfilePasswordPolicy.json +0 -80
- package/skills/getting-metadata-api-context/data/metadata_api/ProfileSearchLayouts.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/ProfileSessionSetting.json +0 -55
- package/skills/getting-metadata-api-context/data/metadata_api/Prompt.json +0 -255
- package/skills/getting-metadata-api-context/data/metadata_api/PublicKeyCertificate.json +0 -50
- package/skills/getting-metadata-api-context/data/metadata_api/PublicKeyCertificateSet.json +0 -65
- package/skills/getting-metadata-api-context/data/metadata_api/Queue.json +0 -123
- package/skills/getting-metadata-api-context/data/metadata_api/QueueRoutingConfig.json +0 -96
- package/skills/getting-metadata-api-context/data/metadata_api/QuickAction.json +0 -175
- package/skills/getting-metadata-api-context/data/metadata_api/QuoteSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/ReadResult.json +0 -16
- package/skills/getting-metadata-api-context/data/metadata_api/RealTimeEventSettings.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/RecommendationStrategy.json +0 -327
- package/skills/getting-metadata-api-context/data/metadata_api/RecordActionDeployment.json +0 -184
- package/skills/getting-metadata-api-context/data/metadata_api/RecordAggregationDefinition.json +0 -148
- package/skills/getting-metadata-api-context/data/metadata_api/RecordAlertCategory.json +0 -42
- package/skills/getting-metadata-api-context/data/metadata_api/RecordPageSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/RecordType.json +0 -68
- package/skills/getting-metadata-api-context/data/metadata_api/RedirectWhitelistUrl.json +0 -26
- package/skills/getting-metadata-api-context/data/metadata_api/ReferencedDashboard.json +0 -55
- package/skills/getting-metadata-api-context/data/metadata_api/RegisteredExternalService.json +0 -72
- package/skills/getting-metadata-api-context/data/metadata_api/RelatedRecordAssocCriteria.json +0 -75
- package/skills/getting-metadata-api-context/data/metadata_api/RelationshipGraphDefinition.json +0 -63
- package/skills/getting-metadata-api-context/data/metadata_api/RemoteSiteSetting.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/Report.json +0 -715
- package/skills/getting-metadata-api-context/data/metadata_api/ReportType.json +0 -118
- package/skills/getting-metadata-api-context/data/metadata_api/RestrictionRule.json +0 -71
- package/skills/getting-metadata-api-context/data/metadata_api/RetailExecutionSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/RetrievalSummaryDefinition.json +0 -76
- package/skills/getting-metadata-api-context/data/metadata_api/RetrieveRequest.json +0 -35
- package/skills/getting-metadata-api-context/data/metadata_api/RetrieveResult.json +0 -103
- package/skills/getting-metadata-api-context/data/metadata_api/Role.json +0 -35
- package/skills/getting-metadata-api-context/data/metadata_api/RoleOrTerritory.json +0 -57
- package/skills/getting-metadata-api-context/data/metadata_api/SalesAgreementSettings.json +0 -180
- package/skills/getting-metadata-api-context/data/metadata_api/SalesWorkQueueSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/SamlSsoConfig.json +0 -128
- package/skills/getting-metadata-api-context/data/metadata_api/SandboxSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/SaveResult.json +0 -22
- package/skills/getting-metadata-api-context/data/metadata_api/SchedulingObjective.json +0 -66
- package/skills/getting-metadata-api-context/data/metadata_api/SchedulingRule.json +0 -66
- package/skills/getting-metadata-api-context/data/metadata_api/SchemaSettings.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/Scontrol.json +0 -72
- package/skills/getting-metadata-api-context/data/metadata_api/SearchCustomization.json +0 -120
- package/skills/getting-metadata-api-context/data/metadata_api/SearchLayouts.json +0 -64
- package/skills/getting-metadata-api-context/data/metadata_api/SearchOrgWideObjectConfig.json +0 -61
- package/skills/getting-metadata-api-context/data/metadata_api/SearchSettings.json +0 -155
- package/skills/getting-metadata-api-context/data/metadata_api/SecuritySettings.json +0 -437
- package/skills/getting-metadata-api-context/data/metadata_api/ServiceAISetupDefinition.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/ServiceAISetupField.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/ServiceChannel.json +0 -123
- package/skills/getting-metadata-api-context/data/metadata_api/ServiceCloudVoiceSettings.json +0 -83
- package/skills/getting-metadata-api-context/data/metadata_api/ServicePresenceStatus.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/ServiceProcess.json +0 -141
- package/skills/getting-metadata-api-context/data/metadata_api/ServiceSetupAssistantSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/SessionHeader.json +0 -17
- package/skills/getting-metadata-api-context/data/metadata_api/SharedTo.json +0 -105
- package/skills/getting-metadata-api-context/data/metadata_api/SharingBaseRule.json +0 -60
- package/skills/getting-metadata-api-context/data/metadata_api/SharingReason.json +0 -34
- package/skills/getting-metadata-api-context/data/metadata_api/SharingRecalculation.json +0 -29
- package/skills/getting-metadata-api-context/data/metadata_api/SharingRules.json +0 -186
- package/skills/getting-metadata-api-context/data/metadata_api/SharingSet.json +0 -78
- package/skills/getting-metadata-api-context/data/metadata_api/SharingSettings.json +0 -92
- package/skills/getting-metadata-api-context/data/metadata_api/SiteDotCom.json +0 -37
- package/skills/getting-metadata-api-context/data/metadata_api/SiteSettings.json +0 -60
- package/skills/getting-metadata-api-context/data/metadata_api/Skill.json +0 -69
- package/skills/getting-metadata-api-context/data/metadata_api/SocialCustomerServiceSettings.json +0 -61
- package/skills/getting-metadata-api-context/data/metadata_api/SocialProfileSettings.json +0 -35
- package/skills/getting-metadata-api-context/data/metadata_api/SourceTrackingSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/StageAssignment.json +0 -113
- package/skills/getting-metadata-api-context/data/metadata_api/StageDefinition.json +0 -237
- package/skills/getting-metadata-api-context/data/metadata_api/StandardValueSet.json +0 -41
- package/skills/getting-metadata-api-context/data/metadata_api/StandardValueSetTranslation.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/StaticResource.json +0 -49
- package/skills/getting-metadata-api-context/data/metadata_api/StreamingAppDataConnector.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/SubscriptionManagementSettings.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/SurveySettings.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/SustainabilityUom.json +0 -61
- package/skills/getting-metadata-api-context/data/metadata_api/SustnUomConversion.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/SvcCatalogCategory.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/SvcCatalogFulfillmentFlow.json +0 -99
- package/skills/getting-metadata-api-context/data/metadata_api/SvcCatalogItemDef.json +0 -202
- package/skills/getting-metadata-api-context/data/metadata_api/SynonymDictionary.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/Tag.json +0 -70
- package/skills/getting-metadata-api-context/data/metadata_api/TagSet.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/Territory.json +0 -39
- package/skills/getting-metadata-api-context/data/metadata_api/Territory2.json +0 -112
- package/skills/getting-metadata-api-context/data/metadata_api/Territory2Model.json +0 -41
- package/skills/getting-metadata-api-context/data/metadata_api/Territory2Rule.json +0 -68
- package/skills/getting-metadata-api-context/data/metadata_api/Territory2Settings.json +0 -111
- package/skills/getting-metadata-api-context/data/metadata_api/Territory2Type.json +0 -42
- package/skills/getting-metadata-api-context/data/metadata_api/TimeSheetTemplate.json +0 -75
- package/skills/getting-metadata-api-context/data/metadata_api/TimelineObjectDefinition.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/TopicsForObjects.json +0 -38
- package/skills/getting-metadata-api-context/data/metadata_api/TrailheadSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/TransactionSecurityPolicy.json +0 -127
- package/skills/getting-metadata-api-context/data/metadata_api/Translations.json +0 -976
- package/skills/getting-metadata-api-context/data/metadata_api/TrialOrgSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/UIBundle.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/UIObjectRelationConfig.json +0 -101
- package/skills/getting-metadata-api-context/data/metadata_api/UiFormatSpecificationSet.json +0 -103
- package/skills/getting-metadata-api-context/data/metadata_api/UiPreviewMessageTabDef.json +0 -70
- package/skills/getting-metadata-api-context/data/metadata_api/UpsertResult.json +0 -25
- package/skills/getting-metadata-api-context/data/metadata_api/UserAccessPolicy.json +0 -120
- package/skills/getting-metadata-api-context/data/metadata_api/UserAuthCertificate.json +0 -57
- package/skills/getting-metadata-api-context/data/metadata_api/UserCriteria.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/UserEngagementSettings.json +0 -136
- package/skills/getting-metadata-api-context/data/metadata_api/UserInterfaceSettings.json +0 -96
- package/skills/getting-metadata-api-context/data/metadata_api/UserManagementSettings.json +0 -108
- package/skills/getting-metadata-api-context/data/metadata_api/UserProfileSearchScope.json +0 -8
- package/skills/getting-metadata-api-context/data/metadata_api/UserProvisioningConfig.json +0 -72
- package/skills/getting-metadata-api-context/data/metadata_api/ValidationRule.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/VirtualVisitConfig.json +0 -97
- package/skills/getting-metadata-api-context/data/metadata_api/VoiceSettings.json +0 -68
- package/skills/getting-metadata-api-context/data/metadata_api/WarrantyLifeCycleMgmtSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/WaveAnalyticAssetCollection.json +0 -73
- package/skills/getting-metadata-api-context/data/metadata_api/WaveApplication.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/WaveComponent.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/WaveDashboard.json +0 -50
- package/skills/getting-metadata-api-context/data/metadata_api/WaveDataflow.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/WaveDataset.json +0 -50
- package/skills/getting-metadata-api-context/data/metadata_api/WaveLens.json +0 -59
- package/skills/getting-metadata-api-context/data/metadata_api/WaveRecipe.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/WaveTemplateBundle.json +0 -37
- package/skills/getting-metadata-api-context/data/metadata_api/WaveXmd.json +0 -567
- package/skills/getting-metadata-api-context/data/metadata_api/WebLink.json +0 -117
- package/skills/getting-metadata-api-context/data/metadata_api/WebStoreBundle.json +0 -10
- package/skills/getting-metadata-api-context/data/metadata_api/WebStoreTemplate.json +0 -166
- package/skills/getting-metadata-api-context/data/metadata_api/WorkDotComSettings.json +0 -76
- package/skills/getting-metadata-api-context/data/metadata_api/WorkSkillRouting.json +0 -76
- package/skills/getting-metadata-api-context/data/metadata_api/Workflow.json +0 -415
- package/skills/getting-metadata-api-context/data/metadata_api/WorkforceEngagementSettings.json +0 -56
- package/skills/getting-metadata-api-context/examples/README.md +0 -169
- package/skills/getting-metadata-api-context/examples/bash_section_loading.sh +0 -142
- package/skills/getting-metadata-api-context/examples/javascript_section_loading.js +0 -162
- package/skills/getting-metadata-api-context/examples/python_section_loading.py +0 -112
- package/skills/getting-metadata-api-context/references/metadata_index_table.md +0 -654
- package/skills/getting-metadata-api-context/references/usage_guide.md +0 -420
- package/skills/handling-sf-data/CREDITS.md +0 -5
- package/skills/handling-sf-data/README.md +0 -112
- package/skills/handling-sf-data/SKILL.md +0 -234
- package/skills/handling-sf-data/assets/bulk/bulk-insert-10000.apex +0 -293
- package/skills/handling-sf-data/assets/bulk/bulk-insert-200.apex +0 -208
- package/skills/handling-sf-data/assets/bulk/bulk-insert-500.apex +0 -219
- package/skills/handling-sf-data/assets/bulk/bulk-upsert-external-id.apex +0 -324
- package/skills/handling-sf-data/assets/cleanup/delete-by-created-date.apex +0 -319
- package/skills/handling-sf-data/assets/cleanup/delete-by-name.apex +0 -240
- package/skills/handling-sf-data/assets/cleanup/delete-test-data.apex +0 -311
- package/skills/handling-sf-data/assets/cleanup/rollback-transaction.apex +0 -266
- package/skills/handling-sf-data/assets/csv/account-import.csv +0 -11
- package/skills/handling-sf-data/assets/csv/contact-import.csv +0 -11
- package/skills/handling-sf-data/assets/csv/custom-object-import.csv +0 -11
- package/skills/handling-sf-data/assets/csv/opportunity-import.csv +0 -11
- package/skills/handling-sf-data/assets/factories/account-factory.apex +0 -165
- package/skills/handling-sf-data/assets/factories/case-factory.apex +0 -237
- package/skills/handling-sf-data/assets/factories/contact-factory.apex +0 -168
- package/skills/handling-sf-data/assets/factories/custom-object-factory.apex +0 -260
- package/skills/handling-sf-data/assets/factories/event-factory.apex +0 -275
- package/skills/handling-sf-data/assets/factories/hierarchy-factory.apex +0 -372
- package/skills/handling-sf-data/assets/factories/lead-factory.apex +0 -190
- package/skills/handling-sf-data/assets/factories/opportunity-factory.apex +0 -206
- package/skills/handling-sf-data/assets/factories/task-factory.apex +0 -246
- package/skills/handling-sf-data/assets/factories/user-factory.apex +0 -278
- package/skills/handling-sf-data/assets/json/account-contact-tree.json +0 -130
- package/skills/handling-sf-data/assets/json/account-opportunity-tree.json +0 -110
- package/skills/handling-sf-data/assets/json/full-hierarchy-tree.json +0 -188
- package/skills/handling-sf-data/assets/soql/aggregate.soql +0 -226
- package/skills/handling-sf-data/assets/soql/child-to-parent.soql +0 -162
- package/skills/handling-sf-data/assets/soql/parent-to-child.soql +0 -153
- package/skills/handling-sf-data/assets/soql/polymorphic.soql +0 -198
- package/skills/handling-sf-data/assets/soql/subquery.soql +0 -287
- package/skills/handling-sf-data/references/anonymous-apex-guide.md +0 -98
- package/skills/handling-sf-data/references/bulk-operations-guide.md +0 -94
- package/skills/handling-sf-data/references/bulk-testing-example.md +0 -194
- package/skills/handling-sf-data/references/cleanup-rollback-example.md +0 -322
- package/skills/handling-sf-data/references/cleanup-rollback-guide.md +0 -84
- package/skills/handling-sf-data/references/crud-workflow-example.md +0 -183
- package/skills/handling-sf-data/references/governor-limits-reference.md +0 -74
- package/skills/handling-sf-data/references/orchestration.md +0 -174
- package/skills/handling-sf-data/references/relationship-query-examples.md +0 -249
- package/skills/handling-sf-data/references/sf-cli-data-commands.md +0 -158
- package/skills/handling-sf-data/references/soql-relationship-guide.md +0 -84
- package/skills/handling-sf-data/references/test-data-best-practices.md +0 -104
- package/skills/handling-sf-data/references/test-data-factory-usage.md +0 -290
- package/skills/handling-sf-data/references/test-data-patterns.md +0 -98
- package/skills/handling-sf-data/scripts/soql_validator.py +0 -292
- package/skills/handling-sf-data/scripts/validate_data_operation.py +0 -379
- package/skills/harmonizing-datacloud/CREDITS.md +0 -3
- package/skills/harmonizing-datacloud/README.md +0 -31
- package/skills/harmonizing-datacloud/SKILL.md +0 -116
- package/skills/implementing-ui-bundle-agentforce-conversation-client/SKILL.md +0 -280
- package/skills/implementing-ui-bundle-agentforce-conversation-client/references/agent-id-resolution.md +0 -46
- package/skills/implementing-ui-bundle-agentforce-conversation-client/references/constraints.md +0 -134
- package/skills/implementing-ui-bundle-agentforce-conversation-client/references/examples.md +0 -132
- package/skills/implementing-ui-bundle-agentforce-conversation-client/references/style-tokens.md +0 -260
- package/skills/implementing-ui-bundle-agentforce-conversation-client/references/troubleshooting.md +0 -57
- package/skills/implementing-ui-bundle-file-upload/SKILL.md +0 -398
- package/skills/integrating-b2b-commerce-open-code-components/SKILL.md +0 -165
- package/skills/investigating-agentforce-architecture/README.md +0 -156
- package/skills/investigating-agentforce-architecture/SKILL.md +0 -230
- package/skills/investigating-agentforce-architecture/assets/cli/describe_sobject.yaml +0 -16
- package/skills/investigating-agentforce-architecture/assets/cli/describe_tooling_sobject.yaml +0 -17
- package/skills/investigating-agentforce-architecture/assets/cli/list_metadata_genaiprompttemplate.yaml +0 -17
- package/skills/investigating-agentforce-architecture/assets/cli/org_display.yaml +0 -15
- package/skills/investigating-agentforce-architecture/assets/cli/retrieve_genai_plugin.yaml +0 -18
- package/skills/investigating-agentforce-architecture/assets/cli/show_access_token.yaml +0 -27
- package/skills/investigating-agentforce-architecture/assets/mermaid/action_tree.mmd +0 -20
- package/skills/investigating-agentforce-architecture/assets/mermaid/data_flow.mmd +0 -19
- package/skills/investigating-agentforce-architecture/assets/mermaid/dependency_graph.mmd +0 -19
- package/skills/investigating-agentforce-architecture/assets/mermaid/invocation_sequence.mmd +0 -20
- package/skills/investigating-agentforce-architecture/assets/mermaid/planner_state.mmd +0 -18
- package/skills/investigating-agentforce-architecture/assets/soql/apex_class_bodies_by_ids.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/apex_class_bodies_by_names.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/bot_definition_details.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/bot_version_lookup.soql +0 -4
- package/skills/investigating-agentforce-architecture/assets/soql/flow_definition_by_ids.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/flow_definition_ids_by_names.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/flow_definition_view_by_durable_ids.soql +0 -4
- package/skills/investigating-agentforce-architecture/assets/soql/flow_metadata_by_id.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/functions_by_plugins.soql +0 -5
- package/skills/investigating-agentforce-architecture/assets/soql/planner_attrs_by_parent_ids.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/planner_bundle_functions.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/planner_definition_by_agent_chain.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/plugin_functions_by_plugin_ids.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/plugin_instructions_by_plugin_ids.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/plugins_by_planner.soql +0 -4
- package/skills/investigating-agentforce-architecture/references/architecture_sections.md +0 -243
- package/skills/investigating-agentforce-architecture/references/contract.json +0 -244
- package/skills/investigating-agentforce-architecture/references/soql_fields.md +0 -512
- package/skills/investigating-agentforce-architecture/scripts/_shared/__init__.py +0 -1
- package/skills/investigating-agentforce-architecture/scripts/_shared/fs_guard.py +0 -329
- package/skills/investigating-agentforce-architecture/scripts/_shared/paths.py +0 -110
- package/skills/investigating-agentforce-architecture/scripts/_shared/runtime.py +0 -59
- package/skills/investigating-agentforce-architecture/scripts/_shared/sql.py +0 -10
- package/skills/investigating-agentforce-architecture/scripts/cache_check.py +0 -234
- package/skills/investigating-agentforce-architecture/scripts/config.py +0 -131
- package/skills/investigating-agentforce-architecture/scripts/fetch_soql.py +0 -689
- package/skills/investigating-agentforce-architecture/scripts/finalize.py +0 -295
- package/skills/investigating-agentforce-architecture/scripts/main.py +0 -2835
- package/skills/investigating-agentforce-architecture/scripts/metadata_listing.py +0 -265
- package/skills/investigating-agentforce-architecture/scripts/parallel_retrieve.py +0 -69
- package/skills/investigating-agentforce-architecture/scripts/parse_bundle.py +0 -215
- package/skills/investigating-agentforce-architecture/scripts/parse_wave.py +0 -845
- package/skills/investigating-agentforce-architecture/scripts/probe_channels.py +0 -302
- package/skills/investigating-agentforce-architecture/scripts/render_architecture.py +0 -1043
- package/skills/investigating-agentforce-architecture/scripts/resolve_bot.py +0 -255
- package/skills/investigating-agentforce-architecture/scripts/resolve_invocation_target.py +0 -130
- package/skills/investigating-agentforce-architecture/scripts/rest_client.py +0 -763
- package/skills/investigating-agentforce-architecture/scripts/retrieve_planner.py +0 -13
- package/skills/investigating-agentforce-architecture/scripts/sf_cli.py +0 -242
- package/skills/investigating-agentforce-architecture/scripts/soql_loader.py +0 -253
- package/skills/investigating-agentforce-architecture/scripts/summarize_tree.py +0 -143
- package/skills/investigating-agentforce-architecture/scripts/tests/__init__.py +0 -0
- package/skills/investigating-agentforce-architecture/scripts/tests/_bootstrap.py +0 -23
- package/skills/investigating-agentforce-architecture/scripts/tests/fixtures/__init__.py +0 -0
- package/skills/investigating-agentforce-architecture/scripts/tests/fixtures/genai_payloads.py +0 -400
- package/skills/investigating-agentforce-architecture/scripts/tests/test_cache_check.py +0 -307
- package/skills/investigating-agentforce-architecture/scripts/tests/test_cache_check_main.py +0 -283
- package/skills/investigating-agentforce-architecture/scripts/tests/test_config.py +0 -115
- package/skills/investigating-agentforce-architecture/scripts/tests/test_end_to_end_fixture.py +0 -651
- package/skills/investigating-agentforce-architecture/scripts/tests/test_finalize.py +0 -278
- package/skills/investigating-agentforce-architecture/scripts/tests/test_flow_children_inflation.py +0 -582
- package/skills/investigating-agentforce-architecture/scripts/tests/test_fs_guard.py +0 -113
- package/skills/investigating-agentforce-architecture/scripts/tests/test_iterative_wave_b.py +0 -478
- package/skills/investigating-agentforce-architecture/scripts/tests/test_main_pipeline.py +0 -3359
- package/skills/investigating-agentforce-architecture/scripts/tests/test_parallel_retrieve.py +0 -131
- package/skills/investigating-agentforce-architecture/scripts/tests/test_parse_bundle.py +0 -400
- package/skills/investigating-agentforce-architecture/scripts/tests/test_parse_wave.py +0 -644
- package/skills/investigating-agentforce-architecture/scripts/tests/test_parse_wave_classifiers.py +0 -224
- package/skills/investigating-agentforce-architecture/scripts/tests/test_parse_wave_helpers.py +0 -380
- package/skills/investigating-agentforce-architecture/scripts/tests/test_parse_wave_main.py +0 -397
- package/skills/investigating-agentforce-architecture/scripts/tests/test_per_branch_visited.py +0 -244
- package/skills/investigating-agentforce-architecture/scripts/tests/test_probe_channels.py +0 -359
- package/skills/investigating-agentforce-architecture/scripts/tests/test_probe_cli_recipes.py +0 -185
- package/skills/investigating-agentforce-architecture/scripts/tests/test_render_architecture.py +0 -810
- package/skills/investigating-agentforce-architecture/scripts/tests/test_resolve_bot.py +0 -203
- package/skills/investigating-agentforce-architecture/scripts/tests/test_resolve_creds.py +0 -157
- package/skills/investigating-agentforce-architecture/scripts/tests/test_resolve_invocation_target.py +0 -145
- package/skills/investigating-agentforce-architecture/scripts/tests/test_rest_client.py +0 -1253
- package/skills/investigating-agentforce-architecture/scripts/tests/test_runtime_override.py +0 -100
- package/skills/investigating-agentforce-architecture/scripts/tests/test_sf_cli.py +0 -261
- package/skills/investigating-agentforce-architecture/scripts/tests/test_signature_stamping.py +0 -466
- package/skills/investigating-agentforce-architecture/scripts/tests/test_soql_loader.py +0 -501
- package/skills/investigating-agentforce-architecture/scripts/tests/test_summarize_tree.py +0 -241
- package/skills/investigating-agentforce-architecture/scripts/tests/test_write_emit_ctx.py +0 -480
- package/skills/investigating-agentforce-architecture/tools/emit_env.py +0 -157
- package/skills/investigating-agentforce-architecture/tools/emit_result.py +0 -262
- package/skills/investigating-agentforce-architecture/tools/sanitize.py +0 -33
- package/skills/investigating-agentforce-architecture/tools/write_emit_ctx.py +0 -332
- package/skills/investigating-agentforce-d360/README.md +0 -123
- package/skills/investigating-agentforce-d360/SKILL.md +0 -163
- package/skills/investigating-agentforce-d360/assets/dc/app_generation.sql +0 -51
- package/skills/investigating-agentforce-d360/assets/dc/content_category.sql +0 -44
- package/skills/investigating-agentforce-d360/assets/dc/content_quality.sql +0 -41
- package/skills/investigating-agentforce-d360/assets/dc/discover_sessions.sql +0 -36
- package/skills/investigating-agentforce-d360/assets/dc/feedback.sql +0 -47
- package/skills/investigating-agentforce-d360/assets/dc/feedback_details.sql +0 -38
- package/skills/investigating-agentforce-d360/assets/dc/gateway_records.sql +0 -45
- package/skills/investigating-agentforce-d360/assets/dc/gateway_request_llm.sql +0 -50
- package/skills/investigating-agentforce-d360/assets/dc/gateway_request_metadata.sql +0 -44
- package/skills/investigating-agentforce-d360/assets/dc/gateway_request_tags.sql +0 -42
- package/skills/investigating-agentforce-d360/assets/dc/gateway_requests.sql +0 -89
- package/skills/investigating-agentforce-d360/assets/dc/gateway_responses.sql +0 -43
- package/skills/investigating-agentforce-d360/assets/dc/generations.sql +0 -52
- package/skills/investigating-agentforce-d360/assets/dc/interactions.sql +0 -53
- package/skills/investigating-agentforce-d360/assets/dc/messages.sql +0 -53
- package/skills/investigating-agentforce-d360/assets/dc/messaging_session.sql +0 -37
- package/skills/investigating-agentforce-d360/assets/dc/moment_interactions.sql +0 -34
- package/skills/investigating-agentforce-d360/assets/dc/moments.sql +0 -39
- package/skills/investigating-agentforce-d360/assets/dc/participants.sql +0 -48
- package/skills/investigating-agentforce-d360/assets/dc/sessions.sql +0 -78
- package/skills/investigating-agentforce-d360/assets/dc/steps.sql +0 -64
- package/skills/investigating-agentforce-d360/assets/dc/tag_associations.sql +0 -46
- package/skills/investigating-agentforce-d360/assets/dc/tag_definition_associations.sql +0 -37
- package/skills/investigating-agentforce-d360/assets/dc/tag_definitions.sql +0 -50
- package/skills/investigating-agentforce-d360/assets/dc/tags.sql +0 -37
- package/skills/investigating-agentforce-d360/assets/dc/telemetry_spans.sql +0 -55
- package/skills/investigating-agentforce-d360/references/artifacts.md +0 -50
- package/skills/investigating-agentforce-d360/references/dc_dmo_fields.md +0 -823
- package/skills/investigating-agentforce-d360/references/dc_pipeline_contract.md +0 -608
- package/skills/investigating-agentforce-d360/scripts/_shared/__init__.py +0 -2
- package/skills/investigating-agentforce-d360/scripts/_shared/cli_override.py +0 -98
- package/skills/investigating-agentforce-d360/scripts/_shared/fs_guard.py +0 -334
- package/skills/investigating-agentforce-d360/scripts/_shared/paths.py +0 -155
- package/skills/investigating-agentforce-d360/scripts/_shared/runtime.py +0 -59
- package/skills/investigating-agentforce-d360/scripts/_shared/sql.py +0 -14
- package/skills/investigating-agentforce-d360/scripts/assemble_dc.py +0 -1624
- package/skills/investigating-agentforce-d360/scripts/config.py +0 -45
- package/skills/investigating-agentforce-d360/scripts/dc.py +0 -188
- package/skills/investigating-agentforce-d360/scripts/discover_sessions.py +0 -556
- package/skills/investigating-agentforce-d360/scripts/fetch_dc.py +0 -1045
- package/skills/investigating-agentforce-d360/scripts/render_dc.py +0 -1750
- package/skills/investigating-agentforce-d360/scripts/resolve_session.py +0 -264
- package/skills/investigating-agentforce-d360/scripts/storage.py +0 -92
- package/skills/investigating-agentforce-d360/scripts/tests/__init__.py +0 -0
- package/skills/investigating-agentforce-d360/scripts/tests/_bootstrap.py +0 -15
- package/skills/investigating-agentforce-d360/scripts/tests/fixtures/__init__.py +0 -0
- package/skills/investigating-agentforce-d360/scripts/tests/fixtures/synthetic_session.py +0 -424
- package/skills/investigating-agentforce-d360/scripts/tests/test_assemble_dc_bootstrap_and_mode.py +0 -115
- package/skills/investigating-agentforce-d360/scripts/tests/test_assemble_dc_gateway_direct.py +0 -220
- package/skills/investigating-agentforce-d360/scripts/tests/test_assemble_dc_gateway_direct_integration.py +0 -158
- package/skills/investigating-agentforce-d360/scripts/tests/test_assemble_dc_helpers.py +0 -287
- package/skills/investigating-agentforce-d360/scripts/tests/test_assemble_dc_integration.py +0 -247
- package/skills/investigating-agentforce-d360/scripts/tests/test_dc_and_resolve_session.py +0 -433
- package/skills/investigating-agentforce-d360/scripts/tests/test_discover_sessions.py +0 -458
- package/skills/investigating-agentforce-d360/scripts/tests/test_discover_sessions_grep_ci.py +0 -193
- package/skills/investigating-agentforce-d360/scripts/tests/test_fetch_dc_helpers.py +0 -266
- package/skills/investigating-agentforce-d360/scripts/tests/test_fetch_dc_identity.py +0 -528
- package/skills/investigating-agentforce-d360/scripts/tests/test_fetch_dc_main.py +0 -251
- package/skills/investigating-agentforce-d360/scripts/tests/test_fetch_dc_waterfall.py +0 -229
- package/skills/investigating-agentforce-d360/scripts/tests/test_fetch_dc_waterfall_full.py +0 -283
- package/skills/investigating-agentforce-d360/scripts/tests/test_identity_coherence.py +0 -327
- package/skills/investigating-agentforce-d360/scripts/tests/test_render_dc_branches.py +0 -256
- package/skills/investigating-agentforce-d360/scripts/tests/test_render_dc_gateway_direct.py +0 -130
- package/skills/investigating-agentforce-d360/scripts/tests/test_render_dc_helpers.py +0 -291
- package/skills/investigating-agentforce-d360/scripts/tests/test_render_dc_integration.py +0 -220
- package/skills/investigating-agentforce-d360/scripts/tests/test_render_dc_planner_llm_calls.py +0 -284
- package/skills/investigating-agentforce-d360/scripts/tests/test_render_dc_show_prompts_gating.py +0 -215
- package/skills/investigating-agentforce-d360/scripts/tests/test_resolve_from_disk.py +0 -100
- package/skills/investigating-agentforce-d360/scripts/tests/test_resolve_session_main.py +0 -149
- package/skills/investigating-agentforce-d360/scripts/tests/test_runtime_override.py +0 -104
- package/skills/investigating-agentforce-d360/scripts/tests/test_session_shape.py +0 -95
- package/skills/investigating-agentforce-d360/scripts/tests/test_session_shape_dropped_by_stdm.py +0 -85
- package/skills/managing-cdc-enablement/SKILL.md +0 -164
- package/skills/managing-cdc-enablement/assets/PlatformEventChannel-template.xml +0 -5
- package/skills/managing-cdc-enablement/assets/PlatformEventChannelMember-template.xml +0 -11
- package/skills/managing-cdc-enablement/references/deploy-troubleshooting.md +0 -73
- package/skills/managing-cdc-enablement/references/filter-expressions.md +0 -93
- package/skills/managing-managed-event-subscription/SKILL.md +0 -152
- package/skills/managing-managed-event-subscription/assets/managed-event-subscription-template.xml +0 -20
- package/skills/managing-managed-event-subscription/references/delete-guide.md +0 -57
- package/skills/managing-managed-event-subscription/references/topic-name-formats.md +0 -26
- package/skills/managing-managed-event-subscription/references/update-constraints.md +0 -30
- package/skills/modeling-omnistudio-epc-catalog/CREDITS.md +0 -14
- package/skills/modeling-omnistudio-epc-catalog/README.md +0 -89
- package/skills/modeling-omnistudio-epc-catalog/SKILL.md +0 -394
- package/skills/modeling-omnistudio-epc-catalog/assets/attribute-assignment-template.json +0 -402
- package/skills/modeling-omnistudio-epc-catalog/assets/compiled-attribute-overrides-template.json +0 -43
- package/skills/modeling-omnistudio-epc-catalog/assets/completion-block-template.txt +0 -8
- package/skills/modeling-omnistudio-epc-catalog/assets/decomposition-relationships-template.json +0 -233
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_AttributeAssignments.json +0 -514
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_CompiledAttributeOverrides.json +0 -21
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_DataPack.json +0 -649
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_DecompositionRelationships.json +0 -200
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_ObjectFieldAttributes.json +0 -138
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_OrchestrationScenarios.json +0 -54
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_OverrideDefinitions.json +0 -266
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_ParentKeys.json +0 -23
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_PriceListEntries.json +0 -54
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_PricebookEntries.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_ProductChildItems.json +0 -34
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_RuleAssignments.json +0 -21
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_AttributeAssignments.json +0 -410
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_DataPack.json +0 -535
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_DecompositionRelationships.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_ObjectFieldAttributes.json +0 -138
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_OrchestrationScenarios.json +0 -28
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_ParentKeys.json +0 -23
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_PriceListEntries.json +0 -220
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_PricebookEntries.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_ProductChildItems.json +0 -414
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_AttributeAssignments.json +0 -382
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_DataPack.json +0 -565
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_DecompositionRelationships.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_ObjectFieldAttributes.json +0 -104
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_OrchestrationScenarios.json +0 -28
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_ParentKeys.json +0 -13
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_PriceListEntries.json +0 -106
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_PricebookEntries.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_ProductChildItems.json +0 -72
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_AttributeAssignments.json +0 -142
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_DataPack.json +0 -377
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_DecompositionRelationships.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_ObjectFieldAttributes.json +0 -36
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_ParentKeys.json +0 -8
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_PriceListEntries.json +0 -54
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_PricebookEntries.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_ProductChildItems.json +0 -34
- package/skills/modeling-omnistudio-epc-catalog/assets/object-field-attributes-template.json +0 -138
- package/skills/modeling-omnistudio-epc-catalog/assets/orchestration-scenarios-template.json +0 -54
- package/skills/modeling-omnistudio-epc-catalog/assets/override-definitions-template.json +0 -134
- package/skills/modeling-omnistudio-epc-catalog/assets/parent-keys-template.json +0 -29
- package/skills/modeling-omnistudio-epc-catalog/assets/price-list-entries-template.json +0 -158
- package/skills/modeling-omnistudio-epc-catalog/assets/pricebook-entries-template.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/assets/product-child-item-template.json +0 -338
- package/skills/modeling-omnistudio-epc-catalog/assets/product2-offer-template.json +0 -527
- package/skills/modeling-omnistudio-epc-catalog/examples/.gitkeep +0 -1
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_AttributeAssignments.json +0 -95
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_CompiledAttributeOverrides.json +0 -1
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_DataPack.json +0 -214
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_DecompositionRelationships.json +0 -28
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_ObjectFieldAttributes.json +0 -98
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_OrchestrationScenarios.json +0 -22
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_OverrideDefinitions.json +0 -1
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_ParentKeys.json +0 -13
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_PriceListEntries.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_PricebookEntries.json +0 -28
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_ProductChildItems.json +0 -110
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/TRANSCRIPT.md +0 -58
- package/skills/modeling-omnistudio-epc-catalog/references/epc-field-guide.md +0 -90
- package/skills/modeling-omnistudio-epc-catalog/references/naming-conventions.md +0 -80
- package/skills/modeling-omnistudio-epc-catalog/references/scoring-model.md +0 -57
- package/skills/modeling-omnistudio-epc-catalog/scripts/cli-validation-commands.sh +0 -19
- package/skills/modeling-omnistudio-epc-catalog/scripts/sample-invocations.sh +0 -18
- package/skills/observing-agentforce/SKILL.md +0 -366
- package/skills/observing-agentforce/apex/AgentforceOptimizeService.cls +0 -1262
- package/skills/observing-agentforce/apex/AgentforceOptimizeService.cls-meta.xml +0 -5
- package/skills/observing-agentforce/references/improve-reference.md +0 -359
- package/skills/observing-agentforce/references/issue-classification.md +0 -220
- package/skills/observing-agentforce/references/reproduce-reference.md +0 -131
- package/skills/observing-agentforce/references/stdm-queries.md +0 -373
- package/skills/observing-agentforce/references/stdm-schema.md +0 -189
- package/skills/orchestrating-datacloud/CREDITS.md +0 -15
- package/skills/orchestrating-datacloud/README.md +0 -127
- package/skills/orchestrating-datacloud/SKILL.md +0 -235
- package/skills/orchestrating-datacloud/UPSTREAM.md +0 -45
- package/skills/orchestrating-datacloud/assets/definitions/activation-target.template.json +0 -5
- package/skills/orchestrating-datacloud/assets/definitions/activation.template.json +0 -7
- package/skills/orchestrating-datacloud/assets/definitions/calculated-insight.template.json +0 -7
- package/skills/orchestrating-datacloud/assets/definitions/data-action-target.template.json +0 -5
- package/skills/orchestrating-datacloud/assets/definitions/data-action.template.json +0 -5
- package/skills/orchestrating-datacloud/assets/definitions/data-graph.template.json +0 -21
- package/skills/orchestrating-datacloud/assets/definitions/data-stream.template.json +0 -55
- package/skills/orchestrating-datacloud/assets/definitions/dmo.template.json +0 -17
- package/skills/orchestrating-datacloud/assets/definitions/identity-resolution.template.json +0 -30
- package/skills/orchestrating-datacloud/assets/definitions/mapping.template.json +0 -14
- package/skills/orchestrating-datacloud/assets/definitions/relationship.template.json +0 -12
- package/skills/orchestrating-datacloud/assets/definitions/search-index.template.json +0 -9
- package/skills/orchestrating-datacloud/assets/definitions/segment.template.json +0 -16
- package/skills/orchestrating-datacloud/references/feature-readiness.md +0 -157
- package/skills/orchestrating-datacloud/references/plugin-setup.md +0 -138
- package/skills/orchestrating-datacloud/scripts/bootstrap-plugin.sh +0 -53
- package/skills/orchestrating-datacloud/scripts/diagnose-org.mjs +0 -511
- package/skills/orchestrating-datacloud/scripts/generate-manifest.mjs +0 -68
- package/skills/orchestrating-datacloud/scripts/verify-plugin.sh +0 -58
- package/skills/platform-agentexchange-partner-offers-enable/SKILL.md +0 -111
- package/skills/platform-agentexchange-partner-offers-enable/assets/org-pref-template.md +0 -27
- package/skills/platform-agentexchange-partner-offers-enable/examples/org-preference-settings.xml +0 -4
- package/skills/preparing-datacloud/CREDITS.md +0 -7
- package/skills/preparing-datacloud/README.md +0 -51
- package/skills/preparing-datacloud/SKILL.md +0 -190
- package/skills/preparing-datacloud/examples/ingestion-api/.env.example +0 -8
- package/skills/preparing-datacloud/examples/ingestion-api/README.md +0 -48
- package/skills/preparing-datacloud/examples/ingestion-api/send-data.py +0 -144
- package/skills/querying-soql/CREDITS.md +0 -21
- package/skills/querying-soql/README.md +0 -41
- package/skills/querying-soql/SKILL.md +0 -142
- package/skills/querying-soql/assets/aggregate-queries.soql +0 -242
- package/skills/querying-soql/assets/basic-queries.soql +0 -188
- package/skills/querying-soql/assets/bulkified-query-pattern.cls +0 -280
- package/skills/querying-soql/assets/optimization-patterns.soql +0 -259
- package/skills/querying-soql/assets/relationship-queries.soql +0 -203
- package/skills/querying-soql/assets/selector-class.cls +0 -219
- package/skills/querying-soql/references/anti-patterns.md +0 -348
- package/skills/querying-soql/references/cli-commands.md +0 -358
- package/skills/querying-soql/references/field-coverage-rules.md +0 -514
- package/skills/querying-soql/references/query-optimization.md +0 -142
- package/skills/querying-soql/references/selector-patterns.md +0 -479
- package/skills/querying-soql/references/soql-reference.md +0 -227
- package/skills/querying-soql/references/soql-syntax-reference.md +0 -208
- package/skills/querying-soql/scripts/post-tool-validate.py +0 -322
- package/skills/retrieving-datacloud/CREDITS.md +0 -7
- package/skills/retrieving-datacloud/README.md +0 -44
- package/skills/retrieving-datacloud/SKILL.md +0 -119
- package/skills/retrieving-datacloud/examples/search-indexes/hybrid-structured.json +0 -44
- package/skills/retrieving-datacloud/examples/search-indexes/vector-knowledge.json +0 -43
- package/skills/reviewing-lwc-mobile-offline/SKILL.md +0 -167
- package/skills/reviewing-lwc-mobile-offline/references/grounding.md +0 -7
- package/skills/reviewing-lwc-mobile-offline/references/inline-graphql.md +0 -43
- package/skills/reviewing-lwc-mobile-offline/references/komaci-eslint.md +0 -125
- package/skills/reviewing-lwc-mobile-offline/references/lwc-if.md +0 -78
- package/skills/reviewing-lwc-mobile-offline/scripts/komaci.config.mjs +0 -18
- package/skills/reviewing-lwc-mobile-offline/scripts/package.json +0 -10
- package/skills/reviewing-lwc-mobile-offline/scripts/run-komaci.sh +0 -69
- package/skills/running-apex-tests/CREDITS.md +0 -22
- package/skills/running-apex-tests/README.md +0 -94
- package/skills/running-apex-tests/SKILL.md +0 -157
- package/skills/running-apex-tests/assets/basic-test.cls +0 -169
- package/skills/running-apex-tests/assets/bulk-test.cls +0 -255
- package/skills/running-apex-tests/assets/dml-mock.cls +0 -339
- package/skills/running-apex-tests/assets/mock-callout-test.cls +0 -353
- package/skills/running-apex-tests/assets/stub-provider-example.cls +0 -364
- package/skills/running-apex-tests/assets/test-data-factory.cls +0 -328
- package/skills/running-apex-tests/hooks/scripts/parse-test-results.py +0 -364
- package/skills/running-apex-tests/references/cli-commands.md +0 -289
- package/skills/running-apex-tests/references/mocking-patterns.md +0 -500
- package/skills/running-apex-tests/references/performance-optimization.md +0 -283
- package/skills/running-apex-tests/references/test-fix-loop.md +0 -49
- package/skills/running-apex-tests/references/test-patterns.md +0 -154
- package/skills/running-apex-tests/references/testing-best-practices.md +0 -509
- package/skills/running-code-analyzer/SKILL.md +0 -495
- package/skills/running-code-analyzer/examples/README.md +0 -38
- package/skills/running-code-analyzer/examples/basic-scan-output.json +0 -92
- package/skills/running-code-analyzer/examples/command-variations.md +0 -333
- package/skills/running-code-analyzer/examples/fix-application-before-after.md +0 -142
- package/skills/running-code-analyzer/examples/large-scan-output.json +0 -67
- package/skills/running-code-analyzer/examples/security-focused-output.json +0 -95
- package/skills/running-code-analyzer/references/command-examples.md +0 -27
- package/skills/running-code-analyzer/references/engine-reference.md +0 -34
- package/skills/running-code-analyzer/references/error-handling.md +0 -29
- package/skills/running-code-analyzer/references/flag-reference.md +0 -96
- package/skills/running-code-analyzer/references/post-scan-workflows.md +0 -286
- package/skills/running-code-analyzer/references/quick-start.md +0 -28
- package/skills/running-code-analyzer/references/special-behaviors.md +0 -83
- package/skills/running-code-analyzer/references/vendor-file-handling.md +0 -239
- package/skills/running-code-analyzer/scripts/apply-fixes.js +0 -86
- package/skills/running-code-analyzer/scripts/describe-rule.js +0 -382
- package/skills/running-code-analyzer/scripts/discover-fixes.js +0 -34
- package/skills/running-code-analyzer/scripts/filter-violations.js +0 -405
- package/skills/running-code-analyzer/scripts/list-rules.js +0 -260
- package/skills/running-code-analyzer/scripts/parse-results.js +0 -59
- package/skills/running-code-analyzer/scripts/query-results.js +0 -230
- package/skills/running-code-analyzer/scripts/summarize-fixes.js +0 -32
- package/skills/running-code-analyzer/scripts/verify-execution.sh +0 -28
- package/skills/searching-media/SKILL.md +0 -348
- package/skills/segmenting-datacloud/CREDITS.md +0 -3
- package/skills/segmenting-datacloud/README.md +0 -36
- package/skills/segmenting-datacloud/SKILL.md +0 -114
- package/skills/switching-org/SKILL.md +0 -28
- package/skills/testing-agentforce/SKILL.md +0 -333
- package/skills/testing-agentforce/assets/basic-test-spec.yaml +0 -63
- package/skills/testing-agentforce/assets/guardrail-test-spec.yaml +0 -105
- package/skills/testing-agentforce/assets/standard-test-spec.yaml +0 -127
- package/skills/testing-agentforce/references/action-execution.md +0 -241
- package/skills/testing-agentforce/references/batch-testing.md +0 -274
- package/skills/testing-agentforce/references/preview-testing.md +0 -353
- package/skills/testing-agentforce/references/test-report-format.md +0 -160
- package/skills/testing-agentforce/references/troubleshooting.md +0 -73
- package/skills/uplifting-components-to-slds2/SKILL.md +0 -239
- package/skills/uplifting-components-to-slds2/references/color-hooks-decision-guide.md +0 -459
- package/skills/uplifting-components-to-slds2/references/common-patterns.md +0 -87
- package/skills/uplifting-components-to-slds2/references/examples.md +0 -461
- package/skills/uplifting-components-to-slds2/references/migration-checklist.md +0 -67
- package/skills/uplifting-components-to-slds2/references/non-color-hooks-decision-guide.md +0 -333
- package/skills/uplifting-components-to-slds2/references/rule-lwc-token-to-slds-hook.md +0 -135
- package/skills/uplifting-components-to-slds2/references/rule-no-deprecated-tokens-slds1.md +0 -211
- package/skills/uplifting-components-to-slds2/references/rule-no-hardcoded-values.md +0 -160
- package/skills/uplifting-components-to-slds2/references/rule-no-slds-class-overrides.md +0 -126
- package/skills/using-mobile-native-capabilities/SKILL.md +0 -181
- package/skills/using-mobile-native-capabilities/references/app-review.md +0 -68
- package/skills/using-mobile-native-capabilities/references/ar-space-capture.md +0 -125
- package/skills/using-mobile-native-capabilities/references/barcode-scanner.md +0 -219
- package/skills/using-mobile-native-capabilities/references/base-capability.md +0 -22
- package/skills/using-mobile-native-capabilities/references/biometrics.md +0 -90
- package/skills/using-mobile-native-capabilities/references/calendar.md +0 -213
- package/skills/using-mobile-native-capabilities/references/contacts.md +0 -232
- package/skills/using-mobile-native-capabilities/references/document-scanner.md +0 -342
- package/skills/using-mobile-native-capabilities/references/geofencing.md +0 -123
- package/skills/using-mobile-native-capabilities/references/location.md +0 -158
- package/skills/using-mobile-native-capabilities/references/mobile-capabilities.md +0 -30
- package/skills/using-mobile-native-capabilities/references/nfc.md +0 -181
- package/skills/using-mobile-native-capabilities/references/payments.md +0 -95
- package/skills/using-salesforce-archive/SKILL.md +0 -121
- package/skills/using-salesforce-archive/examples/monitor-failed-jobs.md +0 -47
- package/skills/using-salesforce-archive/references/archive-activity-entity.md +0 -59
- package/skills/using-salesforce-archive/references/connect-api-operations.md +0 -157
- package/skills/using-ui-bundle-salesforce-data/SKILL.md +0 -638
- package/skills/using-ui-bundle-salesforce-data/scripts/graphql-search.sh +0 -191
- package/skills/validating-slds/SKILL.md +0 -262
- package/skills/validating-slds/references/quality-checks.md +0 -308
- package/skills/validating-slds/references/report-format.md +0 -302
- package/skills/validating-slds/scripts/analyze-quality.cjs +0 -521
|
@@ -1,1476 +0,0 @@
|
|
|
1
|
-
<!-- Parent: generating-lwc-components/SKILL.md -->
|
|
2
|
-
# LWC Component Patterns
|
|
3
|
-
|
|
4
|
-
Comprehensive code examples for common Lightning Web Component patterns.
|
|
5
|
-
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
## Table of Contents
|
|
9
|
-
|
|
10
|
-
1. [PICKLES Framework Details](#pickles-framework-details)
|
|
11
|
-
2. [Wire Service Patterns](#wire-service-patterns)
|
|
12
|
-
- [Wire vs Imperative Apex Calls](#wire-vs-imperative-apex-calls)
|
|
13
|
-
3. [GraphQL Patterns](#graphql-patterns)
|
|
14
|
-
4. [Modal Component Pattern](#modal-component-pattern)
|
|
15
|
-
5. [Record Picker Pattern](#record-picker-pattern)
|
|
16
|
-
6. [Workspace API Pattern](#workspace-api-pattern)
|
|
17
|
-
7. [Parent-Child Communication](#parent-child-communication)
|
|
18
|
-
8. [Sibling Communication (via Parent)](#sibling-communication-via-parent)
|
|
19
|
-
9. [Navigation Patterns](#navigation-patterns)
|
|
20
|
-
10. [TypeScript Patterns](#typescript-patterns)
|
|
21
|
-
11. [Apex Controller Patterns](#apex-controller-patterns)
|
|
22
|
-
|
|
23
|
-
---
|
|
24
|
-
|
|
25
|
-
## PICKLES Framework Details
|
|
26
|
-
|
|
27
|
-
### P - Prototype
|
|
28
|
-
|
|
29
|
-
**Purpose**: Validate ideas early before full implementation.
|
|
30
|
-
|
|
31
|
-
| Action | Description |
|
|
32
|
-
|--------|-------------|
|
|
33
|
-
| Wireframe | Create high-level component sketches |
|
|
34
|
-
| Mock Data | Use sample data to test functionality |
|
|
35
|
-
| Stakeholder Review | Gather feedback before development |
|
|
36
|
-
| Separation of Concerns | Break into smaller functional pieces |
|
|
37
|
-
|
|
38
|
-
```javascript
|
|
39
|
-
// Mock data pattern for prototyping
|
|
40
|
-
const MOCK_ACCOUNTS = [
|
|
41
|
-
{ Id: '001MOCK001', Name: 'Acme Corp', Industry: 'Technology' },
|
|
42
|
-
{ Id: '001MOCK002', Name: 'Global Inc', Industry: 'Finance' }
|
|
43
|
-
];
|
|
44
|
-
|
|
45
|
-
export default class AccountPrototype extends LightningElement {
|
|
46
|
-
accounts = MOCK_ACCOUNTS; // Replace with wire/Apex later
|
|
47
|
-
}
|
|
48
|
-
```
|
|
49
|
-
|
|
50
|
-
### I - Integrate
|
|
51
|
-
|
|
52
|
-
**Purpose**: Determine how components interact with data systems.
|
|
53
|
-
|
|
54
|
-
**Integration Checklist**:
|
|
55
|
-
- [ ] Implement error handling with clear user notifications
|
|
56
|
-
- [ ] Add loading spinners to prevent duplicate requests
|
|
57
|
-
- [ ] Use LDS for single-object operations (minimizes DML)
|
|
58
|
-
- [ ] Respect FLS and CRUD in Apex implementations
|
|
59
|
-
- [ ] Store `wiredResult` for `refreshApex()` support
|
|
60
|
-
|
|
61
|
-
### C - Composition
|
|
62
|
-
|
|
63
|
-
**Purpose**: Structure how LWCs nest and communicate.
|
|
64
|
-
|
|
65
|
-
**Best Practices**:
|
|
66
|
-
- Maintain shallow component hierarchies (max 3-4 levels)
|
|
67
|
-
- Single responsibility per component
|
|
68
|
-
- Clean up subscriptions in `disconnectedCallback()`
|
|
69
|
-
- Use custom events purposefully, not for every interaction
|
|
70
|
-
|
|
71
|
-
```javascript
|
|
72
|
-
// Parent-managed composition pattern
|
|
73
|
-
// parent.js
|
|
74
|
-
handleChildEvent(event) {
|
|
75
|
-
this.selectedId = event.detail.id;
|
|
76
|
-
// Update child via @api
|
|
77
|
-
this.template.querySelector('c-child').selectedId = this.selectedId;
|
|
78
|
-
}
|
|
79
|
-
```
|
|
80
|
-
|
|
81
|
-
### K - Kinetics
|
|
82
|
-
|
|
83
|
-
**Purpose**: Manage user interaction and event responsiveness.
|
|
84
|
-
|
|
85
|
-
```javascript
|
|
86
|
-
// Debounce pattern for search
|
|
87
|
-
delayTimeout;
|
|
88
|
-
|
|
89
|
-
handleSearchChange(event) {
|
|
90
|
-
const searchTerm = event.target.value;
|
|
91
|
-
clearTimeout(this.delayTimeout);
|
|
92
|
-
this.delayTimeout = setTimeout(() => {
|
|
93
|
-
this.dispatchEvent(new CustomEvent('search', {
|
|
94
|
-
detail: { searchTerm }
|
|
95
|
-
}));
|
|
96
|
-
}, 300);
|
|
97
|
-
}
|
|
98
|
-
```
|
|
99
|
-
|
|
100
|
-
### L - Libraries
|
|
101
|
-
|
|
102
|
-
**Purpose**: Leverage Salesforce-provided and platform tools.
|
|
103
|
-
|
|
104
|
-
**Recommended Platform Features**:
|
|
105
|
-
|
|
106
|
-
| API/Module | Use Case |
|
|
107
|
-
|------------|----------|
|
|
108
|
-
| `lightning/navigation` | Page/record navigation |
|
|
109
|
-
| `lightning/uiRecordApi` | LDS operations (getRecord, updateRecord) |
|
|
110
|
-
| `lightning/platformShowToastEvent` | User notifications |
|
|
111
|
-
| `lightning/modal` | Native modal dialogs |
|
|
112
|
-
| Base Components | Pre-built UI (button, input, datatable) |
|
|
113
|
-
| `lightning/refresh` | Dispatch refresh events |
|
|
114
|
-
|
|
115
|
-
**Avoid reinventing** what base components already provide!
|
|
116
|
-
|
|
117
|
-
### E - Execution
|
|
118
|
-
|
|
119
|
-
**Purpose**: Optimize performance and resource efficiency.
|
|
120
|
-
|
|
121
|
-
**Performance Checklist**:
|
|
122
|
-
- [ ] Lazy load with `if:true` / `lwc:if`
|
|
123
|
-
- [ ] Use `key` directive in iterations
|
|
124
|
-
- [ ] Cache computed values in getters
|
|
125
|
-
- [ ] Avoid property updates that trigger re-renders
|
|
126
|
-
- [ ] Use browser DevTools Performance tab
|
|
127
|
-
|
|
128
|
-
### S - Security
|
|
129
|
-
|
|
130
|
-
**Purpose**: Enforce access control and data protection.
|
|
131
|
-
|
|
132
|
-
```apex
|
|
133
|
-
// Secure Apex pattern
|
|
134
|
-
@AuraEnabled(cacheable=true)
|
|
135
|
-
public static List<Account> getAccounts(String searchTerm) {
|
|
136
|
-
String searchKey = '%' + String.escapeSingleQuotes(searchTerm) + '%';
|
|
137
|
-
return [
|
|
138
|
-
SELECT Id, Name, Industry
|
|
139
|
-
FROM Account
|
|
140
|
-
WHERE Name LIKE :searchKey
|
|
141
|
-
WITH SECURITY_ENFORCED
|
|
142
|
-
LIMIT 50
|
|
143
|
-
];
|
|
144
|
-
}
|
|
145
|
-
```
|
|
146
|
-
|
|
147
|
-
---
|
|
148
|
-
|
|
149
|
-
## Wire Service Patterns
|
|
150
|
-
|
|
151
|
-
### Wire vs Imperative Apex Calls
|
|
152
|
-
|
|
153
|
-
LWC can interact with Apex in two ways: **@wire** (reactive/declarative) and **imperative calls** (manual/programmatic). Understanding when to use each is critical for building performant, maintainable components.
|
|
154
|
-
|
|
155
|
-
#### Quick Comparison
|
|
156
|
-
|
|
157
|
-
```
|
|
158
|
-
┌─────────────────────────────────────────────────────────────────────────────────────┐
|
|
159
|
-
│ WIRE vs IMPERATIVE APEX CALLS │
|
|
160
|
-
├──────────────────┬──────────────────────────────┬────────────────────────────────────┤
|
|
161
|
-
│ Aspect │ Wire (@wire) │ Imperative Calls │
|
|
162
|
-
├──────────────────┼──────────────────────────────┼────────────────────────────────────┤
|
|
163
|
-
│ Execution │ Automatic / Reactive │ Manual / Programmatic │
|
|
164
|
-
│ DML Operations │ ❌ Read-Only │ ✅ Insert / Update / Delete │
|
|
165
|
-
│ Data Updates │ ✅ Auto on Parameter Change │ ❌ Manual Refresh Required │
|
|
166
|
-
│ Control │ ⚠️ Low (framework decides) │ ✅ Full (you decide when/how) │
|
|
167
|
-
│ Error Handling │ ✅ Framework Managed │ ⚠️ Developer Managed │
|
|
168
|
-
│ Supported Objects│ ⚠️ UI API Only │ ✅ All Objects │
|
|
169
|
-
│ Caching │ ✅ Built-in (cacheable=true) │ ❌ No automatic caching │
|
|
170
|
-
└──────────────────┴──────────────────────────────┴────────────────────────────────────┘
|
|
171
|
-
```
|
|
172
|
-
|
|
173
|
-
#### Pros & Cons
|
|
174
|
-
|
|
175
|
-
| Wire (@wire) | Imperative Calls |
|
|
176
|
-
|--------------|------------------|
|
|
177
|
-
| ✅ Auto UI sync & caching | ✅ Supports DML & all objects |
|
|
178
|
-
| ✅ Less boilerplate code | ✅ Full control over timing |
|
|
179
|
-
| ✅ Reactive to parameter changes | ✅ Can handle complex logic |
|
|
180
|
-
| ❌ Read-only, limited objects | ❌ Manual handling, no auto refresh |
|
|
181
|
-
| ❌ Can't control execution timing | ❌ More error handling code needed |
|
|
182
|
-
|
|
183
|
-
#### When to Use Each
|
|
184
|
-
|
|
185
|
-
**Use Wire (@wire) when:**
|
|
186
|
-
- 📌 Read-only data display
|
|
187
|
-
- 📌 Auto-refresh UI when parameters change
|
|
188
|
-
- 📌 Stable parameters (recordId, filter values)
|
|
189
|
-
- 📌 Working with UI API supported objects
|
|
190
|
-
|
|
191
|
-
**Use Imperative Calls when:**
|
|
192
|
-
- 📌 User actions (clicks, form submissions)
|
|
193
|
-
- 📌 DML operations (Insert, Update, Delete)
|
|
194
|
-
- 📌 Dynamic parameters determined at runtime
|
|
195
|
-
- 📌 Custom objects or complex queries
|
|
196
|
-
- 📌 Need control over execution timing
|
|
197
|
-
|
|
198
|
-
#### Side-by-Side Code Examples
|
|
199
|
-
|
|
200
|
-
**Wire Example** - Data loads automatically when `selectedIndustry` changes:
|
|
201
|
-
|
|
202
|
-
```javascript
|
|
203
|
-
import { LightningElement, wire } from 'lwc';
|
|
204
|
-
import fetchAccounts from '@salesforce/apex/AccountController.fetchAccounts';
|
|
205
|
-
|
|
206
|
-
export default class WireExample extends LightningElement {
|
|
207
|
-
selectedIndustry = 'Technology';
|
|
208
|
-
accounts;
|
|
209
|
-
error;
|
|
210
|
-
|
|
211
|
-
// Automatically re-fetches when selectedIndustry changes
|
|
212
|
-
@wire(fetchAccounts, { industry: '$selectedIndustry' })
|
|
213
|
-
wiredAccounts({ data, error }) {
|
|
214
|
-
if (data) {
|
|
215
|
-
this.accounts = data;
|
|
216
|
-
this.error = undefined;
|
|
217
|
-
} else if (error) {
|
|
218
|
-
this.error = error;
|
|
219
|
-
this.accounts = undefined;
|
|
220
|
-
}
|
|
221
|
-
}
|
|
222
|
-
}
|
|
223
|
-
```
|
|
224
|
-
|
|
225
|
-
**Imperative Example** - Data loads only when user triggers action:
|
|
226
|
-
|
|
227
|
-
```javascript
|
|
228
|
-
import { LightningElement } from 'lwc';
|
|
229
|
-
import fetchAccounts from '@salesforce/apex/AccountController.fetchAccounts';
|
|
230
|
-
|
|
231
|
-
export default class ImperativeExample extends LightningElement {
|
|
232
|
-
selectedIndustry = 'Technology';
|
|
233
|
-
accounts;
|
|
234
|
-
error;
|
|
235
|
-
isLoading = false;
|
|
236
|
-
|
|
237
|
-
// Called explicitly when user clicks button or submits form
|
|
238
|
-
async fetchAccounts() {
|
|
239
|
-
this.isLoading = true;
|
|
240
|
-
try {
|
|
241
|
-
this.accounts = await fetchAccounts({
|
|
242
|
-
industry: this.selectedIndustry
|
|
243
|
-
});
|
|
244
|
-
this.error = undefined;
|
|
245
|
-
} catch (error) {
|
|
246
|
-
this.error = error;
|
|
247
|
-
this.accounts = undefined;
|
|
248
|
-
} finally {
|
|
249
|
-
this.isLoading = false;
|
|
250
|
-
}
|
|
251
|
-
}
|
|
252
|
-
}
|
|
253
|
-
```
|
|
254
|
-
|
|
255
|
-
#### Decision Tree
|
|
256
|
-
|
|
257
|
-
```
|
|
258
|
-
┌─────────────────────────────┐
|
|
259
|
-
│ Need to modify data? │
|
|
260
|
-
│ (Insert/Update/Delete) │
|
|
261
|
-
└─────────────┬───────────────┘
|
|
262
|
-
│
|
|
263
|
-
┌─────────────┴───────────────┐
|
|
264
|
-
│ │
|
|
265
|
-
YES NO
|
|
266
|
-
│ │
|
|
267
|
-
▼ ▼
|
|
268
|
-
┌─────────────────┐ ┌─────────────────────────┐
|
|
269
|
-
│ IMPERATIVE │ │ Should data auto- │
|
|
270
|
-
│ (Use await) │ │ refresh on param │
|
|
271
|
-
└─────────────────┘ │ change? │
|
|
272
|
-
└───────────┬─────────────┘
|
|
273
|
-
│
|
|
274
|
-
┌───────────┴───────────┐
|
|
275
|
-
│ │
|
|
276
|
-
YES NO
|
|
277
|
-
│ │
|
|
278
|
-
▼ ▼
|
|
279
|
-
┌─────────────────┐ ┌─────────────────┐
|
|
280
|
-
│ @WIRE │ │ IMPERATIVE │
|
|
281
|
-
│ (Reactive) │ │ (On-demand) │
|
|
282
|
-
└─────────────────┘ └─────────────────┘
|
|
283
|
-
```
|
|
284
|
-
|
|
285
|
-
---
|
|
286
|
-
|
|
287
|
-
### 1. Basic Data Display (Wire Service)
|
|
288
|
-
|
|
289
|
-
```javascript
|
|
290
|
-
// accountCard.js
|
|
291
|
-
import { LightningElement, api, wire } from 'lwc';
|
|
292
|
-
import { getRecord, getFieldValue } from 'lightning/uiRecordApi';
|
|
293
|
-
import NAME_FIELD from '@salesforce/schema/Account.Name';
|
|
294
|
-
import INDUSTRY_FIELD from '@salesforce/schema/Account.Industry';
|
|
295
|
-
|
|
296
|
-
const FIELDS = [NAME_FIELD, INDUSTRY_FIELD];
|
|
297
|
-
|
|
298
|
-
export default class AccountCard extends LightningElement {
|
|
299
|
-
@api recordId;
|
|
300
|
-
|
|
301
|
-
@wire(getRecord, { recordId: '$recordId', fields: FIELDS })
|
|
302
|
-
account;
|
|
303
|
-
|
|
304
|
-
get name() {
|
|
305
|
-
return getFieldValue(this.account.data, NAME_FIELD);
|
|
306
|
-
}
|
|
307
|
-
|
|
308
|
-
get industry() {
|
|
309
|
-
return getFieldValue(this.account.data, INDUSTRY_FIELD);
|
|
310
|
-
}
|
|
311
|
-
|
|
312
|
-
get isLoading() {
|
|
313
|
-
return !this.account.data && !this.account.error;
|
|
314
|
-
}
|
|
315
|
-
}
|
|
316
|
-
```
|
|
317
|
-
|
|
318
|
-
```html
|
|
319
|
-
<!-- accountCard.html -->
|
|
320
|
-
<template>
|
|
321
|
-
<template lwc:if={isLoading}>
|
|
322
|
-
<lightning-spinner alternative-text="Loading"></lightning-spinner>
|
|
323
|
-
</template>
|
|
324
|
-
<template lwc:if={account.data}>
|
|
325
|
-
<div class="slds-box slds-theme_default">
|
|
326
|
-
<h2 class="slds-text-heading_medium">{name}</h2>
|
|
327
|
-
<p class="slds-text-color_weak">{industry}</p>
|
|
328
|
-
</div>
|
|
329
|
-
</template>
|
|
330
|
-
<template lwc:if={account.error}>
|
|
331
|
-
<p class="slds-text-color_error">{account.error.body.message}</p>
|
|
332
|
-
</template>
|
|
333
|
-
</template>
|
|
334
|
-
```
|
|
335
|
-
|
|
336
|
-
### 2. Wire Service with Apex
|
|
337
|
-
|
|
338
|
-
```javascript
|
|
339
|
-
// contactList.js
|
|
340
|
-
import { LightningElement, api, wire } from 'lwc';
|
|
341
|
-
import getContacts from '@salesforce/apex/ContactController.getContacts';
|
|
342
|
-
import { refreshApex } from '@salesforce/apex';
|
|
343
|
-
|
|
344
|
-
export default class ContactList extends LightningElement {
|
|
345
|
-
@api recordId;
|
|
346
|
-
contacts;
|
|
347
|
-
error;
|
|
348
|
-
wiredContactsResult;
|
|
349
|
-
|
|
350
|
-
@wire(getContacts, { accountId: '$recordId' })
|
|
351
|
-
wiredContacts(result) {
|
|
352
|
-
this.wiredContactsResult = result; // Store for refreshApex
|
|
353
|
-
const { error, data } = result;
|
|
354
|
-
if (data) {
|
|
355
|
-
this.contacts = data;
|
|
356
|
-
this.error = undefined;
|
|
357
|
-
} else if (error) {
|
|
358
|
-
this.error = error;
|
|
359
|
-
this.contacts = undefined;
|
|
360
|
-
}
|
|
361
|
-
}
|
|
362
|
-
|
|
363
|
-
async handleRefresh() {
|
|
364
|
-
await refreshApex(this.wiredContactsResult);
|
|
365
|
-
}
|
|
366
|
-
}
|
|
367
|
-
```
|
|
368
|
-
|
|
369
|
-
---
|
|
370
|
-
|
|
371
|
-
## GraphQL Patterns
|
|
372
|
-
|
|
373
|
-
> **Module Note**: `lightning/graphql` supersedes `lightning/uiGraphQLApi` and provides newer features like mutations, optional fields, and dynamic query construction.
|
|
374
|
-
|
|
375
|
-
### GraphQL Query (Wire Adapter)
|
|
376
|
-
|
|
377
|
-
```javascript
|
|
378
|
-
// graphqlContacts.js
|
|
379
|
-
import { LightningElement, wire } from 'lwc';
|
|
380
|
-
import { gql, graphql } from 'lightning/graphql';
|
|
381
|
-
|
|
382
|
-
const CONTACTS_QUERY = gql`
|
|
383
|
-
query ContactsQuery($first: Int, $after: String) {
|
|
384
|
-
uiapi {
|
|
385
|
-
query {
|
|
386
|
-
Contact(first: $first, after: $after) {
|
|
387
|
-
edges {
|
|
388
|
-
node {
|
|
389
|
-
Id
|
|
390
|
-
Name { value }
|
|
391
|
-
Email { value }
|
|
392
|
-
Account {
|
|
393
|
-
Name { value }
|
|
394
|
-
}
|
|
395
|
-
}
|
|
396
|
-
cursor
|
|
397
|
-
}
|
|
398
|
-
pageInfo {
|
|
399
|
-
hasNextPage
|
|
400
|
-
endCursor
|
|
401
|
-
}
|
|
402
|
-
}
|
|
403
|
-
}
|
|
404
|
-
}
|
|
405
|
-
}
|
|
406
|
-
`;
|
|
407
|
-
|
|
408
|
-
export default class GraphqlContacts extends LightningElement {
|
|
409
|
-
contacts;
|
|
410
|
-
pageInfo;
|
|
411
|
-
error;
|
|
412
|
-
_cursor;
|
|
413
|
-
|
|
414
|
-
@wire(graphql, {
|
|
415
|
-
query: CONTACTS_QUERY,
|
|
416
|
-
variables: '$queryVariables'
|
|
417
|
-
})
|
|
418
|
-
wiredContacts({ data, error }) {
|
|
419
|
-
if (data) {
|
|
420
|
-
const result = data.uiapi.query.Contact;
|
|
421
|
-
this.contacts = result.edges.map(edge => ({
|
|
422
|
-
id: edge.node.Id,
|
|
423
|
-
name: edge.node.Name.value,
|
|
424
|
-
email: edge.node.Email?.value,
|
|
425
|
-
accountName: edge.node.Account?.Name?.value
|
|
426
|
-
}));
|
|
427
|
-
this.pageInfo = result.pageInfo;
|
|
428
|
-
} else if (error) {
|
|
429
|
-
this.error = error;
|
|
430
|
-
}
|
|
431
|
-
}
|
|
432
|
-
|
|
433
|
-
get queryVariables() {
|
|
434
|
-
return { first: 10, after: this._cursor };
|
|
435
|
-
}
|
|
436
|
-
|
|
437
|
-
loadMore() {
|
|
438
|
-
if (this.pageInfo?.hasNextPage) {
|
|
439
|
-
this._cursor = this.pageInfo.endCursor;
|
|
440
|
-
}
|
|
441
|
-
}
|
|
442
|
-
}
|
|
443
|
-
```
|
|
444
|
-
|
|
445
|
-
### GraphQL Mutations (Spring '26 - GA in API 66.0)
|
|
446
|
-
|
|
447
|
-
Mutations allow create, update, and delete operations via GraphQL. Use `executeMutation` for imperative operations.
|
|
448
|
-
|
|
449
|
-
```javascript
|
|
450
|
-
// graphqlAccountMutation.js
|
|
451
|
-
import { LightningElement, track } from 'lwc';
|
|
452
|
-
import { gql, executeMutation } from 'lightning/graphql';
|
|
453
|
-
import { ShowToastEvent } from 'lightning/platformShowToastEvent';
|
|
454
|
-
|
|
455
|
-
// Create mutation
|
|
456
|
-
const CREATE_ACCOUNT = gql`
|
|
457
|
-
mutation CreateAccount($name: String!, $industry: String) {
|
|
458
|
-
uiapi {
|
|
459
|
-
AccountCreate(input: {
|
|
460
|
-
Account: {
|
|
461
|
-
Name: $name
|
|
462
|
-
Industry: $industry
|
|
463
|
-
}
|
|
464
|
-
}) {
|
|
465
|
-
Record {
|
|
466
|
-
Id
|
|
467
|
-
Name { value }
|
|
468
|
-
Industry { value }
|
|
469
|
-
}
|
|
470
|
-
}
|
|
471
|
-
}
|
|
472
|
-
}
|
|
473
|
-
`;
|
|
474
|
-
|
|
475
|
-
// Update mutation
|
|
476
|
-
const UPDATE_ACCOUNT = gql`
|
|
477
|
-
mutation UpdateAccount($id: ID!, $name: String!) {
|
|
478
|
-
uiapi {
|
|
479
|
-
AccountUpdate(input: {
|
|
480
|
-
Account: {
|
|
481
|
-
Id: $id
|
|
482
|
-
Name: $name
|
|
483
|
-
}
|
|
484
|
-
}) {
|
|
485
|
-
Record {
|
|
486
|
-
Id
|
|
487
|
-
Name { value }
|
|
488
|
-
}
|
|
489
|
-
}
|
|
490
|
-
}
|
|
491
|
-
}
|
|
492
|
-
`;
|
|
493
|
-
|
|
494
|
-
// Delete mutation
|
|
495
|
-
const DELETE_ACCOUNT = gql`
|
|
496
|
-
mutation DeleteAccount($id: ID!) {
|
|
497
|
-
uiapi {
|
|
498
|
-
AccountDelete(input: { Account: { Id: $id } }) {
|
|
499
|
-
Id
|
|
500
|
-
}
|
|
501
|
-
}
|
|
502
|
-
}
|
|
503
|
-
`;
|
|
504
|
-
|
|
505
|
-
export default class GraphqlAccountMutation extends LightningElement {
|
|
506
|
-
@track accountName = '';
|
|
507
|
-
@track industry = '';
|
|
508
|
-
isLoading = false;
|
|
509
|
-
|
|
510
|
-
handleNameChange(event) {
|
|
511
|
-
this.accountName = event.target.value;
|
|
512
|
-
}
|
|
513
|
-
|
|
514
|
-
handleIndustryChange(event) {
|
|
515
|
-
this.industry = event.target.value;
|
|
516
|
-
}
|
|
517
|
-
|
|
518
|
-
async handleCreate() {
|
|
519
|
-
if (!this.accountName) return;
|
|
520
|
-
|
|
521
|
-
this.isLoading = true;
|
|
522
|
-
try {
|
|
523
|
-
const result = await executeMutation(CREATE_ACCOUNT, {
|
|
524
|
-
variables: {
|
|
525
|
-
name: this.accountName,
|
|
526
|
-
industry: this.industry || null
|
|
527
|
-
}
|
|
528
|
-
});
|
|
529
|
-
|
|
530
|
-
const newRecord = result.data.uiapi.AccountCreate.Record;
|
|
531
|
-
this.showToast('Success', `Account "${newRecord.Name.value}" created`, 'success');
|
|
532
|
-
this.resetForm();
|
|
533
|
-
} catch (error) {
|
|
534
|
-
this.handleError(error);
|
|
535
|
-
} finally {
|
|
536
|
-
this.isLoading = false;
|
|
537
|
-
}
|
|
538
|
-
}
|
|
539
|
-
|
|
540
|
-
async handleUpdate(accountId, newName) {
|
|
541
|
-
try {
|
|
542
|
-
const result = await executeMutation(UPDATE_ACCOUNT, {
|
|
543
|
-
variables: { id: accountId, name: newName }
|
|
544
|
-
});
|
|
545
|
-
this.showToast('Success', 'Account updated', 'success');
|
|
546
|
-
return result.data.uiapi.AccountUpdate.Record;
|
|
547
|
-
} catch (error) {
|
|
548
|
-
this.handleError(error);
|
|
549
|
-
}
|
|
550
|
-
}
|
|
551
|
-
|
|
552
|
-
async handleDelete(accountId) {
|
|
553
|
-
try {
|
|
554
|
-
await executeMutation(DELETE_ACCOUNT, {
|
|
555
|
-
variables: { id: accountId }
|
|
556
|
-
});
|
|
557
|
-
this.showToast('Success', 'Account deleted', 'success');
|
|
558
|
-
} catch (error) {
|
|
559
|
-
this.handleError(error);
|
|
560
|
-
}
|
|
561
|
-
}
|
|
562
|
-
|
|
563
|
-
handleError(error) {
|
|
564
|
-
const message = error.graphQLErrors
|
|
565
|
-
? error.graphQLErrors.map(e => e.message).join(', ')
|
|
566
|
-
: error.message || 'Unknown error';
|
|
567
|
-
this.showToast('Error', message, 'error');
|
|
568
|
-
}
|
|
569
|
-
|
|
570
|
-
showToast(title, message, variant) {
|
|
571
|
-
this.dispatchEvent(new ShowToastEvent({ title, message, variant }));
|
|
572
|
-
}
|
|
573
|
-
|
|
574
|
-
resetForm() {
|
|
575
|
-
this.accountName = '';
|
|
576
|
-
this.industry = '';
|
|
577
|
-
}
|
|
578
|
-
}
|
|
579
|
-
```
|
|
580
|
-
|
|
581
|
-
### GraphQL Mutation Operations
|
|
582
|
-
|
|
583
|
-
| Operation | Mutation Type | Notes |
|
|
584
|
-
|-----------|---------------|-------|
|
|
585
|
-
| **Create** | `{Object}Create` | Can request fields from newly created record |
|
|
586
|
-
| **Update** | `{Object}Update` | Cannot query fields in same request |
|
|
587
|
-
| **Delete** | `{Object}Delete` | Cannot query fields in same request |
|
|
588
|
-
|
|
589
|
-
### allOrNone Parameter
|
|
590
|
-
|
|
591
|
-
Control transaction behavior with `allOrNone` (default: `true`):
|
|
592
|
-
|
|
593
|
-
```javascript
|
|
594
|
-
const BATCH_CREATE = gql`
|
|
595
|
-
mutation BatchCreate($allOrNone: Boolean = true) {
|
|
596
|
-
uiapi(allOrNone: $allOrNone) {
|
|
597
|
-
acc1: AccountCreate(input: { Account: { Name: "Account 1" } }) {
|
|
598
|
-
Record { Id }
|
|
599
|
-
}
|
|
600
|
-
acc2: AccountCreate(input: { Account: { Name: "Account 2" } }) {
|
|
601
|
-
Record { Id }
|
|
602
|
-
}
|
|
603
|
-
}
|
|
604
|
-
}
|
|
605
|
-
`;
|
|
606
|
-
|
|
607
|
-
// If allOrNone=true: All rollback if any fails
|
|
608
|
-
// If allOrNone=false: Only failed operations rollback
|
|
609
|
-
```
|
|
610
|
-
|
|
611
|
-
---
|
|
612
|
-
|
|
613
|
-
## Modal Component Pattern
|
|
614
|
-
|
|
615
|
-
Based on [James Simone's composable modal pattern](https://www.jamessimone.net/blog/joys-of-apex/lwc-composable-modal/).
|
|
616
|
-
|
|
617
|
-
```javascript
|
|
618
|
-
// composableModal.js
|
|
619
|
-
import { LightningElement, api } from 'lwc';
|
|
620
|
-
|
|
621
|
-
const OUTER_MODAL_CLASS = 'outerModalContent';
|
|
622
|
-
|
|
623
|
-
export default class ComposableModal extends LightningElement {
|
|
624
|
-
@api modalHeader;
|
|
625
|
-
@api modalTagline;
|
|
626
|
-
@api modalSaveHandler;
|
|
627
|
-
|
|
628
|
-
_isOpen = false;
|
|
629
|
-
_focusableElements = [];
|
|
630
|
-
|
|
631
|
-
@api
|
|
632
|
-
toggleModal() {
|
|
633
|
-
this._isOpen = !this._isOpen;
|
|
634
|
-
if (this._isOpen) {
|
|
635
|
-
this._focusableElements = [...this.querySelectorAll('.focusable')];
|
|
636
|
-
this._focusFirstElement();
|
|
637
|
-
window.addEventListener('keyup', this._handleKeyUp);
|
|
638
|
-
} else {
|
|
639
|
-
window.removeEventListener('keyup', this._handleKeyUp);
|
|
640
|
-
}
|
|
641
|
-
}
|
|
642
|
-
|
|
643
|
-
get modalAriaHidden() {
|
|
644
|
-
return !this._isOpen;
|
|
645
|
-
}
|
|
646
|
-
|
|
647
|
-
get modalClass() {
|
|
648
|
-
return this._isOpen
|
|
649
|
-
? 'slds-modal slds-visible slds-fade-in-open'
|
|
650
|
-
: 'slds-modal slds-hidden';
|
|
651
|
-
}
|
|
652
|
-
|
|
653
|
-
get backdropClass() {
|
|
654
|
-
return this._isOpen ? 'slds-backdrop slds-backdrop_open' : 'slds-backdrop';
|
|
655
|
-
}
|
|
656
|
-
|
|
657
|
-
_handleKeyUp = (event) => {
|
|
658
|
-
if (event.code === 'Escape') {
|
|
659
|
-
this.toggleModal();
|
|
660
|
-
} else if (event.code === 'Tab') {
|
|
661
|
-
this._handleTabNavigation(event);
|
|
662
|
-
}
|
|
663
|
-
}
|
|
664
|
-
|
|
665
|
-
_handleTabNavigation(event) {
|
|
666
|
-
// Focus trap logic - keep focus within modal
|
|
667
|
-
const activeEl = this.template.activeElement;
|
|
668
|
-
const lastIndex = this._focusableElements.length - 1;
|
|
669
|
-
const currentIndex = this._focusableElements.indexOf(activeEl);
|
|
670
|
-
|
|
671
|
-
if (event.shiftKey && currentIndex === 0) {
|
|
672
|
-
this._focusableElements[lastIndex]?.focus();
|
|
673
|
-
} else if (!event.shiftKey && currentIndex === lastIndex) {
|
|
674
|
-
this._focusFirstElement();
|
|
675
|
-
}
|
|
676
|
-
}
|
|
677
|
-
|
|
678
|
-
_focusFirstElement() {
|
|
679
|
-
if (this._focusableElements.length > 0) {
|
|
680
|
-
this._focusableElements[0].focus();
|
|
681
|
-
}
|
|
682
|
-
}
|
|
683
|
-
|
|
684
|
-
handleBackdropClick(event) {
|
|
685
|
-
if (event.target.classList.contains(OUTER_MODAL_CLASS)) {
|
|
686
|
-
this.toggleModal();
|
|
687
|
-
}
|
|
688
|
-
}
|
|
689
|
-
|
|
690
|
-
handleSave() {
|
|
691
|
-
if (this.modalSaveHandler) {
|
|
692
|
-
this.modalSaveHandler();
|
|
693
|
-
}
|
|
694
|
-
this.toggleModal();
|
|
695
|
-
}
|
|
696
|
-
|
|
697
|
-
disconnectedCallback() {
|
|
698
|
-
window.removeEventListener('keyup', this._handleKeyUp);
|
|
699
|
-
}
|
|
700
|
-
}
|
|
701
|
-
```
|
|
702
|
-
|
|
703
|
-
```html
|
|
704
|
-
<!-- composableModal.html -->
|
|
705
|
-
<template>
|
|
706
|
-
<!-- Backdrop -->
|
|
707
|
-
<div class={backdropClass}></div>
|
|
708
|
-
|
|
709
|
-
<!-- Modal -->
|
|
710
|
-
<div class={modalClass}
|
|
711
|
-
role="dialog"
|
|
712
|
-
aria-modal="true"
|
|
713
|
-
aria-hidden={modalAriaHidden}
|
|
714
|
-
aria-labelledby="modal-heading">
|
|
715
|
-
|
|
716
|
-
<div class="slds-modal__container outerModalContent"
|
|
717
|
-
onclick={handleBackdropClick}>
|
|
718
|
-
|
|
719
|
-
<div class="slds-modal__content slds-p-around_medium">
|
|
720
|
-
<!-- Header -->
|
|
721
|
-
<template lwc:if={modalHeader}>
|
|
722
|
-
<h2 id="modal-heading" class="slds-text-heading_medium">
|
|
723
|
-
{modalHeader}
|
|
724
|
-
</h2>
|
|
725
|
-
</template>
|
|
726
|
-
<template lwc:if={modalTagline}>
|
|
727
|
-
<p class="slds-m-top_x-small slds-text-color_weak">
|
|
728
|
-
{modalTagline}
|
|
729
|
-
</p>
|
|
730
|
-
</template>
|
|
731
|
-
|
|
732
|
-
<!-- Slotted Content -->
|
|
733
|
-
<div class="slds-m-top_medium">
|
|
734
|
-
<slot name="modalContent"></slot>
|
|
735
|
-
</div>
|
|
736
|
-
|
|
737
|
-
<!-- Footer -->
|
|
738
|
-
<div class="slds-m-top_medium slds-text-align_right">
|
|
739
|
-
<lightning-button
|
|
740
|
-
label="Cancel"
|
|
741
|
-
onclick={toggleModal}
|
|
742
|
-
class="slds-m-right_x-small focusable">
|
|
743
|
-
</lightning-button>
|
|
744
|
-
<lightning-button
|
|
745
|
-
variant="brand"
|
|
746
|
-
label="Save"
|
|
747
|
-
onclick={handleSave}
|
|
748
|
-
class="focusable">
|
|
749
|
-
</lightning-button>
|
|
750
|
-
</div>
|
|
751
|
-
</div>
|
|
752
|
-
</div>
|
|
753
|
-
</div>
|
|
754
|
-
|
|
755
|
-
<!-- Hidden background content -->
|
|
756
|
-
<div aria-hidden={_isOpen}>
|
|
757
|
-
<slot name="body"></slot>
|
|
758
|
-
</div>
|
|
759
|
-
</template>
|
|
760
|
-
```
|
|
761
|
-
|
|
762
|
-
---
|
|
763
|
-
|
|
764
|
-
## Record Picker Pattern
|
|
765
|
-
|
|
766
|
-
```javascript
|
|
767
|
-
// recordPicker.js
|
|
768
|
-
import { LightningElement, api } from 'lwc';
|
|
769
|
-
|
|
770
|
-
export default class RecordPicker extends LightningElement {
|
|
771
|
-
@api label = 'Select Record';
|
|
772
|
-
@api objectApiName = 'Account';
|
|
773
|
-
@api placeholder = 'Search...';
|
|
774
|
-
@api required = false;
|
|
775
|
-
@api multiSelect = false;
|
|
776
|
-
|
|
777
|
-
_selectedIds = [];
|
|
778
|
-
|
|
779
|
-
@api
|
|
780
|
-
get value() {
|
|
781
|
-
return this.multiSelect ? this._selectedIds : this._selectedIds[0];
|
|
782
|
-
}
|
|
783
|
-
|
|
784
|
-
set value(val) {
|
|
785
|
-
this._selectedIds = Array.isArray(val) ? val : val ? [val] : [];
|
|
786
|
-
}
|
|
787
|
-
|
|
788
|
-
handleChange(event) {
|
|
789
|
-
const recordId = event.detail.recordId;
|
|
790
|
-
if (this.multiSelect) {
|
|
791
|
-
if (!this._selectedIds.includes(recordId)) {
|
|
792
|
-
this._selectedIds = [...this._selectedIds, recordId];
|
|
793
|
-
}
|
|
794
|
-
} else {
|
|
795
|
-
this._selectedIds = recordId ? [recordId] : [];
|
|
796
|
-
}
|
|
797
|
-
|
|
798
|
-
this.dispatchEvent(new CustomEvent('select', {
|
|
799
|
-
detail: {
|
|
800
|
-
recordId: this.value,
|
|
801
|
-
recordIds: this._selectedIds
|
|
802
|
-
}
|
|
803
|
-
}));
|
|
804
|
-
}
|
|
805
|
-
|
|
806
|
-
handleRemove(event) {
|
|
807
|
-
const idToRemove = event.target.dataset.id;
|
|
808
|
-
this._selectedIds = this._selectedIds.filter(id => id !== idToRemove);
|
|
809
|
-
this.dispatchEvent(new CustomEvent('select', {
|
|
810
|
-
detail: { recordIds: this._selectedIds }
|
|
811
|
-
}));
|
|
812
|
-
}
|
|
813
|
-
}
|
|
814
|
-
```
|
|
815
|
-
|
|
816
|
-
```html
|
|
817
|
-
<!-- recordPicker.html -->
|
|
818
|
-
<template>
|
|
819
|
-
<lightning-record-picker
|
|
820
|
-
label={label}
|
|
821
|
-
placeholder={placeholder}
|
|
822
|
-
object-api-name={objectApiName}
|
|
823
|
-
onchange={handleChange}
|
|
824
|
-
required={required}>
|
|
825
|
-
</lightning-record-picker>
|
|
826
|
-
|
|
827
|
-
<template lwc:if={multiSelect}>
|
|
828
|
-
<div class="slds-m-top_x-small">
|
|
829
|
-
<template for:each={_selectedIds} for:item="id">
|
|
830
|
-
<lightning-pill
|
|
831
|
-
key={id}
|
|
832
|
-
label={id}
|
|
833
|
-
data-id={id}
|
|
834
|
-
onremove={handleRemove}>
|
|
835
|
-
</lightning-pill>
|
|
836
|
-
</template>
|
|
837
|
-
</div>
|
|
838
|
-
</template>
|
|
839
|
-
</template>
|
|
840
|
-
```
|
|
841
|
-
|
|
842
|
-
---
|
|
843
|
-
|
|
844
|
-
## Workspace API Pattern
|
|
845
|
-
|
|
846
|
-
```javascript
|
|
847
|
-
// workspaceTabManager.js
|
|
848
|
-
import { LightningElement, wire } from 'lwc';
|
|
849
|
-
import { IsConsoleNavigation, getFocusedTabInfo, openTab, closeTab,
|
|
850
|
-
setTabLabel, setTabIcon, refreshTab } from 'lightning/platformWorkspaceApi';
|
|
851
|
-
|
|
852
|
-
export default class WorkspaceTabManager extends LightningElement {
|
|
853
|
-
@wire(IsConsoleNavigation) isConsole;
|
|
854
|
-
|
|
855
|
-
async openRecordTab(recordId, objectApiName) {
|
|
856
|
-
if (!this.isConsole) return;
|
|
857
|
-
|
|
858
|
-
await openTab({
|
|
859
|
-
recordId,
|
|
860
|
-
focus: true,
|
|
861
|
-
icon: `standard:${objectApiName.toLowerCase()}`,
|
|
862
|
-
label: 'Loading...'
|
|
863
|
-
});
|
|
864
|
-
}
|
|
865
|
-
|
|
866
|
-
async openSubtab(parentTabId, recordId) {
|
|
867
|
-
if (!this.isConsole) return;
|
|
868
|
-
|
|
869
|
-
await openTab({
|
|
870
|
-
parentTabId,
|
|
871
|
-
recordId,
|
|
872
|
-
focus: true
|
|
873
|
-
});
|
|
874
|
-
}
|
|
875
|
-
|
|
876
|
-
async getCurrentTabInfo() {
|
|
877
|
-
if (!this.isConsole) return null;
|
|
878
|
-
return await getFocusedTabInfo();
|
|
879
|
-
}
|
|
880
|
-
|
|
881
|
-
async updateTabLabel(tabId, label) {
|
|
882
|
-
if (!this.isConsole) return;
|
|
883
|
-
await setTabLabel(tabId, label);
|
|
884
|
-
}
|
|
885
|
-
|
|
886
|
-
async updateTabIcon(tabId, iconName) {
|
|
887
|
-
if (!this.isConsole) return;
|
|
888
|
-
await setTabIcon(tabId, iconName);
|
|
889
|
-
}
|
|
890
|
-
|
|
891
|
-
async refreshCurrentTab() {
|
|
892
|
-
if (!this.isConsole) return;
|
|
893
|
-
const tabInfo = await getFocusedTabInfo();
|
|
894
|
-
await refreshTab(tabInfo.tabId);
|
|
895
|
-
}
|
|
896
|
-
|
|
897
|
-
async closeCurrentTab() {
|
|
898
|
-
if (!this.isConsole) return;
|
|
899
|
-
const tabInfo = await getFocusedTabInfo();
|
|
900
|
-
await closeTab(tabInfo.tabId);
|
|
901
|
-
}
|
|
902
|
-
}
|
|
903
|
-
```
|
|
904
|
-
|
|
905
|
-
---
|
|
906
|
-
|
|
907
|
-
<a id="parent-child-communication"></a>
|
|
908
|
-
|
|
909
|
-
## Parent-Child Communication
|
|
910
|
-
|
|
911
|
-
```javascript
|
|
912
|
-
// parent.js
|
|
913
|
-
import { LightningElement } from 'lwc';
|
|
914
|
-
|
|
915
|
-
export default class Parent extends LightningElement {
|
|
916
|
-
selectedAccountId;
|
|
917
|
-
|
|
918
|
-
handleAccountSelected(event) {
|
|
919
|
-
this.selectedAccountId = event.detail.accountId;
|
|
920
|
-
}
|
|
921
|
-
}
|
|
922
|
-
```
|
|
923
|
-
|
|
924
|
-
```html
|
|
925
|
-
<!-- parent.html -->
|
|
926
|
-
<template>
|
|
927
|
-
<c-account-list onaccountselected={handleAccountSelected}></c-account-list>
|
|
928
|
-
<template lwc:if={selectedAccountId}>
|
|
929
|
-
<c-account-detail account-id={selectedAccountId}></c-account-detail>
|
|
930
|
-
</template>
|
|
931
|
-
</template>
|
|
932
|
-
```
|
|
933
|
-
|
|
934
|
-
```javascript
|
|
935
|
-
// child.js (accountList)
|
|
936
|
-
import { LightningElement } from 'lwc';
|
|
937
|
-
|
|
938
|
-
export default class AccountList extends LightningElement {
|
|
939
|
-
handleRowAction(event) {
|
|
940
|
-
const accountId = event.detail.row.Id;
|
|
941
|
-
|
|
942
|
-
// Dispatch event to parent
|
|
943
|
-
this.dispatchEvent(new CustomEvent('accountselected', {
|
|
944
|
-
detail: { accountId },
|
|
945
|
-
bubbles: true,
|
|
946
|
-
composed: false // Don't cross shadow DOM boundaries
|
|
947
|
-
}));
|
|
948
|
-
}
|
|
949
|
-
}
|
|
950
|
-
```
|
|
951
|
-
|
|
952
|
-
---
|
|
953
|
-
|
|
954
|
-
## Sibling Communication (via Parent)
|
|
955
|
-
|
|
956
|
-
When two child components need to communicate but share the same parent, use the **parent as middleware**. This is the recommended pattern for master-detail UIs.
|
|
957
|
-
|
|
958
|
-
```
|
|
959
|
-
┌─────────────────────────────────────────────────────────────────────┐
|
|
960
|
-
│ SIBLING COMMUNICATION FLOW │
|
|
961
|
-
├─────────────────────────────────────────────────────────────────────┤
|
|
962
|
-
│ │
|
|
963
|
-
│ ┌──────────┐ │
|
|
964
|
-
│ │ Parent │ ← Manages state │
|
|
965
|
-
│ └────┬─────┘ │
|
|
966
|
-
│ ┌─────────┴─────────┐ │
|
|
967
|
-
│ │ │ │
|
|
968
|
-
│ CustomEvent @api property │
|
|
969
|
-
│ (up) (down) │
|
|
970
|
-
│ │ │ │
|
|
971
|
-
│ ┌─────┴─────┐ ┌─────┴─────┐ │
|
|
972
|
-
│ │ Child A │ │ Child B │ │
|
|
973
|
-
│ │ (List) │ │ (Detail) │ │
|
|
974
|
-
│ └───────────┘ └───────────┘ │
|
|
975
|
-
│ │
|
|
976
|
-
└─────────────────────────────────────────────────────────────────────┘
|
|
977
|
-
```
|
|
978
|
-
|
|
979
|
-
**The flow**:
|
|
980
|
-
1. **Child A** dispatches a custom event (e.g., user selects an account)
|
|
981
|
-
2. **Parent** catches the event and updates its state
|
|
982
|
-
3. **Parent** passes data to **Child B** via `@api` property
|
|
983
|
-
|
|
984
|
-
### Complete Example: Account List → Account Detail
|
|
985
|
-
|
|
986
|
-
```javascript
|
|
987
|
-
// accountContainer.js - Parent orchestrates communication between siblings
|
|
988
|
-
import { LightningElement } from 'lwc';
|
|
989
|
-
|
|
990
|
-
export default class AccountContainer extends LightningElement {
|
|
991
|
-
// State managed at parent level
|
|
992
|
-
selectedAccountId;
|
|
993
|
-
selectedAccountName;
|
|
994
|
-
|
|
995
|
-
// Child A (accountList) fires this event
|
|
996
|
-
handleAccountSelect(event) {
|
|
997
|
-
this.selectedAccountId = event.detail.accountId;
|
|
998
|
-
this.selectedAccountName = event.detail.accountName;
|
|
999
|
-
}
|
|
1000
|
-
|
|
1001
|
-
// Clear selection (triggered by Child B)
|
|
1002
|
-
handleClearSelection() {
|
|
1003
|
-
this.selectedAccountId = null;
|
|
1004
|
-
this.selectedAccountName = null;
|
|
1005
|
-
}
|
|
1006
|
-
|
|
1007
|
-
get hasSelection() {
|
|
1008
|
-
return !!this.selectedAccountId;
|
|
1009
|
-
}
|
|
1010
|
-
}
|
|
1011
|
-
```
|
|
1012
|
-
|
|
1013
|
-
```html
|
|
1014
|
-
<!-- accountContainer.html -->
|
|
1015
|
-
<template>
|
|
1016
|
-
<div class="slds-grid slds-gutters">
|
|
1017
|
-
<!-- Child A: Account List -->
|
|
1018
|
-
<div class="slds-col slds-size_1-of-2">
|
|
1019
|
-
<c-account-list
|
|
1020
|
-
onaccountselect={handleAccountSelect}
|
|
1021
|
-
selected-id={selectedAccountId}>
|
|
1022
|
-
</c-account-list>
|
|
1023
|
-
</div>
|
|
1024
|
-
|
|
1025
|
-
<!-- Child B: Account Detail (receives data via @api) -->
|
|
1026
|
-
<div class="slds-col slds-size_1-of-2">
|
|
1027
|
-
<template lwc:if={hasSelection}>
|
|
1028
|
-
<c-account-detail
|
|
1029
|
-
account-id={selectedAccountId}
|
|
1030
|
-
account-name={selectedAccountName}
|
|
1031
|
-
onclearselection={handleClearSelection}>
|
|
1032
|
-
</c-account-detail>
|
|
1033
|
-
</template>
|
|
1034
|
-
<template lwc:else>
|
|
1035
|
-
<div class="slds-box slds-theme_shade">
|
|
1036
|
-
Select an account to view details
|
|
1037
|
-
</div>
|
|
1038
|
-
</template>
|
|
1039
|
-
</div>
|
|
1040
|
-
</div>
|
|
1041
|
-
</template>
|
|
1042
|
-
```
|
|
1043
|
-
|
|
1044
|
-
```javascript
|
|
1045
|
-
// accountList.js - Child A: Dispatches events UP to parent
|
|
1046
|
-
import { LightningElement, api, wire } from 'lwc';
|
|
1047
|
-
import getAccounts from '@salesforce/apex/AccountController.getAccounts';
|
|
1048
|
-
|
|
1049
|
-
export default class AccountList extends LightningElement {
|
|
1050
|
-
@api selectedId; // Highlight selected row (from parent)
|
|
1051
|
-
accounts;
|
|
1052
|
-
error;
|
|
1053
|
-
|
|
1054
|
-
@wire(getAccounts)
|
|
1055
|
-
wiredAccounts({ data, error }) {
|
|
1056
|
-
if (data) {
|
|
1057
|
-
this.accounts = data;
|
|
1058
|
-
this.error = undefined;
|
|
1059
|
-
} else if (error) {
|
|
1060
|
-
this.error = error;
|
|
1061
|
-
this.accounts = undefined;
|
|
1062
|
-
}
|
|
1063
|
-
}
|
|
1064
|
-
|
|
1065
|
-
handleRowClick(event) {
|
|
1066
|
-
const accountId = event.currentTarget.dataset.id;
|
|
1067
|
-
const accountName = event.currentTarget.dataset.name;
|
|
1068
|
-
|
|
1069
|
-
// Dispatch event to parent (not bubbles - parent listens directly)
|
|
1070
|
-
this.dispatchEvent(new CustomEvent('accountselect', {
|
|
1071
|
-
detail: { accountId, accountName }
|
|
1072
|
-
}));
|
|
1073
|
-
}
|
|
1074
|
-
|
|
1075
|
-
// Computed: Check if row should be highlighted
|
|
1076
|
-
getRowClass(accountId) {
|
|
1077
|
-
return accountId === this.selectedId
|
|
1078
|
-
? 'slds-item slds-is-selected'
|
|
1079
|
-
: 'slds-item';
|
|
1080
|
-
}
|
|
1081
|
-
}
|
|
1082
|
-
```
|
|
1083
|
-
|
|
1084
|
-
```javascript
|
|
1085
|
-
// accountDetail.js - Child B: Receives data via @api from parent
|
|
1086
|
-
import { LightningElement, api, wire } from 'lwc';
|
|
1087
|
-
import { getRecord, getFieldValue } from 'lightning/uiRecordApi';
|
|
1088
|
-
import INDUSTRY_FIELD from '@salesforce/schema/Account.Industry';
|
|
1089
|
-
import REVENUE_FIELD from '@salesforce/schema/Account.AnnualRevenue';
|
|
1090
|
-
|
|
1091
|
-
const FIELDS = [INDUSTRY_FIELD, REVENUE_FIELD];
|
|
1092
|
-
|
|
1093
|
-
export default class AccountDetail extends LightningElement {
|
|
1094
|
-
@api accountId; // Received from parent
|
|
1095
|
-
@api accountName; // Received from parent
|
|
1096
|
-
|
|
1097
|
-
@wire(getRecord, { recordId: '$accountId', fields: FIELDS })
|
|
1098
|
-
account;
|
|
1099
|
-
|
|
1100
|
-
get industry() {
|
|
1101
|
-
return getFieldValue(this.account.data, INDUSTRY_FIELD);
|
|
1102
|
-
}
|
|
1103
|
-
|
|
1104
|
-
get revenue() {
|
|
1105
|
-
return getFieldValue(this.account.data, REVENUE_FIELD);
|
|
1106
|
-
}
|
|
1107
|
-
|
|
1108
|
-
get isLoading() {
|
|
1109
|
-
return !this.account.data && !this.account.error;
|
|
1110
|
-
}
|
|
1111
|
-
|
|
1112
|
-
handleClose() {
|
|
1113
|
-
// Dispatch event back to parent to clear selection
|
|
1114
|
-
this.dispatchEvent(new CustomEvent('clearselection'));
|
|
1115
|
-
}
|
|
1116
|
-
}
|
|
1117
|
-
```
|
|
1118
|
-
|
|
1119
|
-
### When to Use Sibling Pattern vs LMS
|
|
1120
|
-
|
|
1121
|
-
| Scenario | Sibling Pattern | LMS |
|
|
1122
|
-
|----------|-----------------|-----|
|
|
1123
|
-
| Components share same parent | ✅ Recommended | ❌ Overkill |
|
|
1124
|
-
| State is simple (1-2 values) | ✅ | ❌ |
|
|
1125
|
-
| Need bidirectional updates | ✅ | ✅ |
|
|
1126
|
-
| Components in different DOM trees | ❌ | ✅ Required |
|
|
1127
|
-
| Cross-framework (LWC ↔ Aura) | ❌ | ✅ Required |
|
|
1128
|
-
| Many consumers need same data | ❌ Consider LMS | ✅ |
|
|
1129
|
-
| Component hierarchy is deep (4+ levels) | ❌ Consider LMS | ✅ |
|
|
1130
|
-
|
|
1131
|
-
**Rule of thumb**: If components share a parent and data flow is simple, use sibling pattern. If components are "far apart" in the DOM or you need pub/sub semantics, use LMS.
|
|
1132
|
-
|
|
1133
|
-
---
|
|
1134
|
-
|
|
1135
|
-
## Navigation Patterns
|
|
1136
|
-
|
|
1137
|
-
```javascript
|
|
1138
|
-
// navigator.js
|
|
1139
|
-
import { LightningElement } from 'lwc';
|
|
1140
|
-
import { NavigationMixin } from 'lightning/navigation';
|
|
1141
|
-
|
|
1142
|
-
export default class Navigator extends NavigationMixin(LightningElement) {
|
|
1143
|
-
|
|
1144
|
-
navigateToRecord(recordId, objectApiName = 'Account') {
|
|
1145
|
-
this[NavigationMixin.Navigate]({
|
|
1146
|
-
type: 'standard__recordPage',
|
|
1147
|
-
attributes: {
|
|
1148
|
-
recordId,
|
|
1149
|
-
objectApiName,
|
|
1150
|
-
actionName: 'view'
|
|
1151
|
-
}
|
|
1152
|
-
});
|
|
1153
|
-
}
|
|
1154
|
-
|
|
1155
|
-
navigateToList(objectApiName, filterName = 'Recent') {
|
|
1156
|
-
this[NavigationMixin.Navigate]({
|
|
1157
|
-
type: 'standard__objectPage',
|
|
1158
|
-
attributes: {
|
|
1159
|
-
objectApiName,
|
|
1160
|
-
actionName: 'list'
|
|
1161
|
-
},
|
|
1162
|
-
state: { filterName }
|
|
1163
|
-
});
|
|
1164
|
-
}
|
|
1165
|
-
|
|
1166
|
-
navigateToNewRecord(objectApiName, defaultValues = {}) {
|
|
1167
|
-
this[NavigationMixin.Navigate]({
|
|
1168
|
-
type: 'standard__objectPage',
|
|
1169
|
-
attributes: {
|
|
1170
|
-
objectApiName,
|
|
1171
|
-
actionName: 'new'
|
|
1172
|
-
},
|
|
1173
|
-
state: {
|
|
1174
|
-
defaultFieldValues: Object.entries(defaultValues)
|
|
1175
|
-
.map(([k, v]) => `${k}=${encodeURIComponent(v)}`)
|
|
1176
|
-
.join(',')
|
|
1177
|
-
}
|
|
1178
|
-
});
|
|
1179
|
-
}
|
|
1180
|
-
|
|
1181
|
-
navigateToRelatedList(recordId, relationshipApiName) {
|
|
1182
|
-
this[NavigationMixin.Navigate]({
|
|
1183
|
-
type: 'standard__recordRelationshipPage',
|
|
1184
|
-
attributes: {
|
|
1185
|
-
recordId,
|
|
1186
|
-
relationshipApiName,
|
|
1187
|
-
actionName: 'view'
|
|
1188
|
-
}
|
|
1189
|
-
});
|
|
1190
|
-
}
|
|
1191
|
-
|
|
1192
|
-
navigateToNamedPage(pageName, params = {}) {
|
|
1193
|
-
this[NavigationMixin.Navigate]({
|
|
1194
|
-
type: 'standard__namedPage',
|
|
1195
|
-
attributes: {
|
|
1196
|
-
pageName
|
|
1197
|
-
},
|
|
1198
|
-
state: params
|
|
1199
|
-
});
|
|
1200
|
-
}
|
|
1201
|
-
}
|
|
1202
|
-
```
|
|
1203
|
-
|
|
1204
|
-
---
|
|
1205
|
-
|
|
1206
|
-
## TypeScript Patterns
|
|
1207
|
-
|
|
1208
|
-
### TypeScript Component Pattern
|
|
1209
|
-
|
|
1210
|
-
```typescript
|
|
1211
|
-
// accountList.ts
|
|
1212
|
-
import { LightningElement, api, wire, track } from 'lwc';
|
|
1213
|
-
import { getRecord, getFieldValue } from 'lightning/uiRecordApi';
|
|
1214
|
-
import getAccounts from '@salesforce/apex/AccountController.getAccounts';
|
|
1215
|
-
import ACCOUNT_NAME_FIELD from '@salesforce/schema/Account.Name';
|
|
1216
|
-
|
|
1217
|
-
// Define interfaces for type safety
|
|
1218
|
-
interface AccountRecord {
|
|
1219
|
-
Id: string;
|
|
1220
|
-
Name: string;
|
|
1221
|
-
Industry?: string;
|
|
1222
|
-
AnnualRevenue?: number;
|
|
1223
|
-
}
|
|
1224
|
-
|
|
1225
|
-
interface WireResult<T> {
|
|
1226
|
-
data?: T;
|
|
1227
|
-
error?: Error;
|
|
1228
|
-
}
|
|
1229
|
-
|
|
1230
|
-
export default class AccountList extends LightningElement {
|
|
1231
|
-
// Typed @api properties
|
|
1232
|
-
@api recordId: string | undefined;
|
|
1233
|
-
|
|
1234
|
-
@api
|
|
1235
|
-
get maxRecords(): number {
|
|
1236
|
-
return this._maxRecords;
|
|
1237
|
-
}
|
|
1238
|
-
set maxRecords(value: number) {
|
|
1239
|
-
this._maxRecords = value;
|
|
1240
|
-
}
|
|
1241
|
-
|
|
1242
|
-
// Typed @track properties
|
|
1243
|
-
@track private _accounts: AccountRecord[] = [];
|
|
1244
|
-
@track private _error: string | null = null;
|
|
1245
|
-
|
|
1246
|
-
private _maxRecords: number = 10;
|
|
1247
|
-
private _wiredResult: WireResult<AccountRecord[]> | undefined;
|
|
1248
|
-
|
|
1249
|
-
// Typed wire service
|
|
1250
|
-
@wire(getAccounts, { maxRecords: '$maxRecords' })
|
|
1251
|
-
wiredAccounts(result: WireResult<AccountRecord[]>): void {
|
|
1252
|
-
this._wiredResult = result;
|
|
1253
|
-
const { data, error } = result;
|
|
1254
|
-
|
|
1255
|
-
if (data) {
|
|
1256
|
-
this._accounts = data;
|
|
1257
|
-
this._error = null;
|
|
1258
|
-
} else if (error) {
|
|
1259
|
-
this._error = this.reduceErrors(error);
|
|
1260
|
-
this._accounts = [];
|
|
1261
|
-
}
|
|
1262
|
-
}
|
|
1263
|
-
|
|
1264
|
-
// Typed getters
|
|
1265
|
-
get accounts(): AccountRecord[] {
|
|
1266
|
-
return this._accounts;
|
|
1267
|
-
}
|
|
1268
|
-
|
|
1269
|
-
get hasAccounts(): boolean {
|
|
1270
|
-
return this._accounts.length > 0;
|
|
1271
|
-
}
|
|
1272
|
-
|
|
1273
|
-
// Typed event handlers
|
|
1274
|
-
handleSelect(event: CustomEvent<{ accountId: string }>): void {
|
|
1275
|
-
const { accountId } = event.detail;
|
|
1276
|
-
this.dispatchEvent(new CustomEvent('accountselected', {
|
|
1277
|
-
detail: { accountId },
|
|
1278
|
-
bubbles: true,
|
|
1279
|
-
composed: true
|
|
1280
|
-
}));
|
|
1281
|
-
}
|
|
1282
|
-
|
|
1283
|
-
// Typed utility methods
|
|
1284
|
-
private reduceErrors(error: Error | Error[]): string {
|
|
1285
|
-
const errors = Array.isArray(error) ? error : [error];
|
|
1286
|
-
return errors
|
|
1287
|
-
.filter((e): e is Error => e !== null)
|
|
1288
|
-
.map(e => e.message || 'Unknown error')
|
|
1289
|
-
.join('; ');
|
|
1290
|
-
}
|
|
1291
|
-
}
|
|
1292
|
-
```
|
|
1293
|
-
|
|
1294
|
-
### TypeScript Jest Test Pattern
|
|
1295
|
-
|
|
1296
|
-
```typescript
|
|
1297
|
-
// accountList.test.ts
|
|
1298
|
-
import { createElement, LightningElement } from 'lwc';
|
|
1299
|
-
import AccountList from 'c/accountList';
|
|
1300
|
-
import getAccounts from '@salesforce/apex/AccountController.getAccounts';
|
|
1301
|
-
|
|
1302
|
-
// Type definitions for tests
|
|
1303
|
-
interface AccountRecord {
|
|
1304
|
-
Id: string;
|
|
1305
|
-
Name: string;
|
|
1306
|
-
Industry?: string;
|
|
1307
|
-
}
|
|
1308
|
-
|
|
1309
|
-
// Mock Apex
|
|
1310
|
-
jest.mock(
|
|
1311
|
-
'@salesforce/apex/AccountController.getAccounts',
|
|
1312
|
-
() => ({ default: jest.fn() }),
|
|
1313
|
-
{ virtual: true }
|
|
1314
|
-
);
|
|
1315
|
-
|
|
1316
|
-
const MOCK_ACCOUNTS: AccountRecord[] = [
|
|
1317
|
-
{ Id: '001xx000003DGQ', Name: 'Acme Corp', Industry: 'Technology' }
|
|
1318
|
-
];
|
|
1319
|
-
|
|
1320
|
-
describe('c-account-list', () => {
|
|
1321
|
-
let element: LightningElement & { maxRecords?: number };
|
|
1322
|
-
|
|
1323
|
-
afterEach(() => {
|
|
1324
|
-
while (document.body.firstChild) {
|
|
1325
|
-
document.body.removeChild(document.body.firstChild);
|
|
1326
|
-
}
|
|
1327
|
-
jest.clearAllMocks();
|
|
1328
|
-
});
|
|
1329
|
-
|
|
1330
|
-
it('displays accounts after data loads', async () => {
|
|
1331
|
-
(getAccounts as jest.Mock).mockResolvedValue(MOCK_ACCOUNTS);
|
|
1332
|
-
|
|
1333
|
-
element = createElement('c-account-list', { is: AccountList });
|
|
1334
|
-
document.body.appendChild(element);
|
|
1335
|
-
|
|
1336
|
-
await Promise.resolve();
|
|
1337
|
-
|
|
1338
|
-
const items = element.shadowRoot?.querySelectorAll('.slds-item');
|
|
1339
|
-
expect(items?.length).toBe(MOCK_ACCOUNTS.length);
|
|
1340
|
-
});
|
|
1341
|
-
});
|
|
1342
|
-
```
|
|
1343
|
-
|
|
1344
|
-
### TypeScript Features for LWC
|
|
1345
|
-
|
|
1346
|
-
| Feature | LWC Support | Notes |
|
|
1347
|
-
|---------|-------------|-------|
|
|
1348
|
-
| **Interface definitions** | ✅ | Define shapes for records, events, props |
|
|
1349
|
-
| **Typed @api properties** | ✅ | Getter/setter patterns with types |
|
|
1350
|
-
| **Typed @wire results** | ✅ | Generic `WireResult<T>` pattern |
|
|
1351
|
-
| **Typed event handlers** | ✅ | `CustomEvent<T>` for event detail typing |
|
|
1352
|
-
| **Private class fields** | ✅ | Use `private` keyword |
|
|
1353
|
-
| **Strict null checking** | ✅ | Optional chaining `?.` and nullish coalescing `??` |
|
|
1354
|
-
|
|
1355
|
-
---
|
|
1356
|
-
|
|
1357
|
-
## Apex Controller Patterns
|
|
1358
|
-
|
|
1359
|
-
### Cacheable Methods (for @wire)
|
|
1360
|
-
|
|
1361
|
-
```apex
|
|
1362
|
-
public with sharing class LwcController {
|
|
1363
|
-
|
|
1364
|
-
@AuraEnabled(cacheable=true)
|
|
1365
|
-
public static List<Account> getAccounts(String searchTerm) {
|
|
1366
|
-
String searchKey = '%' + String.escapeSingleQuotes(searchTerm) + '%';
|
|
1367
|
-
return [
|
|
1368
|
-
SELECT Id, Name, Industry, AnnualRevenue
|
|
1369
|
-
FROM Account
|
|
1370
|
-
WHERE Name LIKE :searchKey
|
|
1371
|
-
WITH SECURITY_ENFORCED
|
|
1372
|
-
ORDER BY Name
|
|
1373
|
-
LIMIT 50
|
|
1374
|
-
];
|
|
1375
|
-
}
|
|
1376
|
-
|
|
1377
|
-
@AuraEnabled(cacheable=true)
|
|
1378
|
-
public static List<PicklistOption> getIndustryOptions() {
|
|
1379
|
-
List<PicklistOption> options = new List<PicklistOption>();
|
|
1380
|
-
Schema.DescribeFieldResult fieldResult =
|
|
1381
|
-
Account.Industry.getDescribe();
|
|
1382
|
-
for (Schema.PicklistEntry entry : fieldResult.getPicklistValues()) {
|
|
1383
|
-
if (entry.isActive()) {
|
|
1384
|
-
options.add(new PicklistOption(entry.getLabel(), entry.getValue()));
|
|
1385
|
-
}
|
|
1386
|
-
}
|
|
1387
|
-
return options;
|
|
1388
|
-
}
|
|
1389
|
-
|
|
1390
|
-
public class PicklistOption {
|
|
1391
|
-
@AuraEnabled public String label;
|
|
1392
|
-
@AuraEnabled public String value;
|
|
1393
|
-
|
|
1394
|
-
public PicklistOption(String label, String value) {
|
|
1395
|
-
this.label = label;
|
|
1396
|
-
this.value = value;
|
|
1397
|
-
}
|
|
1398
|
-
}
|
|
1399
|
-
}
|
|
1400
|
-
```
|
|
1401
|
-
|
|
1402
|
-
### Non-Cacheable Methods (for DML)
|
|
1403
|
-
|
|
1404
|
-
```apex
|
|
1405
|
-
@AuraEnabled
|
|
1406
|
-
public static Account createAccount(String accountJson) {
|
|
1407
|
-
Account acc = (Account) JSON.deserialize(accountJson, Account.class);
|
|
1408
|
-
|
|
1409
|
-
// FLS check
|
|
1410
|
-
SObjectAccessDecision decision = Security.stripInaccessible(
|
|
1411
|
-
AccessType.CREATABLE,
|
|
1412
|
-
new List<Account>{ acc }
|
|
1413
|
-
);
|
|
1414
|
-
|
|
1415
|
-
insert decision.getRecords();
|
|
1416
|
-
return (Account) decision.getRecords()[0];
|
|
1417
|
-
}
|
|
1418
|
-
|
|
1419
|
-
@AuraEnabled
|
|
1420
|
-
public static void deleteAccounts(List<Id> accountIds) {
|
|
1421
|
-
if (accountIds == null || accountIds.isEmpty()) {
|
|
1422
|
-
throw new AuraHandledException('No accounts to delete');
|
|
1423
|
-
}
|
|
1424
|
-
|
|
1425
|
-
List<Account> toDelete = [
|
|
1426
|
-
SELECT Id FROM Account
|
|
1427
|
-
WHERE Id IN :accountIds
|
|
1428
|
-
WITH SECURITY_ENFORCED
|
|
1429
|
-
];
|
|
1430
|
-
|
|
1431
|
-
delete toDelete;
|
|
1432
|
-
}
|
|
1433
|
-
```
|
|
1434
|
-
|
|
1435
|
-
### Error Handling Pattern
|
|
1436
|
-
|
|
1437
|
-
```apex
|
|
1438
|
-
@AuraEnabled
|
|
1439
|
-
public static List<Contact> getContactsWithErrorHandling(Id accountId) {
|
|
1440
|
-
try {
|
|
1441
|
-
if (accountId == null) {
|
|
1442
|
-
throw new AuraHandledException('Account ID is required');
|
|
1443
|
-
}
|
|
1444
|
-
|
|
1445
|
-
List<Contact> contacts = [
|
|
1446
|
-
SELECT Id, Name, Email, Phone
|
|
1447
|
-
FROM Contact
|
|
1448
|
-
WHERE AccountId = :accountId
|
|
1449
|
-
WITH SECURITY_ENFORCED
|
|
1450
|
-
ORDER BY Name
|
|
1451
|
-
LIMIT 100
|
|
1452
|
-
];
|
|
1453
|
-
|
|
1454
|
-
return contacts;
|
|
1455
|
-
} catch (Exception e) {
|
|
1456
|
-
throw new AuraHandledException('Error fetching contacts: ' + e.getMessage());
|
|
1457
|
-
}
|
|
1458
|
-
}
|
|
1459
|
-
```
|
|
1460
|
-
|
|
1461
|
-
---
|
|
1462
|
-
|
|
1463
|
-
## Related Resources
|
|
1464
|
-
|
|
1465
|
-
- [lms-guide.md](lms-guide.md) - Lightning Message Service deep dive
|
|
1466
|
-
- [jest-testing.md](jest-testing.md) - Advanced testing patterns
|
|
1467
|
-
- [accessibility-guide.md](accessibility-guide.md) - WCAG compliance
|
|
1468
|
-
- [performance-guide.md](performance-guide.md) - Optimization techniques
|
|
1469
|
-
|
|
1470
|
-
---
|
|
1471
|
-
|
|
1472
|
-
## External References
|
|
1473
|
-
|
|
1474
|
-
- [PICKLES Framework](https://www.salesforceben.com/the-ideal-framework-for-architecting-salesforce-lightning-web-components/) — David Picksley, Third Eye Consulting
|
|
1475
|
-
- [LWC Recipes (GitHub)](https://github.com/trailheadapps/lwc-recipes)
|
|
1476
|
-
- [James Simone - Composable Modal](https://www.jamessimone.net/blog/joys-of-apex/lwc-composable-modal/)
|