Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/netless-io/flat
Project flat is the Web, Windows and macOS client of Agora Flat open source classroom.
https://github.com/netless-io/flat
agora agora-flat cloud-recording e-class e-learning electron flat online-classroom virtual-classroom whiteboard
Last synced: 3 days ago
JSON representation
Project flat is the Web, Windows and macOS client of Agora Flat open source classroom.
- Host: GitHub
- URL: https://github.com/netless-io/flat
- Owner: netless-io
- License: mit
- Created: 2020-08-26T02:21:53.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2024-09-20T02:28:19.000Z (3 months ago)
- Last Synced: 2024-10-29T15:04:52.931Z (about 1 month ago)
- Topics: agora, agora-flat, cloud-recording, e-class, e-learning, electron, flat, online-classroom, virtual-classroom, whiteboard
- Language: TypeScript
- Homepage: https://flat.whiteboard.agora.io
- Size: 69.7 MB
- Stars: 5,715
- Watchers: 76
- Forks: 825
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
- awesome - netless-io/flat - Project flat is the Web, Windows and macOS client of Agora Flat open source classroom. (TypeScript)
- awesome-nas - Agora Flat - io/flat?label= "title")|![图](https://img.shields.io/github/last-commit/netless-io/flat?label= "title")|![图](https://img.shields.io/github/release-date/netless-io/flat?label= "title")|![图](https://img.shields.io/github/license/netless-io/flat?label= "title")|![图](https://img.shields.io/github/stars/netless-io/flat?label=&style=flat "title")|![图](https://img.shields.io/github/languages/top/netless-io/flat "title")| (Work)
- awesome-github-star - flat - io | 4992 | (TypeScript)
README
## Features
- Real-time interaction
- Multifunctional interactive whiteboard
- Real-time video/audio chat (RTC)
- Real-time messaging (RTM)
- Login via
- GitHub
- Classroom management
- Join, create and schedule classrooms
- Support periodic rooms
- Classroom recording and replaying
- Whiteboard replaying
- Cloud recording for video and audio
- Messaging replaying
- Cloud Storage for multi-media courseware
- Screen sharing## Quickstart
You can build and run the Flat client without a server. This repository includes the following projects:
- [Flat Electron client](./desktop) is an Electron implementation of Flat client.
- [Flat Web client](./web) is a web implementation of Flat client.### Installation
> If you don't have pnpm installed:
>
> ```bash
> npm i -g pnpm
> ```Clone or fork this project, at project root run:
```bash
pnpm i
```### Build and run Flat Electron client
Run the following commands at the root of the repository to build and run Flat Electron client.
```shell
pnpm start
```You can use one of the following methods to package your executable:
- Run `pnpm ship` at project root to package based on current system.
- Alternatively, run `pnpm ship:mac` or `pnpm ship:win` at project root to package for a specified system.### Build and run Flat Web client
Run the following command at the root of the repository to build and run Flat web client.
```shell
pnpm start:web
```Alternatively, run the following command:
```shell
cd ./web/flat-web/ && pnpm start
```UI and business logic are separated in Flat. You can view and develop Flat components UI via Storybook. You can either visit the ([Online address][flat-storybook]) or run `pnpm storybook` at the root of the repository to run Storybook locally.
## References
- [Release Version Description](docs/releases)
- [Environment Variables Reference](docs/env/README.md)
- [Debugging Flat](docs/debugging/README.md)## Related Projects
- [Flat Android client][flat-android]
- [Flat Server][flat-server]
- [Flat Website HomePage][flat-homepage]## Contributing
Writing code is great, but there are many other ways to make meaningful contributions to the project:
- [Improve documentation](CONTRIBUTING.md#improve-documentation)
- [Improve issues](CONTRIBUTING.md#improve-issues)
- [Give feedback on issues](CONTRIBUTING.md#give-feedback-on-issues)For more info about how to contribute, see [CONTRIBUTING.md](CONTRIBUTING.md)
## Code Contributors
Thank you to all the people who already contributed to Flat!
## Disclaimer
You may use Flat for commercial purposes but please note that we do not accept customizational commercial requirements and deployment supports. Nor do we offer customer supports for commercial usage. Please head to [Flexible Classroom](https://www.agora.io/en/products/flexible-classroom) for such requirements.
## License
Copyright © Agora Corporation. All rights reserved.
Licensed under the [MIT license](LICENSE).
When using the Flat or other GitHub logos, be sure to follow the [GitHub logo guidelines][github-logo].
[flat-homepage]: https://flat.agora.io/#download
[flat-web]: https://web.flat.agora.io/
[flat-server]: https://github.com/netless-io/flat-server
[flat-android]: https://github.com/netless-io/flat-android
[flat-storybook]: https://netless-io.github.io/flat/
[github-logo]: https://github.com/logos