UNPKG

one

Version:

One is a new React Framework that makes Vite serve both native and web.

300 lines 9.4 kB
var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; var __hasOwnProp = Object.prototype.hasOwnProperty; 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 __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod)); var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var picker_exports = {}; __export(picker_exports, { getBootedSimulators: () => getBootedSimulators, pickServer: () => pickServer, resolvePendingPicker: () => resolvePendingPicker, showPicker: () => showPicker }); module.exports = __toCommonJS(picker_exports); var import_node_child_process = require("node:child_process"); var import_node_util = require("node:util"); var readline = __toESM(require("node:readline"), 1); const execAsync = (0, import_node_util.promisify)(import_node_child_process.exec); let activePickerContext = null; let rl = null; let stdinDataListener = null; async function getBootedSimulators() { try { const { stdout } = await execAsync("xcrun simctl list devices booted -j"); const data = JSON.parse(stdout); const simulators = []; for (const [runtime, devices] of Object.entries(data.devices || {})) { const versionMatch = runtime.match(/iOS-(\d+)-(\d+)/); const iosVersion = versionMatch ? `${versionMatch[1]}.${versionMatch[2]}` : void 0; for (const device of devices) { if (device.state === "Booted") { simulators.push({ name: device.name, udid: device.udid, state: device.state, iosVersion }); } } } return simulators; } catch { return []; } } async function showMacOSDialog(bundleId, servers) { if (process.platform !== "darwin") { return null; } const simulators = await getBootedSimulators(); let simInfo = ""; if (simulators.length > 0) { const seen = /* @__PURE__ */new Set(); const uniqueSims = []; for (const sim of simulators) { const key = `${sim.name}-${sim.iosVersion || ""}`; if (!seen.has(key)) { seen.add(key); uniqueSims.push(sim.iosVersion ? `${sim.name} (iOS ${sim.iosVersion})` : sim.name); } } if (uniqueSims.length === 1) { simInfo = `\\n\\nFrom: ${uniqueSims[0]}`; } else { simInfo = `\\n\\nActive simulators: ${uniqueSims.slice(0, 3).join(", ")}${uniqueSims.length > 3 ? "..." : ""}`; } } const choices = servers.map((s, i) => { const shortRoot = s.root.replace(process.env.HOME || "", "~"); return `${i + 1}. ${shortRoot} (port ${s.port})`; }); const choicesStr = choices.map(c => `"${c.replace(/"/g, '\\"')}"`).join(", "); const prompt = `${bundleId} bundle requested${simInfo}\\n\\nWhich project should serve it?`; const script = `choose from list {${choicesStr}} with title "one daemon" with prompt "${prompt}" default items {"${choices[0].replace(/"/g, '\\"')}"}`; try { const { stdout } = await execAsync(`osascript -e '${script}'`); const result = stdout.trim(); if (result === "false" || !result) { return null; } const match = result.match(/^(\d+)\./); if (match) { const index = parseInt(match[1], 10) - 1; if (index >= 0 && index < servers.length) { return { server: servers[index], remember: false }; } } return null; } catch { return null; } } function showPicker(context) { activePickerContext = context; if (process.platform === "darwin") { showMacOSDialog(context.bundleId, context.servers).then(result => { if (result) { cleanupPicker(); context.onSelect(result.server, result.remember); } else if (activePickerContext === context) { showTerminalPicker(context); } }); return; } showTerminalPicker(context); } function showTerminalPicker(context) { console.log("\n" + "\u2500".repeat(60)); console.log(`\u{1F500} ${context.bundleId} bundle requested`); console.log("\u2500".repeat(60)); getBootedSimulators().then(sims => { if (sims.length > 0) { const seen = /* @__PURE__ */new Set(); const uniqueSims = []; for (const sim of sims) { const key = `${sim.name}-${sim.iosVersion || ""}`; if (!seen.has(key)) { seen.add(key); uniqueSims.push(sim); } } if (uniqueSims.length === 1) { const sim = uniqueSims[0]; console.log(` From: ${sim.name}${sim.iosVersion ? ` (iOS ${sim.iosVersion})` : ""}`); } else { console.log("\nActive simulators:"); for (const sim of uniqueSims.slice(0, 5)) { console.log(` \u2022 ${sim.name}${sim.iosVersion ? ` (iOS ${sim.iosVersion})` : ""}`); } } } }); console.log("\nWhich project should serve it?"); context.servers.forEach((server, i) => { const shortRoot = server.root.replace(process.env.HOME || "", "~"); console.log(` [${i + 1}] ${shortRoot} (port ${server.port})`); }); console.log("\nPress 1-" + context.servers.length + " to select"); console.log("Or 'r' + number to remember (e.g., 'r1')"); console.log("Press 'c' to cancel\n"); setupKeyboardInput(); } function setupKeyboardInput() { if (rl) return; rl = readline.createInterface({ input: process.stdin, output: process.stdout }); if (process.stdin.isTTY) { process.stdin.setRawMode(true); } process.stdin.resume(); let buffer = ""; stdinDataListener = key => { const str = key.toString(); if (str === "") { cancelPicker(); return; } if (str === "\x1B") { cancelPicker(); return; } if (str === "\x7F") { buffer = buffer.slice(0, -1); return; } if (str === "\r" || str === "\n") { processInput(buffer); buffer = ""; return; } buffer += str; if (buffer.length === 1 && /^[1-9]$/.test(buffer)) { processInput(buffer); buffer = ""; } else if (buffer.length === 2 && /^r[1-9]$/i.test(buffer)) { processInput(buffer); buffer = ""; } else if (buffer.toLowerCase() === "c") { cancelPicker(); buffer = ""; } }; process.stdin.on("data", stdinDataListener); const signalHandler = () => { cleanupPicker(); process.exit(0); }; process.on("SIGINT", signalHandler); process.on("SIGTERM", signalHandler); } function processInput(input) { if (!activePickerContext) return; const remember = input.toLowerCase().startsWith("r"); const numStr = remember ? input.slice(1) : input; const num = parseInt(numStr, 10); if (isNaN(num) || num < 1 || num > activePickerContext.servers.length) { console.log(`Invalid selection: ${input}`); return; } const server = activePickerContext.servers[num - 1]; const context = activePickerContext; cleanupPicker(); context.onSelect(server, remember); } function cancelPicker() { const context = activePickerContext; cleanupPicker(); if (context) { context.onCancel(); } } function cleanupPicker() { activePickerContext = null; if (stdinDataListener) { process.stdin.removeListener("data", stdinDataListener); stdinDataListener = null; } if (rl) { rl.close(); rl = null; } if (process.stdin.isTTY) { process.stdin.setRawMode(false); } } let pendingPickerResolvers = /* @__PURE__ */new Map(); function resolvePendingPicker(bundleId, serverId) { const resolver = pendingPickerResolvers.get(bundleId); if (!resolver || !activePickerContext) return false; const server = activePickerContext.servers.find(s => s.id === serverId); if (!server) return false; pendingPickerResolvers.delete(bundleId); cleanupPicker(); resolver.resolve(server); return true; } function pickServer(bundleId, servers) { return new Promise((resolve, reject) => { pendingPickerResolvers.set(bundleId, { resolve: server => resolve({ server, remember: false }), reject }); showPicker({ bundleId, servers, onSelect: (server, remember) => { pendingPickerResolvers.delete(bundleId); resolve({ server, remember }); }, onCancel: () => { pendingPickerResolvers.delete(bundleId); reject(new Error("Selection cancelled")); } }); }); }