6201c92de7
README: fix link to tiptap |
||
---|---|---|
.github | ||
.tx | ||
appinfo | ||
css | ||
cypress | ||
img | ||
js | ||
l10n | ||
lib | ||
src | ||
templates | ||
tests | ||
.eslintignore | ||
.eslintrc.js | ||
.gitattributes | ||
.gitignore | ||
.l10nignore | ||
.php-cs-fixer.dist.php | ||
.stylelintrc.js | ||
CHANGELOG.md | ||
COPYING | ||
Makefile | ||
README.md | ||
babel.config.js | ||
composer.json | ||
composer.lock | ||
cypress.config.js | ||
index.html | ||
jest-raw-loader.js | ||
jsconfig.json | ||
krankerl.toml | ||
package-lock.json | ||
package.json | ||
psalm.xml | ||
renovate.json | ||
vite.config.js | ||
webpack.js |
README.md
Nextcloud Text
📑 Collaborative document editing!
Features
- 📝 Simple focused writing: No distractions, only the formatting you need.
- 🙋 Work together: Share and collaborate with friends and colleagues, no matter if they use Nextcloud or not!
- 💾 Open format: Files are saved as Markdown, so you can edit them from any other text app too.
- ✊ Strong foundation: We use 🐈 tiptap which is based on 🦉 ProseMirror – huge thanks to them!
Nextcloud Text is the default text editor since Nextcloud 17. To start editing just open an existing markdown or plaintext file or create a new one.
Configuration
The rich workspaces in the file list can be disabled either by the users in the files app settings or globally by the admin with the following occ command:
occ config:app:set text workspace_available --value=0
🏗 Development setup
Currently this app requires the master branch of the Viewer app.
- ☁ Clone this app into the
apps
folder of your Nextcloud:git clone https://github.com/nextcloud/text.git
- 👩💻 In the folder of the app, run the command
make
to install dependencies and build the Javascript. - ✅ Enable the app through the app management of your Nextcloud
- 🎉 Partytime! Help fix some issues and review pull requests 👍
🧙 Advanced development stuff
To build the Javascript whenever you make changes, instead of the full make
you can also run npm run build
. Or run npm run watch
to rebuild on every file save.
🐞 Testing the app
Currently this app uses three different kinds of tests:
For testing the backend (PHP) Psalm and PHPUnit are used,
you can run the testcases (placed in tests/
) using the composer scripts psalm
and test:unit
.
For testing the frontend jest is used for unittests, whereas cypress is used for end2end testing.
The unittests are also placed in src/tests/
, the cypress tests are placed in cypress/
.
You can run the tests using the package scripts npm run test
(jest), and respective npm run test:cypress
(cypress).
Please note the cypress tests require a nextcloud server running, the if no running server is detected a docker container will be started,
this requires the current user to be in the docker
group.
Or you might set the CYPRESS_baseUrl
environment variable for a custom nextcloud server.
Adding support for other mime types
- The mime type needs to be known by Nextcloud server (see https://github.com/nextcloud/server/pull/24488 for how this can be added)
- Once that is there, please open a pull request to add them to
12df66ffdd/src/helpers/mime.js (L35-L61)
- You can test them like other mime types in cypress/e2e/files.spec.js