Module: Utilities::TemplateHelper

Includes:
BaseEditingBootstrap::Logging
Included in:
FormHelper, SearchHelper
Defined in:
app/helpers/utilities/template_helper.rb

Instance Method Summary collapse

Methods included from BaseEditingBootstrap::Logging

#bs_logger

Instance Method Details

#find_template_with_fallbacks(obj, field, base_path, generic_field, readonly: false) ⇒ Object

Ricerca template con fallbacks. In ordine, cerca di trovare il partial per l’oggetto(tramite il metodo to_partial_path) e il campo specifico. In successione cerca poi per il partial con nome relativo al tipo di dato sempre nella cartella dell’oggetto ed infine nella cerca nella cartella del base editing

Parameters:

  • obj (Object#to_partial_path)
  • field (Symbol)
  • base_path (String)
  • generic_field (String)
  • readonly (Boolean) (defaults to: false)

    #aggiunge nella ricerca del template la versione readonly



16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
# File 'app/helpers/utilities/template_helper.rb', line 16

def find_template_with_fallbacks(obj, field, base_path, generic_field, readonly: false)
  # nei casi in cui passiamo la classe e non l'oggetto, dobbiamo utilizzare un metodo interno a rails per
  # avere la partial_path

  obj_base_paths = []
  # Primo livello in cui troviamo la partial path rispetto ad istanza o classe
  partial_path = (obj.respond_to? :to_partial_path) ? obj.to_partial_path : obj._to_partial_path
  obj_base_paths << "#{partial_path}/#{base_path}"

  # Cerchiamo anche tutti i livelli di inheritance del modello
  start_class = ((obj.respond_to? :to_partial_path) ? obj.class : obj).superclass

  while start_class < ApplicationRecord
    partial_path = start_class._to_partial_path
    obj_base_paths << "#{partial_path}/#{base_path}"
    start_class = start_class.superclass
  end

  bs_logger.tagged(field) do
    casistiche = [
      # Precedenza modello e campo specifico
      ["Campo SPECIFICO + inheritance tra modelli", field, obj_base_paths],
      # cerco tramite nome modello semplice, con namespace della risorsa (cell_field,header_field,form_field) e nome del campo specifico
      ["Campo specifico con nome modello + inheritance controllers", "#{obj.model_name.element}/#{base_path}/#{field}", lookup_context.prefixes],
      # cerco struttura senza il livello del nome del modello
      ["Campo specifico senza nome modello + inheritance controllers", "#{base_path}/#{field}", lookup_context.prefixes],
      # Ricerca tramite campo generico e prefissi di contesto che contiene anche controller e namespace di controller
      ["Campo GENERICO + inheritance controllers", "#{base_path}/#{generic_field}", lookup_context.prefixes],
      ["Campo GENERICO + inheritance tra modelli", generic_field, obj_base_paths],
      ["Default BaseEditingController", "base_editing/#{base_path}/#{generic_field}", []],
    ]
    # In caso di readonly andremo a ricercare solamente la versione di quel tipo
    if readonly
      casistiche = casistiche.collect do |desc, partial, prefixes|
        [desc, "#{partial}_readonly", prefixes]
      end
    end
    casistiche.each do |desc, partial, prefixes|
      bs_logger.debug { "#{desc} - partial:`#{partial}` in #{prefixes.inspect}" }
      if lookup_context.exists?(partial, prefixes, true)
        return lookup_context.find(partial, prefixes, true)
      end
    end
  end
  # fallback finale
  lookup_context.find("base_editing/#{base_path}/base", [], true)
end