<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>Fuel App</title> <style type="text/css"> body { margin:40px auto; max-width:650px; line-height:1.6; font-size:18px; color:#444; padding:0 10px; font-family: ui-rounded, 'Hiragino Maru Gothic ProN', Quicksand, Comfortaa, Manjari, Nunito, 'Arial Rounded MT', 'Arial Rounded MT Bold', Calibri, source-sans-pro, sans-serif; width: fit-content; } h1,h2,h3{ line-height:1.2 } header { text-align: center } label { font-weight: bold } p { margin: 1em 0 0 } #app { background: ghostwhite; padding: 1em 1em 0.5em; border-radius: 15px; } form { display: grid; grid-template-columns: auto 1fr auto; gap: 10px; } label { grid-column: 1; text-align: right; } input { grid-column: 2; } .unit { grid-column: 3; font-size: smaller; } .total { font-size: 24pt; font-weight: 500; text-align: right; } </style> </head> <body> <header> <h1>⛽<br>Fuel App</h1> </header> <div id="app"> <noscript>JavaScript is required to use this calculator.</noscript> </div> <script type="text/javascript"> const el = document.getElementById('app'); if (el) { const timer = setTimeout(function() { console.log('ran'); el.textContent = "Loading…" }, 500); el.dataset.timer = timer; } </script> <script type="module"> import { reactive, html } from './arrow.min.js'; const data = reactive({ price: 194.9, economy: 7.4, distance: 1050 }); function calculate() { return data.distance / 100.0 * data.economy * data.price / 100.0; } function updateValue(e) { const target = e.target; const value = parseFloat(target.value); if (!isNaN(value)) { data[target.name] = value; } } const app = document.getElementById('app'); clearTimeout(parseInt(app.dataset.timer, 10)); app.replaceChildren(); // Clear loading text html` <form> <label for="price">Price</label> <input @input="${updateValue}" type="number" step="0.1" name="price" id="price" size="6" value="${() => data.price}"> <span><span class="unit">¢/l</span></span> <label for="economy">Consumption</label> <input @input="${updateValue}" type="number" name="economy" id="economy" step="0.1" size="6" value="${() => data.economy}"> <span><span class="unit">l/100km</span></span> <label for="distance">Distance</label> <input @input="${updateValue}" type="number" name="distance" id="distance" step="1" size="6" value="${() => data.distance}"> <span><span class="unit">km</span></span> </form> <p class="total"> $${() => calculate().toFixed(2)} </p> `(app) </script> </body> </html>