<script lang="ts">
  import { browser } from '$app/environment'
  import BarElementCounts from '$figs/bar-element-counts-mp+wbm-normalized=False.svelte'
  import BarElementCountsNormalized from '$figs/bar-element-counts-mp+wbm-normalized=True.svelte'
  import { PtableInset } from '$lib'
  import type { ChemicalElement } from 'matterviz'
  import { ColorScaleSelect, PeriodicTable, TableInset } from 'matterviz'
  import type { D3InterpolateName } from 'matterviz/colors'
  import { RadioButtons, Toggle } from 'svelte-multiselect'

  const elem_counts = $state(
    import.meta.glob(`../wbm-element-counts-*=*.json`, {
      eager: true,
      import: `default`,
    }),
  )
  for (const key of Object.keys(elem_counts)) {
    const new_key = key?.split(`-`).at(-1)?.split(`.`)[0] as string
    elem_counts[new_key] = elem_counts[key]
  }

  let arity_keys = Object.keys(elem_counts).filter((k) => k.startsWith(`arity=`))
  let batch_keys = Object.keys(elem_counts).filter((k) => k.startsWith(`batch=`))
  let log = $state(false) // log color scale
  let filter = $state(arity_keys[0])
  let color_scale = $state<D3InterpolateName[]>([`interpolateViridis`])
  let active_element: ChemicalElement | null = $state(null)
  let active_counts = $derived(elem_counts[filter])
  let normalized_bar_counts: boolean = $state(false)

  const style = `display: flex; place-items: center; place-content: center;`

  const radio_style = `display: inline-flex; margin: 2pt 8pt; border-radius: 3pt;`
</script>

<h1>Too Much Information</h1>

<p>Stuff that didn't make the cut into the main page describing the WBM test set.</p>

<h2>WBM Element Counts for <code>{filter}</code></h2>

<p>
  Filter WBM element counts by composition<strong>arity</strong> (how many elements in the
  formula) or <strong>batch index</strong> (which iteration of elemental substitution the
  structure was generated in).
</p>

<ColorScaleSelect bind:selected={color_scale} />

<form>
  <span>
    number of elements
    <RadioButtons style={radio_style} options={arity_keys} bind:selected={filter}>
      {#snippet children(
        { option, active }: { option: string; active: boolean },
      )}
        <strong class:active>{option.split(`=`).at(-1)}</strong>
      {/snippet}
    </RadioButtons>
  </span>
  <span>
    batch index
    <RadioButtons style={radio_style} options={batch_keys} bind:selected={filter}>
      {#snippet children(
        { option, active }: { option: string; active: boolean },
      )}
        <strong class:active>{option.split(`=`).at(-1)}</strong>
      {/snippet}
    </RadioButtons>
  </span>
</form>

<PeriodicTable
  heatmap_values={active_counts}
  {log}
  color_scale={color_scale[0]}
  bind:active_element
  show_photo={false}
  missing_color="rgba(255,255,255,0.3)"
>
  {#snippet inset()}
    <TableInset>
      <PtableInset element={active_element} elem_counts={active_counts} />
      <span {style}>Log color scale<Toggle bind:checked={log} /></span>
    </TableInset>
  {/snippet}
</PeriodicTable>

<h2>Element Counts</h2>

<label>
  Normalize by data set size
  <input type="checkbox" bind:checked={normalized_bar_counts} />
</label>

{#if browser}
  {#if normalized_bar_counts}
    <BarElementCountsNormalized />
  {:else}
    <BarElementCounts />
  {/if}
{/if}

<style>
  span {
    display: flex;
    gap: 1ex;
    place-items: center;
  }
  form {
    display: flex;
    gap: 5cqw;
    place-content: center;
  }
  form > span strong {
    background-color: var(--nav-bg);
    padding: 3pt 4pt;
  }
  form > span strong.active {
    background-color: var(--btn-bg);
  }
  label {
    display: flex;
    gap: 1ex;
    place-content: center;
    place-items: center;
  }
</style>
