Click here to Skip to main content
15,885,883 members
Articles / Programming Languages / C++

How to Open Documents in Office Web Apps in SharePoint apps (Provider Hosted and SharePoint Hosted)

Rate me:
Please Sign up or sign in to vote.
5.00/5 (1 vote)
16 Jan 2015CPOL1 min read 17.1K   1   4
How to open Documents in Office Web Apps in SharePoint apps (Provider Hosted and SharePoint Hosted)

Office web apps are now getting more and more popular with the SharePoint 2013 environment. In native SharePoint environment when you click on a document, it will open in an office online (OWA) based on configuration.

But if you are writing a SharePoint Hosted app or a Provider Hosted app; you might wonder how to open it in office web apps and what is the URL you are going to use.

You can use JSOM and SharePoint REST services to archive this.

First, you need to send a REST request by mentioning file name.

url: AppWebUrlUrl + "/_api/web/GetFileByServerRelativeUrl('server relative file name')",
method: "GET",
contentType: "application/json;odata=verbose",
headers: { "Accept": "application/json; odata=verbose" }

You should carefully give the sever relative file name for this operation, regardless of app type (Provider hosted or a SharePoint Hosted) file name it coming with app web url.

Example:

Absolute File Url

https://oapp-bfb82901075d6b.sharepoint.com/sites/dev/myapp/lists/lcrdocs/file1.doc

Relative File Url

/sites/dev/myapp/lists/lcrdocs/file1.doc

Depending on the App type, either you need to use the RequestExecutor or normal rest approach.

Using RequestExecutor in Provider Hosted Apps

var executor = new SP.RequestExecutor("app web url"); // you need to pass app web url
 
executor.executeAsync({
url: "app web url" + "/_api/web/GetFileByServerRelativeUrl('relative doc url')",
method: "GET",
contentType: "application/json;odata=verbose",
headers: { "Accept": "application/json; odata=verbose" },
success: function (data) {
    var arry = JSON.parse(data.body).d;
    if (arry.LinkingUrl) {
        // can open with office web apps
        var owaurl = "app web url" + 
        "/_layouts/15/WopiFrame.aspx?sourcedoc={" + 
        arry.UniqueId + "}&file=" + 
        encodeURIComponent(arry.Title) + "&action=default";                   
    } else {
        // can not open with office web apps (ex:txt)
    }
},
error: function (data, errorCode, errorMessage) {
// error
}
});

If the LinkingUrl is available, it indicates it can be opened via office web apps. LinkingUrl sometimes returns direct web app url; thus you don’t need to create the Url by amending items but sometimes it returns absolute document Url. The mentioned approach will be suited for both occasions.  

Ajax Request in SharePoint Hosted Apps

JavaScript
$.Ajax({ // Jquery needed
url: "app web url" + "/_api/web/GetFileByServerRelativeUrl('relative doc url')",
method: "GET",
contentType: "application/json;odata=verbose",
headers: { "Accept": "application/json; odata=verbose" },
success: function (data) {
    var arry = JSON.parse(data.body).d;
    if (arry.LinkingUrl) {
        // can open with office web apps
        var owaurl = "app web url" + "/_layouts/15/WopiFrame.aspx?sourcedoc={" + 
	arry.UniqueId + "}&file=" + encodeURIComponent(arry.Title) + "&action=default";                   
    } else {
        // can not open with office web apps (ex:txt)
    }
},
error: function (data, errorCode, errorMessage) {
// error
}
});

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


Written By
Sri Lanka Sri Lanka
This member has not yet provided a Biography. Assume it's interesting and varied, and probably something to do with programming.

Comments and Discussions

 
QuestionSet Return URL to point to the Provider Hosted App Pin
Michael Demetriou22-Feb-16 23:00
Michael Demetriou22-Feb-16 23:00 
QuestionHow can access relative path without word online login Pin
Bhupendr Chauhan4-Aug-15 2:15
Bhupendr Chauhan4-Aug-15 2:15 
QuestionSample Application Pin
Bhupendr Chauhan3-Aug-15 23:39
Bhupendr Chauhan3-Aug-15 23:39 
QuestionThanks. Pin
eastjie1-Apr-15 4:57
eastjie1-Apr-15 4:57 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.