Pasting content from Microsoft Office
Paste from Office features let you paste content from Microsoft Word and Microsoft Excel and preserve its original structure and formatting. This is an advanced, premium paste from Office enhanced feature.
This premium feature is a part of the Productivity Pack available only for customers with a commercial license. Contact us for more details.
You can also sign up for the CKEditor Premium Features 30-day free trial to test the feature.
There is also the basic, open-source Paste from Office feature, You can read more about the differences between these two further in this guide.
# Demo
Use these sample documents to test pasting from Microsoft Office:
To test pasting from Office, download the sample documents and open them in Microsoft Office applications. Then, copy the content and paste it into the editor below.
This demo only presents a limited set of features. Visit the feature-rich editor example to see more in action.
# Content formatting support
Paste from Office enhanced retains rich content pasted from Microsoft Office applications. See below the full table of supported styles and formatting.
# Microsoft Word
Note: The name of each group in the table corresponds to the category in Wordβs βModify styleβ user interface. If a specific formatting is supported natively (without using the General HTML Support feature), a plugin name responsible for the formatting is provided in parentheses.
Please note that the basic Paste from Office feature only supports inline formatting, introduce via Word UI. It does not support Word styles.
The Paste from Office enhanced feature supports both.
Group | Formatting | Paste from Office | Premium feature Paste from Office enhanced | |
---|---|---|---|---|
Native support | With General HTML Support | |||
Font | Font family | β Yes | β
Yes (FontFamily ) |
β Yes |
Font style (weight, italic) | β Yes | β
Yes (Bold , Italic ) |
β Yes | |
Font size | β Yes | β
Yes (FontSize ) |
β Yes | |
Text color | β Yes | β
Yes (FontColor ) |
β Yes | |
Underline | β Yes | β
Yes (Underline ) [1] |
β Yes [1] | |
Advanced underline | β No | β
Yes (Underline ) [2] |
β Yes [2] | |
Emphasis mark | β No | β No | β Yes | |
Strikethrough | β Yes | β
Yes (Strikethrough ) |
β Yes | |
Double strikethrough | β No | β
Yes (Strikethrough ) [3] |
β
Yes (Strikethrough ) [3] |
|
Superscript | β Yes | β
Yes (Superscript ) |
β Yes | |
Subscript | β Yes | β
Yes (Subscript ) |
β Yes | |
Small caps | β No | β No | β Yes | |
All caps | β No | β No | β Yes | |
Hidden | β No | β No | β Yes | |
Character scale | β No | β No | β No | |
Character spacings | β No | β No | β Yes | |
Advanced typography | β No | β No | β No | |
Paragraph | Alignment | β Yes | β
Yes (Alignment ) |
β Yes |
Indentation left | β Yes | β
Yes (IndentBlock ) |
β Yes | |
Indentation right | β No | β No | β Yes | |
Spacing before | β No | β No | β Yes | |
Spacing after | β No | β No | β Yes | |
Line spacing | β No | β No | β Yes | |
Line spacing at | β No | β No | β Yes | |
No space between sameβstyle paragraphs | β No | β No | β Yes | |
Tabs | Alignment | β No | β Yes [4] | β Yes [4] |
Leader | β No | β Yes [4] | β Yes [4] | |
Borders and shading | Style | β No | β No | β Yes |
Colour | β No | β No | β Yes | |
Width | β No | β No | β Yes | |
Side | β No | β No | β Yes | |
From text | β No | β No | β Yes | |
Fill | β No | β No | β Yes | |
Pattern style | β No | β No | β Yes [5] | |
Pattern colour | β No | β No | β Yes | |
Language | Language | β No | β
Yes (TextPartLanguage ) |
β Yes |
Do not check spelling | β No | β No | β No | |
Frame | Text wrapping | β No | β No | β No |
Size | β No | β No | β No | |
Horizontal | β No | β No | β No | |
Vertical | β No | β No | β No | |
Bullet points and Numbering | General | β
Yes (List ) [7] |
β
Yes (List ) [7] |
β Yes [7] |
- [1] Underline color is ignored.
- [2] Pasted as simple underline
- [3] Pasted as single strikethrough.
- [4] Tabs are non-interactive.
- [5] Not all Word border styles have CSS counterparts.
- [6] The overall density is preserved but the pattern details are lost.
- [7] Partial support.
# Microsoft Excel
Note: The name of each group in the table corresponds to the category in the Excelβs βFormat cellsβ user interface. If a specific formatting is supported natively (without using the General HTML Support feature), a plugin name responsible for the formatting is provided in the parentheses.
Group | Formatting | Paste from Office | Premium feature Paste from Office enhanced | |
---|---|---|---|---|
Native support | With General HTML Support | |||
Alignment | Horizontal alignment | β No | β
Yes (TableCellProperties ) |
β Yes |
Vertical alignment | β No | β
Yes (TableCellProperties ) |
β Yes | |
Indent | β No | β
Yes (TableCellProperties ) |
β Yes | |
Orientation (angle) | β No | β No | β No | |
Font | Family | β No | β
Yes (FontFamily ) |
β Yes |
Style | β No | β
Yes (Bold , Italic ) |
β Yes | |
Size | β No | β
Yes (FontSize ) |
β Yes | |
Underline | β No | β
Yes (Underline ) |
β Yes | |
Advanced underline (e.g. double) | β No | β No | β No | |
Colour | β No | β
Yes (FontColor ) |
β Yes | |
Strikethrough | β No | β
Yes (Strikethrough ) |
β Yes | |
Superscript | β No | β
Yes (Superscript ) |
β Yes | |
Subscript | β No | β
Yes (Subscript ) |
β Yes | |
Border | Border color | β No | β
Yes (TableCellProperties ) |
β Yes |
Border width | β No | β
Yes (TableCellProperties ) |
β Yes | |
Border style | β No | β Yes [1] | β Yes [1] | |
Borders across cell (diagonal) | β No | β No | β No | |
Fill | Background | β No | β
Yes (TableCellProperties ) |
β Yes |
Pattern color | β No | β
Yes (TableCellProperties ) [2] |
β Yes [2] | |
Pattern style | β No | β No | β No |
- [1] Not all Excel border styles have CSS counterparts.
- [2] It overrides the cell background.
# Support for other office applications
At the current stage, the focus of @ckeditor/ckeditor5-paste-from-office
and @ckeditor/ckeditor5-paste-from-office-enhanced
packages is on supporting content that comes from Microsoft Word, Microsoft Excel, and Google Docs. However, it does not mean that pasting from other similar applications (such as Microsoft PowerPoint) is not supported.
By default, CKEditor 5 will support pasting rich-text content from these applications, however, some styles and formatting may be lost, depending on the source application. Also, other minor bugs may appear.
You can find more information regarding compatibility with other applications in this ticket.
If you think that support for any of the applications needs improvements, please add π and comments in the following issues:
Feel free to open a new feature request for other similar applications, too!
# Installation
This feature is enabled by default in the superbuild only.
To add the paste from Office enhanced feature to your editor, install @ckeditor/ckeditor5-paste-from-office
, @ckeditor/ckeditor5-paste-from-office-enhanced
, and @ckeditor/ckeditor5-html-support
packages:
npm install --save \
@ckeditor/ckeditor5-paste-from-office \
@ckeditor/ckeditor5-paste-from-office-enhanced \
@ckeditor/ckeditor5-html-support
Note that the GeneralHtmlSupport
plugin is optional but recommended for optimal pasted styles retention and accuracy. Learn more.
We highly recommend you also add other editor packages to get as much native support for pasted content as possible. You can learn more about editor features that work outβofβtheβbox with content pasted from Microsoft Office in a dedicated section. To install recommended packages, execute the following command:
npm install --save \
@ckeditor/ckeditor5-alignment \
@ckeditor/ckeditor5-basic-styles \
@ckeditor/ckeditor5-font \
@ckeditor/ckeditor5-indent \
@ckeditor/ckeditor5-table \
@ckeditor/ckeditor5-language
Then add the PasteFromOffice
, PasteFromOfficeEnhanced
, and GeneralHtmlSupport
plugins to your plugin list as well as other editor features that support content pasted from Microsoft Office (Bold
, Italic
, FontColor
, Indent
, etc.):
import { PasteFromOffice } from '@ckeditor/ckeditor5-paste-from-office';
import { PasteFromOfficeEnhanced } from '@ckeditor/ckeditor5-paste-from-office-enhanced';
import { GeneralHtmlSupport } from '@ckeditor/ckeditor5-html-support';
import { Alignment } from '@ckeditor/ckeditor5-alignment';
import { Bold, Italic, Underline, Strikethrough, Subscript, Superscript } from '@ckeditor/ckeditor5-basic-styles';
import { FontColor, FontBackgroundColor, FontFamily, FontSize } from '@ckeditor/ckeditor5-font';
import { Indent } from '@ckeditor/ckeditor5-indent';
import { Table, TableProperties, TableCellProperties } from '@ckeditor/ckeditor5-table';
import { TextPartLanguage } from '@ckeditor/ckeditor5-language';
// Other imports...
ClassicEditor
.create( document.querySelector( '#editor' ), {
plugins: [
// Load the open-source feature.
PasteFromOffice,
// Load the enhanced feature.
PasteFromOfficeEnhanced,
// Load the recommended General HTML Support feature.
GeneralHtmlSupport,
// Load other recommended editor features.
Alignment, Bold, Italic, Underline, Strikethrough, Subscript, Superscript,
FontColor, FontBackgroundColor, FontFamily, FontSize, Indent,
Table, TableProperties, TableCellProperties,
TextPartLanguage,
/* ... */
],
// Provide activation key (see explanation below).
licenseKey: 'your-license-key'
// See the "Configuration" section below to learn how to configure
// the editor for the best performance.
// ...
} )
.then( /* ... */ )
.catch( /* ... */ );
Finally, update the configuration.
Read more about installing plugins.
# Activating the feature
In order to use this premium feature, you need to activate it with proper credentials. Please refer to the License key and activation guide for details.
# Configuration
For more technical details, check the plugin configuration reference.
Paste from Office enhanced does not come with its own configuration. Still, we highly recommend other editor features be loaded and configured in a certain way for optimal pasted styles retention and performance:
- General HTML Support β Enabling and configuring this feature will allow you to make the most of the paste from Office enhanced by retaining advanced formatting that would otherwise be rejected by core editor features. See the content compatibility table to learn more.
- Font size and family β Loading and configuring these features will ensure maximal compatibility of fonts in the pasted content.
The recommended configuration is as follows:
import { PasteFromOffice } from '@ckeditor/ckeditor5-paste-from-office';
import { PasteFromOfficeEnhanced } from '@ckeditor/ckeditor5-paste-from-office-enhanced';
import { GeneralHtmlSupport } from '@ckeditor/ckeditor5-html-support';
import { Alignment } from '@ckeditor/ckeditor5-alignment';
import { Bold, Italic, Underline, Strikethrough, Subscript, Superscript } from '@ckeditor/ckeditor5-basic-styles';
import { FontColor, FontBackgroundColor, FontFamily, FontSize } from '@ckeditor/ckeditor5-font';
import { Indent } from '@ckeditor/ckeditor5-indent';
import { Table, TableProperties, TableCellProperties } from '@ckeditor/ckeditor5-table';
import { TextPartLanguage } from '@ckeditor/ckeditor5-language';
// Other imports...
ClassicEditor
.create( document.querySelector( '#editor' ), {
plugins: [
// Load the open-source feature.
PasteFromOffice,
// Load the enhanced feature.
PasteFromOfficeEnhanced,
// Load the recommended General HTML Support feature.
GeneralHtmlSupport,
// Load other recommended editor features.
Alignment, Bold, Italic, Underline, Strikethrough, Subscript, Superscript,
FontColor, FontBackgroundColor, FontFamily, FontSize, Indent,
Table, TableProperties, TableCellProperties,
TextPartLanguage,
/* ... */
],
// Provide activation key.
licenseKey: 'your-license-key',
// Configuration of the GeneralHtmlSupport plugin to allow extra content into the editor.
// This configuration will preserve styles and formatting normally unsupported by core editor features.
htmlSupport: {
allow: [
{
name: /^.*$/,
styles: true,
attributes: true,
classes: true
}
]
},
// Configuration of the FontFamily plugin.
fontFamily: {
// Allow all fonts from Microsoft Office documents
// including those that are unknown to CKEditor.
supportAllValues: true
},
// Configuration of the FontSize plugin.
fontSize: {
options: [
8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22
],
// Allow all font sizes from Microsoft Office documents
// including those that are unknown to CKEditor.
supportAllValues: true
},
// Add UI buttons and dropdowns for extra editor features if you used the feature set
// from "Installation" section.
toolbar: [
// ...
'bold', 'italic', 'underline', 'strikethrough', 'superscript', 'subscript',
'|',
'alignment', 'outdent', 'indent',
'|',
'fontSize', 'fontFamily', 'fontColor', 'fontBackgroundColor',
'|',
'insertTable',
'|',
'textPartLanguage',
// ...
],
// Add UI buttons and dropdowns for extra table features if you used the feature set
// from "Installation" section.
table: {
contentToolbar: [
'tableColumn', 'tableRow', 'mergeTableCells', '|', 'tableProperties', 'tableCellProperties'
]
},
// ...
} )
.then( /* ... */ )
.catch( /* ... */ );
# Known issues
- There is a known issue with cell widths being incorrect upon pasting from Microsoft Excel. Learn more.
- Headings pasted from Microsoft Word with a normal font weight configured in styles will be rendered using a bold font due to default stylesheets provided by the editor.
- A bold text pasted from Microsoft Excel may be occasionally displayed as normal for specific font faces.
- There is a known issue with font family, font size, and text part language values being displayed incorrectly in the CKEditor UI. Learn more
# Related features
CKEditor 5 supports a wider range of paste features, including:
- Paste from Office β Basic, open-source version of the paste from Office plugin.
- Paste from Google Docs β Paste content from Google Docs, maintaining the original formatting and structure.
- Paste plain text β Paste text without formatting that will inherit the style of the content it was pasted into.
- Import from Word β Convert Word files directly into HTML content. You can read more about the differences between the paste from Office and import from Word features in the dedicated comparison guide.
Every day, we work hard to keep our documentation complete. Have you spotted outdated information? Is something missing? Please report it via our issue tracker.