From ef8f27835787c666793cccbeb111d2e603dfe2b6 Mon Sep 17 00:00:00 2001 From: bunhok Date: Tue, 20 Sep 2022 22:44:34 +0700 Subject: [PATCH] [FEATURE] Translate input element refs OSC-17 --- app/assets/javascripts/custom_form_builder.coffee | 4 +++- app/assets/javascripts/multiple_form/form.coffee | 12 ++++++++++++ app/assets/javascripts/program_streams/form.coffee | 4 ++-- app/views/shared/fields/_text.haml | 6 ++++-- app/views/shared/fields/_textarea.haml | 6 ++++-- 5 files changed, 25 insertions(+), 7 deletions(-) diff --git a/app/assets/javascripts/custom_form_builder.coffee b/app/assets/javascripts/custom_form_builder.coffee index 60acc0a5f5..a3e777795b 100644 --- a/app/assets/javascripts/custom_form_builder.coffee +++ b/app/assets/javascripts/custom_form_builder.coffee @@ -130,12 +130,13 @@ class CIF.CustomFormBuilder self.preventClickEnterOrTab(fld) ),50 - eventTextAreaOption: -> + eventTextAreaOption: (fields = []) -> self = @ onadd: (fld) -> $('.rows-wrap, .subtype-wrap, .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() @@ -270,6 +271,7 @@ class CIF.CustomFormBuilder localLabel = "Local Label" if fields[index - 1] localLabel = if fields[index - 1][localLabelName] then fields[index - 1][localLabelName] else localLabel + frmHolder = fldElement.find('.frm-holder') localLabelBlock = "
#{localLabel}
" localLabelBlockElement = $.parseHTML(localLabelBlock) frmHolder.find('.label-wrap').after(localLabelBlockElement) diff --git a/app/assets/javascripts/multiple_form/form.coffee b/app/assets/javascripts/multiple_form/form.coffee index bbfd1fccbc..11aec2ce40 100644 --- a/app/assets/javascripts/multiple_form/form.coffee +++ b/app/assets/javascripts/multiple_form/form.coffee @@ -11,6 +11,8 @@ CIF.Client_trackingsNew = CIF.Client_trackingsCreate = CIF.Client_custom_fieldsN _preventCreateDatePickerClientEnrollment() _setAnotherLanguageFieldValue() _hideAnotherLanguageField() + _copyInputTextToLocalLanguage() + _copyTextAreaTextToLocalLanguage() _initICheckBox = -> $('.i-checks').iCheck @@ -52,6 +54,16 @@ CIF.Client_trackingsNew = CIF.Client_trackingsCreate = CIF.Client_custom_fieldsN _hideAnotherLanguageField = -> $('.client-enrollment').find('.d-none').parent().addClass('hide') + _copyInputTextToLocalLanguage = -> + $('input[type="text"]').on 'keyup', (e) -> + el = $(@) + el.parent().next().find('#' + el.data('local-input')).val(el.val()) + + _copyTextAreaTextToLocalLanguage = -> + $('textarea').on 'keyup', (e) -> + el = $(@) + el.parent().next().find('#' + el.data('local-textarea')).val(el.val()) + _preventRequireFields = -> preventFileUploader() preventRequireFieldInput() diff --git a/app/assets/javascripts/program_streams/form.coffee b/app/assets/javascripts/program_streams/form.coffee index 0a311d54db..8f50bd9bef 100644 --- a/app/assets/javascripts/program_streams/form.coffee +++ b/app/assets/javascripts/program_streams/form.coffee @@ -292,8 +292,8 @@ CIF.Program_streamsNew = CIF.Program_streamsEdit = CIF.Program_streamsCreate = C number: builderOption.eventNumberOption() 'radio-group': builderOption.eventRadioOption() select: builderOption.eventSelectOption(fields) - text: builderOption.eventTextFieldOption() - textarea: builderOption.eventTextAreaOption() + text: builderOption.eventTextFieldOption(fields) + textarea: builderOption.eventTextAreaOption(fields) separateLine: builderOption.eventSeparateLineOption() paragraph: builderOption.eventParagraphOption() } diff --git a/app/views/shared/fields/_text.haml b/app/views/shared/fields/_text.haml index 101e23ee5b..c06543d826 100644 --- a/app/views/shared/fields/_text.haml +++ b/app/views/shared/fields/_text.haml @@ -1,7 +1,9 @@ +- label = field_label(field_props) %div{ class: "form-group #{field_with(field_props['label'],errors)}" } %label.control-label{ class: required?(field_props['required'] || false) } %abbr{ title: 'required' }= '*' if field_props['required'] || false - = field_props['label'].html_safe - = f.input field_props['label'], required: (field_props['required'] || false), input_html: { class: field_props['className'], placeholder: format_placeholder(field_props['placeholder']), title: field_props['description'], name: "#{f.object_name}[#{remove_field_prop_unicode(field_props)}]", type: field_props['subtype'] , id: "#{f.object_name}[#{remove_field_prop_unicode(field_props)}]".parameterize}, label: false + = label.html_safe + = f.input field_props['label'], required: (field_props['required'] || false), input_html: { class: field_props['className'], placeholder: format_placeholder(field_props['placeholder']), title: field_props['description'], name: "#{f.object_name}[#{remove_field_prop_unicode(field_props)}]", type: field_props['subtype'] , id: "#{f.object_name}[#{remove_field_prop_unicode(field_props)}]".parameterize, 'data-local-input': "#{f.object_name}[#{remove_local_field_prop_unicode(field_props)}]".parameterize }, label: false + = f.input field_props['local_label'], :as => :hidden, input_html: { name: "#{f.object_name}[Local_label #{remove_local_field_prop_unicode(field_props)}]", id: "#{f.object_name}[#{remove_local_field_prop_unicode(field_props)}]".parameterize } %span.help-block = field_message(field_props['label'], errors) diff --git a/app/views/shared/fields/_textarea.haml b/app/views/shared/fields/_textarea.haml index c380a038f1..59371541af 100644 --- a/app/views/shared/fields/_textarea.haml +++ b/app/views/shared/fields/_textarea.haml @@ -1,7 +1,9 @@ +- label = field_label(field_props) %div{ class: "form-group #{field_with(field_props['label'],errors)}" } %label.control-label{ class: required?(field_props['required'] || false) } %abbr{ title: 'required' }= '*' if field_props['required'] || false - = field_props['label'].html_safe - = f.input field_props['label'], as: :text, required: (field_props['required'] || false), input_html: { class: field_props['className'], placeholder: format_placeholder(field_props['placeholder']), name: "#{f.object_name}[#{remove_field_prop_unicode(field_props)}]" }, label: false + = label.html_safe + = f.input field_props['label'], as: :text, required: (field_props['required'] || false), input_html: { class: field_props['className'], placeholder: format_placeholder(field_props['placeholder']), name: "#{f.object_name}[#{remove_field_prop_unicode(field_props)}]", 'data-local-textarea': "#{f.object_name}[#{remove_local_field_prop_unicode(field_props)}]".parameterize }, label: false + = f.input field_props['local_label'], :as => :hidden, input_html: { name: "#{f.object_name}[Local_label #{remove_local_field_prop_unicode(field_props)}]", id: "#{f.object_name}[#{remove_local_field_prop_unicode(field_props)}]".parameterize } %span.help-block = field_message(field_props['label'], errors)