Module: RocketJobMissionControl::ApplicationHelper
- Defined in:
- app/helpers/rocket_job_mission_control/application_helper.rb
Constant Summary collapse
- STATE_ICON_MAP =
{ aborted: "fas fa-stop", completed: "fas fa-check", disabled: "fas fa-stop", enabled: "fas fa-check", failed: "fas fa-exclamation-triangle", paused: "fas fa-pause", pending: "fas fa-inbox", queued: "fas fa-inbox", running: "fas fa-play", sleeping: "fas fa-hourglass", scheduled: "fas fa-clock", starting: "fas fa-cogs", stopping: "fas fa-stop", zombie: "fas fa-hourglass" }.freeze
Instance Method Summary collapse
- #active_page(path) ⇒ Object
-
#editable_field_html(klass, field_name, value, f) ⇒ Object
Returns the editable field as html for use in editing dynamic fields from a Job class.
- #escape(s) ⇒ Object
-
#extract_inclusion_values(klass, attribute) ⇒ Object
Returns [Array] list of inclusion values for this attribute.
-
#link_to_add_fields(name, f, association, option) ⇒ Object
This method creates a link with ‘data-id` `data-fields` attributes.
- #pretty_print_array_or_hash(arguments) ⇒ Object
- #site_title ⇒ Object
- #state_icon(state) ⇒ Object
- #title ⇒ Object
- #unescape(s) ⇒ Object
Instance Method Details
#active_page(path) ⇒ Object
33 34 35 |
# File 'app/helpers/rocket_job_mission_control/application_helper.rb', line 33 def active_page(path) "active" if current_page?(path) end |
#editable_field_html(klass, field_name, value, f) ⇒ Object
Returns the editable field as html for use in editing dynamic fields from a Job class.
68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 |
# File 'app/helpers/rocket_job_mission_control/application_helper.rb', line 68 def editable_field_html(klass, field_name, value, f) # When editing a job the values are of the correct type. # When editing a dirmon entry values are strings. field = klass.fields[field_name.to_s] return unless field&.type placeholder = field.default_val placeholder = nil if placeholder.is_a?(Proc) case field.type.name when "Integer" = extract_inclusion_values(klass, field_name) f.number_field(field_name, in: , include_blank: false, value: value, class: "form-control", placeholder: placeholder) when "String", "Symbol", "Mongoid::StringifiedSymbol" = extract_inclusion_values(klass, field_name) if f.select(field_name, , {include_blank: .include?(nil), selected: value}, {class: "selectize form-control"}) else f.text_area(field_name, value: value ? value : "", class: "form-control", placeholder: placeholder) end when "Boolean", "Mongoid::Boolean" = extract_inclusion_values(klass, field_name) || [nil, "true", "false"] f.select(field_name, , {include_blank: .include?(nil), selected: value}, {class: "selectize form-control"}) when "Hash" "[JSON Hash]\n".html_safe + f.text_field(field_name, value: value ? value.to_json : "", class: "form-control", placeholder: '{"key1":"value1", "key2":"value2", "key3":"value3"}') when "Array" = value.present? ? Array(value) : [] f.select(field_name, (, ), {include_hidden: true}, {class: "selectize form-control", multiple: true}) else "[#{field.type.name}]".html_safe + f.text_field(field_name, value: value, class: "form-control", placeholder: placeholder) end end |
#escape(s) ⇒ Object
59 60 61 |
# File 'app/helpers/rocket_job_mission_control/application_helper.rb', line 59 def escape(s) s.dump[1..-2] end |
#extract_inclusion_values(klass, attribute) ⇒ Object
Returns [Array] list of inclusion values for this attribute. Returns nil when there are no inclusion values for this attribute.
46 47 48 49 50 51 52 53 54 55 56 57 |
# File 'app/helpers/rocket_job_mission_control/application_helper.rb', line 46 def extract_inclusion_values(klass, attribute) values = nil klass.validators_on(attribute).each do |validator| case validator when ActiveModel::Validations::InclusionValidator values = validator.[:in] end end values end |
#link_to_add_fields(name, f, association, option) ⇒ Object
This method creates a link with ‘data-id` `data-fields` attributes. These attributes are used to create new instances of the nested fields through Javascript.
104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 |
# File 'app/helpers/rocket_job_mission_control/application_helper.rb', line 104 def link_to_add_fields(name, f, association, option) # Takes an object (@job) and creates a new instance of its associated model (:properties) new_object = f.object.send(association).klass.new # Saves the unique ID of the object into a variable. # This is needed to ensure the key of the associated array is unique. This is makes parsing the content in the `data-fields` attribute easier through Javascript. # We could use another method to achive this. id = new_object.object_id # https://api.rubyonrails.org/ fields_for(record_name, record_object = nil, fields_options = {}, &block) # record_name = :addresses # record_object = new_object # fields_options = { child_index: id } # child_index` is used to ensure the key of the associated array is unique, and that it matched the value in the `data-id` attribute. # `person[addresses_attributes][child_index_value][_destroy]` fields = f.fields_for(association, new_object, child_index: id) do |builder| # `association.to_s.singularize + "_fields"` ends up evaluating to `address_fields` # The render function will then look for `views/people/_address_fields.html.erb` # The render function also needs to be passed the value of 'builder', because `views/dirmon_entries/_input_categories.html.erb` needs this to render the form tags. render(association.to_s.singularize + "_fields", f: builder) end # This renders a simple link, but passes information into `data` attributes. # This info can be named anything we want, but in this case we chose `data-id:` and `data-fields:`. # The `id:` is from `new_object.object_id`. # The `fields:` are rendered from the `fields` blocks. # We use `gsub("\n", "")` to remove anywhite space from the rendered partial. # The `id:` value needs to match the value used in `child_index: id`. link_to(name, '#', class: "add_fields btn btn-#{option}", data: { id: id, fields: fields.gsub("\n", "") }) end |
#pretty_print_array_or_hash(arguments) ⇒ Object
37 38 39 40 41 42 |
# File 'app/helpers/rocket_job_mission_control/application_helper.rb', line 37 def pretty_print_array_or_hash(arguments) return arguments unless arguments.is_a?(Array) || arguments.is_a?(Hash) = {space: " ", indent: " ", array_nl: "<br />", object_nl: "<br />"} JSON.generate(arguments, ).html_safe end |
#site_title ⇒ Object
24 25 26 |
# File 'app/helpers/rocket_job_mission_control/application_helper.rb', line 24 def site_title "Rocket Job Mission Control" end |
#state_icon(state) ⇒ Object
20 21 22 |
# File 'app/helpers/rocket_job_mission_control/application_helper.rb', line 20 def state_icon(state) STATE_ICON_MAP[state.to_sym] + " " + state.to_s end |
#title ⇒ Object
28 29 30 31 |
# File 'app/helpers/rocket_job_mission_control/application_helper.rb', line 28 def title @page_title ||= params[:controller].to_s.titleize h(@full_title || [@page_title, site_title].compact.join(" | ")) end |
#unescape(s) ⇒ Object
63 64 65 |
# File 'app/helpers/rocket_job_mission_control/application_helper.rb', line 63 def unescape(s) "\"#{s}\"".undump end |