4f5d84f480c9fe7c926e1554e36b618cfe39fbd4 tdreszer Thu Nov 18 10:54:15 2010 -0800 Changed configureByPopup json boolean to configureBy none,popup or clickThrough. diff --git src/hg/hgTracks/imageV2.c src/hg/hgTracks/imageV2.c index 6d2c44f..0d1d024 100644 --- src/hg/hgTracks/imageV2.c +++ src/hg/hgTracks/imageV2.c @@ -135,31 +135,31 @@ enum kindOfChild tdbKindOfChild(struct trackDb *tdb) { enum kindOfChild kindOfChild = kocOrphan; if (tdbIsFolderContent(tdb)) kindOfChild = kocFolderContent; else if (tdbIsCompositeChild(tdb)) kindOfChild = kocCompositeChild; else if (tdbIsMultiTrackChild(tdb)) kindOfChild = kocMultiTrackChild; return kindOfChild; } ///////////////////////// // JSON support. Eventually the whole imgTbl could be written out as JSON -void jsonTdbSettingsBuild(struct dyString **jsonTdbSettingsString, struct track *track) +void jsonTdbSettingsBuild(struct dyString **jsonTdbSettingsString, struct track *track, boolean configurable) // Creates then successively adds trackDb settings to the jsonTdbSettingsString // Initially pass in NULL pointer to a dyString to properly begin building { if (*jsonTdbSettingsString==NULL) { *jsonTdbSettingsString = newDyString(1024); dyStringPrintf(*jsonTdbSettingsString, "<!-- trackDbJson -->\n<script>var trackDbJson = {\n\"ruler\": {\"shortLabel\": \"ruler\", \"longLabel\": \"Base Position Controls\", \"canPack\": 0, \"visibility\": %d},\n", rulerMode); } else dyStringAppend(*jsonTdbSettingsString, ",\n"); // track name and type dyStringPrintf(*jsonTdbSettingsString, "\t\"%s\": {", track->track); dyStringPrintf(*jsonTdbSettingsString, "\n\t\t\"type\": \"%s\",", track->tdb->type); @@ -171,46 +171,52 @@ // Tell something about the parent and/or children if (kindOfChild != kocOrphan) { struct trackDb *parentTdb = (kindOfChild == kocFolderContent ? track->tdb->parent :tdbGetContainer(track->tdb)); dyStringPrintf(*jsonTdbSettingsString, "\n\t\t\"parentTrack\": \"%s\",\n\t\t\"parentLabel\": \"%s\",", parentTdb->track, javaScriptLiteralEncode(parentTdb->shortLabel)); if (kindOfChild != kocFolderContent && !track->canPack) { dyStringPrintf(*jsonTdbSettingsString, "\n\t\t\"shouldPack\": 0,"); // default vis is full, but pack is an option track->canPack = parentTdb->canPack; } } dyStringPrintf(*jsonTdbSettingsString, "\n\t\t\"hasChildren\": %d,", slCount(track->tdb->subtracks)); -// Now some miscellaneous tidbids -if (sameString(trackDbSettingClosestToHomeOrDefault(track->tdb, "configureByPopup", +// Configuring? +if (!configurable) + dyStringPrintf(*jsonTdbSettingsString, "\n\t\t\"configureBy\": \"none\","); +else if (sameString(trackDbSettingClosestToHomeOrDefault(track->tdb, "configureByPopup", matchRegex(track->track, "^snp[0-9]+$") || matchRegex(track->track, "^cons[0-9]+way") || matchRegex(track->track, "^multiz") ? "off" : "on"), "off")) - dyStringPrintf(*jsonTdbSettingsString, "\n\t\t\"configureByPopup\": false,"); + dyStringPrintf(*jsonTdbSettingsString, "\n\t\t\"configureBy\": \"clickThrough\","); +else + dyStringPrintf(*jsonTdbSettingsString, "\n\t\t\"configureBy\": \"popup\","); + +// Remote access by URL? if (sameWord(track->tdb->type, "remote") && trackDbSetting(track->tdb, "url") != NULL) dyStringPrintf(*jsonTdbSettingsString, "\n\t\t\"url\": \"%s\",", trackDbSetting(track->tdb, "url")); // Close with some standard vars dyStringPrintf(*jsonTdbSettingsString, "\n\t\t\"shortLabel\": \"%s\",\n\t\t\"longLabel\": \"%s\",\n\t\t\"canPack\": %d,\n\t\t\"visibility\": %d\n\t}", javaScriptLiteralEncode(track->shortLabel), javaScriptLiteralEncode(track->longLabel), track->canPack, track->limitedVis); } char *jsonTdbSettingsUse(struct dyString **jsonTdbSettingsString) // Closes and returns the contents of the jsonTdbSettingsString { -dyStringAppend(*jsonTdbSettingsString, "}\n</script><!-- trackDbJson -->\n"); +dyStringAppend(*jsonTdbSettingsString, "}\n</script>\n<!-- trackDbJson -->\n"); return dyStringCannibalize(jsonTdbSettingsString); } ///////////////////////// // IMAGEv2 // The new way to do images: PLEASE REFER TO imageV2.h FOR A DETAILED DESCRIPTION ///////////////////////// /////////////////////// Maps struct mapSet *mapSetStart(char *name,struct image *img,char *linkRoot) /* Starts a map (aka mapSet) which is the seet of links and image locations used in HTML. Complete a map by adding items with mapItemAdd() */ @@ -1769,34 +1775,36 @@ hPrintf(" class='tableWithDragAndDrop'"); hPrintf(" style='border:1px solid blue;border-collapse:separate;'>\n"); #if defined(CONTEXT_MENU) || defined(TRACK_SEARCH) struct dyString *jsonTdbVars = NULL; #endif/// defined(CONTEXT_MENU) || defined(TRACK_SEARCH) char *newLine = NEWLINE_TO_USE(cgiClientBrowser(NULL,NULL,NULL)); struct imgTrack *imgTrack = imgBox->imgTracks; for(;imgTrack!=NULL;imgTrack=imgTrack->next) { char *trackName = (imgTrack->name != NULL ? imgTrack->name : imgTrack->tdb->track ); #if defined(CONTEXT_MENU) || defined(TRACK_SEARCH) struct track *track = hashFindVal(trackHash, trackName); if(track) - jsonTdbSettingsBuild(&jsonTdbVars, track); + { + struct imgSlice *slice = imgTrackSliceGetByType(imgTrack,stButton); + boolean configurable = (slice->link != NULL || sliceGetMap(slice,FALSE) != NULL); // sliceMap is overkill since stButton has no image + jsonTdbSettingsBuild(&jsonTdbVars, track, configurable); + } #endif - //if(verbose && imgTrack->order == 3) - // imgTrackShow(NULL,imgTrack,0); hPrintf("<TR id='tr_%s' abbr='%d' class='imgOrd%s%s%s'>\n",trackName,imgTrack->order, (imgTrack->reorderable?" trDraggable":" nodrop nodrag"), (imgTrack->centerLabelSeen != clAlways?" clOpt":""), (imgTrack->ajaxRetrieval ?" mustRetrieve":"")); if(imgBox->showSideLabel && imgBox->plusStrand) { // button safef(name, sizeof(name), "btn_%s", trackName); hPrintf(" <TD id='td_%s'%s>\n",name,(imgTrack->reorderable?" class='dragHandle'":"")); sliceAndMapDraw(imgBox,imgTrack,stButton,name,FALSE); hPrintf("</TD>\n"); // leftLabel safef(name,sizeof(name),"side_%s",trackName); if (imgTrack->reorderable)