Skip to content

Releases: pmndrs/leva

[email protected]

17 Dec 18:33
c201433
Compare
Choose a tag to compare

Patch Changes

  • e45e9de: Feat: pass get function to Button and ButtonGroup

@leva-ui/[email protected]

17 Dec 18:33
c201433
Compare
Choose a tag to compare

Patch Changes

@leva-ui/[email protected]

17 Dec 18:33
c201433
Compare
Choose a tag to compare

Patch Changes

[email protected]

15 Dec 15:53
12a9959
Compare
Choose a tag to compare

Patch Changes

  • dc284c7: fix: correct listener path to prevent onEdit callbacks from firing twice or more

[email protected]

29 Nov 15:02
Compare
Choose a tag to compare

Patch Changes

  • 792e702: fix: prevent range and interval from overflowing when provided a value that is out of min / max bounds.

[email protected]

21 Nov 22:32
a8b2465
Compare
Choose a tag to compare

Patch Changes

  • 05ebf42: Upgrade deps and add disabled option to button

@leva-ui/[email protected]

21 Nov 22:32
a8b2465
Compare
Choose a tag to compare

Patch Changes

@leva-ui/[email protected]

21 Nov 22:32
a8b2465
Compare
Choose a tag to compare

Patch Changes

[email protected]

17 Sep 14:01
0cd558f
Compare
Choose a tag to compare

leva

1.0.0

Minor Changes

  • 1001f25: Fix version for stitches before moving to 1.x

0.9.13

Patch Changes

  • 8aba17c: Allow controlling the collapsed state of LevaPanel via object overload for the controlled property.

    const [collapsed, setCollapsed] = React.useState(false)
    
    const leva = <Leva collapsed={{ collapsed, onChange: (collapsed) => setCollapsed(collapsed) }} />

0.9.12

Patch Changes

  • 4f51de7: Switch from tinycolor to colord
  • dd17591: chore: update to stitches 0.2.0
  • ac99a90: feat: add color option to folders
  • d5a5dd2: - Fix: prevent selection on Firefox when closing the Color picker.
    • Fix: add suffix to Number plugin initial value.
    • Feat: add title attribute to Labels when there is no hint prop.

0.9.11

Patch Changes

0.9.10

Patch Changes

  • 16e3c14: feat: add clamp Range and Interval initial values to bounds.
    feat: when title is empty show the drag dots.

0.9.9

Patch Changes

  • f8f7b57: fix: double render issue when using nested components.

0.9.8

Patch Changes

0.9.7

Patch Changes

  • d5383c0: fix: fix bug in which the panel would remove the root node of the app.

0.9.6

Patch Changes

  • 0511799: styles: remove manual 'leva__' prefix from stitches styles.

0.9.5

Patch Changes

  • 234cfcd: Add onEditStart and onEditEnd callbacks for values.

    useControls({
      value: {
        value: 1,
        onEditStart: (value, path) => {},
        onEditEnd: (value, path) => {},
      },
    })

    Add path as a second parameter to onChange callback to mimic onEditXXX signature.

  • a2db0e6: Improve buttonGroup API.

    The label is now completely hidden when specifying key that only includes spaces. Previously the label was still rendered, but without text, this caused ugly spacing when using the oneLineLabels option on the Leva component.

    const [values, set] = useControls(() => ({
      Size: 1,
      ' ': buttonGroup({
        '0.25x': () => set({ Size: 0.25 }),
        '0.5x': () => set({ Size: 0.5 }),
        '1x': () => set({ Size: 1 }),
        '2x': () => set({ Size: 2 }),
        '3x': () => set({ Size: 3 }),
      }),
    }))

    It is now possible to set the label via the buttonGroup arguments by using the alternative API:

    const [values, set] = useControls(() => ({
      Width: 1,
      WidthPresets: buttonGroup({
        label: null,
        opts: {
          '0.25x': () => set({ Size: 0.25 }),
          '0.5x': () => set({ Size: 0.5 }),
          '1x': () => set({ Size: 1 }),
          '2x': () => set({ Size: 2 }),
          '3x': () => set({ Size: 3 }),
        },
      }),
      Height: 1,
      HeightPresets: buttonGroup({
        label: null,
        opts: {
          '0.25x': () => set({ Size: 0.25 }),
          '0.5x': () => set({ Size: 0.5 }),
          '1x': () => set({ Size: 1 }),
          '2x': () => set({ Size: 2 }),
          '3x': () => set({ Size: 3 }),
        },
      }),
    }))

    This also allows passing any JSX element as the label beside strings.

    It also helps avoiding a bunch of `` labels (where each new one contains one more space).

  • d0b45de: Add context argument to onChange handler.

    The context.initial boolean parameter can be used to identify whether onChange is invoked initially.

    useControls({
      value: {
        value: 1,
        onChange: (value, { initial }) => {
          syncValue(value)
          if (!initial) {
            saveValueOnRemote(value)
          }
        },
      },
    })

    The context.fromPanel boolean parameter can be used to identify whether the onChange invocation is caused by the Leva component or via the set function return from the useControl hook.

    const [, set] = useControls(() => ({
      value: {
        value: 1,
        onChange: (value, { initial, fromPanel }) => {
          syncValue(value)
          if (!initial && !fromPanel) {
            // we don't wanna trigger a remote save in case the value has not been updated from the panel
            saveValueOnRemote(value)
          }
        },
      },
    }))

    The context.get parameter can be used for retrieving the up to date state of the store. This is handy if you need to do some invocations based on all the store values.

    const [, set] = useControls(() => ({
      value1: 1,
      value2: 2,
      value3: {
        value: 1,
        onChange: (value3, { get }) => {
          const { value1, value2 } = get()
          // calculate something based on value1 and value2
        },
      },
    }))

0.9.4

Patch Changes

  • 50e8096: fix: sanitize step should behave better.
    improvement: expand panel when filter changes.

  • 09a1a38: Allow specifying the explicit input type via the type option. This is handy when you want to prevent your string value being casted to a color or number.

    import { LevaInputs, useControls } from 'leva'
    
    useControls({
      color: {
        type: LevaInputs.STRING,
        value: '#f00',
      },
      number: {
        type: LevaInputs.STRING,
        value: '1',
      },
    })

0.9.3

Patch Changes

  • 7edbb69: chore: update dependencies.

0.9.2

Patch Changes

  • 34281d7: Add new value option transient. This allows opting out of the transient mode when having a onChange handler invoked.

    const data = useControls({
      color: {
        value: '#7c3d3d',
        onChange: (value) => {
          console.log(value)
        },
        transient: false,
      },
    })
    
    console.log(data) // { color: '#7c3d3d' }
    const data = useControls({
      color: {
        value: '#7c3d3d',
        onChange: (value) => {
          console.log(value)
        },
        transient: true,
      },
    })
    
    console.log(data) // {}

    This is handy if you want to use the onChange handler for triggering a save on a remote server, while still triggering a re-render with the value.

0.9.1

Patch Changes

  • 09ac7b1: chore: remove clipboard-polyfill dependency.

0.9.0

Patch Changes

  • 50d850a: BREAKING CHANGE: Replace hideTitleBar with titleBar option.

    For hiding the title bar the usages of <Leva hideTitleBar /> must be replaced with <Leva titleBar={false} />.

    It is now possible to overwrite the six dots rendered as the title by default by providing a title option to the titleBar property.

    <Leva
      titleBar={{
        title: 'Some Title',
      }}
    />

    Its is now possible to disable dragging of the panel via the drag option to the titleBar property.

    <Leva
      titleBar={{
        drag: false,
      }}
    />

    It is now possible to enable or disable filtering of the panel values via the filter option on the titleBar property.

    <Leva
      titleBar={{
        filter: true,
      }}
    />

0.8.4

Patch Changes

  • e0fdefc: types: fix beautifier union type.

0.8.3

Patch Changes

  • a7f9bf1: types: don't use union type when not using objects as plugin function args.

0.8.2

Patch Changes

  • 7fd9f92: feat: allow input options to be spread inside custom plugin.

  • b4aa43d: Fix: add empty key warning.

  • 7fd9f92: fix: correct onUpdate for a blurred input: previously bluring an input from a
    store while selecting a second store would commit the change on the second
    store.

    fix: return number previous value when field is empty.

    types: (internal) fix default useInputContext types.

  • e21f2fe: fix: slider position overflowing with range input.

0.8.1

Patch Changes

  • c997410: Plugin: add the Bezier plugin

    import { bezier } from '@leva-ui/plugin-bezier'
    useControls({ curve: bezier([0.25, 0.1, 0.25, 1]) })

0.8.0

Minor Changes

  • edc8847: Breaking: change how leva/plugin exports components.

    // before
    import { Row, Label, String } from 'leva/plugin'
    
    // after
    import { Components } from 'leva/plugin'
    const { Row, Label, String } = Components

    Feat: add useValue / useValues hooks that let an input query other inputs values.

    Feat: normalize has additional arguments to its signature:

    /**
     * @path the path of the input
     * @data the data available in the store
     */
    const normalize = (input: Input, path: string, data: Data)

    Feat: sanitize has additional arguments to its signature:

    /**
     * @path the path of the input
     * @store the store
     */
    const sanitize = (
      value: any,
      settings: Settings,
      prevValue: any,
      path: string,
      store: StoreType
    )

    Styles: better feedback when dragging number from inner label.

    Plugin: add the Plot plugin ๐Ÿ“ˆ

    import { plot } from '@leva-ui/plugin-plot'
    useControls({ y: plot({ expression: 'cos(x)', graph: true, boundsX: [-10, 10], boundsY: [0, 100] }) })

0.7.3

Patch Changes

  • f9f7f1e: - Have Select accept functions as value or options. Fixes #165.
    • Temporarily type the set function values with any when useControls is used with the function API. In the future, we should infer th value type from the sanitize function.

0.7.2

Patch Changes

  • d2eaf58: fix: properly resolves value-keyed objects for the Select input.

0.7.1

Patch Changes

  • 98984e1: types: fix set types in transient mode.

0.7.0

Minor Changes

  • 0b7e968: Add the invertY setting for the Vector2D joystick for inverting the y coordinate.

    BREAKING: The default behavior ...

Read more

@leva-ui/[email protected]

17 Sep 14:01
0cd558f
Compare
Choose a tag to compare

@leva-ui/plugin-spring

1.0.0

Minor Changes

  • 1001f25: Fix version for stitches before moving to 1.x

Patch Changes

0.9.12

Patch Changes

  • 4f51de7: Switch from tinycolor to colord
  • d5a5dd2: - Fix: prevent selection on Firefox when closing the Color picker.
    • Fix: add suffix to Number plugin initial value.
    • Feat: add title attribute to Labels when there is no hint prop.
  • Updated dependencies [4f51de7]
  • Updated dependencies [dd17591]
  • Updated dependencies [ac99a90]
  • Updated dependencies [d5a5dd2]

0.9.10

Patch Changes

0.9.8

Patch Changes

0.9.6

Patch Changes

0.9.3

Patch Changes

0.8.1

Patch Changes

  • c997410: Plugin: add the Bezier plugin

    import { bezier } from '@leva-ui/plugin-bezier'
    useControls({ curve: bezier([0.25, 0.1, 0.25, 1]) })
  • Updated dependencies [c997410]

0.8.0

Patch Changes

  • edc8847: Breaking: change how leva/plugin exports components.

    // before
    import { Row, Label, String } from 'leva/plugin'
    
    // after
    import { Components } from 'leva/plugin'
    const { Row, Label, String } = Components

    Feat: add useValue / useValues hooks that let an input query other inputs values.

    Feat: normalize has additional arguments to its signature:

    /**
     * @path the path of the input
     * @data the data available in the store
     */
    const normalize = (input: Input, path: string, data: Data)

    Feat: sanitize has additional arguments to its signature:

    /**
     * @path the path of the input
     * @store the store
     */
    const sanitize = (
      value: any,
      settings: Settings,
      prevValue: any,
      path: string,
      store: StoreType
    )

    Styles: better feedback when dragging number from inner label.

    Plugin: add the Plot plugin ๐Ÿ“ˆ

    import { plot } from '@leva-ui/plugin-plot'
    useControls({ y: plot({ expression: 'cos(x)', graph: true, boundsX: [-10, 10], boundsY: [0, 100] }) })
  • Updated dependencies [edc8847]

0.7.0

Patch Changes

0.6.0

Patch Changes