@cedarjs/web 0.0.4
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/LICENSE +21 -0
- package/README.md +33 -0
- package/apollo/index.js +2 -0
- package/apollo/package.json +4 -0
- package/dist/apollo/fragmentRegistry.d.ts +43 -0
- package/dist/apollo/fragmentRegistry.d.ts.map +1 -0
- package/dist/apollo/fragmentRegistry.js +39 -0
- package/dist/apollo/index.d.ts +77 -0
- package/dist/apollo/index.d.ts.map +1 -0
- package/dist/apollo/index.js +198 -0
- package/dist/apollo/links.d.ts +27 -0
- package/dist/apollo/links.d.ts.map +1 -0
- package/dist/apollo/links.js +94 -0
- package/dist/apollo/sseLink.d.ts +29 -0
- package/dist/apollo/sseLink.d.ts.map +1 -0
- package/dist/apollo/sseLink.js +94 -0
- package/dist/apollo/suspense.d.ts +59 -0
- package/dist/apollo/suspense.d.ts.map +1 -0
- package/dist/apollo/suspense.js +113 -0
- package/dist/apollo/typeOverride.d.ts +21 -0
- package/dist/apollo/typeOverride.d.ts.map +1 -0
- package/dist/apollo/typeOverride.js +0 -0
- package/dist/apollo/useCache.d.ts +22 -0
- package/dist/apollo/useCache.d.ts.map +1 -0
- package/dist/apollo/useCache.js +25 -0
- package/dist/bins/cross-env.d.ts +3 -0
- package/dist/bins/cross-env.d.ts.map +1 -0
- package/dist/bins/msw.d.ts +3 -0
- package/dist/bins/msw.d.ts.map +1 -0
- package/dist/bins/redwood.d.ts +9 -0
- package/dist/bins/redwood.d.ts.map +1 -0
- package/dist/bins/rwfw.d.ts +3 -0
- package/dist/bins/rwfw.d.ts.map +1 -0
- package/dist/bins/storybook.d.ts +3 -0
- package/dist/bins/storybook.d.ts.map +1 -0
- package/dist/bins/tsc.d.ts +3 -0
- package/dist/bins/tsc.d.ts.map +1 -0
- package/dist/bundled/apollo-upload-client.d.ts +3 -0
- package/dist/bundled/apollo-upload-client.d.ts.map +1 -0
- package/dist/bundled/apollo-upload-client.js +4 -0
- package/dist/cjs/apollo/fragmentRegistry.d.ts +43 -0
- package/dist/cjs/apollo/fragmentRegistry.d.ts.map +1 -0
- package/dist/cjs/apollo/fragmentRegistry.js +75 -0
- package/dist/cjs/apollo/index.d.ts +77 -0
- package/dist/cjs/apollo/index.d.ts.map +1 -0
- package/dist/cjs/apollo/index.js +216 -0
- package/dist/cjs/apollo/links.d.ts +27 -0
- package/dist/cjs/apollo/links.d.ts.map +1 -0
- package/dist/cjs/apollo/links.js +122 -0
- package/dist/cjs/apollo/sseLink.d.ts +29 -0
- package/dist/cjs/apollo/sseLink.d.ts.map +1 -0
- package/dist/cjs/apollo/sseLink.js +120 -0
- package/dist/cjs/apollo/suspense.d.ts +59 -0
- package/dist/cjs/apollo/suspense.d.ts.map +1 -0
- package/dist/cjs/apollo/suspense.js +127 -0
- package/dist/cjs/apollo/typeOverride.d.ts +21 -0
- package/dist/cjs/apollo/typeOverride.d.ts.map +1 -0
- package/dist/cjs/apollo/typeOverride.js +16 -0
- package/dist/cjs/apollo/useCache.d.ts +22 -0
- package/dist/cjs/apollo/useCache.d.ts.map +1 -0
- package/dist/cjs/apollo/useCache.js +49 -0
- package/dist/cjs/bins/cross-env.d.ts +3 -0
- package/dist/cjs/bins/cross-env.d.ts.map +1 -0
- package/dist/cjs/bins/cross-env.js +30 -0
- package/dist/cjs/bins/msw.d.ts +3 -0
- package/dist/cjs/bins/msw.d.ts.map +1 -0
- package/dist/cjs/bins/msw.js +28 -0
- package/dist/cjs/bins/redwood.d.ts +9 -0
- package/dist/cjs/bins/redwood.d.ts.map +1 -0
- package/dist/cjs/bins/redwood.js +36 -0
- package/dist/cjs/bins/rwfw.d.ts +3 -0
- package/dist/cjs/bins/rwfw.d.ts.map +1 -0
- package/dist/cjs/bins/rwfw.js +36 -0
- package/dist/cjs/bins/storybook.d.ts +3 -0
- package/dist/cjs/bins/storybook.d.ts.map +1 -0
- package/dist/cjs/bins/storybook.js +49 -0
- package/dist/cjs/bins/tsc.d.ts +3 -0
- package/dist/cjs/bins/tsc.d.ts.map +1 -0
- package/dist/cjs/bins/tsc.js +30 -0
- package/dist/cjs/bundled/apollo-upload-client.d.ts +3 -0
- package/dist/cjs/bundled/apollo-upload-client.d.ts.map +1 -0
- package/dist/cjs/bundled/apollo-upload-client.js +2474 -0
- package/dist/cjs/components/DevFatalErrorPage.d.ts +21 -0
- package/dist/cjs/components/DevFatalErrorPage.d.ts.map +1 -0
- package/dist/cjs/components/DevFatalErrorPage.js +436 -0
- package/dist/cjs/components/FatalErrorBoundary.d.ts +24 -0
- package/dist/cjs/components/FatalErrorBoundary.d.ts.map +1 -0
- package/dist/cjs/components/FatalErrorBoundary.js +63 -0
- package/dist/cjs/components/FetchConfigProvider.d.ts +25 -0
- package/dist/cjs/components/FetchConfigProvider.d.ts.map +1 -0
- package/dist/cjs/components/FetchConfigProvider.js +80 -0
- package/dist/cjs/components/GraphQLHooksProvider.d.ts +45 -0
- package/dist/cjs/components/GraphQLHooksProvider.d.ts.map +1 -0
- package/dist/cjs/components/GraphQLHooksProvider.js +135 -0
- package/dist/cjs/components/MetaTags.d.ts +52 -0
- package/dist/cjs/components/MetaTags.d.ts.map +1 -0
- package/dist/cjs/components/MetaTags.js +69 -0
- package/dist/cjs/components/Metadata.d.ts +9 -0
- package/dist/cjs/components/Metadata.d.ts.map +1 -0
- package/dist/cjs/components/Metadata.js +95 -0
- package/dist/cjs/components/PortalHead.d.ts +4 -0
- package/dist/cjs/components/PortalHead.d.ts.map +1 -0
- package/dist/cjs/components/PortalHead.js +59 -0
- package/dist/cjs/components/RedwoodProvider.d.ts +9 -0
- package/dist/cjs/components/RedwoodProvider.d.ts.map +1 -0
- package/dist/cjs/components/RedwoodProvider.js +58 -0
- package/dist/cjs/components/ServerInject.d.ts +26 -0
- package/dist/cjs/components/ServerInject.d.ts.map +1 -0
- package/dist/cjs/components/ServerInject.js +75 -0
- package/dist/cjs/components/cell/CellCacheContext.d.ts +20 -0
- package/dist/cjs/components/cell/CellCacheContext.d.ts.map +1 -0
- package/dist/cjs/components/cell/CellCacheContext.js +53 -0
- package/dist/cjs/components/cell/CellErrorBoundary.d.ts +25 -0
- package/dist/cjs/components/cell/CellErrorBoundary.d.ts.map +1 -0
- package/dist/cjs/components/cell/CellErrorBoundary.js +66 -0
- package/dist/cjs/components/cell/cellTypes.d.ts +152 -0
- package/dist/cjs/components/cell/cellTypes.d.ts.map +1 -0
- package/dist/cjs/components/cell/cellTypes.js +16 -0
- package/dist/cjs/components/cell/createCell.d.ts +10 -0
- package/dist/cjs/components/cell/createCell.d.ts.map +1 -0
- package/dist/cjs/components/cell/createCell.js +165 -0
- package/dist/cjs/components/cell/createCell.test.js +351 -0
- package/dist/cjs/components/cell/createServerCell.d.ts +15 -0
- package/dist/cjs/components/cell/createServerCell.d.ts.map +1 -0
- package/dist/cjs/components/cell/createServerCell.js +91 -0
- package/dist/cjs/components/cell/createSuspendingCell.d.ts +11 -0
- package/dist/cjs/components/cell/createSuspendingCell.d.ts.map +1 -0
- package/dist/cjs/components/cell/createSuspendingCell.js +152 -0
- package/dist/cjs/components/cell/createSuspendingCell.test.js +115 -0
- package/dist/cjs/components/cell/isCellEmpty.d.ts +41 -0
- package/dist/cjs/components/cell/isCellEmpty.d.ts.map +1 -0
- package/dist/cjs/components/cell/isCellEmpty.js +35 -0
- package/dist/cjs/components/htmlTags.d.ts +52 -0
- package/dist/cjs/components/htmlTags.d.ts.map +1 -0
- package/dist/cjs/components/htmlTags.js +88 -0
- package/dist/cjs/config.d.ts +2 -0
- package/dist/cjs/config.d.ts.map +1 -0
- package/dist/cjs/config.js +6 -0
- package/dist/cjs/entry/index.js +39 -0
- package/dist/cjs/global.web-auto-imports.d.ts +30 -0
- package/dist/cjs/global.web-auto-imports.d.ts.map +1 -0
- package/dist/cjs/global.web-auto-imports.js +16 -0
- package/dist/cjs/graphql.d.ts +24 -0
- package/dist/cjs/graphql.d.ts.map +1 -0
- package/dist/cjs/graphql.js +36 -0
- package/dist/cjs/index.d.ts +20 -0
- package/dist/cjs/index.d.ts.map +1 -0
- package/dist/cjs/index.js +80 -0
- package/dist/cjs/package.json +1 -0
- package/dist/cjs/routeHooks.types.d.ts +12 -0
- package/dist/cjs/routeHooks.types.d.ts.map +1 -0
- package/dist/cjs/routeHooks.types.js +16 -0
- package/dist/cjs/server/MiddlewareRequest.d.ts +28 -0
- package/dist/cjs/server/MiddlewareRequest.d.ts.map +1 -0
- package/dist/cjs/server/MiddlewareRequest.js +71 -0
- package/dist/cjs/server/MiddlewareResponse.d.ts +44 -0
- package/dist/cjs/server/MiddlewareResponse.d.ts.map +1 -0
- package/dist/cjs/server/MiddlewareResponse.js +130 -0
- package/dist/cjs/server/middleware.d.ts +17 -0
- package/dist/cjs/server/middleware.d.ts.map +1 -0
- package/dist/cjs/server/middleware.js +24 -0
- package/dist/cjs/server/request.d.ts +2 -0
- package/dist/cjs/server/request.d.ts.map +1 -0
- package/dist/cjs/server/request.js +34 -0
- package/dist/cjs/streamUtils/useDocumentReady.d.ts +11 -0
- package/dist/cjs/streamUtils/useDocumentReady.d.ts.map +1 -0
- package/dist/cjs/streamUtils/useDocumentReady.js +41 -0
- package/dist/cjs/toast/index.d.ts +3 -0
- package/dist/cjs/toast/index.d.ts.map +1 -0
- package/dist/cjs/toast/index.js +41 -0
- package/dist/components/DevFatalErrorPage.d.ts +21 -0
- package/dist/components/DevFatalErrorPage.d.ts.map +1 -0
- package/dist/components/DevFatalErrorPage.js +402 -0
- package/dist/components/FatalErrorBoundary.d.ts +24 -0
- package/dist/components/FatalErrorBoundary.d.ts.map +1 -0
- package/dist/components/FatalErrorBoundary.js +29 -0
- package/dist/components/FetchConfigProvider.d.ts +25 -0
- package/dist/components/FetchConfigProvider.d.ts.map +1 -0
- package/dist/components/FetchConfigProvider.js +43 -0
- package/dist/components/GraphQLHooksProvider.d.ts +45 -0
- package/dist/components/GraphQLHooksProvider.d.ts.map +1 -0
- package/dist/components/GraphQLHooksProvider.js +94 -0
- package/dist/components/MetaTags.d.ts +52 -0
- package/dist/components/MetaTags.d.ts.map +1 -0
- package/dist/components/MetaTags.js +35 -0
- package/dist/components/Metadata.d.ts +9 -0
- package/dist/components/Metadata.d.ts.map +1 -0
- package/dist/components/Metadata.js +61 -0
- package/dist/components/PortalHead.d.ts +4 -0
- package/dist/components/PortalHead.d.ts.map +1 -0
- package/dist/components/PortalHead.js +29 -0
- package/dist/components/RedwoodProvider.d.ts +9 -0
- package/dist/components/RedwoodProvider.d.ts.map +1 -0
- package/dist/components/RedwoodProvider.js +24 -0
- package/dist/components/ServerInject.d.ts +26 -0
- package/dist/components/ServerInject.d.ts.map +1 -0
- package/dist/components/ServerInject.js +37 -0
- package/dist/components/cell/CellCacheContext.d.ts +20 -0
- package/dist/components/cell/CellCacheContext.d.ts.map +1 -0
- package/dist/components/cell/CellCacheContext.js +18 -0
- package/dist/components/cell/CellErrorBoundary.d.ts +25 -0
- package/dist/components/cell/CellErrorBoundary.d.ts.map +1 -0
- package/dist/components/cell/CellErrorBoundary.js +32 -0
- package/dist/components/cell/cellTypes.d.ts +152 -0
- package/dist/components/cell/cellTypes.d.ts.map +1 -0
- package/dist/components/cell/cellTypes.js +0 -0
- package/dist/components/cell/createCell.d.ts +10 -0
- package/dist/components/cell/createCell.d.ts.map +1 -0
- package/dist/components/cell/createCell.js +131 -0
- package/dist/components/cell/createCell.test.js +328 -0
- package/dist/components/cell/createServerCell.d.ts +15 -0
- package/dist/components/cell/createServerCell.d.ts.map +1 -0
- package/dist/components/cell/createServerCell.js +57 -0
- package/dist/components/cell/createSuspendingCell.d.ts +11 -0
- package/dist/components/cell/createSuspendingCell.d.ts.map +1 -0
- package/dist/components/cell/createSuspendingCell.js +118 -0
- package/dist/components/cell/createSuspendingCell.test.js +92 -0
- package/dist/components/cell/isCellEmpty.d.ts +41 -0
- package/dist/components/cell/isCellEmpty.d.ts.map +1 -0
- package/dist/components/cell/isCellEmpty.js +11 -0
- package/dist/components/htmlTags.d.ts +52 -0
- package/dist/components/htmlTags.d.ts.map +1 -0
- package/dist/components/htmlTags.js +53 -0
- package/dist/config.d.ts +2 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +5 -0
- package/dist/entry/index.d.ts +1 -0
- package/dist/entry/index.js +16 -0
- package/dist/global.web-auto-imports.d.ts +30 -0
- package/dist/global.web-auto-imports.d.ts.map +1 -0
- package/dist/global.web-auto-imports.js +0 -0
- package/dist/graphql.d.ts +24 -0
- package/dist/graphql.d.ts.map +1 -0
- package/dist/graphql.js +12 -0
- package/dist/index.d.ts +20 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +36 -0
- package/dist/package.json +1 -0
- package/dist/routeHooks.types.d.ts +12 -0
- package/dist/routeHooks.types.d.ts.map +1 -0
- package/dist/routeHooks.types.js +0 -0
- package/dist/server/MiddlewareRequest.d.ts +28 -0
- package/dist/server/MiddlewareRequest.d.ts.map +1 -0
- package/dist/server/MiddlewareRequest.js +46 -0
- package/dist/server/MiddlewareResponse.d.ts +44 -0
- package/dist/server/MiddlewareResponse.d.ts.map +1 -0
- package/dist/server/MiddlewareResponse.js +95 -0
- package/dist/server/middleware.d.ts +17 -0
- package/dist/server/middleware.d.ts.map +1 -0
- package/dist/server/middleware.js +2 -0
- package/dist/server/request.d.ts +2 -0
- package/dist/server/request.d.ts.map +1 -0
- package/dist/server/request.js +12 -0
- package/dist/streamUtils/useDocumentReady.d.ts +11 -0
- package/dist/streamUtils/useDocumentReady.d.ts.map +1 -0
- package/dist/streamUtils/useDocumentReady.js +17 -0
- package/dist/toast/index.d.ts +3 -0
- package/dist/toast/index.d.ts.map +1 -0
- package/dist/toast/index.js +5 -0
- package/package.json +193 -0
- package/src/entry/index.jsx +29 -0
- package/toast/index.js +2 -0
- package/toast/package.json +4 -0
|
@@ -0,0 +1,351 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __copyProps = (to, from, except, desc) => {
|
|
9
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
10
|
+
for (let key of __getOwnPropNames(from))
|
|
11
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
12
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
13
|
+
}
|
|
14
|
+
return to;
|
|
15
|
+
};
|
|
16
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
17
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
18
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
19
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
20
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
21
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
22
|
+
mod
|
|
23
|
+
));
|
|
24
|
+
var import_react = __toESM(require("react"), 1);
|
|
25
|
+
var import_react2 = require("@testing-library/react");
|
|
26
|
+
var import_vitest = require("vitest");
|
|
27
|
+
var import_GraphQLHooksProvider = require("../GraphQLHooksProvider.js");
|
|
28
|
+
var import_createCell = require("./createCell.js");
|
|
29
|
+
(0, import_vitest.describe)("createCell", () => {
|
|
30
|
+
(0, import_vitest.beforeAll)(() => {
|
|
31
|
+
globalThis.RWJS_ENV = {
|
|
32
|
+
RWJS_EXP_STREAMING_SSR: false
|
|
33
|
+
};
|
|
34
|
+
});
|
|
35
|
+
(0, import_vitest.test)("Renders a static Success component", () => {
|
|
36
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
37
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
38
|
+
QUERY: "query TestQuery { answer }",
|
|
39
|
+
Success: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Great success!")
|
|
40
|
+
});
|
|
41
|
+
const myUseQueryHook = () => ({ data: {} });
|
|
42
|
+
(0, import_react2.render)(
|
|
43
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null))
|
|
44
|
+
);
|
|
45
|
+
import_react2.screen.getByText(/^Great success!$/);
|
|
46
|
+
});
|
|
47
|
+
(0, import_vitest.test)("Renders Success with data", () => {
|
|
48
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
49
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
50
|
+
QUERY: "query TestQuery { answer }",
|
|
51
|
+
Success: ({ answer }) => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement("dl", null, /* @__PURE__ */ import_react.default.createElement("dt", null, "What's the meaning of life?"), /* @__PURE__ */ import_react.default.createElement("dd", null, answer)))
|
|
52
|
+
});
|
|
53
|
+
const myUseQueryHook = () => {
|
|
54
|
+
return { data: { answer: 42 } };
|
|
55
|
+
};
|
|
56
|
+
(0, import_react2.render)(
|
|
57
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null))
|
|
58
|
+
);
|
|
59
|
+
import_react2.screen.getByText(/^What's the meaning of life\?$/);
|
|
60
|
+
import_react2.screen.getByText(/^42$/);
|
|
61
|
+
});
|
|
62
|
+
(0, import_vitest.test)("Renders Success if any of the fields have data (i.e. not just the first)", () => {
|
|
63
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
64
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
65
|
+
QUERY: "query TestQuery { users { name } posts { title } }",
|
|
66
|
+
Empty: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "No users or posts"),
|
|
67
|
+
Success: ({ users, posts }) => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement("div", null, users.length > 0 ? /* @__PURE__ */ import_react.default.createElement("ul", null, users.map(({ name }) => /* @__PURE__ */ import_react.default.createElement("li", { key: name }, name))) : "no users"), /* @__PURE__ */ import_react.default.createElement("div", null, posts.length > 0 ? /* @__PURE__ */ import_react.default.createElement("ul", null, posts.map(({ title }) => /* @__PURE__ */ import_react.default.createElement("li", { key: title }, title))) : "no posts"))
|
|
68
|
+
});
|
|
69
|
+
const myUseQueryHook = () => {
|
|
70
|
+
return {
|
|
71
|
+
data: {
|
|
72
|
+
users: [],
|
|
73
|
+
posts: [{ title: "bazinga" }, { title: "kittens" }]
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
};
|
|
77
|
+
(0, import_react2.render)(
|
|
78
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null))
|
|
79
|
+
);
|
|
80
|
+
import_react2.screen.getByText(/bazinga/);
|
|
81
|
+
import_react2.screen.getByText(/kittens/);
|
|
82
|
+
});
|
|
83
|
+
(0, import_vitest.test)("Renders default Loading when there is no data", () => {
|
|
84
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
85
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
86
|
+
QUERY: "query TestQuery { answer }",
|
|
87
|
+
Success: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Great success!")
|
|
88
|
+
});
|
|
89
|
+
const myUseQueryHook = () => ({ loading: true });
|
|
90
|
+
(0, import_react2.render)(
|
|
91
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null))
|
|
92
|
+
);
|
|
93
|
+
import_react2.screen.getByText(/^Loading...$/);
|
|
94
|
+
});
|
|
95
|
+
(0, import_vitest.test)("Renders custom Loading when there is no data", () => {
|
|
96
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
97
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
98
|
+
QUERY: "query TestQuery { answer }",
|
|
99
|
+
Success: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Great success!"),
|
|
100
|
+
Loading: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Fetching answer...")
|
|
101
|
+
});
|
|
102
|
+
const myUseQueryHook = () => ({ loading: true });
|
|
103
|
+
(0, import_react2.render)(
|
|
104
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null))
|
|
105
|
+
);
|
|
106
|
+
import_react2.screen.getByText(/^Fetching answer...$/);
|
|
107
|
+
});
|
|
108
|
+
(0, import_vitest.test)("Renders Success even when `loading` is true if there is data", () => {
|
|
109
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
110
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
111
|
+
QUERY: "query TestQuery { answer }",
|
|
112
|
+
Success: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Great success!"),
|
|
113
|
+
Loading: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Fetching answer...")
|
|
114
|
+
});
|
|
115
|
+
const myUseQueryHook = () => ({ loading: true, data: {} });
|
|
116
|
+
(0, import_react2.render)(
|
|
117
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null))
|
|
118
|
+
);
|
|
119
|
+
import_react2.screen.getByText(/^Great success!$/);
|
|
120
|
+
});
|
|
121
|
+
(0, import_vitest.test)("Renders Empty if available, and data field is null", () => {
|
|
122
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
123
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
124
|
+
QUERY: "query TestQuery { answer }",
|
|
125
|
+
Success: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Great success!"),
|
|
126
|
+
Empty: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "No one knows")
|
|
127
|
+
});
|
|
128
|
+
const myUseQueryHook = () => ({ loading: true, data: { answer: null } });
|
|
129
|
+
(0, import_react2.render)(
|
|
130
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null))
|
|
131
|
+
);
|
|
132
|
+
import_react2.screen.getByText(/^No one knows$/);
|
|
133
|
+
});
|
|
134
|
+
(0, import_vitest.test)("Renders Empty if available, and data field is an empty array", () => {
|
|
135
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
136
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
137
|
+
QUERY: "query TestQuery { answers }",
|
|
138
|
+
Success: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Great success!"),
|
|
139
|
+
Empty: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "No one knows")
|
|
140
|
+
});
|
|
141
|
+
const myUseQueryHook = () => ({ loading: true, data: { answers: [] } });
|
|
142
|
+
(0, import_react2.render)(
|
|
143
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null))
|
|
144
|
+
);
|
|
145
|
+
import_react2.screen.getByText(/^No one knows$/);
|
|
146
|
+
});
|
|
147
|
+
(0, import_vitest.test)("Renders Success even if data is empty when no Empty is available", () => {
|
|
148
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
149
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
150
|
+
QUERY: "query TestQuery { answer }",
|
|
151
|
+
Success: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Empty success")
|
|
152
|
+
});
|
|
153
|
+
const myUseQueryHook = () => ({ loading: true, data: { answer: null } });
|
|
154
|
+
(0, import_react2.render)(
|
|
155
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null))
|
|
156
|
+
);
|
|
157
|
+
import_react2.screen.getByText(/^Empty success$/);
|
|
158
|
+
});
|
|
159
|
+
(0, import_vitest.test)("Allows passing children to Success", () => {
|
|
160
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
161
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
162
|
+
QUERY: "query TestQuery { answer }",
|
|
163
|
+
Success: ({ children }) => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Look at my beautiful ", children)
|
|
164
|
+
});
|
|
165
|
+
const myUseQueryHook = () => ({ data: {} });
|
|
166
|
+
(0, import_react2.render)(
|
|
167
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null, /* @__PURE__ */ import_react.default.createElement("div", null, "\u{1F986}")))
|
|
168
|
+
);
|
|
169
|
+
import_react2.screen.getByText(/^Look at my beautiful$/);
|
|
170
|
+
import_react2.screen.getByText(/^🦆$/);
|
|
171
|
+
});
|
|
172
|
+
(0, import_vitest.test)("Cell props are passed to the query as variables", () => {
|
|
173
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
174
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
175
|
+
QUERY: `query Greet($name: String!) {
|
|
176
|
+
greet(name: $name) {
|
|
177
|
+
greeting
|
|
178
|
+
}
|
|
179
|
+
}`,
|
|
180
|
+
Success: ({ greeting }) => /* @__PURE__ */ import_react.default.createElement("p", null, greeting)
|
|
181
|
+
});
|
|
182
|
+
const myUseQueryHook = (_query, options) => {
|
|
183
|
+
return { data: { greeting: `Hello ${options.variables.name}!` } };
|
|
184
|
+
};
|
|
185
|
+
(0, import_react2.render)(
|
|
186
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, { name: "Bob" }))
|
|
187
|
+
);
|
|
188
|
+
import_react2.screen.getByText(/^Hello Bob!$/);
|
|
189
|
+
});
|
|
190
|
+
(0, import_vitest.test)("Allows QUERY to be a function", () => {
|
|
191
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
192
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
193
|
+
QUERY: ({ variables }) => {
|
|
194
|
+
if (variables.character === "BEAST") {
|
|
195
|
+
return "query BeastQuery { name }";
|
|
196
|
+
}
|
|
197
|
+
return "query HeroQuery { name }";
|
|
198
|
+
},
|
|
199
|
+
Success: ({ name }) => /* @__PURE__ */ import_react.default.createElement("p", null, "Call me ", name)
|
|
200
|
+
});
|
|
201
|
+
const myUseQueryHook = (query) => {
|
|
202
|
+
if (query.includes("BeastQuery")) {
|
|
203
|
+
return { data: { name: "Boogeyman" } };
|
|
204
|
+
} else if (query.includes("HeroQuery")) {
|
|
205
|
+
return { data: { name: "Lara Croft" } };
|
|
206
|
+
}
|
|
207
|
+
return { data: { name: "John Doe" } };
|
|
208
|
+
};
|
|
209
|
+
(0, import_react2.render)(
|
|
210
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, { character: "BEAST" }), /* @__PURE__ */ import_react.default.createElement(TestCell, { character: "HERO" }))
|
|
211
|
+
);
|
|
212
|
+
import_react2.screen.getByText(/^Call me Boogeyman$/);
|
|
213
|
+
import_react2.screen.getByText(/^Call me Lara Croft$/);
|
|
214
|
+
});
|
|
215
|
+
(0, import_vitest.test)("Renders Failure when there is an error", () => {
|
|
216
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
217
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
218
|
+
QUERY: "query TestQuery { answer }",
|
|
219
|
+
Failure: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Sad face :("),
|
|
220
|
+
Success: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Great success!"),
|
|
221
|
+
Loading: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Fetching answer...")
|
|
222
|
+
});
|
|
223
|
+
const myUseQueryHook = () => ({ error: true });
|
|
224
|
+
(0, import_react2.render)(
|
|
225
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null))
|
|
226
|
+
);
|
|
227
|
+
import_react2.screen.getByText(/^Sad face :\($/);
|
|
228
|
+
});
|
|
229
|
+
(0, import_vitest.test)("Passes error to Failure component", () => {
|
|
230
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
231
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
232
|
+
QUERY: "query TestQuery { answer }",
|
|
233
|
+
Failure: ({ error }) => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, JSON.stringify(error)),
|
|
234
|
+
Success: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Great success!"),
|
|
235
|
+
Loading: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Fetching answer...")
|
|
236
|
+
});
|
|
237
|
+
const myUseQueryHook = () => ({ error: { msg: "System malfunction" } });
|
|
238
|
+
(0, import_react2.render)(
|
|
239
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null))
|
|
240
|
+
);
|
|
241
|
+
import_react2.screen.getByText(/^{"msg":"System malfunction"}$/);
|
|
242
|
+
});
|
|
243
|
+
(0, import_vitest.test)("Passes error and errorCode to Failure component", () => {
|
|
244
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
245
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
246
|
+
QUERY: "query TestQuery { answer }",
|
|
247
|
+
Failure: ({ error, errorCode }) => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, JSON.stringify(error), ",code:", errorCode),
|
|
248
|
+
Success: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Great success!"),
|
|
249
|
+
Loading: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Fetching answer...")
|
|
250
|
+
});
|
|
251
|
+
const myUseQueryHook = () => ({
|
|
252
|
+
error: { msg: "System malfunction" },
|
|
253
|
+
errorCode: "SIMON_SAYS_NO"
|
|
254
|
+
});
|
|
255
|
+
(0, import_react2.render)(
|
|
256
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null))
|
|
257
|
+
);
|
|
258
|
+
import_react2.screen.getByText(/^{"msg":"System malfunction"},code:SIMON_SAYS_NO$/);
|
|
259
|
+
});
|
|
260
|
+
(0, import_vitest.test)("Passes children to Failure", () => {
|
|
261
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
262
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
263
|
+
QUERY: "query TestQuery { answer }",
|
|
264
|
+
Failure: ({ children }) => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "I'm a failure ", children)
|
|
265
|
+
});
|
|
266
|
+
const myUseQueryHook = () => ({ error: {} });
|
|
267
|
+
(0, import_react2.render)(
|
|
268
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null, /* @__PURE__ */ import_react.default.createElement("div", null, "Child")))
|
|
269
|
+
);
|
|
270
|
+
import_react2.screen.getByText(/^I'm a failure$/);
|
|
271
|
+
import_react2.screen.getByText(/^Child$/);
|
|
272
|
+
});
|
|
273
|
+
(0, import_vitest.test)("Throws an error when there is an error if no Failure component exists", () => {
|
|
274
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
275
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
276
|
+
QUERY: "query TestQuery { answer }",
|
|
277
|
+
Success: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Great success!"),
|
|
278
|
+
Loading: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Fetching answer...")
|
|
279
|
+
});
|
|
280
|
+
const myUseQueryHook = () => ({ error: { message: "200 GraphQL" } });
|
|
281
|
+
const err = console.error;
|
|
282
|
+
console.error = import_vitest.vi.fn();
|
|
283
|
+
let error;
|
|
284
|
+
try {
|
|
285
|
+
(0, import_react2.render)(
|
|
286
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null))
|
|
287
|
+
);
|
|
288
|
+
} catch (e) {
|
|
289
|
+
error = e;
|
|
290
|
+
}
|
|
291
|
+
(0, import_vitest.expect)(error.message).toEqual("200 GraphQL");
|
|
292
|
+
console.error = err;
|
|
293
|
+
});
|
|
294
|
+
(0, import_vitest.test)("Allows overriding of default isDataEmpty", () => {
|
|
295
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
296
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
297
|
+
QUERY: "query TestQuery { answer }",
|
|
298
|
+
Success: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Great success!"),
|
|
299
|
+
Empty: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Got nothing"),
|
|
300
|
+
isEmpty: () => true
|
|
301
|
+
});
|
|
302
|
+
const myUseQueryHook = () => ({
|
|
303
|
+
data: {},
|
|
304
|
+
loading: false
|
|
305
|
+
});
|
|
306
|
+
(0, import_react2.render)(
|
|
307
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null))
|
|
308
|
+
);
|
|
309
|
+
import_react2.screen.getByText(/^Got nothing$/);
|
|
310
|
+
});
|
|
311
|
+
(0, import_vitest.test)("Allows mixing isDataEmpty with custom logic", () => {
|
|
312
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
313
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
314
|
+
QUERY: "query TestQuery { answer }",
|
|
315
|
+
Success: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Great success!"),
|
|
316
|
+
Empty: () => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "Got nothing"),
|
|
317
|
+
isEmpty: (data, { isDataEmpty }) => isDataEmpty(data) || data.answer === "0"
|
|
318
|
+
});
|
|
319
|
+
const myUseQueryHook = () => ({
|
|
320
|
+
data: { answer: "0" },
|
|
321
|
+
loading: false
|
|
322
|
+
});
|
|
323
|
+
(0, import_react2.render)(
|
|
324
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null))
|
|
325
|
+
);
|
|
326
|
+
import_react2.screen.getByText(/^Got nothing$/);
|
|
327
|
+
});
|
|
328
|
+
(0, import_vitest.test)("Allows overriding variables in beforeQuery", () => {
|
|
329
|
+
const TestCell = (0, import_createCell.createCell)({
|
|
330
|
+
// @ts-expect-error - Purposefully using a plain string here.
|
|
331
|
+
QUERY: `query Greet($name: String!) {
|
|
332
|
+
greet(name: $name) {
|
|
333
|
+
greeting
|
|
334
|
+
}
|
|
335
|
+
}`,
|
|
336
|
+
Success: ({ greeting }) => /* @__PURE__ */ import_react.default.createElement("p", null, greeting),
|
|
337
|
+
beforeQuery: () => ({
|
|
338
|
+
variables: {
|
|
339
|
+
name: "Bob"
|
|
340
|
+
}
|
|
341
|
+
})
|
|
342
|
+
});
|
|
343
|
+
const myUseQueryHook = (_query, options) => {
|
|
344
|
+
return { data: { greeting: `Hello ${options.variables.name}!` } };
|
|
345
|
+
};
|
|
346
|
+
(0, import_react2.render)(
|
|
347
|
+
/* @__PURE__ */ import_react.default.createElement(import_GraphQLHooksProvider.GraphQLHooksProvider, { useQuery: myUseQueryHook, useMutation: null }, /* @__PURE__ */ import_react.default.createElement(TestCell, null))
|
|
348
|
+
);
|
|
349
|
+
import_react2.screen.getByText(/^Hello Bob!$/);
|
|
350
|
+
});
|
|
351
|
+
});
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { CreateCellProps } from './cellTypes.js';
|
|
3
|
+
type CreateServerCellProps<CellProps, CellVariables> = Omit<CreateCellProps<CellProps, CellVariables>, 'QUERY' | 'Failure'> & {
|
|
4
|
+
data: (variables?: AnyObj) => any;
|
|
5
|
+
Failure?: React.ComponentType<{
|
|
6
|
+
error: unknown;
|
|
7
|
+
queryResult: {
|
|
8
|
+
refetch: (variables: CellProps) => AnyObj;
|
|
9
|
+
};
|
|
10
|
+
}>;
|
|
11
|
+
};
|
|
12
|
+
type AnyObj = Record<string, unknown>;
|
|
13
|
+
export declare function createServerCell<CellProps extends AnyObj, CellVariables extends AnyObj>(createCellProps: CreateServerCellProps<CellProps, CellVariables>): React.FC<CellProps>;
|
|
14
|
+
export {};
|
|
15
|
+
//# sourceMappingURL=createServerCell.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createServerCell.d.ts","sourceRoot":"","sources":["../../../../src/components/cell/createServerCell.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAmB,MAAM,OAAO,CAAA;AAMvC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAA;AAIrD,KAAK,qBAAqB,CAAC,SAAS,EAAE,aAAa,IAAI,IAAI,CACzD,eAAe,CAAC,SAAS,EAAE,aAAa,CAAC,EACzC,OAAO,GAAG,SAAS,CACpB,GAAG;IACF,IAAI,EAAE,CAAC,SAAS,CAAC,EAAE,MAAM,KAAK,GAAG,CAAA;IACjC,OAAO,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;QAC5B,KAAK,EAAE,OAAO,CAAA;QACd,WAAW,EAAE;YAAE,OAAO,EAAE,CAAC,SAAS,EAAE,SAAS,KAAK,MAAM,CAAA;SAAE,CAAA;KAC3D,CAAC,CAAA;CACH,CAAA;AAED,KAAK,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;AAErC,wBAAgB,gBAAgB,CAC9B,SAAS,SAAS,MAAM,EACxB,aAAa,SAAS,MAAM,EAE5B,eAAe,EAAE,qBAAqB,CAAC,SAAS,EAAE,aAAa,CAAC,GAC/D,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,CA2ErB"}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
+
var createServerCell_exports = {};
|
|
30
|
+
__export(createServerCell_exports, {
|
|
31
|
+
createServerCell: () => createServerCell
|
|
32
|
+
});
|
|
33
|
+
module.exports = __toCommonJS(createServerCell_exports);
|
|
34
|
+
var import_react = __toESM(require("react"), 1);
|
|
35
|
+
var import_isCellEmpty = require("./isCellEmpty.js");
|
|
36
|
+
function createServerCell(createCellProps) {
|
|
37
|
+
const {
|
|
38
|
+
data: dataFn,
|
|
39
|
+
isEmpty = import_isCellEmpty.isDataEmpty,
|
|
40
|
+
Loading,
|
|
41
|
+
Failure,
|
|
42
|
+
Empty,
|
|
43
|
+
Success,
|
|
44
|
+
displayName = "Cell"
|
|
45
|
+
} = createCellProps;
|
|
46
|
+
async function SuspendingSuccess(props) {
|
|
47
|
+
const { children: _, ...variables } = props;
|
|
48
|
+
const FailureComponent = ({ error }) => {
|
|
49
|
+
if (!Failure) {
|
|
50
|
+
throw error;
|
|
51
|
+
}
|
|
52
|
+
const queryResultWithRefetch = {
|
|
53
|
+
refetch: (variables2) => {
|
|
54
|
+
return dataFn(variables2);
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
return /* @__PURE__ */ import_react.default.createElement(Failure, { error, queryResult: queryResultWithRefetch });
|
|
58
|
+
};
|
|
59
|
+
try {
|
|
60
|
+
const data = await dataFn(variables);
|
|
61
|
+
if (isEmpty(data, { isDataEmpty: import_isCellEmpty.isDataEmpty }) && Empty) {
|
|
62
|
+
return /* @__PURE__ */ import_react.default.createElement(Empty, { ...props, ...data });
|
|
63
|
+
}
|
|
64
|
+
return /* @__PURE__ */ import_react.default.createElement(Success, { ...data, ...props });
|
|
65
|
+
} catch (error) {
|
|
66
|
+
return /* @__PURE__ */ import_react.default.createElement(FailureComponent, { error });
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
SuspendingSuccess.displayName = displayName;
|
|
70
|
+
return (props) => {
|
|
71
|
+
const wrapInSuspenseIfLoadingPresent = (suspendingSuccessElement, LoadingComponent) => {
|
|
72
|
+
if (!LoadingComponent) {
|
|
73
|
+
return suspendingSuccessElement;
|
|
74
|
+
}
|
|
75
|
+
return /* @__PURE__ */ import_react.default.createElement(import_react.Suspense, { fallback: /* @__PURE__ */ import_react.default.createElement(LoadingComponent, { ...props }) }, suspendingSuccessElement);
|
|
76
|
+
};
|
|
77
|
+
return (
|
|
78
|
+
// TODO(RSC): Do we always want a client side error boundary? If so, this
|
|
79
|
+
// is where we'd add it
|
|
80
|
+
// <CellErrorBoundary renderFallback={FailureComponent}>
|
|
81
|
+
/* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, wrapInSuspenseIfLoadingPresent(
|
|
82
|
+
/* @__PURE__ */ import_react.default.createElement(SuspendingSuccess, { ...props }),
|
|
83
|
+
Loading
|
|
84
|
+
))
|
|
85
|
+
);
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
89
|
+
0 && (module.exports = {
|
|
90
|
+
createServerCell
|
|
91
|
+
});
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { CreateCellProps } from './cellTypes.js';
|
|
3
|
+
type AnyObj = Record<string, unknown>;
|
|
4
|
+
/**
|
|
5
|
+
* Creates a Cell ~~ with Apollo Client only ~~
|
|
6
|
+
* using the hooks useBackgroundQuery and useReadQuery
|
|
7
|
+
*
|
|
8
|
+
*/
|
|
9
|
+
export declare function createSuspendingCell<CellProps extends AnyObj, CellVariables extends AnyObj>(createCellProps: CreateCellProps<AnyObj, CellVariables>): React.FC<CellProps>;
|
|
10
|
+
export {};
|
|
11
|
+
//# sourceMappingURL=createSuspendingCell.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createSuspendingCell.d.ts","sourceRoot":"","sources":["../../../../src/components/cell/createSuspendingCell.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAmB,MAAM,OAAO,CAAA;AAYvC,OAAO,KAAK,EACV,eAAe,EAIhB,MAAM,gBAAgB,CAAA;AAGvB,KAAK,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;AACrC;;;;GAIG;AACH,wBAAgB,oBAAoB,CAClC,SAAS,SAAS,MAAM,EACxB,aAAa,SAAS,MAAM,EAE5B,eAAe,EAAE,eAAe,CAAC,MAAM,EAAE,aAAa,CAAC,GACtD,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,CAqIrB"}
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
+
var createSuspendingCell_exports = {};
|
|
30
|
+
__export(createSuspendingCell_exports, {
|
|
31
|
+
createSuspendingCell: () => createSuspendingCell
|
|
32
|
+
});
|
|
33
|
+
module.exports = __toCommonJS(createSuspendingCell_exports);
|
|
34
|
+
var import_react = __toESM(require("react"), 1);
|
|
35
|
+
var import_hooks = require("@apollo/client/react/hooks/hooks.cjs");
|
|
36
|
+
var import_GraphQLHooksProvider = require("../GraphQLHooksProvider.js");
|
|
37
|
+
var import_CellErrorBoundary = require("./CellErrorBoundary.js");
|
|
38
|
+
var import_isCellEmpty = require("./isCellEmpty.js");
|
|
39
|
+
function createSuspendingCell(createCellProps) {
|
|
40
|
+
const {
|
|
41
|
+
QUERY,
|
|
42
|
+
beforeQuery = (props) => ({
|
|
43
|
+
// By default, we assume that the props are the gql-variables.
|
|
44
|
+
variables: props,
|
|
45
|
+
/**
|
|
46
|
+
* We're duplicating these props here due to a suspected bug in Apollo Client v3.5.4
|
|
47
|
+
* (it doesn't seem to be respecting `defaultOptions` in `RedwoodApolloProvider`.)
|
|
48
|
+
*
|
|
49
|
+
* @see {@link https://github.com/apollographql/apollo-client/issues/9105}
|
|
50
|
+
*/
|
|
51
|
+
fetchPolicy: "cache-and-network",
|
|
52
|
+
notifyOnNetworkStatusChange: true
|
|
53
|
+
}),
|
|
54
|
+
afterQuery = (data) => ({ ...data }),
|
|
55
|
+
isEmpty = import_isCellEmpty.isDataEmpty,
|
|
56
|
+
Loading,
|
|
57
|
+
Failure,
|
|
58
|
+
Empty,
|
|
59
|
+
Success,
|
|
60
|
+
displayName = "Cell"
|
|
61
|
+
} = createCellProps;
|
|
62
|
+
function SuspendingSuccess(props) {
|
|
63
|
+
const { queryRef, suspenseQueryResult, userProps } = props;
|
|
64
|
+
const { data, networkStatus } = (0, import_GraphQLHooksProvider.useReadQuery)(queryRef);
|
|
65
|
+
const afterQueryData = afterQuery(data);
|
|
66
|
+
const queryResultWithNetworkStatus = {
|
|
67
|
+
...suspenseQueryResult,
|
|
68
|
+
networkStatus
|
|
69
|
+
};
|
|
70
|
+
if (isEmpty(data, { isDataEmpty: import_isCellEmpty.isDataEmpty }) && Empty) {
|
|
71
|
+
return /* @__PURE__ */ import_react.default.createElement(
|
|
72
|
+
Empty,
|
|
73
|
+
{
|
|
74
|
+
...userProps,
|
|
75
|
+
...afterQueryData,
|
|
76
|
+
queryResult: queryResultWithNetworkStatus
|
|
77
|
+
}
|
|
78
|
+
);
|
|
79
|
+
}
|
|
80
|
+
return /* @__PURE__ */ import_react.default.createElement(
|
|
81
|
+
Success,
|
|
82
|
+
{
|
|
83
|
+
...afterQueryData,
|
|
84
|
+
...userProps,
|
|
85
|
+
queryResult: queryResultWithNetworkStatus
|
|
86
|
+
}
|
|
87
|
+
);
|
|
88
|
+
}
|
|
89
|
+
SuspendingSuccess.displayName = displayName;
|
|
90
|
+
return (props) => {
|
|
91
|
+
const { children: _, ...variables } = props;
|
|
92
|
+
const options = beforeQuery(variables);
|
|
93
|
+
const query = typeof QUERY === "function" ? QUERY(options) : QUERY;
|
|
94
|
+
const [queryRef, other] = (0, import_GraphQLHooksProvider.useBackgroundQuery)(query, options);
|
|
95
|
+
const client = (0, import_hooks.useApolloClient)();
|
|
96
|
+
const suspenseQueryResult = {
|
|
97
|
+
client,
|
|
98
|
+
...other,
|
|
99
|
+
called: !!queryRef
|
|
100
|
+
};
|
|
101
|
+
const FailureComponent = ({ error, resetErrorBoundary }) => {
|
|
102
|
+
if (!Failure) {
|
|
103
|
+
if (error) {
|
|
104
|
+
throw error;
|
|
105
|
+
}
|
|
106
|
+
throw new Error("Unreachable code: FailureComponent without a Failure");
|
|
107
|
+
}
|
|
108
|
+
const queryResultWithErrorReset = {
|
|
109
|
+
...suspenseQueryResult,
|
|
110
|
+
refetch: (variables2) => {
|
|
111
|
+
resetErrorBoundary();
|
|
112
|
+
return suspenseQueryResult.refetch?.(variables2);
|
|
113
|
+
}
|
|
114
|
+
};
|
|
115
|
+
return /* @__PURE__ */ import_react.default.createElement(
|
|
116
|
+
Failure,
|
|
117
|
+
{
|
|
118
|
+
error,
|
|
119
|
+
errorCode: error?.graphQLErrors?.[0]?.extensions?.["code"],
|
|
120
|
+
queryResult: queryResultWithErrorReset
|
|
121
|
+
}
|
|
122
|
+
);
|
|
123
|
+
};
|
|
124
|
+
const wrapInSuspenseIfLoadingPresent = (suspendingSuccessElement, LoadingComponent) => {
|
|
125
|
+
if (!LoadingComponent) {
|
|
126
|
+
return suspendingSuccessElement;
|
|
127
|
+
}
|
|
128
|
+
return /* @__PURE__ */ import_react.default.createElement(
|
|
129
|
+
import_react.Suspense,
|
|
130
|
+
{
|
|
131
|
+
fallback: /* @__PURE__ */ import_react.default.createElement(LoadingComponent, { ...props, queryResult: suspenseQueryResult })
|
|
132
|
+
},
|
|
133
|
+
suspendingSuccessElement
|
|
134
|
+
);
|
|
135
|
+
};
|
|
136
|
+
return /* @__PURE__ */ import_react.default.createElement(import_CellErrorBoundary.CellErrorBoundary, { renderFallback: FailureComponent }, wrapInSuspenseIfLoadingPresent(
|
|
137
|
+
/* @__PURE__ */ import_react.default.createElement(
|
|
138
|
+
SuspendingSuccess,
|
|
139
|
+
{
|
|
140
|
+
userProps: props,
|
|
141
|
+
queryRef,
|
|
142
|
+
suspenseQueryResult
|
|
143
|
+
}
|
|
144
|
+
),
|
|
145
|
+
Loading
|
|
146
|
+
));
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
150
|
+
0 && (module.exports = {
|
|
151
|
+
createSuspendingCell
|
|
152
|
+
});
|