"use strict"; function move_checkboxes() { let checkboxes = document.getElementsByName("users"); let fields = document.querySelectorAll(".checkbox_field"); if (checkboxes.length == fields.length) { for (let i = 0; i < fields.length; ++i) { let el = checkboxes[i].cloneNode(true); fields[i].appendChild(el); } } else { alert( "Количество пользователей агентов не соответствует количеству полей в форме AdminPageUsers" ); } } move_checkboxes(); // React class TableRow extends React.Component { render() { return ( {this.props.user.name} {this.props.user.user.email} {this.props.user.role} ); } } class TableBody extends React.Component { constructor(props) { super(props); this.state = { users: [], engineers: 0, light_agents: 0, }; } get_users() { axios.get("/api/users").then((response) => { this.setState({ users: response.data.users, engineers: response.data.engineers, light_agents: response.data.light_agents, }); let elements = document.querySelectorAll(".info-quantity-value"); elements[0].innerHTML = this.state.engineers; elements[1].innerHTML = this.state.light_agents; }); } componentDidMount() { this.interval = setInterval(() => { this.get_users(); }, 10000); } componentWillUnmount() { clearInterval(this.interval); } render() { return this.state.users.map((user, key) => ( )); } } ReactDOM.render(, document.getElementById("new_tbody")); setTimeout(() => document.getElementById("old_tbody").remove(), 10000);