Aug
24
Written by:
Michael Washington
8/24/2014 4:20 PM
data:image/s3,"s3://crabby-images/79942/79942a71c258f78bc24bc1fc00a2168f52dd1169" alt="image image"
You can embed your LightSwitch application directly into the SharePoint website, rather than the default behavior of launching the application full screen. You can also navigate directly to a record using deep linking. This is achieved by adding a SharePoint App Part to the project.
To understand how SharePoint App Parts work, let us first look at the process to install and consume them:
Consuming A Web Part
The SharePoint site administrator installs the application as normal (see: Creating A SharePoint Online Testing Site for an overview of the process).
data:image/s3,"s3://crabby-images/c67f9/c67f938e940b4b81acd2a51ecbe7bdd98d9992f2" alt="image image"
For our example, we will create a page. We start by first selecting Page.
data:image/s3,"s3://crabby-images/1268a/1268a56ec585fd0e49dd992940684ef839454051" alt="image image"
Next, we select View All Pages.
data:image/s3,"s3://crabby-images/68d2f/68d2f22c2ae2145fe01c975a8f9cf0912a630cb4" alt="image image"
We create a new page.
data:image/s3,"s3://crabby-images/21e1b/21e1bf2e0ee39a24bfff8d9e09d7a6827a3294ed" alt="image image"
We enter a name for the page and note the full address of the page.
data:image/s3,"s3://crabby-images/ba92b/ba92b4bfed3ccb5a12c1bb384bfa9a78f60ab470" alt="image image"
After we create the page we select EDIT LINKS.
data:image/s3,"s3://crabby-images/eda84/eda845608978fabe31581c9b9380ea6caaf87e2a" alt="image image"
We add a link.
data:image/s3,"s3://crabby-images/17fca/17fcac85ded14e56e5d581974ddd92ba3bb9ce83" alt="image image"
We create the link.
data:image/s3,"s3://crabby-images/a7485/a7485f66f9e997b3c6017a9ab3797ed6a68f1498" alt="image image"
We Save the changes.
Adding The Web Part
data:image/s3,"s3://crabby-images/654d2/654d2fd610bc1dd508ff2c620d58fac247096ba5" alt="image image"
Now, to add the App Part to the page, we navigate to the page, select Page then Edit.
data:image/s3,"s3://crabby-images/1b682/1b682780ed11dfc8e5f6f8d4ff0658db612674e2" alt="image image"
We select Insert then App Part.
data:image/s3,"s3://crabby-images/a1a29/a1a29d71a6a4cd01803afd25d362516f365859a5" alt="image image"
Next, we select the Cloud Business Tasks part to add the app to the current page.
data:image/s3,"s3://crabby-images/11168/11168bbcc988d1015523e0ca74dc03afd595995a" alt="image image"
Save the page.
data:image/s3,"s3://crabby-images/e6667/e6667d831a0885844365d0f3a3054c74fb1d56c9" alt="image image"
We can click on an existing task to navigate directly to it.
Creating The App Part
data:image/s3,"s3://crabby-images/db8f0/db8f04b7f77d2d25ab6df43fff06ff4355cf5da3" alt="image image"
We start with the application created in the article: Implementing Documents in a SharePoint 2013 Cloud Business App (LightSwitch) (from the book Creating HTML 5 Websites and Cloud Business Apps Using LightSwitch In Visual Studio 2013).
data:image/s3,"s3://crabby-images/94eae/94eae8e94d80e0699d79f89df3f049da9cde6ad6" alt="image image"
We right-click on the SharePoint configuration project and Add a New Item.
data:image/s3,"s3://crabby-images/5a0ba/5a0ba0b3a2e1241624aec81ba9d9a5edfb4ec6d9" alt="image image"
We create a Client Web Part.
data:image/s3,"s3://crabby-images/5eac7/5eac74c937312f4fdaa0e3295bb8bea68f6c5c47" alt="image image"
We create a new page.
data:image/s3,"s3://crabby-images/26851/2685168807bc22b411263bf1617d69518b7cc197" alt="image image"
The page and the configuration files will be created.
data:image/s3,"s3://crabby-images/fe52a/fe52a8209ee4bbdf6c062881493d49ac6eae1895" alt="image image"
We open the .xml file and set the Title, Description and size.
data:image/s3,"s3://crabby-images/7500a/7500a3931bf801639673b42a650c6d19bff7f662" alt="image image"
Next we open the CloudBusinessTasksWebPart.aspx file and change the BODY tag to the following:
<body style="overflow: scroll;">
<form id="form1" runat="server">
<asp:DataList ID="gvOrders" runat="server">
<ItemTemplate>
<ul>
<h1><asp:HyperLink ID="HyperLink1"
runat="server"
NavigateUrl='<%# Eval("HyperLink") %>'
Target="_parent">
<asp:Label runat="server"
Text='<%# Eval("TaskName") %>' />
</asp:HyperLink></h1>
Assigned to: <asp:Label runat="server"
Text='<%# Eval("TaskAssigned") %>' />
<br />Number of Documents: <asp:Label runat="server"
Text='<%# Eval("TaskDocuments") %>' />
</ul>
</ItemTemplate>
</asp:DataList>
</form>
</body>
</html>
data:image/s3,"s3://crabby-images/7d241/7d2416f591380ef03ede9d325345f3f1be001d7c" alt="image image"
Finally, we open the CloudBusinessTasksWebPart.aspx.cs page and use the following code:
using Microsoft.SharePoint.Client;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace LightSwitchApplication.Pages
{
public partial class CloudBusinessTasksWebPart : Page
{
protected void Page_Load(object sender, EventArgs e)
{
ShowTasks();
}
#region ShowOrders
private void ShowTasks()
{
using (var serverContext = GetServerContext())
{
// Get base URL
HttpContext context = HttpContext.Current;
string strBaseURL = context.Request.Url.Scheme
+ "://"
+ context.Request.Url.Authority
+ context.Request.ApplicationPath.TrimEnd('/') + @"/HTMLClient/";
// Construct Edit String
string SPHostUrl = Request.QueryString["SPHostUrl"];
string SPLanguage = Request.QueryString["SPLanguage"];
string SPClientTag = Request.QueryString["SPClientTag"];
string SPProductNumber = Request.QueryString["SPProductNumber"];
string SPAppWebUrl = Request.QueryString["SPAppWebUrl"];
string strUrlString1 = "{0}?SPHostUrl={1}&SPLanguage={2}&SPClientTag={3}";
string strUrlString2 = "&SPProductNumber={4}&SPAppWebUrl={5}&SPChromeColors=FF0072C6FFFFFFFF";
string strEditSring =
String.Format(strUrlString1 + strUrlString2,
strBaseURL, SPHostUrl, SPLanguage, SPClientTag, SPProductNumber, SPAppWebUrl);
// Get the Tasks
// this will automatically follow any business rules in the application
var result = from objTask in serverContext.DataWorkspace.ApplicationData
.Tasks.GetQuery().Execute()
select new TaskInfo
{
TaskID = objTask.Id,
TaskAssigned = objTask.TaskUserInfo.FullName,
TaskName = objTask.TaskName,
TaskDocuments = objTask.TaskDocuments.Count(),
HyperLink = strEditSring
+ "&entity=ApplicationData/Tasks(" + objTask.Id.ToString() + ")"
};
gvOrders.DataSource = result;
gvOrders.DataBind();
}
}
#endregion
#region TaskInfo
public class TaskInfo
{
int _TaskID;
public int TaskID
{
get { return _TaskID; }
set { _TaskID = value; }
}
string _TaskAssigned;
public string TaskAssigned
{
get { return _TaskAssigned; }
set { _TaskAssigned = value; }
}
int _TaskDocuments;
public int TaskDocuments
{
get { return _TaskDocuments; }
set { _TaskDocuments = value; }
}
string _TaskName;
public string TaskName
{
get { return _TaskName; }
set { _TaskName = value; }
}
string _HyperLink;
public string HyperLink
{
get { return _HyperLink; }
set { _HyperLink = value; }
}
}
#endregion
#region GetServerContext
private static ServerApplicationContext GetServerContext()
{
ServerApplicationContext serverContext =
(LightSwitchApplication.ServerApplicationContext)ServerApplicationContext.Current;
if (serverContext == null)
{
serverContext =
(LightSwitchApplication.ServerApplicationContext)ServerApplicationContext.CreateContext();
}
return serverContext;
}
#endregion
}
}
Download Code
The LightSwitch project is available at http://lightswitchhelpwebsite.com/Downloads.aspx
(you must have Visual Studio 2013 (or higher) installed to run the code)
Links – Microsoft
Customizing the SharePoint Chrome Control in LightSwitch
Links – LightSwitch Help Website
Deploy A LightSwitch Application To Office 365 / SharePoint Online
Creating A SharePoint Online Testing Site
Exploring SharePoint 2013 Visual Studio Cloud Business Apps (LightSwitch)
Creating A LightSwitch SharePoint 2013 Multi-Tenant Provider-Hosted Application
Implementing Documents in a SharePoint 2013 Cloud Business App (LightSwitch)
4 comment(s) so far...
My lightswitch app works well in separate browser window. But it doesn't appear in the list of available app parts to add to page. What should I do to see my app in that list together with system parts such as Documents, Form Templates, Site Assets and so on...? Thank You!
By Gennady on
11/11/2014 8:57 AM
|
@Gennady - Following the steps I have outlined should work for you.
By Michael Washington on
11/11/2014 8:58 AM
|
but it doesn't work:) Something went wrong becasue I didn't see app webpart of my application in site's webpart gallery.
By Gennady on
11/12/2014 4:49 AM
|
@Gennady - Try creating a normal Web Part here: http://msdn.microsoft.com/en-us/library/office/fp179921(v=office.15).aspx
By Michael Washington on
11/12/2014 4:50 AM
|