Description
Trix is an open-source project from Basecamp, the creators of Ruby on Rails. Millions of people trust their text to Basecamp, and we built Trix to give them the best possible editing experience. See Trix in action in the all-new Basecamp 3.
trix alternatives and similar libraries
Based on the "Editors" category.
Alternatively, view trix alternatives based on common mentions on social networks and blogs.
-
medium-editor
Medium.com WYSIWYG editor clone. Uses contenteditable API to implement a rich text solution. -
TinyMCE
The world's #1 JavaScript library for rich text editing. Available for React, Vue and Angular -
CKEditor 5
Powerful rich text editor framework with a modular architecture, modern integrations, and features like collaborative editing. -
SimpleMDE
A simple, beautiful, and embeddable JavaScript Markdown editor. Delightful editing for beginners and experts alike. Features built-in autosaving and spell checking. -
wysihtml5
DISCONTINUED. Open source rich text editor based on HTML5 and the progressive-enhancement approach. Uses a sophisticated security concept and aims to generate fully valid HTML5 markup by preventing unmaintainable tag soups and inline styles. -
EpicEditor
EpicEditor is an embeddable JavaScript Markdown editor with split fullscreen editing, live previewing, automatic draft saving, offline support, and more. For developers, it offers a robust API, can be easily themed, and allows you to swap out the bundled Markdown parser with anything you throw at it. -
Materio Free Vuetify VueJS Admin Template
Production Ready, Carefully Crafted, Extensive Vuetifty Free Admin Template š¤© -
Bangle.dev
Collection of higher level rich text editing tools. It powers the local only note taking app https://bangle.io -
Everright-formEditor
:guide_dog: Powerful lowcode|vue form editor,generator,designer,builder library. It provides an easy way to create custom forms. The project is extensible, easy to use and configure, and provides many commonly used form components and functions(vueåÆč§åä½ä»£ē č”Øåč®¾č®”åØćč”Øåē¼č¾åØćelement-plus vantč”Øåč®¾č®”) -
data-structure-typed
Javascript Data Structure & TypeScript Data Structure. Heap, Binary Tree, Red Black Tree, Linked List, Deque, Trie, HashMap, Directed Graph, Undirected Graph, Binary Search Tree, AVL Tree, Priority Queue, Graph, Queue, Tree Multiset, Singly Linked List, Doubly Linked List, Max Heap, Max Priority Queue, Min Heap, Min Priority Queue, Stack. -
React Chat UI
Build your own chat UI with React Chat UI components in a few minutes. React Chat UI Kit from minchat.io is an open source UI toolkit for developing web chat applications.
InfluxDB - Purpose built for real-time analytics at any scale.
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of trix or a related project?
README
Trix
A Rich Text Editor for Everyday Writing
Compose beautifully formatted text in your web application. Trix is a WYSIWYG editor for writing messages, comments, articles, and listsāthe simple documents most web apps are made of. It features a sophisticated document model, support for embedded attachments, and outputs terse and consistent HTML.
Trix is an open-source project from Basecamp, the creators of Ruby on Rails. Millions of people trust their text to Basecamp, and we built Trix to give them the best possible editing experience. See Trix in action in the all-new Basecamp 3.
Different By Design
Most WYSIWYG editors are wrappers around HTMLās contenteditable
and execCommand
APIs, designed by Microsoft to support live editing of web pages in Internet Explorer 5.5, and eventually reverse-engineered and copied by other browsers.
Because these APIs were never fully specified or documented, and because WYSIWYG HTML editors are enormous in scope, each browserās implementation has its own set of bugs and quirks, and JavaScript developers are left to resolve the inconsistencies.
Trix sidesteps these inconsistencies by treating contenteditable
as an I/O device: when input makes its way to the editor, Trix converts that input into an editing operation on its internal document model, then re-renders that document back into the editor. This gives Trix complete control over what happens after every keystroke, and avoids the need to use execCommand
at all.
Built for the Modern Web
Trix supports all evergreen, self-updating desktop and mobile browsers.
Trix is built with emerging web standards, notably Custom Elements, Mutation Observer, and Promises. Eventually we expect all browsers to implement these standards. In the meantime, Trix includes polyfills for missing functionality.
Getting Started
Include the bundled trix.css
and trix.js
files in the <head>
of your page.
<head>
ā¦
<link rel="stylesheet" type="text/css" href="trix.css">
<script type="text/javascript" src="trix.js"></script>
</head>
trix.css
includes default styles for the Trix toolbar, editor, and attachments. Skip this file if you prefer to define these styles yourself.
To use your own polyfills, or to target only browsers that support all of the required standards, include trix-core.js
instead.
Creating an Editor
Place an empty <trix-editor></trix-editor>
tag on the page. Trix will automatically insert a separate <trix-toolbar>
before the editor.
Like an HTML <textarea>
, <trix-editor>
accepts autofocus
and placeholder
attributes. Unlike a <textarea>
, <trix-editor>
automatically expands vertically to fit its contents.
Integrating With Forms
To submit the contents of a <trix-editor>
with a form, first define a hidden input field in the form and assign it an id
. Then reference that id
in the editorās input
attribute.
<form ā¦>
<input id="x" type="hidden" name="content">
<trix-editor input="x"></trix-editor>
</form>
Trix will automatically update the value of the hidden input field with each change to the editor.
Populating With Stored Content
To populate a <trix-editor>
with stored content, include that content in the associated input elementās value
attribute.
<form ā¦>
<input id="x" value="Editor content goes here" type="hidden" name="content">
<trix-editor input="x"></trix-editor>
</form>
Always use an associated input element to safely populate an editor. Trix wonāt load any HTML content inside a <trix-editor>ā¦</trix-editor>
tag.
Styling Formatted Content
To ensure what you see when you edit is what you see when you save, use a CSS class name to scope styles for Trix formatted content. Apply this class name to your <trix-editor>
element, and to a containing element when you render stored Trix content for display in your application.
<trix-editor class="trix-content"></trix-editor>
<div class="trix-content">Stored content here</div>
The default trix.css
file includes styles for basic formatted contentāincluding bulleted and numbered lists, code blocks, and block quotesāunder the class name trix-content
. We encourage you to use these styles as a starting point by copying them into your applicationās CSS with a different class name.
Storing Attached Files
Trix automatically accepts files dragged or pasted into an editor and inserts them as attachments in the document. Each attachment is considered pending until you store it remotely and provide Trix with a permanent URL.
To store attachments, listen for the trix-attachment-add
event. Upload the attached files with XMLHttpRequest yourself and set the attachmentās URL attribute upon completion. See the attachment example for detailed information.
If you donāt want to accept dropped or pasted files, call preventDefault()
on the trix-file-accept
event, which Trix dispatches just before the trix-attachment-add
event.
Editing Text Programmatically
You can manipulate a Trix editor programmatically through the Trix.Editor
interface, available on each <trix-editor>
element through its editor
property.
var element = document.querySelector("trix-editor")
element.editor // is a Trix.Editor instance
Understanding the Document Model
The formatted content of a Trix editor is known as a document, and is represented as an instance of the Trix.Document
class. To get the editorās current document, use the editor.getDocument
method.
element.editor.getDocument() // is a Trix.Document instance
You can convert a document to an unformatted JavaScript string with the document.toString
method.
var document = element.editor.getDocument()
document.toString() // is a JavaScript string
Immutability and Equality
Documents are immutable values. Each change you make in an editor replaces the previous document with a new document. Capturing a snapshot of the editorās content is as simple as keeping a reference to its document, since that document will never change over time. (This is how Trix implements undo.)
To compare two documents for equality, use the document.isEqualTo
method.
var document = element.editor.getDocument()
document.isEqualTo(element.editor.getDocument()) // true
Getting and Setting the Selection
Trix documents are structured as sequences of individually addressable characters. The index of one character in a document is called a position, and a start and end position together make up a range.
To get the editorās current selection, use the editor.getSelectedRange
method, which returns a two-element array containing the start and end positions.
element.editor.getSelectedRange() // [0, 0]
You can set the editorās current selection by passing a range array to the editor.setSelectedRange
method.
// Select the first character in the document
element.editor.setSelectedRange([0, 1])
Collapsed Selections
When the start and end positions of a range are equal, the range is said to be collapsed. In the editor, a collapsed selection appears as a blinking cursor rather than a highlighted span of text.
For convenience, the following calls to setSelectedRange
are equivalent when working with collapsed selections:
element.editor.setSelectedRange(1)
element.editor.setSelectedRange([1])
element.editor.setSelectedRange([1, 1])
Directional Movement
To programmatically move the cursor or selection through the document, call the editor.moveCursorInDirection
or editor.expandSelectionInDirection
methods with a direction argument. The direction can be either "forward"
or "backward"
.
// Move the cursor backward one character
element.editor.moveCursorInDirection("backward")
// Expand the end of the selection forward by one character
element.editor.expandSelectionInDirection("forward")
Converting Positions to Pixel Offsets
Sometimes you need to know the x and y coordinates of a character at a given position in the editor. For example, you might want to absolutely position a pop-up menu element below the editorās cursor.
Call the editor.getClientRectAtPosition
method with a position argument to get a DOMRect
instance representing the left and top offsets, width, and height of the character at the given position.
var rect = element.editor.getClientRectAtPosition(0)
[rect.left, rect.top] // [17, 49]
Inserting and Deleting Text
The editor interface provides methods for inserting, replacing, and deleting text at the current selection.
To insert or replace text, begin by setting the selected range, then call one of the insertion methods below. Trix will first remove any selected text, then insert the new text at the start position of the selected range.
Inserting Plain Text
To insert unformatted text into the document, call the editor.insertString
method.
// Insert āHelloā at the beginning of the document
element.editor.setSelectedRange([0, 0])
element.editor.insertString("Hello")
Inserting HTML
To insert HTML into the document, call the editor.insertHTML
method. Trix will first convert the HTML into its internal document model. During this conversion, any formatting that cannot be represented in a Trix document will be lost.
// Insert a bold āHelloā at the beginning of the document
element.editor.setSelectedRange([0, 0])
element.editor.insertHTML("<strong>Hello</strong>")
Inserting a File
To insert a DOM File
object into the document, call the editor.insertFile
method. Trix will insert a pending attachment for the file as if you had dragged and dropped it onto the editor.
// Insert the selected file from the first file input element
var file = document.querySelector("input[type=file]").file
element.editor.insertFile(file)
Inserting a Content Attachment
Content attachments are self-contained units of HTML that behave like files in the editor. They can be moved or removed, but not edited directly, and are represented by a single character position in the document model.
To insert HTML as an attachment, create a Trix.Attachment
with a content
attribute and call the editor.insertAttachment
method. The HTML inside a content attachment is not subject to Trixās document conversion rules and will be rendered as-is.
var attachment = new Trix.Attachment({ content: '<span class="mention">@trix</span>' })
element.editor.insertAttachment(attachment)
Inserting a Line Break
To insert a line break, call the editor.insertLineBreak
method, which is functionally equivalent to pressing the return key.
// Insert āHello\nā
element.editor.insertString("Hello")
element.editor.insertLineBreak()
Deleting Text
If the current selection is collapsed, you can simulate deleting text before or after the cursor with the editor.deleteInDirection
method.
// āBackspaceā the first character in the document
element.editor.setSelectedRange([1, 1])
element.editor.deleteInDirection("backward")
// Delete the second character in the document
element.editor.setSelectedRange([1, 1])
element.editor.deleteInDirection("forward")
To delete a range of text, first set the selected range, then call editor.deleteInDirection
with either direction as the argument.
// Delete the first five characters
element.editor.setSelectedRange([0, 4])
element.editor.deleteInDirection("forward")
Working With Attributes and Nesting
Trix represents formatting as sets of attributes applied across ranges of a document.
By default, Trix supports the inline attributes bold
, italic
, href
, and strike
, and the block-level attributes heading1
, quote
, code
, bullet
, and number
.
Applying Formatting
To apply formatting to the current selection, use the editor.activateAttribute
method.
element.editor.insertString("Hello")
element.editor.setSelectedRange([0, 5])
element.editor.activateAttribute("bold")
To set the href
attribute, pass a URL as the second argument to editor.activateAttribute
.
element.editor.insertString("Trix")
element.editor.setSelectedRange([0, 4])
element.editor.activateAttribute("href", "https://trix-editor.org/")
Removing Formatting
Use the editor.deactivateAttribute
method to remove formatting from a selection.
element.editor.setSelectedRange([2, 4])
element.editor.deactivateAttribute("bold")
Formatting With a Collapsed Selection
If you activate or deactivate attributes when the selection is collapsed, your formatting changes will apply to the text inserted by any subsequent calls to editor.insertString
.
element.editor.activateAttribute("italic")
element.editor.insertString("This is italic")
Adjusting the Nesting Level
To adjust the nesting level of quotes, bulleted lists, or numbered lists, call the editor.increaseNestingLevel
and editor.decreaseNestingLevel
methods.
element.editor.activateAttribute("quote")
element.editor.increaseNestingLevel()
element.editor.decreaseNestingLevel()
Using Undo and Redo
Trix editors support unlimited undo and redo. Successive typing and formatting changes are consolidated together at five-second intervals; all other input changes are recorded individually in undo history.
Call the editor.undo
and editor.redo
methods to perform an undo or redo operation.
element.editor.undo()
element.editor.redo()
Changes you make through the editor interface will not automatically record undo entries. You can save your own undo entries by calling the editor.recordUndoEntry
method with a description argument.
element.editor.recordUndoEntry("Insert Text")
element.editor.insertString("Hello")
Loading and Saving Editor State
Serialize an editorās state with JSON.stringify
and restore saved state with the editor.loadJSON
method. The serialized state includes the document and current selection, but does not include undo history.
// Save editor state to local storage
localStorage["editorState"] = JSON.stringify(element.editor)
// Restore editor state from local storage
element.editor.loadJSON(JSON.parse(localStorage["editorState"]))
Observing Editor Changes
The <trix-editor>
element emits several events which you can use to observe and respond to changes in editor state.
trix-before-initialize
fires when the<trix-editor>
element is attached to the DOM just before Trix installs itseditor
object.trix-initialize
fires when the<trix-editor>
element is attached to the DOM and itseditor
object is ready for use.trix-change
fires whenever the editorās contents have changed.trix-paste
fires whenever text is pasted into the editor. Thepaste
property on the event contains the pastedstring
orhtml
, and therange
of the inserted text.trix-selection-change
fires any time the selected range changes in the editor.trix-focus
andtrix-blur
fire when the editor gains or loses focus, respectively.trix-file-accept
fires when a file is dropped or inserted into the editor. You can access the DOMFile
object through thefile
property on the event. CallpreventDefault
on the event to prevent attaching the file to the document.trix-attachment-add
fires after an attachment is added to the document. You can access the Trix attachment object through theattachment
property on the event. If theattachment
object has afile
property, you should store this file remotely and set the attachmentās URL attribute. See the attachment example for detailed information.trix-attachment-remove
fires when an attachment is removed from the document. You can access the Trix attachment object through theattachment
property on the event. You may wish to use this event to clean up remotely stored files.
Contributing to Trix
Trix is open-source software, freely distributable under the terms of an [MIT-style license](LICENSE). The source code is hosted on GitHub.
We welcome contributions in the form of bug reports, pull requests, or thoughtful discussions in the GitHub issue tracker. Please see the [Code of Conduct](CODE_OF_CONDUCT.md) for our pledge to contributors.
Trix was created by Javan Makhmali and Sam Stephenson, with development sponsored by Basecamp.
Building From Source
Trix is written in CoffeeScript and compiled to JavaScript with Blade.
From inside a checkout of the Trix Git repository, issue the following commands to build the distributable files in dist/
:
$ bin/setup
$ bin/blade build
Developing In-Browser
You can spawn a development web server to work on Trix in a more convenient fashion. Instead of manually rebuilding the source each time, just reload a page in your browser to see your changes.
To develop in-browser, run bin/setup
and follow the displayed instructions.
Running Tests
Make sure youāre set up to build from source using the instructions above. Then run bin/blade runner
and visit the displayed URL to run the Trix test suite.
Pull Requests
Only commit changes to Trixās source (everything except the compiled files in /dist
) and leave the [VERSION](src/trix/VERSION) unchanged. We update both when publishing new releases. :heart:
Ā© 2020 Basecamp, LLC.
*Note that all licence references and agreements mentioned in the trix README section above
are relevant to that project's source code only.