@kaspernj/api-maker 1.0.2129 → 1.0.2131

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.
@@ -1,7 +1,7 @@
1
1
  export default useCollection;
2
2
  export type UseCollectionResult = {
3
3
  models: Array<import("./base-model.js").default>;
4
- modelIdsCacheString: Array<number | string>;
4
+ modelIdsCacheString: string;
5
5
  overallCount: number;
6
6
  query: import("./collection.js").default<any>;
7
7
  queryName: string;
@@ -14,63 +14,5 @@ export type UseCollectionResult = {
14
14
  showNoRecordsAvailableContent: false | import("react").ReactNode;
15
15
  showNoRecordsFoundContent: false | import("react").ReactNode;
16
16
  };
17
- /**
18
- * @typedef {object} UseCollectionResult
19
- * @property {Array<import("./base-model.js").default>} models
20
- * @property {Array<number | string>} modelIdsCacheString
21
- * @property {number} overallCount
22
- * @property {import("./collection.js").default} query
23
- * @property {string} queryName
24
- * @property {string} queryPerKey
25
- * @property {string} queryQName
26
- * @property {string} querySName
27
- * @property {string} queryPageName
28
- * @property {import("./result.js").default} result
29
- * @property {string[]} searchParams
30
- * @property {false | import("react").ReactNode} showNoRecordsAvailableContent
31
- * @property {false | import("react").ReactNode} showNoRecordsFoundContent
32
- */
33
- /**
34
- * @param {object} props
35
- * @param {Record<string, string[]>} props.abilities
36
- * @param {import("./collection.js").default} props.collection
37
- * @param {Record<string, any>} props.defaultParams
38
- * @param {string[]} props.groupBy
39
- * @param {function() : boolean} props.ifCondition
40
- * @param {number} props.limit
41
- * @param {typeof import("./base-model.js").default} props.modelClass
42
- * @param {function() : import("react").ReactNode} props.noRecordsAvailableContent
43
- * @param {function() : import("react").ReactNode} props.noRecordsFoundContent
44
- * @param {function() : void} props.onModelsLoaded
45
- * @param {boolean} props.pagination
46
- * @param {string[]} props.preloads
47
- * @param {function({query: import("./collection.js").default}) : import("./collection.js").default} props.queryMethod
48
- * @param {string} props.queryName
49
- * @param {Record<string, any>} props.ransack
50
- * @param {Record<string, string[]>} props.select
51
- * @param {Record<string, string[]>} props.selectColumns
52
- * @param {any[]} cacheKeys
53
- * @returns {UseCollectionResult & Record<string, any>}
54
- */
55
- declare function useCollection(props: {
56
- abilities: Record<string, string[]>;
57
- collection: import("./collection.js").default<any>;
58
- defaultParams: Record<string, any>;
59
- groupBy: string[];
60
- ifCondition: () => boolean;
61
- limit: number;
62
- modelClass: typeof import("./base-model.js").default;
63
- noRecordsAvailableContent: () => import("react").ReactNode;
64
- noRecordsFoundContent: () => import("react").ReactNode;
65
- onModelsLoaded: () => void;
66
- pagination: boolean;
67
- preloads: string[];
68
- queryMethod: (arg0: {
69
- query: import("./collection.js").default<any>;
70
- }) => import("./collection.js").default<any>;
71
- queryName: string;
72
- ransack: Record<string, any>;
73
- select: Record<string, string[]>;
74
- selectColumns: Record<string, string[]>;
75
- }, cacheKeys?: any[]): UseCollectionResult & Record<string, any>;
17
+ declare function useCollection(props: any, cacheKeys?: any[]): UseCollectionResult & Record<string, any>;
76
18
  //# sourceMappingURL=use-collection.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"use-collection.d.ts","sourceRoot":"/src/","sources":["use-collection.js"],"names":[],"mappings":";;YAYc,KAAK,CAAC,OAAO,iBAAiB,EAAE,OAAO,CAAC;yBACxC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;kBACtB,MAAM;;eAEN,MAAM;iBACN,MAAM;gBACN,MAAM;gBACN,MAAM;mBACN,MAAM;YACN,OAAO,aAAa,EAAE,OAAO;kBAC7B,MAAM,EAAE;mCACR,KAAK,GAAG,OAAO,OAAO,EAAE,SAAS;+BACjC,KAAK,GAAG,OAAO,OAAO,EAAE,SAAS;;AAd/C;;;;;;;;;;;;;;;GAeG;AAEH;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,sCApBG;IAAwC,SAAS,EAAzC,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC;IACiB,UAAU,EAAnD,sCAAiC;IACN,aAAa,EAAxC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IACH,OAAO,EAAvB,MAAM,EAAE;IACoB,WAAW,EAAvC,MAAa,OAAO;IACN,KAAK,EAAnB,MAAM;IAC0C,UAAU,EAA1D,cAAc,iBAAiB,EAAE,OAAO;IACM,yBAAyB,EAAvE,MAAa,OAAO,OAAO,EAAE,SAAS;IACQ,qBAAqB,EAAnE,MAAa,OAAO,OAAO,EAAE,SAAS;IACb,cAAc,EAAvC,MAAa,IAAI;IACF,UAAU,EAAzB,OAAO;IACS,QAAQ,EAAxB,MAAM,EAAE;IACwF,WAAW,EAA3G,CAAS,IAA0C,EAA1C;QAAC,KAAK,EAAE,sCAAiC,CAAA;KAAC,KAAI,sCAAiC;IAC1E,SAAS,EAAvB,MAAM;IACqB,OAAO,EAAlC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IACa,MAAM,EAAtC,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC;IACQ,aAAa,EAA7C,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC;CAChC,cAAQ,GAAG,EAAE,GACH,mBAAmB,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAsSrD"}
1
+ {"version":3,"file":"use-collection.d.ts","sourceRoot":"/src/","sources":["use-collection.js"],"names":[],"mappings":";;YAYc,KAAK,CAAC,OAAO,iBAAiB,EAAE,OAAO,CAAC;yBACxC,MAAM;kBACN,MAAM;;eAEN,MAAM;iBACN,MAAM;gBACN,MAAM;gBACN,MAAM;mBACN,MAAM;YACN,OAAO,aAAa,EAAE,OAAO;kBAC7B,MAAM,EAAE;mCACR,KAAK,GAAG,OAAO,OAAO,EAAE,SAAS;+BACjC,KAAK,GAAG,OAAO,OAAO,EAAE,SAAS;;AA0W/C,yGA0DC"}
@@ -1,16 +1,16 @@
1
1
  /* eslint-disable no-unused-vars, no-use-before-define, prefer-object-spread, sort-imports */
2
+ import { ShapeHook, useShapeHook } from "set-state-compare";
2
3
  import debounce from "debounce";
3
4
  import { digg } from "diggerize";
4
5
  import * as inflection from "inflection";
5
6
  import ModelEvents from "./model-events.js";
6
- import { useCallback, useEffect, useMemo, useRef } from "react";
7
+ import { useEffect } from "react";
7
8
  import useCreatedEvent from "./use-created-event.js";
8
- import useShape from "./use-shape.js";
9
9
  import useQueryParams from "on-location-changed/build/use-query-params.js";
10
10
  /**
11
11
  * @typedef {object} UseCollectionResult
12
12
  * @property {Array<import("./base-model.js").default>} models
13
- * @property {Array<number | string>} modelIdsCacheString
13
+ * @property {string} modelIdsCacheString
14
14
  * @property {number} overallCount
15
15
  * @property {import("./collection.js").default} query
16
16
  * @property {string} queryName
@@ -45,89 +45,158 @@ import useQueryParams from "on-location-changed/build/use-query-params.js";
45
45
  * @param {any[]} cacheKeys
46
46
  * @returns {UseCollectionResult & Record<string, any>}
47
47
  */
48
- const useCollection = (props, cacheKeys = []) => {
49
- const { abilities, collection, defaultParams, groupBy, ifCondition, limit, modelClass, noRecordsAvailableContent = undefined, noRecordsFoundContent = undefined, onModelsLoaded, pagination = false, preloads = [], queryMethod, queryName: initialQueryName, ransack, select = {}, selectColumns, ...restProps } = props;
50
- if (Object.keys(restProps).length > 0) {
51
- throw new Error(`Unknown props given to useCollection: ${Object.keys(restProps).join(", ")}`);
48
+ /** Hook state container for useCollection. */
49
+ class UseCollectionShapeHook extends ShapeHook {
50
+ /** Constructor. */
51
+ constructor(props) {
52
+ super(props);
53
+ this.loadModelsGeneration = 0;
54
+ this.loadOverallCountGeneration = 0;
55
+ this.queryParams = undefined;
52
56
  }
53
- const s = useShape(props);
54
- const queryName = initialQueryName || digg(modelClass.modelClassData(), "collectionKey");
55
- const loadModelsGenerationRef = useRef(0);
56
- const loadOverallCountGenerationRef = useRef(0);
57
- s.meta.queryParams = useQueryParams();
58
- const hasQParams = useCallback(() => {
59
- if (s.s.queryQName in s.m.queryParams)
60
- return true;
61
- return false;
62
- }, []);
63
- const qParams = useCallback(() => {
64
- if (hasQParams())
65
- return JSON.parse(digg(s.m.queryParams, s.s.queryQName));
66
- return {};
67
- }, []);
68
- s.useStates({
69
- models: undefined,
70
- overallCount: undefined,
71
- query: undefined,
72
- queryName,
73
- queryPerKey: `${queryName}_per`,
74
- queryQName: `${queryName}_q`,
75
- querySName: `${queryName}_s`,
76
- queryPageName: `${queryName}_page`,
77
- result: undefined,
78
- searchParams: undefined,
79
- showNoRecordsAvailableContent: false,
80
- showNoRecordsFoundContent: false
81
- });
82
- s.useStates({
83
- qParams: () => qParams()
84
- });
85
- let modelIdsCacheString;
86
- if (s.s.models === undefined) {
87
- modelIdsCacheString = "models-undefined";
57
+ /** @returns {string} */
58
+ queryName() {
59
+ return this.p.queryName || digg(this.p.modelClass.modelClassData(), "collectionKey");
60
+ }
61
+ /** @returns {string} */
62
+ queryPerKey() {
63
+ return `${this.queryName()}_per`;
64
+ }
65
+ /** @returns {string} */
66
+ queryQName() {
67
+ return `${this.queryName()}_q`;
68
+ }
69
+ /** @returns {string} */
70
+ querySName() {
71
+ return `${this.queryName()}_s`;
72
+ }
73
+ /** @returns {string} */
74
+ queryPageName() {
75
+ return `${this.queryName()}_page`;
76
+ }
77
+ /** @returns {string} */
78
+ modelIdsCacheString() {
79
+ if (this.s.models === undefined) {
80
+ return "models-undefined";
81
+ }
82
+ else if (this.s.models.length === 0) {
83
+ return "no-models";
84
+ }
85
+ else {
86
+ return this.s.models.map((model) => model.cacheKey())?.join("---");
87
+ }
88
+ }
89
+ /** @returns {Function & {clear?: () => void}} */
90
+ loadModelsDebounce() {
91
+ return this.cache("loadModelsDebounce", () => debounce(() => this.loadModels()));
88
92
  }
89
- else if (s.s.models.length === 0) {
90
- modelIdsCacheString = "no-models";
93
+ /** @param {Record<string, any>} args */
94
+ showNoRecordsAvailableContent(args) {
95
+ let models, overallCount;
96
+ if (args.models !== undefined) {
97
+ models = args.models;
98
+ }
99
+ else if (this.s.models !== undefined) {
100
+ models = this.s.models;
101
+ }
102
+ if (args.overallCount !== undefined) {
103
+ overallCount = args.overallCount;
104
+ }
105
+ else if (this.s.overallCount !== undefined) {
106
+ overallCount = this.s.overallCount;
107
+ }
108
+ if (models === undefined || overallCount === undefined || this.p.noRecordsAvailableContent === undefined)
109
+ return false;
110
+ if (models.length === 0 && overallCount === 0 && this.p.noRecordsAvailableContent)
111
+ return true;
91
112
  }
92
- else {
93
- modelIdsCacheString = s.s.models.map((model) => model.cacheKey())?.join("---");
113
+ /** @param {Record<string, any>} args */
114
+ showNoRecordsFoundContent(args) {
115
+ let models, overallCount;
116
+ if (args.models !== undefined) {
117
+ models = args.models;
118
+ }
119
+ else if (this.s.models !== undefined) {
120
+ models = this.s.models;
121
+ }
122
+ if (args.overallCount !== undefined) {
123
+ overallCount = args.overallCount;
124
+ }
125
+ else if (this.s.overallCount !== undefined) {
126
+ overallCount = this.s.overallCount;
127
+ }
128
+ if (models === undefined || this.p.noRecordsFoundContent === undefined)
129
+ return false;
130
+ // Dont show noRecordsAvailableContent together with noRecordsAvailableContent
131
+ if (models.length === 0 && overallCount === 0 && this.p.noRecordsAvailableContent)
132
+ return false;
133
+ if (models.length === 0 && this.p.noRecordsFoundContent)
134
+ return true;
94
135
  }
95
- const loadOverallCount = useCallback(async () => {
136
+ /** @returns {Promise<void>} */
137
+ loadOverallCount = async () => {
96
138
  // Ignore late overall-count responses once a newer load cycle has started or the hook unmounted.
97
- const loadOverallCountGeneration = loadOverallCountGenerationRef.current + 1;
98
- loadOverallCountGenerationRef.current = loadOverallCountGeneration;
99
- const baseQuery = s.p.collection || s.p.modelClass.all();
139
+ const loadOverallCountGeneration = this.loadOverallCountGeneration + 1;
140
+ this.loadOverallCountGeneration = loadOverallCountGeneration;
141
+ const baseQuery = this.p.collection || this.p.modelClass.all();
100
142
  const overallCount = await baseQuery.count();
101
- if (loadOverallCountGeneration != loadOverallCountGenerationRef.current)
143
+ if (loadOverallCountGeneration != this.loadOverallCountGeneration)
102
144
  return;
103
- s.set({
145
+ this.setState({
104
146
  overallCount,
105
- showNoRecordsAvailableContent: showNoRecordsAvailableContent({ overallCount }),
106
- showNoRecordsFoundContent: showNoRecordsFoundContent({ overallCount })
147
+ showNoRecordsAvailableContent: this.showNoRecordsAvailableContent({ overallCount }),
148
+ showNoRecordsFoundContent: this.showNoRecordsFoundContent({ overallCount })
107
149
  });
108
- }, []);
109
- const loadQParams = useCallback(() => {
110
- const qParamsToSet = hasQParams() ? qParams() : Object.assign({}, s.props.defaultParams);
150
+ };
151
+ /** @returns {{qParams: Record<string, any>, searchParams: string[]}} */
152
+ loadQParams() {
153
+ let qParamsToSet = Object.assign({}, this.p.defaultParams);
111
154
  const searchParams = [];
112
- if (s.m.queryParams[s.s.querySName]) {
113
- for (const rawSearchParam of s.m.queryParams[s.s.querySName]) {
155
+ if (this.queryParams && this.queryQName() in this.queryParams) {
156
+ qParamsToSet = JSON.parse(digg(this.queryParams, this.queryQName()));
157
+ }
158
+ if (this.queryParams?.[this.querySName()]) {
159
+ for (const rawSearchParam of this.queryParams[this.querySName()]) {
114
160
  const parsedSearchParam = JSON.parse(rawSearchParam);
115
161
  searchParams.push(parsedSearchParam);
116
162
  }
117
163
  }
118
- s.set({
164
+ this.setState({
119
165
  qParams: qParamsToSet,
120
166
  searchParams
121
167
  });
122
- }, []);
123
- const loadModels = useCallback(async () => {
168
+ return {
169
+ qParams: qParamsToSet,
170
+ searchParams
171
+ };
172
+ }
173
+ /**
174
+ * @param {object} [args]
175
+ * @param {Record<string, any>} [args.qParams]
176
+ * @param {string[]} [args.searchParams]
177
+ * @returns {{qParams: Record<string, any>, searchParams: string[]}}
178
+ */
179
+ loadModelsArgs(args = {}) {
180
+ return {
181
+ qParams: args.qParams ?? this.s.qParams,
182
+ searchParams: args.searchParams ?? this.s.searchParams
183
+ };
184
+ }
185
+ /**
186
+ * @param {object} [args]
187
+ * @param {Record<string, any>} [args.qParams]
188
+ * @param {string[]} [args.searchParams]
189
+ * @returns {Promise<void>}
190
+ */
191
+ loadModels = async (args = {}) => {
124
192
  // Only the newest collection request is allowed to update state after navigation/filter changes.
125
- const loadModelsGeneration = loadModelsGenerationRef.current + 1;
126
- loadModelsGenerationRef.current = loadModelsGeneration;
127
- let query = s.props.collection?.clone() || s.p.modelClass.ransack();
128
- if (s.props.pagination) {
129
- const page = s.m.queryParams[s.s.queryPageName] || 1;
130
- let per = s.m.queryParams[s.s.queryPerKey] || 30;
193
+ const loadModelsGeneration = this.loadModelsGeneration + 1;
194
+ const { qParams, searchParams } = this.loadModelsArgs(args);
195
+ this.loadModelsGeneration = loadModelsGeneration;
196
+ let query = this.p.collection?.clone() || this.p.modelClass.ransack();
197
+ if (this.p.pagination) {
198
+ const page = this.queryParams?.[this.queryPageName()] || 1;
199
+ let per = this.queryParams?.[this.queryPerKey()] || 30;
131
200
  if (per == "all") {
132
201
  per = 999_999_999;
133
202
  }
@@ -136,154 +205,182 @@ const useCollection = (props, cacheKeys = []) => {
136
205
  }
137
206
  query.page(page).per(per);
138
207
  }
139
- if (s.props.groupBy)
140
- query = query.groupBy(...s.p.groupBy);
208
+ if (this.p.groupBy)
209
+ query = query.groupBy(...this.p.groupBy);
141
210
  query = query
142
- .ransack(s.s.qParams)
143
- .search(s.s.searchParams)
144
- .searchKey(s.s.queryQName)
145
- .pageKey(s.s.queryPageName)
146
- .perKey(s.s.queryPerKey);
147
- if (s.props.abilities)
148
- query.abilities(s.p.abilities);
149
- if (s.props.limit !== undefined)
150
- query.limit(s.p.limit);
151
- if (s.props.preloads)
152
- query.preload(s.p.preloads);
153
- if (s.props.ransack)
154
- query.ransack(s.props.ransack);
155
- if (s.props.select)
156
- query.select(s.p.select);
157
- if (s.props.selectColumns)
158
- query.selectColumns(s.p.selectColumns);
211
+ .ransack(qParams)
212
+ .search(searchParams)
213
+ .searchKey(this.queryQName())
214
+ .pageKey(this.queryPageName())
215
+ .perKey(this.queryPerKey());
216
+ if (this.p.abilities)
217
+ query.abilities(this.p.abilities);
218
+ if (this.p.limit !== undefined)
219
+ query.limit(this.p.limit);
220
+ if (this.p.preloads)
221
+ query.preload(this.p.preloads);
222
+ if (this.p.ransack)
223
+ query.ransack(this.p.ransack);
224
+ if (this.p.select)
225
+ query.select(this.p.select);
226
+ if (this.p.selectColumns)
227
+ query.selectColumns(this.p.selectColumns);
159
228
  let result;
160
- if (s.props.queryMethod) {
161
- result = await s.p.queryMethod({ query });
229
+ if (this.p.queryMethod) {
230
+ result = await this.p.queryMethod({ query });
162
231
  }
163
232
  else {
164
233
  result = await query.result();
165
234
  }
166
235
  const models = result.models();
167
- if (loadModelsGeneration != loadModelsGenerationRef.current)
236
+ if (loadModelsGeneration != this.loadModelsGeneration)
168
237
  return;
169
- if (s.props.onModelsLoaded) {
170
- s.p.onModelsLoaded({
238
+ if (this.p.onModelsLoaded) {
239
+ this.p.onModelsLoaded({
171
240
  models,
172
- qParams: s.s.qParams,
241
+ qParams: this.s.qParams,
173
242
  query,
174
243
  result
175
244
  });
176
245
  }
177
- s.set({
178
- models: result.models(),
246
+ this.setState({
247
+ models,
179
248
  query,
180
249
  result,
181
- showNoRecordsAvailableContent: showNoRecordsAvailableContent({ models }),
182
- showNoRecordsFoundContent: showNoRecordsFoundContent({ models })
250
+ showNoRecordsAvailableContent: this.showNoRecordsAvailableContent({ models }),
251
+ showNoRecordsFoundContent: this.showNoRecordsFoundContent({ models })
183
252
  });
184
- }, []);
185
- const loadModelsDebounce = useCallback(debounce(loadModels), []);
186
- const onModelDestroyed = useCallback((args) => {
187
- s.set({
188
- models: s.s.models.filter((model) => model.id() != args.model.id())
253
+ };
254
+ /** @param {{model: import("./base-model.js").default}} args */
255
+ onModelDestroyed(args) {
256
+ const destroyedModel = digg(args, "model");
257
+ this.setState({
258
+ models: this.s.models.filter((model) => model.id() != destroyedModel.id())
189
259
  });
190
- }, []);
191
- const onModelUpdated = useCallback((args) => {
260
+ }
261
+ /** @param {{model: import("./base-model.js").default}} args */
262
+ onModelUpdated(args) {
192
263
  const updatedModel = digg(args, "model");
193
- const foundModel = s.s.models.find((model) => model.id() == updatedModel.id());
264
+ const foundModel = this.s.models.find((model) => model.id() == updatedModel.id());
194
265
  if (foundModel)
195
- loadModelsDebounce();
196
- }, []);
197
- const showNoRecordsAvailableContent = useCallback((args) => {
198
- let models, overallCount;
199
- if (args.models !== undefined) {
200
- models = args.models;
201
- }
202
- else if (s.s.models !== undefined) {
203
- models = s.s.models;
204
- }
205
- if (args.overallCount !== undefined) {
206
- overallCount = args.overallCount;
207
- }
208
- else if (s.s.overallCount !== undefined) {
209
- overallCount = s.s.overallCount;
210
- }
211
- if (models === undefined || overallCount === undefined || s.p.noRecordsAvailableContent === undefined)
212
- return false;
213
- if (models.length === 0 && overallCount === 0 && s.p.noRecordsAvailableContent)
214
- return true;
215
- }, []);
216
- const showNoRecordsFoundContent = useCallback((args) => {
217
- let models, overallCount;
218
- if (args.models !== undefined) {
219
- models = args.models;
220
- }
221
- else if (s.s.models !== undefined) {
222
- models = s.s.models;
223
- }
224
- if (args.overallCount !== undefined) {
225
- overallCount = args.overallCount;
226
- }
227
- else if (s.s.overallCount !== undefined) {
228
- overallCount = s.s.overallCount;
229
- }
230
- if (models === undefined || s.props.noRecordsFoundContent === undefined)
231
- return false;
232
- // Dont show noRecordsAvailableContent together with noRecordsAvailableContent
233
- if (models.length === 0 && overallCount === 0 && s.props.noRecordsAvailableContent)
234
- return false;
235
- if (models.length === 0 && s.props.noRecordsFoundContent)
236
- return true;
237
- }, []);
238
- const onCreated = useCallback(() => {
239
- loadModelsDebounce();
240
- }, []);
241
- // Collection loading has to wait until mount so fast responses cannot get stranded in ShapeHook's pre-mount queue.
242
- useEffect(() => {
243
- if (!("ifCondition" in s.props) || s.props.ifCondition) {
244
- loadQParams();
245
- loadModels();
246
- }
247
- }, [
248
- modelClass,
249
- s.props.ifCondition,
250
- s.s.queryName,
251
- s.m.queryParams[s.s.queryQName],
252
- s.m.queryParams[s.s.queryPageName],
253
- s.m.queryParams[s.s.queryPerKey],
254
- s.m.queryParams[s.s.querySName],
255
- collection
256
- ].concat(cacheKeys));
257
- useEffect(() => {
258
- if (s.props.noRecordsAvailableContent) {
259
- loadOverallCount();
260
- }
261
- }, [modelClass]);
262
- useCreatedEvent(s.p.modelClass, onCreated);
263
- // Invalidate any in-flight async responses so unmounted hooks cannot write stale state.
264
- useEffect(() => () => {
265
- loadModelsGenerationRef.current += 1;
266
- loadOverallCountGenerationRef.current += 1;
267
- }, []);
268
- useEffect(() => {
269
- const connections = [];
270
- if (s.s.models) {
271
- for (const model of s.s.models) {
272
- connections.push(ModelEvents.connectUpdated(model, onModelUpdated));
273
- connections.push(ModelEvents.connectDestroyed(model, onModelDestroyed));
266
+ this.loadModelsDebounce()();
267
+ }
268
+ /** @returns {void} */
269
+ onCreated() {
270
+ this.loadModelsDebounce()();
271
+ }
272
+ /** @returns {void} */
273
+ componentDidMount() {
274
+ this.setState({ readyToLoad: true });
275
+ }
276
+ /** @returns {void} */
277
+ setup() {
278
+ this.useStates({
279
+ models: undefined,
280
+ overallCount: undefined,
281
+ qParams: {},
282
+ query: undefined,
283
+ readyToLoad: false,
284
+ result: undefined,
285
+ searchParams: undefined,
286
+ showNoRecordsAvailableContent: false,
287
+ showNoRecordsFoundContent: false
288
+ });
289
+ this.setInstance({ queryParams: useQueryParams() });
290
+ // Wait until componentDidMount has flipped readyToLoad so the first load runs after useShapeHook has marked the hook mounted.
291
+ useEffect(() => {
292
+ if (!this.s.readyToLoad)
293
+ return;
294
+ let ifConditionMet;
295
+ if (typeof this.p.ifCondition == "function") {
296
+ ifConditionMet = this.p.ifCondition();
274
297
  }
275
- }
276
- return () => {
277
- for (const connection of connections) {
278
- connection.unsubscribe();
298
+ else if (this.p.ifCondition === undefined) {
299
+ ifConditionMet = true;
279
300
  }
280
- };
281
- }, [modelIdsCacheString]);
282
- const result = /** @type {UseCollectionResult & Record<string, any>} */ (Object.assign({}, s.state));
283
- const modelVariableName = inflection.pluralize(inflection.camelize(modelClass.modelClassData().name, true));
284
- result.modelIdsCacheString = modelIdsCacheString;
285
- result[modelVariableName] = s.s.models;
301
+ else {
302
+ ifConditionMet = this.p.ifCondition;
303
+ }
304
+ if (ifConditionMet) {
305
+ const { qParams, searchParams } = this.loadQParams();
306
+ this.loadModels({ qParams, searchParams });
307
+ }
308
+ }, [
309
+ this.p.modelClass,
310
+ this.p.ifCondition,
311
+ this.queryName(),
312
+ this.queryParams?.[this.queryQName()],
313
+ this.queryParams?.[this.queryPageName()],
314
+ this.queryParams?.[this.queryPerKey()],
315
+ this.queryParams?.[this.querySName()],
316
+ this.s.readyToLoad,
317
+ this.p.collection
318
+ ].concat(this.p.cacheKeys));
319
+ useEffect(() => {
320
+ if (!this.s.readyToLoad)
321
+ return;
322
+ if (this.p.noRecordsAvailableContent) {
323
+ this.loadOverallCount();
324
+ }
325
+ }, [this.p.modelClass, this.s.readyToLoad]);
326
+ useCreatedEvent(this.p.modelClass, () => this.onCreated());
327
+ // Invalidate any in-flight async responses so unmounted hooks cannot write stale state.
328
+ useEffect(() => () => {
329
+ this.loadModelsGeneration += 1;
330
+ this.loadOverallCountGeneration += 1;
331
+ this.loadModelsDebounce().clear?.();
332
+ }, []);
333
+ useEffect(() => {
334
+ const connections = [];
335
+ if (this.s.models) {
336
+ for (const model of this.s.models) {
337
+ connections.push(ModelEvents.connectUpdated(model, (args) => this.onModelUpdated(args)));
338
+ connections.push(ModelEvents.connectDestroyed(model, (args) => this.onModelDestroyed(args)));
339
+ }
340
+ }
341
+ return () => {
342
+ for (const connection of connections) {
343
+ connection.unsubscribe();
344
+ }
345
+ };
346
+ }, [this.modelIdsCacheString()]);
347
+ }
348
+ }
349
+ const useCollection = (props, cacheKeys = []) => {
350
+ const { abilities, collection, defaultParams, groupBy, ifCondition, limit, modelClass, noRecordsAvailableContent = undefined, noRecordsFoundContent = undefined, onModelsLoaded, pagination = false, preloads = [], queryMethod, queryName, ransack, select = {}, selectColumns, ...restProps } = props;
351
+ if (Object.keys(restProps).length > 0) {
352
+ throw new Error(`Unknown props given to useCollection: ${Object.keys(restProps).join(", ")}`);
353
+ }
354
+ const shapeHook = useShapeHook(UseCollectionShapeHook, {
355
+ abilities,
356
+ cacheKeys,
357
+ collection,
358
+ defaultParams,
359
+ groupBy,
360
+ ifCondition,
361
+ limit,
362
+ modelClass,
363
+ noRecordsAvailableContent,
364
+ noRecordsFoundContent,
365
+ onModelsLoaded,
366
+ pagination,
367
+ preloads,
368
+ queryMethod,
369
+ queryName,
370
+ ransack,
371
+ select,
372
+ selectColumns
373
+ });
374
+ const result = /** @type {UseCollectionResult & Record<string, any>} */ (Object.assign({}, shapeHook.state));
375
+ const modelVariableName = inflection.pluralize(inflection.camelize(shapeHook.p.modelClass.modelClassData().name, true));
376
+ result.modelIdsCacheString = shapeHook.modelIdsCacheString();
377
+ result.queryName = shapeHook.queryName();
378
+ result.queryPerKey = shapeHook.queryPerKey();
379
+ result.queryQName = shapeHook.queryQName();
380
+ result.querySName = shapeHook.querySName();
381
+ result.queryPageName = shapeHook.queryPageName();
382
+ result[modelVariableName] = shapeHook.s.models;
286
383
  return result;
287
384
  };
288
385
  export default useCollection;
289
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"use-collection.js","sourceRoot":"/src/","sources":["use-collection.js"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-unused-vars, no-use-before-define, prefer-object-spread, sort-imports */\nimport debounce from \"debounce\"\nimport {digg} from \"diggerize\"\nimport * as inflection from \"inflection\"\nimport ModelEvents from \"./model-events.js\"\nimport {useCallback, useEffect, useMemo, useRef} from \"react\"\nimport useCreatedEvent from \"./use-created-event.js\"\nimport useShape from \"./use-shape.js\"\nimport useQueryParams from \"on-location-changed/build/use-query-params.js\"\n\n/**\n * @typedef {object} UseCollectionResult\n * @property {Array<import(\"./base-model.js\").default>} models\n * @property {Array<number | string>} modelIdsCacheString\n * @property {number} overallCount\n * @property {import(\"./collection.js\").default} query\n * @property {string} queryName\n * @property {string} queryPerKey\n * @property {string} queryQName\n * @property {string} querySName\n * @property {string} queryPageName\n * @property {import(\"./result.js\").default} result\n * @property {string[]} searchParams\n * @property {false | import(\"react\").ReactNode} showNoRecordsAvailableContent\n * @property {false | import(\"react\").ReactNode} showNoRecordsFoundContent\n */\n\n/**\n * @param {object} props\n * @param {Record<string, string[]>} props.abilities\n * @param {import(\"./collection.js\").default} props.collection\n * @param {Record<string, any>} props.defaultParams\n * @param {string[]} props.groupBy\n * @param {function() : boolean} props.ifCondition\n * @param {number} props.limit\n * @param {typeof import(\"./base-model.js\").default} props.modelClass\n * @param {function() : import(\"react\").ReactNode} props.noRecordsAvailableContent\n * @param {function() : import(\"react\").ReactNode} props.noRecordsFoundContent\n * @param {function() : void} props.onModelsLoaded\n * @param {boolean} props.pagination\n * @param {string[]} props.preloads\n * @param {function({query: import(\"./collection.js\").default}) : import(\"./collection.js\").default} props.queryMethod\n * @param {string} props.queryName\n * @param {Record<string, any>} props.ransack\n * @param {Record<string, string[]>} props.select\n * @param {Record<string, string[]>} props.selectColumns\n * @param {any[]} cacheKeys\n * @returns {UseCollectionResult & Record<string, any>}\n */\nconst useCollection = (props, cacheKeys = []) => {\n  const {\n    abilities,\n    collection,\n    defaultParams,\n    groupBy,\n    ifCondition,\n    limit,\n    modelClass,\n    noRecordsAvailableContent = undefined,\n    noRecordsFoundContent = undefined,\n    onModelsLoaded,\n    pagination = false,\n    preloads = [],\n    queryMethod,\n    queryName: initialQueryName,\n    ransack,\n    select = {},\n    selectColumns,\n    ...restProps\n  } = props\n\n  if (Object.keys(restProps).length > 0) {\n    throw new Error(`Unknown props given to useCollection: ${Object.keys(restProps).join(\", \")}`)\n  }\n\n  const s = useShape(props)\n  const queryName = initialQueryName || digg(modelClass.modelClassData(), \"collectionKey\")\n  const loadModelsGenerationRef = useRef(0)\n  const loadOverallCountGenerationRef = useRef(0)\n\n  s.meta.queryParams = useQueryParams()\n\n  const hasQParams = useCallback(() => {\n    if (s.s.queryQName in s.m.queryParams) return true\n\n    return false\n  }, [])\n\n  const qParams = useCallback(() => {\n    if (hasQParams()) return JSON.parse(digg(s.m.queryParams, s.s.queryQName))\n\n    return {}\n  }, [])\n\n  s.useStates({\n    models: undefined,\n    overallCount: undefined,\n    query: undefined,\n    queryName,\n    queryPerKey: `${queryName}_per`,\n    queryQName: `${queryName}_q`,\n    querySName: `${queryName}_s`,\n    queryPageName: `${queryName}_page`,\n    result: undefined,\n    searchParams: undefined,\n    showNoRecordsAvailableContent: false,\n    showNoRecordsFoundContent: false\n  })\n  s.useStates({\n    qParams: () => qParams()\n  })\n\n  let modelIdsCacheString\n\n  if (s.s.models === undefined) {\n    modelIdsCacheString = \"models-undefined\"\n  } else if (s.s.models.length === 0) {\n    modelIdsCacheString = \"no-models\"\n  } else {\n    modelIdsCacheString = s.s.models.map((model) => model.cacheKey())?.join(\"---\")\n  }\n\n  const loadOverallCount = useCallback(async () => {\n    // Ignore late overall-count responses once a newer load cycle has started or the hook unmounted.\n    const loadOverallCountGeneration = loadOverallCountGenerationRef.current + 1\n\n    loadOverallCountGenerationRef.current = loadOverallCountGeneration\n\n    const baseQuery = s.p.collection || s.p.modelClass.all()\n    const overallCount = await baseQuery.count()\n\n    if (loadOverallCountGeneration != loadOverallCountGenerationRef.current) return\n\n    s.set({\n      overallCount,\n      showNoRecordsAvailableContent: showNoRecordsAvailableContent({overallCount}),\n      showNoRecordsFoundContent: showNoRecordsFoundContent({overallCount})\n    })\n  }, [])\n\n  const loadQParams = useCallback(() => {\n    const qParamsToSet = hasQParams() ? qParams() : Object.assign({}, s.props.defaultParams)\n    const searchParams = []\n\n    if (s.m.queryParams[s.s.querySName]) {\n      for (const rawSearchParam of s.m.queryParams[s.s.querySName]) {\n        const parsedSearchParam = JSON.parse(rawSearchParam)\n\n        searchParams.push(parsedSearchParam)\n      }\n    }\n\n    s.set({\n      qParams: qParamsToSet,\n      searchParams\n    })\n  }, [])\n\n  const loadModels = useCallback(async () => {\n    // Only the newest collection request is allowed to update state after navigation/filter changes.\n    const loadModelsGeneration = loadModelsGenerationRef.current + 1\n\n    loadModelsGenerationRef.current = loadModelsGeneration\n    let query = s.props.collection?.clone() || s.p.modelClass.ransack()\n\n    if (s.props.pagination) {\n      const page = s.m.queryParams[s.s.queryPageName] || 1\n      let per = s.m.queryParams[s.s.queryPerKey] || 30\n\n      if (per == \"all\") {\n        per = 999_999_999\n      } else {\n        per = Number(per)\n      }\n\n      query.page(page).per(per)\n    }\n\n    if (s.props.groupBy) query = query.groupBy(...s.p.groupBy)\n\n    query = query\n      .ransack(s.s.qParams)\n      .search(s.s.searchParams)\n      .searchKey(s.s.queryQName)\n      .pageKey(s.s.queryPageName)\n      .perKey(s.s.queryPerKey)\n\n    if (s.props.abilities) query.abilities(s.p.abilities)\n    if (s.props.limit !== undefined) query.limit(s.p.limit)\n    if (s.props.preloads) query.preload(s.p.preloads)\n    if (s.props.ransack) query.ransack(s.props.ransack)\n    if (s.props.select) query.select(s.p.select)\n    if (s.props.selectColumns) query.selectColumns(s.p.selectColumns)\n\n    let result\n\n    if (s.props.queryMethod) {\n      result = await s.p.queryMethod({query})\n    } else {\n      result = await query.result()\n    }\n\n    const models = result.models()\n\n    if (loadModelsGeneration != loadModelsGenerationRef.current) return\n\n    if (s.props.onModelsLoaded) {\n      s.p.onModelsLoaded({\n        models,\n        qParams: s.s.qParams,\n        query,\n        result\n      })\n    }\n\n    s.set({\n      models: result.models(),\n      query,\n      result,\n      showNoRecordsAvailableContent: showNoRecordsAvailableContent({models}),\n      showNoRecordsFoundContent: showNoRecordsFoundContent({models})\n    })\n  }, [])\n\n  const loadModelsDebounce = useCallback(debounce(loadModels), [])\n  const onModelDestroyed = useCallback((args) => {\n    s.set({\n      models: s.s.models.filter((model) => model.id() != args.model.id())\n    })\n  }, [])\n\n  const onModelUpdated = useCallback((args) => {\n    const updatedModel = digg(args, \"model\")\n    const foundModel = s.s.models.find((model) => model.id() == updatedModel.id())\n\n    if (foundModel) loadModelsDebounce()\n  }, [])\n\n  const showNoRecordsAvailableContent = useCallback((args) => {\n    let models, overallCount\n\n    if (args.models !== undefined) {\n      models = args.models\n    } else if (s.s.models !== undefined) {\n      models = s.s.models\n    }\n\n    if (args.overallCount !== undefined) {\n      overallCount = args.overallCount\n    } else if (s.s.overallCount !== undefined) {\n      overallCount = s.s.overallCount\n    }\n\n    if (models === undefined || overallCount === undefined || s.p.noRecordsAvailableContent === undefined) return false\n    if (models.length === 0 && overallCount === 0 && s.p.noRecordsAvailableContent) return true\n  }, [])\n\n  const showNoRecordsFoundContent = useCallback((args) => {\n    let models, overallCount\n\n    if (args.models !== undefined) {\n      models = args.models\n    } else if (s.s.models !== undefined) {\n      models = s.s.models\n    }\n\n    if (args.overallCount !== undefined) {\n      overallCount = args.overallCount\n    } else if (s.s.overallCount !== undefined) {\n      overallCount = s.s.overallCount\n    }\n\n    if (models === undefined || s.props.noRecordsFoundContent === undefined) return false\n\n    // Dont show noRecordsAvailableContent together with noRecordsAvailableContent\n    if (models.length === 0 && overallCount === 0 && s.props.noRecordsAvailableContent) return false\n    if (models.length === 0 && s.props.noRecordsFoundContent) return true\n  }, [])\n\n  const onCreated = useCallback(() => {\n    loadModelsDebounce()\n  }, [])\n\n  // Collection loading has to wait until mount so fast responses cannot get stranded in ShapeHook's pre-mount queue.\n  useEffect(\n    () => {\n      if (!(\"ifCondition\" in s.props) || s.props.ifCondition) {\n        loadQParams()\n        loadModels()\n      }\n    },\n    [\n      modelClass,\n      s.props.ifCondition,\n      s.s.queryName,\n      s.m.queryParams[s.s.queryQName],\n      s.m.queryParams[s.s.queryPageName],\n      s.m.queryParams[s.s.queryPerKey],\n      s.m.queryParams[s.s.querySName],\n      collection\n    ].concat(cacheKeys)\n  )\n\n  useEffect(() => {\n    if (s.props.noRecordsAvailableContent) {\n      loadOverallCount()\n    }\n  }, [modelClass])\n\n  useCreatedEvent(s.p.modelClass, onCreated)\n\n  // Invalidate any in-flight async responses so unmounted hooks cannot write stale state.\n  useEffect(() => () => {\n    loadModelsGenerationRef.current += 1\n    loadOverallCountGenerationRef.current += 1\n  }, [])\n\n  useEffect(() => {\n    const connections = []\n\n    if (s.s.models) {\n      for(const model of s.s.models) {\n        connections.push(ModelEvents.connectUpdated(model, onModelUpdated))\n        connections.push(ModelEvents.connectDestroyed(model, onModelDestroyed))\n      }\n    }\n\n    return () => {\n      for(const connection of connections) {\n        connection.unsubscribe()\n      }\n    }\n  }, [modelIdsCacheString])\n\n  const result = /** @type {UseCollectionResult & Record<string, any>} */ (Object.assign({}, s.state))\n  const modelVariableName = inflection.pluralize(inflection.camelize(modelClass.modelClassData().name, true))\n\n  result.modelIdsCacheString = modelIdsCacheString\n  result[modelVariableName] = s.s.models\n\n  return result\n}\n\nexport default useCollection\n"]}
386
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"use-collection.js","sourceRoot":"/src/","sources":["use-collection.js"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-unused-vars, no-use-before-define, prefer-object-spread, sort-imports */\nimport {ShapeHook, useShapeHook} from \"set-state-compare\"\nimport debounce from \"debounce\"\nimport {digg} from \"diggerize\"\nimport * as inflection from \"inflection\"\nimport ModelEvents from \"./model-events.js\"\nimport {useEffect} from \"react\"\nimport useCreatedEvent from \"./use-created-event.js\"\nimport useQueryParams from \"on-location-changed/build/use-query-params.js\"\n\n/**\n * @typedef {object} UseCollectionResult\n * @property {Array<import(\"./base-model.js\").default>} models\n * @property {string} modelIdsCacheString\n * @property {number} overallCount\n * @property {import(\"./collection.js\").default} query\n * @property {string} queryName\n * @property {string} queryPerKey\n * @property {string} queryQName\n * @property {string} querySName\n * @property {string} queryPageName\n * @property {import(\"./result.js\").default} result\n * @property {string[]} searchParams\n * @property {false | import(\"react\").ReactNode} showNoRecordsAvailableContent\n * @property {false | import(\"react\").ReactNode} showNoRecordsFoundContent\n */\n\n/**\n * @param {object} props\n * @param {Record<string, string[]>} props.abilities\n * @param {import(\"./collection.js\").default} props.collection\n * @param {Record<string, any>} props.defaultParams\n * @param {string[]} props.groupBy\n * @param {function() : boolean} props.ifCondition\n * @param {number} props.limit\n * @param {typeof import(\"./base-model.js\").default} props.modelClass\n * @param {function() : import(\"react\").ReactNode} props.noRecordsAvailableContent\n * @param {function() : import(\"react\").ReactNode} props.noRecordsFoundContent\n * @param {function() : void} props.onModelsLoaded\n * @param {boolean} props.pagination\n * @param {string[]} props.preloads\n * @param {function({query: import(\"./collection.js\").default}) : import(\"./collection.js\").default} props.queryMethod\n * @param {string} props.queryName\n * @param {Record<string, any>} props.ransack\n * @param {Record<string, string[]>} props.select\n * @param {Record<string, string[]>} props.selectColumns\n * @param {any[]} cacheKeys\n * @returns {UseCollectionResult & Record<string, any>}\n */\n/** Hook state container for useCollection. */\nclass UseCollectionShapeHook extends ShapeHook {\n  /** Constructor. */\n  constructor(props) {\n    super(props)\n    this.loadModelsGeneration = 0\n    this.loadOverallCountGeneration = 0\n    this.queryParams = undefined\n  }\n\n  /** @returns {string} */\n  queryName() {\n    return this.p.queryName || digg(this.p.modelClass.modelClassData(), \"collectionKey\")\n  }\n\n  /** @returns {string} */\n  queryPerKey() {\n    return `${this.queryName()}_per`\n  }\n\n  /** @returns {string} */\n  queryQName() {\n    return `${this.queryName()}_q`\n  }\n\n  /** @returns {string} */\n  querySName() {\n    return `${this.queryName()}_s`\n  }\n\n  /** @returns {string} */\n  queryPageName() {\n    return `${this.queryName()}_page`\n  }\n\n  /** @returns {string} */\n  modelIdsCacheString() {\n    if (this.s.models === undefined) {\n      return \"models-undefined\"\n    } else if (this.s.models.length === 0) {\n      return \"no-models\"\n    } else {\n      return this.s.models.map((model) => model.cacheKey())?.join(\"---\")\n    }\n  }\n\n  /** @returns {Function & {clear?: () => void}} */\n  loadModelsDebounce() {\n    return this.cache(\"loadModelsDebounce\", () => debounce(() => this.loadModels()))\n  }\n\n  /** @param {Record<string, any>} args */\n  showNoRecordsAvailableContent(args) {\n    let models, overallCount\n\n    if (args.models !== undefined) {\n      models = args.models\n    } else if (this.s.models !== undefined) {\n      models = this.s.models\n    }\n\n    if (args.overallCount !== undefined) {\n      overallCount = args.overallCount\n    } else if (this.s.overallCount !== undefined) {\n      overallCount = this.s.overallCount\n    }\n\n    if (models === undefined || overallCount === undefined || this.p.noRecordsAvailableContent === undefined) return false\n    if (models.length === 0 && overallCount === 0 && this.p.noRecordsAvailableContent) return true\n  }\n\n  /** @param {Record<string, any>} args */\n  showNoRecordsFoundContent(args) {\n    let models, overallCount\n\n    if (args.models !== undefined) {\n      models = args.models\n    } else if (this.s.models !== undefined) {\n      models = this.s.models\n    }\n\n    if (args.overallCount !== undefined) {\n      overallCount = args.overallCount\n    } else if (this.s.overallCount !== undefined) {\n      overallCount = this.s.overallCount\n    }\n\n    if (models === undefined || this.p.noRecordsFoundContent === undefined) return false\n\n    // Dont show noRecordsAvailableContent together with noRecordsAvailableContent\n    if (models.length === 0 && overallCount === 0 && this.p.noRecordsAvailableContent) return false\n    if (models.length === 0 && this.p.noRecordsFoundContent) return true\n  }\n\n  /** @returns {Promise<void>} */\n  loadOverallCount = async () => {\n    // Ignore late overall-count responses once a newer load cycle has started or the hook unmounted.\n    const loadOverallCountGeneration = this.loadOverallCountGeneration + 1\n\n    this.loadOverallCountGeneration = loadOverallCountGeneration\n\n    const baseQuery = this.p.collection || this.p.modelClass.all()\n    const overallCount = await baseQuery.count()\n\n    if (loadOverallCountGeneration != this.loadOverallCountGeneration) return\n\n    this.setState({\n      overallCount,\n      showNoRecordsAvailableContent: this.showNoRecordsAvailableContent({overallCount}),\n      showNoRecordsFoundContent: this.showNoRecordsFoundContent({overallCount})\n    })\n  }\n\n  /** @returns {{qParams: Record<string, any>, searchParams: string[]}} */\n  loadQParams() {\n    let qParamsToSet = Object.assign({}, this.p.defaultParams)\n    const searchParams = []\n\n    if (this.queryParams && this.queryQName() in this.queryParams) {\n      qParamsToSet = JSON.parse(digg(this.queryParams, this.queryQName()))\n    }\n\n    if (this.queryParams?.[this.querySName()]) {\n      for (const rawSearchParam of this.queryParams[this.querySName()]) {\n        const parsedSearchParam = JSON.parse(rawSearchParam)\n\n        searchParams.push(parsedSearchParam)\n      }\n    }\n\n    this.setState({\n      qParams: qParamsToSet,\n      searchParams\n    })\n\n    return {\n      qParams: qParamsToSet,\n      searchParams\n    }\n  }\n\n  /**\n   * @param {object} [args]\n   * @param {Record<string, any>} [args.qParams]\n   * @param {string[]} [args.searchParams]\n   * @returns {{qParams: Record<string, any>, searchParams: string[]}}\n   */\n  loadModelsArgs(args = {}) {\n    return {\n      qParams: args.qParams ?? this.s.qParams,\n      searchParams: args.searchParams ?? this.s.searchParams\n    }\n  }\n\n  /**\n   * @param {object} [args]\n   * @param {Record<string, any>} [args.qParams]\n   * @param {string[]} [args.searchParams]\n   * @returns {Promise<void>}\n   */\n  loadModels = async (args = {}) => {\n    // Only the newest collection request is allowed to update state after navigation/filter changes.\n    const loadModelsGeneration = this.loadModelsGeneration + 1\n    const {qParams, searchParams} = this.loadModelsArgs(args)\n\n    this.loadModelsGeneration = loadModelsGeneration\n    let query = this.p.collection?.clone() || this.p.modelClass.ransack()\n\n    if (this.p.pagination) {\n      const page = this.queryParams?.[this.queryPageName()] || 1\n      let per = this.queryParams?.[this.queryPerKey()] || 30\n\n      if (per == \"all\") {\n        per = 999_999_999\n      } else {\n        per = Number(per)\n      }\n\n      query.page(page).per(per)\n    }\n\n    if (this.p.groupBy) query = query.groupBy(...this.p.groupBy)\n\n    query = query\n      .ransack(qParams)\n      .search(searchParams)\n      .searchKey(this.queryQName())\n      .pageKey(this.queryPageName())\n      .perKey(this.queryPerKey())\n\n    if (this.p.abilities) query.abilities(this.p.abilities)\n    if (this.p.limit !== undefined) query.limit(this.p.limit)\n    if (this.p.preloads) query.preload(this.p.preloads)\n    if (this.p.ransack) query.ransack(this.p.ransack)\n    if (this.p.select) query.select(this.p.select)\n    if (this.p.selectColumns) query.selectColumns(this.p.selectColumns)\n\n    let result\n\n    if (this.p.queryMethod) {\n      result = await this.p.queryMethod({query})\n    } else {\n      result = await query.result()\n    }\n\n    const models = result.models()\n\n    if (loadModelsGeneration != this.loadModelsGeneration) return\n\n    if (this.p.onModelsLoaded) {\n      this.p.onModelsLoaded({\n        models,\n        qParams: this.s.qParams,\n        query,\n        result\n      })\n    }\n\n    this.setState({\n      models,\n      query,\n      result,\n      showNoRecordsAvailableContent: this.showNoRecordsAvailableContent({models}),\n      showNoRecordsFoundContent: this.showNoRecordsFoundContent({models})\n    })\n  }\n\n  /** @param {{model: import(\"./base-model.js\").default}} args */\n  onModelDestroyed(args) {\n    const destroyedModel = digg(args, \"model\")\n\n    this.setState({\n      models: this.s.models.filter((model) => model.id() != destroyedModel.id())\n    })\n  }\n\n  /** @param {{model: import(\"./base-model.js\").default}} args */\n  onModelUpdated(args) {\n    const updatedModel = digg(args, \"model\")\n    const foundModel = this.s.models.find((model) => model.id() == updatedModel.id())\n\n    if (foundModel) this.loadModelsDebounce()()\n  }\n\n  /** @returns {void} */\n  onCreated() {\n    this.loadModelsDebounce()()\n  }\n\n  /** @returns {void} */\n  componentDidMount() {\n    this.setState({readyToLoad: true})\n  }\n\n  /** @returns {void} */\n  setup() {\n    this.useStates({\n      models: undefined,\n      overallCount: undefined,\n      qParams: {},\n      query: undefined,\n      readyToLoad: false,\n      result: undefined,\n      searchParams: undefined,\n      showNoRecordsAvailableContent: false,\n      showNoRecordsFoundContent: false\n    })\n    this.setInstance({queryParams: useQueryParams()})\n\n    // Wait until componentDidMount has flipped readyToLoad so the first load runs after useShapeHook has marked the hook mounted.\n    useEffect(\n      () => {\n        if (!this.s.readyToLoad) return\n        let ifConditionMet\n\n        if (typeof this.p.ifCondition == \"function\") {\n          ifConditionMet = this.p.ifCondition()\n        } else if (this.p.ifCondition === undefined) {\n          ifConditionMet = true\n        } else {\n          ifConditionMet = this.p.ifCondition\n        }\n\n        if (ifConditionMet) {\n          const {qParams, searchParams} = this.loadQParams()\n\n          this.loadModels({qParams, searchParams})\n        }\n      },\n      [\n        this.p.modelClass,\n        this.p.ifCondition,\n        this.queryName(),\n        this.queryParams?.[this.queryQName()],\n        this.queryParams?.[this.queryPageName()],\n        this.queryParams?.[this.queryPerKey()],\n        this.queryParams?.[this.querySName()],\n        this.s.readyToLoad,\n        this.p.collection\n      ].concat(this.p.cacheKeys)\n    )\n\n    useEffect(() => {\n      if (!this.s.readyToLoad) return\n      if (this.p.noRecordsAvailableContent) {\n        this.loadOverallCount()\n      }\n    }, [this.p.modelClass, this.s.readyToLoad])\n\n    useCreatedEvent(this.p.modelClass, () => this.onCreated())\n\n    // Invalidate any in-flight async responses so unmounted hooks cannot write stale state.\n    useEffect(() => () => {\n      this.loadModelsGeneration += 1\n      this.loadOverallCountGeneration += 1\n      this.loadModelsDebounce().clear?.()\n    }, [])\n\n    useEffect(() => {\n      const connections = []\n\n      if (this.s.models) {\n        for (const model of this.s.models) {\n          connections.push(ModelEvents.connectUpdated(model, (args) => this.onModelUpdated(args)))\n          connections.push(ModelEvents.connectDestroyed(model, (args) => this.onModelDestroyed(args)))\n        }\n      }\n\n      return () => {\n        for (const connection of connections) {\n          connection.unsubscribe()\n        }\n      }\n    }, [this.modelIdsCacheString()])\n  }\n}\n\nconst useCollection = (props, cacheKeys = []) => {\n  const {\n    abilities,\n    collection,\n    defaultParams,\n    groupBy,\n    ifCondition,\n    limit,\n    modelClass,\n    noRecordsAvailableContent = undefined,\n    noRecordsFoundContent = undefined,\n    onModelsLoaded,\n    pagination = false,\n    preloads = [],\n    queryMethod,\n    queryName,\n    ransack,\n    select = {},\n    selectColumns,\n    ...restProps\n  } = props\n\n  if (Object.keys(restProps).length > 0) {\n    throw new Error(`Unknown props given to useCollection: ${Object.keys(restProps).join(\", \")}`)\n  }\n\n  const shapeHook = useShapeHook(UseCollectionShapeHook, {\n    abilities,\n    cacheKeys,\n    collection,\n    defaultParams,\n    groupBy,\n    ifCondition,\n    limit,\n    modelClass,\n    noRecordsAvailableContent,\n    noRecordsFoundContent,\n    onModelsLoaded,\n    pagination,\n    preloads,\n    queryMethod,\n    queryName,\n    ransack,\n    select,\n    selectColumns\n  })\n  const result = /** @type {UseCollectionResult & Record<string, any>} */ (Object.assign({}, shapeHook.state))\n  const modelVariableName = inflection.pluralize(inflection.camelize(shapeHook.p.modelClass.modelClassData().name, true))\n\n  result.modelIdsCacheString = shapeHook.modelIdsCacheString()\n  result.queryName = shapeHook.queryName()\n  result.queryPerKey = shapeHook.queryPerKey()\n  result.queryQName = shapeHook.queryQName()\n  result.querySName = shapeHook.querySName()\n  result.queryPageName = shapeHook.queryPageName()\n  result[modelVariableName] = shapeHook.s.models\n\n  return result\n}\n\nexport default useCollection\n"]}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@kaspernj/api-maker",
3
3
  "type": "module",
4
- "version": "1.0.2129",
4
+ "version": "1.0.2131",
5
5
  "description": "My new module",
6
6
  "files": [
7
7
  "build/**"