在我的应用中,有模板和文档。我希望能够从模板创建文档,即用户可以转到模板显示页面,单击按钮,然后重定向到新文档页面,文档文本预先填充模板(我只需要预先填写文本,我不关心文档是否知道它的模板。
但是如何将文本传递到新的文档页面?
答案 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"});
}
});