forlogic-core 2.1.4 → 2.2.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.
Files changed (248) hide show
  1. package/.note/memory/features/import/attachment-idempotency-registry.md +8 -8
  2. package/.note/memory/features/import/attachment-strategy.md +30 -30
  3. package/.note/memory/patterns/admin-i18n-policy.md +20 -20
  4. package/.note/memory/patterns/alias-url-resolution.md +69 -69
  5. package/.note/memory/patterns/doc-sync-rule.md +35 -35
  6. package/.note/memory/patterns/documentation-standard.md +17 -17
  7. package/.note/memory/patterns/dynamic-supabase-config.md +4 -4
  8. package/.note/memory/patterns/environment-detection-logic.md +35 -35
  9. package/.note/memory/patterns/i18n-architecture.md +3 -3
  10. package/README.md +120 -68
  11. package/dist/action-plans/components/ActionPlanAttachmentsTab.d.ts +3 -0
  12. package/dist/action-plans/components/ActionPlanCommentsTab.d.ts +3 -0
  13. package/dist/action-plans/components/ActionPlanCostTab.d.ts +5 -0
  14. package/dist/action-plans/components/ActionPlanGeneralTab.d.ts +3 -0
  15. package/dist/action-plans/components/ActionPlanHistoryTab.d.ts +3 -0
  16. package/dist/action-plans/components/ActionPlanPredecessorsTab.d.ts +5 -0
  17. package/dist/action-plans/components/ActionPlanProgressDialog.d.ts +3 -0
  18. package/dist/action-plans/components/ActionPlanProgressTab.d.ts +5 -0
  19. package/dist/action-plans/components/ActionPlanStatusBadge.d.ts +9 -2
  20. package/dist/action-plans/constants.d.ts +24 -0
  21. package/dist/action-plans/hooks/useActionPlan.d.ts +5 -0
  22. package/dist/action-plans/hooks/useActionPlanProgress.d.ts +5 -0
  23. package/dist/action-plans/types.d.ts +60 -0
  24. package/dist/action-plans/utils/formatTime.d.ts +9 -0
  25. package/dist/audit-trail/components/AuditTrailDetails.d.ts +10 -0
  26. package/dist/audit-trail/components/AuditTrailFilter.d.ts +10 -0
  27. package/dist/audit-trail/components/AuditTrailPage.d.ts +10 -0
  28. package/dist/audit-trail/types.d.ts +58 -0
  29. package/dist/audit-trail/utils.d.ts +18 -2
  30. package/dist/auth/components/EditProfileDialog.d.ts +1 -0
  31. package/dist/auth/components/ProtectedRoute.d.ts +5 -0
  32. package/dist/auth/contexts/AuthContext.d.ts +5 -0
  33. package/dist/auth/pages/CallbackPage.d.ts +5 -0
  34. package/dist/auth/services/AuthService.d.ts +5 -0
  35. package/dist/auth/services/TokenManager.d.ts +5 -0
  36. package/dist/auth/services/TokenService.d.ts +10 -0
  37. package/dist/auth/utils/ErrorInterceptor.d.ts +5 -0
  38. package/dist/components/dashboards/dashboard-form.d.ts +15 -0
  39. package/dist/components/dashboards/dashboard-general-view.d.ts +15 -0
  40. package/dist/components/dashboards/dashboard-grid.d.ts +25 -0
  41. package/dist/components/dashboards/dashboard-list.d.ts +10 -0
  42. package/dist/components/dashboards/dashboard-panel-renderer.d.ts +10 -0
  43. package/dist/components/dashboards/dashboard-view.d.ts +10 -0
  44. package/dist/components/dashboards/helpers.d.ts +44 -5
  45. package/dist/components/dashboards/panels/burndown-panel.d.ts +15 -0
  46. package/dist/components/dashboards/panels/cartesian-panel.d.ts +20 -0
  47. package/dist/components/dashboards/panels/list-panel.d.ts +15 -0
  48. package/dist/components/dashboards/panels/matrix-risk-panel.d.ts +25 -0
  49. package/dist/components/dashboards/panels/numeric-panel.d.ts +10 -0
  50. package/dist/components/dashboards/panels/panel-error.d.ts +10 -0
  51. package/dist/components/dashboards/panels/panel-header.d.ts +10 -0
  52. package/dist/components/dashboards/panels/panel-loader.d.ts +10 -0
  53. package/dist/components/dashboards/panels/panel-no-data.d.ts +10 -0
  54. package/dist/components/dashboards/panels/panel-unavailable.d.ts +10 -0
  55. package/dist/components/dashboards/panels/pareto-panel.d.ts +10 -0
  56. package/dist/components/dashboards/panels/performance-panel.d.ts +15 -0
  57. package/dist/components/dashboards/panels/pie-panel.d.ts +10 -0
  58. package/dist/components/dashboards/panels/text-panel.d.ts +10 -0
  59. package/dist/components/dashboards/types.d.ts +230 -0
  60. package/dist/components/modules/AccessDeniedDialog.d.ts +3 -1
  61. package/dist/components/modules/ModuleAccessGuard.d.ts +3 -1
  62. package/dist/components/modules/ModulesContent.d.ts +3 -1
  63. package/dist/components/modules/ModulesDialog.d.ts +1 -1
  64. package/dist/components/modules/ModulesFooterCards.d.ts +3 -1
  65. package/dist/components/modules/types.d.ts +2 -0
  66. package/dist/components/ui/accordion.d.ts +35 -0
  67. package/dist/components/ui/action-button.d.ts +5 -0
  68. package/dist/components/ui/alert-dialog.d.ts +82 -0
  69. package/dist/components/ui/alert.d.ts +32 -0
  70. package/dist/components/ui/avatar.d.ts +30 -0
  71. package/dist/components/ui/badge.d.ts +32 -0
  72. package/dist/components/ui/breadcrumb.d.ts +54 -0
  73. package/dist/components/ui/button-group.d.ts +15 -0
  74. package/dist/components/ui/button.d.ts +55 -0
  75. package/dist/components/ui/calendar.d.ts +16 -0
  76. package/dist/components/ui/card.d.ts +49 -0
  77. package/dist/components/ui/chart.d.ts +35 -0
  78. package/dist/components/ui/checkbox.d.ts +11 -0
  79. package/dist/components/ui/collapsible.d.ts +15 -0
  80. package/dist/components/ui/color-picker.d.ts +5 -0
  81. package/dist/components/ui/combo-tree.d.ts +23 -0
  82. package/dist/components/ui/combobox.d.ts +28 -0
  83. package/dist/components/ui/command.d.ts +66 -0
  84. package/dist/components/ui/context-menu.d.ts +95 -0
  85. package/dist/components/ui/date-picker.d.ts +10 -0
  86. package/dist/components/ui/dialog-wizard.d.ts +22 -4
  87. package/dist/components/ui/dialog.d.ts +181 -0
  88. package/dist/components/ui/drawer.d.ts +72 -0
  89. package/dist/components/ui/dropdown-menu.d.ts +153 -0
  90. package/dist/components/ui/electronic-signature-dialog.d.ts +10 -0
  91. package/dist/components/ui/export-dialog.d.ts +20 -0
  92. package/dist/components/ui/form.d.ts +96 -0
  93. package/dist/components/ui/hover-card.d.ts +15 -0
  94. package/dist/components/ui/icon-picker.d.ts +5 -0
  95. package/dist/components/ui/iframe-dialog.d.ts +10 -0
  96. package/dist/components/ui/input-group.d.ts +16 -0
  97. package/dist/components/ui/input.d.ts +5 -0
  98. package/dist/components/ui/menubar.d.ts +80 -0
  99. package/dist/components/ui/multiselect-permissions.d.ts +25 -0
  100. package/dist/components/ui/navigation-menu.d.ts +45 -0
  101. package/dist/components/ui/onboarding-dialog.d.ts +15 -0
  102. package/dist/components/ui/online-editor-dialog.d.ts +10 -0
  103. package/dist/components/ui/pagination.d.ts +53 -0
  104. package/dist/components/ui/popover.d.ts +8 -0
  105. package/dist/components/ui/radio-group.d.ts +3 -0
  106. package/dist/components/ui/report-request-list.d.ts +20 -0
  107. package/dist/components/ui/resizable.d.ts +15 -0
  108. package/dist/components/ui/rich-text-editor.d.ts +13 -0
  109. package/dist/components/ui/scroll-area.d.ts +3 -0
  110. package/dist/components/ui/select.d.ts +71 -0
  111. package/dist/components/ui/separator.d.ts +13 -0
  112. package/dist/components/ui/sheet.d.ts +76 -0
  113. package/dist/components/ui/sidebar.d.ts +203 -0
  114. package/dist/components/ui/skeleton-variants.d.ts +25 -0
  115. package/dist/components/ui/skeleton.d.ts +12 -0
  116. package/dist/components/ui/slider.d.ts +5 -0
  117. package/dist/components/ui/sonner.d.ts +5 -0
  118. package/dist/components/ui/spinner.d.ts +5 -0
  119. package/dist/components/ui/split-button.d.ts +6 -0
  120. package/dist/components/ui/stack.d.ts +5 -0
  121. package/dist/components/ui/status-badge.d.ts +52 -0
  122. package/dist/components/ui/step-selector.d.ts +5 -0
  123. package/dist/components/ui/stimulsoft-viewer.d.ts +8 -0
  124. package/dist/components/ui/switch.d.ts +21 -0
  125. package/dist/components/ui/tab-page-layout.d.ts +33 -0
  126. package/dist/components/ui/table-resize-handle.d.ts +10 -3
  127. package/dist/components/ui/table.d.ts +102 -0
  128. package/dist/components/ui/tabs.d.ts +59 -0
  129. package/dist/components/ui/terms-of-use-dialog.d.ts +50 -4
  130. package/dist/components/ui/textarea.d.ts +27 -0
  131. package/dist/components/ui/timepicker.d.ts +23 -0
  132. package/dist/components/ui/toggle-group.d.ts +25 -0
  133. package/dist/components/ui/toggle.d.ts +21 -0
  134. package/dist/components/ui/tooltip.d.ts +48 -0
  135. package/dist/components/ui/truncated-cell.d.ts +13 -0
  136. package/dist/components/ui/typography.d.ts +119 -0
  137. package/dist/components/ui/updates-notification.d.ts +33 -0
  138. package/dist/components/ui/users-groups-selector.d.ts +43 -0
  139. package/dist/components/ui/viewer-dialog.d.ts +107 -0
  140. package/dist/crud/components/ActionMenuItems.d.ts +5 -0
  141. package/dist/crud/components/BaseForm.d.ts +46 -0
  142. package/dist/crud/components/ColumnSettingsPopover.d.ts +10 -0
  143. package/dist/crud/components/CrudActionBar.d.ts +20 -0
  144. package/dist/crud/components/CrudGrid.d.ts +10 -0
  145. package/dist/crud/components/CrudPagination.d.ts +5 -0
  146. package/dist/crud/components/CrudTable.d.ts +5 -0
  147. package/dist/crud/components/TableRowActions.d.ts +5 -0
  148. package/dist/crud/createCrudPage.d.ts +41 -8
  149. package/dist/crud/generateCrudConfig.d.ts +13 -8
  150. package/dist/crud/hooks/useBaseForm.d.ts +39 -0
  151. package/dist/crud/hooks/useColumnManager.d.ts +25 -0
  152. package/dist/crud/hooks/useCrud.d.ts +35 -0
  153. package/dist/crud/primitives/ActionMenu.d.ts +41 -0
  154. package/dist/crud/primitives/FilterBar.d.ts +45 -0
  155. package/dist/crud/primitives/Pagination.d.ts +5 -0
  156. package/dist/crud/primitives/Table.d.ts +6 -1
  157. package/dist/crud/primitives/TreeTable.d.ts +5 -0
  158. package/dist/crud/primitives/types.d.ts +63 -0
  159. package/dist/crud/utils/routingHelpers.d.ts +11 -0
  160. package/dist/custom-form-fields/components/CustomFormFields.d.ts +3 -0
  161. package/dist/custom-form-fields/fields/FormDateField.d.ts +3 -0
  162. package/dist/custom-form-fields/fields/FormMultiSelectionField.d.ts +3 -0
  163. package/dist/custom-form-fields/fields/FormNumericField.d.ts +3 -0
  164. package/dist/custom-form-fields/fields/FormQuestionsField.d.ts +3 -0
  165. package/dist/custom-form-fields/fields/FormSingleSelectionField.d.ts +3 -0
  166. package/dist/custom-form-fields/fields/FormTextField.d.ts +3 -0
  167. package/dist/custom-form-fields/fields/FormTimeField.d.ts +3 -0
  168. package/dist/custom-form-fields/fields/FormUrlField.d.ts +3 -0
  169. package/dist/custom-form-fields/fields/ReadOnlyTextField.d.ts +3 -0
  170. package/dist/custom-form-fields/types.d.ts +84 -21
  171. package/dist/exports/crud.d.ts +5 -0
  172. package/dist/exports/integrations.d.ts +1 -0
  173. package/dist/exports/ui.d.ts +1 -0
  174. package/dist/file-upload/components/SingleFileUpload.d.ts +59 -0
  175. package/dist/file-upload/types.d.ts +15 -0
  176. package/dist/file-upload/utils/formatBytes.d.ts +5 -0
  177. package/dist/file-upload/utils/getFileExtension.d.ts +5 -0
  178. package/dist/hooks/useColumnResize.d.ts +24 -0
  179. package/dist/hooks/useRowResize.d.ts +18 -0
  180. package/dist/hooks/useSidebarResize.d.ts +18 -0
  181. package/dist/hooks/useUpdatesNotification.d.ts +16 -0
  182. package/dist/index.css +1 -1
  183. package/dist/index.css.map +1 -1
  184. package/dist/index.esm.js +1 -1
  185. package/dist/index.js +1 -1
  186. package/dist/integrations/clarity/clarityTracking.d.ts +31 -0
  187. package/dist/integrations/clarity/index.d.ts +3 -0
  188. package/dist/integrations/clarity/types.d.ts +46 -0
  189. package/dist/integrations/clarity/useClarity.d.ts +34 -0
  190. package/dist/integrations/index.d.ts +5 -0
  191. package/dist/providers/CoreProviders.d.ts +16 -1
  192. package/dist/qualiex/components/QualiexUserField.d.ts +8 -0
  193. package/dist/qualiex/hooks/useQualiexUsers.d.ts +16 -26
  194. package/dist/qualiex/services/qualiexApi.d.ts +38 -2
  195. package/dist/qualiex/utils/QualiexErrorInterceptor.d.ts +5 -0
  196. package/dist/supabase/SupabaseSingleton.d.ts +34 -0
  197. package/dist/types.d.ts +51 -2
  198. package/dist/utils/color.d.ts +26 -0
  199. package/dist/utils/index.d.ts +1 -0
  200. package/dist/vite/index.esm.js +4 -1
  201. package/dist/vite/index.js +4 -1
  202. package/docs/PUBLISH.md +168 -0
  203. package/docs/STORAGE_BUCKETS.md +384 -0
  204. package/docs/WORKSPACE_KNOWLEDGE.md +120 -119
  205. package/docs/design-system/README.md +1 -1
  206. package/docs/design-system/buttons-actions.md +130 -130
  207. package/docs/design-system/charts-dashboards.md +340 -301
  208. package/docs/design-system/crud.md +174 -114
  209. package/docs/design-system/data-display.md +108 -103
  210. package/docs/design-system/dialogs.md +212 -212
  211. package/docs/design-system/domain.md +317 -317
  212. package/docs/design-system/examples.md +275 -275
  213. package/docs/design-system/foundation.md +1 -1
  214. package/docs/design-system/inputs.md +131 -131
  215. package/docs/design-system/layout.md +202 -154
  216. package/docs/design-system/navigation.md +271 -325
  217. package/docs/design-system/notifications-feedback.md +34 -34
  218. package/docs/design-system/patterns/README.md +53 -53
  219. package/docs/design-system/patterns/action-button.md +22 -22
  220. package/docs/design-system/patterns/alertdialog-deletion.md +46 -46
  221. package/docs/design-system/patterns/baseform-custom-fields.md +59 -59
  222. package/docs/design-system/patterns/baseform-usage.md +42 -42
  223. package/docs/design-system/patterns/body-content-scroll.md +56 -56
  224. package/docs/design-system/patterns/combo-tree.md +23 -23
  225. package/docs/design-system/patterns/components-registry.md +17 -17
  226. package/docs/design-system/patterns/core-providers.md +41 -39
  227. package/docs/design-system/patterns/crud-bulk-actions.md +12 -12
  228. package/docs/design-system/patterns/crud-config-props.md +16 -16
  229. package/docs/design-system/patterns/crud-defaults.md +17 -17
  230. package/docs/design-system/patterns/crud-toolbar.md +28 -28
  231. package/docs/design-system/patterns/delete-confirmation.md +40 -40
  232. package/docs/design-system/patterns/dialog-body-scroll.md +26 -26
  233. package/docs/design-system/patterns/dialog-structure.md +32 -32
  234. package/docs/design-system/patterns/dialog-variants.md +41 -41
  235. package/docs/design-system/patterns/feature-flags.md +24 -20
  236. package/docs/design-system/patterns/header-metadata.md +57 -57
  237. package/docs/design-system/patterns/i18n-setup.md +117 -117
  238. package/docs/design-system/patterns/pagination.md +27 -27
  239. package/docs/design-system/patterns/single-scroll.md +39 -39
  240. package/docs/design-system/patterns/vite-tailwind-setup.md +48 -48
  241. package/docs/design-system/platform.md +18 -18
  242. package/docs/design-system/selectors.md +240 -236
  243. package/docs/design-system/tables-grids.md +95 -38
  244. package/package.json +150 -144
  245. package/dist/README.md +0 -1079
  246. package/dist/bin/bootstrap.js +0 -40
  247. package/dist/bin/pull-docs.js +0 -186
  248. package/dist/docs/KNOWLEDGE.md +0 -109
@@ -1,275 +1,275 @@
1
- # Golden Snippets — Exemplos Completos do Design System
2
-
3
- > Implementações de referência para a IA copiar e adaptar.
4
- > Cada snippet é funcional e segue 100% dos padrões do DS.
5
-
6
- ---
7
-
8
- ## 1. CRUD Completo com createCrudPage
9
-
10
- ```tsx
11
- // src/pages/ProcessesPage.tsx
12
- import { createSimpleService, createCrudPage, usePageMetadata } from 'forlogic-core';
13
-
14
- const processService = createSimpleService({
15
- tableName: 'processes',
16
- schema: 'quality',
17
- entityName: 'processo',
18
- searchFields: ['title', 'description'],
19
- });
20
-
21
- const ProcessesPage = createCrudPage({
22
- title: 'Processos',
23
- service: processService,
24
- columns: [
25
- { key: 'title', header: 'Título' },
26
- { key: 'status', header: 'Status' },
27
- { key: 'responsible', header: 'Responsável' },
28
- { key: 'updated_at', header: 'Atualizado em', format: 'datetime' },
29
- ],
30
- formSections: [{
31
- id: 'main',
32
- fields: [
33
- { name: 'title', label: 'Título', type: 'text', required: true },
34
- { name: 'description', label: 'Descrição', type: 'textarea' },
35
- { name: 'status', label: 'Status', type: 'combobox', options: [
36
- { value: 'active', label: 'Ativo' },
37
- { value: 'inactive', label: 'Inativo' },
38
- ]},
39
- { name: 'id_responsible', label: 'Responsável', type: 'combobox', entity: 'users' },
40
- ],
41
- }],
42
- actions: [
43
- { label: 'Editar', action: 'edit' },
44
- { label: 'Inativar', action: 'toggle-status', confirm: true },
45
- ],
46
- });
47
-
48
- export default ProcessesPage;
49
- ```
50
-
51
- ---
52
-
53
- ## 2. CrudTable Customizado com ActionButton
54
-
55
- ```tsx
56
- // src/pages/DocumentsPage.tsx
57
- import {
58
- CrudTable, CrudActionBar, ActionButton, Badge,
59
- usePageMetadata, useTranslation, getSupabaseClient,
60
- } from 'forlogic-core';
61
-
62
- export function DocumentsPage() {
63
- const { t } = useTranslation();
64
- usePageMetadata({ title: t('documents'), subtitle: t('documents_subtitle') });
65
-
66
- const columns = [
67
- { key: 'name', header: 'Nome' },
68
- {
69
- key: 'status',
70
- header: 'Status',
71
- cell: (row) => (
72
- <Badge variant={row.status === 'approved' ? 'default' : 'secondary'}>
73
- {row.status}
74
- </Badge>
75
- ),
76
- },
77
- { key: 'version', header: 'Versão' },
78
- {
79
- key: 'actions',
80
- header: '',
81
- cell: (row) => (
82
- <ActionButton
83
- actions={[
84
- { label: 'Editar', onClick: () => handleEdit(row) },
85
- { label: 'Duplicar', onClick: () => handleDuplicate(row) },
86
- { label: 'Inativar', onClick: () => handleDeactivate(row), variant: 'destructive' },
87
- ]}
88
- />
89
- ),
90
- },
91
- ];
92
-
93
- return (
94
- <div className="p-6 space-y-4">
95
- <CrudActionBar
96
- onAdd={() => setDialogOpen(true)}
97
- addLabel="Novo Documento"
98
- showSearch
99
- />
100
- <CrudTable columns={columns} data={documents} />
101
- </div>
102
- );
103
- }
104
- ```
105
-
106
- ---
107
-
108
- ## 3. Layout com AppLayout + Sidebar + Separador
109
-
110
- ```tsx
111
- // src/App.tsx
112
- import { BrowserRouter, Routes, Route } from 'react-router-dom';
113
- import { CoreProviders, AppLayout } from 'forlogic-core';
114
- import { Home, FileText, Settings, BarChart3 } from 'lucide-react';
115
- import ptBR from './i18n/pt-BR.json';
116
-
117
- const sidebarConfig = {
118
- navigation: [
119
- { label: 'Início', path: '/', icon: Home },
120
- { label: 'Documentos', path: '/documents', icon: FileText },
121
- { label: 'Relatórios', path: '/reports', icon: BarChart3 },
122
- { type: 'separator' as const, label: '', path: '' },
123
- { label: 'Configurações', path: '/settings', icon: Settings },
124
- ],
125
- };
126
-
127
- export default function App() {
128
- return (
129
- <CoreProviders moduleAlias="quality" appTranslations={{ 'pt-BR': ptBR }}>
130
- <BrowserRouter>
131
- <AppLayout sidebarConfig={sidebarConfig}>
132
- <Routes>
133
- <Route path="/" element={<HomePage />} />
134
- <Route path="/documents" element={<DocumentsPage />} />
135
- </Routes>
136
- </AppLayout>
137
- </BrowserRouter>
138
- </CoreProviders>
139
- );
140
- }
141
- ```
142
-
143
- ---
144
-
145
- ## 4. Formulário com Dialog + BaseForm + Combobox
146
-
147
- ```tsx
148
- // src/components/ProcessForm.tsx
149
- import {
150
- Dialog, DialogContent, DialogHeader, DialogTitle,
151
- Input, Label, Combobox, Button,
152
- useTranslation,
153
- } from 'forlogic-core';
154
- import { useForm } from 'react-hook-form';
155
- import { zodResolver } from '@hookform/resolvers/zod';
156
- import { z } from 'zod';
157
-
158
- const schema = z.object({
159
- title: z.string().min(3, 'Mínimo 3 caracteres'),
160
- status: z.string(),
161
- id_responsible: z.string().uuid(),
162
- });
163
-
164
- type FormData = z.infer<typeof schema>;
165
-
166
- interface ProcessFormProps {
167
- open: boolean;
168
- onOpenChange: (open: boolean) => void;
169
- onSubmit: (data: FormData) => void;
170
- defaultValues?: Partial<FormData>;
171
- }
172
-
173
- export function ProcessForm({ open, onOpenChange, onSubmit, defaultValues }: ProcessFormProps) {
174
- const { t } = useTranslation();
175
- const form = useForm<FormData>({
176
- resolver: zodResolver(schema),
177
- defaultValues,
178
- });
179
-
180
- return (
181
- <Dialog open={open} onOpenChange={onOpenChange}>
182
- <DialogContent>
183
- <DialogHeader>
184
- <DialogTitle>{defaultValues ? t('edit') : t('create')}</DialogTitle>
185
- </DialogHeader>
186
- <form onSubmit={form.handleSubmit(onSubmit)} className="space-y-4">
187
- <div className="space-y-2">
188
- <Label htmlFor="title">{t('title')}</Label>
189
- <Input id="title" {...form.register('title')} />
190
- </div>
191
- <div className="space-y-2">
192
- <Label>{t('status')}</Label>
193
- <Combobox
194
- options={[
195
- { value: 'active', label: 'Ativo' },
196
- { value: 'inactive', label: 'Inativo' },
197
- ]}
198
- value={form.watch('status')}
199
- onValueChange={(v) => form.setValue('status', v)}
200
- />
201
- </div>
202
- <div className="flex justify-end gap-2">
203
- <Button variant="outline" onClick={() => onOpenChange(false)}>{t('cancel')}</Button>
204
- <Button type="submit">{t('save')}</Button>
205
- </div>
206
- </form>
207
- </DialogContent>
208
- </Dialog>
209
- );
210
- }
211
- ```
212
-
213
- ---
214
-
215
- ## 5. Supabase com Schema Correto
216
-
217
- ```tsx
218
- // src/services/processService.ts
219
- import { getSupabaseClient } from 'forlogic-core';
220
-
221
- const SCHEMA = 'quality';
222
-
223
- export async function fetchProcesses() {
224
- const supabase = getSupabaseClient();
225
- const { data, error } = await supabase
226
- .schema(SCHEMA)
227
- .from('processes')
228
- .select('*')
229
- .is('deleted_at', null)
230
- .order('created_at', { ascending: false });
231
-
232
- if (error) throw error;
233
- return data;
234
- }
235
-
236
- export async function softDeleteProcess(id: string) {
237
- const supabase = getSupabaseClient();
238
- const { error } = await supabase
239
- .schema(SCHEMA)
240
- .from('processes')
241
- .update({ deleted_at: new Date().toISOString() })
242
- .eq('id', id);
243
-
244
- if (error) throw error;
245
- }
246
- ```
247
-
248
- ---
249
-
250
- ## 6. Página com usePageMetadata + Breadcrumbs
251
-
252
- ```tsx
253
- // src/pages/ProcessDetailPage.tsx
254
- import { usePageMetadata } from 'forlogic-core';
255
- import { useParams } from 'react-router-dom';
256
-
257
- export function ProcessDetailPage() {
258
- const { id } = useParams();
259
-
260
- usePageMetadata({
261
- title: 'Detalhes do Processo',
262
- subtitle: 'Visualize e edite os dados do processo',
263
- breadcrumbs: [
264
- { label: 'Processos', href: '/processes' },
265
- { label: 'Detalhes' },
266
- ],
267
- });
268
-
269
- return (
270
- <div className="p-6">
271
- {/* conteúdo da página */}
272
- </div>
273
- );
274
- }
275
- ```
1
+ # Golden Snippets — Exemplos Completos do Design System
2
+
3
+ > Implementações de referência para a IA copiar e adaptar.
4
+ > Cada snippet é funcional e segue 100% dos padrões do DS.
5
+
6
+ ---
7
+
8
+ ## 1. CRUD Completo com createCrudPage
9
+
10
+ ```tsx
11
+ // src/pages/ProcessesPage.tsx
12
+ import { createSimpleService, createCrudPage, usePageMetadata } from 'forlogic-core';
13
+
14
+ const processService = createSimpleService({
15
+ tableName: 'processes',
16
+ schema: 'quality',
17
+ entityName: 'processo',
18
+ searchFields: ['title', 'description'],
19
+ });
20
+
21
+ const ProcessesPage = createCrudPage({
22
+ title: 'Processos',
23
+ service: processService,
24
+ columns: [
25
+ { key: 'title', header: 'Título' },
26
+ { key: 'status', header: 'Status' },
27
+ { key: 'responsible', header: 'Responsável' },
28
+ { key: 'updated_at', header: 'Atualizado em', format: 'datetime' },
29
+ ],
30
+ formSections: [{
31
+ id: 'main',
32
+ fields: [
33
+ { name: 'title', label: 'Título', type: 'text', required: true },
34
+ { name: 'description', label: 'Descrição', type: 'textarea' },
35
+ { name: 'status', label: 'Status', type: 'combobox', options: [
36
+ { value: 'active', label: 'Ativo' },
37
+ { value: 'inactive', label: 'Inativo' },
38
+ ]},
39
+ { name: 'id_responsible', label: 'Responsável', type: 'combobox', entity: 'users' },
40
+ ],
41
+ }],
42
+ actions: [
43
+ { label: 'Editar', action: 'edit' },
44
+ { label: 'Inativar', action: 'toggle-status', confirm: true },
45
+ ],
46
+ });
47
+
48
+ export default ProcessesPage;
49
+ ```
50
+
51
+ ---
52
+
53
+ ## 2. CrudTable Customizado com ActionButton
54
+
55
+ ```tsx
56
+ // src/pages/DocumentsPage.tsx
57
+ import {
58
+ CrudTable, CrudActionBar, ActionButton, Badge,
59
+ usePageMetadata, useTranslation, getSupabaseClient,
60
+ } from 'forlogic-core';
61
+
62
+ export function DocumentsPage() {
63
+ const { t } = useTranslation();
64
+ usePageMetadata({ title: t('documents'), subtitle: t('documents_subtitle') });
65
+
66
+ const columns = [
67
+ { key: 'name', header: 'Nome' },
68
+ {
69
+ key: 'status',
70
+ header: 'Status',
71
+ cell: (row) => (
72
+ <Badge variant={row.status === 'approved' ? 'default' : 'secondary'}>
73
+ {row.status}
74
+ </Badge>
75
+ ),
76
+ },
77
+ { key: 'version', header: 'Versão' },
78
+ {
79
+ key: 'actions',
80
+ header: '',
81
+ cell: (row) => (
82
+ <ActionButton
83
+ actions={[
84
+ { label: 'Editar', onClick: () => handleEdit(row) },
85
+ { label: 'Duplicar', onClick: () => handleDuplicate(row) },
86
+ { label: 'Inativar', onClick: () => handleDeactivate(row), variant: 'destructive' },
87
+ ]}
88
+ />
89
+ ),
90
+ },
91
+ ];
92
+
93
+ return (
94
+ <div className="p-6 space-y-4">
95
+ <CrudActionBar
96
+ onAdd={() => setDialogOpen(true)}
97
+ addLabel="Novo Documento"
98
+ showSearch
99
+ />
100
+ <CrudTable columns={columns} data={documents} />
101
+ </div>
102
+ );
103
+ }
104
+ ```
105
+
106
+ ---
107
+
108
+ ## 3. Layout com AppLayout + Sidebar + Separador
109
+
110
+ ```tsx
111
+ // src/App.tsx
112
+ import { BrowserRouter, Routes, Route } from 'react-router-dom';
113
+ import { CoreProviders, AppLayout } from 'forlogic-core';
114
+ import { Home, FileText, Settings, BarChart3 } from 'lucide-react';
115
+ import ptBR from './i18n/pt-BR.json';
116
+
117
+ const sidebarConfig = {
118
+ navigation: [
119
+ { label: 'Início', path: '/', icon: Home },
120
+ { label: 'Documentos', path: '/documents', icon: FileText },
121
+ { label: 'Relatórios', path: '/reports', icon: BarChart3 },
122
+ { type: 'separator' as const, label: '', path: '' },
123
+ { label: 'Configurações', path: '/settings', icon: Settings },
124
+ ],
125
+ };
126
+
127
+ export default function App() {
128
+ return (
129
+ <CoreProviders moduleAlias="quality" appTranslations={{ 'pt-BR': ptBR }}>
130
+ <BrowserRouter>
131
+ <AppLayout sidebarConfig={sidebarConfig}>
132
+ <Routes>
133
+ <Route path="/" element={<HomePage />} />
134
+ <Route path="/documents" element={<DocumentsPage />} />
135
+ </Routes>
136
+ </AppLayout>
137
+ </BrowserRouter>
138
+ </CoreProviders>
139
+ );
140
+ }
141
+ ```
142
+
143
+ ---
144
+
145
+ ## 4. Formulário com Dialog + BaseForm + Combobox
146
+
147
+ ```tsx
148
+ // src/components/ProcessForm.tsx
149
+ import {
150
+ Dialog, DialogContent, DialogHeader, DialogTitle,
151
+ Input, Label, Combobox, Button,
152
+ useTranslation,
153
+ } from 'forlogic-core';
154
+ import { useForm } from 'react-hook-form';
155
+ import { zodResolver } from '@hookform/resolvers/zod';
156
+ import { z } from 'zod';
157
+
158
+ const schema = z.object({
159
+ title: z.string().min(3, 'Mínimo 3 caracteres'),
160
+ status: z.string(),
161
+ id_responsible: z.string().uuid(),
162
+ });
163
+
164
+ type FormData = z.infer<typeof schema>;
165
+
166
+ interface ProcessFormProps {
167
+ open: boolean;
168
+ onOpenChange: (open: boolean) => void;
169
+ onSubmit: (data: FormData) => void;
170
+ defaultValues?: Partial<FormData>;
171
+ }
172
+
173
+ export function ProcessForm({ open, onOpenChange, onSubmit, defaultValues }: ProcessFormProps) {
174
+ const { t } = useTranslation();
175
+ const form = useForm<FormData>({
176
+ resolver: zodResolver(schema),
177
+ defaultValues,
178
+ });
179
+
180
+ return (
181
+ <Dialog open={open} onOpenChange={onOpenChange}>
182
+ <DialogContent>
183
+ <DialogHeader>
184
+ <DialogTitle>{defaultValues ? t('edit') : t('create')}</DialogTitle>
185
+ </DialogHeader>
186
+ <form onSubmit={form.handleSubmit(onSubmit)} className="space-y-4">
187
+ <div className="space-y-2">
188
+ <Label htmlFor="title">{t('title')}</Label>
189
+ <Input id="title" {...form.register('title')} />
190
+ </div>
191
+ <div className="space-y-2">
192
+ <Label>{t('status')}</Label>
193
+ <Combobox
194
+ options={[
195
+ { value: 'active', label: 'Ativo' },
196
+ { value: 'inactive', label: 'Inativo' },
197
+ ]}
198
+ value={form.watch('status')}
199
+ onValueChange={(v) => form.setValue('status', v)}
200
+ />
201
+ </div>
202
+ <div className="flex justify-end gap-2">
203
+ <Button variant="outline" onClick={() => onOpenChange(false)}>{t('cancel')}</Button>
204
+ <Button type="submit">{t('save')}</Button>
205
+ </div>
206
+ </form>
207
+ </DialogContent>
208
+ </Dialog>
209
+ );
210
+ }
211
+ ```
212
+
213
+ ---
214
+
215
+ ## 5. Supabase com Schema Correto
216
+
217
+ ```tsx
218
+ // src/services/processService.ts
219
+ import { getSupabaseClient } from 'forlogic-core';
220
+
221
+ const SCHEMA = 'quality';
222
+
223
+ export async function fetchProcesses() {
224
+ const supabase = getSupabaseClient();
225
+ const { data, error } = await supabase
226
+ .schema(SCHEMA)
227
+ .from('processes')
228
+ .select('*')
229
+ .is('deleted_at', null)
230
+ .order('created_at', { ascending: false });
231
+
232
+ if (error) throw error;
233
+ return data;
234
+ }
235
+
236
+ export async function softDeleteProcess(id: string) {
237
+ const supabase = getSupabaseClient();
238
+ const { error } = await supabase
239
+ .schema(SCHEMA)
240
+ .from('processes')
241
+ .update({ deleted_at: new Date().toISOString() })
242
+ .eq('id', id);
243
+
244
+ if (error) throw error;
245
+ }
246
+ ```
247
+
248
+ ---
249
+
250
+ ## 6. Página com usePageMetadata + Breadcrumbs
251
+
252
+ ```tsx
253
+ // src/pages/ProcessDetailPage.tsx
254
+ import { usePageMetadata } from 'forlogic-core';
255
+ import { useParams } from 'react-router-dom';
256
+
257
+ export function ProcessDetailPage() {
258
+ const { id } = useParams();
259
+
260
+ usePageMetadata({
261
+ title: 'Detalhes do Processo',
262
+ subtitle: 'Visualize e edite os dados do processo',
263
+ breadcrumbs: [
264
+ { label: 'Processos', href: '/processes' },
265
+ { label: 'Detalhes' },
266
+ ],
267
+ });
268
+
269
+ return (
270
+ <div className="p-6">
271
+ {/* conteúdo da página */}
272
+ </div>
273
+ );
274
+ }
275
+ ```
@@ -41,7 +41,7 @@ const NotesPage = createCrudPage({
41
41
  - Nível Médio: CrudTable/CrudGrid — componentes compostos para layouts customizados
42
42
  - Nível Baixo: Primitives (DataTable, DataPagination, DataFilterBar) — controle total
43
43
 
44
- > Fonte: `src\design-system\docs\components\crud\CrudOverviewDoc.tsx`
44
+ > Fonte: `src/design-system/docs/components/crud/CrudOverviewDoc.tsx`
45
45
 
46
46
  ---
47
47