genome\n");
printGenomeListHtml(database, "change", onChangeOrg);
}
puts(" ");
puts("Assembly\n");
@@ -372,31 +372,31 @@
cgiMakeButtonWithOnClick("ContinueWithWarn", "Continue with Warning", NULL, "return submitClick(this);");
printf(" ");
jsInline(
"$('textarea').change(function() {\n"
" $('#ContinueWithWarn').hide();\n"
"});\n");
}
cgiMakeButtonWithOnClick("Submit", "Submit", NULL, "return submitClick(this);");
printf(" \n");
cgiTableFieldEnd();
}
cgiTableRowEnd();
/* next row - text entry box for data, and clear button */
cgiSimpleTableRowStart();
-puts(" | ");
+puts(" | ");
if (dataUrl)
{
/* can't update via pasting if loaded from URL */
safef(buf, sizeof buf, "Data was uploaded from URL: %s\n"
, ctDataUrl(ct));
cgiMakeTextAreaDisableable(hgCtDataText, buf,
TEXT_ENTRY_ROWS, TEXT_ENTRY_COLS, TRUE);
}
else
{
int rows = (isUpdateForm ? TEXT_ENTRY_ROWS - CONFIG_ENTRY_ROWS :
TEXT_ENTRY_ROWS);
cgiMakeTextArea(hgCtDataText, cartUsualString(cart, hgCtDataText, ""),
rows, TEXT_ENTRY_COLS);
@@ -432,31 +432,31 @@
cgiSimpleTableRowStart();
cgiTableField("Optional track documentation: ");
if (isUpdateForm && ctHtmlUrl(ct))
cgiTableField(" ");
else
{
puts(" | ");
puts("Or upload: ");
cgiMakeFileEntry(hgCtDocFile);
cgiTableFieldEnd();
}
cgiTableRowEnd();
/* next row - text entry for description, and clear button(s) */
cgiSimpleTableRowStart();
-puts(" | ");
+puts(" | ");
if (ct && ctHtmlUrl(ct))
{
safef(buf, sizeof buf, "Replace doc at URL: %s", dataUrl);
cgiMakeTextAreaDisableable(hgCtDocText, buf,
TEXT_ENTRY_ROWS, TEXT_ENTRY_COLS, TRUE);
}
else
{
cgiMakeTextArea(hgCtDocText, cartUsualString(cart, hgCtDocText, ""),
TEXT_ENTRY_ROWS, TEXT_ENTRY_COLS);
cgiTableFieldEnd();
cgiSimpleTableFieldStart();
cgiSimpleTableStart();
cgiSimpleTableRowStart();
@@ -735,30 +735,43 @@
struct slPair *valsAndLabels = slPairNew(hgTracksName(), "Genome Browser");
slAddHead(&valsAndLabels, slPairNew(hgTablesName(), "Table Browser"));
slAddHead(&valsAndLabels, slPairNew(hgVaiName(), "Variant Annotation Integrator"));
slAddHead(&valsAndLabels, slPairNew(hgIntegratorName(), "Data Integrator"));
slReverse(&valsAndLabels);
return valsAndLabels;
}
static void makeOtherCgiForm(char *pos)
/* Make a form for navigating to other CGIs. */
{
struct slPair *valsAndLabels = makeOtherCgiValsAndLabels();
// Default to the first CGI in the menu.
char *defaultCgi = valsAndLabels->name;
char *selected = cartUsualString(cart, hgCtNavDest, defaultCgi);
+if (cfgOptionBooleanDefault("showTutorial", TRUE))
+ {
+ jsIncludeFile("shepherd.min.js", NULL);
+ webIncludeResourceFile("shepherd.css");
+ jsIncludeFile("jquery-ui.js", NULL);
+ webIncludeResourceFile("jquery-ui.css");
+ jsIncludeFile("tutorialPopup.js", NULL);
+ jsIncludeFile("customTrackTutorial.js", NULL);
+ if (sameOk(cgiOptionalString("startCustomTutorial"), "true"))
+ {
+ jsInline("var startCustomTutorialOnLoad = true;");
+ }
+ }
printf("");
}
@@ -827,31 +840,31 @@
/* place for warning messages to appear */
if (isNotEmpty(warnMsg))
{
char *encoded = htmlEncode(warnMsg);
printf(" %s", encoded);
freeMem(encoded);
}
/* count up number of custom tracks for this genome */
int numCts = slCount(ctList);
cgiSimpleTableStart();
cgiSimpleTableRowStart();
if (numCts)
{
- puts(" | ");
+ puts(" | ");
showCustomTrackList(ctList, numCts);
}
else
puts(" | No custom tracks for this genome: ");
puts(" | ");
/* end mainForm; navigation menu has its own form. */
puts("");
puts("");
puts("");
/* determine if there's a navigation position for this screen */
char *pos = NULL;
|