$(document).ready(function(){ var head_data = $.post("/cancerpredictResult",{"header":1,locale:I18n.locale}); var data = {}; if(I18n.locale == 'en'){ var window_width = $(window).width(); if(window_width < 520){ $('#cancer_table .cencer_table_name').css('max-width',''); }else if(window_width < 768){ $('#cancer_table .cencer_table_name').css({'max-width':'','width':'11em'}); }else if(window_width < 860){ $('#cancer_table .cencer_table_name').css('max-width','30%'); }else if(window_width < 1130){ $('#cancer_table .cencer_table_name').css('max-width','33%'); }else{ $('#cancer_table .cencer_table_name').css('max-width','39%'); }; }; head_data.done(function(){ // $('.header-nav').html(head_images.responseJSON['head_images']); // $('.navbar-brand').html(head_images.responseJSON['title']) data['danger_texts'] = head_data.responseJSON['danger_texts']; $('head title').text(head_data.responseJSON['page_title']) }); Array.prototype.remove_item_from_array = function(){ var result_array = this; for(var i=0;i $(this).data('range')[1] && $(this).data('range')[1] != undefined) ){ $(this).css('color','#f24a69'); $(this).addClass('cancertable_empty'); }else{ $(this).css('color','#333'); $(this).removeClass('cancertable_empty'); if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; }; }); $('input#lymph_nodes_positive').off('input').on('input',function(){ $(this).siblings('.num_only_value').val($(this).val()); if( Number($(this).val()) < $(this).data('range_new')[0] || $(this).val() == "" || (Number($(this).val()) > $(this).data('range_new')[1] && $(this).data('range_new')[1] != undefined) ){ $(this).css('color','#f24a69'); $(this).addClass('cancertable_empty'); }else{ $(this).css('color','#333'); $(this).removeClass('cancertable_empty'); if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; }; }); $('input#lymph_nodes_examined').off('input').on('input',function(){ $(this).siblings('.num_only_value').val($(this).val()); if( Number($(this).val()) < $(this).data('range_new')[0] || $(this).val() == "" || (Number($(this).val()) > $(this).data('range_new')[1] && $(this).data('range_new')[1] != undefined) ){ $(this).css('color','#f24a69'); $(this).addClass('cancertable_empty'); }else{ $(this).css('color','#333'); $(this).removeClass('cancertable_empty'); if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; }; }); $('.cancer_help_btn').off("click").on('click',function(){ var modal_head = ""; try{ modal_head = $(this).parent().find(">label").html()}catch(e){}; var modal_body = ""; try{ modal_body = $(this).parent().find(">input.help_texts").attr('value')}catch(e){}; $('#show_help_modal').html("") $('#show_help_modal').modal('show'); $('#show_help_modal .close').off("click").on('click',function(){ $('#show_help_modal').modal('hide'); }); $('#show_help_modal .modal-footer button').off("click").on('click',function(){ $('#show_help_modal').modal('hide'); }); }); $('.btn-add').click(function(){ $(this).parent().find('.num_only').removeClass('cancertable_empty'); if($(this).parent().find('.num_only').val()!=""){ var input_value = Number($(this).parent().find('.num_only').val()); if(Array.isArray($(this).parent().find('.num_only').data('range'))){ var compare_value = $(this).parent().find('.num_only').data('range')[1]; if(compare_value != undefined){ if(input_value+1 <= Number(compare_value)) $(this).parent().find('.num_only').val(input_value+1); else{ input_value = $(this).parent().find('.num_only').data('range')[0]; if(input_value != undefined) $(this).parent().find('.num_only').val(input_value); }; }else{ $(this).parent().find('.num_only').val(input_value+1); }; compare_value = $(this).parent().find('.num_only').data('range')[0]; if(compare_value != undefined){ if($(this).parent().find('.num_only').val() >= compare_value){ $(this).parent().find('.num_only').removeClass('cancertable_empty'); $(this).parent().find('.num_only').css('color','#333'); }; if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; }else{ $(this).parent().find('.num_only').removeClass('cancertable_empty'); $(this).parent().find('.num_only').css('color','#333'); if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; }; }; }else{ try{ var input_value = $(this).parent().find('.num_only').data('range')[0]; if(input_value != undefined) $(this).parent().find('.num_only').val(input_value); }catch(e){ $(this).parent().find('.num_only').val(0); }; if($(this).parent().find('.num_only').val() != ""){ $(this).parent().find('.num_only').removeClass('cancertable_empty'); $(this).parent().find('.num_only').css('color','#333'); }; }; }); $('.btn-sub').click(function(){ if($(this).parent().find('.num_only').val()!=""){ var input_value = Number($(this).parent().find('.num_only').val()); if(Array.isArray($(this).parent().find('.num_only').data('range'))){ var compare_value = $(this).parent().find('.num_only').data('range')[0]; if(compare_value != undefined){ if(input_value-1 >= Number(compare_value)) $(this).parent().find('.num_only').val(input_value-1); else{ input_value = $(this).parent().find('.num_only').data('range')[1]; if(input_value != undefined) $(this).parent().find('.num_only').val(input_value); }; }else{ $(this).parent().find('.num_only').val(input_value-1); }; compare_value = $(this).parent().find('.num_only').data('range')[1]; if(compare_value != undefined){ if($(this).parent().find('.num_only').val() <= compare_value){ $(this).parent().find('.num_only').removeClass('cancertable_empty'); $(this).parent().find('.num_only').css('color','#333'); }; if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; }else{ $(this).parent().find('.num_only').removeClass('cancertable_empty'); $(this).parent().find('.num_only').css('color','#333'); if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; }; }; }else{ try{ var input_value = $(this).parent().find('.num_only').data('range')[1]; if(input_value != undefined){ $(this).parent().find('.num_only').val(input_value); }else{ input_value = $(this).parent().find('.num_only').data('range')[0]; if(input_value != undefined) $(this).parent().find('.num_only').val(input_value); } }catch(e){ $(this).parent().find('.num_only').val(0); }; if($(this).parent().find('.num_only').val() != ""){ $(this).parent().find('.num_only').removeClass('cancertable_empty'); $(this).parent().find('.num_only').css('color','#333'); }; }; if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; }); $('.cancer_table_btn').off('click').on('click',function(){ var index = $(this).index()/2; try{ $(this).parent().find('>input').attr('value',0); $(this).parent().find('>input').eq(index).attr('value',1); $(this).parent().find('>button').removeClass('active'); $(this).parent().removeClass('cancertable_empty'); if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; }catch(e){}; $(this).addClass('active'); }); $('#cancer_table_reset').click(function(){ $('.cancer_table_btn').removeClass('active'); $('.cancer-btn-group input').attr('value',0); $('.num_only').val(''); $('.num_only_value').val(''); $('#cancer_table .cancer_form_field').removeClass('cancertable_empty'); $('#cancer_predict_result_block').css('display','none'); $('#danger_texts').remove(); $('select.select_num').val(''); }); function get_input_data(){ var flag; flag = 1; for(var i = 0;i < $('#cancer_table .cancer_form_field').length;i++){ if($('#cancer_table .cancer_form_field').eq(i).hasClass('num_only')){ if($('#cancer_table .cancer_form_field').eq(i).val()==""){ flag = 0; $('#cancer_table .cancer_form_field').eq(i).addClass('cancertable_empty'); }else if($('#cancer_table .cancer_form_field').eq(i).val() != "" && !$('#cancer_table .cancer_form_field').eq(i).hasClass('cancertable_empty')){ $('#cancer_table .cancer_form_field').eq(i).removeClass('cancertable_empty'); }; }else{ if($('#cancer_table .cancer_form_field').eq(i).find('[value="1"]').length == 0){ flag = 0; $('#cancer_table .cancer_form_field').eq(i).addClass('cancertable_empty'); }else{ $('#cancer_table .cancer_form_field').eq(i).removeClass('cancertable_empty'); } }; }; if( Number($('input#lymph_nodes_examined').siblings('.num_only_value').val()) < Number($('input#lymph_nodes_positive').siblings('.num_only_value').val())){ $('input#lymph_nodes_positive').addClass('cancertable_empty'); $('input#lymph_nodes_positive').css('color','rgb(242, 74, 105)'); }; if($('.cancertable_empty').length != 0){ flag = 0; ($('#danger_texts').length == 0) ? $('#cancer_table_submit').parent().before(''+data['danger_texts']+'') : null; $('#danger_texts').css('margin-left',$(window).width()/2-$('#danger_texts').width()/2); }else{ $('#danger_texts').remove(); }; if(flag == 1){ var post_json= {}; for(var i = 0;i < $('#cancer_table .cancer_form_field').length;i++){ var name = $('#cancer_table .cancer_form_field').eq(i).attr('id') if($('#cancer_table .cancer_form_field').eq(i).hasClass('num_only')) post_json[name] = $('#cancer_table .cancer_form_field').eq(i).siblings('.num_only_value').val(); else{ var index = ($('#cancer_table .cancer_form_field').eq(i).find('[value="1"]').index()+1)/2; post_json[name] = index; }; }; if( post_json["ER_status"] == 2 && post_json["PR_status"] == 2 ){ $('#hormone_therapy .cancer_table_btn').attr('disabled','disabled'); $('[for="hormone_therapy"]').css('color','rgb(204, 204, 204)'); }else{ $('#hormone_therapy .cancer_table_btn').removeAttr('disabled'); $('[for="hormone_therapy"]').css('color',''); }; if(post_json["HER2_status"] != 1){ $('#Targeted_therapy .cancer_table_btn').attr('disabled','disabled'); $('[for="Targeted_therapy"]').css('color','rgb(204, 204, 204)'); }else{ $('#Targeted_therapy .cancer_table_btn').removeAttr('disabled'); $('[for="Targeted_therapy"]').css('color',''); }; return post_json; }else{ return null; } }; function set_result(result){ if(result.responseJSON.lpv != "error"){ $('#choice_fields .cancer_table_btn').removeClass('active'); var load_heml = $('#result_table_content').html(result.responseJSON.table); load_heml.ready(function(){ $('#result_table_content .cancer_years').eq(-1).addClass('active'); for(var i = 0;i < $('#result_table_content .cancer_years').length;i++){ $('#result_table_content .cancer_years').eq(i).attr('index',i) }; $('#result_table_content .cancer_years').off('click').on('click',function(){ try{ $(this).parent().find('.cancer_years').removeClass('active'); }catch(e){}; $(this).addClass('active'); $('#current_year').attr('index',$(this).attr('index')); $('#current_year').attr('value',$(this).html()); $('#current_year').change(); }); }); load_heml = $('#result_text_content').html(result.responseJSON.texts); load_heml.ready(function(){ $('#result_text_content .cancer_years').eq(-1).addClass('active'); for(var i = 0;i < $('#result_text_content .cancer_years').length;i++){ $('#result_text_content .cancer_years').eq(i).attr('index',i) }; $('#current_year').off('change'); $('#result_text_content .cancer_years').off('click') $('#result_text_content .cancer_years').click(function(){ try{ $(this).parent().find('.cancer_years').removeClass('active'); }catch(e){}; $(this).addClass('active'); $('#current_year').attr('value',$(this).html()); $('#current_year').attr('index',$(this).attr('index')); $('.surgery_year').html($(this).html()); $('#current_year').change(); }); $('#cancer_table_right_result .cancer-btn-group .cancer_table_btn').removeClass('active'); $('#cancer_table_right_result .cancer-btn-group >input').attr('value',"0"); for(var i = 0;i < $('#cancer_table_left_result .cancer-btn-group').length;i++){ $('#cancer_table_left_result .cancer-btn-group').eq(i).find('.cancer_table_btn').eq(0).addClass('active'); $('#cancer_table_left_result .cancer-btn-group').eq(i).find('>input').eq(0).attr('value',"1"); }; for(var i = 0;i < $('#cancer_table_right_result .cancer-btn-group').length;i++){ $('#cancer_table_right_result .cancer-btn-group').eq(i).find('.cancer_table_btn').eq(0).addClass('active'); $('#cancer_table_right_result .cancer-btn-group').eq(i).find('>input').eq(0).attr('value',"1"); }; var treatmeny_method = result.responseJSON.treatmeny_method; $('tr.'+treatmeny_method[0]).addClass('tr_show') var lpv = [0,-0.8397,-0.4147,-0.3203,-0.4687]; var servive_ratio_arr = [result.responseJSON.servive_ratio] var yes = (I18n.locale=="zh_tw") ? "是" : "yes"; var year = $('#current_year').attr('value'); var active_treatment = ['Surgery_only']; $('tr.'+active_treatment[0]+' .Overall_Survival').html(servive_ratio_arr[0]+'%'); $('#cancer_predict_result_block').css('display','block'); var lpv_real = [result.responseJSON['lpv']]; var lpv_dict={} var lpv_calc={1:-0.001476145,3:-0.01261639,5:-0.02519608} active_treatment.push = function() { if(arguments.length == 1){ var year = $('#current_year').attr('value'); var lpv_current = lpv_real[lpv_real.length-1]+lpv_dict[arguments[0]]; lpv_real.push(lpv_current); var servive_ratio = Math.round((Math.exp(lpv_calc[year])**Math.exp(lpv_current))*100); var benefit = servive_ratio - servive_ratio_arr[servive_ratio_arr.length - 1]; servive_ratio_arr.push(servive_ratio); $('tr.'+arguments[0]+' td.Overall_Survival').html(servive_ratio+'%'); $('tr.'+arguments[0]+' td.Additional_Benefit').html(benefit+'%'); $('tr.'+arguments[0]).css('display','table-row'); $('tr.tr_show').eq(-1).after($('tr.'+arguments[0])); $('tr.'+arguments[0]).addClass('tr_show'); if(this.length == 1){ $('.addition').css('display','inline-block'); $('#result_text_content .extra-text').css('display','inline-block'); } var add_choices = this.slice(1,this.length); add_choices.push(arguments[0]); var add_choices_transform = []; for(var i = 0;i= 2) add_choices_str += ((I18n.locale == 'en' ? ', and ': '以及')+add_choices_transform[add_choices_transform.length-1]) else add_choices_str = add_choices_transform[0]; var extra_therapy_texts = result.responseJSON['extra_therapy_texts']; extra_therapy_texts = extra_therapy_texts.replace('{{extra_therapy}}',''+add_choices_str+''); extra_therapy_texts = extra_therapy_texts.replace('{{survival_num}}',''+servive_ratio+''); extra_therapy_texts = extra_therapy_texts.replace('{{surgery_year}}',''+year+''); extra_therapy_texts = extra_therapy_texts.replace('{{Additional_Benefit}}',''+benefit+''); var new_text = '

'; new_text += (extra_therapy_texts+'

'); $('#result_text_content .extra-text .texts_show').eq(-1).after(new_text) return Array.prototype.push.apply(this, arguments); }else{ return Array.prototype.push.apply(this, arguments); } }; active_treatment.remove_item_from_array = function(){ if(arguments.length == 1 && !Array.isArray(arguments[0])){ var index = this.indexOf(arguments[0]) var year = $('#current_year').attr('value'); if(index < this.length - 1){ for(var i = index + 1;i < this.length; i++){ lpv_real[i] -= lpv_dict[arguments[0]]; var servive_ratio = Math.round((Math.exp(lpv_calc[year])**Math.exp(lpv_real[i]))*100); servive_ratio_arr[i] = servive_ratio; var benefit = servive_ratio - ((i == index+1) ? servive_ratio_arr[index - 1] : servive_ratio_arr[i - 1]); $('tr.'+active_treatment[i]+' td.Overall_Survival').html(servive_ratio+'%'); $('.'+active_treatment[i]+'.Overall_Survival').html(servive_ratio); $('tr.'+active_treatment[i]+' td.Additional_Benefit').html(benefit+'%'); $('.'+active_treatment[i]+'.Additional_Benefit').html(benefit); }; var add_choices = []; for(var i = 1;i < this.length; i++){ if(i != index){ add_choices.push(this[i]); var add_choices_transform = []; for(var j = 0;j= 2) add_choices_str += ('以及'+add_choices_transform[add_choices_transform.length-1]) else add_choices_str = add_choices_transform[0]; $('.'+active_treatment[i]+'.choices').html(add_choices_str); } }; }; $('tr.'+arguments[0]+' td.Overall_Survival').html('-'); $('tr.'+arguments[0]+' td.Additional_Benefit').html('-'); $('tr.'+arguments[0]).css('display','none'); $('tr.'+arguments[0]).removeClass('tr_show'); $('a.'+arguments[0]).eq(0).parent().remove(); lpv_real = lpv_real.remove_item_from_array(lpv_real[index]); servive_ratio_arr = servive_ratio_arr.remove_item_from_array(servive_ratio_arr[index]); if(this.length == 2){ $('.addition').css('display','none'); $('#result_text_content .extra-text').css('display','none'); }; return Array.prototype.remove_item_from_array.apply(this, arguments); }else{ return Array.prototype.remove_item_from_array.apply(this, arguments); }; }; for(var i = 0;iinput').attr('value',0); $(this).parent().find('>input').eq(index).attr('value',1); $(this).parent().find('>button').removeClass('active'); $(this).parent().removeClass('cancertable_empty'); if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; }catch(e){}; $(this).addClass('active'); if(!click_flag){ if(!active_treatment.includes($(this).parent().attr('id'))){ click_flag = true; active_treatment.push($(this).parent().attr('id')); click_flag = false; }; } }); $('#'+treatmeny_method[i]+' .cancer_table_btn').eq(0).off('click'); $('#'+treatmeny_method[i]+' .cancer_table_btn').eq(0).click(function(){ var index = $(this).index()/2; try{ $(this).parent().find('>input').attr('value',0); $(this).parent().find('>input').eq(index).attr('value',1); $(this).parent().find('>button').removeClass('active'); $(this).parent().removeClass('cancertable_empty'); if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; }catch(e){}; $(this).addClass('active'); if(!click_flag){ if(active_treatment.includes($(this).parent().attr('id'))){ click_flag = true; active_treatment = active_treatment.remove_item_from_array($(this).parent().attr('id')); click_flag = false; }; }; }); }; $('#current_year').change(function(){ year = $(this).attr('value'); $('.surgery_year').html(year); $('.cancer_years').removeClass('active'); $('#result_text_content .cancer_years').eq($(this).attr("index")).addClass('active'); $('#result_table_content .cancer_years').eq($(this).attr("index")).addClass('active'); var obj = {"servive_ratio_arr":servive_ratio_arr,"active_treatment":active_treatment,"lpv_real":lpv_real,"lpv_calc":lpv_calc,"year":year} calculate_and_change_result_value(obj); servive_ratio_arr = obj.servive_ratio_arr; active_treatment = obj.active_treatment; lpv_real = obj.lpv_real; lpv_calc = obj.lpv_calc; year = obj.year; }); $('#cancer_table .cancer_form_field').off('change').on('change',function(){ var obj = {"servive_ratio_arr":servive_ratio_arr,"active_treatment":active_treatment,"lpv_real":lpv_real,"lpv_calc":lpv_calc,"year":year} after_submit_change_func(obj); servive_ratio_arr = obj.servive_ratio_arr; active_treatment = obj.active_treatment; lpv_real = obj.lpv_real; lpv_calc = obj.lpv_calc; year = obj.year; }); $('#cancer_table .cancer_form_field').click(function(){ $(this).change(); }); $('select.select_num').off('click').on('click',function(){ $(this).change(); var obj = {"servive_ratio_arr":servive_ratio_arr,"active_treatment":active_treatment,"lpv_real":lpv_real,"lpv_calc":lpv_calc,"year":year} after_submit_change_func(obj); servive_ratio_arr = obj.servive_ratio_arr; active_treatment = obj.active_treatment; lpv_real = obj.lpv_real; lpv_calc = obj.lpv_calc; year = obj.year; }); $('.num_only').on('input', function() { if( Number($(this).val()) < $(this).data('range')[0] || $(this).val() == "" || (Number($(this).val()) > $(this).data('range')[1] && $(this).data('range')[1] != undefined) ){ $(this).css('color','#f24a69'); $(this).addClass('cancertable_empty'); }else{ $(this).css('color','#333'); $(this).removeClass('cancertable_empty'); if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; var obj = {"servive_ratio_arr":servive_ratio_arr,"active_treatment":active_treatment,"lpv_real":lpv_real,"lpv_calc":lpv_calc,"year":year}; after_submit_change_func(obj); servive_ratio_arr = obj.servive_ratio_arr; active_treatment = obj.active_treatment; lpv_real = obj.lpv_real; lpv_calc = obj.lpv_calc; year = obj.year; }; }); }); }; }; function calculate_and_change_result_value(obj){ obj.servive_ratio_arr = []; for(var i = 0;i(original_value+new_lpv-old_lpv)); calculate_and_change_result_value(obj); }; }; function calculate_first_lpv(result_json){ result = {} result['age1'] = Math.pow((Number(result_json['age'])/100),0.5); result['age2'] = Math.pow((Number(result_json['age'])/100),0.5)*Math.log(result_json['age']/100); result['size1'] = Math.log(Number(result_json['size'])/10); if(Number(result_json['lymph_nodes_examined']) != 0) try{result['ratio'] = Number(result_json['lymph_nodes_positive'])/Number(result_json['lymph_nodes_examined'])}catch(e){result['ratio'] = 0} else result['ratio'] = 0 if(result['ratio'] > 1) result['ratio'] = 1 result['nposit'] = Math.pow(((Number(result['ratio'])+0.1)/0.1),0.5); var T = ''; if(Number(result_json['tumor_direct_extension']) != 1){ if(Number(result_json['size']) <= 20) T = 'T1'; else if(Number(result_json['size']) > 20 && Number(result_json['size']) <= 50) T = 'T2'; else if(Number(result_json['size']) > 50) T = 'T3'; }else{ T = 'T4'; }; var N = ''; if(Number(result_json['lymph_nodes_positive']) == 0) N = 'N0'; else if(Number(result_json['lymph_nodes_positive']) >= 1 && Number(result_json['lymph_nodes_positive']) <= 3 && Number(result_json['micrometastasis']) != 1) N = 'N1'; else if(Number(result_json['lymph_nodes_positive']) >= 1 && Number(result_json['lymph_nodes_positive']) <= 3 && Number(result_json['micrometastasis']) == 1) N = 'N1mi'; else if(Number(result_json['lymph_nodes_positive']) >= 4 && Number(result_json['lymph_nodes_positive']) <= 9) N = 'N2'; else if(Number(result_json['lymph_nodes_positive']) >= 10) N = 'N3'; M = ''; if(Number(result_json['Distant_Metastasis']) != 1) M = 'M0'; else M = 'M1'; if(Number(M == 'M0')) if(T == 'T1' && (N == 'N0' || N == 'N1mi')) result['pstage'] = 1; else if(((T == 'T2' || T == 'T3') && (N == 'N0')) || ((T == 'T1' || T == 'T2') && (N == 'N1'))) result['pstage'] = 2; else if((T == 'T4' && N == 'N0') || ((T == 'T3' || T == 'T4') && N == 'N1') || (N == 'N2' || N == 'N3')) result['pstage'] = 3; else result['pstage'] = 4 if((Number(result_json['ER_status']) != 2 || Number(result_json['PR_status']) != 2) && (Number(result_json['HER2_status']) != 1)) result['subtype'] = 1; else if(Number(result_json['ER_status']) == 2 && Number(result_json['PR_status']) == 2 && (Number(result_json['HER2_status']) == 1)) result['subtype'] = 2; else if(Number(result_json['ER_status']) == 2 && Number(result_json['PR_status']) == 2 && (Number(result_json['HER2_status']) != 1)) result['subtype'] = 3; if( Number(result_json['grade']) == 2 || Number(result_json['grade']) == 4) result['grade_2'] = 1; else result['grade_2'] = 0; if( Number(result_json['grade']) == 3) result['grade_3'] = 1; else result['grade_3'] = 0; if( Number(result['subtype']) == 2) result['subtype_HER2'] = 1; else result['subtype_HER2'] = 0; if( Number(result['subtype']) == 3) result['subtype_triple'] = 1; else result['subtype_triple'] = 0; if( Number(result['pstage']) == 2) result['pstage_2'] = 1; else result['pstage_2'] = 0; if( Number(result['pstage']) == 3) result['pstage_3'] = 1; else result['pstage_3'] = 0; if( Number(result['pstage']) == 4) result['pstage_4'] = 1; else result['pstage_4'] = 0; if( Number(result_json['lvi']) == 1) result['lvi_yes'] = 1; else result['lvi_yes'] = 0; try{ result['lpv'] = ((result['age1']-0.7276655)*(-10.87)+(result['age2']+0.4540707)*8.968+(result['size1']-0.643632)*0.7678+(result['nposit']-1.346932)*0.5339+ result['grade_2']*0.4795+result['grade_3']*0.818+result['subtype_HER2']*0.1806+result['subtype_triple']*0.6457+result['pstage_2']*0.5311+ result['pstage_3']*1.134+result['pstage_4']*2.172+result['lvi_yes']*0.3321-0.04); }catch(e){result['lpv'] = "error"}; return result; }; function submit_fcn(){ var post_json = get_input_data(); if(post_json != null){ post_json['locale'] = I18n.locale; var result = $.post("/cancerpredictResult",{"data":post_json}); result.done(function(){ console.log(result.responseJSON); set_result(result); window.location.hash = ''; window.location.hash = '#cancer_predict_result_block'; }); }; }; $('#cancer_table_submit').click(function(){ submit_fcn(); }); for(var i = 0;i < $('.result_tab').length;i++){ $('.result_tab').eq(i).attr('index',i) }; for(var i = 0;i < $('.result_content').length;i++){ $('.result_content').eq(i).attr('index',i) }; $('.result_tab').click(function(){ var index = $(this).attr('index'); $('.result_tab').removeClass('active'); $(this).addClass('active'); $('.result_content').css('display','none'); $('.result_content[index="'+index+'"]').css('display','block'); }) $('.num_only').keypress(function(event){ return event.keyCode>=48&&event.keyCode<=57||(this.value.indexOf('.')<0?event.keyCode==46:false); }); $('.float_num').off('keyup').on('keyup',function(){ this.value = this.value.replace(/[^\d.]/g,''); }); $('.num_only').blur(function() { if( Number($(this).val()) < $(this).data('range')[0] || $(this).val() == "" || (Number($(this).val()) > $(this).data('range')[1] && $(this).data('range')[1] != undefined) ){ $(this).css('color','#f24a69'); $(this).addClass('cancertable_empty'); }else{ $(this).css('color','#333'); $(this).removeClass('cancertable_empty'); if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; }; }); $('select.select_num').off('click').on('click',function(){ $(this).change(); }); $('select.select_num').change(function(){ if(this.selectedIndex != 0){ $(this).siblings('input.num_only').val($(this).find('option').eq(this.selectedIndex).text()); $(this).siblings('input.num_only').removeClass('cancertable_empty'); $(this).siblings('input.num_only').css('color','#333'); }else{ $(this).siblings('input.num_only').addClass('cancertable_empty'); $(this).siblings('input.num_only').css('color','rgb(242, 74, 105)'); $(this).siblings('input.num_only').val($(this).val()); } $(this).siblings('input.num_only_value').val($(this).val()); if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; }); $('input#lymph_nodes_examined').siblings('select.select_num').off('change').on('change',function(){ var range = $('input#lymph_nodes_positive').data('range'); range[1] = Number($(this).val()); $('input#lymph_nodes_positive').data('range_new', range); if(this.selectedIndex != 0){ $(this).siblings('input.num_only').val($(this).find('option').eq(this.selectedIndex).text()); $(this).siblings('input.num_only').removeClass('cancertable_empty'); $(this).siblings('input.num_only').css('color','#333'); }else{ $(this).siblings('input.num_only').addClass('cancertable_empty'); $(this).siblings('input.num_only').css('color','rgb(242, 74, 105)'); $(this).siblings('input.num_only').val($(this).val()); } $(this).siblings('input.num_only_value').val($(this).val()); if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; $(this).siblings('.num_only_value').val($(this).val()); if( Number($('input#lymph_nodes_positive').siblings('.num_only_value').val()) <= Number($(this).val()) ){ $('input#lymph_nodes_positive').css('color','#333'); $('input#lymph_nodes_positive').removeClass('cancertable_empty'); }; if( Number($(this).val()) < $(this).siblings('.num_only').data('range_new')[0] || $(this).val() == "" || (Number($(this).val()) > $(this).siblings('.num_only').data('range_new')[1] && $(this).siblings('.num_only').data('range_new')[1] != undefined) ){ $(this).siblings('.num_only').css('color','#f24a69'); $(this).siblings('.num_only').addClass('cancertable_empty'); }else{ $(this).siblings('.num_only').css('color','#333'); $(this).siblings('.num_only').removeClass('cancertable_empty'); if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; }; }); $('input#lymph_nodes_positive').siblings('select.select_num').off('change').on('change',function(){ var range = $('input#lymph_nodes_examined').data('range'); range[0] = Number($(this).val()); $('input#lymph_nodes_examined').data('range_new', range); if(this.selectedIndex != 0){ $(this).siblings('input.num_only').val($(this).find('option').eq(this.selectedIndex).text()); $(this).siblings('input.num_only').removeClass('cancertable_empty'); $(this).siblings('input.num_only').css('color','#333'); }else{ $(this).siblings('input.num_only').addClass('cancertable_empty'); $(this).siblings('input.num_only').css('color','rgb(242, 74, 105)'); $(this).siblings('input.num_only').val($(this).val()); } $(this).siblings('input.num_only_value').val($(this).val()); if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; $(this).siblings('.num_only_value').val($(this).val()); if( Number($('input#lymph_nodes_examined').siblings('.num_only_value').val()) >= Number($(this).val()) ){ $('input#lymph_nodes_examined').css('color','#333'); $('input#lymph_nodes_examined').removeClass('cancertable_empty'); }; if( Number($(this).val()) < $(this).siblings('.num_only').data('range_new')[0] || $(this).val() == "" || (Number($(this).val()) > $(this).siblings('.num_only').data('range_new')[1] && $(this).siblings('.num_only').data('range_new')[1] != undefined) ){ $(this).siblings('.num_only').css('color','#f24a69'); $(this).siblings('.num_only').addClass('cancertable_empty'); }else{ $(this).siblings('.num_only').css('color','#333'); $(this).siblings('.num_only').removeClass('cancertable_empty'); if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; }; }); $('select.select_num').blur(function() { if( Number($(this).siblings('.num_only_value').val()) < $(this).siblings('.num_only').data('range')[0] || $(this).siblings('.num_only_value').val() == "" || (Number($(this).siblings('.num_only_value').val()) > $(this).siblings('.num_only').data('range')[1] && $(this).siblings('.num_only').data('range')[1] != undefined) ){ $(this).siblings('.num_only').css('color','#f24a69'); $(this).siblings('.num_only').addClass('cancertable_empty'); }else{ $(this).siblings('.num_only').css('color','#333'); $(this).siblings('.num_only').removeClass('cancertable_empty'); if($('.cancertable_empty').length == 0){ $('#danger_texts').remove(); }; }; }); if($(window).width() < 768) $('#cancer_predict_result').attr('style',''); }); $(window).resize(function(){ if($(window).width() > 768){ if($('.cancer_table_right_result').length != 0) $('#cancer_predict_result').css('float','right'); }else{ $('#cancer_predict_result').attr('style',''); }; if(I18n.locale == 'en'){ var window_width = $(window).width(); if(window_width < 520){ $('#cancer_table .cencer_table_name').css('max-width',''); }else if(window_width < 768){ $('#cancer_table .cencer_table_name').css({'max-width':'','width':'11em'}); }else if(window_width < 860){ $('#cancer_table .cencer_table_name').css('max-width','30%'); }else if(window_width < 1130){ $('#cancer_table .cencer_table_name').css('max-width','33%'); }else{ $('#cancer_table .cencer_table_name').css('max-width','39%'); }; }; });