aeo.js 0.0.7 → 0.0.9

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.
Files changed (68) hide show
  1. package/README.md +119 -164
  2. package/dist/angular.d.mts +1 -1
  3. package/dist/angular.d.ts +1 -1
  4. package/dist/angular.js +69 -13
  5. package/dist/angular.js.map +1 -1
  6. package/dist/angular.mjs +69 -13
  7. package/dist/angular.mjs.map +1 -1
  8. package/dist/astro.d.mts +1 -1
  9. package/dist/astro.d.ts +1 -1
  10. package/dist/astro.js +78 -18
  11. package/dist/astro.js.map +1 -1
  12. package/dist/astro.mjs +78 -18
  13. package/dist/astro.mjs.map +1 -1
  14. package/dist/cli.js +84 -27
  15. package/dist/cli.js.map +1 -1
  16. package/dist/cli.mjs +84 -27
  17. package/dist/cli.mjs.map +1 -1
  18. package/dist/index.d.mts +2 -2
  19. package/dist/index.d.ts +2 -2
  20. package/dist/index.js +89 -29
  21. package/dist/index.js.map +1 -1
  22. package/dist/index.mjs +89 -29
  23. package/dist/index.mjs.map +1 -1
  24. package/dist/next.d.mts +1 -1
  25. package/dist/next.d.ts +1 -1
  26. package/dist/next.js +71 -15
  27. package/dist/next.js.map +1 -1
  28. package/dist/next.mjs +71 -15
  29. package/dist/next.mjs.map +1 -1
  30. package/dist/nuxt.d.mts +1 -1
  31. package/dist/nuxt.d.ts +1 -1
  32. package/dist/nuxt.js +69 -13
  33. package/dist/nuxt.js.map +1 -1
  34. package/dist/nuxt.mjs +69 -13
  35. package/dist/nuxt.mjs.map +1 -1
  36. package/dist/react.d.mts +1 -1
  37. package/dist/react.d.ts +1 -1
  38. package/dist/react.js +52 -7
  39. package/dist/react.js.map +1 -1
  40. package/dist/react.mjs +52 -7
  41. package/dist/react.mjs.map +1 -1
  42. package/dist/{types-Cn_Qbkmg.d.mts → types-BlLNcw-X.d.mts} +2 -0
  43. package/dist/{types-Cn_Qbkmg.d.ts → types-BlLNcw-X.d.ts} +2 -0
  44. package/dist/vite.d.mts +1 -1
  45. package/dist/vite.d.ts +1 -1
  46. package/dist/vite.js +94 -20
  47. package/dist/vite.js.map +1 -1
  48. package/dist/vite.mjs +94 -20
  49. package/dist/vite.mjs.map +1 -1
  50. package/dist/vue.d.mts +1 -1
  51. package/dist/vue.d.ts +1 -1
  52. package/dist/vue.js +52 -7
  53. package/dist/vue.js.map +1 -1
  54. package/dist/vue.mjs +52 -7
  55. package/dist/vue.mjs.map +1 -1
  56. package/dist/webpack.d.mts +1 -1
  57. package/dist/webpack.d.ts +1 -1
  58. package/dist/webpack.js +69 -13
  59. package/dist/webpack.js.map +1 -1
  60. package/dist/webpack.mjs +69 -13
  61. package/dist/webpack.mjs.map +1 -1
  62. package/dist/widget.d.mts +1 -1
  63. package/dist/widget.d.ts +1 -1
  64. package/dist/widget.js +52 -7
  65. package/dist/widget.js.map +1 -1
  66. package/dist/widget.mjs +52 -7
  67. package/dist/widget.mjs.map +1 -1
  68. package/package.json +1 -1
package/dist/astro.js CHANGED
@@ -81,10 +81,19 @@ function generateRobotsTxt(config) {
81
81
  }
82
82
  lines.push("# Default for all other bots");
83
83
  lines.push("User-agent: *");
84
- lines.push("Allow: /");
84
+ for (const path of config.robots.allow.length > 0 ? config.robots.allow : ["/"]) {
85
+ lines.push(`Allow: ${path}`);
86
+ }
87
+ for (const path of config.robots.disallow) {
88
+ lines.push(`Disallow: ${path}`);
89
+ }
90
+ if (config.robots.crawlDelay > 0) {
91
+ lines.push(`Crawl-delay: ${config.robots.crawlDelay}`);
92
+ }
85
93
  lines.push("");
86
- if (config.url) {
87
- lines.push(`Sitemap: ${config.url}/sitemap.xml`);
94
+ const sitemapUrl = config.robots.sitemap || (config.url ? `${config.url}/sitemap.xml` : "");
95
+ if (sitemapUrl) {
96
+ lines.push(`Sitemap: ${sitemapUrl}`);
88
97
  }
89
98
  lines.push("");
90
99
  lines.push("# AEO (Answer Engine Optimization) files");
@@ -166,7 +175,7 @@ function detectFramework(projectRoot = process.cwd()) {
166
175
  };
167
176
  }
168
177
  function resolveConfig(config = {}) {
169
- var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _A, _B, _C, _D, _E, _F, _G, _H, _I, _J, _K, _L, _M;
178
+ var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _A, _B, _C, _D, _E, _F, _G, _H, _I, _J, _K, _L, _M, _N;
170
179
  const frameworkInfo = detectFramework();
171
180
  return {
172
181
  title: config.title || "My Site",
@@ -210,15 +219,16 @@ function resolveConfig(config = {}) {
210
219
  widget: {
211
220
  enabled: ((_A = config.widget) == null ? void 0 : _A.enabled) !== false,
212
221
  position: ((_B = config.widget) == null ? void 0 : _B.position) || "bottom-right",
222
+ size: ((_C = config.widget) == null ? void 0 : _C.size) || "default",
213
223
  theme: {
214
- background: ((_D = (_C = config.widget) == null ? void 0 : _C.theme) == null ? void 0 : _D.background) || "rgba(18, 18, 24, 0.9)",
215
- text: ((_F = (_E = config.widget) == null ? void 0 : _E.theme) == null ? void 0 : _F.text) || "#C0C0C5",
216
- accent: ((_H = (_G = config.widget) == null ? void 0 : _G.theme) == null ? void 0 : _H.accent) || "#E8E8EA",
217
- badge: ((_J = (_I = config.widget) == null ? void 0 : _I.theme) == null ? void 0 : _J.badge) || "#4ADE80"
224
+ background: ((_E = (_D = config.widget) == null ? void 0 : _D.theme) == null ? void 0 : _E.background) || "rgba(18, 18, 24, 0.9)",
225
+ text: ((_G = (_F = config.widget) == null ? void 0 : _F.theme) == null ? void 0 : _G.text) || "#C0C0C5",
226
+ accent: ((_I = (_H = config.widget) == null ? void 0 : _H.theme) == null ? void 0 : _I.accent) || "#E8E8EA",
227
+ badge: ((_K = (_J = config.widget) == null ? void 0 : _J.theme) == null ? void 0 : _K.badge) || "#4ADE80"
218
228
  },
219
- humanLabel: ((_K = config.widget) == null ? void 0 : _K.humanLabel) || "Human",
220
- aiLabel: ((_L = config.widget) == null ? void 0 : _L.aiLabel) || "AI",
221
- showBadge: ((_M = config.widget) == null ? void 0 : _M.showBadge) !== false
229
+ humanLabel: ((_L = config.widget) == null ? void 0 : _L.humanLabel) || "Human",
230
+ aiLabel: ((_M = config.widget) == null ? void 0 : _M.aiLabel) || "AI",
231
+ showBadge: ((_N = config.widget) == null ? void 0 : _N.showBadge) !== false
222
232
  }
223
233
  };
224
234
  }
@@ -275,7 +285,8 @@ function collectMarkdownFiles(dir, base = dir) {
275
285
  for (const entry of entries) {
276
286
  const fullPath = path.join(dir, entry);
277
287
  const stat = fs.statSync(fullPath);
278
- if (stat.isDirectory() && !entry.startsWith(".") && entry !== "node_modules") {
288
+ const SKIP_DIRS = /* @__PURE__ */ new Set(["node_modules", "public", "dist", ".next", ".nuxt", ".output", ".open-next", "coverage", "__tests__", "__mocks__"]);
289
+ if (stat.isDirectory() && !entry.startsWith(".") && !SKIP_DIRS.has(entry)) {
279
290
  files.push(...collectMarkdownFiles(fullPath, base));
280
291
  } else if (stat.isFile() && (path.extname(entry) === ".md" || path.extname(entry) === ".mdx")) {
281
292
  const content = fs.readFileSync(fullPath, "utf-8");
@@ -618,7 +629,8 @@ function collectUrls(dir, config, base = dir) {
618
629
  for (const entry of entries) {
619
630
  const fullPath = path.join(dir, entry);
620
631
  const stat = fs.statSync(fullPath);
621
- if (stat.isDirectory() && !entry.startsWith(".") && entry !== "node_modules") {
632
+ const SKIP_DIRS = /* @__PURE__ */ new Set(["node_modules", "public", "dist", ".next", ".nuxt", ".output", ".open-next", "coverage", "__tests__", "__mocks__"]);
633
+ if (stat.isDirectory() && !entry.startsWith(".") && !SKIP_DIRS.has(entry)) {
622
634
  urls.push(...collectUrls(fullPath, config, base));
623
635
  } else if (stat.isFile() && (path.extname(entry) === ".md" || path.extname(entry) === ".mdx" || path.extname(entry) === ".html")) {
624
636
  const relativePath = path.relative(base, fullPath);
@@ -846,6 +858,22 @@ function generatePageSchemas(page, config) {
846
858
  }))
847
859
  });
848
860
  }
861
+ if (faqItems.length === 0) {
862
+ const howToSteps = detectHowToSteps(page.content || "");
863
+ if (howToSteps.length > 0) {
864
+ schemas.push({
865
+ "@context": "https://schema.org",
866
+ "@type": "HowTo",
867
+ name: page.title || config.title,
868
+ step: howToSteps.map((s, i) => ({
869
+ "@type": "HowToStep",
870
+ position: i + 1,
871
+ name: s.name,
872
+ text: s.text
873
+ }))
874
+ });
875
+ }
876
+ }
849
877
  const pageType = config.schema.defaultType;
850
878
  const pageSchema = {
851
879
  "@context": "https://schema.org",
@@ -922,12 +950,43 @@ function detectFaqPatterns(content) {
922
950
  }
923
951
  return items;
924
952
  }
953
+ function serializeJsonForHtml(value) {
954
+ return JSON.stringify(value).replace(/</g, "\\u003C").replace(/>/g, "\\u003E").replace(/&/g, "\\u0026").replace(/\u2028/g, "\\u2028").replace(/\u2029/g, "\\u2029");
955
+ }
956
+ function detectHowToSteps(content) {
957
+ const steps = [];
958
+ const lines = content.split("\n");
959
+ for (let i = 0; i < lines.length; i++) {
960
+ const line = lines[i].trim();
961
+ const stepMatch = line.match(/^#{1,6}\s+(?:Step\s+\d+[\s:.-]*|(\d+)[.)]\s*)(.+)$/i);
962
+ if (stepMatch) {
963
+ const name = (stepMatch[2] || stepMatch[1] || "").trim();
964
+ const bodyLines = [];
965
+ for (let j = i + 1; j < lines.length; j++) {
966
+ const nextLine = lines[j].trim();
967
+ if (!nextLine) {
968
+ if (bodyLines.length > 0) break;
969
+ continue;
970
+ }
971
+ if (/^#{1,6}\s/.test(nextLine)) break;
972
+ bodyLines.push(nextLine);
973
+ }
974
+ if (name) {
975
+ steps.push({
976
+ name,
977
+ text: bodyLines.join(" ").slice(0, 500)
978
+ });
979
+ }
980
+ }
981
+ }
982
+ return steps.length >= 2 ? steps : [];
983
+ }
925
984
  function generateJsonLdScript(schemas) {
926
985
  if (schemas.length === 0) return "";
927
986
  if (schemas.length === 1) {
928
- return `<script type="application/ld+json">${JSON.stringify(schemas[0])}</script>`;
987
+ return `<script type="application/ld+json">${serializeJsonForHtml(schemas[0])}</script>`;
929
988
  }
930
- return schemas.map((s) => `<script type="application/ld+json">${JSON.stringify(s)}</script>`).join("\n");
989
+ return schemas.map((s) => `<script type="application/ld+json">${serializeJsonForHtml(s)}</script>`).join("\n");
931
990
  }
932
991
  async function generateAEOFiles(configOrRoot, maybeConfig) {
933
992
  var _a;
@@ -1373,7 +1432,7 @@ if (!document.querySelector('meta[name="astro-view-transitions-enabled"]')) {
1373
1432
  devLogger.error(`Failed to generate AEO files: ${error}`);
1374
1433
  }
1375
1434
  const mdHandler = async (req, res, next) => {
1376
- var _a, _b;
1435
+ var _a;
1377
1436
  if (!((_a = req.url) == null ? void 0 : _a.endsWith(".md"))) return next();
1378
1437
  if (req.headers["x-aeo-internal"]) return next();
1379
1438
  const filename = req.url.startsWith("/") ? req.url.slice(1) : req.url;
@@ -1388,8 +1447,9 @@ if (!document.querySelector('meta[name="astro-view-transitions-enabled"]')) {
1388
1447
  let pagePath = req.url.replace(/\.md$/, "") || "/";
1389
1448
  if (pagePath === "/index") pagePath = "/";
1390
1449
  try {
1391
- const host = req.headers.host || "localhost:4321";
1392
- const protocol = ((_b = req.connection) == null ? void 0 : _b.encrypted) ? "https" : "http";
1450
+ const rawHost = req.headers.host || "localhost:4321";
1451
+ const host = /^(localhost|127\.0\.0\.1)(:\d+)?$/.test(rawHost) ? rawHost : "localhost:4321";
1452
+ const protocol = "http";
1393
1453
  const response = await fetch(`${protocol}://${host}${pagePath}`, {
1394
1454
  headers: { "x-aeo-internal": "1" }
1395
1455
  });