This package has been deprecated

Author message:

Project has been moved to "shakl"

react-native-styled

0.0.4 • Public • Published

react-native-styled

npm version

Installation

yarn add react-native-styled

Usage

Creating a styled component

import styled from 'react-native-styled';
 
const Foo = styled(View)({ custom: 'styles' });
<Foo />; // <View style={{ custom: 'styles' }} />

Using primitives

By default, React Native's Text, TouchableOpacity and View are exposed to you, they can be directly used.

styled.Text({ custom: 'styles' });
styled.Touchable({ custom: 'styles' });
styled.View({ custom: 'styles' });
 
// equivalent to
styled(Text)({ custom: 'styles' });
styled(TouchableOpacity)({ custom: 'styles' });
styled(View)({ custom: 'styles' });

Multiple style objects

const Foo = styled.View({ custom: 'styles' }, { more: 'styles' } .. );
<Foo />; // <View style={{ custom: 'styles', more: 'styles' .. }} />

Dynamic styles based on props

const Foo = styled.View(props => ({ padding: props.padded ? 10 : 0 }));
<Foo /> // <View style={{ padding: 0 }} />
<Foo padded /> // <View style={{ padding: 10 }} />

Combining static and dynamic styles

const Foo = styled.View({ is: 'static' }, props => ({ is: 'dynamic' }));

Extending styles

const Title = styled.Text({ fontSize: 20 });
// <Text style={{ fontSize: 20 }} />
 
const BoldTitle = Title.extend({ fontWeight: 'bold' });
// <Text style={{ fontSize: 20, fontWeight: 'bold' }} />
 
const RedBoldTitle = BoldTitle.extend({ color: 'red' });
// <Text style={{ fontSize: 20, fontWeight: 'bold', color: 'red' }} />

Using refs

const List = styled(FlatList)({ custom: 'styles' });
<List ref={this.list} />; // based on React's forwardRef API (16.3.0)
// this.list.scrollTo({ y: 0 })
// or this.list.current.scrollTo({ y: 0 }) (with React.createRef)

Defining a custom display name for debugging

styled(View, { displayName: 'YetAnotherView' });
// default names are StyledText, StyledTouchable, StyledView, StyledComponent, etc

Defining propTypes and defaultProps

const StyledComponent = styled.View({ custom: 'styles' });
StyledComponent.propTypes = { .. };
StyledComponent.defaultProps = { .. };

Readme

Keywords

none

Package Sidebar

Install

npm i react-native-styled

Weekly Downloads

2

Version

0.0.4

License

MIT

Unpacked Size

6.17 kB

Total Files

4

Last publish

Collaborators

  • sonaye