Skip to content

Commit

Permalink
[FEATURE] Translate form builder
Browse files Browse the repository at this point in the history
refs OSC-17
  • Loading branch information
Bunhok committed Sep 20, 2022
1 parent b0eb1c4 commit 5e76c27
Show file tree
Hide file tree
Showing 13 changed files with 128 additions and 26 deletions.
18 changes: 16 additions & 2 deletions app/assets/javascripts/custom_form_builder.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -95,7 +95,7 @@ class CIF.CustomFormBuilder
self.preventClickEnterOrTab(fld)
),50

eventSelectOption: ->
eventSelectOption: (fields = [])->
self = @
onadd: (fld) ->
$('.className-wrap, .access-wrap, .description-wrap, .name-wrap').hide()
Expand All @@ -104,6 +104,7 @@ class CIF.CustomFormBuilder
self.addOptionCallback(fld)
self.generateValueForSelectOption(fld)
self.preventClickEnterOrTab(fld)
self.handleAddTranslateLabelField(fld, fields)
onclone: (fld) ->
setTimeout ( ->
self.handleCheckingForm()
Expand All @@ -113,7 +114,7 @@ class CIF.CustomFormBuilder
self.preventClickEnterOrTab(fld)
),50

eventTextFieldOption: ->
eventTextFieldOption: (fields = []) ->
self = @
onadd: (fld) ->
$('.fld-subtype ').find('option:contains(color)').remove()
Expand All @@ -122,6 +123,7 @@ class CIF.CustomFormBuilder
$('.className-wrap, .value-wrap, .access-wrap, .maxlength-wrap, .description-wrap, .name-wrap').hide()
self.handleCheckingForm()
self.preventClickEnterOrTab(fld)
self.handleAddTranslateLabelField(fld, fields)
onclone: (fld) ->
setTimeout ( ->
self.handleCheckingForm()
Expand Down Expand Up @@ -259,3 +261,15 @@ class CIF.CustomFormBuilder
event.preventDefault()
key = if event.which == 13 then 'Enter key' else 'Semi-colon'
alert("#{key} is not allowed!")

handleAddTranslateLabelField: (fld, fields) ->
fldElement = $(fld)
fldId = fldElement.attr('id')
index = fldId.substr(fldId.length - 1)
localLabelName = "local_label"
localLabel = "Local Label"
if fields[index - 1]
localLabel = if fields[index - 1][localLabelName] then fields[index - 1][localLabelName] else localLabel
localLabelBlock = "<div class='form-group local-label-wrap' style='display: block'><label for='#{localLabelName}'>Local Label</label><div class='input-wrap'><div name='#{localLabelName}' placeholder='Local Label' class='fld-label-#{fldId} form-control' id='local-label-#{fldId}' contenteditable='true'>#{localLabel}</div></div></div>"
localLabelBlockElement = $.parseHTML(localLabelBlock)
frmHolder.find('.label-wrap').after(localLabelBlockElement)
10 changes: 10 additions & 0 deletions app/assets/javascripts/multiple_form/form.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,8 @@ CIF.Client_trackingsNew = CIF.Client_trackingsCreate = CIF.Client_custom_fieldsN
_initICheckBox()
_initDatePicker()
_preventCreateDatePickerClientEnrollment()
_setAnotherLanguageFieldValue()
_hideAnotherLanguageField()

_initICheckBox = ->
$('.i-checks').iCheck
Expand Down Expand Up @@ -42,6 +44,14 @@ CIF.Client_trackingsNew = CIF.Client_trackingsCreate = CIF.Client_custom_fieldsN
currentEnterNgo = $('#current_enter_ngo').val()
$('.client-enrollment-date').datepicker('setStartDate', currentEnterNgo)

_setAnotherLanguageFieldValue = ->
$('select').on 'select2-selecting', (e) ->
$('#' + $(e.target).data('label')).val($(e.choice.element).data('value')).trigger("change")
return

_hideAnotherLanguageField = ->
$('.client-enrollment').find('.d-none').parent().addClass('hide')

_preventRequireFields = ->
preventFileUploader()
preventRequireFieldInput()
Expand Down
82 changes: 70 additions & 12 deletions app/assets/javascripts/program_streams/form.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -249,7 +249,7 @@ CIF.Program_streamsNew = CIF.Program_streamsEdit = CIF.Program_streamsCreate = C
$('#trackings').on 'cocoon:after-insert', (e, element) ->
trackingBuilder = $(element).find('.tracking-builder')
$(element).attr('id', Date.now())
_initProgramBuilder(trackingBuilder, [])
_initMultipleFormBuilder(0, trackingBuilder)
_editTrackingFormName()
_handleRemoveCocoon()
_initSelect2TimeOfFrequency()
Expand All @@ -259,6 +259,57 @@ CIF.Program_streamsNew = CIF.Program_streamsEdit = CIF.Program_streamsCreate = C
_custom_field_list()
_initCheckbox()

_initMultipleFormBuilder = (startIndex, elements) ->
if startIndex < elements.length
dataElement = JSON.parse($(elements[startIndex]).children('span').text())
builderOption = new CIF.CustomFormBuilder()
specialCharacters = { '&amp;': '&', '&lt;': '<', '&gt;': '>', "&qoute;": '"' }
format = new CIF.FormatSpecialCharacters()
fields = format.formatSpecialCharacters((dataElement || []), specialCharacters)

$(elements[startIndex]).formBuilder(
templates: separateLine: (fieldData) ->
{ field: '<hr/>' }
fields: builderOption.thematicBreak()
dataType: 'json'
formData: JSON.stringify(fields)
disableFields: ['autocomplete', 'header', 'hidden', 'button', 'checkbox']
showActionButtons: false
messages: {
cannotBeEmpty: 'name_separated_with_underscore'
}
stickyControls: {
enable: true
offset:
width: '17%'
right: 78
left: 'auto'
}
typeUserEvents: {
'checkbox-group': builderOption.eventCheckboxOption()
date: builderOption.eventDateOption()
file: builderOption.eventFileOption()
number: builderOption.eventNumberOption()
'radio-group': builderOption.eventRadioOption()
select: builderOption.eventSelectOption(fields)
text: builderOption.eventTextFieldOption()
textarea: builderOption.eventTextAreaOption()
separateLine: builderOption.eventSeparateLineOption()
paragraph: builderOption.eventParagraphOption()
}
onAddOption: (optionTemplate, optionIndex) ->
index = optionIndex.index + 1
if !optionTemplate.local_label
optionTemplate.local_label = "Local option #{index}"
optionTemplate.local_value = "Local option #{index}"
return optionTemplate
).promise.then((form) ->
form.element = elements[startIndex]
@formBuilder.push form
startIndex++
_initMultipleFormBuilder(startIndex, elements)
)

_initProgramBuilder = (element, data) ->
builderOption = new CIF.CustomFormBuilder()
specialCharacters = { '&amp;': '&', '&lt;': '<', '&gt;': '>', "&qoute;": '"' }
Expand Down Expand Up @@ -294,9 +345,18 @@ CIF.Program_streamsNew = CIF.Program_streamsEdit = CIF.Program_streamsCreate = C
textarea: builderOption.eventTextAreaOption()
separateLine: builderOption.eventSeparateLineOption()
paragraph: builderOption.eventParagraphOption()
})
formBuilder.element = element
@formBuilder.push formBuilder
}
onAddOption: (optionTemplate, optionIndex) ->
index = optionIndex.index + 1
optionTemplate.local_label = "Local option #{index}"
optionTemplate.local_value = "local-option-#{index}"
return optionTemplate
onOpenFieldEdit: (editPanel) ->
$(editPanel).find('.option-local_value').hide()
).promise

form.element = element
@formBuilder.push form

_editTrackingFormName = ->
inputNames = $(".program_stream_trackings_name input[type='text']")
Expand Down Expand Up @@ -439,19 +499,16 @@ CIF.Program_streamsNew = CIF.Program_streamsEdit = CIF.Program_streamsCreate = C
$('.links a').trigger('click')

_handleInitProgramFields = ->
for element in $('#enrollment, #exit-program')
dataElement = JSON.parse($(element).children('span').text())
_initProgramBuilder($(element), (dataElement || []))

elements = ['#enrollment', '#exit-program']
_initMultipleFormBuilder(0, elements)
for element in elements
if element.id == 'enrollment' and $('#program_stream_id').val() != ''
_preventRemoveField(ENROLLMENT_URL, '#enrollment')
else if element.id == 'exit-program' and $('#program_stream_id').val() != ''
_preventRemoveField(EXIT_PROGRAM_URL, '#exit-program')

trackings = $('.tracking-builder')
for tracking in trackings
trackingValue = JSON.parse($(tracking).children('span').text())
_initProgramBuilder(tracking, (trackingValue || []))
_initMultipleFormBuilder(0, trackings)
_preventRemoveField(TRACKING_URL, '') if $('#program_stream_id').val() != ''

_initButtonSave = ->
Expand All @@ -465,10 +522,11 @@ CIF.Program_streamsNew = CIF.Program_streamsEdit = CIF.Program_streamsCreate = C

_handleSetValueToField = ->
for formBuilder in @formBuilder
console.log(formBuilder.actions.save(), 'form builder actions')
element = formBuilder.element
specialCharacters = { "&": "&amp;", "<": "&lt;", ">": "&gt;", '"': "&qoute;" }
format = new CIF.FormatSpecialCharacters()
fields = format.formatSpecialCharacters(JSON.parse(formBuilder.actions.save()), specialCharacters)
fields = format.formatSpecialCharacters(formBuilder.actions.save(), specialCharacters)
fields = JSON.stringify(fields)
if $(element).is('#enrollment')
$('#program_stream_enrollment').val(fields)
Expand Down
2 changes: 1 addition & 1 deletion app/assets/stylesheets/application.scss
Original file line number Diff line number Diff line change
Expand Up @@ -97,4 +97,4 @@
@import "care_plans/*";
@import "family_advanced_searches/*";
@import "service_deliveries/*";
@import "case_conferences/*";
@import "case_conferences/*";
2 changes: 1 addition & 1 deletion app/assets/stylesheets/client_program_stream.scss
Original file line number Diff line number Diff line change
Expand Up @@ -14,4 +14,4 @@
width: 400px;
}
}
}
}
8 changes: 8 additions & 0 deletions app/assets/stylesheets/program_streams/form.scss
Original file line number Diff line number Diff line change
Expand Up @@ -188,4 +188,12 @@ body[id='program_streams-update'], body[id='program_streams-create'] {
cursor: pointer;
}
}

.wizard > .content > .body {
#enrollment, #trackings, #exit-program {
.field-options {
input.option-value, input[type='radio'].option-selected, input.option-local_value { display: none; }
}
}
}
}
2 changes: 1 addition & 1 deletion app/classes/advanced_searches/enrollment_sql_builder.rb
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ def get_sql
properties_result = client_enrollments.where.not("properties -> '#{@field}' ? '#{@value}' ")
end
when 'less'
properties_result = client_enrollments.where("(properties ->> '#{@field}')#{'::numeric' if integer? } < '#{@value}' AND properties ->> '#{@field}' != '' ")
properties_result = client_enrollments.where("((properties ->> '#{@field}')#{'::numeric' if integer? } < '#{@value}' OR properties ->> 'Local_label #{@field}')#{'::numeric' if integer? } < '#{@value}') AND properties ->> '#{@field}' != '' ")
when 'less_or_equal'
properties_result = client_enrollments.where("(properties ->> '#{@field}')#{ '::numeric' if integer? } <= '#{@value}' AND properties ->> '#{@field}' != '' ")
when 'greater'
Expand Down
5 changes: 5 additions & 0 deletions app/helpers/client_enrollment_helper.rb
Original file line number Diff line number Diff line change
Expand Up @@ -76,4 +76,9 @@ def client_enrollment_destroy_link
end
end
end

def field_label(props, index = nil)
label = I18n.locale.to_s == I18n.default_locale.to_s ? props['label'] : props['local_label']
label
end
end
4 changes: 4 additions & 0 deletions app/helpers/custom_field_properties_helper.rb
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,10 @@ def remove_field_prop_unicode(field_props)
field = field_props['label'].gsub(/\&gt\;|\&lt\;|\&amp\;|\"/, '&lt;' => '<', '&gt;' => '>', '&amp;' => '&', '"' => '%22')
end

def remove_local_field_prop_unicode(field_props)
field = field_props["local_label"].gsub(/\&gt\;|\&lt\;|\&amp\;|\"/, '&lt;' => '<', '&gt;' => '>', '&amp;' => '&', '"' => '%22')
end

def mapping_custom_field_values(field_props)
field_props['values'].map do |f|
[format_placeholder(f['label']).blank? ? f['label'] : format_placeholder(f['label']), f['label'], id: "custom_field_property_properties_#{field_props['label'].gsub('"', '&qoute;').html_safe}_#{f['label'].html_safe}"]
Expand Down
2 changes: 1 addition & 1 deletion app/validators/custom_form_present_validator.rb
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ def initialize(record,table_name,field)

def validate
return unless @record.properties.present?
@record.send(@table_name).send(@field).each do |field|
@record.send(@table_name).send(@field).each_with_index do |field, index|
field_label = field['label']
next unless field['required'] && (@record.properties[field_label].blank? || @record.properties[field_label][0].blank?)
@record.errors.add(field_label, I18n.t('cannot_be_blank')) if field['type'] != 'file'
Expand Down
8 changes: 5 additions & 3 deletions app/views/client_enrolled_programs/show.haml
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
.ibox-content
.table-responsive
%table.table.table-bordered
- @program_stream.enrollment.map{|properties| [properties['type'], properties['label']]}.each do |type, key|
- @program_stream.enrollment.map{|properties| [properties['type'], properties['label'], properties["local_label"]]}.each do |type, key, translated_key|
- unless type == 'separateLine'
- if type == 'paragraph'
%tr
Expand All @@ -25,9 +25,11 @@
- else
%tr
%td.align-justify
= key.html_safe
- label = I18n.locale.to_s === I18n.default_locale.to_s ? key.html_safe : translated_key
= label
%td.align-justify
- key = convert_bracket(key, @client_enrollment.properties)
- key = convert_bracket(label, @client_enrollment.properties)
- key = I18n.locale.to_s === I18n.default_locale.to_s ? key : "Local_label #{key}"
- if type == 'file'
= render 'shared/form_builder/list_attachment', label: key, resource: @client_enrollment
- else
Expand Down
10 changes: 6 additions & 4 deletions app/views/shared/fields/_select.haml
Original file line number Diff line number Diff line change
@@ -1,8 +1,10 @@
%div{ class: "form-group #{field_with(field_props['label'],errors)}" }
- label = field_label(field_props)
%div{ class: "form-group #{field_with(label,errors)}" }
%label.control-label{ class: required?(field_props['required'] || false) }
%abbr{ title: 'required' }= '*' if field_props['required'] || false
= field_props['label'].gsub('&amp;#91;', '&#91;').gsub('&amp;#93;', '&#93;').html_safe
= label.gsub('&amp;#91;', '&#91;').gsub('&amp;#93;', '&#93;').html_safe

= f.input field_props['label'], collection: field_props['values'].map { |f| [format_placeholder(f['label']), f['label'], id: "custom_field_property_properties_#{field_props['label'].gsub('"', '&qoute;').html_safe}_#{f['label'].html_safe}"] }, required: (field_props['required'] || false), input_html: { id: field_props['label'].gsub("'", ""), class: field_props['ClassName'], multiple: field_props['multiple'].present?, name: "#{f.object_name}[#{remove_field_prop_unicode(field_props)}][]", placeholder: format_placeholder(field_props['placeholder']) }, label: false
= f.input field_props['label'].gsub(' ', '_'), collection: field_props['values'].map { |f| [format_placeholder(f['label']), f['label'], id: "custom_field_property_properties_#{field_props['label'].gsub('"', '&qoute;').html_safe}_#{f['label'].html_safe}", 'data-value': f['local_label']] }, required: (field_props['required'] || false), input_html: { id: field_props['label'].gsub(' ', '_').gsub("'", ""), class: "#{field_props['ClassName']} #{I18n.locale.to_s != I18n.default_locale.to_s ? 'd-none' : ''}", multiple: field_props['multiple'].present?, name: "#{f.object_name}[#{remove_field_prop_unicode(field_props)}][]", placeholder: format_placeholder(field_props['placeholder']), 'data-label': field_props["local_label"].gsub(' ', '_').gsub("'", "") }, label: false
= f.input field_props["local_label"].gsub(' ', '_'), collection: field_props['values'].map { |f| [format_placeholder(f['local_label']), f['local_label'], id: "custom_field_property_properties_#{field_props["local_label"].gsub('"', '&qoute;').html_safe}_#{f['local_label'].html_safe}", 'data-value': f['label']] }, required: (field_props['required'] || false), input_html: { id: field_props["local_label"].gsub(' ', '_').gsub("'", ""), class: "#{field_props['ClassName']} #{I18n.locale.to_s == I18n.default_locale.to_s ? 'd-none' : ''}", multiple: field_props['multiple'].present?, name: "#{f.object_name}[Local_label #{remove_local_field_prop_unicode(field_props)}][]", placeholder: format_placeholder(field_props['placeholder']), 'data-label': field_props["label"].gsub(' ', '_').gsub("'", "") }, label: false
%span.help-block
= field_message(field_props['label'], errors)
= field_message(label, errors)
1 change: 0 additions & 1 deletion config/environments/development.rb
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
Rails.application.configure do
config.assets.js_compressor = :terser
# Settings specified here will take precedence over those in config/application.rb.

# In the development environment your application's code is reloaded on
Expand Down

0 comments on commit 5e76c27

Please sign in to comment.