Задать вопрос
@mikor

Как раскидать по компонентам REACT?

Субствено есть компонент Todos

render() {
  const { data: { loading, error, todos } } = this.props;
  if (loading) {
    return <p>Loading...</p>;
  } else if (error) {
    return <p>Error!</p>;
  } else {
    return (
      <ul>
        {todos.map(({ id, text }) => (
          <li key={id}>{text}</li>
        ))}
      </ul>
    );
  }
}


Как сделать так что бы было 3 компонента Error, Loading, Todos, при том что бы Error и Loading "пропадали" как только их статус меняется в false (ну появлялись при true соответственно).

P.S. Это нужно сделать так как будет много аналогичных компонентов и не хочется дублировать код Error и Loading....
  • Вопрос задан
  • 228 просмотров
Подписаться 1 Оценить 2 комментария
Решения вопроса 2
RomReed
@RomReed
JavaScript, Flutter, ReactNative, Redux, Firebase
const Error=()=>{
<div><p>Error!</p></div>
}
const Loading=()=>{
<div><p>Loading...</p></div>
}
const Todos=()=>{
<div><ul>
        {this.props.todos.map(({ id, text }) => (
          <li key={id}>{text}</li>
        ))}
      </ul></div>
}
render() {
  const { data: { loading, error, todos } } = this.props;
  if (loading) {
   <Loading>
  } else if (error) {
   <Error> 
  } else {
    return (
      <Todos todos={todos }>
    );
  }
}
Ответ написан
SPAHI4
@SPAHI4
реактовцы - это не девы, а прокидыватели пропсов
На моем проекте я сделал такой велосипед, не доделан случай, когда не требуется заменять собой весь компонент, стили измените под себя:
import PropTypes from 'prop-types';
import csx from 'classnames';

export const MessageContainer = ({ theme, children }) => (
	<div className={csx('root', theme)}>
		{/* language=SCSS */}
		<style jsx>{`
			.root {
				font-weight: 500;
				display: flex;
				flex: 1;
				align-items: center;
				justify-content: center;
				font-size: 14px;
				padding: 24px;
			}
			.error {
				color: var(--error-color);
			}
			.loading {
				color: var(--accent-color);
			}
			.empty {
				color: #bbbbbb;
			}
		`}</style>
		{children}
	</div>
);

MessageContainer.propTypes = {
	theme: PropTypes.oneOf(['loading', 'empty', 'error']).isRequired,
	children: PropTypes.node.isRequired,
};

export default function withQueryStatus({ emptyText = 'Nothing found', replaceComponent = true, resultPath }) {
	if (!replaceComponent) {
		throw new Error('Not implemented');
	}

	return (ComposedComponent) => {
		const WithQueryStatus = (props) => {
			const data = props.data;
			if (!data) {
				return null;
			}

			if (data.error) {
				return <MessageContainer theme='error'>{data.error.message}</MessageContainer>;
			}

			if (data.loading) {
				return <MessageContainer theme='loading'>Loading...</MessageContainer>;
			}

			if (!data[resultPath].length) {
				return <MessageContainer theme='empty'>{emptyText}</MessageContainer>;
			}

			return <ComposedComponent {...props} />;
		};

		WithQueryStatus.propTypes = {
			data: PropTypes.shape({
				[resultPath]: PropTypes.array,
				loading: PropTypes.bool,
				error: PropTypes.object,
			}),
		};

		WithQueryStatus.defaultProps = {
			data: null,
		};

		return WithQueryStatus;
	};
}

// у вас будет

export default withQueryStatus({ emptyText: 'No todos found', resultPath: 'todos' })(Todos),
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы