Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/shaps80/markdowntext
A native SwiftUI view for rendering Markdown text in an iOS or macOS app
https://github.com/shaps80/markdowntext
ios macos markdown swift swiftui
Last synced: 3 months ago
JSON representation
A native SwiftUI view for rendering Markdown text in an iOS or macOS app
- Host: GitHub
- URL: https://github.com/shaps80/markdowntext
- Owner: shaps80
- License: mit
- Created: 2022-09-06T09:44:37.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2023-08-13T10:35:51.000Z (over 1 year ago)
- Last Synced: 2024-11-09T18:51:50.266Z (3 months ago)
- Topics: ios, macos, markdown, swift, swiftui
- Language: Swift
- Homepage:
- Size: 264 KB
- Stars: 148
- Watchers: 3
- Forks: 22
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
data:image/s3,"s3://crabby-images/a2115/a21158420223cbfe0458c60b054eb6b268259287" alt="macOS"
data:image/s3,"s3://crabby-images/d14b2/d14b2716ada7523486d1131e73ef8951d51975f2" alt="ios"
[data:image/s3,"s3://crabby-images/52158/52158a4c3f94c5f2771cfe908a160b5f54e45803" alt="swift"](https://swiftpackageindex.com/shaps80/MarkdownText)# MarkdownText
A native SwiftUI view for rendering Markdown text in an iOS or macOS app.
## Preview
data:image/s3,"s3://crabby-images/ed318/ed318a8ef1f03106d8fa97b8a617b9189326eeee" alt="Markdown Text Screenshot"
## Sponsor
Building useful libraries like these, takes time away from my family. I build these tools in my spare time because I feel its important to give back to the community. Please consider [Sponsoring](https://github.com/sponsors/shaps80) me as it helps keep me working on useful libraries like these 😬
You can also give me a follow and a 'thanks' anytime.
[data:image/s3,"s3://crabby-images/e4095/e40952985be36ebea43d76be85d6559194c707d5" alt="Twitter"](http://twitter.com/shaps)
## Supported Markdown
- Headings
- Paragraphs
- Quotes
- Inline formatting
- Strong/Bold
- Emphasis/Italic
- Strikethrough
- Code
- Links (non interactive only)
- Lists
- Ordered
- Unordered
- Checklist (GitHub style)
- Thematic Breaks
- Code Blocks
- Images
- A full backport of `AsyncImage` is included
## Features**Style APIs**
Adopting the familiar SwiftUI style-based APIs, you can customize the appearance of almost all markdown elements either individually or composed.
```swift
struct CustomUnorderedBullets: UnorderedListBulletMarkdownStyle {
func makeBody(configuration: Configuration) -> some View {
// you can also provide a completely new View if preferred 👍
configuration.label
.foregroundColor(.blue)
}
}
```You can even customize animations since the library is composed of 100% SwiftUI elements only.
```swift
struct ScaledImageStyle: ImageMarkdownStyle {
// image will scale up as its loaded, moving content out of the way
func makeBody(configuration: Configuration) -> some View {
configuration.label
.transition(.scale)
}
}
```Modifiers for styling and visibility can also be placed anywhere in your SwiftUI hierarchy, just as you'd expect:
```
NavigationView {
MarkdownText(markdown)
}
// Styling
.markdownQuoteStyle(.inset)
.markdownOrderedListBulletStyle(.tinted)
.markdownImageStyle(.animated)// Visibility
.markdownCode(.visible)
.markdownThematicBreak(.hidden)
```## Demo App
A [MarkdownText Demo](https://github.com/shaps80/MarkdownTextDemo) is also available to better showcase the libraries capabilities.
## Usage
Using the view couldn't be easier:
```swift
MarkdownText("Some **markdown** text")
LazyMarkdownText(someMassiveMarkdownText)
```There's even a `LazyMarkdownText` view that loads its view's lazily for those cases where you need improved scrolling and loading performance.
## Installation
You can install manually (by copying the files in the `Sources` directory) or using Swift Package Manager (**preferred**)
To install using Swift Package Manager, add this to the `dependencies` section of your `Package.swift` file:
`.package(url: "https://github.com/shaps80/MarkdownText.git", .upToNextMinor(from: "1.0.0"))`