// MyGemma New Arrivals PLP — side-by-side: MyGemma today (newest-first) vs With Malachyte (personalized)

// =========================================================================
// Top-level: side-by-side comparison
// =========================================================================
function SideBySidePLP({ state, setState }) {
  const persona = window.PERSONAS.find(p => p.id === state.persona) || window.PERSONAS[0];
  const favorites = state.favorites || [];

  const switchPersona = (id) => setState(s => ({ ...s, persona: id, favorites: [] }));

  const toggleFav = (id) => {
    setState(s => {
      const favs = s.favorites || [];
      const next = favs.includes(id) ? favs.filter(x => x !== id) : [...favs, id];
      return { ...s, favorites: next };
    });
  };

  return (
    <div className="sbs-shell">
      <PersonaBar persona={persona} onChange={switchPersona} favoriteCount={favorites.length} />

      <div className="sbs-grid">
        <PLPColumn mode="alpha" state={state} persona={persona} favorites={favorites} onFav={toggleFav} />
        <PLPColumn mode="malachyte" state={state} persona={persona} favorites={favorites} onFav={toggleFav} />
      </div>
    </div>
  );
}

// =========================================================================
// One side of the side-by-side
// =========================================================================
function PLPColumn({ mode, state, persona, favorites, onFav }) {
  const newPool = window.PRODUCTS.filter(p => p.inNewPlp);
  const favWeights = window.buildFavWeights ? window.buildFavWeights(favorites) : null;
  const ranked = mode === 'malachyte'
    ? window.rankProducts(newPool, persona, favWeights)
    : window.defaultOrder(newPool);

  const handleImgErr = (e) => { e.target.src = window.PRODUCT_FALLBACK; };
  const isMal = mode === 'malachyte';

  return (
    <div className={`sbs-col sbs-col--${mode}`}>
      <div className="sbs-col__head">
        <span className="sbs-col__tag">{isMal ? 'AFTER' : 'BEFORE'}</span>
        {isMal
          ? <img src="assets/malachyte-logo-gradient.png" alt="Malachyte" className="sbs-col__logo sbs-col__logo--mal" />
          : <img src="assets/mygemma-logo.png" alt="MyGemma" className="sbs-col__logo sbs-col__logo--mg" />}
        <span className="sbs-col__caption">{isMal ? 'With Malachyte' : 'MyGemma today'}</span>
      </div>

      <div className="sbs-col__viewport">
        <div className="demo-urlbar">
          <div className="demo-urlbar__dots"><span /><span /><span /></div>
          <div className="demo-urlbar__url">
            mygemma.com/collections/new{isMal ? ' · personalized by malachyte' : ''}
          </div>
        </div>

        <WihaChrome />

        <div className="wiha-plp-root">
          <div className="wiha-crumbs">
            <a>Home</a><span className="sep">/</span><span className="current">New In</span>
          </div>

          <h1 className="wiha-plp-title">New Arrivals</h1>

          <div className="sbs-toolbar">
            <span className="sbs-toolbar__count">{ranked.length} of 572 pieces</span>
            <span className="sbs-toolbar__static">{isMal ? 'Sort · Recommended for you' : 'Sort · Newest first'}</span>
          </div>

          <div className={`wiha-grid-wrap wiha-grid-wrap--${mode}`}>
            <div className="wiha-grid-railbar">
              <span className="wiha-grid-railbar__dot" />
              {isMal
                ? <>PERSONALIZED · RANKED FOR <b>{persona.userId}</b></>
                : <>STATIC · NEWEST-FIRST · NO RE-RANKING ON FAVORITES</>}
            </div>
            <div className="wiha-grid sbs-grid-inner">
              {ranked.map((p, i) => (
                <ProductCard
                  key={p.id}
                  product={p}
                  index={i}
                  mode={mode}
                  persona={persona}
                  favWeights={favWeights}
                  isFav={favorites.includes(p.id)}
                  onFav={onFav}
                  onImgErr={handleImgErr}
                />
              ))}
            </div>
          </div>
        </div>
      </div>
    </div>
  );
}

// =========================================================================
// Product card
// =========================================================================
function ProductCard({ product, index, mode, persona, favWeights, isFav, onFav, onImgErr }) {
  const isMal = mode === 'malachyte';
  const reason = isMal ? reasonFor(product, persona, favWeights) : null;
  const showRank = isMal && index < 8;

  return (
    <div className={`wiha-card ${showRank ? 'is-ranked' : ''}`}>
      {showRank && <div className="wiha-rank">#{index + 1}</div>}

      {isMal && (
        <button
          className={`wiha-fav ${isFav ? 'wiha-fav--on' : ''}`}
          onClick={(e) => { e.preventDefault(); onFav(product.id); }}
          aria-label={isFav ? 'Remove from saved' : 'Save'}
        >
          <svg viewBox="0 0 24 24" width="15" height="15">
            <path d="M12 21s-7.5-4.5-9.5-9.2C1 8.4 3 5 6.4 5c2 0 3.4 1.1 4.4 2.5l1.2 1.6 1.2-1.6C14.2 6.1 15.6 5 17.6 5 21 5 23 8.4 21.5 11.8 19.5 16.5 12 21 12 21z"
              fill={isFav ? '#8A2F2A' : 'none'} stroke={isFav ? '#8A2F2A' : '#1F1B17'} strokeWidth="1.5" strokeLinejoin="round" />
          </svg>
        </button>
      )}

      <div className="wiha-card__img">
        <img src={product.img} alt={product.name} onError={onImgErr} loading="lazy" />
      </div>

      <div className="mg-card__brand">{product.brand}</div>
      <h3 className="wiha-card__name">{product.name}</h3>

      {isMal && reason && (
        <span className={`wiha-why ${reason.kind === 'anti' ? 'wiha-why--anti' : ''}`}>
          <span className="wiha-why__dot" />{reason.text}
        </span>
      )}

      <div className="wiha-card__price-row">
        <div>
          <span className="wiha-card__price">${product.price.toLocaleString()}</span>
          {product.orig && <span className="wiha-card__orig">${product.orig.toLocaleString()}</span>}
        </div>
        <span className="wiha-card__sku">#{product.sku}</span>
      </div>
    </div>
  );
}

// =========================================================================
// Persona bar — compact, sits above both columns
// =========================================================================
function PersonaBar({ persona, onChange, favoriteCount }) {
  const [scrolled, setScrolled] = React.useState(false);

  React.useEffect(() => {
    const onScroll = () => setScrolled(window.scrollY > 220);
    window.addEventListener('scroll', onScroll, { passive: true });
    onScroll();
    return () => window.removeEventListener('scroll', onScroll);
  }, []);

  return (
    <>
      <div className="wiha-persona-bar">
        <div className="wiha-persona-bar__id">
          <span className="wiha-persona-eye">Visitor</span>
          <span className="wiha-persona-userid">{persona.userId}</span>
          {favoriteCount > 0 && (
            <span className="wiha-rank-chip" style={{ marginTop: 6 }}>
              <span className="wiha-rank-chip__dot" />
              {favoriteCount} ♥ → re-ranking
            </span>
          )}
        </div>

        <PortraitWithSignals persona={persona} />

        <div className="wiha-persona-bar__switch">
          <label>switch visitor</label>
          <select className="wiha-persona-bar__select" value={persona.id} onChange={(e) => onChange(e.target.value)}>
            {window.PERSONAS.map(p => (
              <option key={p.id} value={p.id}>{p.userId} · {p.name.split('·')[0].trim()}</option>
            ))}
          </select>
        </div>
      </div>

      <div className={`wiha-persona-pill ${scrolled ? 'is-visible' : ''}`}>
        <div className="wiha-persona-pill__avatar">
          <img src={persona.img} alt={persona.name} />
        </div>
        <div className="wiha-persona-pill__meta">
          <span className="wiha-persona-pill__eye">Visitor</span>
          <span className="wiha-persona-pill__id">{persona.userId}</span>
        </div>
        <div className="wiha-persona-pill__chips">
          {(persona.signals || []).slice(0, 3).map((s, i) => (
            <span key={i} className={`wiha-persona-pill__chip wiha-persona-pill__chip--${s.tone || 'amber'}`}>
              {s.label}
            </span>
          ))}
        </div>
        <select
          className="wiha-persona-pill__select"
          value={persona.id}
          onChange={(e) => onChange(e.target.value)}
          title="Switch visitor"
        >
          {window.PERSONAS.map(p => (
            <option key={p.id} value={p.id}>{p.userId}</option>
          ))}
        </select>
      </div>
    </>
  );
}

// =========================================================================
// Why-this-product reason builder
// =========================================================================
function reasonFor(product, persona, favWeights) {
  if (favWeights) {
    const top = product.cats
      .map(c => ({ c, v: favWeights[c] || 0 }))
      .filter(x => x.v >= 0.5)
      .sort((a, b) => b.v - a.v)[0];
    if (top) return { text: `Matches your saved ${prettyCat(top.c)}`, kind: 'fav' };
  }
  const w = persona.weights;
  const top = product.cats
    .map(c => ({ c, v: w[c] || 0 }))
    .filter(x => x.v > 0.5)
    .sort((a, b) => b.v - a.v)[0];
  if (top) return { text: prettyCat(top.c), kind: 'fav' };

  const neg = product.cats
    .map(c => ({ c, v: w[c] || 0 }))
    .filter(x => x.v < -0.4)
    .sort((a, b) => a.v - b.v)[0];
  if (neg) return { text: 'Off-taste for this visitor', kind: 'anti' };
  return null;
}

function prettyCat(c) {
  const m = {
    hermes: 'Hermès affinity', chanel: 'Chanel affinity', lv: 'Louis Vuitton', gucci: 'Gucci',
    tiffany: 'Tiffany & Co.', cartier: 'Cartier', vca: 'Van Cleef & Arpels', 'david-yurman': 'David Yurman',
    bottega: 'Bottega Veneta', dior: 'Dior', ysl: 'Saint Laurent', fendi: 'Fendi', bvlgari: 'BVLGARI',
    'quiet-luxury': 'quiet-luxury house', classic: 'timeless classic', monogram: 'monogram / logo',
    logo: 'logo-forward', trend: 'trend-forward', statement: 'statement piece',
    'fine-jewelry': 'fine jewelry', jewelry: 'jewelry', ring: 'rings', bracelet: 'bracelets',
    necklace: 'necklaces', earrings: 'earrings', gold: 'gold', 'rose-gold': 'rose gold', diamond: 'diamonds',
    bag: 'handbags', tote: 'totes', shoulder: 'shoulder bags', crossbody: 'crossbody', clutch: 'clutches',
    'top-handle': 'top-handle bags', backpack: 'backpacks', 'belt-bag': 'belt bags',
    slg: 'small leather goods', accessory: 'accessories', watch: 'watches', charm: 'charms',
    neutral: 'neutral palette', 'neutral-tone': 'neutral tones', black: 'black', brown: 'brown',
    white: 'white', multicolor: 'multicolour', blue: 'blue', pink: 'pink', red: 'red', grey: 'grey',
    leather: 'leather', canvas: 'coated canvas', gift: 'giftable', engagement: 'engagement',
    investment: 'investment tier', premium: '$3k–6k tier', mid: '$1.5k–3k tier',
    accessible: 'under $1.5k', entry: 'under $500',
  };
  return m[c] || c;
}

Object.assign(window, { SideBySidePLP });
