@donotdev/crud 0.0.9 → 0.0.11

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 (194) hide show
  1. package/dist/CrudService.d.ts +26 -8
  2. package/dist/CrudService.d.ts.map +1 -1
  3. package/dist/CrudService.js +1 -1
  4. package/dist/CrudStore.d.ts.map +1 -1
  5. package/dist/CrudStore.js +1 -1
  6. package/dist/adapters/FirestoreAdapter.d.ts +1 -1
  7. package/dist/adapters/FirestoreAdapter.d.ts.map +1 -1
  8. package/dist/adapters/FirestoreAdapter.js +1 -1
  9. package/dist/adapters/FunctionsAdapter.d.ts +1 -1
  10. package/dist/adapters/FunctionsAdapter.d.ts.map +1 -1
  11. package/dist/adapters/FunctionsAdapter.js +1 -1
  12. package/dist/builtinFieldTypes.d.ts +17 -4
  13. package/dist/builtinFieldTypes.d.ts.map +1 -1
  14. package/dist/builtinFieldTypes.js +1 -1
  15. package/dist/components/DisplayFieldRenderer.d.ts +2 -0
  16. package/dist/components/DisplayFieldRenderer.d.ts.map +1 -1
  17. package/dist/components/DisplayFieldRenderer.js +1 -1
  18. package/dist/components/EntityDisplayRenderer.d.ts +2 -2
  19. package/dist/components/EntityDisplayRenderer.d.ts.map +1 -1
  20. package/dist/components/EntityDisplayRenderer.js +1 -1
  21. package/dist/components/EntityFilters.d.ts +19 -1
  22. package/dist/components/EntityFilters.d.ts.map +1 -1
  23. package/dist/components/EntityFilters.js +1 -1
  24. package/dist/components/FormFieldRenderer.d.ts.map +1 -1
  25. package/dist/components/FormFieldRenderer.js +1 -1
  26. package/dist/components/controlled/input/ControlledCurrencyField.d.ts +8 -0
  27. package/dist/components/controlled/input/ControlledCurrencyField.d.ts.map +1 -0
  28. package/dist/components/controlled/input/ControlledCurrencyField.js +1 -0
  29. package/dist/components/controlled/input/ControlledDurationField.d.ts +7 -0
  30. package/dist/components/controlled/input/ControlledDurationField.d.ts.map +1 -0
  31. package/dist/components/controlled/input/ControlledDurationField.js +1 -0
  32. package/dist/components/controlled/input/ControlledGdprConsentField.d.ts.map +1 -1
  33. package/dist/components/controlled/input/ControlledGdprConsentField.js +1 -1
  34. package/dist/components/controlled/input/ControlledPriceField.d.ts +8 -0
  35. package/dist/components/controlled/input/ControlledPriceField.d.ts.map +1 -0
  36. package/dist/components/controlled/input/ControlledPriceField.js +1 -0
  37. package/dist/components/controlled/input/ControlledRatingField.d.ts +8 -0
  38. package/dist/components/controlled/input/ControlledRatingField.d.ts.map +1 -0
  39. package/dist/components/controlled/input/ControlledRatingField.js +1 -0
  40. package/dist/components/controlled/input/index.d.ts +4 -0
  41. package/dist/components/controlled/input/index.d.ts.map +1 -1
  42. package/dist/components/controlled/input/index.js +1 -1
  43. package/dist/components/controlled/select/ControlledYearField.js +1 -1
  44. package/dist/components/fields/display/AvatarFieldDisplay.d.ts +23 -0
  45. package/dist/components/fields/display/AvatarFieldDisplay.d.ts.map +1 -0
  46. package/dist/components/fields/display/AvatarFieldDisplay.js +1 -0
  47. package/dist/components/fields/display/BadgeFieldDisplay.d.ts +21 -0
  48. package/dist/components/fields/display/BadgeFieldDisplay.d.ts.map +1 -0
  49. package/dist/components/fields/display/BadgeFieldDisplay.js +1 -0
  50. package/dist/components/fields/display/ButtonFieldDisplay.d.ts +29 -0
  51. package/dist/components/fields/display/ButtonFieldDisplay.d.ts.map +1 -0
  52. package/dist/components/fields/display/ButtonFieldDisplay.js +1 -0
  53. package/dist/components/fields/display/CheckboxFieldDisplay.d.ts +21 -0
  54. package/dist/components/fields/display/CheckboxFieldDisplay.d.ts.map +1 -0
  55. package/dist/components/fields/display/CheckboxFieldDisplay.js +1 -0
  56. package/dist/components/fields/display/DateFieldDisplay.d.ts +24 -0
  57. package/dist/components/fields/display/DateFieldDisplay.d.ts.map +1 -0
  58. package/dist/components/fields/display/DateFieldDisplay.js +1 -0
  59. package/dist/components/fields/display/DropdownDisplay.d.ts +21 -0
  60. package/dist/components/fields/display/DropdownDisplay.d.ts.map +1 -0
  61. package/dist/components/fields/display/DropdownDisplay.js +1 -0
  62. package/dist/components/fields/display/FileFieldDisplay.d.ts +21 -0
  63. package/dist/components/fields/display/FileFieldDisplay.d.ts.map +1 -0
  64. package/dist/components/fields/display/FileFieldDisplay.js +1 -0
  65. package/dist/components/fields/display/GeoPointFieldDisplay.d.ts +25 -0
  66. package/dist/components/fields/display/GeoPointFieldDisplay.d.ts.map +1 -0
  67. package/dist/components/fields/display/GeoPointFieldDisplay.js +1 -0
  68. package/dist/components/fields/display/HiddenFieldDisplay.d.ts +30 -0
  69. package/dist/components/fields/display/HiddenFieldDisplay.d.ts.map +1 -0
  70. package/dist/components/fields/display/HiddenFieldDisplay.js +1 -0
  71. package/dist/components/fields/display/ImageFieldDisplay.d.ts +24 -0
  72. package/dist/components/fields/display/ImageFieldDisplay.d.ts.map +1 -0
  73. package/dist/components/fields/display/ImageFieldDisplay.js +1 -0
  74. package/dist/components/fields/display/LinkFieldDisplay.d.ts +22 -0
  75. package/dist/components/fields/display/LinkFieldDisplay.d.ts.map +1 -0
  76. package/dist/components/fields/display/LinkFieldDisplay.js +1 -0
  77. package/dist/components/fields/display/MapFieldDisplay.d.ts +25 -0
  78. package/dist/components/fields/display/MapFieldDisplay.d.ts.map +1 -0
  79. package/dist/components/fields/display/MapFieldDisplay.js +1 -0
  80. package/dist/components/fields/display/MultiDropdownDisplay.d.ts +22 -0
  81. package/dist/components/fields/display/MultiDropdownDisplay.d.ts.map +1 -0
  82. package/dist/components/fields/display/MultiDropdownDisplay.js +1 -0
  83. package/dist/components/fields/display/MultiInputTextFieldDisplay.d.ts +22 -0
  84. package/dist/components/fields/display/MultiInputTextFieldDisplay.d.ts.map +1 -0
  85. package/dist/components/fields/display/MultiInputTextFieldDisplay.js +1 -0
  86. package/dist/components/fields/display/NumberFieldDisplay.d.ts +24 -0
  87. package/dist/components/fields/display/NumberFieldDisplay.d.ts.map +1 -0
  88. package/dist/components/fields/display/NumberFieldDisplay.js +1 -0
  89. package/dist/components/fields/display/PasswordFieldDisplay.d.ts +24 -0
  90. package/dist/components/fields/display/PasswordFieldDisplay.d.ts.map +1 -0
  91. package/dist/components/fields/display/PasswordFieldDisplay.js +1 -0
  92. package/dist/components/fields/display/PhoneNumberDisplay.d.ts +22 -0
  93. package/dist/components/fields/display/PhoneNumberDisplay.d.ts.map +1 -0
  94. package/dist/components/fields/display/PhoneNumberDisplay.js +1 -0
  95. package/dist/components/fields/display/RadioFieldDisplay.d.ts +22 -0
  96. package/dist/components/fields/display/RadioFieldDisplay.d.ts.map +1 -0
  97. package/dist/components/fields/display/RadioFieldDisplay.js +1 -0
  98. package/dist/components/fields/display/RangeFieldDisplay.d.ts +22 -0
  99. package/dist/components/fields/display/RangeFieldDisplay.d.ts.map +1 -0
  100. package/dist/components/fields/display/RangeFieldDisplay.js +1 -0
  101. package/dist/components/fields/display/ReferenceFieldDisplay.d.ts +22 -0
  102. package/dist/components/fields/display/ReferenceFieldDisplay.d.ts.map +1 -0
  103. package/dist/components/fields/display/ReferenceFieldDisplay.js +1 -0
  104. package/dist/components/fields/display/RichTextDisplay.d.ts +25 -0
  105. package/dist/components/fields/display/RichTextDisplay.d.ts.map +1 -0
  106. package/dist/components/fields/display/RichTextDisplay.js +61 -0
  107. package/dist/components/fields/display/TextAreaDisplay.d.ts +22 -0
  108. package/dist/components/fields/display/TextAreaDisplay.d.ts.map +1 -0
  109. package/dist/components/fields/display/TextAreaDisplay.js +1 -0
  110. package/dist/components/fields/display/TextFieldDisplay.d.ts +42 -0
  111. package/dist/components/fields/display/TextFieldDisplay.d.ts.map +1 -0
  112. package/dist/components/fields/display/TextFieldDisplay.js +1 -0
  113. package/dist/components/fields/display/TimestampFieldDisplay.d.ts +22 -0
  114. package/dist/components/fields/display/TimestampFieldDisplay.d.ts.map +1 -0
  115. package/dist/components/fields/display/TimestampFieldDisplay.js +1 -0
  116. package/dist/components/fields/display/index.d.ts +32 -0
  117. package/dist/components/fields/display/index.d.ts.map +1 -0
  118. package/dist/components/fields/display/index.js +1 -0
  119. package/dist/components/form/fields/ComboboxComponent.d.ts +6 -0
  120. package/dist/components/form/fields/ComboboxComponent.d.ts.map +1 -1
  121. package/dist/components/form/fields/ComboboxComponent.js +1 -1
  122. package/dist/components/form/fields/DurationFieldComponent.d.ts +42 -0
  123. package/dist/components/form/fields/DurationFieldComponent.d.ts.map +1 -0
  124. package/dist/components/form/fields/DurationFieldComponent.js +1 -0
  125. package/dist/components/form/fields/GdprConsentFieldComponent.d.ts +2 -2
  126. package/dist/components/form/fields/GdprConsentFieldComponent.d.ts.map +1 -1
  127. package/dist/components/form/fields/GdprConsentFieldComponent.js +1 -1
  128. package/dist/components/form/fields/PriceFieldComponent.d.ts +34 -0
  129. package/dist/components/form/fields/PriceFieldComponent.d.ts.map +1 -0
  130. package/dist/components/form/fields/PriceFieldComponent.js +1 -0
  131. package/dist/components/form/fields/RatingFieldComponent.d.ts +37 -0
  132. package/dist/components/form/fields/RatingFieldComponent.d.ts.map +1 -0
  133. package/dist/components/form/fields/RatingFieldComponent.js +1 -0
  134. package/dist/components/form/fields/index.d.ts +7 -0
  135. package/dist/components/form/fields/index.d.ts.map +1 -1
  136. package/dist/components/form/fields/index.js +1 -1
  137. package/dist/components/index.d.ts +3 -9
  138. package/dist/components/index.d.ts.map +1 -1
  139. package/dist/components/index.js +1 -1
  140. package/dist/fieldTypeRegistry.d.ts +92 -0
  141. package/dist/fieldTypeRegistry.d.ts.map +1 -0
  142. package/dist/fieldTypeRegistry.js +1 -0
  143. package/dist/forms/hooks/useEntityForm.d.ts.map +1 -1
  144. package/dist/forms/hooks/useEntityForm.js +1 -1
  145. package/dist/forms/types.d.ts +5 -3
  146. package/dist/forms/types.d.ts.map +1 -1
  147. package/dist/forms/utils/getFieldsForOperation.d.ts +2 -3
  148. package/dist/forms/utils/getFieldsForOperation.d.ts.map +1 -1
  149. package/dist/forms/utils/getFieldsForOperation.js +1 -1
  150. package/dist/forms/utils/isFieldEditable.d.ts +1 -1
  151. package/dist/forms/utils/isFieldEditable.d.ts.map +1 -1
  152. package/dist/hooks/index.d.ts +5 -0
  153. package/dist/hooks/index.d.ts.map +1 -1
  154. package/dist/hooks/index.js +1 -1
  155. package/dist/hooks/useEntityFavorites.d.ts +53 -0
  156. package/dist/hooks/useEntityFavorites.d.ts.map +1 -0
  157. package/dist/hooks/useEntityFavorites.js +1 -0
  158. package/dist/hooks/useRelatedItems.d.ts +37 -0
  159. package/dist/hooks/useRelatedItems.d.ts.map +1 -0
  160. package/dist/hooks/useRelatedItems.js +1 -0
  161. package/dist/index.d.ts +4 -3
  162. package/dist/index.d.ts.map +1 -1
  163. package/dist/index.js +1 -1
  164. package/dist/registerBuiltinFieldTypes.d.ts +6 -0
  165. package/dist/registerBuiltinFieldTypes.d.ts.map +1 -0
  166. package/dist/registerBuiltinFieldTypes.js +1 -0
  167. package/dist/tsconfig.tsbuildinfo +1 -1
  168. package/dist/types.d.ts +60 -25
  169. package/dist/types.d.ts.map +1 -1
  170. package/dist/useBaseCrudList.d.ts +53 -0
  171. package/dist/useBaseCrudList.d.ts.map +1 -0
  172. package/dist/useBaseCrudList.js +1 -0
  173. package/dist/useCrud.d.ts +3 -6
  174. package/dist/useCrud.d.ts.map +1 -1
  175. package/dist/useCrud.js +1 -1
  176. package/dist/useCrudCardList.d.ts +10 -4
  177. package/dist/useCrudCardList.d.ts.map +1 -1
  178. package/dist/useCrudCardList.js +1 -1
  179. package/dist/useCrudList.d.ts +12 -5
  180. package/dist/useCrudList.d.ts.map +1 -1
  181. package/dist/useCrudList.js +1 -1
  182. package/dist/utils/mergeWithOptimistic.d.ts +4 -5
  183. package/dist/utils/mergeWithOptimistic.d.ts.map +1 -1
  184. package/dist/utils/mergeWithOptimistic.js +1 -1
  185. package/dist/utils/scopeUtils.d.ts +38 -0
  186. package/dist/utils/scopeUtils.d.ts.map +1 -0
  187. package/dist/utils/scopeUtils.js +1 -0
  188. package/package.json +15 -14
  189. package/dist/components/EntityCardList.d.ts +0 -29
  190. package/dist/components/EntityCardList.d.ts.map +0 -1
  191. package/dist/components/EntityCardList.js +0 -1
  192. package/dist/components/EntityList.d.ts +0 -30
  193. package/dist/components/EntityList.d.ts.map +0 -1
  194. package/dist/components/EntityList.js +0 -1
@@ -1,29 +0,0 @@
1
- import type { Entity } from '@donotdev/core';
2
- export interface EntityCardListProps {
3
- /** The entity definition */
4
- entity: Entity;
5
- /** View handler - called when card is clicked */
6
- onView: (id: string) => void;
7
- /** Grid columns (responsive) - defaults to [1, 2, 3, 4] */
8
- cols?: number | [number, number, number, number];
9
- /** Cache stale time is ms - defaults to 30 mins */
10
- staleTime?: number;
11
- /** Optional filter function to filter items client-side */
12
- filter?: (item: any) => boolean;
13
- /** Hide filters section (default: false) */
14
- hideFilters?: boolean;
15
- }
16
- /**
17
- * Entity Card List Component - Card grid view for public/user-facing browsing
18
- *
19
- * Features:
20
- * - Responsive card grid layout
21
- * - Image + key fields display
22
- * - Click card to navigate to detail
23
- * - Simple formatted text display (no boxes, just labels + values)
24
- * - Empty state handling
25
- * - Default routing: `/${entity.collection}/${id}` for view
26
- */
27
- export declare function EntityCardList({ entity, onView, cols, staleTime, // 30 minutes default cache
28
- filter, hideFilters, }: EntityCardListProps): import("react/jsx-runtime").JSX.Element;
29
- //# sourceMappingURL=EntityCardList.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"EntityCardList.d.ts","sourceRoot":"","sources":["../../src/components/EntityCardList.tsx"],"names":[],"mappings":"AA6BA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAO7C,MAAM,WAAW,mBAAmB;IAClC,4BAA4B;IAC5B,MAAM,EAAE,MAAM,CAAC;IACf,iDAAiD;IACjD,MAAM,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;IAC7B,2DAA2D;IAC3D,IAAI,CAAC,EAAE,MAAM,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;IACjD,mDAAmD;IACnD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,2DAA2D;IAC3D,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,GAAG,KAAK,OAAO,CAAC;IAChC,4CAA4C;IAC5C,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB;AAED;;;;;;;;;;GAUG;AACH,wBAAgB,cAAc,CAAC,EAC7B,MAAM,EACN,MAAM,EACN,IAAmB,EACnB,SAA0B,EAAE,2BAA2B;AACvD,MAAM,EACN,WAAmB,GACpB,EAAE,mBAAmB,2CAkOrB"}
@@ -1 +0,0 @@
1
- "use client";import{jsx as r,jsxs as f,Fragment as _}from"react/jsx-runtime";import{useMemo as m,useCallback as k,useState as D}from"react";import{Grid as E,Card as R,Stack as v,Text as g,Section as w}from"@donotdev/components";import{useTranslation as y}from"@donotdev/core";import{translateFieldLabel as B}from"../forms/utils";import{useCrudCardList as G}from"../useCrudCardList";import{formatValue as M}from"./DisplayFieldRenderer";import{EntityFilters as q,matchesFilter as z}from"./EntityFilters";function N({entity:t,onView:j,cols:L=[1,2,3,4],staleTime:O=1e3*60*30,filter:h,hideFilters:T=!1}){const{data:$,loading:A}=G(t,{staleTime:O}),p=$?.items||[],[d,I]=D({}),V=k(e=>Object.keys(d).length===0?!0:Object.entries(d).every(([l,s])=>{const i=e[l],a=t.fields[l]?.type||"text";return z(i,s,a)}),[d,t.fields]),n=m(()=>{let e=p;return e=e.filter(V),h&&(e=e.filter(h)),e},[p,V,h]),{t:F}=y(t.namespace),{t:o}=y("crud"),U=k(e=>{j(e)},[j]),c=m(()=>{const e=t.listCardFields??t.listFields;return e&&e.length>0?e:Object.keys(t.fields).slice(0,4)},[t.listCardFields,t.listFields,t.fields]),u=m(()=>{const e=c.filter(s=>{const i=t.fields[s];return i?.type==="image"||i?.type==="images"});return e.length>0?e[0]:Object.keys(t.fields).filter(s=>{const i=t.fields[s];return i?.type==="image"||i?.type==="images"})[0]||null},[c,t.fields]),x=m(()=>c.filter(e=>e!==u),[c,u]),S=F("name",{defaultValue:t.name});return f(_,{children:[!T&&r(w,{title:o("filters.title",{entity:S,defaultValue:`Browse ${S} - Filters`}),collapsible:!0,defaultOpen:!0,children:r(q,{entity:t,data:p,filters:d,onFiltersChange:I,fieldsToFilter:t.listCardFields})}),r(w,{title:A?o("results.title.fetching",{defaultValue:"Fetching..."}):o("results.title.count",{count:n.length,defaultValue:n.length===1?"Found 1 occurrence":`Found ${n.length} occurrences`}),collapsible:!0,defaultOpen:!0,children:n.length===0?f(v,{align:"center",justify:"center",gap:"medium",style:{padding:"var(--gap-3xl)",textAlign:"center"},children:[r(g,{level:"h3",style:{color:"var(--muted-foreground)"},children:o("emptyState.title",{defaultValue:`No ${t.name.toLowerCase()} found`})}),r(g,{style:{color:"var(--muted-foreground)"},children:o("emptyState.description",{defaultValue:`No ${t.name.toLowerCase()} available at this time.`})})]}):r(E,{cols:L,gap:"medium",children:n.map(e=>{const l=u?e[u]:null,s=l?typeof l=="string"?l:l?.url||l?.thumbUrl||Array.isArray(l)&&l[0]?.url||l[0]?.thumbUrl||l[0]:null,i=x[0],C=i?e[i]:e.id;return r(R,{title:String(C||""),clickable:!0,onClick:()=>U(e.id),elevated:!0,children:f(v,{direction:"column",gap:"medium",children:[s&&r("div",{style:{width:"100%",aspectRatio:"16/9",borderRadius:"var(--radius-md)",overflow:"hidden",backgroundColor:"var(--muted)"},children:r("img",{src:s,alt:String(C||""),style:{width:"100%",height:"100%",objectFit:"cover"}})}),r(v,{direction:"column",gap:"tight",children:x.slice(1,4).map(a=>{const b=t.fields[a];return b?f("div",{children:[r(g,{level:"small",variant:"muted",children:B(a,b,F)}),r(g,{children:M(e[a],b,F,{compact:!0})})]},a):null})})]})},e.id)})})})]})}export{N as EntityCardList};
@@ -1,30 +0,0 @@
1
- import type { Entity } from '@donotdev/core';
2
- export interface EntityListProps {
3
- /** The entity definition */
4
- entity: Entity;
5
- /** Current user role (for UI toggle only - backend enforces security) */
6
- userRole?: string;
7
- /** Edit handler - called when edit button is clicked */
8
- onEdit: (id: string) => void;
9
- /** View handler (row click) - called when row is clicked */
10
- onView?: (id: string) => void;
11
- /** Create handler - called when "Add New" button is clicked */
12
- onCreate?: () => void;
13
- /** Hide filters section (default: false) */
14
- hideFilters?: boolean;
15
- /** Pagination mode: 'client' (default) or 'server' for massive datasets */
16
- pagination?: 'client' | 'server';
17
- /** Default page size (default: 10) */
18
- defaultPageSize?: number;
19
- }
20
- /**
21
- * Entity List Component - Table view for admin/internal operations
22
- *
23
- * Features:
24
- * - Filters section (collapsible) with actions and filter inputs
25
- * - Results section (collapsible) with DataTable
26
- * - Excel-like table display with formatted values
27
- * - Edit and Delete actions (admin only)
28
- */
29
- export declare function EntityList({ entity, userRole, onEdit, onView, onCreate, hideFilters, pagination, defaultPageSize, }: EntityListProps): import("react/jsx-runtime").JSX.Element;
30
- //# sourceMappingURL=EntityList.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"EntityList.d.ts","sourceRoot":"","sources":["../../src/components/EntityList.tsx"],"names":[],"mappings":"AA+BA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAU7C,MAAM,WAAW,eAAe;IAC9B,4BAA4B;IAC5B,MAAM,EAAE,MAAM,CAAC;IACf,yEAAyE;IACzE,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,wDAAwD;IACxD,MAAM,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;IAC7B,4DAA4D;IAC5D,MAAM,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;IAC9B,+DAA+D;IAC/D,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;IACtB,4CAA4C;IAC5C,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,2EAA2E;IAC3E,UAAU,CAAC,EAAE,QAAQ,GAAG,QAAQ,CAAC;IACjC,sCAAsC;IACtC,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED;;;;;;;;GAQG;AACH,wBAAgB,UAAU,CAAC,EACzB,MAAM,EACN,QAAkB,EAClB,MAAM,EACN,MAAM,EACN,QAAQ,EACR,WAAmB,EACnB,UAAqB,EACrB,eAAoB,GACrB,EAAE,eAAe,2CAqSjB"}
@@ -1 +0,0 @@
1
- "use client";import{jsx as n,jsxs as f,Fragment as J}from"react/jsx-runtime";import{RefreshCw as K,Plus as U,Trash2 as W,Edit as X,Search as Y}from"lucide-react";import{useMemo as N,useCallback as o,useState as m}from"react";import{DataTable as Z,Button as V,Stack as y,ActionButton as ee,Section as R,Input as te}from"@donotdev/components";import{useTranslation as _}from"@donotdev/core";import{translateFieldLabel as ae}from"../forms/utils";import{useCrud as le}from"../useCrud";import{useCrudList as re}from"../useCrudList";import{formatValue as ne}from"./DisplayFieldRenderer";import{EntityFilters as ie,matchesFilter as se}from"./EntityFilters";function Fe({entity:l,userRole:oe="guest",onEdit:F,onView:g,onCreate:x,hideFilters:A=!1,pagination:h="client",defaultPageSize:B=10}){const[P,E]=m(1),[v,ue]=m(B),{data:S,loading:p,mutate:T}=re(l,{pagination:h,...h==="server"&&{page:P,pageSize:v}}),{delete:k}=le(l),{t:e}=_("crud"),b=S?.items||[],{t:u}=_(l.namespace),[c,z]=m({}),[d,Q]=m(""),$=o(async()=>{await T()},[T]),L=o(t=>{F(t)},[F]),M=o(t=>{g&&g(t)},[g]),j=o(async t=>{await k(t)},[k]),q=o(t=>{z(t)},[]),D=N(()=>{let t=b;if(d){const i=d.toLowerCase();t=t.filter(r=>Object.values(r).some(a=>a==null?!1:String(a).toLowerCase().includes(i)))}return Object.keys(c).length>0&&(t=t.filter(i=>Object.entries(c).every(([r,a])=>{const s=i[r],O=l.fields[r]?.type||"text";return se(s,a,O)}))),t},[b,d,c,l.fields]),G=N(()=>{const i=(l.listFields||Object.keys(l.fields)).map(r=>{const a=l.fields[r];if(!a)return null;const s=ae(r,a,u),C=a.type||"text";return{key:r,title:s,dataIndex:r,sortable:!0,filterable:!0,align:C==="number"||C==="range"?"end":"start",render:(H,de)=>ne(H,a,u,{compact:!0})}}).filter(Boolean);return i.unshift({key:"_actions",title:e("actions.label",{defaultValue:"Actions"}),dataIndex:void 0,sortable:!1,width:120,align:"center",render:(r,a)=>f(y,{direction:"row",gap:"tight",align:"center",justify:"center",children:[n(V,{variant:"outline",icon:X,onClick:s=>{s.stopPropagation(),L(a.id)},"aria-label":e("edit",{defaultValue:"Edit"})}),n(ee,{action:async()=>{await j(a.id)},confirmText:e("delete.confirm",{defaultValue:"Are you sure you want to delete this item?"}),confirmTitle:e("delete.title",{defaultValue:"Delete Item"}),loadingText:e("delete.loading",{defaultValue:"Deleting..."}),variant:"destructive",icon:W,"aria-label":e("delete",{defaultValue:"Delete"}),children:e("delete",{defaultValue:"Delete"})})]})}),i},[l,u,e,L,j]),I=u("name",{defaultValue:l.name}),w=D.length;return f(J,{children:[n(R,{title:e("filters.title",{entity:I,defaultValue:`Browse ${I} - Filters`}),collapsible:!0,defaultOpen:!0,children:f(y,{gap:"medium",children:[f(y,{direction:"row",gap:"tight",align:"center",className:"dndev-w-full",style:{display:"grid",gridTemplateColumns:"1fr auto auto"},children:[n(te,{placeholder:e("search.placeholder",{defaultValue:"Search..."}),value:d,onChange:t=>Q(t.target.value),icon:Y,className:"dndev-w-full"}),n(V,{icon:K,variant:"outline",onClick:$,disabled:p,display:"compact","aria-label":e("refresh",{defaultValue:"Refresh"})}),x&&n(V,{icon:U,onClick:x,display:"compact",children:e("addNew",{defaultValue:"Add New"})})]}),!A&&n(ie,{entity:l,data:b,filters:c,onFiltersChange:q,fieldsToFilter:l.listFields})]})}),n(R,{title:p?e("results.title.fetching",{defaultValue:"Fetching..."}):e("results.title.count",{count:w,defaultValue:w===1?"Found 1 occurrence":`Found ${w} occurrences`}),collapsible:!0,defaultOpen:!0,children:n(Z,{data:D,columns:G,sortable:!0,searchable:!1,pagination:!0,loading:p,onRowClick:t=>M(t.id),showingLabel:e("pagination.showing",{defaultValue:"Showing {{from}} to {{to}} of {{total}} entries"}),paginationPreviousLabel:e("pagination.previous",{defaultValue:"Previous"}),paginationNextLabel:e("pagination.next",{defaultValue:"Next"}),paginationItemsPerPagePlaceholder:e("pagination.itemsPerPagePlaceholder",{defaultValue:"Items per page"}),...h==="server"&&{currentPage:P,pageSize:v,total:S?.total,onPageChange:E}})})]})}export{Fe as EntityList};