@salesforce/templates 66.5.5 → 66.5.6
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/lib/templates/project/.forceignore +3 -1
- package/lib/templates/project/reactb2e/AGENT.md +12 -2
- package/lib/templates/project/reactb2e/CHANGELOG.md +401 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/.forceignore +15 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/codegen.yml +1 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/eslint.config.js +44 -27
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/index.html +0 -1
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/package.json +7 -11
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/__examples__/api/accountSearchService.ts +46 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/__examples__/api/query/distinctAccountIndustries.graphql +19 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/__examples__/api/query/distinctAccountTypes.graphql +19 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/__examples__/api/query/getAccountDetail.graphql +121 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/__examples__/api/query/searchAccounts.graphql +51 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/__examples__/pages/AccountObjectDetailPage.tsx +357 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/__examples__/pages/AccountSearch.tsx +275 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/__examples__/pages/Home.tsx +34 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/api/objectSearchService.ts +84 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/components/ActiveFilters.tsx +89 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/components/FilterPanel.tsx +127 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/components/ObjectBreadcrumb.tsx +66 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/components/PaginationControls.tsx +151 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/components/SearchBar.tsx +41 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/components/SortControl.tsx +143 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/components/filters/BooleanFilter.tsx +94 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/components/filters/DateFilter.tsx +165 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/components/filters/DateRangeFilter.tsx +78 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/components/filters/MultiSelectFilter.tsx +106 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/components/filters/NumericRangeFilter.tsx +102 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/components/filters/SearchFilter.tsx +40 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/components/filters/SelectFilter.tsx +97 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/components/filters/TextFilter.tsx +77 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/hooks/useAsyncData.ts +53 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/hooks/useCachedAsyncData.ts +183 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/hooks/useObjectSearchParams.ts +225 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/utils/debounce.ts +22 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/utils/fieldUtils.ts +29 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/utils/filterUtils.ts +372 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_os_/utils/sortUtils.ts +38 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/api/graphql-operations-types.ts +11260 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/app.tsx +4 -1
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/appLayout.tsx +1 -1
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/components/AgentforceConversationClient.tsx +33 -5
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/components/alerts/status-alert.tsx +1 -1
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/components/ui/badge.tsx +48 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/components/ui/breadcrumb.tsx +109 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/components/ui/calendar.tsx +232 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/components/ui/checkbox.tsx +32 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/components/ui/collapsible.tsx +33 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/components/ui/datePicker.tsx +127 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/components/ui/popover.tsx +89 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/components/ui/sonner.tsx +20 -0
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/index.ts +3 -117
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/pages/Home.tsx +10 -11
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/pages/TestAccPage.tsx +1 -1
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/routes.tsx +8 -20
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/types/conversation.ts +14 -4
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/tsconfig.json +7 -1
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/vite.config.ts +17 -13
- package/lib/templates/project/reactb2e/_r_/skills/{webapp-react-data-visualization → building-data-visualization}/SKILL.md +3 -3
- package/lib/templates/project/reactb2e/_r_/skills/building-data-visualization/implementation/bar-line-chart.md +316 -0
- package/lib/templates/project/{reactb2x/_r_/skills/webapp-react-data-visualization → reactb2e/_r_/skills/building-data-visualization}/implementation/donut-chart.md +1 -1
- package/lib/templates/project/{reactb2x/_r_/skills/webapp-react → reactb2e/_r_/skills/building-react-components}/SKILL.md +21 -5
- package/lib/templates/project/reactb2e/_r_/skills/{webapp-csp-trusted-sites → configuring-csp-trusted-sites}/SKILL.md +1 -1
- package/lib/templates/project/{reactb2x/_r_/webapp-webapplication.md → reactb2e/_r_/skills/configuring-webapp-metadata/SKILL.md} +2 -3
- package/lib/templates/project/reactb2e/_r_/{webapp.md → skills/creating-webapp/SKILL.md} +46 -4
- package/lib/templates/project/reactb2e/_r_/skills/deploying-to-salesforce/SKILL.md +226 -0
- package/lib/templates/project/reactb2e/_r_/skills/{feature-react-file-upload-file-upload → implementing-file-upload}/SKILL.md +1 -1
- package/lib/templates/project/{reactb2x/_r_/skills/webapp-features → reactb2e/_r_/skills/installing-webapp-features}/SKILL.md +3 -3
- package/lib/templates/project/reactb2e/_r_/skills/managing-agentforce-conversation-client/SKILL.md +186 -0
- package/lib/templates/project/reactb2e/_r_/skills/managing-agentforce-conversation-client/references/constraints.md +134 -0
- package/lib/templates/project/reactb2e/_r_/skills/managing-agentforce-conversation-client/references/examples.md +132 -0
- package/lib/templates/project/reactb2e/_r_/skills/managing-agentforce-conversation-client/references/style-tokens.md +101 -0
- package/lib/templates/project/reactb2e/_r_/skills/managing-agentforce-conversation-client/references/troubleshooting.md +57 -0
- package/lib/templates/project/reactb2e/_r_/skills/using-salesforce-data/SKILL.md +363 -0
- package/lib/templates/project/reactb2e/_r_/skills/using-salesforce-data/graphql-search.sh +139 -0
- package/lib/templates/project/reactb2e/_r_/webapp-data.md +353 -0
- package/lib/templates/project/reactb2e/_r_/webapp-ui.md +16 -0
- package/lib/templates/project/reactb2e/eslint.config.js +7 -0
- package/lib/templates/project/reactb2e/package-lock.json +9995 -0
- package/lib/templates/project/reactb2e/package.json +12 -11
- package/lib/templates/project/reactb2e/scripts/setup-cli.mjs +61 -31
- package/lib/templates/project/reactb2e/scripts/sf-project-setup.mjs +66 -0
- package/lib/templates/project/reactb2x/AGENT.md +12 -2
- package/lib/templates/project/reactb2x/CHANGELOG.md +401 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/.forceignore +15 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/codegen.yml +1 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/eslint.config.js +44 -27
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/index.html +0 -1
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/package.json +8 -11
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/__examples__/api/accountSearchService.ts +46 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/__examples__/api/query/distinctAccountIndustries.graphql +19 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/__examples__/api/query/distinctAccountTypes.graphql +19 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/__examples__/api/query/getAccountDetail.graphql +121 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/__examples__/api/query/searchAccounts.graphql +51 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/__examples__/pages/AccountObjectDetailPage.tsx +357 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/__examples__/pages/AccountSearch.tsx +275 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/__examples__/pages/Home.tsx +34 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/api/objectSearchService.ts +84 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/components/ActiveFilters.tsx +89 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/components/FilterPanel.tsx +127 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/components/ObjectBreadcrumb.tsx +66 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/components/PaginationControls.tsx +151 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/components/SearchBar.tsx +41 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/components/SortControl.tsx +143 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/components/filters/BooleanFilter.tsx +94 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/components/filters/DateFilter.tsx +165 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/components/filters/DateRangeFilter.tsx +78 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/components/filters/MultiSelectFilter.tsx +106 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/components/filters/NumericRangeFilter.tsx +102 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/components/filters/SearchFilter.tsx +40 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/components/filters/SelectFilter.tsx +97 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/components/filters/TextFilter.tsx +77 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/hooks/useAsyncData.ts +53 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/hooks/useCachedAsyncData.ts +183 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/hooks/useObjectSearchParams.ts +225 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/utils/debounce.ts +22 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/utils/fieldUtils.ts +29 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/utils/filterUtils.ts +372 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_os_/utils/sortUtils.ts +38 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/authentication/api/userProfileApi.ts +13 -13
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/authentication/layouts/privateRouteLayout.tsx +10 -2
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/authentication/pages/ChangePassword.tsx +2 -2
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/authentication/pages/ForgotPassword.tsx +2 -2
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/authentication/pages/Login.tsx +2 -2
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/authentication/pages/Profile.tsx +26 -4
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/authentication/pages/Register.tsx +2 -2
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/authentication/pages/ResetPassword.tsx +2 -2
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/authentication/sessionTimeout/SessionTimeoutValidator.tsx +8 -16
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/authentication/sessionTimeout/sessionTimeService.ts +30 -42
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/api/graphql-operations-types.ts +11260 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/app.tsx +3 -1
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/components/alerts/status-alert.tsx +1 -1
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/components/ui/badge.tsx +48 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/components/ui/breadcrumb.tsx +109 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/components/ui/calendar.tsx +232 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/components/ui/checkbox.tsx +32 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/components/ui/collapsible.tsx +33 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/components/ui/datePicker.tsx +127 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/components/ui/popover.tsx +89 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/components/ui/sonner.tsx +20 -0
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/pages/Home.tsx +10 -11
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/routes.tsx +9 -21
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/tsconfig.json +7 -1
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/vite.config.ts +17 -13
- package/lib/templates/project/reactb2x/_p_/_m_/networks/appreacttemplateb2x.network +1 -1
- package/lib/templates/project/reactb2x/_r_/skills/{webapp-react-data-visualization → building-data-visualization}/SKILL.md +3 -3
- package/lib/templates/project/reactb2x/_r_/skills/building-data-visualization/implementation/bar-line-chart.md +316 -0
- package/lib/templates/project/{reactb2e/_r_/skills/webapp-react-data-visualization → reactb2x/_r_/skills/building-data-visualization}/implementation/donut-chart.md +1 -1
- package/lib/templates/project/{reactb2e/_r_/skills/webapp-react → reactb2x/_r_/skills/building-react-components}/SKILL.md +21 -5
- package/lib/templates/project/reactb2x/_r_/skills/{webapp-csp-trusted-sites → configuring-csp-trusted-sites}/SKILL.md +1 -1
- package/lib/templates/project/{reactb2e/_r_/webapp-webapplication.md → reactb2x/_r_/skills/configuring-webapp-metadata/SKILL.md} +2 -3
- package/lib/templates/project/reactb2x/_r_/{webapp.md → skills/creating-webapp/SKILL.md} +46 -4
- package/lib/templates/project/reactb2x/_r_/skills/deploying-to-salesforce/SKILL.md +226 -0
- package/lib/templates/project/reactb2x/_r_/skills/{feature-react-file-upload-file-upload → implementing-file-upload}/SKILL.md +1 -1
- package/lib/templates/project/{reactb2e/_r_/skills/webapp-features → reactb2x/_r_/skills/installing-webapp-features}/SKILL.md +3 -3
- package/lib/templates/project/reactb2x/_r_/skills/managing-agentforce-conversation-client/SKILL.md +186 -0
- package/lib/templates/project/reactb2x/_r_/skills/managing-agentforce-conversation-client/references/constraints.md +134 -0
- package/lib/templates/project/reactb2x/_r_/skills/managing-agentforce-conversation-client/references/examples.md +132 -0
- package/lib/templates/project/reactb2x/_r_/skills/managing-agentforce-conversation-client/references/style-tokens.md +101 -0
- package/lib/templates/project/reactb2x/_r_/skills/managing-agentforce-conversation-client/references/troubleshooting.md +57 -0
- package/lib/templates/project/reactb2x/_r_/skills/using-salesforce-data/SKILL.md +363 -0
- package/lib/templates/project/reactb2x/_r_/skills/using-salesforce-data/graphql-search.sh +139 -0
- package/lib/templates/project/reactb2x/_r_/webapp-data.md +353 -0
- package/lib/templates/project/reactb2x/_r_/webapp-ui.md +16 -0
- package/lib/templates/project/reactb2x/eslint.config.js +7 -0
- package/lib/templates/project/reactb2x/package-lock.json +9995 -0
- package/lib/templates/project/reactb2x/package.json +12 -11
- package/lib/templates/project/reactb2x/scripts/setup-cli.mjs +61 -31
- package/lib/templates/project/reactb2x/scripts/sf-project-setup.mjs +66 -0
- package/lib/templates/webapplication/reactbasic/.forceignore +15 -0
- package/lib/templates/webapplication/reactbasic/codegen.yml +1 -0
- package/lib/templates/webapplication/reactbasic/eslint.config.js +44 -27
- package/lib/templates/webapplication/reactbasic/index.html +0 -1
- package/lib/templates/webapplication/reactbasic/package.json +6 -3
- package/lib/templates/webapplication/reactbasic/src/app.tsx +4 -1
- package/lib/templates/webapplication/reactbasic/src/components/alerts/status-alert.tsx +1 -1
- package/lib/templates/webapplication/reactbasic/src/components/ui/badge.tsx +48 -0
- package/lib/templates/webapplication/reactbasic/src/components/ui/breadcrumb.tsx +109 -0
- package/lib/templates/webapplication/reactbasic/src/components/ui/calendar.tsx +232 -0
- package/lib/templates/webapplication/reactbasic/src/components/ui/checkbox.tsx +32 -0
- package/lib/templates/webapplication/reactbasic/src/components/ui/collapsible.tsx +33 -0
- package/lib/templates/webapplication/reactbasic/src/components/ui/datePicker.tsx +127 -0
- package/lib/templates/webapplication/reactbasic/src/components/ui/popover.tsx +89 -0
- package/lib/templates/webapplication/reactbasic/src/components/ui/sonner.tsx +20 -0
- package/lib/templates/webapplication/reactbasic/tsconfig.json +7 -1
- package/lib/templates/webapplication/reactbasic/vite.config.ts +17 -13
- package/lib/utils/template-placeholders.js +7 -0
- package/lib/utils/template-placeholders.js.map +1 -1
- package/lib/utils/webappTemplateUtils.d.ts +3 -1
- package/lib/utils/webappTemplateUtils.js +4 -1
- package/lib/utils/webappTemplateUtils.js.map +1 -1
- package/package.json +4 -4
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/DetailFields.tsx +0 -55
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/DetailForm.tsx +0 -146
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/DetailHeader.tsx +0 -34
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/DetailLayoutSections.tsx +0 -80
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/Section.tsx +0 -108
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/SectionRow.tsx +0 -20
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/UiApiDetailForm.tsx +0 -140
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/_fmt_/FieldValueDisplay.tsx +0 -73
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/_fmt_/FormattedAddress.tsx +0 -29
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/_fmt_/FormattedEmail.tsx +0 -17
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/_fmt_/FormattedPhone.tsx +0 -24
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/_fmt_/FormattedText.tsx +0 -11
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/_fmt_/FormattedUrl.tsx +0 -29
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/filters/FilterField.tsx +0 -54
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/filters/FilterInput.tsx +0 -55
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/filters/FilterSelect.tsx +0 -72
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/filters/FiltersPanel.tsx +0 -380
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/forms/filters-form.tsx +0 -114
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/forms/submit-button.tsx +0 -47
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/search/GlobalSearchInput.tsx +0 -114
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/search/ResultCardFields.tsx +0 -71
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/search/SearchHeader.tsx +0 -31
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/search/SearchPagination.tsx +0 -144
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/search/SearchResultCard.tsx +0 -136
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/search/SearchResultsPanel.tsx +0 -197
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/shared/LoadingFallback.tsx +0 -61
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/api/objectDetailService.ts +0 -102
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/api/objectInfoGraphQLService.ts +0 -137
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/api/objectInfoService.ts +0 -95
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/api/recordListGraphQLService.ts +0 -364
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/constants.ts +0 -39
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/filters/FilterInput.tsx +0 -55
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/filters/FilterSelect.tsx +0 -72
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/hooks/form.tsx +0 -209
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/hooks/useObjectInfoBatch.ts +0 -65
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/hooks/useObjectSearchData.ts +0 -174
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/hooks/useRecordDetailLayout.ts +0 -137
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/hooks/useRecordListGraphQL.ts +0 -135
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/pages/DetailPage.tsx +0 -109
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/pages/GlobalSearch.tsx +0 -229
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/types/filters/filters.ts +0 -121
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/types/filters/picklist.ts +0 -6
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/types/objectInfo/objectInfo.ts +0 -49
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/types/recordDetail/recordDetail.ts +0 -61
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/types/schema.d.ts +0 -200
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/types/search/searchResults.ts +0 -229
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/apiUtils.ts +0 -59
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/cacheUtils.ts +0 -76
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/debounce.ts +0 -89
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/fieldUtils.ts +0 -354
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/fieldValueExtractor.ts +0 -67
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/filterUtils.ts +0 -32
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/formDataTransformUtils.ts +0 -260
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/formUtils.ts +0 -142
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/graphQLNodeFieldUtils.ts +0 -186
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/graphQLObjectInfoAdapter.ts +0 -77
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/graphQLRecordAdapter.ts +0 -90
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/layoutTransformUtils.ts +0 -236
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/linkUtils.ts +0 -14
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/paginationUtils.ts +0 -49
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/recordUtils.ts +0 -159
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/sanitizationUtils.ts +0 -49
- package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/tsconfig.tsbuildinfo +0 -1
- package/lib/templates/project/reactb2e/_r_/features/feature-graphql-graphql-data-access-rule.md +0 -470
- package/lib/templates/project/reactb2e/_r_/features/feature-react-agentforce-conversation-client-embedded-agent-rule.md +0 -18
- package/lib/templates/project/reactb2e/_r_/features/feature-react-chart-analytics-charts-rule.md +0 -27
- package/lib/templates/project/reactb2e/_r_/skills/_k_/SKILL.md +0 -148
- package/lib/templates/project/reactb2e/_r_/skills/_k_/docs/embed-examples.md +0 -192
- package/lib/templates/project/reactb2e/_r_/skills/_k_/docs/troubleshooting.md +0 -51
- package/lib/templates/project/reactb2e/_r_/skills/feature-graphql-graphql-data-access/SKILL.md +0 -155
- package/lib/templates/project/reactb2e/_r_/skills/feature-graphql-graphql-data-access/docs/explore-schema.md +0 -256
- package/lib/templates/project/reactb2e/_r_/skills/feature-graphql-graphql-data-access/docs/generate-mutation-query.md +0 -228
- package/lib/templates/project/reactb2e/_r_/skills/feature-graphql-graphql-data-access/docs/generate-read-query.md +0 -202
- package/lib/templates/project/reactb2e/_r_/skills/feature-graphql-graphql-data-access/docs/shared-schema.graphqls +0 -1150
- package/lib/templates/project/reactb2e/_r_/skills/feature-micro-frontend-micro-frontend/SKILL.md +0 -137
- package/lib/templates/project/reactb2e/_r_/skills/feature-react-chart-analytics-charts/SKILL.md +0 -41
- package/lib/templates/project/reactb2e/_r_/skills/feature-react-chart-analytics-charts/docs/schema-mapping.md +0 -4
- package/lib/templates/project/reactb2e/_r_/skills/webapp-react-interactive-map/SKILL.md +0 -92
- package/lib/templates/project/reactb2e/_r_/skills/webapp-react-interactive-map/implementation/geocoding.md +0 -245
- package/lib/templates/project/reactb2e/_r_/skills/webapp-react-interactive-map/implementation/leaflet-map.md +0 -279
- package/lib/templates/project/reactb2e/_r_/skills/webapp-react-weather-widget/SKILL.md +0 -65
- package/lib/templates/project/reactb2e/_r_/skills/webapp-react-weather-widget/implementation/weather-hook.md +0 -258
- package/lib/templates/project/reactb2e/_r_/skills/webapp-react-weather-widget/implementation/weather-ui.md +0 -216
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/SKILL.md +0 -271
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/data/charts.csv +0 -26
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/data/colors.csv +0 -97
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/data/icons.csv +0 -101
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/data/landing.csv +0 -31
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/data/products.csv +0 -97
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/data/react-performance.csv +0 -45
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/data/stacks/html-tailwind.csv +0 -56
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/data/stacks/react.csv +0 -54
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/data/stacks/shadcn.csv +0 -61
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/data/styles.csv +0 -68
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/data/typography.csv +0 -58
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/data/ui-reasoning.csv +0 -101
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/data/ux-guidelines.csv +0 -100
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/data/web-interface.csv +0 -31
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/scripts/core.js +0 -255
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/scripts/design_system.js +0 -861
- package/lib/templates/project/reactb2e/_r_/skills/webapp-ui-ux/scripts/search.js +0 -98
- package/lib/templates/project/reactb2e/_r_/skills/webapp-unsplash-images/SKILL.md +0 -71
- package/lib/templates/project/reactb2e/_r_/skills/webapp-unsplash-images/implementation/usage.md +0 -159
- package/lib/templates/project/reactb2e/_r_/webapp-cli-commands.md +0 -88
- package/lib/templates/project/reactb2e/_r_/webapp-react-code-quality.md +0 -136
- package/lib/templates/project/reactb2e/_r_/webapp-react-typescript.md +0 -205
- package/lib/templates/project/reactb2e/_r_/webapp-react.md +0 -202
- package/lib/templates/project/reactb2e/_r_/webapp-skills-first.md +0 -26
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/DetailFields.tsx +0 -55
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/DetailForm.tsx +0 -146
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/DetailHeader.tsx +0 -34
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/DetailLayoutSections.tsx +0 -80
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/Section.tsx +0 -108
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/SectionRow.tsx +0 -20
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/UiApiDetailForm.tsx +0 -140
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/_fmt_/FieldValueDisplay.tsx +0 -73
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/_fmt_/FormattedAddress.tsx +0 -29
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/_fmt_/FormattedEmail.tsx +0 -17
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/_fmt_/FormattedPhone.tsx +0 -24
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/_fmt_/FormattedText.tsx +0 -11
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/_det_/_fmt_/FormattedUrl.tsx +0 -29
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/filters/FilterField.tsx +0 -54
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/filters/FilterInput.tsx +0 -55
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/filters/FilterSelect.tsx +0 -72
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/filters/FiltersPanel.tsx +0 -380
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/forms/filters-form.tsx +0 -114
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/forms/submit-button.tsx +0 -47
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/search/GlobalSearchInput.tsx +0 -114
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/search/ResultCardFields.tsx +0 -71
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/search/SearchHeader.tsx +0 -31
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/search/SearchPagination.tsx +0 -144
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/search/SearchResultCard.tsx +0 -136
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/search/SearchResultsPanel.tsx +0 -197
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/_c_/shared/LoadingFallback.tsx +0 -61
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/api/objectDetailService.ts +0 -102
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/api/objectInfoGraphQLService.ts +0 -137
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/api/objectInfoService.ts +0 -95
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/api/recordListGraphQLService.ts +0 -364
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/constants.ts +0 -39
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/filters/FilterInput.tsx +0 -55
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/filters/FilterSelect.tsx +0 -72
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/hooks/form.tsx +0 -209
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/hooks/useObjectInfoBatch.ts +0 -65
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/hooks/useObjectSearchData.ts +0 -174
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/hooks/useRecordDetailLayout.ts +0 -137
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/hooks/useRecordListGraphQL.ts +0 -135
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/pages/DetailPage.tsx +0 -109
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/pages/GlobalSearch.tsx +0 -229
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/types/filters/filters.ts +0 -121
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/types/filters/picklist.ts +0 -6
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/types/objectInfo/objectInfo.ts +0 -49
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/types/recordDetail/recordDetail.ts +0 -61
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/types/schema.d.ts +0 -200
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/types/search/searchResults.ts +0 -229
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/apiUtils.ts +0 -59
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/cacheUtils.ts +0 -76
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/debounce.ts +0 -89
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/fieldUtils.ts +0 -354
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/fieldValueExtractor.ts +0 -67
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/filterUtils.ts +0 -32
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/formDataTransformUtils.ts +0 -260
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/formUtils.ts +0 -142
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/graphQLNodeFieldUtils.ts +0 -186
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/graphQLObjectInfoAdapter.ts +0 -77
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/graphQLRecordAdapter.ts +0 -90
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/layoutTransformUtils.ts +0 -236
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/linkUtils.ts +0 -14
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/paginationUtils.ts +0 -49
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/recordUtils.ts +0 -159
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/_f_/_gs_/utils/sanitizationUtils.ts +0 -49
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/src/index.ts +0 -120
- package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/tsconfig.tsbuildinfo +0 -1
- package/lib/templates/project/reactb2x/_r_/features/feature-graphql-graphql-data-access-rule.md +0 -470
- package/lib/templates/project/reactb2x/_r_/features/feature-react-agentforce-conversation-client-embedded-agent-rule.md +0 -18
- package/lib/templates/project/reactb2x/_r_/features/feature-react-chart-analytics-charts-rule.md +0 -27
- package/lib/templates/project/reactb2x/_r_/skills/_k_/SKILL.md +0 -148
- package/lib/templates/project/reactb2x/_r_/skills/_k_/docs/embed-examples.md +0 -192
- package/lib/templates/project/reactb2x/_r_/skills/_k_/docs/troubleshooting.md +0 -51
- package/lib/templates/project/reactb2x/_r_/skills/feature-graphql-graphql-data-access/SKILL.md +0 -155
- package/lib/templates/project/reactb2x/_r_/skills/feature-graphql-graphql-data-access/docs/explore-schema.md +0 -256
- package/lib/templates/project/reactb2x/_r_/skills/feature-graphql-graphql-data-access/docs/generate-mutation-query.md +0 -228
- package/lib/templates/project/reactb2x/_r_/skills/feature-graphql-graphql-data-access/docs/generate-read-query.md +0 -202
- package/lib/templates/project/reactb2x/_r_/skills/feature-graphql-graphql-data-access/docs/shared-schema.graphqls +0 -1150
- package/lib/templates/project/reactb2x/_r_/skills/feature-micro-frontend-micro-frontend/SKILL.md +0 -137
- package/lib/templates/project/reactb2x/_r_/skills/feature-react-chart-analytics-charts/SKILL.md +0 -41
- package/lib/templates/project/reactb2x/_r_/skills/feature-react-chart-analytics-charts/docs/schema-mapping.md +0 -4
- package/lib/templates/project/reactb2x/_r_/skills/webapp-react-interactive-map/SKILL.md +0 -92
- package/lib/templates/project/reactb2x/_r_/skills/webapp-react-interactive-map/implementation/geocoding.md +0 -245
- package/lib/templates/project/reactb2x/_r_/skills/webapp-react-interactive-map/implementation/leaflet-map.md +0 -279
- package/lib/templates/project/reactb2x/_r_/skills/webapp-react-weather-widget/SKILL.md +0 -65
- package/lib/templates/project/reactb2x/_r_/skills/webapp-react-weather-widget/implementation/weather-hook.md +0 -258
- package/lib/templates/project/reactb2x/_r_/skills/webapp-react-weather-widget/implementation/weather-ui.md +0 -216
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/SKILL.md +0 -271
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/data/charts.csv +0 -26
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/data/colors.csv +0 -97
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/data/icons.csv +0 -101
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/data/landing.csv +0 -31
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/data/products.csv +0 -97
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/data/react-performance.csv +0 -45
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/data/stacks/html-tailwind.csv +0 -56
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/data/stacks/react.csv +0 -54
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/data/stacks/shadcn.csv +0 -61
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/data/styles.csv +0 -68
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/data/typography.csv +0 -58
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/data/ui-reasoning.csv +0 -101
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/data/ux-guidelines.csv +0 -100
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/data/web-interface.csv +0 -31
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/scripts/core.js +0 -255
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/scripts/design_system.js +0 -861
- package/lib/templates/project/reactb2x/_r_/skills/webapp-ui-ux/scripts/search.js +0 -98
- package/lib/templates/project/reactb2x/_r_/skills/webapp-unsplash-images/SKILL.md +0 -71
- package/lib/templates/project/reactb2x/_r_/skills/webapp-unsplash-images/implementation/usage.md +0 -159
- package/lib/templates/project/reactb2x/_r_/webapp-cli-commands.md +0 -88
- package/lib/templates/project/reactb2x/_r_/webapp-react-code-quality.md +0 -136
- package/lib/templates/project/reactb2x/_r_/webapp-react-typescript.md +0 -205
- package/lib/templates/project/reactb2x/_r_/webapp-react.md +0 -202
- package/lib/templates/project/reactb2x/_r_/webapp-skills-first.md +0 -26
- /package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/{src/components.json → components.json} +0 -0
- /package/lib/templates/project/reactb2e/_r_/skills/{webapp-react-data-visualization → building-data-visualization}/implementation/dashboard-layout.md +0 -0
- /package/lib/templates/project/reactb2e/_r_/skills/{webapp-react-data-visualization → building-data-visualization}/implementation/stat-card.md +0 -0
- /package/lib/templates/project/reactb2e/_r_/skills/{webapp-react → building-react-components}/implementation/component.md +0 -0
- /package/lib/templates/project/reactb2e/_r_/skills/{webapp-react → building-react-components}/implementation/header-footer.md +0 -0
- /package/lib/templates/project/reactb2e/_r_/skills/{webapp-react → building-react-components}/implementation/page.md +0 -0
- /package/lib/templates/project/reactb2e/_r_/skills/{webapp-csp-trusted-sites → configuring-csp-trusted-sites}/implementation/metadata-format.md +0 -0
- /package/lib/templates/project/reactb2x/_p_/_m_/_w_/_a_/{src/components.json → components.json} +0 -0
- /package/lib/templates/project/reactb2x/_r_/skills/{webapp-react-data-visualization → building-data-visualization}/implementation/dashboard-layout.md +0 -0
- /package/lib/templates/project/reactb2x/_r_/skills/{webapp-react-data-visualization → building-data-visualization}/implementation/stat-card.md +0 -0
- /package/lib/templates/project/reactb2x/_r_/skills/{webapp-react → building-react-components}/implementation/component.md +0 -0
- /package/lib/templates/project/reactb2x/_r_/skills/{webapp-react → building-react-components}/implementation/header-footer.md +0 -0
- /package/lib/templates/project/reactb2x/_r_/skills/{webapp-react → building-react-components}/implementation/page.md +0 -0
- /package/lib/templates/project/reactb2x/_r_/skills/{webapp-csp-trusted-sites → configuring-csp-trusted-sites}/implementation/metadata-format.md +0 -0
- /package/lib/templates/webapplication/reactbasic/{src/components.json → components.json} +0 -0
package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/api/objectDetailService.ts
DELETED
|
@@ -1,102 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Record detail service: layout (REST), object metadata (GraphQL), single record (GraphQL).
|
|
3
|
-
*
|
|
4
|
-
* getRecordDetail orchestrates layout + objectInfoBatch + getRecordByIdGraphQL for the detail page.
|
|
5
|
-
* Layout is still REST (uiApiClient); record and object info are GraphQL-backed.
|
|
6
|
-
*
|
|
7
|
-
* @module api/objectDetailService
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
import { uiApiClient } from "@salesforce/webapp-experimental/api";
|
|
11
|
-
import type { LayoutResponse } from "../types/recordDetail/recordDetail";
|
|
12
|
-
import { LayoutResponseSchema } from "../types/recordDetail/recordDetail";
|
|
13
|
-
import { fetchAndValidate, safeEncodePath } from "../utils/apiUtils";
|
|
14
|
-
import { objectInfoService } from "./objectInfoService";
|
|
15
|
-
import type { ObjectInfoResult } from "../types/objectInfo/objectInfo";
|
|
16
|
-
import { getRecordByIdGraphQL, type GraphQLRecordNode } from "./recordListGraphQLService";
|
|
17
|
-
import type { Column } from "../types/search/searchResults";
|
|
18
|
-
import { calculateFieldsToFetch } from "../utils/recordUtils";
|
|
19
|
-
|
|
20
|
-
/** Fallback when record type is unknown. Prefer recordTypeId from the record (e.g. from search or record response) when available. */
|
|
21
|
-
const DEFAULT_RECORD_TYPE_ID = "012000000000000AAA";
|
|
22
|
-
|
|
23
|
-
/**
|
|
24
|
-
* Returns field API names to request for a record from the given layout and object metadata.
|
|
25
|
-
* Used to derive GraphQL columns from layout (detail view). Delegates to recordUtils.calculateFieldsToFetch.
|
|
26
|
-
*
|
|
27
|
-
* @param objectMetadata - Object info (fields, relationshipName, etc.).
|
|
28
|
-
* @param layout - Layout response (sections, layoutItems, layoutComponents).
|
|
29
|
-
* @returns Array of field API names (e.g. ["Name", "OwnerId", "Owner", "CreatedDate"]).
|
|
30
|
-
*/
|
|
31
|
-
export function extractFieldsFromLayout(
|
|
32
|
-
objectMetadata: ObjectInfoResult,
|
|
33
|
-
layout: LayoutResponse,
|
|
34
|
-
): string[] {
|
|
35
|
-
const [optionalFields] = calculateFieldsToFetch(objectMetadata, layout, false);
|
|
36
|
-
return optionalFields;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
export async function getLayout(
|
|
40
|
-
objectApiName: string,
|
|
41
|
-
recordTypeId: string = DEFAULT_RECORD_TYPE_ID,
|
|
42
|
-
): Promise<LayoutResponse> {
|
|
43
|
-
const params = new URLSearchParams({
|
|
44
|
-
layoutType: "Full",
|
|
45
|
-
mode: "View",
|
|
46
|
-
recordTypeId,
|
|
47
|
-
});
|
|
48
|
-
return fetchAndValidate(
|
|
49
|
-
() => uiApiClient.get(`/layout/${safeEncodePath(objectApiName)}?${params.toString()}`),
|
|
50
|
-
{
|
|
51
|
-
schema: LayoutResponseSchema,
|
|
52
|
-
errorContext: `layout for ${objectApiName}`,
|
|
53
|
-
},
|
|
54
|
-
);
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
export interface RecordDetailResult {
|
|
58
|
-
layout: LayoutResponse;
|
|
59
|
-
record: GraphQLRecordNode;
|
|
60
|
-
objectMetadata: ObjectInfoResult;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
/**
|
|
64
|
-
* Converts layout-derived optionalFields (field API names) to Column[] for GraphQL node selection.
|
|
65
|
-
* Uses unqualified names (no entity prefix) so the GraphQL query matches UI API shape.
|
|
66
|
-
* Other Column fields (label, searchable, sortable) are only required by the type; GraphQL selection uses fieldApiName only.
|
|
67
|
-
*/
|
|
68
|
-
function optionalFieldsToColumns(optionalFields: string[]): Column[] {
|
|
69
|
-
return optionalFields.map((fieldApiName) => ({
|
|
70
|
-
fieldApiName,
|
|
71
|
-
label: "",
|
|
72
|
-
searchable: false,
|
|
73
|
-
sortable: false,
|
|
74
|
-
}));
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
export async function getRecordDetail(
|
|
78
|
-
objectApiName: string,
|
|
79
|
-
recordId: string,
|
|
80
|
-
recordTypeId: string = DEFAULT_RECORD_TYPE_ID,
|
|
81
|
-
): Promise<RecordDetailResult> {
|
|
82
|
-
const layout = await getLayout(objectApiName, recordTypeId);
|
|
83
|
-
const objectMetadata = await objectInfoService.getObjectInfoBatch(objectApiName);
|
|
84
|
-
const firstResult = objectMetadata?.results?.[0]?.result;
|
|
85
|
-
if (!firstResult) {
|
|
86
|
-
throw new Error(`Object metadata not found for ${objectApiName}`);
|
|
87
|
-
}
|
|
88
|
-
// Layout-driven optionalFields (fields shown on the detail layout), not list columns
|
|
89
|
-
const [optionalFields] = calculateFieldsToFetch(firstResult, layout, false);
|
|
90
|
-
const columns = optionalFieldsToColumns(optionalFields);
|
|
91
|
-
const record = await getRecordByIdGraphQL(objectApiName, recordId, columns);
|
|
92
|
-
if (!record) {
|
|
93
|
-
throw new Error(`Record not found: ${recordId}`);
|
|
94
|
-
}
|
|
95
|
-
return { layout, record, objectMetadata: firstResult };
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
export const objectDetailService = {
|
|
99
|
-
extractFieldsFromLayout,
|
|
100
|
-
getLayout,
|
|
101
|
-
getRecordDetail,
|
|
102
|
-
};
|
package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/api/objectInfoGraphQLService.ts
DELETED
|
@@ -1,137 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Object metadata GraphQL service (uiapi.objectInfos).
|
|
3
|
-
*
|
|
4
|
-
* Single endpoint for object describe and picklist values. Used by objectInfoService
|
|
5
|
-
* to implement getObjectInfoBatch and getPicklistValues. Not used directly by UI.
|
|
6
|
-
*
|
|
7
|
-
* @module api/objectInfoGraphQLService
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
import { getDataSDK, gql } from "@salesforce/sdk-data";
|
|
11
|
-
import type {
|
|
12
|
-
GetObjectInfosQuery,
|
|
13
|
-
GetObjectInfosQueryVariables,
|
|
14
|
-
GetPicklistValuesQuery,
|
|
15
|
-
GetPicklistValuesQueryVariables,
|
|
16
|
-
ObjectInfoInput,
|
|
17
|
-
} from "../types/schema";
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* Builds objectInfos query (metadata only). Uses apiNames only — do not pass objectInfoInputs.
|
|
21
|
-
*/
|
|
22
|
-
const OBJECT_INFOS_QUERY = gql`
|
|
23
|
-
query GetObjectInfos($apiNames: [String!]!) {
|
|
24
|
-
uiapi {
|
|
25
|
-
objectInfos(apiNames: $apiNames) {
|
|
26
|
-
ApiName
|
|
27
|
-
label
|
|
28
|
-
labelPlural
|
|
29
|
-
nameFields
|
|
30
|
-
defaultRecordTypeId
|
|
31
|
-
keyPrefix
|
|
32
|
-
layoutable
|
|
33
|
-
queryable
|
|
34
|
-
searchable
|
|
35
|
-
updateable
|
|
36
|
-
deletable
|
|
37
|
-
createable
|
|
38
|
-
custom
|
|
39
|
-
mruEnabled
|
|
40
|
-
feedEnabled
|
|
41
|
-
fields {
|
|
42
|
-
ApiName
|
|
43
|
-
label
|
|
44
|
-
dataType
|
|
45
|
-
relationshipName
|
|
46
|
-
reference
|
|
47
|
-
compound
|
|
48
|
-
compoundFieldName
|
|
49
|
-
compoundComponentName
|
|
50
|
-
controllingFields
|
|
51
|
-
controllerName
|
|
52
|
-
referenceToInfos {
|
|
53
|
-
ApiName
|
|
54
|
-
nameFields
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
recordTypeInfos {
|
|
58
|
-
recordTypeId
|
|
59
|
-
name
|
|
60
|
-
master
|
|
61
|
-
available
|
|
62
|
-
defaultRecordTypeMapping
|
|
63
|
-
}
|
|
64
|
-
themeInfo {
|
|
65
|
-
color
|
|
66
|
-
iconUrl
|
|
67
|
-
}
|
|
68
|
-
childRelationships {
|
|
69
|
-
relationshipName
|
|
70
|
-
fieldName
|
|
71
|
-
childObjectApiName
|
|
72
|
-
}
|
|
73
|
-
dependentFields {
|
|
74
|
-
controllingField
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
`;
|
|
80
|
-
|
|
81
|
-
/**
|
|
82
|
-
* Builds objectInfos query with picklist values (API v65.0+).
|
|
83
|
-
* Schema requires objectInfos to be called with either apiNames or objectInfoInputs, not both.
|
|
84
|
-
* This query uses objectInfoInputs only.
|
|
85
|
-
* Optimized to only fetch fields used by extractPicklistValuesFromGraphQLObjectInfo.
|
|
86
|
-
*/
|
|
87
|
-
const PICKLIST_VALUES_QUERY = gql`
|
|
88
|
-
query GetPicklistValues($objectInfoInputs: [ObjectInfoInput!]!) {
|
|
89
|
-
uiapi {
|
|
90
|
-
objectInfos(objectInfoInputs: $objectInfoInputs) {
|
|
91
|
-
ApiName
|
|
92
|
-
fields {
|
|
93
|
-
ApiName
|
|
94
|
-
... on PicklistField {
|
|
95
|
-
picklistValuesByRecordTypeIDs {
|
|
96
|
-
recordTypeID
|
|
97
|
-
defaultValue {
|
|
98
|
-
value
|
|
99
|
-
}
|
|
100
|
-
picklistValues {
|
|
101
|
-
label
|
|
102
|
-
value
|
|
103
|
-
validFor
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
`;
|
|
112
|
-
|
|
113
|
-
export async function queryForObjectInfos(apiNames: string[]): Promise<GetObjectInfosQuery> {
|
|
114
|
-
return runQuery<GetObjectInfosQuery, GetObjectInfosQueryVariables>(OBJECT_INFOS_QUERY, {
|
|
115
|
-
apiNames,
|
|
116
|
-
});
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
export async function queryForPicklistValues(
|
|
120
|
-
objectInfoInputs: ObjectInfoInput[],
|
|
121
|
-
): Promise<GetPicklistValuesQuery> {
|
|
122
|
-
return runQuery<GetPicklistValuesQuery, GetPicklistValuesQueryVariables>(PICKLIST_VALUES_QUERY, {
|
|
123
|
-
objectInfoInputs,
|
|
124
|
-
});
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
async function runQuery<Q, V>(query: string, variables: V): Promise<Q> {
|
|
128
|
-
const data = await getDataSDK();
|
|
129
|
-
const response = await data.graphql?.<Q, V>(query, variables);
|
|
130
|
-
|
|
131
|
-
if (response?.errors?.length) {
|
|
132
|
-
const errorMessages = response.errors.map((e) => e.message).join("; ");
|
|
133
|
-
throw new Error(`GraphQL Error: ${errorMessages}`);
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
return response?.data ?? ({} as Q);
|
|
137
|
-
}
|
package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/api/objectInfoService.ts
DELETED
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
import { uiApiClient } from "@salesforce/webapp-experimental/api";
|
|
2
|
-
import type { Filter } from "../types/filters/filters";
|
|
3
|
-
import { FilterArraySchema } from "../types/filters/filters";
|
|
4
|
-
import type { PicklistValue } from "../types/filters/picklist";
|
|
5
|
-
import type { ObjectInfoBatchResponse } from "../types/objectInfo/objectInfo";
|
|
6
|
-
import { fetchAndValidate, safeEncodePath } from "../utils/apiUtils";
|
|
7
|
-
import { queryForObjectInfos, queryForPicklistValues } from "./objectInfoGraphQLService";
|
|
8
|
-
import {
|
|
9
|
-
graphQLObjectInfosToBatchResponse,
|
|
10
|
-
extractPicklistValuesFromGraphQLObjectInfo,
|
|
11
|
-
} from "../utils/graphQLObjectInfoAdapter";
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Object info and search service.
|
|
15
|
-
*
|
|
16
|
-
* - getObjectInfoBatch / getPicklistValues: GraphQL (objectInfoGraphQLService).
|
|
17
|
-
* - getObjectListFilters: REST (search-info).
|
|
18
|
-
* Hooks use this service; components do not call it directly.
|
|
19
|
-
*
|
|
20
|
-
* @module api/objectInfoService
|
|
21
|
-
*/
|
|
22
|
-
|
|
23
|
-
/** Cache key: sorted, comma-joined object API names. */
|
|
24
|
-
function getObjectInfoBatchCacheKey(objectApiNames: string): string {
|
|
25
|
-
const names = objectApiNames
|
|
26
|
-
.split(",")
|
|
27
|
-
.map((s) => s.trim())
|
|
28
|
-
.filter(Boolean);
|
|
29
|
-
return [...names].sort().join(",");
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
const objectInfoBatchCache = new Map<string, ObjectInfoBatchResponse>();
|
|
33
|
-
const objectInfoBatchInFlight = new Map<string, Promise<ObjectInfoBatchResponse>>();
|
|
34
|
-
|
|
35
|
-
export async function getObjectInfoBatch(objectApiNames: string): Promise<ObjectInfoBatchResponse> {
|
|
36
|
-
const names = objectApiNames
|
|
37
|
-
.split(",")
|
|
38
|
-
.map((s) => s.trim())
|
|
39
|
-
.filter(Boolean);
|
|
40
|
-
if (names.length === 0) {
|
|
41
|
-
return { results: [] };
|
|
42
|
-
}
|
|
43
|
-
const key = getObjectInfoBatchCacheKey(objectApiNames);
|
|
44
|
-
const cached = objectInfoBatchCache.get(key);
|
|
45
|
-
if (cached) return Promise.resolve(cached);
|
|
46
|
-
const inFlight = objectInfoBatchInFlight.get(key);
|
|
47
|
-
if (inFlight) return inFlight;
|
|
48
|
-
const promise = (async () => {
|
|
49
|
-
try {
|
|
50
|
-
const response = await queryForObjectInfos(names);
|
|
51
|
-
const nodes = response?.uiapi?.objectInfos ?? [];
|
|
52
|
-
const result = graphQLObjectInfosToBatchResponse(nodes, names);
|
|
53
|
-
objectInfoBatchCache.set(key, result);
|
|
54
|
-
return result;
|
|
55
|
-
} finally {
|
|
56
|
-
objectInfoBatchInFlight.delete(key);
|
|
57
|
-
}
|
|
58
|
-
})();
|
|
59
|
-
objectInfoBatchInFlight.set(key, promise);
|
|
60
|
-
return promise;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
export async function getObjectListFilters(objectApiName: string): Promise<Filter[]> {
|
|
64
|
-
return fetchAndValidate(
|
|
65
|
-
() => uiApiClient.get(`/search-info/${safeEncodePath(objectApiName)}/filters`),
|
|
66
|
-
{
|
|
67
|
-
schema: FilterArraySchema,
|
|
68
|
-
errorContext: `filters for ${objectApiName}`,
|
|
69
|
-
extractData: (data: unknown) => {
|
|
70
|
-
if (!data) return [];
|
|
71
|
-
return Array.isArray(data) ? data : (data as { filters?: unknown }).filters || [];
|
|
72
|
-
},
|
|
73
|
-
},
|
|
74
|
-
);
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
export async function getPicklistValues(
|
|
78
|
-
objectApiName: string,
|
|
79
|
-
fieldName: string,
|
|
80
|
-
recordTypeId: string = "012000000000000AAA",
|
|
81
|
-
): Promise<PicklistValue[]> {
|
|
82
|
-
const response = await queryForPicklistValues([
|
|
83
|
-
{ apiName: objectApiName, fieldNames: [fieldName] },
|
|
84
|
-
]);
|
|
85
|
-
const nodes = response?.uiapi?.objectInfos ?? [];
|
|
86
|
-
const node = nodes[0];
|
|
87
|
-
if (!node) return [];
|
|
88
|
-
return extractPicklistValuesFromGraphQLObjectInfo(node, fieldName, recordTypeId);
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
export const objectInfoService = {
|
|
92
|
-
getObjectInfoBatch,
|
|
93
|
-
getObjectListFilters,
|
|
94
|
-
getPicklistValues,
|
|
95
|
-
};
|
package/lib/templates/project/reactb2e/_p_/_m_/_w_/_a_/src/_f_/_gs_/api/recordListGraphQLService.ts
DELETED
|
@@ -1,364 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Record GraphQL Service
|
|
3
|
-
*
|
|
4
|
-
* Single service for querying Salesforce object records via GraphQL UI API (uiapi.query).
|
|
5
|
-
* Handles both list (paginated, filter, sort, search) and single-record-by-id using one query shape.
|
|
6
|
-
*
|
|
7
|
-
* @module api/recordListGraphQLService
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
import { getDataSDK } from "@salesforce/sdk-data";
|
|
11
|
-
import type { Column } from "../types/search/searchResults";
|
|
12
|
-
import type { FilterCriteria } from "../types/filters/filters";
|
|
13
|
-
|
|
14
|
-
const DEFAULT_PAGE_SIZE = 50;
|
|
15
|
-
|
|
16
|
-
/** Tree of selection: leaf is "value", branch is nested fields. Keys starting with __on_ are inline fragments (e.g. __on_User). */
|
|
17
|
-
interface SelectionTree {
|
|
18
|
-
[key: string]: "value" | SelectionTree;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
/**
|
|
22
|
-
* Polymorphic relationship fields and the concrete GraphQL types they can resolve to.
|
|
23
|
-
* Only relationship names listed here use inline fragments; others use direct selection
|
|
24
|
-
* (e.g. Parent -> Parent { Name { value } } because "Parent" is not a schema type).
|
|
25
|
-
* We use a single fragment per field to avoid schema validation errors (e.g. User and Group
|
|
26
|
-
* cannot both be spread in the same selection in some contexts).
|
|
27
|
-
*/
|
|
28
|
-
const POLYMORPHIC_RELATIONSHIP_TYPES: Record<string, string[]> = {
|
|
29
|
-
Owner: ["User"],
|
|
30
|
-
CreatedBy: ["User"],
|
|
31
|
-
LastModifiedBy: ["User"],
|
|
32
|
-
};
|
|
33
|
-
|
|
34
|
-
/**
|
|
35
|
-
* Builds a selection tree from columns (fieldApiName). Simple fields (e.g. Name, OwnerId) become
|
|
36
|
-
* top-level leaves. Relationship fields that are in POLYMORPHIC_RELATIONSHIP_TYPES use a single
|
|
37
|
-
* inline fragment on the first concrete type (e.g. ... on User). All other relationship fields
|
|
38
|
-
* (e.g. Parent, Account) use direct selection (e.g. Parent { Name { value } }) because the
|
|
39
|
-
* relationship name is not necessarily a GraphQL type name (e.g. Parent resolves to Account).
|
|
40
|
-
*/
|
|
41
|
-
function buildSelectionTree(columns: Column[]): SelectionTree {
|
|
42
|
-
const allFieldNames = new Set(columns.map((c) => (c.fieldApiName ?? "").trim()).filter(Boolean));
|
|
43
|
-
const tree: SelectionTree = { Id: "value" };
|
|
44
|
-
for (const col of columns) {
|
|
45
|
-
const name = (col.fieldApiName ?? "").trim();
|
|
46
|
-
if (!name) continue;
|
|
47
|
-
const parts = name.split(".");
|
|
48
|
-
if (parts.length === 1) {
|
|
49
|
-
const fieldName = parts[0];
|
|
50
|
-
const hasCorrespondingId = allFieldNames.has(`${fieldName}Id`);
|
|
51
|
-
if (hasCorrespondingId) {
|
|
52
|
-
const knownTypes = POLYMORPHIC_RELATIONSHIP_TYPES[fieldName];
|
|
53
|
-
if (knownTypes?.length) {
|
|
54
|
-
// Use a single inline fragment to avoid "User can never be Group" validation errors
|
|
55
|
-
const typeName = knownTypes[0];
|
|
56
|
-
tree[fieldName] = { [`__on_${typeName}`]: { Name: "value" } };
|
|
57
|
-
} else {
|
|
58
|
-
// Relationship name (e.g. Parent) is not a GraphQL type; use direct selection
|
|
59
|
-
tree[fieldName] = { Name: "value" };
|
|
60
|
-
}
|
|
61
|
-
} else {
|
|
62
|
-
tree[fieldName] = "value";
|
|
63
|
-
}
|
|
64
|
-
} else {
|
|
65
|
-
let current = tree;
|
|
66
|
-
for (let i = 0; i < parts.length; i++) {
|
|
67
|
-
const part = parts[i];
|
|
68
|
-
const isLeaf = i === parts.length - 1;
|
|
69
|
-
if (isLeaf) {
|
|
70
|
-
current[part] = "value";
|
|
71
|
-
} else {
|
|
72
|
-
const existing = current[part];
|
|
73
|
-
if (existing === "value") continue;
|
|
74
|
-
if (!existing) {
|
|
75
|
-
current[part] = {};
|
|
76
|
-
}
|
|
77
|
-
current = current[part] as SelectionTree;
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
return tree;
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
/**
|
|
86
|
-
* Serializes a selection tree to GraphQL selection set string.
|
|
87
|
-
* Keys starting with __on_ are emitted as inline fragments (... on TypeName { ... }).
|
|
88
|
-
* Id is scalar (no subselection); other leaves use { value }.
|
|
89
|
-
*/
|
|
90
|
-
function serializeSelectionTree(tree: SelectionTree, indent: string): string {
|
|
91
|
-
const fragmentKeys = Object.keys(tree).filter((k) => k.startsWith("__on_"));
|
|
92
|
-
const normalKeys = Object.keys(tree).filter((k) => !k.startsWith("__on_"));
|
|
93
|
-
normalKeys.sort((a, b) => {
|
|
94
|
-
if (a === "Id") return -1;
|
|
95
|
-
if (b === "Id") return 1;
|
|
96
|
-
return a.localeCompare(b);
|
|
97
|
-
});
|
|
98
|
-
fragmentKeys.sort();
|
|
99
|
-
const lines: string[] = [];
|
|
100
|
-
const childIndent = `${indent} `;
|
|
101
|
-
for (const key of normalKeys) {
|
|
102
|
-
const val = tree[key];
|
|
103
|
-
if (val === "value") {
|
|
104
|
-
if (key === "Id") {
|
|
105
|
-
lines.push(`${indent}Id`);
|
|
106
|
-
} else {
|
|
107
|
-
lines.push(`${indent}${key} { value }`);
|
|
108
|
-
}
|
|
109
|
-
} else {
|
|
110
|
-
lines.push(`${indent}${key} {`);
|
|
111
|
-
lines.push(serializeSelectionTree(val, childIndent));
|
|
112
|
-
lines.push(`${indent}}`);
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
for (const key of fragmentKeys) {
|
|
116
|
-
const typeName = key.slice(5);
|
|
117
|
-
const val = tree[key];
|
|
118
|
-
if (val && typeof val === "object") {
|
|
119
|
-
lines.push(`${indent}... on ${typeName} {`);
|
|
120
|
-
lines.push(serializeSelectionTree(val, childIndent));
|
|
121
|
-
lines.push(`${indent}}`);
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
return lines.join("\n");
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
function buildNodeSelection(columns: Column[]): string {
|
|
128
|
-
const tree = buildSelectionTree(columns);
|
|
129
|
-
return serializeSelectionTree(tree, " ");
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
/**
|
|
133
|
-
* Builds GraphQL where clause from filter criteria and optional search text.
|
|
134
|
-
* Search text is applied as Name like %query%. Multiple conditions are combined with and.
|
|
135
|
-
*
|
|
136
|
-
* @param criteria - Field filters (fieldPath, operator, values).
|
|
137
|
-
* @param searchQuery - Optional; adds Name like %searchQuery% when provided.
|
|
138
|
-
*/
|
|
139
|
-
export function buildWhereFromCriteria(
|
|
140
|
-
criteria: FilterCriteria[],
|
|
141
|
-
searchQuery?: string,
|
|
142
|
-
): Record<string, unknown> | null {
|
|
143
|
-
const conditions: Record<string, unknown>[] = [];
|
|
144
|
-
|
|
145
|
-
if (searchQuery && searchQuery.trim()) {
|
|
146
|
-
const term = `%${searchQuery.trim()}%`;
|
|
147
|
-
conditions.push({ Name: { like: term } });
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
for (const c of criteria) {
|
|
151
|
-
if (!c.fieldPath || !c.operator || !c.values?.length) continue;
|
|
152
|
-
const op = c.operator;
|
|
153
|
-
const parts = c.fieldPath.split(".");
|
|
154
|
-
const fieldClause = op === "in" ? { in: c.values } : { [op]: c.values[0] };
|
|
155
|
-
if (parts.length === 1) {
|
|
156
|
-
conditions.push({ [parts[0]]: fieldClause });
|
|
157
|
-
} else {
|
|
158
|
-
let nested: Record<string, unknown> = { [parts[parts.length - 1]]: fieldClause };
|
|
159
|
-
for (let i = parts.length - 2; i >= 0; i--) {
|
|
160
|
-
nested = { [parts[i]]: nested };
|
|
161
|
-
}
|
|
162
|
-
conditions.push(nested);
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
if (conditions.length === 0) return null;
|
|
167
|
-
if (conditions.length === 1) return conditions[0] as Record<string, unknown>;
|
|
168
|
-
return { and: conditions };
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
/**
|
|
172
|
-
* Parses sortBy string (e.g. "Name", "Name ASC", "AnnualRevenue DESC") into GraphQL orderBy shape.
|
|
173
|
-
* Default direction is ASC.
|
|
174
|
-
*/
|
|
175
|
-
export function buildOrderByFromSort(
|
|
176
|
-
sortBy: string,
|
|
177
|
-
): Record<string, { order: "ASC" | "DESC" }> | null {
|
|
178
|
-
const trimmed = (sortBy ?? "").trim();
|
|
179
|
-
if (!trimmed || trimmed.toLowerCase() === "relevance") return null;
|
|
180
|
-
const parts = trimmed.split(/\s+/);
|
|
181
|
-
const field = parts[0];
|
|
182
|
-
const dir = parts[1]?.toUpperCase() === "DESC" ? "DESC" : "ASC";
|
|
183
|
-
return { [field]: { order: dir } };
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
/** Variables for the GetRecords GraphQL operation. */
|
|
187
|
-
export interface RecordListGraphQLVariables {
|
|
188
|
-
first?: number;
|
|
189
|
-
after?: string | null;
|
|
190
|
-
where?: Record<string, unknown> | null;
|
|
191
|
-
orderBy?: Record<string, unknown> | null;
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
export interface RecordListGraphQLOptions {
|
|
195
|
-
objectApiName: string;
|
|
196
|
-
columns: Column[];
|
|
197
|
-
/** When set, fetches a single record by Id (first=1, where Id eq); used for detail view. */
|
|
198
|
-
recordId?: string | null;
|
|
199
|
-
first?: number;
|
|
200
|
-
after?: string | null;
|
|
201
|
-
filters?: FilterCriteria[];
|
|
202
|
-
orderBy?: Record<string, unknown> | null;
|
|
203
|
-
searchQuery?: string;
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
/**
|
|
207
|
-
* Builds the GraphQL query string for uiapi.query.{objectApiName}.
|
|
208
|
-
* Used for both list (pagination, where, orderBy) and single record (where Id eq, first 1).
|
|
209
|
-
*
|
|
210
|
-
* @param objectApiName - API name of the object (e.g. Account, Contact).
|
|
211
|
-
* @param columns - Field selection (becomes node selection via buildNodeSelection).
|
|
212
|
-
* @param options - Optional where and orderBy; when recordId is used, where is set to Id eq.
|
|
213
|
-
*/
|
|
214
|
-
export function buildGetRecordsQuery(
|
|
215
|
-
objectApiName: string,
|
|
216
|
-
columns: Column[],
|
|
217
|
-
options?: { where?: Record<string, unknown> | null; orderBy?: Record<string, unknown> | null },
|
|
218
|
-
): string {
|
|
219
|
-
const nodeSelection = buildNodeSelection(columns);
|
|
220
|
-
const hasWhere = options?.where != null && Object.keys(options.where).length > 0;
|
|
221
|
-
const hasOrderBy = options?.orderBy != null && Object.keys(options.orderBy).length > 0;
|
|
222
|
-
|
|
223
|
-
const filterType = `${objectApiName}_Filter`;
|
|
224
|
-
const orderByType = `${objectApiName}_OrderBy`;
|
|
225
|
-
|
|
226
|
-
const varDecls = [
|
|
227
|
-
"$first: Int",
|
|
228
|
-
"$after: String",
|
|
229
|
-
...(hasWhere ? [`$where: ${filterType}`] : []),
|
|
230
|
-
...(hasOrderBy ? [`$orderBy: ${orderByType}`] : []),
|
|
231
|
-
];
|
|
232
|
-
const opArgs = [
|
|
233
|
-
"first: $first",
|
|
234
|
-
"after: $after",
|
|
235
|
-
...(hasWhere ? ["where: $where"] : []),
|
|
236
|
-
...(hasOrderBy ? ["orderBy: $orderBy"] : []),
|
|
237
|
-
];
|
|
238
|
-
|
|
239
|
-
return `query GetRecords(${varDecls.join(", ")}) {
|
|
240
|
-
uiapi {
|
|
241
|
-
query {
|
|
242
|
-
${objectApiName}(${opArgs.join(", ")}) {
|
|
243
|
-
edges {
|
|
244
|
-
node {
|
|
245
|
-
${nodeSelection}
|
|
246
|
-
}
|
|
247
|
-
}
|
|
248
|
-
pageInfo {
|
|
249
|
-
hasNextPage
|
|
250
|
-
hasPreviousPage
|
|
251
|
-
endCursor
|
|
252
|
-
startCursor
|
|
253
|
-
},
|
|
254
|
-
totalCount,
|
|
255
|
-
pageResultCount
|
|
256
|
-
}
|
|
257
|
-
}
|
|
258
|
-
}
|
|
259
|
-
}`;
|
|
260
|
-
}
|
|
261
|
-
|
|
262
|
-
export interface RecordListGraphQLResult {
|
|
263
|
-
uiapi?: {
|
|
264
|
-
query?: {
|
|
265
|
-
[key: string]: {
|
|
266
|
-
edges?: Array<{ node?: Record<string, unknown> }>;
|
|
267
|
-
pageInfo?: {
|
|
268
|
-
hasNextPage?: boolean;
|
|
269
|
-
hasPreviousPage?: boolean;
|
|
270
|
-
endCursor?: string | null;
|
|
271
|
-
startCursor?: string | null;
|
|
272
|
-
};
|
|
273
|
-
};
|
|
274
|
-
};
|
|
275
|
-
};
|
|
276
|
-
}
|
|
277
|
-
|
|
278
|
-
/** GraphQL node shape for a single record (Id + field selections with value/nested). */
|
|
279
|
-
export type GraphQLRecordNode = Record<string, unknown>;
|
|
280
|
-
|
|
281
|
-
/**
|
|
282
|
-
* Fetches records for the given object via GraphQL (single query for both list and single record).
|
|
283
|
-
*
|
|
284
|
-
* - List: pass first, after, filters, orderBy, searchQuery.
|
|
285
|
-
* - Single record: pass recordId; first is set to 1 and where includes Id eq.
|
|
286
|
-
*
|
|
287
|
-
* @param options.objectApiName - API name of the object (e.g. Account, Contact).
|
|
288
|
-
* @param options.columns - Field selection (from filters-derived columns or layout-derived optionalFields).
|
|
289
|
-
* @param options.recordId - If set, fetches one record by Id (first=1, where Id eq).
|
|
290
|
-
* @param options.first - Page size (default 50; ignored when recordId is set).
|
|
291
|
-
* @param options.after - Cursor for next page.
|
|
292
|
-
* @param options.filters - Filter criteria (mapped to where).
|
|
293
|
-
* @param options.orderBy - GraphQL orderBy; use buildOrderByFromSort(sortBy) when needed.
|
|
294
|
-
* @param options.searchQuery - Text search (Name like %query% in where).
|
|
295
|
-
* @returns Connection result (edges, pageInfo); for recordId callers use edges[0].node.
|
|
296
|
-
*/
|
|
297
|
-
export async function getRecordsGraphQL(
|
|
298
|
-
options: RecordListGraphQLOptions,
|
|
299
|
-
): Promise<RecordListGraphQLResult> {
|
|
300
|
-
const {
|
|
301
|
-
objectApiName,
|
|
302
|
-
columns,
|
|
303
|
-
recordId,
|
|
304
|
-
first = DEFAULT_PAGE_SIZE,
|
|
305
|
-
after = null,
|
|
306
|
-
filters = [],
|
|
307
|
-
orderBy = null,
|
|
308
|
-
searchQuery,
|
|
309
|
-
} = options;
|
|
310
|
-
|
|
311
|
-
const listWhere = buildWhereFromCriteria(filters, searchQuery);
|
|
312
|
-
const where =
|
|
313
|
-
recordId != null && recordId !== ""
|
|
314
|
-
? listWhere != null && Object.keys(listWhere).length > 0
|
|
315
|
-
? { and: [{ Id: { eq: recordId } }, listWhere] }
|
|
316
|
-
: { Id: { eq: recordId } }
|
|
317
|
-
: listWhere;
|
|
318
|
-
const effectiveFirst = recordId != null && recordId !== "" ? 1 : first;
|
|
319
|
-
const hasWhere = where != null && Object.keys(where).length > 0;
|
|
320
|
-
const hasOrderBy = orderBy != null && Object.keys(orderBy).length > 0;
|
|
321
|
-
|
|
322
|
-
const query = buildGetRecordsQuery(objectApiName, columns, { where, orderBy });
|
|
323
|
-
const variables: Record<string, unknown> = {
|
|
324
|
-
first: effectiveFirst,
|
|
325
|
-
after: after ?? null,
|
|
326
|
-
...(hasWhere && where ? { where } : {}),
|
|
327
|
-
...(hasOrderBy && orderBy ? { orderBy } : {}),
|
|
328
|
-
};
|
|
329
|
-
|
|
330
|
-
const data = await getDataSDK();
|
|
331
|
-
const response = await data.graphql?.<RecordListGraphQLResult>(query, variables);
|
|
332
|
-
|
|
333
|
-
if (response?.errors?.length) {
|
|
334
|
-
const errorMessages = response.errors.map((e) => e.message).join("; ");
|
|
335
|
-
throw new Error(`GraphQL Error: ${errorMessages}`);
|
|
336
|
-
}
|
|
337
|
-
|
|
338
|
-
return response?.data ?? ({} as RecordListGraphQLResult);
|
|
339
|
-
}
|
|
340
|
-
|
|
341
|
-
/**
|
|
342
|
-
* Fetches a single record by Id. Uses the same GraphQL query as list (getRecordsGraphQL with recordId + first 1).
|
|
343
|
-
*
|
|
344
|
-
* @param objectApiName - API name of the object.
|
|
345
|
-
* @param recordId - Record Id.
|
|
346
|
-
* @param columns - Field selection (e.g. layout-derived optionalFields as Column[]).
|
|
347
|
-
* @returns The record node or null if not found.
|
|
348
|
-
*/
|
|
349
|
-
export async function getRecordByIdGraphQL(
|
|
350
|
-
objectApiName: string,
|
|
351
|
-
recordId: string,
|
|
352
|
-
columns: Column[],
|
|
353
|
-
): Promise<GraphQLRecordNode | null> {
|
|
354
|
-
const result = await getRecordsGraphQL({
|
|
355
|
-
objectApiName,
|
|
356
|
-
columns,
|
|
357
|
-
recordId,
|
|
358
|
-
first: 1,
|
|
359
|
-
});
|
|
360
|
-
const edges =
|
|
361
|
-
result?.uiapi?.query?.[objectApiName]?.edges ??
|
|
362
|
-
([] as Array<{ node?: Record<string, unknown> }>);
|
|
363
|
-
return (edges[0]?.node ?? null) as GraphQLRecordNode | null;
|
|
364
|
-
}
|