Presentation is loading. Please wait.

Presentation is loading. Please wait.

SharePoint 2010 Wizardry with Silverlight

Similar presentations


Presentation on theme: "SharePoint 2010 Wizardry with Silverlight"— Presentation transcript:

1 SharePoint 2010 Wizardry with Silverlight
Widget and Web Part Communication

2

3 Innovation is Key to Success
Consumer Focus “What incredible benefits can we give to the customer? Where can we take the customer? Not starting by sitting down with the engineers and figure out what awesome technology we have and how are we going to market that…” – Steve Jobs “The way to achieve the best long term value is to build real value in the world” – Mark Zuckerberg

4 Understand This Principle
Awesome technology is adopted if it provides a benefit.

5 Some Great Technology SharePoint - the last slide should tell you just how flexible SharePoint as a platform actually is. Flexibility is key here Smart Phones – Windows Phone 7, Android, and iPhones place dotted lines around the form applications can take but allows for highly consistent experiences on the platform. Consistency is key here Windows 8 and iOS – Attempt to provide flexibility and consistency over multiple form factors. Social Platforms – Facebook, Twitter, WordPress

6 SharePoint as a Development Platform
Exemplifies the 80/20 Rule SharePoint can be low cost using all out of the box features and branding The last 20% represent specialized purposes usually at a higher cost Benefits of that last 20% may not exceed the cost of development if poor choices are made

7 SharePoint Development Approaches
A major decision point in this last 20% is on approach The choices include: Creating applications from multiple third party web parts (and features) Super user development using native capabilities Rolling your own widgets with compiled and middle tier code Purchasing complete sub systems such as pmPoint and Project Server Some combination of everything

8 Good Technology + Vision = Excellent Applications
Think in terms of an application domain not just a collection of widgets that meet line item requirements Stay away from monolithic thinking Keep the idea of atomic development a first class principle. Leverage as much of the platform as practical How should platform components communicate with each other to enhance the value and consistency SharePoint falls down in areas where specific requirements exceed the general purpose nature of SharePoint – of to say this another way you’re in the last 20% of your implementation.

9 Linking Applications and Widgets
Huge trend enabling dynamic linking between applications and components as well as more robust communication between components Video

10 Building a Basic Silverlight Web Part
Demo … and web part islands

11 Some Observations Web parts tend to live in self contained islands
Connecting to other web parts OTB is simple but has limited functionality It takes work to connect in ways that reach the vision presented in the video

12 HTML5 Affiliated Communication APIs
Web Messaging Web Sockets Server Sent Events Web Workers Node.js CORS – Cross Origin Resource Sharing XHR -

13 Cross Component Communication in SharePoint
New HTML5 standards when integrated with SharePoint open up the platform for some really unique possibilities Middle Tier Development with JQuery Silverlight has rich connectivity into SharePoint

14 Silverlight/XAML Web Client Duplex Services ScriptObject HTMLPage
SOAP/WCF/RIA LocalMessageReceiver LocalMessageSender CORS – Cross Origin Resource Sharing XHR -

15 Communicating to the Host Page
public void HideHTML(string name) { ScriptObject obj = (ScriptObject)HtmlPage.Window.GetProperty("HideHTML"); obj.InvokeSelf(name); } public void ShowHTML(string name) ScriptObject obj = (ScriptObject)HtmlPage.Window.GetProperty("ShowHTML");

16 Communicating to the Host Page
<asp:Content ContentPlaceHolderId="PlaceHolderAdditionalPageHead" runat="server"> <script type="text/javascript" src="/_layouts/Xaptic/js/jquery min.js"></script>

17 Communicating to the Host Page
<script type="text/javascript"> function AddToHeader(css) { $('head').append(css); } function MoveHTMLTo(name, top, left) { $('#' + name).css('top', top); $('#' + name).css('left', left); </script> Sample Code

18 Communication Between Local Silverlight-Based Applications
// In the receiving application: LocalMessageReceiver messageReceiver = new LocalMessageReceiver("receiver", ReceiverNameScope.Global, LocalMessageReceiver.AnyDomain); // In the sending application: LocalMessageSender messageSender = new LocalMessageSender( "receiver", LocalMessageSender.Global);

19 Making Things a bit Easier
Upload and Drag / Drop Easier to add properties Leverage the web part concept as atomic level widgets Build in communication mechanisms beyond connected web parts

20 Communication Between Local Silverlight-Based Applications
send = new LocalMessageSender(xaptic.GetProperty("SendTo"), System.Windows.Messaging.LocalMessageSender.Global); send.SendCompleted += (object sender, SendCompletedEventArgs e) => {}; allowedSenderDomains.Add("localhost"); allowedSenderDomains.Add("dev"); allowedSenderDomains.Add("dev01.com"); receiver = new LocalMessageReceiver(xaptic.GetProperty("ReceiveFrom"), ReceiverNameScope.Global, allowedSenderDomains); receiver.MessageReceived += (object sender, MessageReceivedEventArgs e) => { L3.Content = e.Message; }; receiver.Listen();

21 Putting it all Together
XAPTIC A Silverlight Widget Platform for Prototyping Rich UI’s in SharePoint 2010

22 Thank you!

23


Download ppt "SharePoint 2010 Wizardry with Silverlight"

Similar presentations


Ads by Google