将预设传递到创建控制器

时间:2013-07-05 21:08:33

标签: ember.js

在我的应用中,有模板和文档。我希望能够从模板创建文档,即用户可以转到模板显示页面,单击按钮,然后重定向到新文档页面,文档文本预先填充模板(我只需要预先填写文本,我不关心文档是否知道它的模板。

但是如何将文本传递到新的文档页面?

2 个答案:

答案 0 :(得分:0)

我最终做了以下事情:

App.Router.map ->
  @resource 'documents', ->
    @route 'new'
    @route 'new_from_template', path: '/new/:template_id'

App.DocumentsNewFromTemplateRoute = Ember.Route.extend
  model: (params) ->
    model = App.Document.createRecord()

    if params.template_id
      App.Template.find(params.template_id).then (template) ->
        model.set 'text', template.get('text')

    model

  setupController: (controller, model) ->
    if model._reference.type == App.Template
      model = @model(template_id: model.id)

    @currentModel = model
    @controllerFor('documentsNew').set 'model', model

  renderTemplate: ->
    @render 'documents/new'

要链接到模板的新文档表单,我只需

{{#linkTo 'documents.new_from_template' template}}Create a document{{/linkTo}}

答案 1 :(得分:0)

您可以在控制器中定义操作:

App.TemplateRoute = Em.Route.extend({
  model: function() {
    return Em.Object.create({
      name: "A Template",
      values: {title: "Templated Title"}
    });
  }
});

App.TemplateController = Em.ObjectController.extend({
  goToNewDocument: function() {
    var o = Em.Object.create(this.get('values'));
    o.set('source', 'Template');
    App.Router.router.transitionTo('newdoc', o);
  }
});

App.NewdocRoute = Em.Route.extend({
  model: function() {
    return Em.Object.create({title: "Default Title", source: "Model hook"});
  }
});

jsbin demo