{
const root = html`<div></div>`;
function UserGreeting(props) {
return htm`<h1>Welcome back!</h1>`;
}
function GuestGreeting(props) {
return htm`<h1>Please sign up.</h1>`;
}
function Greeting(props) {
const isLoggedIn = props.isLoggedIn;
if (isLoggedIn) {
return htm`<${UserGreeting} />`;
}
return htm`<${GuestGreeting} />`;
}
function LoginButton(props) {
return htm`
<button onClick=${props.onClick}>
Login
</button>
`;
}
function LogoutButton(props) {
return htm`
<button onClick=${props.onClick}>
Logout
</button>
`;
}
class LoginControl extends React.Component {
constructor(props) {
super(props);
this.handleLoginClick = this.handleLoginClick.bind(this);
this.handleLogoutClick = this.handleLogoutClick.bind(this);
this.state = {isLoggedIn: false};
}
handleLoginClick() {
this.setState({isLoggedIn: true});
}
handleLogoutClick() {
this.setState({isLoggedIn: false});
}
render() {
const isLoggedIn = this.state.isLoggedIn;
let button;
button = isLoggedIn ? htm`<${LogoutButton} onClick=${this.handleLogoutClick} />` :
htm`<${LoginButton} onClick=${this.handleLoginClick} />`;
return htm`
<div>
<${Greeting} isLoggedIn=${isLoggedIn} />
${button}
</div>
`;
}
}
ReactDOM.render(
htm`<${LoginControl} />`,
root
);
return root;
}