Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/a2lix/symfony-collection
Manage your Symfony collection simply with vanilla JS
https://github.com/a2lix/symfony-collection
collection javascript symfony symfony-collection symfony-form typescript
Last synced: 2 months ago
JSON representation
Manage your Symfony collection simply with vanilla JS
- Host: GitHub
- URL: https://github.com/a2lix/symfony-collection
- Owner: a2lix
- Created: 2018-04-08T16:56:07.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2023-08-07T09:44:02.000Z (over 1 year ago)
- Last Synced: 2024-11-01T21:47:02.792Z (3 months ago)
- Topics: collection, javascript, symfony, symfony-collection, symfony-form, typescript
- Language: TypeScript
- Homepage: https://a2lix.fr
- Size: 33.2 KB
- Stars: 43
- Watchers: 4
- Forks: 16
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# A2LiX JS - symfony-collection
Manage your Symfony Form collection simply with vanilla JS
[![npm version](https://badge.fury.io/js/%40a2lix%2Fsymfony-collection.svg)](https://badge.fury.io/js/%40a2lix%2Fsymfony-collection)
![image](https://user-images.githubusercontent.com/517753/210223130-e5af99fe-204e-4bd3-8b76-ba3ac4946fff.png)
## Install
```cmd
npm install @a2lix/symfony-collection
```## Basic use
See Symfony Encore example (https://github.com/a2lix/Demo/blob/master/assets/app.js)
```js
import a2lix_lib from '@a2lix/symfony-collection/dist/a2lix_sf_collection.min'a2lix_lib.sfCollection.init()
```## Advanced use
Default configuration https://github.com/a2lix/symfony-collection/blob/master/src/a2lix_sf_collection.ts#L3-L45
can be customized globally in javascript during init```js
a2lix_lib.sfCollection.init({
entry: {
add: {
label: 'Add entry'
},
}}
```Or/And more precisely on each collection by using DOM attributes:
```php
...
->add('categories', CollectionType::class, [
...
'attr' => [
'data-entry-add-label' => 'Add Category',
],
])
```### Nested collection(s)
As advised by SF in this case, you must override the default 'prototype_name' option (https://symfony.com/doc/current/reference/forms/types/collection.html#prototype-name) of the nested collection with a custom name. Then, set this same custom name in a 'data-prototype-name' DOM attribute.
Example of a 'tags' collection nested in a 'categories' collection:
```php
...
->add('tags', CollectionType::class, [
'entry_type' => TextType::class,
'allow_add' => true,
'allow_delete' => true,
'delete_empty' => true,
'by_reference' => false,
'prototype_name' => '__name2__', // Advised by Symfony
'attr' => [
'data-prototype-name' => '__name2__' // Required by a2lix_sf_collection
],
'entry_options' => [
'label' => false,
],
```## Contribute help
```cmd
docker run -it --rm --user $(id -u):$(id -g) --name a2lix_nodejs -v "$PWD":/usr/src/app -w /usr/src/app node:alpine npm install
docker run -it --rm --user $(id -u):$(id -g) --name a2lix_nodejs -v "$PWD":/usr/src/app -w /usr/src/app node:alpine npm run build```
# Demo
See [Demo project](https://github.com/a2lix/Demo).