- Split address into street, postal code, city (sortable) - Add billing postal code/city fields - Add e-invoice address and operator fields - Add trivia stats (top postal code, top speed, avg price) - Improved layout with stat cards grid and max-width container - Sticky header, modal animations, search icon - Auto-backup on every save (keeps last 30 backups) - Footer added Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
241 lines
10 KiB
HTML
241 lines
10 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="fi">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
<title>CuituNet Intra - Asiakashallinta</title>
|
|
<link rel="stylesheet" href="style.css">
|
|
</head>
|
|
<body>
|
|
<!-- Login -->
|
|
<div id="login-screen" class="login-screen">
|
|
<div class="login-box">
|
|
<h1>🔒 CuituNet Intra</h1>
|
|
<p>Kirjaudu sisään</p>
|
|
<form id="login-form">
|
|
<input type="password" id="login-password" placeholder="Salasana" required autofocus>
|
|
<button type="submit">Kirjaudu</button>
|
|
</form>
|
|
<div id="login-error" class="error" style="display:none"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Dashboard -->
|
|
<div id="dashboard" style="display:none">
|
|
<header>
|
|
<div class="header-left">
|
|
<div class="header-brand">
|
|
<span class="brand-icon">⚡</span>
|
|
<div>
|
|
<h1>CuituNet Intra</h1>
|
|
<span class="subtitle">Kuituasiakkaiden hallinta</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="header-right">
|
|
<button id="btn-add" class="btn-primary">+ Lisää asiakas</button>
|
|
<button id="btn-logout" class="btn-secondary">Kirjaudu ulos</button>
|
|
</div>
|
|
</header>
|
|
|
|
<div class="main-container">
|
|
<!-- Stat-kortit -->
|
|
<div class="stats-row">
|
|
<div class="stat-card">
|
|
<div class="stat-label">Asiakkaita</div>
|
|
<div class="stat-value" id="stat-count">0</div>
|
|
</div>
|
|
<div class="stat-card">
|
|
<div class="stat-label">Laskutus / kk</div>
|
|
<div class="stat-value stat-highlight" id="stat-billing">0,00 €</div>
|
|
</div>
|
|
<div class="stat-card">
|
|
<div class="stat-label">Laskutus / vuosi</div>
|
|
<div class="stat-value" id="stat-yearly">0,00 €</div>
|
|
</div>
|
|
<div class="stat-card stat-trivia">
|
|
<div class="stat-label">Suosituin postinumero</div>
|
|
<div class="stat-value" id="stat-top-zip">-</div>
|
|
<div class="stat-sub" id="stat-top-zip-detail"></div>
|
|
</div>
|
|
<div class="stat-card stat-trivia">
|
|
<div class="stat-label">Suosituin nopeus</div>
|
|
<div class="stat-value" id="stat-top-speed">-</div>
|
|
<div class="stat-sub" id="stat-top-speed-detail"></div>
|
|
</div>
|
|
<div class="stat-card stat-trivia">
|
|
<div class="stat-label">Keskihinta / kk</div>
|
|
<div class="stat-value" id="stat-avg-price">-</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Toolbar: haku + info -->
|
|
<div class="toolbar">
|
|
<div class="search-bar">
|
|
<span class="search-icon">🔍</span>
|
|
<input type="text" id="search-input" placeholder="Hae yrityksen nimellä, osoitteella tai yhteyshenkilöllä...">
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Taulukko -->
|
|
<div class="table-card">
|
|
<table id="customer-table">
|
|
<thead>
|
|
<tr>
|
|
<th data-sort="yritys">Yritys ↕</th>
|
|
<th data-sort="asennusosoite">Osoite ↕</th>
|
|
<th data-sort="postinumero">Postinro ↕</th>
|
|
<th data-sort="kaupunki">Kaupunki ↕</th>
|
|
<th data-sort="liittymanopeus">Nopeus ↕</th>
|
|
<th data-sort="hinta">Hinta/kk ↕</th>
|
|
<th>Toiminnot</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody id="customer-tbody"></tbody>
|
|
</table>
|
|
<div id="no-customers" class="empty-state" style="display:none">
|
|
<div class="empty-icon">📋</div>
|
|
<p>Ei asiakkaita vielä.</p>
|
|
<p class="empty-hint">Klikkaa "Lisää asiakas" lisätäksesi ensimmäisen asiakkaan.</p>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Yhteenveto -->
|
|
<div class="summary-bar">
|
|
<span id="customer-count">0 asiakasta</span>
|
|
<span id="total-billing">Laskutus yhteensä: 0,00 €/kk</span>
|
|
</div>
|
|
</div>
|
|
|
|
<footer>
|
|
<p>CuituNet Intra — Asiakashallintajärjestelmä</p>
|
|
</footer>
|
|
</div>
|
|
|
|
<!-- Asiakas-modal -->
|
|
<div id="customer-modal" class="modal" style="display:none">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<h2 id="modal-title">Lisää asiakas</h2>
|
|
<button class="modal-close" id="modal-close">×</button>
|
|
</div>
|
|
<form id="customer-form">
|
|
<input type="hidden" id="form-id">
|
|
|
|
<h3>Perustiedot</h3>
|
|
<div class="form-grid">
|
|
<div class="form-group">
|
|
<label for="form-yritys">Yritys *</label>
|
|
<input type="text" id="form-yritys" required>
|
|
</div>
|
|
<div class="form-group">
|
|
<label for="form-ytunnus">Y-tunnus</label>
|
|
<input type="text" id="form-ytunnus" placeholder="1234567-8">
|
|
</div>
|
|
</div>
|
|
|
|
<h3>Asennusosoite</h3>
|
|
<div class="form-grid">
|
|
<div class="form-group full-width">
|
|
<label for="form-asennusosoite">Osoite</label>
|
|
<input type="text" id="form-asennusosoite" placeholder="esim. Kauppakatu 5">
|
|
</div>
|
|
<div class="form-group">
|
|
<label for="form-postinumero">Postinumero</label>
|
|
<input type="text" id="form-postinumero" placeholder="20100">
|
|
</div>
|
|
<div class="form-group">
|
|
<label for="form-kaupunki">Kaupunki</label>
|
|
<input type="text" id="form-kaupunki" placeholder="Turku">
|
|
</div>
|
|
</div>
|
|
|
|
<h3>Liittymä</h3>
|
|
<div class="form-grid">
|
|
<div class="form-group">
|
|
<label for="form-liittymanopeus">Liittymänopeus</label>
|
|
<input type="text" id="form-liittymanopeus" placeholder="esim. 100/100">
|
|
</div>
|
|
<div class="form-group">
|
|
<label for="form-hinta">Hinta €/kk</label>
|
|
<input type="number" id="form-hinta" step="0.01" min="0">
|
|
</div>
|
|
</div>
|
|
|
|
<h3>Yhteystiedot</h3>
|
|
<div class="form-grid">
|
|
<div class="form-group">
|
|
<label for="form-yhteyshenkilo">Yhteyshenkilö</label>
|
|
<input type="text" id="form-yhteyshenkilo">
|
|
</div>
|
|
<div class="form-group">
|
|
<label for="form-puhelin">Puhelin</label>
|
|
<input type="text" id="form-puhelin">
|
|
</div>
|
|
<div class="form-group">
|
|
<label for="form-sahkoposti">Sähköposti</label>
|
|
<input type="email" id="form-sahkoposti">
|
|
</div>
|
|
</div>
|
|
|
|
<h3>Laskutustiedot</h3>
|
|
<div class="form-grid">
|
|
<div class="form-group full-width">
|
|
<label for="form-laskutusosoite">Laskutusosoite</label>
|
|
<input type="text" id="form-laskutusosoite">
|
|
</div>
|
|
<div class="form-group">
|
|
<label for="form-laskutuspostinumero">Postinumero</label>
|
|
<input type="text" id="form-laskutuspostinumero" placeholder="20100">
|
|
</div>
|
|
<div class="form-group">
|
|
<label for="form-laskutuskaupunki">Kaupunki</label>
|
|
<input type="text" id="form-laskutuskaupunki">
|
|
</div>
|
|
<div class="form-group">
|
|
<label for="form-laskutussahkoposti">Laskutussähköposti</label>
|
|
<input type="email" id="form-laskutussahkoposti">
|
|
</div>
|
|
<div class="form-group">
|
|
<label for="form-elaskuosoite">E-laskuosoite</label>
|
|
<input type="text" id="form-elaskuosoite" placeholder="esim. 003712345678">
|
|
</div>
|
|
<div class="form-group">
|
|
<label for="form-elaskuvalittaja">E-laskuvälittäjä</label>
|
|
<input type="text" id="form-elaskuvalittaja" placeholder="esim. DABAFIHH">
|
|
</div>
|
|
</div>
|
|
|
|
<h3>Lisätiedot</h3>
|
|
<div class="form-group full-width">
|
|
<textarea id="form-lisatiedot" rows="3" placeholder="Vapaamuotoiset muistiinpanot..."></textarea>
|
|
</div>
|
|
|
|
<div class="form-actions">
|
|
<button type="submit" class="btn-primary" id="form-submit">Tallenna</button>
|
|
<button type="button" class="btn-secondary" id="form-cancel">Peruuta</button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Tiedot-modal (klikkaa riviä) -->
|
|
<div id="detail-modal" class="modal" style="display:none">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<h2 id="detail-title">Asiakkaan tiedot</h2>
|
|
<button class="modal-close" id="detail-close">×</button>
|
|
</div>
|
|
<div id="detail-body"></div>
|
|
<div class="form-actions">
|
|
<button class="btn-primary" id="detail-edit">Muokkaa</button>
|
|
<button class="btn-danger" id="detail-delete">Poista</button>
|
|
<button class="btn-secondary" id="detail-cancel">Sulje</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<script src="script.js"></script>
|
|
</body>
|
|
</html>
|