Here's a short tutorial on how to make Durandal, PhoneGap and Windows Phone 8 work together:
Download and install PhoneGap’s Visual Studio 2012 template
Start by downloading PhoneGap. At the time of writing this, the latest version is 2.7.0. From inside the zip, copy CordovaWP8_2_7_0.zip(in folder lib/windows-phone-8)to Documents/Visual Studio 2012/Templates/ProjectTemplates:
data:image/s3,"s3://crabby-images/f723e/f723e2a3446fe1ced9928535676dcbfe8cbcc772" alt="image image"
Create a new Windows Phone 8 app using the template
Next step is to create the actual Windows Phone 8 app. For that, use the new Cordova-template:
data:image/s3,"s3://crabby-images/49ec4/49ec4a75d476de0dabe33cd4c5e3cefea8d303fb" alt="image image"
Clone the Durandal and add it to the app
Next step is to get Durandal. After cloning the project, copy App, Content and Scriptsfolders into the app’s www-folder:
data:image/s3,"s3://crabby-images/48dd8/48dd85df25522e1100f6c0cdf11b84dc9233b78f" alt="image image"
Now we just need to modify the PhoneGap’s Index.html so that it uses Durandal.
Create the Index.html for Durandal
Open the index.html and replace the content with this:
<!DOCTYPE html>
<html>
<head>
<title>Durandal</title>
<link rel="apple-touch-startup-image" href="Content/images/ios-startup-image-landscape.png" media="(orientation:landscape)" />
<link rel="apple-touch-startup-image" href="Content/images/ios-startup-image-portrait.png" media="(orientation:portrait)" />
<link rel="apple-touch-icon" href="Content/images/icon.png" />
<!--Durandal does not require Bootstrap or Font Awesome.
They are used to make the samples look nice.-->
<link rel="stylesheet" href="Content/bootstrap.min.css" type="text/css" />
<link rel="stylesheet" href="Content/bootstrap-responsive.min.css" type="text/css" />
<link rel="stylesheet" href="Content/font-awesome.min.css" type="text/css" />
<!--The css in this file makes the modal dialogs work right.-->
<link rel="stylesheet" href="Content/durandal.css" type="text/css" />
<!--Css specific to the samples.-->
<link rel="stylesheet" href="Content/app.css" type="text/css" />
<meta name="apple-mobile-web-app-capable" content="yes" />
<meta name="apple-mobile-web-app-status-bar-style" content="black" />
<meta name="format-detection" content="telephone=no" />
<meta name="viewport" content="width=device-width" />
<script type="text/javascript" src="cordova-2.7.0.js"></script>
</head>
<body>
<div id="applicationHost"></div>
<script type="text/javascript" src="Scripts/jquery-1.9.1.min.js"></script>
<script type="text/javascript" src="Scripts/knockout-2.2.1.js"></script>
<script type="text/javascript" src="Scripts/sammy-0.7.4.js"></script>
<script type="text/javascript" src="app/durandal/amd/require.js" data-main="app/main"></script>
</body>
</html>
In theory, that should be it. But if you run the app, you’ll notice that everything is not working correctly:
data:image/s3,"s3://crabby-images/76569/76569f90ae265b91d198226506fcda75c8fc8321" alt="image image"
The source of problem can be found from Visual Studio’s output window:
data:image/s3,"s3://crabby-images/e7a11/e7a11e22379b9db8598042a703cdeea1c5ba8600" alt="image image"
So it cannot find the shell.html, even though it’s where it should be:
data:image/s3,"s3://crabby-images/8d8c4/8d8c47d94f5ba9c8f2cdfe57263f2da6610c4d21" alt="image image"
“Fix” the PhoneGap
The PhoneGap Visual Studio 2012 template includes the PhoneGap’s source code, which is great. If you now open the Plugins/File.cs and set a breakpoint to readResourceAsText-method, you’ll see what’s causing the problem:
data:image/s3,"s3://crabby-images/8b68b/8b68b03a60d6dd942799db8d8fdd6b98726fce72" alt="image image"
PhoneGap tries to read the file from a wrong folder!The folder is missing the www-part.
Now make a little tweak to the code:
pathToResource = "www/" + pathToResource;
var resource = Application.GetResourceStream(new Uri(pathToResource, UriKind.Relative));
And then run the app again and here it is! Durandal running in a PhoneGap based Windows Phone app:
data:image/s3,"s3://crabby-images/0b7b5/0b7b54fadf0e92d08e58aa8c2e66701287f67293" alt="image image"
Source Code
I created a repository for this sample on GitHub. It’s available from here.