🚧 This project is still in heavy development. Please note that there are likely to be major API changes. Please submit issues and suggestions to us.
Univer is an open-source alternative to Google Sheets, Slides, and Docs.
Highlights:
- 📈 Univer is designed to support both spreadsheets and documents. Slides will be supported as well in the future.
- ⚙️ Univer is easily embeddable, allowing seamless integration into your applications.
- 🎇 Univer is powerful, offering a wide range of features including formulas, conditional formatting, data validation, filtering, collaborative editing, printing, import & export and more features on the horizon.
- 🔌 Univer is highly extensible, thanks to its plug-in architecture and Facade API that makes it a delight for developers to implement their unique requirements on the top of Univer.
- 💄 Univer is highly customizable, allowing you to personalize its appearance using themes. It also provides support for internationalization (i18n).
- ⚡ Univer in performant.
- ✏️ Univer boasts an efficient rendering engine based on canvas, capable of rendering various document types flawlessly. The rendering engines supports advanced typesetting features such as punctuation squeezing, text and image layout and scroll buffering.
- 🧮 Univer incorporates a lightning-fast formula engine that can operate in Web Workers or even on the server side.
- 🌌 Univer is a highly integrated system. Documents, spreadsheets and slides can interoperate with each others and even rendered on the same canvas, allowing information and data flow within Univer.
Sheets Opened: cell styles, formulas. First quarter: conditional formatting, data validation, search and replace. Second quarter (tentative): floating pictures, filtering, sorting, annotations, charts, pivot tables, super tables (tables), shapes |
|
Sheets Multi Multiple Univer instances can be created on a page to allow interoperability between tables |
|
Sheets Uniscript In Univer Sheets, you can directly use JavaScript syntax to operate the data in the table to achieve automation. |
|
Sheets Big Data Loading 10 million cells of data, completed within 500ms |
|
Sheets Collaboration (Pro Feature) Please open two windows or invite friends to experience Univer Sheets collaboration together |
|
Sheets Collaboration Playground (Pro Feature) Demonstrate the process of collaboration. After A edits the form, how does B process it? Here is an interesting experiment |
|
Sheets Import/Export (Pro Feature) Supports xlsx file import and export |
|
Sheets Print (Pro Feature) Experience the HD printing capabilities of Univer Sheets |
|
Docs Already open: ordered and unordered lists, paragraph settings, mixed graphics and text, multi-column/single column display in sections (tentative): hyperlinks, comments, tables, charts |
|
Docs Multi Multiple Univer instances can be created in a page so that doc can interoperate. |
|
Docs Uniscript You can directly use JavaScript syntax to manipulate content in Univer Docs |
|
Docs Big Data 1 million word Docs loading demo |
|
Docs Collaboration (Pro Feature) Please open two windows or invite friends to experience Univer Docs collaboration together |
|
Docs Collaboration Playground (Pro Feature) Demonstrate the process of collaboration. After A edits the document, how does B process it? Here is an interesting experiment |
|
Slides A canvas presentation containing graphic text, floating pictures, tables and other elements |
|
Zen Mode The cell of Sheet is a Doc? |
|
Univer (SaaS version) With Univer, we enable users to create 3 forms of page as they wish. By merging sheet, doc and slide's capabilities together, Univer empowers individuals and teams to create, organize and streamline workflows effortlessly. |
We recommend to import Univer as a npm package. Please checkout the Quick Start section on the documentation website. We also have an online playground which can help you preview Univer without setting up the development environment.
Univer bases on a plugin architecture. You can install the following packages to enhance the functionality of Univer.
Name | Description | Version |
---|---|---|
core | Implements plugin system and architecture of Univer. It also provides basic services and models of different types of documents. | |
data-validation | Implements data validation features in Univer. | |
design | Implements the design system on Univer. It provides CSS and a component kit based on React. | |
docs | Implements basic logics of rich text editing features. It also facilitates text editing in other types of documents. | |
docs-ui | Provides user interface of Univer Documents | |
engine-formula | It implements a rendering engine based on Canvas and is extensible for | |
engine-numfmt | It implements a number format engine. | |
engine-render | It implements a rendering engine based on canvas context2d. | |
facade | It serves as an API layer to make it easier to use Univer | |
find-replace | It implements find and replace features in Univer. | |
network | It implements network services based on WebSocket and HTTP. | |
rpc | It implements a RPC mechanism and methods to sync data between different replicas of Univer documents. | |
sheets | Basic logics of spreadsheet features. | |
sheets-conditional-formatting | It implements conditional formatting in Univer Spreadsheets. | |
sheets-conditional-formatting-ui | It implements conditional formatting in Univer Spreadsheets. | |
sheets-data-validation | It implements data validation in Univer Spreadsheets. | |
sheets-find-replace | It implements find and replace features in Univer Spreadsheets. | |
sheets-formula | It implements formula in spreadsheets. | |
sheets-numfmt | It implements number format in spreadsheets. | |
sheets-zen-editor | It implements Zen editing mode in spreadsheets. | |
sheets-ui | Provides user interface of Univer Spreadsheets | |
ui | Implements basic user interactions with Univer and workbench layout based on React. | |
uniscript (experimental) | Implements a DSL based on Typescript that empowers users to accomplish more sophisticated tasks |
We appreciate any kinds of contributing. You can submit issues or feature requests to us. Please read our contributing guide first.
If you would like to contribute code to Univer, please refer to the contributing guide as well. It would guide you through the process of setting up the development environment and submitting a pull request.
The growth and development of the Univer project rely on the support of its backers and sponsors. If you are interested in supporting our project, we kindly invite you to consider becoming a sponsor. You can sponsor us through Open Collective.
Thanks to our sponsors, just part of them are listed here because of the space limit, ranking is no particular order:
Univer is distributed under the terms of the Apache-2.0 license.
Copyright © 2019-2024 Shanghai DreamNum Technology Co., Ltd. All rights reserved