import { MODELS } from '$lib'
import { format_train_set } from '$lib/metrics'
import type { ModelData } from '$lib/types'
import pkg from '$site/package.json'
import { format_num } from 'matterviz'

export const prerender = true

// Ensure homepage URL ends with a slash for consistent path joining
const base_url = pkg.homepage.endsWith(`/`) ? pkg.homepage : `${pkg.homepage}/`

// Formats model data as XML for RSS feed
function format_model_for_rss(model: ModelData): string {
  // Extract metrics from the 'full_test_set' or fallback to first available discovery set
  const discovery_metrics = model.metrics?.discovery?.full_test_set ||
    (model.metrics?.discovery && Object.values(model.metrics.discovery)[0])

  const training_set = format_train_set(model.training_set, model)
  // Remove HTML tags for plain text display
  const clean_training_set = training_set.replace(/<[^>]*>/g, ``)

  const metrics_text = discovery_metrics
    ? Object.entries(discovery_metrics)
      .filter(([_key, value]) => typeof value === `number`)
      .map(([key, value]) => `${key}: ${format_num(value as number)}`)
      .join(`,<br>&nbsp;&nbsp;`)
    : `No metrics available`

  const authors_text = model.authors
    ? model.authors
      .map((author) => {
        const parts = []
        parts.push(author.name)
        if (author.affiliation) parts.push(`(${author.affiliation})`)
        return parts.join(` `)
      })
      .join(`, `)
    : `Unknown authors`

  const model_type = model.model_type
    ? `<p><strong>Model Type:</strong> ${model.model_type}</p>`
    : ``
  const hyperparams = model.hyperparams
    ? `<p><strong>Key Hyperparameters:</strong><br>&nbsp;&nbsp;${
      Object.entries(
        model.hyperparams,
      )
        .filter(([key]) => !key.includes(`_`))
        .map(([key, value]) => `${key}: ${value}`)
        .join(`,<br>&nbsp;&nbsp;`)
    }</p>`
    : ``
  const license_info = model.license
    ? `<p><strong>License:</strong> ${model.license.code || model.license}</p>`
    : ``
  const date_published = model.date_published
    ? `<p><strong>Date Published:</strong> ${model.date_published}</p>`
    : ``

  return `
    <h2>${model.model_name}</h2>
    <p><strong>Metrics:</strong><br>&nbsp;&nbsp;${metrics_text}</p>
    <p><strong>Parameters:</strong> ${format_num(model.model_params)}</p>
    ${model_type}
    <p><strong>Targets:</strong> ${model.targets}</p>
    <p><strong>Training Set:</strong> ${clean_training_set}</p>
    ${hyperparams}
    ${license_info}
    <p><strong>Date Added:</strong> ${model.date_added}</p>
    ${date_published}
    <p><strong>Authors:</strong> ${authors_text}</p>
    <p>
      <a href="${base_url}models/${model.model_key}">View model details</a>
      ${model.paper ? `| <a href="${model.paper}">Read paper</a>` : ``}
      ${model.repo ? `| <a href="${model.repo}">View code repository</a>` : ``}
    </p>
  `.trim()
}

// Generates an RSS feed of all models
export function GET() {
  // Sort models by date added (newest first)
  const sorted_models = [...MODELS].sort((m1, m2) => {
    return new Date(m2.date_added).getTime() - new Date(m1.date_added).getTime()
  })
  const headers = { 'Content-Type': `application/xml` }
  const rss_feed_url = `${base_url}rss.xml`

  const xml = `
    <rss xmlns:atom="http://www.w3.org/2005/Atom" version="2.0">
      <channel>
        <title>${pkg.name}</title>
        <description>${pkg.description}</description>
        <link>${pkg.homepage}</link>
        <atom:link href="${rss_feed_url}" rel="self" type="application/rss+xml"/>
        ${
    sorted_models.map((model) => `
            <item>
              <title>${model.model_name}</title>
              <description><![CDATA[${format_model_for_rss(model)}]]></description>
              <link>${base_url}models/${model.model_key}</link>
              <guid isPermaLink="true">${base_url}models/${model.model_key}</guid>
              <pubDate>${new Date(model.date_added).toUTCString()}</pubDate>
            </item>
          `).join(``)
  }
      </channel>
    </rss>
  `.trim()

  return new Response(xml, { headers })
}
