@tamagui/cli 1.140.3 → 1.141.0

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.
@@ -0,0 +1,281 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf, __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: !0 });
9
+ }, __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from == "object" || typeof from == "function")
11
+ for (let key of __getOwnPropNames(from))
12
+ !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
13
+ return to;
14
+ };
15
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
16
+ // If the importer is in node compatibility mode or this is not an ESM
17
+ // file that has been converted to a CommonJS file using a Babel-
18
+ // compatible transform (i.e. "__esModule" has not been set), then set
19
+ // "default" to the CommonJS "module.exports" for node compatibility.
20
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: !0 }) : target,
21
+ mod
22
+ )), __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: !0 }), mod);
23
+ var upgrade_exports = {};
24
+ __export(upgrade_exports, {
25
+ upgrade: () => upgrade
26
+ });
27
+ module.exports = __toCommonJS(upgrade_exports);
28
+ var import_chalk = __toESM(require("chalk")), import_node_child_process = require("node:child_process"), import_node_fs = require("node:fs"), import_node_path = require("node:path");
29
+ const TAMAGUI_PACKAGES_PATTERN = /^(@tamagui\/|tamagui$)/, COMMIT_TYPE_ORDER = ["feat", "fix", "perf", "refactor", "docs", "chore", "test", "ci"];
30
+ function parseVersionSpecifier(version) {
31
+ return version.startsWith(">=") ? { specifier: ">=", cleanVersion: version.slice(2) } : version.startsWith(">") ? { specifier: ">", cleanVersion: version.slice(1) } : version.startsWith("^") ? { specifier: "^", cleanVersion: version.slice(1) } : version.startsWith("~") ? { specifier: "~", cleanVersion: version.slice(1) } : version.startsWith("workspace:") ? { specifier: "", cleanVersion: version } : { specifier: "", cleanVersion: version };
32
+ }
33
+ function findPackageJsonFiles(root) {
34
+ const files = [], rootPkgPath = (0, import_node_path.join)(root, "package.json");
35
+ (0, import_node_fs.existsSync)(rootPkgPath) && files.push(rootPkgPath);
36
+ try {
37
+ const foundFiles = (0, import_node_child_process.execSync)(
38
+ `find "${root}" -name "package.json" -not -path "*/node_modules/*" -not -path "*/.git/*" 2>/dev/null`,
39
+ { encoding: "utf-8", maxBuffer: 10485760 }
40
+ ).trim().split(`
41
+ `).filter(Boolean);
42
+ files.push(...foundFiles.filter((f) => !files.includes(f)));
43
+ } catch {
44
+ }
45
+ return files;
46
+ }
47
+ function findTamaguiPackages(root) {
48
+ const packageJsonFiles = findPackageJsonFiles(root), packages = [];
49
+ for (const filePath of packageJsonFiles)
50
+ try {
51
+ const content = (0, import_node_fs.readFileSync)(filePath, "utf-8"), pkg = JSON.parse(content), depTypes = ["dependencies", "devDependencies", "peerDependencies"];
52
+ for (const depType of depTypes) {
53
+ const deps = pkg[depType];
54
+ if (deps)
55
+ for (const [name, version] of Object.entries(deps)) {
56
+ if (typeof version != "string" || !TAMAGUI_PACKAGES_PATTERN.test(name) || version.startsWith("workspace:")) continue;
57
+ const { specifier, cleanVersion } = parseVersionSpecifier(version);
58
+ packages.push({
59
+ name,
60
+ version: cleanVersion,
61
+ versionSpecifier: specifier,
62
+ filePath,
63
+ depType
64
+ });
65
+ }
66
+ }
67
+ } catch {
68
+ }
69
+ return packages;
70
+ }
71
+ async function getLatestVersion() {
72
+ try {
73
+ return (0, import_node_child_process.execSync)("npm view tamagui version", { encoding: "utf-8" }).trim();
74
+ } catch {
75
+ throw new Error("Failed to fetch latest tamagui version from npm");
76
+ }
77
+ }
78
+ function getCurrentVersion(packages) {
79
+ const versions = packages.map((p) => p.version);
80
+ if (versions.length === 0) return null;
81
+ const counts = /* @__PURE__ */ new Map();
82
+ for (const v of versions)
83
+ counts.set(v, (counts.get(v) || 0) + 1);
84
+ let maxCount = 0, mostCommon = versions[0];
85
+ for (const [v, count] of counts)
86
+ count > maxCount && (maxCount = count, mostCommon = v);
87
+ return mostCommon;
88
+ }
89
+ function parseConventionalCommit(message) {
90
+ const match = message.match(/^(\w+)(?:\(([^)]+)\))?(!)?: (.+)$/);
91
+ if (!match) return null;
92
+ const [, type, scope, breaking, msg] = match;
93
+ return ["feat", "fix", "perf", "refactor", "docs", "chore", "test", "ci", "build", "style"].includes(type) ? {
94
+ type,
95
+ scope,
96
+ message: msg,
97
+ breaking: !!breaking || message.toLowerCase().includes("breaking")
98
+ } : null;
99
+ }
100
+ function getChangelogFromGit(fromVersion, toVersion, debug) {
101
+ const commits = [];
102
+ try {
103
+ try {
104
+ (0, import_node_child_process.execSync)("git fetch --tags 2>/dev/null", { encoding: "utf-8", stdio: "pipe" });
105
+ } catch {
106
+ }
107
+ const fromTag = `v${fromVersion}`, toTag = `v${toVersion}`;
108
+ debug && console.log(import_chalk.default.gray(` Looking for commits between ${fromTag} and ${toTag}...`));
109
+ let result;
110
+ try {
111
+ result = (0, import_node_child_process.execSync)(
112
+ `git log ${fromTag}..${toTag} --pretty=format:"%H|%ad|%s" --date=short 2>/dev/null`,
113
+ { encoding: "utf-8", maxBuffer: 10 * 1024 * 1024 }
114
+ );
115
+ } catch {
116
+ return debug && console.log(import_chalk.default.gray(" Tags not found, trying alternative approach...")), commits;
117
+ }
118
+ const lines = result.trim().split(`
119
+ `).filter(Boolean);
120
+ for (const line of lines) {
121
+ const [hash, date, ...messageParts] = line.split("|"), message = messageParts.join("|"), parsed = parseConventionalCommit(message);
122
+ parsed && (["docs", "ci", "test", "build", "style"].includes(parsed.type) || commits.push({
123
+ hash: hash.slice(0, 7),
124
+ type: parsed.type,
125
+ scope: parsed.scope,
126
+ message: parsed.message,
127
+ breaking: parsed.breaking,
128
+ date
129
+ }));
130
+ }
131
+ } catch (err) {
132
+ debug && console.log(import_chalk.default.gray(` Could not fetch git history: ${err}`));
133
+ }
134
+ return commits;
135
+ }
136
+ async function getChangelogFromGitHub(fromVersion, toVersion, debug) {
137
+ try {
138
+ const response = await fetch(
139
+ `https://api.github.com/repos/tamagui/tamagui/releases/tags/v${toVersion}`,
140
+ {
141
+ headers: {
142
+ Accept: "application/vnd.github.v3+json",
143
+ "User-Agent": "tamagui-cli"
144
+ }
145
+ }
146
+ );
147
+ return response.ok ? (await response.json()).body || null : (debug && console.log(import_chalk.default.gray(` GitHub API returned ${response.status}`)), null);
148
+ } catch (err) {
149
+ return debug && console.log(import_chalk.default.gray(` Could not fetch from GitHub: ${err}`)), null;
150
+ }
151
+ }
152
+ function formatChangelog(commits) {
153
+ if (commits.length === 0)
154
+ return import_chalk.default.gray(" No changes found");
155
+ const grouped = /* @__PURE__ */ new Map();
156
+ for (const commit of commits) {
157
+ const existing = grouped.get(commit.type) || [];
158
+ existing.push(commit), grouped.set(commit.type, existing);
159
+ }
160
+ const sortedTypes = Array.from(grouped.keys()).sort((a, b) => {
161
+ const aIdx = COMMIT_TYPE_ORDER.indexOf(a), bIdx = COMMIT_TYPE_ORDER.indexOf(b);
162
+ return (aIdx === -1 ? 999 : aIdx) - (bIdx === -1 ? 999 : bIdx);
163
+ }), lines = [], breakingChanges = commits.filter((c) => c.breaking);
164
+ if (breakingChanges.length > 0) {
165
+ lines.push(""), lines.push(import_chalk.default.red.bold(" BREAKING CHANGES"));
166
+ for (const commit of breakingChanges) {
167
+ const scope = commit.scope ? import_chalk.default.cyan(`(${commit.scope})`) : "";
168
+ lines.push(` ${import_chalk.default.red("!")} ${scope} ${commit.message} ${import_chalk.default.gray(`(${commit.hash})`)}`);
169
+ }
170
+ }
171
+ const typeLabels = {
172
+ feat: "Features",
173
+ fix: "Bug Fixes",
174
+ perf: "Performance",
175
+ refactor: "Refactoring",
176
+ docs: "Documentation",
177
+ chore: "Maintenance",
178
+ test: "Tests",
179
+ ci: "CI"
180
+ }, typeColors = {
181
+ feat: import_chalk.default.green,
182
+ fix: import_chalk.default.yellow,
183
+ perf: import_chalk.default.magenta,
184
+ refactor: import_chalk.default.blue,
185
+ docs: import_chalk.default.gray,
186
+ chore: import_chalk.default.gray,
187
+ test: import_chalk.default.gray,
188
+ ci: import_chalk.default.gray
189
+ };
190
+ for (const type of sortedTypes) {
191
+ const typeCommits = grouped.get(type).filter((c) => !c.breaking);
192
+ if (typeCommits.length === 0) continue;
193
+ const label = typeLabels[type] || type, color = typeColors[type] || import_chalk.default.white;
194
+ lines.push(""), lines.push(color.bold(` ${label}`));
195
+ for (const commit of typeCommits) {
196
+ const scope = commit.scope ? import_chalk.default.cyan(`(${commit.scope})`) : "";
197
+ lines.push(` ${import_chalk.default.gray("-")} ${scope} ${commit.message} ${import_chalk.default.gray(`(${commit.hash})`)}`);
198
+ }
199
+ }
200
+ return lines.join(`
201
+ `);
202
+ }
203
+ function displayPackageSummary(packages) {
204
+ console.log(""), console.log(import_chalk.default.bold("Found Tamagui packages:")), console.log("");
205
+ const byFile = /* @__PURE__ */ new Map();
206
+ for (const pkg of packages) {
207
+ const existing = byFile.get(pkg.filePath) || [];
208
+ existing.push(pkg), byFile.set(pkg.filePath, existing);
209
+ }
210
+ const allVersions = new Set(packages.map((p) => p.version));
211
+ for (const [filePath, pkgs] of byFile) {
212
+ const relativePath = filePath.replace(process.cwd(), ".").replace(/^\.\//, "");
213
+ console.log(import_chalk.default.cyan(` ${relativePath}`));
214
+ for (const pkg of pkgs) {
215
+ const versionDisplay = `${pkg.versionSpecifier}${pkg.version}`, depTypeLabel = pkg.depType === "devDependencies" ? import_chalk.default.gray(" (dev)") : pkg.depType === "peerDependencies" ? import_chalk.default.gray(" (peer)") : "";
216
+ console.log(` ${import_chalk.default.white(pkg.name)} ${import_chalk.default.yellow(versionDisplay)}${depTypeLabel}`);
217
+ }
218
+ console.log("");
219
+ }
220
+ if (allVersions.size > 1) {
221
+ console.log(import_chalk.default.yellow.bold("Warning: Version mismatch detected!")), console.log(import_chalk.default.yellow(" Found multiple versions:"));
222
+ for (const v of allVersions) {
223
+ const count = packages.filter((p) => p.version === v).length;
224
+ console.log(import_chalk.default.yellow(` - ${v} (${count} packages)`));
225
+ }
226
+ console.log("");
227
+ }
228
+ }
229
+ function updatePackages(packages, newVersion, dryRun) {
230
+ const byFile = /* @__PURE__ */ new Map();
231
+ for (const pkg of packages) {
232
+ const existing = byFile.get(pkg.filePath) || [];
233
+ existing.push(pkg), byFile.set(pkg.filePath, existing);
234
+ }
235
+ for (const [filePath, pkgs] of byFile) {
236
+ const content = (0, import_node_fs.readFileSync)(filePath, "utf-8"), pkgJson = JSON.parse(content);
237
+ for (const pkg of pkgs) {
238
+ const newVersionStr = `${pkg.versionSpecifier}${newVersion}`;
239
+ pkgJson[pkg.depType] && pkgJson[pkg.depType][pkg.name] && (pkgJson[pkg.depType][pkg.name] = newVersionStr);
240
+ }
241
+ dryRun || (0, import_node_fs.writeFileSync)(filePath, JSON.stringify(pkgJson, null, 2) + `
242
+ `);
243
+ const relativePath = filePath.replace(process.cwd(), ".").replace(/^\.\//, "");
244
+ console.log(import_chalk.default.green(` ${dryRun ? "[dry-run] " : ""}Updated ${relativePath}`));
245
+ }
246
+ }
247
+ async function upgrade(options = {}) {
248
+ const { from, to, changelogOnly, dryRun, debug } = options, root = process.cwd();
249
+ console.log(""), console.log(import_chalk.default.bold.blue("Tamagui Upgrade")), console.log("");
250
+ const packages = findTamaguiPackages(root);
251
+ if (packages.length === 0 && !changelogOnly) {
252
+ console.log(import_chalk.default.yellow("No Tamagui packages found in this workspace."));
253
+ return;
254
+ }
255
+ let fromVersion = from, toVersion = to;
256
+ if (!fromVersion && packages.length > 0 && (fromVersion = getCurrentVersion(packages) || void 0), toVersion || (console.log(import_chalk.default.gray("Fetching latest version from npm...")), toVersion = await getLatestVersion()), fromVersion || (changelogOnly && (console.log(import_chalk.default.red("Error: --from version is required when using --changelog-only without packages")), process.exit(1)), fromVersion = toVersion), console.log(import_chalk.default.gray(` Current version: ${import_chalk.default.white(fromVersion)}`)), console.log(import_chalk.default.gray(` Target version: ${import_chalk.default.white(toVersion)}`)), console.log(""), packages.length > 0 && !changelogOnly && displayPackageSummary(packages), fromVersion !== toVersion) {
257
+ console.log(import_chalk.default.bold("Changelog:")), console.log(import_chalk.default.gray(` (${fromVersion} -> ${toVersion})`));
258
+ const commits = getChangelogFromGit(fromVersion, toVersion, debug);
259
+ if (commits.length > 0)
260
+ console.log(formatChangelog(commits));
261
+ else {
262
+ const githubChangelog = await getChangelogFromGitHub(fromVersion, toVersion, debug);
263
+ if (githubChangelog) {
264
+ console.log(""), console.log(import_chalk.default.gray(" (from GitHub release notes)"));
265
+ const lines = githubChangelog.split(`
266
+ `).slice(0, 50);
267
+ for (const line of lines)
268
+ console.log(` ${line}`);
269
+ githubChangelog.split(`
270
+ `).length > 50 && console.log(import_chalk.default.gray(" ... (truncated, see full release notes on GitHub)"));
271
+ } else
272
+ console.log(import_chalk.default.gray(" No changelog available. Check https://github.com/tamagui/tamagui/releases"));
273
+ }
274
+ console.log("");
275
+ } else {
276
+ console.log(import_chalk.default.green("Already on the latest version!"));
277
+ return;
278
+ }
279
+ changelogOnly || (console.log(import_chalk.default.bold(`Upgrading to ${toVersion}${dryRun ? " (dry run)" : ""}:`)), console.log(""), updatePackages(packages, toVersion, dryRun), console.log(""), dryRun ? (console.log(import_chalk.default.yellow("Dry run complete. No files were modified.")), console.log(import_chalk.default.gray("Remove --dry-run to perform the actual upgrade."))) : (console.log(import_chalk.default.green.bold("Upgrade complete!")), console.log(""), console.log(import_chalk.default.gray("Next steps:")), console.log(import_chalk.default.gray(" 1. Run your package manager install (npm install, yarn, pnpm install)")), console.log(import_chalk.default.gray(" 2. Review the changelog above for any breaking changes")), console.log(import_chalk.default.gray(" 3. Test your application"))), console.log(""));
280
+ }
281
+ //# sourceMappingURL=upgrade.js.map
@@ -0,0 +1,6 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/upgrade.ts"],
4
+ "mappings": "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",
5
+ "names": ["chalk"]
6
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tamagui/cli",
3
- "version": "1.140.3",
3
+ "version": "1.141.0",
4
4
  "source": "src/index.ts",
5
5
  "types": "./types/index.d.ts",
6
6
  "main": "dist/index.cjs",
@@ -23,11 +23,11 @@
23
23
  "clean:build": "tamagui-build clean:build"
24
24
  },
25
25
  "dependencies": {
26
- "@tamagui/create-theme": "1.140.3",
27
- "@tamagui/generate-themes": "1.140.3",
28
- "@tamagui/static": "1.140.3",
29
- "@tamagui/types": "1.140.3",
30
- "@tamagui/vite-plugin": "1.140.3",
26
+ "@tamagui/create-theme": "1.141.0",
27
+ "@tamagui/generate-themes": "1.141.0",
28
+ "@tamagui/static": "1.141.0",
29
+ "@tamagui/types": "1.141.0",
30
+ "@tamagui/vite-plugin": "1.141.0",
31
31
  "arg": "^5.0.2",
32
32
  "chalk": "^4.1.2",
33
33
  "change-case": "^4.1.2",
@@ -46,7 +46,7 @@
46
46
  "url": "^0.11.0"
47
47
  },
48
48
  "devDependencies": {
49
- "@tamagui/build": "1.140.3",
49
+ "@tamagui/build": "1.141.0",
50
50
  "@types/chokidar": "^2.1.3",
51
51
  "@types/marked": "^5.0.0"
52
52
  }
package/src/cli.ts CHANGED
@@ -166,15 +166,29 @@ const COMMAND_MAP = {
166
166
  },
167
167
  },
168
168
 
169
- // update: {
170
- // shorthands: [],
171
- // description: `Update all tamagui packages within a monorepo`,
172
- // flags: {},
173
- // async run() {
174
- // const { update } = await import('./update')
175
- // await update()
176
- // },
177
- // },
169
+ upgrade: {
170
+ shorthands: ['up'],
171
+ description: `Upgrade all tamagui packages in your workspace to the latest version`,
172
+ flags: {
173
+ '--help': Boolean,
174
+ '--debug': Boolean,
175
+ '--from': String,
176
+ '--to': String,
177
+ '--changelog-only': Boolean,
178
+ '--dry-run': Boolean,
179
+ },
180
+ async run() {
181
+ const { _, ...flags } = arg(this.flags)
182
+ const { upgrade } = require('./upgrade')
183
+ await upgrade({
184
+ from: flags['--from'],
185
+ to: flags['--to'],
186
+ changelogOnly: flags['--changelog-only'],
187
+ dryRun: flags['--dry-run'],
188
+ debug: flags['--debug'],
189
+ })
190
+ },
191
+ },
178
192
 
179
193
  'update-template': {
180
194
  shorthands: ['ut'],