@epic-web/workshop-utils 0.0.0-semantically-released
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/README.md +3 -0
- package/dist/esm/apps.server.d.ts +4205 -0
- package/dist/esm/apps.server.d.ts.map +1 -0
- package/dist/esm/apps.server.js +1198 -0
- package/dist/esm/apps.server.js.map +1 -0
- package/dist/esm/cache.server.d.ts +940 -0
- package/dist/esm/cache.server.d.ts.map +1 -0
- package/dist/esm/cache.server.js +161 -0
- package/dist/esm/cache.server.js.map +1 -0
- package/dist/esm/compile-mdx.server.d.ts +12 -0
- package/dist/esm/compile-mdx.server.d.ts.map +1 -0
- package/dist/esm/compile-mdx.server.js +285 -0
- package/dist/esm/compile-mdx.server.js.map +1 -0
- package/dist/esm/config.server.d.ts +348 -0
- package/dist/esm/config.server.d.ts.map +1 -0
- package/dist/esm/config.server.js +231 -0
- package/dist/esm/config.server.js.map +1 -0
- package/dist/esm/db.server.d.ts +463 -0
- package/dist/esm/db.server.d.ts.map +1 -0
- package/dist/esm/db.server.js +260 -0
- package/dist/esm/db.server.js.map +1 -0
- package/dist/esm/diff.server.d.ts +18 -0
- package/dist/esm/diff.server.d.ts.map +1 -0
- package/dist/esm/diff.server.js +437 -0
- package/dist/esm/diff.server.js.map +1 -0
- package/dist/esm/env.server.d.ts +61 -0
- package/dist/esm/env.server.d.ts.map +1 -0
- package/dist/esm/env.server.js +42 -0
- package/dist/esm/env.server.js.map +1 -0
- package/dist/esm/epic-api.server.d.ts +227 -0
- package/dist/esm/epic-api.server.d.ts.map +1 -0
- package/dist/esm/epic-api.server.js +529 -0
- package/dist/esm/epic-api.server.js.map +1 -0
- package/dist/esm/git.server.d.ts +49 -0
- package/dist/esm/git.server.d.ts.map +1 -0
- package/dist/esm/git.server.js +135 -0
- package/dist/esm/git.server.js.map +1 -0
- package/dist/esm/iframe-sync.d.ts +10 -0
- package/dist/esm/iframe-sync.d.ts.map +1 -0
- package/dist/esm/iframe-sync.js +97 -0
- package/dist/esm/iframe-sync.js.map +1 -0
- package/dist/esm/modified-time.server.d.ts +7 -0
- package/dist/esm/modified-time.server.d.ts.map +1 -0
- package/dist/esm/modified-time.server.js +80 -0
- package/dist/esm/modified-time.server.js.map +1 -0
- package/dist/esm/notifications.server.d.ts +56 -0
- package/dist/esm/notifications.server.d.ts.map +1 -0
- package/dist/esm/notifications.server.js +65 -0
- package/dist/esm/notifications.server.js.map +1 -0
- package/dist/esm/package.json +3 -0
- package/dist/esm/playwright.server.d.ts +6 -0
- package/dist/esm/playwright.server.d.ts.map +1 -0
- package/dist/esm/playwright.server.js +95 -0
- package/dist/esm/playwright.server.js.map +1 -0
- package/dist/esm/process-manager.server.d.ts +77 -0
- package/dist/esm/process-manager.server.d.ts.map +1 -0
- package/dist/esm/process-manager.server.js +266 -0
- package/dist/esm/process-manager.server.js.map +1 -0
- package/dist/esm/test.d.ts +16 -0
- package/dist/esm/test.d.ts.map +1 -0
- package/dist/esm/test.js +56 -0
- package/dist/esm/test.js.map +1 -0
- package/dist/esm/timing.server.d.ts +20 -0
- package/dist/esm/timing.server.d.ts.map +1 -0
- package/dist/esm/timing.server.js +88 -0
- package/dist/esm/timing.server.js.map +1 -0
- package/dist/esm/user.server.d.ts +17 -0
- package/dist/esm/user.server.d.ts.map +1 -0
- package/dist/esm/user.server.js +38 -0
- package/dist/esm/user.server.js.map +1 -0
- package/dist/esm/utils.d.ts +2 -0
- package/dist/esm/utils.d.ts.map +1 -0
- package/dist/esm/utils.js +13 -0
- package/dist/esm/utils.js.map +1 -0
- package/dist/esm/utils.server.d.ts +9 -0
- package/dist/esm/utils.server.d.ts.map +1 -0
- package/dist/esm/utils.server.js +45 -0
- package/dist/esm/utils.server.js.map +1 -0
- package/package.json +221 -0
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { createId as cuid } from '@paralleldrive/cuid2';
|
|
2
|
+
import * as cookie from 'cookie';
|
|
3
|
+
import { getAuthInfo, getClientId } from './db.server.js';
|
|
4
|
+
export async function getUserId({ request }) {
|
|
5
|
+
if (ENV.EPICSHOP_DEPLOYED) {
|
|
6
|
+
const cookieHeader = request.headers.get('cookie');
|
|
7
|
+
const cookieValue = cookie.parse(cookieHeader ?? '');
|
|
8
|
+
if (cookieValue.clientId) {
|
|
9
|
+
return {
|
|
10
|
+
id: cookieValue.clientId,
|
|
11
|
+
type: 'cookie.clientId',
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
const newId = cuid();
|
|
16
|
+
return {
|
|
17
|
+
id: newId,
|
|
18
|
+
type: 'cookie.randomId',
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
const authInfo = await getAuthInfo();
|
|
23
|
+
if (authInfo?.id) {
|
|
24
|
+
return {
|
|
25
|
+
id: authInfo.id,
|
|
26
|
+
type: 'db.authInfo',
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
const clientId = await getClientId();
|
|
30
|
+
return {
|
|
31
|
+
id: clientId,
|
|
32
|
+
type: 'db.clientId',
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
export function getSetClientIdCookieHeader(clientId) {
|
|
36
|
+
return `clientId=${clientId}; Path=/; HttpOnly; SameSite=Lax`;
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=user.server.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user.server.js","sourceRoot":"","sources":["../../src/user.server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,IAAI,EAAE,MAAM,sBAAsB,CAAA;AACvD,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAA;AAChC,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAEzD,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,EAAE,OAAO,EAAwB;IAChE,IAAI,GAAG,CAAC,iBAAiB,EAAE,CAAC;QAC3B,MAAM,YAAY,GAAG,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;QAClD,MAAM,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC,YAAY,IAAI,EAAE,CAAC,CAAA;QAEpD,IAAI,WAAW,CAAC,QAAQ,EAAE,CAAC;YAC1B,OAAO;gBACN,EAAE,EAAE,WAAW,CAAC,QAAQ;gBACxB,IAAI,EAAE,iBAAiB;aACd,CAAA;QACX,CAAC;aAAM,CAAC;YACP,MAAM,KAAK,GAAG,IAAI,EAAE,CAAA;YACpB,OAAO;gBACN,EAAE,EAAE,KAAK;gBACT,IAAI,EAAE,iBAAiB;aACd,CAAA;QACX,CAAC;IACF,CAAC;IAED,MAAM,QAAQ,GAAG,MAAM,WAAW,EAAE,CAAA;IAEpC,IAAI,QAAQ,EAAE,EAAE,EAAE,CAAC;QAClB,OAAO;YACN,EAAE,EAAE,QAAQ,CAAC,EAAE;YACf,IAAI,EAAE,aAAa;SACV,CAAA;IACX,CAAC;IAED,MAAM,QAAQ,GAAG,MAAM,WAAW,EAAE,CAAA;IACpC,OAAO;QACN,EAAE,EAAE,QAAQ;QACZ,IAAI,EAAE,aAAa;KACV,CAAA;AACX,CAAC;AAED,MAAM,UAAU,0BAA0B,CAAC,QAAgB;IAC1D,OAAO,YAAY,QAAQ,kCAAkC,CAAA;AAC9D,CAAC","sourcesContent":["import { createId as cuid } from '@paralleldrive/cuid2'\nimport * as cookie from 'cookie'\nimport { getAuthInfo, getClientId } from './db.server.js'\n\nexport async function getUserId({ request }: { request: Request }) {\n\tif (ENV.EPICSHOP_DEPLOYED) {\n\t\tconst cookieHeader = request.headers.get('cookie')\n\t\tconst cookieValue = cookie.parse(cookieHeader ?? '')\n\n\t\tif (cookieValue.clientId) {\n\t\t\treturn {\n\t\t\t\tid: cookieValue.clientId,\n\t\t\t\ttype: 'cookie.clientId',\n\t\t\t} as const\n\t\t} else {\n\t\t\tconst newId = cuid()\n\t\t\treturn {\n\t\t\t\tid: newId,\n\t\t\t\ttype: 'cookie.randomId',\n\t\t\t} as const\n\t\t}\n\t}\n\n\tconst authInfo = await getAuthInfo()\n\n\tif (authInfo?.id) {\n\t\treturn {\n\t\t\tid: authInfo.id,\n\t\t\ttype: 'db.authInfo',\n\t\t} as const\n\t}\n\n\tconst clientId = await getClientId()\n\treturn {\n\t\tid: clientId,\n\t\ttype: 'db.clientId',\n\t} as const\n}\n\nexport function getSetClientIdCookieHeader(clientId: string) {\n\treturn `clientId=${clientId}; Path=/; HttpOnly; SameSite=Lax`\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA,wBAAgB,eAAe,CAAC,KAAK,EAAE,OAAO,UAY7C"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export function getErrorMessage(error) {
|
|
2
|
+
if (typeof error === 'string')
|
|
3
|
+
return error;
|
|
4
|
+
if (error &&
|
|
5
|
+
typeof error === 'object' &&
|
|
6
|
+
'message' in error &&
|
|
7
|
+
typeof error.message === 'string') {
|
|
8
|
+
return error.message;
|
|
9
|
+
}
|
|
10
|
+
console.error('Unable to get error message for error', error);
|
|
11
|
+
return 'Unknown Error';
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,eAAe,CAAC,KAAc;IAC7C,IAAI,OAAO,KAAK,KAAK,QAAQ;QAAE,OAAO,KAAK,CAAA;IAC3C,IACC,KAAK;QACL,OAAO,KAAK,KAAK,QAAQ;QACzB,SAAS,IAAI,KAAK;QAClB,OAAO,KAAK,CAAC,OAAO,KAAK,QAAQ,EAChC,CAAC;QACF,OAAO,KAAK,CAAC,OAAO,CAAA;IACrB,CAAC;IACD,OAAO,CAAC,KAAK,CAAC,uCAAuC,EAAE,KAAK,CAAC,CAAA;IAC7D,OAAO,eAAe,CAAA;AACvB,CAAC","sourcesContent":["export function getErrorMessage(error: unknown) {\n\tif (typeof error === 'string') return error\n\tif (\n\t\terror &&\n\t\ttypeof error === 'object' &&\n\t\t'message' in error &&\n\t\ttypeof error.message === 'string'\n\t) {\n\t\treturn error.message\n\t}\n\tconsole.error('Unable to get error message for error', error)\n\treturn 'Unknown Error'\n}\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import dayjsLib from 'dayjs';
|
|
2
|
+
import { type Timings } from './timing.server.js';
|
|
3
|
+
export declare const dayjs: typeof dayjsLib;
|
|
4
|
+
export declare function checkConnection(): Promise<boolean>;
|
|
5
|
+
export declare function checkConnectionCached({ request, timings, }?: {
|
|
6
|
+
request?: Request;
|
|
7
|
+
timings?: Timings;
|
|
8
|
+
}): Promise<boolean>;
|
|
9
|
+
//# sourceMappingURL=utils.server.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.server.d.ts","sourceRoot":"","sources":["../../src/utils.server.ts"],"names":[],"mappings":"AACA,OAAO,QAAQ,MAAM,OAAO,CAAA;AAK5B,OAAO,EAAE,KAAK,OAAO,EAAE,MAAM,oBAAoB,CAAA;AAEjD,eAAO,MAAM,KAAK,iBAKhB,CAAA;AAEF,wBAAsB,eAAe,qBASpC;AAED,wBAAsB,qBAAqB,CAAC,EAC3C,OAAO,EACP,OAAO,GACP,GAAE;IACF,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,OAAO,CAAC,EAAE,OAAO,CAAA;CACZ,oBAmBL"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { remember } from '@epic-web/remember';
|
|
2
|
+
import dayjsLib from 'dayjs';
|
|
3
|
+
import relativeTimePlugin from 'dayjs/plugin/relativeTime.js';
|
|
4
|
+
import timeZonePlugin from 'dayjs/plugin/timezone.js';
|
|
5
|
+
import utcPlugin from 'dayjs/plugin/utc.js';
|
|
6
|
+
import { cachified, connectionCache } from './cache.server.js';
|
|
7
|
+
export const dayjs = remember('dayjs', () => {
|
|
8
|
+
dayjsLib.extend(utcPlugin);
|
|
9
|
+
dayjsLib.extend(timeZonePlugin);
|
|
10
|
+
dayjsLib.extend(relativeTimePlugin);
|
|
11
|
+
return dayjsLib;
|
|
12
|
+
});
|
|
13
|
+
export async function checkConnection() {
|
|
14
|
+
try {
|
|
15
|
+
const response = await fetch('https://www.cloudflare.com', {
|
|
16
|
+
method: 'HEAD',
|
|
17
|
+
});
|
|
18
|
+
return response.ok;
|
|
19
|
+
}
|
|
20
|
+
catch {
|
|
21
|
+
return false;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
export async function checkConnectionCached({ request, timings, } = {}) {
|
|
25
|
+
const isOnline = await cachified({
|
|
26
|
+
cache: connectionCache,
|
|
27
|
+
request,
|
|
28
|
+
timings,
|
|
29
|
+
key: 'connected',
|
|
30
|
+
ttl: 1000 * 10,
|
|
31
|
+
async getFreshValue(context) {
|
|
32
|
+
const result = await checkConnection();
|
|
33
|
+
if (result) {
|
|
34
|
+
context.metadata.ttl = 1000 * 60;
|
|
35
|
+
context.metadata.swr = 1000 * 60 * 30;
|
|
36
|
+
return true;
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
return false;
|
|
40
|
+
}
|
|
41
|
+
},
|
|
42
|
+
});
|
|
43
|
+
return isOnline;
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=utils.server.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.server.js","sourceRoot":"","sources":["../../src/utils.server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAA;AAC7C,OAAO,QAAQ,MAAM,OAAO,CAAA;AAC5B,OAAO,kBAAkB,MAAM,8BAA8B,CAAA;AAC7D,OAAO,cAAc,MAAM,0BAA0B,CAAA;AACrD,OAAO,SAAS,MAAM,qBAAqB,CAAA;AAC3C,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AAG9D,MAAM,CAAC,MAAM,KAAK,GAAG,QAAQ,CAAC,OAAO,EAAE,GAAG,EAAE;IAC3C,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAA;IAC1B,QAAQ,CAAC,MAAM,CAAC,cAAc,CAAC,CAAA;IAC/B,QAAQ,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAA;IACnC,OAAO,QAAQ,CAAA;AAChB,CAAC,CAAC,CAAA;AAEF,MAAM,CAAC,KAAK,UAAU,eAAe;IACpC,IAAI,CAAC;QACJ,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,4BAA4B,EAAE;YAC1D,MAAM,EAAE,MAAM;SACd,CAAC,CAAA;QACF,OAAO,QAAQ,CAAC,EAAE,CAAA;IACnB,CAAC;IAAC,MAAM,CAAC;QACR,OAAO,KAAK,CAAA;IACb,CAAC;AACF,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,qBAAqB,CAAC,EAC3C,OAAO,EACP,OAAO,MAIJ,EAAE;IACL,MAAM,QAAQ,GAAG,MAAM,SAAS,CAAC;QAChC,KAAK,EAAE,eAAe;QACtB,OAAO;QACP,OAAO;QACP,GAAG,EAAE,WAAW;QAChB,GAAG,EAAE,IAAI,GAAG,EAAE;QACd,KAAK,CAAC,aAAa,CAAC,OAAO;YAC1B,MAAM,MAAM,GAAG,MAAM,eAAe,EAAE,CAAA;YACtC,IAAI,MAAM,EAAE,CAAC;gBACZ,OAAO,CAAC,QAAQ,CAAC,GAAG,GAAG,IAAI,GAAG,EAAE,CAAA;gBAChC,OAAO,CAAC,QAAQ,CAAC,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,CAAA;gBACrC,OAAO,IAAI,CAAA;YACZ,CAAC;iBAAM,CAAC;gBACP,OAAO,KAAK,CAAA;YACb,CAAC;QACF,CAAC;KACD,CAAC,CAAA;IACF,OAAO,QAAQ,CAAA;AAChB,CAAC","sourcesContent":["import { remember } from '@epic-web/remember'\nimport dayjsLib from 'dayjs'\nimport relativeTimePlugin from 'dayjs/plugin/relativeTime.js'\nimport timeZonePlugin from 'dayjs/plugin/timezone.js'\nimport utcPlugin from 'dayjs/plugin/utc.js'\nimport { cachified, connectionCache } from './cache.server.js'\nimport { type Timings } from './timing.server.js'\n\nexport const dayjs = remember('dayjs', () => {\n\tdayjsLib.extend(utcPlugin)\n\tdayjsLib.extend(timeZonePlugin)\n\tdayjsLib.extend(relativeTimePlugin)\n\treturn dayjsLib\n})\n\nexport async function checkConnection() {\n\ttry {\n\t\tconst response = await fetch('https://www.cloudflare.com', {\n\t\t\tmethod: 'HEAD',\n\t\t})\n\t\treturn response.ok\n\t} catch {\n\t\treturn false\n\t}\n}\n\nexport async function checkConnectionCached({\n\trequest,\n\ttimings,\n}: {\n\trequest?: Request\n\ttimings?: Timings\n} = {}) {\n\tconst isOnline = await cachified({\n\t\tcache: connectionCache,\n\t\trequest,\n\t\ttimings,\n\t\tkey: 'connected',\n\t\tttl: 1000 * 10,\n\t\tasync getFreshValue(context) {\n\t\t\tconst result = await checkConnection()\n\t\t\tif (result) {\n\t\t\t\tcontext.metadata.ttl = 1000 * 60\n\t\t\t\tcontext.metadata.swr = 1000 * 60 * 30\n\t\t\t\treturn true\n\t\t\t} else {\n\t\t\t\treturn false\n\t\t\t}\n\t\t},\n\t})\n\treturn isOnline\n}\n"]}
|
package/package.json
ADDED
|
@@ -0,0 +1,221 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@epic-web/workshop-utils",
|
|
3
|
+
"version": "0.0.0-semantically-released",
|
|
4
|
+
"publishConfig": {
|
|
5
|
+
"access": "public"
|
|
6
|
+
},
|
|
7
|
+
"type": "module",
|
|
8
|
+
"tshy": {
|
|
9
|
+
"project": "./tsconfig.build.json",
|
|
10
|
+
"dialects": [
|
|
11
|
+
"esm"
|
|
12
|
+
],
|
|
13
|
+
"exports": {
|
|
14
|
+
"./package.json": "./package.json",
|
|
15
|
+
"./apps.server": "./src/apps.server.ts",
|
|
16
|
+
"./diff.server": "./src/diff.server.ts",
|
|
17
|
+
"./env.server": "./src/env.server.ts",
|
|
18
|
+
"./epic-api.server": "./src/epic-api.server.ts",
|
|
19
|
+
"./user.server": "./src/user.server.ts",
|
|
20
|
+
"./cache.server": "./src/cache.server.ts",
|
|
21
|
+
"./config.server": "./src/config.server.ts",
|
|
22
|
+
"./db.server": "./src/db.server.ts",
|
|
23
|
+
"./timing.server": "./src/timing.server.ts",
|
|
24
|
+
"./modified-time.server": "./src/modified-time.server.ts",
|
|
25
|
+
"./compile-mdx.server": "./src/compile-mdx.server.ts",
|
|
26
|
+
"./git.server": "./src/git.server.ts",
|
|
27
|
+
"./iframe-sync": "./src/iframe-sync.ts",
|
|
28
|
+
"./playwright.server": "./src/playwright.server.ts",
|
|
29
|
+
"./notifications.server": "./src/notifications.server.ts",
|
|
30
|
+
"./process-manager.server": "./src/process-manager.server.ts",
|
|
31
|
+
"./test": "./src/test.ts",
|
|
32
|
+
"./utils.server": "./src/utils.server.ts",
|
|
33
|
+
"./utils": "./src/utils.ts"
|
|
34
|
+
}
|
|
35
|
+
},
|
|
36
|
+
"exports": {
|
|
37
|
+
"./package.json": "./package.json",
|
|
38
|
+
"./apps.server": {
|
|
39
|
+
"import": {
|
|
40
|
+
"types": "./dist/esm/apps.server.d.ts",
|
|
41
|
+
"default": "./dist/esm/apps.server.js"
|
|
42
|
+
}
|
|
43
|
+
},
|
|
44
|
+
"./diff.server": {
|
|
45
|
+
"import": {
|
|
46
|
+
"types": "./dist/esm/diff.server.d.ts",
|
|
47
|
+
"default": "./dist/esm/diff.server.js"
|
|
48
|
+
}
|
|
49
|
+
},
|
|
50
|
+
"./env.server": {
|
|
51
|
+
"import": {
|
|
52
|
+
"types": "./dist/esm/env.server.d.ts",
|
|
53
|
+
"default": "./dist/esm/env.server.js"
|
|
54
|
+
}
|
|
55
|
+
},
|
|
56
|
+
"./epic-api.server": {
|
|
57
|
+
"import": {
|
|
58
|
+
"types": "./dist/esm/epic-api.server.d.ts",
|
|
59
|
+
"default": "./dist/esm/epic-api.server.js"
|
|
60
|
+
}
|
|
61
|
+
},
|
|
62
|
+
"./user.server": {
|
|
63
|
+
"import": {
|
|
64
|
+
"types": "./dist/esm/user.server.d.ts",
|
|
65
|
+
"default": "./dist/esm/user.server.js"
|
|
66
|
+
}
|
|
67
|
+
},
|
|
68
|
+
"./cache.server": {
|
|
69
|
+
"import": {
|
|
70
|
+
"types": "./dist/esm/cache.server.d.ts",
|
|
71
|
+
"default": "./dist/esm/cache.server.js"
|
|
72
|
+
}
|
|
73
|
+
},
|
|
74
|
+
"./config.server": {
|
|
75
|
+
"import": {
|
|
76
|
+
"types": "./dist/esm/config.server.d.ts",
|
|
77
|
+
"default": "./dist/esm/config.server.js"
|
|
78
|
+
}
|
|
79
|
+
},
|
|
80
|
+
"./db.server": {
|
|
81
|
+
"import": {
|
|
82
|
+
"types": "./dist/esm/db.server.d.ts",
|
|
83
|
+
"default": "./dist/esm/db.server.js"
|
|
84
|
+
}
|
|
85
|
+
},
|
|
86
|
+
"./timing.server": {
|
|
87
|
+
"import": {
|
|
88
|
+
"types": "./dist/esm/timing.server.d.ts",
|
|
89
|
+
"default": "./dist/esm/timing.server.js"
|
|
90
|
+
}
|
|
91
|
+
},
|
|
92
|
+
"./modified-time.server": {
|
|
93
|
+
"import": {
|
|
94
|
+
"types": "./dist/esm/modified-time.server.d.ts",
|
|
95
|
+
"default": "./dist/esm/modified-time.server.js"
|
|
96
|
+
}
|
|
97
|
+
},
|
|
98
|
+
"./compile-mdx.server": {
|
|
99
|
+
"import": {
|
|
100
|
+
"types": "./dist/esm/compile-mdx.server.d.ts",
|
|
101
|
+
"default": "./dist/esm/compile-mdx.server.js"
|
|
102
|
+
}
|
|
103
|
+
},
|
|
104
|
+
"./git.server": {
|
|
105
|
+
"import": {
|
|
106
|
+
"types": "./dist/esm/git.server.d.ts",
|
|
107
|
+
"default": "./dist/esm/git.server.js"
|
|
108
|
+
}
|
|
109
|
+
},
|
|
110
|
+
"./iframe-sync": {
|
|
111
|
+
"import": {
|
|
112
|
+
"types": "./dist/esm/iframe-sync.d.ts",
|
|
113
|
+
"default": "./dist/esm/iframe-sync.js"
|
|
114
|
+
}
|
|
115
|
+
},
|
|
116
|
+
"./playwright.server": {
|
|
117
|
+
"import": {
|
|
118
|
+
"types": "./dist/esm/playwright.server.d.ts",
|
|
119
|
+
"default": "./dist/esm/playwright.server.js"
|
|
120
|
+
}
|
|
121
|
+
},
|
|
122
|
+
"./notifications.server": {
|
|
123
|
+
"import": {
|
|
124
|
+
"types": "./dist/esm/notifications.server.d.ts",
|
|
125
|
+
"default": "./dist/esm/notifications.server.js"
|
|
126
|
+
}
|
|
127
|
+
},
|
|
128
|
+
"./process-manager.server": {
|
|
129
|
+
"import": {
|
|
130
|
+
"types": "./dist/esm/process-manager.server.d.ts",
|
|
131
|
+
"default": "./dist/esm/process-manager.server.js"
|
|
132
|
+
}
|
|
133
|
+
},
|
|
134
|
+
"./test": {
|
|
135
|
+
"import": {
|
|
136
|
+
"types": "./dist/esm/test.d.ts",
|
|
137
|
+
"default": "./dist/esm/test.js"
|
|
138
|
+
}
|
|
139
|
+
},
|
|
140
|
+
"./utils.server": {
|
|
141
|
+
"import": {
|
|
142
|
+
"types": "./dist/esm/utils.server.d.ts",
|
|
143
|
+
"default": "./dist/esm/utils.server.js"
|
|
144
|
+
}
|
|
145
|
+
},
|
|
146
|
+
"./utils": {
|
|
147
|
+
"import": {
|
|
148
|
+
"types": "./dist/esm/utils.d.ts",
|
|
149
|
+
"default": "./dist/esm/utils.js"
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
},
|
|
153
|
+
"files": [
|
|
154
|
+
"dist"
|
|
155
|
+
],
|
|
156
|
+
"scripts": {
|
|
157
|
+
"typecheck": "tsc --noEmit",
|
|
158
|
+
"build": "tshy",
|
|
159
|
+
"build:watch": "nx watch --projects=@epic-web/workshop-utils -- nx run \\$NX_PROJECT_NAME:build"
|
|
160
|
+
},
|
|
161
|
+
"dependencies": {
|
|
162
|
+
"@epic-web/cachified": "^5.6.0",
|
|
163
|
+
"@epic-web/invariant": "^1.0.0",
|
|
164
|
+
"@epic-web/remember": "^1.1.0",
|
|
165
|
+
"@kentcdodds/md-temp": "^10.0.1",
|
|
166
|
+
"@mdx-js/mdx": "^3.1.0",
|
|
167
|
+
"@paralleldrive/cuid2": "^2.2.2",
|
|
168
|
+
"@playwright/test": "^1.53.2",
|
|
169
|
+
"@react-router/node": "^7.6.3",
|
|
170
|
+
"@testing-library/dom": "^10.4.0",
|
|
171
|
+
"@testing-library/jest-dom": "^6.6.3",
|
|
172
|
+
"@total-typescript/ts-reset": "^0.6.1",
|
|
173
|
+
"@types/chai": "^5.2.2",
|
|
174
|
+
"@types/chai-dom": "^1.11.3",
|
|
175
|
+
"@vitest/expect": "^3.2.4",
|
|
176
|
+
"chai": "^5.2.0",
|
|
177
|
+
"chai-dom": "^1.12.1",
|
|
178
|
+
"chalk": "^5.4.1",
|
|
179
|
+
"chokidar": "^4.0.3",
|
|
180
|
+
"close-with-grace": "^2.2.0",
|
|
181
|
+
"cookie": "^1.0.2",
|
|
182
|
+
"cross-spawn": "^7.0.6",
|
|
183
|
+
"dayjs": "^1.11.13",
|
|
184
|
+
"esbuild": "^0.25.5",
|
|
185
|
+
"execa": "^9.6.0",
|
|
186
|
+
"find-process": "^1.4.10",
|
|
187
|
+
"fkill": "^9.0.0",
|
|
188
|
+
"fs-extra": "^11.3.0",
|
|
189
|
+
"globby": "^14.1.0",
|
|
190
|
+
"ignore": "^7.0.5",
|
|
191
|
+
"json5": "^2.2.3",
|
|
192
|
+
"lru-cache": "^11.1.0",
|
|
193
|
+
"lz-string": "^1.5.0",
|
|
194
|
+
"md5-hex": "^5.0.0",
|
|
195
|
+
"mdast-util-mdx-jsx": "^3.2.0",
|
|
196
|
+
"mdx-bundler": "^10.1.1",
|
|
197
|
+
"p-queue": "^8.1.0",
|
|
198
|
+
"parse-git-diff": "^0.0.19",
|
|
199
|
+
"rehype": "^13.0.2",
|
|
200
|
+
"rehype-autolink-headings": "^7.1.0",
|
|
201
|
+
"remark": "^15.0.1",
|
|
202
|
+
"remark-emoji": "^5.0.1",
|
|
203
|
+
"remark-gfm": "^4.0.1",
|
|
204
|
+
"shiki": "^3.7.0",
|
|
205
|
+
"unified": "^11.0.5",
|
|
206
|
+
"unist-util-remove-position": "^5.0.0",
|
|
207
|
+
"unist-util-visit": "^5.0.0",
|
|
208
|
+
"zod": "^3.25.71"
|
|
209
|
+
},
|
|
210
|
+
"devDependencies": {
|
|
211
|
+
"@types/hast": "^3.0.4",
|
|
212
|
+
"@types/mdast": "^4.0.4",
|
|
213
|
+
"@types/node": "^24.0.10",
|
|
214
|
+
"tshy": "^3.0.2"
|
|
215
|
+
},
|
|
216
|
+
"repository": {
|
|
217
|
+
"type": "git",
|
|
218
|
+
"url": "https://github.com/epicweb-dev/epicshop.git",
|
|
219
|
+
"directory": "packages/workshop-utils"
|
|
220
|
+
}
|
|
221
|
+
}
|