rjsf-team/react-jsonschema-form

Nested `if` / `else` support is flaky when using `enums`

Open

#3618 opened on Apr 21, 2023

View on GitHub
 (3 comments) (0 reactions) (0 assignees)TypeScript (13,175 stars) (2,136 forks)batch import
bughelp wantedif-then-else

Description

Prerequisites

What theme are you using?

core

Version

5.x

Current Behavior

With this schema:

{
  "type": "object",
  "properties": {
    "type": {
      "enum": [
        "list-select",
        "empty",
        "static"
      ]
    }
  },
  "if": {
    "properties": {
      "type": {
        "const": "static"
      }
    }
  },
  "then": {
    "properties": {
      "value": {
        "type": "string"
      }
    }
  },
  "else": {
    "if": {
      "properties": {
        "type": {
          "const": "list-select"
        }
      }
    },
    "then": {
      "properties": {
        "id": {
          "enum": []
        }
      }
    }
  }
}

the value string field won't render. If you change the "enum": [] line to something else let's say: "type": "string" then it works.

Expected Behavior

I would have expected it to work either way, although if it didn't work in both cases that would be better than what it is now IMO

Steps To Reproduce

Working Not Working

Select static on both examples and you will see that the value field gets rendered in one but not the other.

Environment

- OS: MacOS
- Browser: Arc

Anything else?

No response

Contributor guide