Using yml:include to create an automatically updating YAP small view


One of the biggest issues that many people have with the small view of a YAP open application is that the view is cached on Yahoo! servers and can only be updated with manual intervention from either the application owner or the application user. In the past, application owners had a few options for updating this small view. The most common were:

  • When the user visited the canvas view of the application the owner would have a setSmallView call set up to refresh the small view of the user (process described here: http://www.nakedtechnologist.com/?p=181. The problem with this is that it requires the user to go to the canvas view. Many users would just view their small view on My Yahoo! so the content of the app was either generic or stale.
  • The owner would set up a cron job to update the small view of their app users on regular intervals (process described here: http://www.nakedtechnologist.com/?p=220). The issue with this one is that the content will only be updated at regular times and will be stale for a user in between those times.
  • The owner would implement a yml:a tag to call a server-side script to update the small view of the user when the user clicked on the link (process described here: http://www.nakedtechnologist.com/?p=204). This relied on user interaction to function and in many cases links on the small view would need to be added just for this requirement.

Many developers, myself included, opted for a mix of all of the options above. This worked fairly well to mimic a dynamic small view, but having three solutions for a single problem was unwieldy.

 

Enter the yml:include tag
The purpose of this tag is to dynamically load content onto a page. This tag can be used in both the canvas and small views, but the real benefit to its use is the small view.

I would recommend looking over the documentation for yml:include as there is quite a lot of detail that a developer would find useful: http://developer.yahoo.com/yap/guide/include.html

The features that are most important to note here are:

  • insert – if a node id is specified in the insert parameter, the content of the include request will load into that node.
  • delay – the amount of time to delay the loading of the content (in milliseconds)

These parameters will help in setting up a dynamic small view for the user. Using these, I’ll go through two examples on how to use yml:include. The first will cover a simple single load case and the second will display how to build a continually updating small view set to update on a specific delay.

 

Simple Use Case – Single Dynamic Load
This first example will display a simple use case for yml:include. We will use the setSmallView call to insert an include tag into the small view of the current user.

 

The PHP layer to this is just to insert that yml:include tag the first time, and is only needed once. This will replace the cached small view of the user with the include tag. For my applications, I ran this in a cron job to update the small view for all users at once. Doing so replaced my need to constantly update the small view of my users on a daily basis.

 

The full details for setting up this example can be found here: http://www.nakedtechnologist.com/?p=181. This piece is the PHP layer that just sets the small view of the user with a yml:include tag and the div node that the content will be inserted into.

$html = '<yml:include params="training_sdk.php" insert="loadHere"></yml:include><div id="loadHere">REPLACE</div>';
if (!$yahoo_user->setSmallView($html)){
	echo "NO SMALL VIEW";
}

When the dropzone (my.yahoo) and application load, an AJAX GET request will be made to training_sdk.php. This file will return the content of the small view and then be inserted into the div with the id of “loadHere” (as denoted by the insert parameter). This allows us to generate whatever content we want within training_sdk.php and the small view will reflect that change as soon as the user loads the application.

 

Extended Use Case – Updating the Small View Every x seconds on a delay
Now we’re going to look into an extended use case for yml:include. This version will extend upon the basic example to refresh the small view automatically every 5000 milliseconds (every 5 seconds). We will start off with the same code that we insert into the small view to include the yml:include tag. From that point we take a look at the file that we capture the content of the small view from, training_sdk.php.

<yml:include params="training_sdk.php" insert="loadHere" delay="5000"></yml:include>
<?= time(); ?>

What we’re doing here is inserting another yml:include tag onto the page. Just like the first tag we are calling the same file, training_sdk.php, and inserting it into the same DOM node. The difference here is that we are delaying the load of this request by 5 seconds with the delay parameter. Following that all we do is display the current UNIX timestamp. What’s going to happen when this content is inserted into the small view is that the new yml:include will count down 5 seconds and then make an AJAX call to the same file and insert another UNIX timestamp and yml:include tag (which is delayed 5 seconds). So there we have it, we now have a small view that will update itself automatically every 5 seconds.

 

There’s only one catch here. There is a limit on the number of times you can call yml:include within a span of time. If too many consecutive yml:include calls are made, you will see the following error message:

 

error-243: maxIncludes limit hit for appid XXX

 

If you see this message, you have made too many yml:include calls within the particular dropzone. Currently the front page will allow unlimited yml:include calls and http://my.yahoo.com will allow 10 calls per session. My Yahoo! is looking into this at the moment so keep checking back to see if there have been changes with this tag. If you see this error, increase the delay on your yml:includes and that should solve the issue.

 

- Jonathan LeBlanc

  • Share/Bookmark


Updating your YAP small view using yml:a


For the second installment in the dynamic small view using yml:a talks, I wanted to take you through another implementation of the yml:a tag created during some head pounding platform work.

 

The Problem
The My Yahoo! small view of an application can’t automatically refresh itself with fresh content. If a user never goes to the large view of your application, they will always see the same stale content in the small view on their My Yahoo! page. If your application relies on fresh content being presented to the user, you need a way of updating the small view content from the small view.

 

The Solution
Basically, what you are trying to do to make this happen is to find a way to make a request to a server side script which will, in turn, instantiate a new Yahoo! session and set the small view content. Again, because of the AJAXian behavior that can be accomplished using the yml:a tag, it’s the perfect candidate for our needs.

 

There are two methods that we’ve used for this task. The first one uses the tab example I spoke about in my last post. Each time a tab (which is a stylized yml:a tag) is clicked, yml:a will call a server side script to rebuild the tab group. While this is occurring, new content can be cached for the user’s small view.

 

The second method, and the one that I’ll go over in depth, is to includ a yml:a link on your small view to “Update Small View”. I like the idea of updating the small view automatically using the tab method, but I also like having this option available to users so that if they see something that is out of the ordinary they can refresh to update their view at will. Let’s look at a code implementation behind this example.

 

First things first, when the large view of your application loads, you’ll need to set the small view. For our needs, all we’re going to insert in the small view (from PHP) is the yml:a link to update:


<?php
require_once('Yahoo.inc');

 

//define constants to store your API Key (Consumer Key) and Shared Secret (Consumer Secret)
define(“API_KEY”,“YOUR KEY”);
define(“SHARED_SECRET”,“YOUR KEY”);

 

//initializes session and current user

 

$yahoo_session = YahooSession::requireSession(API_KEY, SHARED_SECRET);
$yahoo_user = $yahoo_session->getSessionedUser();

 

//set the small view
$uid = $yahoo_user->guid;
$yml = “<div id=’containerHolder’></div><yml:a params=\”updateSmall.php?uid=”.$uid.“\” replace=\”containerHolder\”><span style=\”color:#fff;\”>Click Here to Refresh Your View</span></yml:a>”;

 

$yahoo_user->setSmallView($yml);
?>

 

As we can see, the small view will now have a refresh link on it which in turn calls updateSmall.php through an AJAX request with the user id of the person that clicked on the link, then replaces the DOM element with the id of containerHolder. In updateSmall.php, we’ll capture the user id passed in to us, instantiate a 2-legged OAuth session, then use that id to update the small view cache of the user and finally dump out the new small view content that will be replaced. This would look something like:


<?php
require_once('Yahoo.inc');
define("API_KEY","YOUR KEY");
define("SHARED_SECRET","YOUR KEY");


$uid = $_REQUEST['uid'];


$yahoo_session = new YahooApplication(API_KEY, SHARED_SECRET);
$small_view = ‘Hey, this is my new small view!’;


if (!$yahoo_session->setSmallView($uid, $small_view)){
echo
“ERR: $uid <br />”;
}
echo
$small_view;
?>

 

That’s it, you should now have an easy method for updating the small view for the user using yml:a, as well as updating their small view cache so that they will see the new small view if they refresh the page.

 

– Jonathan LeBlanc

  • Share/Bookmark


Building a dynamic small view on YAP using yml:a


My Yahoo!’s implementation of the Yahoo! Application Platform (YAP) is usually perceived as a mixed bag with the developers and partners we’ve been working with.  On the one hand this is the implementation of the platform on Yahoo! and on the other developers feel restricted because the small view that displays on My Yahoo! only allows HTML, CSS and YML.  Some developers have gone the route of just placing glorified ads or static content on their small views.  Enter the yml:a tag…one of the most powerful tools at a developer’s disposal on the platform.

 

The yml:a tag can be seen as a replacement to the normal HTML anchor tag, but it is much more than that.  Including AJAX functionality with DOM insert / replace techniques, this tag can mimic a dynamic environment to allow developers a greater degree of flexibility.

 

So, I can spout off all of the promotional material I want, but what use is it without examples to back it up.  This code sample will provide all of the functionality of a dynamic tab set within the small view, where the tabs are defined as yml:a tags:


<?php
require_once('Yahoo.inc');

if ($_GET['tabNum']){
    echo 
build_tabs($_GET['tabNum']);

} else {
    
//define application key constants
    
define("API_KEY","YOUR KEY HERE");
    
define("SHARED_SECRET","YOUR KEY HERE");    

    //initialize 2-legged OAuth session
    
$yahooSession = new YahooApplication(API_KEYSHARED_SECRET);
    
    
//set up static html / style block

    $tabNum = ($_GET['tabNum']) ? $_GET['tabNum'] : 1;
    
$tabCode "<style>

                div.pad5{ padding:5px }
                div.tabGroup{ position:relative; border-bottom:0; }
                div.tabGroup div{ background-color:#fff; float:left; width:50px; border:1px solid #795089; 
                                  border-bottom:0; padding:5px 10px; text-align:center; 

                                  font:bold 12px arial,helvetica,sans-serif; cursor:pointer; }
                div.tabGroup div a{ color:#795089; text-decoration:none; }
                div.tabGroup div.selected{ background-color:#795089; }
                div.tabGroup div.selected a{ color:#fff; }

                div.tabGroup div:hover{ background-color:#e2ceea; }
                div.tabGroup div.selected:hover{ background-color:#795089; }
                div.tabContent{ border:1px solid #795089; border-top:10px solid #795089; padding:5px 10px; }

                div.myBox{ width:232px; height:44px; background-image:url(http://l.yimg.com/a/i/ww/beta/y3.gif); }
                </style>"
;
    
$tabCode .= "<div class='pad5'>" build_tabs($tabNum) . '</div>';

    
    
$guid "YOUR GUID";
    if (!
$yahooSession->setSmallView($guid$tabCode)){
        echo 
"UNABLE TO SET SMALL VIEW";

    }
    
    echo 
"LARGE VIEW CONTENT";
}
    
function 
build_tabs($tabNum){
    
$tabCode "<div id='tabContainer'><div class='tabGroup'>";

    
    
//create tab set using the tabNum as the selected tab
    
for ($i 1$i 4$i++){

        $isSelected = ($i === intval($tabNum)) ? 'selected' '';
        
$tabCode .= "<div class=\"$isSelected\"><yml:a params=\"?tabNum=$i\" 

                     replace=\"tabContainer\">Tab $i</yml:a></div>";
    }
    
    
//create tab content
    
$tabContent '';
    switch(
$tabNum){

        case 1$tabContent 'Hi <yml:name uid="viewer" />! This is tab content 1!'; break;

        case 2$tabContent 'Here is my profile badge:<br /><yml:user-badge />'; break;

        case 3$tabContent 'My Pics:<br /><yml:image 
                               src="http://farm1.static.flickr.com/195/449142212_c2e72f83d7.jpg"
                               height="166" width="250" alt="Faceball" />'
; break;

        default: break;
    }
    
    
//build tab content with defined string
    
$tabCode .= "<br style='clear:both'></div><div class='tabContent'>$tabContent</div></div>";

    return $tabCode;
}
?>

Let’s break the code down into the pertinent parts and explain what the heck is going on. This code can be placed as the landing page for your application full view. What will happen is that it will generate a new small view which will display the tabs as yml:a tags. When a tab is clicked, yml:a will send an AJAX request to this same file, but will pass in a numeric query parameter (defined as ‘tabNum’) which will signal which tab has been clicked. The if / else statement at the top will control that flow. If tabNum is not defined, the core container and CSS will be created and the small view will be set using setSmallView. If tabNum is set, just the build_tabs function will be called to recreate the tab container and return it. Essentially, the yml:a tag is just replacing its own container with a new tab view in order to make it look like a new tab has been clicked, without refreshing the page, resetting the css or re-encoding the small view.

 

Let’s look specifically at the yml:a tag within the build_tabs function, where each tab is defined as:
<yml:a params=”?tabNum=$i” replace=”tabContainer”>Tab $i</yml:a>

 

The params attribute specifies that the same file will be called (since no file is defined) and will pass one query parameter, the tab number. The replace attribute specifies the id of the DOM element that will be replaced in the small view once the AJAX request successfully returns. In this case we are replacing the entire tab container, the div with the id of “tabContainer”.

 

That’s all there is to it. That’s one of the many dynamic things you can do with the yml:a tag.

 

Links:
- Tab tutorial on YDN
- yml:a tag description and samples

 

– Jonathan LeBlanc

  • Share/Bookmark


Yahoo! is Open


I had the chance yesterday to be working at the SNAP summit conference for Yahoo! when they announced that the Yahoo! Open Strategy initiative was being launched for developers to start working with the platform. The Yahoo! Open Strategy contains numerous facets, but is put in place to rewire Yahoo! into a completely different business model. Last week Yahoo! launched a new version of their profile system, which turns out to be one of the cornerstones of the initiative. The new profile system will be a centralized location for user information for (eventually) all Yahoo! products. This system will eliminate the need for users to maintain numerous different profiles across numerous different products on Yahoo!. In addition, this system is beginning to tie in all other Yahoo! products across the board. Vitality updates will be shared across numerous programs.

 

So, what does the new Y!OS initiative mean for developers? Well, the new Yahoo! Application Platform (YAP) will allow developers to create function rich Open Social applications utilizing sources of data across numerous Yahoo! properties. Currently developers can begin building and testing application as a precursor to the launch of the gallery and application small view. These applications will be able to leverage around 10 billion social connections among millions of users. Not only does your application have the opportunity to reach this vast user base, but monetization of the applications has already been considered. Shortly there will be a launch of a new YML ad tag. This new tag will allow users to integrate certain popular ad networks within the canvas view of their applications. No longer will users have to find some way of hacking ads into their applications…they will be able to leverage off of some of the same standards that they have been using on any of their other web applications / sites.

 

What Yahoo! is offering is a series of social API’s which may be used within client or server side code to access user profile information, PHP and ActionScript SDK’s for server side data interaction, YML tags that allow the integration of secured widgets / functionality and a wonderfully rich Yahoo! Query Language (YQL) that will allow users to capture data from many Yahoo! properties and all over the web.

 

I look forward to seeing everything that comes from this platform.

 

– Jonathan LeBlanc

  • Share/Bookmark