@himanshu-sorathiya/react-kit 1.0.2 → 1.0.5

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/dist/index.d.ts CHANGED
@@ -5,6 +5,42 @@ export interface ModalProps {
5
5
  className?: string;
6
6
  }
7
7
  export declare function Modal({ children, className }: ModalProps): import("react").ReactPortal;
8
+ export type FilterType = "text" | "number" | "boolean" | "date" | "select" | "multiselect" | "custom";
9
+ export type TextOperator = "contains" | "equals" | "startsWith" | "endsWith" | "notContains";
10
+ export type NumberOperator = "equals" | "greaterThan" | "lessThan" | "greaterThanOrEqual" | "lessThanOrEqual" | "between";
11
+ export type BooleanOperator = "equals";
12
+ export type DateOperator = "equals" | "before" | "after" | "between";
13
+ export type SelectOperator = "equals" | "notEquals";
14
+ export type MultiselectOperator = "in" | "notIn" | "intersects";
15
+ export type CustomOperator = "custom";
16
+ export type FilterOperator = TextOperator | NumberOperator | BooleanOperator | DateOperator | SelectOperator | MultiselectOperator | CustomOperator;
17
+ export interface FilterOptions {
18
+ caseSensitive?: boolean;
19
+ compare?: (itemValue: any, filterValue: any, item: any) => boolean;
20
+ }
21
+ export interface FilterConfig extends FilterOptions {
22
+ id: string;
23
+ field: string;
24
+ type: FilterType;
25
+ operator: FilterOperator;
26
+ value: any;
27
+ }
28
+ export type FilterState = FilterConfig[];
29
+ export interface UseFilterReturn<T> {
30
+ filteredItems: T[];
31
+ filters: FilterState;
32
+ addFilter: (filter: FilterConfig) => void;
33
+ removeFilter: (id: string | string[]) => void;
34
+ clearFilters: () => void;
35
+ resetFilters: () => void;
36
+ setFilters: (filters: FilterConfig[]) => void;
37
+ toggleFilter: (filter: FilterConfig) => void;
38
+ updateFilterConfig: (id: string, partialConfig: Partial<Omit<FilterConfig, "id">>) => void;
39
+ getFilterValue: (id: string) => any;
40
+ updateFilterValue: (id: string, value: any) => void;
41
+ isFilterActive: (id: string) => boolean;
42
+ }
43
+ export declare function useFilter<T>(data: T[], initialFilters?: FilterState): UseFilterReturn<T>;
8
44
  export interface UseModalReturn<TData> {
9
45
  id: string | null;
10
46
  data: TData | undefined;
@@ -29,5 +65,36 @@ export interface UsePaginationReturn<T> {
29
65
  resetPageSize: () => void;
30
66
  }
31
67
  export declare function usePagination<T>(data: T[], initialPageSize: number, initialPageIndex?: number): UsePaginationReturn<T>;
68
+ export type SortType = "numeric" | "alphabetical" | "alphanumeric" | "boolean" | "date" | "basic" | "custom";
69
+ export interface SortOptions {
70
+ desc?: boolean;
71
+ caseSensitive?: boolean;
72
+ disableSortRemoval?: boolean;
73
+ invertSorting?: boolean;
74
+ sortUndefined?: "first" | "last" | false | -1 | 1;
75
+ compare?: (a: any, b: any) => number;
76
+ }
77
+ export interface SortConfig extends SortOptions {
78
+ id: string;
79
+ type: SortType;
80
+ field?: string;
81
+ }
82
+ export type SortState = Array<SortConfig>;
83
+ export interface UseSortReturn<T> {
84
+ sortedItems: T[];
85
+ sorts: SortState;
86
+ addSort: (sort: SortConfig) => void;
87
+ removeSort: (id: string | string[]) => void;
88
+ clearSorts: () => void;
89
+ resetSorts: () => void;
90
+ setSorts: (sorts: SortState) => void;
91
+ getSortDirection: (id: string) => "asc" | "desc" | undefined;
92
+ toggleSort: (id: string, type: SortType, options?: SortOptions & {
93
+ multi?: boolean;
94
+ }) => void;
95
+ getNextSortingOrder: (id: string) => "asc" | "desc" | "none";
96
+ getSortIndex: (id: string) => number | undefined;
97
+ }
98
+ export declare function useSort<T>(data: T[], initialSorts?: SortState): UseSortReturn<T>;
32
99
 
33
- export { };
100
+ export {};
package/dist/index.js CHANGED
@@ -1,6 +1,6 @@
1
- import { useCallback as e, useEffect as t, useMemo as n, useRef as r, useState as i } from "react";
2
- import { createPortal as a } from "react-dom";
3
1
  import { createStore as o, useSelector as s } from "@tanstack/react-store";
2
+ import { useCallback as e, useState as i, useMemo as n, useRef as r, useEffect as t } from "react";
3
+ import { createPortal as a } from "react-dom";
4
4
  import { jsx as c } from "react/jsx-runtime";
5
5
  //#region src/store/modalStore.ts
6
6
  var l = o({
@@ -48,8 +48,99 @@ function d({ children: e, className: n = "" }) {
48
48
  }), document.body);
49
49
  }
50
50
  //#endregion
51
+ //#region src/utils/filterUtils.ts
52
+ var f = {
53
+ text: {
54
+ contains: (e, t, n) => n?.caseSensitive ? String(e).includes(String(t)) : String(e).toLowerCase().includes(String(t).toLowerCase()),
55
+ equals: (e, t, n) => n?.caseSensitive ? String(e) === String(t) : String(e).toLowerCase() === String(t).toLowerCase(),
56
+ startsWith: (e, t, n) => n?.caseSensitive ? String(e).startsWith(String(t)) : String(e).toLowerCase().startsWith(String(t).toLowerCase()),
57
+ endsWith: (e, t, n) => n?.caseSensitive ? String(e).endsWith(String(t)) : String(e).toLowerCase().endsWith(String(t).toLowerCase()),
58
+ notContains: (e, t, n) => n?.caseSensitive ? !String(e).includes(String(t)) : !String(e).toLowerCase().includes(String(t).toLowerCase())
59
+ },
60
+ number: {
61
+ equals: (e, t) => Number(e) === Number(t),
62
+ greaterThan: (e, t) => Number(e) > Number(t),
63
+ lessThan: (e, t) => Number(e) < Number(t),
64
+ greaterThanOrEqual: (e, t) => Number(e) >= Number(t),
65
+ lessThanOrEqual: (e, t) => Number(e) <= Number(t),
66
+ between: (e, t) => Number(e) >= Number(t.min) && Number(e) <= Number(t.max)
67
+ },
68
+ boolean: { equals: (e, t) => !!e == !!t },
69
+ date: {
70
+ equals: (e, t) => new Date(e).getTime() === new Date(t).getTime(),
71
+ before: (e, t) => new Date(e).getTime() < new Date(t).getTime(),
72
+ after: (e, t) => new Date(e).getTime() > new Date(t).getTime(),
73
+ between: (e, t) => {
74
+ let n = new Date(e).getTime();
75
+ return n >= new Date(t.min).getTime() && n <= new Date(t.max).getTime();
76
+ }
77
+ },
78
+ select: {
79
+ equals: (e, t) => e === t,
80
+ notEquals: (e, t) => e !== t
81
+ },
82
+ multiselect: {
83
+ in: (e, t) => t.includes(e),
84
+ notIn: (e, t) => !t.includes(e),
85
+ intersects: (e, t) => e.some((e) => t.includes(e))
86
+ }
87
+ };
88
+ function p(e, t, n) {
89
+ if (typeof e != "object" || !e) return e;
90
+ let r = t || n;
91
+ return r.includes(".") ? r.split(".").reduce((e, t) => e?.[t], e) : e?.[r];
92
+ }
93
+ //#endregion
94
+ //#region src/hooks/useFilter.ts
95
+ function m(t, n = []) {
96
+ let [r, a] = i(n), o = t.filter((e) => r.every((t) => {
97
+ let { id: n, field: r, type: i, operator: a, value: o, compare: s, ...c } = t, l = p(e, r, n);
98
+ if (i === "custom" || a === "custom") return s ? s(l, o, e) : !0;
99
+ let u = f[i];
100
+ if (!u) return !0;
101
+ let d = u[a];
102
+ return d ? d(l, o, c) : !0;
103
+ })), s = e((e) => {
104
+ a((t) => t.some((t) => t.id === e.id) ? t.map((t) => t.id === e.id ? e : t) : [...t, e]);
105
+ }, []), c = e((e) => {
106
+ a((t) => Array.isArray(e) ? t.filter((t) => !e.includes(t.id)) : t.filter((t) => t.id !== e));
107
+ }, []), l = e(() => {
108
+ a([]);
109
+ }, []), u = e(() => {
110
+ a(n);
111
+ }, [n]), d = e((e) => {
112
+ a(e);
113
+ }, []), m = e((e) => r.find((t) => t.id === e)?.value, [r]), h = e((e, t) => {
114
+ a((n) => n.map((n) => n.id === e ? {
115
+ ...n,
116
+ value: t
117
+ } : n));
118
+ }, []), g = e((e) => r.some((t) => t.id === e), [r]);
119
+ return {
120
+ filteredItems: o,
121
+ filters: r,
122
+ addFilter: s,
123
+ removeFilter: c,
124
+ clearFilters: l,
125
+ resetFilters: u,
126
+ toggleFilter: e((e) => {
127
+ a((t) => t.some((t) => t.id === e.id) ? t.filter((t) => t.id !== e.id) : [...t, e]);
128
+ }, []),
129
+ updateFilterConfig: e((e, t) => {
130
+ a((n) => n.map((n) => n.id === e ? {
131
+ ...n,
132
+ ...t
133
+ } : n));
134
+ }, []),
135
+ setFilters: d,
136
+ getFilterValue: m,
137
+ updateFilterValue: h,
138
+ isFilterActive: g
139
+ };
140
+ }
141
+ //#endregion
51
142
  //#region src/hooks/usePagination.ts
52
- function f(t, r, a = 0) {
143
+ function h(t, r, a = 0) {
53
144
  let [o, s] = i(r), [c, l] = i(a), u = Math.max(1, Math.ceil(t.length / Math.max(1, o))), d = Math.min(Math.max(0, c), u - 1);
54
145
  return c !== d && l(d), {
55
146
  currentItems: n(() => typeof o != "number" || o < 1 ? [] : t.slice(c * o, (c + 1) * o), [
@@ -95,4 +186,156 @@ function f(t, r, a = 0) {
95
186
  };
96
187
  }
97
188
  //#endregion
98
- export { d as Modal, u as useModal, f as usePagination };
189
+ //#region src/utils/sortUtils.ts
190
+ function g(e, t, n = {}) {
191
+ let { sortUndefined: r, desc: i = !1 } = n, a = w(e, t, r, i);
192
+ if (a !== null) return a;
193
+ let o = !!e;
194
+ return o === !!t ? 0 : o ? 1 : -1;
195
+ }
196
+ function _(e, t, n = {}) {
197
+ let { sortUndefined: r, desc: i = !1 } = n, a = w(e, t, r, i);
198
+ return a === null ? (Number.isNaN(Number(e)) ? 0 : Number(e)) - (Number.isNaN(Number(t)) ? 0 : Number(t)) : a;
199
+ }
200
+ function v(e, t, n = {}) {
201
+ let { desc: r = !1, sortUndefined: i, caseSensitive: a = !1 } = n, o = w(e, t, i, r);
202
+ if (o !== null) return o;
203
+ let s = String(e), c = String(t);
204
+ return s.localeCompare(c, void 0, { sensitivity: a ? "variant" : "base" });
205
+ }
206
+ function y(e, t, n = {}) {
207
+ let { desc: r = !1, sortUndefined: i, caseSensitive: a = !1 } = n, o = w(e, t, i, r);
208
+ if (o !== null) return o;
209
+ let s = String(e), c = String(t);
210
+ return s.localeCompare(c, void 0, {
211
+ numeric: !0,
212
+ sensitivity: a ? "variant" : "base"
213
+ });
214
+ }
215
+ function b(e, t, n = {}) {
216
+ let { desc: r = !1, sortUndefined: i } = n, a = w(e, t, i, r);
217
+ if (a !== null) return a;
218
+ let o = new Date(e).getTime(), s = new Date(t).getTime();
219
+ return (Number.isNaN(o) ? 0 : o) - (Number.isNaN(s) ? 0 : s);
220
+ }
221
+ function x(e, t, n = {}) {
222
+ let { desc: r = !1, sortUndefined: i } = n, a = w(e, t, i, r);
223
+ return a === null ? e < t ? -1 : +(e > t) : a;
224
+ }
225
+ function S(e, t, n = {}) {
226
+ let { desc: r = !1, sortUndefined: i, compare: a } = n, o = w(e, t, i, r);
227
+ return o === null ? typeof a == "function" ? a(e, t) : e < t ? -1 : +(e > t) : o;
228
+ }
229
+ function C(e, t, n) {
230
+ if (typeof e != "object" || !e) return e;
231
+ let r = t || n;
232
+ return r.includes(".") ? r.split(".").reduce((e, t) => e?.[t], e) : e?.[r];
233
+ }
234
+ function w(e, t, n = !1, r) {
235
+ let i = e ?? void 0, a = t ?? void 0;
236
+ if (i !== void 0 && a !== void 0) return null;
237
+ if (i === void 0 && a === void 0 || n === !1) return 0;
238
+ if (n === "first") return i === void 0 ? -1 : 1;
239
+ if (n === "last") return i === void 0 ? 1 : -1;
240
+ if (n === -1) {
241
+ let e = r ? 1 : -1;
242
+ return i === void 0 ? e : -e;
243
+ }
244
+ if (n === 1) {
245
+ let e = r ? 1 : -1;
246
+ return i === void 0 ? -e : e;
247
+ }
248
+ return null;
249
+ }
250
+ //#endregion
251
+ //#region src/hooks/useSort.ts
252
+ function T(t, r = []) {
253
+ let [a, o] = i(r);
254
+ return {
255
+ sortedItems: n(() => t.toSorted((e, t) => {
256
+ for (let n of a) {
257
+ let { type: r, field: i, id: a, desc: o = !1, invertSorting: s = !1 } = n, c = C(e, i, a), l = C(t, i, a), u;
258
+ switch (r) {
259
+ case "numeric":
260
+ u = _(c, l, n);
261
+ break;
262
+ case "alphabetical":
263
+ u = v(c, l, n);
264
+ break;
265
+ case "alphanumeric":
266
+ u = y(c, l, n);
267
+ break;
268
+ case "boolean":
269
+ u = g(c, l, n);
270
+ break;
271
+ case "date":
272
+ u = b(c, l, n);
273
+ break;
274
+ case "basic":
275
+ u = x(c, l, n);
276
+ break;
277
+ case "custom":
278
+ u = S(c, l, n);
279
+ break;
280
+ default: u = x(c, l, n);
281
+ }
282
+ if (u !== 0) return u * (o === s ? 1 : -1);
283
+ }
284
+ return 0;
285
+ }), [a, t]),
286
+ sorts: a,
287
+ addSort: e((e) => o((t) => t.some((t) => t.id === e.id) ? t.map((t) => t.id === e.id ? e : t) : [...t, e]), []),
288
+ removeSort: e((e) => {
289
+ o((t) => Array.isArray(e) ? t.filter((t) => !e.includes(t.id)) : t.filter((t) => t.id !== e));
290
+ }, []),
291
+ clearSorts: e(() => o([]), []),
292
+ resetSorts: e(() => o(r), [r]),
293
+ setSorts: e((e) => o(e), []),
294
+ getSortDirection: e((e) => {
295
+ let t = a.find((t) => t.id === e);
296
+ return t ? t.desc ? "desc" : "asc" : void 0;
297
+ }, [a]),
298
+ toggleSort: e((e, t, n) => {
299
+ let { multi: r = !1, ...i } = n || {};
300
+ o((n) => {
301
+ let a = n.find((t) => t.id === e);
302
+ if (!a) {
303
+ let a = {
304
+ id: e,
305
+ type: t,
306
+ ...i,
307
+ desc: !1
308
+ };
309
+ return r ? [...n, a] : [a];
310
+ }
311
+ if (!a.desc) {
312
+ let t = {
313
+ ...a,
314
+ ...i,
315
+ desc: !0
316
+ };
317
+ return r ? n.map((n) => n.id === e ? t : n) : [t];
318
+ }
319
+ if (a.disableSortRemoval || i.disableSortRemoval) {
320
+ let t = {
321
+ ...a,
322
+ ...i,
323
+ desc: !1
324
+ };
325
+ return r ? n.map((n) => n.id === e ? t : n) : [t];
326
+ }
327
+ return r ? n.filter((t) => t.id !== e) : [];
328
+ });
329
+ }, []),
330
+ getNextSortingOrder: e((e) => {
331
+ let t = a.find((t) => t.id === e);
332
+ return t ? t.desc ? t.disableSortRemoval ? "asc" : "none" : "desc" : "asc";
333
+ }, [a]),
334
+ getSortIndex: e((e) => {
335
+ let t = a.findIndex((t) => t.id === e);
336
+ return t === -1 ? void 0 : t + 1;
337
+ }, [a])
338
+ };
339
+ }
340
+ //#endregion
341
+ export { d as Modal, m as useFilter, u as useModal, h as usePagination, T as useSort };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@himanshu-sorathiya/react-kit",
3
- "version": "1.0.2",
3
+ "version": "1.0.5",
4
4
  "description": "An opinionated collection of react hooks, and reusable UI components.",
5
5
  "type": "module",
6
6
  "module": "./dist/index.js",