aeo.js 0.0.6 → 0.0.8
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/angular.d.mts +1 -1
- package/dist/angular.d.ts +1 -1
- package/dist/angular.js +65 -11
- package/dist/angular.js.map +1 -1
- package/dist/angular.mjs +65 -11
- package/dist/angular.mjs.map +1 -1
- package/dist/astro.d.mts +1 -1
- package/dist/astro.d.ts +1 -1
- package/dist/astro.js +74 -16
- package/dist/astro.js.map +1 -1
- package/dist/astro.mjs +74 -16
- package/dist/astro.mjs.map +1 -1
- package/dist/cli.js +80 -25
- package/dist/cli.js.map +1 -1
- package/dist/cli.mjs +80 -25
- package/dist/cli.mjs.map +1 -1
- package/dist/index.d.mts +2 -2
- package/dist/index.d.ts +2 -2
- package/dist/index.js +85 -27
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +85 -27
- package/dist/index.mjs.map +1 -1
- package/dist/next.d.mts +1 -1
- package/dist/next.d.ts +1 -1
- package/dist/next.js +65 -11
- package/dist/next.js.map +1 -1
- package/dist/next.mjs +65 -11
- package/dist/next.mjs.map +1 -1
- package/dist/nuxt.d.mts +1 -1
- package/dist/nuxt.d.ts +1 -1
- package/dist/nuxt.js +65 -11
- package/dist/nuxt.js.map +1 -1
- package/dist/nuxt.mjs +65 -11
- package/dist/nuxt.mjs.map +1 -1
- package/dist/react.d.mts +1 -1
- package/dist/react.d.ts +1 -1
- package/dist/react.js +61 -9
- package/dist/react.js.map +1 -1
- package/dist/react.mjs +61 -9
- package/dist/react.mjs.map +1 -1
- package/dist/{types-Cn_Qbkmg.d.mts → types-BlLNcw-X.d.mts} +2 -0
- package/dist/{types-Cn_Qbkmg.d.ts → types-BlLNcw-X.d.ts} +2 -0
- package/dist/vite.d.mts +1 -1
- package/dist/vite.d.ts +1 -1
- package/dist/vite.js +90 -18
- package/dist/vite.js.map +1 -1
- package/dist/vite.mjs +90 -18
- package/dist/vite.mjs.map +1 -1
- package/dist/vue.d.mts +1 -1
- package/dist/vue.d.ts +1 -1
- package/dist/vue.js +61 -9
- package/dist/vue.js.map +1 -1
- package/dist/vue.mjs +61 -9
- package/dist/vue.mjs.map +1 -1
- package/dist/webpack.d.mts +1 -1
- package/dist/webpack.d.ts +1 -1
- package/dist/webpack.js +65 -11
- package/dist/webpack.js.map +1 -1
- package/dist/webpack.mjs +65 -11
- package/dist/webpack.mjs.map +1 -1
- package/dist/widget.d.mts +1 -1
- package/dist/widget.d.ts +1 -1
- package/dist/widget.js +61 -9
- package/dist/widget.js.map +1 -1
- package/dist/widget.mjs +61 -9
- package/dist/widget.mjs.map +1 -1
- package/package.json +1 -1
package/dist/nuxt.mjs
CHANGED
|
@@ -80,10 +80,19 @@ function generateRobotsTxt(config) {
|
|
|
80
80
|
}
|
|
81
81
|
lines.push("# Default for all other bots");
|
|
82
82
|
lines.push("User-agent: *");
|
|
83
|
-
|
|
83
|
+
for (const path of config.robots.allow.length > 0 ? config.robots.allow : ["/"]) {
|
|
84
|
+
lines.push(`Allow: ${path}`);
|
|
85
|
+
}
|
|
86
|
+
for (const path of config.robots.disallow) {
|
|
87
|
+
lines.push(`Disallow: ${path}`);
|
|
88
|
+
}
|
|
89
|
+
if (config.robots.crawlDelay > 0) {
|
|
90
|
+
lines.push(`Crawl-delay: ${config.robots.crawlDelay}`);
|
|
91
|
+
}
|
|
84
92
|
lines.push("");
|
|
85
|
-
|
|
86
|
-
|
|
93
|
+
const sitemapUrl = config.robots.sitemap || (config.url ? `${config.url}/sitemap.xml` : "");
|
|
94
|
+
if (sitemapUrl) {
|
|
95
|
+
lines.push(`Sitemap: ${sitemapUrl}`);
|
|
87
96
|
}
|
|
88
97
|
lines.push("");
|
|
89
98
|
lines.push("# AEO (Answer Engine Optimization) files");
|
|
@@ -165,7 +174,7 @@ function detectFramework(projectRoot = process.cwd()) {
|
|
|
165
174
|
};
|
|
166
175
|
}
|
|
167
176
|
function resolveConfig(config = {}) {
|
|
168
|
-
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;
|
|
177
|
+
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;
|
|
169
178
|
const frameworkInfo = detectFramework();
|
|
170
179
|
return {
|
|
171
180
|
title: config.title || "My Site",
|
|
@@ -209,15 +218,16 @@ function resolveConfig(config = {}) {
|
|
|
209
218
|
widget: {
|
|
210
219
|
enabled: ((_A = config.widget) == null ? void 0 : _A.enabled) !== false,
|
|
211
220
|
position: ((_B = config.widget) == null ? void 0 : _B.position) || "bottom-right",
|
|
221
|
+
size: ((_C = config.widget) == null ? void 0 : _C.size) || "default",
|
|
212
222
|
theme: {
|
|
213
|
-
background: ((
|
|
214
|
-
text: ((
|
|
215
|
-
accent: ((
|
|
216
|
-
badge: ((
|
|
223
|
+
background: ((_E = (_D = config.widget) == null ? void 0 : _D.theme) == null ? void 0 : _E.background) || "rgba(18, 18, 24, 0.9)",
|
|
224
|
+
text: ((_G = (_F = config.widget) == null ? void 0 : _F.theme) == null ? void 0 : _G.text) || "#C0C0C5",
|
|
225
|
+
accent: ((_I = (_H = config.widget) == null ? void 0 : _H.theme) == null ? void 0 : _I.accent) || "#E8E8EA",
|
|
226
|
+
badge: ((_K = (_J = config.widget) == null ? void 0 : _J.theme) == null ? void 0 : _K.badge) || "#4ADE80"
|
|
217
227
|
},
|
|
218
|
-
humanLabel: ((
|
|
219
|
-
aiLabel: ((
|
|
220
|
-
showBadge: ((
|
|
228
|
+
humanLabel: ((_L = config.widget) == null ? void 0 : _L.humanLabel) || "Human",
|
|
229
|
+
aiLabel: ((_M = config.widget) == null ? void 0 : _M.aiLabel) || "AI",
|
|
230
|
+
showBadge: ((_N = config.widget) == null ? void 0 : _N.showBadge) !== false
|
|
221
231
|
}
|
|
222
232
|
};
|
|
223
233
|
}
|
|
@@ -845,6 +855,22 @@ function generatePageSchemas(page, config) {
|
|
|
845
855
|
}))
|
|
846
856
|
});
|
|
847
857
|
}
|
|
858
|
+
if (faqItems.length === 0) {
|
|
859
|
+
const howToSteps = detectHowToSteps(page.content || "");
|
|
860
|
+
if (howToSteps.length > 0) {
|
|
861
|
+
schemas.push({
|
|
862
|
+
"@context": "https://schema.org",
|
|
863
|
+
"@type": "HowTo",
|
|
864
|
+
name: page.title || config.title,
|
|
865
|
+
step: howToSteps.map((s, i) => ({
|
|
866
|
+
"@type": "HowToStep",
|
|
867
|
+
position: i + 1,
|
|
868
|
+
name: s.name,
|
|
869
|
+
text: s.text
|
|
870
|
+
}))
|
|
871
|
+
});
|
|
872
|
+
}
|
|
873
|
+
}
|
|
848
874
|
const pageType = config.schema.defaultType;
|
|
849
875
|
const pageSchema = {
|
|
850
876
|
"@context": "https://schema.org",
|
|
@@ -921,6 +947,34 @@ function detectFaqPatterns(content) {
|
|
|
921
947
|
}
|
|
922
948
|
return items;
|
|
923
949
|
}
|
|
950
|
+
function detectHowToSteps(content) {
|
|
951
|
+
const steps = [];
|
|
952
|
+
const lines = content.split("\n");
|
|
953
|
+
for (let i = 0; i < lines.length; i++) {
|
|
954
|
+
const line = lines[i].trim();
|
|
955
|
+
const stepMatch = line.match(/^#{1,6}\s+(?:Step\s+\d+[\s:.-]*|(\d+)[.)]\s*)(.+)$/i);
|
|
956
|
+
if (stepMatch) {
|
|
957
|
+
const name = (stepMatch[2] || stepMatch[1] || "").trim();
|
|
958
|
+
const bodyLines = [];
|
|
959
|
+
for (let j = i + 1; j < lines.length; j++) {
|
|
960
|
+
const nextLine = lines[j].trim();
|
|
961
|
+
if (!nextLine) {
|
|
962
|
+
if (bodyLines.length > 0) break;
|
|
963
|
+
continue;
|
|
964
|
+
}
|
|
965
|
+
if (/^#{1,6}\s/.test(nextLine)) break;
|
|
966
|
+
bodyLines.push(nextLine);
|
|
967
|
+
}
|
|
968
|
+
if (name) {
|
|
969
|
+
steps.push({
|
|
970
|
+
name,
|
|
971
|
+
text: bodyLines.join(" ").slice(0, 500)
|
|
972
|
+
});
|
|
973
|
+
}
|
|
974
|
+
}
|
|
975
|
+
}
|
|
976
|
+
return steps.length >= 2 ? steps : [];
|
|
977
|
+
}
|
|
924
978
|
async function generateAEOFiles(configOrRoot, maybeConfig) {
|
|
925
979
|
var _a;
|
|
926
980
|
let config;
|