This example illustrates how to add a custom function to the designer and use it in the dashboard template.

First, you need to add the StiNetCoreDesigner component to the view page. Also you need to pass the StiNetCoreDesignerOptions object to the constructor and set the all required actions:
@using Stimulsoft.Report.Mvc;

...

@Html.StiNetCoreDesigner(new StiNetCoreDesignerOptions()
{
	Actions =
	{
		GetReport = "GetReport",
		DesignerEvent = "DesignerEvent"
	}
})

Now you need to open the DesignerController code and add the resulting methods for the specified actions:
public IActionResult GetReport()
{
	// Create the dashboard object
	var report = StiReport.CreateNewDashboard();
	
	// Load dashboard template
	report.Load(StiNetCoreHelper.MapPath(this, "Dashboards/DashboardChristmas.mrt"));
	
	// Return template to the Designer
	return StiNetCoreDesigner.GetReportResult(this, report);
}

public IActionResult DesignerEvent()
{
	return StiNetCoreDesigner.DesignerEventResult(this);
}

Add a custom function in the controller, it must be static. For example, this would be a function MySum() that sums all the values in the list:
public static decimal MySum(object value)
{
	if (!ListExt.IsList(value))
		return Stimulsoft.Base.Helpers.StiValueHelper.TryToDecimal(value);

	return Stimulsoft.Data.Functions.Funcs.SkipNulls(ListExt.ToList(value))
		.TryCastToDecimal()
		.Sum();
}
To add a function to the designer's dictionary, it is enough to call the special StiFunctions.AddFunction() method, this can be done in the static constructor of the controller. In the arguments of this method you should specify all the required parameters - category, function name, description, types of input and return parameters:
static DesignerController()
{
	// How to add my function
	StiFunctions.AddFunction("MyCategory", "MySum",
		"description", typeof(DesignerController),
		typeof(decimal), "Calculates a sum of the specified set of values.",
		new[] { typeof(object) },
		new[] { "values" },
		new[] { "A set of values" }).UseFullPath = false;
}

На скриншоте ниже Вы можете увидеть результат выполнения данного кода:

Adding a Custom Function to the Designer

Используя этот сайт, вы соглашаетесь на использование файлов Cookie для аналитики и персонализированного контента. Файлы Cookie хранят полезную информацию на вашем компьютере, чтобы помочь нам повысить эффективность и удобство использования. Для получения дополнительной информации, пожалуйста, прочтите Конфиденциальность и Использование Cookie.