Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fredrikburmester/streamyfin
A Jellyfin client build with Expo
https://github.com/fredrikburmester/streamyfin
Last synced: about 1 month ago
JSON representation
A Jellyfin client build with Expo
- Host: GitHub
- URL: https://github.com/fredrikburmester/streamyfin
- Owner: fredrikburmester
- License: mpl-2.0
- Created: 2024-07-31T21:20:53.000Z (6 months ago)
- Default Branch: master
- Last Pushed: 2024-12-05T17:10:46.000Z (about 1 month ago)
- Last Synced: 2024-12-05T17:21:19.386Z (about 1 month ago)
- Language: TypeScript
- Homepage:
- Size: 35.6 MB
- Stars: 1,145
- Watchers: 10
- Forks: 33
- Open Issues: 95
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-repositories - fredrikburmester/streamyfin - A Jellyfin client build with Expo (TypeScript)
README
# ๐บ Streamyfin
Welcome to Streamyfin, a simple and user-friendly Jellyfin client built with Expo. If you're looking for an alternative to other Jellyfin clients, we hope you'll find Streamyfin to be a useful addition to your media streaming toolbox.
## ๐ Features
- ๐ **Skp intro / credits support**
- ๐ผ๏ธ **Trickplay images**: The new golden standard for chapter previews when seeking.
- ๐บ **Picture in Picture** (iPhone only): Watch movies in PiP mode on your iPhone.
- ๐ **Background audio**: Stream music in the background, even when locking the phone.
- ๐ฅ **Download media** (Experimental): Save your media locally and watch it offline.
- ๐ก **Chromecast** (Experimental): Cast your media to any Chromecast-enabled device.## ๐งช Experimental Features
Streamyfin includes some exciting experimental features like media downloading and Chromecast support. These are still in development, and we appreciate your patience and feedback as we work to improve them.
### Downloading
Downloading works by using ffmpeg to convert an HLS stream into a video file on the device. This means that you can download and view any file you can stream! The file is converted by Jellyfin on the server in real time as it is downloaded. This means a **bit longer download times** but supports any file that your server can transcode.
### Chromecast
Chromecast support is still in development, and we're working on improving it. Currently, it supports casting videos and audio, but we're working on adding support for subtitles and other features.
## Plugins
In Streamyfin we have built-in support for a few plugins. These plugins are not required to use Streamyfin, but they add some extra functionality.
### Collection rows
Jellyfin collections can be shown as rows or carousel on the home screen.
The following tags can be added to a collection to provide this functionality.Available tags:
- sf_promoted: will make the collection a row at home
- sf_carousel: will make the collection a carousel on home.A plugin exists to create collections based on external sources like mdblist. This make the automatic process of managing collections such as trending, most watched, etc.
See [Collection Import Plugin](https://github.com/lostb1t/jellyfin-plugin-collection-import) for more info.### Jellysearch
[Jellysearch](https://gitlab.com/DomiStyle/jellysearch) now works with Streamyfin! ๐
> A fast full-text search proxy for Jellyfin. Integrates seamlessly with most Jellyfin clients.
## Roadmap for V1
Check out our [Roadmap](https://github.com/users/fredrikburmester/projects/5) to see what we're working on next. We are always open for feedback and suggestions, so please let us know if you have any ideas or feature requests.
## Get it now
Or download the APKs [here on GitHub](https://github.com/fredrikburmester/streamyfin/releases) for Android.
### Beta testing
Get the latest updates by using the TestFlight version of the app.
## ๐ Getting Started
### Prerequisites
- Ensure you have an active Jellyfin server.
- Make sure your device is connected to the same network as your Jellyfin server.## ๐ Contributing
We welcome any help to make Streamyfin better. If you'd like to contribute, please fork the repository and submit a pull request. For major changes, it's best to open an issue first to discuss your ideas.
### Development info
1. Use node `20`
2. Install dependencies `bun i`
3. Create an expo dev build by running `npx expo run:ios` or `npx expo run:android`.## Extended chromecast controls
Add this to AppDelegate.mm:
```
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
// @generated begin react-native-google-cast-didFinishLaunchingWithOptions - expo prebuild (DO NOT MODIFY) sync-8901be60b982d2ae9c658b1e8c50634d61bb5091
#if __has_include()
...[GCKCastContext sharedInstance].useDefaultExpandedMediaControls = true;`
#endif
```Add this to Info.plist:
```
NSBonjourServices_googlecast._tcp
_CC1AD845._googlecast._tcpNSLocalNetworkUsageDescription
${PRODUCT_NAME} uses the local network to discover Cast-enabled devices on your WiFi network.
```## ๐ License
Streamyfin is licensed under the Mozilla Public License 2.0 (MPL-2.0).
This means you are free to use, modify, and distribute this software. The MPL-2.0 is a copyleft license that allows for more flexibility in combining the software with proprietary code.
Key points of the MPL-2.0:- You can use the software for any purpose
- You can modify the software and distribute modified versions
- You must include the original copyright and license notices
- You must disclose your source code for any modifications to the covered files
- Larger works may combine MPL code with code under other licenses
- MPL-licensed components must remain under the MPL, but the larger work can be under a different license
- For the full text of the license, please see the LICENSE file in this repository.## ๐ Connect with Us
Join our Discord: [https://discord.gg/BuGG9ZNhaE](https://discord.gg/BuGG9ZNhaE)
If you have questions or need support, feel free to reach out:
- GitHub Issues: Report bugs or request features here.
- Email: [[email protected]](mailto:[email protected])## ๐ Credits
Streamyfin is developed by Fredrik Burmester and is not affiliated with Jellyfin. The app is built with Expo, React Native, and other open-source libraries.
## โจ Acknowledgements
I'd like to thank the following people and projects for their contributions to Streamyfin:
- [Reiverr](https://github.com/aleksilassila/reiverr) for great help with understanding the Jellyfin API.
- [Jellyfin TS SDK](https://github.com/jellyfin/jellyfin-sdk-typescript) for the TypeScript SDK.
- The Jellyfin devs for always being helpful in the Discord.## Star History
[![Star History Chart](https://api.star-history.com/svg?repos=fredrikburmester/streamyfin&type=Date)](https://star-history.com/#fredrikburmester/streamyfin&Date)