Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/eleev/column-text-view-ui
📄 Column Text View is an adaptive UI component that renders text in columns, horizontally [iOS 12, UIKit, TextKit, SwiftUI].
https://github.com/eleev/column-text-view-ui
core-graphics coregraphics framework ios spm swift swift-package-manager swiftui textkit ui-component uikit
Last synced: 3 months ago
JSON representation
📄 Column Text View is an adaptive UI component that renders text in columns, horizontally [iOS 12, UIKit, TextKit, SwiftUI].
- Host: GitHub
- URL: https://github.com/eleev/column-text-view-ui
- Owner: eleev
- License: mit
- Created: 2019-11-16T13:17:39.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2019-12-29T09:14:24.000Z (about 5 years ago)
- Last Synced: 2024-08-05T11:11:55.240Z (7 months ago)
- Topics: core-graphics, coregraphics, framework, ios, spm, swift, swift-package-manager, swiftui, textkit, ui-component, uikit
- Language: Swift
- Homepage:
- Size: 44.9 MB
- Stars: 14
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# column-text-view-ui [data:image/s3,"s3://crabby-images/67aad/67aad24db041f8e850d074e0216eaf8ecbf7fa20" alt="Awesome"](https://github.com/sindresorhus/awesome)
[data:image/s3,"s3://crabby-images/a1b25/a1b25f79526aac37c7b55b1fdfdaa392f145fb53" alt="Build"]()
[data:image/s3,"s3://crabby-images/beee0/beee0be7605fc131efa4e8dd57771feb3c42635b" alt="Platform"]()
[data:image/s3,"s3://crabby-images/6462f/6462f84b18c899ef3574de9b6c0d3d08ef8094e4" alt="Platform"]()
[data:image/s3,"s3://crabby-images/4de01/4de017c80632ab45011d722b09f1c098439867fe" alt="Language"]()
[data:image/s3,"s3://crabby-images/8fdda/8fddad9a4760761b8068b435dc0d1b096d89447a" alt="SPM"]()
[data:image/s3,"s3://crabby-images/fd432/fd43213bb59a161ac6c4afe58ccd16987c6acfd9" alt="License"]()**Last Update: 29/December/2019.**
data:image/s3,"s3://crabby-images/306b4/306b41fd7bdbf139d03e0d06e33e24e9b641af39" alt=""
### If you like the project, please give it a star ⭐ It will show the creator your appreciation and help others to discover the repo.
# ✍️ About
📄 Column Text View is an adaptive UI component that renders text in columns, horizontally [iOS 12, UIKit, TextKit, SwiftUI].# 📺 Demo
Please wait while the `.gif` files are loading...
![]()
# 🍱 Features
- **Configurable**
- There are a number of configurable properties and you can use, such as, you can specify the number of columns for the supplied text, specify column spacing, paddings and other properties
- **Adaptive**
- The underlying text container adjusts its size to support the needed amount of space for the supplied text
- **SwiftUI Compatable**
- You can use a dedicated wrapper called `ColumnedTextView` to use the componet with `SwiftUI`
- **Ease of Use**
- Instantiate a single instane of `ColumnTextView` or `ColumnedTextView` (for `SwiftUI` ), setup the parent view and supply some text
- **Designable and Inspectable**
- You can use `.storyboard` or `.xib` files to configure the component without touching code (well, almost)# 📚 Usage
The first thing you need to do is to prepare the UI component. The following example demostrates the programmatic approach, where the component is instantiated without `.storyboard` or `.xib` outlets:
```swift
// 1
let columnTextView = ColumnTextView(frame: view.bounds, .columns(2))
columnTextView.autoresizingMask = [.flexibleWidth, .flexibleHeight]
columnTextView.backgroundColor = .white
parentView.addSubview(columnTextView)// 2
columnTextView.attributedText = attributedString
```
- (1) The first part is instantiation and setup. Here we have pretty usual things happenning, nothing exotic 🌴. You can specify the way the columns should be created. Here you have two options: to use `.absolute(***UInt16***)`, where the associated parameter is a single column `width` in points or to use `.columns(***UInt16***)`, where the associated parameter is a positive integer number that specifies the exact number of columns that should be created for the current screen's `width`.
- (2) The next part is about the text `attachment`. You simply create an instance of `NSAttributedString`, configure it as you'd like and that's it.You can change the `attributedText` property, the results will be correspondigly reflected and specify all `four` paddings for `top, right, bottom and left` sides of the component.
# 🏗 Installation
## Swift Package Manager
### Xcode 11+
1. Open `MenuBar` → `File` → `Swift Packages` → `Add Package Dependency...`
2. Paste the package repository url `https://github.com/jVirus/column-text-view-ui` and hit `Next`.
3. Select the installment rules.After specifying which version do you want to install, the package will be downloaded and attached to your project.
### Package.swift
If you already have a `Package.swift` or you are building your own package simply add a new dependency:```swift
dependencies: [
.package(url: "`https://github.com/jVirus/column-text-view-ui", from: "1.0.0")
]
```## Manual
You can always use copy-paste the sources method 😄. Or you can compile the framework and include it with your project.# 🙋♀️🙋♂️ Contributing
Your contributions are always appreciated. There are many ways how you help with the project:- You can suggest something
- You can write additional documentation or sample codes
- Implement a new feature
- Fix a bug
- Help to maintain by answering to the questions (if any) that other folks have
- etc.Overall guidelies are:
- Please, discuss a feature or a major source change/addition before spending time and creating a pool requested via issues.
- Create a separate branch and make sure that your code compiles and does not produce errors and warnings.
- Please, don't be upset if it takes a while to review your code or receive an answer.# 👨💻 Author
[Astemir Eleev](https://github.com/jVirus)# 🔖 Licence
The project is available under [MIT Licence](https://github.com/jVirus/column-text-view-ui/blob/master/LICENSE)