sugarcrm - 如何确保 Sugar 字段验证有足够的时间运行
问题描述
我正在尝试在 Opportunity 模块中创建一个字段验证,当用户尝试将提交阶段从“Upside”或“Commit”更改回“Funnel”时会引发错误。验证功能在record.js
用户尝试保存已编辑的机会时运行。它将选定的提交阶段与保存在数据库中的提交阶段进行比较。如果选定的提交阶段是“漏斗”并且保存的提交阶段是“上行”或“提交”,则会引发验证错误。抛出验证错误时,应突出显示提交阶段字段,并应显示带有错误消息的弹出窗口。
中的验证代码record.js
如下所示:
initialize: function (options) {
this._super('initialize', [options]);
app.error.errorName2Keys['check_commit_stages'] = 'ERROR_CHECK_COMMIT_STAGES';
this.model.addValidationTask('check_commit_stages', _.bind(this._doValidateCommitStages, this));
},
_doValidateCommitStages: function(fields, errors, callback) {
console.log('Validating commit stages in record.js');
let CommitStageSelected = this.model.get('commit_stage_c');
let OpportunityId = this.model.get('id');
let OpportunityBean = app.data.createBean('Opportunities');
OpportunityBean.set('id', OpportunityId);
let CommitStageSaved = '';
OpportunityBean.fetch({success: function(model, data){
CommitStageSaved = OpportunityBean.get('commit_stage_c');
console.log('selected commit stage: ' + CommitStageSelected);
console.log('saved commit stage: ' + CommitStageSaved);
let SavedStageUpsideOrCommit =
("Upside" == CommitStageSaved || "Commit" == CommitStageSaved);
if ("Funnel" == CommitStageSelected && SavedStageUpsideOrCommit) {
errors['commit_stage_c'] = errors['commit_stage_c'] || {};
errors['commit_stage_c'].check_commit_stages = true;
app.alert.show('message-id', {
level: 'error',
messages: 'Commit Stage cannot be changed from Upside or from Commit to Funnel',
autoClose: false
});
}
callback(null, fields, errors);
}});
},
问题是在机会已经保存后会引发验证错误。我收到一个“成功”弹出窗口说“已保存”,然后我收到一个带有验证错误消息的“错误”弹出窗口。提交阶段字段不会突出显示。
我猜测验证任务运行时间太长,可能是由于OpportunityBean.fetch
函数的原因,因此在验证任务有时间抛出错误之前保存了记录。有没有办法延迟保存或加快从 bean 获取数据的速度?或者,问题是否完全不同?
解决方案
我认为您也可以尝试这种方法来完成您要完成的任务
({
extendsFrom: 'OpportunitiesRecordView',
initialize: function (options) {
this._super('initialize', [options]);
app.error.errorName2Keys['check_commit_stages'] = 'ERROR_CHECK_COMMIT_STAGES';
this.model.addValidationTask('check_commit_stages', _.bind(this._doValidateCommitStages, this));
},
_doValidateCommitStages: function(fields, errors, callback) {
console.log('Validating commit stages in record.js');
let CommitStageSaved = this.model.getSynced('commit_stage_c');
let CommitStageSelected = this.model.get('commit_stage_c');
console.log('selected commit stage: ' + CommitStageSelected);
console.log('saved commit stage: ' + CommitStageSaved);
let SavedStageUpsideOrCommit =
("Upside" == CommitStageSaved || "Commit" == CommitStageSaved);
if ("Funnel" == CommitStageSelected && SavedStageUpsideOrCommit) {
errors['commit_stage_c'] = errors['commit_stage_c'] || {};
errors['commit_stage_c'].check_commit_stages = true;
app.alert.show('message-id', {
level: 'error',
messages: 'Commit Stage cannot be changed from Upside or from Commit to Funnel',
autoClose: false
});
}
callback(null, fields, errors);
}, })
使用这种方法,您甚至不必获取 Opportunities bean 即可从数据库中获取保存的数据。
推荐阅读
- python - Pexels API Python 请求
- javascript - JS:触摸事件每次成倍增加
- r - 如何在 geom_col() 中为重复的 x 轴值设置单独的列?
- flutter - 当状态随 Provider 发生变化时,使用 StatelessWidget 是否安全?
- r - 是否有R函数从汉字字符串中提取数量?
- reporting-services - Microsoft 动态媒体集数据类型和 SSRS
- discord.py - 如何使静音命令接受用户 ID 和提及
- python - 从 3d numpy 数组中删除 2d 切片
- validation - 当我在下拉列表谷歌表中选择 Desc 时,你能帮我吗?我希望该值成为唯一编号
- python - 安装 tensorflow 和 tensorflow_probability 时如何解决没有匹配的分布?