@xata.io/client 0.0.0-beta.c21e40a → 0.0.0-beta.c817835

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.
@@ -4,7 +4,7 @@ export declare type SelectableColumn<O, RecursivePath extends any[] = []> = '*'
4
4
  export declare type SelectedPick<O extends XataRecord, Key extends SelectableColumn<O>[]> = XataRecord & UnionToIntersection<Values<{
5
5
  [K in Key[number]]: NestedValueAtColumn<O, K> & XataRecord;
6
6
  }>>;
7
- export declare type ValueAtColumn<O extends XataRecord, P extends SelectableColumn<O>> = P extends '*' ? Values<O> : P extends 'id' ? string : P extends keyof O ? O[P] : P extends `${infer K}.${infer V}` ? K extends keyof O ? Values<O[K] extends XataRecord ? (V extends SelectableColumn<O[K]> ? {
7
+ export declare type ValueAtColumn<O, P extends SelectableColumn<O>> = P extends '*' ? Values<O> : P extends 'id' ? string : P extends keyof O ? O[P] : P extends `${infer K}.${infer V}` ? K extends keyof O ? Values<O[K] extends XataRecord ? (V extends SelectableColumn<O[K]> ? {
8
8
  V: ValueAtColumn<O[K], V>;
9
9
  } : never) : O[K]> : never : never;
10
10
  declare type MAX_RECURSION = 5;
@@ -0,0 +1,17 @@
1
+ import { SingleOrArray, Values } from '../util/types';
2
+ import { XataRecord } from './record';
3
+ import { SelectableColumn } from './selection';
4
+ export declare type SortDirection = 'asc' | 'desc';
5
+ export declare type SortFilterExtended<T extends XataRecord> = {
6
+ column: SelectableColumn<T>;
7
+ direction?: SortDirection;
8
+ };
9
+ export declare type SortFilter<T extends XataRecord> = SelectableColumn<T> | SortFilterExtended<T>;
10
+ export declare type ApiSortFilter<T extends XataRecord> = SingleOrArray<Values<{
11
+ [key in SelectableColumn<T>]: {
12
+ [K in key]: SortDirection;
13
+ };
14
+ }>>;
15
+ export declare function isSortFilterString<T extends XataRecord>(value: any): value is SelectableColumn<T>;
16
+ export declare function isSortFilterObject<T extends XataRecord>(filter: SortFilter<T>): filter is SortFilterExtended<T>;
17
+ export declare function buildSortFilter<T extends XataRecord>(filter: SingleOrArray<SortFilter<T>>): ApiSortFilter<T>;
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.buildSortFilter = exports.isSortFilterObject = exports.isSortFilterString = void 0;
4
+ const lang_1 = require("../util/lang");
5
+ function isSortFilterString(value) {
6
+ return (0, lang_1.isString)(value);
7
+ }
8
+ exports.isSortFilterString = isSortFilterString;
9
+ function isSortFilterObject(filter) {
10
+ return (0, lang_1.isObject)(filter) && filter.column !== undefined;
11
+ }
12
+ exports.isSortFilterObject = isSortFilterObject;
13
+ function buildSortFilter(filter) {
14
+ var _a;
15
+ if (isSortFilterString(filter)) {
16
+ return { [filter]: 'asc' };
17
+ }
18
+ else if (Array.isArray(filter)) {
19
+ return filter.map((item) => buildSortFilter(item));
20
+ }
21
+ else if (isSortFilterObject(filter)) {
22
+ return { [filter.column]: (_a = filter.direction) !== null && _a !== void 0 ? _a : 'asc' };
23
+ }
24
+ else {
25
+ throw new Error(`Invalid sort filter: ${filter}`);
26
+ }
27
+ }
28
+ exports.buildSortFilter = buildSortFilter;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ // Simple sorting
4
+ const simpleSorting = { name: 'asc' };
5
+ // Array of simple sorting
6
+ const arrayOfSimpleSorting = [{ name: 'asc' }, { age: 'desc' }];
7
+ test('fake test', () => {
8
+ // This is a fake test to make sure that the type definitions in this file are working
9
+ });
@@ -0,0 +1,5 @@
1
+ /// <reference path="../../src/types/global-node.d.ts" />
2
+ /// <reference path="../../src/types/global-variables.d.ts" />
3
+ /// <reference path="../../src/types/global-deno.d.ts" />
4
+ export declare function getEnvVariable(name: string): string | undefined;
5
+ export declare function getGitBranch(): Promise<string | undefined>;
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+ // eslint-disable-next-line @typescript-eslint/triple-slash-reference
3
+ ///<reference path="../types/global-node.d.ts"/>
4
+ // eslint-disable-next-line @typescript-eslint/triple-slash-reference
5
+ ///<reference path="../types/global-variables.d.ts"/>
6
+ // eslint-disable-next-line @typescript-eslint/triple-slash-reference
7
+ ///<reference path="../types/global-deno.d.ts"/>
8
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
9
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
10
+ return new (P || (P = Promise))(function (resolve, reject) {
11
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
12
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
13
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
14
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
15
+ });
16
+ };
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ exports.getGitBranch = exports.getEnvVariable = void 0;
19
+ const lang_1 = require("./lang");
20
+ function getEnvVariable(name) {
21
+ var _a, _b;
22
+ // Node.js: process.env
23
+ try {
24
+ if ((0, lang_1.isObject)(process) && (0, lang_1.isString)((_a = process === null || process === void 0 ? void 0 : process.env) === null || _a === void 0 ? void 0 : _a[name])) {
25
+ return process.env[name];
26
+ }
27
+ }
28
+ catch (err) {
29
+ // Ignore: Should never happen
30
+ }
31
+ try {
32
+ // Deno: Deno.env.get
33
+ if ((0, lang_1.isObject)(Deno) && (0, lang_1.isString)((_b = Deno === null || Deno === void 0 ? void 0 : Deno.env) === null || _b === void 0 ? void 0 : _b.get(name))) {
34
+ return Deno.env.get(name);
35
+ }
36
+ }
37
+ catch (err) {
38
+ // Ignore: Will fail if not using --allow-env
39
+ }
40
+ }
41
+ exports.getEnvVariable = getEnvVariable;
42
+ function getGitBranch() {
43
+ return __awaiter(this, void 0, void 0, function* () {
44
+ // Node.js: child_process.execSync
45
+ try {
46
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
47
+ return require('child_process').execSync('git branch --show-current', { encoding: 'utf-8' }).trim();
48
+ }
49
+ catch (err) {
50
+ // Ignore
51
+ }
52
+ // Deno: Deno.run
53
+ try {
54
+ if ((0, lang_1.isObject)(Deno)) {
55
+ const process = Deno.run({
56
+ cmd: ['git', 'branch', '--show-current'],
57
+ stdout: 'piped',
58
+ stderr: 'piped'
59
+ });
60
+ return new TextDecoder().decode(yield process.output()).trim();
61
+ }
62
+ }
63
+ catch (err) {
64
+ // Ignore: Will fail if not using --allow-run
65
+ }
66
+ });
67
+ }
68
+ exports.getGitBranch = getGitBranch;
@@ -0,0 +1,2 @@
1
+ import { FetchImpl } from '../api/fetcher';
2
+ export declare function getFetchImplementation(userFetch?: FetchImpl): FetchImpl | typeof fetch;
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getFetchImplementation = void 0;
4
+ function getFetchImplementation(userFetch) {
5
+ const globalFetch = typeof fetch !== 'undefined' ? fetch : undefined;
6
+ const fetchImpl = userFetch !== null && userFetch !== void 0 ? userFetch : globalFetch;
7
+ if (!fetchImpl) {
8
+ /** @todo add a link after docs exist */
9
+ throw new Error(`The \`fetch\` option passed to the Xata client is resolving to a falsy value and may not be correctly imported.`);
10
+ }
11
+ return fetchImpl;
12
+ }
13
+ exports.getFetchImplementation = getFetchImplementation;
@@ -1,5 +1,5 @@
1
1
  export declare function compact<T>(arr: Array<T | null | undefined>): T[];
2
2
  export declare function compactObject<T>(obj: Record<string, T | null | undefined>): Record<string, T>;
3
3
  export declare type PartialBy<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
4
- export declare function isObject(value: any): value is object;
4
+ export declare function isObject(value: any): value is Record<string, unknown>;
5
5
  export declare function isString(value: any): value is string;
package/dist/util/lang.js CHANGED
@@ -13,7 +13,7 @@ function compactObject(obj) {
13
13
  }
14
14
  exports.compactObject = compactObject;
15
15
  function isObject(value) {
16
- return value !== undefined && value !== null && typeof value === 'object';
16
+ return Boolean(value) && typeof value === 'object' && !Array.isArray(value);
17
17
  }
18
18
  exports.isObject = isObject;
19
19
  function isString(value) {
@@ -11,3 +11,14 @@ export declare type NonEmptyArray<T> = T[] & {
11
11
  export declare type RequiredBy<T, K extends keyof T> = T & {
12
12
  [P in K]-?: NonNullable<T[P]>;
13
13
  };
14
+ export declare type GetArrayInnerType<T extends readonly any[]> = T[number];
15
+ export declare type NonNullableValues<Obj> = {
16
+ [K in keyof Obj]: NonNullable<Obj[K]>;
17
+ };
18
+ export declare type KeysOfUnion<T> = T extends T ? keyof T : never;
19
+ declare type Impossible<K extends keyof any> = {
20
+ [P in K]: never;
21
+ };
22
+ export declare type Exactly<T, U extends T = T> = U & Impossible<Exclude<keyof U, keyof T>>;
23
+ export declare type SingleOrArray<T> = T | T[];
24
+ export {};
package/package.json CHANGED
@@ -1,9 +1,12 @@
1
1
  {
2
2
  "name": "@xata.io/client",
3
- "version": "0.0.0-beta.c21e40a",
3
+ "version": "0.0.0-beta.c817835",
4
4
  "description": "Xata.io SDK for TypeScript and JavaScript",
5
5
  "main": "./dist/index.js",
6
6
  "types": "./dist/index.d.ts",
7
+ "browser": {
8
+ "child_process": false
9
+ },
7
10
  "scripts": {
8
11
  "test": "echo \"Error: no test specified\" && exit 1",
9
12
  "build": "tsc -p tsconfig.build.json",
@@ -20,5 +23,5 @@
20
23
  "url": "https://github.com/xataio/client-ts/issues"
21
24
  },
22
25
  "homepage": "https://github.com/xataio/client-ts/blob/main/client/README.md",
23
- "gitHead": "c21e40af09635fa25df211e8c4840a6da6117fe3"
26
+ "gitHead": "c817835c55f287286f4d30863e7bcfac0215f8f7"
24
27
  }