@fynd-design-engineering/fynd-one-v2 3.1.23 → 3.1.24

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
- "use strict";(()=>{var s=class{constructor(){this.baseUrl="https://www.fynd.com",this.organizationData={"@type":"Organization","@id":`${this.baseUrl}#organization`,name:"Fynd",url:this.baseUrl,logo:`${this.baseUrl}/logo.png`,sameAs:["https://www.linkedin.com/company/fynd","https://en.wikipedia.org/wiki/Fynd","https://twitter.com/Fynd"],description:"Fynd is an AI-powered unified commerce platform enabling brands to manage end-to-end retail operations."}}generateWebsiteSchema(){return{"@type":"WebSite","@id":`${this.baseUrl}#website`,url:this.baseUrl,name:"Fynd",description:"AI-powered unified commerce platform",publisher:{"@id":`${this.baseUrl}#organization`},potentialAction:{"@type":"SearchAction",target:{"@type":"EntryPoint",urlTemplate:`${this.baseUrl}/search?q={search_term_string}`},"query-input":"required name=search_term_string"}}}generateBreadcrumbSchema(e){return{"@type":"BreadcrumbList",itemListElement:e.map((t,r)=>({"@type":"ListItem",position:r+1,name:t.name,item:t.url}))}}generateWebPageSchema(e){let t={"@type":"WebPage","@id":e.url,url:e.url,name:e.title,description:e.description||"",isPartOf:{"@id":`${this.baseUrl}#website`}};return e.mainEntity&&(t.mainEntity=e.mainEntity),t}generateSoftwareSchema(e){return{"@type":"SoftwareApplication","@id":`${e.url}#software`,name:e.name,applicationCategory:e.category||"RetailSoftware",operatingSystem:"Web",featureList:e.features||[],offers:{"@type":"Offer",price:e.price||"Contact for Pricing",priceCurrency:"USD",availability:"InStock",url:`${this.baseUrl}/contact`},audience:{"@type":"Audience",audienceType:e.audience||"Business"},url:e.url,description:e.description,manufacturer:{"@id":`${this.baseUrl}#organization`}}}generateProductSchema(e){return{"@type":"Product",name:e.name,url:e.url,description:e.description,brand:{"@id":`${this.baseUrl}#organization`},offers:{"@type":"Offer",price:e.price||"Contact for Pricing",priceCurrency:"USD",availability:"InStock",url:`${this.baseUrl}/contact`}}}generateFAQSchema(e){return!e||e.length===0?null:{"@type":"FAQPage",mainEntity:e.map(t=>({"@type":"Question",name:t.question,acceptedAnswer:{"@type":"Answer",text:t.answer}}))}}generateArticleSchema(e){return{"@type":"Article",headline:e.title,description:e.description,image:e.image,author:{"@type":"Person",name:e.author||"Fynd Team"},publisher:{"@id":`${this.baseUrl}#organization`},datePublished:e.publishDate,dateModified:e.modifyDate||e.publishDate,mainEntityOfPage:{"@type":"WebPage","@id":e.url}}}generateSchema(e){let t=[];t.push(this.organizationData),t.push(this.generateWebsiteSchema());let r=this.generateWebPageSchema({url:e.url||window.location.href,title:e.title||document.title,description:e.description||document.querySelector('meta[name="description"]')?.content,mainEntity:e.mainEntity});switch(t.push(r),e.breadcrumbs&&t.push(this.generateBreadcrumbSchema(e.breadcrumbs)),e.pageType){case"solution":if(e.solutionData){let i=this.generateSoftwareSchema(e.solutionData);if(t.push(i),e.asProduct){let a=this.generateProductSchema({...e.solutionData});t.push(a)}}break;case"article":e.articleData&&t.push(this.generateArticleSchema(e.articleData));break;case"product":e.productData&&t.push(this.generateProductSchema(e.productData));break}if(e.faqs){let i=this.generateFAQSchema(e.faqs);i&&t.push(i)}return{"@context":"https://schema.org","@graph":t}}injectSchema(e){let t=document.querySelector('script[data-schema="fynd"]');t&&t.remove();let r=document.createElement("script");r.type="application/ld+json",r.setAttribute("data-schema","fynd"),r.textContent=JSON.stringify(e,null,2),document.head.appendChild(r)}},c=class{static getConfigFromDataAttributes(){let e=document.body,t={url:"",title:"",description:"",pageType:"default"};switch(t.url=window.location.href,t.title=document.title,t.description=document.querySelector('meta[name="description"]')?.content,t.pageType=e.dataset.pageType||"default",e.dataset.breadcrumbs?t.breadcrumbs=JSON.parse(e.dataset.breadcrumbs):t.breadcrumbs=this.generateBreadcrumbsFromURL(),t.pageType){case"solution":t.solutionData={name:e.dataset.solutionName||document.title,url:t.url,description:t.description||"",features:e.dataset.features?JSON.parse(e.dataset.features):[],audience:e.dataset.audience,price:e.dataset.price,category:e.dataset.category},t.asProduct=e.dataset.asProduct==="true";break;case"article":t.articleData={title:t.title,url:t.url,description:t.description||"",author:e.dataset.author,publishDate:e.dataset.publishDate||new Date().toISOString(),modifyDate:e.dataset.modifyDate,image:e.dataset.image||document.querySelector('meta[property="og:image"]')?.content};break;case"product":t.productData={name:e.dataset.productName||document.title,url:t.url,description:t.description||"",price:e.dataset.price};break}return t.faqs=this.extractFAQsFromPage(),t}static extractFAQsFromPage(){let e=[];return document.querySelectorAll('[fynd-faq-element="wrapper"]').forEach(r=>{let i=r.querySelector('[fynd-faq-element="toggle"]'),a=r.querySelector('[fynd-faq-element="content"]');if(i&&a){let o=i.querySelector('div[class*="title"], div[data-text-style], .accordian-title'),m=o?(o.textContent||"").trim():"",d=a.querySelector('.richtext, [class*="richtext"], .rich-text, [class*="rich-text"]'),u=d?(d.textContent||"").trim():(a.textContent||"").trim();m&&u&&e.push({question:m,answer:u})}}),e.length>0?e:null}static generateBreadcrumbsFromURL(){let e=window.location.pathname.split("/").filter(i=>i),t=[{name:"Home",url:"https://www.fynd.com"}],r="https://www.fynd.com";return e.forEach(i=>{r+=`/${i}`,t.push({name:i.charAt(0).toUpperCase()+i.slice(1).replace("-"," "),url:r})}),t}};document.addEventListener("DOMContentLoaded",function(){let n=new s,e=c.getConfigFromDataAttributes(),t=n.generateSchema(e);n.injectSchema(t)});window.FyndSchema={generator:s,configManager:c};})();
1
+ "use strict";(()=>{var s=class{constructor(){this.baseUrl="https://www.fynd.com",this.organizationData={"@type":"Organization","@id":`${this.baseUrl}#organization`,name:"Fynd",url:this.baseUrl,logo:`${this.baseUrl}/logo.png`,sameAs:["https://www.linkedin.com/company/fynd","https://en.wikipedia.org/wiki/Fynd","https://twitter.com/Fynd"],description:"Fynd is an AI-powered unified commerce platform enabling brands to manage end-to-end retail operations."}}generateWebsiteSchema(){return{"@type":"WebSite","@id":`${this.baseUrl}#website`,url:this.baseUrl,name:"Fynd",description:"AI-powered unified commerce platform",publisher:{"@id":`${this.baseUrl}#organization`},potentialAction:{"@type":"SearchAction",target:{"@type":"EntryPoint",urlTemplate:`${this.baseUrl}/search?q={search_term_string}`},"query-input":"required name=search_term_string"}}}generateBreadcrumbSchema(e){return{"@type":"BreadcrumbList",itemListElement:e.map((t,r)=>({"@type":"ListItem",position:r+1,name:t.name,item:t.url}))}}generateWebPageSchema(e){let t={"@type":"WebPage","@id":e.url,url:e.url,name:e.title,description:e.description||"",isPartOf:{"@id":`${this.baseUrl}#website`}};return e.mainEntity&&(t.mainEntity=e.mainEntity),t}generateSoftwareSchema(e){return{"@type":"SoftwareApplication","@id":`${e.url}#software`,name:e.name,applicationCategory:e.category||"RetailSoftware",operatingSystem:"Web",featureList:e.features||[],offers:{"@type":"Offer",price:e.price||"Contact for Pricing",priceCurrency:"USD",availability:"InStock",url:`${this.baseUrl}/contact`},audience:{"@type":"Audience",audienceType:e.audience||"Business"},url:e.url,description:e.description,manufacturer:{"@id":`${this.baseUrl}#organization`}}}generateProductSchema(e){return{"@type":"Product",name:e.name,url:e.url,description:e.description,brand:{"@id":`${this.baseUrl}#organization`},offers:{"@type":"Offer",price:e.price||"Contact for Pricing",priceCurrency:"USD",availability:"InStock",url:`${this.baseUrl}/contact`}}}generateFAQSchema(e){return!e||e.length===0?null:{"@type":"FAQPage",mainEntity:e.map(t=>({"@type":"Question",name:t.question,acceptedAnswer:{"@type":"Answer",text:t.answer}}))}}generateArticleSchema(e){return{"@type":"Article",headline:e.title,description:e.description,image:e.image,author:{"@type":"Person",name:e.author||"Fynd Team"},publisher:{"@id":`${this.baseUrl}#organization`},datePublished:e.publishDate,dateModified:e.modifyDate||e.publishDate,mainEntityOfPage:{"@type":"WebPage","@id":e.url}}}generateSchema(e){let t=[];t.push(this.organizationData),t.push(this.generateWebsiteSchema());let r=this.generateWebPageSchema({url:e.url||window.location.href,title:e.title||document.title,description:e.description||document.querySelector('meta[name="description"]')?.content,mainEntity:e.mainEntity});switch(t.push(r),e.breadcrumbs&&t.push(this.generateBreadcrumbSchema(e.breadcrumbs)),e.pageType){case"solution":if(e.solutionData){let i=this.generateSoftwareSchema(e.solutionData);if(t.push(i),e.asProduct){let n=this.generateProductSchema({...e.solutionData});t.push(n)}}break;case"article":e.articleData&&t.push(this.generateArticleSchema(e.articleData));break;case"product":e.productData&&t.push(this.generateProductSchema(e.productData));break}if(e.faqs){let i=this.generateFAQSchema(e.faqs);i&&t.push(i)}return{"@context":"https://schema.org","@graph":t}}injectSchema(e){let t=document.querySelector('script[data-schema="fynd"]');t&&t.remove();let r=document.createElement("script");r.type="application/ld+json",r.setAttribute("data-schema","fynd"),r.textContent=JSON.stringify(e,null,2),document.head.appendChild(r)}},c=class{static safeJsonParse(e,t,r){try{return JSON.parse(e)}catch(i){return console.warn(`\u{1F50D} Fynd Schema: Failed to parse JSON${r?` for ${r}`:""}:`,{jsonString:e,error:i instanceof Error?i.message:i}),t}}static getConfigFromDataAttributes(){let e=document.body,t={url:"",title:"",description:"",pageType:"default"};switch(console.log("\u{1F50D} Fynd Schema: Body data attributes:",e.dataset),t.url=window.location.href,t.title=document.title,t.description=document.querySelector('meta[name="description"]')?.content,t.pageType=e.dataset.pageType||"default",e.dataset.breadcrumbs?t.breadcrumbs=this.safeJsonParse(e.dataset.breadcrumbs,this.generateBreadcrumbsFromURL(),"breadcrumbs"):t.breadcrumbs=this.generateBreadcrumbsFromURL(),t.pageType){case"solution":t.solutionData={name:e.dataset.solutionName||document.title,url:t.url,description:t.description||"",features:e.dataset.features?this.safeJsonParse(e.dataset.features,[],"features"):[],audience:e.dataset.audience,price:e.dataset.price,category:e.dataset.category},t.asProduct=e.dataset.asProduct==="true";break;case"article":t.articleData={title:t.title,url:t.url,description:t.description||"",author:e.dataset.author,publishDate:e.dataset.publishDate||new Date().toISOString(),modifyDate:e.dataset.modifyDate,image:e.dataset.image||document.querySelector('meta[property="og:image"]')?.content};break;case"product":t.productData={name:e.dataset.productName||document.title,url:t.url,description:t.description||"",price:e.dataset.price};break}return t.faqs=this.extractFAQsFromPage(),t}static extractFAQsFromPage(){let e=[];return document.querySelectorAll('[fynd-faq-element="wrapper"]').forEach(r=>{let i=r.querySelector('[fynd-faq-element="toggle"]'),n=r.querySelector('[fynd-faq-element="content"]');if(i&&n){let o=i.querySelector('div[class*="title"], div[data-text-style], .accordian-title'),d=o?(o.textContent||"").trim():"",m=n.querySelector('.richtext, [class*="richtext"], .rich-text, [class*="rich-text"]'),u=m?(m.textContent||"").trim():(n.textContent||"").trim();d&&u&&e.push({question:d,answer:u})}}),e.length>0?e:null}static generateBreadcrumbsFromURL(){let e=window.location.pathname.split("/").filter(i=>i),t=[{name:"Home",url:"https://www.fynd.com"}],r="https://www.fynd.com";return e.forEach(i=>{r+=`/${i}`,t.push({name:i.charAt(0).toUpperCase()+i.slice(1).replace("-"," "),url:r})}),t}};document.addEventListener("DOMContentLoaded",function(){console.log("\u{1F50D} Fynd Schema: DOM loaded, initializing schema...");try{let a=new s,e=c.getConfigFromDataAttributes();console.log("\u{1F50D} Fynd Schema: Page config:",e);let t=a.generateSchema(e);console.log("\u{1F50D} Fynd Schema: Generated schema:",t),a.injectSchema(t),console.log("\u{1F50D} Fynd Schema: Schema injected successfully!");let r=document.querySelector('script[data-schema="fynd"]');r?console.log("\u2705 Fynd Schema: Schema script found in DOM:",r):console.error("\u274C Fynd Schema: Schema script NOT found in DOM")}catch(a){console.error("\u274C Fynd Schema: Error during initialization:",a)}});window.FyndSchema={generator:s,configManager:c};})();
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../bin/live-reload.js", "../../src/seo/schema.ts"],
4
+ "sourcesContent": ["// Only enable live reload when running on localhost\nif (\n window.location.hostname === \"localhost\" ||\n window.location.hostname === \"127.0.0.1\"\n) {\n new EventSource(`${SERVE_ORIGIN}/esbuild`).addEventListener(\"change\", () =>\n location.reload()\n );\n} else {\n console.log(\"Live reload disabled: not running on localhost\");\n}\n", "// Dynamic Schema Generator for Fynd.com\n\n// Type definitions for Schema.org entities\ninterface SchemaOrganization {\n \"@type\": \"Organization\";\n \"@id\": string;\n name: string;\n url: string;\n logo: string;\n sameAs: string[];\n description: string;\n}\n\ninterface SchemaWebsite {\n \"@type\": \"WebSite\";\n \"@id\": string;\n url: string;\n name: string;\n description: string;\n publisher: { \"@id\": string };\n potentialAction: {\n \"@type\": \"SearchAction\";\n target: {\n \"@type\": \"EntryPoint\";\n urlTemplate: string;\n };\n \"query-input\": string;\n };\n}\n\ninterface BreadcrumbItem {\n name: string;\n url: string;\n}\n\ninterface SchemaBreadcrumbList {\n \"@type\": \"BreadcrumbList\";\n itemListElement: Array<{\n \"@type\": \"ListItem\";\n position: number;\n name: string;\n item: string;\n }>;\n}\n\ninterface SchemaWebPage {\n \"@type\": \"WebPage\";\n \"@id\": string;\n url: string;\n name: string;\n description: string;\n isPartOf: { \"@id\": string };\n mainEntity?: any;\n}\n\ninterface SolutionData {\n name: string;\n url: string;\n description: string;\n features?: string[];\n audience?: string;\n price?: string;\n category?: string;\n}\n\ninterface SchemaSoftwareApplication {\n \"@type\": \"SoftwareApplication\";\n \"@id\": string;\n name: string;\n applicationCategory: string;\n operatingSystem: string;\n featureList: string[];\n offers: {\n \"@type\": \"Offer\";\n price: string;\n priceCurrency: string;\n availability: string;\n url: string;\n };\n audience: {\n \"@type\": \"Audience\";\n audienceType: string;\n };\n url: string;\n description: string;\n manufacturer: { \"@id\": string };\n}\n\ninterface ProductData {\n name: string;\n url: string;\n description: string;\n price?: string;\n}\n\ninterface SchemaProduct {\n \"@type\": \"Product\";\n name: string;\n url: string;\n description: string;\n brand: { \"@id\": string };\n offers: {\n \"@type\": \"Offer\";\n price: string;\n priceCurrency: string;\n availability: string;\n url: string;\n };\n}\n\ninterface FAQItem {\n question: string;\n answer: string;\n}\n\ninterface SchemaFAQPage {\n \"@type\": \"FAQPage\";\n mainEntity: Array<{\n \"@type\": \"Question\";\n name: string;\n acceptedAnswer: {\n \"@type\": \"Answer\";\n text: string;\n };\n }>;\n}\n\ninterface ArticleData {\n title: string;\n url: string;\n description: string;\n author?: string;\n publishDate: string;\n modifyDate?: string;\n image?: string;\n}\n\ninterface SchemaArticle {\n \"@type\": \"Article\";\n headline: string;\n description: string;\n image?: string;\n author: {\n \"@type\": \"Person\";\n name: string;\n };\n publisher: { \"@id\": string };\n datePublished: string;\n dateModified: string;\n mainEntityOfPage: {\n \"@type\": \"WebPage\";\n \"@id\": string;\n };\n}\n\ninterface PageConfig {\n url: string;\n title: string;\n description?: string;\n pageType: string;\n breadcrumbs?: BreadcrumbItem[];\n solutionData?: SolutionData;\n asProduct?: boolean;\n articleData?: ArticleData;\n productData?: ProductData;\n faqs?: FAQItem[] | null;\n mainEntity?: any;\n}\n\ninterface SchemaGraph {\n \"@context\": \"https://schema.org\";\n \"@graph\": any[];\n}\n\n// Extend Window interface for FyndSchema\ndeclare global {\n interface Window {\n FyndSchema: {\n generator: typeof FyndSchemaGenerator;\n configManager: typeof PageConfigManager;\n };\n }\n}\n\nclass FyndSchemaGenerator {\n private baseUrl: string;\n private organizationData: SchemaOrganization;\n\n constructor() {\n this.baseUrl = \"https://www.fynd.com\";\n this.organizationData = {\n \"@type\": \"Organization\",\n \"@id\": `${this.baseUrl}#organization`,\n name: \"Fynd\",\n url: this.baseUrl,\n logo: `${this.baseUrl}/logo.png`,\n sameAs: [\n \"https://www.linkedin.com/company/fynd\",\n \"https://en.wikipedia.org/wiki/Fynd\",\n \"https://twitter.com/Fynd\",\n ],\n description:\n \"Fynd is an AI-powered unified commerce platform enabling brands to manage end-to-end retail operations.\",\n };\n }\n\n // Generate base website schema\n generateWebsiteSchema(): SchemaWebsite {\n return {\n \"@type\": \"WebSite\",\n \"@id\": `${this.baseUrl}#website`,\n url: this.baseUrl,\n name: \"Fynd\",\n description: \"AI-powered unified commerce platform\",\n publisher: { \"@id\": `${this.baseUrl}#organization` },\n potentialAction: {\n \"@type\": \"SearchAction\",\n target: {\n \"@type\": \"EntryPoint\",\n urlTemplate: `${this.baseUrl}/search?q={search_term_string}`,\n },\n \"query-input\": \"required name=search_term_string\",\n },\n };\n }\n\n // Generate breadcrumb schema\n generateBreadcrumbSchema(breadcrumbs: BreadcrumbItem[]): SchemaBreadcrumbList {\n return {\n \"@type\": \"BreadcrumbList\",\n itemListElement: breadcrumbs.map((item, index) => ({\n \"@type\": \"ListItem\",\n position: index + 1,\n name: item.name,\n item: item.url,\n })),\n };\n }\n\n // Generate WebPage schema\n generateWebPageSchema(pageData: {\n url: string;\n title: string;\n description?: string;\n mainEntity?: any;\n }): SchemaWebPage {\n const schema: SchemaWebPage = {\n \"@type\": \"WebPage\",\n \"@id\": pageData.url,\n url: pageData.url,\n name: pageData.title,\n description: pageData.description || \"\",\n isPartOf: { \"@id\": `${this.baseUrl}#website` },\n };\n\n if (pageData.mainEntity) {\n schema.mainEntity = pageData.mainEntity;\n }\n\n return schema;\n }\n\n // Generate SoftwareApplication schema for solution pages\n generateSoftwareSchema(solutionData: SolutionData): SchemaSoftwareApplication {\n return {\n \"@type\": \"SoftwareApplication\",\n \"@id\": `${solutionData.url}#software`,\n name: solutionData.name,\n applicationCategory: solutionData.category || \"RetailSoftware\",\n operatingSystem: \"Web\",\n featureList: solutionData.features || [],\n offers: {\n \"@type\": \"Offer\",\n price: solutionData.price || \"Contact for Pricing\",\n priceCurrency: \"USD\",\n availability: \"InStock\",\n url: `${this.baseUrl}/contact`,\n },\n audience: {\n \"@type\": \"Audience\",\n audienceType: solutionData.audience || \"Business\",\n },\n url: solutionData.url,\n description: solutionData.description,\n manufacturer: { \"@id\": `${this.baseUrl}#organization` },\n };\n }\n\n // Generate Product schema\n generateProductSchema(productData: ProductData): SchemaProduct {\n return {\n \"@type\": \"Product\",\n name: productData.name,\n url: productData.url,\n description: productData.description,\n brand: { \"@id\": `${this.baseUrl}#organization` },\n offers: {\n \"@type\": \"Offer\",\n price: productData.price || \"Contact for Pricing\",\n priceCurrency: \"USD\",\n availability: \"InStock\",\n url: `${this.baseUrl}/contact`,\n },\n };\n }\n\n // Generate FAQ schema\n generateFAQSchema(faqs: FAQItem[]): SchemaFAQPage | null {\n if (!faqs || faqs.length === 0) return null;\n\n return {\n \"@type\": \"FAQPage\",\n mainEntity: faqs.map((faq) => ({\n \"@type\": \"Question\",\n name: faq.question,\n acceptedAnswer: {\n \"@type\": \"Answer\",\n text: faq.answer,\n },\n })),\n };\n }\n\n // Generate Article schema for blog posts\n generateArticleSchema(articleData: ArticleData): SchemaArticle {\n return {\n \"@type\": \"Article\",\n headline: articleData.title,\n description: articleData.description,\n image: articleData.image,\n author: {\n \"@type\": \"Person\",\n name: articleData.author || \"Fynd Team\",\n },\n publisher: { \"@id\": `${this.baseUrl}#organization` },\n datePublished: articleData.publishDate,\n dateModified: articleData.modifyDate || articleData.publishDate,\n mainEntityOfPage: {\n \"@type\": \"WebPage\",\n \"@id\": articleData.url,\n },\n };\n }\n\n // Main method to generate complete schema based on page type\n generateSchema(pageConfig: PageConfig): SchemaGraph {\n const graph: any[] = [];\n\n // Always include organization\n graph.push(this.organizationData);\n\n // Always include website\n graph.push(this.generateWebsiteSchema());\n\n // Add webpage schema\n const webPageSchema = this.generateWebPageSchema({\n url: pageConfig.url || window.location.href,\n title: pageConfig.title || document.title,\n description:\n pageConfig.description ||\n (document.querySelector('meta[name=\"description\"]') as HTMLMetaElement)?.content,\n mainEntity: pageConfig.mainEntity,\n });\n graph.push(webPageSchema);\n\n // Add breadcrumbs if provided\n if (pageConfig.breadcrumbs) {\n graph.push(this.generateBreadcrumbSchema(pageConfig.breadcrumbs));\n }\n\n // Page type specific schemas\n switch (pageConfig.pageType) {\n case \"solution\":\n if (pageConfig.solutionData) {\n const softwareSchema = this.generateSoftwareSchema(\n pageConfig.solutionData\n );\n graph.push(softwareSchema);\n\n if (pageConfig.asProduct) {\n const productSchema = this.generateProductSchema({\n ...pageConfig.solutionData,\n });\n graph.push(productSchema);\n }\n }\n break;\n\n case \"article\":\n if (pageConfig.articleData) {\n graph.push(this.generateArticleSchema(pageConfig.articleData));\n }\n break;\n\n case \"product\":\n if (pageConfig.productData) {\n graph.push(this.generateProductSchema(pageConfig.productData));\n }\n break;\n }\n\n // Add FAQ if provided\n if (pageConfig.faqs) {\n const faqSchema = this.generateFAQSchema(pageConfig.faqs);\n if (faqSchema) graph.push(faqSchema);\n }\n\n return {\n \"@context\": \"https://schema.org\",\n \"@graph\": graph,\n };\n }\n\n // Inject schema into page\n injectSchema(schema: SchemaGraph): void {\n // Remove existing schema script if any\n const existingScript = document.querySelector('script[data-schema=\"fynd\"]');\n if (existingScript) {\n existingScript.remove();\n }\n\n // Create and inject new schema script\n const script = document.createElement(\"script\");\n script.type = \"application/ld+json\";\n script.setAttribute(\"data-schema\", \"fynd\");\n script.textContent = JSON.stringify(schema, null, 2);\n document.head.appendChild(script);\n }\n}\n\n// Page Configuration Manager\nclass PageConfigManager {\n // Helper method to safely parse JSON\n private static safeJsonParse<T>(jsonString: string, fallback: T, context?: string): T {\n try {\n return JSON.parse(jsonString);\n } catch (error) {\n console.warn(`\uD83D\uDD0D Fynd Schema: Failed to parse JSON${context ? ` for ${context}` : ''}:`, {\n jsonString,\n error: error instanceof Error ? error.message : error\n });\n return fallback;\n }\n }\n\n static getConfigFromDataAttributes(): PageConfig {\n const body = document.body;\n const config: PageConfig = {\n url: \"\",\n title: \"\",\n description: \"\",\n pageType: \"default\",\n };\n\n // Debug: Log all data attributes\n console.log(\"\uD83D\uDD0D Fynd Schema: Body data attributes:\", body.dataset);\n\n // Get basic page info\n config.url = window.location.href;\n config.title = document.title;\n config.description = (document.querySelector(\n 'meta[name=\"description\"]'\n ) as HTMLMetaElement)?.content;\n\n // Get page type from data attribute\n config.pageType = body.dataset.pageType || \"default\";\n\n // Get breadcrumbs from data attribute or generate from URL\n if (body.dataset.breadcrumbs) {\n config.breadcrumbs = this.safeJsonParse(\n body.dataset.breadcrumbs, \n this.generateBreadcrumbsFromURL(), \n 'breadcrumbs'\n );\n } else {\n config.breadcrumbs = this.generateBreadcrumbsFromURL();\n }\n\n // Page type specific configurations\n switch (config.pageType) {\n case \"solution\":\n config.solutionData = {\n name: body.dataset.solutionName || document.title,\n url: config.url,\n description: config.description || \"\",\n features: body.dataset.features\n ? this.safeJsonParse(body.dataset.features, [], 'features')\n : [],\n audience: body.dataset.audience,\n price: body.dataset.price,\n category: body.dataset.category,\n };\n config.asProduct = body.dataset.asProduct === \"true\";\n break;\n\n case \"article\":\n config.articleData = {\n title: config.title,\n url: config.url,\n description: config.description || \"\",\n author: body.dataset.author,\n publishDate: body.dataset.publishDate || new Date().toISOString(),\n modifyDate: body.dataset.modifyDate,\n image:\n body.dataset.image ||\n (document.querySelector('meta[property=\"og:image\"]') as HTMLMetaElement)?.content,\n };\n break;\n\n case \"product\":\n config.productData = {\n name: body.dataset.productName || document.title,\n url: config.url,\n description: config.description || \"\",\n price: body.dataset.price,\n };\n break;\n }\n\n // Auto-detect FAQs from page content\n config.faqs = this.extractFAQsFromPage();\n\n return config;\n }\n\n static extractFAQsFromPage(): FAQItem[] | null {\n const faqs: FAQItem[] = [];\n\n // Look for Fynd FAQ structure using custom attributes\n const faqWrappers = document.querySelectorAll(\n '[fynd-faq-element=\"wrapper\"]'\n );\n\n faqWrappers.forEach((wrapper) => {\n // Find the toggle element (contains the question)\n const toggle = wrapper.querySelector('[fynd-faq-element=\"toggle\"]');\n // Find the content element (contains the answer)\n const content = wrapper.querySelector('[fynd-faq-element=\"content\"]');\n\n if (toggle && content) {\n // Extract question from the toggle div\n const questionDiv = toggle.querySelector(\n 'div[class*=\"title\"], div[data-text-style], .accordian-title'\n );\n const questionText = questionDiv ? (questionDiv.textContent || \"\").trim() : \"\";\n\n // Extract answer from the content div - look for richtext\n const richTextDiv = content.querySelector(\n '.richtext, [class*=\"richtext\"], .rich-text, [class*=\"rich-text\"]'\n );\n const answerText = richTextDiv\n ? (richTextDiv.textContent || \"\").trim()\n : (content.textContent || \"\").trim();\n\n if (questionText && answerText) {\n faqs.push({\n question: questionText,\n answer: answerText,\n });\n }\n }\n });\n\n return faqs.length > 0 ? faqs : null;\n }\n\n static generateBreadcrumbsFromURL(): BreadcrumbItem[] {\n const pathSegments = window.location.pathname\n .split(\"/\")\n .filter((segment) => segment);\n const breadcrumbs: BreadcrumbItem[] = [{ name: \"Home\", url: \"https://www.fynd.com\" }];\n\n let currentPath = \"https://www.fynd.com\";\n pathSegments.forEach((segment) => {\n currentPath += `/${segment}`;\n breadcrumbs.push({\n name:\n segment.charAt(0).toUpperCase() + segment.slice(1).replace(\"-\", \" \"),\n url: currentPath,\n });\n });\n\n return breadcrumbs;\n }\n}\n\n// Auto-initialize when DOM is ready\ndocument.addEventListener(\"DOMContentLoaded\", function () {\n console.log(\"\uD83D\uDD0D Fynd Schema: DOM loaded, initializing schema...\");\n \n try {\n const schemaGenerator = new FyndSchemaGenerator();\n const pageConfig = PageConfigManager.getConfigFromDataAttributes();\n \n console.log(\"\uD83D\uDD0D Fynd Schema: Page config:\", pageConfig);\n \n const schema = schemaGenerator.generateSchema(pageConfig);\n \n console.log(\"\uD83D\uDD0D Fynd Schema: Generated schema:\", schema);\n \n schemaGenerator.injectSchema(schema);\n \n console.log(\"\uD83D\uDD0D Fynd Schema: Schema injected successfully!\");\n \n // Verify injection\n const injectedScript = document.querySelector('script[data-schema=\"fynd\"]');\n if (injectedScript) {\n console.log(\"\u2705 Fynd Schema: Schema script found in DOM:\", injectedScript);\n } else {\n console.error(\"\u274C Fynd Schema: Schema script NOT found in DOM\");\n }\n \n } catch (error) {\n console.error(\"\u274C Fynd Schema: Error during initialization:\", error);\n }\n});\n\n// Export for manual usage\n(window as any).FyndSchema = {\n generator: FyndSchemaGenerator,\n configManager: PageConfigManager,\n};\n\n// Export to make this file a module (required for global declarations)\nexport {};\n "],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@fynd-design-engineering/fynd-one-v2",
3
- "version": "3.1.23",
3
+ "version": "3.1.24",
4
4
  "description": "Updated CDN for fynd.com",
5
5
  "homepage": "https://github.com/Fynd-Design-Engineering/Fynd-Utils/blob/main/README.md",
6
6
  "license": "ISC",