Having trouble getting help?
Contact Support
Contact Support
Open a document from URL
18 Dec 20226 minutes to read
How to open a document from URL in DocumentEditor
This article explains how to open a document from URL in DocumentEditor.
<ejs-button id="import" content="Open Document" onclick="onClick()"></ejs-button>
<ejs-documenteditorcontainer id="container" serviceUrl="/api/DocumentEditor/" enableToolbar=true created="onCreated"
height="590px"></ejs-documenteditorcontainer>
<script>
var documenteditor;
var container;
function onCreated() {
var documenteditorElement = document.getElementById("container");
container = documenteditorElement.ej2_instances[0];
documenteditor = container.documentEditor;
}
function onClick() {
let http = new XMLHttpRequest();
//add your url in which you want to open document inside the ""
let content = { fileUrl: "" };
let baseurl = "/api/documenteditor/ImportFileURL";
http.open("POST", baseurl, true);
http.setRequestHeader("Content-Type", "application/json;charset=UTF-8");
http.onreadystatechange = () => {
if (http.readyState === 4) {
if (http.status === 200 || http.status === 304) {
//open the SFDT text in Document Editor
container.documentEditor.open(http.responseText);
}
}
};
http.send(JSON.stringify(content));
}
</script>
import * as ReactDOM from 'react-dom';
import * as React from 'react';
import {
DocumentEditorContainerComponent,Toolbar } from '@syncfusion/ej2-react-documenteditor';
DocumentEditorContainerComponent.Inject(Toolbar);
export class App extends React.Component<{}, {}> {
container: DocumentEditorContainerComponent;
public contentChanged:boolean=false;
onClick():void {
let http: XMLHttpRequest = new XMLHttpRequest();
//add your url in which you want to open document inside the ""
let content = { fileUrl: "" };
let baseurl: string = "/api/documenteditor/ImportFileURL";
http.open("POST", baseurl, true);
http.setRequestHeader("Content-Type", "application/json;charset=UTF-8");
http.onreadystatechange = () => {
if (http.readyState === 4) {
if (http.status === 200 || http.status === 304) {
//open the SFDT text in Document Editor
container.documentEditor.open(http.responseText);
}
}
};
http.send(JSON.stringify(content));
}
render() {
return (
<div>
<button id='import' onClick={this.onClick.bind(this)}>Import</button>
<DocumentEditorContainerComponent id="container" ref={(scope) => { this.container = scope; }}
height={'590px'}
serviceUrl="https://ej2services.syncfusion.com/production/web-services/api/documenteditor/"
enableToolbar={true}
/>
</div>
);
}
}
ReactDOM.render(<App />, document.getElementById('root'));
[AcceptVerbs("Post")]
public string ImportFileURL([FromBody]FileUrlInfo param)
{
try {
using(WebClient client = new WebClient())
{
MemoryStream stream = new MemoryStream(client.DownloadData(param.fileUrl));
WordDocument document = WordDocument.Load(stream, FormatType.Docx);
string json = Newtonsoft.Json.JsonConvert.SerializeObject(document);
document.Dispose();
stream.Dispose();
return json;
}
}
catch (Exception) {
return "";
}
}
public class FileUrlInfo {
public string fileUrl { get; set; }
public string Content { get; set; }
}