Tooltip on Multi-Select Checkbox Item

Forums Classic DFFS Tooltip on Multi-Select Checkbox Item

Viewing 1 reply thread
  • Author
    Posts
    • #13068
      Kasey
      Participant

      Is it possible to tie a tooltip via custom js to a specific option in a choice field that is set to multi-select with checkboxes?

    • #13107
      Alexander Bautz
      Keymaster

      The built in DFFS tooltip can only target the fields, but I created a standalone spin-off here: https://spjsblog.com/2015/03/27/spjs-simple-tooltip/

      If you insert the CSS code in Custom CSS like this:

      div.SPJS_SimpleTooltipPlaceholder img{
      	cursor:pointer;
      }
      #SPJS_SimpleTooltipPlaceholder{
      	/*width:350px;*/
      	white-space:normal;
      	background-color:#E7ECEF;
      	border:1px #9F9E9C solid;
      	display:none;
      	font-size:11px;
      	font-weight:normal;
      	max-width:500px;
      	z-index:1001;
      }
      div.SPJS_SimpleTooltipHolderHead{
      	height: 16px;
      	padding:1px;
      	border-bottom:1px silver solid;
      	background-color:#0072C6;
      }	
      div.SPJS_SimpleTooltipHolderClose{
      	float:right;
      	width: 16px;
      	height: 16px;
      	cursor:pointer;
      	background-repeat: no-repeat;
      	background-image: url();
      }

      And then add the JS code to Custom JS like this:

      var SPJS_SimpleTooltip = {
      	"data":{
      		"isSP13":typeof _spPageContextInfo !== "undefined" && _spPageContextInfo.webUIVersion === 15 ? true : false
      	},
      	"show":function(elm,key){
      		var p = $(elm).position(), l = {};
      		if($("#SPJS_SimpleTooltipPlaceholder").length === 0){
      			$("body").append("<div id='SPJS_SimpleTooltipPlaceholder'></div>");
      		}
      		$(elm).after($("#SPJS_SimpleTooltipPlaceholder"));
      		$("#SPJS_SimpleTooltipPlaceholder").html("<div style='padding:3px;'>"+(SPJS_SimpleTooltipContents[key] !== undefined ? SPJS_SimpleTooltipContents[key] : "The tooltip for key \""+key+"\" was not found.")+"</div>").attr("pin","0").css({"position":"absolute","left":p.left+15});
      		// Check left pos
      		l.l = p.left+30;
      		l.tw = $("#SPJS_SimpleTooltipPlaceholder").width();
      		l.ww = $(window).width();
      		if(l.l + l.tw > l.ww){
      			$("#SPJS_SimpleTooltipPlaceholder").css("left",(p.left - (l.l + l.tw - l.ww)));
      		}
      		$("#SPJS_SimpleTooltipPlaceholder").stop(true,true).fadeIn(200);
      	},
      	"click":function(elm){
      		if($("#SPJS_SimpleTooltipPlaceholder").find("div.SPJS_SimpleTooltipHolderClose").length === 0){
      			$("#SPJS_SimpleTooltipPlaceholder").attr("pin","1").prepend("<div class='SPJS_SimpleTooltipHolderHead'><div class='SPJS_SimpleTooltipHolderClose' onclick='SPJS_SimpleTooltip.hide(true);'></div></div>");
      		}
      	},
      	"hide":function(c){
      		if($("#SPJS_SimpleTooltipPlaceholder").attr("pin") !== "1" || c){
      			$("#SPJS_SimpleTooltipPlaceholder").attr("pin","0").stop(true,true).fadeOut(100);
      		}
      	}
      };

      You can add your custom tooltip text in an object like this in Custom JS:

      var SPJS_SimpleTooltipContents = {
      	"helpText1":"<div style='width:200px;'>This is a custom tooltip for field 1<div style='color:red'>You can use HTML</div></div>",
      	"helpText2":"<div style='width:200px;'>This is a custom tooltip for field 2<div style='color:red'>You can use HTML</div></div>"
      };

      Finally you insert the tooltip trigger (question mark image) like this:

      $("#dffs_MyMultichoiceField")
          .find("input:checkbox:eq(2)")
          .next()
          .after("<img style='vertical-align:middle;margin-left:6px;' onmouseover='SPJS_SimpleTooltip.show(this,\"helpText1\")' onmouseout='SPJS_SimpleTooltip.hide()' onclick='SPJS_SimpleTooltip.click(this)' src='/_layouts/images/hhelp.gif' border='0'>");

      The selector looks at a multichoice field named “MyMultichoiceField” and finds the third checkbox using the selector “input:checkbox:eq(2)” – 0 indexed so 2 is the third checkbox.

      Hope you can use this example.

      Best regards,
      Alexander

Viewing 1 reply thread
  • You must be logged in to reply to this topic.