maidang 29.3.1 → 29.3.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/dist/index.js CHANGED
@@ -1,61 +1,17 @@
1
1
  #!/usr/bin/env node
2
2
 
3
3
  // src/index.ts
4
- import { Command as Command6 } from "commander";
4
+ import { Command as Command9 } from "commander";
5
5
 
6
6
  // src/commands/home.ts
7
7
  import { Command } from "commander";
8
8
  import chalk2 from "chalk";
9
9
 
10
- // src/data/home.json
11
- var home_default = {
12
- greetings: [
13
- "\u6B22\u8FCE\u6765\u5230\u9EA6\u5F53\u7684\u4E16\u754C\uFF01\u{1F44B}",
14
- "\u4F60\u597D\u5440\uFF0C\u6211\u662F\u9EA6\u5F53\uFF01\u2728",
15
- "Hey\uFF0C\u6B22\u8FCE\u6765\u4E86\u89E3\u6211\uFF01\u{1F389}",
16
- "\u63A2\u7D22\u9EA6\u5F53\u7684\u79D8\u5BC6\u82B1\u56ED \u{1F338}",
17
- "\u51C6\u5907\u597D\u8BA4\u8BC6\u6211\u4E86\u5417\uFF1F\u{1F680}"
18
- ],
19
- basicInfo: {
20
- name: "\u9EA6\u5F53",
21
- role: "AI \u65F6\u4EE3\u7684\u63A2\u7D22\u8005",
22
- motto: "\u4FDD\u6301\u597D\u5947\uFF0C\u6301\u7EED\u63A2\u7D22"
23
- }
24
- };
25
-
26
10
  // src/utils/display.ts
27
11
  import chalk from "chalk";
28
12
  import boxen from "boxen";
29
13
  import figlet from "figlet";
30
14
  import ora from "ora";
31
- async function displayTitle(text) {
32
- return new Promise((resolve) => {
33
- figlet.text(text, {
34
- font: "Big",
35
- horizontalLayout: "default",
36
- verticalLayout: "default"
37
- }, (err, data) => {
38
- if (err) {
39
- console.log(chalk.cyan.bold(text));
40
- } else {
41
- console.log(chalk.cyan(data));
42
- }
43
- resolve();
44
- });
45
- });
46
- }
47
- function displayBox(content, options) {
48
- const borderOptions = {
49
- padding: options?.padding || 1,
50
- borderColor: options?.borderColor || "cyan",
51
- borderStyle: "round"
52
- };
53
- if (options?.title) {
54
- borderOptions.title = options.title;
55
- borderOptions.titleAlignment = "center";
56
- }
57
- console.log(boxen(content, borderOptions));
58
- }
59
15
  function createSpinner(text) {
60
16
  return ora({
61
17
  text,
@@ -73,34 +29,33 @@ ${title}`));
73
29
  }
74
30
 
75
31
  // src/commands/home.ts
32
+ var commands = [
33
+ { name: "birthday", desc: "\u663E\u793A\u9EA6\u5F53\u7684\u751F\u65E5\u4FE1\u606F" },
34
+ { name: "career", desc: "\u67E5\u770B\u5DE5\u4F5C\u7ECF\u5386" },
35
+ { name: "cat | meow", desc: "\u67E5\u770B\u9EA6\u9EA6" },
36
+ { name: "blog", desc: "\u9605\u8BFB\u535A\u5BA2\u6587\u7AE0" },
37
+ { name: "posts", desc: "\u63A8\u6587\u65F6\u95F4\u7EBF" },
38
+ { name: "links", desc: "\u67E5\u770B\u793E\u4EA4\u94FE\u63A5" },
39
+ { name: "projects", desc: "\u67E5\u770B\u4E2A\u4EBA\u9879\u76EE" },
40
+ { name: "tools", desc: "\u67E5\u770B\u5E38\u7528\u5DE5\u5177" }
41
+ ];
76
42
  function createHomeCommand() {
77
- const cmd = new Command("maidang").description("\u6B22\u8FCE\u6765\u5230\u9EA6\u5F53\u7684\u4E16\u754C").action(async () => {
78
- const randomGreeting = home_default.greetings[Math.floor(Math.random() * home_default.greetings.length)];
79
- const spinner = createSpinner("\u6B63\u5728\u53EC\u5524\u9EA6\u5F53...");
43
+ const cmd = new Command("maidang").description("\u6B22\u8FCE\u6765\u5230\u5356\u5F53\u7684\u4E16\u754C").action(async () => {
44
+ const spinner = createSpinner("\u6B63\u5728\u53EC\u5524\u5356\u5F53...");
80
45
  spinner.start();
81
46
  await new Promise((resolve) => setTimeout(resolve, 1e3));
82
47
  spinner.stop();
83
48
  console.clear();
84
- await displayTitle("MAIDANG");
49
+ console.log(chalk2.cyan.bold("\u5356\u5F53\uFF0CAI \u65F6\u4EE3\u63A2\u7D22\u8005"));
50
+ console.log(chalk2.gray("\u8DF5\u884C\u53EF\u6301\u7EED\u751F\u6D3B\u65B9\u5F0F"));
85
51
  console.log("");
86
- const welcomeContent = `
87
- ${chalk2.white.bold(randomGreeting)}
88
-
89
- ${chalk2.gray("\u2500".repeat(40))}
90
-
91
- ${chalk2.yellow("\u{1F464}")} ${chalk2.white.bold("\u59D3\u540D:")} ${chalk2.cyan(home_default.basicInfo.name)}
92
- ${chalk2.yellow("\u{1F4BC}")} ${chalk2.white.bold("\u8EAB\u4EFD:")} ${chalk2.cyan(home_default.basicInfo.role)}
93
- ${chalk2.yellow("\u{1F4AD}")} ${chalk2.white.bold("\u5EA7\u53F3\u94ED:")} ${chalk2.green(home_default.basicInfo.motto)}
94
-
95
- ${chalk2.gray("\u2500".repeat(40))}
96
-
97
- ${chalk2.gray("\u8F93\u5165 " + chalk2.cyan.bold("maidang --help") + " \u67E5\u770B\u6240\u6709\u547D\u4EE4")}
98
- ${chalk2.gray("\u8F93\u5165 " + chalk2.cyan.bold("maidang career") + " \u67E5\u770B\u5DE5\u4F5C\u7ECF\u5386")}
99
- ${chalk2.gray("\u8F93\u5165 " + chalk2.cyan.bold("maidang cat") + " \u6216 " + chalk2.cyan.bold("maidang meow") + " \u67E5\u770B\u6211\u7684\u732B")}
100
- `;
101
- displayBox(welcomeContent, {
102
- padding: 2
103
- });
52
+ console.log(chalk2.gray("\u2500".repeat(40)));
53
+ console.log("");
54
+ for (const cmd2 of commands) {
55
+ console.log(` ${chalk2.white.bold(cmd2.name.padEnd(12))} ${chalk2.gray(cmd2.desc)}`);
56
+ }
57
+ console.log("");
58
+ console.log(chalk2.gray("\u2500".repeat(40)));
104
59
  console.log("");
105
60
  });
106
61
  return cmd;
@@ -355,35 +310,9 @@ function createBlogCommand() {
355
310
  }
356
311
 
357
312
  // src/commands/posts.tsx
358
- import React2, { useState as useState2 } from "react";
313
+ import React2, { useState as useState2, useEffect } from "react";
359
314
  import { render as render2, Box as Box2, Text as Text2, useInput as useInput2 } from "ink";
360
315
  import { Command as Command5 } from "commander";
361
-
362
- // src/data/posts.json
363
- var posts_default = {
364
- posts: [
365
- {
366
- id: "1",
367
- author: "\u9EA6\u5F53",
368
- handle: "@maidang",
369
- date: "2025-03-13",
370
- time: "10:00",
371
- content: "\u5982\u4F55\u9009\u62E9 Coding Plan\n\n\u4E00\u4E2A\u6700\u5F3A\u7684\u6A21\u578B + \u4E00\u4E2A\u7B2C\u4E00\u68AF\u961F\u6A21\u578B\uFF0C\u5E94\u5BF9\u4EFB\u610F\u6E20\u9053\u7684\u7A81\u53D1\u9650\u6D41\u3001\u65AD\u4F9B\u3001\u5C01\u53F7\n\n\u7248\u672C\u6700\u5F3A\u6A21\u578B\uFF1AClaude\uFF08\u95F2\u9C7C\u968F\u4FBF\u627E\u4E00\u4E2A\uFF09\n\u56FD\u4EA7\u7B2C\u4E00\u68AF\u961F\uFF1Akimi\u3001GLM\u3001Minimax\n\n\u4F7F\u7528 cc-switch \u5207\u6362\u6A21\u578B\u63D0\u4F9B\u5546\u3002\u5F53\u4F9B\u5E94\u5546\u9650\u6D41\u3001\u65AD\u4F9B\u4EE5\u540E\uFF0C\u5FEB\u901F\u5207\u6362\u53E6\u4E00\u4E2A\u3002\n\nhttps://github.com/farion1231/cc-switch",
372
- tags: ["AI", "Claude", "\u6A21\u578B\u9009\u62E9"]
373
- },
374
- {
375
- id: "2",
376
- author: "\u9EA6\u5F53",
377
- handle: "@maidang",
378
- date: "2026-03-23",
379
- time: "20:00",
380
- content: "\u804C\u573A\u53D1\u5C0F\u8981\u79BB\u804C\u4E86\n\n\u8BF4\u5B9E\u8BDD\u633A\u4E0D\u820D\u5F97\uFF0C\u516C\u53F8\u7684\u4F01\u4E1A\u6587\u5316\u624B\u518C\u91CC\u5199\u7740\uFF0C\u5E94\u8BE5\u62DB\u4EC0\u4E48\u6837\u7684\u4EBA\uFF1F\u5C31\u662F\u90A3\u79CD\u79BB\u804C\u7684\u65F6\u5019\u4F60\u4F1A\u6781\u529B\u633D\u7559\u7684\u4EBA\uFF0C\u4F46\u6700\u8FD1\u5DE5\u4F5C\u5F3A\u5EA6\u8D8A\u6765\u8D8A\u5927\uFF0C\u6709\u7684\u540C\u4E8B\u5F00\u6446\u7B49\u793C\u5305\uFF0C\u6709\u7684\u4E0A\u4E86\u730E\u6740\u540D\u5355\uFF0C\u6709\u7684\u4EBA\u8F9E\u804C\u521B\u4E1A\uFF0CAI \u66FF\u4EE3\u5DE5\u4F5C\u7684\u6D6A\u6F6E\u4ECA\u5E74\u4F1A\u6B63\u5F0F\u5F00\u59CB\uFF0C\u4EBA\u4EBA\u81EA\u5371\u7684\u65F6\u5019\uFF0C\u4F60\u53EA\u5E0C\u671B\u4F60\u7684\u670B\u53CB\u8FC7\u5F97\u5065\u5EB7\u5FEB\u4E50\n\n\u524D\u5929\u770B\u4E86\u4E00\u90E8\u7535\u5F71\uFF0C\u53EB\u300A\u6B7B\u4EA1\u7ADE\u8D70\u300B\uFF0C\u6211\u89C9\u5F97\u548C\u73B0\u5728\u7684\u5DE5\u4F5C\u72B6\u6001\u5F88\u50CF\uFF0C\u4F60\u8981\u4E48\u5F80\u524D\u8D70\uFF0C\u8981\u4E48\u51FA\u5C40\uFF08\u6216\u4E3B\u52A8\u6216\u88AB\u52A8\uFF09\uFF0C\u4F46\u4E0D\u8BBA\u662F\u8C01\u80FD\u8D70\u5230\u7EC8\u70B9\uFF0C\u540C\u884C\u7684\u4EBA\u90FD\u662F\u73CD\u8D35\u7684\u4F19\u4F34\n\n\u795D\u4ED6\u4EEC\u4E00\u8DEF\u987A\u98CE",
381
- tags: ["\u804C\u573A", "\u79BB\u804C", "\u670B\u53CB"]
382
- }
383
- ]
384
- };
385
-
386
- // src/commands/posts.tsx
387
316
  var FeedPost = ({ post, isSelected }) => /* @__PURE__ */ React2.createElement(Box2, { flexDirection: "column", paddingX: 1, marginY: 0 }, /* @__PURE__ */ React2.createElement(Box2, null, /* @__PURE__ */ React2.createElement(Text2, { bold: true, color: isSelected ? "cyan" : "white" }, post.author), /* @__PURE__ */ React2.createElement(Text2, { dimColor: true }, " ", post.handle), /* @__PURE__ */ React2.createElement(Text2, { dimColor: true }, " \xB7 ", post.date, " ", post.time)), /* @__PURE__ */ React2.createElement(Box2, { marginTop: 0, flexWrap: "wrap" }, /* @__PURE__ */ React2.createElement(Text2, { color: isSelected ? "gray" : void 0 }, post.content)), post.tags && post.tags.length > 0 && /* @__PURE__ */ React2.createElement(Box2, { marginTop: 0, flexWrap: "wrap" }, post.tags.map((tag) => /* @__PURE__ */ React2.createElement(Text2, { key: tag, dimColor: true }, "#", tag, " "))));
388
317
  var PostsFeed = ({ posts, selectedIndex, onSelect, onQuit }) => {
389
318
  useInput2((input, key) => {
@@ -400,7 +329,7 @@ var PostsFeed = ({ posts, selectedIndex, onSelect, onQuit }) => {
400
329
  return /* @__PURE__ */ React2.createElement(Box2, { flexDirection: "column", paddingX: 2, paddingY: 1 }, /* @__PURE__ */ React2.createElement(Box2, { marginBottom: 1 }, /* @__PURE__ */ React2.createElement(Text2, { bold: true, color: "cyan" }, "\u{1F426} \u9EA6\u5F53\u7684\u63A8\u6587"), /* @__PURE__ */ React2.createElement(Text2, { dimColor: true }, " \xB7 \u65B9\u5411\u952E\u6D4F\u89C8\uFF0Cq \u9000\u51FA")), /* @__PURE__ */ React2.createElement(Box2, { flexDirection: "column", borderStyle: "single", borderColor: "gray", paddingX: 0, paddingY: 0 }, posts.map((post, index) => /* @__PURE__ */ React2.createElement(
401
330
  Box2,
402
331
  {
403
- key: post.id,
332
+ key: post.slug,
404
333
  flexDirection: "column",
405
334
  borderStyle: "single",
406
335
  borderColor: selectedIndex === index ? "cyan" : "gray",
@@ -411,12 +340,43 @@ var PostsFeed = ({ posts, selectedIndex, onSelect, onQuit }) => {
411
340
  /* @__PURE__ */ React2.createElement(FeedPost, { post, isSelected: selectedIndex === index })
412
341
  ))), /* @__PURE__ */ React2.createElement(Box2, { marginTop: 1 }, /* @__PURE__ */ React2.createElement(Text2, { dimColor: true }, "\u2191\u2193 \u9009\u62E9 \xB7 q \u9000\u51FA")));
413
342
  };
414
- var PostsApp = () => {
343
+ var PostsApp = ({ apiUrl }) => {
344
+ const [posts, setPosts] = useState2([]);
415
345
  const [selectedIndex, setSelectedIndex] = useState2(0);
416
- const posts = posts_default.posts;
346
+ const [loading, setLoading] = useState2(true);
347
+ const [error, setError] = useState2(null);
348
+ const [spinnerFrame, setSpinnerFrame] = useState2(0);
349
+ useEffect(() => {
350
+ if (!loading) return;
351
+ const interval = setInterval(() => {
352
+ setSpinnerFrame((f) => (f + 1) % 4);
353
+ }, 150);
354
+ return () => clearInterval(interval);
355
+ }, [loading]);
356
+ useEffect(() => {
357
+ fetch(apiUrl).then((res) => {
358
+ if (!res.ok) throw new Error(`HTTP ${res.status}`);
359
+ return res.json();
360
+ }).then((data) => {
361
+ setPosts(data);
362
+ setLoading(false);
363
+ }).catch((err) => {
364
+ setError(err.message);
365
+ setLoading(false);
366
+ });
367
+ }, [apiUrl]);
417
368
  const handleQuit = () => {
418
369
  process.exit(0);
419
370
  };
371
+ if (loading) {
372
+ return /* @__PURE__ */ React2.createElement(Box2, { flexDirection: "column", paddingX: 2, paddingY: 1 }, /* @__PURE__ */ React2.createElement(Text2, null, /* @__PURE__ */ React2.createElement(Text2, { dimColor: true }, "\u25D0\u25D3\u25D0\u25D3"[spinnerFrame], " \u52A0\u8F7D\u4E2D...")));
373
+ }
374
+ if (error) {
375
+ return /* @__PURE__ */ React2.createElement(Box2, { flexDirection: "column", paddingX: 2, paddingY: 1 }, /* @__PURE__ */ React2.createElement(Text2, { color: "red" }, "\u52A0\u8F7D\u5931\u8D25: ", error), /* @__PURE__ */ React2.createElement(Text2, { dimColor: true }, "\u8BF7\u68C0\u67E5\u7F51\u7EDC\u6216API\u5730\u5740"));
376
+ }
377
+ if (posts.length === 0) {
378
+ return /* @__PURE__ */ React2.createElement(Box2, { flexDirection: "column", paddingX: 2, paddingY: 1 }, /* @__PURE__ */ React2.createElement(Text2, { color: "yellow" }, "\u6682\u65E0\u63A8\u6587"));
379
+ }
420
380
  return /* @__PURE__ */ React2.createElement(
421
381
  PostsFeed,
422
382
  {
@@ -428,8 +388,108 @@ var PostsApp = () => {
428
388
  );
429
389
  };
430
390
  function createPostsCommand() {
431
- const cmd = new Command5("posts").description("\u9EA6\u5F53\u7684\u63A8\u6587\u65F6\u95F4\u7EBF\uFF08\u63A8\u7279\u98CE\u683C\uFF09").action(() => {
432
- render2(/* @__PURE__ */ React2.createElement(PostsApp, null));
391
+ const cmd = new Command5("posts").description("\u9EA6\u5F53\u7684\u63A8\u6587\u65F6\u95F4\u7EBF\uFF08\u63A8\u7279\u98CE\u683C\uFF09").requiredOption("--api <url>", "API\u5730\u5740").action((opts) => {
392
+ render2(/* @__PURE__ */ React2.createElement(PostsApp, { apiUrl: opts.api }));
393
+ });
394
+ return cmd;
395
+ }
396
+
397
+ // src/commands/links.ts
398
+ import { Command as Command6 } from "commander";
399
+ import chalk5 from "chalk";
400
+ function createLinksCommand() {
401
+ const cmd = new Command6("links").description("\u67E5\u770B\u793E\u4EA4\u94FE\u63A5").option("--json", "\u8F93\u51FA JSON \u683C\u5F0F").action(async (opts) => {
402
+ const apiUrl = process.env.MAIDANG_API_URL || "http://localhost:3000";
403
+ try {
404
+ const res = await fetch(`${apiUrl}/api/links`);
405
+ if (!res.ok) throw new Error(`HTTP ${res.status}`);
406
+ const links = await res.json();
407
+ if (opts.json) {
408
+ console.log(JSON.stringify({ tool: "maidang", command: "links", data: links }, null, 2));
409
+ return;
410
+ }
411
+ console.log(chalk5.cyan.bold("\u{1F310} \u793E\u4EA4\u94FE\u63A5\n"));
412
+ for (const link of links) {
413
+ console.log(` ${link.icon} ${chalk5.white(link.name)} - ${chalk5.gray(link.description || "")}`);
414
+ console.log(` ${chalk5.blue(link.url)}
415
+ `);
416
+ }
417
+ } catch (err) {
418
+ console.error(chalk5.red(`\u83B7\u53D6\u94FE\u63A5\u5931\u8D25: ${err instanceof Error ? err.message : err}`));
419
+ process.exit(1);
420
+ }
421
+ });
422
+ return cmd;
423
+ }
424
+
425
+ // src/commands/projects.ts
426
+ import { Command as Command7 } from "commander";
427
+ import chalk6 from "chalk";
428
+ function createProjectsCommand() {
429
+ const cmd = new Command7("projects").description("\u67E5\u770B\u4E2A\u4EBA\u9879\u76EE").option("--json", "\u8F93\u51FA JSON \u683C\u5F0F").action(async (opts) => {
430
+ const apiUrl = process.env.MAIDANG_API_URL || "http://localhost:3000";
431
+ try {
432
+ const res = await fetch(`${apiUrl}/api/projects`);
433
+ if (!res.ok) throw new Error(`HTTP ${res.status}`);
434
+ const projects = await res.json();
435
+ if (opts.json) {
436
+ console.log(JSON.stringify({ tool: "maidang", command: "projects", data: projects }, null, 2));
437
+ return;
438
+ }
439
+ console.log(chalk6.cyan.bold("\u{1F680} \u4E2A\u4EBA\u9879\u76EE\n"));
440
+ for (const project of projects) {
441
+ console.log(` ${project.icon} ${chalk6.white.bold(project.name)} ${chalk6.gray(`[${project.category}]`)}`);
442
+ console.log(` ${project.description}`);
443
+ if (project.url) {
444
+ console.log(` ${chalk6.blue(project.url)}`);
445
+ }
446
+ console.log("");
447
+ }
448
+ } catch (err) {
449
+ console.error(chalk6.red(`\u83B7\u53D6\u9879\u76EE\u5931\u8D25: ${err instanceof Error ? err.message : err}`));
450
+ process.exit(1);
451
+ }
452
+ });
453
+ return cmd;
454
+ }
455
+
456
+ // src/commands/tools.ts
457
+ import { Command as Command8 } from "commander";
458
+ import chalk7 from "chalk";
459
+ function createToolsCommand() {
460
+ const cmd = new Command8("tools").description("\u67E5\u770B\u5E38\u7528\u5DE5\u5177").option("--json", "\u8F93\u51FA JSON \u683C\u5F0F").action(async (opts) => {
461
+ const apiUrl = process.env.MAIDANG_API_URL || "http://localhost:3000";
462
+ try {
463
+ const res = await fetch(`${apiUrl}/api/tools`);
464
+ if (!res.ok) throw new Error(`HTTP ${res.status}`);
465
+ const tools = await res.json();
466
+ if (opts.json) {
467
+ console.log(JSON.stringify({ tool: "maidang", command: "tools", data: tools }, null, 2));
468
+ return;
469
+ }
470
+ const byCategory = tools.reduce((acc, tool) => {
471
+ if (!acc[tool.category]) acc[tool.category] = [];
472
+ acc[tool.category].push(tool);
473
+ return acc;
474
+ }, {});
475
+ const categoryNames = {
476
+ software: "\u5E38\u7528\u8F6F\u4EF6",
477
+ device: "\u8BBE\u5907",
478
+ desktop: "\u684C\u9762\u88C5\u5907"
479
+ };
480
+ console.log(chalk7.cyan.bold("\u{1F527} \u5E38\u7528\u5DE5\u5177\n"));
481
+ for (const [cat, items] of Object.entries(byCategory)) {
482
+ console.log(chalk7.white.bold(` ${categoryNames[cat] || cat}`));
483
+ for (const tool of items) {
484
+ const urlStr = tool.url ? ` ${chalk7.blue(tool.url)}` : "";
485
+ console.log(` ${tool.icon} ${tool.name} - ${chalk7.gray(tool.description)}${urlStr}`);
486
+ }
487
+ console.log("");
488
+ }
489
+ } catch (err) {
490
+ console.error(chalk7.red(`\u83B7\u53D6\u5DE5\u5177\u5931\u8D25: ${err instanceof Error ? err.message : err}`));
491
+ process.exit(1);
492
+ }
433
493
  });
434
494
  return cmd;
435
495
  }
@@ -466,7 +526,7 @@ function getVersionInfo() {
466
526
  }
467
527
 
468
528
  // src/index.ts
469
- var program = new Command6();
529
+ var program = new Command9();
470
530
  var versionInfo = getVersionInfo();
471
531
  program.name("maidang").description("\u4E86\u89E3\u9EA6\u5F53 - \u4E00\u4E2A AI \u65F6\u4EE3\u7684\u63A2\u7D22\u8005").version(getAgeVersion(), "-v, --version", "\u663E\u793A\u9EA6\u5F53\u7684\u5E74\u9F84\u7248\u672C\u53F7");
472
532
  program.command("birthday").description("\u663E\u793A\u9EA6\u5F53\u7684\u751F\u65E5\u4FE1\u606F").action(() => {
@@ -487,10 +547,16 @@ var careerCmd = createCareerCommand();
487
547
  var catCmd = createCatCommand();
488
548
  var blogCmd = createBlogCommand();
489
549
  var postsCmd = createPostsCommand();
550
+ var linksCmd = createLinksCommand();
551
+ var projectsCmd = createProjectsCommand();
552
+ var toolsCmd = createToolsCommand();
490
553
  program.addCommand(careerCmd);
491
554
  program.addCommand(catCmd);
492
555
  program.addCommand(blogCmd);
493
556
  program.addCommand(postsCmd);
557
+ program.addCommand(linksCmd);
558
+ program.addCommand(projectsCmd);
559
+ program.addCommand(toolsCmd);
494
560
  if (!process.argv.slice(2).length) {
495
561
  const homeCmd = createHomeCommand();
496
562
  homeCmd.parse(process.argv);
package/dist/index.js.map CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../src/index.ts", "../src/commands/home.ts", "../src/data/home.json", "../src/utils/display.ts", "../src/commands/career.ts", "../src/data/career.json", "../src/commands/cat.ts", "../src/commands/blog.tsx", "../src/data/blog.json", "../src/commands/posts.tsx", "../src/data/posts.json", "../src/utils/version.ts"],
4
- "sourcesContent": ["#!/usr/bin/env node\n\nimport { Command } from 'commander';\nimport { createHomeCommand } from './commands/home';\nimport { createCareerCommand } from './commands/career';\nimport { createCatCommand } from './commands/cat';\nimport { createBlogCommand } from './commands/blog';\nimport { createPostsCommand } from './commands/posts';\nimport { getAgeVersion, getVersionInfo } from './utils/version';\n\nconst program = new Command();\n\n// \u52A8\u6001\u8BA1\u7B97\u5E74\u9F84\u7248\u672C\u53F7\nconst versionInfo = getVersionInfo();\n\nprogram\n .name('maidang')\n .description('\u4E86\u89E3\u9EA6\u5F53 - \u4E00\u4E2A AI \u65F6\u4EE3\u7684\u63A2\u7D22\u8005')\n .version(getAgeVersion(), '-v, --version', '\u663E\u793A\u9EA6\u5F53\u7684\u5E74\u9F84\u7248\u672C\u53F7');\n\n// \u6DFB\u52A0\u4E00\u4E2A\u7279\u6B8A\u7684\u751F\u65E5\u4FE1\u606F\u547D\u4EE4\nprogram\n .command('birthday')\n .description('\u663E\u793A\u9EA6\u5F53\u7684\u751F\u65E5\u4FE1\u606F')\n .action(() => {\n const { birthDate, currentAge, nextBirthday, version } = versionInfo;\n\n console.log(`\uD83C\uDF82 \u9EA6\u5F53\u7684\u751F\u65E5\u4FE1\u606F`);\n console.log('');\n console.log(`\u51FA\u751F\u65E5\u671F: ${birthDate.toLocaleDateString('zh-CN', { year: 'numeric', month: 'long', day: 'numeric' })}`);\n console.log(`\u5F53\u524D\u5E74\u9F84: ${currentAge} \u5C81`);\n console.log(`\u5F53\u524D\u7248\u672C: ${version} (\u5E74\u9F84\u7248\u672C)`);\n console.log(`\u4E0B\u4E00\u4E2A\u751F\u65E5: ${nextBirthday.toLocaleDateString('zh-CN', { year: 'numeric', month: 'long', day: 'numeric' })}`);\n\n const daysUntilNextBirthday = Math.ceil((nextBirthday.getTime() - new Date().getTime()) / (1000 * 60 * 60 * 24));\n console.log(`\u8DDD\u79BB\u751F\u65E5\u8FD8\u6709: ${daysUntilNextBirthday} \u5929`);\n\n if (daysUntilNextBirthday <= 30) {\n console.log(`\uD83C\uDF89 \u5FEB\u8981\u8FC7\u751F\u65E5\u4E86\uFF01`);\n }\n });\n\nconst careerCmd = createCareerCommand();\nconst catCmd = createCatCommand();\nconst blogCmd = createBlogCommand();\nconst postsCmd = createPostsCommand();\n\nprogram.addCommand(careerCmd);\nprogram.addCommand(catCmd);\nprogram.addCommand(blogCmd);\nprogram.addCommand(postsCmd);\n\nif (!process.argv.slice(2).length) {\n const homeCmd = createHomeCommand();\n homeCmd.parse(process.argv);\n} else {\n program.parse(process.argv);\n}\n", "import { Command } from 'commander';\nimport chalk from 'chalk';\nimport homeData from '../data/home.json';\nimport { displayTitle, displayBox, createSpinner } from '../utils/display';\n\nexport function createHomeCommand(): Command {\n const cmd = new Command('maidang')\n .description('\u6B22\u8FCE\u6765\u5230\u9EA6\u5F53\u7684\u4E16\u754C')\n .action(async () => {\n const randomGreeting = homeData.greetings[Math.floor(Math.random() * homeData.greetings.length)];\n\n const spinner = createSpinner('\u6B63\u5728\u53EC\u5524\u9EA6\u5F53...');\n spinner.start();\n\n await new Promise(resolve => setTimeout(resolve, 1000));\n\n spinner.stop();\n\n console.clear();\n\n await displayTitle('MAIDANG');\n\n console.log('');\n\n const welcomeContent = `\n${chalk.white.bold(randomGreeting)}\n\n${chalk.gray('\u2500'.repeat(40))}\n\n${chalk.yellow('\uD83D\uDC64')} ${chalk.white.bold('\u59D3\u540D:')} ${chalk.cyan(homeData.basicInfo.name)}\n${chalk.yellow('\uD83D\uDCBC')} ${chalk.white.bold('\u8EAB\u4EFD:')} ${chalk.cyan(homeData.basicInfo.role)}\n${chalk.yellow('\uD83D\uDCAD')} ${chalk.white.bold('\u5EA7\u53F3\u94ED:')} ${chalk.green(homeData.basicInfo.motto)}\n\n${chalk.gray('\u2500'.repeat(40))}\n\n${chalk.gray('\u8F93\u5165 ' + chalk.cyan.bold('maidang --help') + ' \u67E5\u770B\u6240\u6709\u547D\u4EE4')}\n${chalk.gray('\u8F93\u5165 ' + chalk.cyan.bold('maidang career') + ' \u67E5\u770B\u5DE5\u4F5C\u7ECF\u5386')}\n${chalk.gray('\u8F93\u5165 ' + chalk.cyan.bold('maidang cat') + ' \u6216 ' + chalk.cyan.bold('maidang meow') + ' \u67E5\u770B\u6211\u7684\u732B')}\n `;\n\n displayBox(welcomeContent, {\n padding: 2\n });\n\n console.log('');\n });\n\n return cmd;\n}\n", "{\n \"greetings\": [\n \"\u6B22\u8FCE\u6765\u5230\u9EA6\u5F53\u7684\u4E16\u754C\uFF01\uD83D\uDC4B\",\n \"\u4F60\u597D\u5440\uFF0C\u6211\u662F\u9EA6\u5F53\uFF01\u2728\",\n \"Hey\uFF0C\u6B22\u8FCE\u6765\u4E86\u89E3\u6211\uFF01\uD83C\uDF89\",\n \"\u63A2\u7D22\u9EA6\u5F53\u7684\u79D8\u5BC6\u82B1\u56ED \uD83C\uDF38\",\n \"\u51C6\u5907\u597D\u8BA4\u8BC6\u6211\u4E86\u5417\uFF1F\uD83D\uDE80\"\n ],\n \"basicInfo\": {\n \"name\": \"\u9EA6\u5F53\",\n \"role\": \"AI \u65F6\u4EE3\u7684\u63A2\u7D22\u8005\",\n \"motto\": \"\u4FDD\u6301\u597D\u5947\uFF0C\u6301\u7EED\u63A2\u7D22\"\n }\n}\n", "import chalk from 'chalk';\nimport boxen from 'boxen';\nimport figlet from 'figlet';\nimport ora, { Ora } from 'ora';\n\nexport async function displayTitle(text: string): Promise<void> {\n return new Promise((resolve) => {\n figlet.text(text, {\n font: 'Big',\n horizontalLayout: 'default',\n verticalLayout: 'default'\n }, (err, data) => {\n if (err) {\n console.log(chalk.cyan.bold(text));\n } else {\n console.log(chalk.cyan(data));\n }\n resolve();\n });\n });\n}\n\nexport function displayBox(content: string, options?: {\n title?: string;\n borderColor?: string;\n padding?: number;\n}): void {\n const borderOptions: any = {\n padding: options?.padding || 1,\n borderColor: options?.borderColor || 'cyan',\n borderStyle: 'round'\n };\n\n if (options?.title) {\n borderOptions.title = options.title;\n borderOptions.titleAlignment = 'center';\n }\n\n console.log(boxen(content, borderOptions));\n}\n\nexport function createSpinner(text: string): Ora {\n return ora({\n text,\n color: 'cyan'\n });\n}\n\nexport function displaySeparator(char: string = '\u2500', length: number = 50): void {\n console.log(chalk.gray(char.repeat(length)));\n}\n\nexport function displayItem(icon: string, text: string, color: string = 'cyan'): void {\n const colorMethod = (chalk as any)[color];\n if (colorMethod) {\n console.log(colorMethod(icon), text);\n } else {\n console.log(chalk.cyan(icon), text);\n }\n}\n\nexport function displaySection(title: string): void {\n displaySeparator();\n console.log(chalk.bold.cyan(`\\n${title}`));\n displaySeparator();\n}\n", "import { Command } from 'commander';\nimport chalk from 'chalk';\nimport careerData from '../data/career.json';\nimport { displaySection } from '../utils/display';\n\nexport function createCareerCommand(): Command {\n const cmd = new Command('career')\n .description('\u67E5\u770B\u6211\u7684\u5DE5\u4F5C\u7ECF\u5386')\n .action(() => {\n displaySection('\uD83D\uDCBC \u5DE5\u4F5C\u7ECF\u5386');\n\n careerData.career.forEach((job, index) => {\n console.log('');\n\n console.log(chalk.yellow.bold(`\uD83D\uDCCB ${job.company}`));\n console.log(chalk.cyan(` ${job.role}`));\n console.log(chalk.gray(` ${job.period}`));\n console.log('');\n\n console.log(chalk.white(' \uD83D\uDCDD ' + job.description));\n console.log('');\n\n if (job.achievements && job.achievements.length > 0) {\n console.log(chalk.gray(' \u4E3B\u8981\u6210\u5C31:'));\n job.achievements.forEach(achievement => {\n console.log(chalk.green(' \u2713 ' + achievement));\n });\n }\n\n if (index < careerData.career.length - 1) {\n console.log('');\n console.log(chalk.gray('\u2500'.repeat(40)));\n }\n });\n\n console.log('');\n });\n\n return cmd;\n}\n", "{\n \"career\": [\n {\n \"company\": \"\u5F71\u5200 RPA\uFF08AI Power \u56E2\u961F\uFF09\",\n \"role\": \"\u5168\u6808\u5DE5\u7A0B\u5E08 / AI Agent \u5F00\u53D1\u8005\",\n \"period\": \"2025.10 - \u81F3\u4ECA\",\n \"description\": \"\u805A\u7126 AI \u5DE5\u4F5C\u6D41\u5EFA\u8BBE\uFF0C\u4E3B\u5BFC AI Agent \u65B9\u6848\u8BBE\u8BA1\u4E0E\u843D\u5730\uFF0C\u63A8\u52A8\u4E1A\u52A1\u4ECE\u529F\u80FD\u5F00\u53D1\u8D70\u5411\u667A\u80FD\u5316\u6D41\u7A0B\u7F16\u6392\u3002\",\n \"achievements\": [\n \"\u8D1F\u8D23 AI \u5DE5\u4F5C\u6D41\u76F8\u5173\u80FD\u529B\u5EFA\u8BBE\uFF0C\u63A8\u52A8\u56E2\u961F\u5F62\u6210\u53EF\u590D\u7528\u7684\u6D41\u7A0B\u5316\u4EA4\u4ED8\u65B9\u5F0F\",\n \"\u62C5\u4EFB AI Agent \u6838\u5FC3\u5F00\u53D1\u8005\uFF0C\u8986\u76D6\u4ECE\u9700\u6C42\u62C6\u89E3\u3001\u63D0\u793A\u8BCD\u8BBE\u8BA1\u5230\u670D\u52A1\u7AEF\u843D\u5730\u7684\u5B8C\u6574\u94FE\u8DEF\",\n \"\u4EE5\u5168\u6808\u65B9\u5F0F\u534F\u540C\u524D\u540E\u7AEF\u5F00\u53D1\uFF0C\u63D0\u5347\u590D\u6742\u4E1A\u52A1\u5728\u7814\u53D1\u4FA7\u7684\u843D\u5730\u6548\u7387\",\n \"\u5728\u56E2\u961F\u5185\u63A8\u8FDB AI \u5DE5\u7A0B\u5316\u5B9E\u8DF5\uFF0C\u6301\u7EED\u63D0\u5347\u9879\u76EE\u7A33\u5B9A\u6027\u4E0E\u8FED\u4EE3\u901F\u5EA6\"\n ]\n },\n {\n \"company\": \"\u676D\u5DDE\u4E0D\u5FD8\u667A\u80FD\u79D1\u6280\u6709\u9650\u516C\u53F8\",\n \"role\": \"\u5168\u6808\u5F00\u53D1\u5DE5\u7A0B\u5E08\",\n \"period\": \"2024.10 - 2025.09\",\n \"description\": \"\u53C2\u4E0E AI \u89C6\u9891\u751F\u6210\u4E0E\u5E7F\u544A\u6295\u653E\u4EA7\u54C1\u5EFA\u8BBE\uFF0C\u8D1F\u8D23\u524D\u540E\u7AEF\u8054\u52A8\u548C\u6838\u5FC3\u529F\u80FD\u843D\u5730\u3002\",\n \"achievements\": [\n \"\u57FA\u4E8E Next.js + React + Node.js \u53C2\u4E0E\u9AD8\u4EA4\u4E92\u5E94\u7528\u4E0E\u4E2D\u53F0\u670D\u52A1\u5F00\u53D1\",\n \"\u53C2\u4E0E ASR\u3001LLM\u3001\u89C6\u9891\u4EFB\u52A1\u94FE\u8DEF\u7B49 AI \u76F8\u5173\u529F\u80FD\u5EFA\u8BBE\",\n \"\u53C2\u4E0E\u81EA\u52A8\u5316\u6295\u653E\u4E0E\u5DE5\u7A0B\u5316\u6D41\u7A0B\u5EFA\u8BBE\uFF0C\u63D0\u5347\u4E1A\u52A1\u5904\u7406\u6548\u7387\"\n ]\n },\n {\n \"company\": \"\u676D\u5DDE\u89C6\u674F\u79D1\u6280\u6709\u9650\u516C\u53F8\",\n \"role\": \"\u524D\u7AEF\u5F00\u53D1\u5DE5\u7A0B\u5E08\",\n \"period\": \"2022.10 - 2024.06\",\n \"description\": \"\u8D1F\u8D23\u524D\u7AEF\u5DE5\u7A0B\u5316\u3001\u4E1A\u52A1\u7CFB\u7EDF\u5F00\u53D1\u4E0E\u56E2\u961F\u534F\u4F5C\u6D41\u7A0B\u4F18\u5316\u3002\",\n \"achievements\": [\n \"\u63A8\u52A8\u89C4\u8303\u4F53\u7CFB\u843D\u5730\uFF08Lint\u3001Commit \u89C4\u8303\u3001\u811A\u624B\u67B6\u7B49\uFF09\uFF0C\u63D0\u5347\u56E2\u961F\u7814\u53D1\u4E00\u81F4\u6027\",\n \"\u53C2\u4E0E\u6784\u5EFA\u79C1\u6709\u5E93\u4E0E\u5DE5\u7A0B\u5316\u4F53\u7CFB\uFF0C\u63D0\u5347\u591A\u9879\u76EE\u590D\u7528\u6548\u7387\",\n \"\u652F\u6491\u540E\u53F0\u7CFB\u7EDF\u4E0E\u6838\u5FC3\u4E1A\u52A1\u9875\u9762\u7684\u6301\u7EED\u8FED\u4EE3\"\n ]\n },\n {\n \"company\": \"\u534E\u76D6\u5BB6\u5C45\u3001\u9177\u5BB6\u4E50\uFF08\u4E0D\u540C\u516C\u53F8\uFF09\",\n \"role\": \"\u524D\u7AEF\u5F00\u53D1\u5DE5\u7A0B\u5E08\",\n \"period\": \"2020.11 - 2022.06\",\n \"description\": \"\u65E9\u671F\u7ECF\u5386\uFF0C\u4E3B\u8981\u8D1F\u8D23 2D Canvas \u76F8\u5173\u529F\u80FD\u5F00\u53D1\u4E0E\u7EF4\u62A4\u3002\",\n \"achievements\": [\n \"\u53C2\u4E0E 2D \u8BBE\u8BA1\u5DE5\u5177\u4E0E\u4E3B\u7AD9\u76F8\u5173\u524D\u7AEF\u529F\u80FD\u5F00\u53D1\",\n \"\u8D1F\u8D23\u753B\u5E03\u4EA4\u4E92\u3001\u5386\u53F2\u8BB0\u5F55\u4E0E\u5FEB\u6377\u952E\u7B49\u80FD\u529B\u8FED\u4EE3\",\n \"\u4E0E\u4EA7\u54C1\u3001\u8BBE\u8BA1\u3001\u6D4B\u8BD5\u534F\u4F5C\u63A8\u8FDB\u7248\u672C\u4EA4\u4ED8\"\n ]\n }\n ]\n}\n", "import { Command } from 'commander';\nimport chalk from 'chalk';\nimport path from 'path';\nimport fs from 'fs';\n\nconst RETRO_PIXEL_WIDTH = 28;\nconst RETRO_PIXEL_HEIGHT = 16;\n\nconst resolveExecutableDir = (): string => {\n if (!process.argv[1]) {\n return process.cwd();\n }\n\n const executablePath = path.resolve(process.argv[1]);\n try {\n const resolvedExecutablePath = fs.realpathSync(executablePath);\n return path.dirname(resolvedExecutablePath);\n } catch {\n return path.dirname(executablePath);\n }\n};\n\nconst resolveCatImagePath = (): string | null => {\n const executableDir = resolveExecutableDir();\n const packageRootDir = path.resolve(executableDir, '..');\n const candidatePaths = [\n path.resolve(process.cwd(), 'src/assets/cat.jpg'),\n path.resolve(packageRootDir, 'src/assets/cat.jpg'),\n path.resolve(packageRootDir, 'dist/assets/cat.jpg'),\n path.resolve(executableDir, 'assets/cat.jpg'),\n path.resolve(executableDir, '../assets/cat.jpg')\n ];\n\n for (const candidatePath of candidatePaths) {\n if (fs.existsSync(candidatePath)) {\n return candidatePath;\n }\n }\n\n return null;\n};\n\nexport function createCatCommand(): Command {\n const cmd = new Command('cat')\n .alias('meow')\n .description('\u67E5\u770B\u9EA6\u9EA6')\n .action(async () => {\n console.log(chalk.yellow.bold('\u9EA6\u9EA6'));\n console.log('');\n\n try {\n const catImagePath = resolveCatImagePath();\n\n if (catImagePath) {\n try {\n const { default: terminalImage } = await import('terminal-image');\n const image = await terminalImage.file(catImagePath, {\n width: RETRO_PIXEL_WIDTH,\n height: RETRO_PIXEL_HEIGHT,\n preserveAspectRatio: true\n });\n\n console.log(image);\n } catch (error) {\n console.log(chalk.red('\u56FE\u7247\u6E32\u67D3\u5931\u8D25'));\n }\n } else {\n console.log(chalk.gray('\u8BF7\u5C06\u732B\u54AA\u56FE\u7247\u653E\u5728 src/assets/cat.jpg'));\n }\n } catch (error) {\n console.log(chalk.gray('\uD83D\uDCF8 \u8BF7\u5C06\u732B\u54AA\u56FE\u7247\u653E\u5728 src/assets/cat.jpg'));\n }\n\n console.log('');\n });\n\n return cmd;\n}\n", "import React, { useState } from 'react';\nimport { render, Box, Text, useInput } from 'ink';\nimport { Command } from 'commander';\nimport blogData from '../data/blog.json';\n\ninterface Post {\n id: string;\n title: string;\n author: string;\n date: string;\n summary: string;\n content: string[];\n tags: string[];\n}\n\n// \u6587\u7AE0\u5217\u8868\u7EC4\u4EF6\nconst PostList: React.FC<{\n posts: Post[];\n selectedIndex: number;\n onSelect: (index: number) => void;\n}> = ({ posts, selectedIndex, onSelect }) => {\n useInput((input, key) => {\n if (key.upArrow) {\n onSelect(Math.max(0, selectedIndex - 1));\n } else if (key.downArrow) {\n onSelect(Math.min(posts.length - 1, selectedIndex + 1));\n }\n });\n\n return (\n <Box flexDirection=\"column\" paddingX={2} paddingY={1}>\n <Box marginBottom={1}>\n <Text bold color=\"cyan\">\n \u9EA6\u5F53\u7684\u535A\u5BA2\n </Text>\n <Text dimColor> \u00B7 \u7528\u65B9\u5411\u952E\u9009\u62E9\uFF0C\u56DE\u8F66\u9605\u8BFB</Text>\n </Box>\n\n <Box flexDirection=\"column\">\n {posts.map((post, index) => (\n <Box\n key={post.id}\n flexDirection=\"column\"\n borderStyle={index === selectedIndex ? 'bold' : 'single'}\n borderColor={index === selectedIndex ? 'cyan' : 'gray'}\n paddingX={1}\n marginY={0}\n >\n <Box>\n <Text bold={index === selectedIndex} color={index === selectedIndex ? 'cyan' : 'white'}>\n {post.title}\n </Text>\n </Box>\n <Box marginTop={0}>\n <Text dimColor>{post.date} \u00B7 {post.author}</Text>\n </Box>\n <Box marginTop={0}>\n <Text dimColor italic>\n {post.summary.substring(0, 60)}...\n </Text>\n </Box>\n </Box>\n ))}\n </Box>\n\n <Box marginTop={1}>\n <Text dimColor>\u6309 ESC \u6216 q \u8FD4\u56DE</Text>\n </Box>\n </Box>\n );\n};\n\n// \u6587\u7AE0\u8BE6\u60C5\u7EC4\u4EF6\nconst PostDetail: React.FC<{\n post: Post;\n onBack: () => void;\n}> = ({ post, onBack }) => {\n useInput((input) => {\n if (input === 'q' || input === 'Q') {\n onBack();\n }\n });\n\n return (\n <Box flexDirection=\"column\" paddingX={2} paddingY={1}>\n <Box flexDirection=\"column\" marginBottom={1}>\n <Text bold color=\"cyan\">\n {post.title}\n </Text>\n <Box marginTop={0}>\n <Text dimColor>\n {post.date} \u00B7 {post.author}\n </Text>\n </Box>\n <Box marginTop={0}>\n {post.tags.map(tag => (\n <Text key={tag} color=\"gray\" backgroundColor=\"black\" dimColor>\n {' '}{tag}{' '}\n </Text>\n ))}\n </Box>\n </Box>\n\n <Box borderStyle=\"single\" borderColor=\"gray\" paddingX={1} marginBottom={1}>\n <Text italic dimColor>\n {post.summary}\n </Text>\n </Box>\n\n <Box flexDirection=\"column\">\n {post.content.map((paragraph, index) => (\n <Box key={index} marginBottom={paragraph === '' ? 0 : 0}>\n <Text>{paragraph}</Text>\n </Box>\n ))}\n </Box>\n\n <Box marginTop={1}>\n <Text dimColor>\u6309 q \u8FD4\u56DE\u5217\u8868</Text>\n </Box>\n </Box>\n );\n};\n\n// \u535A\u5BA2\u5E94\u7528\u4E3B\u7EC4\u4EF6\nconst BlogApp: React.FC = () => {\n const [view, setView] = useState<'list' | 'detail'>('list');\n const [selectedIndex, setSelectedIndex] = useState(0);\n const posts: Post[] = blogData.posts;\n\n useInput((input, key) => {\n if (view === 'list') {\n if (key.return) {\n setView('detail');\n } else if (input === 'q' || input === 'Q') {\n process.exit(0);\n }\n } else if (view === 'detail') {\n if (key.escape) {\n setView('list');\n }\n }\n });\n\n if (view === 'detail') {\n return <PostDetail post={posts[selectedIndex]} onBack={() => setView('list')} />;\n }\n\n return (\n <PostList\n posts={posts}\n selectedIndex={selectedIndex}\n onSelect={setSelectedIndex}\n />\n );\n};\n\nexport function createBlogCommand(): Command {\n const cmd = new Command('blog')\n .description('\u9605\u8BFB\u9EA6\u5F53\u7684\u535A\u5BA2\u6587\u7AE0')\n .action(() => {\n render(<BlogApp />);\n });\n\n return cmd;\n}\n", "{\n \"posts\": [\n {\n \"id\": \"1\",\n \"title\": \"AI \u65F6\u4EE3\u7684\u7F16\u7A0B\u601D\u8003\",\n \"author\": \"\u9EA6\u5F53\",\n \"date\": \"2024-03-15\",\n \"summary\": \"\u5728\u4EBA\u5DE5\u667A\u80FD\u5FEB\u901F\u53D1\u5C55\u7684\u4ECA\u5929\uFF0C\u7A0B\u5E8F\u5458\u7684\u89D2\u8272\u6B63\u5728\u53D1\u751F\u6DF1\u523B\u53D8\u5316\u3002\u672C\u6587\u63A2\u8BA8\u5982\u4F55\u5728\u8FD9\u4E2A\u65B0\u65F6\u4EE3\u4FDD\u6301\u7ADE\u4E89\u529B\u548C\u521B\u9020\u529B\u3002\",\n \"content\": [\n \"\u4EBA\u5DE5\u667A\u80FD\u6B63\u5728\u91CD\u5851\u8F6F\u4EF6\u5F00\u53D1\u7684\u65B9\u65B9\u9762\u9762\u3002\u4ECE\u4EE3\u7801\u8865\u5168\u5230\u81EA\u52A8\u5316\u6D4B\u8BD5\uFF0CAI \u5DE5\u5177\u5DF2\u7ECF\u6210\u4E3A\u5F00\u53D1\u8005\u65E5\u5E38\u5DE5\u4F5C\u7684\u91CD\u8981\u52A9\u624B\u3002\",\n \"\",\n \"\u7136\u800C\uFF0C\u8FD9\u5E76\u4E0D\u610F\u5473\u7740\u7A0B\u5E8F\u5458\u4F1A\u88AB\u53D6\u4EE3\u3002\u76F8\u53CD\uFF0C\u6211\u4EEC\u7684\u89D2\u8272\u6B63\u5728\u4ECE\u300C\u5199\u4EE3\u7801\u300D\u8F6C\u5411\u300C\u8BBE\u8BA1\u7CFB\u7EDF\u300D\u548C\u300C\u89E3\u51B3\u95EE\u9898\u300D\u3002AI \u53EF\u4EE5\u751F\u6210\u4EE3\u7801\uFF0C\u4F46\u7406\u89E3\u4E1A\u52A1\u9700\u6C42\u3001\u8BBE\u8BA1\u67B6\u6784\u3001\u505A\u51FA\u6743\u8861\u51B3\u7B56\uFF0C\u8FD9\u4E9B\u4ECD\u7136\u9700\u8981\u4EBA\u7C7B\u7684\u667A\u6167\u548C\u7ECF\u9A8C\u3002\",\n \"\",\n \"\u5728 AI \u65F6\u4EE3\uFF0C\u6700\u91CD\u8981\u7684\u80FD\u529B\u662F\uFF1A\",\n \"\u2022 \u5FEB\u901F\u5B66\u4E60\u80FD\u529B - \u6280\u672F\u66F4\u65B0\u52A0\u901F\uFF0C\u6301\u7EED\u5B66\u4E60\u6210\u4E3A\u5E38\u6001\",\n \"\u2022 \u7CFB\u7EDF\u601D\u7EF4 - \u7406\u89E3\u590D\u6742\u7CFB\u7EDF\u7684\u6574\u4F53\u8FD0\u4F5C\",\n \"\u2022 \u521B\u9020\u529B - \u5728 AI \u8F85\u52A9\u4E0B\u63A2\u7D22\u66F4\u591A\u53EF\u80FD\u6027\",\n \"\u2022 \u6C9F\u901A\u80FD\u529B - \u51C6\u786E\u7406\u89E3\u9700\u6C42\u5E76\u6709\u6548\u534F\u4F5C\",\n \"\",\n \"\u62E5\u62B1\u53D8\u5316\uFF0C\u4FDD\u6301\u597D\u5947\uFF0C\u6211\u4EEC\u624D\u80FD\u5728\u8FD9\u4E2A\u5145\u6EE1\u673A\u9047\u7684\u65F6\u4EE3\u4E2D\u627E\u5230\u81EA\u5DF1\u7684\u4F4D\u7F6E\u3002\"\n ],\n \"tags\": [\"AI\", \"\u7F16\u7A0B\", \"\u601D\u8003\"]\n }\n ]\n}\n", "import React, { useState } from 'react';\nimport { render, Box, Text, useInput } from 'ink';\nimport { Command } from 'commander';\nimport postsData from '../data/posts.json';\n\ninterface PostItem {\n id: string;\n author: string;\n handle: string;\n date: string;\n time: string;\n content: string;\n tags: string[];\n}\n\nconst FeedPost: React.FC<{\n post: PostItem;\n isSelected: boolean;\n}> = ({ post, isSelected }) => (\n <Box flexDirection=\"column\" paddingX={1} marginY={0}>\n <Box>\n <Text bold color={isSelected ? 'cyan' : 'white'}>\n {post.author}\n </Text>\n <Text dimColor> {post.handle}</Text>\n <Text dimColor> \u00B7 {post.date} {post.time}</Text>\n </Box>\n <Box marginTop={0} flexWrap=\"wrap\">\n <Text color={isSelected ? 'gray' : undefined}>{post.content}</Text>\n </Box>\n {post.tags && post.tags.length > 0 && (\n <Box marginTop={0} flexWrap=\"wrap\">\n {post.tags.map((tag) => (\n <Text key={tag} dimColor>\n #{tag}{' '}\n </Text>\n ))}\n </Box>\n )}\n </Box>\n);\n\nconst PostsFeed: React.FC<{\n posts: PostItem[];\n selectedIndex: number;\n onSelect: (index: number) => void;\n onQuit: () => void;\n}> = ({ posts, selectedIndex, onSelect, onQuit }) => {\n useInput((input, key) => {\n if (input === 'q' || input === 'Q') {\n onQuit();\n return;\n }\n if (key.upArrow) {\n onSelect(Math.max(0, selectedIndex - 1));\n } else if (key.downArrow) {\n onSelect(Math.min(posts.length - 1, selectedIndex + 1));\n }\n });\n\n return (\n <Box flexDirection=\"column\" paddingX={2} paddingY={1}>\n <Box marginBottom={1}>\n <Text bold color=\"cyan\">\n \uD83D\uDC26 \u9EA6\u5F53\u7684\u63A8\u6587\n </Text>\n <Text dimColor> \u00B7 \u65B9\u5411\u952E\u6D4F\u89C8\uFF0Cq \u9000\u51FA</Text>\n </Box>\n\n <Box flexDirection=\"column\" borderStyle=\"single\" borderColor=\"gray\" paddingX={0} paddingY={0}>\n {posts.map((post, index) => (\n <Box\n key={post.id}\n flexDirection=\"column\"\n borderStyle=\"single\"\n borderColor={selectedIndex === index ? 'cyan' : 'gray'}\n paddingX={1}\n paddingY={0}\n marginY={0}\n >\n <FeedPost post={post} isSelected={selectedIndex === index} />\n </Box>\n ))}\n </Box>\n\n <Box marginTop={1}>\n <Text dimColor>\u2191\u2193 \u9009\u62E9 \u00B7 q \u9000\u51FA</Text>\n </Box>\n </Box>\n );\n};\n\nconst PostsApp: React.FC = () => {\n const [selectedIndex, setSelectedIndex] = useState(0);\n const posts: PostItem[] = postsData.posts;\n\n const handleQuit = (): void => {\n process.exit(0);\n };\n\n return (\n <PostsFeed\n posts={posts}\n selectedIndex={selectedIndex}\n onSelect={setSelectedIndex}\n onQuit={handleQuit}\n />\n );\n};\n\nexport function createPostsCommand(): Command {\n const cmd = new Command('posts')\n .description('\u9EA6\u5F53\u7684\u63A8\u6587\u65F6\u95F4\u7EBF\uFF08\u63A8\u7279\u98CE\u683C\uFF09')\n .action(() => {\n render(<PostsApp />);\n });\n\n return cmd;\n}\n", "{\n \"posts\": [\n {\n \"id\": \"1\",\n \"author\": \"\u9EA6\u5F53\",\n \"handle\": \"@maidang\",\n \"date\": \"2025-03-13\",\n \"time\": \"10:00\",\n \"content\": \"\u5982\u4F55\u9009\u62E9 Coding Plan\\n\\n\u4E00\u4E2A\u6700\u5F3A\u7684\u6A21\u578B + \u4E00\u4E2A\u7B2C\u4E00\u68AF\u961F\u6A21\u578B\uFF0C\u5E94\u5BF9\u4EFB\u610F\u6E20\u9053\u7684\u7A81\u53D1\u9650\u6D41\u3001\u65AD\u4F9B\u3001\u5C01\u53F7\\n\\n\u7248\u672C\u6700\u5F3A\u6A21\u578B\uFF1AClaude\uFF08\u95F2\u9C7C\u968F\u4FBF\u627E\u4E00\u4E2A\uFF09\\n\u56FD\u4EA7\u7B2C\u4E00\u68AF\u961F\uFF1Akimi\u3001GLM\u3001Minimax\\n\\n\u4F7F\u7528 cc-switch \u5207\u6362\u6A21\u578B\u63D0\u4F9B\u5546\u3002\u5F53\u4F9B\u5E94\u5546\u9650\u6D41\u3001\u65AD\u4F9B\u4EE5\u540E\uFF0C\u5FEB\u901F\u5207\u6362\u53E6\u4E00\u4E2A\u3002\\n\\nhttps://github.com/farion1231/cc-switch\",\n \"tags\": [\"AI\", \"Claude\", \"\u6A21\u578B\u9009\u62E9\"]\n },\n {\n \"id\": \"2\",\n \"author\": \"\u9EA6\u5F53\",\n \"handle\": \"@maidang\",\n \"date\": \"2026-03-23\",\n \"time\": \"20:00\",\n \"content\": \"\u804C\u573A\u53D1\u5C0F\u8981\u79BB\u804C\u4E86\\n\\n\u8BF4\u5B9E\u8BDD\u633A\u4E0D\u820D\u5F97\uFF0C\u516C\u53F8\u7684\u4F01\u4E1A\u6587\u5316\u624B\u518C\u91CC\u5199\u7740\uFF0C\u5E94\u8BE5\u62DB\u4EC0\u4E48\u6837\u7684\u4EBA\uFF1F\u5C31\u662F\u90A3\u79CD\u79BB\u804C\u7684\u65F6\u5019\u4F60\u4F1A\u6781\u529B\u633D\u7559\u7684\u4EBA\uFF0C\u4F46\u6700\u8FD1\u5DE5\u4F5C\u5F3A\u5EA6\u8D8A\u6765\u8D8A\u5927\uFF0C\u6709\u7684\u540C\u4E8B\u5F00\u6446\u7B49\u793C\u5305\uFF0C\u6709\u7684\u4E0A\u4E86\u730E\u6740\u540D\u5355\uFF0C\u6709\u7684\u4EBA\u8F9E\u804C\u521B\u4E1A\uFF0CAI \u66FF\u4EE3\u5DE5\u4F5C\u7684\u6D6A\u6F6E\u4ECA\u5E74\u4F1A\u6B63\u5F0F\u5F00\u59CB\uFF0C\u4EBA\u4EBA\u81EA\u5371\u7684\u65F6\u5019\uFF0C\u4F60\u53EA\u5E0C\u671B\u4F60\u7684\u670B\u53CB\u8FC7\u5F97\u5065\u5EB7\u5FEB\u4E50\\n\\n\u524D\u5929\u770B\u4E86\u4E00\u90E8\u7535\u5F71\uFF0C\u53EB\u300A\u6B7B\u4EA1\u7ADE\u8D70\u300B\uFF0C\u6211\u89C9\u5F97\u548C\u73B0\u5728\u7684\u5DE5\u4F5C\u72B6\u6001\u5F88\u50CF\uFF0C\u4F60\u8981\u4E48\u5F80\u524D\u8D70\uFF0C\u8981\u4E48\u51FA\u5C40\uFF08\u6216\u4E3B\u52A8\u6216\u88AB\u52A8\uFF09\uFF0C\u4F46\u4E0D\u8BBA\u662F\u8C01\u80FD\u8D70\u5230\u7EC8\u70B9\uFF0C\u540C\u884C\u7684\u4EBA\u90FD\u662F\u73CD\u8D35\u7684\u4F19\u4F34\\n\\n\u795D\u4ED6\u4EEC\u4E00\u8DEF\u987A\u98CE\",\n \"tags\": [\"\u804C\u573A\", \"\u79BB\u804C\", \"\u670B\u53CB\"]\n }\n ]\n}\n", "/**\n * \u8BA1\u7B97\u9EA6\u5F53\u7684\u5E74\u9F84\u7248\u672C\u53F7\n * \u51FA\u751F\u65E5\u671F\uFF1A1997\u5E743\u670810\u65E5\n * \u8FD4\u56DE\u683C\u5F0F\uFF1A\u5E74\u9F84.\u5C0F\u7248\u672C\u53F7.\u8865\u4E01\u53F7\n */\nexport function getAgeVersion(): string {\n const birthDate = new Date(1997, 2, 10); // \u6708\u4EFD\u4ECE0\u5F00\u59CB\uFF0C\u6240\u4EE52\u662F3\u6708\n const today = new Date();\n\n let age = today.getFullYear() - birthDate.getFullYear();\n const monthDiff = today.getMonth() - birthDate.getMonth();\n\n // \u5982\u679C\u8FD8\u6CA1\u8FC7\u751F\u65E5\uFF0C\u5E74\u9F84\u51CF1\n if (monthDiff < 0 || (monthDiff === 0 && today.getDate() < birthDate.getDate())) {\n age--;\n }\n\n // \u8FD9\u91CC\u7684\u5C0F\u7248\u672C\u548C\u8865\u4E01\u53F7\u53EF\u4EE5\u540E\u7EED\u4ECE package.json \u8BFB\u53D6\u6216\u56FA\u5B9A\n // \u73B0\u5728\u5148\u8FD4\u56DE\u7B80\u5355\u683C\u5F0F\n return `${age}.0.0`;\n}\n\n/**\n * \u83B7\u53D6\u7248\u672C\u53F7\u548C\u751F\u65E5\u4FE1\u606F\n */\nexport function getVersionInfo(): { version: string; birthDate: Date; currentAge: number; nextBirthday: Date } {\n const birthDate = new Date(1997, 2, 10); // 1997\u5E743\u670810\u65E5\n const today = new Date();\n\n let currentAge = today.getFullYear() - birthDate.getFullYear();\n const monthDiff = today.getMonth() - birthDate.getMonth();\n\n // \u8BA1\u7B97\u4E0B\u4E00\u4E2A\u751F\u65E5\n const nextBirthday = new Date(today.getFullYear(), birthDate.getMonth(), birthDate.getDate());\n\n if (monthDiff < 0 || (monthDiff === 0 && today.getDate() < birthDate.getDate())) {\n currentAge--;\n } else {\n nextBirthday.setFullYear(today.getFullYear() + 1);\n }\n\n const version = `${currentAge}.0.0`;\n\n return {\n version,\n birthDate,\n currentAge,\n nextBirthday\n };\n}\n"],
5
- "mappings": "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",
6
- "names": ["Command", "chalk", "chalk", "Command", "chalk", "Command", "chalk", "Command", "chalk", "Command", "Command", "React", "useState", "render", "Box", "Text", "useInput", "Command", "React", "Box", "Text", "useInput", "useState", "Command", "render", "Command"]
3
+ "sources": ["../src/index.ts", "../src/commands/home.ts", "../src/utils/display.ts", "../src/commands/career.ts", "../src/data/career.json", "../src/commands/cat.ts", "../src/commands/blog.tsx", "../src/data/blog.json", "../src/commands/posts.tsx", "../src/commands/links.ts", "../src/commands/projects.ts", "../src/commands/tools.ts", "../src/utils/version.ts"],
4
+ "sourcesContent": ["#!/usr/bin/env node\n\nimport { Command } from 'commander';\nimport { createHomeCommand } from './commands/home';\nimport { createCareerCommand } from './commands/career';\nimport { createCatCommand } from './commands/cat';\nimport { createBlogCommand } from './commands/blog';\nimport { createPostsCommand } from './commands/posts';\nimport { createLinksCommand } from './commands/links';\nimport { createProjectsCommand } from './commands/projects';\nimport { createToolsCommand } from './commands/tools';\nimport { getAgeVersion, getVersionInfo } from './utils/version';\n\nconst program = new Command();\n\n// \u52A8\u6001\u8BA1\u7B97\u5E74\u9F84\u7248\u672C\u53F7\nconst versionInfo = getVersionInfo();\n\nprogram\n .name('maidang')\n .description('\u4E86\u89E3\u9EA6\u5F53 - \u4E00\u4E2A AI \u65F6\u4EE3\u7684\u63A2\u7D22\u8005')\n .version(getAgeVersion(), '-v, --version', '\u663E\u793A\u9EA6\u5F53\u7684\u5E74\u9F84\u7248\u672C\u53F7');\n\n// \u6DFB\u52A0\u4E00\u4E2A\u7279\u6B8A\u7684\u751F\u65E5\u4FE1\u606F\u547D\u4EE4\nprogram\n .command('birthday')\n .description('\u663E\u793A\u9EA6\u5F53\u7684\u751F\u65E5\u4FE1\u606F')\n .action(() => {\n const { birthDate, currentAge, nextBirthday, version } = versionInfo;\n\n console.log(`\uD83C\uDF82 \u9EA6\u5F53\u7684\u751F\u65E5\u4FE1\u606F`);\n console.log('');\n console.log(`\u51FA\u751F\u65E5\u671F: ${birthDate.toLocaleDateString('zh-CN', { year: 'numeric', month: 'long', day: 'numeric' })}`);\n console.log(`\u5F53\u524D\u5E74\u9F84: ${currentAge} \u5C81`);\n console.log(`\u5F53\u524D\u7248\u672C: ${version} (\u5E74\u9F84\u7248\u672C)`);\n console.log(`\u4E0B\u4E00\u4E2A\u751F\u65E5: ${nextBirthday.toLocaleDateString('zh-CN', { year: 'numeric', month: 'long', day: 'numeric' })}`);\n\n const daysUntilNextBirthday = Math.ceil((nextBirthday.getTime() - new Date().getTime()) / (1000 * 60 * 60 * 24));\n console.log(`\u8DDD\u79BB\u751F\u65E5\u8FD8\u6709: ${daysUntilNextBirthday} \u5929`);\n\n if (daysUntilNextBirthday <= 30) {\n console.log(`\uD83C\uDF89 \u5FEB\u8981\u8FC7\u751F\u65E5\u4E86\uFF01`);\n }\n });\n\nconst careerCmd = createCareerCommand();\nconst catCmd = createCatCommand();\nconst blogCmd = createBlogCommand();\nconst postsCmd = createPostsCommand();\nconst linksCmd = createLinksCommand();\nconst projectsCmd = createProjectsCommand();\nconst toolsCmd = createToolsCommand();\n\nprogram.addCommand(careerCmd);\nprogram.addCommand(catCmd);\nprogram.addCommand(blogCmd);\nprogram.addCommand(postsCmd);\nprogram.addCommand(linksCmd);\nprogram.addCommand(projectsCmd);\nprogram.addCommand(toolsCmd);\n\nif (!process.argv.slice(2).length) {\n const homeCmd = createHomeCommand();\n homeCmd.parse(process.argv);\n} else {\n program.parse(process.argv);\n}\n", "import { Command } from 'commander';\nimport chalk from 'chalk';\nimport { createSpinner } from '../utils/display';\n\nconst commands = [\n { name: 'birthday', desc: '\u663E\u793A\u9EA6\u5F53\u7684\u751F\u65E5\u4FE1\u606F' },\n { name: 'career', desc: '\u67E5\u770B\u5DE5\u4F5C\u7ECF\u5386' },\n { name: 'cat | meow', desc: '\u67E5\u770B\u9EA6\u9EA6' },\n { name: 'blog', desc: '\u9605\u8BFB\u535A\u5BA2\u6587\u7AE0' },\n { name: 'posts', desc: '\u63A8\u6587\u65F6\u95F4\u7EBF' },\n { name: 'links', desc: '\u67E5\u770B\u793E\u4EA4\u94FE\u63A5' },\n { name: 'projects', desc: '\u67E5\u770B\u4E2A\u4EBA\u9879\u76EE' },\n { name: 'tools', desc: '\u67E5\u770B\u5E38\u7528\u5DE5\u5177' },\n];\n\nexport function createHomeCommand(): Command {\n const cmd = new Command('maidang')\n .description('\u6B22\u8FCE\u6765\u5230\u5356\u5F53\u7684\u4E16\u754C')\n .action(async () => {\n const spinner = createSpinner('\u6B63\u5728\u53EC\u5524\u5356\u5F53...');\n spinner.start();\n\n await new Promise(resolve => setTimeout(resolve, 1000));\n\n spinner.stop();\n\n console.clear();\n\n console.log(chalk.cyan.bold('\u5356\u5F53\uFF0CAI \u65F6\u4EE3\u63A2\u7D22\u8005'));\n console.log(chalk.gray('\u8DF5\u884C\u53EF\u6301\u7EED\u751F\u6D3B\u65B9\u5F0F'));\n console.log('');\n console.log(chalk.gray('\u2500'.repeat(40)));\n console.log('');\n\n for (const cmd of commands) {\n console.log(` ${chalk.white.bold(cmd.name.padEnd(12))} ${chalk.gray(cmd.desc)}`);\n }\n\n console.log('');\n console.log(chalk.gray('\u2500'.repeat(40)));\n console.log('');\n });\n\n return cmd;\n}\n", "import chalk from 'chalk';\nimport boxen from 'boxen';\nimport figlet from 'figlet';\nimport ora, { Ora } from 'ora';\n\nexport async function displayTitle(text: string): Promise<void> {\n return new Promise((resolve) => {\n figlet.text(text, {\n font: 'Big',\n horizontalLayout: 'default',\n verticalLayout: 'default'\n }, (err, data) => {\n if (err) {\n console.log(chalk.cyan.bold(text));\n } else {\n console.log(chalk.cyan(data));\n }\n resolve();\n });\n });\n}\n\nexport function displayBox(content: string, options?: {\n title?: string;\n borderColor?: string;\n padding?: number;\n}): void {\n const borderOptions: any = {\n padding: options?.padding || 1,\n borderColor: options?.borderColor || 'cyan',\n borderStyle: 'round'\n };\n\n if (options?.title) {\n borderOptions.title = options.title;\n borderOptions.titleAlignment = 'center';\n }\n\n console.log(boxen(content, borderOptions));\n}\n\nexport function createSpinner(text: string): Ora {\n return ora({\n text,\n color: 'cyan'\n });\n}\n\nexport function displaySeparator(char: string = '\u2500', length: number = 50): void {\n console.log(chalk.gray(char.repeat(length)));\n}\n\nexport function displayItem(icon: string, text: string, color: string = 'cyan'): void {\n const colorMethod = (chalk as any)[color];\n if (colorMethod) {\n console.log(colorMethod(icon), text);\n } else {\n console.log(chalk.cyan(icon), text);\n }\n}\n\nexport function displaySection(title: string): void {\n displaySeparator();\n console.log(chalk.bold.cyan(`\\n${title}`));\n displaySeparator();\n}\n", "import { Command } from 'commander';\nimport chalk from 'chalk';\nimport careerData from '../data/career.json';\nimport { displaySection } from '../utils/display';\n\nexport function createCareerCommand(): Command {\n const cmd = new Command('career')\n .description('\u67E5\u770B\u6211\u7684\u5DE5\u4F5C\u7ECF\u5386')\n .action(() => {\n displaySection('\uD83D\uDCBC \u5DE5\u4F5C\u7ECF\u5386');\n\n careerData.career.forEach((job, index) => {\n console.log('');\n\n console.log(chalk.yellow.bold(`\uD83D\uDCCB ${job.company}`));\n console.log(chalk.cyan(` ${job.role}`));\n console.log(chalk.gray(` ${job.period}`));\n console.log('');\n\n console.log(chalk.white(' \uD83D\uDCDD ' + job.description));\n console.log('');\n\n if (job.achievements && job.achievements.length > 0) {\n console.log(chalk.gray(' \u4E3B\u8981\u6210\u5C31:'));\n job.achievements.forEach(achievement => {\n console.log(chalk.green(' \u2713 ' + achievement));\n });\n }\n\n if (index < careerData.career.length - 1) {\n console.log('');\n console.log(chalk.gray('\u2500'.repeat(40)));\n }\n });\n\n console.log('');\n });\n\n return cmd;\n}\n", "{\n \"career\": [\n {\n \"company\": \"\u5F71\u5200 RPA\uFF08AI Power \u56E2\u961F\uFF09\",\n \"role\": \"\u5168\u6808\u5DE5\u7A0B\u5E08 / AI Agent \u5F00\u53D1\u8005\",\n \"period\": \"2025.10 - \u81F3\u4ECA\",\n \"description\": \"\u805A\u7126 AI \u5DE5\u4F5C\u6D41\u5EFA\u8BBE\uFF0C\u4E3B\u5BFC AI Agent \u65B9\u6848\u8BBE\u8BA1\u4E0E\u843D\u5730\uFF0C\u63A8\u52A8\u4E1A\u52A1\u4ECE\u529F\u80FD\u5F00\u53D1\u8D70\u5411\u667A\u80FD\u5316\u6D41\u7A0B\u7F16\u6392\u3002\",\n \"achievements\": [\n \"\u8D1F\u8D23 AI \u5DE5\u4F5C\u6D41\u76F8\u5173\u80FD\u529B\u5EFA\u8BBE\uFF0C\u63A8\u52A8\u56E2\u961F\u5F62\u6210\u53EF\u590D\u7528\u7684\u6D41\u7A0B\u5316\u4EA4\u4ED8\u65B9\u5F0F\",\n \"\u62C5\u4EFB AI Agent \u6838\u5FC3\u5F00\u53D1\u8005\uFF0C\u8986\u76D6\u4ECE\u9700\u6C42\u62C6\u89E3\u3001\u63D0\u793A\u8BCD\u8BBE\u8BA1\u5230\u670D\u52A1\u7AEF\u843D\u5730\u7684\u5B8C\u6574\u94FE\u8DEF\",\n \"\u4EE5\u5168\u6808\u65B9\u5F0F\u534F\u540C\u524D\u540E\u7AEF\u5F00\u53D1\uFF0C\u63D0\u5347\u590D\u6742\u4E1A\u52A1\u5728\u7814\u53D1\u4FA7\u7684\u843D\u5730\u6548\u7387\",\n \"\u5728\u56E2\u961F\u5185\u63A8\u8FDB AI \u5DE5\u7A0B\u5316\u5B9E\u8DF5\uFF0C\u6301\u7EED\u63D0\u5347\u9879\u76EE\u7A33\u5B9A\u6027\u4E0E\u8FED\u4EE3\u901F\u5EA6\"\n ]\n },\n {\n \"company\": \"\u676D\u5DDE\u4E0D\u5FD8\u667A\u80FD\u79D1\u6280\u6709\u9650\u516C\u53F8\",\n \"role\": \"\u5168\u6808\u5F00\u53D1\u5DE5\u7A0B\u5E08\",\n \"period\": \"2024.10 - 2025.09\",\n \"description\": \"\u53C2\u4E0E AI \u89C6\u9891\u751F\u6210\u4E0E\u5E7F\u544A\u6295\u653E\u4EA7\u54C1\u5EFA\u8BBE\uFF0C\u8D1F\u8D23\u524D\u540E\u7AEF\u8054\u52A8\u548C\u6838\u5FC3\u529F\u80FD\u843D\u5730\u3002\",\n \"achievements\": [\n \"\u57FA\u4E8E Next.js + React + Node.js \u53C2\u4E0E\u9AD8\u4EA4\u4E92\u5E94\u7528\u4E0E\u4E2D\u53F0\u670D\u52A1\u5F00\u53D1\",\n \"\u53C2\u4E0E ASR\u3001LLM\u3001\u89C6\u9891\u4EFB\u52A1\u94FE\u8DEF\u7B49 AI \u76F8\u5173\u529F\u80FD\u5EFA\u8BBE\",\n \"\u53C2\u4E0E\u81EA\u52A8\u5316\u6295\u653E\u4E0E\u5DE5\u7A0B\u5316\u6D41\u7A0B\u5EFA\u8BBE\uFF0C\u63D0\u5347\u4E1A\u52A1\u5904\u7406\u6548\u7387\"\n ]\n },\n {\n \"company\": \"\u676D\u5DDE\u89C6\u674F\u79D1\u6280\u6709\u9650\u516C\u53F8\",\n \"role\": \"\u524D\u7AEF\u5F00\u53D1\u5DE5\u7A0B\u5E08\",\n \"period\": \"2022.10 - 2024.06\",\n \"description\": \"\u8D1F\u8D23\u524D\u7AEF\u5DE5\u7A0B\u5316\u3001\u4E1A\u52A1\u7CFB\u7EDF\u5F00\u53D1\u4E0E\u56E2\u961F\u534F\u4F5C\u6D41\u7A0B\u4F18\u5316\u3002\",\n \"achievements\": [\n \"\u63A8\u52A8\u89C4\u8303\u4F53\u7CFB\u843D\u5730\uFF08Lint\u3001Commit \u89C4\u8303\u3001\u811A\u624B\u67B6\u7B49\uFF09\uFF0C\u63D0\u5347\u56E2\u961F\u7814\u53D1\u4E00\u81F4\u6027\",\n \"\u53C2\u4E0E\u6784\u5EFA\u79C1\u6709\u5E93\u4E0E\u5DE5\u7A0B\u5316\u4F53\u7CFB\uFF0C\u63D0\u5347\u591A\u9879\u76EE\u590D\u7528\u6548\u7387\",\n \"\u652F\u6491\u540E\u53F0\u7CFB\u7EDF\u4E0E\u6838\u5FC3\u4E1A\u52A1\u9875\u9762\u7684\u6301\u7EED\u8FED\u4EE3\"\n ]\n },\n {\n \"company\": \"\u534E\u76D6\u5BB6\u5C45\u3001\u9177\u5BB6\u4E50\uFF08\u4E0D\u540C\u516C\u53F8\uFF09\",\n \"role\": \"\u524D\u7AEF\u5F00\u53D1\u5DE5\u7A0B\u5E08\",\n \"period\": \"2020.11 - 2022.06\",\n \"description\": \"\u65E9\u671F\u7ECF\u5386\uFF0C\u4E3B\u8981\u8D1F\u8D23 2D Canvas \u76F8\u5173\u529F\u80FD\u5F00\u53D1\u4E0E\u7EF4\u62A4\u3002\",\n \"achievements\": [\n \"\u53C2\u4E0E 2D \u8BBE\u8BA1\u5DE5\u5177\u4E0E\u4E3B\u7AD9\u76F8\u5173\u524D\u7AEF\u529F\u80FD\u5F00\u53D1\",\n \"\u8D1F\u8D23\u753B\u5E03\u4EA4\u4E92\u3001\u5386\u53F2\u8BB0\u5F55\u4E0E\u5FEB\u6377\u952E\u7B49\u80FD\u529B\u8FED\u4EE3\",\n \"\u4E0E\u4EA7\u54C1\u3001\u8BBE\u8BA1\u3001\u6D4B\u8BD5\u534F\u4F5C\u63A8\u8FDB\u7248\u672C\u4EA4\u4ED8\"\n ]\n }\n ]\n}\n", "import { Command } from 'commander';\nimport chalk from 'chalk';\nimport path from 'path';\nimport fs from 'fs';\n\nconst RETRO_PIXEL_WIDTH = 28;\nconst RETRO_PIXEL_HEIGHT = 16;\n\nconst resolveExecutableDir = (): string => {\n if (!process.argv[1]) {\n return process.cwd();\n }\n\n const executablePath = path.resolve(process.argv[1]);\n try {\n const resolvedExecutablePath = fs.realpathSync(executablePath);\n return path.dirname(resolvedExecutablePath);\n } catch {\n return path.dirname(executablePath);\n }\n};\n\nconst resolveCatImagePath = (): string | null => {\n const executableDir = resolveExecutableDir();\n const packageRootDir = path.resolve(executableDir, '..');\n const candidatePaths = [\n path.resolve(process.cwd(), 'src/assets/cat.jpg'),\n path.resolve(packageRootDir, 'src/assets/cat.jpg'),\n path.resolve(packageRootDir, 'dist/assets/cat.jpg'),\n path.resolve(executableDir, 'assets/cat.jpg'),\n path.resolve(executableDir, '../assets/cat.jpg')\n ];\n\n for (const candidatePath of candidatePaths) {\n if (fs.existsSync(candidatePath)) {\n return candidatePath;\n }\n }\n\n return null;\n};\n\nexport function createCatCommand(): Command {\n const cmd = new Command('cat')\n .alias('meow')\n .description('\u67E5\u770B\u9EA6\u9EA6')\n .action(async () => {\n console.log(chalk.yellow.bold('\u9EA6\u9EA6'));\n console.log('');\n\n try {\n const catImagePath = resolveCatImagePath();\n\n if (catImagePath) {\n try {\n const { default: terminalImage } = await import('terminal-image');\n const image = await terminalImage.file(catImagePath, {\n width: RETRO_PIXEL_WIDTH,\n height: RETRO_PIXEL_HEIGHT,\n preserveAspectRatio: true\n });\n\n console.log(image);\n } catch (error) {\n console.log(chalk.red('\u56FE\u7247\u6E32\u67D3\u5931\u8D25'));\n }\n } else {\n console.log(chalk.gray('\u8BF7\u5C06\u732B\u54AA\u56FE\u7247\u653E\u5728 src/assets/cat.jpg'));\n }\n } catch (error) {\n console.log(chalk.gray('\uD83D\uDCF8 \u8BF7\u5C06\u732B\u54AA\u56FE\u7247\u653E\u5728 src/assets/cat.jpg'));\n }\n\n console.log('');\n });\n\n return cmd;\n}\n", "import React, { useState } from 'react';\nimport { render, Box, Text, useInput } from 'ink';\nimport { Command } from 'commander';\nimport blogData from '../data/blog.json';\n\ninterface Post {\n id: string;\n title: string;\n author: string;\n date: string;\n summary: string;\n content: string[];\n tags: string[];\n}\n\n// \u6587\u7AE0\u5217\u8868\u7EC4\u4EF6\nconst PostList: React.FC<{\n posts: Post[];\n selectedIndex: number;\n onSelect: (index: number) => void;\n}> = ({ posts, selectedIndex, onSelect }) => {\n useInput((input, key) => {\n if (key.upArrow) {\n onSelect(Math.max(0, selectedIndex - 1));\n } else if (key.downArrow) {\n onSelect(Math.min(posts.length - 1, selectedIndex + 1));\n }\n });\n\n return (\n <Box flexDirection=\"column\" paddingX={2} paddingY={1}>\n <Box marginBottom={1}>\n <Text bold color=\"cyan\">\n \u9EA6\u5F53\u7684\u535A\u5BA2\n </Text>\n <Text dimColor> \u00B7 \u7528\u65B9\u5411\u952E\u9009\u62E9\uFF0C\u56DE\u8F66\u9605\u8BFB</Text>\n </Box>\n\n <Box flexDirection=\"column\">\n {posts.map((post, index) => (\n <Box\n key={post.id}\n flexDirection=\"column\"\n borderStyle={index === selectedIndex ? 'bold' : 'single'}\n borderColor={index === selectedIndex ? 'cyan' : 'gray'}\n paddingX={1}\n marginY={0}\n >\n <Box>\n <Text bold={index === selectedIndex} color={index === selectedIndex ? 'cyan' : 'white'}>\n {post.title}\n </Text>\n </Box>\n <Box marginTop={0}>\n <Text dimColor>{post.date} \u00B7 {post.author}</Text>\n </Box>\n <Box marginTop={0}>\n <Text dimColor italic>\n {post.summary.substring(0, 60)}...\n </Text>\n </Box>\n </Box>\n ))}\n </Box>\n\n <Box marginTop={1}>\n <Text dimColor>\u6309 ESC \u6216 q \u8FD4\u56DE</Text>\n </Box>\n </Box>\n );\n};\n\n// \u6587\u7AE0\u8BE6\u60C5\u7EC4\u4EF6\nconst PostDetail: React.FC<{\n post: Post;\n onBack: () => void;\n}> = ({ post, onBack }) => {\n useInput((input) => {\n if (input === 'q' || input === 'Q') {\n onBack();\n }\n });\n\n return (\n <Box flexDirection=\"column\" paddingX={2} paddingY={1}>\n <Box flexDirection=\"column\" marginBottom={1}>\n <Text bold color=\"cyan\">\n {post.title}\n </Text>\n <Box marginTop={0}>\n <Text dimColor>\n {post.date} \u00B7 {post.author}\n </Text>\n </Box>\n <Box marginTop={0}>\n {post.tags.map(tag => (\n <Text key={tag} color=\"gray\" backgroundColor=\"black\" dimColor>\n {' '}{tag}{' '}\n </Text>\n ))}\n </Box>\n </Box>\n\n <Box borderStyle=\"single\" borderColor=\"gray\" paddingX={1} marginBottom={1}>\n <Text italic dimColor>\n {post.summary}\n </Text>\n </Box>\n\n <Box flexDirection=\"column\">\n {post.content.map((paragraph, index) => (\n <Box key={index} marginBottom={paragraph === '' ? 0 : 0}>\n <Text>{paragraph}</Text>\n </Box>\n ))}\n </Box>\n\n <Box marginTop={1}>\n <Text dimColor>\u6309 q \u8FD4\u56DE\u5217\u8868</Text>\n </Box>\n </Box>\n );\n};\n\n// \u535A\u5BA2\u5E94\u7528\u4E3B\u7EC4\u4EF6\nconst BlogApp: React.FC = () => {\n const [view, setView] = useState<'list' | 'detail'>('list');\n const [selectedIndex, setSelectedIndex] = useState(0);\n const posts: Post[] = blogData.posts;\n\n useInput((input, key) => {\n if (view === 'list') {\n if (key.return) {\n setView('detail');\n } else if (input === 'q' || input === 'Q') {\n process.exit(0);\n }\n } else if (view === 'detail') {\n if (key.escape) {\n setView('list');\n }\n }\n });\n\n if (view === 'detail') {\n return <PostDetail post={posts[selectedIndex]} onBack={() => setView('list')} />;\n }\n\n return (\n <PostList\n posts={posts}\n selectedIndex={selectedIndex}\n onSelect={setSelectedIndex}\n />\n );\n};\n\nexport function createBlogCommand(): Command {\n const cmd = new Command('blog')\n .description('\u9605\u8BFB\u9EA6\u5F53\u7684\u535A\u5BA2\u6587\u7AE0')\n .action(() => {\n render(<BlogApp />);\n });\n\n return cmd;\n}\n", "{\n \"posts\": [\n {\n \"id\": \"1\",\n \"title\": \"AI \u65F6\u4EE3\u7684\u7F16\u7A0B\u601D\u8003\",\n \"author\": \"\u9EA6\u5F53\",\n \"date\": \"2024-03-15\",\n \"summary\": \"\u5728\u4EBA\u5DE5\u667A\u80FD\u5FEB\u901F\u53D1\u5C55\u7684\u4ECA\u5929\uFF0C\u7A0B\u5E8F\u5458\u7684\u89D2\u8272\u6B63\u5728\u53D1\u751F\u6DF1\u523B\u53D8\u5316\u3002\u672C\u6587\u63A2\u8BA8\u5982\u4F55\u5728\u8FD9\u4E2A\u65B0\u65F6\u4EE3\u4FDD\u6301\u7ADE\u4E89\u529B\u548C\u521B\u9020\u529B\u3002\",\n \"content\": [\n \"\u4EBA\u5DE5\u667A\u80FD\u6B63\u5728\u91CD\u5851\u8F6F\u4EF6\u5F00\u53D1\u7684\u65B9\u65B9\u9762\u9762\u3002\u4ECE\u4EE3\u7801\u8865\u5168\u5230\u81EA\u52A8\u5316\u6D4B\u8BD5\uFF0CAI \u5DE5\u5177\u5DF2\u7ECF\u6210\u4E3A\u5F00\u53D1\u8005\u65E5\u5E38\u5DE5\u4F5C\u7684\u91CD\u8981\u52A9\u624B\u3002\",\n \"\",\n \"\u7136\u800C\uFF0C\u8FD9\u5E76\u4E0D\u610F\u5473\u7740\u7A0B\u5E8F\u5458\u4F1A\u88AB\u53D6\u4EE3\u3002\u76F8\u53CD\uFF0C\u6211\u4EEC\u7684\u89D2\u8272\u6B63\u5728\u4ECE\u300C\u5199\u4EE3\u7801\u300D\u8F6C\u5411\u300C\u8BBE\u8BA1\u7CFB\u7EDF\u300D\u548C\u300C\u89E3\u51B3\u95EE\u9898\u300D\u3002AI \u53EF\u4EE5\u751F\u6210\u4EE3\u7801\uFF0C\u4F46\u7406\u89E3\u4E1A\u52A1\u9700\u6C42\u3001\u8BBE\u8BA1\u67B6\u6784\u3001\u505A\u51FA\u6743\u8861\u51B3\u7B56\uFF0C\u8FD9\u4E9B\u4ECD\u7136\u9700\u8981\u4EBA\u7C7B\u7684\u667A\u6167\u548C\u7ECF\u9A8C\u3002\",\n \"\",\n \"\u5728 AI \u65F6\u4EE3\uFF0C\u6700\u91CD\u8981\u7684\u80FD\u529B\u662F\uFF1A\",\n \"\u2022 \u5FEB\u901F\u5B66\u4E60\u80FD\u529B - \u6280\u672F\u66F4\u65B0\u52A0\u901F\uFF0C\u6301\u7EED\u5B66\u4E60\u6210\u4E3A\u5E38\u6001\",\n \"\u2022 \u7CFB\u7EDF\u601D\u7EF4 - \u7406\u89E3\u590D\u6742\u7CFB\u7EDF\u7684\u6574\u4F53\u8FD0\u4F5C\",\n \"\u2022 \u521B\u9020\u529B - \u5728 AI \u8F85\u52A9\u4E0B\u63A2\u7D22\u66F4\u591A\u53EF\u80FD\u6027\",\n \"\u2022 \u6C9F\u901A\u80FD\u529B - \u51C6\u786E\u7406\u89E3\u9700\u6C42\u5E76\u6709\u6548\u534F\u4F5C\",\n \"\",\n \"\u62E5\u62B1\u53D8\u5316\uFF0C\u4FDD\u6301\u597D\u5947\uFF0C\u6211\u4EEC\u624D\u80FD\u5728\u8FD9\u4E2A\u5145\u6EE1\u673A\u9047\u7684\u65F6\u4EE3\u4E2D\u627E\u5230\u81EA\u5DF1\u7684\u4F4D\u7F6E\u3002\"\n ],\n \"tags\": [\"AI\", \"\u7F16\u7A0B\", \"\u601D\u8003\"]\n }\n ]\n}\n", "import React, { useState, useEffect } from 'react';\nimport { render, Box, Text, useInput } from 'ink';\nimport { Command } from 'commander';\n\ninterface PostItem {\n slug: string;\n author: string;\n handle: string;\n date: string;\n time: string;\n content: string;\n tags: string[];\n}\n\nconst FeedPost: React.FC<{\n post: PostItem;\n isSelected: boolean;\n}> = ({ post, isSelected }) => (\n <Box flexDirection=\"column\" paddingX={1} marginY={0}>\n <Box>\n <Text bold color={isSelected ? 'cyan' : 'white'}>\n {post.author}\n </Text>\n <Text dimColor> {post.handle}</Text>\n <Text dimColor> \u00B7 {post.date} {post.time}</Text>\n </Box>\n <Box marginTop={0} flexWrap=\"wrap\">\n <Text color={isSelected ? 'gray' : undefined}>{post.content}</Text>\n </Box>\n {post.tags && post.tags.length > 0 && (\n <Box marginTop={0} flexWrap=\"wrap\">\n {post.tags.map((tag) => (\n <Text key={tag} dimColor>\n #{tag}{' '}\n </Text>\n ))}\n </Box>\n )}\n </Box>\n);\n\nconst PostsFeed: React.FC<{\n posts: PostItem[];\n selectedIndex: number;\n onSelect: (index: number) => void;\n onQuit: () => void;\n}> = ({ posts, selectedIndex, onSelect, onQuit }) => {\n useInput((input, key) => {\n if (input === 'q' || input === 'Q') {\n onQuit();\n return;\n }\n if (key.upArrow) {\n onSelect(Math.max(0, selectedIndex - 1));\n } else if (key.downArrow) {\n onSelect(Math.min(posts.length - 1, selectedIndex + 1));\n }\n });\n\n return (\n <Box flexDirection=\"column\" paddingX={2} paddingY={1}>\n <Box marginBottom={1}>\n <Text bold color=\"cyan\">\n \uD83D\uDC26 \u9EA6\u5F53\u7684\u63A8\u6587\n </Text>\n <Text dimColor> \u00B7 \u65B9\u5411\u952E\u6D4F\u89C8\uFF0Cq \u9000\u51FA</Text>\n </Box>\n\n <Box flexDirection=\"column\" borderStyle=\"single\" borderColor=\"gray\" paddingX={0} paddingY={0}>\n {posts.map((post, index) => (\n <Box\n key={post.slug}\n flexDirection=\"column\"\n borderStyle=\"single\"\n borderColor={selectedIndex === index ? 'cyan' : 'gray'}\n paddingX={1}\n paddingY={0}\n marginY={0}\n >\n <FeedPost post={post} isSelected={selectedIndex === index} />\n </Box>\n ))}\n </Box>\n\n <Box marginTop={1}>\n <Text dimColor>\u2191\u2193 \u9009\u62E9 \u00B7 q \u9000\u51FA</Text>\n </Box>\n </Box>\n );\n};\n\nconst PostsApp: React.FC<{ apiUrl: string }> = ({ apiUrl }) => {\n const [posts, setPosts] = useState<PostItem[]>([]);\n const [selectedIndex, setSelectedIndex] = useState(0);\n const [loading, setLoading] = useState(true);\n const [error, setError] = useState<string | null>(null);\n const [spinnerFrame, setSpinnerFrame] = useState(0);\n\n useEffect(() => {\n if (!loading) return;\n const interval = setInterval(() => {\n setSpinnerFrame(f => (f + 1) % 4);\n }, 150);\n return () => clearInterval(interval);\n }, [loading]);\n\n useEffect(() => {\n fetch(apiUrl)\n .then((res) => {\n if (!res.ok) throw new Error(`HTTP ${res.status}`);\n return res.json();\n })\n .then((data) => {\n setPosts(data);\n setLoading(false);\n })\n .catch((err) => {\n setError(err.message);\n setLoading(false);\n });\n }, [apiUrl]);\n\n const handleQuit = (): void => {\n process.exit(0);\n };\n\n if (loading) {\n return (\n <Box flexDirection=\"column\" paddingX={2} paddingY={1}>\n <Text>\n <Text dimColor>{\"\u25D0\u25D3\u25D0\u25D3\"[spinnerFrame]} \u52A0\u8F7D\u4E2D...</Text>\n </Text>\n </Box>\n );\n }\n\n if (error) {\n return (\n <Box flexDirection=\"column\" paddingX={2} paddingY={1}>\n <Text color=\"red\">\u52A0\u8F7D\u5931\u8D25: {error}</Text>\n <Text dimColor>\u8BF7\u68C0\u67E5\u7F51\u7EDC\u6216API\u5730\u5740</Text>\n </Box>\n );\n }\n\n if (posts.length === 0) {\n return (\n <Box flexDirection=\"column\" paddingX={2} paddingY={1}>\n <Text color=\"yellow\">\u6682\u65E0\u63A8\u6587</Text>\n </Box>\n );\n }\n\n return (\n <PostsFeed\n posts={posts}\n selectedIndex={selectedIndex}\n onSelect={setSelectedIndex}\n onQuit={handleQuit}\n />\n );\n};\n\nexport function createPostsCommand(): Command {\n const cmd = new Command('posts')\n .description('\u9EA6\u5F53\u7684\u63A8\u6587\u65F6\u95F4\u7EBF\uFF08\u63A8\u7279\u98CE\u683C\uFF09')\n .requiredOption('--api <url>', 'API\u5730\u5740')\n .action((opts) => {\n render(<PostsApp apiUrl={opts.api} />);\n });\n\n return cmd;\n}\n", "import { Command } from 'commander';\nimport chalk from 'chalk';\n\ninterface Link {\n name: string;\n url: string;\n icon: string;\n description: string | null;\n}\n\nexport function createLinksCommand(): Command {\n const cmd = new Command('links')\n .description('\u67E5\u770B\u793E\u4EA4\u94FE\u63A5')\n .option('--json', '\u8F93\u51FA JSON \u683C\u5F0F')\n .action(async (opts) => {\n const apiUrl = process.env.MAIDANG_API_URL || 'http://localhost:3000';\n\n try {\n const res = await fetch(`${apiUrl}/api/links`);\n if (!res.ok) throw new Error(`HTTP ${res.status}`);\n const links: Link[] = await res.json();\n\n if (opts.json) {\n console.log(JSON.stringify({ tool: 'maidang', command: 'links', data: links }, null, 2));\n return;\n }\n\n console.log(chalk.cyan.bold('\uD83C\uDF10 \u793E\u4EA4\u94FE\u63A5\\n'));\n for (const link of links) {\n console.log(` ${link.icon} ${chalk.white(link.name)} - ${chalk.gray(link.description || '')}`);\n console.log(` ${chalk.blue(link.url)}\\n`);\n }\n } catch (err) {\n console.error(chalk.red(`\u83B7\u53D6\u94FE\u63A5\u5931\u8D25: ${err instanceof Error ? err.message : err}`));\n process.exit(1);\n }\n });\n\n return cmd;\n}\n", "import { Command } from 'commander';\nimport chalk from 'chalk';\n\ninterface Project {\n name: string;\n description: string;\n url: string | null;\n icon: string;\n category: string;\n}\n\nexport function createProjectsCommand(): Command {\n const cmd = new Command('projects')\n .description('\u67E5\u770B\u4E2A\u4EBA\u9879\u76EE')\n .option('--json', '\u8F93\u51FA JSON \u683C\u5F0F')\n .action(async (opts) => {\n const apiUrl = process.env.MAIDANG_API_URL || 'http://localhost:3000';\n\n try {\n const res = await fetch(`${apiUrl}/api/projects`);\n if (!res.ok) throw new Error(`HTTP ${res.status}`);\n const projects: Project[] = await res.json();\n\n if (opts.json) {\n console.log(JSON.stringify({ tool: 'maidang', command: 'projects', data: projects }, null, 2));\n return;\n }\n\n console.log(chalk.cyan.bold('\uD83D\uDE80 \u4E2A\u4EBA\u9879\u76EE\\n'));\n for (const project of projects) {\n console.log(` ${project.icon} ${chalk.white.bold(project.name)} ${chalk.gray(`[${project.category}]`)}`);\n console.log(` ${project.description}`);\n if (project.url) {\n console.log(` ${chalk.blue(project.url)}`);\n }\n console.log('');\n }\n } catch (err) {\n console.error(chalk.red(`\u83B7\u53D6\u9879\u76EE\u5931\u8D25: ${err instanceof Error ? err.message : err}`));\n process.exit(1);\n }\n });\n\n return cmd;\n}\n", "import { Command } from 'commander';\nimport chalk from 'chalk';\n\ninterface Tool {\n name: string;\n description: string;\n icon: string;\n url: string | null;\n category: string;\n}\n\nexport function createToolsCommand(): Command {\n const cmd = new Command('tools')\n .description('\u67E5\u770B\u5E38\u7528\u5DE5\u5177')\n .option('--json', '\u8F93\u51FA JSON \u683C\u5F0F')\n .action(async (opts) => {\n const apiUrl = process.env.MAIDANG_API_URL || 'http://localhost:3000';\n\n try {\n const res = await fetch(`${apiUrl}/api/tools`);\n if (!res.ok) throw new Error(`HTTP ${res.status}`);\n const tools: Tool[] = await res.json();\n\n if (opts.json) {\n console.log(JSON.stringify({ tool: 'maidang', command: 'tools', data: tools }, null, 2));\n return;\n }\n\n const byCategory = tools.reduce((acc, tool) => {\n if (!acc[tool.category]) acc[tool.category] = [];\n acc[tool.category].push(tool);\n return acc;\n }, {} as Record<string, Tool[]>);\n\n const categoryNames: Record<string, string> = {\n software: '\u5E38\u7528\u8F6F\u4EF6',\n device: '\u8BBE\u5907',\n desktop: '\u684C\u9762\u88C5\u5907',\n };\n\n console.log(chalk.cyan.bold('\uD83D\uDD27 \u5E38\u7528\u5DE5\u5177\\n'));\n\n for (const [cat, items] of Object.entries(byCategory)) {\n console.log(chalk.white.bold(` ${categoryNames[cat] || cat}`));\n for (const tool of items) {\n const urlStr = tool.url ? ` ${chalk.blue(tool.url)}` : '';\n console.log(` ${tool.icon} ${tool.name} - ${chalk.gray(tool.description)}${urlStr}`);\n }\n console.log('');\n }\n } catch (err) {\n console.error(chalk.red(`\u83B7\u53D6\u5DE5\u5177\u5931\u8D25: ${err instanceof Error ? err.message : err}`));\n process.exit(1);\n }\n });\n\n return cmd;\n}\n", "/**\n * \u8BA1\u7B97\u9EA6\u5F53\u7684\u5E74\u9F84\u7248\u672C\u53F7\n * \u51FA\u751F\u65E5\u671F\uFF1A1997\u5E743\u670810\u65E5\n * \u8FD4\u56DE\u683C\u5F0F\uFF1A\u5E74\u9F84.\u5C0F\u7248\u672C\u53F7.\u8865\u4E01\u53F7\n */\nexport function getAgeVersion(): string {\n const birthDate = new Date(1997, 2, 10); // \u6708\u4EFD\u4ECE0\u5F00\u59CB\uFF0C\u6240\u4EE52\u662F3\u6708\n const today = new Date();\n\n let age = today.getFullYear() - birthDate.getFullYear();\n const monthDiff = today.getMonth() - birthDate.getMonth();\n\n // \u5982\u679C\u8FD8\u6CA1\u8FC7\u751F\u65E5\uFF0C\u5E74\u9F84\u51CF1\n if (monthDiff < 0 || (monthDiff === 0 && today.getDate() < birthDate.getDate())) {\n age--;\n }\n\n // \u8FD9\u91CC\u7684\u5C0F\u7248\u672C\u548C\u8865\u4E01\u53F7\u53EF\u4EE5\u540E\u7EED\u4ECE package.json \u8BFB\u53D6\u6216\u56FA\u5B9A\n // \u73B0\u5728\u5148\u8FD4\u56DE\u7B80\u5355\u683C\u5F0F\n return `${age}.0.0`;\n}\n\n/**\n * \u83B7\u53D6\u7248\u672C\u53F7\u548C\u751F\u65E5\u4FE1\u606F\n */\nexport function getVersionInfo(): { version: string; birthDate: Date; currentAge: number; nextBirthday: Date } {\n const birthDate = new Date(1997, 2, 10); // 1997\u5E743\u670810\u65E5\n const today = new Date();\n\n let currentAge = today.getFullYear() - birthDate.getFullYear();\n const monthDiff = today.getMonth() - birthDate.getMonth();\n\n // \u8BA1\u7B97\u4E0B\u4E00\u4E2A\u751F\u65E5\n const nextBirthday = new Date(today.getFullYear(), birthDate.getMonth(), birthDate.getDate());\n\n if (monthDiff < 0 || (monthDiff === 0 && today.getDate() < birthDate.getDate())) {\n currentAge--;\n } else {\n nextBirthday.setFullYear(today.getFullYear() + 1);\n }\n\n const version = `${currentAge}.0.0`;\n\n return {\n version,\n birthDate,\n currentAge,\n nextBirthday\n };\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["Command", "chalk", "chalk", "cmd", "Command", "chalk", "Command", "chalk", "Command", "chalk", "Command", "Command", "React", "useState", "render", "Box", "Text", "useInput", "Command", "Command", "chalk", "Command", "chalk", "Command", "chalk", "Command"]
7
7
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "maidang",
3
- "version": "29.3.1",
3
+ "version": "29.3.2",
4
4
  "type": "module",
5
5
  "description": "一个展示个人信息与职业经历的命令行工具",
6
6
  "main": "dist/index.js",
@@ -10,15 +10,6 @@
10
10
  "bin": {
11
11
  "maidang": "dist/index.js"
12
12
  },
13
- "scripts": {
14
- "build": "esbuild src/index.ts --bundle --platform=node --format=esm --outfile=dist/index.js --sourcemap --loader:.tsx=tsx --external:commander --external:chalk --external:boxen --external:figlet --external:ora --external:terminal-image --external:ink --external:react && node scripts/copy-assets.mjs",
15
- "dev": "tsx src/index.ts",
16
- "start": "node dist/index.js",
17
- "test": "jest",
18
- "test:watch": "jest --watch",
19
- "test:coverage": "jest --coverage",
20
- "prepublishOnly": "pnpm test && pnpm build"
21
- },
22
13
  "keywords": [
23
14
  "cli",
24
15
  "maidang",
@@ -28,13 +19,13 @@
28
19
  ],
29
20
  "author": "朱建业",
30
21
  "license": "ISC",
31
- "homepage": "https://github.com/maidangzhu/maidang-cli",
22
+ "homepage": "https://github.com/maidangzhu/maidang",
32
23
  "repository": {
33
24
  "type": "git",
34
- "url": "git+https://github.com/maidangzhu/maidang-cli.git"
25
+ "url": "git+https://github.com/maidangzhu/maidang.git"
35
26
  },
36
27
  "bugs": {
37
- "url": "https://github.com/maidangzhu/maidang-cli/issues"
28
+ "url": "https://github.com/maidangzhu/maidang/issues"
38
29
  },
39
30
  "engines": {
40
31
  "node": ">=18"
@@ -61,5 +52,13 @@
61
52
  "ts-jest": "^29.4.6",
62
53
  "tsx": "^4.21.0",
63
54
  "typescript": "^5.9.3"
55
+ },
56
+ "scripts": {
57
+ "build": "esbuild src/index.ts --bundle --platform=node --format=esm --outfile=dist/index.js --sourcemap --loader:.tsx=tsx --external:commander --external:chalk --external:boxen --external:figlet --external:ora --external:terminal-image --external:ink --external:react && node scripts/copy-assets.mjs",
58
+ "dev": "tsx src/index.ts",
59
+ "start": "node dist/index.js",
60
+ "test": "jest",
61
+ "test:watch": "jest --watch",
62
+ "test:coverage": "jest --coverage"
64
63
  }
65
- }
64
+ }