data:image/s3,"s3://crabby-images/b7e5a/b7e5a37ff68899c2277315feabd18a247998f5d5" alt="image image"
You can implement SharePoint documents in your AngularJS applications much easier when you create your code in a Visual Studio LightSwitch Cloud Business app. Essentially we will make a SharePoint CSOM call to create a Word Document in an associated SharePoint list when we create a new task in our SharePoint Provider Hosted application.
The Application
data:image/s3,"s3://crabby-images/1f6e9/1f6e9600f016b039e1abc3693e5cb13826ff3490" alt="image image"
We start with the application created in AngularJS Posting To SharePoint Newsfeed Using Visual Studio LightSwitch.
We add tasks using the add new button and then click Save.
data:image/s3,"s3://crabby-images/6687e/6687e2f8b492c24fa08f8281b6bcaee10cf40b58" alt="image image"
After the task is saved, we can click on the task in the list to edit it.
data:image/s3,"s3://crabby-images/0f79c/0f79c54151943725c8623e3f077198c3ced42d41" alt="image image"
We will see that a Microsoft Word Document has been created and attached to the task.
We can click on either the Direct Link or the Inline Edit link to open the document.
data:image/s3,"s3://crabby-images/58cf6/58cf6d8b5700e2cd8e066fd6a1cbbac6e12d1932" alt="image image"
If we click on the Inline Edit link, the document will open in Word Online in Office 365.
Creating The Application
data:image/s3,"s3://crabby-images/80063/8006323f45579a91ea8c67480ac1ca42676bc161" alt="image image"
We start with the application created in AngularJS Posting To SharePoint Newsfeed Using Visual Studio LightSwitch.
data:image/s3,"s3://crabby-images/9c875/9c8751fa2ef7404b5c2d9cb5a3b7a488b50e0780" alt="image image"
This project is based on the application created in the article An End-to-End AngularJS SharePoint Module using LightSwitch OData as a Back-End.
Add References
data:image/s3,"s3://crabby-images/d3888/d388807e8a74064d72edf6ffee2f5d946ce777f0" alt="image image"
First, to provide the functionality to programmatically create Word documents, install the Open XML SDK for Microsoft Office (OpenXMLSDKV25.msi) from this link.
data:image/s3,"s3://crabby-images/62e44/62e448293d509b8fd6ff13163d92d18ba0a207c6" alt="image image"
Add a reference to DocumentFormat.OpenXml…
data:image/s3,"s3://crabby-images/50894/5089485f328eb028ba7cfbf92defc1119baa2876" alt="image image"
…and WindowsBase.
data:image/s3,"s3://crabby-images/0486d/0486df0fa722db23d0f74286c0ed1b3d69043ffa" alt="image image"
In the Properties for DocumentFormat.OpenXml, ensure you set Copy Local to True so that it will be deployed when you deploy the application to production.
Update the ToDo Table
data:image/s3,"s3://crabby-images/3af40/3af40c2689381f225021f73ee7c12fbabe80bc80" alt="image image"
Open the ToDo table and create a field called TaskID.
We will use this field later to connect this table to the SharePoint Document Library.
Connect LightSwitch To SharePoint Document Library
data:image/s3,"s3://crabby-images/ab09e/ab09e35e97572b6139e8e9cc82a1bca47affe05c" alt="image image"
We will now follow the instructions in the article: Implementing Documents in a SharePoint 2013 Cloud Business App (LightSwitch) to connect the project to the SharePoint Document Library.
data:image/s3,"s3://crabby-images/52b30/52b30acab5bba78424a386b036a9215209490113" alt="image image"
First, we need to create a SharePoint Document Library List.
Log into your SharePoint Development site, and click add an app under Site Contents.
data:image/s3,"s3://crabby-images/44a0c/44a0ce828317bf9db0293a898d7d665e87667eb2" alt="image image"
Add a Document Library.
data:image/s3,"s3://crabby-images/ca0f1/ca0f11745e7ead8c66ac542127bf6f9b3255fb50" alt="image image"
Call it TaskDocuments.
data:image/s3,"s3://crabby-images/87994/87994ecc06ca38ae5d54c90f41237ccef39883af" alt="image image"
After the list is added to the list of apps in Site Contents, select the SETTINGS.
We now need to add a column (TaskID) to allow us to associate a Document to a Task.
data:image/s3,"s3://crabby-images/962f2/962f23d3abb93a26a2ee56c81a0bac7437acab88" alt="image image"
In the Settings, select Create column.
data:image/s3,"s3://crabby-images/2134d/2134df4300b1b10a6681ea790c481b60781e6810" alt="image image"
Call the column TaskID and set its type to Single line of text.
This is so that each document can be associated with a Task in the application.
Click OK.
Connect To The Document Library
data:image/s3,"s3://crabby-images/b0810/b08101ec08633525f428fc185d8994ba8c69263c" alt="image image"
In Visual Studio, right-click on Data Sources and select Add Data Source.
data:image/s3,"s3://crabby-images/6d18d/6d18d64f705599633142048bfb0291b259be3871" alt="image image"
Select SharePoint.
data:image/s3,"s3://crabby-images/8a939/8a939732ab9d5857c0052d01e58a09c27f03aad7" alt="image image"
Enter the address of your Development SharePoint server.
data:image/s3,"s3://crabby-images/52f8e/52f8eb1d05b7e234a87c5609aab1e125437cfd58" alt="image image"
You may have to log in.
data:image/s3,"s3://crabby-images/e47b4/e47b49fa6dab8d0cc72ab89db03b546d400b1a31" alt="image image"
Select the TaskDocuments from Document Libraries, and UserInformationList from Lists.
data:image/s3,"s3://crabby-images/1eb5b/1eb5b4cc4344b434838ae9d5336d95cc12de90fd" alt="image image"
The lists will show in the project.
data:image/s3,"s3://crabby-images/a6d51/a6d510c8d0c8ff99d5333125244f3f5810a0000b" alt="image image"
- Open the TaskDocument table and click the Relationship button.
- Select ToDo as the To table and set the Multiplicity to Many to One.
- Set TaskID as the Primary and Foreign keys.
- Click OK.
data:image/s3,"s3://crabby-images/4efa7/4efa79cb7e9bfc2980619c0ba5e1e5ca61de4727" alt="image image"
The relationship will show.
Creating The Word Document
data:image/s3,"s3://crabby-images/79cd8/79cd8e05aab2c89b1e3fb807ed9d5b809852a928" alt="image image"
Next, we open the ToDo table and select the _Inserting method.
We add the following code to the end of the method:
entity.TaskID = System.Guid.NewGuid().ToString();
var clientContext =
this.Application.SharePoint.GetHostWebClientContext();
Microsoft.SharePoint.Client.Web web = clientContext.Web;
clientContext.Load(web);
clientContext.ExecuteQuery();
Microsoft.SharePoint.Client.WebCollection webs = web.Webs;
clientContext.Load<Microsoft.SharePoint.Client.WebCollection>(webs);
clientContext.ExecuteQuery();
Microsoft.SharePoint.Client.ListCollection Lists = web.Lists;
clientContext.Load<Microsoft.SharePoint.Client.ListCollection>(Lists);
clientContext.ExecuteQuery();
Microsoft.SharePoint.Client.List TaskDocumentsLibrary =
Lists.GetByTitle("TaskDocuments");
Microsoft.SharePoint.Client.Folder destintationFolder =
TaskDocumentsLibrary.RootFolder;
clientContext.Load(destintationFolder);
clientContext.ExecuteQuery();
using (WordprocessingDocument wordDocument =
WordprocessingDocument.Create(
HttpContext.Current.Server.MapPath("~/LocalOOXMLDocument.docx"),
WordprocessingDocumentType.Document))
{
MainDocumentPart mainPart = wordDocument.AddMainDocumentPart();
mainPart.Document = new Document();
Body body = mainPart.Document.AppendChild(new Body());
Paragraph para = body.AppendChild(new Paragraph());
Run run = para.AppendChild(new Run());
run.AppendChild(
new Text(
String.Format("Here's some text for {0}",entity.TaskName)
));
}
FileStream fs = null;
byte[] documentBytes;
fs = System.IO.File.OpenRead(
HttpContext.Current.Server.MapPath("~/LocalOOXMLDocument.docx"));
documentBytes = new byte[fs.Length];
fs.Read(documentBytes, 0, Convert.ToInt32(fs.Length));
Microsoft.SharePoint.Client.FileCreationInformation ooxmlFile
= new Microsoft.SharePoint.Client.FileCreationInformation();
ooxmlFile.Overwrite = true;
ooxmlFile.Url = clientContext.Url
+ destintationFolder.Name
+ "/" + entity.TaskName + ".docx";
ooxmlFile.Content = documentBytes;
Microsoft.SharePoint.Client.File newFile = TaskDocumentsLibrary.RootFolder.Files.Add(ooxmlFile);
clientContext.Load(newFile);
clientContext.ExecuteQuery();
Microsoft.SharePoint.Client.ListItem listItem = newFile.ListItemAllFields;
listItem["TaskID"] = entity.TaskID;
listItem.Update();
clientContext.ExecuteQuery();
You will need to add the following Using statements to the top of the class:
using System.IO;
using Microsoft.SharePoint.Client;
using System.Web;
using DocumentFormat.OpenXml;
using DocumentFormat.OpenXml.Packaging;
using DocumentFormat.OpenXml.Wordprocessing;
Update the AngularJS Application
data:image/s3,"s3://crabby-images/4cb46/4cb46667a8d2564965356a7518fccd0e21d64483" alt="image image"
Open the JayDataCRUD.js file and update the Angular controller with the following code:
$scope.TaskDocuments = [];
$data.initService('/SharePointDocuments.svc').then(function (SharePointDocuments) {
$scope.SharePointDocuments = SharePointDocuments;
$scope.TaskDocuments = SharePointDocuments.TaskDocuments.toLiveArray();
});
Object.defineProperty($scope, "colTaskDocument", {
get: function () {
if ($scope.selectedToDo)
return $scope.SharePointDocuments
.TaskDocuments
.filter('TaskID',
'==',
$scope.selectedToDo.TaskID)
.toLiveArray();
}
});
data:image/s3,"s3://crabby-images/060fd/060fd88478a703dbe1b631fdc5dfc83fd60a180e" alt="image image"
Open the JayDataCRUD.aspx file and update the markup with the following code:
<table>
<tr data-ng-repeat="TaskDocument in colTaskDocument">
<td>
{{TaskDocument.Name}}
</td>
</tr>
</table>
data:image/s3,"s3://crabby-images/52b38/52b3898b531151eaf82181a7f37ff4ff40a65135" alt="image image"
We can now run the application…
data:image/s3,"s3://crabby-images/bccf2/bccf25924b01dc27ccb82b14970bd8cb61229b37" alt="image image"
We can create a new task and then click on it to edit it.
We see that an associated Word document has been created and its name will display.
data:image/s3,"s3://crabby-images/e3dd0/e3dd0e776d21692845998aae6676385e4711385c" alt="image image"
When we go directly to the SharePoint TaskDocument list, we see the Word document can be viewed.
Link To The SharePoint Document From AngularJS
data:image/s3,"s3://crabby-images/b7005/b7005683c10f4094fc0ff7272fb2644a2a190576" alt="image image"
If we navigate directly to the LightSwitch OData feed that it automatically creates for the SharePoint TaskDocuments list (when we connect to it in LightSwitch), we see that it exposes a direct link to the Word document (don’t worry a user still has to be authenticated to get to it).
We can use this property to provide a link to the document in our AngularJS application.
First we add the following filter to the JayDataCRUD.js file (place under var app = angular.module('app', ['jaydata']):
app.filter('WordViewer', function () {
return function (DocumentURL, DocumentName) {
var a = document.createElement('a');
a.href = DocumentURL;
return 'https://'
+ a.hostname
+ '/_layouts/15/WopiFrame.aspx?sourcedoc='
+ DocumentURL
+ '&file='
+ DocumentName
+ '&action=default';
};
});
Next, we update the markup in the JayDataCRUD.aspx file to consume the filter:
<table>
<tr data-ng-repeat="TaskDocument in colTaskDocument">
<td>
{{TaskDocument.Name}}
<a href="{{TaskDocument.Microsoft_LightSwitch_ReadLink}}">[Direct Link]</a>
<a href="{{ TaskDocument.Microsoft_LightSwitch_ReadLink | WordViewer : TaskDocument.Name }}">
[Inline Edit]</a>
</td>
</tr>
</table>
data:image/s3,"s3://crabby-images/36386/3638678b2841d693bdab994b228e1b7166c97dad" alt="image image"
When we run the application, we now have a direct link and a inline edit link to the associated Word document.
Links
SharePoint 2013: Create Word documents using OOXML in apps for SharePoint
Link to open in browser with Office Web Apps
Welcome to the Open XML SDK 2.5 for Office
Links – LightSwitch Help Website
AngularJS Posting To SharePoint Newsfeed Using Visual Studio LightSwitch
An End-to-End AngularJS SharePoint Module using LightSwitch OData as a Back-End
Deploy A LightSwitch Application To Office 365 / SharePoint Online
Exploring SharePoint 2013 Visual Studio Cloud Business Apps (LightSwitch)
Implementing Documents in a SharePoint 2013 Cloud Business App (LightSwitch)
Creating A SharePoint Online Testing Site
Creating A LightSwitch SharePoint 2013 Multi-Tenant Provider-Hosted Application