Я пытаюсь передать свойства своему стилизованному компоненту. Я использую зависимость npm от стилизованного компонента.
import React, { Component } from 'react';
import styled from 'styled-components';
class WidgetContainer extends Component {
render() {
return (
<Wrapper name='widget-container'>
</Wrapper>
);
}
}
const mapStateToProps = state => {
return {
user: state.user,
bannerStatus: true
};
};
export default withRouter(connect(mapStateToProps)(WidgetContainer));
const Wrapper = styled.div`
display: flex;
flex-direction: column;
width: 100%;
min-height: 100vh;
margin: auto;
align-items: center;
justify-content: flex-start;
background: -webkit-linear-gradient(top, rgba(162, 209, 234, 1) 0%, rgba(56, 83, 132, 1) 100%);
padding-top: ${(props) => {
console.info(props.bannerStatus)
console.info('DATA')
return props.user ? '160px' : '126px'}};
overflow-y: auto;
padding-bottom: 40px;
@media(max-width: 768px) {
padding-top: 126px;
padding-bottom: 5px;
}
`;
Вы можете увидеть console.info возвращает undefined. Хотя значение жестко запрограммировано. В результате тернарный оператор не работает.
Вот документы: https://www.styled-components.com/docs/basics#adapting-based-on-props.





Вы сопоставляете состояние с реквизитами только в WidgetContainer. Компоненту Wrapper не передаются никакие реквизиты.
Пытаться
<Wrapper bannerStatus = {props.bannerStatus} name='widget-container'></Wrapper> или <Wrapper user = {props.user} bannerStatus = {props.bannerStatus} name='widget-container'></Wrapper>.
Это сработало. Спасибо за помощь, сэр!
Wrapperвне класса. Можно ли получить таким образом доступ к реквизиту?