Class: DcCommonRenderer
- Inherits:
-
DcRenderer
- Object
- DcRenderer
- DcCommonRenderer
- Includes:
- DcApplicationHelper
- Defined in:
- app/renderers/dc_common_renderer.rb
Overview
Renderer methods which may be useful on any site.
Instance Attribute Summary
Attributes included from DcApplicationHelper
#design, #form, #ids, #json_ld, #menu, #menu_item, #options, #page, #page_title, #part, #parts, #record, #record_footer, #site, #tables
Instance Method Summary collapse
-
#_remove_iframe_edit ⇒ Object
Will return html code required for open edit form in iframe.
-
#google_analytics ⇒ Object
Renderer for Google analytics code.
-
#layout_4print ⇒ Object
Renderer for printer friendly layout.
-
#render_html ⇒ Object
Return HTML part of code.
Methods included from DcApplicationHelper
#_origin, #dc_add2_record_cookie, #dc_add_json_ld, #dc_add_meta_tag, #dc_big_table, #dc_choices4, #dc_choices4_all_collections, #dc_choices4_cmsmenu, #dc_choices4_folders_list, #dc_choices4_menu, #dc_choices4_site_policies, #dc_deprecate, #dc_document_path, #dc_dont?, #dc_edit_mode?, #dc_edit_title, #dc_error_messages_for, #dc_flash_messages, #dc_get_json_ld, #dc_get_seo_meta_tags, #dc_get_site, #dc_icon_for_link, #dc_iframe_edit, #dc_img_alt, #dc_img_alt_tag, #dc_internal_var, #dc_label_for, #dc_limit_string, #dc_link_for_create, #dc_link_for_edit, #dc_link_for_edit1, #dc_link_menu_tag, #dc_link_to, #dc_menu_class, #dc_new_title, #dc_page_bottom, #dc_page_class, #dc_page_edit_menu, #dc_page_top, #dc_render, #dc_render_design, #dc_render_design_part, #dc_render_from_site, #dc_render_partial, #dc_replace_in_design, #dc_submit_tag, #dc_table_title, #dc_user_can_view, #dc_user_has_role, #dc_warning_messages_for, #decamelize_type, #forms_merge
Methods inherited from DcRenderer
Constructor Details
This class inherits a constructor from DcRenderer
Instance Method Details
#_remove_iframe_edit ⇒ Object
Will return html code required for open edit form in iframe. If parameters are found in url iframe will be initial loaded with url parameters thus enabling forms load on page display.
98 99 100 |
# File 'app/renderers/dc_common_renderer.rb', line 98 def _remove_iframe_edit() @parent.render(partial: 'dc_common/iframe_edit', formats: [:html]) end |
#google_analytics ⇒ Object
Renderer for Google analytics code.
Parameters: Are passed through @opts hash and can therefore be set on site
or page document parameters field as ga_acc key. You may also disable sending
If eu_cookies_allowed function is defined in javascript libraries it will be called and if false is returned GA code will not be executed. This is in order with European cookie law.
Example:
dc_render(:dc_common_renderer, method: 'google_analytics', code: 'UA-12345678-9')
70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 |
# File 'app/renderers/dc_common_renderer.rb', line 70 def google_analytics ga_acc = @opts[:code] || @opts[:ga_acc] return '' if ga_acc.nil? or ga_acc == '/' html =<<EOT <!-- Google analytics. --> <script type="text/javascript"> (function(i,s,o,g,r,a,m){ if (typeof(eu_cookies_allowed) === "function" && !eu_cookies_allowed() ) return; i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o), m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m) })(window,document,'script','//www.google-analytics.com/analytics.js','ga'); if (typeof(ga) === "function") { ga('create', '#{ga_acc}', 'auto'); ga('send', 'pageview') } </script> EOT html.html_safe end |
#layout_4print ⇒ Object
Renderer for printer friendly layout. Will call another renderer which should provide html code for printer friendly output.
Parameters are passed through link. There are currently two parameters, which define renderer and method to be used for creating output.
- renderer
-
Defines renderer’s class
- method
-
Defines renderer’s class method
43 44 45 46 47 48 49 50 51 52 53 |
# File 'app/renderers/dc_common_renderer.rb', line 43 def layout_4print return '' if @parent.params[:renderer].blank? opts = @opts.dup opts[:method] = @parent.params[:method] klass = (@parent.params[:renderer] + '_renderer').classify obj = Kernel.const_get(klass, Class.new).new(@parent, opts) # html = obj.render_html @css << obj.render_css.to_s html end |
#render_html ⇒ Object
Return HTML part of code.
105 106 107 108 |
# File 'app/renderers/dc_common_renderer.rb', line 105 def render_html method = @opts[:method] || 'default' respond_to?(method) ? send(method) : "Error DcCommonRenderer: Method #{method} doesn't exist!" end |