我想为创建表单构建预览页面。我在previewAction
时将记录的“已删除”属性设置为“1”,因为在BE中列表模块用于批准插入的记录 - 所以如果记录从未最终保存,则无论如何都要删除。
问题:我可以创建记录(deleted=1
) - 我可以跳回到表单(没有历史记录,因为我必须保留创建的对象)。但如果我再次提交属性映射告诉我
未找到标识“3”的MyModel类型的对象。
当然那是因为它被删除了。存储库中忽略已删除的设置未在此处执行操作。
是的,我可以通过手动填写所有内容来绕过Extbase魔法,但这不是我想要的。
以下是了解我正在尝试的行动
/**
* action preview
*
* @param MyModel
* @return void
*/
public function previewAction(MyModel $newModel)
{
//check if model was already saved
$uid = $this->request->hasArgument('uid') ? this->request->getArgument('uid') : 0;
if($uid){
$newModel = $this->myRepository->findDeletedByUid($uid);
$this->myRepository->update($newModel);
}
else{
$newModel->setDeleted(true);
$this->myRepository->add($newModel);
}
$this->view->assign('ad', $newModel);
$this->persistenceManager->persistAll();
$uid = $this->persistenceManager->getIdentifierByObject($newModel);
$this->view->assign('uid', $uid);
}
有什么想法吗?
答案 0 :(得分:4)
Extbase默认查询设置会禁止删除的对象。
由于您已在存储库中声明了自定义查询findDeletedByUid(),因此您只需将其设置为包含已删除的记录。但是,重要的是,如果要使用对象调用控制器操作,则必须在调用操作之前检索它。使用初始化操作。初始化将在动作之前自动调用。
如果要设置删除对象,您还需要在域模型中定义属性,getter和setter以及在tca中定义一个正确的定义,以使数据映射器能够访问列。
在存储库中:
public function findDeletedByUid($uid) {
$query = $this->createQuery();
$query->getQuerySettings()->setIncludeDeleted(true);
$query->matching(
$query->equals('uid',$uid)
);
return $query->execute();
}
在您的Controller类中:
/**
* initialize action previewAction
* Overrides the default initializeAction with one that can retrieve deleted objects
*/
public function initializePreviewAction(){
if( $this->request->hasArgument('mymodel') ){
$uid = $this->request->getArgument('mymodel');
if( $mymodel = $this->mymodelRepository->findDeletedByUid($uid) ){
$this->request->setArgument($mymodel);
} else {
// handle non retrievable object here
}
} else {
// handle missing argument here
}
}
在您的域模型中:
...
/**
* @var bool
*/
protected $deleted;
/**
* @return bool
*/
public function getDeleted() {
return $this->deleted;
}
/**
* @param bool $deleted
*/
public function setDeleted($deleted) {
$this->deleted = $deleted;
}
在你的tca.php中
...
'deleted' => array(
'exclude' => 1,
'label' => 'LLL:EXT:lang/locallang_general.xlf:LGL.deleted',
'config' => array(
'type' => 'check',
),
),
答案 1 :(得分:0)
您应该使用隐藏字段来允许编辑者预览文档,而不是删除任何魔法。 您可以告诉您的查询在存储库中包含隐藏的记录。
答案 2 :(得分:0)
你的findDeletedByUid($uid)
功能引起了我的注意。如果它不是自定义函数,是应该将findByDeleted(TRUE)
或findByDeleted(1)
与->getFirst()
或->findByUid()
结合使用?您可以在Extbase manual reference和Repository __call() function API部分找到讨论。
答案 3 :(得分:0)
感谢所有提示。
我认为根据答案,如果没有绕过extbase属性映射魔法,它是不可能的。所以我认为一般来说这样做并不是一个好主意。
所以我现在把我自己的旗帜"存储"到模型。
在BE列表模块中,不存储"存储"对象仍然可见,但使用自己的BE模块或删除not"存储" cron-job的对象应该可以胜任。
如果有人有床位想法,请随时分享: - )