lynkow 3.8.53 → 3.8.61

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.d.mts CHANGED
@@ -627,43 +627,44 @@ declare class SeoService extends BaseService {
627
627
  */
628
628
  llmsFullTxt(options?: BaseRequestOptions): Promise<string>;
629
629
  /**
630
- * Retrieves a single blog article as Markdown
630
+ * Retrieves a single content or page as Markdown by its path.
631
631
  *
632
- * @param slug - The article slug
633
- * @returns Article content as Markdown
632
+ * The path is the same as the content's public URL path (available in
633
+ * `Content.path` or `Page.path`). The SDK appends `.md` automatically.
634
+ *
635
+ * @param contentPath - The content's public path.
636
+ * - For blog articles: use `Content.path` directly (includes locale prefix).
637
+ * - For pages in mono-language mode: use `Page.path` directly.
638
+ * - For pages in multi-language mode: prepend the locale manually,
639
+ * e.g., `/${page.locale}${page.path}`.
640
+ * @returns Markdown content
634
641
  *
635
642
  * @example
636
643
  * ```typescript
637
- * // In a Next.js route handler (app/llm/blog/[slug]/route.ts)
638
- * export async function GET(_req: Request, { params }: { params: Promise<{ slug: string }> }) {
639
- * const { slug } = await params
640
- * const md = await lynkow.seo.getContentMarkdown(slug)
641
- * return new Response(md, {
642
- * headers: { 'Content-Type': 'text/plain; charset=utf-8' }
643
- * })
644
- * }
645
- * ```
646
- */
647
- getContentMarkdown(slug: string, options?: BaseRequestOptions): Promise<string>;
648
- /**
649
- * Retrieves a single page as Markdown
644
+ * // Get a blog article as Markdown (path includes locale automatically)
645
+ * const article = await lynkow.contents.getBySlug('my-article')
646
+ * const md = await lynkow.seo.getMarkdown(article.path)
650
647
  *
651
- * @param slug - The page slug
652
- * @returns Page content as Markdown
648
+ * // Get a page as Markdown (mono-language)
649
+ * const page = await lynkow.pages.getBySlug('about')
650
+ * const md = await lynkow.seo.getMarkdown(page.path!)
653
651
  *
654
- * @example
655
- * ```typescript
656
- * // In a Next.js route handler (app/llm/pages/[slug]/route.ts)
657
- * export async function GET(_req: Request, { params }: { params: Promise<{ slug: string }> }) {
658
- * const { slug } = await params
659
- * const md = await lynkow.seo.getPageMarkdown(slug)
652
+ * // Get a page as Markdown (multi-language — prepend locale)
653
+ * const page = await lynkow.pages.getBySlug('about')
654
+ * const md = await lynkow.seo.getMarkdown(`/${page.locale}${page.path}`)
655
+ *
656
+ * // In a Next.js catch-all route handler
657
+ * export async function GET(req: Request) {
658
+ * const url = new URL(req.url)
659
+ * const path = url.pathname.replace(/\.md$/, '')
660
+ * const md = await lynkow.seo.getMarkdown(path)
660
661
  * return new Response(md, {
661
- * headers: { 'Content-Type': 'text/plain; charset=utf-8' }
662
+ * headers: { 'Content-Type': 'text/markdown; charset=utf-8' }
662
663
  * })
663
664
  * }
664
665
  * ```
665
666
  */
666
- getPageMarkdown(slug: string, options?: BaseRequestOptions): Promise<string>;
667
+ getMarkdown(contentPath: string, options?: BaseRequestOptions): Promise<string>;
667
668
  }
668
669
 
669
670
  /**
package/dist/index.d.ts CHANGED
@@ -627,43 +627,44 @@ declare class SeoService extends BaseService {
627
627
  */
628
628
  llmsFullTxt(options?: BaseRequestOptions): Promise<string>;
629
629
  /**
630
- * Retrieves a single blog article as Markdown
630
+ * Retrieves a single content or page as Markdown by its path.
631
631
  *
632
- * @param slug - The article slug
633
- * @returns Article content as Markdown
632
+ * The path is the same as the content's public URL path (available in
633
+ * `Content.path` or `Page.path`). The SDK appends `.md` automatically.
634
+ *
635
+ * @param contentPath - The content's public path.
636
+ * - For blog articles: use `Content.path` directly (includes locale prefix).
637
+ * - For pages in mono-language mode: use `Page.path` directly.
638
+ * - For pages in multi-language mode: prepend the locale manually,
639
+ * e.g., `/${page.locale}${page.path}`.
640
+ * @returns Markdown content
634
641
  *
635
642
  * @example
636
643
  * ```typescript
637
- * // In a Next.js route handler (app/llm/blog/[slug]/route.ts)
638
- * export async function GET(_req: Request, { params }: { params: Promise<{ slug: string }> }) {
639
- * const { slug } = await params
640
- * const md = await lynkow.seo.getContentMarkdown(slug)
641
- * return new Response(md, {
642
- * headers: { 'Content-Type': 'text/plain; charset=utf-8' }
643
- * })
644
- * }
645
- * ```
646
- */
647
- getContentMarkdown(slug: string, options?: BaseRequestOptions): Promise<string>;
648
- /**
649
- * Retrieves a single page as Markdown
644
+ * // Get a blog article as Markdown (path includes locale automatically)
645
+ * const article = await lynkow.contents.getBySlug('my-article')
646
+ * const md = await lynkow.seo.getMarkdown(article.path)
650
647
  *
651
- * @param slug - The page slug
652
- * @returns Page content as Markdown
648
+ * // Get a page as Markdown (mono-language)
649
+ * const page = await lynkow.pages.getBySlug('about')
650
+ * const md = await lynkow.seo.getMarkdown(page.path!)
653
651
  *
654
- * @example
655
- * ```typescript
656
- * // In a Next.js route handler (app/llm/pages/[slug]/route.ts)
657
- * export async function GET(_req: Request, { params }: { params: Promise<{ slug: string }> }) {
658
- * const { slug } = await params
659
- * const md = await lynkow.seo.getPageMarkdown(slug)
652
+ * // Get a page as Markdown (multi-language — prepend locale)
653
+ * const page = await lynkow.pages.getBySlug('about')
654
+ * const md = await lynkow.seo.getMarkdown(`/${page.locale}${page.path}`)
655
+ *
656
+ * // In a Next.js catch-all route handler
657
+ * export async function GET(req: Request) {
658
+ * const url = new URL(req.url)
659
+ * const path = url.pathname.replace(/\.md$/, '')
660
+ * const md = await lynkow.seo.getMarkdown(path)
660
661
  * return new Response(md, {
661
- * headers: { 'Content-Type': 'text/plain; charset=utf-8' }
662
+ * headers: { 'Content-Type': 'text/markdown; charset=utf-8' }
662
663
  * })
663
664
  * }
664
665
  * ```
665
666
  */
666
- getPageMarkdown(slug: string, options?: BaseRequestOptions): Promise<string>;
667
+ getMarkdown(contentPath: string, options?: BaseRequestOptions): Promise<string>;
667
668
  }
668
669
 
669
670
  /**
package/dist/index.js CHANGED
@@ -1,4 +1,4 @@
1
- 'use strict';var C=class s extends Error{name="LynkowError";code;status;details;cause;constructor(e,t,n,o,i){super(e),this.code=t,this.status=n,this.details=o,this.cause=i,Error.captureStackTrace&&Error.captureStackTrace(this,s);}static async fromResponse(e){let t=e.status,n=`HTTP ${t}`,o;try{let r=await e.json();r.errors&&Array.isArray(r.errors)?(o=r.errors,n=r.errors[0]?.message||n):r.error?n=r.error:r.message&&(n=r.message);}catch{n=e.statusText||n;}let i=s.statusToCode(t);return new s(n,i,t,o)}static fromNetworkError(e){return e.name==="AbortError"?new s("Request timed out","TIMEOUT",void 0,void 0,e):e.name==="TypeError"?new s("Network error - please check your connection","NETWORK_ERROR",void 0,void 0,e):new s(e.message||"Unknown error","UNKNOWN",void 0,void 0,e)}static statusToCode(e){switch(e){case 400:return "VALIDATION_ERROR";case 401:return "UNAUTHORIZED";case 403:return "FORBIDDEN";case 404:return "NOT_FOUND";case 429:return "RATE_LIMITED";default:return "UNKNOWN"}}toJSON(){return {name:this.name,message:this.message,code:this.code,status:this.status,details:this.details}}};function ge(s){return s instanceof C}function fe(s){switch(s){case 400:return "BAD_REQUEST";case 401:return "UNAUTHORIZED";case 403:return "FORBIDDEN";case 404:return "NOT_FOUND";case 422:return "VALIDATION_ERROR";case 429:return "TOO_MANY_REQUESTS";case 503:return "SERVICE_UNAVAILABLE";default:return "INTERNAL_ERROR"}}async function U(s,e){let t;try{t=await fetch(s,e);}catch(a){throw new C("Network error: Unable to reach the server","NETWORK_ERROR",0,[{message:a instanceof Error?a.message:"Unknown error"}])}if(t.ok)return t.json();let n={};try{n=await t.json();}catch{}let o=fe(t.status),i=n.error||n.message||`HTTP error: ${t.status}`,r=n.errors||[{message:i}];throw new C(i,o,t.status,r)}function ee(s){let e=new URLSearchParams;for(let[t,n]of Object.entries(s))n!=null&&n!==""&&e.append(t,String(n));return e.toString()}var d={SHORT:300*1e3,MEDIUM:600*1e3,LONG:1800*1e3},g=class{config;cache;constructor(e){this.config=e,this.cache=e.cache;}buildEndpointUrl(e,t){let n=`${this.config.baseUrl}/public/${this.config.siteId}${e}`;if(t&&Object.keys(t).length>0){let o=ee(t);return `${n}?${o}`}return n}async get(e,t,n){let o=n?.locale||this.config.locale,i=o?{...t,locale:o}:t,r=this.buildEndpointUrl(e,i),a=this.mergeFetchOptions(n?.fetchOptions);return U(r,{method:"GET",...a})}async getWithCache(e,t,n,o,i=d.SHORT){return this.cache?this.cache.getOrSet(e,()=>this.get(t,n,o),i):this.get(t,n,o)}invalidateCache(e){this.cache?.invalidate(e);}async post(e,t,n){let o=this.buildEndpointUrl(e),i=this.mergeFetchOptions(n?.fetchOptions);return U(o,{method:"POST",...i,headers:{"Content-Type":"application/json",...i.headers},body:JSON.stringify(t)})}async getText(e,t){let n=this.buildEndpointUrl(e),o=this.mergeFetchOptions(t?.fetchOptions),i=await fetch(n,{method:"GET",...o});if(!i.ok)throw new Error(`HTTP error: ${i.status}`);return i.text()}mergeFetchOptions(e){return {...this.config.fetchOptions,...e,headers:{...this.config.fetchOptions.headers,...e?.headers}}}};var K="contents_",b=class extends g{async list(e,t){let n={};e?.page&&(n.page=e.page),(e?.limit??e?.perPage)&&(n.limit=e?.limit??e?.perPage),e?.category&&(n.category=e.category),e?.tag&&(n.tag=e.tag),e?.search&&(n.search=e.search),e?.sort&&(n.sort=e.sort),e?.order&&(n.order=e.order),e?.locale&&(n.locale=e.locale);let o=`${K}list_${JSON.stringify(e||{})}`;return this.getWithCache(o,"/contents",n,t,d.SHORT)}async getBySlug(e,t){let n=t?.locale||this.config.locale,o=`${K}slug_${e}_${n||"default"}`;return this.getWithCache(o,`/contents/slug/${encodeURIComponent(e)}`,void 0,t,d.SHORT)}clearCache(){this.invalidateCache(K);}};var D="categories_",R=class extends g{async list(e){let t=e?.locale||this.config.locale,n=`${D}list_${t||"default"}`;return this.getWithCache(n,"/categories",void 0,e,d.SHORT)}async tree(e){let t=e?.locale||this.config.locale,n=`${D}tree_${t||"default"}`;return this.getWithCache(n,"/categories/tree",void 0,e,d.SHORT)}async getBySlug(e,t){let n={};t?.page&&(n.page=t.page),(t?.limit??t?.perPage)&&(n.limit=t?.limit??t?.perPage);let o=`${D}slug_${e}_${JSON.stringify(t||{})}`;return this.getWithCache(o,`/categories/${encodeURIComponent(e)}`,n,t,d.SHORT)}clearCache(){this.invalidateCache(D);}};var te="tags_",x=class extends g{async list(e){let t=e?.locale||this.config.locale,n=`${te}list_${t||"default"}`;return this.getWithCache(n,"/tags",void 0,e,d.SHORT)}clearCache(){this.invalidateCache(te);}};var E="pages_",k=class extends g{async list(e){let t=e?.locale||this.config.locale,n={};e?.tag&&(n.tag=e.tag);let o=`${E}list_${t||"default"}_${e?.tag||"all"}`;return this.getWithCache(o,"/pages",n,e,d.SHORT)}async getBySlug(e,t){let n=t?.locale||this.config.locale,o=`${E}slug_${e}_${n||"default"}`;return (await this.getWithCache(o,`/pages/${encodeURIComponent(e)}`,void 0,t,d.SHORT)).data}async getByPath(e,t){let n=t?.locale||this.config.locale,o=`${E}path_${e}_${n||"default"}`;return (await this.getWithCache(o,"/page-by-path",{path:e},t,d.SHORT)).data}async getJsonLd(e,t){let n=t?.locale||this.config.locale,o=`${E}jsonld_${e}_${n||"default"}`;return (await this.getWithCache(o,`/pages/${encodeURIComponent(e)}/json-ld`,void 0,t,d.SHORT)).data}clearCache(){this.invalidateCache(E);}};var j="globals_",T=class extends g{async siteConfig(e){let t=e?.locale||this.config.locale,n=`${j}siteconfig_${t||"default"}`;return this.getWithCache(n,"/site-config",void 0,e,d.MEDIUM)}async getBySlug(e,t){let n=t?.locale||this.config.locale,o=`${j}${e}_${n||"default"}`;return this.getWithCache(o,`/global/${encodeURIComponent(e)}`,void 0,t,d.MEDIUM)}async global(e,t){return this.getBySlug(e,t)}clearCache(){this.invalidateCache(j);}};function H(s){return {_hp:"",_ts:s}}var ne="forms_",S=class extends g{sessionStartTime;constructor(e){super(e),this.sessionStartTime=Date.now();}async getBySlug(e){let t=`${ne}${e}`;return (await this.getWithCache(t,`/forms/${encodeURIComponent(e)}`,void 0,void 0,d.MEDIUM)).data}async submit(e,t,n){let o=H(this.sessionStartTime),i={data:t,honeypot:o._hp,...o};return n?.recaptchaToken&&(i.recaptchaToken=n.recaptchaToken),this.post(`/forms/${encodeURIComponent(e)}/submit`,i,n)}clearCache(){this.invalidateCache(ne);}};var L="reviews_",O=class extends g{sessionStartTime;constructor(e){super(e),this.sessionStartTime=Date.now();}async list(e,t){let n={};e?.page&&(n.page=e.page),(e?.limit??e?.perPage)&&(n.limit=e?.limit??e?.perPage),e?.minRating&&(n.minRating=e.minRating),e?.maxRating&&(n.maxRating=e.maxRating),e?.sort&&(n.sort=e.sort),e?.order&&(n.order=e.order);let o=`${L}list_${JSON.stringify(e||{})}`;return this.getWithCache(o,"/reviews",n,t,d.SHORT)}async getBySlug(e){let t=`${L}slug_${e}`;return (await this.getWithCache(t,`/reviews/${encodeURIComponent(e)}`,void 0,void 0,d.SHORT)).data}async settings(){let e=`${L}settings`;return this.getWithCache(e,"/reviews/settings",void 0,void 0,d.MEDIUM)}async submit(e,t){let n=H(this.sessionStartTime),o={...e,...n};t?.recaptchaToken&&(o._recaptcha_token=t.recaptchaToken);let i=await this.post("/reviews",o,t);return this.invalidateCache(L),i}clearCache(){this.invalidateCache(L);}};var oe="site_",I=class extends g{async getConfig(){let e=`${oe}config`;return (await this.getWithCache(e,"/site",void 0,void 0,d.MEDIUM)).data}clearCache(){this.invalidateCache(oe);}};var z="legal_",P=class extends g{async list(e){let t=e?.locale||this.config.locale,n=`${z}list_${t||"default"}`;return (await this.getWithCache(n,"/pages",{tag:"legal"},e,d.SHORT)).data}async getBySlug(e,t){let n=t?.locale||this.config.locale,o=`${z}slug_${e}_${n||"default"}`;return (await this.getWithCache(o,`/pages/${encodeURIComponent(e)}`,void 0,t,d.SHORT)).data}clearCache(){this.invalidateCache(z);}};var re="cookies_",B=class extends g{async getConfig(){let e=`${re}config`;return (await this.getWithCache(e,"/cookie-consent/config",void 0,void 0,d.MEDIUM)).data}async logConsent(e,t){return this.post("/cookie-consent/log",{preferences:e},t)}clearCache(){this.invalidateCache(re);}};var $=class extends g{async sitemap(e){return this.getText("/sitemap.xml",e)}async robots(e){return this.getText("/robots.txt",e)}async llmsTxt(e){let t=e?.locale,n=t?`/${t}/llms.txt`:"/llms.txt";return this.getText(n,e)}async llmsFullTxt(e){let t=e?.locale,n=t?`/${t}/llms-full.txt`:"/llms-full.txt";return this.getText(n,e)}async getContentMarkdown(e,t){return this.getText(`/llm/blog/${encodeURIComponent(e)}.md`,t)}async getPageMarkdown(e,t){return this.getText(`/llm/pages/${encodeURIComponent(e)}.md`,t)}};var W="paths_",A=class extends g{async list(e){let t=e?.locale||this.config.locale,n=`${W}list_${t||"all"}`;return this.getWithCache(n,"/paths",void 0,e,d.SHORT)}async resolve(e,t){let n=t?.locale||this.config.locale,o=`${W}resolve_${e}_${n||"default"}`;return this.getWithCache(o,"/resolve",{path:e},t,d.SHORT)}async matchRedirect(e,t){try{return (await this.get("/redirects/match",{path:e},t)).data}catch(n){if(n instanceof C&&n.status===404)return null;throw n}}clearCache(){this.invalidateCache(W);}};var c=typeof window<"u"&&typeof window.document<"u"&&typeof window.document.createElement<"u",he=!c;function ye(s,e){return c?s():e}async function Ce(s,e){return c?s():e}var G="lynkow-tracker",N=class{config;enabled=true;initialized=false;loading=false;loadPromise=null;constructor(e){this.config=e;}getTrackerUrl(){return `${this.config.baseUrl}/analytics/tracker.js`}loadTracker(){return !c||window.LynkowAnalytics?Promise.resolve():this.loadPromise?this.loadPromise:(this.loading=true,this.loadPromise=new Promise((e,t)=>{if(document.getElementById(G)){let o=setInterval(()=>{window.LynkowAnalytics&&(clearInterval(o),this.loading=false,e());},50);setTimeout(()=>{clearInterval(o),this.loading=false,t(new Error("Tracker script load timeout"));},1e4);return}let n=document.createElement("script");n.id=G,n.src=this.getTrackerUrl(),n.async=true,n.setAttribute("data-site-id",this.config.siteId),this.config.baseUrl&&n.setAttribute("data-api-url",this.config.baseUrl),n.onload=()=>{this.loading=false,setTimeout(()=>{window.LynkowAnalytics?e():t(new Error("Tracker script loaded but LynkowAnalytics not found"));},0);},n.onerror=()=>{this.loading=false,t(new Error("Failed to load tracker script"));},document.head.appendChild(n);}),this.loadPromise)}async init(){if(!(!c||this.initialized))try{await this.loadTracker(),window.LynkowAnalytics&&!this.initialized&&(this.initialized=!0);}catch(e){console.error("[Lynkow] Failed to initialize analytics:",e);}}async trackEvent(e){!c||!this.enabled||(await this.init(),window.LynkowAnalytics&&window.LynkowAnalytics.track(e));}async trackPageview(e){!c||!this.enabled||(await this.init(),window.LynkowAnalytics&&window.LynkowAnalytics.track({type:"pageview",path:e?.path||window.location.pathname,title:e?.title||document.title,referrer:e?.referrer||document.referrer}));}enable(){this.enabled=true;}disable(){this.enabled=false;}isEnabled(){return this.enabled}isInitialized(){return this.initialized&&!!window.LynkowAnalytics}getTracker(){if(c)return window.LynkowAnalytics}destroy(){if(!c)return;document.getElementById(G)?.remove(),this.initialized=false,this.loadPromise=null;}};var V="_lkw_consent",se="lkw-script-",X={necessary:true,analytics:false,marketing:false,preferences:false},q=class{config;events;bannerElement=null;preferencesElement=null;configCache=null;injectedScriptIds=new Set;constructor(e,t){this.config=e,this.events=t;}async getConfig(){if(this.configCache)return this.configCache;let e=`${this.config.baseUrl}/public/${this.config.siteId}/cookie-consent/config`,t=await fetch(e,{method:"GET",headers:{"Content-Type":"application/json"},...this.config.fetchOptions});if(!t.ok)throw new Error(`Failed to fetch consent config: ${t.status}`);let n=await t.json();return this.configCache=n.data,this.configCache}async logConsent(e,t){let n=`${this.config.baseUrl}/public/${this.config.siteId}/cookie-consent/log`;await fetch(n,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({visitorId:this.getOrCreateVisitorId(),action:t||this.inferAction(e),consentGiven:e,pageUrl:c?window.location.href:void 0}),...this.config.fetchOptions}).catch(()=>{});}getOrCreateVisitorId(){if(!c)return "server";let e="_lkw_vid";try{let t=localStorage.getItem(e);return t||(t=crypto.randomUUID(),localStorage.setItem(e,t)),t}catch{return crypto.randomUUID()}}inferAction(e){let t=Object.entries(e).filter(([i])=>i!=="necessary"),n=t.every(([,i])=>i===true),o=t.every(([,i])=>i===false);return n?"accept_all":o?"reject_all":"customize"}getStoredConsent(){if(!c)return null;try{let e=localStorage.getItem(V);if(e){let t=JSON.parse(e);return t.choices?t.choices:t}}catch{}return null}saveConsent(e){if(c){try{localStorage.setItem(V,JSON.stringify({choices:e}));}catch{}this.events.emit("consent-changed",e),document.dispatchEvent(new CustomEvent("lynkow:consent:update",{detail:e}));}}show(){c&&this.getConfig().then(e=>{if(!e.enabled)return;let t=this.getStoredConsent();if(t){this.activateScripts(t);return}if(this.bannerElement)return;let n=document.createElement("div");n.innerHTML=this.createBannerHTML(e),this.bannerElement=n.firstElementChild,document.body.appendChild(this.bannerElement),this.attachBannerEvents();});}hide(){c&&(this.bannerElement?.remove(),this.bannerElement=null);}showPreferences(){c&&(this.preferencesElement||this.getConfig().then(e=>{let t=this.getCategories(),n=document.createElement("div");n.innerHTML=this.createPreferencesHTML(e,t),this.preferencesElement=n.firstElementChild,document.body.appendChild(this.preferencesElement),this.attachPreferencesEvents(e);}));}getCategories(){return c?this.getStoredConsent()||{...X}:{...X}}hasConsented(){return c?this.getStoredConsent()!==null:false}acceptAll(){if(!c)return;let e={necessary:true,analytics:true,marketing:true,preferences:true};this.saveConsent(e),this.logConsent(e,"accept_all"),this.activateScripts(e),this.hide();}rejectAll(){if(!c)return;let e={necessary:true,analytics:false,marketing:false,preferences:false};this.saveConsent(e),this.logConsent(e,"reject_all"),this.hide();}setCategories(e){if(!c)return;let n={...this.getCategories(),...e,necessary:true};this.saveConsent(n),this.logConsent(n,"customize"),this.activateScripts(n);}reset(){if(c){this.removeInjectedScripts();try{localStorage.removeItem(V);}catch{}this.events.emit("consent-changed",{...X}),this.show();}}activateScripts(e){if(this.configCache?.thirdPartyScripts?.length)for(let[t,n]of Object.entries(e))n&&this.injectScriptsForCategory(t,this.configCache.thirdPartyScripts);}injectScriptsForCategory(e,t){for(let n of t){if(n.category!==e||this.injectedScriptIds.has(n.id))continue;this.injectedScriptIds.add(n.id);let o=document.createElement("div");o.innerHTML=n.script;let i=Array.from(o.children);for(let r=0;r<i.length;r++){let a=i[r],p=`${se}${n.id}-${r}`;if(a.tagName==="SCRIPT"){let f=document.createElement("script");for(let m of Array.from(a.attributes))f.setAttribute(m.name,m.value);a.textContent&&(f.textContent=a.textContent),f.id=p,document.head.appendChild(f);}else a.id=p,document.body.appendChild(a);}}}removeInjectedScripts(){for(let e of this.injectedScriptIds){let t=0,n;for(;n=document.getElementById(`${se}${e}-${t}`);)n.remove(),t++;}this.injectedScriptIds.clear();}createBannerHTML(e){let t=e.position||"bottom",n=e.theme||"light",o=e.layout||"banner",i=e.primaryColor||"#0066cc",r=e.borderRadius??8,a={bottom:"bottom: 0; left: 0; right: 0;",top:"top: 0; left: 0; right: 0;","bottom-left":"bottom: 0; left: 0; right: 0;","bottom-right":"bottom: 0; left: 0; right: 0;",center:"top: 50%; left: 50%; transform: translate(-50%, -50%); max-width: 500px; width: calc(100% - 40px);"},p={bottom:`bottom: 20px; left: 50%; transform: translateX(-50%); max-width: 500px; width: calc(100% - 40px); border-radius: ${r}px;`,top:`top: 20px; left: 50%; transform: translateX(-50%); max-width: 500px; width: calc(100% - 40px); border-radius: ${r}px;`,"bottom-left":`bottom: 20px; left: 20px; max-width: 400px; border-radius: ${r}px;`,"bottom-right":`bottom: 20px; right: 20px; max-width: 400px; border-radius: ${r}px;`,center:`top: 50%; left: 50%; transform: translate(-50%, -50%); max-width: 500px; width: calc(100% - 40px); border-radius: ${r}px;`},f={center:`top: 50%; left: 50%; transform: translate(-50%, -50%); max-width: 500px; width: calc(100% - 40px); border-radius: ${r}px;`,bottom:`top: 50%; left: 50%; transform: translate(-50%, -50%); max-width: 500px; width: calc(100% - 40px); border-radius: ${r}px;`,top:`top: 50%; left: 50%; transform: translate(-50%, -50%); max-width: 500px; width: calc(100% - 40px); border-radius: ${r}px;`,"bottom-left":`top: 50%; left: 50%; transform: translate(-50%, -50%); max-width: 500px; width: calc(100% - 40px); border-radius: ${r}px;`,"bottom-right":`top: 50%; left: 50%; transform: translate(-50%, -50%); max-width: 500px; width: calc(100% - 40px); border-radius: ${r}px;`},m;o==="floating"?m=p:o==="modal"?m=f:m=a;let l=m[t]||m.bottom||"",u=n==="dark",h=u?"#1a1a1a":"#ffffff",y=u?"#ffffff":"#1a1a1a",w=e.texts||{title:"Nous utilisons des cookies",description:"Ce site utilise des cookies pour ameliorer votre experience.",acceptAll:"Accepter tout",rejectAll:"Refuser",customize:"Personnaliser"};return `
1
+ 'use strict';var C=class s extends Error{name="LynkowError";code;status;details;cause;constructor(e,t,n,o,i){super(e),this.code=t,this.status=n,this.details=o,this.cause=i,Error.captureStackTrace&&Error.captureStackTrace(this,s);}static async fromResponse(e){let t=e.status,n=`HTTP ${t}`,o;try{let r=await e.json();r.errors&&Array.isArray(r.errors)?(o=r.errors,n=r.errors[0]?.message||n):r.error?n=r.error:r.message&&(n=r.message);}catch{n=e.statusText||n;}let i=s.statusToCode(t);return new s(n,i,t,o)}static fromNetworkError(e){return e.name==="AbortError"?new s("Request timed out","TIMEOUT",void 0,void 0,e):e.name==="TypeError"?new s("Network error - please check your connection","NETWORK_ERROR",void 0,void 0,e):new s(e.message||"Unknown error","UNKNOWN",void 0,void 0,e)}static statusToCode(e){switch(e){case 400:return "VALIDATION_ERROR";case 401:return "UNAUTHORIZED";case 403:return "FORBIDDEN";case 404:return "NOT_FOUND";case 429:return "RATE_LIMITED";default:return "UNKNOWN"}}toJSON(){return {name:this.name,message:this.message,code:this.code,status:this.status,details:this.details}}};function ge(s){return s instanceof C}function fe(s){switch(s){case 400:return "BAD_REQUEST";case 401:return "UNAUTHORIZED";case 403:return "FORBIDDEN";case 404:return "NOT_FOUND";case 422:return "VALIDATION_ERROR";case 429:return "TOO_MANY_REQUESTS";case 503:return "SERVICE_UNAVAILABLE";default:return "INTERNAL_ERROR"}}async function U(s,e){let t;try{t=await fetch(s,e);}catch(a){throw new C("Network error: Unable to reach the server","NETWORK_ERROR",0,[{message:a instanceof Error?a.message:"Unknown error"}])}if(t.ok)return t.json();let n={};try{n=await t.json();}catch{}let o=fe(t.status),i=n.error||n.message||`HTTP error: ${t.status}`,r=n.errors||[{message:i}];throw new C(i,o,t.status,r)}function ee(s){let e=new URLSearchParams;for(let[t,n]of Object.entries(s))n!=null&&n!==""&&e.append(t,String(n));return e.toString()}var d={SHORT:300*1e3,MEDIUM:600*1e3,LONG:1800*1e3},g=class{config;cache;constructor(e){this.config=e,this.cache=e.cache;}buildEndpointUrl(e,t){let n=`${this.config.baseUrl}/public/${this.config.siteId}${e}`;if(t&&Object.keys(t).length>0){let o=ee(t);return `${n}?${o}`}return n}async get(e,t,n){let o=n?.locale||this.config.locale,i=o?{...t,locale:o}:t,r=this.buildEndpointUrl(e,i),a=this.mergeFetchOptions(n?.fetchOptions);return U(r,{method:"GET",...a})}async getWithCache(e,t,n,o,i=d.SHORT){return this.cache?this.cache.getOrSet(e,()=>this.get(t,n,o),i):this.get(t,n,o)}invalidateCache(e){this.cache?.invalidate(e);}async post(e,t,n){let o=this.buildEndpointUrl(e),i=this.mergeFetchOptions(n?.fetchOptions);return U(o,{method:"POST",...i,headers:{"Content-Type":"application/json",...i.headers},body:JSON.stringify(t)})}async getText(e,t){let n=this.buildEndpointUrl(e),o=this.mergeFetchOptions(t?.fetchOptions),i=await fetch(n,{method:"GET",...o});if(!i.ok)throw new Error(`HTTP error: ${i.status}`);return i.text()}mergeFetchOptions(e){return {...this.config.fetchOptions,...e,headers:{...this.config.fetchOptions.headers,...e?.headers}}}};var K="contents_",b=class extends g{async list(e,t){let n={};e?.page&&(n.page=e.page),(e?.limit??e?.perPage)&&(n.limit=e?.limit??e?.perPage),e?.category&&(n.category=e.category),e?.tag&&(n.tag=e.tag),e?.search&&(n.search=e.search),e?.sort&&(n.sort=e.sort),e?.order&&(n.order=e.order),e?.locale&&(n.locale=e.locale);let o=`${K}list_${JSON.stringify(e||{})}`;return this.getWithCache(o,"/contents",n,t,d.SHORT)}async getBySlug(e,t){let n=t?.locale||this.config.locale,o=`${K}slug_${e}_${n||"default"}`;return this.getWithCache(o,`/contents/slug/${encodeURIComponent(e)}`,void 0,t,d.SHORT)}clearCache(){this.invalidateCache(K);}};var D="categories_",R=class extends g{async list(e){let t=e?.locale||this.config.locale,n=`${D}list_${t||"default"}`;return this.getWithCache(n,"/categories",void 0,e,d.SHORT)}async tree(e){let t=e?.locale||this.config.locale,n=`${D}tree_${t||"default"}`;return this.getWithCache(n,"/categories/tree",void 0,e,d.SHORT)}async getBySlug(e,t){let n={};t?.page&&(n.page=t.page),(t?.limit??t?.perPage)&&(n.limit=t?.limit??t?.perPage);let o=`${D}slug_${e}_${JSON.stringify(t||{})}`;return this.getWithCache(o,`/categories/${encodeURIComponent(e)}`,n,t,d.SHORT)}clearCache(){this.invalidateCache(D);}};var te="tags_",x=class extends g{async list(e){let t=e?.locale||this.config.locale,n=`${te}list_${t||"default"}`;return this.getWithCache(n,"/tags",void 0,e,d.SHORT)}clearCache(){this.invalidateCache(te);}};var E="pages_",k=class extends g{async list(e){let t=e?.locale||this.config.locale,n={};e?.tag&&(n.tag=e.tag);let o=`${E}list_${t||"default"}_${e?.tag||"all"}`;return this.getWithCache(o,"/pages",n,e,d.SHORT)}async getBySlug(e,t){let n=t?.locale||this.config.locale,o=`${E}slug_${e}_${n||"default"}`;return (await this.getWithCache(o,`/pages/${encodeURIComponent(e)}`,void 0,t,d.SHORT)).data}async getByPath(e,t){let n=t?.locale||this.config.locale,o=`${E}path_${e}_${n||"default"}`;return (await this.getWithCache(o,"/page-by-path",{path:e},t,d.SHORT)).data}async getJsonLd(e,t){let n=t?.locale||this.config.locale,o=`${E}jsonld_${e}_${n||"default"}`;return (await this.getWithCache(o,`/pages/${encodeURIComponent(e)}/json-ld`,void 0,t,d.SHORT)).data}clearCache(){this.invalidateCache(E);}};var j="globals_",S=class extends g{async siteConfig(e){let t=e?.locale||this.config.locale,n=`${j}siteconfig_${t||"default"}`;return this.getWithCache(n,"/site-config",void 0,e,d.MEDIUM)}async getBySlug(e,t){let n=t?.locale||this.config.locale,o=`${j}${e}_${n||"default"}`;return this.getWithCache(o,`/global/${encodeURIComponent(e)}`,void 0,t,d.MEDIUM)}async global(e,t){return this.getBySlug(e,t)}clearCache(){this.invalidateCache(j);}};function H(s){return {_hp:"",_ts:s}}var ne="forms_",T=class extends g{sessionStartTime;constructor(e){super(e),this.sessionStartTime=Date.now();}async getBySlug(e){let t=`${ne}${e}`;return (await this.getWithCache(t,`/forms/${encodeURIComponent(e)}`,void 0,void 0,d.MEDIUM)).data}async submit(e,t,n){let o=H(this.sessionStartTime),i={data:t,honeypot:o._hp,...o};return n?.recaptchaToken&&(i.recaptchaToken=n.recaptchaToken),this.post(`/forms/${encodeURIComponent(e)}/submit`,i,n)}clearCache(){this.invalidateCache(ne);}};var L="reviews_",O=class extends g{sessionStartTime;constructor(e){super(e),this.sessionStartTime=Date.now();}async list(e,t){let n={};e?.page&&(n.page=e.page),(e?.limit??e?.perPage)&&(n.limit=e?.limit??e?.perPage),e?.minRating&&(n.minRating=e.minRating),e?.maxRating&&(n.maxRating=e.maxRating),e?.sort&&(n.sort=e.sort),e?.order&&(n.order=e.order);let o=`${L}list_${JSON.stringify(e||{})}`;return this.getWithCache(o,"/reviews",n,t,d.SHORT)}async getBySlug(e){let t=`${L}slug_${e}`;return (await this.getWithCache(t,`/reviews/${encodeURIComponent(e)}`,void 0,void 0,d.SHORT)).data}async settings(){let e=`${L}settings`;return this.getWithCache(e,"/reviews/settings",void 0,void 0,d.MEDIUM)}async submit(e,t){let n=H(this.sessionStartTime),o={...e,...n};t?.recaptchaToken&&(o._recaptcha_token=t.recaptchaToken);let i=await this.post("/reviews",o,t);return this.invalidateCache(L),i}clearCache(){this.invalidateCache(L);}};var oe="site_",I=class extends g{async getConfig(){let e=`${oe}config`;return (await this.getWithCache(e,"/site",void 0,void 0,d.MEDIUM)).data}clearCache(){this.invalidateCache(oe);}};var z="legal_",P=class extends g{async list(e){let t=e?.locale||this.config.locale,n=`${z}list_${t||"default"}`;return (await this.getWithCache(n,"/pages",{tag:"legal"},e,d.SHORT)).data}async getBySlug(e,t){let n=t?.locale||this.config.locale,o=`${z}slug_${e}_${n||"default"}`;return (await this.getWithCache(o,`/pages/${encodeURIComponent(e)}`,void 0,t,d.SHORT)).data}clearCache(){this.invalidateCache(z);}};var re="cookies_",B=class extends g{async getConfig(){let e=`${re}config`;return (await this.getWithCache(e,"/cookie-consent/config",void 0,void 0,d.MEDIUM)).data}async logConsent(e,t){return this.post("/cookie-consent/log",{preferences:e},t)}clearCache(){this.invalidateCache(re);}};var $=class extends g{async sitemap(e){return this.getText("/sitemap.xml",e)}async robots(e){return this.getText("/robots.txt",e)}async llmsTxt(e){let t=e?.locale,n=t?`/${t}/llms.txt`:"/llms.txt";return this.getText(n,e)}async llmsFullTxt(e){let t=e?.locale,n=t?`/${t}/llms-full.txt`:"/llms-full.txt";return this.getText(n,e)}async getMarkdown(e,t){let n=e.startsWith("/")?e:`/${e}`;return this.getText(`${n}.md`,t)}};var W="paths_",A=class extends g{async list(e){let t=e?.locale||this.config.locale,n=`${W}list_${t||"all"}`;return this.getWithCache(n,"/paths",void 0,e,d.SHORT)}async resolve(e,t){let n=t?.locale||this.config.locale,o=`${W}resolve_${e}_${n||"default"}`;return this.getWithCache(o,"/resolve",{path:e},t,d.SHORT)}async matchRedirect(e,t){try{return (await this.get("/redirects/match",{path:e},t)).data}catch(n){if(n instanceof C&&n.status===404)return null;throw n}}clearCache(){this.invalidateCache(W);}};var c=typeof window<"u"&&typeof window.document<"u"&&typeof window.document.createElement<"u",he=!c;function ye(s,e){return c?s():e}async function Ce(s,e){return c?s():e}var G="lynkow-tracker",N=class{config;enabled=true;initialized=false;loading=false;loadPromise=null;constructor(e){this.config=e;}getTrackerUrl(){return `${this.config.baseUrl}/analytics/tracker.js`}loadTracker(){return !c||window.LynkowAnalytics?Promise.resolve():this.loadPromise?this.loadPromise:(this.loading=true,this.loadPromise=new Promise((e,t)=>{if(document.getElementById(G)){let o=setInterval(()=>{window.LynkowAnalytics&&(clearInterval(o),this.loading=false,e());},50);setTimeout(()=>{clearInterval(o),this.loading=false,t(new Error("Tracker script load timeout"));},1e4);return}let n=document.createElement("script");n.id=G,n.src=this.getTrackerUrl(),n.async=true,n.setAttribute("data-site-id",this.config.siteId),this.config.baseUrl&&n.setAttribute("data-api-url",this.config.baseUrl),n.onload=()=>{this.loading=false,setTimeout(()=>{window.LynkowAnalytics?e():t(new Error("Tracker script loaded but LynkowAnalytics not found"));},0);},n.onerror=()=>{this.loading=false,t(new Error("Failed to load tracker script"));},document.head.appendChild(n);}),this.loadPromise)}async init(){if(!(!c||this.initialized))try{await this.loadTracker(),window.LynkowAnalytics&&!this.initialized&&(this.initialized=!0);}catch(e){console.error("[Lynkow] Failed to initialize analytics:",e);}}async trackEvent(e){!c||!this.enabled||(await this.init(),window.LynkowAnalytics&&window.LynkowAnalytics.track(e));}async trackPageview(e){!c||!this.enabled||(await this.init(),window.LynkowAnalytics&&window.LynkowAnalytics.track({type:"pageview",path:e?.path||window.location.pathname,title:e?.title||document.title,referrer:e?.referrer||document.referrer}));}enable(){this.enabled=true;}disable(){this.enabled=false;}isEnabled(){return this.enabled}isInitialized(){return this.initialized&&!!window.LynkowAnalytics}getTracker(){if(c)return window.LynkowAnalytics}destroy(){if(!c)return;document.getElementById(G)?.remove(),this.initialized=false,this.loadPromise=null;}};var V="_lkw_consent",se="lkw-script-",X={necessary:true,analytics:false,marketing:false,preferences:false},q=class{config;events;bannerElement=null;preferencesElement=null;configCache=null;injectedScriptIds=new Set;constructor(e,t){this.config=e,this.events=t;}async getConfig(){if(this.configCache)return this.configCache;let e=`${this.config.baseUrl}/public/${this.config.siteId}/cookie-consent/config`,t=await fetch(e,{method:"GET",headers:{"Content-Type":"application/json"},...this.config.fetchOptions});if(!t.ok)throw new Error(`Failed to fetch consent config: ${t.status}`);let n=await t.json();return this.configCache=n.data,this.configCache}async logConsent(e,t){let n=`${this.config.baseUrl}/public/${this.config.siteId}/cookie-consent/log`;await fetch(n,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({visitorId:this.getOrCreateVisitorId(),action:t||this.inferAction(e),consentGiven:e,pageUrl:c?window.location.href:void 0}),...this.config.fetchOptions}).catch(()=>{});}getOrCreateVisitorId(){if(!c)return "server";let e="_lkw_vid";try{let t=localStorage.getItem(e);return t||(t=crypto.randomUUID(),localStorage.setItem(e,t)),t}catch{return crypto.randomUUID()}}inferAction(e){let t=Object.entries(e).filter(([i])=>i!=="necessary"),n=t.every(([,i])=>i===true),o=t.every(([,i])=>i===false);return n?"accept_all":o?"reject_all":"customize"}getStoredConsent(){if(!c)return null;try{let e=localStorage.getItem(V);if(e){let t=JSON.parse(e);return t.choices?t.choices:t}}catch{}return null}saveConsent(e){if(c){try{localStorage.setItem(V,JSON.stringify({choices:e}));}catch{}this.events.emit("consent-changed",e),document.dispatchEvent(new CustomEvent("lynkow:consent:update",{detail:e}));}}show(){c&&this.getConfig().then(e=>{if(!e.enabled)return;let t=this.getStoredConsent();if(t){this.activateScripts(t);return}if(this.bannerElement)return;let n=document.createElement("div");n.innerHTML=this.createBannerHTML(e),this.bannerElement=n.firstElementChild,document.body.appendChild(this.bannerElement),this.attachBannerEvents();});}hide(){c&&(this.bannerElement?.remove(),this.bannerElement=null);}showPreferences(){c&&(this.preferencesElement||this.getConfig().then(e=>{let t=this.getCategories(),n=document.createElement("div");n.innerHTML=this.createPreferencesHTML(e,t),this.preferencesElement=n.firstElementChild,document.body.appendChild(this.preferencesElement),this.attachPreferencesEvents(e);}));}getCategories(){return c?this.getStoredConsent()||{...X}:{...X}}hasConsented(){return c?this.getStoredConsent()!==null:false}acceptAll(){if(!c)return;let e={necessary:true,analytics:true,marketing:true,preferences:true};this.saveConsent(e),this.logConsent(e,"accept_all"),this.activateScripts(e),this.hide();}rejectAll(){if(!c)return;let e={necessary:true,analytics:false,marketing:false,preferences:false};this.saveConsent(e),this.logConsent(e,"reject_all"),this.hide();}setCategories(e){if(!c)return;let n={...this.getCategories(),...e,necessary:true};this.saveConsent(n),this.logConsent(n,"customize"),this.activateScripts(n);}reset(){if(c){this.removeInjectedScripts();try{localStorage.removeItem(V);}catch{}this.events.emit("consent-changed",{...X}),this.show();}}activateScripts(e){if(this.configCache?.thirdPartyScripts?.length)for(let[t,n]of Object.entries(e))n&&this.injectScriptsForCategory(t,this.configCache.thirdPartyScripts);}injectScriptsForCategory(e,t){for(let n of t){if(n.category!==e||this.injectedScriptIds.has(n.id))continue;this.injectedScriptIds.add(n.id);let o=document.createElement("div");o.innerHTML=n.script;let i=Array.from(o.children);for(let r=0;r<i.length;r++){let a=i[r],p=`${se}${n.id}-${r}`;if(a.tagName==="SCRIPT"){let f=document.createElement("script");for(let u of Array.from(a.attributes))f.setAttribute(u.name,u.value);a.textContent&&(f.textContent=a.textContent),f.id=p,document.head.appendChild(f);}else a.id=p,document.body.appendChild(a);}}}removeInjectedScripts(){for(let e of this.injectedScriptIds){let t=0,n;for(;n=document.getElementById(`${se}${e}-${t}`);)n.remove(),t++;}this.injectedScriptIds.clear();}createBannerHTML(e){let t=e.position||"bottom",n=e.theme||"light",o=e.layout||"banner",i=e.primaryColor||"#0066cc",r=e.borderRadius??8,a={bottom:"bottom: 0; left: 0; right: 0;",top:"top: 0; left: 0; right: 0;","bottom-left":"bottom: 0; left: 0; right: 0;","bottom-right":"bottom: 0; left: 0; right: 0;",center:"top: 50%; left: 50%; transform: translate(-50%, -50%); max-width: 500px; width: calc(100% - 40px);"},p={bottom:`bottom: 20px; left: 50%; transform: translateX(-50%); max-width: 500px; width: calc(100% - 40px); border-radius: ${r}px;`,top:`top: 20px; left: 50%; transform: translateX(-50%); max-width: 500px; width: calc(100% - 40px); border-radius: ${r}px;`,"bottom-left":`bottom: 20px; left: 20px; max-width: 400px; border-radius: ${r}px;`,"bottom-right":`bottom: 20px; right: 20px; max-width: 400px; border-radius: ${r}px;`,center:`top: 50%; left: 50%; transform: translate(-50%, -50%); max-width: 500px; width: calc(100% - 40px); border-radius: ${r}px;`},f={center:`top: 50%; left: 50%; transform: translate(-50%, -50%); max-width: 500px; width: calc(100% - 40px); border-radius: ${r}px;`,bottom:`top: 50%; left: 50%; transform: translate(-50%, -50%); max-width: 500px; width: calc(100% - 40px); border-radius: ${r}px;`,top:`top: 50%; left: 50%; transform: translate(-50%, -50%); max-width: 500px; width: calc(100% - 40px); border-radius: ${r}px;`,"bottom-left":`top: 50%; left: 50%; transform: translate(-50%, -50%); max-width: 500px; width: calc(100% - 40px); border-radius: ${r}px;`,"bottom-right":`top: 50%; left: 50%; transform: translate(-50%, -50%); max-width: 500px; width: calc(100% - 40px); border-radius: ${r}px;`},u;o==="floating"?u=p:o==="modal"?u=f:u=a;let l=u[t]||u.bottom||"",m=n==="dark",h=m?"#1a1a1a":"#ffffff",y=m?"#ffffff":"#1a1a1a",w=e.texts||{title:"Nous utilisons des cookies",description:"Ce site utilise des cookies pour ameliorer votre experience.",acceptAll:"Accepter tout",rejectAll:"Refuser",customize:"Personnaliser"};return `
2
2
  ${o==="modal"?`
3
3
  <div id="lynkow-consent-backdrop" style="
4
4
  position: fixed;
@@ -57,21 +57,21 @@
57
57
  </div>
58
58
  </div>
59
59
  </div>
60
- `}createPreferencesHTML(e,t){let n=e.theme||"light",o=e.primaryColor||"#0066cc",i=e.borderRadius??8,r=n==="dark",a=r?"#1a1a1a":"#ffffff",p=r?"#ffffff":"#1a1a1a",f=e.texts||{title:"Preferences de cookies",save:"Enregistrer"},l=(e.categories||[]).map(u=>`
61
- <label style="display: flex; align-items: flex-start; gap: 10px; margin: 15px 0; cursor: ${u.required?"not-allowed":"pointer"};">
60
+ `}createPreferencesHTML(e,t){let n=e.theme||"light",o=e.primaryColor||"#0066cc",i=e.borderRadius??8,r=n==="dark",a=r?"#1a1a1a":"#ffffff",p=r?"#ffffff":"#1a1a1a",f=e.texts||{title:"Preferences de cookies",save:"Enregistrer"},l=(e.categories||[]).map(m=>`
61
+ <label style="display: flex; align-items: flex-start; gap: 10px; margin: 15px 0; cursor: ${m.required?"not-allowed":"pointer"};">
62
62
  <input
63
63
  type="checkbox"
64
- name="${u.id}"
65
- ${t[u.id]?"checked":""}
66
- ${u.required?"disabled checked":""}
64
+ name="${m.id}"
65
+ ${t[m.id]?"checked":""}
66
+ ${m.required?"disabled checked":""}
67
67
  style="width: 18px; height: 18px; margin-top: 2px; accent-color: ${o};"
68
68
  />
69
69
  <div style="flex: 1;">
70
- <strong style="opacity: ${u.required?"0.6":"1"};">
71
- ${u.name}${u.required?" (requis)":""}
70
+ <strong style="opacity: ${m.required?"0.6":"1"};">
71
+ ${m.name}${m.required?" (requis)":""}
72
72
  </strong>
73
73
  <p style="margin: 5px 0 0 0; font-size: 13px; opacity: 0.8;">
74
- ${u.description}
74
+ ${m.description}
75
75
  </p>
76
76
  </div>
77
77
  </label>
@@ -243,6 +243,6 @@
243
243
  color: #1a1a1a;
244
244
  }
245
245
  }
246
- `,_=class{initialized=false;observer=null;handleWidgetResize=e=>{if(!e.data||e.data.type!=="lynkow-widget-resize")return;document.querySelectorAll('iframe[src*="/widgets/calendar/"]').forEach(n=>{n.contentWindow===e.source&&(n.style.height=e.data.height+"px");});};injectStyles(){if(!c||document.getElementById(Q))return;let e=document.createElement("style");e.id=Q,e.textContent=be,document.head.appendChild(e);}async handleCopyClick(e){let t=e.closest(".code-block");if(!t)return;let n=t.querySelector("code");if(!n)return;let o=n.textContent||"";try{await navigator.clipboard.writeText(o),e.classList.add("copied"),e.innerHTML=we,setTimeout(()=>{e.classList.remove("copied"),e.innerHTML=ve;},2e3);}catch(i){console.error("Lynkow SDK: Failed to copy code",i);}}bindCodeBlockCopy(){if(!c)return;document.querySelectorAll("[data-copy-code]").forEach(t=>{t.dataset.lynkowBound||(t.dataset.lynkowBound="true",t.addEventListener("click",n=>{n.preventDefault(),this.handleCopyClick(t);}));});}activateScripts(e){if(!c)return;(e instanceof HTMLElement?e:document.body).querySelectorAll("script:not([data-lynkow-activated])").forEach(o=>{if(o.src)return;o.setAttribute("data-lynkow-activated","true");let i=document.createElement("script"),r=o.attributes;for(let a=0;a<r.length;a++){let p=r[a];p&&(p.name==="type"&&p.value==="text/plain"||i.setAttribute(p.name,p.value));}i.textContent=o.textContent,o.parentNode?.replaceChild(i,o);});}init(){c&&(this.injectStyles(),this.bindCodeBlockCopy(),this.activateScripts(),window.addEventListener("message",this.handleWidgetResize),this.observer||(this.observer=new MutationObserver(e=>{e.forEach(t=>{t.addedNodes.forEach(n=>{n instanceof HTMLElement&&this.activateScripts(n);});}),this.bindCodeBlockCopy();}),this.observer.observe(document.body,{childList:true,subtree:true})),this.initialized=true);}isInitialized(){return this.initialized}destroy(){c&&(window.removeEventListener("message",this.handleWidgetResize),this.observer&&(this.observer.disconnect(),this.observer=null),document.getElementById(Q)?.remove(),this.initialized=false);}};var F=class{srcset(e,t={}){if(!e)return "";let{widths:n=[400,800,1200,1920],fit:o="scale-down",quality:i=80,gravity:r}=t,a=this.parseImageUrl(e);return a?n.map(p=>{let f=[`w=${p}`,`fit=${o}`,"format=auto",`quality=${i}`,r&&`gravity=${r}`].filter(Boolean).join(",");return `${a.cdnBase}/cdn-cgi/image/${f}/${a.relativePath} ${p}w`}).join(", "):""}transform(e,t={}){if(!e)return "";let n=this.parseImageUrl(e);if(!n)return e||"";let o=[t.w&&`w=${t.w}`,t.h&&`h=${t.h}`,`fit=${t.fit||"scale-down"}`,`format=${t.format||"auto"}`,`quality=${t.quality||80}`,t.gravity&&`gravity=${t.gravity}`,t.dpr&&`dpr=${t.dpr}`].filter(Boolean).join(",");return `${n.cdnBase}/cdn-cgi/image/${o}/${n.relativePath}`}parseImageUrl(e){let t=e.indexOf("/cdn-cgi/image/");if(t!==-1){let i=e.substring(0,t),r=e.substring(t+15),a=r.indexOf("/");if(a===-1)return null;let p=r.substring(a+1);return {cdnBase:i,relativePath:p}}let n=e.indexOf("/sites/");if(n!==-1){let i=e.substring(0,n),r=e.substring(n+1);return {cdnBase:i,relativePath:r}}let o=e.indexOf("/avatars/");if(o!==-1){let i=e.substring(0,o),r=e.substring(o+1);return {cdnBase:i,relativePath:r}}return null}};var Re=300*1e3,xe="lynkow_cache_",v=new Map;function ie(s={}){let e=s.defaultTtl??Re,t=s.prefix??xe;function n(m){return `${t}${m}`}function o(m){return Date.now()>m.expiresAt}function i(m){let l=n(m);if(c)try{let h=localStorage.getItem(l);if(!h)return null;let y=JSON.parse(h);return o(y)?(localStorage.removeItem(l),null):y.value}catch{return null}let u=v.get(l);return u?o(u)?(v.delete(l),null):u.value:null}function r(m,l,u=e){let h=n(m),y={value:l,expiresAt:Date.now()+u};if(c){try{localStorage.setItem(h,JSON.stringify(y));}catch{}return}v.set(h,y);}function a(m){let l=n(m);if(c){try{localStorage.removeItem(l);}catch{}return}v.delete(l);}function p(m){if(c){try{let l=[];for(let u=0;u<localStorage.length;u++){let h=localStorage.key(u);h&&h.startsWith(t)&&(!m||h.includes(m))&&l.push(h);}l.forEach(u=>localStorage.removeItem(u));}catch{}return}if(m)for(let l of v.keys())l.startsWith(t)&&l.includes(m)&&v.delete(l);else for(let l of v.keys())l.startsWith(t)&&v.delete(l);}async function f(m,l,u=e){let h=i(m);if(h!==null)return h;let y=await l();return r(m,y,u),y}return {get:i,set:r,remove:a,invalidate:p,getOrSet:f}}function ae(s){let e=s.prefix||"[Lynkow]";return {debug(...t){s.debug&&console.debug(e,...t);},info(...t){console.info(e,...t);},warn(...t){console.warn(e,...t);},error(...t){console.error(e,...t);},log(t,...n){switch(t){case "debug":this.debug(...n);break;case "info":this.info(...n);break;case "warn":this.warn(...n);break;case "error":this.error(...n);break}}}}function ce(){let s=new Map;function e(r,a){return s.has(r)||s.set(r,new Set),s.get(r).add(a),()=>t(r,a)}function t(r,a){let p=s.get(r);p&&p.delete(a);}function n(r,a){let p=s.get(r);if(p)for(let f of p)try{f(a);}catch(m){console.error(`[Lynkow] Error in event listener for "${r}":`,m);}}function o(r,a){let p=(f=>{t(r,p),a(f);});return e(r,p)}function i(r){r?s.delete(r):s.clear();}return {on:e,off:t,emit:n,once:o,removeAllListeners:i}}var le="lynkow_locale";function Z(s,e){let t=s.toLowerCase();return e.find(n=>n.toLowerCase()===t)??null}function de(s,e){if(!c)return e;let t=Ee();if(t&&s.includes(t))return t;let n=ke(s);if(n)return n;let o=document.documentElement.lang;if(o){let i=Z(o,s);if(i)return i;let r=o.split("-")[0]?.toLowerCase();if(r){let a=Z(r,s);if(a)return a}}return e}function Ee(){if(!c)return null;try{return localStorage.getItem(le)}catch{return null}}function pe(s){if(c)try{localStorage.setItem(le,s);}catch{}}function ke(s){if(!c)return null;let t=window.location.pathname.split("/").filter(Boolean);if(t.length>0){let n=t[0];if(n){let o=Z(n,s);if(o)return o}}return null}function me(s,e){return e.includes(s)}var ue="https://api.lynkow.com";function Te(s){if(!s.siteId)throw new Error("Lynkow SDK: siteId is required");let e=ie(),t=ae({debug:s.debug??false}),n=ce(),o=(s.baseUrl||ue).replace(/\/$/,""),i={siteId:s.siteId,baseUrl:o,locale:s.locale,fetchOptions:s.fetchOptions||{},cache:e},r={locale:s.locale||"fr",availableLocales:["fr"],siteConfig:null,initialized:false},a={contents:new b(i),categories:new R(i),tags:new x(i),pages:new k(i),blocks:new T(i),forms:new S(i),reviews:new O(i),site:new I(i),legal:new P(i),cookies:new B(i),seo:new $(i),paths:new A(i),analytics:new N(i),consent:new q(i,n),branding:new M(i),enhancements:new _,media:new F};function p(l){i.locale=l;}async function f(){if(!r.initialized)try{let l=await a.site.getConfig();r.siteConfig=l;let u=l.defaultLocale||"fr";if(r.availableLocales=l.enabledLocales||[u],c&&!s.locale){let h=de(r.availableLocales,u);r.locale=h,p(h);}r.initialized=!0,t.debug("Client initialized",{locale:r.locale,availableLocales:r.availableLocales}),c&&(a.analytics.init(),a.consent.hasConsented()||a.consent.show(),l.showBranding&&await a.branding.inject(),a.enhancements.init()),n.emit("ready",void 0);}catch(l){t.error("Failed to initialize client",l),n.emit("error",l);}}return c&&(a.enhancements.init(),setTimeout(()=>f(),0)),{...a,globals:a.blocks,config:Object.freeze({siteId:s.siteId,baseUrl:o,debug:s.debug??false}),get locale(){return r.locale},get availableLocales(){return [...r.availableLocales]},setLocale(l){if(!me(l,r.availableLocales)){t.warn(`Locale "${l}" is not available. Available: ${r.availableLocales.join(", ")}`);return}l!==r.locale&&(r.locale=l,p(l),c&&pe(l),e.invalidate(),n.emit("locale-changed",l),t.debug("Locale changed to",l));},clearCache(){e.invalidate(),t.debug("Cache cleared");},destroy(){a.analytics.destroy(),a.consent.destroy(),a.branding.destroy(),a.enhancements.destroy(),e.invalidate(),n.removeAllListeners(),t.debug("Client destroyed");},on(l,u){return n.on(l,u)}}}function Se(s){if(!s.siteId)throw new Error("Lynkow SDK: siteId is required");let e={siteId:s.siteId,baseUrl:(s.baseUrl||ue).replace(/\/$/,""),locale:s.locale,fetchOptions:s.fetchOptions||{}};return {contents:new b(e),categories:new R(e),tags:new x(e),pages:new k(e),blocks:new T(e),forms:new S(e),reviews:new O(e),site:new I(e),legal:new P(e),cookies:new B(e),seo:new $(e),paths:new A(e)}}function Le(s){return s.type==="content"}function Oe(s){return s.type==="category"}
247
- exports.EnhancementsService=_;exports.LynkowError=C;exports.MediaHelperService=F;exports.browserOnly=ye;exports.browserOnlyAsync=Ce;exports.createClient=Te;exports.createLynkowClient=Se;exports.isBrowser=c;exports.isCategoryResolve=Oe;exports.isContentResolve=Le;exports.isLynkowError=ge;exports.isServer=he;//# sourceMappingURL=index.js.map
246
+ `,_=class{initialized=false;observer=null;handleWidgetResize=e=>{if(!e.data||e.data.type!=="lynkow-widget-resize")return;document.querySelectorAll('iframe[src*="/widgets/calendar/"]').forEach(n=>{n.contentWindow===e.source&&(n.style.height=e.data.height+"px");});};injectStyles(){if(!c||document.getElementById(Q))return;let e=document.createElement("style");e.id=Q,e.textContent=be,document.head.appendChild(e);}async handleCopyClick(e){let t=e.closest(".code-block");if(!t)return;let n=t.querySelector("code");if(!n)return;let o=n.textContent||"";try{await navigator.clipboard.writeText(o),e.classList.add("copied"),e.innerHTML=we,setTimeout(()=>{e.classList.remove("copied"),e.innerHTML=ve;},2e3);}catch(i){console.error("Lynkow SDK: Failed to copy code",i);}}bindCodeBlockCopy(){if(!c)return;document.querySelectorAll("[data-copy-code]").forEach(t=>{t.dataset.lynkowBound||(t.dataset.lynkowBound="true",t.addEventListener("click",n=>{n.preventDefault(),this.handleCopyClick(t);}));});}activateScripts(e){if(!c)return;(e instanceof HTMLElement?e:document.body).querySelectorAll("script:not([data-lynkow-activated])").forEach(o=>{if(o.src)return;o.setAttribute("data-lynkow-activated","true");let i=document.createElement("script"),r=o.attributes;for(let a=0;a<r.length;a++){let p=r[a];p&&(p.name==="type"&&p.value==="text/plain"||i.setAttribute(p.name,p.value));}i.textContent=o.textContent,o.parentNode?.replaceChild(i,o);});}init(){c&&(this.injectStyles(),this.bindCodeBlockCopy(),this.activateScripts(),window.addEventListener("message",this.handleWidgetResize),this.observer||(this.observer=new MutationObserver(e=>{e.forEach(t=>{t.addedNodes.forEach(n=>{n instanceof HTMLElement&&this.activateScripts(n);});}),this.bindCodeBlockCopy();}),this.observer.observe(document.body,{childList:true,subtree:true})),this.initialized=true);}isInitialized(){return this.initialized}destroy(){c&&(window.removeEventListener("message",this.handleWidgetResize),this.observer&&(this.observer.disconnect(),this.observer=null),document.getElementById(Q)?.remove(),this.initialized=false);}};var F=class{srcset(e,t={}){if(!e)return "";let{widths:n=[400,800,1200,1920],fit:o="scale-down",quality:i=80,gravity:r}=t,a=this.parseImageUrl(e);return a?n.map(p=>{let f=[`w=${p}`,`fit=${o}`,"format=auto",`quality=${i}`,r&&`gravity=${r}`].filter(Boolean).join(",");return `${a.cdnBase}/cdn-cgi/image/${f}/${a.relativePath} ${p}w`}).join(", "):""}transform(e,t={}){if(!e)return "";let n=this.parseImageUrl(e);if(!n)return e||"";let o=[t.w&&`w=${t.w}`,t.h&&`h=${t.h}`,`fit=${t.fit||"scale-down"}`,`format=${t.format||"auto"}`,`quality=${t.quality||80}`,t.gravity&&`gravity=${t.gravity}`,t.dpr&&`dpr=${t.dpr}`].filter(Boolean).join(",");return `${n.cdnBase}/cdn-cgi/image/${o}/${n.relativePath}`}parseImageUrl(e){let t=e.indexOf("/cdn-cgi/image/");if(t!==-1){let i=e.substring(0,t),r=e.substring(t+15),a=r.indexOf("/");if(a===-1)return null;let p=r.substring(a+1);return {cdnBase:i,relativePath:p}}let n=e.indexOf("/sites/");if(n!==-1){let i=e.substring(0,n),r=e.substring(n+1);return {cdnBase:i,relativePath:r}}let o=e.indexOf("/avatars/");if(o!==-1){let i=e.substring(0,o),r=e.substring(o+1);return {cdnBase:i,relativePath:r}}return null}};var Re=300*1e3,xe="lynkow_cache_",v=new Map;function ie(s={}){let e=s.defaultTtl??Re,t=s.prefix??xe;function n(u){return `${t}${u}`}function o(u){return Date.now()>u.expiresAt}function i(u){let l=n(u);if(c)try{let h=localStorage.getItem(l);if(!h)return null;let y=JSON.parse(h);return o(y)?(localStorage.removeItem(l),null):y.value}catch{return null}let m=v.get(l);return m?o(m)?(v.delete(l),null):m.value:null}function r(u,l,m=e){let h=n(u),y={value:l,expiresAt:Date.now()+m};if(c){try{localStorage.setItem(h,JSON.stringify(y));}catch{}return}v.set(h,y);}function a(u){let l=n(u);if(c){try{localStorage.removeItem(l);}catch{}return}v.delete(l);}function p(u){if(c){try{let l=[];for(let m=0;m<localStorage.length;m++){let h=localStorage.key(m);h&&h.startsWith(t)&&(!u||h.includes(u))&&l.push(h);}l.forEach(m=>localStorage.removeItem(m));}catch{}return}if(u)for(let l of v.keys())l.startsWith(t)&&l.includes(u)&&v.delete(l);else for(let l of v.keys())l.startsWith(t)&&v.delete(l);}async function f(u,l,m=e){let h=i(u);if(h!==null)return h;let y=await l();return r(u,y,m),y}return {get:i,set:r,remove:a,invalidate:p,getOrSet:f}}function ae(s){let e=s.prefix||"[Lynkow]";return {debug(...t){s.debug&&console.debug(e,...t);},info(...t){console.info(e,...t);},warn(...t){console.warn(e,...t);},error(...t){console.error(e,...t);},log(t,...n){switch(t){case "debug":this.debug(...n);break;case "info":this.info(...n);break;case "warn":this.warn(...n);break;case "error":this.error(...n);break}}}}function ce(){let s=new Map;function e(r,a){return s.has(r)||s.set(r,new Set),s.get(r).add(a),()=>t(r,a)}function t(r,a){let p=s.get(r);p&&p.delete(a);}function n(r,a){let p=s.get(r);if(p)for(let f of p)try{f(a);}catch(u){console.error(`[Lynkow] Error in event listener for "${r}":`,u);}}function o(r,a){let p=(f=>{t(r,p),a(f);});return e(r,p)}function i(r){r?s.delete(r):s.clear();}return {on:e,off:t,emit:n,once:o,removeAllListeners:i}}var le="lynkow_locale";function Z(s,e){let t=s.toLowerCase();return e.find(n=>n.toLowerCase()===t)??null}function de(s,e){if(!c)return e;let t=Ee();if(t&&s.includes(t))return t;let n=ke(s);if(n)return n;let o=document.documentElement.lang;if(o){let i=Z(o,s);if(i)return i;let r=o.split("-")[0]?.toLowerCase();if(r){let a=Z(r,s);if(a)return a}}return e}function Ee(){if(!c)return null;try{return localStorage.getItem(le)}catch{return null}}function pe(s){if(c)try{localStorage.setItem(le,s);}catch{}}function ke(s){if(!c)return null;let t=window.location.pathname.split("/").filter(Boolean);if(t.length>0){let n=t[0];if(n){let o=Z(n,s);if(o)return o}}return null}function ue(s,e){return e.includes(s)}var me="https://api.lynkow.com";function Se(s){if(!s.siteId)throw new Error("Lynkow SDK: siteId is required");let e=ie(),t=ae({debug:s.debug??false}),n=ce(),o=(s.baseUrl||me).replace(/\/$/,""),i={siteId:s.siteId,baseUrl:o,locale:s.locale,fetchOptions:s.fetchOptions||{},cache:e},r={locale:s.locale||"fr",availableLocales:["fr"],siteConfig:null,initialized:false},a={contents:new b(i),categories:new R(i),tags:new x(i),pages:new k(i),blocks:new S(i),forms:new T(i),reviews:new O(i),site:new I(i),legal:new P(i),cookies:new B(i),seo:new $(i),paths:new A(i),analytics:new N(i),consent:new q(i,n),branding:new M(i),enhancements:new _,media:new F};function p(l){i.locale=l;}async function f(){if(!r.initialized)try{let l=await a.site.getConfig();r.siteConfig=l;let m=l.defaultLocale||"fr";if(r.availableLocales=l.enabledLocales||[m],c&&!s.locale){let h=de(r.availableLocales,m);r.locale=h,p(h);}r.initialized=!0,t.debug("Client initialized",{locale:r.locale,availableLocales:r.availableLocales}),c&&(a.analytics.init(),a.consent.hasConsented()||a.consent.show(),l.showBranding&&await a.branding.inject(),a.enhancements.init()),n.emit("ready",void 0);}catch(l){t.error("Failed to initialize client",l),n.emit("error",l);}}return c&&(a.enhancements.init(),setTimeout(()=>f(),0)),{...a,globals:a.blocks,config:Object.freeze({siteId:s.siteId,baseUrl:o,debug:s.debug??false}),get locale(){return r.locale},get availableLocales(){return [...r.availableLocales]},setLocale(l){if(!ue(l,r.availableLocales)){t.warn(`Locale "${l}" is not available. Available: ${r.availableLocales.join(", ")}`);return}l!==r.locale&&(r.locale=l,p(l),c&&pe(l),e.invalidate(),n.emit("locale-changed",l),t.debug("Locale changed to",l));},clearCache(){e.invalidate(),t.debug("Cache cleared");},destroy(){a.analytics.destroy(),a.consent.destroy(),a.branding.destroy(),a.enhancements.destroy(),e.invalidate(),n.removeAllListeners(),t.debug("Client destroyed");},on(l,m){return n.on(l,m)}}}function Te(s){if(!s.siteId)throw new Error("Lynkow SDK: siteId is required");let e={siteId:s.siteId,baseUrl:(s.baseUrl||me).replace(/\/$/,""),locale:s.locale,fetchOptions:s.fetchOptions||{}};return {contents:new b(e),categories:new R(e),tags:new x(e),pages:new k(e),blocks:new S(e),forms:new T(e),reviews:new O(e),site:new I(e),legal:new P(e),cookies:new B(e),seo:new $(e),paths:new A(e)}}function Le(s){return s.type==="content"}function Oe(s){return s.type==="category"}
247
+ exports.EnhancementsService=_;exports.LynkowError=C;exports.MediaHelperService=F;exports.browserOnly=ye;exports.browserOnlyAsync=Ce;exports.createClient=Se;exports.createLynkowClient=Te;exports.isBrowser=c;exports.isCategoryResolve=Oe;exports.isContentResolve=Le;exports.isLynkowError=ge;exports.isServer=he;//# sourceMappingURL=index.js.map
248
248
  //# sourceMappingURL=index.js.map