<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: Make Filter Change Handler for Dashboard in Discussions</title>
    <link>https://community.jmp.com/t5/Discussions/Make-Filter-Change-Handler-for-Dashboard/m-p/870044#M103310</link>
    <description>&lt;P&gt;Hi&amp;nbsp;&lt;a href="https://community.jmp.com/t5/user/viewprofilepage/user-id/29012"&gt;@anna_717&lt;/a&gt;&amp;nbsp;,&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I believe this is due to the Filter Change Handler checking row states, so it is checking to see if the row is changed when you hover over a data point. I made an addition of write("Trigger") into the update_chart to see when it happened in the data set and it was when the mouse hovered over data points.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P data-unlink="true"&gt;This has been an issue &lt;A href="https://community.jmp.com/t5/JMP-Wish-List/Improve-JMP-s-state-handlers-hover-label-row-state-handler/idi-p/527992#U527992" target="_self"&gt;that has been Wishlisted&lt;/A&gt;&amp;nbsp;to see if it can be changed - please add a comment to this so development can see.&lt;/P&gt;
&lt;P data-unlink="true"&gt;&amp;nbsp;&lt;/P&gt;
&lt;P data-unlink="true"&gt;I'm going to tag the author&amp;nbsp;&lt;a href="https://community.jmp.com/t5/user/viewprofilepage/user-id/14366"&gt;@jthi&lt;/a&gt;&amp;nbsp;of the Wishlist item to see if he has some thoughts on some resolutions.&amp;nbsp;&lt;/P&gt;
&lt;P data-unlink="true"&gt;&amp;nbsp;&lt;/P&gt;
&lt;P data-unlink="true"&gt;Thanks,&lt;/P&gt;
&lt;P data-unlink="true"&gt;Ben&lt;/P&gt;</description>
    <pubDate>Thu, 24 Apr 2025 15:04:33 GMT</pubDate>
    <dc:creator>Ben_BarrIngh</dc:creator>
    <dc:date>2025-04-24T15:04:33Z</dc:date>
    <item>
      <title>Make Filter Change Handler for Dashboard</title>
      <link>https://community.jmp.com/t5/Discussions/Make-Filter-Change-Handler-for-Dashboard/m-p/867465#M103018</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-jsl"&gt;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;Hi,&lt;/P&gt;
&lt;P&gt;I have a dashboard with local data filter and a number of graph builder charts in tab page boxes.&lt;/P&gt;
&lt;P&gt;I would like to resize the frameboxes in some of the charts when the local data filter selection is changed.&lt;/P&gt;
&lt;P&gt;I have tried using the code below, but it gives an error: "The OwnerBox was deleted before the message &amp;lt;&amp;lt; could be sent because the Graph Builder needed to recalculate first".&lt;/P&gt;
&lt;P&gt;Can anyone suggest how to overcome this error?&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Thanks&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-jsl"&gt;db_1 = db &amp;lt;&amp;lt; Get Windows();

local_filter = ((db_1[1] &amp;lt;&amp;lt; XPath( "//OutlineBox[text()='Local Data Filter']" )) &amp;lt;&amp;lt; get scriptable object())[1];

update_chart = Function( {a},
	Wait( 1 );
	obj1 = db_1[1] &amp;lt;&amp;lt; xpath( "//TabPageBox[contains(text(),'Weight')]//FrameBox" );
	obj1 &amp;lt;&amp;lt; framesize( 300, 300 );
);

filter_handler = local_filter &amp;lt;&amp;lt; Make Filter Change Handler( update_chart );T&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;This is the error message in the log:&lt;/P&gt;
&lt;P&gt;The OwnerBox was deleted before the message &amp;lt;&amp;lt; could be sent because the Graph Builder needed to recalculate first; the Graph Builder displaybox tree was recreated with new boxes. Use the &amp;lt;&amp;lt;report message to get the new displaybox tree from Graph Builder *after* changing the data table. Automatic Recalc recreates the displaytree after a data table change, just before it is needed -- such as &amp;lt;&amp;lt;report in access or evaluation of 'List' , {/*###*/DisplayBox[], DisplayBox[], DisplayBox[FrameBox], DisplayBox[FrameBox]}&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;This is an example using Big Class sample data:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-jsl"&gt;dt = Open( "$SAMPLE_DATA/Big Class.jmp" );

db = JMP App(
	Set Name( "Dashboard" ),
	Set Description( "A dashboard with a single report" ),
	Auto Launch( 1 ),
	Snap To Grid( 1 ),
	Show Grid( 1 ),
	Show Properties( 0 ),
	Show Sources( 0 ),
	Group By Category( 0 ),
	Dashboard Mode( 1 ),
	Parameters,
	Tables(
		DataTable1 = GuiTable(
			Set Path( "$SAMPLE_DATA/Big Class.jmp" ),
			Set Label( "Big Class" ),
			Location( "Current Data Table" ),
			Invisible( 0 )
		)
	),
	Thumbnail(
		New Image(
			Char To Blob(
				"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",
				"base64compressed"
			),
			"png"
		)
	),
	Script(JSL Quote(// This script is executed when the application is run.
// Named objects have been created for the application modules
// (for example, "Module1") and the pre-defined object
// "thisApplication" refers to the application object itself.
// Variables and functions declared here are scoped to the
// Application namespace.

)	),
	Allocate(
		Module1 = Plan(
			PreAllocate,
			Script(JSL Quote(				thisModuleInstance &amp;lt;&amp;lt; Create Objects;				Try(MainTabPage &amp;lt;&amp;lt; Set Scriptable Object(thisApplication));			
)			),
			Allocate(
				DataFilterContext1 = Data Filter Context Box();
				MainTabPage = Tab Page Box();
				Splitter1 = H Splitter Box();
				TabPage1 = Tab Page Box();
				Scroll1 = Scroll Box();
				DataFilter1 = DataTable1 &amp;lt;&amp;lt;
				Data Filter(
					Local,
					Add Filter( columns( :sex ), Where( :sex == {"F", "M"} ) )
				);
				Splitter2 = V Splitter Box();
				TabPage2 = Tab Page Box();
				Scroll2 = Scroll Box();
				Report1 = Platform(
					DataTable1,
					Tabulate(
						Show Control Panel( 0 ),
						Add Table(
							Column Table(
								Analysis Columns( :height ),
								Statistics( Mean, Std Dev )
							),
							Column Table(
								Analysis Columns( :weight ),
								Statistics( Mean, Std Dev )
							),
							Row Table( Grouping Columns( :sex, :age ) )
						),
						SendToReport(
							Dispatch(
								{},
								"",
								TextBox,
								{Set Base Font( "Heading" )}
							)
						)
					)
				);
				Splitter3 = H Splitter Box();
				TabList2 = Tab Box();
				TabPage3 = Tab Page Box();
				Scroll3 = Scroll Box();
				Report2 = Platform(
					DataTable1,
					Graph Builder(
						Size( 389, 236 ),
						Show Control Panel( 0 ),
						Fit to Window( "Off" ),
						Variables( X( :age ), Y( :weight ), Group X( :sex ) ),
						Elements(
							Points( X, Y, Legend( 20 ) ),
							Box Plot( X, Y, Legend( 21 ) )
						)
					)
				);
				TabList1 = Tab Box();
				TabPage4 = Tab Page Box();
				Scroll4 = Scroll Box();
				Report3 = Platform(
					DataTable1,
					Graph Builder(
						Size( 234, 204 ),
						Show Control Panel( 0 ),
						Fit to Window( "Off" ),
						Variables( X( :age ), Overlay( :sex ) ),
						Elements( Bar( X, Legend( 2 ) ) )
					)
				);
				TabPage5 = Tab Page Box();
				Scroll5 = Scroll Box();
				Report4 = Platform(
					DataTable1,
					Graph Builder(
						Size( 327, 204 ),
						Show Control Panel( 0 ),
						Fit to Window( "Off" ),
						Variables(
							X( :weight ),
							Y( :height ),
							Group X( :sex ),
							Color( :age )
						),
						Elements(
							Points( X, Y, Legend( 11 ) ),
							Smoother( X, Y, Legend( 12 ) )
						)
					)
				);
			),
			Organize(
				Reparent( Scroll5( Report4 ) );
				Reparent( TabPage5( Scroll5 ) );
				Reparent( TabList1( TabPage5 ) );
				Reparent( Scroll4( Report3 ) );
				Reparent( TabPage4( Scroll4 ) );
				Reparent( TabList1( TabPage4 ) );
				Reparent(
					TabList2(
						"Other charts",
						Tip( "" ),
						Icon( "" ),
						Closeable( 0 ),
						TabList1
					)
				);
				Reparent( Scroll3( Report2 ) );
				Reparent( TabPage3( Scroll3 ) );
				Reparent( TabList2( TabPage3 ) );
				Reparent( Splitter3( TabList2 ) );
				Reparent( Splitter2( Splitter3 ) );
				Reparent( Scroll2( Report1 ) );
				Reparent( TabPage2( Scroll2 ) );
				Reparent( Splitter2( TabPage2 ) );
				Reparent( Splitter1( Splitter2 ) );
				Reparent( Scroll1( DataFilter1 ) );
				Reparent( TabPage1( Scroll1 ) );
				Reparent( Splitter1( TabPage1 ) );
				Reparent( MainTabPage( Splitter1 ) );
				Reparent( DataFilterContext1( MainTabPage ) );
				Relocate( DataFilterContext1( 0, 0 ) );
			),
			Initialize(
				DataFilterContext1 &amp;lt;&amp;lt; Background Color( "None" ),
				DataFilterContext1 &amp;lt;&amp;lt; Border(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), DataFilterContext1 &amp;lt;&amp;lt; Enabled( 1 ),
				DataFilterContext1 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				DataFilterContext1 &amp;lt;&amp;lt; Margin(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				),
				DataFilterContext1 &amp;lt;&amp;lt; Padding(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), DataFilterContext1 &amp;lt;&amp;lt; Text Color( "None" ),
				DataFilterContext1 &amp;lt;&amp;lt; UI Only( 0 ),
				DataFilterContext1 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				DataFilterContext1 &amp;lt;&amp;lt; Visibility( "Visible" ),
				DataFilterContext1 &amp;lt;&amp;lt; Set Min Size( 356, 191 ),
				DataFilterContext1 &amp;lt;&amp;lt; Set Max Size( 30000, 30000 ),
				DataFilterContext1 &amp;lt;&amp;lt; Set Stretch( {"Neutral", "Neutral"} ),
				MainTabPage &amp;lt;&amp;lt; Background Color( "None" ),
				MainTabPage &amp;lt;&amp;lt; Border(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), MainTabPage &amp;lt;&amp;lt; Enabled( 1 ),
				MainTabPage &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				MainTabPage &amp;lt;&amp;lt; Margin(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				),
				MainTabPage &amp;lt;&amp;lt; Padding(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), MainTabPage &amp;lt;&amp;lt; Text Color( "None" ), MainTabPage &amp;lt;&amp;lt; UI Only( 0 ),
				MainTabPage &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				MainTabPage &amp;lt;&amp;lt; Visibility( "Visible" ),
				MainTabPage &amp;lt;&amp;lt; Set Min Size( 356, 191 ),
				MainTabPage &amp;lt;&amp;lt; Set Max Size( 30000, 30000 ),
				MainTabPage &amp;lt;&amp;lt; Set Stretch( {"Neutral", "Neutral"} ),
				MainTabPage &amp;lt;&amp;lt; Title( "Dashboard" ), MainTabPage &amp;lt;&amp;lt; Tip( "" ),
				MainTabPage &amp;lt;&amp;lt; Icon( "" ), MainTabPage &amp;lt;&amp;lt; Closeable( 0 ),
				MainTabPage &amp;lt;&amp;lt; Moveable( 0 ), MainTabPage &amp;lt;&amp;lt; Set Base Font( "Text" ),
				MainTabPage &amp;lt;&amp;lt; Set Font Scale( 1 ),
				Splitter1 &amp;lt;&amp;lt; Background Color( "None" ),
				Splitter1 &amp;lt;&amp;lt; Border(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), Splitter1 &amp;lt;&amp;lt; Enabled( 1 ),
				Splitter1 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				Splitter1 &amp;lt;&amp;lt; Margin(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				),
				Splitter1 &amp;lt;&amp;lt; Padding(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), Splitter1 &amp;lt;&amp;lt; Text Color( "None" ), Splitter1 &amp;lt;&amp;lt; UI Only( 0 ),
				Splitter1 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				Splitter1 &amp;lt;&amp;lt; Visibility( "Visible" ), Splitter1 &amp;lt;&amp;lt; Dockable( 1 ),
				Splitter1 &amp;lt;&amp;lt; Set Width( 794 ), Splitter1 &amp;lt;&amp;lt; Set Height( 529 ),
				Splitter1 &amp;lt;&amp;lt; Set Sizes( {0.347197106690778, 0.652802893309222} ),
				Splitter1 &amp;lt;&amp;lt; Set Min Size( 356, 165 ),
				Splitter1 &amp;lt;&amp;lt; Set Max Size( 60015, 60067 ),
				Splitter1 &amp;lt;&amp;lt; Set Stretch( {"Window", "Window"} ),
				Splitter1 &amp;lt;&amp;lt; set horizontal( 1 ),
				TabPage1 &amp;lt;&amp;lt; Background Color( "None" ),
				TabPage1 &amp;lt;&amp;lt; Border( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				TabPage1 &amp;lt;&amp;lt; Enabled( 1 ),
				TabPage1 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				TabPage1 &amp;lt;&amp;lt; Margin( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				TabPage1 &amp;lt;&amp;lt; Padding(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), TabPage1 &amp;lt;&amp;lt; Text Color( "None" ), TabPage1 &amp;lt;&amp;lt; UI Only( 0 ),
				TabPage1 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				TabPage1 &amp;lt;&amp;lt; Visibility( "Visible" ),
				TabPage1 &amp;lt;&amp;lt; Set Min Size( 72, 62 ),
				TabPage1 &amp;lt;&amp;lt; Set Max Size( 30000, 30000 ),
				TabPage1 &amp;lt;&amp;lt; Set Stretch( {"Neutral", "Neutral"} ),
				TabPage1 &amp;lt;&amp;lt; Title( "Local Data Filter" ), TabPage1 &amp;lt;&amp;lt; Tip( "" ),
				TabPage1 &amp;lt;&amp;lt; Icon( "Filter" ), TabPage1 &amp;lt;&amp;lt; Closeable( 1 ),
				TabPage1 &amp;lt;&amp;lt; Moveable( 1 ), TabPage1 &amp;lt;&amp;lt; Set Base Font( "Text" ),
				TabPage1 &amp;lt;&amp;lt; Set Font Scale( 1 ),
				Scroll1 &amp;lt;&amp;lt; Background Color( "None" ),
				Scroll1 &amp;lt;&amp;lt; Border( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Scroll1 &amp;lt;&amp;lt; Enabled( 1 ),
				Scroll1 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				Scroll1 &amp;lt;&amp;lt; Margin( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Scroll1 &amp;lt;&amp;lt; Padding( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Scroll1 &amp;lt;&amp;lt; Text Color( "None" ), Scroll1 &amp;lt;&amp;lt; UI Only( 0 ),
				Scroll1 &amp;lt;&amp;lt; User Resizable( {1, 1} ),
				Scroll1 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				Scroll1 &amp;lt;&amp;lt; Visibility( "Visible" ),
				Scroll1 &amp;lt;&amp;lt; Set Min Size( 72, 36 ),
				Scroll1 &amp;lt;&amp;lt; Set Max Size( 30000, 30000 ),
				Scroll1 &amp;lt;&amp;lt; Set Stretch( {"Window", "Window"} ),
				Scroll1 &amp;lt;&amp;lt; Width( 275 ), Scroll1 &amp;lt;&amp;lt; Height( 503 ),
				Scroll1 &amp;lt;&amp;lt; Set Auto Scrollable( 1 ),
				Scroll1 &amp;lt;&amp;lt; Set Scrollers( 1, 1 ), Scroll1 &amp;lt;&amp;lt; Set Show Empty( 0 ),
				Scroll1 &amp;lt;&amp;lt; Set Clip Printing( 0 ),
				DataFilter1 &amp;lt;&amp;lt; Background Color( "None" ),
				DataFilter1 &amp;lt;&amp;lt; Border(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), DataFilter1 &amp;lt;&amp;lt; Enabled( 1 ),
				DataFilter1 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				DataFilter1 &amp;lt;&amp;lt; Margin(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				),
				DataFilter1 &amp;lt;&amp;lt; Padding(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), DataFilter1 &amp;lt;&amp;lt; Text Color( "None" ), DataFilter1 &amp;lt;&amp;lt; UI Only( 0 ),
				DataFilter1 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				DataFilter1 &amp;lt;&amp;lt; Visibility( "Visible" ),
				DataFilter1 &amp;lt;&amp;lt; Set Min Size( 192, 164 ),
				DataFilter1 &amp;lt;&amp;lt; Set Max Size( 30004, 164 ),
				DataFilter1 &amp;lt;&amp;lt; Set Stretch( {"Neutral", "Neutral"} ),
				Splitter2 &amp;lt;&amp;lt; Background Color( "None" ),
				Splitter2 &amp;lt;&amp;lt; Border(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), Splitter2 &amp;lt;&amp;lt; Enabled( 1 ),
				Splitter2 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				Splitter2 &amp;lt;&amp;lt; Margin(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				),
				Splitter2 &amp;lt;&amp;lt; Padding(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), Splitter2 &amp;lt;&amp;lt; Text Color( "None" ), Splitter2 &amp;lt;&amp;lt; UI Only( 0 ),
				Splitter2 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				Splitter2 &amp;lt;&amp;lt; Visibility( "Visible" ), Splitter2 &amp;lt;&amp;lt; Dockable( 1 ),
				Splitter2 &amp;lt;&amp;lt; Set Width( 516 ), Splitter2 &amp;lt;&amp;lt; Set Height( 529 ),
				Splitter2 &amp;lt;&amp;lt; Set Sizes( {0.459409594095941, 0.540590405904059} ),
				Splitter2 &amp;lt;&amp;lt; Set Min Size( 281, 165 ),
				Splitter2 &amp;lt;&amp;lt; Set Max Size( 30012, 60067 ),
				Splitter2 &amp;lt;&amp;lt; Set Stretch( {"Window", "Window"} ),
				Splitter2 &amp;lt;&amp;lt; set horizontal( 0 ),
				TabPage2 &amp;lt;&amp;lt; Background Color( "None" ),
				TabPage2 &amp;lt;&amp;lt; Border( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				TabPage2 &amp;lt;&amp;lt; Enabled( 1 ),
				TabPage2 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				TabPage2 &amp;lt;&amp;lt; Margin( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				TabPage2 &amp;lt;&amp;lt; Padding(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), TabPage2 &amp;lt;&amp;lt; Text Color( "None" ), TabPage2 &amp;lt;&amp;lt; UI Only( 0 ),
				TabPage2 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				TabPage2 &amp;lt;&amp;lt; Visibility( "Visible" ),
				TabPage2 &amp;lt;&amp;lt; Set Min Size( 72, 62 ),
				TabPage2 &amp;lt;&amp;lt; Set Max Size( 30000, 30000 ),
				TabPage2 &amp;lt;&amp;lt; Set Stretch( {"Neutral", "Neutral"} ),
				TabPage2 &amp;lt;&amp;lt; Title( "Tabulate" ), TabPage2 &amp;lt;&amp;lt; Tip( "" ),
				TabPage2 &amp;lt;&amp;lt; Icon( "Tabulate" ), TabPage2 &amp;lt;&amp;lt; Closeable( 1 ),
				TabPage2 &amp;lt;&amp;lt; Moveable( 1 ), TabPage2 &amp;lt;&amp;lt; Set Base Font( "Text" ),
				TabPage2 &amp;lt;&amp;lt; Set Font Scale( 1 ),
				Scroll2 &amp;lt;&amp;lt; Background Color( "None" ),
				Scroll2 &amp;lt;&amp;lt; Border( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Scroll2 &amp;lt;&amp;lt; Enabled( 1 ),
				Scroll2 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				Scroll2 &amp;lt;&amp;lt; Margin( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Scroll2 &amp;lt;&amp;lt; Padding( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Scroll2 &amp;lt;&amp;lt; Text Color( "None" ), Scroll2 &amp;lt;&amp;lt; UI Only( 0 ),
				Scroll2 &amp;lt;&amp;lt; User Resizable( {1, 1} ),
				Scroll2 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				Scroll2 &amp;lt;&amp;lt; Visibility( "Visible" ),
				Scroll2 &amp;lt;&amp;lt; Set Min Size( 72, 36 ),
				Scroll2 &amp;lt;&amp;lt; Set Max Size( 30000, 30000 ),
				Scroll2 &amp;lt;&amp;lt; Set Stretch( {"Window", "Window"} ),
				Scroll2 &amp;lt;&amp;lt; Width( 516 ), Scroll2 &amp;lt;&amp;lt; Height( 215 ),
				Scroll2 &amp;lt;&amp;lt; Set Auto Scrollable( 1 ),
				Scroll2 &amp;lt;&amp;lt; Set Scrollers( 1, 1 ), Scroll2 &amp;lt;&amp;lt; Set Show Empty( 0 ),
				Scroll2 &amp;lt;&amp;lt; Set Clip Printing( 0 ),
				Report1 &amp;lt;&amp;lt; Background Color( "None" ),
				Report1 &amp;lt;&amp;lt; Border( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Report1 &amp;lt;&amp;lt; Enabled( 1 ),
				Report1 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				Report1 &amp;lt;&amp;lt; Margin( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Report1 &amp;lt;&amp;lt; Padding( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Report1 &amp;lt;&amp;lt; Text Color( "None" ), Report1 &amp;lt;&amp;lt; UI Only( 0 ),
				Report1 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				Report1 &amp;lt;&amp;lt; Visibility( "Visible" ),
				Report1 &amp;lt;&amp;lt; Set Min Size( 312, 296 ),
				Report1 &amp;lt;&amp;lt; Set Max Size( 312, 296 ),
				Report1 &amp;lt;&amp;lt; Set Stretch( {"Neutral", "Neutral"} ),
				Report1 &amp;lt;&amp;lt; set horizontal( 0 ),
				Splitter3 &amp;lt;&amp;lt; Background Color( "None" ),
				Splitter3 &amp;lt;&amp;lt; Border(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), Splitter3 &amp;lt;&amp;lt; Enabled( 1 ),
				Splitter3 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				Splitter3 &amp;lt;&amp;lt; Margin(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				),
				Splitter3 &amp;lt;&amp;lt; Padding(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), Splitter3 &amp;lt;&amp;lt; Text Color( "None" ), Splitter3 &amp;lt;&amp;lt; UI Only( 0 ),
				Splitter3 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				Splitter3 &amp;lt;&amp;lt; Visibility( "Visible" ), Splitter3 &amp;lt;&amp;lt; Dockable( 1 ),
				Splitter3 &amp;lt;&amp;lt; Set Width( 516 ), Splitter3 &amp;lt;&amp;lt; Set Height( 285 ),
				Splitter3 &amp;lt;&amp;lt; Set Sizes( {1} ), Splitter3 &amp;lt;&amp;lt; Set Min Size( 281, 100 ),
				Splitter3 &amp;lt;&amp;lt; Set Max Size( 30012, 30064 ),
				Splitter3 &amp;lt;&amp;lt; Set Stretch( {"Window", "Window"} ),
				Splitter3 &amp;lt;&amp;lt; set horizontal( 1 ),
				TabList2 &amp;lt;&amp;lt; Background Color( "None" ),
				TabList2 &amp;lt;&amp;lt; Border( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				TabList2 &amp;lt;&amp;lt; Enabled( 1 ),
				TabList2 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				TabList2 &amp;lt;&amp;lt; Margin( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				TabList2 &amp;lt;&amp;lt; Padding(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), TabList2 &amp;lt;&amp;lt; Text Color( "None" ), TabList2 &amp;lt;&amp;lt; UI Only( 0 ),
				TabList2 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				TabList2 &amp;lt;&amp;lt; Visibility( "Visible" ), TabList2 &amp;lt;&amp;lt; Dockable( 0 ),
				TabList2 &amp;lt;&amp;lt; Set Min Size( 281, 100 ),
				TabList2 &amp;lt;&amp;lt; Set Max Size( 30012, 30064 ),
				TabList2 &amp;lt;&amp;lt; Set Stretch( {"Neutral", "Neutral"} ),
				TabList2 &amp;lt;&amp;lt; Set Selected( 2 ), TabList2 &amp;lt;&amp;lt; Set Style( "Tab" ),
				TabList2 &amp;lt;&amp;lt; Set Title Location( "Top" ),
				TabList2 &amp;lt;&amp;lt; Set Overflow Enabled( 0 ),
				TabList2 &amp;lt;&amp;lt; Set Tab Close( Empty() ),
				TabList2 &amp;lt;&amp;lt; Set Tab Close Tip( "" ),
				TabList2 &amp;lt;&amp;lt; Set Tab New( Empty() ),
				TabList2 &amp;lt;&amp;lt; Set Tab New Tip( "" ),
				TabList2 &amp;lt;&amp;lt; Set Tab New Icon( "" ), TabList2 &amp;lt;&amp;lt; Show Tabs( 1 ),
				TabList2 &amp;lt;&amp;lt; Set Tab Changed( Empty() ),
				TabPage3 &amp;lt;&amp;lt; Background Color( "None" ),
				TabPage3 &amp;lt;&amp;lt; Border( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				TabPage3 &amp;lt;&amp;lt; Enabled( 1 ),
				TabPage3 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				TabPage3 &amp;lt;&amp;lt; Margin( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				TabPage3 &amp;lt;&amp;lt; Padding(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), TabPage3 &amp;lt;&amp;lt; Text Color( "None" ), TabPage3 &amp;lt;&amp;lt; UI Only( 0 ),
				TabPage3 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				TabPage3 &amp;lt;&amp;lt; Visibility( "Visible" ),
				TabPage3 &amp;lt;&amp;lt; Set Min Size( 72, 36 ),
				TabPage3 &amp;lt;&amp;lt; Set Max Size( 30000, 30000 ),
				TabPage3 &amp;lt;&amp;lt; Set Stretch( {"Neutral", "Neutral"} ),
				TabPage3 &amp;lt;&amp;lt; Title( "Age v Weight" ), TabPage3 &amp;lt;&amp;lt; Tip( "" ),
				TabPage3 &amp;lt;&amp;lt; Icon( "Trellis" ), TabPage3 &amp;lt;&amp;lt; Closeable( 1 ),
				TabPage3 &amp;lt;&amp;lt; Moveable( 1 ), TabPage3 &amp;lt;&amp;lt; Set Base Font( "Text" ),
				TabPage3 &amp;lt;&amp;lt; Set Font Scale( 1 ),
				Scroll3 &amp;lt;&amp;lt; Background Color( "None" ),
				Scroll3 &amp;lt;&amp;lt; Border( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Scroll3 &amp;lt;&amp;lt; Enabled( 1 ),
				Scroll3 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				Scroll3 &amp;lt;&amp;lt; Margin( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Scroll3 &amp;lt;&amp;lt; Padding( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Scroll3 &amp;lt;&amp;lt; Text Color( "None" ), Scroll3 &amp;lt;&amp;lt; UI Only( 0 ),
				Scroll3 &amp;lt;&amp;lt; User Resizable( {1, 1} ),
				Scroll3 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				Scroll3 &amp;lt;&amp;lt; Visibility( "Visible" ),
				Scroll3 &amp;lt;&amp;lt; Set Min Size( 72, 36 ),
				Scroll3 &amp;lt;&amp;lt; Set Max Size( 30000, 30000 ),
				Scroll3 &amp;lt;&amp;lt; Set Stretch( {"Window", "Window"} ),
				Scroll3 &amp;lt;&amp;lt; Width( 510 ), Scroll3 &amp;lt;&amp;lt; Height( 253 ),
				Scroll3 &amp;lt;&amp;lt; Set Auto Scrollable( 1 ),
				Scroll3 &amp;lt;&amp;lt; Set Scrollers( 1, 1 ), Scroll3 &amp;lt;&amp;lt; Set Show Empty( 0 ),
				Scroll3 &amp;lt;&amp;lt; Set Clip Printing( 0 ),
				Report2 &amp;lt;&amp;lt; Background Color( "None" ),
				Report2 &amp;lt;&amp;lt; Border( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Report2 &amp;lt;&amp;lt; Enabled( 1 ),
				Report2 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				Report2 &amp;lt;&amp;lt; Margin( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Report2 &amp;lt;&amp;lt; Padding( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Report2 &amp;lt;&amp;lt; Text Color( "None" ), Report2 &amp;lt;&amp;lt; UI Only( 0 ),
				Report2 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				Report2 &amp;lt;&amp;lt; Visibility( "Visible" ),
				Report2 &amp;lt;&amp;lt; Set Min Size( 472, 253 ),
				Report2 &amp;lt;&amp;lt; Set Max Size( 472, 253 ),
				Report2 &amp;lt;&amp;lt; Set Stretch( {"Neutral", "Neutral"} ),
				Report2 &amp;lt;&amp;lt; set horizontal( 0 ),
				TabList1 &amp;lt;&amp;lt; Background Color( "None" ),
				TabList1 &amp;lt;&amp;lt; Border( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				TabList1 &amp;lt;&amp;lt; Enabled( 1 ),
				TabList1 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				TabList1 &amp;lt;&amp;lt; Margin( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				TabList1 &amp;lt;&amp;lt; Padding(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), TabList1 &amp;lt;&amp;lt; Text Color( "None" ), TabList1 &amp;lt;&amp;lt; UI Only( 0 ),
				TabList1 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				TabList1 &amp;lt;&amp;lt; Visibility( "Visible" ), TabList1 &amp;lt;&amp;lt; Dockable( 0 ),
				TabList1 &amp;lt;&amp;lt; Set Min Size( 275, 68 ),
				TabList1 &amp;lt;&amp;lt; Set Max Size( 30006, 30032 ),
				TabList1 &amp;lt;&amp;lt; Set Stretch( {"Neutral", "Neutral"} ),
				TabList1 &amp;lt;&amp;lt; Set Selected( 1 ), TabList1 &amp;lt;&amp;lt; Set Style( "Tab" ),
				TabList1 &amp;lt;&amp;lt; Set Title Location( "Top" ),
				TabList1 &amp;lt;&amp;lt; Set Overflow Enabled( 0 ),
				TabList1 &amp;lt;&amp;lt; Set Tab Close( Empty() ),
				TabList1 &amp;lt;&amp;lt; Set Tab Close Tip( "" ),
				TabList1 &amp;lt;&amp;lt; Set Tab New( Empty() ),
				TabList1 &amp;lt;&amp;lt; Set Tab New Tip( "" ),
				TabList1 &amp;lt;&amp;lt; Set Tab New Icon( "" ), TabList1 &amp;lt;&amp;lt; Show Tabs( 1 ),
				TabList1 &amp;lt;&amp;lt; Set Tab Changed( Empty() ),
				TabPage4 &amp;lt;&amp;lt; Background Color( "None" ),
				TabPage4 &amp;lt;&amp;lt; Border( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				TabPage4 &amp;lt;&amp;lt; Enabled( 1 ),
				TabPage4 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				TabPage4 &amp;lt;&amp;lt; Margin( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				TabPage4 &amp;lt;&amp;lt; Padding(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), TabPage4 &amp;lt;&amp;lt; Text Color( "None" ), TabPage4 &amp;lt;&amp;lt; UI Only( 0 ),
				TabPage4 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				TabPage4 &amp;lt;&amp;lt; Visibility( "Visible" ),
				TabPage4 &amp;lt;&amp;lt; Set Min Size( 72, 36 ),
				TabPage4 &amp;lt;&amp;lt; Set Max Size( 30000, 30000 ),
				TabPage4 &amp;lt;&amp;lt; Set Stretch( {"Neutral", "Neutral"} ),
				TabPage4 &amp;lt;&amp;lt; Title( "Age count" ), TabPage4 &amp;lt;&amp;lt; Tip( "" ),
				TabPage4 &amp;lt;&amp;lt; Icon( "Trellis" ), TabPage4 &amp;lt;&amp;lt; Closeable( 1 ),
				TabPage4 &amp;lt;&amp;lt; Moveable( 1 ), TabPage4 &amp;lt;&amp;lt; Set Base Font( "Text" ),
				TabPage4 &amp;lt;&amp;lt; Set Font Scale( 1 ),
				Scroll4 &amp;lt;&amp;lt; Background Color( "None" ),
				Scroll4 &amp;lt;&amp;lt; Border( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Scroll4 &amp;lt;&amp;lt; Enabled( 1 ),
				Scroll4 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				Scroll4 &amp;lt;&amp;lt; Margin( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Scroll4 &amp;lt;&amp;lt; Padding( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Scroll4 &amp;lt;&amp;lt; Text Color( "None" ), Scroll4 &amp;lt;&amp;lt; UI Only( 0 ),
				Scroll4 &amp;lt;&amp;lt; User Resizable( {1, 1} ),
				Scroll4 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				Scroll4 &amp;lt;&amp;lt; Visibility( "Visible" ),
				Scroll4 &amp;lt;&amp;lt; Set Min Size( 72, 36 ),
				Scroll4 &amp;lt;&amp;lt; Set Max Size( 30000, 30000 ),
				Scroll4 &amp;lt;&amp;lt; Set Stretch( {"Window", "Window"} ),
				Scroll4 &amp;lt;&amp;lt; Width( 504 ), Scroll4 &amp;lt;&amp;lt; Height( 221 ),
				Scroll4 &amp;lt;&amp;lt; Set Auto Scrollable( 1 ),
				Scroll4 &amp;lt;&amp;lt; Set Scrollers( 1, 1 ), Scroll4 &amp;lt;&amp;lt; Set Show Empty( 0 ),
				Scroll4 &amp;lt;&amp;lt; Set Clip Printing( 0 ),
				Report3 &amp;lt;&amp;lt; Background Color( "None" ),
				Report3 &amp;lt;&amp;lt; Border( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Report3 &amp;lt;&amp;lt; Enabled( 1 ),
				Report3 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				Report3 &amp;lt;&amp;lt; Margin( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Report3 &amp;lt;&amp;lt; Padding( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Report3 &amp;lt;&amp;lt; Text Color( "None" ), Report3 &amp;lt;&amp;lt; UI Only( 0 ),
				Report3 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				Report3 &amp;lt;&amp;lt; Visibility( "Visible" ),
				Report3 &amp;lt;&amp;lt; Set Min Size( 289, 221 ),
				Report3 &amp;lt;&amp;lt; Set Max Size( 289, 221 ),
				Report3 &amp;lt;&amp;lt; Set Stretch( {"Neutral", "Neutral"} ),
				Report3 &amp;lt;&amp;lt; set horizontal( 0 ),
				TabPage5 &amp;lt;&amp;lt; Background Color( "None" ),
				TabPage5 &amp;lt;&amp;lt; Border( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				TabPage5 &amp;lt;&amp;lt; Enabled( 1 ),
				TabPage5 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				TabPage5 &amp;lt;&amp;lt; Margin( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				TabPage5 &amp;lt;&amp;lt; Padding(
					{Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )}
				), TabPage5 &amp;lt;&amp;lt; Text Color( "None" ), TabPage5 &amp;lt;&amp;lt; UI Only( 0 ),
				TabPage5 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				TabPage5 &amp;lt;&amp;lt; Visibility( "Visible" ),
				TabPage5 &amp;lt;&amp;lt; Set Min Size( 72, 36 ),
				TabPage5 &amp;lt;&amp;lt; Set Max Size( 30000, 30000 ),
				TabPage5 &amp;lt;&amp;lt; Set Stretch( {"Neutral", "Neutral"} ),
				TabPage5 &amp;lt;&amp;lt; Title( "Height v Weight" ), TabPage5 &amp;lt;&amp;lt; Tip( "" ),
				TabPage5 &amp;lt;&amp;lt; Icon( "Trellis" ), TabPage5 &amp;lt;&amp;lt; Closeable( 1 ),
				TabPage5 &amp;lt;&amp;lt; Moveable( 1 ), TabPage5 &amp;lt;&amp;lt; Set Base Font( "Text" ),
				TabPage5 &amp;lt;&amp;lt; Set Font Scale( 1 ),
				Scroll5 &amp;lt;&amp;lt; Background Color( "None" ),
				Scroll5 &amp;lt;&amp;lt; Border( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Scroll5 &amp;lt;&amp;lt; Enabled( 1 ),
				Scroll5 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				Scroll5 &amp;lt;&amp;lt; Margin( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Scroll5 &amp;lt;&amp;lt; Padding( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Scroll5 &amp;lt;&amp;lt; Text Color( "None" ), Scroll5 &amp;lt;&amp;lt; UI Only( 0 ),
				Scroll5 &amp;lt;&amp;lt; User Resizable( {1, 1} ),
				Scroll5 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				Scroll5 &amp;lt;&amp;lt; Visibility( "Visible" ),
				Scroll5 &amp;lt;&amp;lt; Set Min Size( 72, 36 ),
				Scroll5 &amp;lt;&amp;lt; Set Max Size( 30000, 30000 ),
				Scroll5 &amp;lt;&amp;lt; Set Stretch( {"Window", "Window"} ),
				Scroll5 &amp;lt;&amp;lt; Width( 504 ), Scroll5 &amp;lt;&amp;lt; Height( 221 ),
				Scroll5 &amp;lt;&amp;lt; Set Auto Scrollable( 1 ),
				Scroll5 &amp;lt;&amp;lt; Set Scrollers( 1, 1 ), Scroll5 &amp;lt;&amp;lt; Set Show Empty( 0 ),
				Scroll5 &amp;lt;&amp;lt; Set Clip Printing( 0 ),
				Report4 &amp;lt;&amp;lt; Background Color( "None" ),
				Report4 &amp;lt;&amp;lt; Border( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Report4 &amp;lt;&amp;lt; Enabled( 1 ),
				Report4 &amp;lt;&amp;lt; Horizontal Alignment( "Default" ),
				Report4 &amp;lt;&amp;lt; Margin( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Report4 &amp;lt;&amp;lt; Padding( {Left( 0 ), Top( 0 ), Right( 0 ), Bottom( 0 )} ),
				Report4 &amp;lt;&amp;lt; Text Color( "None" ), Report4 &amp;lt;&amp;lt; UI Only( 0 ),
				Report4 &amp;lt;&amp;lt; Vertical Alignment( "Default" ),
				Report4 &amp;lt;&amp;lt; Visibility( "Visible" ),
				Report4 &amp;lt;&amp;lt; Set Min Size( 414, 221 ),
				Report4 &amp;lt;&amp;lt; Set Max Size( 414, 221 ),
				Report4 &amp;lt;&amp;lt; Set Stretch( {"Neutral", "Neutral"} ),
				Report4 &amp;lt;&amp;lt; set horizontal( 0 )
			)
		)
	),
	Initialize(
		Module1 &amp;lt;&amp;lt; Auto Launch( 1 );
		Module1 &amp;lt;&amp;lt; Set Module Type( "Report" );
		Module1 &amp;lt;&amp;lt; Set Window Title( "^TABLENAME - ^APPNAME" );
	)
) &amp;lt;&amp;lt; Run;


db_1 = db &amp;lt;&amp;lt; Get Windows();

local_filter = ((db_1[1] &amp;lt;&amp;lt; XPath( "//OutlineBox[text()='Local Data Filter']" )) &amp;lt;&amp;lt; get scriptable object())[1];

update_chart = Function( {a},
	Wait( 1 );
	obj1 = db_1[1] &amp;lt;&amp;lt; xpath( "//TabPageBox[contains(text(),'Weight')]//FrameBox" );
	obj1 &amp;lt;&amp;lt; framesize( 300, 300 );
);

filter_handler = local_filter &amp;lt;&amp;lt; Make Filter Change Handler( update_chart );&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Thu, 10 Apr 2025 10:18:14 GMT</pubDate>
      <guid>https://community.jmp.com/t5/Discussions/Make-Filter-Change-Handler-for-Dashboard/m-p/867465#M103018</guid>
      <dc:creator>anna_717</dc:creator>
      <dc:date>2025-04-10T10:18:14Z</dc:date>
    </item>
    <item>
      <title>Re: Make Filter Change Handler for Dashboard</title>
      <link>https://community.jmp.com/t5/Discussions/Make-Filter-Change-Handler-for-Dashboard/m-p/869697#M103252</link>
      <description>&lt;P&gt;Hi&amp;nbsp;&lt;a href="https://community.jmp.com/t5/user/viewprofilepage/user-id/29012"&gt;@anna_717&lt;/a&gt;&amp;nbsp;,&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;You can add an Eval(Eval Expr(.... to the final part of the script to force the JSL to evaluate the newly created display box - in the case of the dashboard the whole display tree is being re-written every time a filter change is applied - so the script gets confused with the object reference for obj1, the Eval term helps to force JMP to check that the term exists and properly references it.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-jsl"&gt;db_1 = db &amp;lt;&amp;lt; Get Windows();

local_filter = ((db_1[1] &amp;lt;&amp;lt; XPath( "//OutlineBox[text()='Local Data Filter']" )) &amp;lt;&amp;lt; get scriptable object())[1];

update_chart = Function( {a},
	eval(evalexpr(obj1 = db_1[1]&amp;lt;&amp;lt;xpath( "//TabPageBox[contains(text(),'Weight')]//FrameBox" );
	obj1 &amp;lt;&amp;lt; framesize( 300, 300 );));
);

filter_handler = local_filter &amp;lt;&amp;lt; Make Filter Change Handler( update_chart );&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Wed, 23 Apr 2025 12:19:34 GMT</pubDate>
      <guid>https://community.jmp.com/t5/Discussions/Make-Filter-Change-Handler-for-Dashboard/m-p/869697#M103252</guid>
      <dc:creator>Ben_BarrIngh</dc:creator>
      <dc:date>2025-04-23T12:19:34Z</dc:date>
    </item>
    <item>
      <title>Re: Make Filter Change Handler for Dashboard</title>
      <link>https://community.jmp.com/t5/Discussions/Make-Filter-Change-Handler-for-Dashboard/m-p/870042#M103309</link>
      <description>&lt;P&gt;Hi Ben,&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Thank you very much for your reply. The charts are now updating using "&lt;SPAN&gt;Eval(Eval Expr(....".&amp;nbsp;&lt;/SPAN&gt;&lt;/P&gt;
&lt;P&gt;&lt;SPAN&gt;However the function is being called whenever I move my cursor over a chart, not just changing the local data filter, which is crashing JMP when using my larger dataset. Is there any way to limit the function to being called only when the local data filter is changed?&lt;/SPAN&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;SPAN&gt;Thanks&lt;/SPAN&gt;&lt;/P&gt;</description>
      <pubDate>Thu, 24 Apr 2025 14:43:56 GMT</pubDate>
      <guid>https://community.jmp.com/t5/Discussions/Make-Filter-Change-Handler-for-Dashboard/m-p/870042#M103309</guid>
      <dc:creator>anna_717</dc:creator>
      <dc:date>2025-04-24T14:43:56Z</dc:date>
    </item>
    <item>
      <title>Re: Make Filter Change Handler for Dashboard</title>
      <link>https://community.jmp.com/t5/Discussions/Make-Filter-Change-Handler-for-Dashboard/m-p/870044#M103310</link>
      <description>&lt;P&gt;Hi&amp;nbsp;&lt;a href="https://community.jmp.com/t5/user/viewprofilepage/user-id/29012"&gt;@anna_717&lt;/a&gt;&amp;nbsp;,&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I believe this is due to the Filter Change Handler checking row states, so it is checking to see if the row is changed when you hover over a data point. I made an addition of write("Trigger") into the update_chart to see when it happened in the data set and it was when the mouse hovered over data points.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P data-unlink="true"&gt;This has been an issue &lt;A href="https://community.jmp.com/t5/JMP-Wish-List/Improve-JMP-s-state-handlers-hover-label-row-state-handler/idi-p/527992#U527992" target="_self"&gt;that has been Wishlisted&lt;/A&gt;&amp;nbsp;to see if it can be changed - please add a comment to this so development can see.&lt;/P&gt;
&lt;P data-unlink="true"&gt;&amp;nbsp;&lt;/P&gt;
&lt;P data-unlink="true"&gt;I'm going to tag the author&amp;nbsp;&lt;a href="https://community.jmp.com/t5/user/viewprofilepage/user-id/14366"&gt;@jthi&lt;/a&gt;&amp;nbsp;of the Wishlist item to see if he has some thoughts on some resolutions.&amp;nbsp;&lt;/P&gt;
&lt;P data-unlink="true"&gt;&amp;nbsp;&lt;/P&gt;
&lt;P data-unlink="true"&gt;Thanks,&lt;/P&gt;
&lt;P data-unlink="true"&gt;Ben&lt;/P&gt;</description>
      <pubDate>Thu, 24 Apr 2025 15:04:33 GMT</pubDate>
      <guid>https://community.jmp.com/t5/Discussions/Make-Filter-Change-Handler-for-Dashboard/m-p/870044#M103310</guid>
      <dc:creator>Ben_BarrIngh</dc:creator>
      <dc:date>2025-04-24T15:04:33Z</dc:date>
    </item>
    <item>
      <title>Re: Make Filter Change Handler for Dashboard</title>
      <link>https://community.jmp.com/t5/Discussions/Make-Filter-Change-Handler-for-Dashboard/m-p/870116#M103320</link>
      <description>&lt;P&gt;In this case it might be enough to check for -1 value of the a variable&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-jsl"&gt;update_chart = Function({a},
	If(a != -1,
		Eval(
			Eval Expr(
				obj1 = db_1[1] &amp;lt;&amp;lt; xpath("//TabPageBox[contains(text(),'Weight')]//FrameBox");
				obj1 &amp;lt;&amp;lt; framesize(300, 300);
			)
		);	
	);
);&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;If this won't work, you might need something more "smart" to check if it was local data filter or hover over which did trigger the filter change handler (like comparing filtered items or something similar).&lt;/P&gt;</description>
      <pubDate>Thu, 24 Apr 2025 18:04:33 GMT</pubDate>
      <guid>https://community.jmp.com/t5/Discussions/Make-Filter-Change-Handler-for-Dashboard/m-p/870116#M103320</guid>
      <dc:creator>jthi</dc:creator>
      <dc:date>2025-04-24T18:04:33Z</dc:date>
    </item>
    <item>
      <title>Re: Make Filter Change Handler for Dashboard</title>
      <link>https://community.jmp.com/t5/Discussions/Make-Filter-Change-Handler-for-Dashboard/m-p/870203#M103334</link>
      <description>&lt;P&gt;Hi&amp;nbsp;&lt;a href="https://community.jmp.com/t5/user/viewprofilepage/user-id/14366"&gt;@jthi&lt;/a&gt;&amp;nbsp;,&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;This is great, I'm just going to add context for your solution in case someone stumbles on to this page (and because I wanted to understand why it works).&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;When the mouse hovers over the data points on the graph, it will return '-1' as the value for [a] in the function of the Data Filter Change Handler, when you use the data filter, it will make the value of [a] the number of rows selected, so it will always be &amp;gt;0.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Great solution!&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Ben&lt;/P&gt;</description>
      <pubDate>Fri, 25 Apr 2025 07:22:46 GMT</pubDate>
      <guid>https://community.jmp.com/t5/Discussions/Make-Filter-Change-Handler-for-Dashboard/m-p/870203#M103334</guid>
      <dc:creator>Ben_BarrIngh</dc:creator>
      <dc:date>2025-04-25T07:22:46Z</dc:date>
    </item>
  </channel>
</rss>

