drf-react-by-schema 0.19.5 → 0.19.7

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/README.md CHANGED
@@ -42,7 +42,7 @@ The _DRF and React By Schema_ Suite is available for React at https://www.npmjs.
42
42
 
43
43
  3. Install all peer-dependencies of drf-react-by-schema:
44
44
  ```
45
- yarn add @emotion/react@^11.11.0 @emotion/styled@^11.11.0 @hookform/resolvers@^2.9.10 @mui/icons-material@^5.11.0 @mui/lab@^5.0.0-alpha.112 @mui/material@^5.13.7 @mui/x-data-grid@^5.17.26 @mui/x-date-pickers@^6.18.1 axios@^0.27.2 date-fns@^4.1.0 dayjs@^1.11.10 react@^18.2.0 react-dom@^18.2.0 react-hook-form@^7.41.3 react-number-format@^5.3.2 string-mask@^0.3.0 yup@^0.32.11
45
+ yarn add @emotion/react@^11.11.0 @emotion/styled@^11.11.0 @hookform/resolvers@^2.9.10 @mui/icons-material@^5.11.0 @mui/lab@^5.0.0-alpha.112 @mui/material@^5.13.7 @mui/x-data-grid@^5.17.26 @mui/x-date-pickers@^6.18.1 axios@^0.27.2 dayjs@^1.11.10 react@^18.2.0 react-dom@^18.2.0 react-hook-form@^7.41.3 react-number-format@^5.3.2 string-mask@^0.3.0 yup@^0.32.11
46
46
  ```
47
47
 
48
48
  4. Install drf-react-by-schema:
package/dist/api.js CHANGED
@@ -14,7 +14,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
14
14
  Object.defineProperty(exports, "__esModule", { value: true });
15
15
  exports.getAllModels = exports.getGenericModel = exports.getGenericModelList = exports.signUp = exports.getSignUpOptions = exports.isLoggedIn = exports.setAuthToken = exports.hasJWT = exports.clearJWT = exports.loginByPayload = exports.getAutoComplete = exports.addExistingRelatedModel = exports.updateDataBySchema = exports.createOrUpdateData = exports.deleteData = exports.createData = exports.partialUpdateData = exports.updateData = exports.getRawData = void 0;
16
16
  const axios_1 = __importDefault(require("axios"));
17
- const format_1 = require("date-fns/format");
17
+ const dayjs_1 = __importDefault(require("dayjs"));
18
18
  const utils_1 = require("./utils");
19
19
  const expiredTokenMessage = 'Token expired! System must login again';
20
20
  const noServerEndPointMessage = 'There is not API definition (serverEndPoint)!';
@@ -449,12 +449,12 @@ const prepareDataBySchema = ({ data, schema }) => {
449
449
  }
450
450
  // Date:
451
451
  if (field.type === 'date') {
452
- dbData[key] = (0, format_1.format)(new Date(data[key]), 'yyyy-MM-dd');
452
+ dbData[key] = (0, dayjs_1.default)(data[key]).format('YYYY-MM-DD');
453
453
  continue;
454
454
  }
455
455
  // DateTime:
456
456
  if (field.type === 'datetime') {
457
- dbData[key] = (0, format_1.format)(new Date(data[key]), "yyyy-MM-dd'T'HH:mm");
457
+ dbData[key] = (0, dayjs_1.default)(data[key]).format("YYYY-MM-DD'T'HH:mm");
458
458
  continue;
459
459
  }
460
460
  // Default:
@@ -46,7 +46,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
46
46
  };
47
47
  Object.defineProperty(exports, "__esModule", { value: true });
48
48
  const react_1 = __importStar(require("react"));
49
- const date_fns_1 = require("date-fns");
49
+ const dayjs_1 = __importDefault(require("dayjs"));
50
50
  const x_data_grid_1 = require("@mui/x-data-grid");
51
51
  const Box_1 = __importDefault(require("@mui/material/Box"));
52
52
  const CircularProgress_1 = __importDefault(require("@mui/material/CircularProgress"));
@@ -250,7 +250,7 @@ const DataGridBySchemaEditable = (0, react_1.forwardRef)(({ schema, data, rowCou
250
250
  case 'date':
251
251
  column.type = 'date';
252
252
  const dateFormat = (0, utils_1.buildDateFormatBySchema)(schema[col.field].date_views);
253
- column.valueFormatter = (params) => params.value ? (0, date_fns_1.format)(new Date(params.value), dateFormat) : '';
253
+ column.valueFormatter = (params) => params.value ? (0, dayjs_1.default)(params.value).format(dateFormat) : '';
254
254
  column.filterOperators = (0, utils_2.quantityOnlyOperators)({
255
255
  type: 'date',
256
256
  });
@@ -262,7 +262,7 @@ const DataGridBySchemaEditable = (0, react_1.forwardRef)(({ schema, data, rowCou
262
262
  case 'datetime':
263
263
  column.type = 'dateTime';
264
264
  column.minWidth = 180;
265
- column.valueFormatter = (params) => params.value ? (0, date_fns_1.format)(new Date(params.value), 'dd/MM/yyyy HH:mm') : '';
265
+ column.valueFormatter = (params) => params.value ? (0, dayjs_1.default)(params.value).format('dd/MM/yyyy HH:mm') : '';
266
266
  column.filterOperators = (0, utils_2.quantityOnlyOperators)({
267
267
  type: 'date',
268
268
  });
@@ -13,6 +13,7 @@ interface GenericModelListProps {
13
13
  indexFieldViewBasePath?: string;
14
14
  addExistingModel?: string;
15
15
  onProcessRow?: (p: Item) => void;
16
+ onDataChange?: (p: Item[]) => void;
16
17
  reloadAfterRowUpdate?: boolean;
17
18
  customColumnOperations?: (column: GridEnrichedBySchemaColDef) => GridEnrichedBySchemaColDef | Promise<GridEnrichedBySchemaColDef>;
18
19
  customFieldFormLayouts?: Record<string, FormFieldLayout[]>;
@@ -38,6 +39,6 @@ interface GenericModelListProps {
38
39
  disableScreenLoading?: boolean;
39
40
  extraValidators?: Item;
40
41
  }
41
- declare const GenericModelList: ({ model, columnFields, hiddenFields, creatableFields, disabledFields, minWidthFields, indexField, indexFieldBasePath, indexFieldViewBasePath, addExistingModel, onProcessRow, reloadAfterRowUpdate, customColumnOperations, customFieldFormLayouts, customLinkDestination, isEditable, hasBulkSelect, onSelectActions, sumRows, isAutoHeight, forceReload, LinkComponent, hasHeader, paginationMode, defaultFilter, queryParams, hideFooterComponent, hideToolbarComponent, tableAutoHeight, actions, customActions, optionsAC, defaultValues, disableScreenLoading, extraValidators, }: GenericModelListProps) => React.JSX.Element;
42
+ declare const GenericModelList: ({ model, columnFields, hiddenFields, creatableFields, disabledFields, minWidthFields, indexField, indexFieldBasePath, indexFieldViewBasePath, addExistingModel, onProcessRow, onDataChange, reloadAfterRowUpdate, customColumnOperations, customFieldFormLayouts, customLinkDestination, isEditable, hasBulkSelect, onSelectActions, sumRows, isAutoHeight, forceReload, LinkComponent, hasHeader, paginationMode, defaultFilter, queryParams, hideFooterComponent, hideToolbarComponent, tableAutoHeight, actions, customActions, optionsAC, defaultValues, disableScreenLoading, extraValidators, }: GenericModelListProps) => React.JSX.Element;
42
43
  export default GenericModelList;
43
44
  //# sourceMappingURL=GenericModelList.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"GenericModelList.d.ts","sourceRoot":"","sources":["../../src/components/GenericModelList.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAuB,aAAa,EAAE,MAAM,OAAO,CAAC;AAOlE,OAAO,EAAa,eAAe,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAMpF,OAAO,EACL,0BAA0B,EAG1B,UAAU,EACV,IAAI,EACJ,eAAe,EACf,SAAS,EACT,eAAe,EACf,YAAY,EAEZ,WAAW,EACX,kBAAkB,EACnB,MAAM,WAAW,CAAC;AAMnB,UAAU,qBAAqB;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;IAC3B,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACxC,UAAU,EAAE,MAAM,CAAC;IACnB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,sBAAsB,CAAC,EAAE,MAAM,CAAC;IAChC,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,YAAY,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,KAAK,IAAI,CAAC;IACjC,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,sBAAsB,CAAC,EAAE,CACvB,MAAM,EAAE,0BAA0B,KAC/B,0BAA0B,GAAG,OAAO,CAAC,0BAA0B,CAAC,CAAC;IACtE,sBAAsB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,EAAE,CAAC,CAAC;IAC3D,qBAAqB,CAAC,EAAE,CAAC,CAAC,EAAE,oBAAoB,KAAK,MAAM,CAAC;IAC5D,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,eAAe,CAAC,EAAE,eAAe,EAAE,CAAC;IACpC,OAAO,CAAC,EAAE,WAAW,CAAC;IACtB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,aAAa,CAAC,EAAE,aAAa,CAAC,kBAAkB,CAAC,GAAG,IAAI,CAAC;IACzD,SAAS,EAAE,OAAO,CAAC;IACnB,cAAc,EAAE,QAAQ,GAAG,QAAQ,CAAC;IACpC,aAAa,CAAC,EAAE,eAAe,CAAC;IAChC,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,OAAO,CAAC,EAAE,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC;IAChC,aAAa,CAAC,EAAE,YAAY,EAAE,CAAC;IAC/B,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,aAAa,CAAC,EAAE,IAAI,CAAC;IACrB,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,eAAe,CAAC,EAAE,IAAI,CAAC;CACxB;AAED,QAAA,MAAM,gBAAgB,GAAI,yjBAoCvB,qBAAqB,sBAqNvB,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
1
+ {"version":3,"file":"GenericModelList.d.ts","sourceRoot":"","sources":["../../src/components/GenericModelList.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAuB,aAAa,EAAE,MAAM,OAAO,CAAC;AAOlE,OAAO,EAAa,eAAe,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAMpF,OAAO,EACL,0BAA0B,EAG1B,UAAU,EACV,IAAI,EACJ,eAAe,EACf,SAAS,EACT,eAAe,EACf,YAAY,EAEZ,WAAW,EACX,kBAAkB,EACnB,MAAM,WAAW,CAAC;AAMnB,UAAU,qBAAqB;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;IAC3B,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACxC,UAAU,EAAE,MAAM,CAAC;IACnB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,sBAAsB,CAAC,EAAE,MAAM,CAAC;IAChC,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,YAAY,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,KAAK,IAAI,CAAC;IACjC,YAAY,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,IAAI,CAAC;IACnC,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,sBAAsB,CAAC,EAAE,CACvB,MAAM,EAAE,0BAA0B,KAC/B,0BAA0B,GAAG,OAAO,CAAC,0BAA0B,CAAC,CAAC;IACtE,sBAAsB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,EAAE,CAAC,CAAC;IAC3D,qBAAqB,CAAC,EAAE,CAAC,CAAC,EAAE,oBAAoB,KAAK,MAAM,CAAC;IAC5D,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,eAAe,CAAC,EAAE,eAAe,EAAE,CAAC;IACpC,OAAO,CAAC,EAAE,WAAW,CAAC;IACtB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,aAAa,CAAC,EAAE,aAAa,CAAC,kBAAkB,CAAC,GAAG,IAAI,CAAC;IACzD,SAAS,EAAE,OAAO,CAAC;IACnB,cAAc,EAAE,QAAQ,GAAG,QAAQ,CAAC;IACpC,aAAa,CAAC,EAAE,eAAe,CAAC;IAChC,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,OAAO,CAAC,EAAE,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC;IAChC,aAAa,CAAC,EAAE,YAAY,EAAE,CAAC;IAC/B,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,aAAa,CAAC,EAAE,IAAI,CAAC;IACrB,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,eAAe,CAAC,EAAE,IAAI,CAAC;CACxB;AAED,QAAA,MAAM,gBAAgB,GAAI,ukBAqCvB,qBAAqB,sBAyNvB,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
@@ -60,7 +60,7 @@ const utils_1 = require("../utils");
60
60
  const api_1 = require("../api");
61
61
  const DRFReactBySchemaContext_1 = require("../context/DRFReactBySchemaContext");
62
62
  const APIWrapperContext_1 = require("../context/APIWrapperContext");
63
- const GenericModelList = ({ model, columnFields, hiddenFields = [], creatableFields, disabledFields, minWidthFields, indexField, indexFieldBasePath, indexFieldViewBasePath, addExistingModel, onProcessRow, reloadAfterRowUpdate, customColumnOperations, customFieldFormLayouts, customLinkDestination, isEditable, hasBulkSelect = false, onSelectActions, sumRows, isAutoHeight = true, forceReload = false, LinkComponent = null, hasHeader = false, paginationMode = 'client', defaultFilter, queryParams, hideFooterComponent, hideToolbarComponent, tableAutoHeight, actions, customActions, optionsAC, defaultValues, disableScreenLoading, extraValidators, }) => {
63
+ const GenericModelList = ({ model, columnFields, hiddenFields = [], creatableFields, disabledFields, minWidthFields, indexField, indexFieldBasePath, indexFieldViewBasePath, addExistingModel, onProcessRow, onDataChange, reloadAfterRowUpdate, customColumnOperations, customFieldFormLayouts, customLinkDestination, isEditable, hasBulkSelect = false, onSelectActions, sumRows, isAutoHeight = true, forceReload = false, LinkComponent = null, hasHeader = false, paginationMode = 'client', defaultFilter, queryParams, hideFooterComponent, hideToolbarComponent, tableAutoHeight, actions, customActions, optionsAC, defaultValues, disableScreenLoading, extraValidators, }) => {
64
64
  const { serverEndPoint, isInBatches, firstBatchLength } = (0, DRFReactBySchemaContext_1.useDRFReactBySchema)();
65
65
  const { onEditModel } = (0, APIWrapperContext_1.useAPIWrapper)();
66
66
  const [data, setData] = (0, react_1.useState)(false);
@@ -171,6 +171,9 @@ const GenericModelList = ({ model, columnFields, hiddenFields = [], creatableFie
171
171
  loadObjectList();
172
172
  return;
173
173
  }
174
+ if (onDataChange) {
175
+ onDataChange(newData);
176
+ }
174
177
  setData(Object.assign(Object.assign({}, data), { data: newData }));
175
178
  }, LinkComponent: LinkComponent || undefined, paginationModel: paginationMode === 'server' ? paginationModel : undefined, setPaginationModel: paginationMode === 'server' ? setPaginationModel : undefined, rowCount: paginationMode === 'client'
176
179
  ? undefined
@@ -17,6 +17,7 @@ interface GenericRelatedModelListProps {
17
17
  addExistingModel?: string;
18
18
  label: string;
19
19
  onProcessRow?: (p: Item) => void;
20
+ onDataChange?: (p: Item[]) => void;
20
21
  reloadAfterRowUpdate?: boolean;
21
22
  customColumnOperations?: (column: GridEnrichedBySchemaColDef) => GridEnrichedBySchemaColDef | Promise<GridEnrichedBySchemaColDef>;
22
23
  isEditable?: boolean;
@@ -38,6 +39,6 @@ interface GenericRelatedModelListProps {
38
39
  LinkComponent?: ComponentType<LinkComponentProps> | null;
39
40
  extraValidators?: Item;
40
41
  }
41
- export default function GenericRelatedModelList({ model, id, relatedModel, columnFields, hiddenFields, creatableFields, disabledFields, usuaria, minWidthFields, indexField, indexFieldBasePath, indexFieldViewBasePath, addExistingModel, label, onProcessRow, reloadAfterRowUpdate, customColumnOperations, isEditable, hasBulkSelect, onSelectActions, sumRows, isAutoHeight, isInBatches, noCardWrapper, paginationMode, defaultFilter, queryParams, hideFooterComponent, hideToolbarComponent, tableAutoHeight, actions, optionsAC, defaultValues, LinkComponent, extraValidators, }: GenericRelatedModelListProps): React.JSX.Element;
42
+ export default function GenericRelatedModelList({ model, id, relatedModel, columnFields, hiddenFields, creatableFields, disabledFields, usuaria, minWidthFields, indexField, indexFieldBasePath, indexFieldViewBasePath, addExistingModel, label, onProcessRow, onDataChange, reloadAfterRowUpdate, customColumnOperations, isEditable, hasBulkSelect, onSelectActions, sumRows, isAutoHeight, isInBatches, noCardWrapper, paginationMode, defaultFilter, queryParams, hideFooterComponent, hideToolbarComponent, tableAutoHeight, actions, optionsAC, defaultValues, LinkComponent, extraValidators, }: GenericRelatedModelListProps): React.JSX.Element;
42
43
  export {};
43
44
  //# sourceMappingURL=GenericRelatedModelList.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"GenericRelatedModelList.d.ts","sourceRoot":"","sources":["../../src/components/GenericRelatedModelList.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAuB,aAAa,EAAE,MAAM,OAAO,CAAC;AAOlE,OAAO,EAAE,eAAe,EAAa,MAAM,kBAAkB,CAAC;AAO9D,OAAO,EACL,UAAU,EAIV,0BAA0B,EAC1B,EAAE,EACF,IAAI,EACJ,kBAAkB,EAClB,eAAe,EACf,SAAS,EAET,WAAW,EACZ,MAAM,WAAW,CAAC;AA4InB,UAAU,4BAA4B;IACpC,KAAK,EAAE,MAAM,CAAC;IACd,EAAE,EAAE,EAAE,CAAC;IACP,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,eAAe,EAAE,MAAM,EAAE,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;IAC1B,OAAO,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC;IACtB,cAAc,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACxC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,sBAAsB,CAAC,EAAE,MAAM,CAAC;IAChC,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,YAAY,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,KAAK,IAAI,CAAC;IACjC,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,sBAAsB,CAAC,EAAE,CACvB,MAAM,EAAE,0BAA0B,KAC/B,0BAA0B,GAAG,OAAO,CAAC,0BAA0B,CAAC,CAAC;IACtE,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,eAAe,CAAC,EAAE,eAAe,EAAE,CAAC;IACpC,OAAO,CAAC,EAAE,WAAW,CAAC;IACtB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,cAAc,EAAE,QAAQ,GAAG,QAAQ,CAAC;IACpC,aAAa,CAAC,EAAE,eAAe,CAAC;IAChC,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,OAAO,CAAC,EAAE,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC;IAChC,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,aAAa,CAAC,EAAE,IAAI,CAAC;IACrB,aAAa,CAAC,EAAE,aAAa,CAAC,kBAAkB,CAAC,GAAG,IAAI,CAAC;IACzD,eAAe,CAAC,EAAE,IAAI,CAAC;CACxB;AAED,MAAM,CAAC,OAAO,UAAU,uBAAuB,CAAC,EAC9C,KAAK,EACL,EAAE,EACF,YAAY,EACZ,YAAY,EACZ,YAAqB,EACrB,eAAe,EACf,cAAc,EACd,OAAc,EACd,cAAc,EACd,UAAU,EACV,kBAAkB,EAClB,sBAAsB,EACtB,gBAAgB,EAChB,KAAK,EACL,YAAY,EACZ,oBAAoB,EACpB,sBAAsB,EACtB,UAAiB,EACjB,aAAqB,EACrB,eAAe,EACf,OAAO,EACP,YAAoB,EACpB,WAAkB,EAClB,aAAqB,EACrB,cAAyB,EACzB,aAAa,EACb,WAAW,EACX,mBAAmB,EACnB,oBAAoB,EACpB,eAAe,EACf,OAAO,EACP,SAAS,EACT,aAAa,EACb,aAAa,EACb,eAAe,GAChB,EAAE,4BAA4B,qBAoN9B"}
1
+ {"version":3,"file":"GenericRelatedModelList.d.ts","sourceRoot":"","sources":["../../src/components/GenericRelatedModelList.tsx"],"names":[],"mappings":"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"}
@@ -47,29 +47,15 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
47
47
  Object.defineProperty(exports, "__esModule", { value: true });
48
48
  exports.default = GenericRelatedModelList;
49
49
  const react_1 = __importStar(require("react"));
50
- const Box_1 = __importDefault(require("@mui/material/Box"));
51
50
  const Card_1 = __importDefault(require("@mui/material/Card"));
52
51
  const CardHeader_1 = __importDefault(require("@mui/material/CardHeader"));
53
52
  const CardContent_1 = __importDefault(require("@mui/material/CardContent"));
54
- const Backdrop_1 = __importDefault(require("@mui/material/Backdrop"));
55
- const CircularProgress_1 = __importDefault(require("@mui/material/CircularProgress"));
56
- const DataGridBySchemaEditable_1 = __importDefault(require("./DataGridBySchemaEditable"));
57
- const DataTotals_1 = __importDefault(require("./DataTotals"));
58
- const DataTotalsServer_1 = __importDefault(require("./DataTotalsServer"));
59
53
  const APIWrapperContext_1 = require("../context/APIWrapperContext");
60
54
  const utils_1 = require("../utils");
61
55
  const api_1 = require("../api");
62
56
  const styles_1 = require("../styles");
63
- const ContentTable = ({ data, relatedModel, model, loading, id, indexField, indexFieldBasePath, indexFieldViewBasePath, addExistingModel, isEditable, onEditModel, finalCustomColumnOperations, setVisibleRows, isAutoHeight, hideFooterPagination, hideFooterComponent, hideToolbarComponent, onProcessRow, onDataChange, sumRows, visibleRows, paginationMode = 'client', paginationModel, setPaginationModel, hasBulkSelect, onSelectActions, tableAutoHeight, actions, customActions, optionsAC, defaultValues, LinkComponent, extraValidators, }) => (react_1.default.createElement(react_1.default.Fragment, null,
64
- data.columns ? (react_1.default.createElement(Box_1.default, { sx: tableAutoHeight ? {} : styles_1.Layout.dataGridFixedHeight },
65
- react_1.default.createElement(DataGridBySchemaEditable_1.default, { data: data.data, columns: data.columns, schema: data.schema, model: relatedModel, modelParent: model, modelParentId: id, loading: loading, indexField: indexField, indexFieldBasePath: indexFieldBasePath, indexFieldViewBasePath: indexFieldViewBasePath, addExistingModel: addExistingModel, isEditable: isEditable, hasBulkSelect: hasBulkSelect, onSelectActions: onSelectActions, onEditModel: onEditModel, isAutoHeight: isAutoHeight, tableAutoHeight: tableAutoHeight, customColumnOperations: finalCustomColumnOperations, setVisibleRows: setVisibleRows, hideFooterPagination: hideFooterPagination, hideFooterComponent: hideFooterComponent, hideToolbarComponent: hideToolbarComponent, actions: actions, customActions: customActions, optionsAC: optionsAC, defaultValues: defaultValues, onProcessRow: onProcessRow, onDataChange: onDataChange, paginationModel: paginationMode === 'server' ? paginationModel : undefined, setPaginationModel: paginationMode === 'server' ? setPaginationModel : undefined, rowCount: paginationMode === 'client'
66
- ? undefined
67
- : typeof data.rowCount !== undefined
68
- ? data.rowCount
69
- : 0, LinkComponent: LinkComponent || undefined, extraValidators: extraValidators }))) : (react_1.default.createElement(Backdrop_1.default, { invisible: true, sx: { color: '#fff', zIndex: (theme) => theme.zIndex.drawer + 1 }, open: loading || false },
70
- react_1.default.createElement(CircularProgress_1.default, null))),
71
- paginationMode === 'client' ? (react_1.default.createElement(DataTotals_1.default, { data: data.data, sumRows: sumRows, visibleRows: visibleRows })) : (react_1.default.createElement(DataTotalsServer_1.default, { sumRows: sumRows, totals: data.sumRowsTotals }))));
72
- function GenericRelatedModelList({ model, id, relatedModel, columnFields, hiddenFields = ['id'], creatableFields, disabledFields, usuaria = null, minWidthFields, indexField, indexFieldBasePath, indexFieldViewBasePath, addExistingModel, label, onProcessRow, reloadAfterRowUpdate, customColumnOperations, isEditable = true, hasBulkSelect = false, onSelectActions, sumRows, isAutoHeight = false, isInBatches = true, noCardWrapper = false, paginationMode = 'client', defaultFilter, queryParams, hideFooterComponent, hideToolbarComponent, tableAutoHeight, actions, optionsAC, defaultValues, LinkComponent, extraValidators, }) {
57
+ const GenericRelatedModelListTable_1 = __importDefault(require("./GenericRelatedModelListTable"));
58
+ function GenericRelatedModelList({ model, id, relatedModel, columnFields, hiddenFields = ['id'], creatableFields, disabledFields, usuaria = null, minWidthFields, indexField, indexFieldBasePath, indexFieldViewBasePath, addExistingModel, label, onProcessRow, onDataChange, reloadAfterRowUpdate, customColumnOperations, isEditable = true, hasBulkSelect = false, onSelectActions, sumRows, isAutoHeight = false, isInBatches = true, noCardWrapper = false, paginationMode = 'client', defaultFilter, queryParams, hideFooterComponent, hideToolbarComponent, tableAutoHeight, actions, optionsAC, defaultValues, LinkComponent, extraValidators, }) {
73
59
  const [data, setData] = (0, react_1.useState)(false);
74
60
  const [visibleRows, setVisibleRows] = (0, react_1.useState)([]);
75
61
  const [loading, setLoading] = (0, react_1.useState)(false);
@@ -151,7 +137,7 @@ function GenericRelatedModelList({ model, id, relatedModel, columnFields, hidden
151
137
  break;
152
138
  }
153
139
  });
154
- const onDataChange = (newData) => {
140
+ const onDataChangeLocal = (newData) => {
155
141
  if (!data) {
156
142
  return;
157
143
  }
@@ -159,6 +145,9 @@ function GenericRelatedModelList({ model, id, relatedModel, columnFields, hidden
159
145
  loadObjectList();
160
146
  return;
161
147
  }
148
+ if (onDataChange) {
149
+ onDataChange(newData);
150
+ }
162
151
  setData(Object.assign(Object.assign({}, data), { data: newData }));
163
152
  };
164
153
  (0, react_1.useEffect)(() => {
@@ -171,8 +160,8 @@ function GenericRelatedModelList({ model, id, relatedModel, columnFields, hidden
171
160
  }
172
161
  // eslint-disable-next-line react-hooks/exhaustive-deps
173
162
  }, [paginationModel]);
174
- return (react_1.default.createElement(react_1.default.Fragment, null, typeof data !== 'boolean' && data.columns && (react_1.default.createElement(react_1.default.Fragment, null, noCardWrapper ? (react_1.default.createElement(ContentTable, { data: data, relatedModel: relatedModel, model: model, loading: loading, id: id, indexField: indexField || '', indexFieldBasePath: indexFieldBasePath, indexFieldViewBasePath: indexFieldViewBasePath, addExistingModel: addExistingModel, isEditable: isEditable, hasBulkSelect: hasBulkSelect, onSelectActions: onSelectActions, onEditModel: onEditModel, onDeleteRelatedModel: onDeleteRelatedModel, finalCustomColumnOperations: finalCustomColumnOperations, setVisibleRows: setVisibleRows, isAutoHeight: isAutoHeight, tableAutoHeight: tableAutoHeight, hideFooterPagination: hideFooterPagination, hideFooterComponent: hideFooterComponent, hideToolbarComponent: hideToolbarComponent, onProcessRow: onProcessRow, onDataChange: onDataChange, sumRows: sumRows, visibleRows: visibleRows, paginationMode: paginationMode, paginationModel: paginationModel, setPaginationModel: setPaginationModel, actions: actions, optionsAC: optionsAC, defaultValues: defaultValues, LinkComponent: LinkComponent, extraValidators: extraValidators })) : (react_1.default.createElement(Card_1.default, { sx: styles_1.Layout.formCard },
163
+ return (react_1.default.createElement(react_1.default.Fragment, null, typeof data !== 'boolean' && data.columns && (react_1.default.createElement(react_1.default.Fragment, null, noCardWrapper ? (react_1.default.createElement(GenericRelatedModelListTable_1.default, { data: data, relatedModel: relatedModel, model: model, loading: loading, id: id, indexField: indexField || '', indexFieldBasePath: indexFieldBasePath, indexFieldViewBasePath: indexFieldViewBasePath, addExistingModel: addExistingModel, isEditable: isEditable, hasBulkSelect: hasBulkSelect, onSelectActions: onSelectActions, onEditModel: onEditModel, onDeleteRelatedModel: onDeleteRelatedModel, finalCustomColumnOperations: finalCustomColumnOperations, setVisibleRows: setVisibleRows, isAutoHeight: isAutoHeight, tableAutoHeight: tableAutoHeight, hideFooterPagination: hideFooterPagination, hideFooterComponent: hideFooterComponent, hideToolbarComponent: hideToolbarComponent, onProcessRow: onProcessRow, onDataChange: onDataChangeLocal, sumRows: sumRows, visibleRows: visibleRows, paginationMode: paginationMode, paginationModel: paginationModel, setPaginationModel: setPaginationModel, actions: actions, optionsAC: optionsAC, defaultValues: defaultValues, LinkComponent: LinkComponent, extraValidators: extraValidators })) : (react_1.default.createElement(Card_1.default, { sx: styles_1.Layout.formCard },
175
164
  react_1.default.createElement(CardHeader_1.default, { title: label }),
176
165
  react_1.default.createElement(CardContent_1.default, null,
177
- react_1.default.createElement(ContentTable, { data: data, relatedModel: relatedModel, model: model, loading: loading, id: id, indexField: indexField || '', indexFieldBasePath: indexFieldBasePath, indexFieldViewBasePath: indexFieldViewBasePath, addExistingModel: addExistingModel, isEditable: isEditable, hasBulkSelect: hasBulkSelect, onSelectActions: onSelectActions, onEditModel: onEditModel, onDeleteRelatedModel: onDeleteRelatedModel, finalCustomColumnOperations: finalCustomColumnOperations, setVisibleRows: setVisibleRows, isAutoHeight: isAutoHeight, tableAutoHeight: tableAutoHeight, hideFooterPagination: hideFooterPagination, hideFooterComponent: hideFooterComponent, hideToolbarComponent: hideToolbarComponent, onProcessRow: onProcessRow, onDataChange: onDataChange, sumRows: sumRows, visibleRows: visibleRows, paginationMode: paginationMode, paginationModel: paginationModel, setPaginationModel: setPaginationModel, actions: actions, optionsAC: optionsAC, defaultValues: defaultValues, LinkComponent: LinkComponent, extraValidators: extraValidators }))))))));
166
+ react_1.default.createElement(GenericRelatedModelListTable_1.default, { data: data, relatedModel: relatedModel, model: model, loading: loading, id: id, indexField: indexField || '', indexFieldBasePath: indexFieldBasePath, indexFieldViewBasePath: indexFieldViewBasePath, addExistingModel: addExistingModel, isEditable: isEditable, hasBulkSelect: hasBulkSelect, onSelectActions: onSelectActions, onEditModel: onEditModel, onDeleteRelatedModel: onDeleteRelatedModel, finalCustomColumnOperations: finalCustomColumnOperations, setVisibleRows: setVisibleRows, isAutoHeight: isAutoHeight, tableAutoHeight: tableAutoHeight, hideFooterPagination: hideFooterPagination, hideFooterComponent: hideFooterComponent, hideToolbarComponent: hideToolbarComponent, onProcessRow: onProcessRow, onDataChange: onDataChangeLocal, sumRows: sumRows, visibleRows: visibleRows, paginationMode: paginationMode, paginationModel: paginationModel, setPaginationModel: setPaginationModel, actions: actions, optionsAC: optionsAC, defaultValues: defaultValues, LinkComponent: LinkComponent, extraValidators: extraValidators }))))))));
178
167
  }
@@ -0,0 +1,43 @@
1
+ import React, { ComponentType } from 'react';
2
+ import { GridRowId } from '@mui/x-data-grid';
3
+ import { OnEditModelType, OnDeleteRelatedModelType } from '../context/APIWrapperContext';
4
+ import { ActionType, CustomAction, DataSchemaColumnsType, GridEnrichedBySchemaColDef, Id, Item, LinkComponentProps, OnSelectActions, OptionsAC, PaginationModel, SumRowsType } from '../@types';
5
+ interface GenericRelatedModelListTableProps {
6
+ data: DataSchemaColumnsType;
7
+ relatedModel: string;
8
+ model: string;
9
+ loading?: boolean;
10
+ id: Id;
11
+ indexField: string;
12
+ indexFieldBasePath?: string;
13
+ indexFieldViewBasePath?: string;
14
+ addExistingModel?: string;
15
+ isEditable?: boolean;
16
+ onEditModel: (p: OnEditModelType) => void;
17
+ onDeleteRelatedModel: (p: OnDeleteRelatedModelType) => Promise<boolean>;
18
+ finalCustomColumnOperations: (p: GridEnrichedBySchemaColDef) => GridEnrichedBySchemaColDef | Promise<GridEnrichedBySchemaColDef>;
19
+ setVisibleRows?: (p: GridRowId[]) => void;
20
+ visibleRows: GridRowId[];
21
+ isAutoHeight?: boolean;
22
+ hideFooterPagination: boolean;
23
+ hideFooterComponent?: boolean;
24
+ hideToolbarComponent?: boolean;
25
+ onProcessRow?: (p: Item) => void;
26
+ onDataChange?: (p: Item[]) => void;
27
+ sumRows?: SumRowsType;
28
+ paginationMode: 'server' | 'client';
29
+ paginationModel?: PaginationModel;
30
+ setPaginationModel?: (x: PaginationModel) => void;
31
+ hasBulkSelect?: boolean;
32
+ onSelectActions?: OnSelectActions[];
33
+ tableAutoHeight?: boolean;
34
+ actions?: Partial<ActionType>[];
35
+ customActions?: CustomAction[];
36
+ optionsAC?: OptionsAC;
37
+ defaultValues?: Item;
38
+ LinkComponent?: ComponentType<LinkComponentProps> | null;
39
+ extraValidators?: Item;
40
+ }
41
+ export default function GenericRelatedModelListTable({ data, relatedModel, model, loading, id, indexField, indexFieldBasePath, indexFieldViewBasePath, addExistingModel, isEditable, onEditModel, finalCustomColumnOperations, setVisibleRows, isAutoHeight, hideFooterPagination, hideFooterComponent, hideToolbarComponent, onProcessRow, onDataChange, sumRows, visibleRows, paginationMode, paginationModel, setPaginationModel, hasBulkSelect, onSelectActions, tableAutoHeight, actions, customActions, optionsAC, defaultValues, LinkComponent, extraValidators, }: GenericRelatedModelListTableProps): React.JSX.Element;
42
+ export {};
43
+ //# sourceMappingURL=GenericRelatedModelListTable.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GenericRelatedModelListTable.d.ts","sourceRoot":"","sources":["../../src/components/GenericRelatedModelListTable.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.default = GenericRelatedModelListTable;
7
+ const react_1 = __importDefault(require("react"));
8
+ const Box_1 = __importDefault(require("@mui/material/Box"));
9
+ const Backdrop_1 = __importDefault(require("@mui/material/Backdrop"));
10
+ const CircularProgress_1 = __importDefault(require("@mui/material/CircularProgress"));
11
+ const DataGridBySchemaEditable_1 = __importDefault(require("./DataGridBySchemaEditable"));
12
+ const DataTotals_1 = __importDefault(require("./DataTotals"));
13
+ const DataTotalsServer_1 = __importDefault(require("./DataTotalsServer"));
14
+ const styles_1 = require("../styles");
15
+ function GenericRelatedModelListTable({ data, relatedModel, model, loading, id, indexField, indexFieldBasePath, indexFieldViewBasePath, addExistingModel, isEditable, onEditModel, finalCustomColumnOperations, setVisibleRows, isAutoHeight, hideFooterPagination, hideFooterComponent, hideToolbarComponent, onProcessRow, onDataChange, sumRows, visibleRows, paginationMode = 'client', paginationModel, setPaginationModel, hasBulkSelect, onSelectActions, tableAutoHeight, actions, customActions, optionsAC, defaultValues, LinkComponent, extraValidators, }) {
16
+ return (react_1.default.createElement(react_1.default.Fragment, null,
17
+ data.columns ? (react_1.default.createElement(Box_1.default, { sx: tableAutoHeight ? {} : styles_1.Layout.dataGridFixedHeight },
18
+ react_1.default.createElement(DataGridBySchemaEditable_1.default, { data: data.data, columns: data.columns, schema: data.schema, model: relatedModel, modelParent: model, modelParentId: id, loading: loading, indexField: indexField, indexFieldBasePath: indexFieldBasePath, indexFieldViewBasePath: indexFieldViewBasePath, addExistingModel: addExistingModel, isEditable: isEditable, hasBulkSelect: hasBulkSelect, onSelectActions: onSelectActions, onEditModel: onEditModel, isAutoHeight: isAutoHeight, tableAutoHeight: tableAutoHeight, customColumnOperations: finalCustomColumnOperations, setVisibleRows: setVisibleRows, hideFooterPagination: hideFooterPagination, hideFooterComponent: hideFooterComponent, hideToolbarComponent: hideToolbarComponent, actions: actions, customActions: customActions, optionsAC: optionsAC, defaultValues: defaultValues, onProcessRow: onProcessRow, onDataChange: onDataChange, paginationModel: paginationMode === 'server' ? paginationModel : undefined, setPaginationModel: paginationMode === 'server' ? setPaginationModel : undefined, rowCount: paginationMode === 'client'
19
+ ? undefined
20
+ : typeof data.rowCount !== undefined
21
+ ? data.rowCount
22
+ : 0, LinkComponent: LinkComponent || undefined, extraValidators: extraValidators }))) : (react_1.default.createElement(Backdrop_1.default, { invisible: true, sx: { color: '#fff', zIndex: (theme) => theme.zIndex.drawer + 1 }, open: loading || false },
23
+ react_1.default.createElement(CircularProgress_1.default, null))),
24
+ paginationMode === 'client' ? (react_1.default.createElement(DataTotals_1.default, { data: data.data, sumRows: sumRows, visibleRows: visibleRows })) : (react_1.default.createElement(DataTotalsServer_1.default, { sumRows: sumRows, totals: data.sumRowsTotals }))));
25
+ }
@@ -5,7 +5,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.default = DetailFieldBySchema;
7
7
  const react_1 = __importDefault(require("react"));
8
- const date_fns_1 = require("date-fns");
8
+ const dayjs_1 = __importDefault(require("dayjs"));
9
9
  const Typography_1 = __importDefault(require("@mui/material/Typography"));
10
10
  const Box_1 = __importDefault(require("@mui/material/Box"));
11
11
  const List_1 = __importDefault(require("@mui/material/List"));
@@ -21,11 +21,11 @@ function DetailFieldBySchema({ name, value, schema, labelKey = 'label', optionId
21
21
  case 'date':
22
22
  return (react_1.default.createElement(Box_1.default, { sx: sxField },
23
23
  react_1.default.createElement(Typography_1.default, { variant: "h5", sx: sxLabel }, schema[name].label),
24
- react_1.default.createElement(Typography_1.default, { variant: "body2", sx: sxValue }, (0, date_fns_1.format)(new Date(value), 'dd/MM/yyyy'))));
24
+ react_1.default.createElement(Typography_1.default, { variant: "body2", sx: sxValue }, (0, dayjs_1.default)(value).format('DD/MM/YYYY'))));
25
25
  case 'datetime':
26
26
  return (react_1.default.createElement(Box_1.default, { sx: sxField },
27
27
  react_1.default.createElement(Typography_1.default, { variant: "h5", sx: sxLabel }, schema[name].label),
28
- react_1.default.createElement(Typography_1.default, { variant: "body2", sx: sxValue }, (0, date_fns_1.format)(new Date(value), 'dd/MM/yyyy HH:mm'))));
28
+ react_1.default.createElement(Typography_1.default, { variant: "body2", sx: sxValue }, (0, dayjs_1.default)(value).format('DD/MM/YYYY HH:mm'))));
29
29
  case 'nested object':
30
30
  case 'field':
31
31
  const multiple = schema[name].many || false;
package/dist/utils.d.ts CHANGED
@@ -26,7 +26,7 @@ export declare const getTmpId: () => string;
26
26
  export declare const isTmpId: (id: string | number | undefined | null) => boolean;
27
27
  export declare function reducer<T>(state: T | null, newState: Partial<T> | null): T | null;
28
28
  export declare const getPatternFormat: (type: string) => string;
29
- export declare function buildDateFormatBySchema(dateViews: string[] | null | undefined): "dd/MM/yyyy" | "MM/yyyy" | "yyyy" | "MM" | "dd";
29
+ export declare function buildDateFormatBySchema(dateViews: string[] | null | undefined): "DD/MM/YYYY" | "MM/YYYY" | "YYYY" | "MM" | "DD";
30
30
  export declare const slugToCamelCase: (str: string, includeFirst?: boolean) => string;
31
31
  export declare const slugify: (text: string | null) => string;
32
32
  export declare function mergeFilterItems(defaultFilter: GridFilterModel | undefined, filter: GridFilterModel | undefined): any;
package/dist/utils.js CHANGED
@@ -291,7 +291,7 @@ const getPatternFormat = (type) => {
291
291
  };
292
292
  exports.getPatternFormat = getPatternFormat;
293
293
  function buildDateFormatBySchema(dateViews) {
294
- const defaultFormat = 'dd/MM/yyyy';
294
+ const defaultFormat = 'DD/MM/YYYY';
295
295
  if (!dateViews) {
296
296
  return defaultFormat;
297
297
  }
@@ -302,16 +302,16 @@ function buildDateFormatBySchema(dateViews) {
302
302
  return defaultFormat;
303
303
  }
304
304
  if (!hasDay && hasMonth && hasYear) {
305
- return 'MM/yyyy';
305
+ return 'MM/YYYY';
306
306
  }
307
307
  if (!hasDay && !hasMonth && hasYear) {
308
- return 'yyyy';
308
+ return 'YYYY';
309
309
  }
310
310
  if (!hasDay && hasMonth && !hasYear) {
311
311
  return 'MM';
312
312
  }
313
313
  if (hasDay && !hasMonth && !hasYear) {
314
- return 'dd';
314
+ return 'DD';
315
315
  }
316
316
  return defaultFormat;
317
317
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "drf-react-by-schema",
3
- "version": "0.19.5",
3
+ "version": "0.19.7",
4
4
  "description": "Components and Tools for building a React App having Django Rest Framework (DRF) as server",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -67,7 +67,6 @@
67
67
  "@mui/x-data-grid": "^5.17.26",
68
68
  "@mui/x-date-pickers": "^6.18.1",
69
69
  "axios": "^0.27.2",
70
- "date-fns": "^4.1.0",
71
70
  "dayjs": "^1.11.10",
72
71
  "react": "^18.2.0",
73
72
  "react-dom": "^18.2.0",