856 lines
38 KiB
JavaScript
856 lines
38 KiB
JavaScript
Array.prototype.get_nearest_value = function(goal){
|
||
var nearest_value = this.reduce(function(prev, curr) {
|
||
return (Math.abs(curr - goal) < Math.abs(prev - goal) ? curr : prev);
|
||
});
|
||
return nearest_value;
|
||
}
|
||
function change_object_variables(obj1,obj2,operator="-",target="new"){
|
||
var obj_new = {};
|
||
var obj_keys = Object.keys(obj1);
|
||
obj_keys.forEach(function(k){
|
||
if(obj2[k] == undefined){
|
||
if( target == "new"){
|
||
obj_new[k] = obj1[k];
|
||
}
|
||
}else{
|
||
if(operator == "-"){
|
||
if( target == "new"){
|
||
obj_new[k] = obj1[k] - obj2[k];
|
||
}else{
|
||
obj1[k] = obj1[k] - obj2[k];
|
||
}
|
||
}else if(operator == "+"){
|
||
if( target == "new"){
|
||
obj_new[k] = obj1[k] + obj2[k];
|
||
}else{
|
||
obj1[k] = obj1[k] + obj2[k];
|
||
}
|
||
}
|
||
}
|
||
})
|
||
if( target == "new"){
|
||
return obj_new;
|
||
}else{
|
||
return obj1;
|
||
}
|
||
}
|
||
$(document).ready(function(){
|
||
var head_data = $.post("/hnc_cancer_predictResult",{"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%');
|
||
};
|
||
};
|
||
function round(num,Digit=0){
|
||
return Math.round(Number(num)*(10**Digit))/(10**Digit);
|
||
};
|
||
head_data.done(function(){
|
||
if(head_data.responseJSON['hnc_head_images'] != ''){
|
||
$('.header-nav').html(head_data.responseJSON['hnc_head_images']);
|
||
}
|
||
if(head_data.responseJSON['title'] != ''){
|
||
$('.navbar-brand').html(head_data.responseJSON['title']);
|
||
}
|
||
data['danger_texts'] = head_data.responseJSON['danger_texts'];
|
||
$('head title').text(head_data.responseJSON['page_title'])
|
||
});
|
||
var mapping_data = $.post("/hnc_cancer_predictResult",{"get_mapping_data_from_csv":1,locale:I18n.locale});
|
||
mapping_data.done(function(){
|
||
// $('.header-nav').html(hnc_head_images.responseJSON['hnc_head_images']);
|
||
// $('.navbar-brand').html(hnc_head_images.responseJSON['title'])
|
||
window.mapping_data_from_csv = mapping_data.responseJSON['mapping_data_from_csv'];
|
||
});
|
||
Array.prototype.remove_item_from_array = function(){
|
||
var result_array = this;
|
||
for(var i=0;i<arguments.length;i++){
|
||
if(Array.isArray(arguments[i])){
|
||
for(var j=0;j<arguments.length;j++){
|
||
var index = result_array.indexOf(arguments[i][j]);
|
||
if(index == -1)
|
||
continue;
|
||
else{
|
||
result_array = result_array.slice(0, index).concat(result_array.slice(index + 1, result_array.length));
|
||
}
|
||
}
|
||
}else{
|
||
var index = result_array.indexOf(arguments[i]);
|
||
if(index == -1)
|
||
continue;
|
||
else{
|
||
result_array = result_array.slice(0, index).concat(result_array.slice(index + 1, result_array.length));
|
||
};
|
||
};
|
||
};
|
||
result_array.push = this.push;
|
||
result_array.remove_item_from_array = this.remove_item_from_array;
|
||
return result_array;
|
||
};
|
||
$('input#lymph_nodes_examined').data('range_new' , $('input#lymph_nodes_examined').data('range'));
|
||
$('input#lymph_nodes_positive').data('range_new' , $('input#lymph_nodes_positive').data('range'));
|
||
$('.num_only').on('input', function() {
|
||
$(this).siblings('.num_only_value').val($(this).val());
|
||
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();
|
||
};
|
||
};
|
||
});
|
||
$('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("<div class='modal-dialog'><div class='modal-content'><div class='modal-header'><button type='button' aria-hidden='true' class='close'>×</button><h4 class='modal-title'>"+modal_head+"</h4>"+
|
||
"</div><div class='modal-body'>"+modal_body+"</div><div class='modal-footer'><button type='button' class='btn btn-default'>Close</button></div></div></div>")
|
||
$('#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');
|
||
$('#hnc_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('<a id="danger_texts" style="color:red;">'+data['danger_texts']+'</a>') : 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] = Number($('#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','');
|
||
};
|
||
/*disable_condition start*/
|
||
/*disable_condition end*/
|
||
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 treatment_method = result.responseJSON.treatment_method;
|
||
var treatment_method_active_indices = result.responseJSON.treatment_method_active_indices;
|
||
$('tr.'+treatment_method[0]).addClass('tr_show');
|
||
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]+'%');
|
||
$('span.'+active_treatment[0]+'.Overall_Survival').html(Math.round(servive_ratio_arr[0]));
|
||
$('#hnc_cancer_predict_result_block').css('display','block');
|
||
var lpv_real = [result.responseJSON['lpv_variable']];
|
||
var lpv = /*therapy_lpv start*/[0, 0.15613, -0.34129];/*therapy_lpv end*/;
|
||
var lpv_dict={};
|
||
var lpv_calc=/*lpv_calc_formula_start*/{"1":"Math.exp(-0.03639284)**( Math.exp(lpv_current) )","3":"Math.exp(-0.08738490)**( Math.exp(lpv_current) )","5":"Math.exp(-0.10683094)**( Math.exp(lpv_current) )"};/*lpv_calc_formula_end*/
|
||
active_treatment.push = function() {
|
||
if(arguments.length == 1){
|
||
var year = $('#current_year').attr('value');
|
||
console.log(lpv_real);
|
||
console.log(lpv_dict[arguments[0]])
|
||
var lpv_current = change_object_variables(lpv_real[lpv_real.length-1],{"lpv": lpv_dict[arguments[0]]},'+');
|
||
lpv_real.push(lpv_current);
|
||
lpv_current = lpv_current['lpv'];
|
||
var servive_ratio = round(eval(lpv_calc[year])*100,2);
|
||
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(round(benefit,2)+'%');
|
||
$('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<add_choices.length;i++){
|
||
add_choices_transform.push($('[for="'+add_choices[i]+'"]').html())
|
||
};
|
||
var add_choices_str = (I18n.locale == 'en' ? add_choices_transform.slice(0,add_choices_transform.length-1).join(', ') : add_choices_transform.slice(0,add_choices_transform.length-1).join('、'));
|
||
if(add_choices_transform.length >= 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}}','</span><span class="'+arguments[0]+' choices">'+add_choices_str+'</span><span>');
|
||
extra_therapy_texts = extra_therapy_texts.replace('{{survival_num}}','</span><span class="'+arguments[0]+' Overall_Survival">'+Math.round(servive_ratio)+'</span><span>');
|
||
extra_therapy_texts = extra_therapy_texts.replace('{{surgery_year}}','</span><span class="surgery_year">'+year+'</span><span>');
|
||
extra_therapy_texts = extra_therapy_texts.replace('{{Additional_Benefit}}','</span><span class="'+arguments[0]+' Additional_Benefit">'+Math.round(benefit)+'</span><span>');
|
||
var new_text = '<p class="texts_show"><span>';
|
||
new_text += (extra_therapy_texts+'</span></p>');
|
||
$('#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++){
|
||
change_object_variables(lpv_real[i] , {"lpv": lpv_dict[arguments[0]]} , '-' , 'self');
|
||
var lpv_current = lpv_real[i];
|
||
lpv_current = lpv_current['lpv'];
|
||
var servive_ratio = round(eval(lpv_calc[year])*100,2);
|
||
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(Math.round(servive_ratio));
|
||
$('tr.'+active_treatment[i]+' td.Additional_Benefit').html(round(benefit,2)+'%');
|
||
$('.'+active_treatment[i]+'.Additional_Benefit').html(Math.round(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<add_choices.length;j++){
|
||
add_choices_transform.push($('[for="'+add_choices[j]+'"]').html())
|
||
};
|
||
var add_choices_str = (I18n.locale == 'en' ? add_choices_transform.slice(0,add_choices_transform.length-1).join(', ') : add_choices_transform.slice(0,add_choices_transform.length-1).join('、'));
|
||
if(add_choices_transform.length >= 2)
|
||
add_choices_str += ((I18n.locale == 'en' ? ', and ': '以及')+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');
|
||
$('span.'+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;i<treatment_method.length;i++){
|
||
lpv_dict[treatment_method[i]] = lpv[i];
|
||
var click_flag=false;
|
||
$('#'+treatment_method[i]+' .cancer_table_btn').off('click').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;
|
||
};
|
||
};
|
||
});
|
||
$('#'+treatment_method[i]+' .cancer_table_btn').eq(treatment_method_active_indices[i]).off('click').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.push($(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 after_submit_change_func(obj){
|
||
var post_json = get_input_data();
|
||
if(post_json != null){
|
||
var new_lpv = calculate_first_lpv(post_json)['lpv_variable'];
|
||
var old_lpv = obj.lpv_real[0];
|
||
obj.lpv_real = obj.lpv_real.map(original_value=>(change_object_variables(original_value,change_object_variables(new_lpv,old_lpv,'-'),'+')));
|
||
calculate_and_change_result_value(obj);
|
||
};
|
||
};
|
||
/* auto add start */
|
||
function calculate_first_lpv(result_json){
|
||
result = {};
|
||
var map_values , mapping_hash , temp_index ,temp_value , index , closest_value;
|
||
result['age'] = Number(result_json['age']);
|
||
result['size'] = Number(result_json['size']);
|
||
result['height'] = Number(result_json['height']);
|
||
result['weight'] = Number(result_json['weight']);
|
||
result['pstage'] = Number(result_json['pstage']);
|
||
result['sex'] = Number(result_json['sex']);
|
||
result['site'] = Number(result_json['site']);
|
||
result['lymph'] = Number(result_json['lymph']);
|
||
result['drinking'] = Number(result_json['drinking']);
|
||
result['smoking'] = Number(result_json['smoking']);
|
||
result['Chemotherapy'] = Number(result_json['Chemotherapy']);
|
||
result['Radiotherapy'] = Number(result_json['Radiotherapy']);
|
||
|
||
Object.keys(result).forEach(function(k){
|
||
if(Number.isNaN(result[k])){
|
||
result[k] = 0;
|
||
}
|
||
})
|
||
bmi = result["weight"] / ((result["height"] / 100.0) ** 2);
|
||
pstage_2 = (result["pstage"] == 2) ? 1 : 0;
|
||
pstage_3 = (result["pstage"] == 3) ? 1 : 0;
|
||
pstage_4 = (result["pstage"] == 4) ? 1 : 0;
|
||
sex_ind = (result["sex"] == 2) ? 1 : 0;
|
||
site_oralph = (result["site"] == 2) ? 1 : 0;
|
||
site_hyph = (result["site"] == 3) ? 1 : 0;
|
||
site_sal = (result["site"] == 4) ? 1 : 0;
|
||
site_lary = (result["site"] == 5) ? 1 : 0;
|
||
lymph_1 = (result["lymph"] == 2) ? 1 : 0;
|
||
lymph_2 = (result["lymph"] == 3) ? 1 : 0;
|
||
lymph_3 = (result["lymph"] == 4) ? 1 : 0;
|
||
lymph_4 = (result["lymph"] == 5) ? 1 : 0;
|
||
lymph_5 = (result["lymph"] == 6) ? 1 : 0;
|
||
lymph_6 = (result["lymph"] == 7) ? 1 : 0;
|
||
lymph_7 = (result["lymph"] == 8) ? 1 : 0;
|
||
drink_ind = (result["drinking"] == 1) ? 0 : 1;
|
||
smoke_ind = (result["smoking"] == 1) ? 0 : 1;
|
||
chemo = (result["Chemotherapy"] == 2) ? 1 : 0;
|
||
radio = (result["Radiotherapy"] == 2) ? 1 : 0;
|
||
try{
|
||
lpv = ((result["age"]-56.13649)*0.00542+(result["size"]-26.24087)*0.01555+(bmi-24.71561)*(-0.03777)+ pstage_2*0.22023+pstage_3*0.11253+pstage_4*0.74585+ sex_ind*(-0.29218)+site_oralph*0.15131+site_hyph*(-0.18040)+site_sal*(-0.32440)+site_lary*(-0.19674)+ lymph_1*0.69354+lymph_2*0.85665+lymph_3*0.92695+lymph_4*0.93122+lymph_5*0.72533+ lymph_6*1.12371+lymph_7*1.13236+drink_ind*0.12961+smoke_ind*(-0.17848)+chemo*(0.15613)+radio*(-0.34129)
|
||
)
|
||
}catch(e){console.log(e)};
|
||
result['lpv_variable'] = {};
|
||
result['lpv_variable']['lpv'] = lpv;
|
||
result['lpv'] = lpv;
|
||
result['lpv_variable']['lpv'] = result['lpv'];
|
||
return result;
|
||
};
|
||
function calculate_and_change_result_value(obj){
|
||
obj.servive_ratio_arr = [];
|
||
for(var i = 0;i<obj.active_treatment.length;i++){
|
||
var servive_ratio = round(calculate_servive_ratio(obj.year,obj.lpv_real[i])*100,2);
|
||
var benefit = servive_ratio - obj.servive_ratio_arr[obj.servive_ratio_arr.length-1];
|
||
obj.servive_ratio_arr.push(servive_ratio);
|
||
$('tr.'+obj.active_treatment[i]+' td.Overall_Survival').html(servive_ratio+'%');
|
||
$('.'+obj.active_treatment[i]+'.Overall_Survival').html(Math.round(servive_ratio));
|
||
if(i != 0){
|
||
$('tr.'+obj.active_treatment[i]+' td.Additional_Benefit').html(round(benefit,2)+'%');
|
||
$('.'+obj.active_treatment[i]+'.Additional_Benefit').html(Math.round(benefit));
|
||
}
|
||
}
|
||
//$('.'+obj.active_treatment[0]+'.Overall_Survival').html(Math.round(obj.servive_ratio_arr[0]));
|
||
};
|
||
|
||
function calculate_servive_ratio(year,obj){
|
||
var servive_ratio;
|
||
var lpv = obj['lpv'];
|
||
switch(year) {
|
||
case '1':
|
||
servive_ratio = Math.exp(-0.03639284)**( Math.exp(lpv) );
|
||
break;
|
||
case '3':
|
||
servive_ratio = Math.exp(-0.08738490)**( Math.exp(lpv) );
|
||
break;
|
||
case '5':
|
||
servive_ratio = Math.exp(-0.10683094)**( Math.exp(lpv) );
|
||
break;
|
||
default:
|
||
console.log('not found year.');
|
||
}
|
||
return servive_ratio;
|
||
}
|
||
/* auto add end */
|
||
function submit_fcn(){
|
||
var post_json = get_input_data();
|
||
if(post_json != null){
|
||
post_json['locale'] = I18n.locale;
|
||
var result = $.post("/hnc_cancer_predictResult",{"data":post_json});
|
||
result.done(function(){
|
||
console.log(result.responseJSON);
|
||
set_result(result);
|
||
window.location.hash = '';
|
||
window.location.hash = '#hnc_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)
|
||
$('#hnc_cancer_predict_result').attr('style','');
|
||
});
|
||
$(window).resize(function(){
|
||
if($(window).width() > 768){
|
||
if($('.cancer_table_right_result').length != 0)
|
||
$('#hnc_cancer_predict_result').css('float','right');
|
||
}else{
|
||
$('#hnc_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%');
|
||
};
|
||
};
|
||
}); |