Skip to content

Commit

Permalink
up and running
Browse files Browse the repository at this point in the history
  • Loading branch information
cprice11 committed Oct 12, 2024
1 parent 3a11cfb commit 72145e3
Show file tree
Hide file tree
Showing 13 changed files with 6,695 additions and 99 deletions.
88 changes: 0 additions & 88 deletions experiences/bus-bunching/controls/lib/index.js

This file was deleted.

170 changes: 170 additions & 0 deletions experiences/bus-bunching/controls/lib/index.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,170 @@
/** @jsxImportSource @emotion/react */
import { css } from "@emotion/react";
import React, { useCallback, useState } from "react";
import { useMessaging } from "@footron/controls-client";
import { Slider, Box, Button } from "@material-ui/core";

const containerStyle = css`
padding: 16px;
overflow-x: hidden;
p {
margin: 0 0 16px;
}
`;
const stopSymbols = ["■", "▲", "●", "♥"];
const stopColors = ["#EE6352", "#08B2E3", "#57A773", "#8657a7", "#2222AA"];

const sectionWrapperStyle = {
justifyContent: "center",
padding: "2em 0 0 0",
margin: "auto",
};

const buttonWrapperStyle = {
width: "100%",
display: "grid",
gridTemplateColumns: "repeat(5, 17%)",
gridTemplateRows: "repeat(4, 100%)",
gap: "3%",
alignItems: "center",
justifyContent: "center",
Height: "auto",
};

const buttonStyle = {
width: "100%",
aspectRatio: "1 / 1",
borderRadius: "100%",
fontSize: "200%",
alignItems: "center",
justifyContent: "center",
};

const ControlsComponent = () => {
const { sendMessage } = useMessaging();
const [buttonCount, setButtonCount] = useState(3);

const updateBusCount = useCallback(
async (event, value) => {
await sendMessage({ type: "numBuses", value: value });
},
[sendMessage]
);

const updateStopCount = useCallback(
async (event, value) => {
setButtonCount(value);
await sendMessage({ type: "numStops", value: value });
},
[sendMessage]
);

const restart = useCallback(
async (event, value) => {
await sendMessage({ type: "restart", value: value });
},
[sendMessage]
);

const pauseStart = useCallback(
async (value) => {
console.log(value);
await sendMessage({ type: "delayStop", value: value });
},
[sendMessage]
);

const pauseEnd = useCallback(
async (value) => {
console.log(value);
await sendMessage({ type: "freeStop", value: value });
},
[sendMessage]
);

const busStopSymbol = (index: number) => {
let stopStyle = {
...buttonStyle,
color: stopColors[index % stopColors.length],
};
return (
<span style={stopStyle}>{stopSymbols[index % stopSymbols.length]}</span>
);
};

const buttons = Array.from({ length: buttonCount }, (_, index) => (
<Button
key={index}
style={buttonStyle}
variant="outlined"
color="primary"
onMouseDown={() => pauseStart(index)}
onMouseUp={() => pauseEnd(index)}
onTouchStart={() => pauseStart(index)}
onTouchEnd={() => pauseEnd(index)}
>
{busStopSymbol(index)}
</Button>
));

return (
<div css={containerStyle}>
<h1>Bus Bunching</h1>
<p>
Learn more about bus bunching here:{" "}
<a href="https://en.wikipedia.org/wiki/Bus_bunching">
Wikipedia "Bus Bunching"
</a>
</p>
<Box style={sectionWrapperStyle}>
<p>
<b>Change the number of buses!</b>
</p>
<Slider
min={1}
max={10}
valueLabelDisplay="auto"
onChange={updateBusCount}
step={1}
marks
defaultValue={3}
/>
<p>
<b>Change the number of bus stops!</b>
</p>
<Slider
min={2}
max={20}
valueLabelDisplay="auto"
onChange={updateStopCount}
step={1}
marks
defaultValue={5}
/>
</Box>
<Box style={sectionWrapperStyle}>
<Box style={{ textAlign: "center" }}>
<Button
style={{ margin: "0 auto" }}
variant="contained"
color="primary"
onClick={restart}
>
<b>Restart</b>
</Button>
</Box>
</Box>
<Box style={sectionWrapperStyle}>
<p>
<b>
Create a delay by clicking and holding any of the bus stops below.
</b>
</p>
<Box style={buttonWrapperStyle}>{buttons}</Box>
</Box>
</div>
);
};

export default ControlsComponent;
1 change: 1 addition & 0 deletions experiences/bus-bunching/web/assets/index-CO6LLJQy.css

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6,518 changes: 6,518 additions & 0 deletions experiences/bus-bunching/web/assets/index-Drcr_JpC.js

Large diffs are not rendered by default.

1 change: 0 additions & 1 deletion experiences/bus-bunching/web/index-DfisqMx5.css

This file was deleted.

15 changes: 5 additions & 10 deletions experiences/bus-bunching/web/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -7,21 +7,16 @@
<title>Bus Bunching: UVX</title>

<script src="./footron-messaging.development.js" type="text/javascript"></script>
<script>
if (typeof module === "object") {
window.module = module
module = undefined
}
</script>
<script>if (typeof module === 'object') { window.module = module; module = undefined; }</script>
<script src="./jquery-3.6.0.min.js" type="text/javascript"></script>
<script src="./fader.js" type="text/javascript"></script>
<script type="module" crossorigin src="index-DUfHmJ6Z.js"></script>
<link rel="stylesheet" crossorigin href="index-DfisqMx5.css">
<script type="module" crossorigin src="/assets/index-Drcr_JpC.js"></script>
<link rel="stylesheet" crossorigin href="/assets/index-CO6LLJQy.css">
</head>

<body>
<div class="storytext fader">Have you ever been waiting for a bus for a long time when several buses arrive at
once?</div>
<div class="storytext fader">Have you ever been waiting for a bus for a long time when several arrive at
once?.</div>

<div class="storytext fader">This phenomenon is called <strong>bus bunching</strong>.</div>

Expand Down
1 change: 1 addition & 0 deletions experiences/bus-bunching/web/models/library.gltf

Large diffs are not rendered by default.

Binary file not shown.
Binary file not shown.
Binary file added experiences/bus-bunching/web/models/stop.glb
Binary file not shown.
Binary file added experiences/bus-bunching/web/models/uvx-back.glb
Binary file not shown.
Binary file added experiences/bus-bunching/web/models/uvx-front.glb
Binary file not shown.

0 comments on commit 72145e3

Please sign in to comment.