diff options
author | Thomas F. K. Jorna <[email protected]> | 2021-07-15 13:54:55 +0200 |
---|---|---|
committer | Thomas F. K. Jorna <[email protected]> | 2021-07-15 13:54:55 +0200 |
commit | 3de8a0a99f74cef8032d718e4b51d5c9c364db56 (patch) | |
tree | e54b9268bdfc27223c2221279c79637bde2d4789 /app/components/tweaks | |
parent | a23e3d6e46ed79b3406759bec5a4879124e791af (diff) |
made graph interactively tweakable
Diffstat (limited to 'app/components/tweaks')
-rw-r--r-- | app/components/tweaks/tweaks.story.tsx | 15 | ||||
-rw-r--r-- | app/components/tweaks/tweaks.tsx | 62 |
2 files changed, 77 insertions, 0 deletions
diff --git a/app/components/tweaks/tweaks.story.tsx b/app/components/tweaks/tweaks.story.tsx new file mode 100644 index 0000000..7ff70d6 --- /dev/null +++ b/app/components/tweaks/tweaks.story.tsx @@ -0,0 +1,15 @@ +import * as React from "react" +import { storiesOf } from "@storybook/react-native" +import { StoryScreen, Story, UseCase } from "../../../storybook/views" +import { color } from "../../theme" +import { Tweaks } from "./tweaks" + +storiesOf("Tweaks", module) + .addDecorator((fn) => <StoryScreen>{fn()}</StoryScreen>) + .add("Style Presets", () => ( + <Story> + <UseCase text="Primary" usage="The primary."> + <Tweaks style={{ backgroundColor: color.error }} /> + </UseCase> + </Story> + )) diff --git a/app/components/tweaks/tweaks.tsx b/app/components/tweaks/tweaks.tsx new file mode 100644 index 0000000..d1c8c2a --- /dev/null +++ b/app/components/tweaks/tweaks.tsx @@ -0,0 +1,62 @@ +import * as React from "react" +import { StyleProp, Switch, TextStyle, View, ViewStyle } from "react-native" +import { observer } from "mobx-react-lite" +import { color, typography } from "../../theme" +import { Text } from "../" +import { flatten } from "ramda" +import Slider from "@react-native-community/slider" +import { useState } from "react" + +const CONTAINER: ViewStyle = { + justifyContent: "center", +} + +const TEXT: TextStyle = { + fontFamily: typography.primary, + fontSize: 14, + color: color.primary, +} + +export interface TweaksProps { + /** + * An optional style override useful for padding & margin. + */ + style?: StyleProp<ViewStyle> + physics + setPhysics +} + +/** + * Describe your component here + */ +export const Tweaks = observer(function Tweaks(props: TweaksProps) { + const { style, physics, setPhysics } = props + const styles = flatten([CONTAINER, style]) + + return ( + <> + <Slider style={{ position: "absolute", top: 50, zIndex: 100, width: "20%", height: 40 }} + minimumValue={-100} + maximumValue={0} + onValueChange={(value) => { setPhysics({...physics, charge: value}) }} + value={physics.charge} + step={1}/> + <Slider style={{ position: "absolute", top: 100, zIndex: 100, width: "20%", height: 40 }} + minimumValue={0} + maximumValue={10} + onValueChange={(value) => { setPhysics({...physics, linkStrength: value}) }} + value={physics.linkStrength} + step={1}/> + <Slider style={{ position: "absolute", top: 150, zIndex: 100, width: "20%", height: 40 }} + minimumValue={1} + maximumValue={5} + onValueChange={(value) => { setPhysics({...physics, linkIts: value}) }} + value={physics.linkIts} + step={1}/> + <Switch style={{ position: "absolute", top: 200, zIndex: 100, width: "5", height: 40 }} + value={physics.collision} + onValueChange={()=>{setPhysics({...physics, collision: !physics.collision})}} + /> + </> + ) +}) |