45 lines
1.5 KiB
JavaScript
45 lines
1.5 KiB
JavaScript
define("dijit/layout/LinkPane", [
|
|
"./ContentPane",
|
|
"../_TemplatedMixin",
|
|
"dojo/_base/declare" // declare
|
|
], function(ContentPane, _TemplatedMixin, declare){
|
|
|
|
// module:
|
|
// dijit/layout/LinkPane
|
|
|
|
|
|
return declare("dijit.layout.LinkPane", [ContentPane, _TemplatedMixin], {
|
|
// summary:
|
|
// A ContentPane with an href where (when declared in markup)
|
|
// the title is specified as innerHTML rather than as a title attribute.
|
|
// description:
|
|
// LinkPane is just a ContentPane that is declared in markup similarly
|
|
// to an anchor. The anchor's body (the words between `<a>` and `</a>`)
|
|
// become the title of the widget (used for TabContainer, AccordionContainer, etc.)
|
|
// example:
|
|
// | <a href="foo.html">my title</a>
|
|
|
|
// I'm using a template because the user may specify the input as
|
|
// <a href="foo.html">title</a>, in which case we need to get rid of the
|
|
// <a> because we don't want a link.
|
|
templateString: '<div class="dijitLinkPane" data-dojo-attach-point="containerNode"></div>',
|
|
|
|
postMixInProperties: function(){
|
|
// If user has specified node contents, they become the title
|
|
// (the link must be plain text)
|
|
if(this.srcNodeRef){
|
|
this.title += this.srcNodeRef.innerHTML;
|
|
}
|
|
this.inherited(arguments);
|
|
},
|
|
|
|
_fillContent: function(){
|
|
// Overrides _Templated._fillContent().
|
|
|
|
// _Templated._fillContent() relocates srcNodeRef innerHTML to templated container node,
|
|
// but in our case the srcNodeRef innerHTML is the title, so shouldn't be
|
|
// copied
|
|
}
|
|
});
|
|
});
|