Template:domxref

  • Revision slug: Template:domxref
  • Revision title: Template:domxref
  • Revision id: 56129
  • Created:
  • Creator: Sevenspade
  • Is current revision? No
  • Comment Document this more sanely; 66 words added, 20 words removed

Revision Content

/* Used for generating cross-references within the DOM documentation. */
/* This will first try to link to DOM/$0, then DOM:$0 if that doesn't exist */
/* if you specify the API name with parens (ie, "foo()"), the link is to
/* lang/DOM/foo but the title is displayed as "foo()" to make it clear it's
/* a function */
/* @param */
/*   The path of the page to link to, relative to the DOM documentation path.
/* @param [optional]
/*   The text to use for the link.  If omitted, the value of the first
/*   parameter will be used

/* get a page's language (Don't use page.language!) */
var u = Uri.Parts(Page.uri);
var lang = u.path[0];
if(string.Contains(lang, "project") || string.Contains(lang, "Project")) {
 lang = string.Substr(lang, 8);
}
var api = $0;
var str = $0;

if ($1) {
  str = $1;
}

if (string.endswith($0, '()')) {
    api = string.remove(api, string.length(api) - 2);
}

var destOldType = lang + '/' + 'DOM:' + api;
var destNewType = lang + '/' + 'DOM/' + api;

if(wiki.pageExists(destNewType)) { /* the page exists from the dekiwiki age */
    (web.link(wiki.uri(destNewType),str));
} else 
if (wiki.pageExists(destOldType)) { /* the page exists from the mediawiki age */
    (web.link(wiki.uri(destOldType),str));
} else { /* the page doesn't exist */
    <a rel=('internal') href=(wiki.uri(destNewType)) class=('new')>(str)a>;
}

Revision Source

<pre class="script">
/* Used for generating cross-references within the DOM documentation. */
/* This will first try to link to DOM/$0, then DOM:$0 if that doesn't exist */
/* if you specify the API name with parens (ie, "foo()"), the link is to
/* lang/DOM/foo but the title is displayed as "foo()" to make it clear it's
/* a function */
/* @param */
/*   The path of the page to link to, relative to the DOM documentation path.
/* @param [optional]
/*   The text to use for the link.  If omitted, the value of the first
/*   parameter will be used

/* get a page's language (Don't use page.language!) */
var u = Uri.Parts(Page.uri);
var lang = u.path[0];
if(string.Contains(lang, "project") || string.Contains(lang, "Project")) {
 lang = string.Substr(lang, 8);
}
var api = $0;
var str = $0;

if ($1) {
  str = $1;
}

if (string.endswith($0, '()')) {
    api = string.remove(api, string.length(api) - 2);
}

var destOldType = lang + '/' + 'DOM:' + api;
var destNewType = lang + '/' + 'DOM/' + api;

if(wiki.pageExists(destNewType)) { /* the page exists from the dekiwiki age */
    <code>(web.link(wiki.uri(destNewType),str))</code>;
} else 
if (wiki.pageExists(destOldType)) { /* the page exists from the mediawiki age */
    <code>(web.link(wiki.uri(destOldType),str))</code>;
} else { /* the page doesn't exist */
    <code><<span class="start-tag">a</span><span class="attribute-name"> rel</span>=(<span class="attribute-value">'internal') </span><span class="attribute-name">href</span><span>=</span>(<span>wiki.uri(</span>destNewType<span>)) </span><span class="attribute-name">class</span>=<span class="attribute-value">('new')></span>(str)</<span class="end-tag">a></span></code>;
}
</pre>
Revert to this revision