summaryrefslogtreecommitdiff
path: root/examples/framework-multiple/src/components/PreactCounter.tsx
blob: be4ddb6ce63fef11fc2dadb800382a0d1f4ddc49 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
import { h, Fragment } from 'preact';
import { useState } from 'preact/hooks';

/** a counter written in Preact */
export function PreactCounter({ children }) {
  const [count, setCount] = useState(0);
  const add = () => setCount((i) => i + 1);
  const subtract = () => setCount((i) => i - 1);

  return (
    <>
      <div className="counter">
        <button onClick={subtract}>-</button>
        <pre>{count}</pre>
        <button onClick={add}>+</button>
      </div>
      <div className="children">{children}</div>
    </>
  );
}