fuse
Version:
The magical GraphQL framework
113 lines (109 loc) • 5.46 kB
JavaScript
var __defProp = Object.defineProperty;
var __defProps = Object.defineProperties;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __propIsEnum = Object.prototype.propertyIsEnumerable;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __spreadValues = (a, b) => {
for (var prop in b || (b = {}))
if (__hasOwnProp.call(b, prop))
__defNormalProp(a, prop, b[prop]);
if (__getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(b)) {
if (__propIsEnum.call(b, prop))
__defNormalProp(a, prop, b[prop]);
}
return a;
};
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
// src/client.ts
var client_exports = {};
__export(client_exports, {
cacheExchange: () => cacheExchange,
createClient: () => createClient
});
module.exports = __toCommonJS(client_exports);
var import_urql = require("urql");
// src/exchanges/cache.ts
var import_core = require("@urql/core");
var import_wonka = require("wonka");
var cacheExchange = ({ forward, client, dispatchDebug }) => {
const cache$ = (0, import_core.cacheExchange)({ client, dispatchDebug, forward });
const warned = /* @__PURE__ */ new Set();
return (ops$) => {
return (0, import_wonka.pipe)(
cache$(ops$),
(0, import_wonka.tap)((result) => {
if (false)
return;
if (warned.has(result.operation.key))
return;
if (result.operation.kind === "mutation" && !result.operation.context.additionalTypenames) {
Object.entries(result.data).forEach(([key, value]) => {
if (value != null && typeof value !== "object") {
warned.add(result.operation.key);
console.warn(
`Saw return of type "${typeof value}" for "${key}", returning scalar values can lead to stale cache-entires. Consider using "additionalTypenames" to correctly evict cache-entries affected by this mutation.`
);
}
});
} else if (result.operation.kind === "query" && !result.operation.context.additionalTypenames) {
Object.entries(result.data).forEach(([key, value]) => {
if (value == null) {
warned.add(result.operation.key);
console.warn(
`Saw return value of "null" for "${key}", we aren't able to derive an associated type for this key, this means that a mutation won't be able to evict this query. Consider using "additionalTypenames" to correctly evict this cache-entry.`
);
} else if (Array.isArray(value) && value.length === 0) {
warned.add(result.operation.key);
console.warn(
`Saw an empty array for "${key}", we aren't able to derive an associated type for members of this list, this means that a mutation won't be able to evict this query. Consider using "additionalTypenames" to correctly evict this cache-entry.`
);
} else if (value != null && typeof value === "object") {
const data = value;
if (data.nodes && Array.isArray(data.nodes) && data.nodes.length === 0) {
warned.add(result.operation.key);
console.warn(
`Saw an empty array for "${key}.nodes", we aren't able to derive an associated type for members of this list, this means that a mutation won't be able to evict this query. Consider using "additionalTypenames" to correctly evict this cache-entry.`
);
} else if (data.edges && Array.isArray(data.edges) && data.edges.length === 0) {
warned.add(result.operation.key);
console.warn(
`Saw an empty array for "${key}.edges", we aren't able to derive an associated type for members of this list, this means that a mutation won't be able to evict this query. Consider using "additionalTypenames" to correctly evict this cache-entry.`
);
}
}
});
}
})
);
};
};
// src/client.ts
__reExport(client_exports, require("urql"), module.exports);
var createClient = (opts) => {
var _a;
const options = __spreadProps(__spreadValues({}, opts), {
suspense: (_a = opts.suspense) != null ? _a : true,
exchanges: opts.exchanges || [cacheExchange, import_urql.fetchExchange]
});
return (0, import_urql.createClient)(options);
};
;