Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/code-with-rails/filepond-rails
An integration library for FilePond and Ruby on Rails
https://github.com/code-with-rails/filepond-rails
javascript javascript-library ruby-gem ruby-on-rails rubygem rubygems-plugin
Last synced: 14 days ago
JSON representation
An integration library for FilePond and Ruby on Rails
- Host: GitHub
- URL: https://github.com/code-with-rails/filepond-rails
- Owner: Code-With-Rails
- License: mit
- Created: 2022-12-24T13:18:24.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2023-10-11T11:35:29.000Z (about 1 year ago)
- Last Synced: 2024-12-20T00:33:43.504Z (16 days ago)
- Topics: javascript, javascript-library, ruby-gem, ruby-on-rails, rubygem, rubygems-plugin
- Language: Ruby
- Homepage: https://codewithrails.com/filepond-rails
- Size: 1.71 MB
- Stars: 16
- Watchers: 1
- Forks: 4
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: MIT-LICENSE
Awesome Lists containing this project
README
# filepond-rails
[![Gem Version](https://badge.fury.io/rb/filepond-rails.svg)](https://badge.fury.io/rb/filepond-rails)
![Build Status](https://github.com/Code-With-Rails/filepond-rails/actions/workflows/ci.yml/badge.svg)This gem allows you to quickly integrate [FilePond](https://github.com/pqina/filepond) with your Ruby on Rails app.
## Requirements
* Rails 7.0.x and above
* Use of [importmap-rails](https://github.com/rails/importmap-rails)## Installation
Add this line to your application's Gemfile:```ruby
gem 'filepond-rails'
```And then run:
```bash
$ bundle
```Add the following to your `application.css`:
```css
*= require 'filepond'
```Add `javascript_importmap_tags` in the `head` section of your layout:
```erb
<%= javascript_importmap_tags %>
```Mount `filepond-rails` routes:
```ruby
Rails.application.routes.draw do
mount Filepond::Rails::Engine, at: '/filepond'
end
```Note: You must mount the routes at `/filepond`.
## Usage
This gem compromises of two parts:
1. An ingress controller for the FilePond `fetch` and `remove` server calls. The JavaScript code leverages Active Storage's existing direct upload endpoint.
2. JavaScript ESM module to automatically connect configured elements with the above endpoints.At the present moment, the above parts are designed (and assumed) to work together.
The gem assumes that you set up your models and Active Storage configuration in a standard Rails way. Assuming you have a form that looks like this:
```erb
<%= form_with model: @user, url: update_avatar_path, method: :post do |f| %>
<%= f.label :avatar, 'Update your avatar' %>
<%= f.file_field :avatar, class: 'filepond', direct_upload: true %>
<%= f.button 'Update' %>
<% end %>
```You can instantiate the `file_field` component like so:
```js
// app/javascript/application.js
import { FilePondRails, FilePond } from 'filepond-rails'window.FilePond = FilePond
window.FilePondRails = FilePondRailsconst input = document.querySelector('.filepond')
FilePondRails.create(input)
```The gem's JavaScript provide two available exports:
1. `FilePond` (which corresponds to the original FilePond library)
2. `FilePondRails` (which is a convenience helper that integrates and sets up FilePond to work with our `FilePond::Rails::IngressController`## Development
filepond-rails is configured with Docker to help developer-contributors be able to easily work on this gem locally.
To get started:
1. Fork this repository
2. git clone it to your local machine and cd into it
3. Run `docker compose build`To run the gem through the "dummy" app, run:
```bash
docker compose up
```To enter the development environment where you can run `bin/rails g controller` and other commands:
```bash
docker compose run app bash
```You should now be able to run tests locally within this bash container:
```bash
bin/rails test && bin/rails app:test:system
```## Reference
* Read [How to create a Ruby on Rails gem from your existing code](https://codewithrails.com/create-rails-gem) for a background on this gem## License
The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).