若回答对您有帮助,记得点下赞同哦~
2024年05月
2024年04月
2024年03月
2024年02月
2023年12月
2023年11月
您好参考一下下列配置:
如果没有从子表单获取参考:
您好,可以通过给自定义组件添加一个 function 类型的属性,即事件回调。 在页面中可以通过这个事件回调和页面其他组件做联动。 在组件中可以通过 this.props.xxx() 在合适的时机,比如组件的某个事件或组件的 DidMount 来执行这个回调。 小提示: function 类型的属性可以添加默认值并且可以设置隐藏。
可以参考一下这个实例:
点击按钮拿到表格中的内容传递给普通表单的多行文本
您好在可以通过公式获取当前登陆人的一些信息然后通过连接器传递给第三方应用。公式文档 :https://docs.aliwork.com/docs/yida_support/cnzrgo/gvtpe4/namr73vcz90gduud/oyuexdmpaxiys2tm。
如果自带的登陆者信息不满足的话可以调用查询用户详情openApi获取用户信息,文档地址:https://open.dingtalk.com/document/orgapp/query-user-details
类似案例 :https://docs.aliwork.com/docs/yida_subject/_2/yp2zw44ikdgdcmlz
您好可以参考一下 https://docs.aliwork.com/docs/yida_subject/xnc05ivrxsq23833 这个案例,提交时触发校验,编辑时不触发。
您好可以通过css样式实现,可以参考文档
https://docs.aliwork.com/docs/yida_subject/_6/lp2x5tkw3624d1p8
1.通过审查元素找到分组头部的class类名
2.在分组组件的样式-源码编辑中给对应的class加上css样式
3.实现效果
您好可以通过链接拼接的方式实现:
1.找到对应表单的一条实例信息点击查看详情
2.从实例链接上=往前截取对应的链接信息
3.粘贴到对应的链接器参数或者消息通知链接跳转中拼接实例id字段
您好可以参考一下下方配置信息:
实现效果:
您好,可以在表单设置一个多行文本为备注内容,在打印模版中设置打印该备注字段。如果有备注信息填写在多行文本中即可。
您好可以参考一下 https://docs.aliwork.com/docs/yida_subject/_6/_3/kafz1azdym749wug 这个文档,通过数据联动结合成员组件实现。
您好可以使用地址组件的快速定位功能,效果如下。
可以通过开放平台openAPI接口获取宜搭表单数据和新增宜搭表单数据。接口文档地址:https://open.dingtalk.com/document/orgapp/overview-yida
可以通过js实现,参考下图。
1.选择需要关联的表单,显示设置-主要信息选择流水号
2.给关联表单组件绑定onChange事件,通过js遍历拼接对应的流水号
/**
* AssociationFormField onChange
* @param value 当前值
*/
export function onChange({ value }) {
// 使用 map 遍历数组并获取 title,使用 join 拼接为一个字符串
const titles = value.map(item => item.title).join(',');
// textField_lvyvjzv1 为需要拼接赋值单行文本组件唯一标识
this.$('textField_lvyvjzv1').setValue(titles);
}
实现效果:
可以用单行文本组件替代一下,通过UUID生成唯一编码,文档地址 :https://docs.aliwork.com/docs/yida_support/cnzrgo/gvtpe4/wcguece1v2ok8b00/xb7gg8vrhik5yg5s
1.可以使用指标卡展示求和字段 :https://docs.aliwork.com/docs/yida_support/tsmk65/aii2tp/wq6oap/mtmqkn/vn761o
2.可以通过交叉透视表展示求和字段 :https://docs.aliwork.com/docs/yida_support/tsmk65/aii2tp/wq6oap/rci3kg/osbbht
您好可以尝试返回布尔值true和false。返回true为阻断,返回false则不阻断。类似公式配置
参考一下:
用/v1.0/yida/forms/instances 更新数据接口更新两次就可以了useLatestVersion 参数传递true,第一次更新值,第二次更新更新组件状态。
您好您是需要主表字段和历史提交的数据做匹配还是子表单里面的某一行和历史子表单里面填写的信息做匹配呀?如果是主表的话可以参考一下这个案例:https://docs.aliwork.com/docs/yida_subject/xnc05ivrxsq23833
如果是子表单参考一下下列方式:
接口地址:
`/${window.pageConfig.appType || window.g_config.appKey}/query/formProcInstData/getInstanceDatasLight.json`
export function didMount() {
this.setState({
options: {
formUuid: 'formUuid', // 需要参与校验的表 formUuid
checkedTable: '组件唯一标识', // 需要参与校验的子表单组件唯一标识
checkedField: '组件id' // 需要参与校验的子表单内组件唯一标识
}
});
if (!this.utils.isSubmissionPage()) {
// 获取未修改前的被校验子表单数据
const { options } = this.state;
const oldData = this.$(options.checkedTable).getValue();
this.setState({
oldData,
});
};
}
async function validateRule(value) {
if (!value) { return true };
const { options, oldData } = this.state;
if (!this.utils.isSubmissionPage() && oldData.length && oldData[this.index] && (value == oldData[this.index][options.checkedField])) {
return true;
} else {
return await this.dataSourceMap.checkOnly.load({
formUuid: options.formUuid,
searchField: JSON.stringify([{ "key": options.checkedField, "value": value, "type": "TEXT", "operator": "eq", "componentName": "TextField", "parentId": options.checkedTable }]),
pageSize: 10,
currentPage: 1,
page: 1,
limit: 10
}).then(res => {
if (!res.totalCount) { return true };
return false;
}).catch(error => {
this.utils.toast({
title: error.message,
type: 'error',
});
return true;
});
}
}
你好可以参考一下下列文档通过js校验 :https://www.yuque.com/xinjing-cxw9l/yida_demo/vby24n#QwPMv
// 子组件 onChange 中
// 单行文本组件是否必填组件 onChange
export function onChange2({ value }) {
const validation = value === '是' ? [{ type: 'required' }] : [];
this.$('textField_limgqi76').setValidation(validation);
}
目前精品应用暂不支持删除。你可通过精品应用里面的相关链接和二维码进入宜搭精品应用官方交流群,便于了解最新消息。