rjsf-team/react-jsonschema-form

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

Open

#3,618 建立於 2023年4月21日

在 GitHub 查看
 (3 留言) (0 反應) (0 負責人)TypeScript (13,175 star) (2,136 fork)batch import
bughelp wantedif-then-else

描述

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

貢獻者指南