@t1mmen/srtd 0.4.0 → 0.4.2
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 +24 -22
- package/dist/__tests__/apply.test.d.ts +1 -0
- package/dist/__tests__/apply.test.js +69 -0
- package/dist/__tests__/apply.test.js.map +1 -0
- package/dist/__tests__/build.test.d.ts +1 -0
- package/dist/__tests__/build.test.js +67 -0
- package/dist/__tests__/build.test.js.map +1 -0
- package/dist/__tests__/watch.test.js +9 -3
- package/dist/__tests__/watch.test.js.map +1 -1
- package/dist/commands/_app.js +11 -17
- package/dist/commands/_app.js.map +1 -1
- package/dist/commands/apply.d.ts +2 -1
- package/dist/commands/apply.js +16 -19
- package/dist/commands/apply.js.map +1 -1
- package/dist/commands/build.d.ts +5 -1
- package/dist/commands/build.js +25 -9
- package/dist/commands/build.js.map +1 -1
- package/dist/commands/index.js +2 -1
- package/dist/commands/index.js.map +1 -1
- package/dist/commands/register.js +6 -5
- package/dist/commands/register.js.map +1 -1
- package/dist/commands/watch.js +35 -23
- package/dist/commands/watch.js.map +1 -1
- package/dist/components/Branding.js +7 -7
- package/dist/components/Branding.js.map +1 -1
- package/dist/components/Debug.d.ts +2 -0
- package/dist/components/Debug.js +160 -0
- package/dist/components/Debug.js.map +1 -0
- package/dist/components/ProcessingResults.d.ts +9 -0
- package/dist/components/ProcessingResults.js +32 -0
- package/dist/components/ProcessingResults.js.map +1 -0
- package/dist/components/Quittable.js +1 -1
- package/dist/components/customTheme.d.ts +10 -0
- package/dist/components/customTheme.js +66 -0
- package/dist/components/customTheme.js.map +1 -0
- package/dist/hooks/useDatabaseConnection.js +21 -32
- package/dist/hooks/useDatabaseConnection.js.map +1 -1
- package/dist/hooks/useTemplateProcessor.d.ts +11 -0
- package/dist/hooks/useTemplateProcessor.js +71 -0
- package/dist/hooks/useTemplateProcessor.js.map +1 -0
- package/dist/lib/templateManager.d.ts +4 -0
- package/dist/lib/templateManager.js +29 -6
- package/dist/lib/templateManager.js.map +1 -1
- package/dist/lib/templateManager.test.js +54 -31
- package/dist/lib/templateManager.test.js.map +1 -1
- package/dist/types.d.ts +3 -0
- package/dist/utils/databaseConnection.d.ts +5 -0
- package/dist/utils/databaseConnection.js +36 -21
- package/dist/utils/databaseConnection.js.map +1 -1
- package/dist/utils/store.d.ts +5 -0
- package/dist/utils/store.js +10 -0
- package/dist/utils/store.js.map +1 -0
- package/package.json +2 -1
package/dist/commands/watch.js
CHANGED
|
@@ -6,8 +6,10 @@ import React, { useMemo } from 'react';
|
|
|
6
6
|
import Branding from '../components/Branding.js';
|
|
7
7
|
import Quittable from '../components/Quittable.js';
|
|
8
8
|
import { TimeSince } from '../components/TimeSince.js';
|
|
9
|
+
import { COLOR_ACCENT, COLOR_ERROR, COLOR_SUCCESS, COLOR_WARNING, } from '../components/customTheme.js';
|
|
9
10
|
import { useDatabaseConnection } from '../hooks/useDatabaseConnection.js';
|
|
10
11
|
import { useTemplateManager } from '../hooks/useTemplateManager.js';
|
|
12
|
+
import { store } from '../utils/store.js';
|
|
11
13
|
const MAX_FILES = 10;
|
|
12
14
|
const MAX_CHANGES = 15;
|
|
13
15
|
const PATH_DISPLAY_LENGTH = 15;
|
|
@@ -35,6 +37,8 @@ function formatTemplateDisplay(templatePath, templateDir) {
|
|
|
35
37
|
}
|
|
36
38
|
const TemplateRow = React.memo(({ template, isLatest, templateDir, }) => {
|
|
37
39
|
const displayName = formatTemplateDisplay(template.path, templateDir ?? '');
|
|
40
|
+
const needsBuild = !template.buildState.lastBuildDate ||
|
|
41
|
+
template.currentHash !== template.buildState.lastBuildHash;
|
|
38
42
|
return (React.createElement(Box, { marginLeft: 2 },
|
|
39
43
|
React.createElement(Box, { width: 2 },
|
|
40
44
|
React.createElement(Text, null, template.buildState.lastAppliedError ? '❌' : isLatest ? '⚡️' : '✓')),
|
|
@@ -44,13 +48,12 @@ const TemplateRow = React.memo(({ template, isLatest, templateDir, }) => {
|
|
|
44
48
|
React.createElement(Text, { dimColor: true },
|
|
45
49
|
"applied ",
|
|
46
50
|
React.createElement(TimeSince, { date: template.buildState.lastAppliedDate }),
|
|
47
|
-
" ago",
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
" ago"))))));
|
|
51
|
+
" ago"),
|
|
52
|
+
React.createElement(Text, null, " \u2022 "),
|
|
53
|
+
React.createElement(Text, { dimColor: true }, template.wip ? (React.createElement(React.Fragment, null, "wip")) : needsBuild ? (React.createElement(React.Fragment, null, "needs build")) : (React.createElement(React.Fragment, null,
|
|
54
|
+
"built ",
|
|
55
|
+
React.createElement(TimeSince, { date: template.buildState.lastBuildDate }),
|
|
56
|
+
" ago"))))));
|
|
54
57
|
});
|
|
55
58
|
TemplateRow.displayName = 'TemplateRow';
|
|
56
59
|
const UpdateLog = React.memo(({ updates, templateDir, }) => {
|
|
@@ -71,8 +74,13 @@ const UpdateLog = React.memo(({ updates, templateDir, }) => {
|
|
|
71
74
|
};
|
|
72
75
|
return (React.createElement(Box, { flexDirection: "column", marginTop: 1 },
|
|
73
76
|
React.createElement(Text, { bold: true }, "Changelog:"),
|
|
77
|
+
!sortedUpdates.length && React.createElement(Text, { dimColor: true }, "Nothing changed yet"),
|
|
74
78
|
sortedUpdates.map(update => (React.createElement(Box, { key: `${update.template.path}-${update.timestamp}`, marginLeft: 2 },
|
|
75
|
-
React.createElement(Text, { color: update.type === 'error'
|
|
79
|
+
React.createElement(Text, { color: update.type === 'error'
|
|
80
|
+
? COLOR_ERROR
|
|
81
|
+
: update.type === 'applied'
|
|
82
|
+
? COLOR_SUCCESS
|
|
83
|
+
: COLOR_ACCENT },
|
|
76
84
|
update.type === 'error' ? '❌' : update.type === 'applied' ? '✨' : '📝',
|
|
77
85
|
' ',
|
|
78
86
|
formatTemplateDisplay(update.template.path, templateDir ?? ''),
|
|
@@ -82,50 +90,54 @@ const UpdateLog = React.memo(({ updates, templateDir, }) => {
|
|
|
82
90
|
? formatError(update.error)
|
|
83
91
|
: update.type === 'applied'
|
|
84
92
|
? 'applied successfully'
|
|
85
|
-
: 'changed
|
|
93
|
+
: 'changed'))))));
|
|
86
94
|
});
|
|
87
95
|
UpdateLog.displayName = 'UpdateLog';
|
|
88
96
|
export default function Watch() {
|
|
89
97
|
const { isConnected } = useDatabaseConnection();
|
|
90
98
|
const { templates, updates, stats, isLoading, errors, latestPath, templateDir } = useTemplateManager();
|
|
91
|
-
const [showUpdates, setShowUpdates] = React.useState(
|
|
99
|
+
const [showUpdates, setShowUpdates] = React.useState(store.get('showWatchLogs'));
|
|
92
100
|
const activeTemplates = useMemo(() => templates.slice(-MAX_FILES), [templates]);
|
|
93
101
|
const hasErrors = errors.size > 0;
|
|
94
102
|
useInput(input => {
|
|
95
103
|
if (input === 'u') {
|
|
96
|
-
|
|
104
|
+
const show = !showUpdates;
|
|
105
|
+
setShowUpdates(show);
|
|
106
|
+
store.set('showWatchLogs', show);
|
|
97
107
|
}
|
|
98
108
|
});
|
|
99
109
|
if (!isConnected) {
|
|
100
110
|
return (React.createElement(Box, { flexDirection: "column" },
|
|
101
|
-
React.createElement(Text, { color:
|
|
111
|
+
React.createElement(Text, { color: COLOR_ERROR }, "Unable to connect to database. Is Supabase running?"),
|
|
102
112
|
React.createElement(Quittable, null)));
|
|
103
113
|
}
|
|
104
114
|
return (React.createElement(Box, { flexDirection: "column" },
|
|
105
115
|
React.createElement(Branding, { subtitle: "\uD83D\uDC40 Watch Mode" }),
|
|
106
|
-
React.createElement(Box, {
|
|
107
|
-
React.createElement(StatBadge, { label: "Total", value: stats.total, color:
|
|
108
|
-
stats.needsBuild > 0 && (React.createElement(StatBadge, { label: "Needs Build", value: stats.needsBuild, color:
|
|
109
|
-
stats.recentlyChanged > 0 && (React.createElement(StatBadge, { label: "Recent Changes", value: stats.recentlyChanged, color:
|
|
110
|
-
hasErrors && React.createElement(StatBadge, { label: "Errors", value: stats.errors, color:
|
|
116
|
+
React.createElement(Box, { marginBottom: 1 },
|
|
117
|
+
React.createElement(StatBadge, { label: "Total", value: stats.total, color: COLOR_SUCCESS }),
|
|
118
|
+
stats.needsBuild > 0 && (React.createElement(StatBadge, { label: "Needs Build", value: stats.needsBuild, color: COLOR_WARNING })),
|
|
119
|
+
stats.recentlyChanged > 0 && (React.createElement(StatBadge, { label: "Recent Changes", value: stats.recentlyChanged, color: COLOR_ACCENT })),
|
|
120
|
+
hasErrors && React.createElement(StatBadge, { label: "Errors", value: stats.errors, color: COLOR_ERROR })),
|
|
111
121
|
isLoading ? (React.createElement(Text, null, "\uD83D\uDD0D Finding templates...")) : (React.createElement(Box, { flexDirection: "column" },
|
|
122
|
+
React.createElement(Text, { bold: true }, "Recently modified templates:"),
|
|
123
|
+
activeTemplates.length === 0 && React.createElement(Text, { dimColor: true }, "No templates found"),
|
|
112
124
|
activeTemplates.map(template => (React.createElement(TemplateRow, { key: template.path, template: template, isLatest: template.path === latestPath, templateDir: templateDir }))),
|
|
113
|
-
showUpdates &&
|
|
125
|
+
showUpdates && React.createElement(UpdateLog, { updates: updates, templateDir: templateDir }),
|
|
114
126
|
hasErrors && (React.createElement(Box, { flexDirection: "column", marginTop: 1 },
|
|
115
|
-
React.createElement(Text, { bold: true, color:
|
|
127
|
+
React.createElement(Text, { bold: true, color: COLOR_ERROR }, "Errors:"),
|
|
116
128
|
Array.from(errors.entries()).map(([path, error]) => (React.createElement(Box, { key: path, marginLeft: 2, marginTop: 1 },
|
|
117
|
-
React.createElement(Text, { color:
|
|
129
|
+
React.createElement(Text, { color: COLOR_ERROR, wrap: "wrap" },
|
|
118
130
|
formatTemplateDisplay(path, templateDir ?? ''),
|
|
119
131
|
": ",
|
|
120
132
|
String(error))))))))),
|
|
121
133
|
React.createElement(Box, { marginY: 1, flexDirection: "row", gap: 1 },
|
|
122
134
|
React.createElement(Quittable, null),
|
|
123
|
-
|
|
135
|
+
React.createElement(React.Fragment, null,
|
|
124
136
|
React.createElement(Box, { marginY: 1 },
|
|
125
137
|
React.createElement(Text, { dimColor: true }, "\u2022")),
|
|
126
138
|
React.createElement(Box, { marginY: 1 },
|
|
127
|
-
React.createElement(Text, { dimColor: true }, "
|
|
139
|
+
React.createElement(Text, { dimColor: true }, "Press "),
|
|
128
140
|
React.createElement(Text, { underline: showUpdates }, "u"),
|
|
129
|
-
React.createElement(Text, { dimColor: true }, " to toggle updates"))))))
|
|
141
|
+
React.createElement(Text, { dimColor: true }, " to toggle updates"))))));
|
|
130
142
|
}
|
|
131
143
|
//# sourceMappingURL=watch.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"watch.js","sourceRoot":"","sources":["../../src/commands/watch.tsx"],"names":[],"mappings":"AAAA,2BAA2B;AAC3B,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,KAAK,EAAE,MAAM,WAAW,CAAC;AAClC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,KAAK,CAAC;AAC1C,OAAO,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,QAAQ,MAAM,2BAA2B,CAAC;AACjD,OAAO,SAAS,MAAM,4BAA4B,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AACvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;
|
|
1
|
+
{"version":3,"file":"watch.js","sourceRoot":"","sources":["../../src/commands/watch.tsx"],"names":[],"mappings":"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"}
|
|
@@ -3,25 +3,25 @@ import { Box, Text } from 'ink';
|
|
|
3
3
|
import React from 'react';
|
|
4
4
|
import packageJson from '../../package.json' assert { type: 'json' };
|
|
5
5
|
import { useDatabaseConnection } from '../hooks/useDatabaseConnection.js';
|
|
6
|
+
import { COLOR_ERROR, COLOR_SUPABASE, COLOR_WARNING } from './customTheme.js';
|
|
6
7
|
export default function Branding({ subtitle }) {
|
|
7
8
|
const { error, isConnected } = useDatabaseConnection();
|
|
8
|
-
const badgeColor = error ?
|
|
9
|
+
const badgeColor = error ? COLOR_ERROR : isConnected ? COLOR_SUPABASE : COLOR_WARNING;
|
|
9
10
|
return (React.createElement(Box, { marginBottom: 1, marginTop: 1, gap: 1, flexDirection: "column" },
|
|
10
11
|
React.createElement(Box, { gap: 1 },
|
|
11
12
|
React.createElement(Badge, { color: badgeColor }, " srtd "),
|
|
12
13
|
subtitle ? (React.createElement(Text, null, subtitle)) : (React.createElement(Text, null,
|
|
13
|
-
|
|
14
|
-
React.createElement(Text, { bold: true, color: "#3ecf8e" }, "S"),
|
|
14
|
+
React.createElement(Text, { bold: true, color: COLOR_SUPABASE }, "S"),
|
|
15
15
|
"upabase",
|
|
16
16
|
' ',
|
|
17
|
-
React.createElement(Text, { bold: true, color:
|
|
17
|
+
React.createElement(Text, { bold: true, color: COLOR_SUPABASE }, "R"),
|
|
18
18
|
"epeatable",
|
|
19
19
|
' ',
|
|
20
|
-
React.createElement(Text, { bold: true, color:
|
|
20
|
+
React.createElement(Text, { bold: true, color: COLOR_SUPABASE }, "T"),
|
|
21
21
|
"emplate",
|
|
22
22
|
' ',
|
|
23
|
-
React.createElement(Text, { bold: true, color:
|
|
24
|
-
"efinitions
|
|
23
|
+
React.createElement(Text, { bold: true, color: COLOR_SUPABASE }, "D"),
|
|
24
|
+
"efinitions")),
|
|
25
25
|
React.createElement(Text, { dimColor: true },
|
|
26
26
|
"v",
|
|
27
27
|
packageJson.version))));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Branding.js","sourceRoot":"","sources":["../../src/components/Branding.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,WAAW,CAAC;AAClC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,WAAW,MAAM,oBAAoB,CAAC,SAAS,IAAI,EAAE,MAAM,EAAE,CAAC;AACrE,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;
|
|
1
|
+
{"version":3,"file":"Branding.js","sourceRoot":"","sources":["../../src/components/Branding.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,WAAW,CAAC;AAClC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,WAAW,MAAM,oBAAoB,CAAC,SAAS,IAAI,EAAE,MAAM,EAAE,CAAC;AACrE,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAM9E,MAAM,CAAC,OAAO,UAAU,QAAQ,CAAC,EAAE,QAAQ,EAAS;IAClD,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,GAAG,qBAAqB,EAAE,CAAC;IAEvD,MAAM,UAAU,GAAG,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,aAAa,CAAC;IACtF,OAAO,CACL,oBAAC,GAAG,IAAC,YAAY,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,aAAa,EAAC,QAAQ;QAChE,oBAAC,GAAG,IAAC,GAAG,EAAE,CAAC;YACT,oBAAC,KAAK,IAAC,KAAK,EAAE,UAAU,aAAgB;YACvC,QAAQ,CAAC,CAAC,CAAC,CACV,oBAAC,IAAI,QAAE,QAAQ,CAAQ,CACxB,CAAC,CAAC,CAAC,CACF,oBAAC,IAAI;gBACH,oBAAC,IAAI,IAAC,IAAI,QAAC,KAAK,EAAE,cAAc,QAEzB;;gBACC,GAAG;gBACX,oBAAC,IAAI,IAAC,IAAI,QAAC,KAAK,EAAE,cAAc,QAEzB;;gBACG,GAAG;gBACb,oBAAC,IAAI,IAAC,IAAI,QAAC,KAAK,EAAE,cAAc,QAEzB;;gBACC,GAAG;gBACX,oBAAC,IAAI,IAAC,IAAI,QAAC,KAAK,EAAE,cAAc,QAEzB;6BAEF,CACR;YACD,oBAAC,IAAI,IAAC,QAAQ;;gBAAG,WAAW,CAAC,OAAO,CAAQ,CACxC,CACF,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
import { Box, Text, useInput } from 'ink';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { getConnectionStats } from '../utils/databaseConnection.js';
|
|
4
|
+
import { store } from '../utils/store.js';
|
|
5
|
+
function getResourceInfo() {
|
|
6
|
+
// @ts-expect-error
|
|
7
|
+
const handles = process._getActiveHandles?.() || [];
|
|
8
|
+
// @ts-expect-error
|
|
9
|
+
const requests = process._getActiveRequests?.() || [];
|
|
10
|
+
const handlesByType = handles
|
|
11
|
+
.map((h) => h?.constructor?.name)
|
|
12
|
+
.filter(Boolean)
|
|
13
|
+
.reduce((acc, name) => {
|
|
14
|
+
acc[name] = (acc[name] || 0) + 1;
|
|
15
|
+
return acc;
|
|
16
|
+
}, {});
|
|
17
|
+
return {
|
|
18
|
+
// File System
|
|
19
|
+
watchers: handlesByType.FSWatcher || 0,
|
|
20
|
+
events: handlesByType.FSEventWrap || 0,
|
|
21
|
+
// Timing
|
|
22
|
+
timers: handlesByType.Timeout || 0,
|
|
23
|
+
intervals: handlesByType.Interval || 0,
|
|
24
|
+
immediates: handlesByType.Immediate || 0,
|
|
25
|
+
// IO & Network
|
|
26
|
+
sockets: handlesByType.Socket || 0,
|
|
27
|
+
servers: handlesByType.Server || 0,
|
|
28
|
+
tcpWraps: handlesByType.TCP || 0,
|
|
29
|
+
pipes: handlesByType.Pipe || 0,
|
|
30
|
+
ttys: handlesByType.TTY || 0,
|
|
31
|
+
// Process
|
|
32
|
+
checks: handlesByType.Check || 0,
|
|
33
|
+
signals: handlesByType.Signal || 0,
|
|
34
|
+
// Other
|
|
35
|
+
asyncHooks: handlesByType.AsyncHook || 0,
|
|
36
|
+
requests: requests.length,
|
|
37
|
+
// Count handles not explicitly tracked
|
|
38
|
+
misc: Object.entries(handlesByType)
|
|
39
|
+
.filter(([k]) => ![
|
|
40
|
+
'FSWatcher',
|
|
41
|
+
'FSEventWrap',
|
|
42
|
+
'Timeout',
|
|
43
|
+
'Interval',
|
|
44
|
+
'Immediate',
|
|
45
|
+
'Socket',
|
|
46
|
+
'Server',
|
|
47
|
+
'TCP',
|
|
48
|
+
'Pipe',
|
|
49
|
+
'TTY',
|
|
50
|
+
'Check',
|
|
51
|
+
'Signal',
|
|
52
|
+
'AsyncHook',
|
|
53
|
+
].includes(k))
|
|
54
|
+
.reduce((sum, [_, count]) => sum + (count || 0), 0),
|
|
55
|
+
total: handles.length + requests.length,
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
export default function Debug() {
|
|
59
|
+
const [enabled, setEnabled] = React.useState(store.get('debugEnabled'));
|
|
60
|
+
const [stats, setStats] = React.useState({
|
|
61
|
+
db: getConnectionStats(),
|
|
62
|
+
resources: getResourceInfo(),
|
|
63
|
+
});
|
|
64
|
+
useInput(input => {
|
|
65
|
+
if (input === 'd') {
|
|
66
|
+
const newState = !enabled;
|
|
67
|
+
setEnabled(newState);
|
|
68
|
+
store.set('debugEnabled', newState);
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
React.useEffect(() => {
|
|
72
|
+
if (!enabled)
|
|
73
|
+
return;
|
|
74
|
+
const interval = setInterval(() => {
|
|
75
|
+
setStats({
|
|
76
|
+
db: getConnectionStats(),
|
|
77
|
+
resources: getResourceInfo(),
|
|
78
|
+
});
|
|
79
|
+
}, 1000);
|
|
80
|
+
return () => clearInterval(interval);
|
|
81
|
+
}, [enabled]);
|
|
82
|
+
if (!enabled)
|
|
83
|
+
return null;
|
|
84
|
+
return (React.createElement(Box, { flexDirection: "column", marginY: 1 },
|
|
85
|
+
React.createElement(Box, { flexDirection: "row", gap: 1 },
|
|
86
|
+
React.createElement(Text, { bold: true }, "Debug:"),
|
|
87
|
+
React.createElement(Text, { dimColor: true }, "(press 'd' to toggle)")),
|
|
88
|
+
React.createElement(Box, { paddingLeft: 2, flexDirection: "column" },
|
|
89
|
+
React.createElement(Text, { dimColor: true },
|
|
90
|
+
"\uD83D\uDCBE DB: ",
|
|
91
|
+
stats.db ? `${stats.db.active} active, ${stats.db.idle} idle` : 'none'),
|
|
92
|
+
React.createElement(Text, { dimColor: true },
|
|
93
|
+
"\uD83D\uDCCA Resources (",
|
|
94
|
+
stats.resources.total,
|
|
95
|
+
" total):"),
|
|
96
|
+
React.createElement(Box, { paddingLeft: 3, flexDirection: "row", gap: 2 },
|
|
97
|
+
React.createElement(Text, { dimColor: true },
|
|
98
|
+
"\uD83D\uDC40 ",
|
|
99
|
+
stats.resources.watchers,
|
|
100
|
+
" watch"),
|
|
101
|
+
React.createElement(Text, { dimColor: true },
|
|
102
|
+
"\uD83D\uDCE1 ",
|
|
103
|
+
stats.resources.events,
|
|
104
|
+
" event"),
|
|
105
|
+
React.createElement(Text, { dimColor: true },
|
|
106
|
+
"\u23F3 ",
|
|
107
|
+
stats.resources.timers,
|
|
108
|
+
" timer"),
|
|
109
|
+
React.createElement(Text, { dimColor: true },
|
|
110
|
+
"\uD83D\uDD04 ",
|
|
111
|
+
stats.resources.intervals,
|
|
112
|
+
" intv"),
|
|
113
|
+
React.createElement(Text, { dimColor: true },
|
|
114
|
+
"\u26A1\uFE0F ",
|
|
115
|
+
stats.resources.immediates,
|
|
116
|
+
" imm")),
|
|
117
|
+
React.createElement(Box, { paddingLeft: 3, flexDirection: "row", gap: 2 },
|
|
118
|
+
React.createElement(Text, { dimColor: true },
|
|
119
|
+
"\uD83D\uDD0C ",
|
|
120
|
+
stats.resources.sockets,
|
|
121
|
+
" sock"),
|
|
122
|
+
React.createElement(Text, { dimColor: true },
|
|
123
|
+
"\uD83D\uDDA5\uFE0F ",
|
|
124
|
+
stats.resources.servers,
|
|
125
|
+
" srv"),
|
|
126
|
+
React.createElement(Text, { dimColor: true },
|
|
127
|
+
"\uD83C\uDF10 ",
|
|
128
|
+
stats.resources.tcpWraps,
|
|
129
|
+
" tcp"),
|
|
130
|
+
React.createElement(Text, { dimColor: true },
|
|
131
|
+
"\uD83D\uDCDD ",
|
|
132
|
+
stats.resources.pipes,
|
|
133
|
+
" pipe"),
|
|
134
|
+
React.createElement(Text, { dimColor: true },
|
|
135
|
+
"\uD83D\uDCBB ",
|
|
136
|
+
stats.resources.ttys,
|
|
137
|
+
" tty")),
|
|
138
|
+
React.createElement(Box, { paddingLeft: 3, flexDirection: "row", gap: 2 },
|
|
139
|
+
React.createElement(Text, { dimColor: true },
|
|
140
|
+
"\uD83D\uDD0D ",
|
|
141
|
+
stats.resources.checks,
|
|
142
|
+
" chk"),
|
|
143
|
+
React.createElement(Text, { dimColor: true },
|
|
144
|
+
"\u26A1 ",
|
|
145
|
+
stats.resources.signals,
|
|
146
|
+
" sig"),
|
|
147
|
+
React.createElement(Text, { dimColor: true },
|
|
148
|
+
"\uD83C\uDFA3 ",
|
|
149
|
+
stats.resources.asyncHooks,
|
|
150
|
+
" hook"),
|
|
151
|
+
React.createElement(Text, { dimColor: true },
|
|
152
|
+
"\uD83D\uDCE5 ",
|
|
153
|
+
stats.resources.requests,
|
|
154
|
+
" req"),
|
|
155
|
+
stats.resources.misc > 0 && React.createElement(Text, { dimColor: true },
|
|
156
|
+
"\u2753 ",
|
|
157
|
+
stats.resources.misc,
|
|
158
|
+
" misc")))));
|
|
159
|
+
}
|
|
160
|
+
//# sourceMappingURL=Debug.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Debug.js","sourceRoot":"","sources":["../../src/components/Debug.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { ProcessedTemplateResult } from '../types.js';
|
|
3
|
+
interface Props {
|
|
4
|
+
result: ProcessedTemplateResult;
|
|
5
|
+
showBuild?: boolean;
|
|
6
|
+
showApply?: boolean;
|
|
7
|
+
}
|
|
8
|
+
export declare function ProcessingResults({ result, showBuild, showApply }: Props): React.JSX.Element;
|
|
9
|
+
export {};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Box, Text } from 'ink';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { COLOR_ERROR } from './customTheme.js';
|
|
4
|
+
function ResultSection({ items, label }) {
|
|
5
|
+
if (items.length === 0)
|
|
6
|
+
return null;
|
|
7
|
+
return (React.createElement(Box, { flexDirection: "column" },
|
|
8
|
+
React.createElement(Text, null,
|
|
9
|
+
label,
|
|
10
|
+
":"),
|
|
11
|
+
items.map(item => (React.createElement(Text, { key: item },
|
|
12
|
+
" \u2713 ",
|
|
13
|
+
item)))));
|
|
14
|
+
}
|
|
15
|
+
export function ProcessingResults({ result, showBuild = true, showApply = false }) {
|
|
16
|
+
return (React.createElement(Box, { flexDirection: "column", gap: 1 },
|
|
17
|
+
showBuild && React.createElement(ResultSection, { items: result.built, label: "Built" }),
|
|
18
|
+
showApply && React.createElement(ResultSection, { items: result.applied, label: "Applied" }),
|
|
19
|
+
result.skipped.length > 0 && (React.createElement(Text, { dimColor: true },
|
|
20
|
+
"Skipped ",
|
|
21
|
+
result.skipped.length,
|
|
22
|
+
" template(s)")),
|
|
23
|
+
result.errors.length > 0 && (React.createElement(Box, { flexDirection: "column" },
|
|
24
|
+
React.createElement(Text, { color: COLOR_ERROR }, "Errors:"),
|
|
25
|
+
result.errors.map(error => (React.createElement(Text, { key: error.file, color: COLOR_ERROR },
|
|
26
|
+
"\u2717 ",
|
|
27
|
+
error.templateName,
|
|
28
|
+
": ",
|
|
29
|
+
error.error))))),
|
|
30
|
+
!result.built.length && !result.applied.length && !result.errors.length && (React.createElement(Text, null, "No changes made"))));
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=ProcessingResults.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProcessingResults.js","sourceRoot":"","sources":["../../src/components/ProcessingResults.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAQ/C,SAAS,aAAa,CAAC,EAAE,KAAK,EAAE,KAAK,EAAsC;IACzE,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IAEpC,OAAO,CACL,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ;QACzB,oBAAC,IAAI;YAAE,KAAK;gBAAS;QACpB,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CACjB,oBAAC,IAAI,IAAC,GAAG,EAAE,IAAI;;YAAM,IAAI,CAAQ,CAClC,CAAC,CACE,CACP,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,EAAE,MAAM,EAAE,SAAS,GAAG,IAAI,EAAE,SAAS,GAAG,KAAK,EAAS;IACtF,OAAO,CACL,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,GAAG,EAAE,CAAC;QAC/B,SAAS,IAAI,oBAAC,aAAa,IAAC,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,KAAK,EAAC,OAAO,GAAG;QAEjE,SAAS,IAAI,oBAAC,aAAa,IAAC,KAAK,EAAE,MAAM,CAAC,OAAO,EAAE,KAAK,EAAC,SAAS,GAAG;QAErE,MAAM,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,CAC5B,oBAAC,IAAI,IAAC,QAAQ;;YAAU,MAAM,CAAC,OAAO,CAAC,MAAM;2BAAoB,CAClE;QAEA,MAAM,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,IAAI,CAC3B,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ;YACzB,oBAAC,IAAI,IAAC,KAAK,EAAE,WAAW,cAAgB;YACvC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAC1B,oBAAC,IAAI,IAAC,GAAG,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,WAAW;;gBACpC,KAAK,CAAC,YAAY;;gBAAI,KAAK,CAAC,KAAK,CAC/B,CACR,CAAC,CACE,CACP;QAEA,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,IAAI,CAC1E,oBAAC,IAAI,0BAAuB,CAC7B,CACG,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -27,7 +27,7 @@ export default function Quittable(props) {
|
|
|
27
27
|
}
|
|
28
28
|
});
|
|
29
29
|
return (React.createElement(Box, { marginY: 1 },
|
|
30
|
-
React.createElement(Text, { dimColor: true }, "
|
|
30
|
+
React.createElement(Text, { dimColor: true }, "Press "),
|
|
31
31
|
React.createElement(Text, null, "q"),
|
|
32
32
|
React.createElement(Text, { dimColor: true }, " or "),
|
|
33
33
|
React.createElement(Text, null, "Ctrl+c"),
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export declare const COLOR_SUPABASE = "#3ecf8e";
|
|
2
|
+
export declare const COLOR_ACCENT = "magenta";
|
|
3
|
+
export declare const COLOR_SUCCESS = "green";
|
|
4
|
+
export declare const COLOR_ERROR = "red";
|
|
5
|
+
export declare const COLOR_WARNING = "yellow";
|
|
6
|
+
export declare const COLOR_SKIP = "gray";
|
|
7
|
+
export declare const OPTION_COLOR_SELECTED = "green";
|
|
8
|
+
export declare const customTheme: {
|
|
9
|
+
components: Record<string, import("@inkjs/ui").ComponentTheme>;
|
|
10
|
+
};
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { defaultTheme, extendTheme } from '@inkjs/ui';
|
|
2
|
+
export const COLOR_SUPABASE = '#3ecf8e';
|
|
3
|
+
export const COLOR_ACCENT = 'magenta';
|
|
4
|
+
export const COLOR_SUCCESS = 'green';
|
|
5
|
+
export const COLOR_ERROR = 'red';
|
|
6
|
+
export const COLOR_WARNING = 'yellow';
|
|
7
|
+
export const COLOR_SKIP = 'gray';
|
|
8
|
+
export const OPTION_COLOR_SELECTED = 'green';
|
|
9
|
+
export const customTheme = extendTheme(defaultTheme, {
|
|
10
|
+
components: {
|
|
11
|
+
Select: {
|
|
12
|
+
styles: {
|
|
13
|
+
focusIndicator: () => ({
|
|
14
|
+
color: COLOR_ACCENT,
|
|
15
|
+
bold: true,
|
|
16
|
+
}),
|
|
17
|
+
label({ isSelected, isFocused }) {
|
|
18
|
+
let color;
|
|
19
|
+
let bold;
|
|
20
|
+
if (isSelected && isFocused) {
|
|
21
|
+
color = OPTION_COLOR_SELECTED;
|
|
22
|
+
bold = true;
|
|
23
|
+
}
|
|
24
|
+
else if (isSelected) {
|
|
25
|
+
color = OPTION_COLOR_SELECTED;
|
|
26
|
+
}
|
|
27
|
+
else if (isFocused) {
|
|
28
|
+
color = COLOR_ACCENT;
|
|
29
|
+
}
|
|
30
|
+
return { color, bold };
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
},
|
|
34
|
+
MultiSelect: {
|
|
35
|
+
styles: {
|
|
36
|
+
focusIndicator: () => ({
|
|
37
|
+
color: COLOR_ACCENT,
|
|
38
|
+
bold: true,
|
|
39
|
+
}),
|
|
40
|
+
label({ isFocused, isSelected }) {
|
|
41
|
+
let color;
|
|
42
|
+
let bold;
|
|
43
|
+
if (isSelected && isFocused) {
|
|
44
|
+
color = OPTION_COLOR_SELECTED;
|
|
45
|
+
bold = true;
|
|
46
|
+
}
|
|
47
|
+
else if (isSelected) {
|
|
48
|
+
color = OPTION_COLOR_SELECTED;
|
|
49
|
+
}
|
|
50
|
+
else if (isFocused) {
|
|
51
|
+
color = COLOR_ACCENT;
|
|
52
|
+
}
|
|
53
|
+
return { color, bold };
|
|
54
|
+
},
|
|
55
|
+
},
|
|
56
|
+
},
|
|
57
|
+
Spinner: {
|
|
58
|
+
styles: {
|
|
59
|
+
frame: () => ({
|
|
60
|
+
color: COLOR_ACCENT,
|
|
61
|
+
}),
|
|
62
|
+
},
|
|
63
|
+
},
|
|
64
|
+
},
|
|
65
|
+
});
|
|
66
|
+
//# sourceMappingURL=customTheme.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"customTheme.js","sourceRoot":"","sources":["../../src/components/customTheme.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAGtD,MAAM,CAAC,MAAM,cAAc,GAAG,SAAS,CAAC;AACxC,MAAM,CAAC,MAAM,YAAY,GAAG,SAAS,CAAC;AACtC,MAAM,CAAC,MAAM,aAAa,GAAG,OAAO,CAAC;AACrC,MAAM,CAAC,MAAM,WAAW,GAAG,KAAK,CAAC;AACjC,MAAM,CAAC,MAAM,aAAa,GAAG,QAAQ,CAAC;AACtC,MAAM,CAAC,MAAM,UAAU,GAAG,MAAM,CAAC;AACjC,MAAM,CAAC,MAAM,qBAAqB,GAAG,OAAO,CAAC;AAE7C,MAAM,CAAC,MAAM,WAAW,GAAG,WAAW,CAAC,YAAY,EAAE;IACnD,UAAU,EAAE;QACV,MAAM,EAAE;YACN,MAAM,EAAE;gBACN,cAAc,EAAE,GAAc,EAAE,CAAC,CAAC;oBAChC,KAAK,EAAE,YAAY;oBACnB,IAAI,EAAE,IAAI;iBACX,CAAC;gBACF,KAAK,CAAC,EAAE,UAAU,EAAE,SAAS,EAAE;oBAC7B,IAAI,KAAyB,CAAC;oBAC9B,IAAI,IAAyB,CAAC;oBAE9B,IAAI,UAAU,IAAI,SAAS,EAAE,CAAC;wBAC5B,KAAK,GAAG,qBAAqB,CAAC;wBAC9B,IAAI,GAAG,IAAI,CAAC;oBACd,CAAC;yBAAM,IAAI,UAAU,EAAE,CAAC;wBACtB,KAAK,GAAG,qBAAqB,CAAC;oBAChC,CAAC;yBAAM,IAAI,SAAS,EAAE,CAAC;wBACrB,KAAK,GAAG,YAAY,CAAC;oBACvB,CAAC;oBAED,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;gBACzB,CAAC;aACF;SACF;QACD,WAAW,EAAE;YACX,MAAM,EAAE;gBACN,cAAc,EAAE,GAAc,EAAE,CAAC,CAAC;oBAChC,KAAK,EAAE,YAAY;oBACnB,IAAI,EAAE,IAAI;iBACX,CAAC;gBACF,KAAK,CAAC,EAAE,SAAS,EAAE,UAAU,EAAE;oBAC7B,IAAI,KAAyB,CAAC;oBAC9B,IAAI,IAAyB,CAAC;oBAE9B,IAAI,UAAU,IAAI,SAAS,EAAE,CAAC;wBAC5B,KAAK,GAAG,qBAAqB,CAAC;wBAC9B,IAAI,GAAG,IAAI,CAAC;oBACd,CAAC;yBAAM,IAAI,UAAU,EAAE,CAAC;wBACtB,KAAK,GAAG,qBAAqB,CAAC;oBAChC,CAAC;yBAAM,IAAI,SAAS,EAAE,CAAC;wBACrB,KAAK,GAAG,YAAY,CAAC;oBACvB,CAAC;oBAED,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;gBACzB,CAAC;aACF;SACF;QACD,OAAO,EAAE;YACP,MAAM,EAAE;gBACN,KAAK,EAAE,GAAc,EAAE,CAAC,CAAC;oBACvB,KAAK,EAAE,YAAY;iBACpB,CAAC;aACH;SACF;KACF;CACF,CAAC,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// hooks/useDatabaseConnection.ts
|
|
2
2
|
import { useEffect, useState } from 'react';
|
|
3
|
-
import {
|
|
3
|
+
import { testConnection } from '../utils/databaseConnection.js';
|
|
4
4
|
function parseDbError(error) {
|
|
5
5
|
if (error instanceof Error) {
|
|
6
6
|
if (error.message.includes('Connection terminated unexpectedly')) {
|
|
@@ -13,56 +13,45 @@ function parseDbError(error) {
|
|
|
13
13
|
}
|
|
14
14
|
return String(error);
|
|
15
15
|
}
|
|
16
|
-
export function useDatabaseConnection(checkInterval =
|
|
16
|
+
export function useDatabaseConnection(checkInterval = 3000) {
|
|
17
17
|
const [state, setState] = useState({
|
|
18
18
|
isConnected: false,
|
|
19
19
|
isChecking: true,
|
|
20
20
|
});
|
|
21
21
|
useEffect(() => {
|
|
22
22
|
let mounted = true;
|
|
23
|
-
let timeoutId;
|
|
24
|
-
let intervalId = undefined;
|
|
25
23
|
async function checkConnection() {
|
|
26
24
|
if (!mounted)
|
|
27
25
|
return;
|
|
28
26
|
setState(prev => ({ ...prev, isChecking: true }));
|
|
29
27
|
try {
|
|
30
|
-
const
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
28
|
+
const isConnected = await testConnection();
|
|
29
|
+
if (!mounted)
|
|
30
|
+
return;
|
|
31
|
+
setState({
|
|
32
|
+
isConnected,
|
|
33
|
+
error: undefined,
|
|
34
|
+
isChecking: false,
|
|
35
35
|
});
|
|
36
|
-
const isConnected = await Promise.race([connectionPromise, timeoutPromise]);
|
|
37
|
-
if (mounted) {
|
|
38
|
-
setState({
|
|
39
|
-
isConnected,
|
|
40
|
-
error: undefined,
|
|
41
|
-
isChecking: false,
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
36
|
}
|
|
45
37
|
catch (err) {
|
|
46
|
-
if (mounted)
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
finally {
|
|
55
|
-
clearTimeout(timeoutId);
|
|
38
|
+
if (!mounted)
|
|
39
|
+
return;
|
|
40
|
+
setState({
|
|
41
|
+
isConnected: false,
|
|
42
|
+
error: parseDbError(err),
|
|
43
|
+
isChecking: false,
|
|
44
|
+
});
|
|
56
45
|
}
|
|
57
46
|
}
|
|
58
|
-
checkConnection();
|
|
59
|
-
intervalId = setInterval(checkConnection, checkInterval);
|
|
47
|
+
void checkConnection();
|
|
48
|
+
const intervalId = !state.isConnected ? setInterval(checkConnection, checkInterval) : undefined;
|
|
60
49
|
return () => {
|
|
61
50
|
mounted = false;
|
|
62
|
-
|
|
63
|
-
|
|
51
|
+
if (intervalId)
|
|
52
|
+
clearInterval(intervalId);
|
|
64
53
|
};
|
|
65
|
-
}, [checkInterval]);
|
|
54
|
+
}, [checkInterval, state.isConnected]);
|
|
66
55
|
return state;
|
|
67
56
|
}
|
|
68
57
|
//# sourceMappingURL=useDatabaseConnection.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useDatabaseConnection.js","sourceRoot":"","sources":["../../src/hooks/useDatabaseConnection.ts"],"names":[],"mappings":"AAAA,iCAAiC;AACjC,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"useDatabaseConnection.js","sourceRoot":"","sources":["../../src/hooks/useDatabaseConnection.ts"],"names":[],"mappings":"AAAA,iCAAiC;AACjC,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,gCAAgC,CAAC;AAQhE,SAAS,YAAY,CAAC,KAAc;IAClC,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;QAC3B,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,oCAAoC,CAAC,EAAE,CAAC;YACjE,OAAO,gDAAgD,CAAC;QAC1D,CAAC;QACD,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC;YAC3C,OAAO,qDAAqD,CAAC;QAC/D,CAAC;QACD,OAAO,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC;IACvD,CAAC;IACD,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC;AACvB,CAAC;AAED,MAAM,UAAU,qBAAqB,CAAC,aAAa,GAAG,IAAI;IACxD,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAoB;QACpD,WAAW,EAAE,KAAK;QAClB,UAAU,EAAE,IAAI;KACjB,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,OAAO,GAAG,IAAI,CAAC;QAEnB,KAAK,UAAU,eAAe;YAC5B,IAAI,CAAC,OAAO;gBAAE,OAAO;YACrB,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;YAElD,IAAI,CAAC;gBACH,MAAM,WAAW,GAAG,MAAM,cAAc,EAAE,CAAC;gBAC3C,IAAI,CAAC,OAAO;oBAAE,OAAO;gBACrB,QAAQ,CAAC;oBACP,WAAW;oBACX,KAAK,EAAE,SAAS;oBAChB,UAAU,EAAE,KAAK;iBAClB,CAAC,CAAC;YACL,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,IAAI,CAAC,OAAO;oBAAE,OAAO;gBACrB,QAAQ,CAAC;oBACP,WAAW,EAAE,KAAK;oBAClB,KAAK,EAAE,YAAY,CAAC,GAAG,CAAC;oBACxB,UAAU,EAAE,KAAK;iBAClB,CAAC,CAAC;YACL,CAAC;QACH,CAAC;QAED,KAAK,eAAe,EAAE,CAAC;QAEvB,MAAM,UAAU,GAAG,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,eAAe,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAEhG,OAAO,GAAG,EAAE;YACV,OAAO,GAAG,KAAK,CAAC;YAChB,IAAI,UAAU;gBAAE,aAAa,CAAC,UAAU,CAAC,CAAC;QAC5C,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,aAAa,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC;IAEvC,OAAO,KAAK,CAAC;AACf,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { ProcessedTemplateResult } from '../types.js';
|
|
2
|
+
interface ProcessorOptions {
|
|
3
|
+
force?: boolean;
|
|
4
|
+
apply?: boolean;
|
|
5
|
+
generateFiles?: boolean;
|
|
6
|
+
}
|
|
7
|
+
export declare function useTemplateProcessor(options: ProcessorOptions): {
|
|
8
|
+
result: ProcessedTemplateResult;
|
|
9
|
+
isProcessing: boolean;
|
|
10
|
+
};
|
|
11
|
+
export {};
|