отображает на странице контент в табличном виде. В зависимости от типа контента меняется его отображение (кастомные колонки, иконки, кнопки для взаимодействия с данными).
В качестве аргументов: data и contentType. Тип контента: users | projects | settings.
Также существуют интерфейсы/типа для data для каждого из типов контента.
Собственно, вопрос: как грамотно реализовать опциональный тип для аргумента data, который бы смотрел на contentType?
Что-то типа:
type ComponentType = {
contentType: "users" | "projects" | "settings",
data: contentType === "users" ? User[] : contentType === "projects" ? Project[] : contentType === "settings" ? Setting[] : null;
}
discriminated union
Спасибо, чекну!
Обсуждают сегодня