Paste Options
When pasting content in RadRichTextEditor, you might want to style it in different ways depending on the specific situation. The control allows you to specify how the styles of the content being pasted should be resolved and you can choose to preserve the styling as it was in the moment of copying it or you would prefer to keep the formatting you already have in RadRichTextEditor. Merging the styles is available as well. This topic explains the API of this functionality and how you can achieve the different scenarios.
Available Paste Options
The options which can be used are defined in the PasteOption enumeration. Here are the possible values:
- KeepSourceFormatting: Preserves the formatting of the content as it was when it has been copied.
- MergeFormatting: Keeps the underline, font weight and font style applied to the source. The other styles are used from the StyleRepository of the target document.
- KeepTextOnly: Strips the formatting of the content and pastes it as plain text.
- UseDestinationStyles: Keeps the styles used in the RadDocument instance and ignore the ones of the source.
Paste Sources
While pasting, the API determines the source of the content which is inside the clipboard and can apply different paste option depending on it.
The different sources are defined in the PasteSource enumeration:
- SameRadDocument: Used when the copy and paste operations are performed within the same instance of RadDocument.
- AnotherRadDocument: Used when the copy and paste operations are performed between different instances of RadDocument.
- AnotherRichTextDocument: A rich text document which was copied from application and not from a RadDocument instance.
- DocumentWithConflictingStyles: Document whose styles are in conflict with the ones defined in the target RadDocument. When this option is used, the specific source is not defined.
Default and Available Paste Options
For each of the PasteSource values, there is defined a specific PasteOption which will be executed for this source. The next list shows the predefined settings:
Paste Source | Available Paste Options | Default Paste Option |
---|---|---|
SameRadDocument | KeepSourceFormatting, KeepTextOnly, Merge Formatting | KeepSourceFormatting |
AnotherRadDocument | KeepSourceFormatting, KeepTextOnly, Merge Formatting | KeepSourceFormatting |
AnotherRichTextDocument | KeepSourceFormatting, KeepTextOnly, Merge Formatting | KeepSourceFormatting |
DocumentWithConflictingStyles | KeepSourceFormatting, KeepTextOnly, Merge Formatting, UseDestinationStyles | UseDestinationStyles |
You can change these settings using the PasteSettings class and the methods it exposes.
Turning Paste Options On/Off and Setting Default Behavior
RadRichTextEditor.RichTextBoxElement exposes the PasteSettings property to enable you specify whether you would like to use the Paste Options functionality and how you would like it to behave. The property is of type PasteSettings and you can use the members of the class to adjust the settings according to your needs.
PasteSettings Members
In addition to enabling or disabling the functionality, the members of this class enable you to set how the paste options should behave depending on the source the content has been copied from.
GetDefaultPasteOptionForPasteSource(PasteSource pasteSource): Gets the default PasteOption which will be executed when content from a given PasteSource is pasted.
SetDefaultPasteOptionForPasteSource(PasteSource pasteSource, PasteOption pasteOption): Enables you to set the default PasteOptions for a given PasteSource.
GetAvailablePasteOptions(PasteSource pasteSource): Gets a list of PasteOptions which could be performed when content with a given PasteSource is pasted.
SetAvailablePasteOptions(PasteSource pasteSource, params PasteOption[] pasteOptions): Sets a list of available PasteOptions for a given PasteSource.
SetAvailablePasteOptions(PasteSource pasteSource, IEnumerable<PasteOption> pasteOptions): Sets a list of available PasteOptions for a given PasteSource.
Executing Paste in Code
You can invoke the paste with specific options through the RadRichTextEditor/RadDocumentEditor class. In addition to the normal paste functionality, invoked using the Paste() method, the interface common for both classes exposes one more overload which enables you to specify the option wich will be used during the paste - Paste(PasteOption pasteOption).
The method exposed by RadRichTextEditor executes the paste and shows the popup for the user to choose another paste option if they would like to. If you would like to paste from the code without showing any UI, you can use the method of RadDocumentEditor.
[C#] Example 1: Paste with Specific Settings
this.radRichTextEditor1.Paste(Telerik.WinForms.Documents.Model.PasteOption.MergeFormatting);
Me.radRichTextEditor1.Paste(Telerik.WinForms.Documents.Model.PasteOption.MergeFormatting)
Executing Paste through UI
When the users paste content in RadRichTextEditor using the Ctrl+V keyboard shortcut, a popup appears to let them choose the paste option they would like to use. If none of the buttons is pressed, the deafult option for the source is used.