Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/native-ly/native-layout-stack
↘️ SwiftUI like layout management for React Native
https://github.com/native-ly/native-layout-stack
android expo grid horizontal ios layout library mobile react react-native spacer stack swiftui vertical web
Last synced: 2 months ago
JSON representation
↘️ SwiftUI like layout management for React Native
- Host: GitHub
- URL: https://github.com/native-ly/native-layout-stack
- Owner: native-ly
- License: mit
- Created: 2020-08-28T04:53:34.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2023-02-03T15:43:54.000Z (almost 2 years ago)
- Last Synced: 2024-10-07T12:38:35.342Z (3 months ago)
- Topics: android, expo, grid, horizontal, ios, layout, library, mobile, react, react-native, spacer, stack, swiftui, vertical, web
- Language: TypeScript
- Homepage: https://snack.expo.io/@jbiesiada/native-layout-stack
- Size: 2.65 MB
- Stars: 10
- Watchers: 1
- Forks: 1
- Open Issues: 19
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# [native-layout-stack](https://github.com/native-ly/native-layout-stack)
[![NPM version](https://img.shields.io/npm/v/native-layout-stack?style=flat-square)](https://www.npmjs.com/package/native-layout-stack)
[![NPM downloads](https://img.shields.io/npm/dm/native-layout-stack?style=flat-square)](https://www.npmjs.com/package/native-layout-stack)
[![NPM license](https://img.shields.io/npm/l/native-layout-stack?style=flat-square)](https://www.npmjs.com/package/native-layout-stack)
[![run in expo snack](https://img.shields.io/badge/Run%20in%20Snack-4630EB?style=flat-square&logo=EXPO&labelColor=FFF&logoColor=000)](https://snack.expo.io/@jbiesiada/native-layout-stack)
[![Codecov](https://img.shields.io/codecov/c/github/native-ly/native-layout-stack?style=flat-square)](https://codecov.io/gh/native-ly/native-layout-stack)
[![Travis](https://img.shields.io/travis/com/native-ly/native-layout-stack/main?style=flat-square)](https://app.travis-ci.com/github/native-ly/native-layout-stack)## About
[SwiftUI](https://developer.apple.com/xcode/swiftui/) like layout management for React Native
### Idea
This library recreates SwiftUI components in React Native:
**Stack**
- [HStack](https://developer.apple.com/documentation/swiftui/hstack/)
- [VStack](https://developer.apple.com/documentation/swiftui/vstack/)**Spacer**
- [Spacer](https://developer.apple.com/documentation/swiftui/spacer/)
### Alternatives
- [Stacks](https://github.com/mobily/stacks/) by [Marcin Dziewulski](https://github.com/mobily/)
- [react-native-divisible-view](https://github.com/kangsu-dev/react-native-divisible-view/) by [kangsu](https://github.com/kangsu-dev/)
- [React Native Spacing System](https://github.com/hirokazutei/react-native-spacing-system/) by [Hirokazu Nakano Tei](https://github.com/hirokazutei/)
- [react-native-stacks](https://github.com/andrew-levy/react-native-stacks/) by [Andrew Levy](https://github.com/andrew-levy/)## How to Install
First, install the library in your project by npm:
```sh
$ npm install native-layout-stack
```Or Yarn:
```sh
$ yarn add native-layout-stack
```## Getting Started
**• Connect library with project using ES6 import:**
```js
import { LayoutProvider, Stack, Spacer } from 'native-layout-stack'
```## Options
### LayoutProvider
| **name** | **type** | **description** |
| ------------- | ------------------------------------------------------------------------------------------- | ------------------------------------------------- |
| padding | Space or [Space] or [Space, Space] or [Space, Space, Space] or [Space, Space, Space, Space] | Outer space |
| spaces | Space | Space between children |
| omitNull | boolean | Skip elements that are `null` or `React.Fragment` |
| arrayDivision | boolean | |
| debug | boolean | Add random color to spaces |### Stack
Stack extends ViewProps and implements all [`LayoutProvider`](#layoutprovider) props without `debug`
### Spacer
Component uses ViewProps
### Types
| **name** | **type** |
| -------- | ---------------- |
| Space | number or string |## Example
```jsx
import React from 'react'
import { View } from 'react-native'
import { LayoutProvider, Stack, Spacer } from 'native-layout-stack'const MyComponent = () => {
return (
)
}const App = () => {
return (
)
}export default App
```## License
This project is licensed under the MIT License © 2020-present Jakub Biesiada