自定义表达式函数

由于表达式内的函数在前后端都可能执行,所以同一个表达式需要前后端同时定义

后端表达式自定义

package pro.shushi.pamirs.demo.core.fun;

import org.apache.commons.lang3.StringUtils;
import org.joda.time.DateTime;
import pro.shushi.pamirs.meta.annotation.Fun;
import pro.shushi.pamirs.meta.annotation.Function;
import pro.shushi.pamirs.meta.common.constants.NamespaceConstants;

import java.util.Date;
import java.util.List;

import static pro.shushi.pamirs.meta.enmu.FunctionCategoryEnum.TEXT;
import static pro.shushi.pamirs.meta.enmu.FunctionCategoryEnum.TIME;
import static pro.shushi.pamirs.meta.enmu.FunctionLanguageEnum.JAVA;
import static pro.shushi.pamirs.meta.enmu.FunctionOpenEnum.LOCAL;
import static pro.shushi.pamirs.meta.enmu.FunctionSceneEnum.EXPRESSION;

/**
 * 自定义函数
 */
@Fun(NamespaceConstants.expression)
public class DemoCustomFunctions {

    @Function.Advanced(
            displayName = "逗号分隔字符串数组", language = JAVA,
            builtin = true, category = TEXT
    )
    @Function.fun("MY_COMMA")
    @Function(name = "MY_COMMA", scene = {EXPRESSION}, openLevel = LOCAL,
            summary = "函数示例: MY_COMMA(list)\n函数说明: 将字符串数组转为逗号分隔的字符串"
    )
    public String myComma(List<String> list) {
        return StringUtils.join(list, ",");
    }

    @Function.Advanced(
            displayName = "根据出生算年龄", language = JAVA,
            builtin = true, category = TIME
    )
    @Function.fun("CALC_AGE")
    @Function(name = "CALC_AGE", scene = {EXPRESSION}, openLevel = LOCAL,
            summary = "函数示例: CALC_AGE(birthDate)\n函数说明: 根据出生算年龄"
    )
    public Integer calcAge(Date birthDate) {
        if (birthDate == null) {
            return 0;
        }
        return new DateTime().getYear() - new DateTime(birthDate).getYear();
    }
}

前端表达式定义

定义后导入到main.ts里,导入@kunlun/dependencies的代码之后

import { Expression } from '@kunlun/dependencies';
import dayjs from 'dayjs';

Expression.getInstance().registerFunction('MY_COMMA', ['array'], (list: string[]) => {
  return (list || [])
    .map((value) => {
      return `'${value}'`;
    })
    .join(',');
});

Expression.getInstance().registerFunction('CALC_AGE', ['string'], (birthDate: string) => {
  if (birthDate == null) {
    return 0;
  }
  return Math.ceil(dayjs().year() - dayjs(birthDate, 'YYYY-MM-DD HH:mm:ss').year());
});
界面设计器拖入年龄的非存储字段,属性面板的计算公式的函数中选择自定义的函数

注意:不能在时间类型字段的计算公式使用该函数,因为计算后的结果为数字类型,与原字段不一致

自定义表达式函数

表格页可以看到根据发布时间计算的年龄,与预期一致

自定义表达式函数

Oinone社区 作者:nation原创文章,如若转载,请注明出处:https://doc.oinone.top/install/frontendinstall/14564.html

访问Oinone官网:https://www.oinone.top获取数式Oinone低代码应用平台体验

(0)
nation的头像nation数式员工
上一篇 2024年7月10日 上午11:00
下一篇 2024年7月11日 下午4:29

相关推荐

  • nginx如何配置后端服务的负载均衡

    要在Nginx中实现对同一套服务部署两遍并且按比例分配请求,你可以利用Nginx的负载均衡功能。具体做法如下: 步骤 1: 配置 upstream 首先,在Nginx的配置文件(通常是/etc/nginx/nginx.conf或/etc/nginx/sites-available/default,具体路径可能因系统而异)中定义一个upstream块,列出你的…

    2024年6月5日
    63800
  • 后端初始化工程启动

    在拿到Oinone初始化的后端工程体验时,配置修改点

    2023年11月3日
    82400
  • Oinone设计器部署参数说明

    概述 Oinone提供两种设计器部署方式,合作伙伴可以自行选择适合自己的部署方式。 Docker配置参数 环境变量 ARG_ENV:指定spring.profiles.active(默认:dev) ARG_LIFECYCLE:指定-Plifecycle(默认:INSTALL) JVM_OPTIONS:jvm参数 PROGRAM_ARGS:程序参数 JVM_O…

    2024年11月4日
    43100
  • 【MSSQL】后端部署使用MSSQL数据库(SQLServer)

    MSSQL数据库配置 驱动配置 Maven配置(2017版本可用) <mssql.version>9.4.0.jre8</mssql.version> <dependency> <groupId>com.microsoft.sqlserver</groupId> <artifactId>…

    2024年10月18日
    37400
  • 如何排查启动依赖错误的问题

    场景 启动的时候可能会出现以下错误提示 启动模块中包含jar包或者数据库中不存在的模块 启动模块中包含不存在的模块 启动模块互斥模块中包含已安装模块 排查项 确保启动工程的application.yml中的启动模块pamirs.boot.modules配置项内的模块在pom.xml内依赖了对应模块的jar包 确保出问题的模块的定义文件内的包扫描前缀packa…

    2024年7月18日
    71400

发表回复

登录后才能评论