one
Version:
One is a new React Framework that makes Vite serve both native and web.
300 lines • 9.4 kB
JavaScript
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"));
}
});
});
}