Class: React::JSX::JSXTransformer
- Inherits:
-
Object
- Object
- React::JSX::JSXTransformer
- Defined in:
- lib/react/jsx/jsx_transformer.rb
Overview
A React::JSX-compliant transformer which uses the deprecated ‘JSXTransformer.js` to transform JSX.
Constant Summary collapse
- DEFAULT_ASSET_PATH =
'JSXTransformer.js'
Instance Method Summary collapse
-
#initialize(options) ⇒ JSXTransformer
constructor
A new instance of JSXTransformer.
-
#jsx_transform_code ⇒ Object
search for transformer file using sprockets - allows user to override this file in his own application.
- #transform(code) ⇒ Object
Constructor Details
#initialize(options) ⇒ JSXTransformer
Returns a new instance of JSXTransformer.
7 8 9 10 11 12 13 14 15 16 17 18 19 |
# File 'lib/react/jsx/jsx_transformer.rb', line 7 def initialize() @transform_options = { stripTypes: .fetch(:strip_types, false), harmony: .fetch(:harmony, false) } @asset_path = .fetch(:asset_path, DEFAULT_ASSET_PATH) # If execjs uses therubyracer, there is no 'global'. Make sure # we have it so JSX script can work properly. js_code = 'var global = global || this;' + jsx_transform_code @context = ExecJS.compile(js_code) end |
Instance Method Details
#jsx_transform_code ⇒ Object
search for transformer file using sprockets - allows user to override this file in his own application
28 29 30 |
# File 'lib/react/jsx/jsx_transformer.rb', line 28 def jsx_transform_code ::Rails.application.assets[@asset_path].to_s end |
#transform(code) ⇒ Object
21 22 23 24 |
# File 'lib/react/jsx/jsx_transformer.rb', line 21 def transform(code) result = @context.call('JSXTransformer.transform', code, @transform_options) result['code'] end |