┌─┐ ║"│ └┬┘ ┌┼┐ │ ┌──────────────┐ ┌───────────────┐ ┌──────────────────┐ ┌┴┐ │User Interface│ │JavaScript Code│ │Calculation Engine│ User └───────┬──────┘ └───────┬───────┘ └─────────┬────────┘ │Clicks on buttons ┌┴┐ │ │ │──────────────────> │ │ │ │ │ │ │ │ │ │ │ │ Interacts with buttons ┌┴┐ │ │ │ │ ───────────────────────>│ │ │ │ │ │ │ │ │ │ │ │ Updates display and DOM │ │ │ │ │ │ <───────────────────────│ │ │ │ │ │ │ │ │ │ │ │ │ │ ────┐ │ │ │ │ │ │ │ Sends input to Calculation Engine │ │ │ │ │ │ <───┘ │ │ │ │ │ │ │ │ │ │ │ │ Receives result │ │ │ │ │ │ <─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─│ │ └┬┘ └┬┘ │ │ │ Displays result │ │ │ │<──────────────────────────│ ┌┴┐ User ┌───────┴──────┐ ┌───────┴───────┐ ┌────────│ │───────┐ ┌─┐ │User Interface│ │JavaScript Code│ │Calculat│ │ Engine│ ║"│ └──────────────┘ └───────────────┘ └────────│ │───────┘ └┬┘ │ │ ┌┼┐ │ │ │ │ │ ┌┴┐ │ │ └┬┘