markopress 0.0.5 → 0.0.6

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.
@@ -1 +1 @@
1
- import e from"minisearch";let t=null,r=null;export async function initSearch(i=""){return t||(r||(r=fetch(i?i+"/search-index.json":"/search-index.json").then(e=>{if(!e.ok)throw Error("Failed to load search index: "+e.status);return e.json()}).then(r=>(console.log("[search] Loaded index with",r.documentCount,"documents"),t=e.loadJSON(JSON.stringify(r),{fields:["title","titles","text"],storeFields:["title","titles","url"]}),t)).catch(e=>{throw console.error("[search] Failed to load index:",e),r=null,e}),r))}export async function search(e,t,r=10){if(!e.trim())return[];try{const i=(await initSearch()).search(e,{fuzzy:t?.minisearch?.fuzzy??.2,prefix:t?.minisearch?.prefix??!0,boost:{title:t?.minisearch?.boost?.title??4,titles:t?.minisearch?.boost?.titles??2,text:t?.minisearch?.boost?.text??1}});return console.log("[search] Query:",e,"Results:",i.length),i.slice(0,r).map(e=>({id:e.id,title:e.title,titles:e.titles,text:e.text??"",url:e.url,score:e.score}))}catch(e){return console.error("[search] Search failed:",e),[]}}export function clearSearchIndex(){t=null,r=null}
1
+ import t from"minisearch";let e=null,r=null;export async function initSearch(i){if(e)return e;if(r)return r;const n=function(t){const e=t.trim();return e&&"/"!==e?(e.startsWith("/")?e:"/"+e).replace(/\/+$/,""):""}(i??function(){const t=globalThis.__MARKOPRESS_BASE_PATH__;if("string"==typeof t)return t;const e=globalThis.document?.documentElement?.getAttribute?.("data-markopress-base-path");if("string"==typeof e)return e;const r=import.meta.env?.BASE_URL;return"string"==typeof r?r:""}());return r=fetch(n+"/search-index.json").then(t=>{if(!t.ok)throw Error("Failed to load search index: "+t.status);return t.json()}).then(r=>(console.log("[search] Loaded index with",r.documentCount,"documents"),e=t.loadJSON(JSON.stringify(r),{fields:["title","titles","text"],storeFields:["title","titles","url"]}),e)).catch(t=>{throw console.error("[search] Failed to load index:",t),r=null,t}),r}export async function search(t,e,r=10){if(!t.trim())return[];try{const i=(await initSearch()).search(t,{fuzzy:e?.minisearch?.fuzzy??.2,prefix:e?.minisearch?.prefix??!0,boost:{title:e?.minisearch?.boost?.title??4,titles:e?.minisearch?.boost?.titles??2,text:e?.minisearch?.boost?.text??1}});return console.log("[search] Query:",t,"Results:",i.length),i.slice(0,r).map(t=>({id:t.id,title:t.title,titles:t.titles,text:t.text??"",url:t.url,score:t.score}))}catch(t){return console.error("[search] Search failed:",t),[]}}export function clearSearchIndex(){e=null,r=null}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "markopress",
3
- "version": "0.0.5",
3
+ "version": "0.0.6",
4
4
  "description": "A fast, modern static site generator built on Marko.js v6 - drop-in alternative to VitePress and Docusaurus with full content compatibility",
5
5
  "keywords": [
6
6
  "static-site-generator",
@@ -1,5 +1,5 @@
1
1
  <!DOCTYPE html>
2
- <html lang=$global.lang||"en">
2
+ <html lang=$global.lang||"en" data-markopress-base-path="{{BASE_PATH}}">
3
3
  <head>
4
4
  <meta charset="UTF-8">
5
5
  <meta name="viewport" content="width=device-width, initial-scale=1.0">