5

我有以下模型的管理生成器:

#schema.yml
Author:
  columns:
    name: { type: string(255), notnull: true }

Book:
  columns:
    authorId: { type: integer, notnull: true }
    title: { type: string(512), notnull: true }
    content: { type: string(512), notnull: true }
  relations:
    Author: { onDelete: CASCADE, local: authorId, foreign: id, foreignAlias: Books}

我已经生成了 2 页与每个表对应

php symfony doctrine:generate-admin backend Author
php symfony doctrine:generate-admin backend Book

现在我想在作者中查看他的书的链接。最好的方法是什么?我的尝试是预先选择过滤器的自定义链接,但我不知道该怎么做。

#generator.yml for Author
# ...
    config:
      actions: ~
      fields:
      list:
        display: [id, name, _booksLink]
      filter:  ~
      form:    ~
      edit:    ~
      new:     ~

<!-- modules/author/templates/_booksLink.php -->
<a href="<?= link_to('book?author_id='.$author->getId()) ?>"><!-- how to select filter? -->
  See <?= $author->getName() ?> books
</a>

谢谢

4

1 回答 1

5

本讲座回答您的问题(幻灯片 39 和 40): http ://www.slideshare.net/jcleveley/working-with-the-admin-generator

在你的actions.class php中添加:


class AuthorActions extends AutoAuthorActions
{
  public function executeViewBooks($request) { 
    $this->getUser()->setAttribute( 'book.filters',   
    array('authorId' => $request->getParameter('id')), 'admin_module' ); 
    $this->redirect($this->generateUrl('book')); 
  }
}

关于大小写的注意事项:字段名称与架构中定义的大小写匹配。例如:如果您在模式中有,则必须在上面的函数中authorId编写(第 5 行)。authorId如果你author_id在模式中有,你必须写author_id在函数中。此外,模块名称始终为小写并带有下划线(例如:)schema : MyBooks -> module name: my_books

在你的 generator.yml


list: 
  object_actions:
    _edit: ~
    _delete: ~
    viewPhones: { label: View books, action: viewBooks } 

于 2011-06-01T12:33:31.827 回答