Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Expand one empty collection item fields in the form without click on Add button #20

Open
igormisha opened this issue Feb 21, 2019 · 4 comments

Comments

@igormisha
Copy link

What is the way to make one group of fields for adding new collection item to show up without need to click on the Add button?

@jakub-zawislak
Copy link
Owner

jakub-zawislak commented Feb 23, 2019

Are you asking about a JS function, or the way to add item it in backend?

@igormisha
Copy link
Author

Making them on the backend would be better I think but ideally I'd like to have both options.

@jakub-zawislak
Copy link
Owner

Backend

You must add a new items to your struct with additional formex_id value. On the JS side I'm generating new values using UUID, but it can be also numbers "1", "2", .... or any other string.

If you are using Ecto, then you have to preload that association before adding new items.

Example with Ecto:

article = Repo.get!(Article, id)
|> Repo.preload(:comments)

article = Map.put(article, :comments, article.comments ++ [
  %App.Comment{
    content: "default content of a new comment", # optional
    formex_id: "1" # required. it may be any unique string
  },
  %App.Comment{
    content: "default content of yet another new comment",
    formex_id: "2"
  }
])

form = create_form(App.ArticleType, article)

JS

import { Collection } from 'formex'

Collection.addCollectionItemForm($('.formex-collection'))

Sorry for the jQuery dependency 😄

@igormisha
Copy link
Author

Thanks, I'll try it out...
As for the jQuery... well I used to love it long ago))

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants