React Downshift добавляет URL-ссылки в раскрывающийся список
Я хочу добавить URL-ссылки в приведенный ниже скрипт с помощью Downshift
У меня есть в книжном состоянии атрибут имени и ссылки. Имена книг отлично отображаются в раскрывающемся списке, но мне интересно, как мне лучше всего использовать ссылки для каждого раскрывающегося элемента. Я бы хотел, чтобы список раскрылся, и, например, щелкните книгу о Гарри Поттере, и она будет ссылаться на страницу о Гарри Поттере.
Вот код, который я использую:
CodeSandbox:https://codesandbox.io/s/dropdown-with-downshift-1c978?fontsize=14
import React, { Component } from "react";
import ReactDOM from "react-dom";
import Downshift from "downshift";
import "./styles.css";
class DownshiftThree extends Component {
constructor(props) {
super(props);
this.books = [
{ name: "Harry Potter", link: "/harry-potter" },
{ name: "Net Moves", link: "/net-moves" },
{ name: "Half of a yellow sun", link: "/yellow-sun" },
{ name: "The Da Vinci Code", link: "/da-vinci-code" },
{ name: "Born a crime", link: "/born-a-crime" }
];
this.state = {
selectedBook: ""
};
this.onChange = this.onChange.bind(this);
}
onChange(selectedBook) {
this.setState({ selectedBook: selectedBook.name });
}
render() {
return (
<Downshift
onChange={this.onChange}
selectedItem={this.state.selectedBook}
itemToString={books => (books ? books.name : "")}
>
{({
isOpen,
getToggleButtonProps,
getItemProps,
highlightedIndex,
selectedItem: dsSelectedItem,
getLabelProps
}) => (
<div>
<label
style={{ marginTop: "1rem", display: "block" }}
{...getLabelProps()}
>
Select your favourite book
</label>{" "}
<br />
<button className="dropdown-button" {...getToggleButtonProps()}>
{this.state.selectedBook !== ""
? this.state.selectedBook
: "Select a book ..."}
</button>
<div style={{ position: "relative" }}>
{isOpen ? (
<div className="downshift-dropdown">
{this.books.map((item, index) => (
<div
className="dropdown-item"
{...getItemProps({ key: index, index, item })}
style={{
backgroundColor:
highlightedIndex === index ? "lightgray" : "white",
fontWeight: dsSelectedItem === item ? "bold" : "normal"
}}
>
<a href="{item.link}">{item.name}</a>
</div>
))}
</div>
) : null}
</div>
</div>
)}
</Downshift>
);
}
}
const rootElement = document.getElementById("root");
ReactDOM.render(<DownshiftThree />, rootElement);