Skip to content

Latest commit

 

History

History
311 lines (228 loc) · 6.38 KB

README.md

File metadata and controls

311 lines (228 loc) · 6.38 KB

Opal::Connect

This gem connect opal with custom plugins allows to use a set of predefined plugins as:

  • abilities
  • current_user
  • dom
  • events
  • form
  • html
  • modal
  • pjax
  • rspec
  • scope
  • server
  • store

The goal of this gem is collected implementations of common functionalities using opal builder to parse Ruby code into Javascript.

It also exposes opal methods to set dom, set elements values (depends of opal-jquery).

You can also create your own plugins and make them available only for your app. This helps you to keep your app DRY and share common elements, functions between ruby classes.

Installation

Add this line to your application's Gemfile:

  gem 'opal-connect'

And then execute:

$ bundle

Or install it yourself as:

$ gem install opal-connect

Usage

Initialize

You should add to your boot process a file to setup the opal connect. This allows you to define what default plugins opal-connect should load and set a path for your local plugins.

How to load plugins

Select the default plugin to load and load your custom plugins here. The plugin name is the registered name of plugin module name. Normally and following conventions should be same name of module in downcase and underscore.

 # in your initializer file
 # rails
 # config/initializers/opal-connect

 Opal::Connect.setup do
   options[:plugins] do
     server,
     html,
     dom
   end
  end
Plugins path.

How to set the plugins path?

Add the current directory. Then open the setup block and set the plugins_path to your plugins directory.

 Opal.append_path = Dir.pwd
 Opal::Connect.setup do
   options['plugins_path'] = 'app/plugins'
 end
Livereload

Set the live reload for development scenarios?

This option tells the opal connect to reload files everytime the directories are reload.

 ...
 Opal::Connect.setup do
   options[:livereload] = # true or false
 end
Scope

The scope option sets the current scope of your application. Normally you should pass your application class scope.

 ...
 Opal::Connect.setup do
   options[:scope] = App.new
 end

How to create a plugin?

It is possible to add custom plugins. You have to create a module and added to the Opal::Connect::ConnectPlugins.

  1. First create a module
module Opal::Connect
  module ConnectPlugins
    module CustomPlugin
    end
  end
end
  1. Validate if the ruby engine is opal and there add the code that is going to use opal
module Opal::Connect
  module ConnectPlugins
    module CustomPlugin
      if RUBY_ENGINE == 'opal'
        # code
      end
    end
  end
end
  1. Add your opal methods and logic to the module InstanceMethods
module Opal::Connect
  module ConnectPlugins
    module CustomPlugin
      if RUBY_ENGINE == 'opal'
        module InstanceMethods
          # code
        end
      end
    end
  end
end
  1. Register your plugin
module Opal::Connect
  module ConnectPlugins
    module CustomPlugin
      if RUBY_ENGINE == 'opal'
        module InstanceMethods
          # code
        end
      end
     end
    register_plugin :custom_plugin, CustomPlugin
  end
end

Existing plugins

  • abilities
  • current_user
  • dom
  • events
  • form
  • html
  • modal
  • pjax
  • rspec
  • scope
  • server
  • store

HTML Plugin

This plugin is responsible to parse html tags to strings and build the DOM using opal builder method.

How to build tags

  1. Load the plugin
  require 'opal/connect/plugins/html'
  1. Instance DSL class passing the desire html tag
  Opal::Connect::ConnectPlugins::HTML::DSL.new('p')
  1. Call to_html to get the html string
  "<p></p>"

How to build tags with attributes as class or id

  1. Pass the args to DSL.new method
  Opal::Connect::ConnectPlugins::HTML::DSL.new('p', class:'red')
  • returns DSL instance
  1. to_html method generates

Opal::Connect::ConnectPlugins::HTML::DSL.new('p', class:'red').to_html

  • returns "<p class=\"red\"></p>"
Passing attributes.
  Opal::Connect::ConnectPlugins::HTML::DSL.new('p', class:'red', id:'main').to_html

How to build data tags

  1. Create string symbols in ruby and pass as argument to DSL
  Opal::Connect::ConnectPlugins::HTML::DSL.new('p', class:'red', id: 'main', 'data-value': 'testing')
  • returns a DSL instance
  1. to_html method generates
  "<p class=\"red\" id=\"main\" data-value=\"testing\"></p>"

How to build custom tags as XML tags

  • HTML plugin allows you to create custom tags because it catches all missing methods and create a DSL child with the given tag.

You can pass tags for instance:

  # tag_name  {value}
  test 'value'
  test url: 'value' { text 'value' }

The tag name is consider for ruby interpreter as undefined method DSL class implements method_missing and create an instance of given name converting to string to_s and passing the arguments as atrributes and the block inside to wrap your block data.

  • example:
  xml! do
    xml url: 'testing-custom-tags' do
      body id 'body' do
        tester do
          text 'value'
        end
      end
    end
  end
  • returns
  #<#<Class:0x007ff9b6169a10>:0x007ff9b6169998 @tag=nil, @content=nil, @attributes=nil, @attr_string=[], @children=[#<#<Class:0x007ff9b6169600>:0x007ff9b6169560 @tag="xml", @content=nil, @attributes={:url=>"testing-custom-tags"}, @attr_string=[], @children=[#<#<Class:0x007ff9b6169308>:0x007ff9b6169290 @tag="id", @content="body", @attributes=nil, @attr_string=[]>, #<#<Class:0x007ff9b6169010>:0x007ff9b6168f98 @tag="body", @content=nil, @attributes=nil, @attr_string=[], @children=[#<#<Class:0x007ff9b6168d40>:0x007ff9b6168cc8 @tag="tester", @content=nil, @attributes=nil, @attr_string=[], @children=[#<#<Class:0x007ff9b6168ac0>:0x007ff9b6168a48 @tag="text", @content="value", @attributes=nil, @attr_string=[]>]>]>]>]>
  • to_html produces
  "<xml url=\"testing-custom-tags\"><id>body</id><body><tester><text>value</text></tester></body></xml>"

Contributing

  1. Fork it ( https://github.com/[my-github-username]/opal-connect/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request