76 lines
2.9 KiB
JavaScript
76 lines
2.9 KiB
JavaScript
import { Database } from "bun:sqlite";
|
|
import chalk from "chalk";
|
|
import { select, input } from "@inquirer/prompts";
|
|
const LIMIT = 50;
|
|
export default async function showEntries({ db, tableName }) {
|
|
let page = 0;
|
|
let searchField = null;
|
|
let searchTerm = null;
|
|
while (true) {
|
|
const offset = page * LIMIT;
|
|
const rows = searchTerm
|
|
? db
|
|
.query(`SELECT * FROM "${tableName}" WHERE "${searchField}" LIKE ? LIMIT ${LIMIT} OFFSET ${offset}`)
|
|
.all(`%${searchTerm}%`)
|
|
: db
|
|
.query(`SELECT * FROM "${tableName}" LIMIT ${LIMIT} OFFSET ${offset}`)
|
|
.all();
|
|
const countRow = (searchTerm
|
|
? db
|
|
.query(`SELECT COUNT(*) as count FROM "${tableName}" WHERE "${searchField}" LIKE ?`)
|
|
.get(`%${searchTerm}%`)
|
|
: db.query(`SELECT COUNT(*) as count FROM "${tableName}"`).get());
|
|
const total = countRow.count;
|
|
const searchInfo = searchTerm
|
|
? chalk.dim(` · searching "${searchField}" = "${searchTerm}"`)
|
|
: "";
|
|
console.log(`\n${chalk.bold(tableName)} — Page ${page + 1}${searchInfo} (${rows.length} of ${total}):\n`);
|
|
if (rows.length) {
|
|
console.log(rows);
|
|
// if (rows.length) console.table(rows);
|
|
}
|
|
else {
|
|
console.log(chalk.yellow("No rows found."));
|
|
console.log();
|
|
}
|
|
const choices = [];
|
|
if (page > 0)
|
|
choices.push({ name: "← Previous Page", value: "prev" });
|
|
if (offset + rows.length < total)
|
|
choices.push({ name: "Next Page →", value: "next" });
|
|
choices.push({ name: "Search by Field", value: "search" });
|
|
if (searchTerm)
|
|
choices.push({ name: "Clear Search", value: "clear_search" });
|
|
choices.push({ name: chalk.dim("← Go Back"), value: "__back__" });
|
|
choices.push({ name: chalk.dim("✕ Exit"), value: "__exit__" });
|
|
const action = await select({ message: "Navigate:", choices });
|
|
if (action === "__back__")
|
|
break;
|
|
if (action === "__exit__")
|
|
return "__exit__";
|
|
if (action === "next")
|
|
page++;
|
|
if (action === "prev")
|
|
page--;
|
|
if (action === "clear_search") {
|
|
searchField = null;
|
|
searchTerm = null;
|
|
page = 0;
|
|
}
|
|
if (action === "search") {
|
|
const columns = db
|
|
.query(`PRAGMA table_info("${tableName}")`)
|
|
.all();
|
|
searchField = await select({
|
|
message: "Search by field:",
|
|
choices: columns.map((c) => ({ name: c.name, value: c.name })),
|
|
});
|
|
searchTerm = await input({
|
|
message: `Search term for "${searchField}":`,
|
|
validate: (v) => v.trim().length > 0 || "Cannot be empty",
|
|
});
|
|
page = 0;
|
|
}
|
|
}
|
|
}
|